:root{
  --container: 1200px;
  --container-pad: 20px;

  --bg:#0b1220; --bg2:#0f172a;
  --t:#0f172a; --m:#475569;
  --b1:#7c3aed; --b2:#22d3ee;
  --r:18px;
  --sh:0 22px 55px rgba(2,6,23,.18);
  --sh2:0 12px 34px rgba(2,6,23,.10);
  --w:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
:target{scroll-margin-top:92px}
section{scroll-margin-top:92px}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;color:var(--t);background:#f8fafc}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{
  width: 100%;
  max-width: var(--container);
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-pad);
  padding-right: var(--container-pad);
}

/* Top bar */
.topbar{
  background:linear-gradient(90deg,rgba(124,58,237,.12),rgba(34,211,238,.10));
  border-bottom:1px solid rgba(226,232,240,.9);
  font-size:13px
}
.topbar .inner{display:flex;gap:18px;align-items:center;justify-content:space-between;padding:10px 0;flex-wrap:wrap}
.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.78);border:1px solid rgba(226,232,240,.92);box-shadow:0 6px 18px rgba(2,6,23,.06)}
.pill svg{width:16px;height:16px}

/* Nav */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(248,250,252,.72);
  backdrop-filter:blur(18px);
  border-bottom:1px solid rgba(226,232,240,.9)
}
.nav .inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:16px}
.brand{display:flex;align-items:center;gap:12px;min-width:200px}
.brand img{height:44px;width:auto}
.navlinks{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.navlinks a,.navlinks button.lang{
  font-size:14px;font-weight:750;padding:10px 12px;border-radius:12px
}
.navlinks a:hover,.navlinks button.lang:hover{background:rgba(124,58,237,.08)}
.navlinks .cta{
  background:linear-gradient(135deg,var(--b1),var(--b2));
  color:#fff; box-shadow:var(--sh2)
}
.lang{
  border:1px solid rgba(226,232,240,.95);
  background:rgba(255,255,255,.75);
  cursor:pointer;display:inline-flex;align-items:center;gap:8px
}
.lang .dot{width:8px;height:8px;border-radius:99px;background:linear-gradient(135deg,var(--b1),var(--b2))}
.lang strong{font-weight:900}
.dropdown{position:relative}

/* Mega menu */
.dropdown>a::after{content:"▾";margin-left:6px;font-size:12px;opacity:.8}
.megamenu{
  position:absolute;top:44px;left:-120px;width:min(720px,calc(100vw - 40px));
  background:rgba(255,255,255,.96);
  border:1px solid rgba(226,232,240,.95);
  border-radius:18px;box-shadow:var(--sh);
  padding:14px;display:none
}
.dropdown:hover .megamenu{display:block}
.mega-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:14px}
.mega-left{
  border:1px solid rgba(226,232,240,.95);
  border-radius:16px;
  background:linear-gradient(180deg,rgba(124,58,237,.10),rgba(34,211,238,.08));
  padding:14px
}
.mega-left h4{margin:0 0 6px;font-size:14px;letter-spacing:.02em;text-transform:uppercase}
.mega-left p{margin:0;color:var(--m);line-height:1.7}
.mega-items{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.mega-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:12px;border-radius:16px;border:1px solid rgba(226,232,240,.95);
  background:rgba(255,255,255,.85);
  transition:transform .18s ease, box-shadow .18s ease
}
.mega-item:hover{transform:translateY(-2px);box-shadow:0 18px 40px rgba(2,6,23,.12)}
.mega-item .ico{
  width:42px;height:42px;border-radius:14px;
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(226,232,240,.95);
  background:linear-gradient(135deg,rgba(124,58,237,.18),rgba(34,211,238,.14))
}
.mega-item svg{width:22px;height:22px}
.mega-item b{display:block}
.mega-item small{display:block;color:var(--m);margin-top:4px;font-weight:700;line-height:1.5}

