/* ============================================================
   Elevarts CINEMATIC — page-specific layer over lab.css
   Dark, editorial, oversized type, transform-only motion.
   Award-winning structure (landonorris-style) · Elevarts brand.
   ============================================================ */

:root{
  --edge: clamp(20px, 4.4vw, 90px);
  --colw: clamp(1.5rem, 6vw, 6rem);
  --ease: cubic-bezier(.19,1,.22,1);
}

body{ background:#08060F; }
.cine{ position:relative; overflow-x:clip; }

/* grain + vignette signature over everything (cheap, static) */
.cine::after{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:120; mix-blend-mode:soft-light; opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%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)' opacity='.5'/%3E%3C/svg%3E");
}
.cine::before{
  content:""; position:fixed; inset:0; pointer-events:none; z-index:1;
  background:radial-gradient(120% 90% at 50% 0%, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* ---------- section chrome ---------- */
.sec{ position:relative; z-index:2; padding-block:clamp(90px,14vh,180px); }
.sec-head{ display:flex; align-items:baseline; gap:1.2em; margin-bottom:clamp(32px,5vw,72px); }
.sec-num{ font-family:var(--mono); font-size:.8rem; letter-spacing:.24em; color:var(--ink-3); }
.sec-num b{ color:var(--magenta); font-weight:500; }
.kicker{ font-family:var(--mono); font-size:.74rem; letter-spacing:.26em; text-transform:uppercase; color:var(--ink-3);
  display:inline-flex; align-items:center; gap:.7em; }
.kicker::before{ content:""; width:34px; height:1px; background:linear-gradient(90deg,var(--magenta),transparent); }

.mega{ font-weight:700; letter-spacing:-.04em; line-height:.9;
  font-size:clamp(2.6rem,8.5vw,7.2rem); }
.grad{ background:var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;
  padding-bottom:.08em; }

/* ============================================================
   CURTAIN INTRO  (theatre curtain rising)
   ============================================================ */
.curtain{ display:none; }
.anim .curtain{
  display:grid; place-items:center; position:fixed; inset:0; z-index:300;
  background:radial-gradient(120% 120% at 50% 40%, #17122b 0%, #08060F 70%);
}
.curtain-word{ font-weight:700; letter-spacing:-.03em; line-height:1; overflow:hidden;
  font-size:clamp(2.4rem,10vw,8rem); display:flex; }
.curtain-word .cch{ display:inline-block; transform:translateY(110%); will-change:transform; }
.curtain-sub{ margin-top:1.4em; font-family:var(--mono); font-size:.74rem; letter-spacing:.4em; text-transform:uppercase;
  color:var(--ink-3); opacity:0; }
.curtain-bar{ position:absolute; left:0; right:0; bottom:0; height:2px; transform:scaleX(0); transform-origin:left;
  background:var(--grad); }
.anim-fail .curtain{ opacity:0; visibility:hidden; transition:opacity .5s, visibility .5s; }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column; justify-content:flex-end;
  padding:0 var(--edge) clamp(28px,5vh,64px); overflow:clip; }
.hero-stage{ position:absolute; inset:0; z-index:0; }
.hero-stage canvas.hero-gl{ position:absolute; inset:0; width:100%!important; height:100%!important; }
.hero-fallback{ position:absolute; top:50%; left:50%; width:min(78vw,760px); transform:translate(-46%,-52%);
  object-fit:contain; transition:opacity .6s; z-index:0; filter:drop-shadow(0 40px 80px rgba(0,0,0,.6)); }
@media(min-aspect-ratio:11/10){ .hero-fallback{ transform:translate(-38%,-50%); } }
@media(max-width:820px){ .hero-fallback{ width:min(132vw,560px); top:42%; left:52%; transform:translate(-50%,-50%); } }
.hero-glow{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(50% 40% at 28% 30%, color-mix(in srgb,var(--magenta) 26%,transparent), transparent 70%),
    radial-gradient(46% 42% at 74% 66%, color-mix(in srgb,var(--purple) 24%,transparent), transparent 72%); }

.hero-top{ position:absolute; top:clamp(84px,12vh,120px); left:var(--edge); right:var(--edge); z-index:3;
  display:flex; justify-content:space-between; gap:1em; }
.hero-top .meta{ font-family:var(--mono); font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-2); }
.hero-top .meta.r{ text-align:right; color:var(--ink-3); }
@media(max-width:640px){ .hero-top .meta.r{ display:none; } }

.hero-copy{ position:relative; z-index:3; max-width:100%; }
.hero-title{ font-weight:700; letter-spacing:-.045em; line-height:.84;
  font-size:clamp(2.9rem,12.5vw,10.5rem); text-transform:uppercase; }
.hero-title .ln{ display:block; overflow:hidden; padding-bottom:.16em; margin-bottom:-.12em; }
.hero-title .ln > span{ display:inline-block; will-change:transform; }
.hero-lead{ margin-top:1.1em; max-width:44ch; font-size:clamp(1rem,1.5vw,1.28rem); color:var(--ink-2);
  overflow:hidden; }
.hero-lead > span{ display:inline-block; will-change:transform; }
.hero-cta{ margin-top:1.6em; display:flex; gap:14px; flex-wrap:wrap; align-items:center; }

.scrollcue{ position:absolute; bottom:26px; left:50%; transform:translateX(-50%); z-index:3;
  display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--ink-3);
  font-family:var(--mono); font-size:.64rem; letter-spacing:.3em; text-transform:uppercase; }
