:root{
  --cream:#F7EFD7;
  --band:#F1E2A0;
  --orange:#DE5E3B;
  --orange-dk:#C24C2B;
  --black:#161616;
  --bar:#EAE3D6;
  --ink:#1a1a1a;
  --maxw:480px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  color:var(--cream);
  background:var(--black);
  line-height:1.4;
  padding-bottom:92px;
  -webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 22px}

/* scarcity band */
.band{background:var(--band);color:#171717;text-align:center;
  font-weight:700;font-size:14.5px;padding:13px 18px;letter-spacing:.2px}

/* sections */
section{padding:44px 0}
.bg-orange{background:var(--orange);color:var(--cream)}
.bg-black{background:var(--black);color:var(--cream)}
.bg-cream{background:var(--cream);color:var(--ink)}

/* type */
.display{font-family:"Fraunces",Georgia,serif;font-weight:600;
  font-size:clamp(38px,11vw,52px);line-height:1.03;letter-spacing:-.5px}
.display.sm{font-size:clamp(29px,8.2vw,38px)}
.eyebrow{font-weight:700;text-transform:uppercase;letter-spacing:1.6px;
  font-size:11.5px;opacity:.82;margin-bottom:14px}
.lead{font-size:18px;line-height:1.5;margin-top:18px;opacity:.95}
.marker{font-family:"Permanent Marker",cursive;display:inline-block;
  transform:rotate(-3deg);font-weight:400}
