/* ============================================================
   VALENTIN GRÜNER — Field dossier site
   Design system: National Geographic / Explorers Club
   Near-black base, one loud expedition yellow.
   Archivo (display) · Spectral (story) · JetBrains Mono (labels)
   ============================================================ */

:root{
  /* palette */
  --base:#0E1012;
  --panel:#181B1F;
  --panel-2:#1F2429;
  --accent:#FFC400;
  --accent-hover:#E0A200;
  --teal:#15303B;
  --red:#C8362B;
  --light:#F5F4EF;
  --white:#FFFFFF;
  --muted:#8A8F94;
  --hair:rgba(245,244,239,.14);
  --hair-strong:rgba(245,244,239,.28);

  /* tweakable */
  --hero-overlay:.58;     /* 0..1 darkness of hero gradient */
  --mo:1;                 /* motion duration multiplier (higher = slower) */

  /* spacing scale: 4 8 16 24 40 64 96 */
  --s1:4px; --s2:8px; --s3:16px; --s4:24px; --s5:40px; --s6:64px; --s7:96px;

  --maxw:1120px;

  --ff-display:"Archivo",system-ui,sans-serif;
  --ff-body:"Spectral",Georgia,serif;
  --ff-mono:"JetBrains Mono",ui-monospace,monospace;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

body{
  margin:0;
  background:var(--base);
  color:var(--light);
  font-family:var(--ff-body);
  font-weight:400;
  font-size:18px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}

/* ---- typography primitives ---- */
.display{
  font-family:var(--ff-display);
  font-weight:900;
  font-stretch:72%;
  text-transform:uppercase;
  line-height:.9;
  letter-spacing:-.01em;
  color:var(--white);
  margin:0;
}
.mono{
  font-family:var(--ff-mono);
  text-transform:uppercase;
  letter-spacing:.18em;
  font-weight:500;
  font-size:12px;
  color:var(--muted);
}
.mono.accent{color:var(--accent)}
.serif-lead{font-family:var(--ff-body);font-weight:300;font-size:clamp(22px,2.6vw,30px);line-height:1.5}
em{font-style:italic;color:var(--white)}

/* ---- layout ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--s4)}
section{position:relative}

/* faint atlas grid texture + film grain + vignette overlays */
.tex{position:fixed;inset:0;pointer-events:none;z-index:60}
.tex--grid{
  background-image:
    linear-gradient(rgba(245,244,239,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(245,244,239,.025) 1px,transparent 1px);
  background-size:64px 64px;
  mix-blend-mode:screen;
}
.tex--vignette{
  background:radial-gradient(120% 90% at 50% 42%,transparent 55%,rgba(0,0,0,.55) 100%);
}
.tex--grain{
  opacity:.05;
  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' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:80;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(16px,4vw,40px);
  transition:background calc(.4s * var(--mo)) ease,backdrop-filter calc(.4s * var(--mo)) ease,border-color calc(.4s * var(--mo)) ease;
  border-bottom:1px solid transparent;
}
.nav[data-scrolled="1"]{
  background:rgba(14,16,18,.82);
  backdrop-filter:blur(10px) saturate(140%);
  border-bottom-color:var(--hair);
}
.nav__brand{
  font-family:var(--ff-display);font-weight:800;font-stretch:78%;
  text-transform:uppercase;letter-spacing:.04em;font-size:16px;color:var(--white);
  display:flex;align-items:center;gap:10px;
}
.nav__brand .tick{width:9px;height:9px;background:var(--accent);flex:0 0 auto}
.nav__links{display:flex;align-items:center;gap:clamp(14px,2.4vw,30px)}
.nav__link{
  position:relative;font-family:var(--ff-mono);text-transform:uppercase;
  letter-spacing:.16em;font-size:11.5px;font-weight:500;color:var(--light);
  padding:6px 0;
}
.nav__link::after{
  content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;
  background:var(--accent);
  transition:width calc(.2s * var(--mo)) ease;
}
.nav__link:hover::after{width:100%}
.nav__cta{
  font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.14em;
  font-size:11.5px;font-weight:700;color:var(--base);
  background:var(--accent);padding:9px 16px;
  transition:background calc(.25s * var(--mo)) ease,transform calc(.25s * var(--mo)) ease;
}
.nav__cta:hover{background:var(--accent-hover);transform:translateY(-2px)}
@media (max-width:720px){
  .nav__links .nav__link{display:none}
  .nav__cta{display:none}
  .nav__burger{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:none;border:0;cursor:pointer;padding:0;flex:0 0 auto}
  .nav__burger span{display:block;width:22px;height:2px;background:var(--light);position:relative}
  .nav__burger span::before,.nav__burger span::after{content:"";position:absolute;left:0;width:100%;height:2px;background:var(--light)}
  .nav__burger span::before{top:-7px}
  .nav__burger span::after{top:7px}
}
@media (min-width:721px){.nav__burger{display:none}}

/* mobile overlay menu */
.nav__overlay{
  position:fixed;inset:0;z-index:90;background:rgba(14,16,18,.96);
  backdrop-filter:blur(16px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
  opacity:0;pointer-events:none;transition:opacity .3s ease;
}
.nav__overlay[data-open="1"]{opacity:1;pointer-events:auto}
.nav__overlay a{
  font-family:var(--ff-display);font-weight:800;font-stretch:76%;text-transform:uppercase;
  letter-spacing:.04em;font-size:clamp(28px,7vw,40px);color:var(--white);
  padding:12px 0;position:relative;
}
.nav__overlay a::after{content:"";position:absolute;left:0;bottom:6px;height:2px;width:0;background:var(--accent);transition:width .2s ease}
.nav__overlay a:hover::after{width:100%}
.nav__overlay .nav__overlay-cta{
  margin-top:24px;font-family:var(--ff-mono);font-size:13px;letter-spacing:.14em;font-weight:700;
  color:var(--base);background:var(--accent);padding:14px 28px;
}
.nav__overlay-close{
  position:absolute;top:18px;right:clamp(16px,4vw,40px);
  width:44px;height:44px;background:none;border:0;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
}
.nav__overlay-close span{display:block;width:24px;height:2px;background:var(--light);transform:rotate(45deg);position:relative}
.nav__overlay-close span::after{content:"";position:absolute;width:100%;height:2px;background:var(--light);transform:rotate(-90deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{height:100svh;min-height:640px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:space-between}
.hero__media{position:absolute;inset:0;overflow:hidden;background:var(--base)}
.hero__img{
  width:100%;height:100%;object-fit:cover;object-position:58% 55%;
  transform:scale(1.04);transform-origin:58% 50%;
}
.hero__grad{
  position:absolute;inset:0;
  background:
    linear-gradient(to top,rgba(14,16,18,calc(.6 * var(--hero-overlay) + .15)) 0%,rgba(14,16,18,calc(.15*var(--hero-overlay))) 25%,transparent 45%),
    linear-gradient(to bottom,rgba(14,16,18,.85) 0%,rgba(14,16,18,.65) 20%,rgba(14,16,18,.35) 40%,rgba(14,16,18,.12) 55%,transparent 65%);
}
/* yellow corner markers */
.corner{position:absolute;width:26px;height:26px;border:2px solid var(--accent);z-index:5;pointer-events:none;opacity:.9}
.corner--tl{top:88px;left:clamp(16px,4vw,40px);border-right:0;border-bottom:0}
.corner--tr{top:88px;right:clamp(16px,4vw,40px);border-left:0;border-bottom:0}
.corner--bl{bottom:28px;left:clamp(16px,4vw,40px);border-right:0;border-top:0}
.corner--br{bottom:28px;right:clamp(16px,4vw,40px);border-left:0;border-top:0}

.hero__inner{position:relative;z-index:6;width:100%;max-width:var(--maxw);margin:0 auto;padding:clamp(90px,12vh,130px) clamp(16px,4vw,40px) 0}
.hero__kicker{display:flex;flex-wrap:wrap;align-items:center;gap:10px 18px;margin-top:32px;margin-bottom:18px}
.hero__kicker .mono{color:var(--white)}
.hero__kicker .dot{width:5px;height:5px;background:var(--accent);border-radius:50%}
.hero__title{
  font-size:clamp(52px,11vw,148px);
  margin:0 0 16px;
  text-shadow:0 2px 16px rgba(0,0,0,.3);
}
.hero__roles{display:flex;flex-wrap:wrap;gap:4px 12px;align-items:center;margin-bottom:22px}
.hero__roles span{font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.2em;font-size:clamp(11px,1.3vw,14px);font-weight:500;color:var(--light);text-shadow:0 1px 4px rgba(0,0,0,.4)}
.hero__roles .sep{color:var(--accent);font-weight:700}
.hero__meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;border-top:1px solid var(--hair);padding:18px clamp(16px,4vw,40px) clamp(24px,4vh,40px);position:relative;z-index:6;max-width:var(--maxw);margin:0 auto;width:100%}
.hero__scroll{display:flex;align-items:center;gap:12px}
.hero__scroll .line{width:46px;height:1px;background:var(--accent);position:relative;overflow:hidden}
.hero__scroll .mono{color:var(--white)}
.hero__cred{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.14em;color:var(--white);text-transform:uppercase}

/* ============================================================
   SECTION HEADER (shared)
   ============================================================ */
.shead{display:flex;align-items:baseline;gap:18px;margin-bottom:var(--s5)}
.shead__num{font-family:var(--ff-mono);font-size:12px;letter-spacing:.18em;color:var(--accent);font-weight:700}
.shead__label{font-family:var(--ff-mono);font-size:12px;letter-spacing:.22em;color:var(--muted);text-transform:uppercase}

/* hairline divider that draws across */
.divider{height:1px;background:var(--hair);transform-origin:left center;}
html[data-motion="on"] .divider.reveal{transform:scaleX(0)}
html[data-motion="on"] .divider.reveal.is-in{transform:scaleX(1);transition:transform calc(.6s * var(--mo)) cubic-bezier(.22,.61,.36,1)}

/* ============================================================
   STORY
   ============================================================ */
.story{padding:var(--s7) 0}
.story__grid{display:grid;grid-template-columns:minmax(0,2.1fr) minmax(0,1fr);gap:clamp(32px,6vw,80px);align-items:start}
.story__title{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;line-height:.92;font-size:clamp(34px,5vw,64px);color:var(--white);margin:0 0 var(--s4)}
.story__body p{margin:0 0 var(--s4);max-width:60ch;color:var(--light);text-wrap:pretty}
.story__body p.drop::first-letter{
  font-family:var(--ff-display);font-weight:900;font-stretch:74%;
  float:left;font-size:84px;line-height:.72;padding:6px 14px 0 0;color:var(--accent);
}
.story__aside{position:relative;border-left:1px solid var(--hair);padding-left:var(--s4)}
.story__aside .mono{display:block;margin-bottom:14px}
.story__quote{font-family:var(--ff-body);font-style:italic;font-weight:300;font-size:clamp(20px,2.2vw,26px);line-height:1.45;color:var(--white)}
.story__id{margin:0;display:flex;flex-direction:column}
.idrow{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:13px 0;border-bottom:1px solid var(--hair)}
.idrow:first-child{padding-top:0}
.idrow:last-child{border-bottom:0}
.idrow dt{margin:0;font-size:10.5px}
.idrow dd{margin:0;font-family:var(--ff-body);font-style:italic;font-weight:300;font-size:15px;color:var(--light);text-align:right}
@media (max-width:820px){.story__grid{grid-template-columns:1fr}.story__aside{border-left:0;border-top:1px solid var(--hair);padding-left:0;padding-top:var(--s4)}}

/* ============================================================
   PHOTO BREAK — full-bleed cinematic image
   ============================================================ */
.photobreak{position:relative;overflow:hidden;height:clamp(320px,50vw,560px)}
.photobreak__img{width:100%;height:100%;object-fit:cover;object-position:center 60%}
.photobreak__grad{position:absolute;inset:0;background:
  linear-gradient(to top,rgba(14,16,18,.7) 0%,rgba(14,16,18,.15) 35%,transparent 60%),
  linear-gradient(to bottom,rgba(14,16,18,.6) 0%,transparent 18%);
}
.photobreak .corner{z-index:3}
.photobreak .corner--bl{bottom:20px;left:clamp(16px,4vw,40px)}
.photobreak .corner--br{bottom:20px;right:clamp(16px,4vw,40px)}
.photobreak__cap{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);z-index:4;text-align:center}

/* STORY PHOTO — inline cinematic photo inside the story section */
.story__photo{position:relative;overflow:hidden;margin-top:var(--s5);margin-bottom:var(--s3)}
.story__photo img{width:100%;height:auto;display:block}
.story__photo__grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,16,18,.5) 0%,transparent 30%)}
.story__photo__cap{position:absolute;bottom:14px;right:18px;z-index:2}
.story__photo .corner{z-index:3}
.story__photo .corner--bl{bottom:12px;left:12px;width:18px;height:18px}
.story__photo .corner--tr{top:12px;right:12px;width:18px;height:18px}

