:root{
  --bg:#FFFFFF; --bg-soft:#F3F8F4; --bg-tint:#F7FBF8;
  --ink:#0E0B1C; --ink-2:#322C4A; --muted:#6B6783; --muted-2:#8E8AA0;
  --line:#ECEBF3; --line-2:#E3E1ED;

  --violet:#0E8A43; --violet-2:#43B26B; --violet-d:#067A3C; --violet-soft:#E7F6EC;
  --indigo:#4F46E5; --blue:#2563EB; --cyan:#0891B2; --teal:#0E9BB8;
  --emerald:#059669; --amber:#F59E0B; --orange:#EA580C; --pink:#DB2777; --rose:#E11D48; --yellow:#FACC15;

  --d-bg:#06140C;

  --r-sm:12px; --r:16px; --r-lg:22px; --r-xl:28px; --r-2xl:34px;
  --mono:ui-monospace,'SF Mono',SFMono-Regular,Menlo,Consolas,monospace;
  --maxw:1200px;
  --sh-sm:0 1px 2px rgba(14,8,40,.05),0 4px 10px -4px rgba(16,64,38,.10);
  --sh:0 1px 3px rgba(14,8,40,.05),0 16px 34px -14px rgba(16,64,38,.20);
  --sh-lg:0 2px 6px rgba(14,8,40,.06),0 36px 64px -22px rgba(16,64,38,.30);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;line-height:1.55}
.d{font-family:'Inter Tight','Inter',sans-serif;letter-spacing:-.025em;line-height:1.04}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
a{color:inherit;text-decoration:none}
img{display:block}
::selection{background:rgba(14,138,67,.22)}

