/* ============================================
   NextLayer — "Live Build → Expand"
   Intro builds a site, browser expands to
   become the actual site. Then everything breathes.
   ============================================ */

:root {
  --black:#000; --bg:#060608; --surface:#0a0a0f;
  --card:#0d0d15; --elevated:#12121e;
  --w:#fff;
  --w90:rgba(255,255,255,.92); --w60:rgba(255,255,255,.6);
  --w40:rgba(255,255,255,.4); --w20:rgba(255,255,255,.2);
  --w10:rgba(255,255,255,.1); --w06:rgba(255,255,255,.06);
  --w03:rgba(255,255,255,.03);
  --accent:#6366f1; --accent-b:#818cf8;
  --accent-g:rgba(99,102,241,.35);
  --font:"Helvetica Neue",Helvetica,Arial,sans-serif;
  --max-w:1280px;
  --ease:cubic-bezier(.4,0,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-spring:cubic-bezier(.34,1.56,.64,1);
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;scrollbar-width:thin;scrollbar-color:var(--w10) var(--black)}
html::-webkit-scrollbar{width:4px}
html::-webkit-scrollbar-track{background:var(--black)}
html::-webkit-scrollbar-thumb{background:var(--w10)}

body{font-family:var(--font);font-size:16px;line-height:1.7;color:var(--w60);background:var(--black);overflow-x:hidden;cursor:none}
body.locked{overflow:hidden}
@media(max-width:768px){body{cursor:auto}}

img{max-width:100%;display:block}
a{text-decoration:none;color:inherit;cursor:none}
button{cursor:none;font-family:var(--font)}
ul{list-style:none}
@media(max-width:768px){a,button{cursor:pointer}}

/* ── Cursor ── */
.cur{position:fixed;width:8px;height:8px;background:var(--w);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:difference;transition:width .3s var(--ease),height .3s var(--ease)}
.cur.a{width:56px;height:56px}
.cur-o{position:fixed;width:36px;height:36px;border:1px solid var(--w20);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:width .4s var(--ease),height .4s var(--ease),opacity .4s}
.cur-o.a{width:64px;height:64px;opacity:.2}
@media(max-width:768px){.cur,.cur-o{display:none!important}}

/* ── Layout ── */
.w{width:100%;max-width:var(--max-w);margin:0 auto;padding:0 48px}
@media(max-width:768px){.w{padding:0 24px}}

/* ── Scroll Reveal ── */
.sr{opacity:0;transform:translateY(44px);transition:opacity 1.1s var(--ease-out),transform 1.1s var(--ease-out)}
.sr.v{opacity:1;transform:translateY(0)}
.d1{transition-delay:.06s}.d2{transition-delay:.12s}.d3{transition-delay:.18s}.d4{transition-delay:.24s}

/* ── Floating / breathing animations ── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes breathe{0%,100%{opacity:.6}50%{opacity:1}}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
@keyframes drift{0%{transform:translate(0,0)}33%{transform:translate(15px,-10px)}66%{transform:translate(-10px,8px)}100%{transform:translate(0,0)}}
@keyframes textGlow{0%,100%{text-shadow:0 0 40px var(--accent-g),0 0 80px rgba(99,102,241,.1)}50%{text-shadow:0 0 60px var(--accent-g),0 0 120px rgba(99,102,241,.2)}}

/* Animated gradient line */
.grad-line{height:1px;background:linear-gradient(90deg,transparent,var(--accent-b),transparent);background-size:200% 100%;animation:shimmer 4s linear infinite;opacity:.3}


/* ============================================
   INTRO — builds site, then browser EXPANDS
   ============================================ */
.intro{
  position:fixed;inset:0;z-index:10000;
  background:var(--black);
  display:flex;align-items:center;justify-content:center;
  pointer-events:all;
}

/* Phase 2: code fades, browser expands */
.intro.expand .intro-code{opacity:0;transition:opacity .6s var(--ease)}
.intro.expand .intro-msg{opacity:0!important;transition:opacity .3s}
.intro.expand .intro-browser{
  animation:browserExpand 1.2s var(--ease-out) forwards;
}

/* Phase 3: fully gone */
.intro.done{opacity:0;visibility:hidden;pointer-events:none;transition:opacity .5s var(--ease) .1s,visibility .5s .1s}

@keyframes browserExpand{
  0%{
    width:680px;max-width:80vw;
    border-radius:14px;
    border-color:var(--w06);
  }
  60%{
    width:100vw;max-width:100vw;
    border-radius:0;
    border-color:transparent;
    transform:scale(1);
  }
  100%{
    width:100vw;max-width:100vw;
    border-radius:0;
    border-color:transparent;
    transform:scale(1.05);
    opacity:0;
  }
}

/* Code rain */
.intro-code{
  position:absolute;left:48px;top:0;bottom:0;width:420px;
  font-family:"Courier New",monospace;font-size:12px;line-height:1.6;color:var(--w10);overflow:hidden;
  mask-image:linear-gradient(to bottom,transparent,black 10%,black 90%,transparent);
  -webkit-mask-image:linear-gradient(to bottom,transparent,black 10%,black 90%,transparent);
  transition:opacity .6s;
}
.intro-code-inner{animation:codeScroll 4s linear infinite}
@keyframes codeScroll{0%{transform:translateY(0)}100%{transform:translateY(-50%)}}
.intro-code .hl{color:var(--accent-b);opacity:.4}
.intro-code .cm{color:rgba(255,255,255,.05)}

/* Browser shell */
.intro-browser{
  width:680px;max-width:80vw;
  border-radius:14px;border:1px solid var(--w06);
  background:var(--bg);overflow:hidden;
  position:relative;z-index:2;
  animation:browserIn .8s var(--ease-out) .3s both;
}
@keyframes browserIn{from{opacity:0;transform:scale(.92) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}

.intro-bar{height:36px;background:var(--w03);display:flex;align-items:center;padding:0 14px;gap:7px;border-bottom:1px solid var(--w06)}
.intro-dot{width:8px;height:8px;border-radius:50%}
.intro-dot-r{background:#ff5f57;opacity:.6}
.intro-dot-y{background:#ffbd2e;opacity:.6}
.intro-dot-g{background:#28c840;opacity:.6}

.intro-url{margin-left:16px;padding:4px 16px;background:var(--w03);border-radius:6px;font-size:11px;color:var(--w20);letter-spacing:.3px;overflow:hidden;white-space:nowrap}
.intro-url span{display:inline-block;animation:typeUrl 1.5s steps(22) .8s both;width:0;overflow:hidden}
@keyframes typeUrl{to{width:100%}}

.intro-body{padding:28px;min-height:360px;position:relative}
.intro-el{opacity:0;transform:translateY(8px);animation:elBuild .5s var(--ease-out) forwards}
.intro-el:nth-child(1){animation-delay:1.2s}
.intro-el:nth-child(2){animation-delay:1.5s}
.intro-el:nth-child(3){animation-delay:1.8s}
.intro-el:nth-child(4){animation-delay:2s}
.intro-el:nth-child(5){animation-delay:2.2s}
.intro-el:nth-child(6){animation-delay:2.4s}
.intro-el:nth-child(7){animation-delay:2.6s}
.intro-el:nth-child(8){animation-delay:2.8s}
@keyframes elBuild{to{opacity:1;transform:translateY(0)}}

.intro-line{height:6px;border-radius:3px;background:var(--w06);margin-bottom:10px}
.intro-line.acc{background:rgba(99,102,241,.15)}
.intro-line.w30{width:30%}.intro-line.w50{width:50%}.intro-line.w70{width:70%}.intro-line.w90{width:90%}
.intro-block{width:100%;height:48px;border-radius:8px;background:var(--w03);border:1px solid var(--w06);margin:16px 0}
.intro-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin:16px 0}
.intro-sq{aspect-ratio:1.2;border-radius:6px;background:var(--w03);border:1px solid var(--w06)}
.intro-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.intro-nav-logo{width:60px;height:14px;border-radius:3px;background:var(--w10)}
.intro-nav-links{display:flex;gap:16px}
.intro-nav-link{width:40px;height:6px;border-radius:3px;background:var(--w06)}

.intro-msg{position:absolute;bottom:0;left:0;right:0;text-align:center;padding:32px;opacity:0;animation:msgIn .6s var(--ease-out) 3.2s forwards}
@keyframes msgIn{to{opacity:1}}
.intro-msg-text{font-size:13px;font-weight:600;color:var(--w40);letter-spacing:3px;text-transform:uppercase}
.intro-msg-text span{color:var(--accent-b)}

.intro-progress{height:2px;background:var(--w03);position:relative;overflow:hidden}
.intro-progress-bar{height:100%;background:var(--accent);width:0;animation:progFill 3.6s var(--ease) .3s forwards;box-shadow:0 0 20px var(--accent-g)}
@keyframes progFill{to{width:100%}}


/* ============================================
   NAVIGATION
   ============================================ */
.nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:28px 0;transition:all .5s var(--ease)}
.nav.solid{padding:18px 0;background:rgba(0,0,0,.85);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px)}
.nav-i{display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:52px;filter:brightness(0) invert(1);transition:height .4s var(--ease)}
.nav.solid .nav-logo img{height:40px}
.nav-m{display:flex;align-items:center;gap:44px}
.nav-m a{font-size:12px;font-weight:500;letter-spacing:1.5px;text-transform:uppercase;color:var(--w);opacity:.5;transition:opacity .3s;position:relative}
.nav-m a:hover{opacity:1}
.nav-m a::after{content:"";position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--w);transition:width .4s var(--ease-out)}
.nav-m a:hover::after{width:100%}
.nav-btn{font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--w)!important;background:var(--accent);padding:11px 28px;border-radius:100px;border:none;transition:all .4s var(--ease);box-shadow:0 0 20px rgba(99,102,241,.25);opacity:1!important}
.nav-btn::after{display:none!important}
.nav-btn:hover{background:var(--accent-b);box-shadow:0 0 30px rgba(99,102,241,.5);transform:translateY(-1px)}
.burger{display:none;background:none;border:none;width:28px;height:20px;position:relative}
.burger span{position:absolute;left:0;width:100%;height:1.5px;background:var(--w);transition:all .3s var(--ease)}
.burger span:nth-child(1){top:0}
.burger span:nth-child(2){top:50%;transform:translateY(-50%)}
.burger span:nth-child(3){bottom:0}
.burger.on span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.burger.on span:nth-child(2){opacity:0}
.burger.on span:nth-child(3){bottom:50%;transform:translateY(50%) rotate(-45deg)}