.scrollcue .rail{ width:1px; height:46px; background:linear-gradient(var(--ink-3),transparent); position:relative; overflow:hidden; }
.scrollcue .rail::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%;
  background:var(--magenta); animation:cue 2.1s var(--ease) infinite; }
@keyframes cue{ 0%{ transform:translateY(-100%); } 60%,100%{ transform:translateY(300%); } }

/* ============================================================
   02 · EDITORIAL SPLIT  (on stage / behind the scenes)
   ============================================================ */
.editorial{ display:grid; gap:clamp(80px,12vh,180px); }
.ed-row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,84px); align-items:center; }
.ed-row.rev{ direction:rtl; } .ed-row.rev > *{ direction:ltr; }
.ed-media{ position:relative; border-radius:var(--radius); overflow:hidden; aspect-ratio:4/5; }
.ed-media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.14); will-change:transform; }
.ed-media .tagno{ position:absolute; top:16px; left:18px; z-index:2; font-family:var(--mono); font-size:.72rem;
  letter-spacing:.2em; color:#fff; mix-blend-mode:difference; }
.ed-media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,6,15,.5)); }
.ed-copy h3{ font-size:clamp(2rem,5.4vw,4.4rem); letter-spacing:-.035em; line-height:.94; margin-bottom:.5em; }
.ed-copy .lead{ color:var(--ink-2); font-size:clamp(1rem,1.5vw,1.22rem); max-width:44ch; }
.ed-copy .mini{ margin-top:1.6em; display:flex; gap:2.4em; flex-wrap:wrap; }
.ed-copy .mini div{ }
.ed-copy .mini .n{ font-size:1.9rem; font-weight:700; letter-spacing:-.03em; }
.ed-copy .mini .l{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); }
@media(max-width:820px){ .ed-row,.ed-row.rev{ grid-template-columns:1fr; direction:ltr; gap:26px; }
  .ed-media{ aspect-ratio:16/11; } }

/* ============================================================
   03 · PERSONAJE — pinned horizontal hall of fame
   ============================================================ */
.hall{ position:relative; }
.hall-pin{ position:sticky; top:0; height:100svh; overflow:hidden; display:flex; flex-direction:column; justify-content:center; }
.hall-head{ position:absolute; top:clamp(28px,7vh,80px); left:var(--edge); right:var(--edge); z-index:4;
  display:flex; justify-content:space-between; align-items:flex-end; gap:1em; pointer-events:none; }
.hall-track{ display:flex; gap:clamp(18px,2.4vw,40px); padding-inline:var(--edge); will-change:transform; }
.pcard{ position:relative; flex:0 0 auto; width:clamp(230px,26vw,380px); aspect-ratio:3/4; border-radius:22px;
  overflow:hidden; background:linear-gradient(160deg,var(--panel),var(--bg-2)); border:1px solid var(--line);
  cursor:pointer; }
.pcard::before{ content:""; position:absolute; inset:0; z-index:2;
  background:radial-gradient(120% 80% at 50% 120%, color-mix(in srgb,var(--accent) 42%,transparent), transparent 62%);
  opacity:.5; transition:opacity .5s; }
