/* ============================================================
   AL-CANTÀRA — Design system (multi-page, IT/EN)
   Style:  Editorial luxury · "Etna Editorial"
   Type:   Playfair Display + Inter + Cormorant (poetry)
   Palette: lava black + warm ivory + brand gold #AE9A63
   Shared stylesheet for every page.
   ============================================================ */

:root{
  --lava:#14110E; --lava-2:#1D1813; --lava-3:#2A231C; --ink:#211C17;
  --ivory:#F8F3E9; --ivory-2:#F1E9DA; --paper:#FFFFFF;
  --gold:#AE9A63; --gold-soft:#C5B27E; --gold-deep:#8A7642;
  --wine:#6E1A22; --wine-soft:#8A2A30;
  --text-dark:#2A241D; --text-muted:#6F665A; --text-light:#ECE3D2; --text-faint:#B9AE99;
  --line:#DED3BF; --line-dark:rgba(174,154,99,.22);
  --maxw:1240px; --gutter:clamp(1.25rem,4vw,4rem);
  --ease:cubic-bezier(.21,.6,.35,1);
  --serif:"Playfair Display",Georgia,serif;
  --poem:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  --hh:84px; /* header height reserve */
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } }
body{
  margin:0; font-family:var(--sans); color:var(--text-dark); background:var(--ivory);
  font-size:16px; line-height:1.65; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* film grain overlay */
body::after{
  content:""; position:fixed; inset:0; z-index:9999; pointer-events:none;
  opacity:.04; mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- shared atoms ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gutter); }
.narrow{ max-width:820px; }
.eyebrow{ font-size:.72rem; font-weight:600; letter-spacing:.32em; text-transform:uppercase; color:var(--gold-deep); display:inline-flex; align-items:center; gap:.7rem; }
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--gold); display:inline-block; }
.eyebrow.center{ justify-content:center; }
.eyebrow.center::after{ content:""; width:34px; height:1px; background:var(--gold); display:inline-block; }
.eyebrow.light{ color:var(--gold-soft); }

h1,h2,h3,h4{ font-family:var(--serif); font-weight:500; line-height:1.1; margin:0; letter-spacing:-.01em; }
.h-display{ font-size:clamp(2.6rem,7vw,5.4rem); }
.h-page{ font-size:clamp(2.3rem,5.5vw,4rem); font-weight:400; }
.h-section{ font-size:clamp(2rem,4.6vw,3.4rem); font-weight:400; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--text-muted); line-height:1.8; }
p{ margin:0 0 1.1em; }

.btn{ display:inline-flex; align-items:center; gap:.6rem; font-size:.78rem; font-weight:600; letter-spacing:.16em; text-transform:uppercase; padding:1.05rem 2rem; border-radius:2px; transition:all .35s var(--ease); border:1px solid transparent; white-space:nowrap; }
.btn .ar{ transition:transform .35s var(--ease); }
.btn:hover .ar{ transform:translateX(4px); }
.btn-gold{ background:var(--gold); color:var(--lava); }
.btn-gold:hover{ background:var(--gold-soft); }
.btn-ghost{ border-color:rgba(174,154,99,.55); color:var(--gold-soft); }
.btn-ghost:hover{ background:var(--gold); color:var(--lava); border-color:var(--gold); }
.btn-dark{ border-color:var(--ink); color:var(--ink); }
.btn-dark:hover{ background:var(--ink); color:var(--ivory); }
.btn-sm{ padding:.8rem 1.4rem; font-size:.72rem; }

/* reveal */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .9s var(--ease),transform .9s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; }
.reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1!important; transform:none!important; transition:none!important; } }

