/* Zettar redesign — design system (preview build) */
:root{
  --bg:#FFFFFF; --bg-soft:#F3F6FB; --surface:#FFFFFF; --surface-2:#EEF2F8;
  --border:rgba(12,22,42,0.10); --border-2:rgba(12,22,42,0.18);
  --text:#0E1A2E; --muted:#52607A; --muted-2:#7E8CA6;
  --accent:#1E54DB; --accent-soft:rgba(30,84,219,0.12);
  --cyan:#0E9E86; --cyan-soft:rgba(14,158,134,0.12);
  --maxw:1160px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:ui-monospace,'SFMono-Regular',Menlo,Consolas,monospace;
}
/* dark zones keep the navy palette via scoped custom properties */
.hdr,.ft,.hero,.page-hero{
  --bg:#0A0E1A; --bg-soft:#0E1424; --surface:#121C30; --surface-2:#16223A;
  --border:rgba(255,255,255,0.09); --border-2:rgba(255,255,255,0.16);
  --text:#E9EFF8; --muted:#9AACC6; --muted-2:#6F84A3; --cyan:#2DE2C0;
  color:var(--text);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--mono);font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);font-weight:600}
/* Final-CTA & HPE blocks aren't .sec-head, so their heading has no top margin — give the eyebrow a gap to match the section-head rhythm */
.hero .eyebrow,.final .eyebrow,.hpe .eyebrow,.proof .eyebrow{margin-bottom:14px}
.btn{display:inline-block;font-weight:700;font-size:.98rem;border-radius:10px;padding:13px 26px;cursor:pointer;transition:.15s;border:1px solid transparent}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 3px 10px rgba(47,107,246,.24)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(47,107,246,.32)}
.btn-ghost{background:transparent;border-color:var(--border-2);color:var(--text)}
.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}
section{position:relative}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
.section-pad{padding:80px 0}
.lead{color:var(--muted);font-size:1.18rem;max-width:none}
.lead + .lead{margin-top:18px} /* space between stacked body paragraphs (e.g. About "Our story") */