.pcard:hover::before{ opacity:.85; }
.pcard .ch{ position:absolute; inset:0; z-index:3; display:grid; place-items:end center; padding-bottom:6%; }
.pcard .ch img{ width:96%; height:96%; object-fit:contain; object-position:bottom;
  transform:translateY(4%) scale(1.02); transition:transform .6s var(--ease); filter:drop-shadow(0 20px 40px rgba(0,0,0,.5)); }
.pcard:hover .ch img{ transform:translateY(0) scale(1.09); }
/* clip-path ellipse reveal panel that "grows" over the card on hover */
.pcard .reveal{ position:absolute; inset:0; z-index:4;
  background-size:cover; background-position:center;
  clip-path:ellipse(0% 0% at 50% 100%); transition:clip-path .7s var(--ease); }
.pcard:hover .reveal{ clip-path:ellipse(150% 150% at 50% 100%); }
.pcard .cap{ position:absolute; left:16px; bottom:14px; z-index:5; }
.pcard .cap .nm{ font-weight:700; font-size:1.15rem; letter-spacing:-.02em; }
.pcard .cap .tg{ font-family:var(--mono); font-size:.64rem; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-2); }
.pcard .idx{ position:absolute; top:14px; right:16px; z-index:5; font-family:var(--mono); font-size:.7rem; color:var(--ink-3); }
/* mobile: native swipe carousel */
@media(max-width:820px),(pointer:coarse){
  .hall-pin{ position:static; height:auto; padding-block:10px; }
  .hall-track{ overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch;
    padding-bottom:14px; transform:none!important; }
  .hall-track::-webkit-scrollbar{ display:none; }
  .pcard{ scroll-snap-align:center; width:min(74vw,320px); }
  .pcard .reveal{ clip-path:ellipse(150% 150% at 50% 100%); opacity:.001; } /* keep off on touch */
}

/* ============================================================
   04 · TRUST — logo marquee
   ============================================================ */
.trust{ border-block:1px solid var(--line); padding-block:clamp(44px,7vh,88px); overflow:hidden; }
.trust .kicker{ padding-inline:var(--edge); margin-bottom:34px; }
.mq{ display:flex; overflow:hidden; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.mq-row{ display:flex; gap:clamp(40px,6vw,96px); align-items:center; padding-left:clamp(40px,6vw,96px);
  animation:mqx 42s linear infinite; will-change:transform; flex:0 0 auto; }
.mq:hover .mq-row{ animation-play-state:paused; }
.mq.rev .mq-row{ animation-direction:reverse; animation-duration:52s; }
@keyframes mqx{ to{ transform:translateX(-100%); } }
.mq .cli{ font-weight:600; font-size:clamp(1.3rem,3vw,2.4rem); letter-spacing:-.02em; color:var(--ink-3);
  white-space:nowrap; transition:color .35s; }
.mq .cli:hover{ color:var(--ink); }
.mq .dot{ width:6px; height:6px; border-radius:50%; background:var(--magenta); opacity:.6; flex:0 0 auto; }

/* ============================================================
   05 · STATS — count up
   ============================================================ */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(20px,3vw,48px); }
.stat{ border-top:1px solid var(--line-2); padding-top:22px; }
.stat .num{ font-size:clamp(2.6rem,7vw,6rem); font-weight:700; letter-spacing:-.04em; line-height:1;
  font-variant-numeric:tabular-nums; }
.stat .num .grad{ }
.stat .lbl{ margin-top:.5em; font-family:var(--mono); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); }
@media(max-width:720px){ .stats{ grid-template-columns:repeat(2,1fr); } }

/* ============================================================
   06 · SOCIAL FEED
   ============================================================ */
.social-head{ display:flex; justify-content:space-between; align-items:flex-end; gap:1.5em; flex-wrap:wrap; margin-bottom:38px; }
.social-links{ display:flex; gap:10px; flex-wrap:wrap; }
.slink{ display:inline-flex; align-items:center; gap:.55em; padding:.6em 1em; border-radius:100px;
  border:1px solid var(--line-2); color:var(--ink-2); font-size:.9rem; transition:border-color .3s,color .3s,transform .3s; }
