/* =========================================================
   TID · 5 AÑOS — VICIO collage OSCURO · SCROLL 100% LATERAL
   ========================================================= */
:root{
  --bg:#0b0a0e; --surface:#16131f; --surface2:#1d1928; --ink:#0c0b0f; --paper:#f4ecd9;
  --magenta:#ff2e7e; --gold:#e7ad3e; --blue:#36b6ff;
  --purple:#8e2d6b; --lime:#c8ff3d; --red:#ff2b2b;
  --line:#2c2738;
  --shadow:7px 7px 0 #000;
}
*{margin:0;padding:0;box-sizing:border-box}
body{
  background:var(--bg);color:var(--paper);
  font-family:"General Sans","Satoshi",system-ui,sans-serif;
  overflow-x:hidden;cursor:none;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;border:0;background:none;color:inherit}
::selection{background:var(--magenta);color:#fff}

h1,h2,h3{font-family:"Clash Display",sans-serif;font-weight:800;line-height:.88;letter-spacing:-.025em;text-transform:uppercase;color:var(--paper)}
.hl-pink{color:var(--magenta)} .hl-blue{color:var(--blue)} .hl-gold{color:var(--gold)}

/* ---------- cursor-logo TID (bloques reales del logo; la T delante; i y d persiguen) ---------- */
.tidcur{position:fixed;top:0;left:0;pointer-events:none;will-change:transform;
  filter:drop-shadow(3px 3px 0 rgba(0,0,0,.55))}
.tidcur svg{display:block;height:42px;width:auto}
#curT{z-index:9999} #curI{z-index:9998} #curD{z-index:9997}
@media (hover:none){.tidcur{display:none}body{cursor:auto}}

/* ---------- botones ---------- */
.btn{position:relative;display:inline-flex;align-items:center;gap:.5em;
  font-family:"Clash Display";font-weight:700;text-transform:uppercase;
  font-size:clamp(.85rem,1.1vw,1.05rem);padding:.85em 1.6em;border-radius:999px;
  border:3px solid #000;white-space:nowrap;will-change:transform}
.btn--pop{background:var(--lime);color:var(--ink);box-shadow:var(--shadow)}
.btn--ghost{background:#fff;color:var(--ink);border-color:#000;box-shadow:var(--shadow)}
.btn--lg{font-size:clamp(.95rem,1.5vw,1.25rem);padding:1em 1.7em}

/* =========================================================
   UI FIJA
   ========================================================= */
.brand{position:fixed;top:16px;left:clamp(16px,3vw,40px);z-index:200;will-change:transform}
.brand img{height:clamp(46px,5.4vw,66px)}

.hud{position:fixed;top:24px;right:clamp(16px,3vw,40px);z-index:200;display:flex;gap:15px;align-items:center}
.hud button,.hud a{font-family:"Clash Display";font-weight:600;text-transform:uppercase;
  font-size:.82rem;letter-spacing:.02em;cursor:none;position:relative;will-change:transform;color:var(--paper)}
.hud button::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:3px;background:var(--magenta);transition:width .25s}
.hud button:hover::after{width:100%}
.hud__cta{background:var(--magenta);color:#fff!important;border:3px solid #000;
  padding:.6em 1.1em;border-radius:999px;box-shadow:4px 4px 0 #000}
@media(max-width:920px){.hud button{display:none}}

.scrollhint{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);z-index:200;
  font-family:"Clash Display";font-weight:700;text-transform:uppercase;letter-spacing:.2em;
  font-size:.78rem;color:var(--ink);display:flex;gap:.6em;align-items:center;
  background:var(--lime);border:3px solid #000;padding:.5em 1em;border-radius:999px;box-shadow:4px 4px 0 #000}
.scrollhint span{display:inline-block;animation:nudge 1.1s ease-in-out infinite}
@keyframes nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(8px)}}

.progress{position:fixed;left:0;bottom:0;width:100%;height:6px;background:#221d30;z-index:200}
.progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--magenta),var(--gold),var(--blue))}

/* =========================================================
   CINTA HORIZONTAL
   ========================================================= */
#pin{height:100vh;overflow:hidden}
#track{display:flex;height:100vh;align-items:stretch;width:max-content}
.scene{position:relative;height:100vh;flex:0 0 auto;background:transparent;
  display:flex;flex-direction:column;justify-content:center;
  padding:0 clamp(40px,7vw,130px);overflow:hidden}

/* =========================================================
   STICKERS / DECORACIONES
   ========================================================= */
.sticker{position:absolute;font-family:"Clash Display";font-weight:700;text-transform:uppercase;
  padding:.55em 1.05em;border:3px solid #000;box-shadow:5px 5px 0 #000;
  font-size:clamp(.82rem,1.15vw,1.05rem);z-index:30;white-space:nowrap;border-radius:9px;line-height:1.05}
