@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700;800&family=DM+Serif+Display:ital@0;1&display=swap');

:root {
  /* Lighter, richer navy — not pure black */
  --navy-950: #0b1a35;
  --navy-900: #102040;
  --navy-800: #162d58;
  --navy-700: #1e3d72;
  --navy-600: #254e8e;
  --navy-500: #2e63b0;
  --navy-400: #4080d0;
  --navy-300: #6aa0e0;
  --navy-200: #9fc2f0;
  --navy-100: #cde0f8;
  --navy-50:  #eef5fd;
  --gold:       #f0b535;
  --gold-light: #f8d070;
  --gold-pale:  rgba(240,181,53,0.14);
  --teal:       #00c8b0;
  --teal-pale:  rgba(0,200,176,0.12);
  --red-pale:   rgba(210,70,40,0.12);
  --white:      #ffffff;
  --text-muted: rgba(210,225,248,0.80);
  --text-dim:   rgba(210,225,248,0.48);
  --border:     rgba(255,255,255,0.11);
  --border-mid: rgba(255,255,255,0.20);
  --r-sm: 8px; --r-md: 12px; --r-lg: 18px; --r-xl: 24px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Outfit',sans-serif;background:var(--navy-950);color:var(--white);overflow-x:hidden;line-height:1.6;}

/* ── LAYOUT ── */
.container{max-width:1200px;margin:0 auto;padding:0 48px;}
.section{padding:100px 0;}
.section-sm{padding:68px 0;}

/* ── TYPE ── */
.label{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:18px;}
.display{font-family:'DM Serif Display',serif;font-size:clamp(48px,6vw,80px);color:var(--white);line-height:1.05;letter-spacing:-.02em;margin-bottom:24px;}
.headline{font-family:'DM Serif Display',serif;font-size:clamp(32px,4vw,52px);color:var(--white);line-height:1.12;letter-spacing:-.02em;margin-bottom:16px;}
.subhead{font-size:17px;color:var(--text-muted);line-height:1.78;max-width:580px;}
.accent{color:var(--gold);font-style:italic;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:var(--r-sm);font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;text-decoration:none;transition:all .2s;cursor:pointer;border:none;}
.btn-primary{background:var(--gold);color:var(--navy-900);}
.btn-primary:hover{background:var(--gold-light);transform:translateY(-1px);}
.btn-outline{background:transparent;color:var(--white);border:1px solid var(--border-mid);}
.btn-outline:hover{border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.05);}
.btn-sm{padding:9px 18px;font-size:13px;}

/* ── TAGS ── */
.tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:100px;font-size:11px;font-weight:600;letter-spacing:.04em;}
.tag-gold{background:var(--gold-pale);border:1px solid rgba(232,168,48,.3);color:var(--gold);}
.tag-teal{background:var(--teal-pale);border:1px solid rgba(0,184,160,.3);color:var(--teal);}
.tag-navy{background:rgba(255,255,255,.06);border:1px solid var(--border);color:var(--navy-200);}
.dot{width:6px;height:6px;border-radius:50%;background:currentColor;}
.dot-pulse{animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}

/* --- Logo Enhancements (Global) --- */
.nav-logo {
  font-size: 32px !important; 
  font-weight: 800;
  letter-spacing: 1px;
  padding: 16px 24px !important; 
  margin-left: -24px; 
  display: inline-flex;
  align-items: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.nav-logo:hover {
  opacity: 0.85; 
  transform: scale(1.2); 
}


/* ── NAV ── */
nav.site-nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  padding: 0 40px; 
  height: 76px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(11,26,53,.96);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-mid);
}

.nav-logo {
  font-family: 'DM Serif Display', serif;
  font-size: 32px !important; 
  font-weight: 800;
  letter-spacing: 1px;
  padding: 16px 24px !important; 
  margin-left: -24px; 
  display: inline-flex;
  align-items: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
  color: var(--white);
  text-decoration: none;
}

.nav-logo:hover {
  opacity: 0.85; 
  transform: scale(1.2); 
}

.nav-logo span {
  color: var(--gold);
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 12px; 
  list-style: none;
  margin: 0;
  padding: 0;
}

.nav-links a:not(.nav-cta) {
  color: rgba(255, 255, 255, 0.9); 
  text-decoration: none;
  font-size: 15px; 
  font-weight: 500;
  padding: 10px 16px; 
  border-radius: 8px;
  transition: all 0.2s ease;
}

