/* =========================================================================
   Weingut Schroth — site.css  (V3 Modern-Minimal Design-System)
   Fonts: Bricolage Grotesque (display) + Hanken Grotesk (body)
   ========================================================================= */
:root{
  --ink:#16130F; --ink-2:#34302A; --gold:#9A6B12; --gold-2:#B8842A;
  --bg:#ECEAE5; --bg-2:#E4E1DA; --paper:#F6F5F2; --fg:#16130F; --mut:#8A847A; --line:#D3CFC6;
  --wine:#6E1423; --ok:#3d7a4e;
  --display:'Bricolage Grotesque',system-ui,sans-serif; --body:'Hanken Grotesk',system-ui,sans-serif;
  --maxw:1280px; --ease:cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--fg);background:var(--bg);-webkit-font-smoothing:antialiased;line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 32px}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;line-height:.96;letter-spacing:-.02em;color:var(--ink)}
.label{font-size:11px;font-weight:600;letter-spacing:.26em;text-transform:uppercase;color:var(--mut)}
.label .dot{color:var(--gold)}
.gold{color:var(--gold)}
.section{padding:120px 0}
.center{text-align:center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;cursor:pointer;border:none;font-family:var(--body);font-size:13px;font-weight:600;letter-spacing:.04em;padding:15px 28px;border-radius:0;transition:.25s var(--ease)}
.btn-primary{background:var(--ink);color:#F6F5F2}
.btn-primary:hover{background:var(--gold);transform:translateY(-2px)}
.btn-line{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-line:hover{background:var(--ink);color:#F6F5F2}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-2)}
.arrow{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:3px;transition:.25s;width:fit-content}
.arrow:hover{color:var(--gold);border-color:var(--gold);gap:14px}

/* ---------- NAV ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.4s var(--ease);padding:22px 0}
.nav.scrolled{background:rgba(236,234,229,.93);backdrop-filter:blur(12px);border-bottom:1px solid var(--line);padding:13px 0}
.nav.solid{background:var(--ink)} /* for subpages w/o dark hero use .light-nav instead */
.nav-in{display:flex;align-items:center;gap:24px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mk{width:34px;height:34px;display:grid;place-items:center;background:var(--gold);border-radius:50%;transition:.4s var(--ease);flex:none}
.nav.scrolled .brand .mk{background:var(--ink)}
.brand .mk img{width:21px;height:21px;filter:brightness(0) invert(1)}
.brand b{font-family:var(--display);font-size:18px;font-weight:700;letter-spacing:-.01em;color:#F6F5F2;transition:.4s var(--ease)}
.nav.scrolled .brand b{color:var(--ink)}
.nav-links{display:flex;gap:28px;margin-left:auto}
.nav-links a{font-size:13.5px;font-weight:500;color:rgba(246,245,242,.85);transition:.25s;position:relative}
.nav.scrolled .nav-links a{color:var(--ink-2)}
.nav-links a:hover,.nav-links a.active{color:var(--gold-2)}
.nav.scrolled .nav-links a:hover,.nav.scrolled .nav-links a.active{color:var(--gold)}
.nav-cta{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#F6F5F2;border:1px solid rgba(246,245,242,.5);padding:9px 16px;transition:.25s}
.nav.scrolled .nav-cta{color:var(--ink);border-color:var(--ink)}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);color:#fff}
.cart-count{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--gold);color:#fff;font-size:11px;font-weight:700}
.nav.scrolled .cart-count{background:var(--ink)}
.burger{display:none;width:42px;height:42px;border:1px solid rgba(246,245,242,.4);background:transparent;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:4px}
.nav.scrolled .burger{border-color:var(--ink)}
.burger span{width:18px;height:2px;background:#F6F5F2;transition:.3s}
.nav.scrolled .burger span{background:var(--ink)}
/* light-theme nav variant (subpages with light page-hero) */
.nav.lighttop .brand b{color:var(--ink)} .nav.lighttop .brand .mk{background:var(--ink)}
.nav.lighttop .nav-links a{color:var(--ink-2)} .nav.lighttop .nav-cta{color:var(--ink);border-color:var(--ink)}
.nav.lighttop .burger span{background:var(--ink)} .nav.lighttop .burger{border-color:var(--ink)}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:99;background:var(--ink);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:6px;transform:translateY(-100%);transition:.45s var(--ease);visibility:hidden}
.mobile-menu.open{transform:none;visibility:visible}
.mobile-menu a{font-family:var(--display);font-size:34px;font-weight:700;text-transform:uppercase;color:#F6F5F2;padding:8px}
.mobile-menu a:hover{color:var(--gold-2)}

/* ---------- HERO (dark cinematic) ---------- */
.hero{position:relative;background:#100D0B;color:#F6F5F2;padding:150px 0 64px;overflow:hidden;min-height:100vh;display:flex;flex-direction:column;justify-content:center}
.smoke{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.3;display:block;pointer-events:none}
.hero::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(120% 90% at 72% 18%,transparent 24%,rgba(16,13,11,.62) 100%),linear-gradient(180deg,rgba(16,13,11,.5),rgba(16,13,11,.2) 42%,rgba(16,13,11,.92))}
.hero .wrap{position:relative;z-index:3}
/* ---------- 3D SCREEN ROOM (Hero-Hintergrund: Flaschen + Namen laufen rechts->links) ---------- */
.screen3d{position:absolute;inset:0;z-index:0;overflow:hidden;background:radial-gradient(120% 100% at 50% 40%,#181006,#0a0706 55%,#040302);perspective:720px;perspective-origin:50% 40%}
.room{position:absolute;top:50%;left:50%;width:0;height:0;transform-style:preserve-3d}
.room .face{position:absolute;top:50%;left:50%;overflow:hidden;background:linear-gradient(180deg,#0c0907,#070504)}
.room .r-back{width:1200px;height:760px;margin:-380px 0 0 -600px;transform:translateZ(-800px);background:#090706}
.room .r-back img{width:100%;height:100%;object-fit:cover;opacity:.9;display:block}
.room .r-back::after{content:"";position:absolute;inset:0;background:radial-gradient(125% 105% at 50% 45%,transparent 28%,rgba(8,6,5,.82));box-shadow:inset 0 0 0 2px rgba(184,132,42,.5),inset 0 0 120px rgba(184,132,42,.18)}
.room .r-left{width:1600px;height:760px;margin:-380px 0 0 -800px;transform:rotateY(90deg) translateZ(-600px);box-shadow:inset 0 3px 0 rgba(184,132,42,.55),inset 0 -3px 0 rgba(184,132,42,.55),inset -60px 0 110px rgba(0,0,0,.55)}
.room .r-right{width:1600px;height:760px;margin:-380px 0 0 -800px;transform:rotateY(-90deg) translateZ(-600px);box-shadow:inset 0 3px 0 rgba(184,132,42,.55),inset 0 -3px 0 rgba(184,132,42,.55),inset 60px 0 110px rgba(0,0,0,.55)}
.room .r-ceil{width:1200px;height:1600px;margin:-800px 0 0 -600px;transform:rotateX(90deg) translateZ(-380px);background:linear-gradient(180deg,#0b0806,#050302);box-shadow:inset 0 -40px 120px rgba(0,0,0,.6),inset 0 6px 0 rgba(184,132,42,.25)}
.room .r-floor{width:1200px;height:1600px;margin:-800px 0 0 -600px;transform:rotateX(-90deg) translateZ(-380px);background:linear-gradient(0deg,#100b07,#050302);box-shadow:inset 0 60px 160px rgba(0,0,0,.65),inset 0 -6px 0 rgba(184,132,42,.3)}
.room .wall-marquee{position:absolute;top:50%;left:0;display:flex;align-items:center;flex-wrap:nowrap;transform:translate(0,-50%);animation:wallrun 46s linear infinite;will-change:transform}
.room .r-right .wall-marquee{animation-delay:-23s}
@keyframes wallrun{from{transform:translate(0,-50%)}to{transform:translate(-50%,-50%)}}
.room .ru{display:inline-flex;align-items:center;gap:44px;padding:0 50px}
.room .ru img{height:560px;width:auto;object-fit:contain;mix-blend-mode:screen;filter:drop-shadow(0 18px 50px rgba(184,132,42,.45))}
.room .rw{font-family:var(--display);font-weight:800;font-size:150px;line-height:1;text-transform:uppercase;letter-spacing:-.02em;white-space:nowrap;color:transparent;-webkit-text-stroke:2px rgba(214,184,120,.5)}
.room .ru:nth-child(even) .rw{color:var(--gold-2);-webkit-text-stroke:0}
.hero-top{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:26px;flex-wrap:wrap}
.hero-top .label{color:var(--gold-2)}
.hero-top p{max-width:36ch;color:rgba(246,245,242,.75);font-size:16px}
.hero h1{font-size:clamp(54px,11.5vw,186px);line-height:.85;letter-spacing:-.03em;text-transform:uppercase;font-weight:800;color:#F6F5F2}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln span{display:block;transform:translateY(105%)}
.hero h1 .it{font-family:var(--display);font-style:normal;color:var(--gold-2)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center;margin-top:40px}
.hero-media{position:relative;height:54vh;min-height:380px;overflow:hidden;border:1px solid rgba(246,245,242,.14)}
.hero-media video,.hero-media .poster{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.hero-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(16,13,11,.5))}
.video-tag{position:absolute;left:20px;bottom:18px;z-index:3;display:flex;align-items:center;gap:8px;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:#F6F5F2;background:rgba(16,13,11,.5);padding:8px 13px;border-radius:999px;backdrop-filter:blur(6px)}
.video-tag .dot,.hero-top .dot{width:7px;height:7px;border-radius:50%;background:var(--gold-2);display:inline-block;animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(184,132,42,.5)}70%{box-shadow:0 0 0 9px rgba(184,132,42,0)}100%{box-shadow:0 0 0 0 rgba(184,132,42,0)}}
.hero-stats{display:flex;gap:0;margin-top:40px;border-top:1px solid rgba(246,245,242,.18)}
.hero-stats .s{flex:1;padding:22px 0}
.hero-stats .s+.s{border-left:1px solid rgba(246,245,242,.18);padding-left:26px}
.hero-stats .n{font-family:var(--display);font-size:40px;font-weight:700;color:#F6F5F2;line-height:1}
.hero-stats .l{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:rgba(246,245,242,.6);margin-top:6px}

/* ---------- 3D CUBE ---------- */
.cube-stage{position:relative;width:100%;height:100%;min-height:360px;display:grid;place-items:center;perspective:1400px}
.cube{position:relative;width:230px;height:230px;transform-style:preserve-3d;animation:cubespin 18s linear infinite}
.cube .face{position:absolute;inset:0;display:grid;place-items:center;border:1px solid rgba(184,132,42,.5);background:rgba(16,13,11,.55);backdrop-filter:blur(2px);font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:42px;letter-spacing:-.02em;color:#F6F5F2;text-align:center;box-shadow:inset 0 0 60px rgba(184,132,42,.12)}
.cube .face small{display:block;font-family:var(--body);font-size:11px;font-weight:600;letter-spacing:.24em;color:var(--gold-2);margin-top:8px}
.cube .f1{transform:rotateY(0deg) translateZ(115px)}
.cube .f2{transform:rotateY(90deg) translateZ(115px)}
.cube .f3{transform:rotateY(180deg) translateZ(115px)}
.cube .f4{transform:rotateY(270deg) translateZ(115px)}
.cube .f5{transform:rotateX(90deg) translateZ(115px);color:var(--gold-2)}
.cube .f6{transform:rotateX(-90deg) translateZ(115px);color:var(--gold-2)}
@keyframes cubespin{from{transform:rotateX(-18deg) rotateY(0)}to{transform:rotateX(-18deg) rotateY(360deg)}}

/* ---------- KINETIC marquee ---------- */
.kinetic{background:var(--ink);overflow:hidden;border-top:1px solid rgba(246,245,242,.1);border-bottom:1px solid rgba(246,245,242,.1)}
.kinetic .track{display:flex;width:max-content;white-space:nowrap;will-change:transform;animation:marquee 26s linear infinite}
.kinetic .track span{font-family:var(--display);font-size:clamp(38px,7vw,100px);font-weight:800;text-transform:uppercase;letter-spacing:-.02em;padding:24px 34px;color:#F6F5F2}
.kinetic .track span.acc{color:var(--gold-2)}
.kinetic .track .dotm{color:var(--gold-2)}
@keyframes marquee{to{transform:translateX(-50%)}}

/* ---------- PAGE HERO (subpages, light) ---------- */
.pagehero{padding:170px 0 70px;background:var(--bg-2);border-bottom:1px solid var(--line)}
.pagehero .crumb{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--mut);margin-bottom:18px}
.pagehero .crumb a:hover{color:var(--gold)}
.pagehero h1{font-size:clamp(44px,8vw,120px);text-transform:uppercase;letter-spacing:-.03em}
.pagehero p{max-width:60ch;color:var(--ink-2);font-size:17px;margin-top:18px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .85s var(--ease),transform .85s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ---------- sec-head ---------- */
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:54px;flex-wrap:wrap}
.sec-head h2{font-size:clamp(34px,6vw,78px);text-transform:uppercase;letter-spacing:-.02em}
.sec-head .label{display:block;margin-bottom:14px}

/* ---------- STORY ---------- */
.story{background:var(--bg-2)}
.story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.story-grid img{width:100%;aspect-ratio:1/1;object-fit:cover}
.story h2{font-size:clamp(34px,4.6vw,64px);text-transform:uppercase;margin-bottom:22px}
.story p{color:var(--ink-2);font-size:16.5px;margin-bottom:18px;max-width:50ch}

/* ---------- WINE CATEGORY LIST (home) ---------- */
.cat-list{border-top:1px solid var(--line)}
.cat-row{display:grid;grid-template-columns:60px 1fr auto 160px;gap:30px;align-items:center;padding:30px 0;border-bottom:1px solid var(--line);transition:.3s var(--ease)}
.cat-row:hover{padding-left:14px}
.cat-row .num{font-family:var(--display);font-size:15px;color:var(--gold)}
.cat-row h3{font-size:clamp(26px,3.4vw,44px);text-transform:uppercase;letter-spacing:-.02em}
.cat-row p{color:var(--mut);font-size:14px;max-width:34ch}
.cat-row .pr{font-family:var(--display);font-size:18px;color:var(--ink);text-align:right}

/* ---------- SHOP ---------- */
.shop-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:40px}
.filter{font-size:12.5px;font-weight:600;letter-spacing:.04em;padding:10px 18px;border:1px solid var(--line);background:var(--paper);cursor:pointer;transition:.25s;color:var(--ink-2)}
.filter:hover{border-color:var(--ink)}
.filter.active{background:var(--ink);color:#F6F5F2;border-color:var(--ink)}
.shop-count{margin-left:auto;font-size:13px;color:var(--mut)}
.wine-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.wine-grid.cols3{grid-template-columns:repeat(3,1fr)}
.wcard{background:var(--paper);padding:30px 24px 26px;transition:.3s var(--ease);position:relative;display:flex;flex-direction:column}
.wcard:hover{background:#fff}
.wcard .badge{position:absolute;top:16px;right:16px;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--wine)}
.wcard .wimg{height:240px;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.wcard .wimg img{max-height:100%;width:auto;object-fit:contain;transition:.4s var(--ease);filter:drop-shadow(0 14px 20px rgba(0,0,0,.12))}
.wcard:hover .wimg img{transform:translateY(-6px)}
.wcard .ctag{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--mut);margin-bottom:6px}
.wcard h3{font-size:19px;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:6px;line-height:1.05}
.wcard .desc{font-size:13px;color:var(--mut);min-height:38px;flex:1}
.wcard .foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px}
.wcard .pr{font-family:var(--display);font-size:22px;color:var(--ink)}
.wcard .pr small{font-size:11px;color:var(--mut);font-family:var(--body)}
.wcard .add{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);padding:9px 14px;cursor:pointer;transition:.25s}
.wcard .add:hover{background:var(--ink);color:#F6F5F2}

/* ---------- WINE DETAIL ---------- */
.detail{display:grid;grid-template-columns:.9fr 1.1fr;gap:64px;align-items:start}
.detail .media{background:var(--ink);position:relative;aspect-ratio:3/4;display:flex;align-items:center;justify-content:center;overflow:hidden}
.detail .media img{max-height:86%;width:auto;filter:drop-shadow(0 24px 40px rgba(0,0,0,.5))}
.detail .media .sm{position:absolute;inset:0;z-index:0;opacity:.4}
.detail .media img{position:relative;z-index:1}
.detail .ctag{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.detail h1{font-size:clamp(34px,4.5vw,58px);text-transform:uppercase;letter-spacing:-.02em;margin-bottom:8px}
.detail .sub{color:var(--mut);font-size:15px;margin-bottom:22px}
.detail .price{font-family:var(--display);font-size:38px;color:var(--ink);margin:8px 0}
.detail .price small{font-size:14px;color:var(--mut);font-family:var(--body)}
.detail .lead{font-size:16px;color:var(--ink-2);margin:18px 0;max-width:52ch}
.qty{display:inline-flex;align-items:center;border:1px solid var(--ink);margin-right:12px}
.qty button{width:42px;height:46px;background:transparent;border:none;font-size:18px;cursor:pointer}
.qty input{width:46px;height:46px;border:none;text-align:center;font-family:var(--body);font-size:15px;-moz-appearance:textfield}
.qty input::-webkit-outer-spin-button,.qty input::-webkit-inner-spin-button{-webkit-appearance:none}
.profile{margin:28px 0;display:grid;gap:14px;max-width:420px}
.profile .row{display:grid;grid-template-columns:110px 1fr;align-items:center;gap:14px;font-size:13px}
.profile .row .bar{height:6px;background:var(--line);position:relative}
.profile .row .bar i{position:absolute;left:0;top:0;bottom:0;background:var(--gold)}
.profile .row .lbl{color:var(--mut);text-transform:uppercase;letter-spacing:.08em;font-size:11px}
.spec{width:100%;border-collapse:collapse;margin-top:24px;font-size:14px}
.spec th,.spec td{text-align:left;padding:12px 0;border-bottom:1px solid var(--line);vertical-align:top}
.spec th{width:42%;color:var(--mut);font-weight:500}
.eu-note{font-size:12px;color:var(--mut);margin-top:14px;padding:14px;background:var(--bg-2);border-left:2px solid var(--gold)}
.pairing{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.pairing span{font-size:12px;padding:7px 13px;background:var(--bg-2);border:1px solid var(--line)}

/* ---------- LAGEN ---------- */
.lagen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.lage{position:relative;min-height:420px;overflow:hidden;display:flex;align-items:flex-end}
.lage img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:grayscale(.25);transition:1s var(--ease)}
.lage:hover img{filter:grayscale(0);transform:scale(1.06)}
.lage::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(16,13,11,.9))}
.lage .c{position:relative;z-index:2;padding:30px;color:#F6F5F2}
.lage .idx{font-family:var(--display);font-size:14px;color:var(--gold-2)}
.lage h3{color:#F6F5F2;font-size:30px;text-transform:uppercase;margin:6px 0 8px}
.lage p{font-size:13.5px;color:rgba(246,245,242,.82)}
.lage .soil{margin-top:10px;font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2)}
.darkpanel{background:var(--ink);color:#E8E4DC}
.darkpanel h2,.darkpanel h3{color:#F6F5F2}.darkpanel .label{color:rgba(232,228,220,.6)}

/* ---------- EVENTS ---------- */
.ev{display:grid;grid-template-columns:120px 1fr auto;gap:30px;align-items:center;padding:28px 0;border-top:1px solid var(--line);transition:.3s var(--ease)}
.ev:last-child{border-bottom:1px solid var(--line)}
.ev:hover{padding-left:12px}
.ev .date{font-family:var(--display);font-size:26px;color:var(--ink)}
.ev .date small{display:block;font-size:11px;letter-spacing:.12em;color:var(--mut);margin-top:3px;font-family:var(--body)}
.ev .name{font-family:var(--display);font-size:24px;text-transform:uppercase;letter-spacing:-.01em}
.ev .name span{display:block;font-family:var(--body);font-size:13px;text-transform:none;color:var(--mut);margin-top:3px;letter-spacing:0;font-weight:400}
.ev .tag{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold)}

/* ---------- BANNER (hochzeit etc) ---------- */
.banner{position:relative;min-height:560px;display:flex;align-items:center;overflow:hidden}
.banner img.bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.banner::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,13,11,.82),rgba(16,13,11,.3))}
.banner .inner{position:relative;z-index:2;max-width:560px;color:#F6F5F2}
.banner h2{color:#F6F5F2;font-size:clamp(34px,5vw,64px);text-transform:uppercase;margin:14px 0 18px}
.banner p{color:rgba(246,245,242,.85);font-size:16px;margin-bottom:26px}
.banner .label{color:var(--gold-2)}

/* ---------- PRICING (weinclub) ---------- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:stretch}
.tier{background:var(--paper);border:1px solid var(--line);padding:38px 30px;display:flex;flex-direction:column}
.tier.feat{background:var(--ink);color:#F6F5F2;border-color:var(--ink)}
.tier .tname{font-family:var(--display);font-size:24px;text-transform:uppercase;margin-bottom:6px}
.tier.feat .tname{color:#F6F5F2}
.tier .tprice{font-family:var(--display);font-size:46px;margin:10px 0}
.tier .tprice small{font-size:14px;color:var(--mut);font-family:var(--body)}
.tier.feat .tprice small{color:rgba(246,245,242,.6)}
.tier ul{list-style:none;margin:18px 0 26px;display:grid;gap:12px}
.tier li{font-size:14px;display:flex;gap:10px;align-items:flex-start;color:var(--ink-2)}
.tier.feat li{color:rgba(246,245,242,.85)}
.tier li::before{content:"—";color:var(--gold)}
.tier .btn{margin-top:auto}
.feat-flag{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-2);margin-bottom:10px}

/* ---------- BUNDLES (probierpakete) ---------- */
.bundles{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.bundle{background:var(--paper);border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:.3s var(--ease)}
.bundle:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(16,13,11,.3)}
.bundle .top{background:var(--ink);color:#F6F5F2;padding:30px;position:relative}
.bundle .top .n{font-family:var(--display);font-size:26px;text-transform:uppercase}
.bundle .top .meta{font-size:12px;color:rgba(246,245,242,.6);letter-spacing:.1em;text-transform:uppercase;margin-top:4px}
.bundle .body{padding:26px 30px;display:flex;flex-direction:column;flex:1}
.bundle .body p{font-size:14px;color:var(--ink-2);margin-bottom:16px;flex:1}
.bundle .body .pr{font-family:var(--display);font-size:30px}

/* ---------- FORM ---------- */
.form{display:grid;gap:16px;max-width:620px}
.form .two{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field label{display:block;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--mut);margin-bottom:7px}
.field input,.field textarea,.field select{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--paper);font-family:var(--body);font-size:14px;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--gold)}
.field textarea{min-height:130px;resize:vertical}

/* ---------- NEWSLETTER ---------- */
.news{background:var(--bg-2);text-align:center}
.news .inner{max-width:640px;margin:0 auto}
.news h2{font-size:clamp(34px,5.5vw,74px);text-transform:uppercase;margin:12px 0}
.news p{color:var(--ink-2);margin-bottom:28px}
.news form{display:flex;gap:0;max-width:480px;margin:0 auto;border:1px solid var(--ink)}
.news input{flex:1;padding:16px 18px;border:none;font-family:var(--body);font-size:14px;background:transparent}
.news input:focus{outline:none}
.news .hint{font-size:11.5px;color:var(--mut);margin-top:14px}

/* ---------- CART DRAWER ---------- */
.cart-drawer{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:90vw;background:var(--paper);z-index:200;transform:translateX(100%);transition:.4s var(--ease);box-shadow:-20px 0 60px -20px rgba(0,0,0,.4);display:flex;flex-direction:column}
.cart-drawer.open{transform:none}
.cart-backdrop{position:fixed;inset:0;background:rgba(16,13,11,.5);z-index:199;opacity:0;visibility:hidden;transition:.4s}
.cart-backdrop.open{opacity:1;visibility:visible}
.cart-head{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--line)}
.cart-head h3{font-size:18px;text-transform:uppercase}
.cart-head .x{cursor:pointer;font-size:22px;background:none;border:none}
.cart-items{flex:1;overflow:auto;padding:12px 24px}
.cart-item{display:grid;grid-template-columns:1fr auto;gap:6px;padding:16px 0;border-bottom:1px solid var(--line);font-size:14px}
.cart-item .nm{font-weight:600}
.cart-item .mt{color:var(--mut);font-size:12px}
.cart-foot{padding:24px;border-top:1px solid var(--line)}
.cart-foot .sum{display:flex;justify-content:space-between;font-family:var(--display);font-size:20px;margin-bottom:16px}
.cart-empty{color:var(--mut);font-size:14px;padding:30px 0;text-align:center}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(232,228,220,.65);padding:90px 0 36px}
.f-top{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;margin-bottom:60px}
.f-big{font-family:var(--display);font-size:clamp(40px,8vw,116px);font-weight:800;text-transform:uppercase;letter-spacing:-.03em;color:#F6F5F2;line-height:.9}
.f-cols{display:flex;gap:56px;flex-wrap:wrap}
.f-col h4{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#F6F5F2;margin-bottom:16px}
.f-col a,.f-col p{display:block;font-size:14px;color:rgba(232,228,220,.6);margin-bottom:10px;transition:.2s}
.f-col a:hover{color:var(--gold-2)}
.f-bottom{display:flex;justify-content:space-between;padding-top:28px;border-top:1px solid rgba(232,228,220,.16);font-size:12.5px;color:rgba(232,228,220,.5);flex-wrap:wrap;gap:12px}

/* ---------- AGE GATE ---------- */
.agegate{position:fixed;inset:0;z-index:300;background:rgba(16,13,11,.96);display:flex;align-items:center;justify-content:center;padding:24px}
.agegate .box{max-width:440px;text-align:center;color:#F6F5F2}
.agegate .mk{width:60px;height:60px;border-radius:50%;background:var(--gold);display:grid;place-items:center;margin:0 auto 22px}
.agegate .mk img{width:36px;filter:brightness(0) invert(1)}
.agegate h2{color:#F6F5F2;font-size:30px;text-transform:uppercase;margin-bottom:12px}
.agegate p{color:rgba(246,245,242,.7);font-size:14px;margin-bottom:24px}
.agegate .row{display:flex;gap:12px;justify-content:center}

/* ---------- RESPONSIVE ---------- */
@media(max-width:1000px){
  .wine-grid{grid-template-columns:repeat(2,1fr)}
  .tiers,.bundles,.lagen-grid{grid-template-columns:1fr}
  .hero-grid{grid-template-columns:1fr}
  .detail{grid-template-columns:1fr;gap:36px}
}
@media(max-width:760px){
  .nav-links{display:none}.burger{display:flex}
  .screen3d{perspective:620px}
  .room .ru img{height:300px}.room .rw{font-size:92px}
  .story-grid{grid-template-columns:1fr;gap:36px}
  .wine-grid{grid-template-columns:1fr;max-width:420px;margin:0 auto}
  .cat-row{grid-template-columns:36px 1fr;gap:14px}.cat-row .pr,.cat-row p{display:none}
  .ev{grid-template-columns:78px 1fr;gap:14px}.ev .tag{display:none}
  .news form{flex-direction:column;border:none;gap:10px}
  .news input{border:1px solid var(--ink)}
  .f-top{flex-direction:column}.section{padding:80px 0}
  .form .two{grid-template-columns:1fr}
  .hero-stats{flex-wrap:wrap}.hero-stats .s{flex:1 1 42%}.hero-stats .s+.s{border-left:none}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}.hero h1 .ln span{transform:none}
  .cube{animation:none}
}
