/* ============================================================
   SEO Soar — shared site stylesheet (Ultraviolet brand)
   Used by every page. Header/footer markup is injected by site.js.
   ============================================================ */
:root{
  --uv-1:#2563EB; --uv-2:#7c3aed; --uv-3:#9333EA;
  --uv-grad:linear-gradient(120deg,#2563EB,#7c3aed,#9333EA);
  --soft-uv:linear-gradient(120deg,#7AA2FF,#C084FC);
  --bg:#07060f; --panel:#0f0d20; --panel2:#14122a;
  --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.15);
  --text:#e7e6f5; --muted:#9c9ab8; --lav:#a78bfa;
  --good:#34d399; --warn:#fbbf24; --bad:#fb7185;
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:"Inter",-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* grain (premium anti-banding) */
body::after{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
h1,h2,h3,h4{margin:0;font-weight:800;letter-spacing:-.02em;color:#fff;line-height:1.12}
p{margin:0}
a{color:inherit;text-decoration:none}
h2 a,h3 a{transition:color .15s}
h2 a:hover,h3 a:hover{color:var(--lav)}
img{max-width:100%}

/* ---- utilities ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.eyebrow{text-transform:uppercase;letter-spacing:4px;font-size:12px;font-weight:800;color:var(--lav)}
.grad{background:var(--soft-uv);-webkit-background-clip:text;background-clip:text;color:transparent}
.muted{color:var(--muted)}
.center{text-align:center}
section{padding:90px 0;position:relative}
.band{background:linear-gradient(180deg,#0c0a1c,#08071260);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{max-width:720px;margin-bottom:42px}
.sec-head.center{margin-left:auto;margin-right:auto}
.sec-head h2{font-size:clamp(28px,4vw,44px)}
.sec-head p{color:var(--muted);font-size:18px;margin-top:14px}
.glow{position:absolute;border-radius:50%;filter:blur(20px);z-index:0;pointer-events:none}
.glass{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:18px;backdrop-filter:blur(12px);position:relative}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 22px;border-radius:12px;font-weight:700;
  font-size:15px;border:1px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .15s}
.btn-primary{background:var(--uv-grad);color:#fff;box-shadow:0 8px 30px rgba(124,58,237,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 38px rgba(124,58,237,.5)}
.btn-ghost{background:rgba(255,255,255,.05);border-color:var(--line2);color:#fff}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-lg{font-size:17px;padding:16px 30px}

/* ============ HEADER + MEGA MENU ============ */
header.site{position:sticky;top:0;z-index:200;backdrop-filter:blur(14px);
  background:rgba(7,6,15,.8);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{display:flex;flex-direction:column;align-items:center;gap:4px;line-height:1}
.logo .bird{height:30px;width:auto;aspect-ratio:920/470;flex:none;display:block;max-width:none}
.logo .wm{font-size:11px;font-weight:800;letter-spacing:3px;word-spacing:3px;white-space:nowrap;background:var(--uv-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.menu{display:flex;align-items:center;gap:2px}
.menu>a{display:flex;align-items:center;gap:6px;padding:10px 15px;border-radius:10px;font-size:15px;
  font-weight:600;color:#cfcce6;cursor:pointer}
.menu>a:hover,.menu>a.on{color:#fff;background:rgba(255,255,255,.05)}
.menu>a.has::after{content:"";width:7px;height:7px;border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;transform:rotate(45deg) translateY(-2px);opacity:.7}
.nav-cta{display:flex;align-items:center;gap:14px}
.nav-cta .phone{font-size:14px;color:var(--muted);font-weight:600;text-decoration:none}
.btn-call{display:none;width:44px;height:44px;border-radius:11px;border:0;background:linear-gradient(135deg,#2563EB,#9333EA);color:#fff;align-items:center;justify-content:center;box-shadow:0 6px 18px rgba(124,58,237,.4)}
header.site .nav{transition:height .22s ease}
header.site.shrink .nav{height:54px}
header.site.shrink .logo .bird{height:24px}
header.site.shrink{box-shadow:0 10px 34px rgba(0,0,0,.45)}
.burger{display:none;width:42px;height:42px;border-radius:10px;border:1px solid var(--line2);background:rgba(255,255,255,.04);color:#fff;cursor:pointer;align-items:center;justify-content:center}

.mega{position:absolute;left:0;right:0;top:100%;z-index:190;
  background:linear-gradient(180deg,#0c0a1c,#08071a);border-bottom:1px solid var(--line2);
  box-shadow:0 40px 80px rgba(0,0,0,.55);opacity:0;visibility:hidden;transform:translateY(-8px);transition:.18s ease}
.mega.open{opacity:1;visibility:visible;transform:none}
.mega .inner{max-width:var(--maxw);margin:0 auto;padding:26px 28px;display:grid;grid-template-columns:230px 1fr 300px;gap:26px}
.mega .inner.simple{grid-template-columns:1fr 290px}
.mega .inner.full{grid-template-columns:1fr}
.lens{display:flex;flex-direction:column;gap:6px}
.lens a{display:flex;align-items:center;gap:12px;text-align:left;background:transparent;border:0;color:#cfcce6;text-decoration:none;
  font:inherit;font-weight:700;font-size:15px;padding:13px 14px;border-radius:12px;cursor:pointer;border-left:3px solid transparent}
.lens a .ic{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;flex:none;background:rgba(124,58,237,.16);border:1px solid rgba(124,58,237,.3)}
.lens a small{display:block;color:var(--muted);font-weight:500;font-size:12px}
.lens a.act{background:rgba(124,58,237,.1);border-left-color:var(--uv-2);color:#fff}
.pane{display:none;grid-template-columns:1fr 1fr;gap:8px 26px}
.pane.act{display:grid}
.pane a,.ll a{display:block;padding:9px 10px;border-radius:9px}
.pane a:hover,.ll a:hover{background:rgba(255,255,255,.04)}
.pane a b,.ll a b{display:block;font-size:14px;color:#fff;font-weight:700}
.pane a small{font-size:12px;color:var(--muted)}
.viewall{grid-column:1/-1;margin-top:8px;font-size:13px;font-weight:700;color:var(--lav)}
.ll{display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px 18px;align-content:start}
.feat{background:var(--panel);border:1px solid var(--line2);border-radius:16px;padding:18px;position:relative;overflow:hidden}
.feat .tag{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--lav)}
.feat h4{margin:8px 0 6px;font-size:17px;color:#fff}
.feat p{font-size:13px;color:var(--muted);margin-bottom:14px}
.feat .g{position:absolute;width:200px;height:200px;right:-60px;top:-60px;background:radial-gradient(closest-side,rgba(124,58,237,.4),transparent);filter:blur(10px)}
.res-cols{display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px}
.res-cols h5{margin:0 0 6px;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--lav);font-weight:800}
.res-cols a{display:block;padding:8px 0;font-size:14px;color:#e7e6f5}
.res-cols a:hover{color:#fff}
.res-cols a .nu{font-size:9px;font-weight:800;background:var(--uv-grad);color:#fff;padding:1px 6px;border-radius:999px;margin-left:6px;vertical-align:middle}

/* mobile drawer */
.drawer{position:fixed;inset:0;z-index:300;background:rgba(7,6,15,.98);backdrop-filter:blur(8px);display:none;flex-direction:column;padding:20px 24px;overflow:auto}
.drawer.open{display:flex}
.drawer .dtop{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.drawer a{display:block;padding:14px 4px;font-size:18px;font-weight:700;color:#e7e6f5;border-bottom:1px solid var(--line)}

/* ============ HERO (home) ============ */
.hero{position:relative;overflow:hidden;padding:96px 0 70px}
.hero .b1{width:720px;height:720px;right:-12%;top:-30%;background:radial-gradient(closest-side,rgba(147,51,234,.4),rgba(37,99,235,.16),transparent 72%)}
.hero .b2{width:520px;height:520px;left:-12%;bottom:-40%;background:radial-gradient(closest-side,rgba(37,99,235,.28),transparent 70%)}
.hero .wrap{position:relative;z-index:1}
.hero h1{font-size:clamp(38px,6vw,70px);font-weight:900;letter-spacing:-.04em;margin:16px 0 18px;max-width:880px}
.hero .sub{font-size:19px;color:#c7c4e0;max-width:600px}
.cta-row{display:flex;gap:13px;margin:30px 0 22px;flex-wrap:wrap}
.auditform{display:flex;gap:10px;max-width:520px;margin:26px 0 18px}
.auditform input{flex:1;background:rgba(255,255,255,.05);border:1px solid var(--line2);border-radius:12px;padding:14px 16px;color:#fff;font:inherit;font-size:15px}
.auditform input::placeholder{color:#8b88a8}
.trustbar{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.trustbar span{font-size:13px;color:#d6d3ef;background:rgba(255,255,255,.04);border:1px solid var(--line);padding:8px 13px;border-radius:999px;display:flex;align-items:center;gap:7px}
.trustbar span::before{content:"✓";color:var(--good);font-weight:900}

/* ============ INNER PAGE HERO ============ */
.phero{position:relative;overflow:hidden;padding:64px 0 54px;border-bottom:1px solid var(--line)}
.phero .b1{width:600px;height:600px;right:-8%;top:-40%;background:radial-gradient(closest-side,rgba(124,58,237,.3),transparent 70%)}
.phero .wrap{position:relative;z-index:1;max-width:880px}
.breadcrumb{font-size:13px;color:var(--muted);margin-bottom:14px;display:flex;gap:8px;flex-wrap:wrap}
.breadcrumb a:hover{color:#fff}
.phero h1{font-size:clamp(32px,5vw,54px);font-weight:900;letter-spacing:-.03em}
.phero .sub{font-size:18px;color:#c7c4e0;margin-top:16px;max-width:680px}
.phero .cta-row{margin-top:26px}

/* ============ CARDS / GRIDS ============ */
.grid{display:grid;gap:18px}
.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{padding:24px;border:1px solid var(--line);border-radius:16px;background:var(--panel);transition:border-color .2s,transform .2s}
.card:hover{border-color:var(--line2);transform:translateY(-3px)}
.card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:14px;background:rgba(124,58,237,.16);border:1px solid rgba(124,58,237,.3);font-size:20px}
.card h3{font-size:18px;margin:0 0 8px}
.card p{color:var(--muted);font-size:14.5px;margin:0}
.card .tag{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--lav)}
.svc-card{padding:24px;border:1px solid var(--line);border-radius:16px;background:var(--panel);transition:border-color .2s,transform .2s}
.svc-card:hover{border-color:var(--line2);transform:translateY(-3px)}
.svc-card .ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:14px;background:rgba(124,58,237,.16);border:1px solid rgba(124,58,237,.3);font-size:20px}
.svc-card h3{font-size:18px;margin:0 0 8px}.svc-card p{color:var(--muted);font-size:14.5px;margin:0}

/* stats */
.stat{padding:28px;border:1px solid var(--line);border-radius:18px;background:linear-gradient(180deg,var(--panel),#0b0a18)}
.stat .big{font-size:44px;font-weight:900;letter-spacing:-.03em;line-height:1;background:var(--soft-uv);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat p{color:var(--muted);font-size:14.5px;margin-top:12px}

/* feature row (alternating image/text) */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.feature.flip .fx-media{order:2}
.fx-media{position:relative}
.fx-media .ph{aspect-ratio:4/3;border-radius:18px;border:1px solid var(--line);background:linear-gradient(140deg,#13112a,#0b0a18);display:grid;place-items:center;color:var(--muted);font-size:13px}
.feature h3{font-size:clamp(22px,3vw,32px);margin-bottom:14px}
.feature p{color:#c7c4e0;font-size:16px;margin-bottom:14px}
.ticks{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:10px}
.ticks li{position:relative;padding-left:28px;color:#cdcbe4;font-size:15px}
.ticks li::before{content:"";position:absolute;left:0;top:3px;width:18px;height:18px;border-radius:50%;
  background:rgba(52,211,153,.14) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2334d399' stroke-width='3'%3E%3Cpath d='M5 13l4 4L19 7'/%3E%3C/svg%3E") center/12px no-repeat}

/* process timeline */
.tl{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tl .step{padding:26px;position:relative}
.tl .step .m{font-size:12px;font-weight:900;letter-spacing:2px;color:var(--lav)}
.tl .step h3{font-size:20px;margin:12px 0 10px}
.tl .step ul{margin:0;padding-left:18px;color:var(--muted);font-size:14px}
.tl .step li{margin:6px 0}
.tl .num{position:absolute;right:20px;top:18px;font-size:46px;font-weight:900;color:rgba(255,255,255,.05);letter-spacing:-.04em}

/* comparison */
.cmp{display:grid;grid-template-columns:1.1fr 1fr 1fr;border:1px solid var(--line);border-radius:18px;overflow:hidden}
.cmp .ch{padding:22px;border-bottom:1px solid var(--line);text-align:center}
.cmp .ch h3{font-size:18px}.cmp .ch .s{font-size:12.5px;color:var(--muted);margin-top:4px}
.cmp .col.you{position:relative;background:linear-gradient(180deg,rgba(124,58,237,.12),rgba(124,58,237,.02));border-left:1px solid rgba(124,58,237,.4);border-right:1px solid rgba(124,58,237,.4)}
.cmp .col.you .ch h3{color:#fff}
.cmp .row{padding:13px 18px;font-size:13.5px;border-bottom:1px solid var(--line);min-height:50px;display:flex;align-items:center;justify-content:center;text-align:center;color:#cdcbe4}
.cmp .row.y{color:#fff;font-weight:600}
.cmp .row .yes{color:var(--good);font-weight:900;margin-right:6px}
.cmp .row .no{color:var(--bad);font-weight:900;margin-right:6px}
.cmp .rl{justify-content:flex-start;text-align:left;font-weight:700;color:#fff;background:rgba(255,255,255,.02)}

/* FAQ */
.faq{max-width:840px;margin:0 auto}
.faq .item{border:1px solid var(--line);border-radius:14px;margin-bottom:12px;background:var(--panel);overflow:hidden;transition:border-color .2s}
.faq .item.open{border-color:rgba(124,58,237,.5)}
.faq .q{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 22px;cursor:pointer;font-weight:700;font-size:16px;color:#fff}
.faq .q .ic{width:26px;height:26px;flex:none;border-radius:8px;display:grid;place-items:center;background:rgba(124,58,237,.16);border:1px solid rgba(124,58,237,.3);color:#c4b5fd;font-weight:900;transition:transform .25s}
.faq .item.open .ic{transform:rotate(45deg)}
.faq .a{max-height:0;overflow:hidden;transition:max-height .28s ease}
.faq .item.open .a{max-height:320px}
.faq .a p{padding:0 22px 20px;color:var(--muted);font-size:15px;margin:0}

/* case-study cards */
.cases{display:grid;grid-template-columns:1.15fr 1fr 1fr;gap:18px}
.case{padding:24px;position:relative;overflow:hidden;display:flex;flex-direction:column}
.case .vert{font-size:12.5px;font-weight:700;color:#cfcce6;display:flex;align-items:center;gap:7px;margin-bottom:14px}
.case .metric{font-size:46px;font-weight:900;letter-spacing:-.03em;line-height:1}
.case .ml{font-size:14px;color:var(--muted);margin:6px 0 16px}
.case .subs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:14px}
.case .subs span{font-size:11.5px;font-weight:600;color:#d6d3ef;background:rgba(255,255,255,.05);border:1px solid var(--line);padding:5px 10px;border-radius:999px}
.case .win{font-size:13px;color:var(--muted);margin-top:auto;border-top:1px solid var(--line);padding-top:12px}
.case.feat-case{border-color:rgba(124,58,237,.5)}
.case.feat-case::after{content:"";position:absolute;width:240px;height:240px;right:-80px;top:-80px;background:radial-gradient(closest-side,rgba(124,58,237,.34),transparent);pointer-events:none}

/* tool widget / forms */
.tool{padding:34px;max-width:760px;margin:0 auto;text-align:center;position:relative;overflow:hidden}
.tool .g{width:380px;height:380px;left:50%;top:-40%;transform:translateX(-50%);background:radial-gradient(closest-side,rgba(124,58,237,.3),transparent)}
.toolform{display:flex;gap:10px;max-width:520px;margin:20px auto 8px;position:relative;z-index:1}
.toolform input{flex:1;background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:12px;padding:15px 16px;color:#fff;font:inherit}
.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:620px;margin:0 auto}
.formgrid .full{grid-column:1/-1}
.formgrid label{font-size:13px;color:var(--muted);font-weight:600;display:block;margin-bottom:6px}
.formgrid input,.formgrid textarea,.formgrid select{width:100%;background:rgba(255,255,255,.05);border:1px solid var(--line2);border-radius:12px;padding:13px 15px;color:#fff;font:inherit}

/* blog */
.posts{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--panel);transition:border-color .2s,transform .2s}
.post:hover{border-color:var(--line2);transform:translateY(-3px)}
.post .thumb{aspect-ratio:16/9;background:linear-gradient(140deg,#1a1633,#0b0a18);display:grid;place-items:center;color:var(--muted);font-size:13px}
.post .pb{padding:20px}
.post .cat{font-size:11px;font-weight:800;letter-spacing:1px;text-transform:uppercase;color:var(--lav)}
.post h3{font-size:18px;margin:8px 0 8px;line-height:1.3}
.post p{color:var(--muted);font-size:14px}
.post .meta{font-size:12px;color:var(--muted);margin-top:12px;display:flex;gap:10px;align-items:center}
.prose{max-width:760px;margin:0 auto}
.prose p{color:#cdcbe4;font-size:17px;margin:0 0 18px}
.prose h2{font-size:28px;margin:34px 0 14px}
.prose h3{font-size:21px;margin:26px 0 10px}
.prose ul{color:#cdcbe4;font-size:17px;padding-left:22px}.prose li{margin:8px 0}

/* CTA band */
.final{text-align:center;position:relative;overflow:hidden}
.final::before{content:"";position:absolute;inset:auto 50% -60% auto;transform:translateX(50%);width:900px;height:600px;background:radial-gradient(closest-side,rgba(124,58,237,.3),transparent 70%);pointer-events:none}
.final .wrap{position:relative}
.final h2{font-size:clamp(30px,5vw,52px);margin-top:12px}
.final p{color:#c7c4e0;font-size:18px;margin:16px auto 28px;max-width:540px}

/* ============ FOOTER ============ */
footer.site{border-top:1px solid var(--line);padding:56px 0 30px;color:var(--muted);font-size:14px}
.fcols{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:34px;margin-bottom:34px}
.fcols h5{font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--lav);font-weight:800;margin:0 0 14px}
.fcols a{display:block;padding:5px 0;color:#cdcbe4;font-size:14px}
.fcols a:hover{color:#fff}
.fcols .blurb{color:var(--muted);font-size:14px;max-width:260px;margin-top:12px}
.fbar{border-top:1px solid var(--line);padding-top:22px;display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center}

/* mobile sticky CTA */
.mbar{position:fixed;left:0;right:0;bottom:0;z-index:250;display:none;gap:10px;padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:rgba(10,8,20,.86);backdrop-filter:blur(14px);border-top:1px solid var(--line2)}
.mbar a{flex:1;text-align:center;justify-content:center}
.mbar .call{flex:none;width:48px;display:grid;place-items:center;background:rgba(255,255,255,.06);border:1px solid var(--line2);border-radius:12px;color:#fff}

/* ---- scroll reveal (gated on .anim, set before paint; reduced-motion safe) ---- */
.anim .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s ease, transform .7s cubic-bezier(.22,.61,.36,1)}
.anim .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.anim .reveal{opacity:1!important;transform:none!important;transition:none!important}}

/* ============ RESPONSIVE ============ */
@media(max-width:1080px){.g4{grid-template-columns:1fr 1fr}}
@media(max-width:960px){
  .menu,.nav-cta .phone{display:none}.burger{display:inline-flex}.btn-call{display:inline-flex}
  .nav-cta .btn-primary{display:none}
  .mega{display:none!important}
  .hero .wrap,.feature,.cmp,.tl,.cases,.res-cols,.posts,.g3,.g4,.fcols{grid-template-columns:1fr}
  .feature.flip .fx-media{order:0}
  .mbar{display:flex}
  section{padding:64px 0}
}
@media(max-width:680px){.g2,.formgrid{grid-template-columns:1fr}}
