/* Modewelt Schweiger - Custom LP Design System
   Visual-Klon des originalen Impulse-Theme von modewelt-schweiger.de */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Tokens vom Original-Theme */
  --bg:#FFFFFF;
  --bg-soft:#F8F6F2;
  --bg-section:#FAF8F4;
  --bg-warm:#F5EFE6;
  --border:#E8E3DC;
  --border-strong:#D4CCC0;
  --text:#1C1C1C;
  --text-secondary:#525252;
  --text-muted:#8B8478;
  --accent:#ccbfa2;       /* warmes beige */
  --accent-dark:#A89A7E;
  --rust:#D05B2E;         /* sale accent */
  --link:#1C1C1C;
  --success:#2D6A4F;
  --danger:#C84141;

  /* Fonts */
  --font-display:'Fustat','Cormorant Garamond',Georgia,serif;
  --font-body:'Host Grotesk','Inter',-apple-system,BlinkMacSystemFont,sans-serif;

  /* Spacing */
  --container:1400px;
  --gutter:24px;
  --radius:0;
  --radius-sm:2px;
}

html,body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--link);text-decoration:none}
a:hover{opacity:0.7}
img{max-width:100%;height:auto;display:block}
button{font-family:inherit;cursor:pointer}

/* Display / Headings */
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:600;letter-spacing:-0.01em;line-height:1.15}
h1{font-size:clamp(36px,5vw,68px)}
h2{font-size:clamp(26px,3.4vw,42px)}
h3{font-size:clamp(20px,2vw,28px)}
h4{font-size:18px}

.eyebrow{font-family:var(--font-body);font-size:10.5px;text-transform:uppercase;letter-spacing:0.18em;color:var(--text-secondary);font-weight:600}

/* Topbar / Announcement */
.topbar{background:var(--bg-warm);color:var(--text);font-size:12px;text-align:center;padding:9px 16px;letter-spacing:0.04em;font-weight:500}
.topbar b{font-weight:700}

