:root{
  --bg:#000;
  --fg:#fff;
  --muted:#8a8a8a;
  --accent:#ff5421;
  --accent-2:#ff7a3d;
  --line:rgba(255,255,255,0.1);
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--fg);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{cursor:none}
h1,h2,h3,h4{font-family:'Space Grotesk',sans-serif;font-weight:700;letter-spacing:-0.03em;line-height:0.95}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* Custom cursor */
.cursor{position:fixed;width:14px;height:14px;border-radius:50%;background:var(--accent);pointer-events:none;z-index:9999;mix-blend-mode:difference;transition:transform .2s ease,width .2s,height .2s;transform:translate(-50%,-50%)}
.cursor.big{width:60px;height:60px}
.cursor-ring{position:fixed;width:40px;height:40px;border:1px solid rgba(255,84,33,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .4s cubic-bezier(.2,.8,.2,1),width .3s,height .3s}

/* Noise overlay */
.noise{position:fixed;inset:0;pointer-events:none;z-index:200;opacity:0.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:24px 40px;display:flex;justify-content:space-between;align-items:center;mix-blend-mode:difference}
.nav-logo{display:flex;align-items:center;gap:12px;font-family:'Space Grotesk';font-weight:800;font-size:16px;letter-spacing:0.08em}
.nav-logo img{height:76px;width:auto;display:block}
.nav-links{display:flex;gap:40px;font-size:13px;font-weight:500;text-transform:uppercase;letter-spacing:0.1em}
.nav-links a{position:relative;color:#fff}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:#fff;transform:scaleX(0);transform-origin:right;transition:transform .4s ease}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}
.nav-links a.active::after{transform:scaleX(1);transform-origin:left}
.nav-cta{padding:12px 22px;border:1px solid #fff;border-radius:100px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;transition:all .3s}
.nav-cta:hover{background:#fff;color:#000}

/* HERO */
.hero{min-height:100vh;position:relative;display:flex;align-items:center;padding:0 40px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 100%,rgba(255,84,33,0.25),transparent 70%)}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.05) 1px,transparent 1px);background-size:80px 80px;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%)}
.hero-inner{position:relative;z-index:2;width:100%;max-width:1800px;margin:0 auto}

