/* churrascowars.com — Yeezy-grade structure, Churrasco Wars palette. Zero deps. */

:root{
  /* palette */
  --char-000:#160D06; --char-050:#1C1714; --char-100:#201712; --char-200:#25160C;
  --char-300:#3A2A1F; --cream:#FFE3B5; --parch:#DDD1BE; --sub:#A48E73;
  --ember:#D1C9BC; --gold:#BEB3A2; --amber:#C8BFB0; --gold-lit:#E8E2D8;
  --pink:#FF4FA3; --pink-red:#FF2030; --blue:#4FC3FF; --festa-cool:#D6CEC1; --festa-hot:#AEA593;
  --line:rgba(221,209,190,.14); --line-strong:rgba(221,209,190,.28);
  /* fonts */
  --font-display:'Anton','Arial Narrow',system-ui,sans-serif;
  --font-ui:'Archivo',system-ui,-apple-system,'Helvetica Neue',sans-serif;
  /* type scale */
  --fs-hero:clamp(64px,12vw,168px); --fs-quote:clamp(34px,6vw,80px); --fs-h2:clamp(40px,7vw,104px);
  --fs-close:clamp(28px,5vw,64px); --fs-note:clamp(24px,3vw,30px); --fs-body:clamp(15px,2vw,17px);
  --fs-sub:clamp(15px,2vw,19px); --fs-label:11px; --fs-nano:12px;
  /* motion */
  --ease-out:cubic-bezier(0.16,1,0.3,1); --ease-in:cubic-bezier(0.7,0,0.84,0);
  --t-link:120ms; --t-fast:140ms; --t-reveal:420ms;
  /* layout */
  --gutter:clamp(20px,4vw,48px); --maxw:1240px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--char-000); color:var(--cream); font-family:var(--font-ui);
  font-size:var(--fs-body); line-height:1.6; font-weight:400;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; overflow-x:hidden;
}
section{scroll-margin-top:72px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
:focus-visible{outline:2px solid var(--ember);outline-offset:3px}
::selection{background:var(--ember);color:var(--char-000)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity var(--t-reveal) var(--ease-out),transform var(--t-reveal) var(--ease-out)}
.reveal.in{opacity:1;transform:none}
.reveal:nth-child(2){transition-delay:60ms}
.reveal:nth-child(3){transition-delay:120ms}
.reveal:nth-child(4){transition-delay:180ms}

.grad{
  background:linear-gradient(100deg,#EEE8DE 0%,#C7BEAE 45%,#978F82 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.eyebrow{
  font-family:var(--font-ui);font-weight:700;font-size:var(--fs-label);
  letter-spacing:.2em;text-transform:uppercase;color:var(--sub);
}
/* blurred secret — readable on hover/focus, veiled otherwise */
.blurred{
  filter:blur(4px);cursor:default;-webkit-user-select:none;user-select:none;
  transition:filter .4s var(--ease-out);
}
.blurred:hover,.blurred:focus{filter:blur(0)}
@media (prefers-reduced-motion:reduce){.blurred{transition:none}}
/* in-story link — fits the theme, subtle hairline, no garish underline */
.prose a{color:var(--cream);text-decoration:none;border-bottom:1px solid var(--line-strong);transition:border-color var(--t-link) var(--ease-out),color var(--t-link) var(--ease-out)}
.prose a:hover{color:#ECE6DC;border-color:var(--sub)}

/* ============ A · NAV ============ */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 var(--gutter);background:transparent;
}
.wordmark{
  font-family:var(--font-ui);font-weight:700;font-size:13px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--cream);
}
.nav-links{display:flex;gap:clamp(16px,3vw,38px)}
.nav-links a{
  position:relative;font-family:var(--font-ui);font-weight:600;font-size:12px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--parch);
  padding:4px 0;transition:color var(--t-link) var(--ease-out);
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:var(--ember);transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-fast) var(--ease-out);
}
.nav-links a:hover{color:var(--cream)}
.nav-links a:hover::after{transform:scaleX(1)}