/* ============================================
   HERO — much more alive
   ============================================ */
.hero{position:relative;min-height:100vh;display:flex;align-items:flex-end;padding:0 0 72px;overflow:hidden}

#hc{position:absolute;inset:0;width:100%;height:100%;z-index:0}

/* Floating particles layer (CSS-only) */
.hero-particles{position:absolute;inset:0;z-index:1;pointer-events:none;overflow:hidden}
.particle{position:absolute;width:2px;height:2px;background:var(--w);border-radius:50%;opacity:0}
.particle:nth-child(1){left:15%;top:20%;animation:drift 8s ease-in-out infinite,breathe 4s ease-in-out infinite;animation-delay:0s}
.particle:nth-child(2){left:70%;top:30%;animation:drift 10s ease-in-out infinite,breathe 5s ease-in-out infinite;animation-delay:-2s}
.particle:nth-child(3){left:40%;top:60%;animation:drift 12s ease-in-out infinite,breathe 6s ease-in-out infinite;animation-delay:-4s}
.particle:nth-child(4){left:85%;top:50%;animation:drift 9s ease-in-out infinite,breathe 4.5s ease-in-out infinite;animation-delay:-1s}
.particle:nth-child(5){left:25%;top:80%;animation:drift 11s ease-in-out infinite,breathe 5.5s ease-in-out infinite;animation-delay:-3s}
.particle:nth-child(6){left:55%;top:15%;animation:drift 7s ease-in-out infinite,breathe 3.5s ease-in-out infinite;animation-delay:-5s}

