/* ═══════════════════════════════════════════════════════════
   AYATI ANALYTICS — Design System v1
   Bebas Neue (display) + Outfit (body)
   Purple / Dark / Off-white palette
   Built from scratch — no legacy
═══════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Outfit:wght@300;400;500;600;700&display=swap');

/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --p:      #7C3AED;
  --p-mid:  #6D28D9;
  --p-dark: #4C1D95;
  --p-lt:   #A855F7;
  --p-pale: #EDE9FE;
  --violet: #4F46E5;
  --dark:   #0F0F1A;
  --dark2:  #1A1A2E;
  --charcoal:#161627;
  --ink:    #1C1C2E;
  --off:    #F8F7FF;
  --white:  #FFFFFF;
  --gray:   #71717A;
  --border: #E4E4EF;
  --rule:   rgba(124,58,237,0.15);

  --display:'Bebas Neue',sans-serif;
  --sans:   'Outfit',system-ui,sans-serif;
  --nav-h:  68px;
  --max:    1400px;
  --pad:    clamp(20px,4vw,56px);
  --radius: 0px;
  --shadow: 0 8px 40px rgba(0,0,0,0.18);
  --shadow-p: 0 8px 40px rgba(124,58,237,0.25);
}

/* ── RESET ───────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--sans);color:var(--ink);background:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%;height:auto}
button{cursor:pointer;font-family:inherit;border:none;background:none;padding:0}
ul,ol{list-style:none}
[id]{scroll-margin-top:calc(var(--nav-h)+20px)}

/* ── TYPOGRAPHY ──────────────────────────────────────────── */
h1,h2,h3{font-family:var(--display);letter-spacing:1px;line-height:.95}
h4,h5,h6{font-family:var(--sans);letter-spacing:-.01em}
h1{font-size:clamp(3rem,7.5vw,7rem)}
h2{font-size:clamp(2.2rem,4.5vw,5rem)}
h3{font-size:clamp(1.6rem,2.5vw,2.8rem)}
h4{font-size:1.1rem;font-weight:600}
h5{font-size:.8rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase}
p{line-height:1.75;color:var(--gray)}
strong{font-weight:600}
em{font-style:normal;color:var(--p-lt)}

.eyebrow{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--p);display:flex;align-items:center;gap:10px}
.eyebrow::before{content:'';display:block;width:20px;height:2px;background:var(--p);flex-shrink:0}
.eyebrow-lt{color:var(--p-lt)}
.eyebrow-lt::before{background:var(--p-lt)}

