:root{--bg: #05060f;--bg-2: #0a0d1f;--panel: rgba(255, 255, 255, .035);--panel-border: rgba(255, 255, 255, .09);--text: #eef0ff;--text-dim: #9aa0c4;--text-faint: #5e6494;--accent: #7c5cff;--accent-2: #22d3ee;--maxw: 1180px}*{box-sizing:border-box}html{scroll-behavior:smooth}html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:hidden}body{margin:0;background:var(--bg);color:var(--text);font-family:Sora,system-ui,-apple-system,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden}::selection{background:var(--accent);color:#fff}a{color:inherit;text-decoration:none}.mono{font-family:JetBrains Mono,monospace}.space-bg{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-2;background:radial-gradient(1200px 700px at 75% -10%,rgba(124,92,255,.18),transparent 60%),radial-gradient(900px 600px at 10% 20%,rgba(34,211,238,.12),transparent 60%),radial-gradient(700px 700px at 90% 90%,rgba(251,113,133,.1),transparent 60%),linear-gradient(180deg,var(--bg) 0%,var(--bg-2) 100%)}.webgl{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none}.webgl canvas{display:block}.cursor-dot,.cursor-ring{position:fixed;top:0;left:0;border-radius:50%;pointer-events:none;z-index:9999;will-change:transform;margin-left:-4px;margin-top:-4px}.cursor-dot{width:8px;height:8px;background:#fff;mix-blend-mode:difference}.cursor-ring{width:34px;height:34px;margin-left:-17px;margin-top:-17px;border:1.5px solid var(--accent-2);transition:opacity .25s,border-color .25s}body.has-custom-cursor,body.has-custom-cursor a,body.has-custom-cursor button,body.has-custom-cursor .project-card{cursor:none}@media (pointer: coarse){.cursor-dot,.cursor-ring{display:none}}.grid-glow{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;background-image:linear-gradient(rgba(124,92,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(124,92,255,.04) 1px,transparent 1px);background-size:60px 60px;-webkit-mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 75%);mask-image:radial-gradient(circle at 50% 30%,#000 0%,transparent 75%);pointer-events:none}.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:18px clamp(20px,5vw,64px);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(180deg,rgba(5,6,15,.7),transparent)}.nav .brand{font-weight:700;letter-spacing:.5px}.nav .brand span{color:var(--accent)}.nav-links{display:flex;gap:28px}.nav-links a{color:var(--text-dim);font-size:14px;transition:color .2s}.nav-links a:hover{color:var(--text)}@media (max-width: 640px){.nav-links{display:none}}.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(20px,5vw,40px)}section{position:relative}.eyebrow{font-family:JetBrains Mono,monospace;font-size:13px;letter-spacing:2px;text-transform:uppercase;color:var(--accent-2);margin-bottom:16px}.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding-top:80px}.hero:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;background:linear-gradient(90deg,rgba(5,6,15,.82) 0%,rgba(5,6,15,.5) 40%,rgba(5,6,15,.1) 65%,transparent 80%)}.hero .wrap{position:relative;z-index:2}.hero .scroll-hint{z-index:2}.hero h1{font-size:clamp(40px,8vw,92px);line-height:1.02;margin:0 0 24px;font-weight:800;letter-spacing:-1.5px}.hero h1 .grad{background:linear-gradient(120deg,#fff 10%,var(--accent) 55%,var(--accent-2) 100%);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.hero p.lead{font-size:clamp(16px,2.2vw,21px);color:var(--text-dim);max-width:620px;line-height:1.6;margin:0 0 36px}.hero-cta{display:flex;gap:16px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 26px;border-radius:14px;font-weight:600;font-size:15px;cursor:pointer;border:1px solid var(--panel-border);transition:transform .2s,box-shadow .2s,background .2s}.btn.primary{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#06070f;border:none;box-shadow:0 10px 40px #7c5cff59}.btn.ghost{background:var(--panel);color:var(--text)}.btn:hover{transform:translateY(-2px)}.btn.primary:hover{box-shadow:0 16px 50px #7c5cff80}.hero-services{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:34px}.service-chip{font-size:13px;font-weight:500;padding:8px 15px;border-radius:999px;color:var(--text-dim);border:1px solid rgba(255,255,255,.12);background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:color .2s,border-color .2s,transform .2s}.service-chip:hover{color:var(--text);border-color:var(--accent-2);transform:translateY(-2px)}.hero-stats{display:flex;gap:clamp(24px,5vw,56px);margin-top:64px;flex-wrap:wrap}.stat .num{font-size:clamp(28px,4vw,40px);font-weight:700;background:linear-gradient(120deg,#fff,var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.stat .lbl{color:var(--text-faint);font-size:13px;margin-top:4px}.scroll-hint{position:absolute;bottom:32px;left:50%;transform:translate(-50%);color:var(--text-faint);font-size:12px;letter-spacing:2px;text-transform:uppercase}.section-head{margin-bottom:56px;max-width:640px}.section-head h2{font-size:clamp(30px,5vw,52px);margin:0 0 16px;font-weight:700;letter-spacing:-1px}.section-head p{color:var(--text-dim);font-size:17px;line-height:1.6;margin:0}.projects{padding:clamp(80px,14vh,160px) 0}.project-card{position:relative;margin-bottom:40px;perspective:1300px}.pc-inner{position:relative;border-radius:24px;padding:clamp(28px,4vw,48px);background:linear-gradient(155deg,#1e213ac7,#0c0e1cb3);border:1px solid rgba(255,255,255,.14);box-shadow:0 30px 80px -22px #000000bf,0 12px 30px -14px #0009,inset 0 1px #ffffff1a,inset 0 0 40px -20px #ffffff14;backdrop-filter:blur(22px) saturate(1.4);-webkit-backdrop-filter:blur(22px) saturate(1.4);transform-style:preserve-3d;transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .35s,border-color .35s,background .35s;will-change:transform}.project-card:hover .pc-inner{background:linear-gradient(155deg,#2c3052d6,#121528c2);border-color:color-mix(in srgb,var(--card-accent) 60%,transparent);box-shadow:0 50px 110px -28px #000c,0 0 0 1px color-mix(in srgb,var(--card-accent) 30%,transparent),0 26px 60px -18px var(--card-glow),inset 0 1px #ffffff29}.project-card:hover .pc-inner:before{opacity:1}.pc-inner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(560px 320px at var(--mx, 80%) var(--my, 0%),var(--card-glow),transparent 68%);opacity:.85;pointer-events:none;transition:opacity .3s;transform:translateZ(1px)}@property --beam{syntax: "<angle>"; inherits: false; initial-value: 0deg;}.pc-inner:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;padding:1.6px;background:conic-gradient(from var(--beam),transparent 0%,color-mix(in srgb,var(--card-accent) 70%,transparent) 6%,var(--card-accent) 10%,#ffffff 12.5%,var(--card-accent) 15%,transparent 22%,transparent 50%,color-mix(in srgb,var(--card-accent) 50%,transparent) 56%,#ffffff 60%,transparent 66%,transparent 100%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;opacity:0;transition:opacity .35s;pointer-events:none;filter:drop-shadow(0 0 4px var(--card-accent))}.project-card:hover .pc-inner:after{opacity:1;animation:beam-run 2.6s linear infinite}@keyframes beam-run{to{--beam: 360deg}}.project-card .pc-grid>div{transform-style:preserve-3d}.pc-inner h3{transform:translateZ(55px)}.pc-inner .pc-tagline{transform:translateZ(42px)}.pc-inner .pc-index{transform:translateZ(30px)}.pc-inner .pc-meta{transform:translateZ(24px)}.pc-inner .pc-actions{transform:translateZ(60px)}.pc-inner .pc-block{transform:translateZ(20px)}.pc-inner .pc-block:nth-child(2){transform:translateZ(34px)}.pc-inner .pc-block:nth-child(3){transform:translateZ(48px)}.project-card .pc-grid{position:relative;transform-style:preserve-3d;display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(24px,4vw,48px)}@media (max-width: 820px){.project-card .pc-grid{grid-template-columns:1fr}}.pc-index{font-family:JetBrains Mono,monospace;font-size:13px;color:var(--text-faint)}.project-card h3{font-size:clamp(30px,4.2vw,48px);margin:10px 0 8px;font-weight:800;letter-spacing:-.6px;color:#fff;text-shadow:0 2px 24px rgba(0,0,0,.6),0 0 1px rgba(0,0,0,.8)}.pc-tagline{color:var(--card-accent);font-size:17px;margin:0 0 22px;font-weight:600;text-shadow:0 0 18px var(--card-glow)}.pc-meta{display:flex;flex-direction:column;gap:14px;margin-bottom:24px}.pc-meta .row{font-size:14px;color:var(--text-dim)}.pc-meta .row b{color:var(--text-faint);font-weight:500;display:block;font-size:12px;letter-spacing:1px;text-transform:uppercase;margin-bottom:3px}.stack{display:flex;flex-wrap:wrap;gap:8px}.chip{font-family:JetBrains Mono,monospace;font-size:12px;padding:6px 12px;border-radius:999px;border:1px solid var(--panel-border);color:var(--text-dim);background:#ffffff08}.pc-actions{display:flex;flex-wrap:wrap;align-items:center;gap:12px;margin-top:8px}.pc-request{font-family:inherit;cursor:pointer;padding:11px 20px;border-radius:12px;font-weight:600;font-size:14px;color:var(--text);background:#ffffff0a;border:1px solid var(--card-accent);transition:background .2s,color .2s,transform .2s,box-shadow .2s}.pc-request:hover{background:var(--card-accent);color:#06070f;transform:translateY(-2px);box-shadow:0 10px 30px var(--card-glow)}.pc-link{display:inline-flex;align-items:center;gap:8px;padding:11px 20px;border-radius:12px;font-weight:600;font-size:14px;color:#06070f;background:var(--card-accent);box-shadow:0 8px 30px var(--card-glow);transition:transform .2s,box-shadow .2s}.pc-link:hover{transform:translateY(-2px);box-shadow:0 14px 40px var(--card-glow)}.pc-private{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--text-faint);background:#ffffff08;border:1px dashed var(--panel-border);padding:11px 16px;border-radius:12px;max-width:360px;line-height:1.4}.pc-private .lock{font-size:14px;filter:grayscale(.2)}.pc-blocks{display:flex;flex-direction:column;gap:20px}.pc-block{border-left:2px solid var(--card-accent);padding-left:18px}.pc-block .k{font-family:JetBrains Mono,monospace;font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--card-accent);margin-bottom:8px;font-weight:600;text-shadow:0 0 14px var(--card-glow)}.pc-block .v{color:#d6dbf2;font-size:15.5px;line-height:1.64;text-shadow:0 1px 3px rgba(0,0,0,.55)}.footer{padding:clamp(60px,12vh,130px) 0 80px;text-align:center}.footer h2{font-size:clamp(30px,6vw,60px);margin:0 0 20px;font-weight:800;letter-spacing:-1px}.footer h2 .grad{background:linear-gradient(120deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.footer p{color:var(--text-dim);max-width:480px;margin:0 auto 32px;font-size:17px;line-height:1.6}.footer-links{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}.footer .copy{margin-top:60px;color:var(--text-faint);font-size:13px}.reveal{will-change:transform,opacity}.audio-toggle{position:fixed;right:clamp(16px,4vw,32px);bottom:clamp(16px,4vw,28px);z-index:60;display:inline-flex;align-items:center;gap:10px;padding:10px 16px 10px 14px;border-radius:999px;cursor:pointer;color:var(--text);font-family:inherit;font-size:13px;font-weight:600;border:1px solid var(--panel-border);background:#0a0c1a99;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);transition:border-color .25s,box-shadow .25s,transform .2s}.audio-toggle:hover{transform:translateY(-2px);border-color:var(--accent-2)}.audio-toggle.on{border-color:var(--accent-2);box-shadow:0 10px 30px #22d3ee40}.audio-toggle .eq{display:inline-flex;align-items:flex-end;gap:2.5px;height:14px}.audio-toggle .eq i{width:2.5px;height:5px;border-radius:2px;background:var(--accent-2);opacity:.55}.audio-toggle.on .eq i{opacity:1;animation:eq .9s ease-in-out infinite}.audio-toggle.on .eq i:nth-child(2){animation-delay:.15s}.audio-toggle.on .eq i:nth-child(3){animation-delay:.3s}.audio-toggle.on .eq i:nth-child(4){animation-delay:.45s}@keyframes eq{0%,to{height:4px}50%{height:14px}}@media (max-width: 520px){.audio-label{display:none}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:#03040ca8;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}.modal{position:relative;width:100%;max-width:480px;border-radius:24px;padding:clamp(28px,5vw,40px);background:linear-gradient(155deg,#1e2038eb,#0e1020eb);border:1px solid rgba(255,255,255,.14);box-shadow:0 40px 100px -30px #000c,0 0 0 1px color-mix(in srgb,var(--card-accent) 22%,transparent),0 20px 60px -24px var(--card-glow, rgba(124, 92, 255, .4));-webkit-backdrop-filter:blur(24px) saturate(1.3);backdrop-filter:blur(24px) saturate(1.3)}.modal-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:10px;border:1px solid var(--panel-border);background:#ffffff0a;color:var(--text-dim);font-size:15px;cursor:pointer;transition:background .2s,color .2s}.modal-close:hover{background:#ffffff1a;color:var(--text)}.modal-eyebrow{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--card-accent);margin-bottom:8px}.modal-title{font-size:clamp(24px,5vw,32px);margin:0 0 4px;font-weight:700;letter-spacing:-.5px}.modal-sub{color:var(--text-dim);font-size:15px;margin:0 0 24px}.modal-form{display:flex;flex-direction:column;gap:16px}.modal-form label{display:flex;flex-direction:column;gap:7px}.modal-form label span{font-size:12px;letter-spacing:.5px;color:var(--text-faint);text-transform:uppercase}.modal-form input,.modal-form textarea{font-family:inherit;font-size:15px;color:var(--text);background:#ffffff0a;border:1px solid var(--panel-border);border-radius:12px;padding:12px 14px;resize:vertical;transition:border-color .2s,background .2s}.modal-form input::placeholder,.modal-form textarea::placeholder{color:var(--text-faint)}.modal-form input:focus,.modal-form textarea:focus{outline:none;border-color:var(--card-accent);background:#ffffff0f}.modal-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:6px}.modal-actions .btn{flex:1;justify-content:center;min-width:150px}.modal-contacts{margin-top:20px;text-align:center;color:var(--text-faint);font-size:12px}.modal-toast{position:absolute;left:50%;bottom:-14px;transform:translate(-50%,100%);background:var(--card-accent);color:#06070f;font-size:13px;font-weight:600;padding:10px 18px;border-radius:12px;white-space:nowrap;box-shadow:0 12px 40px var(--card-glow, rgba(0,0,0,.4))}@media (max-width: 520px){.modal-toast{white-space:normal;max-width:90vw;text-align:center}}@supports (height: 100svh){.hero{min-height:100svh}}@media (max-width: 900px){.hero h1{font-size:clamp(34px,8.5vw,64px)}.hero:before{background:linear-gradient(180deg,#05060f59,#05060f8c 45%,#05060fd9)}}@media (max-width: 768px){.nav{padding:14px 18px}.nav .brand{font-size:15px}.hero{padding-top:88px}.hero p.lead{font-size:16px;line-height:1.55}.hero-services{gap:8px;margin-bottom:26px}.service-chip{font-size:12px;padding:7px 12px}.hero-cta{gap:12px}.hero-cta .btn{padding:13px 22px;font-size:14px}.hero-stats{gap:26px;margin-top:44px}.scroll-hint{display:none}.projects{padding:64px 0}.section-head{margin-bottom:36px}.project-card{perspective:none;margin-bottom:28px}.pc-inner{backdrop-filter:blur(12px) saturate(1.2);-webkit-backdrop-filter:blur(12px) saturate(1.2)}.pc-inner:after{display:none}.project-card .pc-grid{gap:22px}.modal-overlay{padding:14px}.modal{padding:26px 20px;max-height:90vh;overflow-y:auto}.modal-actions{gap:10px}.modal-actions .btn{min-width:100%}.audio-toggle{right:14px;bottom:14px;padding:9px 12px}}@media (max-width: 420px){.hero h1{font-size:clamp(28px,9.5vw,40px);letter-spacing:-.5px}.pc-inner{padding:22px 20px}.project-card h3{font-size:clamp(26px,8vw,34px)}.pc-tagline{font-size:15px}.chip,.service-chip{font-size:11px}}@media (prefers-reduced-motion: reduce){html{scroll-behavior:auto}.project-card:hover .pc-inner:after{animation:none}.audio-toggle.on .eq i{animation:none}}