.nav-links a:not(.nav-cta):hover {
  color: #ffffff;
  background-color: rgba(255, 255, 255, 0.08); 
}

.nav-links a:focus-visible {
  outline: 2px solid var(--gold); 
  outline-offset: 2px;
}

.nav-links a.active {
  color: var(--gold) !important; 
  font-weight: 600;
  background-color: rgba(240, 181, 53, 0.1); 
  border-bottom: none;
}

.nav-cta {
  background: var(--gold) !important;
  color: #0b1a35 !important;
  padding: 10px 22px !important;
  border-radius: var(--r-sm) !important;
  border-bottom: none !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  margin-left: 12px; 
  transition: background 0.2s ease;
}

.nav-cta:hover {
  background: var(--gold-light) !important;
}

/* ── FOOTER ── */
footer.site-footer{border-top:1px solid var(--border);padding:52px 48px 40px;display:grid;grid-template-columns:1fr auto 1fr;align-items:start;gap:32px;}
.footer-brand .nav-logo{display:block;margin-bottom:10px;}
.footer-brand p{font-size:13px;color:var(--text-dim);max-width:220px;line-height:1.6;}
.footer-links-group h4{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:16px;}
.footer-links-group a{display:block;font-size:14px;color:var(--text-muted);text-decoration:none;margin-bottom:10px;transition:color .2s;}
.footer-links-group a:hover{color:var(--white);}
.footer-right{text-align:right;}
.footer-right .footer-email{color:var(--navy-200);font-size:15px;display:block;margin-bottom:6px;text-decoration:none;}
.footer-right .footer-copy{font-size:12px;color:var(--text-dim);margin-top:16px;}

/* ── PAGE HERO ── */
.page-hero{padding:148px 0 88px;border-bottom:1px solid var(--border);position:relative;overflow:hidden;}
.page-hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 80% 70% at 25% 50%,rgba(30,61,114,.65) 0%,transparent 70%),var(--navy-950);}
.page-hero-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 65% 85% at 30% 50%,black 0%,transparent 80%);}
.page-hero-inner{position:relative;z-index:2;}

/* ── CARDS ── */
.card{background:rgba(22,45,88,.55);border:1px solid var(--border-mid);border-radius:var(--r-xl);overflow:hidden;transition:border-color .3s,transform .3s;}
.card:hover{border-color:rgba(240,181,53,.35);transform:translateY(-3px);}
.card-pad{padding:36px;}

/* ── FEATURE LIST ── */
.feat-list{list-style:none;display:flex;flex-direction:column;gap:10px;}
.feat-list li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:rgba(196,210,240,.72);line-height:1.55;}
.feat-list li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--gold);margin-top:6px;flex-shrink:0;}

/* ── TRUST STRIP ── */
.trust-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:rgba(12,31,63,.35);padding:26px 40px;}
.trust-inner{display:flex;align-items:center;gap:40px;justify-content:center;flex-wrap:wrap;}
.trust-label{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--text-dim);}
.industry-pill{background:rgba(255,255,255,.05);border:1px solid var(--border);border-radius:6px;padding:7px 16px;font-size:12px;font-weight:600;color:var(--navy-200);letter-spacing:.03em;}

/* ── STAT BOXES ── */
.stat-box{background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:var(--r-sm);padding:18px 14px;text-align:center;}
.stat-val{font-family:'DM Serif Display',serif;font-size:28px;color:var(--gold);display:block;margin-bottom:4px;}
.stat-lbl{font-size:11px;color:var(--text-dim);}

/* ── PERF STRIP ── */
.perf-strip{display:grid;grid-template-columns:repeat(4,1fr);background:rgba(12,31,63,.5);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;}
.perf-item{padding:32px 24px;border-left:1px solid var(--border);text-align:center;}
.perf-item:first-child{border-left:none;}
.perf-val{font-family:'DM Serif Display',serif;font-size:38px;color:var(--gold);display:block;margin-bottom:8px;}
.perf-lbl{font-size:13px;color:var(--text-muted);line-height:1.5;}

