/* ============================================================
   ORFEO 404 — DIRECTION B · "CINEMÁTICA / TRÁILER"
   Full-bleed, letterboxed, poster typography. Restrained glitch.
   ============================================================ */

:root{
  --bg:#040507;
  --txt:#f1f2f4;
  --mute:#9aa1ad;
  --dim:#5b6470;
  --red:#ff2a20;
  --red-soft:#ff5a4d;
  --mono:"JetBrains Mono",ui-monospace,Menlo,monospace;
  --disp:"Anton",Impact,system-ui,sans-serif;
  --body:"Archivo",system-ui,sans-serif;
  --bar:64px; /* letterbox bar height */
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--txt);font-family:var(--body);
  font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
::selection{background:var(--red);color:#fff;}

/* ---------------- letterbox + chrome ---------------- */
.cine-top,.cine-bot{position:fixed;left:0;right:0;height:var(--bar);background:#000;z-index:40;
  display:flex;align-items:center;justify-content:space-between;padding:0 32px;
  font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);
  pointer-events:none;}
.cine-top{top:0;border-bottom:1px solid rgba(255,255,255,.06);}
.cine-bot{bottom:0;border-top:1px solid rgba(255,255,255,.06);}
.cine-top .brand{color:var(--txt);letter-spacing:.32em;font-weight:700;}
.cine-top .brand b{color:var(--red);}
.cine-top > *,.cine-bot > *{pointer-events:auto;}
.cine-bot .prog{position:absolute;top:-1px;left:0;height:2px;background:var(--red);width:100%;
  transform:scaleX(0);transform-origin:0 50%;transition:transform .1s linear;}

/* lang toggle */
.lang{display:flex;gap:0;border:1px solid rgba(255,255,255,.18);pointer-events:auto;}
.lang button{background:transparent;border:0;color:var(--dim);font-family:var(--mono);font-size:11px;
  letter-spacing:.1em;padding:5px 10px;cursor:pointer;transition:.2s;}
.lang button:hover{color:var(--txt);}
html[data-lang="es"] .lang .l-es,html[data-lang="en"] .lang .l-en{background:var(--red);color:#fff;}

/* grain overlay */
.fx-grain{position:fixed;inset:0;z-index:38;pointer-events:none;opacity:.045;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ---------------- entry gate ---------------- */
#gate{position:fixed;inset:0;z-index:200;background:#000;overflow:hidden;
  display:flex;align-items:center;justify-content:center;text-align:center;
  transition:opacity 1s ease,visibility 1s;}
#gate.gate-out{opacity:0;visibility:hidden;}
#gate .g-bg{position:absolute;inset:0;opacity:.4;}
#gate .g-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3) brightness(.5) contrast(1.1);}
#gate .g-bg::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 50%,transparent 20%,#000 80%);}
.g-inner{position:relative;z-index:2;padding:24px;}
.g-pre{font-family:var(--mono);font-size:11px;letter-spacing:.5em;color:var(--red);text-transform:uppercase;margin-bottom:26px;}
.g-logo{font-family:var(--disp);font-size:clamp(70px,17vw,210px);line-height:.84;letter-spacing:.01em;margin:0;text-transform:uppercase;}
.g-logo .n4{color:var(--red);}
.g-sub{color:var(--mute);font-size:13px;letter-spacing:.18em;max-width:520px;margin:24px auto 0;line-height:1.7;text-transform:uppercase;}
.g-enter{margin-top:46px;pointer-events:auto;display:inline-flex;align-items:center;gap:16px;cursor:pointer;
  background:transparent;border:0;color:var(--txt);font-family:var(--mono);font-size:13px;letter-spacing:.3em;text-transform:uppercase;
  padding:14px 0;position:relative;}
.g-enter::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:var(--red);
  transform:scaleX(.3);transform-origin:0 50%;transition:transform .3s;}