/* ── LAYOUT ──────────────────────────────────────────────── */
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:80px 0}
.section-sm{padding:64px 0}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:64px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;gap:10px;font-family:var(--sans);font-weight:600;font-size:14px;letter-spacing:.02em;transition:.2s ease;white-space:nowrap}
.btn-primary{background:linear-gradient(135deg,var(--p),var(--violet));color:#fff;padding:13px 28px}
.btn-primary:hover{opacity:.85;color:#fff}
.btn-ghost{border:1.5px solid rgba(255,255,255,.2);color:rgba(255,255,255,.75);padding:13px 28px}
.btn-ghost:hover{border-color:var(--p-lt);color:var(--p-lt)}
.btn-outline{border:1.5px solid var(--border);color:var(--ink);padding:11px 24px;font-size:13px}
.btn-outline:hover{border-color:var(--p);color:var(--p)}
.btn-text{color:var(--p);font-size:13px;font-weight:600;display:inline-flex;align-items:center;gap:6px;transition:gap .2s}
.btn-text:hover{gap:10px}
.arrow{display:inline-block;transition:transform .2s}
.btn-text:hover .arrow{transform:translateX(4px)}

/* ── NAV ─────────────────────────────────────────────────── */
#nav{position:fixed;top:0;left:0;right:0;z-index:900;background:var(--dark);height:var(--nav-h);border-bottom:1px solid rgba(124,58,237,.15);transition:box-shadow .3s}
#nav.scrolled{box-shadow:0 4px 40px rgba(0,0,0,.5)}
.nav-inner{height:var(--nav-h);display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.nav-logo-mark{font-family:var(--display);font-size:26px;color:#fff;letter-spacing:3px}
.nav-logo-mark .dot{color:var(--p-lt)}
.nav-logo-sub{font-size:9px;font-weight:500;color:rgba(255,255,255,.25);letter-spacing:.15em;text-transform:uppercase;margin-top:-2px}
.nav-links{display:flex;align-items:stretch;height:var(--nav-h);gap:0;list-style:none}
.nav-links li{position:relative;display:flex;align-items:center}
.nav-links li a{display:flex;align-items:center;gap:5px;padding:0 15px;height:100%;font-size:13px;font-weight:500;color:rgba(255,255,255,.55);border-bottom:2px solid transparent;transition:.15s;white-space:nowrap}
.nav-links li a:hover,.nav-links li.active a{color:#fff;border-bottom-color:var(--p-lt)}
.nav-caret{font-size:7px;opacity:.5;transition:transform .2s}
.nav-links li.mega-open .nav-caret{transform:rotate(180deg)}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.4);transition:.15s}
.nav-icon:hover{color:#fff}
.nav-icon svg{width:16px;height:16px}
.nav-cta{background:linear-gradient(135deg,var(--p),var(--violet));color:#fff;font-size:12.5px;font-weight:600;padding:9px 18px;letter-spacing:.03em;transition:opacity .2s}
.nav-cta:hover{opacity:.85;color:#fff}

/* Hamburger */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px}
.hamburger span{display:block;height:1.5px;background:rgba(255,255,255,.7);transition:.25s}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* Mobile Drawer */
.mobile-drawer{position:fixed;top:var(--nav-h);left:0;right:0;bottom:0;background:var(--dark);z-index:800;padding:28px var(--pad) 40px;overflow-y:auto;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column}
.mobile-drawer.open{transform:none}
.drawer-section{margin-bottom:28px}
.drawer-label{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.2);margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}
.drawer-link{display:block;padding:13px 0;font-size:16px;font-weight:500;color:rgba(255,255,255,.6);border-bottom:1px solid rgba(255,255,255,.05)}
.drawer-link strong{display:block;color:rgba(255,255,255,.85);font-size:15px}
.drawer-link span{font-size:12px;color:rgba(255,255,255,.3);font-weight:300}
.drawer-link:hover{color:var(--p-lt)}
.drawer-cta{margin-top:auto;padding-top:24px}
.drawer-cta a{display:block;text-align:center;padding:14px;background:linear-gradient(135deg,var(--p),var(--violet));color:#fff;font-weight:600;font-size:15px}

/* ── MEGA PANELS ──────────────────────────────────────────── */
#mega-root{position:relative;z-index:890}
.mega{position:fixed;top:var(--nav-h);left:0;right:0;background:var(--dark);border-top:1px solid rgba(124,58,237,.2);border-bottom:1px solid rgba(124,58,237,.12);box-shadow:0 24px 64px rgba(0,0,0,.6);opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .2s,transform .2s}
.mega.visible{opacity:1;pointer-events:all;transform:none}
.mega-body{display:flex;align-items:flex-start;gap:40px;padding:36px var(--pad);max-width:var(--max);margin:0 auto}
.mega-col-group{display:flex;gap:0;flex:1;max-width:700px}
.mega-col{flex:1 1 200px;min-width:180px;max-width:260px;padding:0 28px 0 0;margin:0 0 0 0;border-right:1px solid rgba(255,255,255,.06)}
.mega-col:last-child{border-right:none;padding-right:0}
.mega-col h6{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}
.mega-col ul{display:flex;flex-direction:column;gap:0}
.mega-col a{display:flex;flex-direction:column;gap:2px;padding:9px 10px;transition:.12s;border-radius:0}
.mega-col a:hover{background:rgba(124,58,237,.1)}
.mega-col a strong{font-size:13px;font-weight:600;color:rgba(255,255,255,.8)}
.mega-col a span{font-size:11px;font-weight:300;color:rgba(255,255,255,.3)}
.mega-col a:hover strong{color:#fff}
.mega-see-all{display:inline-flex;align-items:center;gap:6px;margin-top:12px;padding:6px 10px;font-size:11px;font-weight:600;color:var(--p-lt);letter-spacing:.02em}
.mega-see-all:hover{color:#fff}
.mega-featured{background:rgba(124,58,237,.08);border-left:2px solid var(--p);padding:20px 24px;display:flex;flex-direction:column;gap:12px;min-width:260px;max-width:280px}
.mega-featured-badge{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--p-lt)}
.mega-featured img{width:100%;height:100px;object-fit:cover;filter:brightness(.5)}
.mega-featured-title{font-size:13px;font-weight:400;color:rgba(255,255,255,.6);line-height:1.55}
.mega-featured-link{font-size:12px;font-weight:600;color:var(--p-lt);display:inline-flex;align-items:center;gap:6px;margin-top:auto}
.mega-featured-link:hover{color:#fff}

/* ── HERO STYLES ──────────────────────────────────────────── */
/* Shared hero base */
.hero-base{padding-top:var(--nav-h);background:var(--dark);position:relative;overflow:hidden}
.hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(124,58,237,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(124,58,237,.06) 1px,transparent 1px);background-size:48px 48px;pointer-events:none}
.hero-glow-tr{position:absolute;top:-100px;right:-100px;width:700px;height:700px;background:radial-gradient(ellipse,rgba(124,58,237,.22) 0%,transparent 68%);pointer-events:none}
.hero-glow-bl{position:absolute;bottom:-100px;left:-80px;width:500px;height:500px;background:radial-gradient(ellipse,rgba(79,70,229,.15) 0%,transparent 68%);pointer-events:none}

/* Home hero — two column */
.hero-split{min-height:100svh;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:64px;padding:80px var(--pad) 64px;max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.hero-eyebrow{margin-bottom:24px}
.hero-h1{color:#fff;margin-bottom:24px;max-width:13ch}
.hero-h1 .outline{-webkit-text-stroke:1.5px rgba(255,255,255,.35);-webkit-text-fill-color:transparent}
.hero-dek{font-size:17px;font-weight:300;color:rgba(255,255,255,.5);line-height:1.75;max-width:46ch;margin-bottom:36px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}

/* Hero image frame */
.hero-frame{position:relative}
.hero-frame-inner{position:relative;border:1px solid rgba(124,58,237,.35)}
.hero-frame-inner::before{content:'';position:absolute;inset:-3px;border:1px solid rgba(124,58,237,.12);z-index:-1}
.hero-frame-inner img{width:100%;height:460px;object-fit:cover;display:block;filter:brightness(.4) saturate(.6)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(15,15,26,.7),rgba(124,58,237,.2))}
.hero-corner-tl{position:absolute;top:12px;left:12px;width:20px;height:20px;border-top:2px solid var(--p-lt);border-left:2px solid var(--p-lt)}
.hero-corner-br{position:absolute;bottom:12px;right:12px;width:20px;height:20px;border-bottom:2px solid var(--p-lt);border-right:2px solid var(--p-lt)}
.hero-stats-bar{position:absolute;bottom:0;left:0;right:0;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(124,58,237,.25)}
.hstat{background:rgba(15,15,26,.85);backdrop-filter:blur(12px);padding:16px 14px}
.hstat-n{font-family:var(--display);font-size:32px;color:var(--p-lt);line-height:1;letter-spacing:1px}
.hstat-l{font-size:10px;color:rgba(255,255,255,.4);margin-top:4px;line-height:1.4}

/* Page hero — single column */
.hero-page{min-height:28vh;display:flex;flex-direction:column;justify-content:flex-end;padding:72px var(--pad) 36px;max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.hero-page-breadcrumb{font-size:11px;font-weight:500;color:rgba(255,255,255,.3);margin-bottom:16px;display:flex;align-items:center;gap:8px}
.hero-page-breadcrumb a{color:rgba(255,255,255,.3);transition:.15s}
.hero-page-breadcrumb a:hover{color:rgba(255,255,255,.7)}
.hero-sep{color:rgba(255,255,255,.15)}
.hero-page h1{color:#fff;margin-bottom:16px;max-width:20ch}
.hero-page .dek{font-size:16px;font-weight:300;color:rgba(255,255,255,.45);max-width:60ch;line-height:1.75;margin-bottom:28px}
.hero-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--p-lt);border:1px solid rgba(124,58,237,.4);padding:4px 10px}

/* Product hero — two column with widget */
.hero-product{display:grid;grid-template-columns:1fr 380px;align-items:start;gap:48px;padding:72px var(--pad) 56px;max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.hero-product-num{font-family:var(--display);font-size:80px;color:rgba(255,255,255,.04);line-height:1;margin-bottom:-20px}
.hero-product h1{color:#fff;font-size:clamp(2.5rem,5.5vw,5.5rem);margin-bottom:10px}
.hero-product-name{font-size:14px;font-weight:400;color:rgba(255,255,255,.35);margin-bottom:20px;letter-spacing:.5px}
.hero-product .dek{font-size:15px;font-weight:300;color:rgba(255,255,255,.45);max-width:52ch;line-height:1.75;margin-bottom:28px}
.hero-product-widget{background:rgba(255,255,255,.04);border:1px solid rgba(124,58,237,.2)}
.widget-head{background:rgba(124,58,237,.12);border-bottom:1px solid rgba(124,58,237,.2);padding:14px 18px;display:flex;align-items:center;justify-content:space-between}
.widget-title{font-size:10px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--p-lt)}
.widget-dot{width:8px;height:8px;border-radius:50%;background:var(--p-lt);animation:pulse 2s ease infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.widget-body{padding:18px}
.widget-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.widget-row:last-child{border-bottom:none}
.widget-letter{font-family:var(--display);font-size:22px;color:var(--p-lt);line-height:1;flex-shrink:0;width:28px}
.widget-info{flex:1}
.widget-name{font-size:12px;font-weight:600;color:rgba(255,255,255,.8)}
.widget-sub{font-size:11px;color:rgba(255,255,255,.3);font-weight:300;margin-top:2px}
.widget-tag{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(124,58,237,.3);color:var(--p-lt);padding:2px 6px;flex-shrink:0;align-self:flex-start;margin-top:2px}

/* ── TICKER ───────────────────────────────────────────────── */
.ticker{background:linear-gradient(90deg,var(--p-dark),var(--p),var(--violet),var(--p-dark));padding:11px 0;overflow:hidden}
.ticker-track{display:flex;animation:tick 32s linear infinite;white-space:nowrap;width:max-content}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 24px}
.ticker-sep{color:rgba(255,255,255,.3);padding:0 4px}

/* ── SERVICES GRID ────────────────────────────────────────── */
.svc-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px;gap:24px}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border)}
.svc-card{background:var(--white);padding:36px 28px;position:relative;overflow:hidden;transition:.25s;cursor:pointer}
.svc-card::after{content:'';position:absolute;top:0;right:0;width:3px;height:0;background:linear-gradient(to bottom,var(--p),var(--violet));transition:height .3s}
.svc-card:hover::after{height:100%}
.svc-card:hover{background:var(--dark)}
.svc-badge{display:inline-block;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--p);border:1px solid rgba(124,58,237,.4);padding:3px 9px;margin-bottom:14px;transition:.25s}
.svc-title{font-size:17px;font-weight:600;line-height:1.3;margin-bottom:10px;transition:.25s;color:var(--ink)}
.svc-desc{font-size:13.5px;color:var(--gray);line-height:1.65;font-weight:300;transition:.25s}
.svc-link{display:inline-flex;align-items:center;gap:6px;margin-top:18px;font-size:12px;font-weight:600;color:var(--p);opacity:0;transition:.2s;transform:translateY(4px)}
.svc-card:hover .svc-badge{border-color:var(--p-lt);color:var(--p-lt)}
.svc-card:hover .svc-title{color:#fff}
.svc-card:hover .svc-desc{color:rgba(255,255,255,.4)}
.svc-card:hover .svc-link{opacity:1;transform:none;color:var(--p-lt)}

/* ── WHO SECTION ──────────────────────────────────────────── */
.who-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;margin-top:48px}
.who-card{position:relative;overflow:hidden;min-height:460px;display:flex;flex-direction:column;justify-content:flex-end;cursor:pointer}
.who-img{position:absolute;inset:0}
.who-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.22) saturate(.35);transition:transform .5s,filter .5s}
.who-card:hover .who-img img{transform:scale(1.04);filter:brightness(.3) saturate(.5)}
.who-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(15,15,26,.98) 0%,rgba(124,58,237,.12) 55%,transparent 100%)}
.who-body{position:relative;z-index:1;padding:28px 24px;border-top:2px solid var(--p)}
.who-title{font-size:20px;font-weight:700;color:#fff;margin-bottom:14px}
.who-items{display:flex;flex-direction:column;gap:8px}
.who-item{font-size:13px;color:rgba(255,255,255,.5);font-weight:300;padding-left:16px;position:relative;line-height:1.55}
.who-item::before{content:'›';position:absolute;left:0;color:var(--p-lt);font-weight:700}
.who-card-link{display:inline-flex;align-items:center;gap:6px;margin-top:14px;font-size:12px;font-weight:600;color:var(--p-lt)}

/* ── PHILOSOPHY ───────────────────────────────────────────── */
.phil{background:var(--charcoal)}
.phil-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.phil-img{height:460px;overflow:hidden;position:relative}
.phil-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.45) saturate(.5)}
.phil-img::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(124,58,237,.3),transparent)}
.phil-img-corner{position:absolute;top:16px;right:16px;width:24px;height:24px;border-top:2px solid var(--p-lt);border-right:2px solid var(--p-lt)}
.phil-statement{font-family:var(--display);font-size:clamp(2rem,3.5vw,3.8rem);color:#fff;line-height:1;letter-spacing:1px;margin-bottom:24px}
.phil-sub{font-size:15px;color:rgba(255,255,255,.45);line-height:1.75;font-weight:300;margin-bottom:36px}
.phil-pillars{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.pillar{background:rgba(255,255,255,.04);padding:22px 20px;border-left:3px solid var(--p);transition:.2s}
.pillar:hover{background:rgba(124,58,237,.12)}
.pillar h4{font-size:12px;font-weight:700;color:#fff;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px;line-height:1.2}
.pillar p{font-size:13px;color:rgba(255,255,255,.4);line-height:1.6;font-weight:300}

/* ── PRODUCTS ECOSYSTEM ───────────────────────────────────── */
.prd-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);margin-top:48px}
.prd-card{background:var(--white);padding:0;overflow:hidden;transition:.2s;position:relative}
.prd-card-img{height:160px;overflow:hidden;position:relative}
.prd-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.4) saturate(.5);transition:.4s}
.prd-card:hover .prd-card-img img{filter:brightness(.55) saturate(.7)}
.prd-card-img-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(255,255,255,.95))}
.prd-card-body{padding:24px 28px 28px}
.prd-card-num{font-family:var(--display);font-size:44px;color:rgba(124,58,237,.08);line-height:1;margin-bottom:-12px}
.prd-card-tag{font-size:9px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--p);margin-bottom:6px}
.prd-card-title{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:4px;line-height:1.2}
.prd-card-name{font-size:12px;color:var(--gray);font-weight:300;margin-bottom:12px}
.prd-card-desc{font-size:13.5px;color:var(--gray);line-height:1.6;font-weight:300;margin-bottom:18px}
.prd-card-badges{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}
.prd-mini-badge{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(124,58,237,.2);color:var(--p);padding:2px 7px}
.prd-card-arrow{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--p);margin-top:auto}
.prd-card:hover{box-shadow:0 0 0 1.5px var(--p)}

