/* Karanikolas Winery. Hand-built styles.
   Dark, editorial, typographic. No framework. */

/* ─── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--ff-body);background:var(--bg);color:var(--fg);line-height:1.5;font-weight:300;overflow-x:hidden}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
::selection{background:var(--accent);color:var(--bg)}

/* ─── Tokens ────────────────────────────────────────────── */
:root{
  --bg:#0B0908;
  --bg-2:#13100E;
  --fg:#EAE3D4;
  --fg-dim:rgba(234,227,212,.55);
  --fg-faint:rgba(234,227,212,.2);
  --accent:#C19A4D;              /* aged brass */
  --line:rgba(234,227,212,.12);

  /* Per-wine colors derived from each label */
  --wine-red:#931E25;            /* Aetokorfes Merlot/Cab Sauv */
  --wine-rose:#1F2A6A;           /* Aetokorfes Rose / blue label */
  --wine-white:#5C9A82;          /* Aetokorfes Roditis / green label */
  --wine-vigla-red:#0E0B0A;      /* Vigla red - black w/ gold */
  --wine-vigla-white:#13100E;    /* Vigla Malagousia - black w/ gold */

  --ff-display:"GFS Didot","Cormorant Garamond",Georgia,serif;
  --ff-body:"Inter","Helvetica Neue",Arial,sans-serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;

  --w-page:1280px;
  --pad-x:clamp(1.25rem,4vw,3rem);
}

/* Type */
.display{font-family:var(--ff-display);font-weight:400;letter-spacing:-.005em;line-height:1.02}
.h-xxl{font-size:clamp(2.25rem,5.5vw,4.75rem)}
.h-xl{font-size:clamp(2rem,4vw,3.5rem)}
.h-l{font-size:clamp(1.5rem,2.6vw,2.25rem)}
.h-m{font-size:clamp(1.25rem,1.8vw,1.65rem)}
.eyebrow{font-family:var(--ff-mono);font-size:.72rem;font-weight:400;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim)}
.lede{font-family:var(--ff-display);font-style:italic;font-weight:400;font-size:clamp(1.25rem,2.2vw,1.75rem);line-height:1.35;color:var(--fg);max-width:30ch}
.body-l{font-size:1.05rem;line-height:1.7;color:var(--fg);max-width:62ch}
.body-l p+p{margin-top:1.1em}

/* ─── Layout ────────────────────────────────────────────── */
.wrap{max-width:var(--w-page);margin:0 auto;padding-inline:var(--pad-x)}
.section{padding-block:clamp(5rem,10vh,9rem)}
.full{min-height:100vh;display:grid;align-content:center}
.rule{height:1px;background:var(--line);width:100%}

/* ─── Header / Nav ──────────────────────────────────────── */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.25rem var(--pad-x);display:flex;justify-content:space-between;align-items:center;background:linear-gradient(180deg,rgba(11,9,8,.92),rgba(11,9,8,.5) 70%,rgba(11,9,8,0))}
@media(min-width:721px){
  .nav{backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
}
.nav__brand{font-family:var(--ff-display);font-size:1.15rem;letter-spacing:.04em;display:flex;align-items:center;gap:.85rem}
.nav__brand small{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;display:block;color:var(--fg-dim);margin-top:.15rem}
.nav__logo{height:34px;width:auto;display:block}
.nav__logo[data-fallback]{display:none}
.foot__logo{height:42px;width:auto;display:block;margin-bottom:1rem}
.foot__logo[data-fallback]{display:none}
.nav__links{display:flex;gap:clamp(1rem,3vw,2.25rem);align-items:center;font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}
.nav__links a{color:var(--fg-dim);transition:color .25s ease;position:relative;padding-block:.25rem}
.nav__links a:hover,.nav__links a.is-current{color:var(--fg)}
.nav__links a.is-current::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:1px;background:var(--accent)}
.lang{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--ff-mono);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase}
.lang a{color:var(--fg-dim)}.lang a.is-current{color:var(--accent)}
.lang span{color:var(--fg-faint)}

/* Hamburger toggle (mobile only) */
.nav__toggle{display:none;width:38px;height:38px;background:none;border:0;cursor:pointer;padding:0;position:relative;z-index:110}
.nav__toggle span{position:absolute;left:8px;right:8px;height:1px;background:var(--fg);transition:transform .3s ease,top .3s ease,opacity .2s ease}
.nav__toggle span:nth-child(1){top:14px}
.nav__toggle span:nth-child(2){top:22px}
.nav.is-open .nav__toggle span:nth-child(1){top:18px;transform:rotate(45deg)}
.nav.is-open .nav__toggle span:nth-child(2){top:18px;transform:rotate(-45deg)}

