/* shared-styles.css – Gemeinsame Styles für alle Shop-Seiten */
:root{--gold:#C4923A;--gold-l:#E8C97A;--cream:#FAF6F0;--warm-gray:#8C8070;--dark:#1A1510;--charcoal:#2E2820;--border:rgba(196,146,58,0.2);--shadow:0 4px 24px rgba(26,21,16,0.08);}
*{margin:0;padding:0;box-sizing:border-box;}
body{font-family:'DM Sans',sans-serif;background:var(--cream);color:var(--dark);overflow-x:hidden;}

.announcement{background:var(--dark);color:var(--gold-l);text-align:center;padding:.55rem;font-size:.8rem;letter-spacing:.08em;}
header{position:sticky;top:0;z-index:100;background:rgba(250,246,240,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);padding:0 2rem;}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:68px;}
.logo{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;letter-spacing:.03em;color:var(--dark);text-decoration:none;}
.logo span{color:var(--gold);}
nav{display:flex;gap:1.75rem;align-items:center;}
nav a{font-size:.82rem;font-weight:400;letter-spacing:.06em;text-transform:uppercase;color:var(--charcoal);text-decoration:none;transition:color .2s;}
nav a:hover,nav a.active{color:var(--gold);}
.cart-btn{background:var(--dark);color:var(--cream);border:none;padding:.5rem 1.2rem;font-family:'DM Sans',sans-serif;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:.5rem;border-radius:2px;}
.cart-btn:hover{background:var(--gold);}
.review-btn{background:var(--gold);color:var(--dark);text-decoration:none;padding:.45rem 1rem;font-family:'DM Sans',sans-serif;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;border-radius:2px;white-space:nowrap;transition:background .2s;display:flex;align-items:center;gap:.3rem;}
.review-btn:hover{background:#b8924a;color:#fff;}
.cart-count{background:var(--gold);color:var(--dark);width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:500;}

.btn-primary{background:var(--dark);color:var(--cream);border:1.5px solid var(--dark);padding:.75rem 2rem;font-family:'DM Sans',sans-serif;font-size:.85rem;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;transition:all .2s;border-radius:2px;text-decoration:none;display:inline-block;}
.btn-primary:hover{background:var(--gold);border-color:var(--gold);}
.btn-outline{background:transparent;color:var(--dark);border:1.5px solid var(--border);padding:.75rem 2rem;font-family:'DM Sans',sans-serif;font-size:.85rem;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;transition:all .2s;border-radius:2px;text-decoration:none;display:inline-block;}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}

.usp-strip{background:var(--dark);padding:2rem 0;}
.usp-inner{max-width:1200px;margin:0 auto;padding:0 2rem;display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;}
.usp-item{text-align:center;}
.usp-item .usp-icon{font-size:1.8rem;margin-bottom:.5rem;display:block;}
.usp-item h4{font-size:.85rem;letter-spacing:.06em;font-weight:500;color:var(--cream);margin-bottom:.25rem;}
.usp-item p{font-size:.78rem;color:rgba(250,246,240,.55);}

.section{max-width:1200px;margin:0 auto;padding:4.5rem 2rem;}
.section-header{display:flex;align-items:baseline;gap:1.5rem;margin-bottom:2.5rem;}
.section-header h2{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;}
.section-header .line{flex:1;height:1px;background:var(--border);}
.section-header .sub{font-size:.8rem;color:var(--warm-gray);font-style:italic;}

.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem;}
.product-card{background:#fff;border:1px solid var(--border);border-radius:4px;overflow:hidden;transition:all .25s;cursor:pointer;}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);}
.product-img{height:220px;overflow:hidden;position:relative;background:#EDE8E0;}
.product-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s ease;}
.product-card:hover .product-img img{transform:scale(1.05);}
.product-img .fallback-icon{position:absolute;inset:0;display:none;align-items:center;justify-content:center;font-size:3.5rem;}
.product-badge{position:absolute;top:.75rem;left:.75rem;background:var(--gold);color:var(--dark);font-size:.7rem;font-weight:500;letter-spacing:.05em;padding:.25rem .6rem;border-radius:2px;text-transform:uppercase;}
.product-badge.neu{background:var(--dark);color:var(--cream);}
.product-info{padding:1rem 1.25rem 1.25rem;}
.product-info .category{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--warm-gray);margin-bottom:.3rem;}
.product-info h3{font-family:'Cormorant Garamond',serif;font-size:1.1rem;font-weight:400;margin-bottom:.75rem;color:var(--dark);}
.product-footer{display:flex;align-items:center;justify-content:space-between;}
.price{font-size:1.05rem;font-weight:500;}
.add-btn{background:var(--dark);color:var(--cream);border:none;padding:.45rem 1rem;font-family:'DM Sans',sans-serif;font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:background .2s;}
.add-btn:hover{background:var(--gold);}
.var-select select{width:100%;border:1px solid var(--border);background:#fff;padding:.42rem .7rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.8rem;outline:none;color:var(--dark);margin-bottom:.6rem;}

footer{background:var(--dark);color:rgba(250,246,240,.7);padding:3.5rem 2rem 2rem;}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,.08);}
.footer-brand .logo{color:var(--cream);display:block;margin-bottom:1rem;}
.footer-brand p{font-size:.85rem;line-height:1.7;max-width:260px;}
.footer-brand .social{display:flex;gap:.75rem;margin-top:1.25rem;}
.social-link{width:34px;height:34px;border:1px solid rgba(255,255,255,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;transition:border-color .2s;text-decoration:none;color:rgba(250,246,240,.7);}
.social-link:hover{border-color:var(--gold);color:var(--gold);}
.footer-col h4{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cream);margin-bottom:1.25rem;font-weight:500;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem;}
.footer-col ul li a{font-size:.85rem;color:rgba(250,246,240,.6);text-decoration:none;transition:color .2s;}
.footer-col ul li a:hover{color:var(--gold);}
.footer-bottom{max-width:1200px;margin:1.5rem auto 0;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;}