/* ============================================================ HEADER */
.site-header{ position:fixed; inset:0 0 auto 0; z-index:100; padding:.55rem 0; transition:background .4s var(--ease),box-shadow .4s var(--ease),padding .4s var(--ease); background:linear-gradient(to bottom,rgba(20,17,14,.55),rgba(20,17,14,0)); }
.site-header.solid{ background:rgba(20,17,14,.93); -webkit-backdrop-filter:blur(14px); backdrop-filter:blur(14px); box-shadow:0 1px 0 var(--line-dark),0 14px 40px -28px rgba(0,0,0,.9); }
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.brand{ display:flex; align-items:center; gap:.85rem; }
.brand img{ height:54px; width:auto; transition:height .4s var(--ease); }
.site-header.solid .brand img{ height:46px; }
.brand-txt{ font-family:var(--serif); color:var(--ivory); font-size:1.35rem; line-height:1; letter-spacing:.02em; }
.brand-txt small{ display:block; font-family:var(--sans); font-size:.56rem; font-weight:600; letter-spacing:.34em; color:var(--gold-soft); text-transform:uppercase; margin-top:.34rem; }
.menu{ display:flex; align-items:center; gap:1.9rem; }
.menu a{ color:var(--text-light); font-size:.82rem; font-weight:500; letter-spacing:.04em; position:relative; padding:.4rem 0; transition:color .3s; }
.menu a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--gold); transition:width .35s var(--ease); }
.menu a:hover{ color:var(--gold-soft); }
.menu a:hover::after,.menu a.active::after{ width:100%; }
.menu a.active{ color:var(--gold-soft); }
.nav-right{ display:flex; align-items:center; gap:1.2rem; }
.lang{ display:flex; gap:.5rem; font-size:.72rem; font-weight:600; letter-spacing:.1em; color:var(--text-faint); }
.lang a.on{ color:var(--gold-soft); }
.lang span{ opacity:.4; }
.header-cta{ font-size:.72rem; font-weight:600; letter-spacing:.14em; text-transform:uppercase; color:var(--lava); background:var(--gold); padding:.7rem 1.25rem; border-radius:2px; transition:background .3s; }
.header-cta:hover{ background:var(--gold-soft); }
.burger{ display:none; background:none; border:0; width:42px; height:42px; padding:0; flex-direction:column; gap:5px; align-items:center; justify-content:center; }
.burger span{ width:24px; height:1.6px; background:var(--ivory); transition:.3s var(--ease); }
.mobile-menu{ position:fixed; inset:0; z-index:99; background:var(--lava); display:flex; flex-direction:column; justify-content:center; padding:2rem var(--gutter); transform:translateX(100%); transition:transform .5s var(--ease); visibility:hidden; }
.mobile-menu.open{ transform:none; visibility:visible; }
.mobile-menu a{ font-family:var(--serif); font-size:1.7rem; color:var(--ivory); padding:.45rem 0; border-bottom:1px solid var(--line-dark); }
.mobile-menu a.active{ color:var(--gold-soft); }
.mobile-menu .mm-lang{ margin-top:1.6rem; display:flex; gap:1rem; font-family:var(--sans); font-size:.85rem; letter-spacing:.1em; }
.mobile-menu .mm-foot{ margin-top:1.6rem; color:var(--text-faint); font-size:.85rem; line-height:1.9; }

/* ============================================================ HERO (home) */
.hero{ position:relative; min-height:100vh; min-height:100svh; display:flex; align-items:flex-end; color:var(--ivory); overflow:hidden; }
.hero-bg{ position:absolute; inset:0; z-index:0; }
.hero-bg img{ width:100%; height:100%; object-fit:cover; }
.hero-bg.kenburns img{ animation:kb 20s ease-out forwards; }
@keyframes kb{ from{ transform:scale(1.06); } to{ transform:scale(1); } }
@media (prefers-reduced-motion:reduce){ .hero-bg.kenburns img{ animation:none; } }
.hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(15,12,10,.95) 4%,rgba(15,12,10,.32) 46%,rgba(15,12,10,.55) 100%),radial-gradient(120% 80% at 80% 0%,rgba(15,12,10,.22),transparent 60%); }
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(3rem,9vh,7rem); padding-top:9rem; }
.hero h1{ margin:.7rem 0 0; }
.hero .h1-sub{ font-family:var(--poem); font-style:italic; font-weight:400; font-size:clamp(1.4rem,3vw,2.2rem); color:var(--gold-soft); display:block; margin-top:.2rem; letter-spacing:.01em; }
.hero-lead{ max-width:34rem; margin:1.6rem 0 2.2rem; color:var(--text-light); font-size:clamp(1rem,1.5vw,1.2rem); line-height:1.8; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:1rem; }
.scroll-cue{ position:absolute; left:var(--gutter); bottom:1.7rem; z-index:2; display:flex; align-items:center; gap:.7rem; color:var(--text-faint); font-size:.66rem; font-weight:600; letter-spacing:.28em; text-transform:uppercase; }
.scroll-cue .ln{ width:50px; height:1px; background:var(--gold); transform-origin:left; animation:cue 2.4s var(--ease) infinite; }
@keyframes cue{ 0%,100%{ transform:scaleX(.4); opacity:.5; } 50%{ transform:scaleX(1); opacity:1; } }
@media (prefers-reduced-motion:reduce){ .scroll-cue .ln{ animation:none; } }
.hero-meta{ position:absolute; right:var(--gutter); bottom:1.7rem; z-index:2; text-align:right; color:var(--text-faint); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; line-height:2; }
.hero-meta b{ color:var(--gold-soft); font-weight:600; }