@media(max-width:720px){
  .nav__toggle{display:block}
  .nav__brand small{display:none}
  .nav__brand-text{font-size:.95rem}
  .nav__links{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:0;padding:6rem var(--pad-x) 4rem;z-index:99;opacity:0;pointer-events:none;transform:translateY(-1rem);transition:opacity .35s ease,transform .35s ease;text-align:center}
  .nav.is-open .nav__links{opacity:1;pointer-events:auto;transform:translateY(0)}
  .nav__links > a{display:block;font-family:var(--ff-display);font-size:2.25rem;letter-spacing:-.01em;text-transform:none;color:var(--fg);font-weight:400;line-height:1;padding:.85rem 0}
  .nav__links > a.is-current{color:var(--accent)}
  .nav__links > a.is-current::after{display:none}
  .nav__links .lang{margin-top:2.5rem;padding-top:2rem;border-top:1px solid var(--line);display:inline-flex;gap:1rem;align-items:center;min-width:8rem;justify-content:center}
  .nav__links .lang a{font-family:var(--ff-mono);font-size:1rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim)}
  .nav__links .lang a.is-current{color:var(--accent)}
  .nav__links .lang span{color:var(--fg-faint);font-size:1rem}
}

/* Hero */
.hero{position:relative;min-height:92svh;display:flex;flex-direction:column;justify-content:space-between;padding-block:6.5rem clamp(3rem,6vh,4.5rem);overflow:hidden}
.hero__figures{padding-top:2rem}
.hero__figures .figures{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem 2.5rem;border-top:1px solid var(--line);padding-top:1.75rem;margin-top:0}
.hero__figures .figures div{padding-block:.25rem}
.hero__figures .figures dt{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:.4rem}
.hero__figures .figures dd{font-family:var(--ff-display);font-size:clamp(1.75rem,2.8vw,2.5rem);line-height:1}
.hero__figures .figures small{font-family:var(--ff-body);font-size:.85rem;color:var(--fg-dim);font-weight:300;margin-left:.25rem}
@media(max-width:760px){.hero__figures .figures{grid-template-columns:repeat(2,1fr);gap:1.5rem}}
.hero__bg{position:absolute;inset:0;background:radial-gradient(120% 80% at 50% 100%, rgba(193,154,77,.06), transparent 60%),radial-gradient(80% 60% at 0% 0%, rgba(147,30,37,.04), transparent 60%),var(--bg);z-index:-1}
.hero__ridge{position:absolute;left:0;right:0;bottom:0;width:100%;height:auto;opacity:.12;z-index:-1}
.hero__meta{display:flex;flex-wrap:wrap;gap:1.5rem;font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:1.75rem}
.hero__meta span+span{position:relative;padding-left:1.75rem}
.hero__meta span+span::before{content:"";position:absolute;left:0;top:50%;width:.85rem;height:1px;background:var(--fg-faint)}
.hero__title{font-family:var(--ff-display);font-size:clamp(2.5rem,5.5vw,4.75rem);line-height:1.04;letter-spacing:-.005em;max-width:18ch}
.hero__title em{font-style:italic;color:var(--accent);font-weight:400}
.hero__sub{margin-top:1.5rem;font-family:var(--ff-body);font-size:clamp(1rem,1.2vw,1.1rem);color:var(--fg-dim);max-width:48ch;line-height:1.6;font-weight:300}
.hero__scroll{position:absolute;right:var(--pad-x);bottom:2rem;font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);writing-mode:vertical-rl;rotate:180deg;display:flex;align-items:center;gap:1rem}
.hero__scroll::after{content:"";display:block;width:1px;height:2.5rem;background:linear-gradient(180deg,var(--fg-faint),transparent)}

/* Bird mark */
.bird{display:inline-block;width:.85em;height:auto;vertical-align:.05em;color:var(--accent)}

/* ─── Section intro pattern (eyebrow + heading + lede) ──── */
.intro{display:grid;grid-template-columns:1fr;gap:2rem;align-items:start;margin-bottom:4rem}
@media(min-width:880px){.intro{grid-template-columns:1fr 1.4fr;gap:5rem}}
.intro__lead .eyebrow{margin-bottom:1.25rem}