/* ── INSIGHTS ─────────────────────────────────────────────── */
.ins-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.ins-card{background:var(--white);border:1px solid var(--border);overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.ins-card:hover{border-color:var(--p);box-shadow:var(--shadow-p)}
.ins-card-img{height:180px;overflow:hidden;position:relative}
.ins-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(.7) saturate(.6);transition:.4s}
.ins-card:hover .ins-card-img img{filter:brightness(.85) saturate(.8)}
.ins-card-body{padding:24px;flex:1;display:flex;flex-direction:column;gap:10px}
.ins-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--p)}
.ins-title{font-size:16px;font-weight:600;line-height:1.35;color:var(--ink)}
.ins-excerpt{font-size:13.5px;color:var(--gray);line-height:1.65;font-weight:300;flex:1}
.ins-meta{font-size:11px;color:var(--gray);margin-top:auto;padding-top:12px;border-top:1px solid var(--border);display:flex;gap:12px}
.ins-cta{font-size:12px;font-weight:600;color:var(--p);display:flex;align-items:center;gap:5px;margin-top:12px}
.ins-cta:hover{gap:8px}

/* ── TESTIMONIALS ─────────────────────────────────────────── */
.testimonials{background:var(--off)}
.voice-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:48px}
.voice-card{background:var(--white);padding:32px 28px;border:1px solid var(--border);position:relative;overflow:hidden;display:flex;flex-direction:column;gap:16px}
.voice-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p),var(--violet))}
.voice-mark{font-family:var(--display);font-size:64px;color:var(--p);line-height:.7;opacity:.18}
.voice-text{font-size:15px;color:var(--ink);font-weight:300;font-style:italic;line-height:1.7;flex:1}
.voice-attr{font-size:11px;font-weight:600;color:var(--p);letter-spacing:.5px;text-transform:uppercase;margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}