/* ============ B · HERO ============ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  padding:96px var(--gutter) 72px;overflow:hidden;
}
#embers{position:absolute;inset:0;z-index:0;pointer-events:none}
.hero-inner{position:relative;z-index:1;max-width:960px;width:100%}
.hero-title{
  font-family:var(--font-display);font-weight:400;font-size:var(--fs-hero);
  line-height:.9;letter-spacing:-.02em;text-transform:uppercase;
  margin:.18em 0 .32em;color:#ECE6DC;
}
.hero-sub{max-width:46ch;font-size:var(--fs-sub);color:var(--parch);line-height:1.55}
.hero-cta{margin:2.2em 0 1.1em}
.hero-note{font-size:var(--fs-label);letter-spacing:.2em;text-transform:uppercase;color:var(--sub)}

.play{
  display:inline-flex;align-items:center;gap:.7em;cursor:pointer;
  font-family:var(--font-ui);font-weight:700;font-size:18px;letter-spacing:.04em;
  text-transform:uppercase;color:var(--char-000);background:#DCD5C9;
  border:none;border-radius:2px;padding:18px 38px;
  transition:background var(--t-fast) var(--ease-out),transform var(--t-fast) var(--ease-out);
}
.play:hover{background:#F0EBE1;transform:translateY(-2px)}
.play:active{transform:translateY(0)}
.play .tri{
  width:0;height:0;border-style:solid;border-width:6px 0 6px 10px;
  border-color:transparent transparent transparent currentColor;
}
.scroll-cue{
  position:absolute;left:var(--gutter);bottom:26px;z-index:1;
  font-size:var(--fs-label);letter-spacing:.24em;text-transform:uppercase;color:var(--sub);
  animation:cue 2.4s var(--ease-out) infinite;
}
@keyframes cue{0%,100%{opacity:.45;transform:translateY(0)}50%{opacity:1;transform:translateY(4px)}}
/* tiny hidden message, just above SCROLL */
.hidden-msg{
  position:absolute;left:var(--gutter);bottom:50px;z-index:1;
  font-family:var(--font-ui);font-size:9px;letter-spacing:.14em;
  color:rgba(164,142,115,.45);user-select:text;
}
/* CAI CODING — sits in the gap between SCROLL and THE STORY, styled like SCROLL */
.interlude{display:flex;justify-content:center;padding:clamp(44px,9vh,96px) var(--gutter) 0}
.interlude span{font-size:var(--fs-label);letter-spacing:.24em;text-transform:uppercase;color:var(--sub)}