/* Mobile */
.mobile-toggle{display:none;width:44px;height:44px;border:1px solid rgba(226,232,240,.95);background:rgba(255,255,255,.75);border-radius:14px;cursor:pointer}
.mobile-menu{display:none;padding:12px 0 18px}
.mobile-menu a{display:block;padding:10px 12px;border-radius:12px;font-weight:900}
.mobile-menu a:hover{background:rgba(124,58,237,.08)}
.mobile-menu .grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* Hero (WOW + particles canvas) */
.hero{
  position:relative;overflow:hidden;
  background:
    radial-gradient(1200px 700px at 20% 20%,rgba(124,58,237,.30),transparent 55%),
    radial-gradient(1000px 600px at 80% 70%,rgba(34,211,238,.28),transparent 55%),
    linear-gradient(180deg,#070b14,#0f172a 62%,#070b14);
  color:#e5e7eb
}
.hero::before{
  content:""; position:absolute; inset:-40%;
  background:conic-gradient(from 180deg at 50% 50%, rgba(124,58,237,.22), rgba(34,211,238,.16), rgba(124,58,237,.18));
  filter:blur(60px);
  animation:spin 16s linear infinite;
  opacity:.52;
}
@keyframes spin{to{transform:rotate(360deg)}}
.hero::after{
  content:""; position:absolute; inset:0;
  background-image:radial-gradient(rgba(255,255,255,.13) 1px, transparent 1px);
  background-size:28px 28px;
  opacity:.07; pointer-events:none;
}
.hero canvas#fx{
  position:absolute; inset:0; width:100%; height:100%;
  opacity:.55; pointer-events:none; mix-blend-mode:screen;
}
.hero .inner{
  display:grid;grid-template-columns:1.05fr .95fr;gap:26px;align-items:center;
  padding:78px 0 22px;position:relative;z-index:1
}
.kicker{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:999px;
  border:1px solid rgba(148,163,184,.22);
  background:rgba(15,23,42,.50);
  width:fit-content;font-weight:850;color:#e2e8f0
}
.kicker .spark{width:10px;height:10px;border-radius:99px;background:linear-gradient(135deg,var(--b1),var(--b2));box-shadow:0 0 0 6px rgba(124,58,237,.16)}
.hero h1{margin:14px 0 10px;font-size:clamp(34px,4vw,54px);line-height:1.03;letter-spacing:-.035em}
.hero p{margin:0 0 18px;font-size:16px;line-height:1.7;color:#cbd5e1;max-width:60ch}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:14px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid rgba(148,163,184,.22);
  background:rgba(15,23,42,.50);
  color:#e2e8f0;font-weight:950;
  box-shadow:0 16px 55px rgba(2,6,23,.28);
  transition:transform .15s ease, filter .15s ease
}
.btn.primary{border:none;background:linear-gradient(135deg,var(--b1),var(--b2));color:#fff}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}
.btn:active{transform:translateY(0)}
.hero .meta{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:22px}
.stat{
  background:rgba(15,23,42,.52);
  border:1px solid rgba(148,163,184,.18);
  border-radius:16px;padding:14px;
  box-shadow:0 18px 55px rgba(2,6,23,.25)
}
.stat .n{font-size:18px;font-weight:950}
.stat .t{font-size:12px;color:#cbd5e1;font-weight:750;margin-top:6px}
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center}
.hero-visual img{width:min(520px,100%);height:auto;filter:drop-shadow(0 34px 74px rgba(2,6,23,.62));transform:translateY(6px)}

/* Tech carousel */
.hero-tech{
  margin-top:28px;
  border-radius:18px;
  border:1px solid rgba(148,163,184,.18);
  background:rgba(2,6,23,.28);
  overflow:hidden;
  box-shadow:0 22px 70px rgba(2,6,23,.35)
}
.hero-tech .cap{
  padding:12px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:10px;
  border-bottom:1px solid rgba(148,163,184,.14);
  color:#cbd5e1;font-weight:850;font-size:13px
}
.marquee{
  overflow:hidden;
  position:relative;
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
  mask-image:linear-gradient(90deg, transparent, #000 6%, #000 94%, transparent);
}
.marquee:hover .track{animation-play-state:paused}
.track{
  display:flex;gap:14px;align-items:center;
  width:max-content;
  padding:14px;
  animation:mar 26s linear infinite;
}
.track.fast{animation-duration:20s}

.track.slow{animation-duration:34s}
.track.xslow{animation-duration:46s}
.track.reverse{animation-direction:reverse}

.tlogo{
  display:block;
  height:28px;width:auto;
  border-radius:14px;
  padding:8px 12px;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(226,232,240,.92);
  box-shadow:
    0 16px 46px rgba(2,6,23,.16),
    inset 0 1px 0 rgba(255,255,255,.75);
  filter:grayscale(1) saturate(0) brightness(.92);
  opacity:.92;
  transform:translate3d(0,0,0);
  transition:
    transform .22s ease,
    filter .25s ease,
    opacity .25s ease,
    box-shadow .25s ease,
    background .25s ease;
  will-change:transform;
}
.tlogo:hover{
  transform:translate3d(0,-2px,0);
  filter:none;
  opacity:1;
  background:rgba(255,255,255,.92);
  box-shadow:
    0 24px 70px rgba(2,6,23,.20),
    inset 0 1px 0 rgba(255,255,255,.78);
}
.hero-tech .marquee + .marquee{border-top:1px solid rgba(148,163,184,.10)}
@media (max-width: 640px){
  
.tlogo.badge{
  height:48px;
  padding:8px 10px;
  filter:none;
  opacity:1;
}
.tlogo:hover{
  filter:none;
  opacity:1;
  transform:translate3d(0,-2px,0) scale(1.03);
  box-shadow:
    0 26px 85px rgba(2,6,23,.22),
    0 0 0 1px rgba(124,58,237,.20),
    0 0 0 8px rgba(124,58,237,.08);
  background:rgba(255,255,255,.86);
}

  .track{gap:12px;padding:12px}
}

@keyframes mar{to{transform:translate3d(-50%,0,0)}}}
.tlogo{
  height:56px;width:auto;border-radius:16px;
  background:rgba(255,255,255,.92);
  border:1px solid rgba(226,232,240,.92);
  box-shadow:0 14px 36px rgba(2,6,23,.28)
}



/* Mini tech stacks inside service cards */
.mini-stack{
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(148,163,184,.14);
}
.mini-title{
  display:flex;align-items:center;gap:10px;
  font-weight:950;
  font-size:12px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:rgba(15,23,42,.72);
  margin-bottom:10px;
}
.mini-title:before{
  content:"";
  width:8px;height:8px;border-radius:999px;
  background:linear-gradient(90deg,var(--a),var(--b));
  box-shadow:0 0 0 4px rgba(124,58,237,.12);
}
.mini-row{margin-top:10px}
.mini-cap{
  font-size:12px;
  color:var(--m);
  margin:0 0 6px;
  font-weight:750;
}
.mini-marquee{
  border:1px solid rgba(226,232,240,.92);
  border-radius:16px;
  background:rgba(255,255,255,.70);
}
.mini-marquee .track{padding:10px 12px;gap:12px}
.mini-marquee .tlogo{
  height:42px;border-radius:14px;
  box-shadow:0 10px 26px rgba(2,6,23,.14);
}
@media (max-width: 980px){
  .mini-marquee .tlogo{height:38px}
}
@media (max-width: 640px){
  .mini-title{margin-bottom:8px}
  .mini-cap{font-size:11px}
  .mini-marquee .tlogo{height:36px;border-radius:12px}
}

/* Stack groups (services) */
.stack-head{margin-top:26px}
.stack-title{margin:10px 0 6px;font-size:clamp(18px,2vw,22px);letter-spacing:-.01em}
.stack-sub{margin:0;color:var(--m);max-width:84ch;line-height:1.7}

.stack-groups{display:flex;flex-direction:column;gap:14px;margin-top:16px}
.stack-group{
  border:1px solid rgba(226,232,240,.95);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(248,250,252,.92));
  box-shadow:0 18px 44px rgba(2,6,23,.08);
  overflow:hidden;
}
.stack-h{
  display:flex;align-items:flex-end;justify-content:space-between;gap:14px;
  padding:14px 16px 6px 16px;
}
.stack-k{font-weight:950;letter-spacing:-.01em}
.stack-d{color:var(--m);font-size:13px;margin-top:2px}
.stack-marquee{border-top:1px solid rgba(148,163,184,.12)}
.stack-marquee .track{padding:12px 14px}
.stack-grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width: 980px){
  .stack-grid2{grid-template-columns:1fr}
}

