:root{
  --navy:#0e1a4a;
  --navy-2:#10245f;
  --navy-3:#1b2f7a;
  --blue:#2b5bd7;
  --blue-soft:#eaf0ff;
  --ink:#0b1331;
  --text:#1f2747;
  --muted:#5b6483;
  --line:#e6e9f2;
  --bg:#ffffff;
  --bg-soft:#f6f8fc;
  --bg-band:#f1f4fb;
  --green:#1aa874;
  --orange:#f59e0b;
  --red:#e0524b;
  --purple:#7b61ff;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;-webkit-text-size-adjust:100%}
a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}
button{font-family:inherit}
.container{max-width:1200px;margin:0 auto;padding:0 18px;width:100%}
.ic-stroke{stroke:currentColor;stroke-width:1.6;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ===========================
   MOBILE FIRST (base styles)
   =========================== */

/* === NAV (mobile) === */
.nav{position:sticky;top:0;background:#fff;border-bottom:1px solid var(--line);z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0;gap:12px;position:relative}
.logo{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.16em;font-size:12px;color:var(--navy)}
.logo-mark{width:22px;height:22px;border-radius:5px;background:var(--navy);position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-mark::after{content:"";width:8px;height:8px;border:2px solid #fff;border-radius:2px;transform:rotate(45deg)}
.nav-cta-d{display:none !important}
.hamburger{display:flex !important;flex-direction:column;justify-content:center;gap:4px;width:42px;height:42px;background:transparent;border:1px solid var(--line);border-radius:8px;cursor:pointer;padding:0;align-items:center;flex-shrink:0}
.hamburger span{display:block;width:18px;height:2px;background:var(--navy);border-radius:2px;transition:transform .25s,opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.nav-links{display:none;flex-direction:column;gap:0;align-items:stretch;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 0;box-shadow:0 12px 24px -16px rgba(14,26,74,.25)}
.nav-links.open{display:flex}
.nav-links a{font-size:15px;color:#283057;font-weight:500;padding:14px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f1f4fb;cursor:pointer}
.nav-links a:last-of-type{border-bottom:none}
.nav-links a.active{color:var(--blue)}
.nav-links a .chev{width:8px;height:8px;border-right:1.5px solid #6b7299;border-bottom:1.5px solid #6b7299;transform:rotate(-45deg)}
.nav-links .mobile-cta{padding:14px 22px}
.nav-links .mobile-cta .btn{width:100%;justify-content:center}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:13px 18px;font-weight:600;font-size:14px;cursor:pointer;border:1px solid transparent;transition:all .2s ease;white-space:normal;text-align:center;min-height:44px;line-height:1.2}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:#0a1539}
.btn-outline{background:#fff;border-color:#cdd3e3;color:var(--navy)}
.btn-outline:hover{border-color:var(--navy)}
.btn-ghost{background:#fff;border-color:#e6e9f2;color:var(--navy)}
.btn .arrow{transition:transform .2s}
.btn:hover .arrow{transform:translateX(3px)}

/* === HERO (mobile) === */
.hero{padding:36px 0 40px;background:linear-gradient(180deg,#fff 0%,#f7f9fe 100%);overflow:hidden}
.hero-grid{display:flex;flex-direction:column;gap:32px;align-items:stretch}
h1.hero-title{font-size:32px;line-height:1.12;letter-spacing:-.02em;color:var(--ink);font-weight:800;margin:0 0 16px}
.hero p.lead{font-size:15px;color:var(--muted);margin:0 0 22px}
.hero-cta{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
.hero-cta .btn{width:100%}
.hero-pills{display:grid;grid-template-columns:repeat(2,1fr);gap:18px 12px;justify-items:center}
.pill{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;max-width:140px}
.pill .ic{width:30px;height:30px;color:var(--blue)}
.pill .lab{font-size:10px;font-weight:700;letter-spacing:.12em;color:var(--navy);line-height:1.3}

/* Sub-hero used on interior pages */
.subhero{padding:48px 0 32px;background:linear-gradient(180deg,#fff,#f7f9fe);text-align:center}
.subhero .eyebrow{margin-bottom:14px}
.subhero h1{font-size:32px;line-height:1.12;letter-spacing:-.02em;color:var(--ink);font-weight:800;margin:0 0 14px;max-width:780px;margin-left:auto;margin-right:auto}
.subhero p{font-size:15px;color:var(--muted);max-width:640px;margin:0 auto 20px}
.subhero .cta-row{display:flex;flex-direction:column;gap:10px;align-items:center;margin-top:8px}
.subhero .cta-row .btn{width:100%;max-width:320px}

/* dashboard mock (mobile) */
.dash{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px;box-shadow:0 20px 60px -30px rgba(14,26,74,.25),0 6px 18px -10px rgba(14,26,74,.08)}
.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px}
.dash-row.r2{grid-template-columns:1fr 1fr}
.card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;min-width:0;overflow:hidden}
.card h5{margin:0 0 8px;font-size:9.5px;font-weight:700;letter-spacing:.12em;color:#7a82a3;text-transform:uppercase}
.ring{position:relative;display:flex;align-items:center;justify-content:center;height:80px}
.ring svg{transform:rotate(-90deg)}
.ring .val{position:absolute;font-weight:800;font-size:22px;color:var(--navy)}
.legend{display:flex;gap:6px;flex-wrap:wrap;font-size:9px;color:#6b7299;margin-top:6px}
.legend i{display:inline-block;width:8px;height:8px;border-radius:2px;margin-right:3px;vertical-align:middle}
.risk-list{display:flex;flex-direction:column;gap:5px;font-size:10.5px;color:#3a4366}
.risk-list .row{display:flex;justify-content:space-between;align-items:center}
.risk-list .row .v{font-weight:700;color:var(--navy)}
.risk-list .dot{display:inline-block;width:7px;height:7px;border-radius:50%;margin-right:5px;vertical-align:middle}
.delta{font-size:11px;font-weight:700;color:var(--green);display:inline-flex;align-items:center;gap:4px}
.delta.down{color:var(--red)}

/* === SECTION BASE === */
section{padding:48px 0}
.h2{font-size:24px;line-height:1.2;letter-spacing:-.015em;color:var(--ink);font-weight:800;margin:0 0 14px;text-align:center}
.h2.left{text-align:left}
.sub{color:var(--muted);margin:0 auto 28px;text-align:center;font-size:14px;max-width:640px}
.eyebrow{font-size:10.5px;font-weight:700;letter-spacing:.16em;color:var(--blue);text-transform:uppercase;margin-bottom:12px}

/* === Struggle === */
.struggle{background:#fff;padding:48px 0}
.struggle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 16px;margin-top:32px}
.struggle-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px}
.struggle-card .ic{width:50px;height:50px;display:flex;align-items:center;justify-content:center;color:var(--blue)}
.struggle-card .t{font-size:13px;color:var(--text);font-weight:500;line-height:1.4;max-width:160px}

/* === Outcomes / Pyramid === */
.outcomes{background:linear-gradient(180deg,#f7f9fe,#eef2fb);padding:56px 0}
.outcomes-grid{display:flex;flex-direction:column;gap:32px;align-items:stretch}
.checks{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:12px}
.checks li{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--text)}
.checks li svg{flex-shrink:0;color:var(--green);margin-top:2px}

.pyramid{display:flex;flex-direction:column;gap:0;position:relative}
.py-step{position:relative;display:flex;justify-content:center;padding:10px 0;margin-bottom:-4px}
.py-step::before{content:"";position:absolute;top:0;bottom:0;background:#cfdcf8;border-radius:12px}
.py-step.s1::before{left:10%;right:10%}
.py-step.s2::before{left:4%;right:4%}
.py-step.s3::before{left:0;right:0}
.py-card{position:relative;background:#fff;border:1px solid #dde3f4;border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:10px;box-shadow:0 2px 8px -4px rgba(14,26,74,.18)}
.py-step.s1 .py-card{width:80%}
.py-step.s2 .py-card{width:88%}
.py-step.s3 .py-card{width:96%}
.py-card .ic{width:26px;height:26px;color:var(--blue);flex-shrink:0;background:#eaf0ff;border-radius:50%;padding:4px;box-sizing:border-box}
.py-card .meta{display:flex;flex-direction:column;flex:1;min-width:0}
.py-card .lab{font-size:10px;font-weight:700;letter-spacing:.14em;color:var(--navy)}
.py-card .desc{font-size:10.5px;color:var(--muted);margin-top:2px;letter-spacing:0}
.py-card .chev{color:#a8b3da;display:flex;gap:4px}
.py-bot{display:grid;grid-template-columns:1fr;gap:8px;margin-top:14px}
.py-bot .py-card{width:100%;padding:12px 14px}

/* === ExecLens === */
.execlens{padding:56px 0;background:#fff}
.execlens-grid{display:flex;flex-direction:column-reverse;gap:32px;align-items:stretch}
.el-mock{display:grid;grid-template-columns:60px 1fr;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;box-shadow:0 24px 60px -32px rgba(14,26,74,.25)}
.el-side{background:var(--navy);color:#fff;padding:14px 8px;display:flex;flex-direction:column;align-items:center;gap:16px}
.el-side .lg{font-size:8.5px;font-weight:800;letter-spacing:.18em;text-align:center;line-height:1.2}
.el-side .icons{display:flex;flex-direction:column;gap:14px;margin-top:4px;color:#a8b3da}
.el-body{padding:14px;min-width:0}
.el-body h4{margin:0 0 12px;font-size:13px;color:var(--navy);font-weight:700}
.el-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.el-stat .label{font-size:9px;font-weight:700;letter-spacing:.1em;color:#7a82a3;text-transform:uppercase}
.el-stat .v{font-size:20px;font-weight:800;color:var(--navy);margin-top:2px}
.el-cols{display:flex;flex-direction:column;gap:12px}
.ki h5{margin:0 0 8px;font-size:11px;font-weight:700;color:var(--navy);letter-spacing:.06em}
.ki .item{display:flex;gap:8px;align-items:flex-start;font-size:11.5px;color:#3a4366;margin-bottom:8px}
.ki .item .b{font-weight:700;color:var(--navy)}
.ki .item .sm{font-size:10.5px;color:#7a82a3}
.ki .item svg{flex-shrink:0;color:var(--blue);margin-top:2px}

/* === Coverage === */
.coverage{background:#fff;padding:48px 0}
.cov-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px 16px;margin-top:32px;justify-items:center}
.cov-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:12px;max-width:200px}
.cov-card .ic{width:54px;height:54px;display:flex;align-items:center;justify-content:center}
.cov-card .lab{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--navy)}
.cov-card .desc{font-size:12.5px;color:var(--muted);line-height:1.45}

/* === Connected systems === */
.connected{background:linear-gradient(180deg,#fff,#fafbff);padding:56px 0;border-top:1px solid var(--line)}
.conn-grid{display:flex;flex-direction:column;gap:28px;align-items:stretch}
.stat-row{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:12px}
.stat-card{background:#fff;border:1px solid var(--line);border-radius:10px;padding:12px}
.stat-card .lab{font-size:9.5px;font-weight:700;letter-spacing:.12em;color:#7a82a3;text-transform:uppercase}
.stat-card .val{font-size:22px;font-weight:800;color:var(--navy);margin-top:4px}
.stat-card .spark{margin-top:4px;height:38px}
.funnel{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px;display:flex;flex-direction:column;gap:18px}
.funnel h5{margin:0 0 10px;font-size:11px;font-weight:700;letter-spacing:.06em;color:var(--navy)}
.funnel-bars{display:flex;flex-direction:column;gap:4px;align-items:center;font-size:10.5px;color:#3a4366}
.fbar{display:flex;align-items:center;justify-content:center;height:20px;background:linear-gradient(90deg,#2b5bd7,#7b61ff);color:#fff;font-weight:600;border-radius:2px;font-size:10.5px}
.acti-list{display:flex;flex-direction:column;gap:8px;font-size:11.5px;color:#3a4366}
.acti-list .row{display:flex;gap:8px;align-items:flex-start}
.acti-list .dot{width:8px;height:8px;border-radius:50%;margin-top:5px;flex-shrink:0}
.integrations{margin-top:24px;display:flex;flex-direction:column;align-items:center;gap:16px}
.integrations .lab{font-size:10.5px;font-weight:700;letter-spacing:.14em;color:var(--muted);text-transform:uppercase}
.integ-row{display:flex;gap:22px;align-items:center;flex-wrap:wrap;justify-content:center;color:var(--navy);font-weight:700}
.integ-logo{display:flex;align-items:center;gap:8px;color:#3a4366;font-size:15px;font-weight:700}

/* === PDP === */
.pdp{background:#fff;padding:56px 0}
.pdp-grid{display:flex;flex-direction:column;gap:32px;align-items:stretch}
.steps{background:#f6f8fc;border:1px solid var(--line);border-radius:14px;padding:24px 18px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:18px}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;max-width:220px}
.step .ic{width:56px;height:56px;border-radius:50%;background:#fff;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--green)}
.step .t{font-size:15px;font-weight:700;color:var(--navy)}
.step .d{font-size:12px;color:var(--muted);line-height:1.4}
.arrow-sep{color:#cbd2e6;transform:rotate(90deg);flex-shrink:0}

/* === Engage === */
.engage{background:#fafbff;padding:48px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.eng-grid{display:grid;grid-template-columns:1fr;gap:14px;margin-top:28px}
.eng-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px}
.eng-card .ic{width:44px;height:44px;border-radius:10px;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.eng-card h4{margin:0 0 8px;font-size:15px;font-weight:700;color:var(--navy)}
.eng-card p{margin:0;font-size:13px;color:var(--muted);line-height:1.5}

/* === Trust === */
.trust{padding:32px 0 16px;background:#fff}
.trust-title{text-align:center;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--navy);text-transform:uppercase;margin-bottom:22px}
.trust-row{display:flex;justify-content:center;align-items:center;gap:24px;flex-wrap:wrap;color:#3a4366;font-weight:700;font-size:15px}
.trust-row .l{display:flex;align-items:center;gap:6px;color:#3a4366;opacity:.85}

/* === Testimonials === */
.testi{padding:24px 0 56px;background:#fff}
.testi-title{text-align:center;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--navy);text-transform:uppercase;margin-bottom:22px}
.testi-grid{display:grid;grid-template-columns:1fr;gap:14px;max-width:1000px;margin:0 auto}
.testi-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:20px;box-shadow:0 14px 36px -22px rgba(14,26,74,.18)}
.testi-card .q{font-size:13px;color:#3a4366;line-height:1.6;margin:0 0 14px}
.testi-card .by{display:flex;align-items:center;gap:10px}
.testi-card .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,#7b61ff,#2b5bd7);flex-shrink:0}
.testi-card .nm{font-size:12.5px;font-weight:700;color:var(--navy)}
.testi-card .ti{font-size:11px;color:var(--muted)}
.testi-mark{font-size:30px;color:#cbd2e6;font-family:Georgia,serif;line-height:.6;margin-bottom:8px}

/* === Footer CTA === */
.cta{background:linear-gradient(135deg,#0e1a4a 0%,#1b2f7a 60%,#2b5bd7 130%);color:#fff;padding:48px 0;text-align:center;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(800px 300px at 30% 20%,rgba(123,97,255,.25),transparent 60%),radial-gradient(700px 300px at 80% 80%,rgba(43,91,215,.35),transparent 60%);pointer-events:none}
.cta h2{font-size:24px;font-weight:800;letter-spacing:-.015em;margin:0 0 12px;position:relative;line-height:1.2}
.cta p{color:#cdd3e9;margin:0 auto 22px;position:relative;font-size:14px}
.cta .btn{position:relative;background:#fff;color:var(--navy)}
.cta .btn:hover{background:#eef2fb}

/* === Footer === */
footer{background:#0b1331;color:#a8b3da;padding:24px 0;font-size:12.5px;text-align:center}
.footer-grid{display:grid;grid-template-columns:1fr;gap:28px;text-align:left;padding-bottom:24px;border-bottom:1px solid #1d264f;margin-bottom:18px}
.footer-col h6{margin:0 0 10px;font-size:11px;font-weight:700;color:#fff;letter-spacing:.14em;text-transform:uppercase}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px;font-size:13px}
.footer-col ul a{color:#a8b3da;transition:color .2s}
.footer-col ul a:hover{color:#fff}
.footer-bot{text-align:center;font-size:12.5px;color:#7a82a3}
.footer-logo{display:flex;align-items:center;gap:8px;font-weight:800;letter-spacing:.16em;font-size:12px;color:#fff;margin-bottom:14px}
.footer-logo .logo-mark{background:#fff}
.footer-logo .logo-mark::after{border-color:var(--navy)}
.footer-desc{font-size:13px;color:#a8b3da;line-height:1.55;max-width:320px}

/* === New components for inner pages === */
/* Feature grid (used on multiple pages) */
.feature-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:32px}
.feature-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;transition:transform .2s,box-shadow .2s}
.feature-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(14,26,74,.2)}
.feature-card .fc-ic{width:48px;height:48px;border-radius:12px;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.feature-card h4{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--navy)}
.feature-card p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.55}
.feature-card .more{margin-top:14px;font-size:13px;color:var(--blue);font-weight:600;display:inline-flex;align-items:center;gap:6px}

/* Problem detail cards (challenges page) */
.problem-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:32px}
.problem-card{background:#fff;border:1px solid var(--line);border-left:3px solid var(--red);border-radius:10px;padding:20px}
.problem-card .num{font-size:11px;font-weight:700;color:var(--red);letter-spacing:.16em;margin-bottom:8px}
.problem-card h4{margin:0 0 6px;font-size:16px;font-weight:700;color:var(--navy)}
.problem-card p{margin:0;font-size:13.5px;color:var(--muted);line-height:1.6}

/* Article cards (resources page) */
.article-grid{display:grid;grid-template-columns:1fr;gap:18px;margin-top:32px}
.article-card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:transform .2s,box-shadow .2s;display:flex;flex-direction:column}
.article-card:hover{transform:translateY(-2px);box-shadow:0 12px 32px -16px rgba(14,26,74,.2)}
.article-cover{height:120px;background:linear-gradient(135deg,#2b5bd7,#7b61ff);position:relative}
.article-cover.v2{background:linear-gradient(135deg,#0e1a4a,#2b5bd7)}
.article-cover.v3{background:linear-gradient(135deg,#1aa874,#2b5bd7)}
.article-cover.v4{background:linear-gradient(135deg,#7b61ff,#0e1a4a)}
.article-cover.v5{background:linear-gradient(135deg,#f59e0b,#e0524b)}
.article-cover.v6{background:linear-gradient(135deg,#2b5bd7,#1aa874)}
.article-cover::after{content:"";position:absolute;inset:0;background:radial-gradient(400px 200px at 30% 30%,rgba(255,255,255,.18),transparent 60%)}
.article-body{padding:18px;flex:1;display:flex;flex-direction:column}
.article-tag{font-size:10.5px;font-weight:700;letter-spacing:.14em;color:var(--blue);text-transform:uppercase;margin-bottom:8px}
.article-card h4{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--navy);line-height:1.3}
.article-card p{margin:0 0 14px;font-size:13px;color:var(--muted);line-height:1.55;flex:1}
.article-meta{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;color:#7a82a3;border-top:1px solid var(--line);padding-top:12px}

/* About / team / values */
.value-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:28px}
.value-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:22px}
.value-card .v-ic{width:40px;height:40px;border-radius:10px;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.value-card h4{margin:0 0 6px;font-size:15px;font-weight:700;color:var(--navy)}
.value-card p{margin:0;font-size:13px;color:var(--muted);line-height:1.55}

.metric-row{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin:28px 0}
.metric-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center}
.metric-card .v{font-size:28px;font-weight:800;color:var(--navy);letter-spacing:-.01em}
.metric-card .l{font-size:11px;font-weight:700;color:var(--muted);letter-spacing:.12em;text-transform:uppercase;margin-top:4px}

/* Contact form */
.form-grid{display:flex;flex-direction:column;gap:28px;margin-top:8px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px}
.form-row{display:grid;grid-template-columns:1fr;gap:14px;margin-bottom:14px}
.form-field label{display:block;font-size:12px;font-weight:600;color:var(--navy);margin-bottom:6px;letter-spacing:.02em}
.form-field input,.form-field textarea,.form-field select{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:8px;font-size:14px;font-family:inherit;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}
.form-field input:focus,.form-field textarea:focus,.form-field select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(43,91,215,.15)}
.form-field textarea{resize:vertical;min-height:96px}
.form-help{font-size:12px;color:var(--muted);margin-top:14px}
.expect-list{display:flex;flex-direction:column;gap:14px}
.expect-list li{display:flex;gap:12px;align-items:flex-start;font-size:13.5px;color:var(--text);list-style:none}
.expect-list .n{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--blue-soft);color:var(--blue);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.expect-list .t{font-weight:700;color:var(--navy);font-size:14px;margin-bottom:2px}
.expect-list .d{font-size:12.5px;color:var(--muted);line-height:1.5}

/* Two-col content blocks for inner pages */
.two-col{display:flex;flex-direction:column;gap:32px;align-items:stretch}
.two-col h2{font-size:24px;line-height:1.2;letter-spacing:-.015em;color:var(--ink);font-weight:800;margin:0 0 14px}
.two-col p{font-size:14px;color:var(--muted);margin:0 0 14px;line-height:1.6}

/* Simple stat band */
.stat-band{background:linear-gradient(135deg,#0e1a4a,#1b2f7a);color:#fff;padding:40px 0;text-align:center}
.stat-band-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.stat-band .v{font-size:28px;font-weight:800;letter-spacing:-.01em}
.stat-band .l{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#a8b3da;margin-top:4px}

/* helpers */
.icon-circle{width:56px;height:56px;border-radius:50%;background:#eef2fb;display:flex;align-items:center;justify-content:center;color:var(--navy)}

/* ===========================
   TABLET — 600px+
   =========================== */
@media (min-width:600px){
  .container{padding:0 24px}
  section{padding:64px 0}
  h1.hero-title{font-size:40px}
  .h2{font-size:28px}
  .subhero{padding:64px 0 40px}
  .subhero h1{font-size:42px}
  .subhero p{font-size:16px}
  .subhero .cta-row{flex-direction:row}
  .subhero .cta-row .btn{width:auto}
  .struggle-grid{grid-template-columns:repeat(3,1fr)}
  .cov-grid{grid-template-columns:repeat(3,1fr)}
  .hero-pills{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:18px}
  .pill{width:110px}
  .hero-cta{flex-direction:row;flex-wrap:wrap}
  .hero-cta .btn{width:auto}
  .dash-row{grid-template-columns:1fr 1.4fr 1fr}
  .dash-row.r2{grid-template-columns:1.4fr 1fr 1fr}
  .el-stats{grid-template-columns:repeat(4,1fr)}
  .el-cols{flex-direction:row}
  .el-cols > *{flex:1;min-width:0}
  .stat-row{grid-template-columns:repeat(3,1fr)}
  .funnel{display:grid;grid-template-columns:1fr 1fr}
  .py-step.s1 .py-card{width:64%}
  .py-step.s2 .py-card{width:80%}
  .py-step.s3 .py-card{width:96%}
  .py-step.s1::before{left:16%;right:16%}
  .py-step.s2::before{left:8%;right:8%}
  .py-bot{grid-template-columns:1fr 1fr}
  .eng-grid{grid-template-columns:repeat(2,1fr)}
  .testi-grid{grid-template-columns:repeat(2,1fr)}
  .integrations{flex-direction:row;justify-content:center;gap:32px}
  .cta h2{font-size:30px}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .problem-grid{grid-template-columns:repeat(2,1fr)}
  .article-grid{grid-template-columns:repeat(2,1fr)}
  .value-grid{grid-template-columns:repeat(2,1fr)}
  .metric-row{grid-template-columns:repeat(4,1fr)}
  .stat-band-grid{grid-template-columns:repeat(4,1fr)}
  .form-row{grid-template-columns:1fr 1fr}
  .form-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:32px}
  .footer-grid{grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px}
}

/* ===========================
   DESKTOP — 1024px+
   =========================== */
@media (min-width:1024px){
  body{font-size:15px}
  .container{padding:0 28px}
  section{padding:72px 0}
  h1.hero-title{font-size:54px;line-height:1.08}
  .h2{font-size:34px;line-height:1.15}
  .h2.left{text-align:left}
  .subhero{padding:80px 0 48px}
  .subhero h1{font-size:48px;line-height:1.1}

  /* nav */
  .hamburger{display:none !important}
  .nav-links{display:flex !important;flex-direction:row;gap:24px;align-items:center;position:static;background:transparent;border:none;padding:0;box-shadow:none}
  .nav-links a{font-size:14px;padding:0;border:none;justify-content:flex-start}
  .nav-links a .chev{transform:rotate(45deg);margin-top:0}
  .nav-links .mobile-cta{display:none}
  .nav-cta-d{display:inline-flex !important;padding:8px 16px !important;min-height:36px !important;font-size:13px !important;white-space:nowrap !important;align-self:center !important}

  /* hero */
  .hero{padding:64px 0 56px}
  .hero-grid{display:grid;grid-template-columns:1.05fr 1.15fr;gap:60px;align-items:center}
  .hero p.lead{font-size:16px;max-width:520px}
  .hero-cta{margin-bottom:36px}
  .hero-pills{gap:14px}
  .pill{width:98px}

  /* struggle / cov */
  .struggle{padding:72px 0 56px}
  .struggle-grid{grid-template-columns:repeat(6,1fr);gap:18px;margin-top:46px}
  .cov-grid{grid-template-columns:repeat(5,1fr);gap:24px;margin-top:46px}
  .cov-card{max-width:170px}

  /* outcomes */
  .outcomes{padding:80px 0}
  .outcomes-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:64px;align-items:center}
  .checks li{font-size:14.5px}
  .py-step.s1 .py-card{width:54%}
  .py-step.s2 .py-card{width:74%}
  .py-step.s3 .py-card{width:94%}
  .py-step.s1::before{left:22%;right:22%}
  .py-step.s2::before{left:11%;right:11%}
  .py-card{padding:12px 22px;gap:14px}
  .py-card .lab{font-size:11px;letter-spacing:.18em}
  .py-card .desc{font-size:11.5px}
  .py-card .ic{width:28px;height:28px}
  .py-bot{margin-top:18px}

  /* execlens */
  .execlens{padding:80px 0}
  .execlens-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:64px;align-items:center;flex-direction:row}
  .el-mock{grid-template-columns:80px 1fr}
  .el-side{padding:18px 14px;gap:20px}
  .el-body{padding:18px}
  .el-stats{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}

  /* connected */
  .connected{padding:80px 0}
  .conn-grid{display:grid;grid-template-columns:1fr 1.35fr;gap:56px;align-items:start}
  .integrations{margin-top:30px;justify-content:space-between;gap:32px}
  .integ-row{gap:42px}
  .integ-logo{font-size:18px}

  /* PDP */
  .pdp{padding:80px 0}
  .pdp-grid{display:grid;grid-template-columns:1fr 1.25fr;gap:64px;align-items:center}
  .steps{padding:32px 24px;flex-direction:row;justify-content:space-between;gap:8px}
  .step{flex:1;max-width:none}
  .step .ic{width:64px;height:64px}
  .step .d{max-width:130px}
  .arrow-sep{transform:none}

  /* engage / testi */
  .engage{padding:72px 0}
  .eng-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
  .eng-card{padding:24px}
  .trust{padding:40px 0 24px}
  .trust-row{gap:64px;font-size:17px}
  .testi{padding:24px 0 72px}
  .testi-grid{grid-template-columns:repeat(3,1fr);gap:20px}
  .testi-card{padding:22px}

  /* cta */
  .cta{padding:72px 0}
  .cta h2{font-size:36px}
  .cta p{font-size:15px;max-width:620px}
  footer{padding:36px 0;font-size:13px}
  .footer-grid{padding-bottom:32px;margin-bottom:24px}

  /* inner page extras */
  .feature-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
  .problem-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
  .article-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
  .value-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-top:40px}
  .two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
  .two-col.flip > :first-child{order:2}
  .two-col h2{font-size:30px}
  .two-col p{font-size:15px}
  .stat-band{padding:56px 0}
  .stat-band .v{font-size:36px}
  .form-grid{gap:48px}
}

/* Very small screens — refine */
@media (max-width:360px){
  .hero-pills{grid-template-columns:repeat(2,1fr);gap:14px 8px}
  .pill .lab{font-size:9px}
  h1.hero-title{font-size:28px}
  .h2{font-size:22px}
  .container{padding:0 14px}
}

/* ==========================================================================
   NEW COMPONENTS & ACCESSIBILITY EXTENSIONS (PRD §5)
   ========================================================================== */

/* === Focus Outline (WCAG 2.2 AA Compliance) === */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible {
  outline: 2px solid var(--blue) !important;
  outline-offset: 2px !important;
}

/* === Dropdown Navigation Styles === */
.dropdown {
  position: relative;
}
.dropdown-trigger {
  background: transparent;
  border: none;
  font-size: 14px;
  color: #283057;
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  padding: 0;
}
.dropdown-trigger .chev {
  border-right: 1.5px solid #6b7299;
  border-bottom: 1.5px solid #6b7299;
  width: 6px;
  height: 6px;
  transform: rotate(45deg);
  margin-top: 0;
  transition: transform 0.2s ease;
}
.dropdown-panel {
  opacity: 0;
  visibility: hidden;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  min-width: 260px;
  box-shadow: 0 24px 60px -32px rgba(14,26,74,.25);
  z-index: 100;
  margin-top: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s;
}
.dropdown-panel a {
  font-size: 13.5px;
  padding: 8px 12px;
  border-radius: 6px;
  color: var(--navy);
  font-weight: 500;
  text-align: left;
  display: block;
  border-bottom: none !important;
  transition: background 0.2s, color 0.2s;
}
.dropdown-panel a:hover {
  background: var(--blue-soft);
  color: var(--blue);
}
.dropdown-panel a.active-link {
  font-weight: 700;
  color: var(--blue);
  background: var(--blue-soft);
}

/* Active Dropdown Triggers */
.dropdown.show .dropdown-panel {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
.dropdown.show .dropdown-trigger {
  color: var(--blue);
}
.dropdown.show .dropdown-trigger .chev {
  transform: rotate(-135deg);
  margin-top: 2px;
}

/* Mobile Nav Accordion Behavior */
@media (max-width: 1023px) {
  .dropdown-trigger {
    width: 100%;
    justify-content: space-between;
    padding: 14px 22px;
    border-bottom: 1px solid #f1f4fb;
  }
  .dropdown-panel {
    display: none;
    position: static;
    transform: none;
    box-shadow: none;
    border: none;
    border-bottom: 1px solid #f1f4fb;
    border-radius: 0;
    padding: 6px 14px 12px 28px;
    opacity: 1;
    visibility: visible;
    background: var(--bg-soft);
  }
  .dropdown.show .dropdown-panel {
    display: flex;
  }
  .dropdown-panel a {
    padding: 10px 12px;
    font-size: 14px;
  }
  .dropdown.show .dropdown-trigger .chev {
    transform: rotate(225deg);
    margin-top: 4px;
  }
}

/* === Breadcrumbs === */
.breadcrumbs {
  font-size: 12px;
  color: var(--muted);
  padding: 8px 0;
  margin-bottom: -16px;
  display: flex;
  align-items: center;
  gap: 6px;
  position: relative;
  z-index: 10;
  flex-wrap: wrap;
}
.breadcrumbs a {
  color: var(--muted);
  transition: color 0.2s;
}
.breadcrumbs a:hover {
  color: var(--blue);
}
.breadcrumbs .sep {
  color: #cbd2e6;
  user-select: none;
}
.breadcrumbs span.current {
  font-weight: 700;
  color: var(--navy);
}

/* === Section Anchor Nav === */
.anchor-nav-wrapper {
  position: sticky;
  top: 70px;
  background: #fff;
  border-bottom: 1px solid var(--line);
  z-index: 40;
  padding: 10px 0;
}
.anchor-nav-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.anchor-nav {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
}
@media (min-width: 768px) {
  .anchor-nav {
    justify-content: center;
    width: 100%;
  }
}
.anchor-nav::-webkit-scrollbar {
  display: none;
}
.anchor-chip {
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  white-space: nowrap;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--navy);
  scroll-snap-align: start;
  transition: all 0.2s ease;
}
.anchor-chip:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.anchor-chip.active {
  background: var(--navy);
  color: #fff;
  border-color: var(--navy);
}
.anchor-select-wrapper {
  display: none;
}
@media (max-width: 767px) {
  .anchor-nav-wrapper {
    display: none;
  }
  .anchor-select-wrapper {
    display: block;
    padding: 12px 18px;
    background: var(--bg-soft);
    border-bottom: 1px solid var(--line);
    position: sticky;
    top: 70px;
    z-index: 40;
  }
  .anchor-select {
    width: 100%;
    padding: 10px;
    border-radius: 8px;
    border: 1px solid var(--line);
    font-weight: 600;
    color: var(--navy);
    background: #fff;
    font-size: 14px;
  }
}

/* === Stat Strip (PRD §5.8) === */
.stat-strip-section {
  background: #fff;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.stat-strip {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  padding: 48px 0;
  text-align: center;
}
@media (min-width: 600px) {
  .stat-strip {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .stat-strip {
    grid-template-columns: repeat(4, 1fr);
    padding: 64px 0;
  }
}
.stat-item-huge {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
}
.stat-val-huge {
  font-size: 48px;
  font-weight: 800;
  color: var(--navy);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.stat-label-huge {
  font-size: 11px;
  font-weight: 700;
  color: var(--muted);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* === Quote Callout (PRD §5.9) === */
.quote-callout {
  background: var(--bg-band);
  padding: 64px 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.quote-callout-inner {
  max-width: 760px;
  margin: 0 auto;
  position: relative;
  padding: 0 24px;
  z-index: 2;
}
.quote-text-large {
  font-family: Georgia, serif;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.6;
  margin-bottom: 24px;
}
.quote-attribution {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.quote-avatar {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--blue), var(--purple));
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}
.quote-author-info {
  text-align: left;
}
.quote-author-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--navy);
}
.quote-author-title {
  font-size: 12px;
  color: var(--muted);
}
.quote-mark-left, .quote-mark-right {
  font-size: 96px;
  font-family: Georgia, serif;
  color: var(--blue-soft);
  position: absolute;
  opacity: 0.45;
  user-select: none;
  line-height: 1;
}
.quote-mark-left {
  top: -30px;
  left: -20px;
}
.quote-mark-right {
  bottom: -60px;
  right: -20px;
}
@media (max-width: 767px) {
  .quote-text-large {
    font-size: 18px;
  }
  .quote-mark-left { left: 0; top: -40px; }
  .quote-mark-right { right: 0; bottom: -40px; }
}

/* === Comparison Table (PRD §5.10) === */
.comp-table-wrapper {
  overflow-x: auto;
  margin: 32px 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 8px 24px -12px rgba(14,26,74,.1);
}
.comp-table {
  width: 100%;
  border-collapse: collapse;
  text-align: left;
  min-width: 750px;
}
.comp-table th, .comp-table td {
  padding: 16px 24px;
  border-bottom: 1px solid var(--line);
  font-size: 14px;
}
.comp-table th {
  background: var(--bg-soft);
  color: var(--navy);
  font-weight: 800;
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.12em;
}
.comp-table tr:last-child td {
  border-bottom: none;
}
.comp-table tr:nth-child(even) td {
  background: var(--bg-soft);
}
.comp-table .check-icon {
  color: var(--green);
  display: inline-flex;
  align-items: center;
}
.comp-table .dash-icon {
  color: var(--muted);
}
.comp-table th:not(:first-child),
.comp-table td:not(:first-child) {
  text-align: center;
}
.comp-mobile-cards {
  display: none;
}

@media (max-width: 767px) {
  .comp-table-wrapper {
    display: none;
  }
  .comp-mobile-cards {
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin: 24px 0;
  }
  .comp-card {
    background: #fff;
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 20px;
  }
  .comp-card h4 {
    font-size: 16px;
    font-weight: 800;
    color: var(--navy);
    margin: 0 0 12px;
  }
  .comp-item {
    display: flex;
    justify-content: space-between;
    padding: 8px 0;
    border-bottom: 1px solid var(--bg-soft);
    font-size: 13.5px;
  }
  .comp-item:last-child {
    border-bottom: none;
  }
  .comp-item .val {
    font-weight: 700;
  }
  .comp-card.popular {
    border-color: var(--blue);
    position: relative;
  }
  .comp-card.popular::before {
    content: "Recommended";
    position: absolute;
    top: -10px;
    right: 20px;
    background: var(--blue);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 8px;
    border-radius: 4px;
    text-transform: uppercase;
    letter-spacing: 0.08em;
  }
}

/* === FAQ Accordion (PRD §5.11) === */
.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 24px;
}
.faq-item {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
  transition: border-color 0.2s;
}
.faq-item[open] {
  border-color: var(--blue);
}
.faq-item summary {
  padding: 18px 20px;
  font-weight: 700;
  color: var(--navy);
  font-size: 16px;
  cursor: pointer;
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  user-select: none;
}
.faq-item summary::-webkit-details-marker {
  display: none;
}
.faq-item summary .faq-icon {
  width: 16px;
  height: 16px;
  position: relative;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.faq-item summary .faq-icon::before,
.faq-item summary .faq-icon::after {
  content: "";
  position: absolute;
  background: var(--navy);
  transition: background-color 0.2s;
}
/* Horizontal bar */
.faq-item summary .faq-icon::before {
  top: 7px;
  left: 0;
  width: 16px;
  height: 2px;
}
/* Vertical bar */
.faq-item summary .faq-icon::after {
  top: 0;
  left: 7px;
  width: 2px;
  height: 16px;
}
.faq-item[open] summary .faq-icon {
  transform: rotate(45deg);
}
.faq-item[open] summary .faq-icon::before,
.faq-item[open] summary .faq-icon::after {
  background: var(--blue);
}
.faq-answer {
  padding: 0 20px 20px;
  font-size: 14px;
  color: var(--text);
  line-height: 1.6;
}
.faq-answer p {
  margin: 0 0 10px;
}
.faq-answer p:last-child {
  margin-bottom: 0;
}

/* === Timeline Components === */
.timeline-container {
  position: relative;
  margin: 40px 0;
  padding-left: 32px;
  border-left: 2px solid var(--line);
}
.timeline-item {
  position: relative;
  margin-bottom: 40px;
}
.timeline-item:last-child {
  margin-bottom: 0;
}
.timeline-item::before {
  content: "";
  position: absolute;
  left: -39px;
  top: 4px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--blue);
  border: 2px solid #fff;
  box-shadow: 0 0 0 4px var(--blue-soft);
  z-index: 2;
}
.timeline-year {
  font-size: 18px;
  font-weight: 800;
  color: var(--blue);
  margin-bottom: 4px;
}
.timeline-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 8px;
}
.timeline-desc {
  font-size: 14px;
  color: var(--muted);
  line-height: 1.55;
}

/* Gantt timeline component for PDP */
.gantt-wrapper {
  overflow-x: auto;
  margin: 32px 0;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 8px 24px -12px rgba(14,26,74,.1);
}
.gantt-chart {
  min-width: 800px;
  padding: 24px;
}
.gantt-header {
  display: grid;
  grid-template-columns: 200px 1fr;
  border-bottom: 2px solid var(--line);
  padding-bottom: 12px;
  margin-bottom: 16px;
}
.gantt-weeks {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  font-weight: 700;
  color: var(--navy);
  letter-spacing: 0.08em;
}
.gantt-week-label {
  flex: 1;
  text-align: center;
}
.gantt-row {
  display: grid;
  grid-template-columns: 200px 1fr;
  align-items: center;
  margin-bottom: 18px;
}
.gantt-row:last-child {
  margin-bottom: 0;
}
.gantt-label {
  font-weight: 700;
  color: var(--navy);
  font-size: 14px;
  padding-right: 12px;
}
.gantt-bar-container {
  position: relative;
  height: 28px;
  background: var(--bg-soft);
  border-radius: 6px;
  border: 1px solid var(--line);
}
.gantt-bar {
  position: absolute;
  height: 100%;
  border-radius: 5px;
  background: linear-gradient(90deg, var(--blue), var(--purple));
  display: flex;
  align-items: center;
  padding-left: 12px;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 2px 6px rgba(43,91,215,0.25);
}

/* === Team Grid and Headshot Cards === */
.team-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 32px;
}
@media (min-width: 600px) {
  .team-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1024px) {
  .team-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.team-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 16px;
  text-align: center;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.team-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px -16px rgba(14,26,74,.20);
}
.team-photo {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  background: var(--blue-soft);
  margin-bottom: 16px;
  object-fit: cover;
}
.team-name {
  font-size: 16px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 4px;
}
.team-role {
  font-size: 12.5px;
  color: var(--blue);
  font-weight: 600;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.team-bio {
  font-size: 12px;
  color: var(--muted);
  line-height: 1.5;
  margin-bottom: 12px;
}
.team-social {
  display: flex;
  justify-content: center;
  gap: 12px;
  color: var(--muted);
}
.team-social a:hover {
  color: var(--blue);
}

/* === Category Filter Chips (Case Studies & Blog) === */
.filter-row {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 6px 0;
  margin-top: 24px;
  scrollbar-width: none;
}
.filter-row::-webkit-scrollbar {
  display: none;
}
.filter-chip {
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 13px;
  font-weight: 600;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--navy);
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s ease;
}
.filter-chip:hover {
  border-color: var(--blue);
  color: var(--blue);
}
.filter-chip.active {
  background: var(--navy);
  color: #fff;
  border-color: var(--navy);
}

/* === Featured Blog Card === */
.featured-card {
  grid-column: span 1;
  display: grid;
  grid-template-columns: 1fr;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 12px 32px -16px rgba(14,26,74,.2);
  margin-top: 32px;
}
@media (min-width: 1024px) {
  .featured-card {
    grid-column: span 2;
    grid-template-columns: 1.2fr 1fr;
  }
}
.featured-cover {
  height: 240px;
  background: linear-gradient(135deg, var(--navy), var(--blue));
  position: relative;
}
@media (min-width: 1024px) {
  .featured-cover {
    height: 100%;
    min-height: 320px;
  }
}
.featured-cover::after {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(400px 200px at 30% 30%,rgba(255,255,255,.18),transparent 60%);
}
.featured-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* === In-line CTA Card inside Blog Posts === */
.inline-cta-card {
  background: var(--blue-soft);
  border: 1px solid rgba(43,91,215,0.15);
  border-radius: 12px;
  padding: 24px;
  margin: 32px 0;
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: flex-start;
}
.inline-cta-card h4 {
  font-size: 18px;
  font-weight: 800;
  color: var(--navy);
  margin: 0;
}
.inline-cta-card p {
  font-size: 14px;
  color: var(--text);
  margin: 0;
  line-height: 1.5;
}

/* === Newsletter Signup Band === */
.newsletter-band {
  background: var(--bg-band);
  padding: 48px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.newsletter-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
  align-items: center;
}
@media (min-width: 768px) {
  .newsletter-grid {
    grid-template-columns: 1.1fr 0.9fr;
    gap: 48px;
  }
}
.newsletter-info h3 {
  font-size: 22px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 8px;
}
.newsletter-info p {
  font-size: 14px;
  color: var(--muted);
  margin: 0;
}
.newsletter-form {
  display: flex;
  gap: 10px;
}
.newsletter-form input {
  flex: 1;
  padding: 12px 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
}
.newsletter-form input:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(43,91,215,.15);
}

/* === Governance & Trust Panel (PRD §6.13) === */
.trust-panel {
  background: var(--bg-band);
  padding: 48px 24px;
  border-radius: 14px;
  border: 1px solid var(--line);
  margin: 32px 0;
}
.trust-panel h3 {
  font-size: 20px;
  font-weight: 800;
  color: var(--navy);
  margin: 0 0 20px;
  text-align: center;
}
.trust-panel-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 768px) {
  .trust-panel-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.trust-panel-col h4 {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  margin: 0 0 8px;
}
.trust-panel-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--muted);
}
.trust-panel-col ul li {
  position: relative;
  padding-left: 14px;
}
.trust-panel-col ul li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: var(--blue);
}

/* === Platform Toggle Tabs (CRM page) === */
.platform-tabs-nav {
  display: flex;
  justify-content: center;
  border-bottom: 2px solid var(--line);
  margin-bottom: 32px;
}
.platform-tab-btn {
  background: transparent;
  border: none;
  padding: 12px 24px;
  font-size: 16px;
  font-weight: 700;
  color: var(--muted);
  cursor: pointer;
  border-bottom: 3px solid transparent;
  margin-bottom: -2px;
  transition: all 0.2s;
}
.platform-tab-btn:hover {
  color: var(--navy);
}
.platform-tab-btn.active[data-platform="salesforce"] {
  color: #00a1e0;
  border-bottom-color: #00a1e0;
}
.platform-tab-btn.active[data-platform="hubspot"] {
  color: #ff7a59;
  border-bottom-color: #ff7a59;
}
.platform-content {
  display: none;
}
.platform-content.active {
  display: block;
}

/* === Pagination styles === */
.pagination {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}

/* === Accessibility: prefers-reduced-motion === */
@media (prefers-reduced-motion: reduce) {
  *, ::before, ::after {
    animation-delay: -1ms !important;
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    background-attachment: initial !important;
    scroll-behavior: auto !important;
    transition-duration: 0s !important;
    transition-delay: 0s !important;
  }
}

/* === Stakeholder Grid Override === */
@media (min-width: 768px) {
  .stakeholder-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
  }
}