/* ── CTA SECTION ──────────────────────────────────────────── */
.cta-section{background:var(--dark);padding:96px 0;position:relative;overflow:hidden}
.cta-glow{position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,rgba(124,58,237,.2),transparent 70%);pointer-events:none}
.cta-inner{position:relative;z-index:1;display:flex;justify-content:space-between;align-items:center;gap:64px}
.cta-h2{font-family:var(--display);font-size:clamp(2.2rem,4.5vw,5rem);color:#fff;line-height:.95;letter-spacing:1px;margin-bottom:12px}
.cta-dek{font-size:16px;color:rgba(255,255,255,.45);line-height:1.7;font-weight:300;max-width:44ch}
.btn-cta{background:linear-gradient(135deg,var(--p),var(--violet));color:#fff;font-size:15px;font-weight:700;padding:16px 36px;flex-shrink:0;transition:opacity .2s}
.btn-cta:hover{opacity:.85;color:#fff}

/* ── CONTACT FORM ─────────────────────────────────────────── */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start}
.contact-left h2{color:#fff;margin-bottom:16px}
.contact-left p{color:rgba(255,255,255,.45);font-size:15px;font-weight:300;max-width:44ch;line-height:1.75}
.contact-assurances{display:flex;flex-direction:column;gap:14px;margin-top:36px}
.assurance{display:flex;align-items:flex-start;gap:12px}
.assurance-dot{width:8px;height:8px;background:var(--p-lt);flex-shrink:0;margin-top:5px}
.assurance p{font-size:13px;color:rgba(255,255,255,.35);font-weight:300;line-height:1.5;margin:0}
.form-field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-field label{font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.35)}
.form-input{width:100%;padding:11px 14px;background:rgba(255,255,255,.05);border:1.5px solid rgba(124,58,237,.2);color:#fff;font-family:var(--sans);font-size:14px;outline:none;transition:.15s}
.form-input::placeholder{color:rgba(255,255,255,.2)}
.form-input:focus{border-color:var(--p-lt);background:rgba(124,58,237,.06)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-submit{width:100%;padding:13px;background:linear-gradient(135deg,var(--p),var(--violet));color:#fff;font-family:var(--sans);font-size:14px;font-weight:600;cursor:pointer;border:none;margin-top:8px;transition:opacity .2s}
.form-submit:hover{opacity:.85}

/* ── FOOTER ───────────────────────────────────────────────── */
footer{background:#06040F;padding:64px var(--pad) 32px}
.footer-top{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:48px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.06);margin-bottom:32px}
.footer-brand{font-family:var(--display);font-size:28px;color:#fff;letter-spacing:3px;margin-bottom:12px}
.footer-brand span{color:var(--p-lt)}
.footer-tagline{font-size:13px;color:rgba(255,255,255,.25);font-weight:300;line-height:1.65;max-width:28ch;margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.fsoc{width:36px;height:36px;border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.35);transition:.15s}
.fsoc:hover{border-color:var(--p-lt);color:var(--p-lt)}
.fsoc svg{width:14px;height:14px}
.footer-col h5{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.25);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid rgba(255,255,255,.06)}
.footer-col ul{display:flex;flex-direction:column;gap:9px}
.footer-col a{font-size:13px;font-weight:300;color:rgba(255,255,255,.4);transition:.15s}
.footer-col a:hover{color:var(--p-lt)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer-copy{font-size:12px;color:rgba(255,255,255,.18)}
.footer-legal{display:flex;gap:20px}
.footer-legal a{font-size:12px;color:rgba(255,255,255,.18);transition:.15s}
.footer-legal a:hover{color:rgba(255,255,255,.5)}

/* ── ARTICLE LAYOUT ───────────────────────────────────────── */
.article-hero{background:var(--dark);padding:calc(var(--nav-h) + 56px) var(--pad) 56px;position:relative;overflow:hidden}
.article-hero-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1fr 380px;gap:64px;align-items:end;position:relative;z-index:1}
.article-tag-row{display:flex;align-items:center;gap:14px;margin-bottom:16px;flex-wrap:wrap}
.article-tag{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border:1px solid rgba(124,58,237,.4);color:var(--p-lt);padding:4px 10px}
.article-meta{font-size:12px;color:rgba(255,255,255,.3)}
.article-hero h1{font-size:clamp(2rem,4.5vw,4.5rem);color:#fff;margin-bottom:16px;max-width:24ch}
.article-opening{font-size:16px;color:rgba(255,255,255,.45);font-weight:300;line-height:1.75;max-width:56ch}
.article-hero-img{width:100%;height:240px;object-fit:cover;filter:brightness(.4) saturate(.5)}
.article-body-wrap{max-width:var(--max);margin:0 auto;padding:64px var(--pad);display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:start}
.article-content h2{font-family:var(--display);font-size:clamp(1.6rem,2.5vw,2.8rem);color:var(--dark);margin:40px 0 16px}
.article-content h3{font-family:var(--sans);font-size:1.1rem;font-weight:700;color:var(--dark);margin:28px 0 10px}
.article-content p{font-size:15px;color:var(--gray);line-height:1.85;margin-bottom:18px;font-weight:300}
.article-content blockquote{border-left:3px solid var(--p);padding:16px 20px;background:var(--off);margin:24px 0;font-style:italic;color:var(--ink);font-size:15px}
.article-sidebar{position:sticky;top:calc(var(--nav-h)+24px)}
.sidebar-box{background:var(--off);border:1px solid var(--border);padding:24px;margin-bottom:24px}
.sidebar-box-title{font-size:10px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--p);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.toc-list{display:flex;flex-direction:column;gap:4px}
.toc-list a{font-size:13px;font-weight:300;color:var(--gray);padding:5px 8px;border-left:2px solid transparent;transition:.15s}
.toc-list a:hover{color:var(--p);border-left-color:var(--p)}
.cta-box{background:linear-gradient(135deg,var(--p),var(--violet));padding:24px;color:#fff;display:flex;flex-direction:column;gap:10px}
.cta-box h4{font-size:14px;color:#fff;font-weight:700}
.cta-box p{font-size:13px;color:rgba(255,255,255,.7);font-weight:300;margin:0;line-height:1.55}
.cta-box a{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#fff;margin-top:4px;background:rgba(255,255,255,.15);padding:8px 14px}
.cta-box a:hover{background:rgba(255,255,255,.22)}

/* ── THOUGHT LEADERSHIP ───────────────────────────────────── */
.tl-filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:40px}
.filter-btn{font-size:11px;font-weight:600;letter-spacing:.05em;padding:7px 16px;border:1px solid var(--border);color:var(--gray);background:var(--white);cursor:pointer;transition:.15s;font-family:var(--sans)}
.filter-btn:hover,.filter-btn.active{background:var(--p);border-color:var(--p);color:#fff}
.essay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.essay-card{border:1px solid var(--border);padding:28px;display:flex;flex-direction:column;gap:12px;transition:.2s;cursor:pointer;background:var(--white)}
.essay-card:hover{border-color:var(--p);box-shadow:0 4px 24px rgba(124,58,237,.1)}
.essay-num{font-family:var(--display);font-size:40px;color:rgba(124,58,237,.1);line-height:1}
.essay-cat{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--p)}
.essay-title{font-size:16px;font-weight:600;color:var(--ink);line-height:1.35}
.essay-excerpt{font-size:13px;color:var(--gray);font-weight:300;line-height:1.6;flex:1}
.essay-link{font-size:12px;font-weight:600;color:var(--p);display:flex;align-items:center;gap:5px;margin-top:auto}
.essay-link:hover{gap:8px}

/* ── AMI MIX CARDS ────────────────────────────────────────── */
.ami-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--border);margin-top:48px}
.ami-card{background:var(--white);padding:28px;position:relative;overflow:hidden;transition:.2s;display:flex;flex-direction:column;gap:14px}
.ami-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--p),var(--violet))}
.ami-card-icon{width:48px;height:48px;background:rgba(124,58,237,.08);display:flex;align-items:center;justify-content:center}
.ami-card-icon svg{width:22px;height:22px;stroke:var(--p);fill:none;stroke-width:1.5}
.ami-card-domain{font-size:9px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gray)}
.ami-card-title{font-size:17px;font-weight:700;color:var(--ink);line-height:1.2}
.ami-card-desc{font-size:13.5px;color:var(--gray);line-height:1.6;font-weight:300;flex:1}
.ami-card-tags{display:flex;gap:6px;flex-wrap:wrap}
.ami-tag{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(124,58,237,.2);color:var(--p);padding:2px 7px}
.ami-card-link{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--p);margin-top:auto}
.ami-card:hover{box-shadow:0 4px 24px rgba(124,58,237,.12);border:none;outline:1.5px solid var(--p)}

/* ── STATS STRIP ──────────────────────────────────────────── */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);margin:48px 0}
.stat-cell{background:var(--white);padding:32px 24px;text-align:center}
.stat-n{font-family:var(--display);font-size:clamp(2.5rem,4vw,4rem);color:var(--p);line-height:1;letter-spacing:1px}
.stat-l{font-size:12px;color:var(--gray);font-weight:300;line-height:1.5;margin-top:6px}

