/* ===================== DESIGN TOKENS ===================== */
:root {
  color-scheme: dark;
  --bg:     #07090f;
  --bg2:    #0c0f1a;
  --bg3:    #111520;
  --sf:     rgba(255,255,255,0.035);
  --sf2:    rgba(255,255,255,0.065);
  --bd:     rgba(255,255,255,0.07);
  --bd2:    rgba(255,255,255,0.13);
  --tx:     #e4e8f0;
  --tx2:    #7e8a9e;
  --tx3:    #424d60;
  --ac:     #7c6af7;
  --ac2:    #a595ff;
  --glow:   rgba(124,106,247,0.22);
  --glow2:  rgba(124,106,247,0.45);
  --gr:     #34d399;
  --cy:     #22d3ee;
  --pk:     #f472b6;
  --am:     #fbbf24;
  --fn:     'Space Grotesk', sans-serif;
  --mo:     'JetBrains Mono', monospace;
  --r:      12px;
  --rl:     18px;
  /* theme-aware surfaces */
  --nav-bg:    rgba(7,9,15,0.82);
  --nav-bg-sc: rgba(7,9,15,0.96);
  --grid:      rgba(124,106,247,0.022);
  --shadow:    rgba(0,0,0,0.4);
}

/* ===================== LIGHT THEME ===================== */
html[data-theme="light"] {
  color-scheme: light;
  --bg:     #f6f7fb;
  --bg2:    #ffffff;
  --bg3:    #eef0f7;
  --sf:     rgba(17,22,38,0.025);
  --sf2:    rgba(17,22,38,0.055);
  --bd:     rgba(17,24,45,0.10);
  --bd2:    rgba(17,24,45,0.17);
  --tx:     #161c2c;
  --tx2:    #52607a;
  --tx3:    #8a95aa;
  --ac:     #6a54ef;
  --ac2:    #8470ff;
  --glow:   rgba(106,84,239,0.16);
  --glow2:  rgba(106,84,239,0.30);
  --nav-bg:    rgba(255,255,255,0.82);
  --nav-bg-sc: rgba(255,255,255,0.95);
  --grid:      rgba(106,84,239,0.04);
  --shadow:    rgba(15,23,42,0.10);
}

*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background:var(--bg); color:var(--tx);
  font-family:var(--fn); line-height:1.65;
  overflow-x:hidden; -webkit-font-smoothing:antialiased;
  transition:background .3s ease,color .3s ease;
}
body::before {
  content:''; position:fixed; inset:0;
  background-image:
    linear-gradient(var(--grid) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid) 1px,transparent 1px);
  background-size:64px 64px; pointer-events:none; z-index:0;
}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--ac);border-radius:2px}

/* Orbs */
.orb{position:fixed;border-radius:50%;filter:blur(90px);pointer-events:none;z-index:0}
.orb1{width:600px;height:600px;background:rgba(124,106,247,0.09);top:-150px;right:-150px}
.orb2{width:450px;height:450px;background:rgba(34,211,238,0.05);bottom:25%;left:-120px}
.orb3{width:300px;height:300px;background:rgba(244,114,182,0.035);top:60%;right:10%}

section{position:relative;z-index:1}
.container{max-width:1180px;margin:0 auto;padding:0 5%}
.sp{padding:100px 0}
.sh{text-align:center;margin-bottom:56px}
.sr{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:40px;flex-wrap:wrap;gap:12px}

/* Labels */
.lbl{display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--ac);font-family:var(--mo);letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.lbl::before{content:'●';font-size:7px}
.stitle{font-size:clamp(26px,3vw,40px);font-weight:700;margin-bottom:14px;line-height:1.15}
.sdesc{font-size:15px;color:var(--tx2);line-height:1.8}
.va{font-size:13px;color:var(--ac);text-decoration:none;display:inline-flex;align-items:center;gap:5px;transition:gap .2s}
.va:hover{gap:10px}