.hero-c{position:relative;z-index:2;width:100%}

.hero-h{
  font-size:clamp(52px,9vw,128px);
  font-weight:700;line-height:.93;
  letter-spacing:-5px;color:var(--w);
  margin-bottom:48px;
  transition:transform .15s linear;
}
.hero-h .ln{display:block;overflow:hidden}
.hero-h .lt{display:block;transform:translateY(115%);animation:hUp 1.1s var(--ease-out) forwards}
.hero-h .ln:nth-child(2) .lt{animation-delay:.1s}
.hero-h .ln:nth-child(3) .lt{animation-delay:.2s}
@keyframes hUp{to{transform:translateY(0)}}

.hero-h .ol{-webkit-text-stroke:1.5px var(--w);color:transparent}

.hero-h .gw{
  color:var(--accent-b);
  animation:textGlow 4s ease-in-out infinite;
  position:relative;
}

.hero-h .gw::after{
  content:"✦";position:absolute;top:-.2em;right:-.4em;
  font-size:.18em;color:var(--accent-b);
  animation:spin 6s linear infinite;
  -webkit-text-stroke:0;
  text-shadow:0 0 12px var(--accent-g);
}
@keyframes spin{to{transform:rotate(360deg)}}

/* Animated underline on glow word */
.hero-h .gw::before{
  content:"";position:absolute;bottom:.05em;left:0;
  width:100%;height:3px;
  background:linear-gradient(90deg,transparent,var(--accent-b),transparent);
  background-size:200% 100%;
  animation:shimmer 3s linear infinite;
  border-radius:2px;opacity:.5;
}