.slink:hover{ color:var(--ink); border-color:var(--magenta); transform:translateY(-2px); }
.slink svg{ width:18px; height:18px; }
.feed{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:1fr; gap:12px; }
.feed a{ position:relative; overflow:hidden; border-radius:14px; aspect-ratio:1; background:var(--panel); display:block; }
.feed a.wide{ grid-column:span 2; }
.feed a.tall{ grid-row:span 2; aspect-ratio:auto; }
.feed img{ width:100%; height:100%; object-fit:cover; transform:scale(1.02); transition:transform .7s var(--ease),filter .5s;
  filter:saturate(.92) brightness(.92); }
.feed a:hover img{ transform:scale(1.12); filter:saturate(1.08) brightness(1); }
.feed a::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(8,6,15,.6));
  opacity:0; transition:opacity .4s; }
.feed a:hover::after{ opacity:1; }
.feed .plat{ position:absolute; top:10px; left:11px; z-index:2; width:22px; height:22px; color:#fff;
  opacity:0; transform:translateY(-6px); transition:opacity .4s,transform .4s; }
.feed a:hover .plat{ opacity:1; transform:none; }
@media(max-width:820px){ .feed{ grid-template-columns:repeat(2,1fr); }
  .feed a.wide{ grid-column:span 2; } .feed a.tall{ grid-row:span 1; aspect-ratio:1; } }

/* ============================================================
   07 · FOOTER CTA
   ============================================================ */
.cta{ position:relative; text-align:center; padding-block:clamp(90px,16vh,220px); overflow:hidden; }
.cta-glow{ position:absolute; inset:0; z-index:0; pointer-events:none;
  background:radial-gradient(60% 60% at 50% 100%, color-mix(in srgb,var(--magenta) 30%,transparent), transparent 70%); }
.cta h2{ position:relative; z-index:2; font-size:clamp(2.4rem,8vw,7rem); letter-spacing:-.04em; line-height:.94;
  max-width:16ch; margin:0 auto; }
.cta .row{ position:relative; z-index:2; margin-top:2.2em; display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }
.cta .contact{ position:relative; z-index:2; margin-top:2.6em; display:flex; gap:2.4em; justify-content:center;
  flex-wrap:wrap; font-family:var(--mono); font-size:.8rem; letter-spacing:.06em; color:var(--ink-3); }
.cta .contact a{ color:var(--ink-2); transition:color .3s; }
.cta .contact a:hover{ color:var(--magenta); }
.foot-mini{ position:relative; z-index:2; border-top:1px solid var(--line); padding:26px var(--edge);
  display:flex; justify-content:space-between; gap:1em; flex-wrap:wrap;
  font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; color:var(--ink-3); }

/* ---------- reveal states (gated on .anim so no-JS shows all) ---------- */
.anim [data-anim]{ opacity:0; }
.anim [data-anim="up"]{ transform:translateY(40px); }
.anim [data-anim="scale"]{ transform:scale(.92); }
.anim-fail [data-anim]{ opacity:1!important; transform:none!important; }
.anim-fail .hall-track{ overflow-x:auto; } /* no-JS desktop: let the hall scroll horizontally */
@media(prefers-reduced-motion:reduce){ [data-anim]{ opacity:1!important; transform:none!important; } }

/* nav (cinematic, minimal) */
.cnav{ position:fixed; top:0; left:0; right:0; z-index:140; display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--edge); transition:background .4s,backdrop-filter .4s,padding .4s; mix-blend-mode:difference; }
.cnav.solid{ mix-blend-mode:normal; background:color-mix(in srgb,#08060F 78%,transparent); backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line); padding-block:12px; }
.cnav .wm{ font-weight:700; letter-spacing:-.02em; font-size:1.15rem; display:flex; align-items:center; gap:.5em; }
.cnav .wm .dot{ width:8px; height:8px; border-radius:50%; background:var(--grad-warm); }
.cnav .nlinks{ display:flex; gap:26px; font-size:.86rem; font-family:var(--mono); letter-spacing:.08em; text-transform:uppercase; }
.cnav .nlinks a{ color:currentColor; opacity:.85; transition:opacity .25s; }
.cnav .nlinks a:hover{ opacity:1; }
@media(max-width:720px){ .cnav .nlinks{ display:none; } }