/* ============================================================
   SIRGA — cinematic feature panel
   ============================================================ */
.sirga{padding:0;position:relative;overflow:hidden;min-height:520px;display:flex;align-items:flex-end}
.sirga__media{position:absolute;inset:0;overflow:hidden;background:var(--teal)}
.sirga__media image-slot{width:100%;height:100%}
.sirga__grad{position:absolute;inset:0;background:
  linear-gradient(to right,rgba(14,16,18,.92) 0%,rgba(14,16,18,.6) 40%,rgba(14,16,18,.2) 70%,transparent 100%),
  linear-gradient(to top,rgba(14,16,18,.7) 0%,transparent 40%);
}
.sirga__inner{position:relative;z-index:4;max-width:var(--maxw);margin:0 auto;padding:var(--s7) var(--s4)}
.sirga__kick{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.sirga__kick .bar{width:36px;height:2px;background:var(--accent)}
.sirga__title{font-family:var(--ff-display);font-weight:900;font-stretch:72%;text-transform:uppercase;line-height:.88;font-size:clamp(42px,7vw,96px);color:var(--white);margin:0 0 var(--s4)}
.sirga__body{max-width:48ch;font-size:clamp(17px,1.8vw,20px);color:var(--light);line-height:1.6}
.sirga__body p{margin:0 0 var(--s3);text-wrap:pretty}
.sirga .corner{z-index:5}
.sirga .corner--tl{top:var(--s4);left:var(--s4)}
.sirga .corner--br{bottom:var(--s4);right:var(--s4)}
.sirga__coord{position:absolute;bottom:var(--s4);right:clamp(60px,8vw,120px);z-index:5}

/* Sirga timeline — then/now photo strip */
.sirga__tl{padding:var(--s6) 0 var(--s5)}
.sirga__tl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}
.sirga__tl-item{position:relative;overflow:hidden}
.sirga__tl-item img{width:100%;height:auto;aspect-ratio:4/5;object-fit:cover;display:block}
.sirga__tl-item__grad{position:absolute;inset:0;background:linear-gradient(to top,rgba(14,16,18,.7) 0%,transparent 40%)}
.sirga__tl-item__cap{position:absolute;bottom:14px;left:16px;z-index:2;display:flex;flex-direction:column;gap:4px}
.sirga__tl-item .corner{z-index:3;width:16px;height:16px}
.sirga__tl-item .corner--tl{top:10px;left:10px}
.sirga__tl-item .corner--br{bottom:10px;right:10px}
@media (max-width:640px){.sirga__tl-grid{grid-template-columns:1fr}.sirga__tl-item img{aspect-ratio:16/10}}
.sirga__tl-item:last-child img{object-position:center center}
.sirga__tl-item:nth-child(2) img{object-position:right center}