/* Sections */
.section{padding:70px 0}
.head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:26px}
h2{margin:0;font-size:clamp(24px,2.8vw,34px);letter-spacing:-.02em}
.sub{margin:0;color:var(--m);max-width:74ch;line-height:1.7}
.badge{display:inline-flex;align-items:center;gap:10px;padding:8px 12px;border-radius:999px;border:1px solid rgba(226,232,240,.9);background:rgba(255,255,255,.72);box-shadow:0 12px 34px rgba(2,6,23,.06);font-weight:950;font-size:13px}
.badge .dot{width:10px;height:10px;border-radius:99px;background:linear-gradient(135deg,var(--b1),var(--b2))}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

/* Tilt cards + neon border */
.tilt{transform-style:preserve-3d; perspective:900px}
.card{
  background:#fff;border:1px solid rgba(226,232,240,.95);
  border-radius:var(--r);box-shadow:var(--sh2);
  padding:18px;position:relative;overflow:hidden;
  transition:transform .18s ease, box-shadow .18s ease
}
.card::before{
  content:""; position:absolute; inset:-2px;
  background:linear-gradient(135deg,rgba(124,58,237,.0),rgba(34,211,238,.12),rgba(124,58,237,.0));
  opacity:.0; transition:opacity .18s ease;
}
.card::after{
  content:""; position:absolute; inset:-2px;
  background:conic-gradient(from 120deg, rgba(124,58,237,.0), rgba(34,211,238,.35), rgba(124,58,237,.0));
  opacity:0; filter:blur(14px);
  transition:opacity .18s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh)}