/* ── GRID HELPERS ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:24px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
.grid-2-gap{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}

/* ── ROADMAP ── */
.roadmap-steps{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;}
.roadmap-step{padding:30px 24px;border-left:1px solid var(--border);}
.roadmap-step:first-child{border-left:none;}
.roadmap-step.current{background:rgba(22,56,114,.22);}
.road-phase{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);margin-bottom:5px;}
.road-year{font-size:13px;font-weight:700;color:var(--gold);margin-bottom:10px;}
.road-trl{display:inline-block;font-size:10px;font-weight:700;padding:2px 10px;border-radius:4px;margin-bottom:12px;background:var(--gold-pale);border:1px solid rgba(232,168,48,.25);color:var(--gold);}
.road-trl.done{background:var(--teal-pale);border-color:rgba(0,184,160,.25);color:var(--teal);}
.roadmap-step h4{font-size:14px;font-weight:700;color:var(--white);margin-bottom:8px;}
.roadmap-step p{font-size:12px;color:var(--text-muted);line-height:1.6;}

/* ── PROOF ── */
.quote-card{background:rgba(22,56,114,.2);border:1px solid rgba(37,99,196,.25);border-radius:var(--r-xl);padding:44px;}
.quote-mark{font-family:'DM Serif Display',serif;font-size:64px;color:var(--gold);line-height:.6;margin-bottom:20px;opacity:.45;}
.quote-text{font-size:17px;font-style:italic;color:rgba(196,210,240,.85);line-height:1.75;margin-bottom:24px;}
.quote-author strong{display:block;font-size:14px;color:var(--white);font-weight:600;margin-bottom:2px;}
.quote-author span{font-size:13px;color:var(--text-dim);}
.stat-card-lg{background:rgba(12,31,63,.5);border:1px solid var(--border);border-radius:var(--r-lg);padding:28px 24px;}
.stat-card-num{font-family:'DM Serif Display',serif;font-size:42px;color:var(--white);display:block;margin-bottom:6px;}
.stat-card-desc{font-size:13px;color:var(--text-muted);line-height:1.5;}

/* ── CTA SECTION ── */
.cta-section{background:linear-gradient(135deg,rgba(22,56,114,.5) 0%,rgba(4,13,28,.8) 100%);border-top:1px solid var(--border);text-align:center;position:relative;overflow:hidden;}
.cta-bg{position:absolute;inset:0;background:radial-gradient(circle 400px at 50% 50%,rgba(232,168,48,.05) 0%,transparent 70%);}
.cta-inner{position:relative;z-index:2;}
.cta-section h2{font-family:'DM Serif Display',serif;font-size:clamp(30px,4vw,50px);color:var(--white);margin-bottom:16px;}
.cta-section p{font-size:17px;color:var(--text-muted);max-width:440px;margin:0 auto 36px;line-height:1.75;}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;}

/* ── SECTION ALT BG ── */
.bg-alt{background:rgba(7,20,40,.7);border-top:1px solid var(--border);border-bottom:1px solid var(--border);}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .65s ease both;}
.d1{animation-delay:.1s}.d2{animation-delay:.2s}.d3{animation-delay:.3s}.d4{animation-delay:.4s}

/* ── FORM ── */
.form-group{margin-bottom:20px;}
.form-label{display:block;font-size:13px;font-weight:600;color:var(--navy-200);margin-bottom:8px;letter-spacing:.02em;}
.form-input,.form-select,.form-textarea{width:100%;background:rgba(12,31,63,.6);border:1px solid var(--border-mid);border-radius:var(--r-sm);padding:13px 16px;font-family:'Outfit',sans-serif;font-size:14px;color:var(--white);transition:border-color .2s,background .2s;outline:none;}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:rgba(232,168,48,.5);background:rgba(22,56,114,.25);}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-dim);}
.form-select option{background:var(--navy-800);color:var(--white);}
.form-textarea{resize:vertical;min-height:140px;line-height:1.6;}
.form-submit{width:100%;padding:15px;font-size:15px;font-weight:700;border-radius:var(--r-sm);background:var(--gold);color:var(--navy-900);border:none;cursor:pointer;font-family:'Outfit',sans-serif;transition:all .2s;}
.form-submit:hover{background:var(--gold-light);transform:translateY(-1px);}
.form-success{display:none;background:var(--teal-pale);border:1px solid rgba(0,184,160,.3);border-radius:var(--r-md);padding:24px;text-align:center;color:var(--teal);}
.form-success.show{display:block;}

