/*
Theme Name:  Paycape
Theme URI:   https://paycape.com
Author:      Paycape
Description: Official marketing theme for Paycape — the finance OS for African businesses.
Version:     6.0.0
License:     GNU General Public License v2 or later
Text Domain: paycape
*/

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,700;12..96,800&family=Mona+Sans:ital,wdth,wght@0,75..125,300..900;1,75..125,300..900&display=swap');

/* ══ TOKENS ══════════════════════════════════════════ */
:root {
  --blue:    #1736B0; --blue-d:  #0f258a; --blue-l:  #EEF2FF;
  --blue-2:  #25346F; --cyan:    #0FE2E9; --cyan-l:  #CCFBFB;
  --yellow:  #F0EB88; --navy:    #07123F; --ink:     #080B18;
  --white:   #FFFFFF; --off:     #F6F8FF; --line:    #E7ECFF;
  --text:    #0a0b12; --muted:   #657086;
  --fd: 'Bricolage Grotesque', Georgia, serif;
  --fb: 'Mona Sans', system-ui, sans-serif;
  --r-sm:4px; --r-md:8px; --r-lg:14px; --r-xl:20px;
  --r-2xl:28px; --r-3xl:38px; --r-full:9999px;
  --sh-sm: 0 2px 8px rgba(23,54,176,.07);
  --sh-md: 0 12px 40px rgba(23,54,176,.12);
  --sh-lg: 0 28px 80px rgba(23,54,176,.16);
  --ease: cubic-bezier(.16,1,.3,1);
  --shell: 1180px;
  --nav-h: 80px;
}

/* ══ RESET ══════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);color:var(--text);background:#fff;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}
p{margin-bottom:1rem}
p:last-child{margin-bottom:0}
h1,h2,h3,h4,h5,h6{font-family:var(--fd);font-weight:800;line-height:1.05;letter-spacing:-.05em;color:var(--text)}
h1{font-size:clamp(40px,6vw,80px)}
h2{font-size:clamp(30px,4vw,58px)}
h3{font-size:clamp(18px,2.2vw,28px);letter-spacing:-.04em}
h4{font-size:17px;letter-spacing:-.03em}
.lead{font-size:17px;color:var(--muted);line-height:1.7}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ══ LAYOUT ══════════════════════════════════════════ */
.shell{width:min(var(--shell),calc(100% - 48px));margin:0 auto}
.section{padding:80px 0}
.section-sm{padding:52px 0}
.section-lg{padding:110px 0}
.sec-alt{background:var(--off)}
.sec-dark{background:var(--ink)}
.sec-navy{background:var(--navy)}
.sec-hd{margin-bottom:48px}
.sec-hd.center{text-align:center}
.sec-hd.center .lead{max-width:620px;margin:14px auto 0}

