:root{
  --red:#d70018; --red-dark:#a60012; --red-soft:#ff2b45;
  --ink:#0b0b0d; --ink-2:#16161a; --ink-3:#202028;
  --paper:#ffffff; --mist:#f5f5f7; --line:#e6e6ea;
  --muted:#6b6b76; --muted-d:#9a9aa6;
  --gold:#ffd25a;
  --shadow:0 18px 50px rgba(0,0,0,.10);
  --shadow-lg:0 30px 80px rgba(215,0,24,.18);
  --r:18px; --r-lg:28px;
  --maxw:1180px;
  --hero-bg:url('assets/img/hero-stage.jpg');
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Be Vietnam Pro',system-ui,sans-serif;color:var(--ink);background:var(--paper);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
section{position:relative}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.em{color:var(--red)}

#progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--red),var(--gold));z-index:200;transition:width .1s linear}

nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:.35s}
nav .bar{display:flex;align-items:center;justify-content:space-between;height:72px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
nav.scrolled{background:rgba(255,255,255,.85);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line)}
.brand{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:-.02em}
.brand img{height:26px}
.brand .tag{font-size:11px;font-weight:600;color:var(--red);background:rgba(215,0,24,.08);padding:3px 9px;border-radius:99px;letter-spacing:.04em}
.navlinks{display:flex;gap:30px;align-items:center}
.navlinks a{font-size:14.5px;font-weight:500;color:var(--ink);opacity:.78;transition:.2s;position:relative}
nav.light .navlinks a,nav.light .brand{color:#fff}
nav.light.scrolled .navlinks a,nav.light.scrolled .brand{color:var(--ink)}
.navlinks a:hover{opacity:1}
.navlinks a.active{opacity:1;color:var(--red)}
.nav-cta{background:var(--red);color:#fff!important;padding:10px 20px;border-radius:99px;font-weight:600;font-size:14px;opacity:1!important;transition:.25s}
.nav-cta:hover{background:var(--red-dark);transform:translateY(-1px)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;padding:8px}
.burger span{width:24px;height:2px;background:currentColor;transition:.3s;color:var(--ink)}
nav.light:not(.scrolled) .burger span{background:#fff}

.hero{min-height:100vh;display:flex;align-items:center;color:#fff;position:relative;overflow:hidden;background:radial-gradient(120% 120% at 80% -10%,#ff1f3a 0%,#b8000f 38%,#5c0008 100%)}
.hero::after{content:"";position:absolute;inset:0;background:var(--hero-bg) center/cover;opacity:.16;mix-blend-mode:luminosity}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(80% 70% at 50% 30%,#000,transparent)}
.hero .wrap{position:relative;z-index:2;padding-top:90px;padding-bottom:60px}
.eyebrow{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);padding:8px 16px;border-radius:99px;backdrop-filter:blur(6px)}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(255,210,90,.3);animation:pulse 2s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 8px rgba(255,210,90,0)}}
.hero h1{font-size:clamp(40px,7vw,84px);line-height:1.02;font-weight:800;letter-spacing:-.03em;margin:26px 0 0}
.hero h1 .hl{position:relative;white-space:nowrap}
.hero h1 .hl::after{content:"";position:absolute;left:-2px;right:-2px;bottom:.08em;height:.28em;background:var(--gold);z-index:-1;border-radius:4px;transform:scaleX(0);transform-origin:left;animation:swipe 1s .6s forwards cubic-bezier(.7,0,.2,1)}
@keyframes swipe{to{transform:scaleX(1)}}
.hero p.lead{font-size:clamp(17px,2.1vw,21px);max-width:620px;margin:26px 0 0;color:rgba(255,255,255,.9);font-weight:300}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:38px}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:16px;padding:15px 28px;border-radius:99px;cursor:pointer;border:0;transition:.25s;font-family:inherit}
.btn-primary{background:#fff;color:var(--red)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px rgba(0,0,0,.3)}
.btn-ghost{background:rgba(255,255,255,.1);color:#fff;border:1px solid rgba(255,255,255,.35)}
.btn-ghost:hover{background:rgba(255,255,255,.2)}
.hero-stats{display:flex;gap:40px;margin-top:60px;flex-wrap:wrap}
.hero-stats .s b{font-size:34px;font-weight:800;display:block;line-height:1}
.hero-stats .s span{font-size:13.5px;color:rgba(255,255,255,.78)}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.7);font-size:12px;letter-spacing:.1em;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-hint .mouse{width:22px;height:36px;border:2px solid rgba(255,255,255,.6);border-radius:14px;position:relative}
.scroll-hint .mouse::after{content:"";position:absolute;top:6px;left:50%;transform:translateX(-50%);width:3px;height:7px;background:#fff;border-radius:2px;animation:wheel 1.6s infinite}
@keyframes wheel{0%{opacity:0;top:6px}30%{opacity:1}60%{opacity:1;top:16px}100%{opacity:0;top:18px}}

.sec{padding:110px 0}
.sec.alt{background:var(--mist)}
.sec.dark{background:var(--ink);color:#fff}
.kicker{display:inline-flex;align-items:center;gap:9px;color:var(--red);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:16px}
.kicker::before{content:"";width:26px;height:2px;background:var(--red);display:inline-block}
.dark .kicker{color:var(--gold)}.dark .kicker::before{background:var(--gold)}
.sec h2{font-size:clamp(30px,4.4vw,50px);font-weight:800;letter-spacing:-.025em;line-height:1.08}
.sec .sub{font-size:17.5px;color:var(--muted);max-width:660px;margin-top:18px;font-weight:300}
.dark .sub{color:var(--muted-d)}
.head-center{text-align:center}.head-center .sub{margin-left:auto;margin-right:auto}
.head-center .kicker::before{display:none}

.reveal{opacity:0;transform:translateY(30px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:56px}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:var(--r-lg);padding:38px 32px;transition:.35s;position:relative;overflow:hidden}
.pcard::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--red),var(--gold));transform:scaleX(0);transform-origin:left;transition:.4s}
.pcard:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:transparent}
.pcard:hover::before{transform:scaleX(1)}
.picon{width:62px;height:62px;border-radius:18px;display:grid;place-items:center;background:rgba(215,0,24,.08);color:var(--red);margin-bottom:22px;transition:.35s}
.pcard:hover .picon{background:var(--red);color:#fff;transform:rotate(-6deg)}
.picon svg{width:30px;height:30px}
.pcard h3{font-size:22px;font-weight:700;letter-spacing:-.01em}
.pcard p{color:var(--muted);margin-top:12px;font-size:15.5px}
.pnum{position:absolute;top:24px;right:28px;font-size:54px;font-weight:800;color:var(--mist);line-height:1;z-index:0}

.statband{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:54px}
.stat{background:var(--ink-2);border:1px solid var(--ink-3);border-radius:var(--r);padding:34px 26px;text-align:center;transition:.3s}
.stat:hover{border-color:var(--red);transform:translateY(-6px)}
.stat b{font-size:clamp(38px,5vw,54px);font-weight:800;line-height:1;background:linear-gradient(120deg,#fff,var(--gold));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block}
.stat span{display:block;color:var(--muted-d);font-size:14.5px;margin-top:12px;font-weight:500}

/* timeline rail */
.tlrail{margin-top:56px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch}
.tltrack{display:flex;position:relative;width:100%;padding:42px 0 6px}
.tlnode{flex:1 1 0;min-width:172px;text-align:center;position:relative;cursor:pointer;padding:0 14px}
.tlnode::before{content:"";position:absolute;top:51px;left:50%;width:100%;height:3px;background:linear-gradient(90deg,var(--red),var(--gold));z-index:0}
.tlnode:last-child::before{display:none}
.tldot{width:18px;height:18px;border-radius:50%;background:#fff;border:4px solid var(--red);margin:0 auto;position:relative;z-index:2;transition:.25s}
.tlnode:hover .tldot{transform:scale(1.3);box-shadow:0 0 0 6px rgba(215,0,24,.15)}
.tlcardin{margin-top:36px;padding:20px 16px 18px;border-radius:16px;transition:.25s}
.tlyear{font-size:30px;font-weight:800;color:var(--red);letter-spacing:-.02em;line-height:1;transition:.25s}
.tlnode:hover .tlyear{color:var(--gold);transform:scale(1.15)}
.tlteaser{font-size:14px;color:var(--muted);margin-top:12px;line-height:1.5;min-height:42px}
.tlmore{font-size:11.5px;font-weight:800;color:var(--red);margin-top:14px;text-transform:uppercase;letter-spacing:.06em;display:inline-flex;align-items:center;gap:5px;transition:.2s}
.tlmore:hover{opacity:.7;transform:translateX(4px)}
/* timeline popup */
#tlpop{position:fixed;inset:0;background:rgba(10,10,13,.72);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:300;padding:24px;animation:fade .25s}
#tlpop.show{display:flex}
@keyframes fade{from{opacity:0}to{opacity:1}}
#tlpop .pop{background:#fff;border-radius:24px;max-width:720px;width:100%;max-height:88vh;overflow:auto;position:relative;box-shadow:0 40px 100px rgba(0,0,0,.5);animation:popin .35s cubic-bezier(.2,.8,.2,1)}
@keyframes popin{from{transform:translateY(24px) scale(.96);opacity:0}to{transform:none;opacity:1}}
#tlpop .pclose{position:absolute;top:16px;right:18px;z-index:3;width:38px;height:38px;border-radius:50%;background:rgba(0,0,0,.5);color:#fff;font-size:24px;line-height:36px;text-align:center;cursor:pointer;backdrop-filter:blur(4px)}
#tlpop .pimg{width:100%;height:300px;object-fit:cover;display:block}
#tlpop .pbody{padding:30px 36px 36px}
#tlpop .pyear{font-size:54px;font-weight:800;color:var(--red);line-height:1;letter-spacing:-.03em}
#tlpop .pyear small{display:block;font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.tl-list{margin-top:24px;display:grid;gap:14px}
.tl-list li{list-style:none;display:flex;gap:14px;align-items:flex-start;font-size:16px}
.tl-list .mk{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:rgba(215,0,24,.1);color:var(--red);display:grid;place-items:center;font-size:13px;font-weight:800;margin-top:2px}
@media(max-width:640px){#tlpop .pimg{height:210px}#tlpop .pbody{padding:24px}#tlpop .pyear{font-size:42px}}

.cmp{display:grid;grid-template-columns:1fr 1fr;gap:0;margin-top:54px;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.cmp-col{padding:38px 34px}
.cmp-col.us{background:linear-gradient(160deg,#d70018,#8a0010);color:#fff}
.cmp-col.them{background:var(--paper)}
.cmp-col h3{font-size:21px;font-weight:800;display:flex;align-items:center;gap:12px;margin-bottom:8px}
.cmp-col.us h3 .logo{background:#fff;color:var(--red);padding:3px 8px;border-radius:6px;font-size:13px}
.cmp-col.them h3{color:var(--muted)}
.cmp-row{padding:22px 0;border-top:1px solid rgba(255,255,255,.18)}
.cmp-col.them .cmp-row{border-top-color:var(--line)}
.cmp-row .lab{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.7;margin-bottom:7px}
.cmp-row p{font-size:15.5px;line-height:1.55}
.cmp-col.them .cmp-row p{color:var(--muted)}

.partners{margin-top:50px;text-align:center}
.partner-row{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;margin-top:24px}
.chip{padding:14px 30px;border-radius:14px;border:1px solid var(--line);background:var(--paper);font-weight:700;font-size:19px;letter-spacing:-.01em;transition:.3s;color:var(--ink)}
.chip:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:var(--red)}
.chip.soon{border-style:dashed;color:var(--muted-d);font-weight:600;font-size:16px}
.plabel{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:42px}

.cases{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:20px;margin-top:54px}
.case{aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;position:relative;cursor:pointer;transition:.35s}
.case img{width:100%;height:100%;object-fit:cover;transition:.5s}
.case:hover img{transform:scale(1.08)}
.case-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(11,11,13,.82) 0%,rgba(11,11,13,.1) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:24px;transition:.3s}
.case:hover .case-overlay{background:linear-gradient(to top,rgba(11,11,13,.9) 0%,rgba(11,11,13,.3) 60%,transparent 100%)}
.case-overlay .score{position:absolute;top:16px;right:16px;background:var(--gold);color:#3a2b00;padding:6px 12px;border-radius:12px;font-weight:800;font-size:14px;display:flex;align-items:center;gap:4px;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.case-overlay h3{color:#fff;font-size:17px;font-weight:700;line-height:1.3}
.case-overlay .meta{color:rgba(255,255,255,.7);font-size:13px;margin-top:6px}

.videowrap{margin-top:50px;border-radius:var(--r-lg);overflow:hidden;position:relative;background:#000;aspect-ratio:16/9;box-shadow:0 40px 90px rgba(0,0,0,.5);border:1px solid var(--ink-3)}
.videowrap iframe,.videowrap video{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-ph{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:18px;background:radial-gradient(70% 70% at 50% 35%,#2a0307,#000);color:#fff;padding:30px}
.play-btn{width:84px;height:84px;border-radius:50%;background:var(--red);display:grid;place-items:center;box-shadow:0 0 0 0 rgba(215,0,24,.5);animation:ring 2.4s infinite;cursor:pointer;transition:.25s}
.play-btn:hover{transform:scale(1.08);background:var(--red-soft)}
@keyframes ring{0%{box-shadow:0 0 0 0 rgba(215,0,24,.5)}70%{box-shadow:0 0 0 26px rgba(215,0,24,0)}100%{box-shadow:0 0 0 0 rgba(215,0,24,0)}}
.play-btn svg{width:32px;height:32px;margin-left:5px}
.video-ph small{color:var(--muted-d);max-width:440px;font-size:13.5px;line-height:1.6}
.video-ph code{background:rgba(255,255,255,.1);padding:2px 7px;border-radius:6px;font-size:12px}

.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:14px;margin-top:54px}
.gal figure{position:relative;overflow:hidden;border-radius:16px;cursor:pointer;margin:0}
.gal figure img{width:100%;height:100%;object-fit:cover;transition:.6s}
.gal figure:hover img{transform:scale(1.08)}
.gal figure::after{content:attr(data-cap);position:absolute;left:0;right:0;bottom:0;padding:30px 16px 14px;color:#fff;font-size:13.5px;font-weight:500;background:linear-gradient(transparent,rgba(0,0,0,.8));opacity:0;transform:translateY(8px);transition:.3s}
.gal figure:hover::after{opacity:1;transform:none}
.gal .w2{grid-column:span 2}.gal .h2{grid-row:span 2}

#lb{position:fixed;inset:0;background:rgba(0,0,0,.92);display:none;align-items:center;justify-content:center;z-index:300;padding:30px;cursor:zoom-out}
#lb.show{display:flex}
#lb img{max-width:92vw;max-height:88vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lb .x{position:absolute;top:22px;right:28px;color:#fff;font-size:34px;cursor:pointer;line-height:1}

.quotes{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:54px}
.quote{background:var(--ink-2);border:1px solid var(--ink-3);border-radius:var(--r-lg);padding:40px 36px;position:relative}
.quote .mark{font-size:80px;color:var(--red);font-weight:800;line-height:.6;font-family:Georgia,serif;position:absolute;top:26px;left:30px;opacity:.5}
.quote p{font-size:18px;line-height:1.7;color:#fff;font-style:italic;position:relative;padding-top:30px}
.quote .by{margin-top:20px;color:var(--muted-d);font-size:13.5px;font-weight:500}
.quote .by b,.quote .by strong{color:var(--gold)}

.bens{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:54px}
.ben{display:flex;gap:20px;padding:30px;border:1px solid var(--line);border-radius:var(--r);background:var(--paper);transition:.3s}
.ben:hover{box-shadow:var(--shadow);transform:translateY(-4px)}
.ben .bi{flex:0 0 auto;width:54px;height:54px;border-radius:14px;background:var(--red);color:#fff;display:grid;place-items:center}
.ben .bi svg{width:26px;height:26px}
.ben h4{font-size:18px;font-weight:700}
.ben p{color:var(--muted);font-size:14.5px;margin-top:6px}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:54px;counter-reset:s}
.step{padding:30px 24px;position:relative}
.step:not(:last-child)::after{content:"";position:absolute;top:46px;right:-12px;width:24px;height:24px;border-top:2px dashed var(--red);border-right:2px dashed var(--red);transform:rotate(45deg)}
.step .n{counter-increment:s;width:56px;height:56px;border-radius:50%;background:linear-gradient(140deg,var(--red),var(--red-dark));color:#fff;display:grid;place-items:center;font-size:22px;font-weight:800;margin-bottom:20px;box-shadow:0 12px 26px rgba(215,0,24,.3)}
.step .n::before{content:counter(s)}
.step h4{font-size:17px;font-weight:700;letter-spacing:-.01em}
.step p{color:var(--muted);font-size:14px;margin-top:8px}

.cta{background:radial-gradient(120% 130% at 80% 0%,#ff1f3a,#a00010 55%,#4d0007);color:#fff;border-radius:32px;padding:64px 56px;margin-top:10px;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:46px 46px;mask-image:radial-gradient(70% 100% at 80% 0,#000,transparent)}
.cta .inner{position:relative;z-index:2;display:grid;grid-template-columns:1.2fr 1fr;gap:46px;align-items:center}
.cta h2{font-size:clamp(28px,4vw,44px);font-weight:800;letter-spacing:-.02em;line-height:1.1}
.cta .q{font-size:16.5px;color:rgba(255,255,255,.88);margin-top:18px;font-weight:300;font-style:italic}
.contact-card{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:22px;padding:32px;backdrop-filter:blur(8px)}
.contact-card .who{font-size:13px;letter-spacing:.1em;text-transform:uppercase;opacity:.75}
.contact-card .nm{font-size:24px;font-weight:800;margin:6px 0 22px}
.crow{display:flex;align-items:center;gap:14px;padding:12px 0;border-top:1px solid rgba(255,255,255,.18);font-size:15.5px}
.crow svg{width:20px;height:20px;flex:0 0 auto;opacity:.9}
.crow a{font-weight:500}.crow a:hover{text-decoration:underline}

footer{background:var(--ink);color:var(--muted-d);padding:50px 0 40px;text-align:center}
footer .brand{justify-content:center;color:#fff;margin-bottom:14px}
footer img{height:24px}
footer .fl{display:flex;gap:26px;justify-content:center;margin:18px 0;flex-wrap:wrap}
footer .fl a{font-size:14px;transition:.2s}footer .fl a:hover{color:#fff}
footer .cp{font-size:13px;opacity:.6;margin-top:14px}

@media(max-width:920px){
  .pillars,.statband,.quotes,.bens,.steps{grid-template-columns:1fr 1fr}
  .step::after{display:none}
  .cmp{grid-template-columns:1fr}
  .cta .inner{grid-template-columns:1fr;gap:30px}
  .gal{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .navlinks{position:fixed;top:72px;right:0;left:0;background:#fff;flex-direction:column;padding:24px;gap:18px;box-shadow:var(--shadow);transform:translateY(-130%);transition:.4s;align-items:flex-start}
  .navlinks.open{transform:none}
  nav.light .navlinks a{color:var(--ink)}
  .burger{display:flex}
  .sec{padding:78px 0}
  .pillars,.statband,.quotes,.bens,.steps,.gal{grid-template-columns:1fr}
  .hero-stats{gap:26px}
  .cta{padding:40px 26px}
  .tl-card{padding:30px 22px}
}