/* ── PRODUCT CARD HOVER ZOOM ── */
.prod-photo-wrap { overflow:hidden; border-radius:20px 20px 0 0; }
.prod-photo-wrap img { width:100%; height:260px; object-fit:cover; display:block; transition:transform .5s ease; }
.prod-card-outer { border-radius:20px; overflow:hidden; border:1px solid var(--border-mid); background:rgba(14,30,62,.55); transition:border-color .3s, transform .3s, box-shadow .3s; text-decoration:none; display:block; }
.prod-card-outer:hover { border-color:rgba(240,181,53,.4); transform:translateY(-4px); box-shadow:0 28px 72px rgba(0,0,0,.55); }
.prod-card-outer:hover .prod-photo-wrap img { transform:scale(1.04); }
.prod-card-body { padding:28px 28px 32px; }

/* ── KPI STRIP ── */
.kpi-strip { display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:rgba(14,30,62,.4); }
.kpi-item { padding:28px 24px; border-left:1px solid var(--border); text-align:center; }
.kpi-item:first-child { border-left:none; }
.kpi-val { font-family:'DM Serif Display',serif; font-size:38px; color:var(--gold); display:block; margin-bottom:6px; }
.kpi-lbl { font-size:13px; color:var(--text-muted); line-height:1.4; }

/* ════════════════════════════════════════════════════
   RESPONSIVE — MOBILE & TABLET
   Breakpoints: 768px (mobile), 1024px (tablet)
════════════════════════════════════════════════════ */

/* ── HAMBURGER BUTTON ── */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 6px;
  border-radius: 8px;
  transition: background .2s;
  z-index: 1001;
}
.nav-toggle:hover { background: rgba(255,255,255,.08); }
.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--white);
  border-radius: 2px;
  transition: transform .3s, opacity .3s;
}
/* Animate to X when open */
nav.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
nav.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
nav.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── TABLET (max 1024px) ── */
@media (max-width: 1024px) {
  .container { padding: 0 32px; }
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .roadmap-steps { grid-template-columns: repeat(2, 1fr); }
  .perf-strip { grid-template-columns: repeat(2, 1fr); }
  .kpi-strip { grid-template-columns: repeat(2, 1fr); }
  .kpi-item:nth-child(1),
  .kpi-item:nth-child(2) { border-top: none; }
  .kpi-item:nth-child(1) { border-left: none; }
  .kpi-item:nth-child(3) { border-left: none; }
}