.hero-bot{display:flex;align-items:flex-end;justify-content:space-between;gap:48px}

.hero-p{
  font-size:17px;line-height:1.8;color:var(--w40);
  max-width:420px;
  animation:fIn 1s var(--ease-out) .4s both;
}
@keyframes fIn{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

.hero-cta{display:flex;align-items:center;gap:16px;animation:fIn 1s var(--ease-out) .55s both;flex-shrink:0}

/* Buttons */
.btn-w{
  display:inline-flex;align-items:center;gap:14px;
  padding:20px 44px;font-family:var(--font);font-size:14px;font-weight:600;
  background:var(--w);color:var(--black);border:none;border-radius:100px;
  position:relative;overflow:hidden;transition:all .5s var(--ease);
}
.btn-w .fill{position:absolute;inset:0;background:var(--accent-b);transform:translateY(102%);transition:transform .5s var(--ease-out);border-radius:100px}
.btn-w:hover .fill{transform:translateY(0)}
.btn-w:hover{color:var(--w)}
.btn-w span{position:relative;z-index:1;display:flex;align-items:center;gap:14px}
.btn-w .arr{transition:transform .4s var(--ease-spring)}
.btn-w:hover .arr{transform:translateX(6px)}

.btn-g{
  display:inline-flex;align-items:center;gap:14px;
  padding:20px 36px;font-family:var(--font);font-size:14px;font-weight:500;
  background:transparent;color:var(--w60);
  border:1px solid var(--w10);border-radius:100px;
  transition:all .4s var(--ease);
}
.btn-g:hover{color:var(--w);border-color:var(--w20);background:var(--w03)}

/* Scroll hint */
.scr-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;z-index:2;animation:fIn 1s var(--ease-out) 1.2s both}
.scr-hint span{font-size:9px;letter-spacing:3px;text-transform:uppercase;color:var(--w20)}
.scr-line{width:1px;height:48px;background:var(--w06);position:relative;overflow:hidden}
.scr-line::after{content:"";position:absolute;top:-100%;width:100%;height:50%;background:var(--w60);animation:scP 2s ease-in-out infinite}
@keyframes scP{0%{top:-50%}100%{top:150%}}


/* ============================================
   NUMBERS
   ============================================ */
.nums{padding:56px 0;border-bottom:1px solid var(--w06)}
.nums-g{display:grid;grid-template-columns:repeat(4,1fr)}
.num{text-align:center;padding:20px;position:relative}
.num:not(:last-child)::after{content:"";position:absolute;right:0;top:20%;bottom:20%;width:1px;background:var(--w06)}
.num-v{font-size:clamp(36px,4vw,52px);font-weight:700;color:var(--w);letter-spacing:-2px;line-height:1;margin-bottom:8px}
.num-l{font-size:11px;font-weight:500;letter-spacing:2px;text-transform:uppercase;color:var(--w20)}