/* ============================================================
   BOOKS — dossier cards
   ============================================================ */
.books{padding:var(--s7) 0}
.books__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.bcard{background:var(--panel);border:1px solid var(--hair);display:flex;flex-direction:column;position:relative;overflow:hidden}
.bcard__cover{aspect-ratio:3/4;background:var(--teal);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.bcard__cover image-slot{width:100%;height:100%}
.bcard__cover-placeholder{font-family:var(--ff-display);font-weight:900;font-stretch:72%;text-transform:uppercase;font-size:clamp(20px,3vw,32px);color:var(--white);opacity:.25;text-align:center;padding:var(--s4);position:absolute;z-index:1;pointer-events:none}
.bcard__body{padding:clamp(22px,3vw,36px);display:flex;flex-direction:column;gap:12px;flex:1}
.bcard__tag{display:inline-flex;align-items:center;gap:8px}
.bcard__tag .dot{width:6px;height:6px;background:var(--accent);flex:0 0 auto}
.bcard__title{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;line-height:.92;font-size:clamp(26px,3.6vw,42px);color:var(--white);margin:0}
.bcard__sub{font-family:var(--ff-body);font-style:italic;font-weight:300;font-size:16px;color:var(--light);margin:0}
.bcard__meta{display:flex;flex-wrap:wrap;gap:8px 20px;margin-top:auto;padding-top:16px;border-top:1px solid var(--hair)}
.bcard__meta span{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.bcard__meta span em{font-style:normal;color:var(--light)}
.bcard--upcoming{border-style:dashed;border-color:var(--hair-strong)}
.bcard--upcoming .bcard__cover{background:var(--panel-2)}
.bcard--upcoming::after{content:"Coming Fall 2026";position:absolute;top:18px;right:18px;font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);background:rgba(14,16,18,.8);padding:6px 12px;z-index:2}
@media (max-width:760px){.books__grid{grid-template-columns:1fr}.bcard__cover{aspect-ratio:16/9}}

/* ============================================================
   PRESS & MEDIA
   ============================================================ */
.press{padding:var(--s7) 0}
.press__grid{display:grid;grid-template-columns:minmax(0,1.6fr) minmax(0,1fr);gap:clamp(32px,6vw,80px);align-items:start}
.press__body{max-width:52ch}
.press__body p{margin:0 0 var(--s4);color:var(--light);text-wrap:pretty}
.press__downloads{display:flex;flex-direction:column;gap:0}
.pdl{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 0;border-bottom:1px solid var(--hair)}
.pdl:first-child{border-top:1px solid var(--hair)}
.pdl__info{display:flex;flex-direction:column;gap:3px}
.pdl__name{font-family:var(--ff-display);font-weight:800;font-stretch:80%;text-transform:uppercase;letter-spacing:.01em;font-size:15px;color:var(--white)}
.pdl__desc{font-family:var(--ff-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.pdl__action{font-family:var(--ff-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-weight:700;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}
.pdl:hover .pdl__action{text-decoration:underline;text-underline-offset:3px}
.press__contact{margin-top:var(--s5);background:var(--panel);border:1px solid var(--hair);padding:clamp(22px,3vw,36px)}
.press__contact h4{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;font-size:20px;color:var(--white);margin:0 0 10px}
.press__contact p{margin:0;color:var(--muted);font-size:15px}
.press__contact a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
@media (max-width:820px){.press__grid{grid-template-columns:1fr}}

/* ============================================================
   STATS
   ============================================================ */
.stats{padding:var(--s6) 0}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.stat{padding:var(--s5) var(--s4);border-left:1px solid var(--hair)}
.stat:first-child{border-left:0;padding-left:0}
.stat__num{font-family:var(--ff-display);font-weight:900;font-stretch:74%;font-size:clamp(54px,8vw,104px);line-height:.86;color:var(--white)}
.stat__num .u{color:var(--accent);font-size:.42em;vertical-align:baseline}
.stat__label{font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.18em;font-size:11.5px;color:var(--muted);margin-top:14px}
.stat:last-child{padding-right:0}
@media (max-width:720px){.stats__grid{grid-template-columns:1fr}.stat{border-left:0;border-top:1px solid var(--hair);padding-left:0;padding-right:0}.stat:first-child{border-top:0}}

/* ============================================================
   SPEAKING / TOUR
   ============================================================ */
.tour{padding:var(--s7) 0}
.tour__head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:var(--s5)}
.tour__title{font-family:var(--ff-display);font-weight:900;font-stretch:72%;text-transform:uppercase;line-height:.88;font-size:clamp(40px,7vw,92px);color:var(--white);margin:6px 0 0}
.tour__sub{max-width:44ch;color:var(--muted);font-size:16px;margin-top:14px}
.tour__legend{display:flex;flex-wrap:wrap;gap:10px 16px;margin-bottom:var(--s4)}
.lg{display:flex;align-items:center;gap:7px;font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.lg .sw{width:9px;height:9px;flex:0 0 auto}

.tour__month{display:flex;align-items:center;gap:16px;margin:var(--s5) 0 var(--s2);cursor:pointer;user-select:none}
.tour__month h3{font-family:var(--ff-display);font-weight:800;font-stretch:76%;text-transform:uppercase;letter-spacing:.02em;font-size:18px;color:var(--light);margin:0;white-space:nowrap}
.tour__month .rule{flex:1;height:1px;background:var(--hair)}
.tour__month .ct{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;color:var(--muted)}
.tour__month .toggle-icon{font-family:var(--ff-mono);font-size:14px;color:var(--accent);transition:transform .25s ease;flex:0 0 auto}
.tour__month[data-collapsed="1"] .toggle-icon{transform:rotate(-90deg)}
.tour__month[data-collapsed="1"] ~ .show{display:none}
.tour__shows{overflow:hidden}
.tour__shows[data-collapsed="1"]{display:none}

.show{
  display:grid;
  grid-template-columns:128px 64px minmax(0,1.4fr) 96px 120px;
  align-items:center;gap:18px;
  padding:18px 14px;border-top:1px solid var(--hair);
  position:relative;
  transition:background calc(.25s * var(--mo)) ease;
}
.show:last-child{border-bottom:1px solid var(--hair)}
.show::before{content:"";position:absolute;left:0;top:-1px;bottom:0;width:2px;background:var(--accent);transform:scaleY(0);transform-origin:top;transition:transform calc(.25s * var(--mo)) ease}
.show:hover{background:var(--panel)}
.show:hover::before{transform:scaleY(1)}
.show__date{font-family:var(--ff-mono);font-size:13px;letter-spacing:.04em;color:var(--white);font-weight:500}
.show__date .dow{display:block;color:var(--muted);font-size:10.5px;letter-spacing:.14em;margin-top:3px}
.show__time{font-family:var(--ff-mono);font-size:13px;color:var(--accent);font-weight:500}
.show__city{font-family:var(--ff-display);font-weight:800;font-stretch:80%;text-transform:uppercase;letter-spacing:.01em;font-size:21px;color:var(--white);line-height:1}
.show__venue{font-family:var(--ff-body);font-style:italic;font-weight:300;color:var(--muted);font-size:15px;margin-top:5px}
.show__org{font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--light);display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.show__org .sw{width:8px;height:8px;flex:0 0 auto}
.show__tix{
  justify-self:end;
  font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:700;
  color:var(--accent);display:inline-flex;align-items:center;gap:8px;
  transition:gap calc(.25s * var(--mo)) ease,color calc(.25s * var(--mo)) ease;
}
.show:hover .show__tix{gap:13px}
.show__tix .arr{transition:transform calc(.25s * var(--mo)) ease}
.show:hover .show__tix .arr{transform:translateX(2px)}

@media (max-width:860px){
  .show{grid-template-columns:80px 1fr auto;gap:8px 14px;padding:14px 10px}
  .show__date{grid-column:1;grid-row:1}
  .show__time{grid-column:1;grid-row:2}
  .show__cityblock{grid-column:2;grid-row:1 / span 2}
  .show__org{grid-column:3;grid-row:1;align-self:start}
  .show__tix{grid-column:3;grid-row:2;justify-self:end;align-self:end}
}

/* booking CTA bar */
.book{margin-top:var(--s6);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:20px;background:var(--panel);border:1px solid var(--hair);padding:clamp(24px,4vw,40px)}
.book__txt h4{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;font-size:clamp(22px,3vw,32px);color:var(--white);margin:0 0 8px}
.book__txt p{margin:0;color:var(--muted);font-size:15px}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--ff-mono);text-transform:uppercase;letter-spacing:.14em;font-size:12px;font-weight:700;
  background:var(--accent);color:var(--base);
  padding:14px 22px;border:0;cursor:pointer;
  transition:background calc(.25s * var(--mo)) ease,transform calc(.25s * var(--mo)) ease,box-shadow calc(.25s * var(--mo)) ease;
}
.btn:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.btn .arr{transition:transform calc(.25s * var(--mo)) ease}
.btn:hover .arr{transform:translateX(3px)}
.btn--ghost{background:transparent;color:var(--light);border:1px solid var(--hair-strong)}
.btn--ghost:hover{background:transparent;border-color:var(--accent);color:var(--accent);box-shadow:none}

/* ============================================================
   PRESS LOGOS — bold typographic strip
   ============================================================ */
.press__logos{
  display:flex;flex-wrap:wrap;align-items:center;
  gap:12px 0;
  margin-bottom:var(--s5);padding-bottom:var(--s5);
  border-bottom:1px solid var(--hair);
}
.press__logos a,.press__logos>span{
  font-family:var(--ff-display);font-weight:900;font-stretch:76%;
  text-transform:uppercase;letter-spacing:.02em;
  font-size:clamp(20px,3vw,30px);
  color:var(--light);opacity:.35;
  transition:opacity .3s ease,color .3s ease;
  padding:4px 0;
}
.press__logos a:hover{opacity:1;color:var(--accent)}
.press__logos a::after,.press__logos>span:not(:last-child)::after{
  content:"\00B7";display:inline-block;
  margin:0 clamp(14px,2.4vw,28px);
  color:var(--accent);opacity:.6;font-weight:400;
}
@media (max-width:540px){
  .press__logos{gap:6px 0}
  .press__logos a,.press__logos>span{font-size:clamp(16px,5vw,22px)}
}

/* press pullquote — social proof */
.press__pullquote{margin-bottom:var(--s6)}
.press__pullquote blockquote{
  margin:0;padding:0 0 0 clamp(18px,2.4vw,28px);
  border-left:2px solid var(--accent);
  font-family:var(--ff-body);font-style:italic;font-weight:300;
  font-size:clamp(18px,2.2vw,24px);line-height:1.55;
  color:var(--muted);max-width:52ch;
}

/* ============================================================
   SUPPORT — Patreon + Modisa cinematic panels
   ============================================================ */
.support{padding:var(--s6) 0 var(--s7)}
.support__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--s3)}
.cpanel{position:relative;overflow:hidden;min-height:440px;display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--hair)}
.cpanel image-slot{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.cpanel__wash{position:absolute;inset:0;z-index:1;background:linear-gradient(to top,rgba(14,16,18,.94) 8%,rgba(14,16,18,.55) 45%,rgba(14,16,18,.25) 100%)}
.cpanel--teal .cpanel__wash{background:linear-gradient(to top,rgba(14,16,18,.94) 8%,rgba(21,48,59,.6) 50%,rgba(21,48,59,.3) 100%)}
.cpanel__body{position:relative;z-index:2;padding:clamp(26px,4vw,44px)}
.cpanel__kick{font-family:var(--ff-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.cpanel__title{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;line-height:.9;font-size:clamp(30px,4vw,46px);color:var(--white);margin:0 0 14px}
.cpanel__txt{color:var(--light);font-size:16px;max-width:38ch;margin:0 0 24px;opacity:.92}
.cpanel .corner{position:absolute;z-index:3}
.cpanel .corner--tl{top:18px;left:18px}
.cpanel .corner--br{bottom:18px;right:18px}
@media (max-width:760px){.support__grid{grid-template-columns:1fr}}

/* ============================================================
   PATREON STRIP — secondary CTA after Sirga
   ============================================================ */
.patreon-strip { padding: var(--s5) 0; }
.patreon-strip__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 16px 32px;
  padding: clamp(22px, 3vw, 32px) clamp(22px, 3vw, 36px);
  border: 1px solid var(--hair);
  background: var(--panel);
}
.patreon-strip__text {
  display: flex;
  align-items: center;
  gap: 10px;
}
.patreon-strip__text .bar {
  width: 28px;
  height: 2px;
  background: var(--accent);
}
.patreon-strip__body {
  flex: 1;
  min-width: 200px;
  margin: 0;
  color: var(--muted);
  font-size: 15px;
}
.patreon-strip__inner .btn--ghost {
  flex-shrink: 0;
  margin-left: auto;
}
@media (max-width: 600px) {
  .patreon-strip__inner { flex-direction: column; align-items: flex-start; }
  .patreon-strip__inner .btn--ghost { margin-left: 0; }
}

/* ============================================================
   NEWSLETTER
   ============================================================ */
.dispatch{padding:var(--s6) 0;border-top:1px solid var(--hair)}
.dispatch__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(28px,5vw,64px);align-items:center}
.dispatch__title{font-family:var(--ff-display);font-weight:900;font-stretch:74%;text-transform:uppercase;line-height:.92;font-size:clamp(30px,4.4vw,52px);color:var(--white);margin:0 0 14px}
.dispatch__txt{color:var(--muted);font-size:16px;max-width:42ch}
.dform{display:flex;gap:0;border:1px solid var(--hair-strong);background:var(--panel)}
.dform input{flex:1;min-width:0;background:transparent;border:0;outline:none;color:var(--light);font-family:var(--ff-mono);font-size:13px;letter-spacing:.06em;padding:0 16px}
.dform input::placeholder{color:var(--muted);text-transform:uppercase;letter-spacing:.12em;font-size:11.5px}
.dform button{flex:0 0 auto}
.dform__note{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:12px}
@media (max-width:760px){.dispatch__grid{grid-template-columns:1fr}}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{border-top:1px solid var(--hair);padding:var(--s6) 0 var(--s5)}
.foot__top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:36px;margin-bottom:var(--s6)}
.foot__brand .display{font-size:clamp(30px,4vw,46px)}
.foot__coord{font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;margin-top:14px;line-height:1.9}
.foot__cols{display:flex;gap:clamp(32px,6vw,80px);flex-wrap:wrap}
.foot__col h5{font-family:var(--ff-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 14px;font-weight:500}
.foot__col a{display:block;font-family:var(--ff-mono);font-size:12px;letter-spacing:.06em;color:var(--light);padding:4px 0;position:relative;width:fit-content}
.foot__col a::after{content:"";position:absolute;left:0;bottom:2px;height:1px;width:0;background:var(--accent);transition:width calc(.2s * var(--mo)) ease}
.foot__col a:hover::after{width:100%}
.foot__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:14px;align-items:center;border-top:1px solid var(--hair);padding-top:24px}
.foot__bottom span{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ============================================================
   MOTION — initial hidden states only when motion ON
   ============================================================ */
html[data-motion="on"] .reveal{opacity:0;transform:translateY(16px)}
html[data-motion="on"] .reveal.is-in{opacity:1;transform:none;transition:opacity calc(.4s * var(--mo)) ease-out,transform calc(.4s * var(--mo)) ease-out}

/* hero staggered fade-up */
html[data-motion="on"] .hero [data-stagger]{opacity:0;transform:translateY(18px)}
html[data-motion="on"] .hero [data-stagger].is-in{opacity:1;transform:none;transition:opacity calc(.25s * var(--mo)) ease-out,transform calc(.25s * var(--mo)) ease-out}

/* ken burns */
@keyframes kenburns{
  0%{transform:scale(1.04) translate(0,0)}
  100%{transform:scale(1.14) translate(-1.5%,-1.5%)}
}
html[data-motion="on"] .hero__img{animation:kenburns calc(20s * var(--mo)) ease-in-out infinite alternate}

/* scroll-cue shimmer (subtle, allowed loop is hero only — keep static otherwise) */
html[data-motion="on"] .hero__scroll .line::after{
  content:"";position:absolute;inset:0;width:40%;
  background:linear-gradient(90deg,transparent,var(--base),transparent);
  animation:cue calc(2.4s * var(--mo)) ease-in-out infinite;
}
@keyframes cue{0%{transform:translateX(-120%)}100%{transform:translateX(260%)}}

@media (prefers-reduced-motion:reduce){
  html .reveal,html .hero [data-stagger]{opacity:1!important;transform:none!important}
  html .hero__img{animation:none!important}
  html .hero__scroll .line::after{animation:none!important}
  html .divider.reveal{transform:none!important}
}

/* ============================================================
   MOBILE — comprehensive responsive pass
   ============================================================ */
@media (max-width:600px){
  :root{--s6:40px;--s7:56px}
  body{font-size:16px}
  .wrap{padding-inline:var(--s3)}

  /* hero */
  .hero{min-height:100svh}
  .hero__inner{padding:clamp(130px,24vh,210px) var(--s3) 0}
  .hero__img{object-position:center 70%}
  .hero__kicker{gap:6px 12px;margin-top:8px;margin-bottom:14px}
  .hero__kicker .mono{font-size:11px;letter-spacing:.14em}
  .hero__title{font-size:clamp(64px,19vw,110px)!important;margin-bottom:14px}
  .hero__roles{gap:6px 12px;margin-bottom:16px}
  .hero__roles span{font-size:12px;letter-spacing:.14em;text-shadow:0 1px 4px rgba(0,0,0,.4)}
  .hero__title{text-shadow:0 1px 8px rgba(0,0,0,.35)}
  .hero__kicker .mono{text-shadow:0 1px 4px rgba(0,0,0,.4)}
  .hero__meta{flex-direction:column;align-items:flex-start;gap:10px}
  .hero__cred{font-size:9.5px}
  .corner{width:20px;height:20px}
  .corner--tl{top:62px}

  /* story */
  .story__body p.drop::first-letter{font-size:60px;padding:4px 10px 0 0}

  /* sirga */
  .sirga{min-height:400px}
  .sirga__grad{background:
    linear-gradient(to top,rgba(14,16,18,.95) 0%,rgba(14,16,18,.7) 45%,rgba(14,16,18,.3) 70%,transparent 100%)!important;
  }
  .sirga__inner{padding:var(--s6) var(--s3)}
  .sirga__coord{display:none}
  .sirga__body{font-size:16px}

  /* stats */
  .stat__num{font-size:clamp(44px,14vw,72px)}
  .stat__label{font-size:10.5px}

  /* tour */
  .show{grid-template-columns:1fr;grid-template-areas:none;gap:8px;padding:16px 10px}
  .show__date,.show__time,.show__cityblock,.show__org,.show__tix{grid-area:auto}
  .show__date{display:flex;align-items:baseline;gap:10px}
  .show__date .dow{display:inline;margin-top:0;margin-left:0}
  .show__time{font-size:12px}
  .show__city{font-size:18px}
  .show__venue{font-size:14px}
  .show__tix{justify-self:start}
  .tour__month h3{font-size:15px}

  /* books */
  .bcard__cover{aspect-ratio:3/4}
  .bcard__body{padding:20px}

  /* booking bar */
  .book{flex-direction:column;align-items:flex-start}

  /* support panels */
  .cpanel{min-height:360px}

  /* newsletter form */
  .dform{flex-direction:column}
  .dform input{padding:14px 16px}

  /* footer */
  .foot__cols{gap:clamp(24px,5vw,40px)}
  .foot__top{flex-direction:column}
}

/* small-phone extra tightening */
@media (max-width:380px){
  .hero__title{font-size:clamp(48px,16vw,60px)!important}
  .hero__kicker .mono:nth-child(n+4){display:none}
  .sirga__title{font-size:clamp(36px,12vw,52px)}
  .stat__num{font-size:clamp(36px,13vw,54px)}
}