.hero h1{
  font-family:'Anton',sans-serif;
  font-weight:400;
  font-size:clamp(60px,13vw,220px);
  line-height:.92;
  letter-spacing:-0.02em;
  text-transform:uppercase;
}
.hero h1 .line{display:block;overflow:hidden;padding:0.08em 0;margin:-0.08em 0}
.hero h1 .line span{display:inline-block;transform:translateY(110%);animation:slideUp 1.1s cubic-bezier(.2,.9,.2,1) forwards}
.hero h1 .line:nth-child(1) span{animation-delay:.3s}
.hero h1 .line:nth-child(2) span{animation-delay:.45s}
.hero h1 .line:nth-child(3) span{animation-delay:.6s}
@keyframes slideUp{to{transform:translateY(0)}}
.hero h1 em{font-style:normal;color:var(--accent);font-family:'Anton',sans-serif}
.hero-outline{-webkit-text-stroke:2px #fff;color:transparent;paint-order:stroke fill}

.hero-footer{display:flex;justify-content:space-between;align-items:flex-end;margin-top:80px;gap:40px;flex-wrap:wrap;opacity:0;animation:fade 1s ease 1.2s forwards}
@keyframes fade{to{opacity:1}}
.hero-sub{max-width:440px;color:#bbb;font-size:16px;line-height:1.6}
.hero-ctas{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:12px;padding:20px 32px;border-radius:100px;font-size:14px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;transition:all .35s cubic-bezier(.2,.9,.2,1);cursor:none;border:none;font-family:inherit}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:#fff;color:#000;transform:translate(-2px,-2px)}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:#fff;background:#fff;color:#000}
.btn .arrow{width:20px;height:20px;border-radius:50%;background:#000;display:inline-flex;align-items:center;justify-content:center;font-size:10px;color:#fff}
.btn-primary:hover .arrow{background:var(--accent);color:#fff}
.btn-ghost .arrow{background:#fff;color:#000}

.scroll-hint{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);font-size:11px;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:14px}
.scroll-hint::after{content:"";width:1px;height:40px;background:linear-gradient(#fff,transparent);animation:sl 2s ease-in-out infinite}
@keyframes sl{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* MARQUEE */
.marquee{padding:30px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden;background:#000}
.marquee-track{display:flex;gap:60px;white-space:nowrap;animation:mscroll 25s linear infinite}
.marquee-track span{font-family:'Anton',sans-serif;font-size:80px;text-transform:uppercase;letter-spacing:-0.02em;display:flex;align-items:center;gap:60px}
.marquee-track span::after{content:"★";color:var(--accent);font-size:50px}
.marquee .outline{-webkit-text-stroke:2px #fff;color:transparent}
@keyframes mscroll{to{transform:translateX(-50%)}}

/* METRICS — huge kinetic */
.metrics{padding:160px 40px;position:relative;max-width:1800px;margin:0 auto}
.metrics-label{display:flex;align-items:center;gap:16px;font-size:11px;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent);margin-bottom:60px}
.metrics-label::before{content:"";width:40px;height:1px;background:var(--accent)}
.metrics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line)}
.metric{padding:50px 30px 50px 0;border-bottom:1px solid var(--line);position:relative;transition:background .4s}
.metric:not(:last-child){border-right:1px solid var(--line);padding-right:30px}
.metric:not(:first-child){padding-left:30px}
.metric:hover{background:rgba(255,84,33,0.03)}
.metric .big{font-family:'Anton',sans-serif;font-size:clamp(64px,7vw,120px);line-height:0.9;background:linear-gradient(180deg,#fff,#666);-webkit-background-clip:text;background-clip:text;color:transparent}
.metric .cap{font-size:12px;text-transform:uppercase;letter-spacing:0.15em;color:var(--muted);margin-top:20px}
.metric .num{font-size:11px;color:var(--muted);position:absolute;top:20px;right:20px;font-family:'Space Grotesk'}

/* BIG HEADING BLOCK */
.big-heading{padding:200px 40px;max-width:1800px;margin:0 auto;position:relative}
.big-heading h2{font-family:'Anton',sans-serif;font-size:clamp(70px,13vw,220px);line-height:0.92;text-transform:uppercase;letter-spacing:-0.02em;padding:0.08em 0;margin:-0.08em 0}
.big-heading h2 em{font-style:normal;-webkit-text-stroke:2px var(--accent);color:transparent}
.big-heading .accent-word{color:var(--accent)}
.big-heading .row{display:flex;gap:40px;align-items:flex-end;flex-wrap:wrap}
.big-heading .desc{max-width:380px;color:#bbb;margin-top:40px;font-size:16px;line-height:1.7}

/* SERVICES — stacked list rows */
.services{padding:0 0 120px;max-width:1800px;margin:0 auto}
.service-row{display:grid;grid-template-columns:80px 1fr 2fr auto;gap:40px;align-items:center;padding:50px 40px;border-top:1px solid var(--line);cursor:none;transition:all .5s ease;position:relative;overflow:hidden;isolation:isolate}
.service-row:last-child{border-bottom:1px solid var(--line)}
.service-row::before{content:"";position:absolute;inset:0;background:var(--accent);transform:translateY(100%);transition:transform .6s cubic-bezier(.2,.9,.2,1);z-index:0}
.service-row:hover::before{transform:translateY(0)}
.service-row:hover{color:#000}
.service-row:hover .s-num,.service-row:hover .s-name,.service-row:hover .s-desc{color:#000}
.service-row > *{position:relative;z-index:1}
.service-row .s-num{font-family:'Space Grotesk';font-size:14px;color:var(--muted);font-weight:500}
.service-row .s-name{font-family:'Anton',sans-serif;font-size:clamp(36px,5vw,72px);text-transform:uppercase;line-height:0.95}
.service-row .s-desc{font-size:15px;color:var(--muted);max-width:460px;line-height:1.6}
.service-row .s-arrow{width:60px;height:60px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .4s;font-size:18px}
.service-row:hover .s-arrow{border-color:#000;background:#000;color:#fff;transform:rotate(-45deg)}

/* CASES — cards w/ hover images */
.cases{padding:160px 40px;max-width:1800px;margin:0 auto}
.cases-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:80px;gap:40px;flex-wrap:wrap}
.cases-head h2{font-family:'Anton';font-size:clamp(60px,9vw,140px);text-transform:uppercase;line-height:0.9}
.cases-head h2 em{font-style:normal;-webkit-text-stroke:2px #fff;color:transparent}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.case{position:relative;padding:40px;background:#0a0a0a;border:1px solid var(--line);border-radius:24px;overflow:hidden;transition:all .5s;cursor:none}
.case::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,84,33,0.2),transparent 50%);opacity:0;transition:opacity .4s}
.case:hover{transform:translateY(-8px);border-color:var(--accent)}
.case:hover::before{opacity:1}
.case-inner{position:relative;z-index:2}
.case-brand{font-size:12px;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);margin-bottom:50px;display:flex;justify-content:space-between}
.case-brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 12px var(--accent)}
.case-stats{display:flex;flex-direction:column;gap:28px;margin-bottom:50px}
.case-stat .v{font-family:'Anton',sans-serif;font-size:64px;line-height:0.9;color:#fff}
.case-stat .v em{font-style:normal;color:var(--accent)}
.case-stat .l{font-size:11px;text-transform:uppercase;letter-spacing:0.15em;color:var(--muted);margin-top:6px}
.case-link{display:inline-flex;align-items:center;gap:10px;font-size:12px;text-transform:uppercase;letter-spacing:0.15em;padding-top:28px;border-top:1px solid var(--line)}

/* PROCESS */
.process{position:relative;background:#000;height:100vh}
.process-pin{height:100%;overflow:hidden}
.process-rail{display:flex;height:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:auto}
.process-rail::-webkit-scrollbar{display:none}
.process-panel{flex:0 0 100vw;height:100vh;padding:120px 8vw 90px;display:flex;align-items:center}
.process-intro{max-width:920px}
.process-intro .label{display:flex;align-items:center;gap:16px;font-size:11px;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent);margin-bottom:34px}
.process-intro .label::before{content:"";width:40px;height:1px;background:var(--accent)}
.process-intro h2{font-family:'Anton';font-size:clamp(64px,10vw,170px);text-transform:uppercase;line-height:0.9;margin-bottom:30px}
.process-intro h2 em{font-style:normal;-webkit-text-stroke:2px #fff;color:transparent}
.process-intro p{color:#bbb;font-size:19px;max-width:560px;line-height:1.7}
.process-step{width:100%;display:grid;grid-template-columns:220px minmax(360px,620px);gap:40px;align-items:end}
.process-step .num{font-family:'Anton';font-size:240px;line-height:0.8;-webkit-text-stroke:2px var(--accent);color:transparent}
.process-step .body h3{font-family:'Anton';font-size:clamp(64px,8vw,120px);text-transform:uppercase;margin-bottom:18px;line-height:0.9}
.process-step .body p{color:#aaa;font-size:18px;line-height:1.7;max-width:520px}
.process-step .tag{font-size:11px;text-transform:uppercase;letter-spacing:0.2em;color:var(--accent);margin-bottom:14px}

/* TESTIMONIALS */
.testimonials{padding:160px 40px;max-width:1800px;margin:0 auto}
.t-head{margin-bottom:80px}
.t-head h2{font-family:'Anton';font-size:clamp(60px,10vw,160px);text-transform:uppercase;line-height:0.9}
.t-head h2 em{font-style:normal;-webkit-text-stroke:2px #fff;color:transparent}
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.t-card{padding:50px 40px;border:1px solid var(--line);border-radius:24px;background:#0a0a0a;position:relative;transition:all .4s;cursor:none}
.t-card:hover{border-color:var(--accent);transform:translateY(-6px)}
.t-card .q-mark{font-family:'Anton';font-size:120px;line-height:0.5;color:var(--accent);margin-bottom:30px;display:block}
.t-card .quote{font-size:18px;line-height:1.6;color:#e0e0e0;margin-bottom:40px;font-weight:500}
.t-card .person{display:flex;align-items:center;gap:16px;padding-top:30px;border-top:1px solid var(--line)}
.avatar{width:50px;height:50px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-weight:700;font-family:'Space Grotesk'}
.person .name{font-weight:600;font-size:15px}
.person .co{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em;margin-top:2px}

/* FINAL CTA — huge kinetic */
.final{padding:200px 40px;text-align:center;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at center,rgba(255,84,33,0.3),transparent 60%)}
.final-inner{position:relative;z-index:2;max-width:1400px;margin:0 auto}
.final h2{font-family:'Anton';font-size:clamp(70px,14vw,260px);text-transform:uppercase;line-height:0.92;margin-bottom:50px;padding:0.08em 0;margin-top:-0.08em}
.final h2 em{font-style:normal;color:var(--accent)}
.final h2 .outline{-webkit-text-stroke:2px #fff;color:transparent}
.final p{font-size:18px;color:#bbb;max-width:500px;margin:0 auto 50px;line-height:1.7}
.final-cta{display:inline-flex;align-items:center;gap:20px;padding:30px 50px;background:var(--accent);border-radius:100px;font-size:18px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;transition:all .4s;cursor:none}
.final-cta:hover{background:#fff;color:#000;transform:scale(1.05)}
.final-cta .circle{width:40px;height:40px;border-radius:50%;background:#000;display:flex;align-items:center;justify-content:center}
.final-cta:hover .circle{background:var(--accent)}

/* FOOTER */
footer{background:
  radial-gradient(circle at 10% 10%,rgba(255,84,33,0.16),transparent 38%),
  linear-gradient(180deg,#030303 0%,#000 100%);
  border-top:1px solid var(--line);padding:100px 40px 40px}
.foot-inner{max-width:1800px;margin:0 auto}
.foot-logo{margin:0 auto 80px;display:flex;align-items:center;justify-content:center}
.foot-logo img{width:min(92vw,1100px);height:auto;display:block}
.foot-grid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1.2fr;gap:60px;padding:50px 40px;border:1px solid var(--line);border-radius:24px;background:rgba(255,255,255,0.02);backdrop-filter:blur(4px);margin-bottom:40px}
.foot-grid h4{font-size:11px;text-transform:uppercase;letter-spacing:0.2em;color:var(--muted);margin-bottom:24px}
.foot-grid ul{list-style:none}
.foot-grid li{margin-bottom:14px}
.foot-grid li a{font-size:15px;color:#ddd;transition:color .2s}
.foot-grid li a:hover{color:var(--accent)}
.foot-about-wrap{display:flex;align-items:flex-start;gap:16px}
.foot-symbol{width:56px;height:56px;flex:0 0 56px;display:block}
.foot-about{color:#bbb;font-size:15px;max-width:360px;line-height:1.6}
.foot-contact{display:grid;gap:14px}
.foot-contact a,.foot-contact span{font-size:15px;color:#ddd}
.foot-contact a:hover{color:var(--accent)}
.foot-legal{display:flex;gap:16px;flex-wrap:wrap}
.foot-legal a{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:0.1em}
.foot-legal a:hover{color:var(--accent)}
.foot-bottom{border-top:1px solid var(--line);padding-top:30px;display:flex;justify-content:space-between;align-items:center;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0.1em;flex-wrap:wrap;gap:20px}

/* Logo marquee (brand logos) */
.brand-strip{padding:80px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.brand-label{text-align:center;font-size:11px;text-transform:uppercase;letter-spacing:0.25em;color:var(--muted);margin-bottom:50px}
.brand-track{display:flex;gap:100px;animation:mscroll 35s linear infinite;white-space:nowrap}
.brand-item{font-family:'Space Grotesk';font-size:32px;font-weight:700;color:#555;transition:color .3s;letter-spacing:-0.02em}
.brand-item:hover{color:#fff}

/* Generic page layouts */
.page-main{padding-top:88px}
.page-hero{padding:120px 40px 80px;max-width:1600px;margin:0 auto}
.page-hero-inner{max-width:980px}
.page-kicker{font-size:11px;text-transform:uppercase;letter-spacing:0.25em;color:var(--accent);margin-bottom:24px}
.page-hero h1{font-family:'Anton',sans-serif;font-size:clamp(56px,10vw,160px);line-height:0.9;letter-spacing:-0.02em;text-transform:uppercase;margin-bottom:24px}
.page-hero p{font-size:19px;line-height:1.7;color:#bcbcbc;max-width:720px}
.page-section{padding:0 40px 80px;max-width:1600px;margin:0 auto}
.page-grid{display:grid;gap:24px}
.page-grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.page-grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.page-card{padding:36px;border:1px solid var(--line);border-radius:20px;background:#080808}
.page-card h3{font-family:'Anton',sans-serif;font-size:clamp(30px,4vw,54px);line-height:0.95;text-transform:uppercase;margin-bottom:18px}
.page-card p{color:#b9b9b9;font-size:16px;line-height:1.7}
.page-card a{color:var(--accent)}
.page-cta{padding:40px 40px 120px;max-width:1600px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.page-cta h2{font-family:'Anton',sans-serif;font-size:clamp(44px,7vw,96px);line-height:0.9;text-transform:uppercase}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(60px);transition:all 1s cubic-bezier(.2,.9,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.1s}
.reveal.d2{transition-delay:.2s}
.reveal.d3{transition-delay:.3s}

@media (max-width:1000px){
  body{cursor:auto}.cursor,.cursor-ring{display:none}
  .nav-links{display:none}
  .metrics-grid,.services-grid,.cases-grid,.t-grid,.foot-grid{grid-template-columns:1fr}
  .service-row{grid-template-columns:1fr;gap:16px;padding:30px 20px}
  .process{height:auto;padding:80px 20px}
  .process-pin{position:static;height:auto;overflow:visible}
  .process-rail{display:block}
  .process-panel{height:auto;padding:0}
  .process-intro{padding:0 0 28px}
  .process-step{grid-template-columns:1fr;border-top:1px solid var(--line);padding:28px 0}
  .process-step .num{font-size:140px}
  .process-step .body h3{font-size:52px}
  .process-intro p,.process-step .body p{font-size:16px}
  .page-hero,.page-section,.page-cta{padding-left:20px;padding-right:20px}
  .page-grid-2,.page-grid-3{grid-template-columns:1fr}
  .cases-grid{grid-template-columns:1fr}
  .nav-logo img{height:56px}
  nav{padding:20px}
  .hero,.metrics,.big-heading,.cases,.testimonials,.final,footer{padding-left:20px;padding-right:20px}
  .foot-logo img{width:min(92vw,700px)}
  .foot-about-wrap{gap:12px}
  .foot-symbol{width:44px;height:44px;flex-basis:44px}
  .foot-grid{padding:30px 24px}
}
