/* ═══════════════════════════════════════
   ALIT CONSULTING v3 — Global Stylesheet
   Split: dark hero / light content
   Logo: A-monogram + circuit crossbar
   ═══════════════════════════════════════ */
:root {
  /* Light content palette */
  --ink:    #f4f6f9;
  --ink2:   #ffffff;
  --ink3:   #edf0f7;
  --ink4:   #e2e6f0;
  --border: rgba(0,0,0,0.07);
  --border2:rgba(0,0,0,0.13);
  --text:   #0e1828;
  --text2:  #3d5068;
  --text3:  #8898b0;
  /* Dark hero palette */
  --dark:   #070e1a;
  --dark2:  #0b1628;
  --dark3:  #0f1f38;
  --dark4:  #152a4a;
  --dborder:rgba(255,255,255,0.07);
  --dborder2:rgba(255,255,255,0.13);
  --dtext:  #c8d8ea;
  --dtext2: #6a90b0;
  --dtext3: #3a5570;
  /* Brand */
  --navy:   #0d2d4a;
  --blue:   #1e6fa8;
  --blue2:  #155d8f;
  --blue-dim:rgba(30,111,168,0.12);
  --blue-glow:rgba(30,111,168,0.28);
  --teal:   #00b896;
  --teal2:  #009d80;
  --teal-dim:rgba(0,184,150,0.12);
  --amber:  #d97706;
  --red:    #dc2626;
  /* Type */
  --font-head:'Syne','Georgia',serif;
  --font-body:'Instrument Sans',sans-serif;
  --font-mono:'DM Mono','Courier New',monospace;
  /* Layout */
  --max:1180px;
  --r:12px;
  --r-sm:8px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{font-family:var(--font-body);background:var(--ink);color:var(--text);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* ── THREAT BANNER ── */
.threat-banner{background:#7c1515;color:#fecaca;padding:9px 40px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;font-size:12px;font-family:var(--font-mono);letter-spacing:0.03em}
.threat-banner.dismissed{display:none}
.threat-left{display:flex;align-items:center;gap:10px}
.threat-dot{width:6px;height:6px;border-radius:50%;background:#f87171;flex-shrink:0;animation:blink 2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.3}}
.threat-banner strong{color:#fff}
.threat-banner a{color:#fca5a5;text-decoration:underline}
.threat-banner a:hover{color:#fff}
.threat-close{background:none;border:none;color:#fca5a5;cursor:pointer;font-size:16px;padding:2px 8px;line-height:1}
.threat-close:hover{color:#fff}

/* ── NAV ── */
.nav{position:-webkit-sticky;position:sticky;top:0;z-index:200;padding:0 48px;height:68px;display:flex;align-items:center;justify-content:space-between;background:var(--dark);border-bottom:1px solid var(--dborder)}
.nav-logo{display:flex;align-items:center;gap:12px;cursor:pointer}

/* SVG logo in nav */
.nav-logo-svg{flex-shrink:0}
.nav-logo-name{font-family:var(--font-head);font-size:15px;font-weight:700;letter-spacing:1px;color:#e8f4ff}
.nav-logo-name em{color:var(--teal);font-style:normal}

.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{font-size:13px;color:var(--dtext2);padding:6px 13px;border-radius:var(--r-sm);transition:all 0.15s;letter-spacing:0.01em}
.nav-links a:hover{color:var(--dtext);background:var(--dark3)}
.nav-links a.active{color:#e8f4ff;font-weight:500}
.nav-portal{font-size:11px!important;font-family:var(--font-mono)!important;color:var(--dtext3)!important;border:1px solid var(--dborder)!important;padding:5px 11px!important;border-radius:var(--r-sm)!important;letter-spacing:0.04em!important}
.nav-portal:hover{background:var(--dark3)!important;color:var(--dtext)!important;border-color:var(--dborder2)!important}
.nav-cta{background:var(--teal)!important;color:#fff!important;font-weight:500!important;padding:8px 20px!important;border-radius:var(--r-sm)!important;letter-spacing:0.01em!important}
.nav-cta:hover{background:var(--teal2)!important}
.nav-ham{display:none;background:none;border:none;color:var(--dtext2);cursor:pointer;padding:6px}

/* ── MOBILE MENU ── */
.mob-menu{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:250;background:rgba(7,14,26,0.98);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:center;gap:0;overflow-y:auto}
.mob-menu.open{display:flex}
.mob-menu a{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--dtext2);transition:color 0.15s;width:100%;text-align:center;padding:16px 24px;border-bottom:1px solid var(--dborder)}
.mob-menu a:hover{color:#e8f4ff;background:var(--dark3)}
.mob-menu a:last-child{border-bottom:none;color:var(--teal)!important;margin-top:8px}
.mob-close{position:absolute;top:16px;right:20px;background:none;border:none;color:var(--dtext3);cursor:pointer;font-size:28px;line-height:1;padding:8px;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}

/* ── DARK HERO ── */
.page-hero{background:var(--dark);padding:100px 48px 80px;position:relative;overflow:hidden}
.page-hero::after{content:'';position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse 80% 60% at 70% 50%,rgba(0,184,150,0.06) 0%,transparent 70%);pointer-events:none}
.hero-bg-img{position:absolute;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;opacity:0.12;filter:saturate(0.4)}
.hero-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(var(--dborder) 1px,transparent 1px),linear-gradient(90deg,var(--dborder) 1px,transparent 1px);background-size:48px 48px;opacity:0.5}
.hero-inner{max-width:var(--max);margin:0 auto;position:relative;z-index:1}
.hero-eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-mono);font-size:11px;color:var(--teal);text-transform:uppercase;letter-spacing:0.14em;margin-bottom:24px}
.hero-eyebrow::before{content:'';width:18px;height:1px;background:var(--teal)}
.hero-h1{font-family:var(--font-head);font-size:clamp(40px,6vw,82px);font-weight:800;letter-spacing:-0.035em;color:#e8f4ff;line-height:1.0;margin-bottom:22px}
.hero-h1 em{color:var(--teal);font-style:normal}
.hero-sub{font-size:clamp(14px,1.6vw,17px);color:var(--dtext2);max-width:520px;line-height:1.8;margin-bottom:36px}
.hero-actions{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-bottom:48px}
.h-btn-p{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;background:var(--teal);color:#fff;border-radius:var(--r-sm);font-size:15px;font-weight:500;font-family:var(--font-body);transition:all 0.18s;box-shadow:0 4px 20px rgba(0,184,150,0.3)}
.h-btn-p:hover{background:var(--teal2);transform:translateY(-2px)}
.h-btn-p svg{width:15px;height:15px}
.h-btn-g{display:inline-flex;align-items:center;gap:8px;padding:12px 22px;color:var(--dtext);border:1px solid var(--dborder2);border-radius:var(--r-sm);font-size:15px;font-family:var(--font-body);transition:all 0.15s}
.h-btn-g:hover{background:var(--dark3);border-color:var(--dborder2)}
.trust-bar{display:flex;gap:18px;flex-wrap:wrap;padding-top:32px;border-top:1px solid var(--dborder)}
.trust-pill{display:flex;align-items:center;gap:7px;font-size:11px;color:var(--dtext3);font-family:var(--font-mono);letter-spacing:0.04em}
.trust-pill svg{width:12px;height:12px;color:var(--teal)}

/* ── HERO CARD (status panel) ── */
.hero-grid{display:grid;grid-template-columns:1fr 380px;gap:60px;align-items:center}
.hero-card{background:rgba(11,22,40,0.9);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid var(--dborder2);border-radius:var(--r);padding:24px;position:relative;overflow:hidden}
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal))}
.hc-title{font-family:var(--font-head);font-size:13px;font-weight:600;color:#e8f4ff;margin-bottom:2px}
.hc-sub{font-size:10px;color:var(--dtext3);font-family:var(--font-mono);letter-spacing:0.06em;margin-bottom:18px}
.hc-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--dborder)}
.hc-row:last-child{border-bottom:none}
.hc-ico{width:30px;height:30px;border-radius:7px;background:rgba(0,184,150,0.1);border:1px solid rgba(0,184,150,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hc-ico svg{width:13px;height:13px;color:var(--teal)}
.hc-label{font-size:12px;font-weight:500;color:#c8d8ea}
.hc-note{font-size:11px;color:var(--dtext3)}
.hc-badge{margin-left:auto;font-size:10px;font-family:var(--font-mono);color:var(--teal);background:rgba(0,184,150,0.1);border:1px solid rgba(0,184,150,0.2);padding:2px 7px;border-radius:4px;white-space:nowrap;letter-spacing:0.04em}

/* ── LIGHT SECTION ── */
.section{padding:88px 48px}
.section-sm{padding:56px 48px}
.section-dark{background:var(--dark);padding:88px 48px}
.section-mid{background:var(--dark2);padding:88px 48px}
.inner{max-width:var(--max);margin:0 auto}
.rule-light{height:1px;border:none;background:linear-gradient(90deg,transparent,var(--border2) 30%,var(--border2) 70%,transparent)}
.rule-dark{height:1px;border:none;background:linear-gradient(90deg,transparent,var(--dborder2) 30%,var(--dborder2) 70%,transparent)}
.section-eyebrow{font-family:var(--font-mono);font-size:11px;color:var(--teal);text-transform:uppercase;letter-spacing:0.12em;display:flex;align-items:center;gap:10px;margin-bottom:12px}
.section-eyebrow::before{content:'';width:18px;height:1px;background:var(--teal)}
.section-title{font-family:var(--font-head);font-size:clamp(24px,3.5vw,44px);font-weight:700;letter-spacing:-0.025em;line-height:1.12;margin-bottom:12px}
.section-title.light{color:var(--text)}
.section-title.dark{color:#e8f4ff}
.section-sub{font-size:16px;max-width:540px;line-height:1.75}
.section-sub.light{color:var(--text2)}
.section-sub.dark{color:var(--dtext2)}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:500;border:none;cursor:pointer;transition:all 0.18s;border-radius:var(--r-sm)}
.btn svg{width:15px;height:15px;flex-shrink:0}
.btn-teal{padding:12px 26px;background:var(--teal);color:#fff;font-size:15px;box-shadow:0 2px 16px rgba(0,184,150,0.25)}
.btn-teal:hover{background:var(--teal2);transform:translateY(-2px);box-shadow:0 6px 24px rgba(0,184,150,0.35)}
.btn-navy{padding:12px 22px;background:var(--navy);color:#e8f4ff;font-size:14px}
.btn-navy:hover{background:var(--dark3);transform:translateY(-1px)}
.btn-outline-light{padding:11px 20px;background:transparent;color:var(--text2);font-size:14px;border:1px solid var(--border2)}
.btn-outline-light:hover{color:var(--text);border-color:var(--text3);background:var(--ink3)}
.btn-outline-dark{padding:11px 20px;background:transparent;color:var(--dtext);font-size:14px;border:1px solid var(--dborder2)}
.btn-outline-dark:hover{color:#e8f4ff;border-color:var(--dborder2);background:var(--dark3)}
.btn-white{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#fff;color:var(--navy);border-radius:var(--r-sm);font-size:15px;font-weight:500;font-family:var(--font-body);transition:all 0.18s}
.btn-white:hover{background:rgba(255,255,255,0.92);transform:translateY(-1px)}
.btn-white svg{width:15px;height:15px}

/* ── CARDS ── */
.card{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;transition:all 0.22s}
.card:hover{border-color:var(--border2);transform:translateY(-3px);box-shadow:0 10px 36px rgba(0,0,0,0.07)}
.card-img{aspect-ratio:16/9;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s}
.card:hover .card-img img{transform:scale(1.04)}
.card-body{padding:22px}
.card-label{font-family:var(--font-mono);font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:7px}
.card-title{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px}
.card-desc{font-size:13px;color:var(--text2);line-height:1.7}

/* ── DARK CARDS ── */
.dark-card{background:var(--dark3);border:1px solid var(--dborder);border-radius:var(--r);overflow:hidden;transition:all 0.22s}
.dark-card:hover{border-color:var(--dborder2);transform:translateY(-3px);box-shadow:0 10px 36px rgba(0,0,0,0.3)}

/* ── STAT ROW ── */
.stat-row{display:flex;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.stat-block{flex:1;padding:28px 20px;border-right:1px solid var(--border);text-align:center;background:var(--ink2)}
.stat-block:last-child{border-right:none}
.stat-val{font-family:var(--font-head);font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--teal);letter-spacing:-0.04em}
.stat-label{font-size:11px;color:var(--text3);margin-top:5px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.07em}
.dark-stat-row{display:flex;border:1px solid var(--dborder);border-radius:var(--r);overflow:hidden}
.dark-stat-block{flex:1;padding:28px 20px;border-right:1px solid var(--dborder);text-align:center;background:var(--dark3)}
.dark-stat-block:last-child{border-right:none}
.dark-stat-val{font-family:var(--font-head);font-size:clamp(26px,4vw,42px);font-weight:800;color:var(--teal);letter-spacing:-0.04em}
.dark-stat-label{font-size:11px;color:var(--dtext3);margin-top:5px;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.07em}

/* ── FEATURE ROW ── */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.feature-row.flip{direction:rtl}.feature-row.flip>*{direction:ltr}
.feature-img{border-radius:var(--r);overflow:hidden;position:relative}
.feature-img img{width:100%;aspect-ratio:4/3;object-fit:cover}
.feature-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(0,184,150,0.08) 0%,transparent 60%)}
.feature-eyebrow{font-family:var(--font-mono);font-size:11px;color:var(--teal);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.feature-eyebrow::before{content:'';width:14px;height:1px;background:var(--teal)}
.feature-text h2{font-family:var(--font-head);font-size:clamp(22px,3vw,38px);font-weight:700;letter-spacing:-0.025em;color:var(--text);line-height:1.15;margin-bottom:14px}
.feature-text p{font-size:15px;color:var(--text2);line-height:1.8;margin-bottom:20px}
.feature-checks{display:flex;flex-direction:column;gap:10px;margin-bottom:24px}
.feature-check{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text2)}
.feature-check svg{width:15px;height:15px;color:var(--teal);flex-shrink:0}

/* ── SERVICES GRID ── */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--dborder);border:1px solid var(--dborder);border-radius:var(--r);overflow:hidden;margin-top:48px}
.svc-tile{background:var(--dark3);padding:28px 24px;position:relative;overflow:hidden;transition:background 0.18s;cursor:default}
.svc-tile::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--blue),var(--teal));transform:scaleX(0);transition:transform 0.25s;transform-origin:left}
.svc-tile:hover{background:var(--dark4)}
.svc-tile:hover::after{transform:scaleX(1)}
.svc-icon{width:40px;height:40px;border-radius:9px;background:rgba(0,184,150,0.1);border:1px solid rgba(0,184,150,0.2);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.svc-icon svg{width:18px;height:18px;color:var(--teal)}
.svc-title{font-family:var(--font-head);font-size:15px;font-weight:600;color:#e8f4ff;margin-bottom:7px}
.svc-desc{font-size:12px;color:var(--dtext2);line-height:1.7}
.svc-link{display:inline-flex;align-items:center;gap:4px;font-size:11px;color:var(--teal);margin-top:12px;font-family:var(--font-mono);opacity:0;transition:opacity 0.18s;overflow:hidden;max-height:20px}
.svc-link svg{width:11px!important;height:11px!important;min-width:11px;min-height:11px;max-width:11px;max-height:11px;flex-shrink:0;overflow:hidden}
.svc-tile:hover .svc-link{opacity:1}

/* ── STACK STRIP ── */
.stack-strip{display:grid;grid-template-columns:repeat(6,1fr);gap:0;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:44px}
.stack-pill{padding:18px 12px;border-right:1px solid var(--border);background:var(--ink2);text-align:center;transition:background 0.15s}
.stack-pill:last-child{border-right:none}
.stack-pill:hover{background:var(--ink3)}
.sp-icon{width:34px;height:34px;border-radius:7px;background:var(--blue-dim);border:1px solid rgba(30,111,168,0.15);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.sp-icon svg{width:15px;height:15px;color:var(--blue)}
.sp-name{font-family:var(--font-head);font-size:12px;font-weight:600;color:var(--text)}
.sp-role{font-size:10px;color:var(--text3);font-family:var(--font-mono);margin-top:1px}

/* ── CTA STRIP ── */
.cta-strip{background:linear-gradient(135deg,var(--navy) 0%,var(--dark3) 100%);border:1px solid var(--dborder2);border-radius:var(--r);padding:52px 44px;display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap}
.cta-strip h2{font-family:var(--font-head);font-size:clamp(20px,3vw,34px);font-weight:700;letter-spacing:-0.025em;color:#e8f4ff;margin-bottom:8px}
.cta-strip p{font-size:15px;color:var(--dtext2);max-width:420px;line-height:1.7}
.cta-strip-actions{display:flex;gap:10px;flex-wrap:wrap;flex-shrink:0}

/* ── PARTNER STRIP ── */
.partner-strip{padding:32px 48px;background:var(--ink2);border-top:1px solid var(--border)}
.partner-strip-label{font-size:10px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:0.12em;text-align:center;margin-bottom:18px;font-family:var(--font-mono)}
.partner-logos{display:flex;align-items:center;justify-content:center;border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.partner-logo{flex:1;padding:16px 12px;border-right:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:6px;transition:background 0.15s;min-width:90px}
.partner-logo:last-child{border-right:none}
.partner-logo:hover{background:var(--ink3)}
.p-icon{width:32px;height:32px;border-radius:7px;background:var(--blue-dim);border:1px solid rgba(30,111,168,0.15);display:flex;align-items:center;justify-content:center}
.p-icon svg{width:16px;height:16px;color:var(--blue)}
.p-name{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--text)}
.p-type{font-size:9px;color:var(--text3);font-family:var(--font-mono)}

/* ── FOOTER ── */
.footer{border-top:1px solid var(--dborder);padding:52px 48px 28px;background:var(--dark)}
.footer-inner{max-width:var(--max);margin:0 auto}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
.f-logo-row{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.f-logo-name{font-family:var(--font-head);font-size:14px;font-weight:700;color:#e8f4ff;letter-spacing:0.5px}
.f-logo-name em{color:var(--teal);font-style:normal}
.footer-brand p{font-size:13px;color:var(--dtext3);line-height:1.7;max-width:220px}
.footer-col h4{font-family:var(--font-head);font-size:11px;font-weight:600;color:var(--dtext2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:14px}
.footer-col a{display:block;font-size:13px;color:var(--dtext3);margin-bottom:9px;transition:color 0.15s}
.footer-col a:hover{color:#e8f4ff}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:20px;border-top:1px solid var(--dborder);flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:11px;color:var(--dtext3);font-family:var(--font-mono)}
.footer-links{display:flex;gap:18px}
.footer-links a{font-size:11px;color:var(--dtext3);transition:color 0.15s;font-family:var(--font-mono)}
.footer-links a:hover{color:var(--dtext2)}

/* ── SERVICES PAGE SPECIFIC ── */
.svc-section{padding:80px 48px}
.svc-section:nth-child(odd){background:var(--ink)}
.svc-section:nth-child(even){background:var(--ink2)}
.svc-hdr{display:flex;align-items:flex-start;gap:18px;margin-bottom:48px}
.svc-hdr-ico{width:50px;height:50px;border-radius:12px;background:var(--blue-dim);border:1px solid rgba(30,111,168,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:4px}
.svc-hdr-ico svg{width:23px;height:23px;color:var(--blue)}
.svc-dtitle{font-family:var(--font-head);font-size:clamp(26px,4vw,46px);font-weight:800;letter-spacing:-0.03em;color:var(--text);line-height:1.1;margin-bottom:8px}
.svc-dsub{font-size:15px;color:var(--text2);line-height:1.75;max-width:580px}
.svc-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.svc-photo{border-radius:var(--r);overflow:hidden}
.svc-photo img{width:100%;aspect-ratio:4/3;object-fit:cover}
.svc-h3{font-family:var(--font-head);font-size:17px;font-weight:600;color:var(--text);margin-bottom:9px;margin-top:22px}
.svc-h3:first-child{margin-top:0}
.svc-content p{font-size:14px;color:var(--text2);line-height:1.8;margin-bottom:13px}
.svc-checks{display:flex;flex-direction:column;gap:8px;margin:13px 0}
.svc-chk{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--text2)}
.svc-chk svg{width:15px;height:15px;color:var(--teal);flex-shrink:0;margin-top:2px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:16px}
.svc-tag{font-size:11px;font-family:var(--font-mono);padding:3px 9px;border:1px solid var(--border2);border-radius:4px;color:var(--text2)}

/* ── STACK CARDS (services page) ── */
.stack-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:44px}
.stack-card{background:var(--dark2);border:1px solid var(--dborder);border-radius:var(--r);overflow:hidden;transition:all 0.22s}
.stack-card:hover{border-color:var(--dborder2);transform:translateY(-3px)}
.stack-card-img{height:130px;overflow:hidden}
.stack-card-img img{width:100%;height:100%;object-fit:cover;filter:brightness(0.7) saturate(0.6)}
.stack-card-body{padding:18px}
.stack-chip{font-size:10px;font-family:var(--font-mono);padding:3px 8px;border-radius:4px;border:1px solid;margin-bottom:8px;display:inline-block;letter-spacing:0.06em}
.chip-blue{border-color:rgba(30,111,168,0.4);color:var(--blue);background:var(--blue-dim)}
.chip-teal{border-color:rgba(0,184,150,0.4);color:var(--teal);background:var(--teal-dim)}
.chip-amber{border-color:rgba(217,119,6,0.3);color:var(--amber);background:rgba(217,119,6,0.08)}
.stack-name{font-family:var(--font-head);font-size:18px;font-weight:700;color:#e8f4ff;margin-bottom:6px}
.stack-desc{font-size:12px;color:var(--dtext2);line-height:1.7}

/* ── PRICING ── */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.pricing-card{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);padding:30px;position:relative;transition:all 0.22s}
.pricing-card:hover{transform:translateY(-4px);box-shadow:0 10px 40px rgba(0,0,0,0.08)}
.pricing-card.featured{border:2px solid var(--teal)}
.pricing-badge{position:absolute;top:-11px;left:50%;transform:translateX(-50%);background:var(--teal);color:#fff;font-size:11px;font-weight:600;padding:3px 14px;border-radius:20px;font-family:var(--font-mono);white-space:nowrap;letter-spacing:0.04em}
.pricing-tier{font-family:var(--font-mono);font-size:10px;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:6px}
.pricing-name{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--text);margin-bottom:14px}
.pricing-desc{font-size:13px;color:var(--text2);line-height:1.65;margin-bottom:14px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.pricing-features{display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.pf{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--text2)}
.pf svg{width:15px;height:15px;color:var(--teal);flex-shrink:0;margin-top:2px}
.pf.no svg{color:var(--text3)}.pf.no{color:var(--text3)}
.pricing-btn{display:block;width:100%;padding:12px;text-align:center;border-radius:var(--r-sm);font-size:14px;font-weight:500;font-family:var(--font-body);transition:all 0.18s;cursor:pointer;border:none}
.pb-solid{background:var(--teal);color:#fff}.pb-solid:hover{background:var(--teal2)}
.pb-out{background:transparent;color:var(--teal);border:1px solid var(--teal)}.pb-out:hover{background:var(--teal-dim)}
.pricing-note{font-size:11px;color:var(--text3);text-align:center;margin-top:7px;font-family:var(--font-mono)}
.compare-table{width:100%;border-collapse:collapse;border:1px solid var(--border);border-radius:var(--r);overflow:hidden;font-size:13px}
.compare-table th{background:var(--ink3);font-family:var(--font-head);font-weight:600;font-size:12px;color:var(--text);padding:13px 16px;text-align:left;border-bottom:1px solid var(--border)}
.compare-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text2)}
.compare-table tr:last-child td{border-bottom:none}
.compare-table tr:hover td{background:var(--ink3)}
.compare-table td:first-child{color:var(--text);font-weight:500}
.cy{color:var(--teal);font-size:15px}.cn{color:var(--text3);font-size:15px}

/* ── ABOUT ── */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:48px}
.about-photo{border-radius:var(--r);overflow:hidden;position:relative}
.about-photo img{width:100%;aspect-ratio:4/5;object-fit:cover;object-position:center top}
.about-photo-card{position:absolute;bottom:20px;left:20px;right:20px;background:rgba(7,14,26,0.88);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--dborder2);border-radius:var(--r-sm);padding:14px 16px}
.about-photo-card-name{font-family:var(--font-head);font-size:14px;font-weight:600;color:#e8f4ff}
.about-photo-card-role{font-size:11px;color:var(--teal);font-family:var(--font-mono);margin-top:2px;letter-spacing:0.04em}
.about-badge{display:flex;align-items:center;gap:12px;padding:13px 16px;background:var(--ink2);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:10px;transition:border-color 0.15s}
.about-badge:hover{border-color:var(--teal)}
.ab-icon{width:30px;height:30px;border-radius:7px;background:var(--teal-dim);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ab-icon svg{width:14px;height:14px;color:var(--teal)}
.ab-title{font-size:13px;font-weight:500;color:var(--text)}
.ab-sub{font-size:12px;color:var(--text3)}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:48px}
.value-card{padding:24px;background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);transition:border-color 0.18s}
.value-card:hover{border-color:var(--teal)}
.v-num{font-family:var(--font-mono);font-size:10px;color:var(--text3);margin-bottom:12px;letter-spacing:0.06em}
.v-title{font-family:var(--font-head);font-size:16px;font-weight:600;color:var(--text);margin-bottom:8px}
.v-desc{font-size:13px;color:var(--text2);line-height:1.7}
.approach-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;margin-top:48px}
.approach-photo{border-radius:var(--r);overflow:hidden}
.approach-photo img{width:100%;aspect-ratio:16/10;object-fit:cover}
.ap-steps{display:flex;flex-direction:column;gap:22px}
.ap-step{display:grid;grid-template-columns:34px 1fr;gap:14px;align-items:flex-start}
.ap-num{width:32px;height:32px;border-radius:50%;background:var(--teal-dim);border:1px solid rgba(0,184,150,0.3);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:11px;color:var(--teal);flex-shrink:0}
.ap-title{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--text);margin-bottom:5px;margin-top:5px}
.ap-desc{font-size:13px;color:var(--text2);line-height:1.7}
.ind-photo-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:44px}
.ind-photo-card{border-radius:var(--r);overflow:hidden;position:relative}
.ind-photo-card img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:brightness(0.55) saturate(0.6);transition:all 0.4s}
.ind-photo-card:hover img{filter:brightness(0.45) saturate(0.5)}
.ind-overlay{position:absolute;bottom:0;left:0;right:0;padding:16px 14px;background:linear-gradient(0deg,rgba(7,14,26,0.9) 0%,transparent 100%)}
.ind-ilabel{font-family:var(--font-mono);font-size:10px;color:var(--teal);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:3px}
.ind-ititle{font-family:var(--font-head);font-size:14px;font-weight:600;color:#e8f4ff}

/* ── CONTACT ── */
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;margin-top:48px}
.contact-card{display:flex;align-items:center;gap:14px;padding:13px 16px;background:var(--ink3);border:1px solid var(--border);border-radius:var(--r-sm);margin-bottom:10px;transition:border-color 0.15s}
.contact-card:hover{border-color:var(--teal)}
.cc-icon{width:32px;height:32px;border-radius:7px;background:var(--teal-dim);border:1px solid rgba(0,184,150,0.2);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cc-icon svg{width:14px;height:14px;color:var(--teal)}
.cc-label{font-size:11px;color:var(--text3);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:2px}
.cc-val{font-size:14px;color:var(--text);font-weight:500}
.contact-photo{border-radius:var(--r);overflow:hidden;margin-top:20px}
.contact-photo img{width:100%;aspect-ratio:16/9;object-fit:cover}
.contact-form-box{background:var(--ink2);border:1px solid var(--border);border-radius:var(--r);padding:30px;box-shadow:0 4px 20px rgba(0,0,0,0.05)}
.cf-title{font-family:var(--font-head);font-size:19px;font-weight:600;color:var(--text);margin-bottom:4px}
.cf-sub{font-size:11px;color:var(--text3);font-family:var(--font-mono);letter-spacing:0.05em;margin-bottom:22px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-field{margin-bottom:14px}
.form-field label{display:block;font-size:11px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:5px;font-family:var(--font-mono)}
.form-field input,.form-field select,.form-field textarea{width:100%;padding:9px 11px;background:var(--ink3);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text);font-size:13px;font-family:var(--font-body);outline:none;transition:border-color 0.15s}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--teal);background:var(--ink2)}
.form-field input::placeholder,.form-field textarea::placeholder{color:var(--text3)}
.form-field select option{background:var(--ink2);color:var(--text)}
.form-field textarea{resize:vertical;min-height:100px}
.form-submit{width:100%;padding:12px;background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all 0.18s;display:flex;align-items:center;justify-content:center;gap:8px}
.form-submit:hover{background:var(--teal2)}
.form-note{font-size:11px;color:var(--text3);text-align:center;margin-top:10px;font-family:var(--font-mono)}
.form-success{display:none;text-align:center;padding:28px}
.form-success.show{display:block}
.fs-icon{width:52px;height:52px;background:var(--teal-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.fs-icon svg{width:26px;height:26px;color:var(--teal)}
.faq-wrap{border:1px solid var(--border);border-radius:var(--r);overflow:hidden;margin-top:44px}
.faq-item{border-bottom:1px solid var(--border);background:var(--ink2)}
.faq-item:last-child{border-bottom:none}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:18px 22px;cursor:pointer;user-select:none}
.faq-q-text{font-family:var(--font-head);font-size:15px;font-weight:600;color:var(--text)}
.faq-ico{width:20px;height:20px;border-radius:50%;background:var(--ink4);border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all 0.18s}
.faq-ico svg{width:11px;height:11px;color:var(--text2);transition:transform 0.18s}
.faq-item.open .faq-ico{background:var(--teal-dim);border-color:rgba(0,184,150,0.3)}
.faq-item.open .faq-ico svg{transform:rotate(45deg);color:var(--teal)}
.faq-a{display:none;padding:0 22px 18px;font-size:14px;color:var(--text2);line-height:1.8}
.faq-item.open .faq-a{display:block}

/* ── ASSESSMENT ── */
.quiz-wrap{max-width:720px;margin:48px auto 0}
.quiz-prog{height:3px;background:var(--border);border-radius:2px;margin-bottom:36px;overflow:hidden}
.quiz-prog-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--teal));border-radius:2px;transition:width 0.4s ease}
.quiz-step{display:none}
.quiz-step.active{display:block;animation:fadeUp 0.3s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.q-num{font-family:var(--font-mono);font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:10px}
.q-text{font-family:var(--font-head);font-size:clamp(18px,2.5vw,26px);font-weight:700;color:var(--text);letter-spacing:-0.02em;line-height:1.3;margin-bottom:26px}
.q-options{display:flex;flex-direction:column;gap:9px;margin-bottom:28px}
.q-opt{display:flex;align-items:center;gap:14px;padding:14px 18px;background:var(--ink2);border:1.5px solid var(--border);border-radius:var(--r);cursor:pointer;transition:all 0.15s}
.q-opt:hover{border-color:var(--teal);background:var(--teal-dim)}
.q-opt.selected{border-color:var(--teal);background:var(--teal-dim)}
.q-radio{width:18px;height:18px;border-radius:50%;border:2px solid var(--border2);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
.q-opt.selected .q-radio{border-color:var(--teal);background:var(--teal)}
.q-opt.selected .q-radio::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}
.q-opt-text{font-size:14px;color:var(--text);font-weight:500}
.q-opt-sub{font-size:12px;color:var(--text3);margin-top:2px}
.q-nav{display:flex;align-items:center;justify-content:space-between;gap:12px}
.q-back{padding:10px 18px;border:1px solid var(--border2);background:transparent;color:var(--text2);border-radius:var(--r-sm);font-size:14px;font-family:var(--font-body);cursor:pointer;transition:all 0.15s}
.q-back:hover{background:var(--ink3);color:var(--text)}
.q-next{padding:11px 26px;background:var(--teal);color:#fff;border:none;border-radius:var(--r-sm);font-size:14px;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:all 0.15s;display:flex;align-items:center;gap:8px}
.q-next:hover{background:var(--teal2)}
.q-next:disabled{opacity:0.4;cursor:not-allowed}
.q-next svg{width:15px;height:15px}
.quiz-result{display:none;text-align:center}
.quiz-result.show{display:block;animation:fadeUp 0.4s ease}
.score-ring{width:130px;height:130px;margin:0 auto 20px;position:relative}
.score-ring svg{width:130px;height:130px;transform:rotate(-90deg)}
.score-inner{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.score-num{font-family:var(--font-head);font-size:34px;font-weight:800;color:var(--text);letter-spacing:-0.04em}
.score-of{font-size:11px;color:var(--text3);font-family:var(--font-mono)}
.result-grade{font-family:var(--font-head);font-size:24px;font-weight:700;margin-bottom:10px}
.result-summary{font-size:15px;color:var(--text2);max-width:520px;margin:0 auto 32px;line-height:1.75}
.result-breakdown{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:28px 0;text-align:left}
.rb-item{padding:14px 16px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--ink2)}
.rb-label{font-size:11px;color:var(--text3);font-family:var(--font-mono);margin-bottom:4px;text-transform:uppercase;letter-spacing:0.06em}
.rb-val{font-size:13px;font-weight:500}
.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ── REVEAL ── */
.reveal{opacity:0;transform:translateY(24px);transition:opacity 0.6s ease,transform 0.6s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.d1{transition-delay:0.08s}.d2{transition-delay:0.16s}.d3{transition-delay:0.24s}.d4{transition-delay:0.32s}

/* ══════════════════════════════════════════
   RESPONSIVE — TABLET (≤960px)
   ══════════════════════════════════════════ */
@media(max-width:960px){
  /* Nav */
  .nav{padding:0 20px;height:60px}
  .nav-links a:not(.nav-cta):not(.nav-portal){display:none}
  .nav-ham{display:block}
  .nav-cta{padding:7px 14px!important;font-size:13px!important}
  .nav-portal{display:none!important}

  /* Mobile menu — full screen, large tap targets */
  .mob-menu{gap:0;justify-content:flex-start;padding-top:80px}
  .mob-menu a{font-size:20px;width:100%;text-align:center;padding:14px 0;border-bottom:1px solid var(--dborder)}
  .mob-menu a:last-child{border-bottom:none;margin-top:12px}

  /* Threat banner */
  .threat-banner{padding:8px 16px;font-size:11px}

  /* Hero */
  .page-hero{padding:72px 20px 48px}
  .hero-inner{padding:0}
  .hero-h1{font-size:clamp(32px,8vw,52px)}
  .hero-sub{font-size:14px}
  .hero-grid{grid-template-columns:1fr;gap:28px}
  .hero-card{display:none}
  .trust-bar{gap:12px}
  .trust-pill{font-size:10px}

  /* Sections */
  .section,.section-dark,.section-mid,.svc-section{padding:52px 20px}
  .section-sm{padding:36px 20px}
  .section-title{font-size:clamp(22px,5vw,36px)}

  /* Grids → single column */
  .feature-row,.feature-row.flip{grid-template-columns:1fr;gap:28px;direction:ltr}
  .about-grid,.approach-grid,.contact-layout,.svc-layout{grid-template-columns:1fr;gap:28px}
  .pricing-grid{grid-template-columns:1fr;gap:14px}
  .values-grid{grid-template-columns:1fr 1fr;gap:12px}
  .ind-photo-grid{grid-template-columns:1fr 1fr;gap:8px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .stack-grid{grid-template-columns:1fr 1fr;gap:12px}
  .stack-strip{grid-template-columns:repeat(3,1fr)}
  .case-grid{grid-template-columns:1fr}

  /* Stats */
  .stat-row,.dark-stat-row{flex-wrap:wrap}
  .stat-block,.dark-stat-block{flex:0 0 50%;border-bottom:1px solid var(--border)}
  .stat-val,.dark-stat-val{font-size:28px}

  /* Partner strip */
  .partner-strip{padding:20px}
  .partner-logos{flex-wrap:wrap;border-radius:var(--r-sm)}
  .partner-logo{flex:0 0 33.33%;min-width:0;border-right:none;border-bottom:1px solid var(--border);padding:12px 8px}
  .p-name{font-size:10px}
  .p-type{display:none}

  /* CTA strip */
  .cta-strip{flex-direction:column;padding:28px 20px;gap:20px;text-align:center}
  .cta-strip p{max-width:100%}
  .cta-strip-actions{justify-content:center}

  /* Footer */
  .footer{padding:36px 20px 20px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .footer-brand{grid-column:1/-1}

  /* Contact */
  .contact-layout{grid-template-columns:1fr}
  .contact-photo{display:none}

  /* Pricing */
  .pricing-card.featured{margin:0}
  .compare-table{font-size:12px;display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}

  /* About */
  .about-photo{max-height:320px;overflow:hidden}
  .about-photo img{aspect-ratio:16/9;object-position:center 20%}

  /* Assessment */
  .quiz-wrap{margin:32px auto 0}
  .result-breakdown{grid-template-columns:1fr 1fr}
}

/* ══════════════════════════════════════════
   RESPONSIVE — MOBILE (≤560px)
   ══════════════════════════════════════════ */
@media(max-width:560px){
  /* Nav */
  .nav{padding:0 16px;height:56px}
  .nav-logo-name{font-size:13px}
  .nav-cta{padding:6px 12px!important;font-size:12px!important}

  /* Hero */
  .page-hero{padding:64px 16px 40px;min-height:auto}
  .hero-h1{font-size:clamp(28px,9vw,42px);letter-spacing:-0.03em}
  .hero-actions{flex-direction:column;align-items:stretch;gap:10px}
  .h-btn-p,.h-btn-g{text-align:center;justify-content:center;width:100%}
  .trust-bar{display:none}

  /* Sections */
  .section,.section-dark,.section-mid,.svc-section{padding:40px 16px}
  .section-sm{padding:28px 16px}
  .inner{padding:0}

  /* All grids → full single column */
  .svc-grid,.stack-strip{grid-template-columns:1fr}
  .values-grid,.ind-photo-grid{grid-template-columns:1fr}
  .stack-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .result-breakdown{grid-template-columns:1fr}
  .case-results{grid-template-columns:repeat(3,1fr)}

  /* Stats → 2 per row */
  .stat-block,.dark-stat-block{flex:0 0 50%}
  .stats-row-sm .stat-sm{padding:12px 8px}
  .stat-sm-val{font-size:18px}

  /* Service tiles */
  .svc-tile{padding:20px 16px}

  /* Partner strip */
  .partner-logo{flex:0 0 50%}

  /* CTA */
  .cta-strip{padding:24px 16px}
  .cta-strip h2{font-size:22px}
  .btn-white,.btn-outline-dark{width:100%;justify-content:center;text-align:center}

  /* Footer */
  .footer{padding:28px 16px 16px}
  .footer-grid{grid-template-columns:1fr;gap:20px}
  .footer-brand{grid-column:auto}
  .footer-col h4{margin-bottom:10px}
  .footer-bottom{flex-direction:column;align-items:flex-start;gap:8px}
  .footer-links{flex-wrap:wrap;gap:12px}

  /* Pricing */
  .pricing-card{padding:22px 18px}
  .pricing-name{font-size:20px}

  /* About badges */
  .about-badge{padding:10px 12px}

  /* Contact form */
  .contact-form-box{padding:20px 16px}

  /* Assessment */
  .q-opt{padding:12px 14px}
  .q-back,.q-next{padding:10px 16px;font-size:13px}

  /* Threat banner */
  .threat-banner{padding:8px 12px;font-size:10px;gap:8px}
  .threat-banner a{display:none}

  /* Section eyebrow */
  .section-eyebrow{font-size:10px}

  /* Feature section images — hide on mobile to save space */
  .feature-img{display:none}

  /* Stack strip pills */
  .stack-pill{padding:14px 8px}
  .sp-icon{width:28px;height:28px}
  .sp-name{font-size:11px}
  .sp-role{display:none}

  /* Resource page grid */
  .resources-grid{grid-template-columns:1fr!important}

  /* Threats page */
  .cve-top{flex-direction:column;gap:6px}
  .cve-badges{margin-left:0}
  .threat-filters{gap:6px}
  .tf-btn{font-size:11px;padding:5px 10px}

  /* Values grid */
  .value-card{padding:18px}

  /* Approach steps */
  .ap-step{gap:10px}

  /* Industry photo grid */
  .ind-photo-card img{aspect-ratio:16/9}
  .ind-ititle{font-size:13px}
}

/* ═══════════════════════════════════════
   CROSS-BROWSER FIXES
   Firefox · Edge · Safari
   ═══════════════════════════════════════ */

/* SVG icon sizing — Firefox renders inline SVGs at intrinsic size
   without explicit constraints, causing oversized icons */
.svc-icon svg,
.hc-ico svg,
.ab-icon svg,
.ap-num svg,
.cc-icon svg,
.fs-icon svg,
.p-icon svg,
.sp-icon svg,
.stack-card-img svg,
.partner-logo svg,
.nav-ham svg,
.mob-close svg,
.hero-eyebrow svg,
.trust-pill svg,
.svc-link svg,
.btn svg,
.h-btn-p svg,
.h-btn-g svg,
.btn-white svg,
.faq-ico svg,
.threat-close svg,
.q-next svg,
.form-submit svg {
  display: block;
  flex-shrink: 0;
  overflow: hidden;
}

/* Force ALL inline SVGs that are decorative icons to never exceed their container */
.svc-link svg { width: 11px !important; height: 11px !important; max-width: 11px !important; max-height: 11px !important; }
.svc-icon svg { width: 18px !important; height: 18px !important; max-width: 18px !important; max-height: 18px !important; }
.svc-tile-icon svg { width: 18px !important; height: 18px !important; max-width: 18px !important; max-height: 18px !important; }
.hc-ico svg { width: 13px !important; height: 13px !important; max-width: 13px !important; max-height: 13px !important; }
.ab-icon svg { width: 14px !important; height: 14px !important; max-width: 14px !important; max-height: 14px !important; }
.cc-icon svg { width: 14px !important; height: 14px !important; max-width: 14px !important; max-height: 14px !important; }
.fs-icon svg { width: 26px !important; height: 26px !important; max-width: 26px !important; max-height: 26px !important; }
.p-icon svg { width: 16px !important; height: 16px !important; max-width: 16px !important; max-height: 16px !important; }
.sp-icon svg { width: 15px !important; height: 15px !important; max-width: 15px !important; max-height: 15px !important; }
.svc-hdr-ico svg { width: 23px !important; height: 23px !important; max-width: 23px !important; max-height: 23px !important; }
.faq-ico svg { width: 11px !important; height: 11px !important; max-width: 11px !important; max-height: 11px !important; }
.trust-pill svg { width: 12px !important; height: 12px !important; max-width: 12px !important; max-height: 12px !important; }
.btn svg, .h-btn-p svg, .h-btn-g svg, .btn-white svg, .form-submit svg, .q-next svg { width: 15px !important; height: 15px !important; max-width: 15px !important; max-height: 15px !important; }
.nav-ham svg { width: 22px !important; height: 22px !important; max-width: 22px !important; max-height: 22px !important; }
.mob-close svg { width: 24px !important; height: 24px !important; max-width: 24px !important; max-height: 24px !important; }
.nav-logo-svg { width: 36px !important; height: 36px !important; max-width: 36px !important; max-height: 36px !important; }

/* Firefox: gap in flex containers fallback */
@supports not (gap: 1px) {
  .nav-links a + a { margin-left: 2px; }
  .trust-bar .trust-pill + .trust-pill { margin-left: 18px; }
  .hero-actions > * + * { margin-left: 12px; }
  .cta-strip-actions > * + * { margin-left: 10px; }
  .partner-logos .partner-logo + .partner-logo { border-left: 1px solid var(--border); }
}

/* Firefox: aspect-ratio fallback for card images */
@supports not (aspect-ratio: 16/9) {
  .card-img { padding-top: 56.25%; position: relative; height: 0; }
  .card-img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
  .svc-photo img { padding-top: 75%; position: relative; height: 0; }
  .case-img { padding-top: 56.25%; position: relative; height: 0; }
  .case-img img { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }
}

/* Edge: ensure sticky nav works */
.nav {
  -ms-overflow-style: none;
}

/* Firefox: backdrop-filter fallback — darken bg instead */
@supports not (backdrop-filter: blur(1px)) {
  .mob-menu { background: rgba(7,14,26,0.99); }
  .hero-card { background: #0b1628; }
  .about-photo-card { background: rgba(7,14,26,0.96); }
}

/* Firefox: clamp() is supported from FF 75, but add min font-size fallback */
.hero-h1 { min-font-size: 40px; }

/* Ensure SVG text doesn't inherit browser defaults in Firefox */
.nav-logo-svg text,
.footer text {
  font-family: 'Syne', Georgia, serif;
}

/* Firefox form styling reset */
.form-field input,
.form-field select,
.form-field textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.form-field select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238898b0' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 30px;
}

/* Firefox: button styling */
button { -moz-appearance: none; }

/* Edge legacy: grid gap */
.stat-row { grid-gap: 0; }
.svc-grid { grid-gap: 1px; }
.pricing-grid { grid-gap: 16px; }
.values-grid { grid-gap: 14px; }
.stack-grid { grid-gap: 14px; }
.footer-grid { grid-gap: 48px; }
.hero-grid { grid-gap: 60px; }
.case-grid { grid-gap: 22px; }

/* Firefox: ::before/::after on flex items need explicit dimensions */
.hero-eyebrow::before { display: inline-block; }
.section-eyebrow::before { display: inline-block; }
.feature-eyebrow::before { display: inline-block; }

/* ── FIREFOX SVG NUCLEAR FIX ──
   Target the specific arrow SVGs that were blowing up.
   These are 12x12 viewBox SVGs used as button/link chevrons. */
a svg, button svg {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
}
/* But override for specific icon sizes */
.svc-link > svg,
.svc-link svg:last-child {
  width: 11px !important;
  height: 11px !important;
  min-width: 11px !important;
  max-width: 11px !important;
  min-height: 11px !important;
  max-height: 11px !important;
  display: block;
}
/* Clip the tile itself so nothing escapes */
.svc-tile {
  overflow: hidden;
  contain: layout;
}

/* ── FORMSPREE STATES ── */
.form-submit[disabled] {
  opacity: 0.6;
  cursor: not-allowed;
  transform: none !important;
}
[data-fs-success] { display: none; }
[data-fs-success]:not([style*="display:none"]) { display: block; }
[data-fs-error]:empty { display: none !important; }
[data-fs-error] {
  font-size: 11px;
  color: var(--red);
  margin-top: 4px;
  display: block;
  font-family: var(--font-mono);
}
.form-field input[aria-invalid="true"],
.form-field textarea[aria-invalid="true"] {
  border-color: var(--red);
  background: rgba(220,38,38,0.04);
}