/* header */
.hdr{position:sticky;top:0;z-index:50;background:#0A0E1A;border-bottom:1px solid var(--border)}
.hdr-in{display:flex;align-items:center;justify-content:space-between;height:68px}
.logo{font-weight:900;font-size:1.35rem;letter-spacing:-.03em}
.logo span{color:var(--accent)}
.nav{display:flex;align-items:center;gap:20px}
.nav a{color:#C7D2E4;font-weight:600;font-size:.93rem}
.nav a:hover{color:#fff}
/* mobile nav handled in the nav block at the end of this file */

/* hero */
.hero{padding:84px 0 72px;background-color:#0A0E1A;background-image:
  radial-gradient(900px 500px at 75% -10%,rgba(79,140,255,.18),transparent 60%),
  radial-gradient(700px 500px at 5% 30%,rgba(45,226,192,.10),transparent 55%)}
.hero h1{font-size:clamp(2.3rem,5.2vw,3.9rem);font-weight:900;margin:18px 0}
.hero h1 .grad{background:linear-gradient(100deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .lead{font-size:1.28rem;margin-bottom:30px}
.hero-kicker{margin:0 0 16px;font-size:clamp(1.05rem,1.7vw,1.32rem);font-weight:600;line-height:1.3;color:var(--muted);max-width:44ch;min-height:1.7em}
.hero-kicker .krot{color:var(--cyan);transition:opacity .4s ease}
.hero-kicker .krot.is-fading{opacity:0}
@media(prefers-reduced-motion:reduce){.hero-kicker .krot{transition:none}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-stat{margin-top:46px;display:flex;gap:14px;flex-wrap:wrap}
.hero-stat .pill{font-family:var(--mono);font-size:.82rem;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:999px;padding:8px 16px}
.hero-stat .pill b{color:var(--cyan);font-weight:700}

/* trust */
.trust{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-soft);padding:30px 0}
.trust-line{text-align:center;color:var(--muted-2);font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}
.logos{display:flex;gap:34px;justify-content:center;flex-wrap:wrap;align-items:center;opacity:.85}
.logos span{font-weight:800;color:var(--muted);font-size:1.05rem;letter-spacing:.02em}

/* generic section heading */
.sec-head{max-width:none}
.sec-head .lead{max-width:none}
.sec-head h2{font-size:clamp(1.8rem,3.6vw,2.6rem);margin:14px 0}

/* solution chips */
.chips{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:40px}
.chip{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px}
.chip h3{font-size:1.12rem;margin-bottom:8px}
.chip p{color:var(--muted);font-size:.96rem}
.chip .ico{font-family:var(--mono);color:var(--cyan);font-weight:700;font-size:.8rem;letter-spacing:.1em}

/* pillars */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
.pillar{border-top:2px solid var(--accent);padding-top:20px}
.pillar h3{font-size:1.2rem;margin-bottom:10px}
.pillar p{color:var(--muted);font-size:1rem}

/* verticals */
.verticals{background:var(--bg-soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.vcards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:44px}
.vcard{background:linear-gradient(180deg,var(--surface),var(--bg-soft));border:1px solid var(--border);border-radius:18px;padding:30px;transition:.18s}
.vcard:hover{border-color:var(--accent);transform:translateY(-4px)}
.vcard .tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--cyan)}
.vcard h3{font-size:1.3rem;margin:12px 0 10px}
.vcard p{color:var(--muted);font-size:.98rem;margin-bottom:18px}
.vcard a{color:var(--accent);font-weight:700;font-size:.95rem}

/* proof */
.proof{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.proof blockquote{font-size:1.25rem;font-weight:700;line-height:1.4;letter-spacing:-.01em}
.proof .src{color:var(--muted);font-family:var(--mono);font-size:.85rem;margin-top:16px}
.bigstat{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:34px;text-align:center}
.bigstat .n{font-size:3.4rem;font-weight:900;background:linear-gradient(100deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.03em}
.bigstat .l{color:var(--muted);font-size:.95rem;margin-top:6px}

/* outcomes */
.outcomes{background:var(--bg-soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.ogrid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:40px;text-align:center}
.ogrid .n{font-size:2.8rem;font-weight:900;background:linear-gradient(100deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-.02em}
.ogrid .l{color:var(--muted);margin-top:4px}

/* hpe band */
.hpe{background:linear-gradient(120deg,rgba(79,140,255,.10),rgba(45,226,192,.06));border:1px solid var(--border);border-radius:22px;padding:48px;text-align:center;margin:0 auto}
.hpe h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:14px}
.hpe p{color:var(--muted);max-width:62ch;margin:0 auto 22px}

/* final cta */
.final{text-align:center;padding:88px 0}
.final h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:14px}
.final p{color:var(--muted);font-size:1.2rem;margin-bottom:30px}

/* footer */
.ft{border-top:1px solid var(--border);background:var(--bg-soft);padding:54px 0 36px}
.ft-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr 1fr;gap:28px}
.ft h4{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);margin-bottom:14px}
.ft a{display:block;color:var(--muted);font-size:.94rem;padding:5px 0}
.ft a:hover{color:var(--text)}
.ft-bottom{border-top:1px solid var(--border);margin-top:36px;padding-top:22px;color:var(--muted-2);font-size:.86rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}

/* preview banner */
.previewbar{background:#1b2942;border-bottom:1px solid var(--border);text-align:center;font-family:var(--mono);font-size:.78rem;color:var(--cyan);padding:7px}

@media(max-width:860px){
  .chips,.pillars,.vcards,.ogrid{grid-template-columns:1fr}
  .proof{grid-template-columns:1fr;gap:28px}
  .ft-grid{grid-template-columns:1fr 1fr}
  .ft-grid>:first-child{grid-column:1 / -1}   /* brand spans full width; 4 link columns form a balanced 2×2 */
  .section-pad{padding:64px 0}
}

/* ---------- interior pages ---------- */
.page-hero{padding:64px 0 56px;background-color:#0A0E1A;background-image:
  radial-gradient(800px 440px at 80% -20%,rgba(79,140,255,.16),transparent 60%),
  radial-gradient(600px 420px at 0% 20%,rgba(45,226,192,.08),transparent 55%);
  border-bottom:1px solid var(--border)}
.page-hero h1{font-size:clamp(2rem,4.4vw,3.2rem);font-weight:900;margin:16px 0}
.page-hero h1 .grad{background:linear-gradient(100deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero .lead{font-size:1.22rem;margin-bottom:28px}
.feature{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:42px}
.fcard{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:28px}
.fcard h3{font-size:1.15rem;margin-bottom:8px}
.fcard p{color:var(--muted);font-size:.97rem}
/* Two-paragraph cards: promote the first line to a full-strength lead, keep the detail quiet.
   :has(+ p) targets the hook only when a detail paragraph follows, so single-p cards are untouched. */
.fcard p:has(+ p){color:var(--text);font-weight:500;margin-bottom:8px}
.fcard p + p{font-size:.92rem}
/* inline source/citation link (backs a claim with its published source) */
.cite{color:var(--accent);font-weight:600;font-size:.85rem;white-space:nowrap}
.cite:hover{text-decoration:underline}
/* centered group label inside a section (e.g. the two halves of "Trusted & proven") */
.tgroup-label{text-align:center;font-family:var(--mono);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted-2)}
.fcard .k,.ucard .k{font-family:var(--mono);color:var(--cyan);font-size:.76rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.painlist{list-style:none;margin-top:26px;display:grid;gap:14px;max-width:none}
.painlist li{padding-left:30px;position:relative;color:var(--muted);font-size:1.04rem}
.painlist li::before{content:"→";position:absolute;left:0;color:var(--accent);font-weight:800}
.engine{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:40px}
.eng{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:22px}
.eng .nm{font-weight:800;font-size:1.05rem}
.eng .nm b{color:var(--accent)}
.eng p{color:var(--muted);font-size:.9rem;margin-top:7px}
.spec{width:100%;border-collapse:collapse;margin-top:36px;font-size:.96rem}
.spec th,.spec td{text-align:left;padding:14px 16px;border-bottom:1px solid var(--border)}
.spec th{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted-2)}
.spec td{color:var(--muted)}.spec td:first-child{color:var(--text);font-weight:700}
.note{font-size:.85rem;color:var(--muted-2);margin-top:12px;font-style:italic}
@media(max-width:860px){.feature,.engine{grid-template-columns:1fr}}

/* ---------- hero animation layout ---------- */
.hero-in{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:start}
.hero-copy{min-width:0;margin-top:28px}
.hero-art{position:relative;display:flex;justify-content:center;align-items:center}
.hero-art::before{content:"";position:absolute;inset:8%;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,rgba(79,140,255,.22),rgba(45,226,192,.10) 45%,transparent 70%);
  filter:blur(16px);z-index:0}
.hero-lottie{position:relative;z-index:1;width:100%;max-width:540px;aspect-ratio:1/1}
@media(max-width:980px){
  .hero-in{grid-template-columns:1fr;gap:16px}
  .hero-art{max-width:380px;margin:6px auto 0}
  .hero-copy{margin-top:0}        /* drop desktop alignment nudge once stacked */
  .hero .hero-in{margin-top:14px}
}

/* ---------- publications & news ---------- */
.pubgroup{margin-top:42px}
.pubgroup .yr{font-family:var(--mono);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted-2);padding-bottom:10px;border-bottom:1px solid var(--border-2)}
.pubitem{display:grid;grid-template-columns:172px 1fr;gap:26px;padding:22px 2px;border-bottom:1px solid var(--border);transition:.15s}
.pubitem:hover{background:rgba(255,255,255,.018)}
.pubitem .meta{font-family:var(--mono);font-size:.78rem;color:var(--cyan);line-height:1.55}
.pubitem .meta .date{display:block;color:var(--text);font-weight:700;margin-bottom:3px;letter-spacing:.01em}
.pubitem .body h3{font-size:1.08rem;line-height:1.32;margin-bottom:6px}
.pubitem .body p{color:var(--muted);font-size:.95rem;margin-bottom:9px;max-width:80ch}
.pubitem .body a.read{color:var(--accent);font-weight:700;font-size:.88rem}
.pubitem .body a.read:hover{color:var(--text)}
@media(max-width:860px){.pubitem{grid-template-columns:1fr;gap:8px}}

/* ---------- legacy-structure homepage sections ---------- */
/* partner band */
.partners{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px}
.pcard{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:12px}
.pcard .pname{font-weight:800;font-size:1.05rem;letter-spacing:-.01em}
.pcard-logo{height:30px;width:auto;display:block}
.pcard .pname b{color:var(--accent)}
.pcard p{color:var(--muted);font-size:.95rem;flex:1;margin:0}
.pcard a{color:var(--accent);font-weight:700;font-size:.9rem}
.pcard a:hover{color:var(--text)}

/* 4-up pillars */
.pillars.quad{grid-template-columns:repeat(4,1fr)}

/* split section: copy + animation */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.split .lead{margin-bottom:22px}
.split-sub{font-family:var(--mono);color:var(--cyan);font-size:.9rem;letter-spacing:.03em;margin:-2px 0 16px}
.split-art{position:relative;display:flex;justify-content:center;align-items:center}
.split-art::before{content:"";position:absolute;inset:8%;border-radius:50%;
  background:radial-gradient(circle at 50% 45%,rgba(45,226,192,.18),rgba(79,140,255,.10) 45%,transparent 70%);filter:blur(16px);z-index:0}
.split-lottie{position:relative;z-index:1;width:100%;max-width:520px;aspect-ratio:1/1}


/* news cards */
.newsrow{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:40px}
.newscard{background:linear-gradient(180deg,var(--surface),var(--bg-soft));border:1px solid var(--border);border-radius:16px;padding:28px}
.newscard .when{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.newscard h3{font-size:1.12rem;margin:10px 0 8px;line-height:1.32}
.newscard p{color:var(--muted);font-size:.93rem;margin-bottom:12px}
.newscard a{color:var(--accent);font-weight:700;font-size:.9rem}
.newscard a:hover{color:var(--text)}
.newsmore{text-align:center;margin-top:30px}

@media(max-width:980px){.split{grid-template-columns:1fr;gap:16px}.split-art{max-width:380px;margin:6px auto 0}}
@media(max-width:860px){.partners,.ucards,.newsrow{grid-template-columns:1fr}.pillars.quad{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.pillars.quad{grid-template-columns:1fr}}

/* ---------- forms ---------- */
.form{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:720px;margin-top:10px;position:relative}
.form .full{grid-column:1/-1}
.form label{display:block;font-size:.8rem;color:var(--muted);margin-bottom:6px;font-weight:600}
.form input,.form select,.form textarea{width:100%;background:var(--surface);border:1px solid var(--border-2);border-radius:10px;padding:12px 14px;color:var(--text);font-family:inherit;font-size:.95rem}
.form input:focus,.form select:focus,.form textarea:focus{outline:none;border-color:var(--accent)}
.form textarea{min-height:120px;resize:vertical}
.form .hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form .consent{display:flex;gap:10px;align-items:flex-start;font-size:.85rem;color:var(--muted)}
.form .consent input{width:auto;margin-top:3px}
.contact-grid{display:grid;grid-template-columns:1.3fr .9fr;gap:48px;align-items:start}
.contact-methods a{color:var(--accent);font-weight:700}
.contact-methods a:hover{color:var(--text)}
@media(max-width:780px){.contact-grid{grid-template-columns:1fr;gap:28px}}
@media(max-width:680px){.form{grid-template-columns:1fr}}


/* ---------- nav: utility bar + dropdowns + mobile toggle ---------- */
.topbar{background:#0E1424;border-bottom:1px solid var(--border-2)}
.topbar-in{display:flex;justify-content:space-between;align-items:center;height:44px}
.topbar-label{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#90A2C0}
.topbar-links{display:flex;gap:26px;align-items:center}
.topbar a{font-family:var(--font);font-size:.9rem;letter-spacing:0;color:#D7E0EF;font-weight:600}
.topbar a:hover{color:#fff}
@media(max-width:560px){.topbar-label{display:none}.topbar-in{justify-content:center}.topbar-links{gap:18px}}
.nav-link i{font-style:normal;font-size:.66em;opacity:.6;margin-left:3px;vertical-align:2px}
.navitem{position:relative;display:flex;align-items:center}
.dropdown{position:absolute;top:calc(100% + 8px);left:0;min-width:214px;background:var(--surface);border:1px solid var(--border-2);border-radius:12px;padding:8px;display:none;flex-direction:column;gap:2px;box-shadow:0 18px 44px rgba(0,0,0,.45);z-index:60}
.navitem:hover .dropdown,.navitem:focus-within .dropdown{display:flex}
.dropdown::before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px}
.dropdown a{color:var(--muted);font-weight:600;font-size:.9rem;padding:9px 12px;border-radius:8px;white-space:nowrap}
.dropdown a:hover{color:var(--text);background:var(--surface-2)}
.dropdown-right{left:auto;right:0}
.dropdown .grp{font-family:var(--mono);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);padding:9px 12px 4px}
.dropdown a + .grp{margin-top:6px;border-top:1px solid var(--border-2);padding-top:11px}
.navitem-cust{margin-left:10px}
.navitem-cust .navparent{border:1px solid var(--border-2);border-radius:9px;padding:8px 14px}
.navitem-cust:hover .navparent,.navitem-cust .navparent:focus{border-color:var(--accent);color:#fff}
@media(max-width:1080px){.navitem-cust .navparent{border:none;border-radius:0;padding:13px 0}}
.navtoggle{position:absolute;left:-9999px}
.navburger{display:none}
@media(max-width:1080px){
  .navburger{display:flex;flex-direction:column;gap:5px;cursor:pointer;padding:6px}
  .navburger span{width:24px;height:2px;background:var(--text);border-radius:2px}
  .nav{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--bg-soft);border-bottom:1px solid var(--border);padding:8px 24px 18px;max-height:82vh;overflow:auto}
  .navtoggle:checked ~ .nav{display:flex}
  .nav>.nav-link{padding:13px 0;border-bottom:1px solid var(--border)}
  .navitem{display:block;position:static}
  .navitem>.nav-link{padding:13px 0;border-bottom:1px solid var(--border)}
  .dropdown{position:static;display:flex;min-width:0;border:none;box-shadow:none;background:transparent;padding:4px 0 10px 14px}
  .nav .btn-primary{margin-top:14px;text-align:center}
}

.navparent{color:#C7D2E4;font-weight:600;font-size:.93rem;cursor:default}
.navitem:hover .navparent,.navparent:focus{color:#fff;outline:none}

/* light-theme card elevation */
.chip,.fcard,.vcard,.eng,.ucard,.pcard,.bigstat,.newscard{box-shadow:0 1px 2px rgba(12,22,42,.05),0 10px 26px rgba(12,22,42,.06)}

/* logo image + animation container sizing */
.logo-img{height:30px;width:auto;display:block}
.hero-lottie,.split-lottie{min-height:240px}
/* full-width hero headline above the animation */
.hero .hero-title{font-size:clamp(2.4rem,6vw,4.4rem);max-width:none;margin:14px 0 6px}
.hero .hero-in{margin-top:24px}
/* dark feature band (homepage "approach") — gives the reused dark animation its needed navy bg */
.darkband{--bg:#0A0E1A;--bg-soft:#0E1424;--surface:#121C30;--surface-2:#16223A;--border:rgba(255,255,255,0.09);--border-2:rgba(255,255,255,0.16);--text:#E9EFF8;--muted:#9AACC6;--muted-2:#6F84A3;--cyan:#2DE2C0;background:#0A0E1A;color:var(--text)}
/* full-width proof strip at the bottom of the hero banner */
.hero-statbar{margin-top:46px;padding-top:26px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:14px 24px;justify-content:center}

/* paper figures */
.figure{margin-top:40px}
.figure img{width:100%;height:auto;display:block;border:1px solid var(--border);border-radius:14px;background:#fff}
.figcap{margin-top:12px;font-family:var(--mono);font-size:.8rem;color:var(--muted-2);letter-spacing:.02em}

/* comparison table */
.compare-wrap{overflow-x:auto;margin-top:30px;border:1px solid var(--border);border-radius:14px}
.compare{width:100%;border-collapse:collapse;font-size:.95rem;min-width:760px}
.compare th,.compare td{padding:13px 14px;border-bottom:1px solid var(--border);text-align:center}
.compare tr:last-child td{border-bottom:none}
.compare th:first-child,.compare td:first-child{text-align:left;color:var(--text);font-weight:600;min-width:240px}
.compare thead th{font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted-2);font-weight:700}
.compare thead th.zx,.compare td.zx{background:var(--accent-soft)}
.compare thead th.zx{color:var(--accent)}
.compare .y{color:var(--accent);font-weight:800}
.compare .n{color:var(--muted-2)}
.compare .p{color:var(--muted);font-size:.82rem}

/* logo strip (trust section) */
.logostrip{display:flex;align-items:center;justify-content:center;gap:42px;flex-wrap:wrap;margin:6px 0 4px}
.logostrip img{width:auto}
.logostrip .lt{font-family:var(--mono);font-size:.8rem;color:var(--muted-2);letter-spacing:.06em}

/* Glossary */
.glossary{margin-top:34px;column-gap:48px}
.glossary dt{font-weight:800;font-size:1.12rem;color:var(--text);margin-top:24px;scroll-margin-top:90px}
.glossary dt:first-child{margin-top:0}
.glossary dd{margin:7px 0 0;color:var(--muted);max-width:74ch;line-height:1.6}
.glossary dd a{color:var(--accent);font-weight:600}
.glossary dd a:hover{color:var(--text)}

/* Blog */
.article{max-width:768px;margin:0 auto}
.article .meta{color:var(--muted);font-family:var(--mono);font-size:.84rem;letter-spacing:.04em;margin-bottom:26px}
.article p{font-size:1.13rem;color:var(--text);line-height:1.72;margin-top:20px}
.article h2{font-size:1.55rem;margin-top:44px}
.article ul{margin:18px 0 0 22px}
.article li{color:var(--text);font-size:1.08rem;line-height:1.6;margin-top:9px}
.article a{color:var(--accent);font-weight:600}
.article a:hover{color:var(--text)}
.postlist{display:grid;gap:20px;margin-top:44px}
.post{display:block;background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:30px;transition:.16s}
.post:hover{border-color:var(--accent);transform:translateY(-3px)}
.post .tag{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--cyan)}
.post h3{font-size:1.4rem;margin:10px 0 8px;color:var(--text)}
.post p{color:var(--muted);font-size:1rem}
.post .more{color:var(--accent);font-weight:700;font-size:.92rem;margin-top:12px;display:inline-block}

/* audience sub-segment tags in industry hero */
.serves{margin-top:20px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.serves .lbl{font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-right:6px}
.serves .tag{font-family:var(--mono);font-size:.74rem;color:var(--text);background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:999px;padding:5px 12px;white-space:nowrap}

/* transfer calculator */
.calc{display:grid;grid-template-columns:1fr 1fr;gap:30px;align-items:start;margin-top:10px}
.calc-in label{display:block;font-family:var(--mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.calc-in input,.calc-in select{width:100%;margin-top:8px;padding:13px 14px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:1rem;font-family:inherit;font-weight:600}
.calc-in select{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding-right:44px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2352607A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;background-size:12px 8px}
.calc-row{display:flex;gap:10px;margin-top:8px}
.calc-row input{flex:2;margin-top:0}.calc-row select{flex:1;margin-top:0}
.calc-out{display:flex;flex-direction:column;gap:14px}
.calc-res{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:0 1px 3px rgba(14,26,46,.05)}
.calc-k{font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.calc-n{font-size:2.6rem;font-weight:900;line-height:1.05;margin:8px 0 2px;background:linear-gradient(100deg,var(--accent),var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent}
.calc-today{opacity:.9}.calc-today .calc-n{background:none;color:var(--muted);-webkit-text-fill-color:var(--muted)}
.calc-l{font-size:.9rem;color:var(--muted)}
.calc-delta{font-size:1.15rem;color:var(--text);font-weight:500;padding:6px 2px}
.calc-delta b{color:var(--cyan);font-weight:800}
/* labelled field + info popover (cost-of-slow-data calc) */
.calc-in .cfield{margin-bottom:20px}
.calc-in .clab-row{display:flex;align-items:center;gap:7px;min-height:16px}
.calc-in .clab{font-family:var(--mono);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.info{display:inline-flex;align-items:center;justify-content:center;flex:none;width:18px;height:18px;border-radius:50%;border:1px solid var(--accent);background:var(--surface);color:var(--accent);font:700 11px/1 var(--mono);font-style:normal;cursor:pointer;position:relative;user-select:none}
.info:hover,.info:focus{background:var(--accent);color:#fff;outline:none}
.info-pop{display:none;position:absolute;z-index:40;left:-4px;top:24px;width:min(290px,80vw);background:var(--surface);color:var(--text);border:1px solid var(--border);border-radius:10px;padding:13px 15px;font-family:inherit;font-size:.82rem;font-weight:400;font-style:normal;line-height:1.55;letter-spacing:normal;text-transform:none;box-shadow:0 10px 34px rgba(14,26,46,.18)}
.info-pop b{color:var(--text);font-weight:700}
.info-pop a{color:var(--accent)}
.info-pop cite{display:block;margin-top:7px;font-size:.74rem;color:var(--muted);font-style:normal}
.info:hover .info-pop,.info:focus .info-pop,.info:focus-within .info-pop{display:block}
.calc-sol{font-size:.95rem;line-height:1.5;background:var(--bg-soft);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:12px;padding:13px 16px;color:var(--text)}
.calc-sol b{font-weight:700}
.calc-sol a{color:var(--accent);font-weight:700;white-space:nowrap}
.calc-energy{background:var(--bg-soft);border:1px solid var(--border);border-left:3px solid var(--cyan);border-radius:14px;padding:15px 18px}
.calc-energy .ce-k{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.calc-energy .ce-n{font-size:1.45rem;font-weight:800;color:var(--text);margin:6px 0 3px;line-height:1.15}
.calc-energy .ce-n b{color:var(--cyan);font-weight:800}
.calc-energy .ce-l{font-size:.85rem;color:var(--muted);line-height:1.45}
@media(max-width:760px){.calc{grid-template-columns:1fr;gap:20px}}

/* business-case print view */
.printonly{display:none}
#pcard .pc-h{display:flex;align-items:center;gap:12px;font-size:1.1rem;font-weight:800;color:#0E1A2E;margin-bottom:18px}
#pcard .pc-h img{height:34px}
#pcard .pc-ind{font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;color:#52607A;font-size:.8rem;margin-bottom:6px}
#pcard .pc-t{width:100%;border-collapse:collapse;margin:10px 0 18px}
#pcard .pc-t td{padding:7px 0;border-bottom:1px solid #E2E8F2;font-size:.95rem;color:#0E1A2E}
#pcard .pc-t td:last-child{text-align:right;color:#52607A}
#pcard .pc-big{font-size:2rem;font-weight:900;color:#0E1A2E;margin:10px 0 4px}
#pcard .pc-sub{color:#52607A;margin-bottom:18px}
#pcard .pc-p{font-size:.95rem;color:#0E1A2E;line-height:1.6;margin:10px 0}
@media print{
  body *{visibility:hidden}
  #pcard,#pcard *{visibility:visible}
  #pcard{display:block;position:absolute;left:0;top:0;width:100%;padding:48px 56px;background:#fff}
  .hdr,.ft,header,footer,.navtoggle,.navburger{display:none!important}
}

/* pitch builder */
.pitch-ctl{display:flex;flex-wrap:wrap;gap:20px;align-items:flex-end;margin-bottom:0}
.pitch-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:26px}
.pitch-ctl label{display:block;font-family:var(--mono);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.pitch-ctl select{display:block;margin-top:8px;padding:12px 40px 12px 15px;border:1px solid var(--border);border-radius:10px;background:var(--surface);color:var(--text);font-size:1rem;font-weight:600;min-width:268px}
.pdoc{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px 44px;max-width:780px;box-shadow:0 2px 10px rgba(14,26,46,.06);margin-top:26px}
.pdoc .pd-head{display:flex;align-items:center;gap:12px;font-size:1.15rem;font-weight:800;color:var(--text);margin-bottom:6px}
.pdoc .pd-head img{height:34px}
.pdoc .pd-meta{font-family:var(--mono);font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin-bottom:20px}
.pdoc h3{font-size:1.05rem;margin:20px 0 4px;color:var(--text)}
.pdoc p{color:var(--muted);line-height:1.65;margin:4px 0}
.pdoc b{color:var(--text)}
.pdoc .pd-foot{margin-top:24px;padding-top:16px;border-top:1px solid var(--border);font-family:var(--mono);font-size:.78rem;color:var(--muted)}
@media print{
  body *{visibility:hidden}
  #pdoc,#pdoc *{visibility:visible}
  /* pitch page: drop all chrome from the print FLOW so the doc prints from the top and paginates cleanly (no absolute-positioning offset/clipping) */
  .pitch-print .hdr,.pitch-print header,.pitch-print .toolnav,.pitch-print .page-hero,.pitch-print .pitch-ctl,.pitch-print .pitch-actions,.pitch-print .note,.pitch-print .final,.pitch-print .ft,.pitch-print footer{display:none!important}
  .pitch-print .section-pad{padding:0!important}
  .pitch-print .wrap{padding:0!important;max-width:none!important}
  .pitch-print #pdoc{position:static;margin:0;border:none;box-shadow:none;max-width:none;padding:16px 38px}
  .pitch-print #pdoc h3{font-size:1rem;margin:13px 0 3px;break-after:avoid;page-break-after:avoid}
  .pitch-print #pdoc p,.pitch-print #pdoc li{font-size:.9rem;line-height:1.48}
  .pitch-print #pdoc .pd-sum{font-size:.94rem;padding-bottom:12px;margin-bottom:4px}
  .pitch-print #pdoc .pd-rec{padding:12px 15px}
  /* keep every section/box/list intact across page breaks so the last card never gets cut off */
  .pitch-print #pdoc p,.pitch-print #pdoc ul,.pitch-print #pdoc ol,.pitch-print #pdoc li,.pitch-print #pdoc .pd-rec,.pitch-print #pdoc .pd-sum,.pitch-print #pdoc .pd-foot{break-inside:avoid;page-break-inside:avoid}
  .hdr,.ft,header,footer{display:none!important}
}

.dropdown .dd-cta{margin-top:6px;border-top:1px solid var(--border-2);padding-top:11px;color:var(--cyan);font-weight:700}
.dropdown .dd-cta:hover{color:var(--cyan);background:var(--surface-2)}

/* use-case grid (video tiles) */
.ucards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:42px}
.ucard{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:24px;transition:.16s;display:flex;flex-direction:column}
.ucard:hover{border-color:var(--accent);transform:translateY(-3px)}
.ucard h3{font-size:1.05rem;margin-bottom:8px}
/* Video cards — typographic tiles: big title + play button (no thumbnail) */
.ucard-vid{position:relative;min-height:196px;padding:22px;display:flex;flex-direction:column;text-decoration:none;background:linear-gradient(155deg,#13243F 0%,#0A0E1A 72%);border:1px solid rgba(255,255,255,.08)}
.ucard-vid:hover{border-color:var(--accent);transform:translateY(-3px)}
.ucard-vid .k{color:#2DE2C0}
.ucard-vid h3{color:#fff;font-size:1.32rem;line-height:1.2;font-weight:800;margin:10px 0 0;flex:1}
.vplay{display:inline-flex;align-items:center;gap:12px;margin-top:20px;color:#C7D2E4;font-weight:600;font-size:.85rem}
.vplay-btn{position:relative;flex:none;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);transition:.18s}
.vplay-btn::before{content:"";position:absolute;inset:0;margin:auto;width:0;height:0;border-style:solid;border-width:7px 0 7px 12px;border-color:transparent transparent transparent #fff;transform:translateX(2px)}
.ucard-vid:hover .vplay-btn{background:var(--accent);border-color:var(--accent)}
.ucard-vid:hover .vplay{color:#fff}

/* business-case hub — tool cards */
.toolgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(272px,1fr));gap:18px;margin-top:26px}
.toolcard{position:relative;display:flex;flex-direction:column;gap:11px;padding:28px 26px 24px;border:1px solid var(--border);border-radius:18px;background:var(--surface);text-decoration:none;color:var(--text);box-shadow:0 1px 3px rgba(14,26,46,.05);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.toolcard:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(14,26,46,.13);border-color:var(--cyan)}
.toolcard.accent:hover{border-color:var(--accent)}
.toolcard .tc-tag{font-family:var(--mono);font-size:.64rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted-2);font-weight:700}
.toolcard h3{font-size:1.15rem;margin:0;line-height:1.25;color:var(--text)}
.toolcard p{color:var(--muted);font-size:.91rem;line-height:1.55;margin:0;flex:1}
.toolcard .tc-btn{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:6px;padding:9px 16px;border-radius:11px;border:1px solid var(--cyan);background:var(--cyan-soft);color:var(--cyan);font-weight:700;font-size:.88rem;transition:background .15s ease,color .15s ease}
.toolcard .tc-btn svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.toolcard:hover .tc-btn{background:var(--cyan);color:#fff}
.toolcard.accent .tc-btn{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.toolcard.accent:hover .tc-btn{background:var(--accent);color:#fff}
.toolcard .tc-badge{position:absolute;top:-11px;left:24px;background:var(--accent);color:#fff;font-family:var(--mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;padding:5px 11px;border-radius:999px;box-shadow:0 4px 10px rgba(30,84,219,.32)}
@media(max-width:560px){.toolgrid{grid-template-columns:1fr}}

/* business-case tool switcher (sub-nav on calculator pages) */
.toolnav{background:var(--bg);border-bottom:1px solid var(--border);position:sticky;top:68px;z-index:30}
.toolnav-in{display:flex;flex-wrap:wrap;gap:8px;align-items:center;padding-top:11px;padding-bottom:11px}
.toolnav a{font-size:.85rem;font-weight:600;color:var(--muted);padding:7px 13px;border-radius:999px;border:1px solid transparent;white-space:nowrap;transition:.14s}
.toolnav a:hover{color:var(--text);background:var(--surface-2)}
.toolnav a.active{color:var(--cyan);border-color:var(--cyan);background:var(--cyan-soft)}
.toolnav-home{color:var(--text);font-weight:700;border-right:1px solid var(--border);border-radius:0;padding-right:16px;margin-right:6px}
.toolnav-home:hover{color:var(--cyan);background:transparent}
@media(max-width:640px){.toolnav{position:static}.toolnav-home{border-right:0}}

/* contextual return link on contact page (shown only for tool-originated visits) */
.bc-return{display:inline-flex;align-items:center;gap:6px;font-size:.86rem;font-weight:700;color:var(--cyan);margin-bottom:14px}
.bc-return:hover{text-decoration:underline}

.pdoc .pd-rec{background:var(--cyan-soft);border:1px solid var(--cyan);border-left-width:4px;border-radius:8px;padding:14px 16px;margin:6px 0 10px;color:var(--text);font-size:.98rem;line-height:1.55}

.pdoc .pd-cmp{margin:6px 0 4px;padding-left:20px}
.pdoc .pd-cmp li{color:var(--muted);line-height:1.55;margin:6px 0;font-size:.95rem}
.pdoc .pd-cmp li b{color:var(--text)}

.pdoc .pd-sum{font-size:1.02rem;color:var(--text);line-height:1.6;margin:0 0 8px;padding-bottom:16px;border-bottom:1px solid var(--border)}

.bizcase-band{padding:48px 0;background:var(--bg-soft);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.bizcase-band h2{font-size:clamp(1.5rem,3vw,2rem);margin:10px 0 18px}
.bizcase-band.bizcase-compact{padding:40px 0}
.bizcase-band.bizcase-compact h2{font-size:clamp(1.4rem,2.6vw,1.8rem);margin:8px 0 16px}

.pitch-ctl select:invalid{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.pitch-actions .btn[disabled],.pitch-actions .btn.is-off{opacity:.45;pointer-events:none;box-shadow:none}
.pdoc .pd-empty{text-align:center;color:var(--muted);font-size:1.04rem;line-height:1.65;padding:34px 14px;margin:0}
.pdoc .pd-empty b{color:var(--text)}
.pdoc .pd-plan{margin:8px 0 4px;padding-left:22px}
.pdoc .pd-plan li{color:var(--muted);line-height:1.55;margin:7px 0;font-size:.96rem}
.pdoc .pd-plan li b{color:var(--text)}

/* comparison table */
.cmp-wrap{overflow-x:auto;margin-top:24px}
.cmp{width:100%;border-collapse:collapse;font-size:.96rem;min-width:560px}
.cmp th,.cmp td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--border);vertical-align:top}
.cmp thead th{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);border-bottom:1px solid var(--border-2)}
.cmp th:first-child,.cmp td:first-child{font-weight:700;color:var(--text);width:24%}
.cmp .z{background:var(--cyan-soft)}
.cmp thead th.z{color:var(--cyan)}
.cmp td.z{color:var(--text);font-weight:600}
.cmp tbody tr:last-child td{border-bottom:none}

/* Solutions mega dropdown — two columns side by side */
.dropdown-mega{flex-direction:row;flex-wrap:wrap;min-width:480px;gap:0 20px;padding:12px}
.dropdown-mega .dd-col{display:flex;flex-direction:column;gap:2px;flex:1 1 210px}
.dropdown-mega .dd-cta{flex-basis:100%;width:100%;margin-top:8px}
@media(max-width:1080px){.dropdown-mega{flex-direction:column;min-width:0;padding:4px 0 10px 14px}.dropdown-mega .dd-col{flex:1 1 auto}}

/* cookie-consent banner (small, bottom-left, non-intrusive) */
.ckbar{position:fixed;left:18px;bottom:18px;z-index:300;max-width:330px;display:flex;flex-direction:column;gap:11px;background:#121C30;color:#E9EFF8;border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:14px 16px;box-shadow:0 16px 44px rgba(0,0,0,.45);font-size:.85rem;line-height:1.5}
.ckbar[hidden]{display:none}
.ckbar-act{display:flex;gap:8px;justify-content:flex-end}
.ckbar button{font-weight:700;font-size:.82rem;border-radius:8px;padding:7px 15px;cursor:pointer;border:1px solid transparent;font-family:inherit}
.ckbar #ckno{background:transparent;border-color:rgba(255,255,255,.24);color:#C7D2E4}
.ckbar #ckno:hover{color:#fff;border-color:#fff}
.ckbar #ckyes{background:var(--accent);color:#fff}
.ckbar #ckyes:hover{filter:brightness(1.1)}
@media(max-width:480px){.ckbar{left:12px;right:12px;bottom:12px;max-width:none}}

/* legal pages */
.legal{max-width:760px}
.legal h2{font-size:1.3rem;margin:34px 0 10px}
.legal p{color:var(--muted);margin:10px 0;line-height:1.7}
.legal ul{color:var(--muted);margin:10px 0 10px 22px;line-height:1.7}
.legal li{margin:6px 0}
.legal a{color:var(--accent);font-weight:600}
.legal a:hover{text-decoration:underline}
.legal code{font-family:var(--mono);font-size:.88em;background:var(--surface-2);padding:1px 5px;border-radius:4px}
.legal .upd{font-family:var(--mono);font-size:.8rem;color:var(--muted-2);text-transform:uppercase;letter-spacing:.06em;margin-bottom:18px}
.ft-bottom a{display:inline;color:inherit;padding:0}
.ft-bottom a:hover{color:var(--text)}

/* hero — tighten on phones: less padding, compact headline/subtitle/pills */
@media(max-width:600px){
  .hero{padding:52px 0 46px}
  .hero-kicker{font-size:1.08rem;margin-bottom:14px;min-height:2.9em}  /* reserve 2 lines: longer phrases wrap on phones */
  .hero .lead{font-size:1.12rem;margin-bottom:20px}
  .hero-stat{margin-top:26px;gap:9px}
  .hero-stat .pill{font-size:.76rem;padding:6px 12px}
}