/* ============================================
   SERVICES
   ============================================ */
.svc{padding:160px 0;position:relative}

/* Ambient side glow */
.svc::before{
  content:"";position:absolute;
  top:20%;right:-200px;width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(99,102,241,.06),transparent 70%);
  animation:drift 15s ease-in-out infinite;
  pointer-events:none;
}

.svc-top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:80px}
.svc-h{font-size:clamp(36px,4.5vw,60px);font-weight:700;letter-spacing:-2px;color:var(--w);line-height:1.05;max-width:600px}
.svc-sub{font-size:15px;color:var(--w20);max-width:340px;text-align:right;line-height:1.8}

.svc-row{
  display:grid;grid-template-columns:56px 1fr 1fr;
  gap:40px;align-items:center;padding:44px 0;
  border-top:1px solid var(--w06);
  transition:all .5s var(--ease);position:relative;
}
.svc-row:last-child{border-bottom:1px solid var(--w06)}
.svc-row::before{content:"";position:absolute;left:-48px;right:-48px;top:0;bottom:0;background:var(--w03);opacity:0;transition:opacity .5s;pointer-events:none}
.svc-row:hover::before{opacity:1}
.svc-row:hover{padding-left:16px}

.svc-n{font-size:13px;font-weight:600;color:var(--w10);letter-spacing:1px;transition:color .4s}
.svc-row:hover .svc-n{color:var(--accent-b)}

.svc-name{font-size:clamp(24px,3vw,38px);font-weight:700;color:var(--w);letter-spacing:-1px;transition:transform .5s var(--ease-out)}
.svc-row:hover .svc-name{transform:translateX(8px)}

.svc-desc{font-size:15px;color:var(--w20);line-height:1.7;transition:color .4s}
.svc-row:hover .svc-desc{color:var(--w40)}

/* Accent dot appears on hover */
.svc-row::after{
  content:"";position:absolute;right:48px;top:50%;
  width:6px;height:6px;border-radius:50%;
  background:var(--accent-b);
  transform:translateY(-50%) scale(0);
  transition:transform .4s var(--ease-spring);
}
.svc-row:hover::after{transform:translateY(-50%) scale(1)}


/* ============================================
   WHY
   ============================================ */
.why{padding:160px 0;background:var(--surface);position:relative;overflow:hidden}

/* Floating accent orb */
.why::before{
  content:"";position:absolute;
  bottom:-100px;left:-100px;width:350px;height:350px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(99,102,241,.08),transparent 70%);
  animation:drift 20s ease-in-out infinite;
  pointer-events:none;
}

.why-hd{max-width:680px;margin-bottom:80px}
.why-hd .svc-h{margin-bottom:24px}
.why-d{font-size:17px;color:var(--w20);line-height:1.8}

.why-g{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--w06);border-radius:20px;overflow:hidden}

.why-c{background:var(--bg);padding:52px 36px;position:relative;overflow:hidden;transition:all .5s var(--ease)}
.why-c::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 50% 120%,var(--accent-g),transparent 70%);opacity:0;transition:opacity .6s var(--ease);pointer-events:none}
.why-c:hover{background:var(--card)}
.why-c:hover::after{opacity:1}

.why-ic{width:48px;height:48px;border:1px solid var(--w06);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:32px;transition:all .4s var(--ease)}
.why-c:hover .why-ic{border-color:var(--accent-b);box-shadow:0 0 24px var(--accent-g)}
.why-ic svg{width:22px;height:22px;stroke:var(--w20);stroke-width:1.5;fill:none;transition:stroke .4s}
.why-c:hover .why-ic svg{stroke:var(--accent-b)}

.why-c h3{font-size:18px;font-weight:700;color:var(--w);letter-spacing:-.3px;margin-bottom:12px}
.why-c p{font-size:14px;color:var(--w20);line-height:1.7;transition:color .4s}
.why-c:hover p{color:var(--w40)}


/* ============================================
   PORTFOLIO
   ============================================ */
.pf{padding:160px 0;position:relative}
.pf-hd{margin-bottom:72px}
.pf-hd .svc-h{margin-bottom:16px}
.pf-sub{font-size:16px;color:var(--w20);max-width:480px}

