/* ============================================================
   ZONDER DIGITAL — HOMEPAGE
   Hand-coded, framework-free. Desktop-first, responsive @900px.
   Display: Bricolage Grotesque · Body: Inter · Labels: JetBrains Mono
   ============================================================ */

/* ---- Tokens ---- */
:root{
  --purple:#7C3AED;
  --purple-deep:#5B21B6;
  --purple-darkest:#2E1065;
  --purple-light:#A78BFA;
  --purple-50:#F5F3FF;
  --purple-100:#EDE9FE;
  --purple-200:#DDD6FE;
  --amber:#F59E0B;
  --amber-bright:#FBBF24;
  --ink:#0F172A;
  --ink-2:#334155;
  --muted:#475569;
  --muted-2:#64748B;
  --faint:#94A3B8;
  --line:#E2E8F0;
  --line-soft:#EEF1F6;
  --bg:#F8FAFC;
  --white:#FFFFFF;
  --footer-bg:#0B1120;

  --font-display:'Bricolage Grotesque', sans-serif;
  --font-body:'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:'JetBrains Mono', monospace;

  --maxw:1200px;
  --pad:32px;
  --radius:16px;
}

/* ---- Reset ---- */
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  line-height:1.5;
}
a{text-decoration:none;color:inherit;}
img{max-width:100%;display:block;}
input,select,textarea,button{font-family:inherit;}
::selection{background:var(--purple-light);color:#fff;}
h1,h2,h3{margin:0;}

/* ---- Helpers ---- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad);}
.eyebrow{
  font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;
  color:var(--purple);font-weight:600;text-transform:uppercase;
}
.mono{font-family:var(--font-mono);}
.btn{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;border-radius:11px;
  cursor:pointer;border:1px solid transparent;transition:.18s ease;
}
.btn .arrow{transition:transform .18s ease;}
.btn:hover .arrow{transform:translateX(3px);}
.btn-primary{background:var(--purple);color:#fff;padding:15px 26px;font-size:16px;
  box-shadow:0 14px 30px -12px rgba(124,58,237,0.6);}
.btn-primary:hover{background:var(--purple-deep);transform:translateY(-1px);}
.btn-ghost{background:#fff;color:var(--ink-2);padding:15px 18px;font-size:16px;border-color:var(--line);}
.btn-ghost:hover{border-color:#CBD5E1;color:var(--ink);}

.section{padding:72px 0;}
.section-head{max-width:640px;}
.section-head h2{
  font-family:var(--font-display);font-weight:700;
  font-size:clamp(32px,3.6vw,46px);line-height:1.02;letter-spacing:-0.025em;
  margin:14px 0;
}
.section-head p{font-size:17px;line-height:1.6;color:var(--muted);margin:0;}

/* ---- Scroll reveal ---- */
[data-reveal]{opacity:0;transform:translateY(16px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
[data-reveal].is-in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1;transform:none;transition:none;}
  html{scroll-behavior:auto;}
}

/* ============================================================ NAV */
.nav{position:sticky;top:0;z-index:60;
  background:rgba(248,250,252,0.82);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:13px var(--pad);
  max-width:var(--maxw);margin:0 auto;}
.brand{display:flex;align-items:center;gap:11px;}
.logomark{width:32px;height:32px;border-radius:9px;
  background:linear-gradient(150deg,var(--purple),var(--purple-deep));
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-weight:800;font-size:19px;color:#fff;
  box-shadow:0 6px 16px -6px rgba(124,58,237,0.6);}
.wordmark{font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.02em;color:var(--ink);}
.wordmark span{color:var(--faint);font-weight:600;}
.nav-links{display:flex;align-items:center;gap:6px;}
.nav-link{padding:9px 13px;border-radius:8px;font-size:14.5px;font-weight:500;color:var(--ink-2);transition:.15s;}
.nav-link:hover{background:var(--line-soft);color:var(--ink);}
.nav-cta{margin-left:8px;background:var(--purple);color:#fff;padding:10px 17px;border-radius:9px;
  font-size:14.5px;font-weight:600;transition:.18s;display:inline-flex;align-items:center;gap:7px;}
.nav-cta:hover{background:var(--purple-deep);}

/* dropdown */
.has-drop{position:relative;}
.drop-trigger{display:flex;align-items:center;gap:5px;}
.caret{font-size:11px;color:var(--faint);}
.dropdown{
  position:absolute;top:calc(100% + 8px);left:0;width:340px;
  background:#fff;border:1px solid var(--line);border-radius:14px;
  box-shadow:0 24px 50px -20px rgba(15,23,42,0.28);padding:8px;
  opacity:0;visibility:hidden;transform:translateY(6px);transition:.18s ease;
}
.has-drop:hover .dropdown,.has-drop:focus-within .dropdown{opacity:1;visibility:visible;transform:translateY(0);}
.drop-item{display:flex;align-items:flex-start;gap:11px;padding:11px 12px;border-radius:10px;transition:.15s;}
.drop-item:hover{background:var(--purple-50);}
.drop-key{font-family:var(--font-mono);font-size:10px;color:var(--faint);font-weight:600;margin-top:3px;width:34px;flex-shrink:0;}
.drop-key.is-aeo{color:var(--purple);}
.drop-item b{display:block;font-weight:600;font-size:14px;color:var(--ink);}
.drop-item small{display:block;font-size:12.5px;color:var(--muted-2);margin-top:1px;}
.drop-all{display:block;margin:6px 4px 2px;padding:10px 8px;border-top:1px solid #F1F5F9;
  font-size:13px;font-weight:600;color:var(--purple);}

/* ============================================================ HERO */
.hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line-soft);
  background:radial-gradient(120% 100% at 85% -10%, #F3EEFF 0%, var(--bg) 46%);}
.hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:60px;align-items:center;
  padding:84px var(--pad) 92px;max-width:var(--maxw);margin:0 auto;}