/* ============================================================ PAGE HERO (inner) */
.page-hero{ position:relative; min-height:60vh; min-height:60svh; display:flex; align-items:flex-end; color:var(--ivory); overflow:hidden; }
.page-hero-bg{ position:absolute; inset:0; z-index:0; }
.page-hero-bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero-bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top,rgba(15,12,10,.92) 2%,rgba(15,12,10,.35) 55%,rgba(15,12,10,.5) 100%); }
.page-hero-inner{ position:relative; z-index:2; width:100%; padding:9rem 0 clamp(2.5rem,5vw,4rem); }
.breadcrumb{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-faint); margin-bottom:1rem; display:flex; gap:.6rem; align-items:center; }
.breadcrumb a:hover{ color:var(--gold-soft); }
.breadcrumb span{ color:var(--gold); }
.page-hero h1{ color:var(--ivory); max-width:18ch; }
.page-hero .ph-sub{ color:var(--text-light); max-width:46ch; margin-top:1.1rem; font-size:clamp(1rem,1.5vw,1.18rem); line-height:1.75; }

/* ============================================================ AWARDS STRIP (readable chips) */
.awards{ background:var(--lava); color:var(--ivory); padding:clamp(3rem,6vw,4.5rem) 0; }
.awards-top{ display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:2rem; margin-bottom:2.6rem; }
.awards-top .lab{ max-width:26rem; }
.awards-top h3{ font-size:clamp(1.5rem,2.6vw,2.1rem); font-weight:400; color:var(--ivory); margin-top:.6rem; }
.scores{ display:flex; gap:clamp(1.5rem,4vw,3.2rem); }
.score{ text-align:center; }
.score .n{ font-family:var(--serif); font-size:clamp(2.2rem,4vw,3rem); color:var(--gold); line-height:1; }
.score .l{ font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--text-faint); margin-top:.5rem; }
.guides{ display:grid; grid-template-columns:repeat(6,1fr); gap:1rem; align-items:stretch; border-top:1px solid var(--line-dark); padding-top:2.4rem; }
.guide{ background:#F4EEE2; border-radius:4px; height:78px; display:flex; align-items:center; justify-content:center; padding:.9rem 1.1rem; transition:transform .35s var(--ease),box-shadow .35s var(--ease); }
.guide:hover{ transform:translateY(-3px); box-shadow:0 18px 30px -18px rgba(0,0,0,.6); }
.guide img{ max-height:46px; max-width:100%; width:auto; object-fit:contain; }

/* ============================================================ SECTIONS */
.sec{ padding:clamp(4.5rem,9vw,8rem) 0; position:relative; }
.sec-sm{ padding:clamp(3rem,6vw,5rem) 0; }
.bg-ivory2{ background:var(--ivory-2); }
.bg-lava{ background:var(--lava); color:var(--ivory); }
.bg-lava2{ background:var(--lava-2); color:var(--ivory); }
.sec-head{ max-width:46rem; margin-bottom:clamp(2.5rem,5vw,4rem); }
.sec-head.center{ margin-inline:auto; text-align:center; }
.sec-head h2{ margin-top:1rem; }
.sec-head p{ margin-top:1.3rem; }
.on-dark h1,.on-dark h2,.on-dark h3,.on-dark h4,.bg-lava h2,.bg-lava2 h2{ color:var(--ivory); }

/* split editorial */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(2.5rem,6vw,6rem); align-items:center; }
.split.rev .split-media{ order:2; }
.split-media{ position:relative; }
.split-media img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:2px; }
.split-media.wide img{ aspect-ratio:4/3; }
.split-media .frame{ position:absolute; inset:14px; border:1px solid var(--gold); pointer-events:none; opacity:.55; border-radius:2px; }
.split-media .tagimg{ position:absolute; left:-22px; bottom:34px; background:var(--lava); color:var(--gold-soft); font-family:var(--serif); font-size:1rem; padding:.9rem 1.4rem; box-shadow:0 24px 50px -24px rgba(0,0,0,.6); }
.split-media .tagimg.right{ left:auto; right:-22px; }