/* BUTTONS */
.bp{display:inline-flex;align-items:center;gap:8px;background:var(--ac);color:#fff;border:none;padding:13px 28px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--fn);text-decoration:none;transition:all .25s;box-shadow:0 0 24px var(--glow),0 4px 16px rgba(0,0,0,.3)}
.bp:hover{background:var(--ac2);transform:translateY(-2px);box-shadow:0 0 40px var(--glow2)}
.bs{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--tx);border:1px solid var(--bd2);padding:13px 28px;border-radius:var(--r);font-size:14px;font-weight:500;cursor:pointer;font-family:var(--fn);text-decoration:none;transition:all .25s}
.bs:hover{border-color:var(--ac);color:var(--ac);background:rgba(124,106,247,.08)}
.bg2{display:inline-flex;align-items:center;gap:8px;background:var(--sf2);color:var(--tx2);border:1px solid var(--bd);padding:10px 20px;border-radius:var(--r);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--fn);text-decoration:none;transition:all .2s}
.bg2:hover{border-color:var(--bd2);color:var(--tx)}

/* NAV */
.nav-bar{position:fixed;top:0;left:0;right:0;z-index:200;height:64px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;background:var(--nav-bg);backdrop-filter:blur(24px) saturate(160%);border-bottom:1px solid var(--bd);transition:all .3s}
.nav-bar.scrolled{background:var(--nav-bg-sc);border-color:var(--bd2)}
.logo{font-family:var(--mo);font-weight:700;font-size:17px;color:var(--tx);text-decoration:none}
.logo span{color:var(--ac)}
.nl{display:flex;gap:2px;align-items:center}
.nl a{color:var(--tx2);text-decoration:none;font-size:13px;padding:7px 13px;border-radius:8px;transition:all .2s}
.nl a:hover,.nl a.active{color:var(--tx);background:var(--sf2)}
.nh{background:var(--ac);color:#fff;border:none;padding:8px 20px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--fn);transition:all .2s;box-shadow:0 0 16px var(--glow);text-decoration:none}
.nh:hover{background:var(--ac2);box-shadow:0 0 28px var(--glow2)}
/* THEME TOGGLE (desktop) */
.theme-toggle{position:relative;width:38px;height:38px;border-radius:50%;border:1px solid var(--bd2);background:var(--sf);color:var(--tx2);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color .2s,background .2s,color .2s,transform .2s;flex-shrink:0;padding:0;overflow:hidden}
.theme-toggle:hover{border-color:var(--ac);color:var(--ac);background:rgba(124,106,247,.1);transform:translateY(-1px)}
.theme-toggle:active{transform:scale(.92)}
.theme-toggle svg{position:absolute;width:18px;height:18px;transition:transform .45s cubic-bezier(.5,1.4,.5,1),opacity .3s ease}
.theme-toggle .icon-moon{opacity:1;transform:rotate(0) scale(1)}
.theme-toggle .icon-sun{opacity:0;transform:rotate(-90deg) scale(.3)}
html[data-theme="light"] .theme-toggle .icon-moon{opacity:0;transform:rotate(90deg) scale(.3)}
html[data-theme="light"] .theme-toggle .icon-sun{opacity:1;transform:rotate(0) scale(1)}

/* THEME TOGGLE (mobile menu) */
.theme-toggle-mm{display:flex;align-items:center;gap:12px;width:100%;justify-content:flex-start;color:var(--tx2);text-decoration:none;font-size:15px;padding:12px 16px;border-radius:10px;background:none;border:none;cursor:pointer;font-family:var(--fn);transition:all .2s}
.theme-toggle-mm:hover{color:var(--tx);background:var(--sf2)}
.theme-toggle-mm svg{width:18px;height:18px;flex-shrink:0}
.theme-toggle-mm .icon-sun{display:none}
.theme-toggle-mm .icon-moon{display:inline-block}
html[data-theme="light"] .theme-toggle-mm .icon-sun{display:inline-block}
html[data-theme="light"] .theme-toggle-mm .icon-moon{display:none}
.hb{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hb span{width:22px;height:2px;background:var(--tx);border-radius:2px;transition:all .3s;display:block}
.hb.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hb.open span:nth-child(2){opacity:0}
.hb.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.mm{position:fixed;top:64px;left:0;right:0;z-index:199;background:var(--nav-bg-sc);backdrop-filter:blur(24px);border-bottom:1px solid var(--bd);padding:20px 5%;transform:translateY(-110%);opacity:0;transition:all .35s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:4px}
.mm.open{transform:translateY(0);opacity:1}
.mm a{color:var(--tx2);text-decoration:none;font-size:15px;padding:12px 16px;border-radius:10px;transition:all .2s}
.mm a:hover{color:var(--tx);background:var(--sf2)}

/* HERO */
#hero{min-height:100vh;display:flex;align-items:center;padding-top:64px;overflow:hidden}
.hg{display:grid;grid-template-columns:1fr 460px;gap:60px;align-items:center;width:100%;padding:60px 0}
.hey{display:inline-flex;align-items:center;gap:8px;font-size:13px;color:var(--tx2);font-family:var(--mo);background:var(--sf);border:1px solid var(--bd);padding:6px 14px;border-radius:20px;margin-bottom:20px}
.dg{width:7px;height:7px;border-radius:50%;background:var(--gr);box-shadow:0 0 8px var(--gr);animation:pg 2s infinite}
@keyframes pg{0%,100%{box-shadow:0 0 6px var(--gr)}50%{box-shadow:0 0 14px var(--gr),0 0 20px rgba(52,211,153,.3)}}
.hname{font-size:clamp(40px,5.5vw,66px);font-weight:700;line-height:1.05;margin-bottom:14px}
.hname .ag{background:linear-gradient(135deg,var(--ac),var(--cy));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hsub{font-size:18px;color:var(--tx2);margin-bottom:18px;font-weight:400}
.hdesc{font-size:15px;color:var(--tx3);line-height:1.8;margin-bottom:30px;max-width:500px}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:34px}
.pill{display:inline-flex;align-items:center;gap:7px;padding:5px 13px;border-radius:20px;border:1px solid var(--bd2);background:var(--sf);font-size:12px;color:var(--tx2);font-family:var(--mo);transition:all .2s}
.pill:hover{border-color:var(--ac);color:var(--ac2)}
.pd{width:6px;height:6px;border-radius:50%}
.hbtns{display:flex;gap:12px;margin-bottom:44px;flex-wrap:wrap}
.hstats{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;background:var(--sf)}
.si{padding:18px 12px;text-align:center;border-right:1px solid var(--bd);transition:background .2s}
.si:last-child{border-right:none}
.si:hover{background:var(--sf2)}
.sn{font-size:26px;font-weight:700;color:var(--ac);font-family:var(--mo);line-height:1;display:block}
.sl{font-size:11px;color:var(--tx3);margin-top:4px}

/* Hero right */
.hr{position:relative;display:flex;flex-direction:column;gap:14px}
.avf{display:flex;align-items:center;gap:12px;background:var(--bg2);border:1px solid var(--bd2);border-radius:var(--r);padding:14px 18px;box-shadow:0 4px 24px rgba(0,0,0,.4);position:absolute;top:-16px;right:0;z-index:2}
.avd{width:9px;height:9px;border-radius:50%;background:var(--gr);box-shadow:0 0 8px var(--gr);flex-shrink:0;animation:pg 2s infinite}
.avt{font-size:13px;font-weight:600}
.avs{font-size:11px;color:var(--tx3)}
.fbs{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}
.fb{background:var(--bg2);border:1px solid var(--bd);border-radius:10px;padding:10px 14px;font-family:var(--mo);font-size:13px;color:var(--tx2);animation:fl 3s ease-in-out infinite;transition:all .2s}
.fb:hover{border-color:var(--ac);color:var(--ac)}
.fb:nth-child(2){animation-delay:.5s}.fb:nth-child(3){animation-delay:1s}.fb:nth-child(4){animation-delay:1.5s}
@keyframes fl{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}
.sd{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;color:var(--tx3);font-size:11px;letter-spacing:.08em;text-transform:uppercase;font-family:var(--mo)}
.sr2{width:36px;height:36px;border-radius:50%;border:1px solid var(--bd2);display:flex;align-items:center;justify-content:center;font-size:16px;animation:bd 2s infinite}
@keyframes bd{0%,100%{transform:translateY(0)}50%{transform:translateY(5px)}}

/* TERMINAL */
.term{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);overflow:hidden;font-family:var(--mo);box-shadow:0 8px 40px rgba(0,0,0,.4)}
.tb2{display:flex;align-items:center;gap:7px;padding:12px 16px;border-bottom:1px solid var(--bd);background:rgba(255,255,255,.02)}
.tc{width:11px;height:11px;border-radius:50%}
.tc-r{background:#ff5f57}.tc-y{background:#febc2e}.tc-g{background:#28c840}
.tl2{font-size:11px;color:var(--tx3);margin-left:auto}
.tbody{padding:22px;font-size:13px;line-height:2.1}
.tpr{color:var(--ac2);margin-right:8px}
.tcm{color:var(--tx)}
.tog{color:var(--gr);display:block}
.toc{color:var(--cy);display:block}
.cur{display:inline-block;width:8px;height:15px;background:var(--ac);border-radius:1px;animation:bl 1s step-end infinite;vertical-align:-2px}
@keyframes bl{0%,100%{opacity:1}50%{opacity:0}}

/* ABOUT */
.ag2{display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center}
.acb{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);padding:28px;font-family:var(--mo);font-size:12.5px;line-height:2;box-shadow:0 8px 32px rgba(0,0,0,.35)}
.cc{color:var(--tx3)}.ck{color:var(--cy)}.cs{color:var(--gr)}.ca{color:var(--ac2)}.cbr{color:var(--tx2)}
.sbr{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}
.skb{display:inline-flex;align-items:center;gap:8px;padding:7px 14px;border-radius:8px;background:var(--sf);border:1px solid var(--bd);font-size:12px;color:var(--tx2);transition:all .2s}
.skb:hover{border-color:var(--ac);color:var(--ac2);background:rgba(124,106,247,.08)}

/* SKILLS */
.skg{display:grid;grid-template-columns:repeat(6,1fr);gap:12px;margin-top:40px}
.skc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--r);padding:20px 12px;text-align:center;transition:all .3s;cursor:default;position:relative;overflow:hidden}
.skc:hover{border-color:var(--ac);transform:translateY(-4px);box-shadow:0 8px 24px rgba(124,106,247,.12)}
.ski{font-size:28px;margin-bottom:10px;display:block}
.skn{font-size:11px;font-weight:600;color:var(--tx);margin-bottom:4px}
.sklv{font-size:10px;color:var(--tx3);font-family:var(--mo)}
.skbar{height:2px;background:var(--bd);border-radius:2px;margin-top:8px;overflow:hidden}
.skfill{height:100%;background:linear-gradient(90deg,var(--ac),var(--cy));border-radius:2px;width:0;transition:width 1.2s ease}