/* ── FEATURE GRID ─────────────────────────────────────────── */
.feature-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2px;background:var(--border);margin-top:48px}
.feature-cell{background:var(--white);padding:32px 28px;display:flex;flex-direction:column;gap:12px}
.feature-num{font-family:var(--display);font-size:48px;color:rgba(124,58,237,.1);line-height:1;margin-bottom:-10px}
.feature-title{font-size:16px;font-weight:700;color:var(--ink)}
.feature-body{font-size:14px;color:var(--gray);line-height:1.7;font-weight:300}
.feature-tags{display:flex;gap:6px;flex-wrap:wrap}
.feature-tag{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;border:1px solid rgba(124,58,237,.2);color:var(--p);padding:2px 7px}

/* ── WORKFLOW STEPS ───────────────────────────────────────── */
.steps{display:flex;align-items:flex-start;gap:0;margin:48px 0}
.step{flex:1;padding:28px 24px;position:relative}
.step::after{content:'→';position:absolute;top:36px;right:-14px;font-size:18px;color:rgba(124,58,237,.3);z-index:1}
.step:last-child::after{display:none}
.step-num{font-family:var(--display);font-size:40px;color:var(--p-lt);line-height:1;opacity:.35;margin-bottom:8px}
.step-title{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:8px}
.step-desc{font-size:13px;color:var(--gray);line-height:1.6;font-weight:300}