/* grapes trio (compact) */
.grapes{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; margin-top:2.4rem; }
.grape{ border-top:1px solid var(--line); padding-top:1.2rem; }
.grape h4{ font-size:1.25rem; }
.grape .vt{ font-size:.66rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); font-weight:600; }
.grape p{ font-size:.92rem; color:var(--text-muted); margin:.5rem 0 0; }

/* vitigno cards (rich, with image) */
.vitigni{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.4rem,3vw,2.2rem); }
.vitigno{ background:var(--paper); border:1px solid var(--line); border-radius:4px; overflow:hidden; display:flex; flex-direction:column; transition:transform .45s var(--ease),box-shadow .45s var(--ease); }
.vitigno:hover{ transform:translateY(-6px); box-shadow:0 34px 60px -34px rgba(40,30,15,.4); }
.vitigno-img{ aspect-ratio:4/3; overflow:hidden; }
.vitigno-img img{ width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.vitigno:hover .vitigno-img img{ transform:scale(1.05); }
.vitigno-body{ padding:1.6rem 1.5rem 1.9rem; }
.vitigno-body .vt{ font-size:.64rem; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-deep); font-weight:700; }
.vitigno-body h3{ font-size:1.6rem; margin:.5rem 0 .8rem; }
.vitigno-body p{ font-size:.92rem; color:var(--text-muted); margin:0; }
.vitigno-body .chips{ display:flex; flex-wrap:wrap; gap:.4rem; margin-top:1.1rem; }
.vitigno-body .chip{ font-size:.64rem; letter-spacing:.08em; text-transform:uppercase; color:var(--gold-deep); border:1px solid var(--line); border-radius:30px; padding:.3rem .7rem; }

/* manifesto poetry */
.manifesto{ background:var(--lava); color:var(--ivory); text-align:center; overflow:hidden; }
.manifesto .wrap{ position:relative; z-index:2; }
.manifesto .quote{ font-family:var(--poem); font-style:italic; font-weight:400; font-size:clamp(1.7rem,4vw,3.1rem); line-height:1.34; color:var(--ivory); max-width:30ch; margin:1.8rem auto; }
.manifesto .quote em{ color:var(--gold-soft); }
.manifesto .sig{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--text-faint); }
.manifesto .deco{ position:absolute; font-family:var(--serif); font-size:30rem; line-height:0; color:rgba(174,154,99,.06); top:46%; left:50%; transform:translate(-50%,-50%); pointer-events:none; user-select:none; }

/* prose article */
.prose{ max-width:780px; }
.prose.center{ margin-inline:auto; }
.prose p{ font-size:1.06rem; line-height:1.85; color:var(--text-dark); }
.prose p.lead-p{ font-size:1.2rem; color:var(--text-muted); }
.prose h3{ font-size:clamp(1.5rem,2.6vw,2rem); margin:2.4rem 0 1rem; }
.prose .drop::first-letter{ font-family:var(--serif); font-size:3.6em; float:left; line-height:.8; padding:.05em .12em 0 0; color:var(--gold-deep); }
.prose blockquote{ margin:2rem 0; padding:.4rem 0 .4rem 1.6rem; border-left:2px solid var(--gold); font-family:var(--poem); font-style:italic; font-size:1.5rem; line-height:1.4; color:var(--ink); }
.figure{ margin:2.2rem 0; }
.figure img{ width:100%; border-radius:3px; }
.figure figcaption{ font-size:.82rem; color:var(--text-muted); margin-top:.7rem; font-style:italic; }