.g-enter:hover::after{transform:scaleX(1);}
.g-enter .pl{width:34px;height:34px;border:1px solid var(--red);border-radius:50%;display:grid;place-items:center;color:var(--red);transition:.25s;}
.g-enter:hover .pl{background:var(--red);color:#fff;}

body:not(.entered){overflow:hidden;height:100vh;}
body:not(.entered) .cine-top,body:not(.entered) .cine-bot{opacity:0;}

/* ---------------- scroll panels ---------------- */
main{scroll-snap-type:y proximity;}
.panel{position:relative;min-height:100vh;display:flex;align-items:center;
  padding:calc(var(--bar) + 40px) 0;scroll-snap-align:start;overflow:hidden;}
.panel.tall{min-height:auto;padding:120px 0;}
.pwrap{position:relative;z-index:5;width:100%;max-width:1180px;margin:0 auto;padding:0 56px;}

.pbg{position:absolute;inset:0;z-index:0;}
.pbg img{width:100%;height:100%;object-fit:cover;filter:contrast(1.06) brightness(.62) saturate(.96);}
.pbg.grade img{filter:contrast(1.08) brightness(.5) saturate(.9);}
.pbg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(4,5,7,.55) 0%,rgba(4,5,7,.2) 35%,rgba(4,5,7,.78) 100%);}
.pbg.left::after{background:linear-gradient(90deg,rgba(4,5,7,.9) 0%,rgba(4,5,7,.55) 45%,rgba(4,5,7,.25) 100%);}
.pbg.right::after{background:linear-gradient(270deg,rgba(4,5,7,.9) 0%,rgba(4,5,7,.5) 45%,rgba(4,5,7,.2) 100%);}

/* labels + type */
.plabel{font-family:var(--mono);font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--red);
  display:flex;align-items:center;gap:14px;margin-bottom:26px;}
.plabel .n{color:var(--txt);opacity:.5;}
.plabel::before{content:"";width:30px;height:1px;background:var(--red);}

.title{font-family:var(--disp);font-weight:400;text-transform:uppercase;line-height:.92;letter-spacing:.005em;
  font-size:clamp(48px,8.5vw,128px);margin:0;}