/* ─── Story split ───────────────────────────────────────── */
.story{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:880px){.story{grid-template-columns:1fr 1fr;gap:5rem;align-items:end}}
.story figure{position:relative}
.story figcaption{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-dim);margin-top:1rem}
.story__placeholder{aspect-ratio:3/4;background:linear-gradient(135deg,#1A1614,#0E0B0A);border:1px solid var(--line);display:grid;place-content:center;color:var(--fg-faint);font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase}

/* Wine collection preview (home page grid) */
.collection{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin-top:3rem}
@media(max-width:880px){.collection{grid-template-columns:repeat(2,1fr)}}
.collection__item{position:relative;aspect-ratio:1/2;border:1px solid var(--line);overflow:hidden;display:block;transition:transform .5s ease}
.collection__item:hover{transform:translateY(-4px)}
.collection__item .swatch{position:absolute;inset:0;opacity:.95;transition:opacity .35s ease;z-index:1}
.collection__item:hover .swatch{opacity:1}
.collection__item .bottle{position:absolute;left:50%;top:6%;transform:translateX(-50%);height:92%;width:auto;max-width:88%;object-fit:contain;object-position:top center;z-index:2;filter:drop-shadow(0 25px 40px rgba(0,0,0,.45))}
.collection__item .label{position:absolute;left:0;right:0;bottom:0;padding:1rem .85rem;font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.9);background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));z-index:3;text-align:center}
.collection__item .num{position:absolute;top:.75rem;left:.85rem;font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.18em;color:rgba(255,255,255,.7);z-index:3}

