*{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#f6f1e8;--card:#fdfaf4;--ink:#2c1a1e;--mut:#7a6a67;--vino:#6b1f2e;--vino-d:#521622;--gold:#c8a35a;--line:#e6dcc9}
html{scroll-behavior:smooth}
body{font-family:'Spline Sans',sans-serif;background:var(--bg);color:var(--ink);line-height:1.72;font-size:16.5px;overflow-x:hidden}
h1,h2,h3{font-family:'Gloock',serif;font-weight:400;line-height:1.18}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:1060px;margin:0 auto;padding:0 24px}

.ribbon{background:var(--vino-d);color:#c8b5b0;font-size:13.5px;padding:9px 16px;text-align:center;position:relative;z-index:80}
.ribbon b{color:#f6f1e8}
.ribbon a{display:inline-block;margin-left:12px;background:var(--gold);color:#2c1a1e;font-weight:700;padding:3px 14px;border-radius:2px;font-size:13px}
.ribbon a:hover{background:#b8933f}

/* ===== SIDE RAIL NAV (desktop) ===== */
.rail{position:fixed;top:0;left:0;bottom:0;width:230px;background:var(--vino-d);color:#f6f1e8;z-index:70;display:flex;flex-direction:column;padding:34px 28px}
body{padding-left:230px}
.ribbon{margin-left:-230px;padding-left:246px}
.rail .logo{font-family:'Gloock',serif;font-size:22px;line-height:1.25;margin-bottom:6px}
.rail .logo b{color:var(--gold)}
.rail .sub{font-size:11.5px;letter-spacing:.22em;text-transform:uppercase;color:#b59a95;margin-bottom:40px}
.rail nav{display:flex;flex-direction:column;gap:4px}
.rail nav a{padding:11px 0;font-size:15px;color:#d9c9c4;border-bottom:1px solid rgba(255,255,255,.08);transition:.15s;display:flex;justify-content:space-between;align-items:center}
.rail nav a::after{content:"→";opacity:0;transition:.15s;color:var(--gold)}
.rail nav a:hover,.rail nav a.on{color:#fff;padding-left:6px}
.rail nav a:hover::after,.rail nav a.on::after{opacity:1}
.rail .cta-btn{margin-top:auto;background:var(--gold);color:#2c1a1e;text-align:center;padding:13px;border-radius:2px;font-weight:700;font-size:14.5px}
.rail .cta-btn:hover{background:#b8933f}
.rail .foot{margin-top:18px;font-size:12px;color:#b59a95}
/* mobile topbar (hidden on desktop) */
.mtop{display:none}

/* ===== FULLSCREEN OVERLAY MENU (mobile) ===== */
.fsmenu{position:fixed;inset:0;background:var(--vino-d);z-index:90;display:none;flex-direction:column;justify-content:center;padding:40px 34px;opacity:0;transition:opacity .25s}
.fsmenu.open{display:flex;opacity:1}
.fsmenu a{font-family:'Gloock',serif;font-size:clamp(28px,8vw,40px);color:#f6f1e8;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.12);display:flex;align-items:baseline;gap:16px}
.fsmenu a i{font-family:'Spline Sans',sans-serif;font-style:normal;font-size:13px;color:var(--gold)}
.fsmenu .close{position:absolute;top:24px;right:24px;background:none;border:1.5px solid rgba(255,255,255,.4);color:#f6f1e8;width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer}

/* hero */
.hero{position:relative;overflow:hidden;color:#fff;min-height:520px;display:flex;align-items:flex-end}
.hero .bgimg{position:absolute;inset:0;background:url(../img/hero.jpg) center/cover}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(30,12,16,.15),rgba(30,12,16,.72) 92%)}
.hero .in{position:relative;z-index:2;width:100%;max-width:1060px;margin:0 auto;padding:90px 24px 56px}
.hero .kicker{display:inline-block;color:var(--gold);font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:12px;margin-bottom:14px}
.hero h1{font-size:clamp(36px,5.4vw,64px)}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p{max-width:520px;color:#ead9d3;font-size:17.5px;margin:16px 0 26px}
.btn{display:inline-block;background:var(--vino);color:#fff;padding:14px 30px;border-radius:2px;font-weight:600;font-size:15.5px;transition:.15s;border:0;cursor:pointer;font-family:'Spline Sans',sans-serif}
.btn:hover{background:var(--vino-d)}
.btn.gold{background:var(--gold);color:#2c1a1e}
.btn.gold:hover{background:#b8933f}
.btn.ghost{background:transparent;border:1.5px solid rgba(255,255,255,.6);color:#fff}
.btn.ghost:hover{background:#fff;color:var(--vino-d)}

section{padding:80px 0}
.shead{max-width:640px;margin-bottom:44px}
.shead .eyebrow{color:var(--gold);font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:10px}
.shead h2{font-size:clamp(26px,3.6vw,38px)}
.shead h2 em{font-style:italic;color:var(--vino)}
.shead p{color:var(--mut);margin-top:12px}

/* wine cards */
.filtry{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:28px}
.filtry button{border:1px solid var(--line);background:var(--card);padding:9px 18px;border-radius:2px;cursor:pointer;font-family:inherit;font-size:14px;transition:.12s}
.filtry button.on{background:var(--vino);color:#fff;border-color:var(--vino)}
.vino-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.vin{background:var(--card);border:1px solid var(--line);padding:26px 24px;transition:.16s;position:relative}
.vin::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--vino)}
.vin.bile::before{background:var(--gold)}
.vin.sekt::before{background:#8a97a8}
.vin:hover{transform:translateY(-4px);box-shadow:0 16px 40px rgba(44,26,30,.12)}
.vin .typ{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--mut)}
.vin h3{font-size:21px;margin:6px 0 4px}
.vin .roc{color:var(--gold);font-weight:600;font-size:14px;margin-bottom:10px}
.vin p{color:var(--mut);font-size:14px}
.vin .price{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);margin-top:14px;padding-top:12px}
.vin .price b{font-family:'Gloock',serif;font-size:20px;color:var(--vino)}
.vin .price span{font-size:12.5px;color:var(--mut)}

/* deg cards */
.deg-g{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.deg{background:var(--card);border:1px solid var(--line);padding:30px 28px;text-align:center}
.deg h3{font-size:20px;margin-bottom:6px}
.deg .cena{font-family:'Gloock',serif;font-size:26px;color:var(--vino);margin:10px 0 4px}
.deg .os{color:var(--mut);font-size:13px;margin-bottom:12px}
.deg p{color:var(--mut);font-size:14px}
.deg ul{list-style:none;margin-top:12px;text-align:left}
.deg li{padding:5px 0 5px 22px;position:relative;font-size:14px;color:var(--mut)}
.deg li::before{content:"—";position:absolute;left:0;color:var(--gold)}

/* gallery */
.gal-g{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.gal-g img{width:100%;height:280px;object-fit:cover;border:1px solid var(--line)}

/* quote */
.quote{display:grid;grid-template-columns:.85fr 1.15fr;gap:46px;align-items:center}
.quote img{width:100%;height:420px;object-fit:cover;border:1px solid var(--line)}
.quote blockquote{font-family:'Gloock',serif;font-size:23px;line-height:1.5;margin-bottom:16px}
.quote blockquote em{font-style:italic;color:var(--vino)}
.quote .who{color:var(--mut)}

/* form */
.form-g{display:grid;grid-template-columns:1fr 1fr;gap:46px}
.fg{margin-bottom:16px}
.fg label{display:block;margin-bottom:7px;font-weight:600;font-size:14px}
input,select,textarea{width:100%;background:#fff;border:1px solid var(--line);border-radius:2px;color:var(--ink);padding:12px 14px;font-family:inherit;font-size:15px}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--vino)}
.fnote{font-size:13px;color:var(--mut);margin-top:10px}
.ok-msg{display:none;background:#eee7d8;border:1px solid var(--gold);color:#6b5320;padding:16px;border-radius:2px;margin-top:14px}
.k-card{background:var(--card);border:1px solid var(--line);padding:24px;margin-bottom:16px}
.k-card h3{font-size:17.5px;margin-bottom:6px}
.k-card p,.k-card a{color:var(--mut);font-size:15px}

.band{background:var(--vino);color:#f6f1e8;padding:66px 0;text-align:center}
.band h2{font-size:clamp(25px,3.6vw,38px);font-family:'Gloock',serif}
.band h2 em{font-style:italic;color:var(--gold)}
.band p{color:#d9c0ba;margin:10px 0 24px}
.band a{background:var(--gold);color:#2c1a1e;display:inline-block;padding:14px 32px;border-radius:2px;font-weight:700}

footer{background:var(--vino-d);color:#c8b5b0;padding:50px 0 38px}
.f-g{display:grid;grid-template-columns:2fr 1fr 1fr;gap:36px;max-width:1060px;margin:0 auto;padding:0 24px}
footer h4{font-family:'Gloock',serif;color:#f6f1e8;font-size:17px;margin-bottom:12px}
footer a,footer p{color:#c8b5b0;font-size:14.5px;display:block;margin-bottom:8px}
footer a:hover{color:#fff}
.f-bot{max-width:1060px;margin:32px auto 0;padding:18px 24px 0;border-top:1px solid rgba(255,255,255,.12);font-size:13px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

.phero{background:var(--vino);color:#f6f1e8}
.phero .in{max-width:1060px;margin:0 auto;padding:56px 24px 48px}
.phero .kicker{color:var(--gold);font-weight:600;letter-spacing:.24em;text-transform:uppercase;font-size:12px;display:block;margin-bottom:12px}
.phero h1{font-size:clamp(30px,4.4vw,48px)}
.phero h1 em{font-style:italic;color:var(--gold)}
.phero p{color:#d9c0ba;max-width:600px;margin-top:12px;font-size:16.5px}
section.hero,section.phero{padding:0}

@media(max-width:980px){
 body{padding-left:0}
 .rail{display:none}
 .ribbon{margin-left:0;padding-left:16px}
 .mtop{display:flex;position:sticky;top:0;z-index:60;background:rgba(246,241,232,.95);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);align-items:center;justify-content:space-between;height:64px;padding:0 20px}
 .mtop .mlogo{font-family:'Gloock',serif;font-size:19px}
 .mtop .mlogo b{color:var(--vino)}
 .mtop .mburger{background:var(--vino);border:0;color:#fff;padding:10px 16px;border-radius:2px;font-family:'Spline Sans',sans-serif;font-size:13.5px;font-weight:600;cursor:pointer;letter-spacing:.06em}
 .vino-g,.deg-g{grid-template-columns:1fr 1fr}
 .quote,.form-g{grid-template-columns:1fr}
 .quote img{height:320px}
 .f-g{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
 .vino-g,.deg-g,.gal-g,.f-g{grid-template-columns:1fr}
 section{padding:56px 0}
 .hero{min-height:420px}
 .hero .in{padding:60px 20px 40px}
 .phero .in{padding:40px 20px 34px}
}