.title.glitch{position:relative;}
.title .red{color:var(--red);}
.subtitle{font-family:var(--body);font-weight:500;font-size:clamp(17px,2.1vw,23px);line-height:1.55;
  color:#d7dbe2;max-width:60ch;margin:26px 0 0;}
.subtitle b{color:var(--red-soft);font-weight:700;}
.kmono{font-family:var(--mono);font-size:13px;letter-spacing:.1em;color:var(--mute);}

/* glitch (restrained — only on hover / reveal pulse) */
.glitch[data-text]{position:relative;}
.glitch[data-text]::before,.glitch[data-text]::after{content:attr(data-text);position:absolute;inset:0;opacity:0;pointer-events:none;}
.glitch.in::before{color:var(--red);transform:translate(-3px,1px);animation:gpulse .5s steps(2) 1;}
.glitch.in::after{color:#36d0ff;transform:translate(3px,-1px);animation:gpulse .5s steps(2) 1;}
@keyframes gpulse{0%{opacity:.8;}60%{opacity:.5;}100%{opacity:0;}}
@media (prefers-reduced-motion:reduce){.glitch::before,.glitch::after{display:none;}}

/* reveal */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s ease,transform 1s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.1s;}.reveal.d2{transition-delay:.22s;}.reveal.d3{transition-delay:.34s;}

/* ---------------- HERO ---------------- */
.hero .title{font-size:clamp(78px,17vw,230px);text-shadow:0 8px 50px rgba(0,0,0,.6);}
.hero-tag{text-shadow:0 2px 16px rgba(0,0,0,.85);font-family:var(--mono);font-size:clamp(14px,1.7vw,19px);letter-spacing:.04em;color:#e6e9ee;
  margin-top:24px;max-width:44ch;line-height:1.5;}
.hero-tag .red{color:var(--red);}
.scrollcue{position:absolute;bottom:calc(var(--bar) + 22px);left:50%;transform:translateX(-50%);z-index:6;
  font-family:var(--mono);font-size:10px;letter-spacing:.3em;color:var(--mute);text-transform:uppercase;text-align:center;}
.scrollcue .ln{width:1px;height:34px;background:linear-gradient(var(--red),transparent);margin:10px auto 0;}

/* ---------------- LOGLINE ---------------- */
.logline-txt{font-family:var(--disp);font-weight:400;font-size:clamp(28px,4.4vw,60px);line-height:1.05;
  text-transform:uppercase;max-width:18ch;letter-spacing:.005em;}
.logline-txt .red{color:var(--red);}
.logline-foot{font-family:var(--mono);font-size:13px;color:var(--mute);letter-spacing:.06em;margin-top:30px;max-width:54ch;line-height:1.7;}

/* ---------------- WHY NOW (text panel) ---------------- */
.why{background:#070809;}
.why-list{display:grid;gap:0;margin-top:30px;border-top:1px solid rgba(255,255,255,.1);}
.why-row{display:grid;grid-template-columns:80px 1fr 1.4fr;gap:30px;align-items:baseline;
  padding:30px 0;border-bottom:1px solid rgba(255,255,255,.1);transition:.3s;}
.why-row:hover{padding-left:14px;}
.why-row .wn{font-family:var(--mono);color:var(--red);font-size:13px;letter-spacing:.1em;}
.why-row .wt{font-family:var(--disp);font-size:clamp(22px,2.6vw,34px);text-transform:uppercase;line-height:1;}
.why-row .wd{color:var(--mute);font-size:15.5px;}

/* ---------------- COMPARABLES ---------------- */
.comp{background:#060708;}
.comp-row{display:flex;flex-wrap:wrap;gap:10px 26px;margin:24px 0 34px;align-items:baseline;}
.comp-row span{font-family:var(--disp);font-size:clamp(26px,4vw,54px);text-transform:uppercase;color:var(--dim);
  line-height:1;transition:color .3s;cursor:default;}
.comp-row span:hover{color:var(--txt);}
.comp-row .sep{color:var(--red);font-size:.5em;transform:translateY(-.3em);}
.comp-formula{font-family:var(--disp);font-size:clamp(24px,3.4vw,44px);text-transform:uppercase;line-height:1.1;
  max-width:24ch;letter-spacing:.005em;}
.comp-formula .red{color:var(--red);}

/* ---------------- CHARACTERS ---------------- */
.chars{background:#050507;padding:calc(var(--bar) + 90px) 0;}
.chars .pwrap{max-width:1280px;}
.char-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px;}
.cha{position:relative;overflow:hidden;}
.cha .ph{aspect-ratio:3/4;overflow:hidden;}
.cha .ph img{width:100%;height:100%;object-fit:cover;filter:grayscale(.35) contrast(1.05) brightness(.9);transition:.6s;}
.cha:hover .ph img{filter:grayscale(0) contrast(1.08) brightness(1);transform:scale(1.04);}
.cha .meta{position:absolute;left:0;right:0;bottom:0;padding:24px 22px;
  background:linear-gradient(transparent,rgba(4,5,7,.95));}
.cha .nm{font-family:var(--disp);font-size:34px;text-transform:uppercase;line-height:.9;}
.cha .rl{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--red);margin:8px 0 8px;}
.cha .bi{font-size:13.5px;color:var(--mute);max-width:30ch;}
.char-foot{font-family:var(--disp);font-size:clamp(22px,3vw,40px);text-transform:uppercase;margin-top:34px;line-height:1.05;}
.char-foot .red{color:var(--red);}

/* ---------------- QUOTE PANELS ---------------- */
.quote-c{max-width:20ch;}
.bigquote{font-family:var(--disp);font-size:clamp(30px,5vw,72px);text-transform:uppercase;line-height:1.02;letter-spacing:.005em;}
.bigquote .red{color:var(--red);}
.quote-attr{font-family:var(--mono);font-size:12px;letter-spacing:.2em;color:var(--mute);margin-top:22px;text-transform:uppercase;}

/* ---------------- THEMES strip ---------------- */
.themes{background:#070809;}
.theme-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:30px;border:1px solid rgba(255,255,255,.1);}
.theme-c{padding:36px 30px;border-right:1px solid rgba(255,255,255,.1);}
.theme-c:last-child{border-right:0;}
.theme-c .tq{font-family:var(--disp);font-size:34px;color:var(--red);line-height:1;}
.theme-c h4{font-family:var(--disp);font-size:22px;text-transform:uppercase;margin:14px 0 10px;line-height:1;}
.theme-c p{color:var(--mute);font-size:14.5px;margin:0;}

/* ---------------- PILOT ---------------- */
.pilot-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:38px;}
.scene{position:relative;overflow:hidden;min-height:420px;display:flex;align-items:flex-end;}
.scene img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.55) contrast(1.05);z-index:0;}
.scene::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(4,5,7,.95));z-index:1;}
.scene .sc-in{position:relative;z-index:2;padding:34px;}
.scene .sc-tag{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--red);text-transform:uppercase;margin-bottom:12px;}
.scene .sc-h{font-family:var(--disp);font-size:clamp(28px,3vw,42px);text-transform:uppercase;line-height:.95;margin-bottom:14px;}
.scene p{font-size:14px;color:#cfd4dc;margin:0 0 8px;max-width:42ch;}
.scene .sys{font-family:var(--mono);color:#36d0ff;font-size:12px;letter-spacing:.06em;border:1px dashed rgba(54,208,255,.4);padding:7px 11px;display:inline-block;margin-top:6px;}

/* ---------------- ARC ---------------- */
.arc{background:#060708;}
.arc-wave{margin:30px 0 6px;border:1px solid rgba(255,255,255,.1);overflow:hidden;}
.arc-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid rgba(255,255,255,.1);border-top:0;}
.arc-step{padding:26px;border-right:1px solid rgba(255,255,255,.1);}
.arc-step:last-child{border-right:0;}
.arc-step .as{font-family:var(--mono);font-size:11px;letter-spacing:.2em;color:var(--red);text-transform:uppercase;margin-bottom:12px;}
.arc-step h4{font-family:var(--disp);font-size:21px;text-transform:uppercase;margin:0 0 8px;}
.arc-step p{color:var(--mute);font-size:14px;margin:0;}

/* ---------------- SAGA ---------------- */
.saga{background:#050507;}
.saga-wave{margin:30px 0 30px;}
.saga-list{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}
.saga-i{border-top:2px solid var(--red);padding-top:16px;}
.saga-i .t{font-family:var(--disp);font-size:34px;color:var(--red);line-height:.9;}
.saga-i p{margin:10px 0 0;color:#cfd4dc;font-size:14.5px;}

/* ---------------- CTA ---------------- */
.cta{background:linear-gradient(180deg,#070809,#040507);}
.cta .pwrap{max-width:780px;text-align:center;}
.cta .title{font-size:clamp(38px,6vw,84px);}
.cta .subtitle{margin:18px auto 0;}
.cta .note{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin:18px 0 38px;}
form#request-form{display:grid;grid-template-columns:1fr 1fr;gap:14px;text-align:left;}
form#request-form .full{grid-column:1/-1;}
.field label{display:block;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);margin-bottom:8px;}
.field input{width:100%;background:#0c0e11;border:1px solid rgba(255,255,255,.14);color:var(--txt);
  font-family:var(--body);font-size:15px;padding:15px 16px;outline:none;transition:.2s;}
.field input:focus{border-color:var(--red);}
.submit{grid-column:1/-1;margin-top:8px;display:inline-flex;align-items:center;justify-content:center;gap:14px;
  border:0;background:var(--red);color:#fff;font-family:var(--mono);font-size:14px;letter-spacing:.22em;
  text-transform:uppercase;padding:19px;cursor:pointer;transition:.25s;}
.submit:hover{background:var(--red-soft);letter-spacing:.28em;}
.form-ok{grid-column:1/-1;display:none;color:#36d0ff;font-size:13px;font-family:var(--mono);
  border:1px dashed rgba(54,208,255,.4);padding:14px;text-align:center;margin-top:6px;}
.form-ok.show{display:block;}
.cta-foot{font-family:var(--mono);font-size:11px;letter-spacing:.14em;color:var(--dim);text-transform:uppercase;margin-top:34px;}
.cta-foot a{color:var(--red-soft);}

/* ---------------- responsive ---------------- */
@media (max-width:920px){
  :root{--bar:46px;}
  .pwrap{padding:0 26px;}
  .why-row{grid-template-columns:40px 1fr;gap:14px;}
  .why-row .wd{grid-column:1/-1;}
  .char-row{grid-template-columns:1fr;}
  .cha .ph{aspect-ratio:16/10;}
  .theme-grid{grid-template-columns:1fr;}
  .theme-c{border-right:0;border-bottom:1px solid rgba(255,255,255,.1);}
  .pilot-grid{grid-template-columns:1fr;}
  .arc-steps{grid-template-columns:repeat(2,1fr);}
  .arc-step:nth-child(2){border-right:0;}
  .saga-list{grid-template-columns:repeat(2,1fr);}
  form#request-form{grid-template-columns:1fr;}
  .cine-top .mid,.cine-bot .mid{display:none;}
}
@media (max-width:560px){
  .arc-steps,.saga-list{grid-template-columns:1fr;}
}

/* ---------------- EXECUTIVE SNAPSHOT ---------------- */
.snapshot{background:linear-gradient(180deg,#070809,#050607);}
.snapshot-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;margin-top:34px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.12);}
.snapshot-row{background:#090b0e;padding:30px;min-height:190px;display:grid;grid-template-rows:auto auto 1fr;gap:12px;transition:background .25s ease,transform .25s ease;}
.snapshot-row:hover{background:#101319;transform:translateY(-2px);}
.snapshot-row .sn{font-family:var(--mono);font-size:11px;letter-spacing:.22em;color:var(--red);text-transform:uppercase;}
.snapshot-row .st{font-family:var(--disp);font-size:clamp(24px,2.8vw,38px);text-transform:uppercase;line-height:.95;color:var(--txt);}
.snapshot-row .sd{align-self:end;color:var(--mute);font-size:15px;line-height:1.55;max-width:42ch;}

@media (max-width:920px){
  .snapshot-grid{grid-template-columns:1fr;}
  .snapshot-row{min-height:auto;}
}

/* ---------------- MOBILE POLISH v3 ---------------- */
@supports (height:100svh){
  #gate{min-height:100svh;}
  .panel{min-height:100svh;}
}

@media (hover:none){
  .why-row:hover{padding-left:0;}
  .snapshot-row:hover{transform:none;}
  .comp-row span:hover{color:var(--dim);}
  .cha:hover .ph img{filter:grayscale(.35) contrast(1.05) brightness(.9);transform:none;}
}

@media (max-width:560px){
  :root{--bar:42px;}

  body{font-size:15px;}
  .cine-top,.cine-bot{padding:0 14px;font-size:9px;letter-spacing:.13em;}
  .cine-top .brand{letter-spacing:.2em;}
  .lang button{font-size:10px;padding:4px 7px;}

  .panel{padding:calc(var(--bar) + 28px) 0 calc(var(--bar) + 34px);align-items:center;}
  .panel.tall{padding:calc(var(--bar) + 42px) 0 calc(var(--bar) + 58px);}
  .pwrap{padding:0 18px;}

  .g-inner{padding:18px;}
  .g-pre{font-size:10px;letter-spacing:.32em;margin-bottom:20px;}
  .g-logo{font-size:clamp(58px,18vw,96px);line-height:.88;}
  .g-sub{font-size:11px;letter-spacing:.12em;margin-top:18px;}
  .g-enter{margin-top:34px;font-size:11px;letter-spacing:.22em;}

  .plabel{font-size:10px;letter-spacing:.22em;gap:9px;margin-bottom:20px;line-height:1.35;}
  .plabel::before{width:18px;}

  .title{font-size:clamp(38px,14vw,68px);line-height:.96;}
  .hero .title{font-size:clamp(58px,20vw,94px);line-height:.9;}
  .hero-tag{font-size:12px;line-height:1.55;max-width:30ch;margin-top:18px;}
  .scrollcue{bottom:calc(var(--bar) + 14px);font-size:9px;letter-spacing:.22em;}
  .scrollcue .ln{height:24px;}

  .logline-txt{font-size:clamp(34px,13vw,52px);max-width:16ch;line-height:1.02;}
  .logline-foot{font-size:12px;line-height:1.65;margin-top:24px;}

  .why-row{grid-template-columns:34px 1fr;gap:12px;padding:22px 0;}
  .why-row .wn{font-size:11px;}
  .why-row .wt{font-size:clamp(22px,8vw,30px);min-width:0;}
  .why-row .wd{grid-column:1/-1;font-size:14px;line-height:1.55;}

  .snapshot .title{font-size:clamp(36px,12.5vw,58px);}
  .snapshot-grid{margin-top:26px;}
  .snapshot-row{padding:24px 20px;gap:10px;}
  .snapshot-row .st{font-size:clamp(22px,8vw,32px);}
  .snapshot-row .sd{font-size:14px;line-height:1.55;}

  .comp-row{gap:8px 14px;margin:20px 0 28px;}
  .comp-row span{font-size:clamp(26px,10vw,42px);}
  .comp-formula{font-size:clamp(23px,8.5vw,34px);max-width:18ch;}

  .chars{padding:calc(var(--bar) + 52px) 0 calc(var(--bar) + 58px);}
  .char-row{gap:18px;margin-top:28px;}
  .cha .ph{aspect-ratio:4/5;}
  .cha .meta{padding:22px 18px;}
  .cha .nm{font-size:32px;}
  .cha .bi{font-size:13px;}
  .char-foot{font-size:clamp(24px,9vw,34px);}

  .quote-c{max-width:18ch;}
  .bigquote{font-size:clamp(34px,13vw,56px);line-height:1.04;}
  .quote-attr{font-size:10px;letter-spacing:.14em;line-height:1.55;}

  .theme-c{padding:28px 22px;}
  .theme-c h4{font-size:21px;}

  .pilot-grid{gap:16px;margin-top:28px;}
  .scene{min-height:350px;}
  .scene .sc-in{padding:26px 22px;}
  .scene .sc-tag{font-size:10px;letter-spacing:.16em;}
  .scene p{font-size:13.5px;}
  .scene .sys{font-size:10.5px;line-height:1.45;}

  .arc-wave,.saga-wave{margin-top:24px;}
  .arc-step{padding:22px;border-right:0;border-bottom:1px solid rgba(255,255,255,.1);}
  .arc-step:last-child{border-bottom:0;}
  .saga-i .t{font-size:31px;}

  .cta .pwrap{padding-left:18px;padding-right:18px;}
  .cta .title{font-size:clamp(38px,14vw,64px);}
  .cta .subtitle{font-size:15.5px;line-height:1.55;}
  .cta .note{font-size:10px;letter-spacing:.14em;margin-bottom:28px;}
  .field input{font-size:16px;padding:14px 15px;}
  .submit{font-size:11px;letter-spacing:.14em;padding:17px 12px;line-height:1.25;}
  .submit:hover{letter-spacing:.14em;}
  .cta-foot{font-size:9.5px;letter-spacing:.1em;line-height:1.6;}
}

@media (max-width:380px){
  .cine-top,.cine-bot{padding:0 10px;}
  .cine-top .brand{letter-spacing:.14em;}
  .pwrap{padding:0 15px;}
  .title{font-size:clamp(36px,13.5vw,58px);}
  .hero .title{font-size:clamp(54px,19vw,82px);}
  .plabel{letter-spacing:.18em;}
  .snapshot .title{font-size:clamp(34px,12vw,52px);}
  .comp-formula{max-width:17ch;}
}

/* ---------------- INLINE CTAS · v4 ---------------- */
.cta-row{margin-top:34px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.inline-cta{display:inline-flex;align-items:center;justify-content:center;gap:12px;min-height:46px;padding:13px 20px;border:1px solid var(--red);background:rgba(255,42,32,.08);color:var(--txt);font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;line-height:1.25;transition:background .25s ease,border-color .25s ease,transform .25s ease,letter-spacing .25s ease;}
.inline-cta::after{content:"→";color:var(--red-soft);font-size:14px;line-height:1;}
.inline-cta:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-1px);letter-spacing:.23em;}
.inline-cta:hover::after{color:#fff;}
.snapshot .cta-row,.pilot-grid + .cta-row,.saga-list + .cta-row{justify-content:flex-start;}

@media (max-width:920px){
  .cta-row{margin-top:28px;}
  .inline-cta{width:100%;min-height:50px;padding:14px 16px;font-size:11px;letter-spacing:.14em;}
  .inline-cta:hover{letter-spacing:.14em;transform:none;}
}


/* ---------------- LEGAL + FORM MICROCOPY ---------------- */
.form-legal{grid-column:1/-1;margin:4px 0 0;color:var(--dim);font-size:12px;line-height:1.6;text-align:left;}
.form-legal a{color:var(--red-soft);text-decoration:underline;text-underline-offset:3px;}
.legal-links{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;margin-top:18px;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);}
.legal-links a{color:var(--dim);transition:color .2s ease;}
.legal-links a:hover{color:var(--red-soft);}
.legal-page{background:#050607;min-height:100vh;padding:calc(var(--bar) + 70px) 0 calc(var(--bar) + 70px);}
.legal-page .pwrap{max-width:900px;}
.legal-kicker{font-family:var(--mono);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--red);margin-bottom:18px;}
.legal-title{font-family:var(--disp);font-weight:400;text-transform:uppercase;line-height:.95;letter-spacing:.005em;font-size:clamp(42px,7vw,96px);margin:0 0 28px;}
.legal-content{border:1px solid rgba(255,255,255,.1);background:#090b0e;padding:34px;color:#cfd4dc;}
.legal-content h2{font-family:var(--disp);font-weight:400;text-transform:uppercase;font-size:clamp(24px,3vw,38px);line-height:1;margin:34px 0 12px;color:var(--txt);}
.legal-content h2:first-child{margin-top:0;}
.legal-content p,.legal-content li{font-size:15px;line-height:1.75;color:#cfd4dc;}
.legal-content p{margin:0 0 14px;}
.legal-content ul{margin:0 0 18px;padding-left:20px;}
.legal-content a{color:var(--red-soft);text-decoration:underline;text-underline-offset:3px;}
.legal-back{display:inline-flex;margin-top:24px;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--red-soft);}
@media (max-width:560px){
  .legal-page{padding:calc(var(--bar) + 42px) 0 calc(var(--bar) + 50px);}
  .legal-content{padding:24px 20px;}
  .legal-links{gap:12px;font-size:9.5px;letter-spacing:.12em;}
}

/* ---------------- EDITORIAL CLARITY + LIGHT BALANCE · v6 ---------------- */
.hero-cta{margin-top:28px;}
.hero-cta .inline-cta{background:rgba(255,42,32,.12);backdrop-filter:blur(4px);}

.tone-row span{color:#7f8793;}
.tone-row span[data-en]{color:#7f8793;}
.comp-formula{max-width:26ch;}

.cha-angel .ph img{filter:grayscale(.18) contrast(1.04) brightness(1.08) saturate(1.05);}
.cha-angel .meta{background:linear-gradient(transparent,rgba(4,5,7,.86));}
@media (hover:none){
  .cha-angel:hover .ph img{filter:grayscale(.18) contrast(1.04) brightness(1.08) saturate(1.05);}
}

section[data-name="CONCLUSION"] .pbg.grade img{filter:contrast(1.04) brightness(.64) saturate(.95);}
section[data-name="CONCLUSION"] .pbg::after{background:radial-gradient(circle at 50% 48%,rgba(255,255,255,.08),rgba(4,5,7,.52) 42%,rgba(4,5,7,.86) 100%);}

section[data-name="THE MECHANICS"] .pbg.grade img{filter:contrast(1.05) brightness(.58) saturate(.92);}

@media (max-width:560px){
  .hero-cta{margin-top:22px;}
  .hero-cta .inline-cta{width:auto;min-width:0;padding-left:18px;padding-right:18px;}
  .tone-row span{font-size:clamp(24px,9vw,38px);}
  .comp-formula{max-width:19ch;}
}


/* ---------------- VISUAL BREATHING + READABILITY · v6.1 ---------------- */
/* Más rango tonal: mantiene la oscuridad, pero evita que todas las escenas queden aplastadas. */
.pbg.grade img{filter:contrast(1.05) brightness(.57) saturate(.96);}
.pbg::after{background:linear-gradient(180deg,rgba(4,5,7,.46) 0%,rgba(4,5,7,.16) 38%,rgba(4,5,7,.72) 100%);}
.pbg.left::after{background:linear-gradient(90deg,rgba(4,5,7,.78) 0%,rgba(4,5,7,.46) 44%,rgba(4,5,7,.18) 100%);}
.pbg.right::after{background:linear-gradient(270deg,rgba(4,5,7,.78) 0%,rgba(4,5,7,.45) 44%,rgba(4,5,7,.18) 100%);}

/* Un poco de aire para las zonas de humanidad / ángel / verdad. */
.chars{background:radial-gradient(circle at 78% 28%,rgba(255,230,190,.075),transparent 34%),#050507;}
.cha-angel .ph{position:relative;}
.cha-angel .ph::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 48% 20%,rgba(255,238,205,.16),transparent 44%);mix-blend-mode:screen;opacity:.55;}
.cha-angel .ph img{filter:grayscale(.10) contrast(1.02) brightness(1.12) saturate(1.04);}

/* Evita que titulares largos parezcan cortados en escritorio. */
.mechanics-panel .quote-c{max-width:34ch !important;}
.mechanics-panel .bigquote{font-size:clamp(38px,4.6vw,70px);line-height:1.02;max-width:34ch;}
.mechanics-panel .quote-attr{max-width:44ch;}
.mechanics-panel .pwrap{padding-top:10px;padding-bottom:10px;}
.mechanics-panel .pbg.grade img{filter:contrast(1.03) brightness(.64) saturate(.96);}
.mechanics-panel .pbg.left::after{background:linear-gradient(90deg,rgba(4,5,7,.82) 0%,rgba(4,5,7,.44) 45%,rgba(4,5,7,.12) 100%);}

/* El cierre mantiene misterio, pero con sensación de revelación y no solo opresión. */
.truth-lift .pbg.grade img{filter:contrast(1.03) brightness(.70) saturate(.98);}
.truth-lift .pbg::after{background:radial-gradient(circle at 50% 45%,rgba(255,232,190,.14),rgba(4,5,7,.44) 42%,rgba(4,5,7,.82) 100%);}
.truth-lift .bigquote{font-size:clamp(34px,4.5vw,64px);}

@media (max-height:820px) and (min-width:921px){
  .bigquote{font-size:clamp(32px,4.25vw,62px);}
  .mechanics-panel .bigquote{font-size:clamp(32px,4vw,58px);}
  .mechanics-panel .quote-c{max-width:36ch !important;}
  .panel{padding-top:calc(var(--bar) + 28px);padding-bottom:calc(var(--bar) + 28px);}
}

@media (max-width:920px){
  .mechanics-panel .quote-c{max-width:24ch !important;}
  .mechanics-panel .bigquote{font-size:clamp(32px,8.5vw,54px);}
}

@media (max-width:560px){
  .pbg.grade img{filter:contrast(1.04) brightness(.60) saturate(.96);}
  .mechanics-panel .quote-c{max-width:19ch !important;}
  .mechanics-panel .bigquote{font-size:clamp(30px,11vw,46px);}
  .truth-lift .bigquote{font-size:clamp(32px,11.5vw,50px);}
  .cha-angel .ph img{filter:grayscale(.08) contrast(1.02) brightness(1.10) saturate(1.04);}
}

/* ---------------- COPY + CTA REFINEMENT v6.2 ---------------- */
.hero-cta{margin-top:34px;max-width:640px;}
.hero-cta .inline-cta{backdrop-filter:blur(8px);}
.ghost-cta{background:rgba(255,255,255,.035);border-color:rgba(255,255,255,.22);color:#dfe3ea;}
.ghost-cta::after{color:var(--red-soft);}
.ghost-cta:hover{background:rgba(255,42,32,.18);border-color:var(--red);}

.arc-step p{font-size:14.5px;line-height:1.55;}

@media (max-width:920px){
  .hero-cta{margin-top:28px;max-width:none;}
  .hero-cta .inline-cta + .inline-cta{margin-top:10px;}
}

@media (max-width:560px){
  .hero-cta{margin-top:24px;}
  .hero-cta .inline-cta{min-height:48px;}
  .hero-cta .ghost-cta{min-height:42px;font-size:10px;opacity:.86;}
  .arc-step p{font-size:13.5px;line-height:1.6;}
}

/* ---------------- SECURE FORM v7 ---------------- */
.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;overflow:hidden!important;opacity:0!important;pointer-events:none!important;}
.turnstile-wrap{grid-column:1/-1;margin:8px 0 2px;display:flex;justify-content:flex-start;min-height:65px;}
.form-error{grid-column:1/-1;display:none;color:#ff8a80;font-size:13px;font-family:var(--mono);border:1px dashed rgba(255,138,128,.45);padding:14px;text-align:center;margin-top:6px;}
.form-error.show{display:block;}
.submit.is-loading{opacity:.65;pointer-events:none;}
@media (max-width:560px){.turnstile-wrap{transform:scale(.92);transform-origin:left top;margin-bottom:-4px;}}


/* ---------------- FORM HARDENING PATCH v7.1 ---------------- */
.hp-field{
  position:absolute!important;left:-10000px!important;top:auto!important;
  width:1px!important;height:1px!important;overflow:hidden!important;
  opacity:0!important;pointer-events:none!important;clip:rect(0 0 0 0)!important;
  clip-path:inset(50%)!important;white-space:nowrap!important;
}
.form-ok:not(.show),.form-error:not(.show){display:none!important;}
.field input:-webkit-autofill,
.field input:-webkit-autofill:hover,
.field input:-webkit-autofill:focus{
  -webkit-text-fill-color:var(--txt);
  box-shadow:0 0 0 1000px #0c0e11 inset;
  transition:background-color 9999s ease-in-out 0s;
}