/* Header */
.site-header{position:sticky;top:0;background:var(--bg);border-bottom:1px solid var(--border);z-index:100}
.site-header-inner{max-width:var(--container);margin:0 auto;padding:18px var(--gutter);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.header-left,.header-right{display:flex;align-items:center;gap:18px}
.header-right{justify-content:flex-end}
.icon-btn{background:none;border:none;color:var(--text);width:32px;height:32px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%}
.icon-btn:hover{background:var(--bg-warm)}
.icon-btn svg{width:20px;height:20px}
.brand-logo{text-align:center;line-height:1}
.brand-logo .logo-mark{font-family:var(--font-display);font-size:28px;font-weight:600;letter-spacing:-0.01em}
.brand-logo .logo-sub{font-family:var(--font-body);font-size:9.5px;letter-spacing:0.32em;color:var(--text);text-transform:uppercase;font-weight:600;margin-top:2px}

.site-nav{border-top:1px solid var(--border);background:var(--bg)}
.site-nav-inner{max-width:var(--container);margin:0 auto;padding:14px var(--gutter);display:flex;justify-content:center;gap:32px}
.site-nav a{font-size:12.5px;text-transform:uppercase;letter-spacing:0.12em;font-weight:500;color:var(--text);position:relative;padding:6px 2px}
.site-nav a.active{color:var(--accent-dark)}
.site-nav a:hover{opacity:1;color:var(--accent-dark)}

/* Cart count badge */
.cart-link{position:relative}
.cart-count{position:absolute;top:-4px;right:-6px;background:var(--text);color:#fff;border-radius:50%;width:18px;height:18px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-body)}
.cart-count.empty{display:none}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:14px 30px;font-family:var(--font-body);font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:0.14em;border:1px solid var(--text);background:var(--text);color:#fff;border-radius:var(--radius);cursor:pointer;transition:all .15s;text-decoration:none}
.btn:hover{background:var(--bg);color:var(--text);opacity:1}
.btn-outline{background:transparent;color:var(--text)}
.btn-outline:hover{background:var(--text);color:#fff}
.btn-block{width:100%}
.btn-large{padding:18px 36px;font-size:14px}

/* Container */
.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}

/* Sections */
.section{padding:72px 0}
.section-title{text-align:center;margin-bottom:42px}
.section-title h2{margin-bottom:8px}
.section-title .eyebrow{margin-bottom:12px;display:block}

/* Hero */
.hero{position:relative;height:clamp(420px,62vh,680px);overflow:hidden;background:#222}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0.18) 0%,rgba(0,0,0,0.42) 100%)}
.hero-inner{position:relative;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;text-align:center;padding:0 24px}
.hero-inner h1{color:#fff;text-transform:uppercase;letter-spacing:0.02em;text-shadow:0 2px 16px rgba(0,0,0,0.35);font-size:clamp(46px,7vw,96px);font-weight:600}
.hero-inner p{margin-top:12px;font-size:15px;letter-spacing:0.06em;max-width:540px;text-shadow:0 2px 8px rgba(0,0,0,0.45)}
.hero-cta{margin-top:24px;background:rgba(255,255,255,0.95);color:var(--text);border-color:transparent}
.hero-cta:hover{background:#fff;color:var(--text)}

/* Product Grid */
.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.product-card{background:var(--bg);position:relative}
.product-card-img{aspect-ratio:3/4;background:var(--bg-soft);overflow:hidden;position:relative}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .55s ease}
.product-card:hover .product-card-img img{transform:scale(1.04)}
.product-card-badge{position:absolute;top:12px;left:12px;background:var(--rust);color:#fff;font-size:10.5px;font-weight:700;padding:5px 9px;text-transform:uppercase;letter-spacing:0.08em}
.product-card-info{padding:16px 4px 8px;text-align:left}
.product-card-title{font-family:var(--font-body);font-size:13.5px;font-weight:500;color:var(--text);margin-bottom:6px;letter-spacing:0.02em}
.product-card-vendor{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:6px;font-weight:600}
.product-card-price{display:flex;gap:8px;align-items:baseline;font-family:var(--font-body)}
.product-card-price .now{font-size:15px;font-weight:700}
.product-card-price .was{font-size:13px;color:var(--text-muted);text-decoration:line-through}
.product-card-colors{display:flex;gap:5px;margin-top:8px}
.product-card-colors .dot{width:14px;height:14px;border-radius:50%;border:1px solid var(--border)}

/* Product page detail */
.pdp{display:grid;grid-template-columns:1.2fr 1fr;gap:56px;padding:48px 0}
.pdp-main img{width:100%;aspect-ratio:3/4;object-fit:cover;background:var(--bg-soft)}
/* .pdp-thumbs styles live in product.html inline CSS (horizontal carousel) */
.pdp-info h1{font-size:32px;margin-bottom:8px;font-weight:500}
.pdp-vendor{font-size:11.5px;text-transform:uppercase;letter-spacing:0.18em;color:var(--text-muted);margin-bottom:18px;font-weight:600}
.pdp-price{font-size:22px;font-weight:700;margin-bottom:6px}
.pdp-price .was{font-size:15px;color:var(--text-muted);text-decoration:line-through;font-weight:400;margin-left:8px}
.pdp-vat{font-size:11px;color:var(--text-muted);margin-bottom:24px}
.pdp-label{font-size:11.5px;text-transform:uppercase;letter-spacing:0.16em;color:var(--text);font-weight:600;margin-bottom:10px;display:block}
.pdp-options{margin-bottom:24px}
.pdp-color-list{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}
.pdp-color{padding:8px 14px;border:1px solid var(--border);background:var(--bg);font-size:12.5px;cursor:pointer;font-weight:500;letter-spacing:0.04em;transition:all .15s}
.pdp-color.active{border-color:var(--text);background:var(--text);color:#fff}
.pdp-size-list{display:flex;flex-wrap:wrap;gap:6px}
.pdp-size{min-width:44px;padding:10px 0;border:1px solid var(--border);background:var(--bg);font-size:12.5px;cursor:pointer;font-weight:600;text-align:center;font-family:var(--font-body)}
.pdp-size.active{border-color:var(--text);background:var(--text);color:#fff}
.pdp-size.unavailable{opacity:0.3;cursor:not-allowed;text-decoration:line-through}

/* Bundle */
.bundle{border:1px solid var(--border);margin-bottom:24px}
.bundle-row{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--border);cursor:pointer}
.bundle-row:last-child{border-bottom:none}
.bundle-row.active{background:var(--bg-warm)}
.bundle-radio{width:18px;height:18px;border:1.5px solid var(--text);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.bundle-radio::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--text);opacity:0;transition:opacity .12s}
.bundle-row.active .bundle-radio::after{opacity:1}
.bundle-text{flex:1}
.bundle-text strong{display:block;font-size:14px;font-weight:600}
.bundle-text .save{font-size:11.5px;color:var(--rust);font-weight:600;text-transform:uppercase;letter-spacing:0.08em}
.bundle-price{text-align:right}
.bundle-price .now{font-weight:700;font-size:15px}
.bundle-price .was{font-size:12px;color:var(--text-muted);text-decoration:line-through}

.pdp-description{margin-top:48px;padding-top:32px;border-top:1px solid var(--border);font-size:14.5px;line-height:1.7;color:var(--text-secondary)}
.pdp-description h2,.pdp-description h3{font-size:18px;color:var(--text);margin:18px 0 8px}

/* Cart drawer */
.cart-drawer{position:fixed;top:0;right:0;width:min(420px,100vw);height:100vh;background:#fff;box-shadow:-10px 0 40px rgba(0,0,0,0.18);z-index:200;transform:translateX(100%);transition:transform .3s ease;display:flex;flex-direction:column}
.cart-drawer.open{transform:translateX(0)}
.cart-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:190;opacity:0;pointer-events:none;transition:opacity .25s}
.cart-backdrop.open{opacity:1;pointer-events:all}
.cart-header{padding:22px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.cart-header h3{font-size:20px;font-weight:600}
.cart-close{background:none;border:none;font-size:22px;color:var(--text);width:32px;height:32px;display:flex;align-items:center;justify-content:center}
.cart-items{flex:1;overflow-y:auto;padding:18px 24px}
.cart-empty{text-align:center;padding:40px 12px;color:var(--text-muted);font-size:14px}
.cart-item{display:grid;grid-template-columns:78px 1fr auto;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}
.cart-item img{width:78px;height:100px;object-fit:cover;background:var(--bg-soft)}
.cart-item-title{font-size:13.5px;font-weight:600;margin-bottom:4px;line-height:1.3}
.cart-item-meta{font-size:11.5px;color:var(--text-muted);margin-bottom:6px}
.cart-item-qty{display:flex;align-items:center;border:1px solid var(--border);width:fit-content;font-size:13px}
.cart-item-qty button{width:26px;height:26px;background:none;border:none;font-size:14px}
.cart-item-qty span{min-width:22px;text-align:center;font-weight:600}
.cart-item-right{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end}
.cart-item-price{font-weight:700;font-size:14px}
.cart-item-remove{background:none;border:none;color:var(--text-muted);font-size:11px;text-decoration:underline;padding:0}
.cart-footer{padding:22px 24px;border-top:1px solid var(--border);background:var(--bg)}
.cart-subtotal{display:flex;justify-content:space-between;margin-bottom:14px;font-size:14px}
.cart-subtotal-value{font-weight:700;font-size:18px;font-family:var(--font-display)}
.cart-info{font-size:11.5px;color:var(--text-muted);margin-bottom:14px}

/* Footer */
.site-footer{background:var(--bg-warm);padding:64px 0 32px;margin-top:80px}
.footer-grid{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px}
.footer-col h4{font-family:var(--font-body);font-size:11.5px;text-transform:uppercase;letter-spacing:0.16em;font-weight:700;margin-bottom:18px;color:var(--text)}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:9px}
.footer-col a{font-size:13.5px;color:var(--text-secondary)}
.footer-col a:hover{color:var(--text);opacity:1}
.footer-brand .logo-mark{font-family:var(--font-display);font-size:24px;margin-bottom:4px;font-weight:600}
.footer-brand .logo-sub{font-size:9.5px;letter-spacing:0.32em;font-weight:600;text-transform:uppercase;margin-bottom:18px}
.footer-brand p{font-size:13.5px;color:var(--text-secondary);max-width:280px;line-height:1.65}
.footer-bottom{max-width:var(--container);margin:48px auto 0;padding:24px var(--gutter) 0;border-top:1px solid var(--border-strong);display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--text-muted)}
.footer-payments{display:flex;gap:8px}

/* Mobile */
@media(max-width:900px){
  .product-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .pdp{grid-template-columns:1fr;gap:32px;padding:24px 0}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px}
  .footer-brand{grid-column:1/-1}
  .site-nav-inner{gap:16px;font-size:11px;overflow-x:auto;padding:12px var(--gutter)}
  .site-nav a{white-space:nowrap;font-size:11.5px}
  .section{padding:48px 0}
}
@media(max-width:560px){
  .site-header-inner{padding:14px var(--gutter)}
  .brand-logo .logo-mark{font-size:22px}
  .brand-logo .logo-sub{font-size:8.5px;letter-spacing:0.28em}
  .icon-btn{width:28px;height:28px}
  .icon-btn svg{width:18px;height:18px}
}