/* ══ EYEBROW ══════════════════════════════════════════ */
.eyebrow{display:inline-flex;align-items:center;gap:7px;font-family:var(--fb);font-size:12px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);background:var(--blue-l);padding:5px 14px;border-radius:var(--r-full);margin-bottom:18px}
.eyebrow .dot{width:7px;height:7px;border-radius:50%;background:var(--cyan);animation:blink 2s infinite}
.eyebrow.light{color:var(--cyan);background:rgba(15,226,233,.12)}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.grad-text{background:linear-gradient(135deg,var(--blue),var(--cyan) 80%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hl{background:var(--blue);color:#fff!important;border-radius:8px;padding:0 8px;-webkit-text-fill-color:#fff!important}

/* ══ BUTTONS ══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 26px;border-radius:var(--r-full);font-family:var(--fb);font-size:14px;font-weight:800;line-height:1;border:1.5px solid transparent;transition:all 200ms var(--ease);white-space:nowrap;cursor:pointer}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:0 10px 32px rgba(23,54,176,.28)}
.btn-primary:hover{background:var(--blue-d);transform:translateY(-2px);box-shadow:0 16px 44px rgba(23,54,176,.38)}
.btn-dark{background:#141414;color:#fff;border-color:#141414;box-shadow:0 8px 24px rgba(0,0,0,.18)}
.btn-dark:hover{background:#000;transform:translateY(-2px)}
.btn-cyan{background:var(--cyan);color:var(--navy);border-color:var(--cyan);font-weight:900;box-shadow:0 10px 32px rgba(15,226,233,.28)}
.btn-cyan:hover{background:#00d5dc;transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--text);border-color:var(--line)}
.btn-outline:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}
.btn-outline-w{background:transparent;color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.3)}
.btn-outline-w:hover{border-color:rgba(255,255,255,.65);background:rgba(255,255,255,.08)}
.btn-sm{padding:9px 18px;font-size:13px}
.btn-lg{padding:16px 32px;font-size:15px}

/* ══ NAV ══════════════════════════════════════════════ */
.site-header{position:sticky;top:0;z-index:200;background:#fff;padding:12px 0;transition:box-shadow 200ms}
.site-header.scrolled{box-shadow:0 2px 24px rgba(23,54,176,.08)}

.nav-pill{display:flex;align-items:center;height:58px;background:#141414;border-radius:var(--r-full);padding:6px 8px 6px 20px;box-shadow:0 14px 40px rgba(0,0,0,.2);gap:0}

/* Logo — inverted white on dark pill */
.nav-logo{display:flex;align-items:center;flex-shrink:0;margin-right:24px}
.nav-logo-img{height:26px;width:auto;display:block}

.nav-links{display:flex;align-items:center;gap:2px;flex:1}
.nav-link{font-family:var(--fb);font-size:13px;font-weight:700;color:rgba(255,255,255,.62);padding:8px 13px;border-radius:var(--r-full);cursor:pointer;transition:all 140ms;display:flex;align-items:center;gap:4px;white-space:nowrap;background:none;border:none}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(255,255,255,.1)}
.chev{width:12px;height:12px;opacity:.5;transition:transform 220ms var(--ease);flex-shrink:0}
.nav-item{position:relative}
.nav-item:hover .chev,.nav-item.open .chev{transform:rotate(180deg)}
/* Bridge gap so mouse can reach dropdown */
.nav-item::after{content:'';position:absolute;bottom:-12px;left:0;right:0;height:12px}

/* Dropdown */
.nav-dropdown{position:absolute;top:calc(100% + 14px);left:50%;transform:translateX(-50%) translateY(-6px);background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);box-shadow:var(--sh-lg);padding:10px;width:580px;display:grid;grid-template-columns:1fr 1fr;gap:4px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 200ms var(--ease),transform 200ms var(--ease),visibility 200ms;z-index:300}
.nav-item:hover .nav-dropdown,.nav-item.open .nav-dropdown{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.dd-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--r-lg);transition:background 140ms;cursor:pointer;text-decoration:none}
.dd-item:hover{background:var(--off)}
.dd-icon{width:36px;height:36px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--blue)}
.dd-icon svg{width:16px;height:16px}
.di1{background:var(--blue-l)}  .di2{background:#dcfce7}
.di3{background:#fef3c7}        .di4{background:#ede9fe}
.di5{background:#fee2e2}        .di6{background:rgba(15,226,233,.12)}
.di7{background:#ffedd5}        .di8{background:var(--blue-l)}
.dd-text strong{display:block;font-size:13px;font-weight:700;color:var(--text);font-family:var(--fb)}
.dd-text span{display:block;font-size:11px;color:var(--muted);margin-top:2px;line-height:1.4}

/* Nav end — fixed alignment and spacing */
.nav-end{display:flex;align-items:center;gap:8px;flex-shrink:0;margin-left:16px}
.nav-ghost{height:40px;padding:0 16px;border-radius:var(--r-full);font-size:13px;font-weight:700;color:rgba(255,255,255,.8);border:1px solid rgba(255,255,255,.22);background:transparent;transition:all 140ms;display:flex;align-items:center;white-space:nowrap;text-decoration:none}
.nav-ghost:hover{border-color:rgba(255,255,255,.55);color:#fff}
.nav-cta{height:40px;padding:0 18px;border-radius:var(--r-full);font-size:13px;font-weight:800;color:var(--navy);background:var(--cyan);border:none;box-shadow:0 4px 16px rgba(15,226,233,.3);transition:all 140ms;display:flex;align-items:center;white-space:nowrap;text-decoration:none}
.nav-cta:hover{background:#00d5dc;transform:translateY(-1px)}
.nav-toggle{display:none;flex-direction:column;gap:5px;padding:8px;margin-left:12px}
.nav-toggle span{display:block;width:22px;height:2px;background:rgba(255,255,255,.8);border-radius:2px;transition:all 220ms}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ══ HERO ══════════════════════════════════════════════ */
.hero{padding:72px 0 48px;text-align:center;overflow:hidden;position:relative;background:linear-gradient(180deg,#fff 0%,#fff 52%,var(--off) 100%)}
.hero::before{content:'';position:absolute;inset:60px 8% auto 8%;height:340px;background-image:linear-gradient(rgba(23,54,176,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(23,54,176,.045) 1px,transparent 1px);background-size:80px 80px;mask-image:linear-gradient(180deg,transparent,black 30%,transparent);pointer-events:none}
.hero-body{position:relative;z-index:1;max-width:860px;margin:0 auto;padding:0 24px}
.hero h1{margin-bottom:20px}
.hero-desc{font-size:17px;color:var(--muted);line-height:1.7;max-width:600px;margin:0 auto 28px}
.hero-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-bottom:28px}

/* Team proof row in hero */
.hero-proof{display:flex;align-items:center;justify-content:center;gap:12px;font-size:13px;color:var(--muted);margin-bottom:52px}
.proof-faces{display:flex}
.pf{width:36px;height:36px;border-radius:50%;border:2.5px solid #fff;overflow:hidden;margin-left:-10px;flex-shrink:0}
.pf:first-child{margin-left:0}
.pf img{width:100%;height:100%;object-fit:cover}
.pf-fallback{background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:800;color:#fff;width:100%;height:100%}
.hero-proof strong{color:var(--text);font-weight:700}

/* Dashboard art */
.hero-art{position:relative;max-width:1000px;height:auto;margin:0 auto}
.dash-frame{position:relative;background:#141414;border-radius:22px;padding:14px;box-shadow:0 36px 100px rgba(0,0,0,.28);overflow:hidden}
.dash-frame img{width:100%;height:auto;border-radius:14px;display:block}
/* Fallback mockup if no image */
.dash-screen{background:#fff;border-radius:14px;padding:20px 22px;text-align:left}
.ds-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.ds-head h3{font-size:18px;font-weight:800;letter-spacing:-.04em}
.ds-user{display:flex;align-items:center;gap:8px;background:var(--off);border-radius:var(--r-full);padding:5px 12px;font-size:12px;font-weight:800}
.ds-dot{width:22px;height:22px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:8px;color:#fff;font-weight:800}
.ds-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:12px}
.ds-m{background:var(--off);border-radius:12px;padding:12px}
.ds-m small{display:block;font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:5px}
.ds-m b{display:block;font-family:var(--fd);font-size:22px;font-weight:800;letter-spacing:-.05em}
.dsc{font-size:9px;font-weight:800;margin-top:2px}.dsc.up{color:#16a34a}.dsc.dn{color:#dc2626}
.ds-chart{background:linear-gradient(180deg,#FAFCFF,var(--off));border-radius:12px;height:88px;position:relative;overflow:hidden}
.ds-bars{position:absolute;bottom:0;left:14px;right:14px;display:flex;align-items:flex-end;gap:5px;height:80%}
.ds-bar{flex:1;border-radius:3px 3px 0 0;background:var(--blue);min-height:5px}

/* Float cards */
.hf{position:absolute;background:#fff;border-radius:var(--r-xl);padding:12px 14px;box-shadow:var(--sh-lg);z-index:4;text-align:left;border:1px solid var(--line)}
.hf small{display:block;font-size:10px;font-weight:800;color:var(--muted);margin-bottom:2px}
.hf b{display:block;font-family:var(--fd);font-size:18px;font-weight:800;letter-spacing:-.04em}
.hf-sub{font-size:10px;color:var(--muted);margin-top:2px}
.hf-badge{display:inline-block;font-size:9px;font-weight:800;padding:2px 8px;border-radius:var(--r-full);background:#dcfce7;color:#166534;margin-top:3px}
.hf1{left:0;bottom:120px;width:175px;animation:fY1 5s ease-in-out infinite}
.hf2{right:0;bottom:140px;width:190px;animation:fY2 5s ease-in-out infinite 1.4s}
@keyframes fY1{0%,100%{transform:translateY(0) rotate(-5deg)}50%{transform:translateY(-8px) rotate(-5deg)}}
@keyframes fY2{0%,100%{transform:translateY(0) rotate(4deg)}50%{transform:translateY(-8px) rotate(4deg)}}

/* ══ LOGOS STRIP ══════════════════════════════════════ */
.logos-strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:16px 0}
.logos-inner{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.logos-label{font-size:12px;color:#c5cad8;font-weight:600;white-space:nowrap}
.logos-row{display:flex;gap:7px;flex-wrap:wrap;flex:1}
.logo-chip{height:26px;background:var(--off);border-radius:var(--r-md);padding:0 14px;display:flex;align-items:center;font-size:11px;font-weight:700;color:#9ca3af;transition:all 140ms}
.logo-chip:hover{background:var(--blue-l);color:var(--blue)}

/* ══ BENTO GRID ══════════════════════════════════════ */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.bc{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);padding:24px;position:relative;overflow:hidden;transition:transform 200ms var(--ease),box-shadow 200ms,border-color 200ms}
.bc:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(23,54,176,.18)}
.bc.sp2{grid-column:span 2}
.bc.dark{background:var(--navy);border-color:transparent}
.bc::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;transform:scaleX(0);transform-origin:left;transition:transform 360ms var(--ease)}
.bc:hover::before{transform:scaleX(1)}
.bab::before{background:var(--blue)}.bac::before{background:var(--cyan)}
.bag::before{background:#16a34a} .baa::before{background:#d97706}
.bap::before{background:#7c3aed} .bar::before{background:#dc2626}
.bi{width:42px;height:42px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.bi svg{width:18px;height:18px}
.bib{background:var(--blue-l)}.bic{background:rgba(15,226,233,.12)}
.big{background:#dcfce7}      .bia{background:#fef3c7}
.bip{background:#ede9fe}      .bir{background:#fee2e2}
.bc h3{font-family:var(--fd);font-size:17px;font-weight:800;letter-spacing:-.04em;color:var(--text);margin-bottom:6px}
.bc.dark h3{color:#fff}
.bc p{font-size:13px;color:var(--muted);line-height:1.6}
.bc.dark p{color:rgba(255,255,255,.5)}
.bento-lnk{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:800;color:var(--blue);margin-top:12px;transition:gap 140ms}
.bc.dark .bento-lnk{color:var(--cyan)}
.bento-lnk:hover{gap:8px}
.bento-lnk svg{width:10px;height:10px}
.bw{margin-top:14px;background:var(--off);border:1px solid var(--line);border-radius:var(--r-lg);padding:10px}
.bwd{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.1)}
.bw-row{display:flex;justify-content:space-between;align-items:center;padding:6px 0;font-size:12px;border-bottom:1px solid var(--line)}
.bw-row:last-child{border-bottom:0}
.bwd .bw-row{border-color:rgba(255,255,255,.1);color:rgba(255,255,255,.8)}
.bw-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.bw-stat{background:#fff;border-radius:var(--r-md);padding:7px;border:1px solid var(--line)}
.bw-stat .sl{font-size:8px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
.bw-stat .sv{font-family:var(--fd);font-size:12px;font-weight:800}
.bw-stat .sc{font-size:8px;color:#16a34a;font-weight:700}
.mp{display:grid;gap:3px}
.mp-row{display:flex;justify-content:space-between;font-size:11px;color:rgba(255,255,255,.7);padding:3px 0}
.mp-sep{height:1px;background:rgba(255,255,255,.1);margin:3px 0}
.mp-tot{color:var(--cyan)!important;font-weight:800}
.mp-v{font-family:var(--fd);font-size:13px;letter-spacing:-.03em}

/* ══ AI ASSISTANT SECTION ══════════════════════════════ */
.ai-section{padding:88px 0;background:linear-gradient(180deg,var(--ink) 0%,#0B1535 100%);position:relative;overflow:hidden}
.ai-section::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:380px;opacity:.04;pointer-events:none}
.ai-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;position:relative;z-index:1}
.ai-copy h2{color:#fff;margin-bottom:16px}
.ai-copy .lead{color:rgba(255,255,255,.65);margin-bottom:28px}
.ai-feat{display:grid;gap:14px;margin-bottom:32px}
.ai-feat-item{display:flex;align-items:flex-start;gap:12px}
.ai-feat-icon{width:36px;height:36px;border-radius:50%;background:rgba(15,226,233,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ai-feat-icon svg{width:16px;height:16px;stroke:var(--cyan)}
.ai-feat-text strong{display:block;font-size:14px;font-weight:800;color:#fff;margin-bottom:2px}
.ai-feat-text span{font-size:13px;color:rgba(255,255,255,.6);line-height:1.5}

/* AI Chat animation */
.ai-chat-wrap{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-2xl);padding:24px;backdrop-filter:blur(12px)}
.ai-chat-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid rgba(255,255,255,.1)}
.ai-orb{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--cyan));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 0 0 4px rgba(15,226,233,.15)}
.ai-orb svg{width:16px;height:16px;stroke:#fff}
.ai-chat-header span{font-size:14px;font-weight:800;color:#fff}
.ai-chat-header small{display:block;font-size:11px;color:rgba(255,255,255,.5)}
.ai-status{width:8px;height:8px;border-radius:50%;background:#4ade80;margin-left:auto;box-shadow:0 0 0 3px rgba(74,222,128,.25);animation:pulse-green 2s infinite}
@keyframes pulse-green{0%,100%{box-shadow:0 0 0 3px rgba(74,222,128,.25)}50%{box-shadow:0 0 0 6px rgba(74,222,128,.08)}}

.ai-messages{display:flex;flex-direction:column;gap:14px;min-height:260px}
.ai-msg{max-width:82%;padding:12px 16px;border-radius:18px;font-size:14px;line-height:1.55}
.ai-msg.user{align-self:flex-end;background:var(--blue);color:#fff;border-radius:18px 18px 4px 18px;opacity:0;animation:msgIn 400ms var(--ease) forwards}
.ai-msg.bot{align-self:flex-start;background:rgba(255,255,255,.1);color:rgba(255,255,255,.9);border-radius:18px 18px 18px 4px;opacity:0;animation:msgIn 400ms var(--ease) forwards}
.ai-typing{align-self:flex-start;background:rgba(255,255,255,.1);border-radius:18px 18px 18px 4px;padding:12px 16px;display:flex;gap:5px;align-items:center;opacity:0;animation:msgIn 400ms var(--ease) forwards}
.ai-typing span{width:7px;height:7px;border-radius:50%;background:rgba(255,255,255,.5);animation:typingDot 1.2s infinite}
.ai-typing span:nth-child(2){animation-delay:.2s}
.ai-typing span:nth-child(3){animation-delay:.4s}
@keyframes typingDot{0%,80%,100%{transform:scale(.8);opacity:.4}40%{transform:scale(1.2);opacity:1}}
@keyframes msgIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.ai-input-row{display:flex;gap:8px;margin-top:16px;padding-top:14px;border-top:1px solid rgba(255,255,255,.1)}
.ai-inp{flex:1;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--r-full);padding:10px 16px;font-size:13px;color:#fff;font-family:var(--fb)}
.ai-inp::placeholder{color:rgba(255,255,255,.35)}
.ai-send{width:38px;height:38px;border-radius:50%;background:var(--cyan);border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all 140ms}
.ai-send:hover{background:#00d5dc;transform:scale(1.08)}
.ai-send svg{width:16px;height:16px;stroke:var(--navy)}

/* ══ STEPS ══════════════════════════════════════════ */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;position:relative}
.steps-grid::before{content:'';position:absolute;top:40px;left:calc(16.667% + 14px);right:calc(16.667% + 14px);height:2px;background:linear-gradient(90deg,var(--blue),var(--cyan));opacity:.25}
.step{text-align:center;display:flex;flex-direction:column;align-items:center;position:relative;z-index:1}
.orb{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-family:var(--fd);font-size:26px;font-weight:800;color:#fff;box-shadow:0 14px 36px rgba(23,54,176,.22)}
.ob{background:linear-gradient(135deg,#8EA2FF,var(--blue))}
.oc{background:linear-gradient(135deg,#8BFAFF,var(--cyan));color:var(--navy)}
.ok{background:linear-gradient(135deg,#F8F2A8,#D4C932);color:var(--navy)}
.step h3{font-size:20px;margin-bottom:8px}
.step p{font-size:14px;color:var(--muted);line-height:1.6}

/* ══ PRICING ══════════════════════════════════════════ */
.pricing-toggle{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:40px}
.tgl-pill{width:52px;height:28px;background:var(--line);border-radius:var(--r-full);cursor:pointer;position:relative;transition:background 220ms}
.tgl-pill.on{background:var(--blue)}
.tgl-thumb{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:#fff;box-shadow:var(--sh-sm);transition:transform 220ms var(--ease)}
.tgl-pill.on .tgl-thumb{transform:translateX(24px)}
.tgl-lbl{font-size:14px;font-weight:700;color:var(--muted)}
.tgl-lbl.active{color:var(--text)}
.save-chip{font-size:10px;font-weight:800;color:#0a6b6f;background:var(--cyan-l);padding:2px 10px;border-radius:var(--r-full)}
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;align-items:start}
.pc{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-2xl);padding:24px;position:relative;transition:transform 200ms var(--ease),box-shadow 200ms}
.pc:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.pc.feat{background:var(--navy);border-color:var(--blue);transform:translateY(-8px)}
.pc.feat:hover{transform:translateY(-12px)}
.feat-tag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--cyan);color:var(--navy);font-size:10px;font-weight:900;letter-spacing:.07em;text-transform:uppercase;padding:3px 14px;border-radius:var(--r-full);white-space:nowrap}
.p-tier{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--blue);margin-bottom:10px}
.feat .p-tier{color:var(--cyan)}
.p-amt{display:flex;align-items:baseline;gap:3px;margin-bottom:6px}
.p-sym{font-size:15px;font-weight:800;color:var(--text);align-self:flex-start;padding-top:6px}
.p-num{font-family:var(--fd);font-size:38px;font-weight:800;letter-spacing:-.05em;color:var(--text);line-height:1}
.p-per{font-size:13px;color:var(--muted)}
.feat .p-sym,.feat .p-num{color:#fff}
.feat .p-per{color:rgba(255,255,255,.45)}
.p-annual{font-size:11px;color:var(--muted);margin-bottom:4px;display:none}
.p-desc{font-size:13px;color:var(--muted);line-height:1.55;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--line)}
.feat .p-desc{color:rgba(255,255,255,.5);border-color:rgba(255,255,255,.1)}
.p-feats{display:grid;gap:7px;margin-bottom:20px}
.pf-item{display:flex;align-items:flex-start;gap:6px;font-size:13px;color:var(--muted);line-height:1.4}
.pf-yes{color:#16a34a;font-weight:800;flex-shrink:0}.pf-no{color:var(--line);flex-shrink:0}
.feat .pf-item{color:rgba(255,255,255,.65)}.feat .pf-yes{color:var(--cyan)}
.p-cta{width:100%;padding:10px;border-radius:var(--r-full);font-family:var(--fb);font-size:13px;font-weight:800;cursor:pointer;transition:all 140ms;border:1.5px solid var(--line);color:var(--text);background:#fff}
.p-cta:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}
.feat .p-cta{background:var(--cyan);color:var(--navy);border-color:var(--cyan);box-shadow:0 6px 18px rgba(15,226,233,.35)}
.feat .p-cta:hover{background:#00d5dc}

/* ══ TESTIMONIALS ══════════════════════════════════════ */
.t-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.t-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);padding:24px;display:flex;flex-direction:column;gap:12px;transition:transform 200ms var(--ease),box-shadow 200ms}
.t-card:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.t-card.feat{background:var(--navy);border-color:rgba(23,54,176,.4)}
.t-stars{display:flex;gap:3px}
.t-star{width:12px;height:12px;background:#f59e0b;clip-path:polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%)}
.t-card.feat .t-star{background:var(--yellow)}
.t-quote{font-size:14px;color:var(--muted);line-height:1.75;flex:1}
.t-card.feat .t-quote{color:rgba(255,255,255,.75)}
.t-author{display:flex;align-items:center;gap:10px}
.t-av{width:36px;height:36px;border-radius:50%;background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:10px;font-weight:800;color:var(--blue);flex-shrink:0;overflow:hidden}
.t-av img{width:100%;height:100%;object-fit:cover}
.t-card.feat .t-av{background:rgba(255,255,255,.12);color:rgba(204,216,255,1)}
.t-name{font-size:13px;font-weight:800}
.t-role{font-size:11px;color:var(--muted);margin-top:1px}
.t-card.feat .t-name{color:#fff}
.t-card.feat .t-role{color:rgba(255,255,255,.4)}

/* ══ ICP GRID ══════════════════════════════════════════ */
.icp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.icp-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);padding:22px;transition:transform 200ms var(--ease),box-shadow 200ms,border-color 200ms}
.icp-card:hover{transform:translateY(-4px);box-shadow:var(--sh-md);border-color:rgba(23,54,176,.18)}
.icp-icon{width:48px;height:48px;border-radius:var(--r-lg);background:var(--blue-l);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-size:11px;font-weight:800;color:var(--blue);margin-bottom:16px}
.icp-card h3{font-size:22px;margin-bottom:7px}
.icp-card p{font-size:13px;color:var(--muted);line-height:1.6}

/* ══ CTA PANEL — consistent across all pages ══════════ */
/* Single source of truth for all CTA blocks */
.cta-panel{background:linear-gradient(135deg,var(--blue),#0B1F72 70%);border-radius:var(--r-3xl);padding:80px 32px;text-align:center;position:relative;overflow:hidden}
.cta-panel::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:420px;opacity:.06;pointer-events:none}
.cta-panel h2{color:#fff;margin-bottom:14px;position:relative;z-index:1}
.cta-panel p,.cta-panel .lead{color:rgba(255,255,255,.65);margin-bottom:32px;max-width:520px;margin-left:auto;margin-right:auto;position:relative;z-index:1}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;position:relative;z-index:1}
/* Product CTA at bottom of product pages */
.product-cta-strip{background:var(--navy);border-radius:var(--r-3xl);padding:72px 32px;text-align:center;position:relative;overflow:hidden;margin:0 0 80px}
.product-cta-strip::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:380px;opacity:.05;pointer-events:none}
.product-cta-strip h2{color:#fff;margin-bottom:14px;position:relative;z-index:1}
.product-cta-strip p{color:rgba(255,255,255,.6);margin-bottom:28px;position:relative;z-index:1;max-width:480px;margin-left:auto;margin-right:auto}
.product-cta-strip .cta-btns{position:relative;z-index:1}

/* ══ INLINE CTA ══════════════════════════════════════ */
.inline-cta{background:linear-gradient(135deg,var(--blue),#0B1F72);border-radius:var(--r-2xl);padding:30px 34px;margin:36px 0;display:flex;align-items:center;justify-content:space-between;gap:22px;position:relative;overflow:hidden}
.inline-cta::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:300px;opacity:.05}
.inline-cta-text{position:relative;z-index:1}
.inline-cta-text strong{display:block;font-family:var(--fd);font-size:19px;font-weight:800;color:#fff;letter-spacing:-.04em;margin-bottom:5px}
.inline-cta-text span{font-size:14px;color:rgba(255,255,255,.65)}
.inline-cta .btn{position:relative;z-index:1;flex-shrink:0}

/* ══ FAQ — Yoast FAQ block ══════════════════════════ */
.wp-block-yoast-faq-block{margin:0!important;padding:0!important}
.wp-block-yoast-faq-block .schema-faq{display:grid;gap:0}
.wp-block-yoast-faq-block .schema-faq-section{border-bottom:1px solid var(--line)}
.wp-block-yoast-faq-block .schema-faq-section:first-child{border-top:1px solid var(--line)}
.wp-block-yoast-faq-block .schema-faq-question{display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-family:var(--fb);font-size:15px;font-weight:800;color:var(--text);cursor:pointer;gap:16px;user-select:none}
.wp-block-yoast-faq-block .schema-faq-question::after{content:'+';min-width:30px;height:30px;border-radius:50%;background:var(--blue-l);color:var(--blue);display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1;flex-shrink:0;transition:transform 220ms var(--ease),background 220ms,color 220ms}
.wp-block-yoast-faq-block .schema-faq-section.open .schema-faq-question::after{transform:rotate(45deg);background:var(--blue);color:#fff}
.wp-block-yoast-faq-block .schema-faq-answer{font-size:15px;color:var(--muted);line-height:1.7;padding-bottom:18px;display:none}
.wp-block-yoast-faq-block .schema-faq-section.open .schema-faq-answer{display:block}
.faq-two-col{display:grid;grid-template-columns:.7fr 1.3fr;gap:72px;align-items:start}
.faq-section{padding:80px 0}

/* ══ BLOG / NEWS ══════════════════════════════════════ */
.archive-hero{background:var(--ink);padding:64px 0;position:relative;overflow:hidden}
.archive-hero::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-fill.png');background-size:400px;opacity:.04;pointer-events:none}
.archive-hero .shell{position:relative;z-index:1}
.archive-hero h1{color:#fff;margin-bottom:12px}
.archive-hero p{color:rgba(255,255,255,.65);font-size:17px;max-width:560px}
.cat-filter{display:flex;gap:8px;flex-wrap:wrap;padding:22px 0;border-bottom:1px solid var(--line);margin-bottom:44px}
.cat-pill{height:32px;padding:0 16px;border-radius:var(--r-full);font-size:12px;font-weight:800;border:1.5px solid var(--line);color:var(--muted);background:#fff;cursor:pointer;transition:all 140ms;display:flex;align-items:center;text-decoration:none}
.cat-pill:hover,.cat-pill.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.post-featured{grid-column:1 / -1;display:grid;grid-template-columns:1.2fr 1fr;gap:0;border-radius:var(--r-2xl);overflow:hidden;border:1px solid var(--line);background:#fff;transition:box-shadow 200ms,transform 200ms var(--ease)}
.post-featured:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.post-featured .post-img{height:100%;min-height:300px;background:linear-gradient(135deg,var(--blue),var(--navy));overflow:hidden}
.post-featured .post-img img{width:100%;height:100%;object-fit:cover}
.post-featured .post-body{padding:36px;display:flex;flex-direction:column;justify-content:center}
.post-featured .post-title{font-size:clamp(20px,2.5vw,30px);margin-bottom:12px}
.post-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);overflow:hidden;display:flex;flex-direction:column;transition:transform 200ms var(--ease),box-shadow 200ms,border-color 200ms}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg);border-color:rgba(23,54,176,.18)}
.post-thumb{height:200px;background:linear-gradient(135deg,var(--blue-l),var(--cyan-l));display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.post-thumb img{width:100%;height:100%;object-fit:cover}
.post-body{padding:20px;flex:1;display:flex;flex-direction:column}
.post-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:8px}
.post-cat{font-size:10px;font-weight:800;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);background:var(--blue-l);padding:3px 10px;border-radius:var(--r-full)}
.post-date{font-size:12px;color:var(--muted)}
.post-title-link{display:block;font-family:var(--fd);font-size:17px;font-weight:800;letter-spacing:-.03em;line-height:1.3;color:var(--text);margin-bottom:7px;transition:color 140ms}
.post-title-link:hover{color:var(--blue)}
.post-excerpt{font-size:13px;color:var(--muted);line-height:1.65;flex:1}
.post-read{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:800;color:var(--blue);margin-top:12px;transition:gap 140ms}
.post-read:hover{gap:8px}
.post-read svg{width:10px;height:10px}
.pagination{display:flex;gap:6px;justify-content:center;margin-top:52px;padding-top:36px;border-top:1px solid var(--line)}
.page-numbers{width:40px;height:40px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;border:1.5px solid var(--line);color:var(--muted);transition:all 140ms;text-decoration:none}
.page-numbers:hover,.page-numbers.current{background:var(--blue);color:#fff;border-color:var(--blue)}
.page-numbers.prev,.page-numbers.next{width:auto;padding:0 14px}

/* ══ SINGLE POST ══════════════════════════════════════ */
.single-hero{background:var(--off);border-bottom:1px solid var(--line);padding:52px 0}
.single-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.read-time{font-size:12px;color:var(--muted);display:flex;align-items:center;gap:5px}
.single-layout{display:grid;grid-template-columns:1fr 300px;gap:52px;padding:52px 0 80px}
.post-content{font-size:17px;line-height:1.85;color:var(--muted)}
.post-content h2,.post-content h3{color:var(--text);margin:2.5rem 0 1rem}
.post-content p{margin-bottom:1.5rem}
.post-content ul,.post-content ol{padding-left:1.5rem;margin-bottom:1.5rem}
.post-content li{margin-bottom:.5rem}
.post-content strong{color:var(--text)}
.post-content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.post-content blockquote{border-left:3px solid var(--blue);padding:14px 22px;background:var(--blue-l);border-radius:0 var(--r-lg) var(--r-lg) 0;margin:2rem 0;font-style:italic;color:var(--blue-2)}
.post-hero-img{border-radius:var(--r-2xl);overflow:hidden;margin-bottom:36px;aspect-ratio:16/7}
.post-hero-img img{width:100%;height:100%;object-fit:cover}
.post-sidebar{position:sticky;top:calc(var(--nav-h) + 16px);height:fit-content;display:flex;flex-direction:column;gap:18px}
.sidebar-widget{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:18px}
.sidebar-widget h4{font-size:14px;font-weight:800;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--blue)}
.widget-cta{background:var(--navy);border-color:transparent}
.widget-cta h4{color:#fff;border-color:var(--cyan)}
.widget-cta p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.65;margin-bottom:12px}
.related-item{padding-bottom:11px;margin-bottom:11px;border-bottom:1px solid var(--line)}
.related-item:last-child{padding-bottom:0;margin-bottom:0;border-bottom:none}
.related-item a{font-size:13px;font-weight:700;color:var(--text);line-height:1.4;display:block;transition:color 140ms}
.related-item a:hover{color:var(--blue)}
.related-item .r-date{font-size:11px;color:var(--muted);margin-top:2px}
.post-nav{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:44px;padding-top:28px;border-top:1px solid var(--line)}
.post-nav a{padding:14px;border:1.5px solid var(--line);border-radius:var(--r-xl);transition:all 140ms;display:block}
.post-nav a:hover{border-color:var(--blue);background:var(--blue-l)}
.pn-dir{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:3px}
.pn-title{font-size:14px;font-weight:800;color:var(--text);letter-spacing:-.02em}

/* ══ GLOSSARY ══════════════════════════════════════════ */
.glossary-hero{background:var(--ink);padding:64px 0;position:relative;overflow:hidden}
.glossary-hero::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-fill.png');background-size:400px;opacity:.04;pointer-events:none}
.glossary-hero .shell{position:relative;z-index:1;text-align:center}
.glossary-hero h1{color:#fff;margin-bottom:12px}
.glossary-hero p{color:rgba(255,255,255,.7)}
.gloss-search-wrap{max-width:480px;margin:22px auto 0;position:relative}
.gloss-search-wrap input{width:100%;padding:13px 16px 13px 44px;border-radius:var(--r-2xl);border:1.5px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-size:15px;font-family:var(--fb);backdrop-filter:blur(8px);transition:border-color 140ms}
.gloss-search-wrap input::placeholder{color:rgba(255,255,255,.45)}
.gloss-search-wrap input:focus{outline:none;border-color:var(--cyan)}
.gloss-ico{position:absolute;left:15px;top:50%;transform:translateY(-50%);width:16px;height:16px;opacity:.55}
.alpha-filter{display:flex;gap:5px;flex-wrap:wrap;padding:22px 0;border-bottom:1px solid var(--line);margin-bottom:36px}
.ltr-btn{width:36px;height:36px;border-radius:var(--r-md);font-family:var(--fd);font-size:14px;font-weight:800;display:flex;align-items:center;justify-content:center;cursor:pointer;border:1.5px solid var(--line);color:var(--muted);background:#fff;transition:all 140ms}
.ltr-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l)}
.ltr-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.ltr-btn.all-btn{width:auto;padding:0 14px;font-family:var(--fb);font-size:13px}
.gl-group{margin-bottom:44px}
.gl-letter{font-family:var(--fd);font-size:3rem;font-weight:800;letter-spacing:-.06em;color:var(--blue);margin-bottom:14px;padding-bottom:8px;border-bottom:2.5px solid var(--blue)}
.gl-term{background:#fff;border:1.5px solid var(--line);border-radius:var(--r-xl);padding:16px 20px;margin-bottom:7px;transition:all 140ms}
.gl-term:hover{border-color:rgba(23,54,176,.25);transform:translateX(4px);box-shadow:var(--sh-sm)}
.gl-term dt{font-family:var(--fd);font-weight:800;font-size:15px;color:var(--text);margin-bottom:3px;letter-spacing:-.02em}
.gl-term dd{font-size:14px;color:var(--muted);line-height:1.7}

/* ══ CONTACT PAGE ══════════════════════════════════════ */
.contact-hero{background:var(--ink);padding:64px 0;position:relative;overflow:hidden}
.contact-hero::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-fill.png');background-size:380px;opacity:.04}
.contact-hero .shell{position:relative;z-index:1}
.contact-hero h1{color:#fff;margin-bottom:14px}
.contact-hero p{color:rgba(255,255,255,.65);font-size:17px;max-width:540px}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:68px;padding:68px 0 80px;align-items:start}
.contact-form-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);padding:34px;box-shadow:var(--sh-md)}
.contact-form-wrap h2{font-size:26px;margin-bottom:7px}
.contact-form-wrap .sub{font-size:15px;color:var(--muted);margin-bottom:26px}
.form-row{margin-bottom:18px}
.form-row label{display:block;font-size:13px;font-weight:800;color:var(--text);margin-bottom:5px}
.form-row input,.form-row textarea,.form-row select{width:100%;padding:11px 14px;border:1.5px solid var(--line);border-radius:var(--r-lg);font-size:14px;font-family:var(--fb);color:var(--text);background:#fff;transition:border-color 200ms,box-shadow 200ms}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,54,176,.1)}
.form-row textarea{min-height:120px;resize:vertical}
.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-info{display:flex;flex-direction:column;gap:22px;padding-top:12px}
.c-info-card{background:var(--off);border-radius:var(--r-xl);padding:22px;border:1px solid var(--line)}
.c-info-icon{width:42px;height:42px;border-radius:var(--r-lg);background:var(--blue-l);display:flex;align-items:center;justify-content:center;margin-bottom:12px}
.c-info-icon svg{width:19px;height:19px}
.c-info-card h3{font-size:15px;margin-bottom:5px}
.c-info-card p{font-size:14px;color:var(--muted);line-height:1.6}
.c-info-card a{color:var(--blue);font-weight:700}

/* ══ PRICING PAGE ══════════════════════════════════════ */
.pricing-hero{padding:68px 0;text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,var(--off) 100%)}
.pricing-hero::before{content:'';position:absolute;inset:50px 10% auto 10%;height:300px;background-image:linear-gradient(rgba(23,54,176,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(23,54,176,.05) 1px,transparent 1px);background-size:80px 80px;mask-image:linear-gradient(180deg,transparent,black 30%,transparent);pointer-events:none}
.pricing-hero h1{margin-bottom:14px;position:relative;z-index:1}
.pricing-hero p{color:var(--muted);font-size:17px;max-width:520px;margin:0 auto;position:relative;z-index:1}
.comp-table{width:100%;border-collapse:separate;border-spacing:0;margin-top:52px}
.comp-table th{padding:14px 18px;font-size:13px;font-weight:800;text-align:left;background:var(--off);border-bottom:2px solid var(--line)}
.comp-table th:first-child{border-radius:var(--r-lg) 0 0 0}
.comp-table th:last-child{border-radius:0 var(--r-lg) 0 0}
.comp-table th.featured-col{background:var(--blue);color:#fff}
.comp-table td{padding:13px 18px;font-size:13px;border-bottom:1px solid var(--line);vertical-align:middle}
.comp-table tr:last-child td{border-bottom:0}
.comp-table td.featured-col{background:rgba(23,54,176,.04);font-weight:700}
.comp-table .section-row td{background:var(--off);font-weight:800;font-size:12px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);padding:9px 18px}
.check-yes{color:#16a34a;font-weight:800;font-size:16px}
.check-no{color:#d1d5db;font-weight:800}

/* ══ PRODUCT PAGES ══════════════════════════════════════ */
.product-hero{padding:64px 0 56px;position:relative;overflow:hidden}
/* Remove the large gap between hero and next section */
.product-hero + section,.product-hero + .section,.product-hero + div{margin-top:0}
.ph-blue{background:linear-gradient(135deg,var(--blue),var(--navy))}
.ph-blue h1,.ph-blue .lead{color:#fff}
.ph-blue .lead{color:rgba(255,255,255,.7)}
.ph-blue .eyebrow{color:var(--cyan);background:rgba(15,226,233,.12)}
.ph-green{background:radial-gradient(circle at 80% 20%,rgba(40,199,111,.15) 0%,transparent 12%),linear-gradient(180deg,#EEFFF5 0%,#F5FFF9 60%,#fff 100%)}
.ph-cream{background:radial-gradient(circle at 80% 20%,rgba(240,235,136,.35) 0%,transparent 14%),linear-gradient(180deg,#FFFDE8 0%,#FFFCF0 60%,#fff 100%)}
.ph-cyan{background:radial-gradient(circle at 15% 30%,rgba(15,226,233,.18) 0%,transparent 12%),linear-gradient(180deg,#EEFFFE 0%,#F5FFFE 60%,#fff 100%)}
.ph-purple{background:radial-gradient(circle at 12% 22%,rgba(15,226,233,.18) 0%,transparent 12%),radial-gradient(circle at 80% 20%,rgba(123,97,255,.17) 0%,transparent 13%),linear-gradient(180deg,#F5E9FF 0%,#F7F4FF 52%,#fff 100%)}

/* Feature sections — compact spacing */
.prod-feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;padding:56px 0;border-top:1px solid var(--line)}
.prod-feat-grid:first-child{border-top:0;padding-top:0}
.prod-checks{display:grid;gap:10px;margin-bottom:24px}
.prod-check{display:flex;align-items:center;gap:9px;font-weight:700;font-size:14px}
.prod-check::before{content:'';width:22px;height:22px;border-radius:50%;background:var(--blue-l) url("data:image/svg+xml,%3Csvg width='12' height='12' viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 6l3 3 5-5' stroke='%231736B0' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;flex-shrink:0}
.prod-vis{min-height:380px;border-radius:var(--r-2xl);position:relative;overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-lg)}
.pv-blue{background:linear-gradient(135deg,var(--blue),var(--navy))}
.pv-light{background:linear-gradient(135deg,var(--off),#fff)}
.pv-cream{background:linear-gradient(135deg,#FFFBE0,#fff)}
.mock-win{position:absolute;left:24px;right:24px;top:28px;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-radius:var(--r-2xl);padding:16px 18px;box-shadow:var(--sh-md);color:var(--text);border:1px solid rgba(255,255,255,.4)}
.pv-blue .mock-win{background:rgba(255,255,255,.1);color:#fff;border-color:rgba(255,255,255,.15)}
.mock-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;font-weight:800;font-size:13px}
.mock-tag{font-size:10px;font-weight:800;padding:3px 9px;border-radius:var(--r-full);background:var(--blue-l);color:var(--blue)}
.pv-blue .mock-tag{background:rgba(15,226,233,.2);color:var(--cyan)}
.mock-row{display:flex;justify-content:space-between;align-items:flex-start;gap:14px;padding:10px 0;border-bottom:1px solid rgba(23,54,176,.08);font-size:13px;font-weight:700}
.pv-blue .mock-row{border-color:rgba(255,255,255,.1)}
.mock-row:last-child{border-bottom:0}
.mock-row small{display:block;font-size:11px;font-weight:500;color:var(--muted);margin-top:2px}
.pv-blue .mock-row small{color:rgba(255,255,255,.55)}

/* Feat cards */
.feat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.feat-card{border-radius:26px;padding:26px;min-height:200px;position:relative;overflow:hidden;border:1px solid var(--line);transition:transform 200ms var(--ease),box-shadow 200ms}
.feat-card:hover{transform:translateY(-4px);box-shadow:var(--sh-lg)}
.fc-0{background:var(--off)}.fc-y{background:linear-gradient(135deg,#FFF8D7,#fff)}
.fc-c{background:linear-gradient(135deg,#EEFBFF,#fff)}.fc-p{background:linear-gradient(135deg,#FFF1F7,#fff)}
.fc-b{background:linear-gradient(135deg,#EEF4FF,#fff)}.fc-g{background:linear-gradient(135deg,#F2FFF5,#fff)}
.fc-k{background:linear-gradient(135deg,#FFFBE0,#fff)}
.feat-icon{width:46px;height:46px;border-radius:16px;background:#fff;display:grid;place-items:center;color:var(--blue);font-weight:900;font-size:11px;font-family:var(--fd);box-shadow:0 10px 24px rgba(23,54,176,.1);margin-bottom:14px}
.feat-card h3{font-family:var(--fd);font-size:22px;line-height:1;letter-spacing:-.04em;margin:0 0 8px}
.feat-card p{color:var(--muted);line-height:1.55;margin:0;font-size:14px}

/* ══ ABOUT PAGE ══════════════════════════════════════ */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.team-card{text-align:center}
.team-photo{width:160px;height:160px;border-radius:50%;overflow:hidden;margin:0 auto 16px;border:3px solid var(--line);box-shadow:var(--sh-md)}
.team-photo img{width:100%;height:100%;object-fit:cover}
.team-card h3{font-size:18px;margin-bottom:5px}
.team-card .role{color:var(--blue);font-weight:700;font-size:14px;margin-bottom:10px}
.team-card p{font-size:13px;color:var(--muted);line-height:1.6}

/* ══ CALCULATOR PAGES ══════════════════════════════════ */
.calc-hero{padding:64px 0 52px;position:relative;overflow:hidden}
.calc-hero-pattern{position:absolute;inset:50px 8% auto 8%;height:280px;background-image:linear-gradient(rgba(23,54,176,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(23,54,176,.045) 1px,transparent 1px);background-size:72px 72px;mask-image:linear-gradient(180deg,transparent,black 30%,transparent);pointer-events:none}
.calc-hero-inner{display:grid;grid-template-columns:1fr 260px;gap:48px;align-items:center}
.calc-hero-h1{font-size:clamp(32px,5vw,58px);margin-bottom:14px}
.calc-hero-desc{font-size:16px;color:var(--muted);line-height:1.7;margin-bottom:24px}
.calc-hero-stats{display:flex;align-items:center;gap:0;flex-wrap:wrap}
.chs-item{text-align:center}
.chs-item b{display:block;font-family:var(--fd);font-size:22px;font-weight:800;letter-spacing:-.04em;color:var(--blue)}
.chs-item span{font-size:11px;color:var(--muted);font-weight:600}
.chs-divider{width:1px;height:34px;background:var(--line);margin:0 18px}
.calc-hero-badge{display:flex;align-items:center;justify-content:center}
.chb-circle{width:150px;height:150px;border-radius:50%;background:linear-gradient(135deg,var(--blue-l),#fff);border:2px solid var(--line);display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:var(--sh-lg)}
.chb-pct{font-family:var(--fd);font-size:32px;font-weight:800;color:var(--blue);letter-spacing:-.04em}
.chb-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;margin-top:2px}

/* Gate */
.calc-gate-section{background:var(--navy);padding:68px 0;position:relative;overflow:hidden}
.calc-gate-section::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:360px;opacity:.04}
.calc-gate-wrap{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;position:relative;z-index:1}
.calc-gate-heading{font-size:clamp(28px,3.8vw,44px);color:#fff;margin-bottom:12px}
.calc-gate-sub{font-size:15px;color:rgba(255,255,255,.65);line-height:1.7;margin-bottom:24px}
.calc-gate-perks{display:grid;gap:11px;margin-bottom:26px}
.cgp-item{display:flex;align-items:flex-start;gap:9px;font-size:14px;color:rgba(255,255,255,.8);font-weight:600}
.cgp-icon{width:22px;height:22px;border-radius:50%;background:rgba(15,226,233,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cgp-icon svg{width:12px;height:12px}
.calc-gate-proof{display:flex;align-items:center;gap:0;font-size:13px;color:rgba(255,255,255,.6)}
.calc-gate-proof strong{color:#fff}
.calc-gate-form-wrap{background:#fff;border-radius:var(--r-2xl);padding:32px;box-shadow:var(--sh-lg)}
.calc-gate-form-title{font-size:21px;margin-bottom:7px}
.calc-gate-form-desc{font-size:14px;color:var(--muted);line-height:1.65;margin-bottom:18px}
.calc-gate-error{background:#fee2e2;border:1px solid #fecaca;color:#dc2626;border-radius:var(--r-lg);padding:9px 13px;font-size:13px;font-weight:700;margin-bottom:14px}
.calc-gate-form{display:grid;gap:13px}
.calc-gate-privacy{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--muted);text-align:center;justify-content:center;margin-top:6px!important}
.calc-welcome-banner{background:linear-gradient(90deg,var(--navy),var(--blue-2));padding:13px 0}
.calc-welcome-inner{display:flex;align-items:center;justify-content:space-between;gap:14px;font-size:14px;color:rgba(255,255,255,.85);flex-wrap:wrap}

/* Calculator form */
.calc-layout{display:grid;grid-template-columns:1fr 310px;gap:28px;align-items:start}
.calc-main{display:flex;flex-direction:column;gap:0}
.calc-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-2xl);padding:28px;box-shadow:var(--sh-md)}
.calc-card-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px;padding-bottom:18px;border-bottom:1px solid var(--line)}
.cc-icon{width:46px;height:46px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cc-icon svg{width:20px;height:20px}
.cc-title{font-size:19px;font-weight:800;color:var(--text);letter-spacing:-.04em;margin-bottom:2px}
.cc-sub{font-size:13px;color:var(--muted)}
.calc-fields{display:grid;gap:18px}
.cf-section-head{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--blue);padding-bottom:7px;border-bottom:1px solid var(--line)}
.cf-row{display:grid;gap:5px}
.cf-label{font-size:13px;font-weight:800;color:var(--text);display:block}
.cf-hint{display:block;font-size:11px;font-weight:400;color:var(--muted);margin-top:2px}
.cf-input-wrap{position:relative;display:flex;align-items:center}
.cf-prefix{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:15px;font-weight:700;color:var(--muted);pointer-events:none;z-index:1}
.cf-input{width:100%;height:46px;border-radius:var(--r-full);border:1.5px solid var(--line);padding:0 13px 0 38px;font-family:var(--fb);font-size:15px;font-weight:600;color:var(--text);background:#fff;transition:border-color 140ms,box-shadow 140ms;-moz-appearance:textfield}
.cf-input::-webkit-inner-spin-button,.cf-input::-webkit-outer-spin-button{-webkit-appearance:none}
.cf-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(23,54,176,.1)}
.cf-select{width:100%;height:46px;border-radius:var(--r-full);border:1.5px solid var(--line);padding:0 38px 0 13px;font-family:var(--fb);font-size:14px;font-weight:600;color:var(--text);background:#fff url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23657086' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 14px center;cursor:pointer;-webkit-appearance:none;transition:border-color 140ms}
.cf-select:focus{outline:none;border-color:var(--blue)}
.cf-radio-group{display:grid;gap:7px}
.cf-radio{display:flex;align-items:flex-start;gap:9px;padding:12px 14px;border-radius:var(--r-xl);border:1.5px solid var(--line);cursor:pointer;transition:border-color 140ms,background 140ms}
.cf-radio.active{border-color:var(--blue);background:var(--blue-l)}
.cf-radio input{display:none}
.cf-radio-mark{width:18px;height:18px;border-radius:50%;border:2px solid var(--line);flex-shrink:0;margin-top:2px;transition:border-color 140ms,background 140ms;position:relative}
.cf-radio.active .cf-radio-mark{border-color:var(--blue);background:var(--blue)}
.cf-radio.active .cf-radio-mark::after{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#fff}
.cf-radio-text strong{display:block;font-size:14px;font-weight:800;color:var(--text)}
.cf-radio-text span{display:block;font-size:12px;color:var(--muted);margin-top:2px}
.calc-results{margin-top:22px;border-top:2px solid var(--line);padding-top:22px}
.cr-title{font-size:15px;font-weight:800;margin-bottom:14px;letter-spacing:-.03em}
.cr-grid{display:grid;gap:0}
.cr-item{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}
.cr-item:last-child{border-bottom:0}
.cr-indent{padding-left:18px}
.cr-total{padding-top:10px}
.cr-divider-row{padding:7px 0 3px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--blue);border-bottom:1px solid var(--line)}
.cr-label{font-size:14px;color:var(--muted)}
.cr-value{font-size:15px;font-weight:800;color:var(--text);font-family:var(--fd);letter-spacing:-.02em}
.cr-value.accent{color:var(--blue)}
.cr-value.cr-deduct{color:#dc2626}
.cr-value.cr-big{font-size:22px;color:var(--blue)}
.cr-note{display:flex;gap:7px;align-items:flex-start;font-size:12px;color:var(--muted);line-height:1.5;padding:11px 13px;background:var(--off);border-radius:var(--r-lg);margin-top:14px;border:1px solid var(--line)}
.cr-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.calc-sidebar{display:flex;flex-direction:column;gap:18px;position:sticky;top:calc(var(--nav-h) + 16px)}
.calc-sidebar-widget{background:#fff;border:1px solid var(--line);border-radius:var(--r-xl);padding:18px}
.csw-title{font-size:14px;font-weight:800;margin-bottom:10px;padding-bottom:9px;border-bottom:2px solid var(--blue);letter-spacing:-.02em}
.csw-body p{font-size:13px;color:var(--muted);line-height:1.65;margin-bottom:.7rem}
.csw-table{display:grid;gap:0}
.cswt-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;font-size:13px;border-bottom:1px solid var(--line)}
.cswt-row:last-child{border-bottom:0}
.cswt-row span{color:var(--muted)}
.cswt-row strong{color:var(--text);font-weight:800}
.cswt-row.header span,.cswt-row.header strong{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--muted)}
.calc-sidebar-upsell{background:var(--navy);border-radius:var(--r-xl);padding:18px}
.calc-sidebar-upsell h4{font-size:15px;font-weight:800;color:#fff;margin-bottom:7px;letter-spacing:-.03em}
.calc-sidebar-upsell p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6;margin-bottom:12px}
.inv-item-row{display:flex;gap:8px;align-items:center;margin-top:7px}

/* ══ FOOTER ══════════════════════════════════════════ */
.site-footer{background:var(--ink);padding:68px 0 26px;position:relative;overflow:hidden}
.site-footer::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:440px;opacity:.03;pointer-events:none}
.footer-inner{position:relative;z-index:1}
.footer-grid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px;margin-bottom:48px}
.footer-col-brand{}
/* Footer logo — white invert from blue logo.png */
.footer-logo-link{display:block;margin-bottom:13px}
.footer-logo-img{height:28px;width:auto;display:block}
.footer-desc{font-size:14px;color:rgba(255,255,255,.4);line-height:1.75;margin-bottom:20px;max-width:260px}
.nl-row{display:flex;gap:6px;max-width:278px}
.nl-input{flex:1;height:40px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:var(--r-full);font-size:13px;color:#fff;padding:0 13px;font-family:var(--fb);transition:border-color 140ms}
.nl-input::placeholder{color:rgba(255,255,255,.3)}
.nl-input:focus{outline:none;border-color:var(--cyan)}
.nl-btn{width:40px;height:40px;border-radius:50%;background:var(--cyan);color:var(--navy);border:none;font-size:16px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:all 140ms}
.nl-btn:hover{background:#00d5dc;transform:scale(1.08)}
.f-head{font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.9);margin-bottom:12px;display:block}
.f-links{display:grid;gap:8px}
.f-links a{font-size:14px;color:rgba(255,255,255,.45);transition:color 140ms;display:block}
.f-links a:hover{color:#fff}
.footer-bottom{border-top:1px solid rgba(255,255,255,.06);padding-top:20px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:13px;color:rgba(255,255,255,.25)}
.footer-legal{display:flex;gap:18px}
.footer-legal a{color:rgba(255,255,255,.25);transition:color 140ms}
.footer-legal a:hover{color:rgba(255,255,255,.65)}

/* ══ PAGE TEMPLATES ══════════════════════════════════ */
.page-hero{background:var(--off);border-bottom:1px solid var(--line);padding:48px 0}
.page-content-wrap{padding:48px 0 80px}
.the-content h2{font-size:26px;margin:2.5rem 0 1rem}
.the-content h3{font-size:21px;margin:2rem 0 .75rem}
.the-content p{color:var(--muted);line-height:1.85;margin-bottom:1.2rem}
.the-content ul,.the-content ol{padding-left:1.5rem;margin-bottom:1.2rem}
.the-content li{color:var(--muted);margin-bottom:.45rem;line-height:1.65}
.the-content a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}

/* ══ METRICS ══════════════════════════════════════════ */
.metrics-row{display:flex;gap:48px;flex-wrap:wrap;margin-top:28px}
.metric-stat b{display:block;font-family:var(--fd);font-size:48px;letter-spacing:-.05em;line-height:1}
.metric-stat span{display:block;color:var(--muted);font-size:13px;margin-top:4px;font-weight:600}

/* ══ REVEAL ══════════════════════════════════════════ */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.reveal.visible{opacity:1;transform:none}

/* ══ RESPONSIVE ══════════════════════════════════════ */
@media(max-width:1100px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bc.sp2{grid-column:span 1}
  .pricing-grid{grid-template-columns:repeat(2,1fr)}
  .pc.feat{transform:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .icp-grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .calc-layout{grid-template-columns:1fr}
  .calc-sidebar{position:static}
}
@media(max-width:900px){
  .ai-grid,.prod-feat-grid,.faq-two-col{grid-template-columns:1fr;gap:36px}
  .steps-grid{grid-template-columns:1fr}
  .steps-grid::before{display:none}
  .t-grid,.post-grid{grid-template-columns:1fr 1fr}
  .post-featured{grid-template-columns:1fr}
  .post-featured .post-img{min-height:200px}
  .single-layout{grid-template-columns:1fr}
  .post-sidebar{position:static}
  .hf1,.hf2{display:none}
  .dash-frame{position:relative;left:auto;transform:none;bottom:auto;margin-top:24px}
  .feat-grid{grid-template-columns:1fr 1fr}
  .calc-hero-inner{grid-template-columns:1fr}
  .calc-hero-badge{display:none}
  .calc-gate-wrap{grid-template-columns:1fr;gap:32px}
}
@media(max-width:768px){
  .nav-links,.nav-end{display:none}
  .nav-links.open{display:flex;flex-direction:column;position:absolute;top:calc(100% + 8px);left:12px;right:12px;background:var(--ink);border-radius:var(--r-2xl);padding:12px;gap:3px;border:1px solid rgba(255,255,255,.1);box-shadow:0 18px 52px rgba(0,0,0,.28);z-index:400}
  .nav-links.open .nav-link{border-radius:var(--r-lg);color:rgba(255,255,255,.75);width:100%;padding:10px 13px}
  .nav-links.open .nav-dropdown{display:none!important}
  .nav-end.open{display:flex;flex-direction:column;position:absolute;top:calc(100% + 8px);left:12px;right:12px;background:var(--ink);border-radius:var(--r-2xl);padding:12px;border:1px solid rgba(255,255,255,.1);gap:8px;z-index:400}
  .nav-end.open .nav-ghost,.nav-end.open .nav-cta{width:100%;justify-content:center;height:44px;display:flex;align-items:center;border-radius:var(--r-full);font-size:14px;font-weight:800}
  .site-header{position:relative}
  .nav-toggle{display:flex}
  .bento,.pricing-grid,.icp-grid,.team-grid{grid-template-columns:1fr}
  .t-grid,.post-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .cta-panel,.product-cta-strip{padding:52px 20px}
  .inline-cta{flex-direction:column}
  .feat-grid,.form-2col{grid-template-columns:1fr}
  .shell{width:calc(100% - 32px)}
  .contact-grid{grid-template-columns:1fr}
  .calc-layout{grid-template-columns:1fr}
  h1{font-size:clamp(34px,9vw,50px)}
  h2{font-size:clamp(26px,6.5vw,38px)}
}

/* ══ HERO FLOAT CARD 3 ══════════════════════════════ */
.hf3{left:0;bottom:30px;width:175px;animation:fY3 6s ease-in-out infinite 2.2s}
@keyframes fY3{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-8px) rotate(-4deg)}}

/* ══ APP REDIRECT MODAL ═════════════════════════════ */
.app-modal-overlay{position:fixed;inset:0;z-index:9999;background:rgba(7,18,63,.92);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity 300ms var(--ease),visibility 300ms}
.app-modal-overlay.open{opacity:1;visibility:visible}
.app-modal{background:#fff;border-radius:var(--r-3xl);padding:56px 48px;max-width:480px;width:calc(100% - 48px);text-align:center;transform:translateY(18px) scale(.97);transition:transform 400ms var(--ease);box-shadow:0 40px 100px rgba(0,0,0,.3)}
.app-modal-overlay.open .app-modal{transform:none}
.app-modal-orb{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--cyan));margin:0 auto 24px;display:flex;align-items:center;justify-content:center;box-shadow:0 16px 40px rgba(23,54,176,.3);animation:modal-pulse 2s ease-in-out infinite}
@keyframes modal-pulse{0%,100%{box-shadow:0 16px 40px rgba(23,54,176,.3),0 0 0 0 rgba(15,226,233,.3)}50%{box-shadow:0 16px 40px rgba(23,54,176,.3),0 0 0 12px rgba(15,226,233,0)}}
.app-modal-orb svg{width:36px;height:36px}
.app-modal h2{font-size:clamp(22px,3vw,30px);margin-bottom:10px;letter-spacing:-.04em}
.app-modal p{color:var(--muted);font-size:16px;line-height:1.65;margin-bottom:28px}
.app-modal-progress{height:4px;background:var(--line);border-radius:999px;margin-bottom:24px;overflow:hidden}
.app-modal-bar{height:100%;background:linear-gradient(90deg,var(--blue),var(--cyan));border-radius:999px;width:0;transition:width 2.8s linear}
.app-modal-note{font-size:13px;color:var(--muted)}
.app-modal-cancel{display:inline-block;margin-top:16px;font-size:13px;color:var(--muted);cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.app-modal-cancel:hover{color:var(--text)}

/* ══ BLOG SINGLE FIXES ══════════════════════════════ */
/* Clock icon — was too large */
.read-time svg{width:13px!important;height:13px!important;flex-shrink:0;vertical-align:middle}
/* Featured image — full width no crop */
.post-hero-img{border-radius:var(--r-2xl);overflow:hidden;margin-bottom:36px}
.post-hero-img img{width:100%;height:auto;object-fit:contain;display:block;border-radius:var(--r-2xl)}
/* All in-article images — rounded */
.post-content img{border-radius:var(--r-xl);max-width:100%;height:auto;display:block;margin:24px auto}
/* Featured blog post image — show full image */
.post-featured .post-img img{width:100%;height:100%;object-fit:contain;background:var(--off)}

/* ══ SIDEBAR CTA REDESIGN ═══════════════════════════ */
.widget-cta{background:linear-gradient(145deg,var(--blue),#0B1F72)!important;border:none!important;border-radius:var(--r-2xl)!important;padding:28px!important}
.widget-cta::before{content:'\201C';font-family:Georgia,serif;font-size:80px;line-height:.7;color:rgba(255,255,255,.15);display:block;margin-bottom:8px}
.widget-cta h4{color:#fff!important;border-color:var(--cyan)!important;font-size:16px!important;margin-bottom:12px!important}
.widget-cta p{color:rgba(255,255,255,.7)!important;font-size:14px!important;line-height:1.65!important;margin-bottom:16px!important;font-style:italic}
.widget-cta .btn{width:100%;justify-content:center;font-size:14px}

/* ══ YOAST FAQ BLOCK ════════════════════════════════ */
/* Override Yoast defaults with custom accordion design */
.wp-block-yoast-faq-block,.schema-faq{margin:0!important;padding:0!important;border:none!important}
.schema-faq-section{border-bottom:1px solid var(--line)!important;border-top:none!important;border-left:none!important;border-right:none!important;margin:0!important;padding:0!important}
.schema-faq-section:first-child{border-top:1px solid var(--line)!important}
.schema-faq-question,.wp-block-yoast-faq-block .schema-faq-question{
  display:flex!important;justify-content:space-between!important;align-items:center!important;
  padding:18px 4px!important;font-family:var(--fb)!important;font-size:15px!important;
  font-weight:700!important;color:var(--text)!important;cursor:pointer!important;
  gap:16px!important;user-select:none!important;list-style:none!important;
  margin:0!important;background:none!important;border:none!important
}
.schema-faq-question::after{
  content:'+';flex-shrink:0;width:32px;height:32px;border-radius:50%;
  background:var(--blue-l);color:var(--blue);display:flex;align-items:center;
  justify-content:center;font-size:22px;line-height:1;font-weight:400;
  transition:transform 220ms var(--ease),background 220ms,color 220ms
}
.schema-faq-section.open .schema-faq-question::after{
  transform:rotate(45deg);background:var(--blue);color:#fff
}
.schema-faq-answer,.wp-block-yoast-faq-block .schema-faq-answer{
  font-size:15px!important;color:var(--muted)!important;line-height:1.75!important;
  padding:0 4px 18px!important;margin:0!important;display:none!important
}
.schema-faq-section.open .schema-faq-answer{display:block!important}

/* ══ LEGAL PAGES ════════════════════════════════════ */
.legal-hero{background:var(--ink);padding:64px 0;position:relative;overflow:hidden}
.legal-hero::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:380px;opacity:.04;pointer-events:none}
.legal-hero .shell{position:relative;z-index:1}
.legal-hero h1{color:#fff;margin-bottom:10px;font-size:clamp(28px,4vw,48px)}
.legal-hero p{color:rgba(255,255,255,.6);font-size:16px}
.legal-meta{font-size:13px;color:rgba(255,255,255,.4);margin-top:8px}
.legal-layout{display:grid;grid-template-columns:220px 1fr;gap:52px;padding:56px 0 88px;align-items:start}
.legal-toc{position:sticky;top:calc(var(--nav-h) + 16px);background:var(--off);border-radius:var(--r-xl);padding:18px;border:1px solid var(--line)}
.legal-toc h4{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.legal-toc a{display:block;font-size:13px;color:var(--muted);padding:5px 0;border-left:2px solid transparent;padding-left:10px;transition:all 140ms;text-decoration:none}
.legal-toc a:hover,.legal-toc a.active{color:var(--blue);border-left-color:var(--blue)}
.legal-body h2{font-size:20px;font-weight:800;color:var(--text);margin:2.5rem 0 .8rem;padding-top:2.5rem;border-top:1px solid var(--line)}
.legal-body h2:first-child{border-top:none;margin-top:0;padding-top:0}
.legal-body h3{font-size:16px;font-weight:800;color:var(--text);margin:1.5rem 0 .5rem}
.legal-body p{font-size:15px;color:var(--muted);line-height:1.8;margin-bottom:1rem}
.legal-body ul,.legal-body ol{padding-left:1.4rem;margin-bottom:1rem}
.legal-body li{font-size:15px;color:var(--muted);line-height:1.7;margin-bottom:.4rem}
.legal-body a{color:var(--blue);text-decoration:underline;text-underline-offset:3px}
.legal-body strong{color:var(--text)}
.legal-body .legal-note{background:var(--blue-l);border-left:3px solid var(--blue);padding:14px 18px;border-radius:0 var(--r-lg) var(--r-lg) 0;margin:1.5rem 0}
.legal-body .legal-note p{color:var(--blue-2);margin:0}
@media(max-width:768px){
  .legal-layout{grid-template-columns:1fr}
  .legal-toc{position:static;display:none}
}

/* ══ CAREERS PAGE ═══════════════════════════════════ */
.careers-hero{background:linear-gradient(155deg,var(--blue) 0%,#0B1F72 100%);padding:80px 0;position:relative;overflow:hidden}
.careers-hero::before{content:'';position:absolute;inset:0;background-image:url('images/pattern-stroke.png');background-size:380px;opacity:.06;pointer-events:none}
.careers-hero h1{color:#fff;margin-bottom:16px}
.careers-hero p{color:rgba(255,255,255,.7);max-width:520px}
.careers-values{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:48px 0}
.cv-card{background:var(--off);border-radius:var(--r-2xl);padding:28px;border:1px solid var(--line)}
.cv-num{font-family:var(--fd);font-size:36px;font-weight:800;color:var(--blue);letter-spacing:-.05em;margin-bottom:8px}
.no-roles-box{background:var(--off);border-radius:var(--r-2xl);padding:52px 40px;border:1px solid var(--line);text-align:center;max-width:680px;margin:0 auto}
.no-roles-box h3{font-size:22px;margin-bottom:12px}
.no-roles-box p{color:var(--muted);line-height:1.75;margin-bottom:20px}

/* ══ PRODUCT PAGE TESTIMONIALS WITH PHOTOS ══════════ */
.prod-t-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px}
.prod-t-card{background:var(--off);border-radius:var(--r-2xl);padding:28px;border:1px solid var(--line)}
.prod-t-card.dark{background:var(--navy);border-color:transparent}
.prod-t-photo{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0;border:2px solid var(--line)}
.prod-t-photo img{width:100%;height:100%;object-fit:cover}
.prod-t-photo.dark-border{border-color:rgba(255,255,255,.2)}

/* ══ CALCULATOR CTA ICON FIX ════════════════════════ */
.calc-upsell-icon{width:64px;height:64px;border-radius:var(--r-xl);background:rgba(15,226,233,.15);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;flex-shrink:0}
.calc-upsell-icon svg{width:32px;height:32px;stroke:var(--cyan);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}

/* ══ MOBILE FIXES ════════════════════════════════════ */
@media(max-width:768px){
  /* Hero */
  .hero-art{padding:0 12px}
  .hf1,.hf2,.hf3{display:none}
  .dash-frame{margin-top:20px}
  /* Nav */
  .nav-pill{padding:6px 8px 6px 14px}
  .nav-logo-img{height:22px}
  /* Grid layouts */
  .prod-t-grid{grid-template-columns:1fr}
  .careers-values{grid-template-columns:1fr}
  .faq-two-col{grid-template-columns:1fr;gap:28px}
  /* Legal */
  .legal-layout{grid-template-columns:1fr}
  /* Post content */
  .post-content{font-size:16px}
  /* Buttons — no arrows on mobile, just text */
  .btn{padding:12px 20px;font-size:14px}
  .btn.btn-lg{padding:14px 24px;font-size:15px}
  /* CTA panel */
  .cta-panel,.product-cta-strip{padding:40px 20px;border-radius:var(--r-2xl)}
  /* Sections */
  .section{padding:52px 0}
  .section-lg{padding:72px 0}
  /* Bento */
  .bento{grid-template-columns:1fr}
  .bc.sp2{grid-column:span 1}
  /* Pricing */
  .pricing-grid{grid-template-columns:1fr}
  .pc.feat{transform:none!important}
  /* Teams / ICP */
  .icp-grid{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  /* Footer */
  .footer-grid{grid-template-columns:1fr 1fr;gap:28px}
  .footer-col-brand{grid-column:1/-1}
  /* Shell */
  .shell{width:calc(100% - 24px)}
  /* Product hero grids */
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
  [style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}
}
@media(max-width:480px){
  .icp-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr}
}