/* timeline */
.timeline{ position:relative; max-width:840px; margin:0 auto; }
.timeline::before{ content:""; position:absolute; left:0; top:.6rem; bottom:.6rem; width:1px; background:var(--line); }
.tl-item{ position:relative; padding:0 0 2.6rem 2.4rem; }
.tl-item::before{ content:""; position:absolute; left:-5px; top:.45rem; width:11px; height:11px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 4px var(--ivory); }
.bg-ivory2 .tl-item::before{ box-shadow:0 0 0 4px var(--ivory-2); }
.bg-lava .tl-item::before{ box-shadow:0 0 0 4px var(--lava); }
.bg-lava2 .tl-item::before{ box-shadow:0 0 0 4px var(--lava-2); }
.bg-lava .timeline::before,.bg-lava2 .timeline::before{ background:var(--line-dark); }
.tl-year{ font-family:var(--serif); font-size:1.5rem; color:var(--gold-deep); line-height:1; }
.bg-lava .tl-year,.bg-lava2 .tl-year{ color:var(--gold); }
.tl-body{ margin-top:.5rem; color:var(--text-muted); font-size:1rem; line-height:1.75; }
.bg-lava .tl-body,.bg-lava2 .tl-body{ color:var(--text-light); }
.tl-body strong{ color:var(--ink); font-weight:600; }
.bg-lava .tl-body strong,.bg-lava2 .tl-body strong{ color:var(--gold-soft); }

/* catalog */
.filters{ display:flex; flex-wrap:wrap; gap:.6rem; justify-content:center; margin-bottom:3rem; }
.filter{ background:transparent; border:1px solid var(--line); color:var(--text-muted); font-size:.74rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; padding:.7rem 1.3rem; border-radius:40px; transition:all .3s var(--ease); }
.filter:hover{ border-color:var(--gold); color:var(--ink); }
.filter.on{ background:var(--lava); border-color:var(--lava); color:var(--gold-soft); }
.wine-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1rem,2vw,1.6rem); }
.wine{ background:var(--paper); border:1px solid var(--line); border-radius:3px; overflow:hidden; display:flex; flex-direction:column; transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s; }
.wine:hover{ transform:translateY(-7px); box-shadow:0 34px 60px -34px rgba(40,30,15,.45); border-color:var(--gold); }
.wine-img{ position:relative; aspect-ratio:1/1.16; display:flex; align-items:center; justify-content:center; background:radial-gradient(120% 90% at 50% 12%,#fff 0%,#F3ECDE 100%); overflow:hidden; }
.wine-img img{ height:88%; width:auto; object-fit:contain; transition:transform .55s var(--ease); filter:drop-shadow(0 18px 24px rgba(0,0,0,.22)); }
.wine:hover .wine-img img{ transform:scale(1.06) translateY(-3px); }
.wine-cat{ position:absolute; top:.8rem; left:.8rem; font-size:.56rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--gold-deep); background:rgba(255,255,255,.85); padding:.32rem .6rem; border-radius:30px; }
.wine-body{ padding:1.1rem 1.15rem 1.3rem; border-top:1px solid var(--line); }
.wine-body h4{ font-size:1.12rem; line-height:1.18; }
.wine-body .den{ font-size:.74rem; letter-spacing:.04em; color:var(--text-muted); margin-top:.4rem; display:flex; align-items:center; gap:.45rem; }
.wine-body .den::before{ content:""; width:14px; height:1px; background:var(--gold); flex:0 0 14px; }
.cat-note{ text-align:center; max-width:40rem; margin:0 auto 2.5rem; color:var(--text-muted); }
.catalog-cta{ text-align:center; margin-top:3.2rem; }

/* metrics */
.metrics{ display:grid; grid-template-columns:repeat(2,1fr); gap:1.6rem 2.2rem; margin-top:2.4rem; }
.metrics.cols4{ grid-template-columns:repeat(4,1fr); }
.metric{ border-top:1px solid var(--line); padding-top:1.1rem; }
.bg-lava .metric,.bg-lava2 .metric{ border-color:var(--line-dark); }
.metric .n{ font-family:var(--serif); font-size:clamp(1.7rem,3vw,2.3rem); color:var(--gold-deep); line-height:1; }
.bg-lava .metric .n,.bg-lava2 .metric .n{ color:var(--gold); }
.metric .t{ font-weight:600; margin-top:.5rem; font-size:.96rem; }
.metric p{ font-size:.86rem; color:var(--text-muted); margin:.3rem 0 0; }
.bg-lava .metric p,.bg-lava2 .metric p{ color:var(--text-faint); }

/* sustainability cards */
.sustain-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.4rem,3vw,2.4rem); }
.scard{ background:var(--paper); border:1px solid var(--line); border-radius:3px; padding:2.2rem 1.8rem; transition:transform .4s var(--ease),box-shadow .4s var(--ease); }
.scard:hover{ transform:translateY(-6px); box-shadow:0 30px 56px -34px rgba(40,30,15,.4); }
.scard .ic{ width:52px; height:52px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:var(--ivory-2); color:var(--gold-deep); margin-bottom:1.4rem; }
.scard .ic svg{ width:24px; height:24px; }
.scard h4{ font-size:1.3rem; }
.scard p{ font-size:.92rem; color:var(--text-muted); margin:.7rem 0 0; }