/* SERVICES */
.svg{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-top:48px}
.svc{background:var(--sf);border:1px solid var(--bd);border-radius:var(--rl);padding:28px 18px;text-align:center;transition:all .3s;cursor:pointer;position:relative;overflow:hidden}
.svc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ac),var(--cy));transform:scaleX(0);transition:transform .3s;transform-origin:left}
.svc:hover{border-color:rgba(124,106,247,.4);transform:translateY(-6px);box-shadow:0 16px 40px rgba(124,106,247,.1)}
.svc:hover::after{transform:scaleX(1)}
.svci{width:52px;height:52px;border-radius:14px;background:rgba(124,106,247,.1);border:1px solid rgba(124,106,247,.2);display:flex;align-items:center;justify-content:center;margin:0 auto 18px;font-size:24px;transition:all .3s}
.svc:hover .svci{background:rgba(124,106,247,.2);transform:scale(1.05)}
.svcn{font-size:13px;font-weight:600;margin-bottom:10px}
.svcd{font-size:11px;color:var(--tx3);line-height:1.65}

/* EXPERIENCE */
.exg{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.tli{display:flex;gap:20px;position:relative}
.tll{display:flex;flex-direction:column;align-items:center}
.tldot{width:12px;height:12px;border-radius:50%;background:var(--ac);border:2px solid var(--bg);box-shadow:0 0 10px var(--glow);flex-shrink:0;margin-top:4px}
.tlln{width:1px;flex:1;background:var(--bd);margin:6px 0}
.tli:last-child .tlln{display:none}
.tlc{padding-bottom:32px;flex:1}
.tlr{font-size:14px;font-weight:600;margin-bottom:4px}
.tlco{font-size:13px;color:var(--ac2);margin-bottom:4px}
.tld{font-size:11px;color:var(--tx3);font-family:var(--mo);margin-bottom:10px}
.tldsc{font-size:13px;color:var(--tx2);line-height:1.7}
.certg{display:flex;flex-direction:column;gap:14px}
.certc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:18px 20px;display:flex;align-items:center;gap:16px;transition:all .2s}
.certc:hover{border-color:var(--bd2);transform:translateX(4px)}
.certn{font-size:13px;font-weight:600;margin-bottom:3px}
.certi{font-size:11px;color:var(--tx3);font-family:var(--mo)}