.bg-orange .marker,.bg-cream .marker{color:#161616}
.bg-black .marker{color:var(--orange)}

/* lists */
.checks{list-style:none;margin:24px 0 0}
.checks li{position:relative;padding:12px 0 12px 34px;font-size:17px;
  border-bottom:1px solid rgba(255,255,255,.12)}
.bg-cream .checks li{border-bottom:1px solid rgba(0,0,0,.1)}
.checks li:before{content:"\2713";position:absolute;left:0;top:11px;
  color:var(--orange);font-weight:800;font-size:18px}

/* price tiers */
.tiers{display:grid;gap:15px;margin-top:26px}
.tier{background:rgba(0,0,0,.05);border:1px solid rgba(0,0,0,.14);
  border-radius:16px;padding:22px}
.tier.hero{background:var(--orange);border-color:var(--orange);color:var(--cream)}
.tier .price{font-family:"Fraunces",serif;font-size:34px;font-weight:600;line-height:1}
.tier .name{font-weight:700;font-size:13px;text-transform:uppercase;
  letter-spacing:.5px;margin-bottom:8px}
.tier .desc{font-size:15px;opacity:.92;margin-top:8px;line-height:1.45}

/* proof image — stack of sheets to convey "paquete", not one loose doc */
.proof{position:relative;margin:36px auto 14px;max-width:300px}
.proof .sheet{position:relative;z-index:3;display:block;border-radius:12px;overflow:hidden;
  box-shadow:0 18px 40px rgba(0,0,0,.34)}
.proof .sheet img{display:block;width:100%}
.proof:before,.proof:after{content:"";position:absolute;left:0;right:0;top:0;bottom:0;
  border-radius:12px;background:#f3eee2;box-shadow:0 10px 24px rgba(0,0,0,.22)}
.proof:before{z-index:1;transform:rotate(-5deg) translateY(9px) scale(.99)}
.proof:after{z-index:2;transform:rotate(3.5deg) translateY(4px)}
.proof-cap{text-align:center;font-size:13.5px;opacity:.72;max-width:330px;
  margin:0 auto;line-height:1.45}
.ph{aspect-ratio:3/4;background:#fff;color:#9a9a9a;display:flex;
  align-items:center;justify-content:center;text-align:center;padding:24px;
  font-size:13px;line-height:1.4}

/* buttons */
.btn{display:inline-block;background:var(--orange);color:#fff;font-weight:800;
  text-decoration:none;padding:17px 26px;border-radius:14px;font-size:16px;
  text-align:center;border:none;cursor:pointer;letter-spacing:.3px}
.btn:active{background:var(--orange-dk)}
.btn.block{display:block;width:100%}

/* route cards (index) — r-doc/r-dir avoid colliding with legal .doc page class */
.route{display:block;text-decoration:none;border-radius:18px;padding:22px 20px;
  margin-top:15px;overflow:hidden;text-align:left}
.route.r-doc{background:var(--orange);color:var(--cream)}
.route.r-dir{background:#1f1f1f;color:var(--cream);border:1px solid rgba(255,255,255,.16)}
.route h3{font-family:"Fraunces",serif;font-size:24px;font-weight:600;margin-bottom:6px}
.route .route-tag{font-size:14.5px;font-weight:700;opacity:1;margin-bottom:8px}
.route .route-desc{font-size:14px;line-height:1.5;opacity:.9;margin-bottom:16px}
.route .route-cta{display:flex;align-items:center;justify-content:space-between;gap:10px;
  font-weight:800;font-size:14.5px;padding:13px 18px;border-radius:12px;letter-spacing:.2px}
.route.r-doc .route-desc{opacity:.95}
.route.r-doc .route-cta{background:var(--cream);color:var(--orange-dk)}
.route.r-dir .route-cta{background:var(--orange);color:#fff}
.route .arrow{display:none}

/* form */
.field{margin-top:15px}
.field label{display:block;font-weight:600;font-size:14px;margin-bottom:6px}
.field input,.field select{width:100%;padding:14px;border-radius:12px;
  border:1.5px solid rgba(0,0,0,.2);font-size:16px;font-family:inherit;
  background:#fff;color:#161616}

/* sticky bar */
.sticky{position:fixed;left:0;right:0;bottom:0;background:var(--bar);
  border-top:1px solid rgba(0,0,0,.1);z-index:50}
.sticky .wrap{display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:11px 18px}
.sticky .brand{font-weight:800;color:#161616;font-size:16px;white-space:nowrap}
.sticky .btn{padding:14px 20px;font-size:15px}

.mt{margin-top:22px}
small.note{display:block;opacity:.62;font-size:12px;margin-top:14px;line-height:1.4}

/* billboard at night (estilo reference) */
.bb-scene{margin:26px -22px 4px;padding:34px 22px 28px;position:relative;overflow:hidden;
  background:radial-gradient(120% 75% at 50% 16%, #2d2d30 0%, #18181a 52%, #0d0d0e 100%)}
.bb{position:relative;max-width:330px;margin:0 auto}
.bb-lights{display:flex;justify-content:center;gap:52px;position:relative;z-index:3;margin-bottom:-4px}
.bb-lamp{position:relative;width:34px}
.bb-lamp:before{content:"";display:block;width:34px;height:11px;border-radius:5px 5px 2px 2px;
  background:linear-gradient(#3c3c40,#1f1f22);margin:0 auto;box-shadow:0 1px 3px rgba(0,0,0,.6)}
.bb-lamp:after{content:"";position:absolute;left:50%;top:11px;width:3px;height:13px;
  background:#2a2a2c;transform:translateX(-50%)}
.bb-cone{position:absolute;top:9px;left:50%;transform:translateX(-50%);width:78px;height:118px;
  background:linear-gradient(to bottom, rgba(255,238,180,.42), rgba(255,238,180,0));
  clip-path:polygon(44% 0, 56% 0, 100% 100%, 0 100%);filter:blur(2px);z-index:2;pointer-events:none}
.bb-panel{position:relative;z-index:1;background:#201e1a;padding:11px;border-radius:5px;
  border:2px solid #100f0b;box-shadow:0 20px 44px rgba(0,0,0,.6),inset 0 0 0 2px rgba(255,255,255,.05)}
.bb-panel .screen{background:#fff;border-radius:3px;overflow:hidden}
.bb-panel .screen img{display:block;width:100%}
.bb-panel .screen .ph{aspect-ratio:16/10;background:#fafafa;color:#9a9a9a;display:flex;
  align-items:center;justify-content:center;text-align:center;padding:18px;font-size:12.5px;line-height:1.4}
.bb-post{width:30px;height:72px;margin:0 auto;position:relative;z-index:0;border-left:2px solid #2c2c2c;
  border-right:2px solid #2c2c2c;
  background:repeating-linear-gradient(45deg,#262626 0 5px,#171717 5px 10px)}
.bb-scene .glow{position:absolute;bottom:18px;width:5px;height:5px;border-radius:50%;
  background:#ffd98a;box-shadow:0 0 13px 3px rgba(255,210,120,.5);z-index:0}
.bb-scene .g1{left:13%}.bb-scene .g2{left:36%}.bb-scene .g3{right:31%}.bb-scene .g4{right:11%}
.bb-cap{font-family:"Permanent Marker",cursive;color:var(--orange);text-align:center;
  font-size:18px;margin-top:18px;transform:rotate(-2deg)}
.bb-cap .arrow{display:inline-block;transform:rotate(10deg);margin-right:4px}
.hero-img{display:block;width:calc(100% + 44px);margin:30px -22px -44px;border-radius:0}

/* cookie banner */
#cookies{display:none;position:fixed;left:0;right:0;bottom:0;z-index:210;background:#1a1a1a;
  border-top:1px solid rgba(247,239,215,.18);padding:14px 18px}
#cookies .ck-inner{max-width:560px;margin:0 auto;display:flex;align-items:center;gap:14px;
  justify-content:space-between;flex-wrap:wrap;color:rgba(247,239,215,.9);font-size:13px;line-height:1.4}
#cookies a{color:var(--orange);font-weight:600}
#cookies .ck-btns{display:flex;gap:8px;flex:none}
#cookies button{font-family:inherit;font-weight:700;font-size:13px;border-radius:9px;padding:9px 16px;cursor:pointer;border:none}
#cookies .ck-yes{background:var(--orange);color:#fff}
#cookies .ck-no{background:transparent;color:rgba(247,239,215,.7);border:1px solid rgba(247,239,215,.35)}

/* country gate */
#gate{position:fixed;top:0;left:0;width:100%;height:100%;z-index:200;background:#0e0e0f;display:flex;
  align-items:center;justify-content:center;text-align:center;padding:26px}
#gate.gate-out{animation:gateOut .45s ease forwards}
@keyframes gateIn{from{opacity:0}to{opacity:1}}
@keyframes gateOut{from{opacity:1}to{opacity:0;visibility:hidden}}
.gate-inner{max-width:330px;width:100%;animation:gateUp .6s .08s ease both}
@keyframes gateUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.gate-brand{font-weight:800;color:var(--cream);letter-spacing:.5px;margin-bottom:16px;opacity:.8;font-size:15px}
.gate-q{font-family:"Fraunces",Georgia,serif;color:var(--cream);font-size:34px;font-weight:600;line-height:1.1;margin-bottom:28px}
.gate-btns{display:flex;flex-direction:column;gap:12px}
.btn.ghost-light{background:transparent;border:1.5px solid rgba(247,239,215,.4);color:var(--cream)}
.btn.ghost-light:active{background:rgba(247,239,215,.08)}

/* mobile polish */
@media (max-width:480px){
  section{padding:34px 0}
  .wrap{padding:0 20px}
  .display{font-size:clamp(33px,9.4vw,44px);line-height:1.06}
  .display.sm{font-size:clamp(26px,7.4vw,33px)}
  .lead{font-size:17px;margin-top:16px}
  .eyebrow{font-size:11px}
  .route h3{font-size:23px}
  .hero-img{width:calc(100% + 40px);margin:24px -20px -34px}
  .checks li{font-size:16px}
  .band{font-size:13.5px;padding:12px 16px}
}

/* faq */
.faq details{border-bottom:1px solid rgba(255,255,255,.14);padding:2px 0}
.bg-cream .faq details{border-bottom:1px solid rgba(0,0,0,.12)}
.faq summary{cursor:pointer;font-weight:700;font-size:16px;padding:15px 0;list-style:none;
  display:flex;justify-content:space-between;gap:12px;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:"+";font-size:22px;font-weight:400;opacity:.55}
.faq details[open] summary:after{content:"\2212"}
.faq p{font-size:15px;line-height:1.5;opacity:.9;padding:0 0 15px;margin:0}

/* consent checkbox */
.consent{display:flex;gap:10px;align-items:flex-start;margin-top:16px;font-size:13px;line-height:1.45}
.consent input{margin-top:2px;width:18px;height:18px;flex:none}
.consent a{color:var(--orange);font-weight:600}

/* legal doc page */
.doc{padding:34px 0 64px}
.doc h1{font-family:"Fraunces",Georgia,serif;font-size:32px;font-weight:600;margin-bottom:6px}
.doc h2{font-family:"Fraunces",Georgia,serif;font-size:22px;font-weight:600;margin:26px 0 8px}
.doc p{font-size:15px;line-height:1.6;opacity:.92;margin-bottom:10px}
.doc a{color:var(--orange);font-weight:600}
.doc .upd{opacity:.55;font-size:13px}
.doc ul{margin:0 0 10px 18px}
.doc li{font-size:15px;line-height:1.6;opacity:.92;margin-bottom:6px}

/* textarea */
.field textarea{width:100%;padding:14px;border-radius:12px;border:1.5px solid rgba(0,0,0,.2);
  font-size:16px;font-family:inherit;background:#fff;color:#161616;min-height:96px;resize:vertical}

/* how it works steps */
.steps{list-style:none;counter-reset:step;margin:26px 0 0}
.steps li{position:relative;padding:0 0 22px 52px;counter-increment:step}
.steps li:before{content:counter(step);position:absolute;left:0;top:0;
  width:34px;height:34px;border-radius:50%;background:var(--orange);color:#fff;
  font-family:"Fraunces",serif;font-weight:600;font-size:18px;
  display:flex;align-items:center;justify-content:center}
.steps li:not(:last-child):after{content:"";position:absolute;left:16px;top:40px;
  bottom:4px;width:2px;background:rgba(0,0,0,.12)}
.steps h4{font-size:17px;font-weight:700;margin-bottom:3px;line-height:1.25}
.steps p{font-size:15px;line-height:1.45;opacity:.85;margin:0}
.steps .ex{font-style:italic;color:var(--orange-dk);opacity:.95}
.diff{font-family:"Fraunces",serif;font-size:clamp(21px,6vw,25px);line-height:1.25;
  font-weight:600;margin-top:30px}
.promise{font-size:17px;line-height:1.5;opacity:.95;margin-top:18px}

/* footer */
.foot{background:#0f0f0f;padding:26px 0 30px;text-align:center}
.foot a{color:rgba(247,239,215,.72);text-decoration:none;font-size:13px}
.foot a:hover{color:var(--orange)}
.foot .row a{margin:0 7px}
.foot .lr{display:inline-flex;align-items:center;gap:6px;border:1px solid rgba(247,239,215,.28);
  border-radius:9px;padding:7px 12px;color:rgba(247,239,215,.85);margin-top:12px}
.foot .cc{font-size:12px;opacity:.4;margin-top:14px}
