:root{
  --bg:#050505;--fg:#fff;--muted:rgba(255,255,255,.42);--faint:rgba(255,255,255,.16);
  --line:rgba(255,255,255,.08);--accent:#6d5cff;--accent2:#00d4ff;
  --display:'Syne',sans-serif;--body:'Sora',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--fg);font-family:var(--body);font-weight:300;overflow-x:hidden;cursor:none}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent);color:#fff}

#webgl{position:fixed;inset:0;width:100%;height:100%;z-index:0}
#grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.04;
  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' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.content{position:relative;z-index:3}

#cursor{position:fixed;width:8px;height:8px;border-radius:50%;background:#fff;z-index:9999;pointer-events:none;
  transform:translate(-50%,-50%);mix-blend-mode:difference;transition:width .25s,height .25s}
#cursor-ring{position:fixed;width:34px;height:34px;border:1px solid rgba(255,255,255,.35);border-radius:50%;
  z-index:9999;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s,height .3s,border-color .3s}
.hovering #cursor{width:0;height:0}
.hovering #cursor-ring{width:54px;height:54px;border-color:var(--accent2)}

nav{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;justify-content:space-between;align-items:center;
  padding:24px 48px;mix-blend-mode:difference}
.logo{font-family:var(--display);font-weight:800;font-size:18px;letter-spacing:-.02em}
.nav-links{display:flex;gap:36px;align-items:center}
.nav-links a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .3s;position:relative}
.nav-links a:hover,.nav-links a.active{color:#fff}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-5px;width:0;height:1px;background:#fff;transition:width .3s}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-cta{font-size:11px!important;letter-spacing:.14em;text-transform:uppercase;border:1px solid rgba(255,255,255,.4);
  padding:11px 22px;color:#fff!important}
.nav-cta::after{display:none}
.nav-cta:hover{background:#fff;color:#000!important}
.menu-btn{display:none;font-family:var(--display);font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  background:none;border:none;color:#fff;cursor:none}

.page{padding:160px 48px 120px;max-width:1180px;margin:0 auto;min-height:60vh}
.page-head{margin-bottom:90px}
.page-head .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:24px}
.page-head h1{font-family:var(--display);font-weight:800;font-size:clamp(40px,7vw,88px);line-height:.95;letter-spacing:-.03em}
.page-head h1 em{font-style:italic;font-weight:400;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.55)}
.page-head .lead{font-size:16px;color:var(--muted);max-width:520px;line-height:1.9;margin-top:30px}

.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s cubic-bezier(.16,1,.3,1),transform 1s cubic-bezier(.16,1,.3,1)}
.reveal.in{opacity:1;transform:none}

#loader{position:fixed;inset:0;z-index:9000;background:#050505;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:26px;transition:opacity .7s ease,visibility .7s}
#loader.done{opacity:0;visibility:hidden}
#loader .loader-logo{font-family:var(--display);font-weight:800;font-size:26px;letter-spacing:-.02em}
#loader .loader-bar{width:180px;height:2px;background:var(--line);position:relative;overflow:hidden}
#loader .loader-bar i{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .2s}
#loader .loader-pct{font-family:var(--display);font-size:12px;letter-spacing:.2em;color:var(--muted)}

#hero-canvas{position:absolute;inset:0;width:100%!important;height:100%!important;z-index:-1;opacity:0;transition:opacity 1.4s ease .3s}
body.loaded #hero-canvas{opacity:1}