/* Wines page poster panels */
.poster{position:relative;min-height:100svh;display:grid;grid-template-columns:1fr;align-items:center;overflow:hidden;padding:8rem var(--pad-x) 5rem}
@media(min-width:980px){.poster{grid-template-columns:1.05fr .95fr;padding-block:6rem}}
.poster__bg{position:absolute;inset:0;z-index:0}
.poster__bg::before{content:"";position:absolute;inset:0;background:radial-gradient(140% 90% at 50% 100%,rgba(0,0,0,.45),transparent 70%)}
.poster__num{position:absolute;top:6rem;left:var(--pad-x);font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.55);z-index:3}
.poster__visual{position:relative;z-index:2;display:grid;place-items:center;padding:2rem}
.poster__visual .bottle{height:min(78vh,720px);width:auto;filter:drop-shadow(0 60px 80px rgba(0,0,0,.55))}
.poster__text{position:relative;z-index:2;padding:2rem clamp(1rem,4vw,3rem);color:#fff}
.poster__text .eyebrow{color:rgba(255,255,255,.7)}
.poster__text .name{font-family:var(--ff-display);font-weight:400;line-height:.95;letter-spacing:-.01em;font-size:clamp(2.75rem,6.5vw,5.5rem);margin-block:.5rem 0;color:#fff}
.poster__text .name em{font-style:italic;font-weight:400}
.poster__text .vars{font-family:var(--ff-mono);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.85);margin-top:1.5rem}
.poster__text .lede{color:rgba(255,255,255,.95);margin-top:1.5rem;max-width:34ch}
.poster__text .specs{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem 2.5rem;margin-top:2.5rem;border-top:1px solid rgba(255,255,255,.18);padding-top:1.5rem;max-width:32rem}
.poster__text .specs dt{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:.25rem}
.poster__text .specs dd{font-family:var(--ff-display);font-size:1.15rem;color:#fff;margin-bottom:1rem}
.poster__notes{margin-top:2rem;max-width:38rem;font-size:.95rem;line-height:1.65;color:rgba(255,255,255,.85)}
.poster__notes p+p{margin-top:.9em}

/* Per-poster theming via attribute */
.poster[data-wine="aetokorfes-red"]   .poster__bg{background:linear-gradient(160deg,#B22730 0%,#641418 75%,#3A0A0D 100%)}
.poster[data-wine="aetokorfes-rose"]  .poster__bg{background:linear-gradient(160deg,#2C3A8C 0%,#192466 70%,#0E1542 100%)}
.poster[data-wine="aetokorfes-white"] .poster__bg{background:linear-gradient(160deg,#6FB39B 0%,#3F7E69 70%,#234C3F 100%)}
.poster[data-wine="vigla-red"]        .poster__bg{background:linear-gradient(160deg,#1F1C1A 0%,#0E0B0A 70%,#000 100%)}
.poster[data-wine="vigla-red"]        .poster__num,.poster[data-wine="vigla-red"] .poster__text .name em{color:var(--accent)}
.poster[data-wine="vigla-white"]      .poster__bg{background:linear-gradient(160deg,#1F1C1A 0%,#0E0B0A 70%,#000 100%)}
.poster[data-wine="vigla-white"]      .poster__num,.poster[data-wine="vigla-white"] .poster__text .name em{color:var(--accent)}

/* Reversed layout every other panel for rhythm */
.poster.is-flip{grid-template-columns:1fr}
@media(min-width:980px){
  .poster.is-flip{grid-template-columns:.95fr 1.05fr}
  .poster.is-flip .poster__visual{order:2}
  .poster.is-flip .poster__text{order:1;text-align:left}
}

/* ─── Visit page ────────────────────────────────────────── */
.visit__grid{display:grid;grid-template-columns:1fr;gap:3rem}
@media(min-width:880px){.visit__grid{grid-template-columns:1fr 1fr;gap:5rem}}
.visit__block dt{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:.5rem}
.visit__block dd{font-family:var(--ff-display);font-size:1.5rem;margin-bottom:2rem;line-height:1.3}
.visit__block dd a{border-bottom:1px solid var(--fg-faint);transition:border-color .25s ease}
.visit__block dd a:hover{border-color:var(--accent)}
.map{aspect-ratio:4/3;border:1px solid var(--line);overflow:hidden;filter:grayscale(.4) contrast(1.05) brightness(.9)}
.map iframe{width:100%;height:100%;border:0;filter:invert(.92) hue-rotate(180deg)}

/* ─── Footer ────────────────────────────────────────────── */
.foot{padding:5rem var(--pad-x) 3rem;border-top:1px solid var(--line);margin-top:6rem}
.foot__row{display:grid;grid-template-columns:1fr;gap:2rem;margin-bottom:3rem;max-width:var(--w-page);margin-inline:auto}
@media(min-width:760px){.foot__row{grid-template-columns:2fr 1fr 1fr 1fr}}
.foot h4{font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:1rem}
.foot p,.foot a{font-family:var(--ff-display);font-size:1.1rem;line-height:1.5}
.foot a{color:var(--fg);border-bottom:1px solid transparent;transition:border-color .25s ease}
.foot a:hover{border-color:var(--accent)}
.foot__brand p{color:var(--fg-dim);max-width:34ch;font-size:.95rem;line-height:1.6}
.foot__bottom{max-width:var(--w-page);margin-inline:auto;display:flex;justify-content:space-between;font-family:var(--ff-mono);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);padding-top:2rem;border-top:1px solid var(--line)}

/* ─── Reveal-on-scroll utility ──────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(20px);transition:opacity 1s cubic-bezier(.2,.6,.2,1),transform 1s cubic-bezier(.2,.6,.2,1)}
[data-reveal].is-in{opacity:1;transform:none}

/* ─── Tasting CTA ───────────────────────────────────────── */
.cta{display:inline-flex;align-items:center;gap:1rem;padding:1.1rem 1.5rem;border:1px solid var(--fg-faint);font-family:var(--ff-mono);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:var(--fg);transition:border-color .25s ease,background-color .25s ease}
.cta:hover{border-color:var(--accent);background:rgba(193,154,77,.05)}
.cta svg{width:.85em;height:auto}

/* ─── Bottle placeholder (until real PNGs are processed) ─ */
.bottle-placeholder{width:240px;aspect-ratio:1/3;background:linear-gradient(180deg,#2a2421 0%,#3a3530 40%,#2a2421 100%);border-radius:120px 120px 8px 8px / 220px 220px 8px 8px;display:grid;place-content:center;color:rgba(255,255,255,.4);font-family:var(--ff-mono);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;text-align:center;padding:1rem;box-shadow:inset 0 0 60px rgba(0,0,0,.4)}

/* ─── Quotes / blockquotes ──────────────────────────────── */
.quote{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.5rem,3vw,2.5rem);line-height:1.3;max-width:36ch;color:var(--fg);position:relative;padding-left:1.5rem;border-left:1px solid var(--accent);margin:3rem 0}
.quote cite{display:block;margin-top:1.25rem;font-family:var(--ff-mono);font-size:.7rem;font-style:normal;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim)}

/* Wide cinematic photo */
.photo-wide{margin-top:4rem;aspect-ratio:21/9;overflow:hidden;border:1px solid var(--line);position:relative;background:var(--bg-2)}
.photo-wide img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1.2s cubic-bezier(.2,.6,.2,1)}
.photo-wide:hover img{transform:scale(1.03)}
.photo-wide figcaption{position:absolute;bottom:1rem;left:1.25rem;font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.88);background:rgba(0,0,0,.45);padding:.45rem .85rem;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
@media(max-width:760px){.photo-wide{aspect-ratio:16/9}}

/* Numbers (vineyard stats etc) */
.figures{display:grid;grid-template-columns:1fr;gap:.5rem;margin-top:4rem;border-top:1px solid var(--line);padding-top:2rem}
@media(min-width:600px){.figures{grid-template-columns:repeat(4,1fr);gap:2rem}}
.figures dt{font-family:var(--ff-mono);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;color:var(--fg-dim);margin-bottom:.5rem}
.figures dd{font-family:var(--ff-display);font-size:clamp(2rem,3.5vw,3rem);line-height:1}
.figures div{padding-block:1rem}
.figures small{font-family:var(--ff-body);font-size:.85rem;color:var(--fg-dim);font-weight:300;margin-left:.25rem}