.pf-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px}
.pf-card{border-radius:16px;overflow:hidden;background:var(--surface);border:1px solid var(--w03);position:relative;transition:all .6s var(--ease)}
.pf-card:hover{border-color:var(--w06)}
.pf-card.big{grid-column:1/-1}

.pf-sc{width:100%;aspect-ratio:16/9;background:var(--bg);position:relative;overflow:hidden}
.pf-card.big .pf-sc{aspect-ratio:21/9}

.pf-br{position:absolute;inset:20px;border-radius:10px;background:var(--card);border:1px solid var(--w03);overflow:hidden;transition:transform .8s var(--ease-out)}
.pf-card:hover .pf-br{transform:scale(1.015)}

.pf-bbar{height:28px;background:var(--w03);display:flex;align-items:center;padding:0 12px;gap:6px;border-bottom:1px solid var(--w03)}
.pf-d{width:7px;height:7px;border-radius:50%}
.pf-d-r{background:#ff5f57;opacity:.6}.pf-d-y{background:#ffbd2e;opacity:.6}.pf-d-g{background:#28c840;opacity:.6}
.pf-url{margin-left:14px;padding:2px 12px;background:var(--w03);border-radius:4px;font-size:10px;color:var(--w20)}

.pf-wf{padding:18px}
.pf-wl{height:5px;border-radius:2px;background:var(--w03);margin-bottom:8px}
.pf-wl.ac{background:rgba(99,102,241,.12)}
.pf-wl.w30{width:30%}.pf-wl.w50{width:50%}.pf-wl.w70{width:70%}.pf-wl.w90{width:90%}
.pf-wb{width:100%;height:40px;border-radius:6px;background:var(--w03);margin:14px 0;border:1px solid var(--w03)}
.pf-wg{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-top:12px}
.pf-ws{aspect-ratio:1;border-radius:6px;background:var(--w03);border:1px solid var(--w03)}

.pf-info{padding:28px 32px;display:flex;justify-content:space-between;align-items:center}
.pf-tag{font-size:10px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent-b);margin-bottom:4px}
.pf-info h3{font-size:18px;font-weight:700;color:var(--w);letter-spacing:-.3px}
.pf-info p{font-size:13px;color:var(--w20);margin-top:2px}

.pf-lk{width:44px;height:44px;border-radius:50%;border:1px solid var(--w06);display:flex;align-items:center;justify-content:center;transition:all .4s var(--ease);flex-shrink:0}
.pf-lk:hover{background:var(--w);border-color:var(--w)}
.pf-lk svg{width:16px;height:16px;stroke:var(--w40);stroke-width:2;fill:none;transition:stroke .3s}
.pf-lk:hover svg{stroke:var(--black)}


/* ============================================
   TESTIMONIALS
   ============================================ */
.tst{padding:160px 0;background:var(--surface)}
.tst-hd{text-align:center;margin-bottom:80px}
.tst-hd .svc-h{margin-bottom:16px}
.tst-sub{font-size:16px;color:var(--w20)}

.tst-g{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--w06);border-radius:20px;overflow:hidden}
.tst-c{background:var(--bg);padding:48px 40px;transition:background .5s var(--ease);position:relative}
.tst-c:hover{background:var(--card)}
.tst-q{font-size:72px;font-weight:700;color:var(--w06);line-height:.8;margin-bottom:20px;transition:color .4s}
.tst-c:hover .tst-q{color:var(--accent-g)}
.tst-txt{font-size:15px;line-height:1.8;color:var(--w60);margin-bottom:36px;font-style:italic}
.tst-a{display:flex;align-items:center;gap:14px}
.tst-av{width:40px;height:40px;border-radius:50%;background:var(--elevated);border:1px solid var(--w06);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--w40)}
.tst-nm{font-size:14px;font-weight:600;color:var(--w)}
.tst-rl{font-size:12px;color:var(--w20)}


/* ============================================
   CTA
   ============================================ */