.hero{height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:flex-start;max-width:1100px;margin:0 auto;padding:0 48px;position:relative}
.hero h1 .line span,.hero .eyebrow span,.hero p,.hero-cta{animation-play-state:paused}
body.loaded .hero h1 .line span,body.loaded .hero .eyebrow span,body.loaded .hero p,body.loaded .hero-cta{animation-play-state:running}
.btn,.nav-cta{transition:transform .25s cubic-bezier(.16,1,.3,1),background .35s,color .35s,border-color .35s}
.hero .eyebrow{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:34px;overflow:hidden}
.hero .eyebrow span{display:inline-block;animation:slideUp 1s cubic-bezier(.16,1,.3,1) .2s both}
.hero h1{font-family:var(--display);font-weight:800;font-size:clamp(48px,9vw,128px);line-height:.92;letter-spacing:-.03em;margin-bottom:38px}
.hero h1 .line{overflow:hidden;display:block}
.hero h1 .line span{display:inline-block;animation:slideUp 1.1s cubic-bezier(.16,1,.3,1) both}
.hero h1 .line:nth-child(1) span{animation-delay:.35s}
.hero h1 .line:nth-child(2) span{animation-delay:.5s}
.hero h1 em{font-style:italic;font-weight:400;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.55)}
.hero p{font-size:16px;color:var(--muted);max-width:440px;line-height:1.9;animation:fadeIn 1.2s ease .8s both;margin-bottom:42px}
.hero-cta{display:flex;gap:18px;animation:fadeIn 1.2s ease 1s both}
.btn{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.14em;text-transform:uppercase;
  padding:16px 36px;cursor:none;transition:all .35s;border:1px solid rgba(255,255,255,.7);color:#fff;background:transparent;display:inline-block}
.btn:hover{background:#fff;color:#000}
.btn.ghost{border-color:var(--line);color:var(--muted)}
.btn.ghost:hover{color:#fff;border-color:#fff;background:transparent}
@keyframes slideUp{from{transform:translateY(110%)}to{transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.scroll-cue{position:absolute;bottom:38px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:12px;animation:fadeIn 1s ease 1.4s both}
.scroll-cue span{font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--faint)}
.scroll-line{width:1px;height:46px;background:var(--line);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:-100%;left:0;width:1px;height:100%;background:rgba(255,255,255,.7);animation:scrolldown 2s ease-in-out infinite}
@keyframes scrolldown{to{top:100%}}

.section-head{display:flex;align-items:baseline;gap:18px;margin-bottom:64px}
.section-num{font-family:var(--display);font-size:13px;color:var(--accent);font-weight:600}
.section-title{font-family:var(--display);font-weight:700;font-size:clamp(26px,4vw,42px);letter-spacing:-.02em}
.section{padding:90px 48px;max-width:1180px;margin:0 auto}

.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:90px;align-items:start}
.about-lead{font-family:var(--display);font-weight:600;font-size:clamp(24px,3vw,38px);line-height:1.25;letter-spacing:-.02em}
.about-lead .hl{color:transparent;-webkit-text-stroke:1px var(--accent2)}
.about-body{font-size:15px;color:var(--muted);line-height:2;margin-bottom:24px}
.about-stats{display:flex;gap:54px;margin-top:44px}
.stat .n{font-family:var(--display);font-weight:700;font-size:46px;letter-spacing:-.02em}
.stat .l{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:6px}

.skill-list{border-top:1px solid var(--line)}
.skill-row{display:flex;align-items:center;justify-content:space-between;padding:30px 8px;border-bottom:1px solid var(--line);position:relative;overflow:hidden;transition:padding-left .4s}
.skill-row:hover{padding-left:28px}
.skill-row::before{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(109,92,255,.08),transparent);opacity:0;transition:opacity .4s}
.skill-row:hover::before{opacity:1}
.skill-name{font-family:var(--display);font-weight:600;font-size:clamp(20px,2.4vw,30px);letter-spacing:-.01em;position:relative}
.skill-meta{display:flex;align-items:center;gap:24px;position:relative}
.skill-tag{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.skill-bar{width:120px;height:2px;background:var(--line);position:relative;overflow:hidden}
.skill-bar i{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width 1.2s cubic-bezier(.16,1,.3,1)}
.skill-row.in .skill-bar i{width:var(--w)}

.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.service-card{background:var(--bg);padding:48px 42px;transition:background .4s}
.service-card:hover{background:#0b0a14}
.service-card .si{font-family:var(--display);font-size:13px;color:var(--accent);font-weight:600;margin-bottom:26px}
.service-card h3{font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-.01em;margin-bottom:16px}
.service-card p{font-size:14px;color:var(--muted);line-height:1.9}

.process-step{display:grid;grid-template-columns:120px 1fr;gap:40px;padding:46px 0;border-top:1px solid var(--line);align-items:start}
.process-step:last-child{border-bottom:1px solid var(--line)}
.process-step .pn{font-family:var(--display);font-weight:800;font-size:60px;color:transparent;-webkit-text-stroke:1px var(--faint);line-height:1}
.process-step:hover .pn{-webkit-text-stroke:1px var(--accent2)}
.process-step h3{font-family:var(--display);font-weight:700;font-size:26px;letter-spacing:-.01em;margin-bottom:14px}
.process-step p{font-size:15px;color:var(--muted);line-height:1.9;max-width:560px}

.tech-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.tech-cell{background:var(--bg);aspect-ratio:3/2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;transition:background .35s}
.tech-cell:hover{background:#0b0a14}
.tech-cell .tdot{width:34px;height:34px;border-radius:50%;border:1px solid var(--faint);display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:13px;color:var(--accent2);transition:border-color .35s}
.tech-cell:hover .tdot{border-color:var(--accent2)}
.tech-cell span{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}

.exp-item{display:grid;grid-template-columns:160px 1fr;gap:50px;padding:42px 0;border-top:1px solid var(--line);align-items:start;transition:padding-left .4s}
.exp-item:hover{padding-left:18px}
.exp-item:last-child{border-bottom:1px solid var(--line)}
.exp-year{font-family:var(--display);font-weight:600;font-size:14px;color:var(--accent);letter-spacing:.06em}
.exp-item h3{font-family:var(--display);font-weight:700;font-size:24px;letter-spacing:-.01em;margin-bottom:8px}
.exp-item .role{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.exp-item p{font-size:14px;color:var(--muted);line-height:1.9;max-width:600px}

.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.work-card{position:relative;aspect-ratio:4/3;overflow:hidden;background:#0a0a0a;border:1px solid var(--line)}
.work-card.wide{grid-column:1/-1;aspect-ratio:21/9}
.work-card canvas{position:absolute;inset:0;width:100%!important;height:100%!important}
.work-overlay{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;padding:38px;background:linear-gradient(to top,rgba(5,5,5,.85),transparent 65%)}
.work-overlay .wtag{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent2);margin-bottom:12px}
.work-overlay .wname{font-family:var(--display);font-weight:700;font-size:clamp(20px,2.4vw,30px);letter-spacing:-.01em}
.work-overlay .wdesc{font-size:13px;color:var(--muted);margin-top:10px;max-width:380px;line-height:1.7;opacity:0;transform:translateY(12px);transition:opacity .4s,transform .4s}
.work-card:hover .wdesc{opacity:1;transform:none}
.work-arrow{position:absolute;top:34px;right:34px;z-index:2;width:46px;height:46px;border:1px solid var(--faint);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;opacity:0;transform:scale(.7) rotate(-30deg);transition:all .4s}
.work-card:hover .work-arrow{opacity:1;transform:scale(1) rotate(0)}

.test-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:6px}
.test-card{border:1px solid var(--line);padding:46px 42px;transition:background .4s,border-color .4s}
.test-card:hover{background:#0b0a14;border-color:rgba(0,212,255,.25)}
.test-card .quote{font-family:var(--display);font-weight:600;font-size:21px;line-height:1.5;letter-spacing:-.01em;margin-bottom:34px}
.test-card .quote::before{content:'\201C';color:var(--accent);margin-right:4px}
.test-author{display:flex;align-items:center;gap:16px}
.test-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;font-size:15px;color:#fff}
.test-author .an{font-family:var(--display);font-weight:600;font-size:15px}
.test-author .ar{font-size:12px;color:var(--muted);margin-top:2px}

.cta-band{text-align:center;padding:130px 48px;max-width:1100px;margin:0 auto}
.cta-band .pre{font-size:12px;letter-spacing:.3em;text-transform:uppercase;color:var(--muted);margin-bottom:30px}
.cta-band h2{font-family:var(--display);font-weight:800;font-size:clamp(36px,7vw,92px);line-height:.95;letter-spacing:-.03em;margin-bottom:44px}
.cta-band h2 a{color:transparent;-webkit-text-stroke:1.5px #fff;transition:color .4s,-webkit-text-stroke .4s}
.cta-band h2 a:hover{color:#fff;-webkit-text-stroke:1.5px transparent}

.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-info h3{font-family:var(--display);font-weight:600;font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;margin-top:34px}
.contact-info h3:first-child{margin-top:0}
.contact-info a,.contact-info p{font-family:var(--display);font-size:22px;font-weight:600;letter-spacing:-.01em;display:block}
.contact-info a:hover{color:var(--accent2)}
.contact-socials{display:flex;gap:24px;margin-top:14px}
.contact-socials a{font-family:var(--body);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.contact-socials a:hover{color:#fff}
.field{margin-bottom:28px}
.field label{display:block;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:12px}
.field input,.field textarea{width:100%;background:transparent;border:none;border-bottom:1px solid var(--line);color:#fff;font-family:var(--body);font-size:17px;font-weight:300;padding:10px 0;outline:none;transition:border-color .3s}
.field input:focus,.field textarea:focus{border-color:var(--accent2)}
.field textarea{resize:none;min-height:90px}
#cf-status{margin-top:16px;font-size:13px;color:var(--accent2);min-height:18px}

footer{border-top:1px solid var(--line);padding:60px 48px 42px;position:relative;z-index:3;max-width:1180px;margin:0 auto}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:50px;margin-bottom:54px}
.footer-brand .logo{font-size:22px;margin-bottom:18px}
.footer-brand p{font-size:13px;color:var(--muted);line-height:1.9;max-width:300px}
.footer-col h4{font-family:var(--display);font-weight:600;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.footer-col a{display:block;font-size:14px;color:rgba(255,255,255,.7);margin-bottom:12px;transition:color .3s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--line);padding-top:30px;flex-wrap:wrap;gap:16px}
.footer-copy{font-size:11px;color:var(--faint);letter-spacing:.08em}
.footer-social{display:flex;gap:26px}
.footer-social a{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);transition:color .3s}
.footer-social a:hover{color:#fff}

@media(max-width:820px){
  body{cursor:auto}
  #cursor,#cursor-ring{display:none}
  nav{padding:18px 22px}
  .nav-links{position:fixed;inset:0;background:rgba(5,5,5,.97);flex-direction:column;justify-content:center;gap:30px;
    transform:translateX(100%);transition:transform .4s cubic-bezier(.16,1,.3,1);mix-blend-mode:normal;z-index:200}
  .nav-links.open{transform:none}
  .nav-links a{font-size:18px}
  .menu-btn{display:block;z-index:201}
  .page,.section,.hero,.cta-band,footer{padding-left:22px;padding-right:22px}
  .about-grid,.contact-wrap{grid-template-columns:1fr;gap:46px}
  .services-grid,.test-grid,.work-grid{grid-template-columns:1fr}
  .work-card.wide{aspect-ratio:4/3}
  .tech-grid{grid-template-columns:repeat(2,1fr)}
  .process-step,.exp-item{grid-template-columns:1fr;gap:14px}
  .process-step .pn{font-size:44px}
  .about-stats{gap:34px}
  .footer-top{grid-template-columns:1fr;gap:36px}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}