/* ── MOBILE (max 768px) ── */
@media (max-width: 768px) {

  /* Container */
  .container { padding: 0 20px; }

  /* Sections */
  .section    { padding: 56px 0; }
  .section-sm { padding: 40px 0; }

  /* Typography */
  .display  { font-size: clamp(36px, 9vw, 56px); }
  .headline { font-size: clamp(26px, 7vw, 38px); }
  .subhead  { font-size: 15px; }

  /* ── NAVIGATION ── */
  .nav-toggle { display: flex; }

  .nav-links {
    display: none;
    position: fixed;
    top: 76px;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(8,18,42,.98);
    backdrop-filter: blur(20px);
    flex-direction: column;
    align-items: flex-start;
    padding: 32px 24px;
    gap: 4px;
    overflow-y: auto;
    border-top: 1px solid var(--border);
    z-index: 999;
  }
  nav.nav-open .nav-links { display: flex; }

  .nav-links li { width: 100%; }
  .nav-links a:not(.nav-cta) {
    display: block;
    font-size: 18px;
    padding: 14px 16px;
    border-radius: 10px;
    width: 100%;
  }
  .nav-cta {
    margin-left: 0 !important;
    margin-top: 16px;
    width: 100%;
    justify-content: center;
    text-align: center;
    display: block !important;
    padding: 14px 24px !important;
    font-size: 16px !important;
  }

  /* ── INLINE GRID OVERRIDES ──
     Targets all inline style grids — makes them single column on mobile */
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:1fr 1.4fr"],
  [style*="grid-template-columns:1.4fr 1fr"],
  [style*="grid-template-columns:1.2fr 0.8fr"],
  [style*="grid-template-columns:0.8fr 1.2fr"],
  [style*="grid-template-columns:1.1fr 0.9fr"],
  [style*="grid-template-columns:1fr 1fr 1fr"],
  [style*="grid-template-columns:repeat(3,1fr)"],
  [style*="grid-template-columns:repeat(4,1fr)"],
  [style*="grid-template-columns:repeat(6,1fr)"],
  [style*="grid-template-columns:1fr auto 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  /* CSS class grids */
  .grid-2, .grid-3, .grid-4, .grid-2-gap { grid-template-columns: 1fr !important; }
  .prod-grid { grid-template-columns: 1fr !important; }

  /* KPI & perf strips → 2×2 */
  .kpi-strip,
  .perf-strip {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  .kpi-item  { border-left: none; border-top: 1px solid var(--border); }
  .kpi-item:nth-child(1),
  .kpi-item:nth-child(2) { border-top: none; }
  .perf-item { border-left: none; border-top: 1px solid var(--border); }
  .perf-item:nth-child(1),
  .perf-item:nth-child(2) { border-top: none; }

  /* Roadmap → 2×2 */
  .roadmap-steps { grid-template-columns: repeat(2, 1fr) !important; }
  .roadmap-step { border-left: none; border-top: 1px solid var(--border); }
  .roadmap-step:nth-child(1),
  .roadmap-step:nth-child(2) { border-top: none; }
  .roadmap-step:nth-child(2n+1) { border-left: none; }

  /* Page hero */
  .page-hero { padding: 108px 0 52px; }

  /* Product cards */
  .prod-img-wrap img    { height: 220px; }
  .prod-card-body       { padding: 20px 20px 24px; }

  /* Full-screen section heroes */
  section[style*="min-height:100vh"] .container > div[style*="max-width:640px"],
  section[style*="min-height:100vh"] .container > div[style*="max-width:700px"] {
    max-width: 100% !important;
  }
  section[style*="min-height:100vh"] { padding-bottom: 52px; }

  /* Big hero text overlay on product pages */
  div[style*="padding:0 64px"] {
    padding: 0 24px !important;
    max-width: 100% !important;
  }

  /* Buttons */
  .cta-btns { flex-direction: column; align-items: center; }
  .cta-btns .btn { width: 100%; max-width: 320px; justify-content: center; }

  /* Trust / industry pills */
  .trust-inner { gap: 10px; justify-content: center; }
  .industry-pill { font-size: 11px; padding: 5px 12px; }

  /* Footer → single column */
  footer.site-footer {
    grid-template-columns: 1fr !important;
    text-align: center;
    padding: 40px 24px 32px;
    gap: 32px;
  }
  .footer-right { text-align: center; }
  .footer-brand p { max-width: 100%; }
  .footer-links-group a { display: inline-block; margin: 0 6px 8px; }

  /* Software hero 2-col → stack */
  section.page-hero > div.container > div[style*="grid-template-columns:1fr 1fr;gap:56px"] {
    grid-template-columns: 1fr !important;
  }

  /* Stat boxes */
  .stat-box  { padding: 14px 10px; }
  .stat-val  { font-size: 22px; }

  /* Forms */
  div[style*="grid-template-columns:1fr 1fr;gap:16px"] {
    grid-template-columns: 1fr !important;
  }

  /* Services process (6-col) */
  div[style*="repeat(6,1fr)"] {
    grid-template-columns: 1fr !important;
  }
  div[style*="repeat(6,1fr)"] > div {
    border-left: none !important;
    border-top: 1px solid var(--border);
  }
  div[style*="repeat(6,1fr)"] > div:first-child {
    border-top: none;
  }

  /* Tables / spec tables on modular/printing pages */
  table { font-size: 11px; }

  /* Full-width banner image sections */
  section[style*="max-height:480px"],
  section[style*="max-height:520px"] {
    max-height: 260px !important;
  }
  section[style*="max-height:480px"] img,
  section[style*="max-height:520px"] img {
    max-height: 260px !important;
  }

  /* Hide tagline bar on mobile to save space */
  .tagline-bar { font-size: 11px; padding: 12px 0 0; }

  /* Cards padding */
  .card-pad { padding: 24px 20px; }

  /* Schematic SVG */
  svg[viewBox="0 0 680 280"],
  svg[viewBox="0 0 680 290"],
  svg[viewBox="0 0 680 330"] {
    min-height: 180px;
  }
}

/* ── SMALL MOBILE (max 480px) ── */
@media (max-width: 480px) {
  .container { padding: 0 16px; }
  .display  { font-size: clamp(30px, 8vw, 42px); }
  .headline { font-size: clamp(22px, 6vw, 32px); }
  .kpi-strip,
  .perf-strip { grid-template-columns: 1fr 1fr !important; }
  .kpi-val  { font-size: 28px; }
  .perf-val { font-size: 28px; }
  .roadmap-steps { grid-template-columns: 1fr !important; }
  .roadmap-step { border-top: 1px solid var(--border); }
  .roadmap-step:first-child { border-top: none; }
}