.pill{display:inline-flex;align-items:center;gap:9px;padding:7px 13px;border:1px solid var(--purple-200);
  background:#FBFAFF;border-radius:999px;margin-bottom:24px;}
.pill .dot{width:6px;height:6px;border-radius:50%;background:var(--purple);box-shadow:0 0 0 4px rgba(124,58,237,0.16);}
.pill span{font-family:var(--font-mono);font-size:11px;letter-spacing:0.16em;font-weight:600;color:#6D28D9;}
.hero h1{font-family:var(--font-display);font-weight:700;
  font-size:clamp(44px,5.4vw,68px);line-height:0.99;letter-spacing:-0.03em;margin-bottom:22px;}
.hero h1 em{font-style:normal;color:var(--purple);}
.hero-sub{font-size:18px;line-height:1.62;color:var(--muted);max-width:540px;margin:0 0 32px;}
.hero-sub b{color:var(--ink);font-weight:600;}
.hero-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.trust{margin-top:34px;display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
.trust .lab{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.12em;color:var(--faint);}
.trust .div{height:13px;width:1px;background:var(--line);}
.trust .names{font-family:var(--font-mono);font-size:12px;letter-spacing:0.06em;color:var(--muted-2);font-weight:500;}

/* AI answer card */
.hero-visual{position:relative;justify-self:center;width:100%;max-width:460px;}
.stat-chip{position:absolute;top:-18px;right:-6px;z-index:3;background:var(--ink);color:#fff;
  border-radius:13px;padding:13px 16px;box-shadow:0 18px 40px -16px rgba(15,23,42,0.5);}
.stat-chip b{font-family:var(--font-display);font-weight:700;font-size:24px;line-height:1;color:var(--amber-bright);display:block;}
.stat-chip small{font-size:11px;color:#CBD5E1;margin-top:3px;display:block;letter-spacing:0.02em;}
.answer-card{background:#fff;border:1px solid var(--line);border-radius:20px;
  box-shadow:0 30px 70px -30px rgba(15,23,42,0.32);overflow:hidden;}
.ac-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;
  border-bottom:1px solid #F1F5F9;background:#FBFBFD;}
.ac-head .left{display:flex;align-items:center;gap:9px;}
.ac-head .left b{font-weight:600;font-size:13px;color:var(--ink);}
.ac-orb{width:9px;height:9px;border-radius:50%;background:linear-gradient(140deg,var(--purple),var(--purple-light));}
.ac-tag{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;color:var(--faint);}
.ac-query{margin:16px 18px 6px;display:flex;align-items:center;gap:10px;
  border:1px solid var(--line);background:var(--bg);border-radius:11px;padding:11px 13px;}
.ac-query .ring{width:7px;height:7px;border-radius:50%;border:2px solid var(--faint);flex-shrink:0;}
.ac-query span{font-size:13.5px;color:var(--ink-2);}
.ac-query em{font-style:normal;color:var(--purple);font-weight:600;}
.ac-answer{padding:14px 18px 6px;font-size:14px;line-height:1.62;color:var(--ink-2);}
.brand-chip{background:var(--purple-100);color:#6D28D9;font-weight:600;padding:1px 7px;border-radius:6px;border:1px solid var(--purple-200);}
.ac-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:13px;}
.ac-chips .c{font-family:var(--font-mono);font-size:10.5px;color:var(--muted-2);background:#F1F5F9;border-radius:6px;padding:4px 8px;}
.ac-foot{margin-top:16px;padding:13px 18px;border-top:1px solid #F1F5F9;background:#FBFBFD;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.ac-foot .lab{font-family:var(--font-mono);font-size:10px;letter-spacing:0.1em;color:var(--faint);}
.ac-foot .engines{font-size:12px;color:var(--muted);font-weight:500;}

/* ============================================================ SERVICES */
.services-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;
  flex-wrap:wrap;margin-bottom:34px;}
.link-pill{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:15px;color:var(--purple);
  border:1px solid var(--purple-200);background:#fff;padding:12px 18px;border-radius:10px;white-space:nowrap;transition:.18s;}
.link-pill:hover{background:var(--purple-50);border-color:#C4B5FD;}

.strategy-band{position:relative;max-width:560px;margin:0 auto;border-radius:var(--radius);
  background:var(--purple-50);border:1px solid var(--purple-100);padding:14px 24px;text-align:center;}
.strategy-line{margin:0;font-family:var(--font-display);font-weight:500;font-size:17px;color:var(--ink-2);letter-spacing:-0.01em;}
.connector{display:flex;justify-content:center;margin-bottom:4px;}
.connector i{width:1px;height:30px;background:linear-gradient(var(--purple-deep),var(--line));}

.tile-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.tile{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 24px;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;}
.tile:hover{transform:translateY(-4px);border-color:#C4B5FD;box-shadow:0 22px 44px -30px rgba(15,23,42,0.3);}
.tile .num{font-family:var(--font-mono);font-size:11px;color:#CBD5E1;font-weight:600;margin-bottom:18px;}
.tile h3{font-family:var(--font-display);font-weight:700;font-size:24px;letter-spacing:-0.02em;margin-bottom:4px;}
.tile .kicker{font-size:12.5px;color:var(--faint);font-weight:600;margin-bottom:12px;}
.tile p{font-size:14.5px;line-height:1.6;color:var(--muted);margin:0 0 18px;}
.tile .more{font-size:14px;font-weight:600;color:var(--purple);}
.tile.featured{position:relative;border:2px solid var(--purple);
  background:linear-gradient(180deg,#FAF8FF,#fff);box-shadow:0 22px 44px -28px rgba(124,58,237,0.45);}
.tile.featured:hover{box-shadow:0 30px 54px -26px rgba(124,58,237,0.5);}
.tile.featured .num{color:var(--purple-light);}
.tile.featured .kicker{color:var(--purple);}
.badge{position:absolute;top:18px;right:18px;background:var(--purple);color:#fff;
  font-family:var(--font-mono);font-size:9.5px;letter-spacing:0.1em;font-weight:600;padding:5px 9px;border-radius:6px;}

/* ============================================================ RESULTS */
.results{position:relative;overflow:hidden;
  background:linear-gradient(160deg,var(--purple-darkest) 0%,var(--purple-deep) 60%,#6D28D9 100%);}
.results::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 15% 0%, rgba(167,139,250,0.28), transparent 50%);pointer-events:none;}
.results .wrap{position:relative;}
.results .eyebrow{color:#C4B5FD;}
.results h2{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,3.6vw,46px);
  line-height:1.02;letter-spacing:-0.025em;color:#fff;margin:14px 0 40px;max-width:620px;}
.result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.result-card{background:rgba(255,255,255,0.06);border:1px solid rgba(196,181,253,0.22);
  border-radius:var(--radius);padding:26px 24px;backdrop-filter:blur(4px);}
.result-card .stat{font-family:var(--font-display);font-weight:700;font-size:46px;line-height:1;
  letter-spacing:-0.03em;color:#fff;margin-bottom:6px;}
.result-card .stat i{font-style:normal;font-size:28px;color:var(--purple-light);}
.result-card .label{font-weight:600;font-size:15px;color:var(--purple-100);margin-bottom:10px;}
.result-card p{font-size:13.5px;line-height:1.55;color:#C7BEE8;margin:0;}

/* ============================================================ ABOUT */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.about-copy h2{font-family:var(--font-display);font-weight:700;font-size:clamp(30px,3.4vw,44px);
  line-height:1.04;letter-spacing:-0.025em;margin:14px 0 20px;}
.about-copy p{font-size:16.5px;line-height:1.65;color:var(--muted);margin:0 0 18px;}
.pull{border-left:3px solid var(--purple);padding:6px 0 6px 20px;margin-top:8px;}
.pull b{font-family:var(--font-display);font-weight:600;font-size:22px;letter-spacing:-0.01em;color:var(--ink);}
.people{display:grid;gap:16px;}
.person{display:flex;gap:18px;align-items:center;background:#fff;border:1px solid var(--line);
  border-radius:var(--radius);padding:18px;}
.person .photo{width:84px;height:84px;border-radius:14px;flex-shrink:0;border:1px solid var(--purple-200);
  background:repeating-linear-gradient(135deg,var(--purple-100),var(--purple-100) 8px,var(--purple-50) 8px,var(--purple-50) 16px);
  display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:9px;color:#8B5CF6;text-align:center;line-height:1.3;}
.person b{font-family:var(--font-display);font-weight:700;font-size:19px;color:var(--ink);}
.person .role{font-size:13px;color:var(--purple);font-weight:600;margin:2px 0 7px;}
.person .bio{font-size:13.5px;color:var(--muted-2);line-height:1.5;}

/* ============================================================ EXPERIENCE / MARQUEE */
.experience{background:#fff;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  padding:46px 0;overflow:hidden;}
.exp-label{display:flex;align-items:center;gap:13px;justify-content:center;margin-bottom:26px;}
.exp-label i{height:1px;width:36px;background:var(--line);}
.exp-label span{font-family:var(--font-mono);font-size:13px;letter-spacing:0.16em;color:var(--muted-2);}
.marquee{position:relative;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);}
.marquee-track{display:flex;width:max-content;gap:18px;animation:zmarquee 34s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.logo-set{display:flex;gap:18px;}
.logo-cell{width:168px;height:60px;border:1px dashed #CBD5E1;border-radius:10px;
  display:flex;align-items:center;justify-content:center;background:#FBFCFE;
  font-family:var(--font-mono);font-size:11px;color:var(--faint);letter-spacing:0.06em;}
.logo-cell.empty{font-size:10px;color:var(--faint);}
.exp-note{text-align:center;margin-top:20px;font-family:var(--font-mono);font-size:10.5px;color:#CBD5E1;letter-spacing:0.04em;}
@keyframes zmarquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ============================================================ PHASE 2 */
.phase2-label{display:flex;align-items:center;gap:12px;margin-bottom:22px;}
.phase2-label .tag{font-family:var(--font-mono);font-size:10px;letter-spacing:0.14em;color:var(--purple-light);
  font-weight:600;border:1px solid var(--purple-200);border-radius:6px;padding:4px 9px;}
.phase2-label .note{font-family:var(--font-mono);font-size:11px;color:var(--faint);letter-spacing:0.04em;}
.phase2-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.slot{border:1.5px dashed #CBD5E1;border-radius:var(--radius);padding:40px 28px;min-height:180px;
  display:flex;flex-direction:column;justify-content:center;
  background:repeating-linear-gradient(135deg,#FBFCFE,#FBFCFE 14px,#F4F7FB 14px,#F4F7FB 28px);}
.slot b{font-family:var(--font-display);font-weight:700;font-size:21px;color:var(--muted);letter-spacing:-0.01em;}
.slot small{font-size:14px;color:var(--faint);margin-top:8px;line-height:1.5;}

/* ============================================================ CONTACT */
.contact{position:relative;overflow:hidden;background:var(--ink);padding:90px 0;}
.contact::before{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 110% at 90% 0%, rgba(124,58,237,0.32), transparent 55%);pointer-events:none;}
.contact-grid{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;max-width:1080px;margin:0 auto;}
.contact .eyebrow{color:var(--purple-light);}
.contact h2{font-family:var(--font-display);font-weight:700;font-size:clamp(32px,3.6vw,46px);
  line-height:1.02;letter-spacing:-0.025em;color:#fff;margin:16px 0 18px;}
.contact-copy>p{font-size:16.5px;line-height:1.6;color:var(--faint);margin:0 0 28px;max-width:420px;}
.contact-meta{display:flex;flex-direction:column;gap:12px;}
.contact-meta div{display:flex;align-items:center;gap:11px;color:#CBD5E1;font-size:15px;}
.contact-meta .d{width:7px;height:7px;border-radius:50%;background:var(--purple-light);}
.form{background:#fff;border-radius:18px;padding:26px;box-shadow:0 30px 70px -30px rgba(0,0,0,0.6);}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:13px;}
.field{display:block;margin-top:13px;}
.field:first-child,.form-row .field{margin-top:0;}
.field span{display:block;font-size:12.5px;font-weight:600;color:var(--muted);margin-bottom:6px;}
.field input,.field select,.field textarea{width:100%;border:1px solid var(--line);border-radius:10px;
  padding:12px 13px;font-size:14.5px;color:var(--ink);background:var(--bg);transition:.15s;}
.field textarea{resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--purple);background:#fff;outline:none;}
.form .btn-primary{margin-top:16px;width:100%;justify-content:center;padding:14px;font-size:15.5px;box-shadow:none;}

/* ============================================================ FOOTER */
.footer{background:var(--footer-bg);color:var(--faint);padding:60px var(--pad) 34px;border-top:1px solid #1E293B;}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;max-width:var(--maxw);margin:0 auto;}
.footer-brand .brand{margin-bottom:16px;}
.footer-brand .wordmark{color:#fff;}
.footer-brand p{font-size:14px;line-height:1.6;color:var(--muted-2);margin:0 0 18px;max-width:280px;}
.footer-brand .tagline{font-family:var(--font-display);font-weight:600;font-size:15px;color:var(--purple-light);}
.foot-col h4{font-family:var(--font-mono);font-size:10.5px;letter-spacing:0.14em;color:#475569;font-weight:600;margin:0 0 16px;}
.foot-col .links{display:flex;flex-direction:column;gap:11px;font-size:14.5px;}
.foot-col .links a:hover{color:#fff;}
.footer-bottom{max-width:var(--maxw);margin:44px auto 0;padding-top:22px;border-top:1px solid #1E293B;
  display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.footer-bottom span{font-size:13px;color:#475569;}
.footer-bottom .legal{display:flex;gap:20px;font-size:13px;color:#475569;}
.footer-bottom .legal a:hover{color:var(--faint);}

/* ============================================================ RESPONSIVE @900px */
@media (max-width:900px){
  :root{--pad:22px;}
  .section{padding:52px 0;}
  .nav-links{display:none;}
  .nav-toggle{display:flex;}
  .mobile-menu:not([hidden]){display:flex;}
  .hero-grid{grid-template-columns:1fr;gap:44px;padding:56px var(--pad) 64px;}
  .hero-visual{max-width:420px;}
  .tile-grid{grid-template-columns:1fr;}
  .result-grid{grid-template-columns:1fr 1fr;}
  .about-grid{grid-template-columns:1fr;gap:36px;}
  .contact-grid{grid-template-columns:1fr;gap:32px;}
  .phase2-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:560px){
  .result-grid{grid-template-columns:1fr;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .hero h1{font-size:clamp(38px,11vw,52px);}
}

/* ============================================================ MOBILE NAV + FORM ADDITIONS (Zonder) */
.nav-toggle{display:none;width:42px;height:42px;border:1px solid var(--line);background:#fff;border-radius:10px;
  cursor:pointer;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex-shrink:0;}
.nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);border-radius:2px;transition:.2s ease;}
.nav-toggle.is-open span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.nav-toggle.is-open span:nth-child(2){opacity:0;}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}

.mobile-menu{display:none;flex-direction:column;gap:2px;
  padding:8px var(--pad) 18px;background:rgba(248,250,252,0.98);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border-bottom:1px solid var(--line);}
.mobile-menu a{padding:11px 8px;border-radius:8px;font-size:15px;font-weight:500;color:var(--ink-2);}
.mobile-menu a:hover{background:var(--line-soft);color:var(--ink);}
.mobile-menu .mm-sub{font-size:13px;color:var(--muted-2);padding-left:18px;}
.mobile-menu .mm-cta{margin-top:8px;background:var(--ink);color:#fff;font-weight:600;text-align:center;}

/* Photos as real images */
.person img.photo{object-fit:cover;object-position:center top;}

/* Contact form column + honeypot + success */
.contact-form-col{position:relative;}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.success-msg{display:none;margin-top:16px;padding:18px 16px;border-radius:12px;
  background:rgba(124,58,237,0.12);border:1px solid var(--purple-light);
  color:#fff;font-size:14.5px;font-weight:600;text-align:center;}

/* ============================================================ PLACEHOLDER HERO GRAPHIC (from current site) */
/* Alias old token names so the ported dashboard markup works unchanged. */
:root{
  --primary:var(--purple);
  --primary-light:var(--purple-light);
  --text-dark:var(--ink);
  --text-medium:var(--muted);
  --text-light:var(--faint);
  --border:var(--line);
  --font-h:var(--font-display);
}
.dstack{position:relative;height:460px;display:flex;align-items:center;justify-content:center;z-index:1;}
.dcard{position:absolute;background:#fff;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,.11),0 2px 8px rgba(0,0,0,.05);overflow:hidden;border:1px solid var(--border);}
.dcard.main{width:320px;height:218px;z-index:3;top:50%;left:50%;transform:translate(-50%,-50%);}
.dcard.bl{width:290px;height:182px;z-index:1;top:10%;left:-5%;transform:rotate(-4deg);opacity:.72;}
.dcard.br{width:258px;height:172px;z-index:2;bottom:6%;right:-3%;transform:rotate(3deg);opacity:.78;}
.dchrome{display:flex;align-items:center;gap:5px;padding:9px 11px;background:#f6f7f9;border-bottom:1px solid #eee;}
.dd{width:7px;height:7px;border-radius:50%;}
.dd.r{background:#ff5f57;}.dd.y{background:#ffbd2e;}.dd.g{background:#28ca40;}
.durl{flex:1;background:#ebebed;border-radius:4px;height:13px;margin-left:8px;font-size:8px;color:#888;display:flex;align-items:center;padding:0 7px;overflow:hidden;white-space:nowrap;}
.dbody{padding:12px 13px;}
.drow{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.dtitle{font-size:10px;font-weight:700;color:var(--text-dark);}
.dbadge{font-size:8px;font-weight:700;padding:2px 7px;border-radius:20px;}
.dbadge.g{background:#dcfce7;color:#16a34a;}
.dbadge.p{background:#ede9fe;color:var(--primary);}
.dbadge.a{background:#fef3c7;color:#d97706;}
.krow{display:flex;gap:7px;margin-bottom:10px;}
.k{flex:1;background:var(--bg);border-radius:7px;padding:7px 9px;}
.kv{font-size:15px;font-weight:800;color:var(--text-dark);font-family:var(--font-h);line-height:1.1;}
.kv.up{color:#16a34a;}.kv.pu{color:var(--primary);}
.kl{font-size:8px;color:var(--text-light);font-weight:500;margin-top:2px;}
.kd{font-size:8px;font-weight:600;color:#16a34a;}
.kd.r{color:#dc2626;}
.bars{display:flex;align-items:flex-end;gap:3px;height:38px;}
.bar{flex:1;border-radius:3px 3px 0 0;background:#e9e9ff;}
.bar.act{background:var(--primary);}
.bar.hi{background:var(--primary-light);}
.mention-list{list-style:none;margin-top:4px;}
.mention-list li{display:grid;grid-template-columns:85px 45px 20px;align-items:center;padding:4px 0;border-bottom:1px solid #f1f1f1;font-size:9px;color:var(--text-dark);font-weight:500;}
.mention-src{font-weight:700;font-size:8.5px;}
.mention-header{font-weight:700!important;font-size:8px!important;color:var(--text-light)!important;text-transform:uppercase;letter-spacing:0.5px;}
.mention-arrow{font-size:10px;font-weight:700;color:#16a34a;}
.frow{display:flex;align-items:center;gap:5px;margin-bottom:5px;}
.fbar{flex:1;background:#f1f0ff;border-radius:4px;height:12px;overflow:hidden;}
.ffill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--primary),var(--primary-light));}
.fl{font-size:8px;color:var(--text-medium);font-weight:600;min-width:52px;}
.fv{font-size:8px;color:var(--primary);font-weight:700;min-width:34px;text-align:right;}

/* Logo wall: make the named (real) cells legible while placeholders await real files */
.logo-cell:not(.empty){color:var(--ink-2);border-style:solid;border-color:var(--line);background:#fff;font-family:var(--font-b);font-weight:700;font-size:16px;letter-spacing:0.01em;}

/* ============================================================ SERVICE PAGES (template) */
.bg-white{background:#fff;}
.svc-hero{position:relative;overflow:hidden;border-bottom:1px solid var(--line-soft);
  background:radial-gradient(120% 100% at 85% -10%, #F3EEFF 0%, var(--bg) 46%);}
.svc-hero .wrap{padding:74px var(--pad) 60px;}
.svc-hero h1{font-family:var(--font-display);font-weight:700;font-size:clamp(40px,5vw,60px);
  line-height:1.0;letter-spacing:-0.03em;margin:14px 0 20px;max-width:760px;}
.svc-hero h1 em{font-style:normal;color:var(--purple);}
.svc-sub{font-size:18px;line-height:1.62;color:var(--muted);max-width:640px;margin:0 0 28px;}
.svc-sub b{color:var(--ink);font-weight:600;}
.svc-actions{display:flex;gap:14px;flex-wrap:wrap;}

.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px;}
.why-card{border-top:2px solid var(--purple-200);padding-top:16px;}
.why-card .n{font-family:var(--font-mono);font-size:11px;color:var(--purple);font-weight:600;letter-spacing:0.08em;}
.why-card b{display:block;font-family:var(--font-display);font-weight:700;font-size:18px;letter-spacing:-0.01em;margin:0 0 10px;}
.why-card p{font-size:14.5px;line-height:1.6;color:var(--muted);margin:0;}

.pillar-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}

.metric-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;}
.metric{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:22px 22px;}
.metric b{display:block;font-family:var(--font-display);font-weight:700;font-size:17px;letter-spacing:-0.01em;margin-bottom:6px;}
.metric p{font-size:14px;line-height:1.55;color:var(--muted);margin:0;}

.cta-band{position:relative;overflow:hidden;border-radius:var(--radius);
  background:linear-gradient(160deg,var(--purple-darkest) 0%,var(--purple-deep) 60%,#6D28D9 100%);
  padding:50px 40px;text-align:center;}
.cta-band::before{content:"";position:absolute;inset:0;
  background:radial-gradient(80% 120% at 15% 0%, rgba(167,139,250,0.28), transparent 50%);pointer-events:none;}
.cta-band > *{position:relative;}
.cta-band h2{font-family:var(--font-display);font-weight:700;font-size:clamp(26px,3vw,38px);
  line-height:1.05;letter-spacing:-0.02em;color:#fff;margin:0 0 12px;}
.cta-band p{font-size:16px;line-height:1.6;color:var(--purple-100);margin:0 auto 22px;max-width:580px;}
.cta-band .btn-primary{background:#fff;color:var(--purple-deep);box-shadow:0 14px 30px -12px rgba(0,0,0,0.4);}
.cta-band .btn-primary:hover{background:var(--purple-100);color:var(--purple-darkest);}

@media (max-width:900px){
  .why-grid{grid-template-columns:1fr;gap:20px;}
  .pillar-grid{grid-template-columns:1fr;}
  .metric-grid{grid-template-columns:1fr;}
  .svc-hero .wrap{padding:52px var(--pad) 48px;}
}

/* ============================================================ CAPABILITY TILES (service pages) */
.cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.cap{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#fff;border:1px solid var(--line);
  border-radius:12px;font-size:14px;font-weight:600;color:var(--ink-2);transition:border-color .18s, box-shadow .18s;}
.cap::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--purple-light);flex-shrink:0;}
.cap:hover{border-color:var(--purple-200);box-shadow:0 6px 18px -10px rgba(124,58,237,0.3);}
@media(max-width:900px){.cap-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.cap-grid{grid-template-columns:1fr;}}

/* ============================================================ HERO EYEBROW (homepage, scoped) + service-hero eyebrow spacing */
.hero .hero-eyebrow{font-family:var(--font-mono);font-size:13px;letter-spacing:0.16em;color:var(--purple);font-weight:600;text-transform:uppercase;margin-bottom:18px;}
.svc-hero .eyebrow{margin-bottom:16px;}