/* ── BACK TO TOP ──────────────────────────────────────────── */
#btt{position:fixed;bottom:28px;right:28px;width:42px;height:42px;background:var(--p);color:#fff;display:none;align-items:center;justify-content:center;z-index:800;cursor:pointer;transition:.2s;box-shadow:0 4px 20px rgba(124,58,237,.35)}
#btt.visible{display:flex}
#btt:hover{background:var(--p-mid)}
#btt svg{width:16px;height:16px}

/* ── FLOATING CHAT ────────────────────────────────────────── */
#fq-trigger{position:fixed;bottom:76px;right:28px;z-index:799;width:52px;height:52px;background:var(--p);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 24px rgba(124,58,237,.4);transition:.2s}
#fq-trigger:hover{transform:scale(1.06);box-shadow:0 6px 32px rgba(124,58,237,.5)}
#fq-trigger svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}

/* ── UTILITIES ────────────────────────────────────────────── */
.text-white{color:#fff!important}
.text-purple{color:var(--p)!important}
.bg-dark{background:var(--dark)!important}
.bg-off{background:var(--off)!important}
.bg-charcoal{background:var(--charcoal)!important}
.mt-0{margin-top:0!important}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s,transform .5s}
.reveal.in{opacity:1;transform:none}

/* ── RESPONSIVE ───────────────────────────────────────────── */
@media(max-width:1024px){
  .hero-split{grid-template-columns:1fr;min-height:auto;gap:40px;padding:72px var(--pad) 48px}
  .hero-frame{display:none}
  .grid-2,.phil-layout,.contact-layout{grid-template-columns:1fr;gap:40px}
  .grid-3,.svc-grid,.who-grid,.prd-grid,.voice-grid{grid-template-columns:repeat(2,1fr)}
  .ins-grid,.ami-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:36px}
  .cta-inner{flex-direction:column;align-items:flex-start;gap:24px}
  .article-body-wrap,.article-hero-inner{grid-template-columns:1fr}
  .hero-product{grid-template-columns:1fr}
  .hero-product-widget{display:none}
  .stats-strip{grid-template-columns:repeat(2,1fr)}
  .steps{flex-direction:column}
  .step::after{display:none}
  .feature-grid{grid-template-columns:1fr}
  .essay-grid{grid-template-columns:repeat(2,1fr)}
  .tl-filter-row{gap:6px}
  .phil-img{height:280px}
  .nav-links,.nav-icon{display:none}
  .hamburger{display:flex}
  .mega{display:none!important}
  .nav-right{gap:0;border:none;padding:0}
}
@media(max-width:640px){
  .grid-3,.svc-grid,.who-grid,.prd-grid,.voice-grid,.ins-grid,.ami-grid,.essay-grid{grid-template-columns:1fr}
  .grid-4,.stats-strip{grid-template-columns:repeat(2,1fr)}
  .hero-btns{flex-direction:column;align-items:stretch}
  .btn-primary,.btn-ghost,.btn-cta{width:100%;justify-content:center;text-align:center}
  .section{padding:48px 0}
  .container{padding:0 20px}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:12px}
  .footer-legal{flex-wrap:wrap;gap:14px}
  .form-row{grid-template-columns:1fr}
  .phil-pillars{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:1fr}
  .hero-stats-bar{display:none}
  .hero-page{min-height:28vh;padding:56px 20px 36px}
  .cta-h2{font-size:2.4rem}
  .tl-filter-row .filter-btn{font-size:10px;padding:6px 12px}
  #fq-trigger{bottom:84px;right:16px}
  #btt{bottom:20px;right:16px}
  .svc-header{flex-direction:column;align-items:flex-start;gap:16px}
}
@media(max-width:380px){
  .nav-cta{padding:8px 12px;font-size:11px}
  h1{font-size:2.4rem}
}
table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
img,video,iframe{max-width:100%}