.st-pink{background:var(--magenta);color:#fff} .st-blue{background:var(--blue);color:var(--ink)}
.st-gold{background:var(--gold);color:var(--ink)} .st-lime{background:var(--lime);color:var(--ink)}
.st-red{background:var(--red);color:#fff} .st-ink{background:#fff;color:var(--ink)}
.st-paper{background:#fff;color:var(--ink)}
.st-chrome{background:linear-gradient(135deg,#d9d9e6,#9fa6c4 40%,#f2f0ff 60%,#aab0cc);color:var(--ink);border-color:#000}
.sticker.round{border-radius:999px}
.sticker.badge{border-radius:16px;text-align:center;box-shadow:6px 6px 0 #000;transform:rotate(-6deg);padding:.7em 1.1em}
.sticker.badge b{display:block;font-size:1.45em;line-height:1.05}
.sticker.badge small{display:block;font-size:.74em;font-weight:600;letter-spacing:.01em;opacity:.95;margin-top:.25em}

/* fuentes variadas para los stickers (cada uno distinto) */
.f-anton{font-family:"Anton",sans-serif!important;font-weight:400;letter-spacing:.03em}
.f-serif{font-family:"DM Serif Display",Georgia,serif!important;font-weight:400;font-style:italic;text-transform:none;letter-spacing:0}
.f-mono{font-family:"Space Mono",ui-monospace,monospace!important;font-weight:700;letter-spacing:.01em}
.f-syne{font-family:"Syne",sans-serif!important;font-weight:800;letter-spacing:-.01em}
.f-sat{font-family:"Satoshi","General Sans",sans-serif!important;font-weight:900;letter-spacing:-.01em}

.deco{position:absolute;z-index:6;font-family:"Clash Display";font-weight:800;
  pointer-events:none;line-height:1;user-select:none}
.deco.d-star{color:var(--magenta)} .deco.d-spark{color:var(--blue)}
.deco.d-arrow{color:var(--paper)} .deco.d-gold{color:var(--gold)}

.lbl{position:absolute;z-index:6;font-family:ui-monospace,"Cascadia Code",monospace;
  font-size:.66rem;letter-spacing:.04em;color:var(--paper);text-transform:uppercase;
  display:flex;align-items:center;gap:.4em;white-space:nowrap;opacity:.75}
.lbl::before{content:"";width:9px;height:9px;border:2px solid var(--paper);border-radius:50%}
.lbl.box::before{border-radius:0}

.tile{position:absolute;z-index:5;border:4px solid #000;box-shadow:10px 10px 0 #000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:16px;overflow:hidden}
.tile--logo{background:#fff}
.tile--logo img{width:78%}

/* =========================================================
   HERO
   ========================================================= */
.scene--hero{width:100vw;justify-content:center}
.bgword{position:absolute;left:-2vw;top:50%;transform:translateY(-50%);
  font-family:"Clash Display";font-weight:800;font-size:34vw;color:rgba(255,255,255,.045);
  letter-spacing:-.04em;pointer-events:none;z-index:0}
.hero__tag{position:relative;z-index:5;display:inline-flex;align-items:center;gap:.6em;width:max-content;
  background:#fff;border:3px solid #000;padding:.5em 1em;border-radius:999px;box-shadow:4px 4px 0 #000;color:var(--ink);
  font-family:"Clash Display";font-weight:600;text-transform:uppercase;font-size:.78rem;margin-bottom:22px}
.hero__tag .dot{width:10px;height:10px;border-radius:50%;background:var(--magenta)}
.hero__title{position:relative;z-index:5;font-size:clamp(3rem,9vw,8.6rem);margin-bottom:22px}
.hero__sub{position:relative;z-index:5;font-size:clamp(1rem,1.7vw,1.35rem);max-width:30ch;line-height:1.4;font-weight:600;margin-bottom:24px;color:#d9d2c4}
.hero__sub b{color:var(--lime)}
.scene--hero .btn{position:relative;z-index:5;align-self:flex-start}
.five{position:absolute;right:5vw;top:50%;transform:translateY(-50%);z-index:2;
  font-family:"Clash Display";font-weight:800;font-size:clamp(16rem,40vh,40rem);line-height:.8;
  color:var(--magenta);-webkit-text-stroke:5px #000;text-shadow:16px 16px 0 var(--blue);pointer-events:none}
@media(max-width:900px){.five{opacity:.22;right:-4vw}}

/* =========================================================
   RIBBON
   ========================================================= */
.ribbon{flex:0 0 auto;width:clamp(74px,8vw,120px);height:100vh;overflow:hidden;
  border-left:4px solid #000;border-right:4px solid #000;position:relative}
.ribbon--pink{background:var(--magenta);color:#fff}
.ribbon--lime{background:var(--lime);color:var(--ink)}
.ribbon--red{background:var(--red);color:#fff}
.ribbon__tk{position:absolute;top:50%;left:50%;transform-origin:center;
  white-space:nowrap;font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(1.6rem,2.4vw,2.4rem);letter-spacing:-.01em;animation:ribbonmove 16s linear infinite}
.ribbon--lime .ribbon__tk{animation-direction:reverse}
@keyframes ribbonmove{
  from{transform:translate(-50%,-50%) rotate(90deg) translateX(0)}
  to{transform:translate(-50%,-50%) rotate(90deg) translateX(-50%)}
}

/* =========================================================
   MANIFIESTO
   ========================================================= */
.scene--mani{width:90vw;justify-content:center}
.mani{font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(2.4rem,7vw,6rem);line-height:1;max-width:16ch}
.mw{display:inline-block;color:var(--paper);opacity:.16;transition:opacity .15s}
.mw.is-on{opacity:1}
.mw.stamp{color:var(--gold);opacity:.32}.mw.stamp.is-on{opacity:1}

/* =========================================================
   SERVICIOS
   ========================================================= */
.scene--serv{flex-direction:row;align-items:center;gap:clamp(22px,2.5vw,40px)}
.serv__head{flex:0 0 auto;width:34vw;min-width:280px}
.serv__head .kick{font-family:"Clash Display";font-weight:700;letter-spacing:.1em;color:var(--magenta)}
.serv__head h2{font-size:clamp(3rem,8vw,7rem);margin-top:10px}
.card{position:relative;flex:0 0 auto;width:clamp(300px,30vw,400px);height:66vh;
  border:4px solid #000;border-radius:18px;padding:36px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:14px 14px 0 #000;overflow:hidden}
.card--pink{background:var(--magenta);color:#fff} .card--gold{background:var(--gold);color:var(--ink)}
.card--blue{background:var(--blue);color:var(--ink)} .card--purple{background:var(--purple);color:#fff}
.card--lime{background:var(--lime);color:var(--ink)}
.card__no{font-family:"Clash Display";font-weight:800;font-size:clamp(3rem,6vw,5rem);line-height:1;opacity:.85}
.card h3{font-size:clamp(1.6rem,2.6vw,2.4rem);color:inherit}
.card p{font-size:clamp(.95rem,1.2vw,1.15rem);font-weight:600;max-width:24ch;line-height:1.35}
.card__sticker{position:absolute;top:22px;right:-6px;background:#000;color:var(--paper);
  padding:.4em .9em;border-radius:6px;font-family:"Clash Display";font-weight:700;text-transform:uppercase;
  font-size:.8rem;transform:rotate(6deg);box-shadow:4px 4px 0 rgba(0,0,0,.4)}

/* =========================================================
   NÚMEROS
   ========================================================= */
.scene--nums{flex-direction:row;align-items:center;gap:clamp(18px,2vw,34px)}
.nums__head{flex:0 0 auto;width:30vw;min-width:260px}
.nums__head h2{font-size:clamp(2.6rem,6.5vw,6rem)}
.stat{flex:0 0 auto;width:clamp(180px,15vw,230px);height:46vh;min-height:280px;
  border:3px solid var(--line);border-radius:16px;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;padding:16px;background:var(--surface);box-shadow:7px 7px 0 #000}
.stat__n{font-family:"Clash Display";font-weight:800;font-size:clamp(2.6rem,5vw,4.4rem);line-height:1;color:var(--lime)}
.stat__l{margin-top:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;color:#b7afa0}
.stat:nth-child(3) .stat__n{color:var(--magenta)}
.stat:nth-child(4) .stat__n{color:var(--blue)}
.stat:nth-child(5) .stat__n{color:var(--gold)}
.stat:nth-child(6) .stat__n{color:var(--magenta)}
.stat:nth-child(7) .stat__n{color:var(--blue)}

/* =========================================================
   PROCESO
   ========================================================= */
.scene--proc{flex-direction:row;align-items:center;gap:clamp(20px,2.4vw,38px)}
.proc__head{flex:0 0 auto;width:28vw;min-width:250px}
.proc__head h2{font-size:clamp(2.6rem,7vw,6rem)}
.step{flex:0 0 auto;width:clamp(240px,22vw,300px);height:58vh;min-height:340px;
  border:4px solid #000;border-radius:16px;padding:32px;color:var(--ink);
  display:flex;flex-direction:column;justify-content:space-between;box-shadow:12px 12px 0 #000}
.step--pink{background:var(--magenta);color:#fff} .step--blue{background:var(--blue)}
.step--gold{background:var(--gold)} .step--purple{background:var(--purple);color:#fff}
.step h3{color:inherit}
.step__n{font-family:"Clash Display";font-weight:800;font-size:clamp(3rem,5vw,4.6rem);line-height:1}
.step h3{font-size:clamp(1.5rem,2.4vw,2.2rem)}
.step p{font-weight:600;font-size:1rem;line-height:1.35}

/* =========================================================
   CASOS
   ========================================================= */
.scene--cases{flex-direction:row;align-items:center;gap:clamp(16px,1.8vw,28px)}
.cases__head{flex:0 0 auto;width:26vw;min-width:240px}
.cases__head h2{font-size:clamp(3rem,8vw,7rem)}
.chip{flex:0 0 auto;display:flex;align-items:center;justify-content:center;text-align:center;
  width:clamp(180px,16vw,240px);height:clamp(180px,16vw,240px);border-radius:50%;
  border:4px solid #000;font-family:"Clash Display";font-weight:700;text-transform:uppercase;
  font-size:clamp(1.05rem,1.5vw,1.4rem);padding:20px;background:#fff;color:var(--ink);box-shadow:7px 7px 0 #000}
.chip:nth-child(2){background:var(--magenta);color:#fff}
.chip:nth-child(4){background:var(--gold);color:var(--ink)}
.chip:nth-child(6){background:var(--blue);color:var(--ink)}

/* =========================================================
   CONTACTO
   ========================================================= */
.scene--contact{width:100vw;align-items:center;text-align:center}
.contact__big{display:flex;flex-direction:column;align-items:center;gap:6px;
  font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(2.6rem,7vw,6rem);line-height:.95}
.contact__logo{height:clamp(60px,9vw,110px);margin:4px 0}
.contact__btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin:34px 0 22px}
.contact__soc{display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
  font-family:"Clash Display";font-weight:600;text-transform:uppercase;font-size:.9rem}
.contact__soc a:hover{color:var(--lime)}
.copy{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
  font-family:ui-monospace,monospace;font-weight:600;font-size:.74rem;color:#8a8478;white-space:nowrap}

/* =========================================================
   ESCENA SHOWCASE · "UNIVERSO TID"
   ========================================================= */
.scene--show{flex-direction:row;align-items:center;gap:clamp(20px,2.4vw,40px)}
.show__head{flex:0 0 auto;width:28vw;min-width:250px;position:relative;z-index:5}
.show__head .kick{font-family:"Clash Display";font-weight:700;letter-spacing:.1em;color:var(--magenta)}
.show__head h2{font-size:clamp(3rem,8vw,7.5rem);margin-top:10px}
.show__head h2 .o{-webkit-text-stroke:3px var(--paper);color:transparent}

.show__grid{flex:0 0 auto;display:grid;grid-template-rows:repeat(2,38vh);
  grid-auto-flow:column;grid-auto-columns:clamp(220px,20vw,300px);gap:clamp(12px,1.4vw,22px)}
.mtile{position:relative;border:4px solid #000;border-radius:14px;overflow:hidden;
  box-shadow:10px 10px 0 #000;display:flex;align-items:flex-end;padding:14px}
.mtile.tall{grid-row:span 2}
.mtile__lbl{position:relative;z-index:2;font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(1rem,1.6vw,1.5rem);line-height:.95;color:#fff;text-shadow:2px 2px 0 #000}
.mtile--logo{background:#fff;align-items:center;justify-content:center}
.mtile--logo img{width:80%}
.mtile--item{background:var(--surface2);align-items:center;justify-content:center;padding:18px}

/* MONOGRAMA */
.mono{position:absolute;inset:-20%;display:block;
  font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(1.4rem,2.4vw,2.2rem);line-height:.86;letter-spacing:-.03em;
  word-break:break-word;transform:rotate(-13deg);opacity:.95;user-select:none;
  animation:monodrift 22s linear infinite alternate}
@keyframes monodrift{from{transform:rotate(-13deg) translate(0,0)}to{transform:rotate(-13deg) translate(6%,-6%)}}
.mono--pinkblk{background:var(--magenta);color:var(--ink)}
.mono--blkpaper{background:#000;color:var(--paper)}
.mono--bluewhite{background:var(--blue);color:#fff}
.mono--goldblk{background:var(--gold);color:var(--ink)}

/* MERCH clúster (bolsa+vaso+qr+redes) */
.merch{flex:0 0 auto;position:relative;width:clamp(300px,26vw,380px);height:80vh;z-index:5}
.bag{position:absolute;left:0;bottom:6%;width:62%;height:64%;border:4px solid #000;border-radius:4px 4px 8px 8px;
  background:repeating-conic-gradient(var(--red) 0% 25%,#fff 0% 50%) 0 0/38px 38px;box-shadow:10px 10px 0 #000;overflow:hidden}
.bag::before{content:"";position:absolute;top:0;left:12%;width:76%;height:16%;background:#fff;border-bottom:4px solid #000}
.bag__logo{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:54%}
.cup{position:absolute;right:4%;bottom:8%;width:30%;height:50%;
  background:#fff;border:4px solid #000;border-radius:6px 6px 14px 14px;
  clip-path:polygon(8% 0,92% 0,100% 100%,0 100%);box-shadow:8px 8px 0 #000}
.cup__band{position:absolute;top:30%;left:-4px;right:-4px;height:34%;background:var(--magenta);border-top:4px solid #000;border-bottom:4px solid #000;
  display:flex;align-items:center;justify-content:center;color:#fff;font-family:"Clash Display";font-weight:800;font-size:.8rem;text-transform:uppercase;letter-spacing:.02em}
.qr{position:absolute;top:2%;right:2%;width:34%;background:#fff;border:4px solid #000;border-radius:10px;padding:10px;box-shadow:6px 6px 0 #000;transform:rotate(6deg)}
.qr svg{width:100%;display:block}
.qr small{display:block;text-align:center;font-family:"Clash Display";font-weight:700;text-transform:uppercase;font-size:.62rem;margin-top:6px;color:var(--ink)}
.soccol{position:absolute;top:2%;left:0;display:flex;flex-direction:column;gap:8px;z-index:6}
.soccol span{width:42px;height:42px;border:3px solid #000;border-radius:50%;background:#fff;box-shadow:3px 3px 0 #000;
  display:flex;align-items:center;justify-content:center;font-family:"Clash Display";font-weight:800;font-size:.8rem;color:var(--ink)}

/* ---- MOCKUPS de merch ---- */
/* sudadera */
.hoodie{position:relative;width:74%;aspect-ratio:1/1.06}
.hoodie__sleeve{position:absolute;top:22%;width:26%;height:48%;background:var(--magenta);border:3px solid #000;border-radius:14px;z-index:1}
.hoodie__sleeve.l{left:0;transform:rotate(12deg)} .hoodie__sleeve.r{right:0;transform:rotate(-12deg)}
.hoodie__body{position:absolute;left:18%;right:18%;top:20%;bottom:0;background:var(--magenta);border:3px solid #000;border-radius:16px 16px 20px 20px;z-index:2}
.hoodie__hood{position:absolute;left:31%;right:31%;top:6%;height:24%;background:var(--magenta);border:3px solid #000;border-radius:48% 48% 38% 38%;z-index:3}
.hoodie__pocket{position:absolute;left:31%;right:31%;bottom:16%;height:24%;border:3px solid #000;border-radius:10px;z-index:3}
.hoodie__logo{position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);z-index:4;
  font-family:"Clash Display";font-weight:800;color:#fff;font-size:clamp(1rem,1.6vw,1.5rem)}
/* tote */
.tote{position:relative;width:64%;aspect-ratio:1/1.16}
.tote__h{position:absolute;top:0;width:30%;height:42%;border:3px solid #000;border-bottom:none;border-radius:46px 46px 0 0;z-index:1}
.tote__h.l{left:13%} .tote__h.r{right:13%}
.tote__bag{position:absolute;left:0;right:0;bottom:0;top:30%;background:var(--gold);border:3px solid #000;border-radius:6px;
  display:flex;align-items:center;justify-content:center;z-index:2}
.tote__bag img{width:58%}
/* hoja de pegatinas */
.sheet{position:relative;width:88%;height:84%;background:#fff;border:3px solid #000;border-radius:10px;
  padding:14px;display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:1fr;gap:10px;align-content:center}
.schip{display:flex;align-items:center;justify-content:center;text-align:center;border:2px solid #000;border-radius:8px;
  font-family:"Clash Display";font-weight:800;text-transform:uppercase;font-size:.66rem;padding:.3em;color:var(--ink)}
.schip.c1{background:var(--magenta);color:#fff;transform:rotate(-5deg)}
.schip.c2{background:var(--blue);transform:rotate(4deg)}
.schip.c3{background:var(--lime);transform:rotate(3deg)}
.schip.c4{background:var(--gold);transform:rotate(-4deg)}
.mtile--item .mtile__lbl{position:absolute;left:14px;bottom:14px}

/* =========================================================
   ESCENA SORTEO · 5º ANIVERSARIO
   ========================================================= */
.scene--sorteo{flex-direction:row;align-items:center;gap:clamp(22px,2.8vw,46px)}
.sorteo__head{flex:0 0 auto;width:26vw;min-width:240px;position:relative;z-index:5}
.sorteo__head .kick{font-family:"Clash Display";font-weight:700;letter-spacing:.1em;color:var(--lime)}
.sorteo__head h2{font-size:clamp(2.8rem,7.5vw,6.6rem);margin-top:10px}
.sorteo__head p{margin-top:14px;font-weight:600;max-width:24ch;color:#d9d2c4;line-height:1.4}

/* ticket */
.ticket{flex:0 0 auto;position:relative;width:clamp(330px,38vw,540px);height:66vh;min-height:430px;
  background:var(--lime);color:var(--ink);border:4px solid #000;border-radius:22px;
  box-shadow:16px 16px 0 #000;display:flex;flex-direction:column;justify-content:center;
  padding:clamp(26px,2.8vw,46px);overflow:hidden;z-index:5}
.ticket::before,.ticket::after{content:"";position:absolute;top:50%;width:48px;height:48px;border-radius:50%;
  background:var(--bg);border:4px solid #000;transform:translateY(-50%)}
.ticket::before{left:-28px} .ticket::after{right:-28px}
.ticket__kick{font-family:"Clash Display";font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.9rem}
.ticket__prize{font-family:"Clash Display";font-weight:800;text-transform:uppercase;
  font-size:clamp(1.7rem,3.6vw,3.2rem);line-height:.95;margin:8px 0 6px}
.ticket__desc{font-weight:700;font-size:clamp(1rem,1.4vw,1.25rem);line-height:1.3;max-width:26ch}
.ticket__div{border-top:4px dashed #000;margin:clamp(16px,2vw,26px) 0}
.ticket__row{display:flex;justify-content:space-between;align-items:flex-end;gap:14px}
.ticket__val{font-family:"Clash Display";font-weight:800;font-size:clamp(2rem,4vw,3.4rem);line-height:1}
.ticket__val small{display:block;font-size:.34em;letter-spacing:.06em}
.ticket__date{font-family:ui-monospace,monospace;font-size:.74rem;text-transform:uppercase;text-align:right;line-height:1.4}
.ticket__stamp{position:absolute;top:18px;right:18px;background:var(--red);color:#fff;border:3px solid #000;
  border-radius:50%;width:84px;height:84px;display:flex;align-items:center;justify-content:center;text-align:center;
  font-family:"Clash Display";font-weight:800;text-transform:uppercase;font-size:.78rem;line-height:.9;transform:rotate(12deg);box-shadow:4px 4px 0 #000}

/* pasos de participación */
.sorteo__steps{flex:0 0 auto;width:clamp(250px,24vw,340px);display:flex;flex-direction:column;gap:14px;z-index:5}
.gstep{display:flex;gap:14px;align-items:center;background:var(--surface);border:3px solid var(--line);
  border-radius:14px;padding:16px 18px}
.gstep b{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--magenta);color:#fff;border:3px solid #000;
  display:flex;align-items:center;justify-content:center;font-family:"Clash Display";font-weight:800;font-size:1.1rem}
.gstep:nth-child(2) b{background:var(--blue);color:var(--ink)}
.gstep:nth-child(3) b{background:var(--gold);color:var(--ink)}
.gstep span{font-weight:600;font-size:.98rem;line-height:1.25}
.sorteo__steps .btn{margin-top:6px;justify-content:center}

/* =========================================================
   ALTERNANCIA NEGRO/BLANCO + BURBUJA DE TRANSICIÓN
   ========================================================= */
.scene.is-light{color:var(--ink)}
.scene.is-light h1,.scene.is-light h2,.scene.is-light h3{color:var(--ink)}
.scene.is-light .mw{color:var(--ink)}
.scene.is-light .mw.stamp{color:var(--gold)}
.scene.is-light .lbl{color:var(--ink)} .scene.is-light .lbl::before{border-color:var(--ink)}
.scene.is-light .hero__sub{color:#3a352d}
.scene.is-light .show__head h2 .o{-webkit-text-stroke-color:var(--ink)}
.scene.is-light .sorteo__head .kick{color:var(--magenta)}
.scene.is-light .sorteo__head p{color:#3a352d}
.scene.is-light .ticket::before,.scene.is-light .ticket::after{background:#fff}
.scene.is-light .stat{background:var(--ink);border-color:#000}
.scene.is-light .gstep{background:#f1eee7;border-color:#d9d4c8}
.scene.is-light .gstep span{color:var(--ink)}

/* HUD se adapta al fondo claro */
body.on-light .hud button,body.on-light .hud a{color:var(--ink)}

/* el contenido real SIEMPRE por encima de los stickers/decoraciones (que son fondo collage) */
.hero__tag,.hero__title,.hero__sub,.scene--hero .btn,
.serv__head,.nums__head,.proc__head,.cases__head,.show__head,.sorteo__head,
.mani,.contact__big,.contact__btns,.contact__soc,
.card,.step,.chip,.stat,.ticket,.sorteo__steps,.show__grid,.mtile{position:relative;z-index:20}

/* cabeceras se ajustan a su título -> nunca se cortan ni pisan las cards */
.serv__head,.nums__head,.proc__head,.cases__head,.show__head,.sorteo__head{width:max-content;max-width:42vw}

/* letras de los títulos (relleno con el scroll) */
.ch{display:inline-block;will-change:opacity}


@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}
  #bubblefx{display:none}}


/* =========================================================
   VERSIÓN MÓVIL · MISMA IDENTIDAD, RECORRIDO VERTICAL NATIVO
   ========================================================= */
@media (max-width: 767px){
  html{scroll-behavior:smooth;background:var(--bg)}
  body{cursor:auto;min-width:0;overflow-x:hidden}
  body.tid-mobile{padding:0}
  .tidcur{display:none!important}

  /* UI fija, reducida y táctil */
  .brand{top:12px;left:14px;z-index:300}
  .brand img{height:44px}
  .hud{top:14px;right:14px;gap:0;z-index:300}
  .hud button{display:none!important}
  .hud__cta{font-size:.72rem!important;padding:.58em .82em;border-width:2px;box-shadow:3px 3px 0 #000}
  .scrollhint{bottom:14px;font-size:.66rem;letter-spacing:.14em;padding:.46em .75em;z-index:300}
  .scrollhint span{animation:none;transform:rotate(90deg)}
  .progress{height:4px;z-index:300}

  /* El carril horizontal pasa a ser un relato vertical. */
  #wrap,#pin,#track{width:100%!important;height:auto!important;min-height:0!important;overflow:visible!important;transform:none!important}
  #track{display:block!important}
  .scene{
    display:flex!important; flex-direction:column!important; align-items:stretch!important;
    justify-content:flex-start!important; gap:22px!important;
    width:100%!important; min-width:0!important; height:auto!important; min-height:0!important;
    padding:clamp(72px,12vw,96px) 20px!important; overflow:hidden!important;
  }
  .scene > *{min-width:0}
  .scene h1,.scene h2,.scene h3{word-break:normal;overflow-wrap:normal}

  /* Hero: misma composición de collage, sin perder aire ni lectura. */
  .scene--hero{
    min-height:100svh!important;justify-content:center!important;padding:108px 20px 92px!important;
    gap:0!important;isolation:isolate;
  }
  .scene--hero .bgword{left:-14vw;top:53%;font-size:56vw;line-height:.8;opacity:.8}
  .hero__tag{font-size:.64rem;margin-bottom:16px;padding:.48em .78em;max-width:calc(100vw - 40px)}
  .hero__tag .dot{width:8px;height:8px;flex:0 0 auto}
  .hero__title{font-size:clamp(3.35rem,15.5vw,5.2rem);line-height:.84;margin-bottom:18px;letter-spacing:-.04em}
  .hero__sub{font-size:1rem;line-height:1.35;max-width:26ch;margin-bottom:22px}
  .scene--hero .btn{align-self:flex-start;font-size:.87rem;padding:.84em 1.1em}
  .five{right:-5vw;top:52%;font-size:clamp(14rem,60vw,19rem);-webkit-text-stroke:3px #000;text-shadow:9px 9px 0 var(--blue);opacity:.48}
  .scene--hero .sticker,.scene--hero .deco,.scene--hero .tile{z-index:12}
  .scene--hero > .sticker:nth-child(7){top:13%!important;left:auto!important;right:7%!important;transform:rotate(-7deg) scale(.78)!important}
  .scene--hero > .sticker:nth-child(8){top:21%!important;left:auto!important;right:-6%!important;transform:rotate(8deg) scale(.68)!important}
  .scene--hero > .sticker:nth-child(9){top:auto!important;bottom:10%!important;left:5%!important;transform:rotate(4deg) scale(.76)!important}
  .scene--hero > .sticker:nth-child(10){top:auto!important;bottom:18%!important;left:auto!important;right:4%!important;transform:rotate(-6deg) scale(.63)!important}
  .scene--hero > .sticker:nth-child(11){top:64%!important;left:auto!important;right:2%!important;transform:rotate(5deg) scale(.72)!important}
  .scene--hero > .sticker:nth-child(12){display:none!important}
  .scene--hero > .deco:nth-child(13){top:19%!important;left:55%!important;font-size:1.5rem!important}
  .scene--hero > .deco:nth-child(14){display:none!important}
  .scene--hero > .sticker:nth-child(15){top:45%!important;left:54%!important;transform:rotate(-6deg) scale(.72)!important}
  .scene--hero > .sticker:nth-child(16){top:auto!important;bottom:31%!important;left:15%!important;transform:rotate(5deg) scale(.72)!important}
  .scene--hero > .tile:nth-child(17){width:86px!important;height:86px!important;top:auto!important;bottom:20%!important;left:auto!important;right:4%!important;transform:rotate(-7deg)!important;box-shadow:6px 6px 0 #000}
  .scene--hero > .tile:nth-child(17) img{width:72%}

  /* Cintas laterales convertidas en fajas horizontales. */
  .ribbon{width:100%!important;height:58px!important;min-height:58px!important;border-left:0;border-right:0;border-top:4px solid #000;border-bottom:4px solid #000}
  .ribbon__tk{top:50%;left:0;transform:translateY(-50%);font-size:1.08rem;letter-spacing:.01em;animation:mobile-ribbonmove 15s linear infinite}
  @keyframes mobile-ribbonmove{from{transform:translate(0,-50%)}to{transform:translate(-48%,-50%)}}

  /* Manifiesto */
  .scene--mani{min-height:68svh!important;justify-content:center!important;padding-top:86px!important;padding-bottom:86px!important}
  .mani{font-size:clamp(2.35rem,12vw,4rem);line-height:.93;max-width:12ch;position:relative;z-index:20}
  .scene--mani > .sticker:nth-last-of-type(3){top:11%!important;left:auto!important;right:5%!important;transform:rotate(-7deg) scale(.72)!important}
  .scene--mani > .sticker:nth-last-of-type(2){bottom:10%!important;left:4%!important;transform:rotate(6deg) scale(.7)!important}
  .scene--mani > .sticker:nth-last-of-type(1){top:auto!important;bottom:27%!important;left:auto!important;right:5%!important;transform:rotate(-6deg) scale(.65)!important}
  .scene--mani .deco{display:none!important}

  /* Servicios: tarjetas verticales con proporciones de la versión original. */
  .scene--serv,.scene--nums,.scene--proc,.scene--cases,.scene--show,.scene--sorteo{align-items:stretch!important}
  .serv__head,.nums__head,.proc__head,.cases__head,.show__head,.sorteo__head{width:auto!important;max-width:none!important;min-width:0!important;flex:0 0 auto!important}
  .serv__head h2,.show__head h2,.cases__head h2{font-size:clamp(3.1rem,15vw,5.2rem)}
  .nums__head h2,.proc__head h2,.sorteo__head h2{font-size:clamp(2.8rem,14vw,4.65rem)}
  .scene--serv > .sticker,.scene--nums > .sticker,.scene--nums > .deco,.scene--proc > .deco,.scene--cases > .sticker,.scene--show > .sticker,.scene--sorteo > .sticker{display:none!important}
  .card{width:100%!important;height:clamp(330px,72vw,420px)!important;min-height:0!important;padding:27px!important;border-width:3px;box-shadow:8px 8px 0 #000;border-radius:15px}
  .card__no{font-size:4.2rem}
  .card h3{font-size:clamp(2rem,9vw,2.75rem)}
  .card p{font-size:1rem;max-width:27ch}
  .card__sticker{top:16px;right:-5px;font-size:.7rem}

  /* Universo: mosaico real, a dos columnas y con jerarquía de piezas. */
  .scene--show{padding-bottom:90px!important}
  .show__grid{display:grid!important;width:100%!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;grid-template-rows:none!important;grid-auto-flow:row!important;grid-auto-columns:auto!important;gap:12px!important}
  .mtile{min-height:165px;border-width:3px;border-radius:12px;box-shadow:7px 7px 0 #000;padding:12px}
  .mtile.tall{grid-row:span 2;min-height:342px}
  .mtile__lbl{font-size:1.05rem}
  .mono{font-size:1.2rem}

  /* Resultados: cuadrícula compacta, no carril de tarjetas. */
  .scene--nums{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:14px!important}
  .nums__head{grid-column:1/-1!important;margin-bottom:4px}
  .stat{width:auto!important;height:154px!important;min-height:0!important;border-width:3px;padding:12px;box-shadow:5px 5px 0 #000;border-radius:14px}
  .stat__n{font-size:clamp(2.35rem,11vw,3.3rem)}
  .stat__l{font-size:.68rem;margin-top:7px}

  /* Proceso: una secuencia vertical. */
  .step{width:100%!important;height:315px!important;min-height:0!important;padding:24px!important;border-width:3px;box-shadow:8px 8px 0 #000;border-radius:15px}
  .step__n{font-size:3.8rem}
  .step h3{font-size:2rem}

  /* Casos: discos que mantienen la composición de escritorio. */
  .scene--cases{display:grid!important;grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:18px 14px!important;align-items:center!important}
  .cases__head{grid-column:1/-1!important;margin-bottom:8px}
  .chip{width:100%!important;height:auto!important;aspect-ratio:1/1;min-width:0!important;font-size:clamp(.95rem,4.5vw,1.15rem);padding:13px;border-width:3px;box-shadow:5px 5px 0 #000}

  /* Sorteo: ticket a escala móvil y pasos completos. */
  .sorteo__head p{max-width:31ch;font-size:1rem}
  .ticket{width:100%!important;height:auto!important;min-height:0!important;padding:31px 24px!important;border-width:3px;box-shadow:9px 9px 0 #000;border-radius:18px}
  .ticket::before,.ticket::after{width:34px;height:34px;border-width:3px}
  .ticket::before{left:-21px}.ticket::after{right:-21px}
  .ticket__stamp{top:14px;right:14px;width:70px;height:70px;font-size:.68rem;border-width:2px}
  .ticket__kick{font-size:.75rem;padding-right:58px}
  .ticket__prize{font-size:clamp(2rem,10vw,3.1rem);padding-top:6px}
  .ticket__desc{font-size:1rem;max-width:22ch}
  .ticket__row{gap:10px}
  .ticket__val{font-size:2.5rem}.ticket__date{font-size:.62rem}
  .sorteo__steps{width:100%!important;gap:11px}
  .gstep{padding:13px 14px;border-width:2px;border-radius:12px;gap:11px}
  .gstep b{width:34px;height:34px;font-size:1rem;border-width:2px}.gstep span{font-size:.92rem}
  .sorteo__steps .btn{width:100%;white-space:normal;text-align:center;padding:.9em 1em}

  /* Contacto. */
  .scene--contact{min-height:100svh!important;justify-content:center!important;align-items:center!important;text-align:center!important;padding:106px 20px 88px!important;gap:0!important}
  .contact__big{font-size:clamp(3.15rem,14vw,5.1rem);line-height:.86;gap:8px}
  .contact__logo{height:76px;margin:5px 0}
  .contact__btns{width:100%;margin:30px 0 20px;gap:13px;flex-direction:column;align-items:stretch}
  .contact__btns .btn{width:100%;justify-content:center;white-space:normal;font-size:.82rem;padding:.9em .8em}
  .contact__soc{gap:10px;flex-direction:column;font-size:.82rem}
  .copy{bottom:18px;width:calc(100% - 40px);font-size:.62rem;white-space:normal;line-height:1.3}
  .scene--contact > .sticker{display:none!important}

  /* Entrada nativa al hacer scroll. */
  .mobile-reveal{opacity:0;transform:translateY(30px) scale(.97);transition:opacity .65s cubic-bezier(.2,.8,.2,1),transform .65s cubic-bezier(.2,.8,.2,1)}
  .mobile-reveal.is-visible{opacity:1;transform:translateY(0) scale(1)}
  .scene--hero .hero__tag,.scene--hero .hero__title,.scene--hero .hero__sub,.scene--hero .btn{opacity:0;transform:translateY(20px)}
  body.tid-mobile-ready .scene--hero .hero__tag,body.tid-mobile-ready .scene--hero .hero__title,body.tid-mobile-ready .scene--hero .hero__sub,body.tid-mobile-ready .scene--hero .btn{animation:mobile-hero-in .72s cubic-bezier(.2,.8,.2,1) forwards}
  body.tid-mobile-ready .scene--hero .hero__title{animation-delay:.12s}body.tid-mobile-ready .scene--hero .hero__sub{animation-delay:.24s}body.tid-mobile-ready .scene--hero .btn{animation-delay:.36s}
  @keyframes mobile-hero-in{to{opacity:1;transform:translateY(0)}}
  .scene--hero .five{animation:mobile-five-in .9s .18s cubic-bezier(.2,.8,.2,1) both}
  @keyframes mobile-five-in{from{opacity:0;transform:translateY(-50%) scale(.65) rotate(-10deg)}to{opacity:.48;transform:translateY(-50%) scale(1) rotate(0)}}
  .scene--hero .sticker{animation:mobile-float 3.8s ease-in-out infinite alternate}
  .scene--hero .sticker:nth-child(2n){animation-delay:.5s}
  @keyframes mobile-float{from{margin-top:0}to{margin-top:-7px}}

  /* Accesibilidad. */
  @media (prefers-reduced-motion:reduce){
    html{scroll-behavior:auto}.mobile-reveal{opacity:1!important;transform:none!important;transition:none!important}
    .scene--hero .hero__tag,.scene--hero .hero__title,.scene--hero .hero__sub,.scene--hero .btn{opacity:1!important;transform:none!important;animation:none!important}
    .scene--hero .five,.scene--hero .sticker,.ribbon__tk{animation:none!important}
  }
}