/* PRICING */
.prg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:920px;margin:0 auto}
.prc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);padding:32px 28px;position:relative;transition:all .3s}
.prc:hover{transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.3)}
.prc.feat{border-color:rgba(124,106,247,.5);background:linear-gradient(160deg,rgba(124,106,247,.08),rgba(34,211,238,.04),var(--bg2));box-shadow:0 0 40px rgba(124,106,247,.12)}
.pp2{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(90deg,var(--ac),var(--cy));color:#fff;font-size:10px;font-weight:700;padding:4px 18px;border-radius:20px;letter-spacing:.05em;white-space:nowrap}
.prpl{font-size:15px;font-weight:700;margin-bottom:4px}
.prsb{font-size:12px;color:var(--tx3);margin-bottom:22px}
.prpr{font-size:42px;font-weight:700;font-family:var(--mo);line-height:1;margin-bottom:4px}
.prpr .pru{font-size:14px;color:var(--tx3);font-weight:400;font-family:var(--fn)}
.prdv{height:1px;background:var(--bd);margin:22px 0}
.prft{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:28px}
.prft li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--tx2)}
.prch{color:var(--gr);font-size:15px;flex-shrink:0}
.prb{width:100%;padding:13px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--fn);transition:all .2s;border:none;text-align:center;display:block;text-decoration:none}
.prb.ol{background:transparent;border:1px solid var(--bd2);color:var(--tx)}
.prb.ol:hover{border-color:var(--ac);color:var(--ac);background:rgba(124,106,247,.07)}
.prb.sl2{background:var(--ac);color:#fff;box-shadow:0 0 20px var(--glow)}
.prb.sl2:hover{background:var(--ac2);box-shadow:0 0 32px var(--glow2)}

/* PROJECTS */
.pjg{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pjc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);overflow:hidden;transition:all .3s;cursor:pointer;display:block;text-decoration:none;color:inherit}
.pjc:hover{border-color:rgba(124,106,247,.4);transform:translateY(-5px);box-shadow:0 20px 40px rgba(0,0,0,.3)}
.pjt{height:130px;display:flex;align-items:center;justify-content:center;font-size:36px;position:relative;overflow:hidden}
.pt1{background:linear-gradient(135deg,#1a0533,#2d1b69,#0d0a1a)}
.pt2{background:linear-gradient(135deg,#0d1f3c,#183660,#050f1e)}
.pt3{background:linear-gradient(135deg,#0d2a0d,#1a5c1a,#050e05)}
.pt4{background:linear-gradient(135deg,#2d0d1a,#5c1a33,#1a050d)}
.pjb{padding:18px}
.pjn{font-size:13px;font-weight:600;margin-bottom:7px}
.pjd{font-size:11px;color:var(--tx3);margin-bottom:14px;line-height:1.6}
.ttgs{display:flex;flex-wrap:wrap;gap:5px}
.ttg{font-size:10px;padding:3px 8px;border-radius:4px;background:rgba(124,106,247,.1);color:var(--ac2);font-family:var(--mo);border:1px solid rgba(124,106,247,.15)}
.pjlk{display:flex;gap:8px;margin-top:12px}
.pjl{font-size:11px;padding:4px 10px;border-radius:6px;border:1px solid var(--bd);color:var(--tx3);text-decoration:none;transition:all .2s}
.pjl:hover{border-color:var(--ac);color:var(--ac)}

/* PRODUCTS */
.pdg{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.pdc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);overflow:hidden;transition:all .3s;cursor:pointer}
.pdc:hover{border-color:rgba(124,106,247,.4);transform:translateY(-5px);box-shadow:0 16px 36px rgba(0,0,0,.3)}
.pdcv{height:105px;display:flex;align-items:center;justify-content:center;font-size:38px}
.pc1{background:linear-gradient(135deg,#1a0a2e,#3d1a6e)}
.pc2{background:linear-gradient(135deg,#0a1a2e,#1a3a6e)}
.pc3{background:linear-gradient(135deg,#0a2e0a,#1a6e1a)}
.pc4{background:linear-gradient(135deg,#2e1a0a,#6e3d0a)}
.pc5{background:linear-gradient(135deg,#1a0a1a,#5c1a5c)}
.pdb{padding:16px}
.pdn{font-size:12px;font-weight:600;margin-bottom:4px;line-height:1.4}
.pdt{font-size:10px;color:var(--tx3);margin-bottom:14px}
.pdf{display:flex;align-items:center;justify-content:space-between}
.pdp{font-size:18px;font-weight:700;font-family:var(--mo)}
.buyb{font-size:11px;padding:6px 13px;border-radius:7px;background:var(--ac);color:#fff;border:none;cursor:pointer;font-family:var(--fn);font-weight:600;transition:all .2s;text-decoration:none;display:inline-block}
.buyb:hover{background:var(--ac2);transform:scale(1.04)}

/* TESTIMONIALS */
.testg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:48px}
.testc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);padding:28px;transition:all .3s}
.testc:hover{border-color:var(--bd2);transform:translateY(-3px)}
.testq{font-size:36px;color:var(--ac);line-height:1;margin-bottom:12px;opacity:.4}
.tsts{color:var(--am);font-size:13px;letter-spacing:2px;margin-bottom:14px}
.testt{font-size:13px;color:var(--tx2);line-height:1.75;margin-bottom:20px;font-style:italic}
.testa{display:flex;align-items:center;gap:12px}
.testav{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.testn{font-size:13px;font-weight:600}
.testl{font-size:11px;color:var(--tx3)}

/* BLOG */
.blg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:16px}
.blc{background:var(--bg2);border:1px solid var(--bd);border-radius:var(--rl);overflow:hidden;transition:all .3s;cursor:pointer;text-decoration:none;color:inherit;display:block}
.blc:hover{border-color:rgba(124,106,247,.35);transform:translateY(-4px);box-shadow:0 16px 36px rgba(0,0,0,.3)}
.blcv{height:140px;display:flex;align-items:center;justify-content:center;font-size:42px}
.bc1{background:linear-gradient(135deg,#1a0d33,#2d1a5c)}
.bc2{background:linear-gradient(135deg,#0d1a0d,#1a3d1a)}
.bc3{background:linear-gradient(135deg,#1a0d0d,#3d1a0d)}
.blb{padding:20px}
.blm{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}
.blcat{font-size:10px;padding:3px 10px;border-radius:20px;background:rgba(124,106,247,.12);color:var(--ac2);font-weight:600;letter-spacing:.04em}
.bldt{font-size:11px;color:var(--tx3);font-family:var(--mo)}
.blti{font-size:14px;font-weight:600;margin-bottom:8px;line-height:1.5}
.blex{font-size:12px;color:var(--tx3);line-height:1.65;margin-bottom:16px}
.blrd{font-size:12px;color:var(--ac);display:flex;align-items:center;gap:5px}

/* CONTACT */
.cg{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.cinfo{display:flex;flex-direction:column;gap:14px}
.cit{display:flex;align-items:center;gap:16px;background:var(--bg2);border:1px solid var(--bd);border-radius:var(--r);padding:18px 20px;transition:all .2s}
.cit:hover{border-color:var(--bd2);transform:translateX(4px)}
.cii{width:42px;height:42px;border-radius:10px;background:rgba(124,106,247,.1);border:1px solid rgba(124,106,247,.2);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.cil{font-size:11px;color:var(--tx3);margin-bottom:3px}
.civ{font-size:14px;font-weight:500}
.cf{display:flex;flex-direction:column;gap:14px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.fg{display:flex;flex-direction:column;gap:6px}
.flbl{font-size:12px;color:var(--tx2);font-weight:500}
.fi,.fta{background:var(--bg2);border:1px solid var(--bd);border-radius:10px;padding:13px 16px;font-size:14px;color:var(--tx);font-family:var(--fn);outline:none;transition:all .2s;resize:none;width:100%}
.fi:focus,.fta:focus{border-color:var(--ac);box-shadow:0 0 0 3px rgba(124,106,247,.12)}
.fi::placeholder,.fta::placeholder{color:var(--tx3)}
.fta{min-height:120px}
.fsub{background:linear-gradient(135deg,var(--ac),#6254d8);color:#fff;border:none;padding:14px 28px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--fn);transition:all .2s;display:flex;align-items:center;gap:8px;justify-content:center;box-shadow:0 0 24px var(--glow);width:100%}
.fsub:hover{transform:translateY(-2px);box-shadow:0 0 40px var(--glow2)}

/* CTA */
.ctab{background:linear-gradient(135deg,rgba(124,106,247,.1),rgba(34,211,238,.05),rgba(124,106,247,.08));border:1px solid rgba(124,106,247,.25);border-radius:28px;padding:70px 40px;text-align:center;position:relative;overflow:hidden;box-shadow:0 0 80px rgba(124,106,247,.08)}
.ctab::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 0%,rgba(124,106,247,.1),transparent 60%);pointer-events:none}
.ctati{font-size:clamp(28px,3.5vw,46px);font-weight:700;margin-bottom:14px;position:relative}
.ctasb{font-size:16px;color:var(--tx2);margin-bottom:40px;position:relative}
.ctabs{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;position:relative}
.wab{display:inline-flex;align-items:center;gap:10px;background:#25D366;color:#fff;border:none;padding:14px 28px;border-radius:var(--r);font-size:14px;font-weight:600;cursor:pointer;font-family:var(--fn);text-decoration:none;transition:all .2s;box-shadow:0 4px 20px rgba(37,211,102,.3)}
.wab:hover{background:#20BA5B;transform:translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.4)}

/* FOOTER */
footer{background:var(--bg2);border-top:1px solid var(--bd);padding:64px 0 28px;position:relative;z-index:1}
.ftg{display:grid;grid-template-columns:2fr 1fr 1fr 1.5fr;gap:48px;margin-bottom:48px}
.ftl{font-family:var(--mo);font-weight:700;font-size:18px;margin-bottom:14px}
.ftl span{color:var(--ac)}
.fttg{font-size:13px;color:var(--tx3);line-height:1.75;margin-bottom:22px;max-width:260px}
.socs{display:flex;gap:8px}
.socb{width:34px;height:34px;border-radius:8px;border:1px solid var(--bd);background:var(--sf);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--tx3);text-decoration:none;transition:all .2s;cursor:pointer}
.socb:hover{border-color:var(--ac);color:var(--ac);transform:translateY(-2px)}
.fth{font-size:12px;font-weight:700;color:var(--tx);margin-bottom:18px;letter-spacing:.07em;text-transform:uppercase}
.ftls{list-style:none;display:flex;flex-direction:column;gap:9px}
.ftls a{font-size:13px;color:var(--tx3);text-decoration:none;display:flex;align-items:center;gap:6px;transition:color .2s}
.ftls a::before{content:'›';color:var(--ac);font-size:14px}
.ftls a:hover{color:var(--tx)}
.ftct{display:flex;flex-direction:column;gap:12px}
.ftci{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--tx3)}
.ftcii{width:30px;height:30px;border-radius:7px;background:rgba(124,106,247,.1);display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}
.ftbot{border-top:1px solid var(--bd);padding-top:24px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.ftcp{font-size:12px;color:var(--tx3)}
.ftbk{font-size:12px;color:var(--tx3);cursor:pointer;display:flex;align-items:center;gap:6px;background:none;border:1px solid var(--bd);padding:6px 12px;border-radius:6px;font-family:var(--fn);transition:all .2s}
.ftbk:hover{border-color:var(--ac);color:var(--ac)}

/* SCROLL + TOAST */
.sctop{position:fixed;bottom:30px;right:30px;z-index:300;width:44px;height:44px;border-radius:50%;background:var(--ac);color:#fff;border:none;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 0 20px var(--glow);opacity:0;transform:translateY(20px);transition:all .3s}
.sctop.show{opacity:1;transform:translateY(0)}
.sctop:hover{background:var(--ac2);box-shadow:0 0 32px var(--glow2);transform:translateY(-2px)}

/* REVEAL ANIMATIONS */
.rv{opacity:0;transform:translateY(28px);transition:opacity .65s ease,transform .65s ease}
.rvl{opacity:0;transform:translateX(-28px);transition:opacity .65s ease,transform .65s ease}
.rvr{opacity:0;transform:translateX(28px);transition:opacity .65s ease,transform .65s ease}
.rv.vis,.rvl.vis,.rvr.vis{opacity:1;transform:translate(0)}

/* RESPONSIVE */
@media(max-width:1024px){
  .svg{grid-template-columns:repeat(3,1fr)}
  .pjg{grid-template-columns:repeat(2,1fr)}
  .pdg{grid-template-columns:repeat(3,1fr)}
  .skg{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:768px){
  .hg{grid-template-columns:1fr;gap:40px;padding:40px 0}
  .hr{display:none}
  .hstats{grid-template-columns:repeat(2,1fr)}
  .ag2,.cg,.exg{grid-template-columns:1fr;gap:40px}
  .prg{grid-template-columns:1fr;max-width:400px;margin:0 auto}
  .pjg{grid-template-columns:1fr}
  .pdg{grid-template-columns:repeat(2,1fr)}
  .testg,.blg{grid-template-columns:1fr}
  .ftg{grid-template-columns:1fr 1fr;gap:32px}
  .frow{grid-template-columns:1fr}
  .skg{grid-template-columns:repeat(3,1fr)}
  .svg{grid-template-columns:repeat(2,1fr)}
  .nl{display:none}
  .hb{display:flex}
  .nh{display:none}
  .sp{padding:70px 0}
  .ctab{padding:50px 24px}
}
@media(max-width:480px){
  .pdg{grid-template-columns:1fr}
  .skg{grid-template-columns:repeat(2,1fr)}
  .svg{grid-template-columns:1fr}
  .ftg{grid-template-columns:1fr}
}