/* award/Vinitaly highlight band */
.cta-band{ background:linear-gradient(120deg,var(--lava),var(--lava-3)); color:var(--ivory); border-radius:6px; padding:clamp(2.4rem,5vw,4rem); display:grid; grid-template-columns:auto 1fr auto; gap:2rem; align-items:center; }
.cta-band .medal{ width:70px; height:70px; border-radius:50%; border:1px solid var(--gold); display:flex; align-items:center; justify-content:center; color:var(--gold); flex:0 0 70px; }
.cta-band .medal svg{ width:34px; height:34px; }
.cta-band h3{ color:var(--ivory); font-size:clamp(1.4rem,2.4vw,2rem); font-weight:400; }
.cta-band p{ color:var(--text-faint); margin:.5rem 0 0; max-width:46ch; }

/* gallery */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:1rem; }
.gallery-grid img{ width:100%; height:100%; object-fit:cover; border-radius:3px; transition:transform .5s var(--ease),filter .5s; }
.gallery-grid a{ overflow:hidden; border-radius:3px; display:block; }
.gallery-grid a:hover img{ transform:scale(1.05); }
.gallery-grid .tall{ grid-row:span 2; }
.gallery-grid .wide{ grid-column:span 2; }

/* visit / contact */
.visit-grid{ display:grid; grid-template-columns:1.1fr .9fr; gap:clamp(2.5rem,6vw,5rem); align-items:start; }
.contact-rows{ margin-top:2rem; display:grid; gap:1.3rem; }
.crow{ display:flex; gap:1.1rem; align-items:flex-start; }
.crow .ic{ width:40px; height:40px; flex:0 0 40px; border:1px solid var(--line-dark); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--gold); }
.crow .ic svg{ width:18px; height:18px; }
.crow .ct b{ display:block; font-weight:600; color:var(--ivory); font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:.2rem; }
.crow .ct span,.crow .ct a{ color:var(--text-light); font-size:1rem; }
.crow .ct a:hover{ color:var(--gold-soft); }
.visit-card{ background:linear-gradient(180deg,var(--lava-3),var(--lava-2)); border:1px solid var(--line-dark); border-radius:4px; padding:clamp(2rem,4vw,3rem); text-align:center; }
.visit-card .badge{ font-family:var(--serif); font-size:1.1rem; color:var(--gold-soft); }
.visit-card h3{ color:var(--ivory); font-size:1.9rem; margin:.6rem 0 1rem; }
.visit-card p{ color:var(--text-faint); font-size:.95rem; }
.visit-card .btn{ margin-top:1.2rem; width:100%; justify-content:center; }
.opening{ margin-top:1.6rem; border-top:1px solid var(--line-dark); padding-top:1.4rem; display:grid; gap:.5rem; }
.opening .o{ display:flex; justify-content:space-between; font-size:.86rem; color:var(--text-light); }
.opening .o span:last-child{ color:var(--gold-soft); }