.cart-overlay{position:fixed;inset:0;background:rgba(26,21,16,.5);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s;}
.cart-overlay.open{opacity:1;pointer-events:all;}
.cart-panel{position:fixed;right:0;top:0;bottom:0;width:420px;background:var(--cream);transform:translateX(100%);transition:transform .35s ease;display:flex;flex-direction:column;border-left:1px solid var(--border);}
.cart-overlay.open .cart-panel{transform:translateX(0);}
.cart-header{padding:1.5rem 1.75rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);}
.cart-header h3{font-family:'Cormorant Garamond',serif;font-size:1.4rem;font-weight:400;}
.close-btn{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--warm-gray);}
.cart-items{flex:1;overflow-y:auto;padding:1.25rem 1.75rem;}
.cart-empty{text-align:center;padding:3rem 1rem;color:var(--warm-gray);font-size:.9rem;}
.cart-empty span{font-size:3rem;display:block;margin-bottom:1rem;}
.cart-item{display:flex;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border);align-items:center;}
.cart-item-img{width:60px;height:60px;background:#EDE8E0;border-radius:3px;overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.cart-item-img img{width:100%;height:100%;object-fit:cover;}
.cart-item-info{flex:1;}
.cart-item-info .name{font-family:'Cormorant Garamond',serif;font-size:1rem;margin-bottom:.25rem;}
.cart-item-info .price-small{font-size:.85rem;color:var(--warm-gray);}
.remove-item{background:none;border:none;cursor:pointer;color:var(--warm-gray);font-size:1rem;transition:color .2s;}
.remove-item:hover{color:#c0392b;}
.cart-footer{padding:1.5rem 1.75rem;border-top:1px solid var(--border);}
.cart-total{display:flex;justify-content:space-between;font-size:1rem;font-weight:500;margin-bottom:1.25rem;}
.checkout-btn{width:100%;background:var(--dark);color:var(--cream);border:none;padding:1rem;font-family:'DM Sans',sans-serif;font-size:.85rem;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;border-radius:2px;transition:background .2s;}
.checkout-btn:hover{background:var(--gold);}
#paypal-button-container{margin-top:.75rem;}
#paypal-button-container.hidden{display:none;}
.cart-note{font-size:.75rem;color:var(--warm-gray);text-align:center;margin-top:.6rem;}
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(100px);background:var(--dark);color:var(--cream);padding:.8rem 1.5rem;border-radius:3px;font-size:.85rem;z-index:300;transition:transform .3s ease;}
.toast.show{transform:translateX(-50%) translateY(0);}

.newsletter{background:var(--charcoal);padding:4rem 2rem;text-align:center;}
.newsletter h2{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:300;color:var(--cream);margin-bottom:.75rem;}
.newsletter p{color:rgba(250,246,240,.6);font-size:.9rem;margin-bottom:2rem;}
.newsletter-form{display:flex;max-width:460px;margin:0 auto;border:1px solid rgba(196,146,58,.4);border-radius:3px;overflow:hidden;}
.newsletter-form input{flex:1;background:transparent;border:none;outline:none;padding:.85rem 1.25rem;color:var(--cream);font-family:'DM Sans',sans-serif;font-size:.9rem;}
.newsletter-form input::placeholder{color:rgba(250,246,240,.4);}
.newsletter-form button{background:var(--gold);color:var(--dark);border:none;padding:.85rem 1.5rem;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:.8rem;letter-spacing:.07em;text-transform:uppercase;font-weight:500;transition:background .2s;}
.newsletter-form button:hover{background:var(--gold-l);}

.page-hero{background:var(--dark);padding:4rem 2rem;text-align:center;}
.page-hero h1{font-family:'Cormorant Garamond',serif;font-size:clamp(2.2rem,4vw,3.2rem);font-weight:300;color:var(--cream);margin-bottom:.75rem;}
.page-hero h1 em{font-style:italic;color:var(--gold-l);}
.page-hero p{color:rgba(250,246,240,.65);font-size:.95rem;max-width:520px;margin:0 auto 1.5rem;}
.breadcrumb{font-size:.78rem;color:rgba(250,246,240,.4);}
.breadcrumb a{color:rgba(250,246,240,.4);text-decoration:none;}
.breadcrumb a:hover{color:var(--gold-l);}

.subcat-filter{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem;}
.subcat-btn{border:1px solid var(--border);padding:.38rem .9rem;border-radius:20px;font-size:.78rem;letter-spacing:.05em;background:transparent;cursor:pointer;color:var(--warm-gray);transition:all .2s;font-family:'DM Sans',sans-serif;}
.subcat-btn.on,.subcat-btn:hover{background:var(--dark);color:var(--cream);border-color:var(--dark);}

@media(max-width:900px){
  .usp-inner{grid-template-columns:1fr 1fr;}
  .footer-inner{grid-template-columns:1fr 1fr;}
  nav{display:none;}
  .cart-panel{width:100%;}
  .review-btn{font-size:.7rem;padding:.4rem .7rem;}
}

.product-subtitle{font-size:.8rem;color:var(--warm-gray);font-style:italic;margin:-.1rem 0 .4rem;line-height:1.45;}

/* ══ WIDERRUF OVERLAY ══ */
.wid-ov{position:fixed;inset:0;background:rgba(26,21,16,.6);z-index:500;display:none;align-items:flex-start;justify-content:center;padding:1.5rem 1rem;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;backdrop-filter:blur(3px);}
.wid-ov.open{display:flex;}
.wid-box{background:#FAF6F0;border-radius:6px;width:100%;max-width:700px;box-shadow:0 8px 48px rgba(26,21,16,.22);margin:auto;display:flex;flex-direction:column;}
.wid-head{padding:1.1rem 1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;background:#fff;border-radius:6px 6px 0 0;position:sticky;top:0;z-index:1;}
.wid-head h2{font-family:'Cormorant Garamond',serif;font-size:1.25rem;font-weight:300;color:var(--dark);}
.wid-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--warm-gray);padding:.2rem .5rem;border-radius:3px;transition:background .15s;}
.wid-close:hover{background:#EDE8E0;}
.wid-info{padding:.85rem 1.5rem;background:#FFF8EC;border-bottom:1px solid rgba(196,146,58,.2);font-size:.8rem;color:#8a5c0a;line-height:1.6;}
.wid-body{padding:1.5rem;display:flex;flex-direction:column;gap:.85rem;}
.wid-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
.wid-field{display:flex;flex-direction:column;gap:.28rem;}
.wid-field.full{grid-column:1/-1;}
.wid-field label{font-size:.68rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--warm-gray);}
.wid-field label .req{color:var(--gold);}
.wid-field input,.wid-field select,.wid-field textarea{border:1px solid var(--border);background:#FAFAF6;padding:.55rem .75rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.85rem;outline:none;color:var(--dark);transition:border-color .15s;width:100%;box-sizing:border-box;}
.wid-field input:focus,.wid-field select:focus,.wid-field textarea:focus{border-color:var(--gold);background:#fff;}
.wid-field textarea{resize:vertical;min-height:70px;}
.wid-section-title{font-size:.68rem;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--warm-gray);padding-bottom:.5rem;border-bottom:1px solid var(--border);grid-column:1/-1;}
.wid-foot{padding:1rem 1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:.65rem;background:#FAFAF6;border-radius:0 0 6px 6px;}
.wid-cancel{border:1px solid var(--border);background:transparent;padding:.55rem 1.1rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.8rem;cursor:pointer;color:var(--warm-gray);transition:all .15s;}
.wid-cancel:hover{border-color:var(--dark);color:var(--dark);}
.wid-submit{background:var(--dark);color:var(--cream);border:1px solid var(--dark);padding:.55rem 1.25rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.8rem;font-weight:500;letter-spacing:.04em;cursor:pointer;transition:all .2s;}
.wid-submit:hover{background:var(--gold);border-color:var(--gold);}
.wid-submit:disabled{opacity:.5;cursor:not-allowed;}
.wid-success{padding:3rem 2rem;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.75rem;}
.wid-success .si{font-size:3rem;}
.wid-success h3{font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:300;}
.wid-success p{font-size:.85rem;color:var(--warm-gray);line-height:1.7;max-width:380px;}
.wid-ref{background:#FFF8EC;border:1px solid rgba(196,146,58,.3);border-radius:3px;padding:.5rem 1rem;font-size:.82rem;color:#8a5c0a;font-weight:500;}
.btn-widerruf:hover{border-color:rgba(250,246,240,.6);color:#fff;}
@media(max-width:600px){
  .wid-ov{padding:.5rem 0;}
  .wid-box{border-radius:10px 10px 0 0;margin-top:auto;}
  .wid-grid{grid-template-columns:1fr;}
  .wid-field.full{grid-column:auto;}
  .wid-body{padding:1rem;}
  .wid-head{padding:.85rem 1rem;}
  .wid-foot{flex-direction:column;}
  .wid-foot button{width:100%;}
}

/* ══ PREISRECHNER OVERLAY (3d-druck.html) ══ */
.calc-ov{position:fixed;inset:0;background:rgba(26,21,16,.65);z-index:400;display:none;align-items:center;justify-content:center;padding:1.5rem 1rem;overflow-y:auto;backdrop-filter:blur(3px);}
.calc-ov.open{display:flex;}
.calc-box{background:#FAF6F0;border-radius:6px;width:100%;max-width:520px;box-shadow:0 8px 48px rgba(26,21,16,.25);display:flex;flex-direction:column;margin:auto;}
.calc-box-head{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;border-bottom:1px solid var(--border);background:#fff;border-radius:6px 6px 0 0;}
.calc-box-head-inner{display:flex;align-items:center;gap:.75rem;}
.calc-box-title h2{font-family:'Cormorant Garamond',serif;font-size:1.2rem;font-weight:300;color:var(--dark);}
.calc-box-title p{font-size:.72rem;color:var(--warm-gray);margin-top:.1rem;}
.calc-box-close{background:none;border:none;font-size:1.2rem;cursor:pointer;color:var(--warm-gray);padding:.25rem .5rem;border-radius:3px;transition:background .15s;}
.calc-box-close:hover{background:#EDE8E0;}
.calc-box-body{padding:1.25rem;display:flex;flex-direction:column;gap:1rem;}
.calc-mat-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;}
.calc-mat-btn{border:1px solid var(--border);background:#FAFAF6;padding:.6rem .75rem;border-radius:4px;text-align:left;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .15s;}
.calc-mat-btn:hover{border-color:var(--gold);background:#FFF8EC;}
.calc-mat-btn.active{border-color:var(--gold);background:#FFF3DC;}
.calc-mat-name{display:block;font-size:.82rem;font-weight:500;color:var(--dark);}
.calc-mat-hint{display:block;font-size:.68rem;color:var(--warm-gray);margin-top:.15rem;}
.calc-result{background:#F7F4EF;border-radius:4px;padding:1rem 1.1rem;display:flex;flex-direction:column;gap:.35rem;}
.calc-result .calc-price-main{font-family:'Cormorant Garamond',serif;font-size:1.6rem;font-weight:300;color:var(--dark);}
.calc-result .calc-breakdown{font-size:.75rem;color:var(--warm-gray);display:flex;flex-direction:column;gap:.2rem;}
.calc-box-foot{padding:.85rem 1.25rem;border-top:1px solid var(--border);background:#FAFAF6;border-radius:0 0 6px 6px;display:flex;align-items:center;justify-content:space-between;font-size:.78rem;color:var(--warm-gray);}
.calc-box-foot-link{color:var(--gold);text-decoration:none;font-size:.75rem;}
.calc-box-foot-link:hover{text-decoration:underline;}
.calc-field-label{font-size:.68rem;font-weight:500;letter-spacing:.07em;text-transform:uppercase;color:var(--warm-gray);margin-bottom:.3rem;}
.calc-input-row{display:flex;align-items:center;gap:.5rem;}
.calc-input-row input{border:1px solid var(--border);background:#fff;padding:.55rem .75rem;border-radius:3px;font-family:'DM Sans',sans-serif;font-size:.9rem;outline:none;color:var(--dark);transition:border-color .15s;width:100%;}
.calc-input-row input:focus{border-color:var(--gold);}
.calc-input-row .unit{font-size:.82rem;color:var(--warm-gray);white-space:nowrap;}

/* ══ WIDERRUF BUTTON – passend zu Anfrage/Preisrechner Buttons ══ */
.btn-widerruf{background:transparent;color:rgba(250,246,240,.8);border:1.5px solid rgba(250,246,240,.3);padding:.75rem 1.5rem;font-family:'DM Sans',sans-serif;font-size:.85rem;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;transition:all .2s;border-radius:2px;text-decoration:none;display:inline-block;line-height:1;}
.btn-widerruf:hover{border-color:rgba(250,246,240,.6);color:#fff;}

/* ══ HERO ACTIONS ROW ══ */
.hero-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;justify-content:center;margin-top:1.5rem;}