/* ============ C · STORY ============ */
.story{max-width:var(--maxw);margin:0 auto;padding:clamp(96px,16vh,200px) var(--gutter)}
.pull{
  font-family:var(--font-display);font-weight:400;font-size:var(--fs-quote);
  line-height:.98;letter-spacing:-.01em;text-transform:uppercase;
  margin:.35em 0 .9em;max-width:18ch;color:#ECE6DC;
}
.prose{max-width:62ch}
.prose p{font-size:var(--fs-sub);color:var(--parch);margin-bottom:1.15em;line-height:1.7}
.prose .stanza{color:#ECE6DC;line-height:1.5;margin:1.5em 0;letter-spacing:.01em}
.attrib{
  margin-top:2.4em;font-family:var(--font-ui);font-weight:700;font-size:var(--fs-nano);
  letter-spacing:.22em;text-transform:uppercase;color:var(--sub);
}

/* ============ D · MAP ============ */
.map{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,10vh,140px) var(--gutter)}
.map-fig{max-width:560px;margin:1.6em 0 0}
.map-fig img{
  width:100%;height:auto;image-rendering:pixelated;border:1px solid var(--line);
  box-shadow:0 40px 120px rgba(0,0,0,.6);border-radius:2px;
}
.map-fig figcaption{display:flex;flex-direction:column;gap:.4em;margin-top:1.2em}
.map-title{font-family:var(--font-display);font-size:clamp(26px,4vw,40px);letter-spacing:-.01em;text-transform:uppercase;color:#ECE6DC}
.map-note{font-size:var(--fs-body);color:var(--sub);max-width:42ch}

/* ============ E · FIELD NOTES ============ */
.notes{max-width:var(--maxw);margin:0 auto;padding:clamp(64px,10vh,140px) var(--gutter)}
.ledger{list-style:none;margin-top:2.2em}
.row{
  display:grid;grid-template-columns:auto minmax(220px,300px) 1fr;
  gap:clamp(20px,4vw,48px);align-items:center;
  padding:40px 0;border-top:1px solid var(--line);
}
.row:last-child{border-bottom:1px solid var(--line)}
.no{font-family:var(--font-ui);font-weight:700;font-size:var(--fs-nano);letter-spacing:.18em;color:var(--ember);align-self:start;padding-top:6px}
.rowtext h3{font-family:var(--font-display);font-weight:400;font-size:clamp(24px,3.4vw,32px);letter-spacing:-.01em;text-transform:uppercase;color:#ECE6DC;margin-bottom:.45em}
.rowtext p{font-size:var(--fs-body);color:var(--parch);max-width:44ch;line-height:1.65}

/* plate frame */
.plate{aspect-ratio:4/5;border:1px solid var(--line-strong);border-radius:3px;overflow:hidden;background:var(--char-200)}
.cap{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:22px;text-align:center}
.cap-eyebrow{font-family:var(--font-ui);font-weight:700;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--sub)}

/* 001 score */
.cap-score{background:radial-gradient(120% 90% at 50% 0%,#2a1d10,var(--char-200))}
.cap-score .stars{display:flex;gap:8px}
.cap-score .star{width:30px;height:30px;fill:var(--gold-lit);filter:drop-shadow(0 0 10px rgba(209,201,188,.50))}
.score-num{font-family:var(--font-display);font-size:clamp(34px,7vw,52px);color:var(--gold-lit);letter-spacing:.02em;line-height:1}
.score-line{display:flex;gap:10px;align-items:baseline;font-family:var(--font-ui);font-weight:700;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--sub)}
.score-line .amt{color:var(--amber)}

/* 002 specials */
.cap-special{background:radial-gradient(120% 90% at 50% 100%,#23170d,var(--char-200))}
.chips{display:flex;flex-direction:column;gap:10px;width:100%;max-width:200px}
.chip{font-family:var(--font-ui);font-weight:800;font-size:13px;letter-spacing:.1em;text-transform:uppercase;padding:9px 12px;border-radius:999px;border:1.5px solid;background:rgba(0,0,0,.25)}
.chip-ponto{color:var(--gold-lit);border-color:var(--gold)}
.chip-blaze{color:var(--blue);border-color:var(--blue)}
.chip-rodizio{color:var(--ember);border-color:var(--ember)}

/* 003 pink + supafire */
.cap-pink{background:radial-gradient(120% 90% at 50% 30%,#2a1220,var(--char-200))}
.pinkpair{display:flex;align-items:center;gap:14px}
.pinkpair .meat{width:46px;height:46px;border-radius:50%;background:radial-gradient(circle at 38% 35%,#ff8fc4,var(--pink) 60%,var(--pink-red));border:2px solid var(--pink);box-shadow:0 0 16px rgba(255,79,163,.55)}
.pinkpair .plus{font-family:var(--font-display);font-size:26px;color:var(--cream)}
.supabar{width:88%;max-width:200px;height:12px;border-radius:999px;background:rgba(0,0,0,.4);overflow:hidden;border:1px solid var(--line-strong)}
.supafill{display:block;height:100%;width:92%;background:linear-gradient(90deg,var(--ember),var(--gold),var(--gold-lit));box-shadow:0 0 14px rgba(209,201,188,.50)}
.supalabel{font-family:var(--font-display);font-size:18px;letter-spacing:.06em;color:var(--gold-lit);text-shadow:0 0 12px rgba(232,226,216,.55)}

/* 004 festa */
.cap-festa{background:radial-gradient(120% 90% at 50% 100%,#2a1709,var(--char-200))}
.festabar{width:90%;max-width:210px;height:16px;border-radius:999px;background:rgba(0,0,0,.4);overflow:hidden;border:1px solid var(--line-strong)}
.festafill{display:block;height:100%;width:100%;background:linear-gradient(90deg,var(--festa-cool),var(--festa-hot));box-shadow:0 0 16px rgba(174,165,147,.50)}
.festaticks{display:flex;justify-content:space-between;width:90%;max-width:210px;font-family:var(--font-ui);font-weight:700;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--sub)}
.festaticks .lit{color:var(--festa-hot)}

/* ============ F · CLOSING ============ */
.close{max-width:var(--maxw);margin:0 auto;padding:clamp(110px,20vh,240px) var(--gutter);text-align:center}
.close-line{display:flex;flex-direction:column;align-items:center;font-family:var(--font-display);font-weight:400;font-size:var(--fs-close);line-height:1.0;letter-spacing:-.01em;text-transform:uppercase;color:#ECE6DC;margin:0 auto}
.close-line .cl-1{white-space:nowrap;position:relative;z-index:1}
.close-boxed{display:inline-block;white-space:nowrap;background:#DCD5C9;color:#160D06;padding:.06em .3em .02em;margin-top:-.10em;border-radius:2px;position:relative;z-index:2}
.close-sub{margin-top:1.4em;font-size:var(--fs-sub);color:var(--sub)}
.close-cta{margin-top:2.4em}

/* ============ G · FOOTER ============ */
.foot{border-top:1px solid var(--line);padding:36px var(--gutter);display:flex;flex-direction:column;gap:10px}
.foot-row{display:flex;justify-content:space-between;gap:16px;font-family:var(--font-ui);font-weight:500;font-size:12px;letter-spacing:.06em;color:var(--parch)}
.foot-sub{color:var(--sub)}
.foot a{color:inherit;text-decoration:none;transition:color var(--t-link) var(--ease-out)}
.foot a:hover{color:var(--cream)}

/* ============ H · CINEMA ============ */
#cinema{position:fixed;inset:0;z-index:200;background:var(--char-000);display:flex;align-items:center;justify-content:center}
#cinema[hidden]{display:none}
#introvid{width:100%;height:100%;object-fit:contain;background:#000}
#cine-skip{
  position:absolute;right:24px;bottom:24px;cursor:pointer;
  font-family:var(--font-ui);font-weight:700;font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--cream);background:rgba(0,0,0,.4);border:1px solid var(--line-strong);
  padding:11px 22px;border-radius:2px;transition:background var(--t-fast),color var(--t-fast);
}
#cine-skip:hover{background:var(--cream);color:var(--char-000)}

/* ============ RESPONSIVE ============ */
@media (max-width:720px){
  .nav{height:58px}
  .nav-links{gap:14px}
  .nav-links a{font-size:11px;letter-spacing:.12em}
  .row{grid-template-columns:1fr;gap:18px}
  .no{padding-top:0}
  .plate{max-width:300px}
}
@media (max-width:440px){
  .nav-links a:not(:last-child){display:none} /* keep FIELD NOTES anchor; wordmark + one link */
}

/* ============ REDUCED MOTION ============ */
@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto !important}
  .reveal{opacity:1 !important;transform:none !important;transition:none !important}
  .scroll-cue{animation:none}
  #embers{display:none}
}