/* contact form */
.form{ display:grid; gap:1.2rem; }
.form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field label{ font-size:.72rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-deep); }
.bg-lava .field label,.bg-lava2 .field label{ color:var(--gold-soft); }
.field input,.field textarea,.field select{ font-family:var(--sans); font-size:1rem; color:var(--ink); background:var(--paper); border:1px solid var(--line); border-radius:3px; padding:.85rem 1rem; transition:border-color .3s,box-shadow .3s; }
.bg-lava .field input,.bg-lava .field textarea,.bg-lava .field select,.bg-lava2 .field input,.bg-lava2 .field textarea{ background:rgba(255,255,255,.04); border-color:var(--line-dark); color:var(--ivory); }
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--gold); box-shadow:0 0 0 3px rgba(174,154,99,.18); }
.field textarea{ min-height:130px; resize:vertical; }
.form .note{ font-size:.8rem; color:var(--text-muted); }
.bg-lava .form .note{ color:var(--text-faint); }

/* map */
.map-embed{ border-radius:4px; overflow:hidden; border:1px solid var(--line-dark); min-height:320px; }
.map-embed iframe{ width:100%; height:100%; min-height:320px; border:0; display:block; filter:grayscale(.3) contrast(1.05); }

/* ============================================================ FOOTER */
.site-footer{ background:#100D0B; color:var(--text-faint); padding:clamp(3.5rem,6vw,5rem) 0 2rem; }
.foot-top{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2.5rem; padding-bottom:3rem; border-bottom:1px solid var(--line-dark); }
.foot-brand img{ height:64px; margin-bottom:1.2rem; }
.foot-brand p{ font-size:.9rem; max-width:24rem; line-height:1.8; }
.foot-col h5{ font-size:.72rem; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--gold-soft); margin:0 0 1.2rem; }
.foot-col a{ display:block; font-size:.92rem; padding:.32rem 0; color:var(--text-light); transition:color .25s; }
.foot-col a:hover{ color:var(--gold-soft); }
.foot-bottom{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding-top:1.8rem; font-size:.78rem; letter-spacing:.04em; }
.foot-bottom a:hover{ color:var(--gold-soft); }
.socials{ display:flex; gap:.8rem; }
.socials a{ width:36px; height:36px; border:1px solid var(--line-dark); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--text-faint); transition:.3s; }
.socials a:hover{ border-color:var(--gold); color:var(--gold); }
.socials svg{ width:16px; height:16px; }
.age{ font-size:.72rem; color:var(--text-faint); opacity:.7; margin-top:1.4rem; }

/* ============================================================ RESPONSIVE */
@media (max-width:1000px){
  .menu,.nav-right .lang,.nav-right .header-cta{ display:none; }
  .burger{ display:flex; }
  .guides{ grid-template-columns:repeat(3,1fr); gap:1rem; }
  .wine-grid{ grid-template-columns:repeat(3,1fr); }
  .vitigni{ grid-template-columns:1fr; max-width:520px; margin-inline:auto; }
  .visit-grid{ grid-template-columns:1fr; }
  .foot-top{ grid-template-columns:1fr 1fr; gap:2rem; }
  .cta-band{ grid-template-columns:auto 1fr; }
  .cta-band .btn{ grid-column:1/-1; justify-self:start; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:720px){
  .split{ grid-template-columns:1fr; gap:2.5rem; }
  .split.rev .split-media{ order:0; }
  .grapes{ grid-template-columns:1fr; gap:1rem; }
  .metrics,.metrics.cols4{ grid-template-columns:1fr 1fr; }
  .sustain-grid{ grid-template-columns:1fr; }
  .awards-top{ flex-direction:column; align-items:flex-start; }
  .scores{ width:100%; justify-content:space-between; }
  .wine-grid{ grid-template-columns:repeat(2,1fr); }
  .foot-top{ grid-template-columns:1fr; }
  .hero-meta{ display:none; }
  .form .row2{ grid-template-columns:1fr; }
}
@media (max-width:430px){
  .guides{ grid-template-columns:repeat(2,1fr); }
  .scores{ flex-wrap:wrap; gap:1.4rem; }
  .score{ flex:1 0 40%; }
  .wine-grid{ grid-template-columns:1fr 1fr; }
}