.cta{padding:200px 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;top:50%;left:50%;width:600px;height:600px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,var(--accent-g),transparent 70%);pointer-events:none;opacity:.6;animation:breathe 6s ease-in-out infinite}
.cta-h{font-size:clamp(40px,6vw,80px);font-weight:700;letter-spacing:-3px;color:var(--w);line-height:1.05;margin-bottom:24px;position:relative;z-index:2}
.cta-p{font-size:18px;color:var(--w20);max-width:480px;margin:0 auto 48px;line-height:1.7;position:relative;z-index:2}
.cta-btns{display:flex;justify-content:center;gap:16px;position:relative;z-index:2}
.cta-note{margin-top:28px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--w10);position:relative;z-index:2}


/* ============================================
   FOOTER
   ============================================ */
.ft{padding:72px 0 40px;border-top:1px solid var(--w06)}
.ft-g{display:grid;grid-template-columns:2.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:64px}
.ft-br img{height:30px;filter:brightness(0) invert(1);margin-bottom:20px}
.ft-br-t{font-size:14px;color:var(--w20);line-height:1.7;max-width:280px}
.ft-col h5{font-size:10px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--w10);margin-bottom:24px}
.ft-col a{display:block;font-size:14px;color:var(--w20);margin-bottom:14px;transition:all .3s}
.ft-col a:hover{color:var(--w);transform:translateX(4px)}
.ft-bot{display:flex;align-items:center;justify-content:space-between;padding-top:32px;border-top:1px solid var(--w06)}
.ft-cp{font-size:12px;color:var(--w10);letter-spacing:.5px}
.ft-soc{display:flex;gap:8px}
.ft-soc a{width:36px;height:36px;border-radius:50%;border:1px solid var(--w06);display:flex;align-items:center;justify-content:center;transition:all .3s var(--ease)}
.ft-soc a:hover{border-color:var(--w20);background:var(--w03)}
.ft-soc svg{width:14px;height:14px;fill:var(--w20);transition:fill .3s}
.ft-soc a:hover svg{fill:var(--w)}


/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .svc-top{flex-direction:column;align-items:flex-start;gap:24px}.svc-sub{text-align:left}
  .svc-row{grid-template-columns:40px 1fr}.svc-desc{display:none}.svc-row::after{display:none}
  .why-g{grid-template-columns:1fr 1fr}
  .pf-row{grid-template-columns:1fr}.pf-card.big{grid-column:auto}
  .tst-g{grid-template-columns:1fr 1fr}
  .ft-g{grid-template-columns:1fr 1fr}
  .intro-code{display:none}.intro-browser{max-width:90vw}
}

@media(max-width:768px){
  .nav-m{position:fixed;top:0;right:-100%;width:80%;max-width:320px;height:100vh;background:var(--bg);flex-direction:column;align-items:flex-start;justify-content:center;padding:48px 40px;gap:32px;transition:right .5s var(--ease-out);box-shadow:-40px 0 80px rgba(0,0,0,.8);z-index:1001;border-left:1px solid var(--w06)}
  .nav-m.on{right:0}
  .nav-m a{font-size:18px;letter-spacing:0;text-transform:none;opacity:.7}
  .nav-btn{display:inline-flex}.burger{display:block}
  .mob-ov{position:fixed;inset:0;background:rgba(0,0,0,.7);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:all .4s;z-index:999}
  .mob-ov.vis{opacity:1;visibility:visible}

  .hero{min-height:auto;padding:140px 0 60px}.hero-h{letter-spacing:-2px}
  .hero-bot{flex-direction:column;align-items:flex-start;gap:32px}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .nums-g{grid-template-columns:1fr 1fr}.num:nth-child(2)::after{display:none}
  .svc,.why,.pf,.tst{padding:100px 0}.cta{padding:120px 0}
  .svc-row{grid-template-columns:1fr;gap:12px;padding:32px 0}.svc-desc{display:block}
  .why-g,.tst-g{grid-template-columns:1fr}
  .cta-btns{flex-direction:column;align-items:center}
  .ft-g{grid-template-columns:1fr;gap:32px}
  .ft-bot{flex-direction:column;gap:20px;text-align:center}
  .intro-body{min-height:240px}.intro-cols{grid-template-columns:1fr 1fr}
}

@media(max-width:400px){
  .hero-h{font-size:38px;letter-spacing:-1.5px}
  .btn-w,.btn-g{width:100%;justify-content:center}
}