.card:hover::before{opacity:1}
.card:hover::after{opacity:.35}
.card .icon,.card h3,.card p,.card ul,.card .price,.card .link{position:relative;z-index:1}
.icon{
  width:46px;height:46px;border-radius:16px;
  background:linear-gradient(135deg,rgba(124,58,237,.16),rgba(34,211,238,.16));
  display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(226,232,240,.95);margin-bottom:10px
}
.icon svg{width:24px;height:24px}
.card h3{margin:10px 0 6px;font-size:18px}
.card p{margin:0;color:var(--m);line-height:1.6}
.card ul{margin:12px 0 0;padding-left:18px;color:#334155;line-height:1.7;font-weight:700}
.price{margin-top:14px;display:flex;align-items:baseline;gap:8px}
.price b{font-size:22px}
.link{margin-top:14px;display:inline-flex;gap:10px;align-items:center;font-weight:950}
.link svg{width:16px;height:16px}

.split{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.panel{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:var(--r);box-shadow:var(--sh2);padding:18px;overflow:hidden}
.panel.dark{background:linear-gradient(180deg,#070b14,#0f172a);color:#e5e7eb;border:1px solid rgba(148,163,184,.18)}
.panel.dark .muted{color:#cbd5e1}
.muted{color:var(--m);line-height:1.7}

.pricing{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.plan{background:#fff;border:1px solid rgba(226,232,240,.95);border-radius:var(--r);box-shadow:var(--sh2);padding:18px;position:relative;overflow:hidden}
.plan.featured{border:1px solid rgba(124,58,237,.35);box-shadow:0 32px 75px rgba(124,58,237,.18);transform:translateY(-6px)}
.tag{position:absolute;top:16px;right:16px;background:linear-gradient(135deg,var(--b1),var(--b2));color:#fff;padding:6px 10px;border-radius:999px;font-weight:950;font-size:12px}
.big{margin:10px 0 6px;font-size:36px;font-weight:950;letter-spacing:-.03em}
.big small{font-size:13px;font-weight:850;color:var(--m)}
.plan ul{line-height:1.7;font-weight:750;color:#334155}
.plan .cta a{display:inline-flex;margin-top:12px;padding:12px 14px;border-radius:14px;background:linear-gradient(135deg,var(--b1),var(--b2));color:#fff;font-weight:950}

/* Compare table */
.table-wrap{
  border-radius:18px; overflow:hidden;
  border:1px solid rgba(226,232,240,.95);
  box-shadow:0 20px 60px rgba(2,6,23,.10);
  background:#fff
}
table.compare{width:100%;border-collapse:separate;border-spacing:0}
table.compare th, table.compare td{padding:14px 14px;border-bottom:1px solid rgba(226,232,240,.95);vertical-align:middle}
table.compare th{background:linear-gradient(180deg,rgba(124,58,237,.10),rgba(34,211,238,.08));text-align:left;font-size:13px;text-transform:uppercase;letter-spacing:.02em}
table.compare td{font-weight:750;color:#334155}
table.compare td.ok{color:#0f172a}
table.compare td.muted{color:#64748b}
table.compare tr:last-child td{border-bottom:none}
table.compare .col-pro{background:rgba(124,58,237,.05)}
table.compare .col-prem{background:rgba(34,211,238,.05)}
.check{display:inline-flex;align-items:center;gap:8px}
.check svg{width:18px;height:18px}

/* Cases */
.cases{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.case{
  background:#fff;border:1px solid rgba(226,232,240,.95);
  border-radius:18px;box-shadow:var(--sh2);padding:18px;position:relative;overflow:hidden
}
.case::before{
  content:""; position:absolute; inset:-2px;
  background:radial-gradient(380px 160px at 20% 20%, rgba(124,58,237,.16), transparent 60%),
             radial-gradient(320px 140px at 80% 60%, rgba(34,211,238,.14), transparent 60%);
  opacity:1;
}
.case h3,.case p,.case .metrics{position:relative;z-index:1}
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}
.metric{padding:12px;border-radius:16px;border:1px solid rgba(226,232,240,.95);background:rgba(255,255,255,.72);font-weight:950}
.metric small{display:block;margin-top:6px;color:#64748b;font-weight:750}

/* Footer */
.footer{padding:50px 0 28px;background:#070b14;color:#e2e8f0}
.footer .grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:18px}
.footer a{color:#e2e8f0;opacity:.92}
.footer a:hover{opacity:1}
.footer h4{margin:0 0 10px;font-size:14px;letter-spacing:.02em;text-transform:uppercase;opacity:.9}
.footer p{margin:0;color:#cbd5e1;line-height:1.75}
.small{margin-top:20px;border-top:1px solid rgba(148,163,184,.18);padding-top:18px;font-size:12px;color:#94a3b8;display:flex;justify-content:space-between;gap:10px;flex-wrap:wrap}

/* Help drawer */
.help-fab{position:fixed;right:18px;bottom:18px;z-index:90;display:flex;gap:10px;align-items:center}
.help-fab button{display:inline-flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;border:none;cursor:pointer;color:#fff;background:linear-gradient(135deg,var(--b1),var(--b2));box-shadow:0 22px 60px rgba(124,58,237,.25);font-weight:950}
.help-drawer{position:fixed;right:18px;bottom:74px;width:min(420px,calc(100% - 36px));border-radius:18px;background:rgba(255,255,255,.96);border:1px solid rgba(226,232,240,.95);box-shadow:var(--sh);z-index:90;overflow:hidden;display:none}
.help-drawer.open{display:block;animation:pop .14s ease-out}
@keyframes pop{from{transform:translateY(10px);opacity:0}to{transform:translateY(0);opacity:1}}
.help-drawer header{padding:14px;border-bottom:1px solid rgba(226,232,240,.95);display:flex;justify-content:space-between;align-items:center;gap:10px}
.help-drawer header b{font-weight:950}
.help-drawer header button{width:36px;height:36px;border-radius:12px;border:1px solid rgba(226,232,240,.95);background:rgba(15,23,42,.02);cursor:pointer}
.help-drawer .body{padding:14px}
.help-drawer input{width:100%;padding:12px;border-radius:14px;border:1px solid rgba(226,232,240,.95);outline:none;font-weight:750}
.help-drawer .links{margin-top:12px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.help-drawer .links a{padding:12px;border-radius:14px;border:1px solid rgba(226,232,240,.95);background:rgba(15,23,42,.02);font-weight:950}
.help-drawer .links small{display:block;margin-top:6px;color:var(--m);font-weight:750}
.help-drawer .foot{padding:12px 14px;border-top:1px solid rgba(226,232,240,.95);background:rgba(248,250,252,.92);color:var(--t)}
.help-drawer .foot a{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:12px 14px;border-radius:14px;font-weight:950;color:#fff;background:linear-gradient(135deg,var(--b1),var(--b2))}

[data-animate]{opacity:0;transform:translateY(14px) scale(.992);filter:blur(10px);transition:opacity .70s ease,transform .70s ease,filter .70s ease}
[data-animate].in{opacity:1;transform:translateY(0) scale(1);filter:none}

/* Responsive */
@media(max-width:1020px){
  .hero .inner{grid-template-columns:1fr;padding:58px 0 18px}
  .hero-visual{order:-1}
  .hero .meta{grid-template-columns:1fr}
  .grid3,.pricing,.cases{grid-template-columns:1fr}
  .split{grid-template-columns:1fr}
  .footer .grid{grid-template-columns:1fr}
  .navlinks{display:none}
  .mobile-toggle{display:inline-flex;align-items:center;justify-content:center}
  .mobile-menu.open{display:block}
  .megamenu{display:none !important}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  [data-animate]{transition:none;opacity:1;transform:none}
  .track{animation:none}
  .btn:hover,.card:hover,.tlogo:hover{transform:none}
  .hero::before{animation:none}
  .hero canvas#fx{display:none}
}


/* Footer: hosting partners strip */
.footer-partners{
  margin-top:18px;
  padding:14px 16px;
  border:1px solid rgba(148,163,184,.18);
  border-radius:18px;
  background:rgba(255,255,255,.04);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}
.footer-partners .cap{
  font-size:12px;
  text-transform:uppercase;
  letter-spacing:.10em;
  font-weight:900;
  color:#cbd5e1;
  opacity:.92;
}
.footer-partners .logos{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.footer-partners .logos a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:8px 10px;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.16);
  background:rgba(255,255,255,.06);
  transition:background .2s ease, border-color .2s ease, transform .2s ease;
}
.footer-partners .logos a:hover{
  background:rgba(255,255,255,.10);
  border-color:rgba(148,163,184,.26);
  transform:translateY(-1px);
}
.footer-partners .logos img{
  height:26px;
  width:auto;
  display:block;
  opacity:.96;
}



/* Logos page */
.logo-list{
  list-style:none;
  padding:0;
  margin:0;
  display:grid;
  gap:12px;
}
.logo-list li{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:14px;
  border-top:1px solid rgba(148,163,184,.14);
  padding-top:12px;
}
.logo-list li:first-child{
  border-top:0;
  padding-top:0;
}
.logo-list .name{
  font-weight:900;
  letter-spacing:.01em;
}
.logo-list .links{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  font-size:13px;
  opacity:.92;
  text-align:right;
}
.logo-list .links a{
  text-decoration:none;
}
.logo-list .links a:hover{
  text-decoration:underline;
}



/* Stack bands under offers (premium logo carousel) */
.stack-band{
  margin-top:18px;
  border:1px solid rgba(226,232,240,.92);
  border-radius:22px;
  background:rgba(255,255,255,.70);
  backdrop-filter: blur(10px);
  box-shadow: 0 22px 60px rgba(2,6,23,.12);
  padding:14px 14px 6px;
}
.stack-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:16px;
  padding:4px 6px 10px;
}
.stack-title{
  font-weight:950;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:12px;
  color:rgba(15,23,42,.72);
  display:flex;align-items:center;gap:10px;
}
.stack-title:before{
  content:"";
  width:8px;height:8px;border-radius:999px;
  background:linear-gradient(90deg,var(--a),var(--b));
  box-shadow:0 0 0 4px rgba(124,58,237,.12);
}
.stack-sub{
  font-size:12px;
  color:rgba(15,23,42,.55);
  font-weight:650;
  white-space:nowrap;
}
.stack-rows{display:flex;flex-direction:column;gap:10px}
.stack-row{display:flex;flex-direction:column;gap:6px}
.stack-cap{
  font-size:12px;
  color:var(--m);
  font-weight:750;
  margin:0 0 0 6px;
}
.stack-marquee{
  border:1px solid rgba(226,232,240,.85);
  border-radius:18px;
  background:rgba(255,255,255,.66);
}
.stack-marquee .track{padding:10px 12px;gap:12px}
.stack-band .tlogo{
  height:44px;
  border-radius:14px;
  box-shadow:0 12px 28px rgba(2,6,23,.14);
}
@media (max-width: 640px){
  .stack-band{padding:12px 12px 6px}
  .stack-band .tlogo{height:40px}
  .stack-sub{display:none}
}


/* v10 premium polish */
.stack-band{
  border-radius:24px;
  position:relative;
  overflow:hidden;
  background:rgba(255,255,255,.58);
  border:1px solid rgba(226,232,240,.92);
  box-shadow: 0 28px 95px rgba(2,6,23,.14);
  backdrop-filter: blur(12px);
}
.stack-band:before{
  content:"";
  position:absolute;inset:-2px;
  background:linear-gradient(90deg,rgba(124,58,237,.0),rgba(124,58,237,.18),rgba(34,211,238,.16),rgba(124,58,237,.0));
  transform:translateX(-45%);
  opacity:.55;
  pointer-events:none;
  filter:blur(16px);
}
.stack-band:hover:before{animation:shine 2.8s ease-in-out infinite}
@keyframes shine{50%{transform:translateX(45%)}}

.stack-marquee{
  background:rgba(255,255,255,.50);
  border-radius:20px;
  overflow:hidden;
}

.track{will-change:transform;transform:translate3d(0,0,0)}

.tbadge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:28px;
  padding:0 12px;
  border-radius:14px;
  background:rgba(255,255,255,.74);
  border:1px solid rgba(226,232,240,.92);
  box-shadow:
    0 16px 46px rgba(2,6,23,.16),
    inset 0 1px 0 rgba(255,255,255,.75);
  font-weight:850;
  letter-spacing:.02em;
  color:rgba(15,23,42,.86);
  white-space:nowrap;
  transition:transform .22s ease, background .25s ease, box-shadow .25s ease, color .25s ease;
}
.tbadge:hover{
  transform:translate3d(0,-2px,0);
  background:rgba(255,255,255,.92);
  color:rgba(15,23,42,1);
  box-shadow:
    0 24px 70px rgba(2,6,23,.20),
    inset 0 1px 0 rgba(255,255,255,.78);
}

.stack-marquee.compact .track{padding:10px 10px;gap:10px}
.stack-band.compact{padding:12px 12px 8px}
.stack-rows.compact{gap:10px}
.stack-cap{margin:0 0 0 4px}

@media (max-width: 640px){
  .tlogo{height:26px;padding:7px 10px;border-radius:13px}
  .tbadge{height:26px;padding:0 10px;border-radius:13px}
  .track{padding:10px;gap:10px}
  .stack-band{margin-top:14px}
}


/* Domain search (premium) */
.domain-card{
  border:1px solid rgba(226,232,240,.92);
  border-radius:22px;
  background:rgba(255,255,255,.78);
  backdrop-filter: blur(12px);
  box-shadow: 0 26px 70px rgba(2,6,23,.12);
  padding:16px;
}
.domain-form{
  display:flex;
  gap:10px;
  align-items:center;
}
.domain-form input{
  flex:1;
  padding:14px 16px;
  border-radius:16px;
  border:1px solid rgba(226,232,240,.95);
  background:rgba(255,255,255,.92);
  font-weight:800;
  outline:none;
}
.domain-form input:focus{
  border-color: rgba(124,58,237,.45);
  box-shadow: 0 0 0 6px rgba(124,58,237,.12);
}
.domain-hint{
  margin-top:10px;
  color: rgba(15,23,42,.62);
  font-size: 13px;
  font-weight: 650;
}
.domain-strip{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  border:1px solid rgba(226,232,240,.92);
  border-radius:22px;
  background:rgba(255,255,255,.72);
  padding:14px;
  box-shadow: 0 18px 46px rgba(2,6,23,.10);
}
.domain-strip-text{display:flex;flex-direction:column;gap:2px}
.domain-strip-text b{font-weight:950}
.domain-strip-text span{color:rgba(15,23,42,.60);font-weight:650;font-size:13px}
.domain-form.compact input{padding:12px 14px;border-radius:14px;font-weight:800;min-width:260px}
@media(max-width: 820px){
  .domain-form{flex-direction:column;align-items:stretch}
  .domain-form.compact input{min-width:unset}
  .domain-strip{flex-direction:column;align-items:stretch}
}


/* Domain results UI */
.domain-results{margin-top:14px;border-top:1px solid rgba(226,232,240,.85);padding-top:12px}
.domain-results-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}
.domain-results-title{font-weight:950;letter-spacing:.02em}
.domain-grid{display:grid;grid-template-columns:repeat(3, minmax(0,1fr));gap:10px}
.domain-item{
  border:1px solid rgba(226,232,240,.92);
  border-radius:18px;
  background:rgba(255,255,255,.75);
  padding:12px;
  display:flex;
  flex-direction:column;
  gap:6px;
  box-shadow: 0 16px 40px rgba(2,6,23,.08);
}
.domain-item .dname{font-weight:950}
.domain-item .dmeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:999px;
  font-weight:850;font-size:12px;
  border:1px solid rgba(226,232,240,.92);
  background:rgba(248,250,252,.92);
}
.pill.ok{border-color:rgba(34,197,94,.35);background:rgba(34,197,94,.10);color:rgba(15,23,42,.86)}
.pill.no{border-color:rgba(239,68,68,.35);background:rgba(239,68,68,.10);color:rgba(15,23,42,.86)}
.pill.premium{border-color:rgba(245,158,11,.35);background:rgba(245,158,11,.12);color:rgba(15,23,42,.86)}
.domain-item .price{color:rgba(15,23,42,.75);font-weight:850;font-size:13px}
.domain-note{margin-top:10px;color:rgba(15,23,42,.60);font-size:13px;font-weight:650}
.domain-error{margin-top:10px;border:1px solid rgba(239,68,68,.30);background:rgba(239,68,68,.08);border-radius:16px;padding:12px;font-weight:800;color:rgba(15,23,42,.85)}
.domain-banner{
  margin:12px 0 0;
  border:1px solid rgba(226,232,240,.92);
  border-radius:18px;
  background:rgba(255,255,255,.72);
  padding:12px 14px;
  box-shadow: 0 18px 46px rgba(2,6,23,.08);
  font-weight:850;
}
@media(max-width: 860px){
  .domain-grid{grid-template-columns:repeat(2, minmax(0,1fr))}
}
@media(max-width: 520px){
  .domain-grid{grid-template-columns:1fr}
}


/* === Premium width discipline (v16) === */
.section{padding-left:0;padding-right:0} /* container controls width */
.head .sub, .hero .sub, .section p.sub{max-width: 62ch}
.hero h1{max-width: 22ch}
.hero .cta-row{flex-wrap: wrap; gap: 12px}
.grid2, .grid3, .grid4{gap: 18px}
.card{border-radius: 22px}
.navbar .container{max-width: var(--container)}
.footer .container{max-width: var(--container)}

@media (min-width: 1280px){
  :root{ --container: 1200px; --container-pad: 22px; }
}
@media (max-width: 1024px){
  :root{ --container-pad: 18px; }
}
@media (max-width: 560px){
  :root{ --container-pad: 16px; }
  .hero h1{max-width: 16ch}
}


/* Carousels sizing: keep premium, not full-bleed */
.marquee, .logo-marquee, .stack-marquee{
  width: 100%;
  overflow: hidden;
}
.marquee .track, .logo-marquee .track, .stack-marquee .track{
  width: max-content;
}
.logo-pill, .logo-item, .stack-pill{
  height: 52px;
}
@media(max-width: 560px){
  .logo-pill, .logo-item, .stack-pill{height: 46px}
}


/* Ultra hardening: utilities (replacing inline styles) */
.op50{opacity:.5}
.op65{opacity:.65}
.op70{opacity:.7}
.op85fw{opacity:.85;font-weight:850}
.op90{opacity:.9}

.mt10{margin-top:10px}
.mt12{margin-top:12px}
.mt14{margin-top:14px}
.mt16{margin-top:16px}
.mt18{margin-top:18px}

.pt34{padding-top:34px}
.pt110{padding-top:110px}
.py26{padding-top:26px;padding-bottom:26px}
.pb0{padding-bottom:0}
.pt28{padding-top:28px}
.py54_28{padding-top:54px;padding-bottom:28px}

.row-center-gap10{display:flex;align-items:center;gap:10px}
.wrap-gap10{display:flex;gap:10px;flex-wrap:wrap}
.flex-end-gap10{display:flex;justify-content:flex-end;gap:10px}

.bg-glass65{background:rgba(255,255,255,.65)}
.bg-white-topline{background:#fff;border-top:1px solid rgba(226,232,240,.9)}
.bg-white-border{background:#fff;border-color:rgba(226,232,240,.95)}

.btn-reset{border:none;background:transparent;padding:0;cursor:pointer}
.icon32{width:32px;height:32px}
.logo-img{height:44px;width:auto;filter:brightness(1.1)}

.nav-active{color:#0f172a;border-bottom:1px solid rgba(226,232,240,.95)}
.section-soft{
  background:linear-gradient(180deg,rgba(124,58,237,.05),rgba(34,211,238,.03));
  border-top:1px solid rgba(226,232,240,.9);
  border-bottom:1px solid rgba(226,232,240,.9);
}

/* Form controls (no inline styles) */
.input-base,.textarea-base{
  padding:12px;
  border-radius:14px;
  border:1px solid rgba(226,232,240,.95);
  font-weight:750;
}
.textarea-base{resize:vertical}

.grid-gap10{display:grid;gap:10px}

.is-hidden{display:none !important}

.op75{opacity:.75}

/* Toast (demo feedback) */
.toast{
  position:fixed;
  left:50%;
  bottom:22px;
  transform:translateX(-50%) translateY(16px);
  opacity:0;
  z-index:9999;
  padding:12px 14px;
  border-radius:16px;
  border:1px solid rgba(226,232,240,.92);
  background:rgba(255,255,255,.82);
  box-shadow: 0 20px 60px rgba(2,6,23,.18);
  font-weight:850;
  max-width:min(560px, calc(100vw - 32px));
  text-align:center;
  transition: opacity .22s ease, transform .22s ease;
}
.toast.in{opacity:1; transform:translateX(-50%) translateY(0)}

/* CSS-only tilt for ultra CSP (no JS transforms) */
.tilt .card,.tilt .plan,.tilt .case,.tilt .panel{
  transition: transform .28s ease, box-shadow .28s ease;
}
.tilt:hover .card,.tilt:hover .plan,.tilt:hover .case,.tilt:hover .panel{
  transform: translateY(-3px) scale(1.01);
  box-shadow: 0 18px 46px rgba(2,6,23,.12);
}
@media (prefers-reduced-motion: reduce){
  .tilt .card,.tilt .plan,.tilt .case,.tilt .panel{transition:none}
  #fx{display:none !important}
}


/* Wide container (for portfolio/gallery pages) */
:root{
  --container-wide: 1400px;
}
.container--wide{
  max-width: var(--container-wide);
}

/* Full-bleed sections (background spans width, content stays in container) */
.section--fullbleed{
  position: relative;
}
.section--fullbleed::before{
  content:"";
  position:absolute;
  inset:0;
  background: var(--fullbleed-bg, transparent);
  border-top: var(--fullbleed-border-top, none);
  border-bottom: var(--fullbleed-border-bottom, none);
  pointer-events:none;
}
.section--fullbleed > .container,
.section--fullbleed > .container--wide{
  position: relative;
}

/* Portfolio */
.portfolio-filters{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:14px;
}
.filter-btn{
  border:1px solid rgba(226,232,240,.92);
  background:rgba(255,255,255,.75);
  border-radius:999px;
  padding:10px 14px;
  font-weight:900;
  letter-spacing:.01em;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.filter-btn[aria-pressed="true"]{
  border-color: rgba(124,58,237,.55);
  box-shadow: 0 10px 28px rgba(2,6,23,.10);
}
.filter-btn:hover{ transform: translateY(-1px); }

.portfolio-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:14px;
  margin-top:18px;
}
@media(max-width: 1100px){ .portfolio-grid{ grid-template-columns: repeat(3, minmax(0,1fr)); } }
@media(max-width: 820px){ .portfolio-grid{ grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media(max-width: 520px){ .portfolio-grid{ grid-template-columns: 1fr; } }

.portfolio-item{
  width:100%;
  text-align:left;
  border:1px solid rgba(226,232,240,.92);
  border-radius:22px;
  background:rgba(255,255,255,.78);
  box-shadow: 0 18px 48px rgba(2,6,23,.08);
  overflow:hidden;
  cursor:pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  display:flex;
  flex-direction:column;
}
.portfolio-item:hover{
  transform: translateY(-2px);
  box-shadow: 0 28px 70px rgba(2,6,23,.12);
  border-color: rgba(124,58,237,.35);
}
.portfolio-item img{
  width:100%;
  height: 170px;
  object-fit: cover;
  display:block;
}
.pi-meta{ padding:12px 14px 14px; display:flex; flex-direction:column; gap:6px; }
.pi-title{ font-weight:950; }
.pi-desc{ color: rgba(15,23,42,.62); font-weight:700; font-size:13px; line-height:1.3; }
.pi-tags{ display:flex; gap:8px; flex-wrap:wrap; }

/* Lightbox */
.lightbox{
  border: none;
  padding: 0;
  width: min(980px, calc(100vw - 32px));
  border-radius: 26px;
  background: rgba(255,255,255,.92);
  box-shadow: 0 40px 120px rgba(2,6,23,.30);
}
.lightbox::backdrop{
  background: rgba(2,6,23,.62);
  backdrop-filter: blur(6px);
}
.lightbox-inner{ display:grid; grid-template-columns: 1.1fr .9fr; gap:0; }
@media(max-width: 900px){ .lightbox-inner{ grid-template-columns: 1fr; } }
.lightbox-media{ padding:14px; }
.lightbox-media img{ width:100%; height:auto; border-radius:18px; border:1px solid rgba(226,232,240,.92); background: rgba(248,250,252,.9); }
.lightbox-side{ padding:18px 18px 22px; border-left:1px solid rgba(226,232,240,.92); }
@media(max-width: 900px){ .lightbox-side{ border-left:none; border-top:1px solid rgba(226,232,240,.92);} }
.lightbox-close{
  position:absolute;
  top:12px;
  right:12px;
  width:42px;height:42px;
  border-radius:14px;
  border:1px solid rgba(226,232,240,.92);
  background:rgba(255,255,255,.82);
  cursor:pointer;
  display:grid;place-items:center;
  box-shadow: 0 10px 28px rgba(2,6,23,.10);
}
.lightbox-close svg{ width:20px; height:20px; }

/* Graphic design full-width offer */
.section--design{
  --fullbleed-bg: linear-gradient(180deg, rgba(124,58,237,.06), rgba(34,211,238,.03));
  --fullbleed-border-top: 1px solid rgba(226,232,240,.92);
  --fullbleed-border-bottom: 1px solid rgba(226,232,240,.92);
}
.design-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap:14px;
  margin-top: 16px;
}
@media(max-width: 960px){ .design-grid{ grid-template-columns: 1fr; } }

/* Realizations preview strip on homepage */
.preview-strip{
  display:flex;
  gap:12px;
  overflow:auto;
  padding: 6px 2px 10px;
  scroll-snap-type: x mandatory;
}
.preview-strip::-webkit-scrollbar{ height: 10px; }
.preview-card{
  min-width: 240px;
  scroll-snap-align: start;
  border:1px solid rgba(226,232,240,.92);
  border-radius:20px;
  background:rgba(255,255,255,.78);
  box-shadow: 0 16px 44px rgba(2,6,23,.08);
  overflow:hidden;
}
.preview-card img{ width:100%; height: 140px; object-fit:cover; display:block; }
.preview-card .meta{ padding:10px 12px 12px; display:flex; flex-direction:column; gap:4px; }
.preview-card .meta b{ font-weight:950; }
.preview-card .meta span{ color: rgba(15,23,42,.62); font-weight:700; font-size:12px; }


/* Realizations page helpers (no inline) */
.section--portfolio-bg{
  --fullbleed-bg: linear-gradient(180deg, rgba(2,6,23,.02), rgba(2,6,23,0));
}
.real-actions{margin-top:18px;display:flex;justify-content:flex-end;}
.lb-title{margin:0;font-weight:1000;}
.lb-desc{margin-top:10px;color:rgba(15,23,42,.68);font-weight:750;line-height:1.45;}
.lb-pills{margin-top:16px;display:flex;gap:10px;flex-wrap:wrap;}
.lb-cta{margin-top:18px;}


.section--portfolio-preview{
  --fullbleed-bg: linear-gradient(180deg, rgba(2,6,23,.02), rgba(2,6,23,0));
  --fullbleed-border-top: 1px solid rgba(226,232,240,.92);
}

.icon img{width:24px;height:24px}


/* SEO & marketing section */
.section--seo{background:linear-gradient(180deg,rgba(15,23,42,.04),rgba(255,255,255,0));padding:72px 0}
.checks{margin:14px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.checks li{position:relative;padding-left:30px;color:#0f172a;font-weight:800;line-height:1.55}
.checks li:before{content:"";position:absolute;left:0;top:.35em;width:18px;height:18px;border-radius:8px;background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(34,211,238,.25));border:1px solid rgba(226,232,240,.95)}
.faq{border:1px solid rgba(226,232,240,.95);border-radius:18px;padding:14px 14px;background:#fff;box-shadow:var(--shadow);margin-top:12px}
.faq summary{cursor:pointer;font-weight:950;color:#0f172a;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq-body{margin-top:10px;color:var(--m);line-height:1.7}
.cta-row{margin-top:20px;display:flex;gap:12px;flex-wrap:wrap}