.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.22,.7,.2,1),transform .7s cubic-bezier(.22,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;font-family:'Inter';font-weight:600;font-size:14.5px;line-height:1;border-radius:999px;padding:13px 22px;transition:transform .18s cubic-bezier(.2,.7,.2,1),box-shadow .25s,background .25s,color .2s,border-color .2s}
.btn:active{transform:scale(.97)}
.btn-v{color:#fff;background:linear-gradient(180deg,#36A95E,#0E8A43);box-shadow:inset 0 1px 0 rgba(255,255,255,.28),0 8px 22px -8px rgba(14,138,67,.65),0 1px 2px rgba(8,40,20,.25)}
.btn-v:hover{box-shadow:inset 0 1px 0 rgba(255,255,255,.32),0 14px 30px -8px rgba(14,138,67,.75),0 1px 2px rgba(8,40,20,.25);transform:translateY(-1px)}
.btn-w{background:#fff;color:var(--violet-d);box-shadow:var(--sh-sm)}
.btn-w:hover{transform:translateY(-1px);box-shadow:0 14px 30px -12px rgba(8,40,20,.35)}
.btn-g{background:var(--bg-soft);color:var(--ink-2);border:1px solid var(--line)}
.btn-g:hover{background:#fff;border-color:var(--line-2);box-shadow:var(--sh-sm)}
.btn-ghost{background:rgba(255,255,255,.06);color:#fff;border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:rgba(255,255,255,.13);border-color:rgba(255,255,255,.4)}
.btn-lg{padding:15px 28px;font-size:15.5px}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .35s,box-shadow .35s,border-color .35s}
.nav::after{content:'';position:absolute;inset:0;border-bottom:1px solid transparent;transition:border-color .35s;pointer-events:none}
.nav.scrolled{background:rgba(255,255,255,.72);backdrop-filter:blur(18px) saturate(160%)}
.nav.scrolled::after{border-bottom-color:var(--line)}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;position:relative;z-index:1}
.logo{display:flex;align-items:center;gap:11px;font-size:19px;line-height:1}
.logo .lm{width:34px;height:34px;display:block;flex:0 0 auto;border-radius:11px;box-shadow:0 6px 16px -8px rgba(14,138,67,.65)}
.logo .wm{font-family:'Sora','Inter Tight',sans-serif;font-weight:700;letter-spacing:-.03em;line-height:1;position:relative;top:1px}
.logo .wm .pro{color:#34A35A;font-weight:500}
.nav nav{display:flex;gap:6px;font-size:14.5px;font-weight:500}
.nav nav a{padding:9px 14px;border-radius:10px;color:#E9E6F5;transition:background .2s,color .2s}
.nav nav a:hover{background:rgba(255,255,255,.1)}
.nav .act{display:flex;align-items:center;gap:14px;font-size:14.5px;font-weight:600}
.nav .act .login{color:#EFEDF8;padding:9px 6px;transition:color .2s}
.nav .act .login:hover{color:#fff}
/* scrolled -> dark text over light glass */
.nav .logo{color:#fff}
.nav.scrolled .logo{color:var(--ink)}
.nav.scrolled nav a{color:var(--ink-2)}
.nav.scrolled nav a:hover{background:var(--violet-soft);color:var(--violet-d)}
.nav.scrolled .act .login{color:var(--ink-2)}
.nav.scrolled .act .login:hover{color:var(--violet-d)}
.burger{display:none;width:42px;height:42px;border-radius:11px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);color:#fff;font-size:20px;place-items:center;cursor:pointer}
.nav.scrolled .burger{color:var(--ink);border-color:var(--line);background:#fff}

/* ---------- hero ---------- */
.hero{position:relative;color:#fff;overflow:hidden;padding:152px 0 118px;
  background:
    radial-gradient(78% 56% at 50% -8%, rgba(14,138,67,.50), transparent 62%),
    radial-gradient(46% 50% at 84% 16%, rgba(37,99,235,.34), transparent 64%),
    radial-gradient(42% 52% at 12% 72%, rgba(219,39,119,.24), transparent 62%),
    radial-gradient(60% 70% at 50% 116%, rgba(67,178,107,.30), transparent 60%),
    var(--d-bg);
}
.hero::before{content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(120% 78% at 50% 2%,#000 32%,transparent 76%);
          mask-image:radial-gradient(120% 78% at 50% 2%,#000 32%,transparent 76%);}
.hero::after{content:'';position:absolute;left:0;right:0;bottom:0;height:160px;background:linear-gradient(transparent,rgba(9,6,15,.0) 0%,#fff 220%);pointer-events:none;opacity:0}
.hero .wrap{position:relative;z-index:2}
.hstage{position:relative;text-align:center;max-width:780px;margin:0 auto}
.htag{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:500;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:7px 16px 7px 12px;margin-bottom:26px;backdrop-filter:blur(8px);color:#EFEDFA}
.htag .pd{width:7px;height:7px;border-radius:50%;background:#34D399;box-shadow:0 0 0 0 rgba(52,211,153,.6);animation:pl 1.9s infinite}
@keyframes pl{0%,100%{box-shadow:0 0 0 0 rgba(52,211,153,.55)}50%{box-shadow:0 0 0 7px rgba(52,211,153,0)}}
.hero h1{font-size:clamp(44px,6.7vw,80px);font-weight:700;letter-spacing:-.035em;line-height:1.02}
.grad{background:linear-gradient(100deg,#9BD3AC,#86CF9F 38%,#F5A8E8 72%,#9BD3AC);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:sh 7s linear infinite}
@keyframes sh{to{background-position:200% center}}
.hero .sub{font-size:clamp(16px,1.7vw,19px);color:rgba(236,233,247,.74);max-width:560px;margin:24px auto 0;line-height:1.62}
.hsearch{margin:36px auto 0;display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.97);border-radius:999px;padding:7px 7px 7px 20px;max-width:560px;box-shadow:0 30px 70px -24px rgba(16,80,40,.7),inset 0 0 0 1px rgba(255,255,255,.4)}
.hsearch i.ti{font-size:20px;color:#9b97ad}
.hsearch input{flex:1;border:none;outline:none;background:transparent;font-size:15px;color:var(--ink);font-family:'Inter',sans-serif}
.hsearch input::placeholder{color:#9b97ad}
.hquick{display:flex;gap:18px;justify-content:center;align-items:center;margin-top:22px;flex-wrap:wrap}
.htrust{display:flex;align-items:center;gap:13px;margin-top:34px;justify-content:center;color:rgba(236,233,247,.66);font-size:13.5px}
.htrust .avs{display:flex}
.htrust .avs img{width:34px;height:34px;border-radius:50%;border:2px solid #14102a;object-fit:cover;margin-left:-10px;box-shadow:0 2px 8px rgba(0,0,0,.4)}
.htrust .avs img:first-child{margin-left:0}
.htrust b{color:#fff;font-weight:600}
.htrust .stars-y{color:#FACC15;letter-spacing:1px}

.float{position:absolute;background:rgba(20,14,36,.55);border:1px solid rgba(255,255,255,.12);border-radius:16px;box-shadow:0 24px 50px -18px rgba(0,0,0,.65);padding:13px 15px;z-index:3;backdrop-filter:blur(16px) saturate(150%);color:#fff;transition:transform .18s ease-out;will-change:transform}
.f1{right:100%;margin-right:20px;top:34px;rotate:-5deg;animation:fl 6s ease-in-out infinite}
.f2{left:100%;margin-left:20px;top:62px;rotate:4deg;animation:fl 7s ease-in-out infinite .5s}
.f3{right:100%;margin-right:20px;bottom:24px;rotate:3deg;animation:fl 6.5s ease-in-out infinite .25s}
.f4{left:100%;margin-left:20px;bottom:34px;rotate:-4deg;animation:fl 7.5s ease-in-out infinite .7s}
@keyframes fl{0%,100%{translate:0 0}50%{translate:0 -15px}}
.float .ttl{font-size:13px;font-weight:600}
.float .sm{font-size:11.5px;color:rgba(236,233,247,.6)}
.av{width:38px;height:38px;border-radius:50%;object-fit:cover}
.chip{font-size:11px;font-weight:600;border-radius:999px;padding:3px 9px}
@media(max-width:1200px){.float{display:none}}

/* ---------- marquee ---------- */
.mq{background:#0F0A1E;color:#B9B2D4;padding:0;overflow:hidden;border-top:1px solid rgba(255,255,255,.06);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.mqt{display:flex;width:max-content;animation:scr 32s linear infinite}
.mqt span{display:flex;align-items:center;gap:40px;white-space:nowrap;font-family:'Inter Tight';font-weight:600;font-size:19px;padding:18px 20px 18px 0}
.mqt span i{font-size:9px;color:var(--violet-2);transform:translateY(-1px)}
@keyframes scr{to{transform:translateX(-50%)}}

/* ---------- sections ---------- */
section{padding:88px 0;position:relative}
.alt{background:var(--bg-soft)}
.grid-bg{background-image:radial-gradient(rgba(14,138,67,.07) 1px,transparent 1px);background-size:26px 26px}
.s-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:42px;gap:24px;flex-wrap:wrap}
.kick{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:12px;font-weight:600;color:var(--violet);letter-spacing:.12em;text-transform:uppercase;margin-bottom:15px}
.kick::before{content:'';width:18px;height:1.5px;background:linear-gradient(90deg,var(--violet),transparent)}
.s-head h2{font-size:clamp(28px,3.8vw,46px);font-weight:700;max-width:22ch;letter-spacing:-.03em}
.s-head .sd{font-size:15px;color:var(--muted);margin-top:12px;max-width:46ch;line-height:1.6}
.more{font-size:14.5px;font-weight:600;color:var(--violet-d);display:inline-flex;gap:7px;align-items:center;white-space:nowrap;padding:10px 16px;border:1px solid var(--line-2);border-radius:999px;transition:background .2s,border-color .2s,gap .2s}
.more:hover{background:var(--violet-soft);border-color:transparent;gap:11px}

/* ---------- dual cards ---------- */
.cards2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.pcardz{border-radius:var(--r-2xl);padding:38px;color:#fff;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;box-shadow:var(--sh)}
.pcardz:hover{transform:translateY(-5px);box-shadow:var(--sh-lg)}
.pcardz::before{content:'';position:absolute;inset:0;background:linear-gradient(150deg,rgba(255,255,255,.18),transparent 45%);pointer-events:none}
.pcardz::after{content:'';position:absolute;width:280px;height:280px;right:-60px;top:-90px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.28),transparent 70%);pointer-events:none}
.pcardz.a{background:linear-gradient(145deg,#0E8A43,#4C1D95)}
.pcardz.b{background:linear-gradient(145deg,#0E9BB8,#075C72)}
.pcardz .em{font-family:var(--mono);font-size:13px;font-weight:600;letter-spacing:.14em;opacity:.7;position:relative;z-index:1}
.pcardz h3{font-family:'Inter Tight';font-size:28px;font-weight:700;letter-spacing:-.02em;margin:6px 0 18px;position:relative;z-index:1}
.pcardz ul{list-style:none;display:flex;flex-direction:column;gap:12px;font-size:15px;color:rgba(255,255,255,.92);position:relative;z-index:1}
.pcardz li{display:flex;gap:11px;align-items:flex-start}
.pcardz li i{color:#fff;background:rgba(255,255,255,.2);width:20px;height:20px;border-radius:50%;display:grid;place-items:center;font-size:12px;flex:0 0 auto;margin-top:1px}
.pcardz .go{margin-top:26px;display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--ink);font-weight:600;font-size:14px;border-radius:999px;padding:12px 22px;position:relative;z-index:1;transition:gap .2s,box-shadow .2s}
.pcardz .go:hover{gap:12px;box-shadow:0 12px 24px -10px rgba(0,0,0,.4)}

/* ---------- benefits ---------- */
.benefits{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:transform .28s,box-shadow .28s,border-color .28s;box-shadow:var(--sh-sm)}
.bcard:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:var(--line-2)}
.bcard .bi{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-size:23px;color:#fff;margin-bottom:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.bcard h4{font-family:'Inter Tight';font-size:17.5px;font-weight:700;letter-spacing:-.01em;margin-bottom:7px}
.bcard p{font-size:13.5px;color:var(--muted);line-height:1.58}

/* ---------- categories ---------- */
.cats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.cat{position:relative;border-radius:var(--r-lg);padding:22px;min-height:152px;display:flex;flex-direction:column;justify-content:space-between;color:#fff;overflow:hidden;box-shadow:0 10px 28px -16px rgba(16,64,38,.55);transition:transform .3s,box-shadow .3s}
.cat::before{content:'';position:absolute;inset:0;background:linear-gradient(160deg,rgba(255,255,255,.24),transparent 42%);pointer-events:none}
.cat:hover{transform:translateY(-6px);box-shadow:0 26px 46px -18px rgba(16,64,38,.6)}
.cat .ic{width:46px;height:46px;border-radius:13px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.2);display:grid;place-items:center;font-size:23px;backdrop-filter:blur(4px)}
.cat .c-t{font-family:'Inter Tight';font-size:17px;font-weight:700;letter-spacing:-.01em;margin-top:auto}
.cat .c-n{font-family:var(--mono);font-size:12px;opacity:.82;margin-top:4px}
.cat .arr{position:absolute;top:18px;right:18px;font-size:18px;opacity:0;transform:translate(-4px,4px);transition:opacity .26s,transform .26s}
.cat:hover .arr{opacity:.95;transform:none}

/* ---------- projects ---------- */
.proj{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.prow{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:20px;display:flex;align-items:flex-start;gap:16px;transition:transform .22s,box-shadow .22s,border-color .22s;cursor:pointer;box-shadow:var(--sh-sm)}
.prow:hover{transform:translateY(-3px);box-shadow:var(--sh);border-color:#E2D7F8}
.prow .picon{width:42px;height:42px;border-radius:12px;flex:0 0 auto;display:grid;place-items:center;font-size:19px;color:#fff}
.prow .p-t{font-size:15.5px;font-weight:600;letter-spacing:-.01em;line-height:1.3}
.prow .p-d{font-size:13px;color:var(--muted);margin-top:5px;line-height:1.45}
.prow .p-m{font-size:12.5px;color:var(--muted-2);margin-top:11px;display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.prow .p-m .dot{width:3px;height:3px;border-radius:50%;background:#cfcadb}
.tag{font-size:11.5px;background:var(--violet-soft);color:var(--violet-d);border-radius:999px;padding:3px 10px;font-weight:600}
.prow .p-b{margin-left:auto;font-family:'Inter Tight';font-weight:700;font-size:18px;letter-spacing:-.02em;white-space:nowrap;text-align:right}
.prow .p-b small{display:block;font-family:'Inter';font-weight:500;font-size:11px;color:var(--muted-2);margin-top:3px}

/* ---------- freelancers ---------- */
.fl{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.fcard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;transition:transform .28s,box-shadow .28s,border-color .28s;box-shadow:var(--sh-sm);display:flex;flex-direction:column}
.fcard:hover{transform:translateY(-6px);box-shadow:var(--sh);border-color:var(--line-2)}
.fcard .top{display:flex;align-items:center;gap:13px}
.fcard .pa{width:54px;height:54px;border-radius:15px;object-fit:cover;background:#eee;flex:0 0 auto;box-shadow:var(--sh-sm)}
.fcard .nm{font-family:'Inter Tight';font-size:16.5px;font-weight:700;letter-spacing:-.01em;display:flex;align-items:center;gap:6px}
.fcard .vf{color:#fff;background:var(--emerald);width:16px;height:16px;border-radius:50%;display:inline-grid;place-items:center;font-size:9px}
.fcard .ro{font-size:12.5px;color:var(--muted);margin-top:3px}
.fcard .ab{font-size:13px;color:var(--muted);line-height:1.55;margin:15px 0;flex:1}
.fcard .ft{display:flex;justify-content:space-between;align-items:center;font-size:13px;border-top:1px solid var(--line);padding-top:15px}
.fcard .ft .rate{display:flex;align-items:center;gap:5px;font-weight:600}
.fcard .ft .rate small{color:var(--muted-2);font-weight:500}
.fcard .rt{font-family:'Inter Tight';font-weight:700;font-size:16px;color:var(--violet-d);letter-spacing:-.01em}
.stars{color:var(--amber)}

/* ---------- services ---------- */
.svc{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.scard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;transition:transform .28s,box-shadow .28s,border-color .28s;box-shadow:var(--sh-sm);position:relative;overflow:hidden}
.scard:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:var(--line-2)}
.scard .si{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:23px;color:#fff;margin-bottom:18px;box-shadow:inset 0 1px 0 rgba(255,255,255,.3)}
.scard h4{font-family:'Inter Tight';font-size:18px;font-weight:700;letter-spacing:-.01em;margin-bottom:8px}
.scard p{font-size:13.5px;color:var(--muted);line-height:1.55}
.scard .sf{margin-top:20px;display:flex;align-items:center;justify-content:space-between}
.scard .pr{font-family:'Inter Tight';font-weight:700;font-size:18px;color:var(--ink);letter-spacing:-.01em}
.scard .pr span{font-family:'Inter';font-weight:500;font-size:12px;color:var(--muted-2)}
.scard .sgo{width:36px;height:36px;border-radius:50%;border:1px solid var(--line-2);display:grid;place-items:center;color:var(--violet-d);font-size:17px;transition:background .2s,color .2s,border-color .2s}
.scard:hover .sgo{background:var(--violet);color:#fff;border-color:var(--violet)}

/* ---------- portfolio bento ---------- */
.pf{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:200px;gap:14px}
.pcell{position:relative;border-radius:var(--r);overflow:hidden;background:#ddd;box-shadow:var(--sh-sm)}
.pcell img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.pcell:hover img{transform:scale(1.07)}
.pcell::after{content:'';position:absolute;inset:0;background:linear-gradient(140deg,rgba(14,138,67,.4),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none;z-index:1}
.pcell:hover::after{opacity:1}
.pcell .ov{position:absolute;inset:0;background:linear-gradient(transparent 40%,rgba(12,7,24,.78))}
.pcell .lb{position:absolute;left:16px;bottom:14px;right:16px;color:#fff;font-weight:600;font-size:14px;z-index:1;letter-spacing:-.01em}
.pcell .pc{position:absolute;left:14px;top:14px;z-index:1;font-size:11px;font-weight:600;color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px);border-radius:999px;padding:4px 11px;opacity:0;transform:translateY(-4px);transition:opacity .26s,transform .26s}
.pcell:hover .pc{opacity:1;transform:none}
.g6x2{grid-column:span 6;grid-row:span 2}.g6{grid-column:span 6}.g4{grid-column:span 4}.g3{grid-column:span 3}

/* ---------- articles ---------- */
.artgrid{display:grid;grid-template-columns:1.15fr 1fr;gap:20px}
.feat{position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:440px;box-shadow:var(--sh-sm);display:block}
.feat>img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.feat:hover>img{transform:scale(1.05)}
.feat .ov{position:absolute;inset:0;background:linear-gradient(transparent 30%,rgba(10,6,20,.55) 60%,rgba(10,6,20,.92))}
.feat .fc{position:absolute;left:26px;right:26px;bottom:26px;color:#fff;z-index:1}
.feat .at{display:inline-block;font-size:11.5px;font-weight:600;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);backdrop-filter:blur(6px);border-radius:999px;padding:5px 13px;margin-bottom:15px}
.feat h3{font-family:'Inter Tight';font-size:25px;font-weight:700;letter-spacing:-.02em;line-height:1.22;margin-bottom:10px}
.feat p{font-size:14px;color:rgba(255,255,255,.78);line-height:1.55;max-width:44ch;margin-bottom:16px}
.feat .am{font-family:var(--mono);font-size:11.5px;color:rgba(255,255,255,.68);display:flex;align-items:center;gap:8px}
.amini{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.acard{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;transition:transform .28s,box-shadow .28s,border-color .28s;box-shadow:var(--sh-sm)}
.acard:hover{transform:translateY(-5px);box-shadow:var(--sh);border-color:var(--line-2)}
.acard .ai{aspect-ratio:16/10;overflow:hidden;background:#eee;position:relative}
.acard .ai img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.acard:hover .ai img{transform:scale(1.06)}
.acard .at{position:absolute;left:12px;top:12px;font-size:10.5px;font-weight:600;color:#fff;background:rgba(20,14,36,.6);border:1px solid rgba(255,255,255,.18);backdrop-filter:blur(6px);border-radius:999px;padding:4px 11px}
.acard .ab{padding:15px 16px 17px}
.acard h4{font-family:'Inter Tight';font-size:15px;font-weight:700;letter-spacing:-.01em;margin:0 0 11px;line-height:1.32}
.acard .am{font-family:var(--mono);font-size:11px;color:var(--muted-2);display:flex;align-items:center;gap:7px}
@media(max-width:860px){.artgrid{grid-template-columns:1fr}.feat{min-height:330px}}
@media(max-width:560px){.amini{grid-template-columns:1fr}}

/* ---------- stats ---------- */
.statband{position:relative;overflow:hidden;border-radius:var(--r-2xl);margin:0 28px;color:#fff;
  background:linear-gradient(135deg,#0E8A43,#4C1D95);box-shadow:0 40px 80px -30px rgba(76,29,149,.6)}
.statband::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:radial-gradient(120% 120% at 50% 0%,#000,transparent 75%);mask-image:radial-gradient(120% 120% at 50% 0%,#000,transparent 75%)}
.statband::after{content:'';position:absolute;inset:0;background:radial-gradient(50% 80% at 86% 8%,rgba(250,204,21,.2),transparent),radial-gradient(44% 74% at 8% 92%,rgba(14,155,184,.34),transparent)}
.stats{display:grid;grid-template-columns:repeat(4,1fr);padding:58px 44px;position:relative;z-index:1;gap:30px 24px}
.stat .si{width:44px;height:44px;border-radius:13px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;font-size:22px;color:#fff;margin-bottom:18px}
.stat .v{font-family:'Inter Tight';font-size:clamp(38px,5vw,62px);font-weight:700;letter-spacing:-.035em;line-height:1}
.stat .l{font-size:13.5px;color:rgba(255,255,255,.82);margin-top:8px}

/* ---------- reviews ---------- */
.rv{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.rcard{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:26px;display:flex;flex-direction:column;box-shadow:var(--sh-sm);transition:transform .25s,box-shadow .25s,border-color .25s}
.rcard:hover{transform:translateY(-4px);box-shadow:var(--sh);border-color:var(--line-2)}
.rcard .qm{position:absolute;top:6px;right:20px;font-family:'Inter Tight';font-size:92px;font-weight:800;line-height:1;color:var(--violet-soft);z-index:0;pointer-events:none}
.rcard .st{color:var(--amber);font-size:14px;margin-bottom:14px;letter-spacing:2px;position:relative;z-index:1}
.rcard .q{font-size:15px;line-height:1.6;margin-bottom:22px;font-weight:500;color:var(--ink-2);position:relative;z-index:1}
.rcard .who{display:flex;align-items:center;gap:12px;margin-top:auto;position:relative;z-index:1}
.rcard .who img{width:42px;height:42px;border-radius:50%;object-fit:cover;box-shadow:0 0 0 2px #fff,0 0 0 3px var(--violet-soft)}
.rcard .who .nm{font-size:14px;font-weight:600;display:flex;align-items:center;gap:5px}
.rcard .who .nm .vf{color:#fff;background:var(--emerald);width:14px;height:14px;border-radius:50%;display:inline-grid;place-items:center;font-size:8px}
.rcard .who .ro{font-size:12.5px;color:var(--muted)}
.rcard.feat-r{grid-column:span 2;color:#fff;border:none;background:linear-gradient(140deg,#0E8A43,#4C1D95)}
.rcard.feat-r .qm{color:rgba(255,255,255,.16)}
.rcard.feat-r .q{color:#fff;font-size:19px;font-weight:600;font-family:'Inter Tight';letter-spacing:-.01em;line-height:1.45}
.rcard.feat-r .who .ro{color:rgba(255,255,255,.78)}
.rcard.feat-r .who img{box-shadow:0 0 0 2px rgba(255,255,255,.28)}
@media(max-width:580px){.rcard.feat-r{grid-column:span 1}}

/* ---------- tags ---------- */
.tags{display:flex;flex-wrap:wrap;gap:11px}
.tagc{background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:9px 17px;font-size:14px;color:var(--ink-2);transition:background .2s,color .2s,border-color .2s,transform .16s,box-shadow .2s}
.tagc::before{content:'#';color:var(--violet);font-weight:700;margin-right:5px;opacity:.55;transition:color .2s,opacity .2s}
.tagc:hover{background:linear-gradient(180deg,#36A95E,#0E8A43);color:#fff;border-color:transparent;transform:translateY(-2px);box-shadow:0 12px 24px -10px rgba(14,138,67,.65)}
.tagc:hover::before{color:#fff;opacity:.85}

/* ---------- cta ---------- */
.cta{position:relative;overflow:hidden;border-radius:var(--r-2xl);padding:84px 40px;text-align:center;margin:0 28px;color:#fff;
  background:radial-gradient(120% 140% at 50% -10%,#43B26B,#0E7A3C 52%,#053D1F);box-shadow:0 50px 90px -34px rgba(16,80,40,.6)}
.cta::before{content:'';position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:50px 50px;-webkit-mask-image:radial-gradient(110% 110% at 50% 0,#000,transparent 72%);mask-image:radial-gradient(110% 110% at 50% 0,#000,transparent 72%)}
.cta::after{content:'';position:absolute;inset:0;background:radial-gradient(40% 60% at 12% 88%,rgba(250,204,21,.2),transparent),radial-gradient(40% 60% at 88% 80%,rgba(14,155,184,.32),transparent)}
.cta .ckick{position:relative;z-index:1;font-family:var(--mono);font-size:12px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:18px}
.cta h2{font-family:'Inter Tight';font-size:clamp(32px,5vw,58px);font-weight:700;letter-spacing:-.03em;max-width:18ch;margin:0 auto 30px;position:relative;z-index:1;line-height:1.05}
.cta h2 em{font-style:normal;color:#FACC15}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}

/* ---------- footer ---------- */
footer{background:var(--d-bg);color:#C8C2DC;padding:80px 0 40px;margin-top:88px;position:relative;overflow:hidden}
footer::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(14,138,67,.5),transparent)}
.fgrid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px;padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.08)}
footer .logo{color:#fff}
footer .about{font-size:14px;color:rgba(200,194,220,.7);max-width:34ch;margin:16px 0 20px;line-height:1.65}
.soc{display:flex;gap:10px}
.soc a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);display:grid;place-items:center;font-size:17px;color:#D7D2E6;transition:background .2s,color .2s,transform .18s}
.soc a:hover{background:var(--violet);color:#fff;border-color:var(--violet);transform:translateY(-2px)}
.fcol h5{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:rgba(200,194,220,.5);margin-bottom:18px;font-weight:600;font-family:var(--mono)}
.fcol a{display:block;font-size:14.5px;margin-bottom:12px;color:rgba(200,194,220,.82);transition:color .2s,padding .2s}
.fcol a:hover{color:#fff;padding-left:4px}
.fbot{display:flex;justify-content:space-between;align-items:center;padding-top:26px;font-size:13px;color:rgba(200,194,220,.55);flex-wrap:wrap;gap:12px}
.lang{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:7px 14px;display:inline-flex;align-items:center;gap:7px;color:#D7D2E6}

/* ---------- responsive ---------- */
@media(max-width:960px){
  .cats,.fl,.benefits{grid-template-columns:repeat(2,1fr)}
  .svc,.rv,.proj{grid-template-columns:1fr 1fr}.cards2{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:34px 24px}.fgrid{grid-template-columns:1fr 1fr}
  .pf{grid-template-columns:repeat(2,1fr);grid-auto-rows:158px}.g6x2,.g6,.g4,.g3{grid-column:span 1;grid-row:span 1}
  .nav nav{display:none}.burger{display:grid}.nav .act .login{display:none}
}
@media(max-width:580px){
  .wrap{padding:0 18px}
  .cats,.svc,.rv,.fl,.proj,.benefits,.fgrid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}.statband,.cta{margin:0 18px}
  .hero{padding:124px 0 86px}.hquick{flex-direction:column}.hquick .btn{width:100%}
  section{padding:64px 0}.pcardz{padding:30px}
}
/* hero aurora orbs */
.hero .orb{position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none}
.hero::before{z-index:1}
.orb1{width:440px;height:440px;background:radial-gradient(circle,#34A35A,transparent 68%);left:-140px;top:20px;animation:drift1 19s ease-in-out infinite}
.orb2{width:380px;height:380px;background:radial-gradient(circle,#2563EB,transparent 68%);right:-120px;top:90px;animation:drift2 23s ease-in-out infinite}
.orb3{width:320px;height:320px;background:radial-gradient(circle,#DB2777,transparent 70%);left:42%;bottom:-150px;animation:drift3 21s ease-in-out infinite}
@keyframes drift1{0%,100%{transform:translate(0,0)}50%{transform:translate(50px,34px)}}
@keyframes drift2{0%,100%{transform:translate(0,0)}50%{transform:translate(-46px,40px)}}
@keyframes drift3{0%,100%{transform:translate(-50%,0)}50%{transform:translate(calc(-50% + 28px),-42px)}}
@media(max-width:680px){.hero .orb{display:none}}

/* hero popular chips */
.hpop{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-top:16px;align-items:center}
.hpop .pl{font-size:12px;color:rgba(236,233,247,.5)}
.hpop a{font-size:13px;color:#EDEAF8;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);border-radius:999px;padding:6px 13px;transition:background .2s,border-color .2s,transform .15s}
.hpop a:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.38);transform:translateY(-1px)}

/* how it works */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;position:relative}
.steps::before{content:'';position:absolute;top:32px;left:16.5%;right:16.5%;height:2px;background:repeating-linear-gradient(90deg,var(--line-2) 0 7px,transparent 7px 15px);z-index:0}
.step{position:relative;z-index:1;text-align:center}
.step .icn{position:relative;width:64px;height:64px;border-radius:18px;display:grid;place-items:center;font-size:28px;color:#fff;margin:0 auto 20px;box-shadow:inset 0 1px 0 rgba(255,255,255,.3),0 12px 26px -10px rgba(16,64,38,.5)}
.step .icn .num{position:absolute;top:-9px;right:-9px;width:27px;height:27px;border-radius:50%;background:#fff;border:1px solid var(--line-2);color:var(--violet-d);font-family:var(--mono);font-size:11.5px;font-weight:700;display:grid;place-items:center;box-shadow:var(--sh-sm)}
.step h4{font-family:'Inter Tight';font-size:19px;font-weight:700;letter-spacing:-.01em;margin-bottom:9px}
.step p{font-size:14px;color:var(--muted);line-height:1.6;max-width:32ch;margin:0 auto}
@media(max-width:780px){.steps{grid-template-columns:1fr;gap:22px}.steps::before{display:none}}

/* scroll progress + back to top */
.progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,#43B26B,#0E8A43,#2563EB);z-index:200;box-shadow:0 0 12px rgba(14,138,67,.6)}
.totop{position:fixed;right:22px;bottom:22px;width:48px;height:48px;border-radius:14px;border:none;background:linear-gradient(180deg,#36A95E,#0E8A43);color:#fff;display:grid;place-items:center;font-size:20px;cursor:pointer;box-shadow:0 14px 30px -10px rgba(14,138,67,.7);opacity:0;transform:translateY(12px) scale(.92);pointer-events:none;transition:opacity .3s,transform .3s;z-index:120}
.totop.show{opacity:1;transform:none;pointer-events:auto}
.totop.show:hover{transform:translateY(-3px)}

@media(prefers-reduced-motion:reduce){*{animation-duration:.001ms!important;animation-iteration-count:1!important}.reveal{opacity:1;transform:none}}
/* lang switcher in the dark nav (overrides _lang_switcher.php inline styles) */
.nav #lang-cell{display:inline-flex;align-items:center;padding:0}
.nav #lang-switch>summary{background:rgba(255,255,255,.08)!important;border-color:rgba(255,255,255,.22)!important;color:#EFEDF8!important;font-weight:600}
.nav #lang-switch>summary:hover,.nav #lang-switch[open]>summary{background:rgba(255,255,255,.16)!important;border-color:rgba(255,255,255,.4)!important}
.nav #lang-switch .lang-chev,.nav #lang-switch>summary svg{stroke:#fff!important}
.nav.scrolled #lang-switch>summary{background:var(--bg-soft)!important;border-color:var(--line-2)!important;color:var(--ink-2)!important}
.nav.scrolled #lang-switch .lang-chev,.nav.scrolled #lang-switch>summary svg{stroke:var(--violet-d)!important}
.nav #lang-switch .lang-menu{background:#fff!important;border-color:var(--line-2)!important}
.nav #lang-switch .lang-menu .cur{background:var(--violet)!important}
.nav #lang-switch .lang-menu a:hover{background:var(--violet-soft)!important;color:var(--violet-d)!important}
/* portfolio: tighter rows so small source images upscale less */
.pf{grid-auto-rows:168px}
@media(max-width:960px){.pf{grid-auto-rows:148px}}

/* language switcher in nav — new design */
.navlang{position:relative;font-size:14px}
.navlang-btn{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:11px;color:#E9E6F5;font-weight:600;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);transition:background .2s,color .2s,border-color .2s}
.navlang-btn::-webkit-details-marker{display:none}
.navlang-btn i.ti-world{font-size:17px}
.navlang-btn .navlang-c{font-size:15px;transition:transform .15s}
.navlang.open .navlang-c{transform:rotate(180deg)}
.navlang-btn:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.38)}
.nav.scrolled .navlang-btn{color:var(--ink-2);background:var(--bg-soft);border-color:var(--line-2)}
.nav.scrolled .navlang-btn:hover{background:var(--violet-soft);color:var(--violet-d);border-color:transparent}
.navlang-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:160px;background:#fff;border:1px solid var(--line-2);border-radius:14px;box-shadow:var(--sh-lg);padding:6px;z-index:300}
.navlang-menu a,.navlang-menu .cur{display:block;padding:9px 13px;border-radius:9px;font-size:14px;color:var(--ink-2);text-decoration:none;white-space:nowrap}
.navlang-menu a:hover{background:var(--violet-soft);color:var(--violet-d)}
.navlang-menu .cur{background:linear-gradient(180deg,#36A95E,#0E8A43);color:#fff;font-weight:600}
@media(max-width:960px){.navlang{display:none}}

.navlang-btn{font-family:inherit}
.navlang-menu{display:none}
.navlang.open .navlang-menu{display:block}
.navlang.open .navlang-c{transform:rotate(180deg)}

.nav::before,.nav::after{pointer-events:none}


/* ===== Promo / featured services ===== */
#promo{padding:54px 0}
#promo .promo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:26px}
@media(max-width:980px){#promo .promo-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:620px){#promo .promo-grid{grid-template-columns:1fr}}
.pcard{position:relative;display:flex;flex-direction:column;gap:12px;background:#fff;border:1px solid var(--line-2);border-radius:20px;padding:20px;text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s,border-color .25s;overflow:hidden}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:transparent}
.pcard.is-promo{border:1.5px solid transparent;background:linear-gradient(#fff,#fff) padding-box,linear-gradient(135deg,#43B26B,#0E8A43) border-box;box-shadow:0 12px 32px -18px rgba(14,138,67,.55)}
.pcard.is-promo::before{content:'';position:absolute;inset:0 0 auto 0;height:3px;background:linear-gradient(90deg,#43B26B,#0E8A43)}
.pbadge{position:absolute;top:14px;right:14px;display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;letter-spacing:.3px;color:#fff;background:linear-gradient(135deg,#f59e0b,#f97316);padding:4px 9px;border-radius:999px;box-shadow:0 5px 14px -4px rgba(249,115,22,.65)}
.pbadge .ti{font-size:12px}
.pcard .ph{display:flex;align-items:center;gap:11px}
.pava{flex:0 0 auto;width:44px;height:44px;border-radius:13px;overflow:hidden;display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:18px;background:var(--bg-soft)}
.pava img{width:100%;height:100%;object-fit:cover;display:block}
.pwho{display:flex;flex-direction:column;min-width:0}
.pwho strong{font-size:14px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pwho small{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pcard h4{font-size:16px;font-weight:700;line-height:1.3;margin:0;color:var(--ink)}
.pcard p{font-size:13.5px;color:var(--muted);line-height:1.5;margin:0;flex:1 1 auto;min-height:40px}
.pfoot{display:flex;align-items:center;justify-content:space-between;margin-top:2px}
.pfoot .pr{font-size:13px;font-weight:700;color:var(--violet-d);background:var(--violet-soft);padding:5px 11px;border-radius:999px}
.pgo{width:34px;height:34px;border-radius:11px;background:var(--bg-soft);display:flex;align-items:center;justify-content:center;color:var(--ink-2);transition:background .2s,color .2s}
.pcard:hover .pgo{background:var(--violet);color:#fff}

/* ===== Banner ad slot ===== */
#adslot{padding:14px 0}
.adbn{display:flex;align-items:center;gap:18px;border-radius:22px;text-decoration:none;color:inherit}
.adbn>img{display:block;max-width:100%;height:auto;border-radius:22px;margin:0 auto}
.adbn-ph{padding:22px 26px;background:linear-gradient(120deg,#07160E,#0E2E1C 58%,#16482C);border:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden;transition:transform .25s,box-shadow .25s}
.adbn-ph:hover{transform:translateY(-2px);box-shadow:0 18px 44px -22px rgba(14,138,67,.8)}
.adbn-ph::after{content:'';position:absolute;inset:0;background:radial-gradient(620px 220px at 12% 0,rgba(67,178,107,.32),transparent 62%);pointer-events:none}
.adbn-i{flex:0 0 auto;width:52px;height:52px;border-radius:15px;background:linear-gradient(135deg,#43B26B,#0E8A43);display:flex;align-items:center;justify-content:center;color:#fff;font-size:26px;box-shadow:0 10px 24px -10px rgba(14,138,67,.85);position:relative;z-index:1}
.adbn-t{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0;position:relative;z-index:1}
.adbn-t strong{color:#fff;font-size:17px;font-weight:700}
.adbn-t small{color:rgba(255,255,255,.62);font-size:13px}
.adbn-cta{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;font-weight:600;font-size:14px;color:#fff;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:11px 18px;border-radius:999px;transition:background .2s;position:relative;z-index:1;white-space:nowrap}
.adbn-cta .ti{transition:transform .2s}
.adbn-ph:hover .adbn-cta{background:rgba(255,255,255,.2)}
.adbn-ph:hover .adbn-cta .ti{transform:translateX(3px)}
@media(max-width:640px){.adbn-ph{flex-direction:column;text-align:center;padding:24px 20px}.adbn-t{align-items:center}}


/* === brand logo (old green wordmark) === */
.logo{gap:0}
.logo img{height:50px;width:auto;display:block}
.logo .logo-c{display:none}
.nav.scrolled .logo .logo-w{display:none}
.nav.scrolled .logo .logo-c{display:block}
@media(max-width:520px){.logo img{height:40px}}
