/* ================================================================
   CertiTrust Consulting — Expert UI/UX Redesign 2026
   Senior UI/UX Designer — Full Design System
   Colors extracted from official CertiTrust logo:
     Brand Blue  : #0058A0 (logo arrow blue)
     Brand Green : #08A850 (logo arrow green)
     Silver/Chrome: #B8C0C8 (logo outer ring)
   ================================================================ */

/* ================================================================
   1. DESIGN TOKENS
   ================================================================ */
:root {
  /* Logo-Exact Blue Family */
  --blue-950:  #001628;
  --blue-900:  #002848;
  --blue-800:  #003868;
  --blue-700:  #004880;
  --blue-600:  #005898;
  --blue-500:  #0068B0;
  --blue-400:  #1A80C8;
  --blue-300:  #4AA0DC;
  --blue-200:  #8CC4EE;
  --blue-100:  #C8E4F8;
  --blue-50:   #EBF5FC;

  /* Logo-Exact Green Family */
  --green-950: #011A0A;
  --green-900: #022E12;
  --green-800: #044820;
  --green-700: #066030;
  --green-600: #077840;
  --green-500: #08A850;
  --green-400: #18BE64;
  --green-300: #3DD47E;
  --green-200: #80E4A8;
  --green-100: #C0F2D4;
  --green-50:  #EAFBF2;

  /* Silver/Chrome Family */
  --chrome-600: #7A8898;
  --chrome-500: #9AAABB;
  --chrome-400: #B4C0CC;
  --chrome-300: #C8D2DC;
  --chrome-200: #DCE4EC;
  --chrome-100: #EDF2F7;
  --chrome-50:  #F5F8FC;

  /* Semantic */
  --color-primary:      var(--blue-600);
  --color-accent:       var(--green-500);
  --color-primary-soft: var(--blue-50);
  --color-accent-soft:  var(--green-50);

  /* Surfaces */
  --surface-white:  #FFFFFF;
  --surface-light:  #F4F8FC;
  --surface-subtle: #ECF3FA;
  --surface-dark:   var(--blue-950);
  --surface-dark2:  var(--blue-900);

  /* Text */
  --text-900: #071C30;
  --text-700: #1C3A58;
  --text-500: #3E5E7E;
  --text-300: #6E8EA8;
  --text-inv: #FFFFFF;

  /* Borders */
  --border-light:  rgba(0,88,152,.08);
  --border-medium: rgba(0,88,152,.14);
  --border-strong: rgba(0,88,152,.26);

  /* Typography */
  --font-display: "Plus Jakarta Sans","Inter",system-ui,sans-serif;
  --font-sans:    "Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
  --font-mono:    "JetBrains Mono",ui-monospace,"SF Mono",Menlo,monospace;

  /* Layout */
  --max-w: 1280px;
  --pad:   clamp(20px,5vw,56px);

  /* Radii */
  --r-sm:  6px;  --r-md: 10px; --r-lg: 16px;
  --r-xl: 22px; --r-2xl:32px; --r-full:9999px;

  /* Shadows */
  --sh-xs: 0 1px 3px rgba(0,22,40,.05);
  --sh-sm: 0 2px 8px rgba(0,22,40,.08), 0 1px 2px rgba(0,22,40,.04);
  --sh-md: 0 8px 24px rgba(0,22,40,.10), 0 2px 6px rgba(0,22,40,.05);
  --sh-lg: 0 20px 48px rgba(0,22,40,.12), 0 6px 16px rgba(0,22,40,.06);
  --sh-xl: 0 36px 80px rgba(0,22,40,.15), 0 12px 28px rgba(0,22,40,.08);
  --sh-blue:  0 8px 28px rgba(0,88,152,.30);
  --sh-green: 0 8px 28px rgba(8,168,80,.26);

  /* Motion */
  --ease:     cubic-bezier(.22,.61,.36,1);
  --ease-spr: cubic-bezier(.34,1.46,.64,1);
  --t-fast:  150ms;
  --t-base:  220ms;
  --t-slow:  380ms;

  /* Spacing */
  --sp-1:4px; --sp-2:8px;  --sp-3:12px; --sp-4:16px;
  --sp-5:20px;--sp-6:24px; --sp-8:32px; --sp-10:40px;
  --sp-12:48px;--sp-16:64px;--sp-20:80px;--sp-24:96px;
}

/* ================================================================
   2. RESET & BASE
   ================================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-padding-top:90px} /* offset for fixed nav */
a,button{-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;overflow-x:hidden}
body{
  font-family:var(--font-sans);
  color:var(--text-900);
  background:var(--surface-white);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:var(--color-primary);text-decoration:none;transition:color var(--t-fast) var(--ease)}
a:hover{color:var(--blue-400)}
ul{list-style:none}

h1,h2,h3,h4,h5{
  font-family:var(--font-display);
  font-weight:700;
  line-height:1.14;
  letter-spacing:-.025em;
  color:var(--text-900);
}
h1{font-size:clamp(2.4rem,5vw,3.8rem);letter-spacing:-.04em}
h2{font-size:clamp(1.8rem,3.2vw,2.6rem);letter-spacing:-.03em}
h3{font-size:1.2rem;font-weight:600;letter-spacing:-.015em}
h4{font-size:1rem;font-weight:600;letter-spacing:-.01em}
p{color:var(--text-500);line-height:1.72}
p+p{margin-top:1em}
strong{color:var(--text-700);font-weight:600}

.lead{
  font-size:clamp(1.05rem,1.8vw,1.18rem);
  color:var(--text-500);
  line-height:1.74;
  max-width:62ch;
}
.mono{font-family:var(--font-mono);font-size:.78rem;letter-spacing:.02em}
.text-blue   {color:var(--blue-600)  !important}
.text-green  {color:var(--green-600) !important}
.text-white  {color:#fff             !important}
.text-muted  {color:var(--text-300)  !important}
.text-center {text-align:center}
.text-sm     {font-size:.88rem}

/* Eyebrow */
.eyebrow{
  display:inline-flex;align-items:center;gap:var(--sp-2);
  font-family:var(--font-mono);font-size:.70rem;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue-600);
  background:var(--blue-50);
  border:1px solid rgba(0,88,152,.15);
  padding:6px 14px;border-radius:var(--r-full);
}
.eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--green-500);flex-shrink:0;
}
.eyebrow.green{color:var(--green-700);background:var(--green-50);border-color:rgba(8,168,80,.18)}
.eyebrow.green::before{background:var(--blue-600)}
.eyebrow.dark{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.18);color:rgba(255,255,255,.92)}
.eyebrow.dark::before{background:var(--green-400)}

/* ================================================================
   3. LAYOUT
   ================================================================ */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad)}
.section{padding:clamp(72px,9vw,120px) 0;position:relative}
.section.tight{padding:clamp(48px,6vw,80px) 0}

.section.light {background:var(--surface-light)}
.section.subtle{background:var(--surface-subtle)}
.section.dark{
  background:
    radial-gradient(ellipse 900px 500px at 110% -10%,rgba(8,168,80,.12),transparent 55%),
    radial-gradient(ellipse 700px 400px at -10% 110%,rgba(0,88,152,.18),transparent 55%),
    var(--blue-950);
  color:rgba(255,255,255,.88);
}
.section.dark h1,.section.dark h2,.section.dark h3{color:#fff}
.section.dark p,.section.dark .lead{color:rgba(255,255,255,.78)}

.grid  {display:grid;gap:var(--sp-6)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}

.split{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.split.flip{grid-template-columns:1fr 1.1fr}

@media(max-width:1000px){.split,.split.flip{grid-template-columns:1fr;gap:40px}}
@media(max-width:960px) {.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px) {.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.section-head{text-align:center;max-width:740px;margin:0 auto clamp(48px,6vw,72px)}
.section-head .eyebrow{margin-bottom:var(--sp-4)}
.section-head h2{margin-bottom:var(--sp-4)}
.section-head .lead{margin:0 auto}

/* ================================================================
   4. BUTTONS
   ================================================================ */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-sans);font-weight:600;font-size:.94rem;
  letter-spacing:-.01em;padding:13px 24px;
  min-height:44px; /* WCAG 2.5.5 touch target */
  border-radius:var(--r-md);border:1.5px solid transparent;
  cursor:pointer;white-space:nowrap;position:relative;overflow:hidden;
  text-decoration:none;transition:all var(--t-base) var(--ease);
}
.btn:hover{transform:translateY(-2px);text-decoration:none}
.btn:active{transform:translateY(0)}
.btn .arrow{transition:transform var(--t-base) var(--ease-spr)}
.btn:hover .arrow{transform:translateX(5px)}

.btn-primary{
  background:linear-gradient(135deg,var(--blue-500) 0%,var(--blue-600) 45%,var(--blue-700) 100%);
  color:#fff;border-color:transparent;
  box-shadow:var(--sh-blue),inset 0 1px 0 rgba(255,255,255,.14);
}
.btn-primary:hover{
  color:#fff;
  box-shadow:0 14px 38px rgba(0,88,152,.40),inset 0 1px 0 rgba(255,255,255,.14);
}

.btn-accent{
  background:linear-gradient(135deg,var(--green-400) 0%,var(--green-500) 45%,var(--green-700) 100%);
  color:#fff;border-color:transparent;
  box-shadow:var(--sh-green),inset 0 1px 0 rgba(255,255,255,.14);
}
.btn-accent:hover{
  color:#fff;
  box-shadow:0 14px 38px rgba(8,168,80,.38),inset 0 1px 0 rgba(255,255,255,.14);
}

.btn-ghost{
  background:rgba(255,255,255,.92);color:var(--blue-600);
  border-color:var(--border-medium);backdrop-filter:blur(8px);
  box-shadow:var(--sh-xs);
}
.btn-ghost:hover{border-color:var(--blue-600);background:var(--blue-50);color:var(--blue-700);box-shadow:var(--sh-sm)}

.btn-ghost-white{
  background:rgba(255,255,255,.10);color:#fff;
  border-color:rgba(255,255,255,.28);backdrop-filter:blur(8px);
}
.btn-ghost-white:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.50);color:#fff}

.btn-outline{background:transparent;color:var(--blue-600);border-color:var(--blue-600)}
.btn-outline:hover{background:var(--blue-600);color:#fff}
.btn-link{padding:0;background:transparent;border:none;color:var(--blue-600);font-weight:600;box-shadow:none}
.btn-link:hover{color:var(--blue-500);transform:none}
.btn-sm{padding:9px 18px;font-size:.86rem}
.btn-lg{padding:16px 32px;font-size:1.02rem;border-radius:var(--r-lg)}

/* ================================================================
   5. NAVIGATION
   ================================================================ */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,.93);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--border-light);
  box-shadow:0 2px 20px rgba(0,22,40,.06);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:90px;gap:var(--sp-6);
}
.brand{display:inline-flex;align-items:center;flex-shrink:0}
.brand:hover{text-decoration:none}

img.nav-logo{
  height:68px !important;width:auto !important;
  object-fit:contain;
  transition:transform var(--t-base) var(--ease-spr);
}
.brand:hover img.nav-logo{transform:scale(1.04)}

.nav-links{display:flex;align-items:center;gap:2px}
.nav-links a{
  color:var(--text-700);font-size:.93rem;font-weight:500;
  padding:9px 14px;border-radius:var(--r-md);
  transition:color var(--t-fast),background var(--t-fast);
  white-space:nowrap;
}
.nav-links a:hover{color:var(--blue-600);background:var(--blue-50)}
.nav-links a.current{color:var(--blue-600);background:var(--blue-50);font-weight:600}
.nav-links a.current::after{
  content:"";display:block;height:2px;border-radius:2px;
  background:linear-gradient(90deg,var(--blue-600),var(--green-500));
  margin-top:3px;
}

.nav-dropdown{position:relative}
.nav-dropdown>a{display:flex;align-items:center;gap:4px}
.nav-dropdown>a::after{
  content:"▾";font-size:.62em;opacity:.5;
  transition:transform var(--t-fast) var(--ease);
}
.nav-dropdown:hover>a::after{transform:rotate(180deg);opacity:.8}

.nav-dropdown-menu{
  position:absolute;top:calc(100% + 10px);left:-12px;
  min-width:300px;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  border:1px solid var(--border-light);border-radius:var(--r-xl);
  padding:12px;box-shadow:var(--sh-lg);
  opacity:0;visibility:hidden;
  transform:translateY(-8px) scale(.98);transform-origin:top left;
  transition:all var(--t-base) var(--ease);list-style:none;
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu{
  opacity:1;visibility:visible;transform:translateY(0) scale(1);
}
.nav-dropdown-menu a{
  display:flex;align-items:center;gap:10px;
  padding:11px 14px;border-radius:var(--r-md);
  color:var(--text-700);font-size:.91rem;
}
.nav-dropdown-menu a:hover{background:var(--blue-50);color:var(--blue-600)}
.nav-dropdown-menu .menu-label{
  display:block;font-family:var(--font-mono);font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-300);padding:12px 14px 6px;
}
.nav-cta{display:flex;align-items:center;gap:10px;flex-shrink:0}

.nav-toggle{
  display:none;background:var(--surface-white);
  border:1.5px solid var(--border-medium);color:var(--text-900);
  width:44px;height:44px;border-radius:var(--r-md);
  cursor:pointer;align-items:center;justify-content:center;
  transition:all var(--t-fast);
}
.nav-toggle:hover{border-color:var(--blue-600);color:var(--blue-600)}

@media(max-width:1100px){.nav-links li:nth-child(n+4){display:none}}
@media(max-width:960px){
  .nav-links,.nav-cta .btn-ghost,.nav-cta .btn-primary{display:none}
  .nav-toggle{display:inline-flex}
}

.mobile-sheet{
  position:fixed;inset:90px 0 0 0;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  z-index:99;padding:var(--sp-6) var(--sp-6) var(--sp-12);
  overflow-y:auto;display:none;
  border-top:1px solid var(--border-light);
  box-shadow:0 20px 60px rgba(0,22,40,.15);
}
.mobile-sheet.open{display:block}
.mobile-sheet a{
  display:block;padding:15px 0;color:var(--text-700);
  font-size:1.02rem;font-weight:500;
  border-bottom:1px solid var(--border-light);
}
.mobile-sheet a:hover{color:var(--blue-600)}
.mobile-sheet .menu-label{
  font-family:var(--font-mono);font-size:.66rem;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--text-300);padding-top:22px;display:block;
}

/* ================================================================
   MOBILE HEADER - Dedicated Mobile Navigation
   ================================================================ */
.mobile-header{
  display:none;
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:1000;
  background:rgba(255,255,255,.98);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom:1px solid var(--border-light);
  box-shadow:0 2px 20px rgba(0,22,40,.06);
}

.mobile-header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 16px;
  height:64px;
}

.mobile-header-brand{
  display:flex;
  align-items:center;
  flex-shrink:0;
}

.mobile-header-brand img{
  height:48px;
  width:auto;
  object-fit:contain;
}

.mobile-header-toggle{
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  width:44px;
  height:44px;
  background:var(--surface-white);
  border:1.5px solid var(--border-medium);
  border-radius:var(--r-md);
  cursor:pointer;
  transition:all var(--t-fast);
  padding:0;
}

.mobile-header-toggle:hover{
  border-color:var(--blue-600);
  background:var(--blue-50);
}

.mobile-header-toggle span{
  display:block;
  width:20px;
  height:2px;
  background:var(--text-900);
  border-radius:2px;
  transition:all var(--t-base) var(--ease);
  margin:2px 0;
}

.mobile-header-toggle.active span:nth-child(1){
  transform:rotate(45deg) translate(5px,5px);
}

.mobile-header-toggle.active span:nth-child(2){
  opacity:0;
  transform:translateX(-10px);
}

.mobile-header-toggle.active span:nth-child(3){
  transform:rotate(-45deg) translate(5px,-5px);
}

.mobile-nav-overlay{
  position:fixed;
  inset:64px 0 0 0;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(20px);
  z-index:10000;
  display:none;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}

.mobile-nav-overlay.open{
  display:block;
  animation:slideDown 0.3s var(--ease);
}

@keyframes slideDown{
  from{
    opacity:0;
    transform:translateY(-10px);
  }
  to{
    opacity:1;
    transform:translateY(0);
  }
}

.mobile-nav-content{
  padding:20px 16px 40px;
}

.mobile-nav-section{
  margin-bottom:24px;
}

.mobile-nav-label{
  font-family:var(--font-mono);
  font-size:.70rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--text-300);
  padding:8px 0 12px;
  font-weight:600;
}

.mobile-nav-link{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  color:var(--text-700);
  font-size:1rem;
  font-weight:500;
  border-radius:var(--r-md);
  text-decoration:none;
  transition:all var(--t-fast);
  border:1px solid transparent;
}

.mobile-nav-link:hover{
  background:var(--blue-50);
  color:var(--blue-600);
  border-color:rgba(0,88,152,.10);
}

.mobile-nav-link svg{
  width:18px;
  height:18px;
  opacity:0.5;
  transition:opacity var(--t-fast);
}

.mobile-nav-link:hover svg{
  opacity:1;
}

.mobile-nav-cta{
  padding:24px 16px 0;
  border-top:1px solid var(--border-light);
  margin-top:16px;
}

.mobile-nav-cta .btn{
  width:100%;
  justify-content:center;
  margin-bottom:12px;
}

@media(max-width:960px){
  .mobile-header{
    display:block;
  }
  .site-header{
    display:none;
  }
  .nav-cta .btn-primary,
  .nav-cta .btn-ghost{
    display:none;
  }
}

/* ================================================================
   6. HERO
   ================================================================ */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(88px,10vw,140px) 0 clamp(72px,8vw,110px);
  background:var(--surface-white);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(ellipse 900px 600px at 90% -20%,rgba(0,88,152,.09),transparent 60%),
    radial-gradient(ellipse 600px 400px at -5% 60%, rgba(8,168,80,.07), transparent 55%),
    radial-gradient(ellipse 500px 300px at 50% 110%,rgba(0,88,152,.05),transparent 55%);
  pointer-events:none;
}
.hero::after{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(0,88,152,.07) 1px,transparent 1px);
  background-size:30px 30px;pointer-events:none;
  mask-image:radial-gradient(ellipse 80% 70% at 50% 30%,#000 25%,transparent 80%);
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.08fr 1fr;
  gap:clamp(40px,6vw,80px);align-items:center;
}
@media(max-width:960px){.hero-grid{grid-template-columns:1fr;gap:40px}}

.hero h1{
  margin-bottom:var(--sp-6);
  background:linear-gradient(135deg,var(--text-900) 0%,var(--blue-700) 60%,var(--blue-500) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1.10;
}
.hero .lead{margin-bottom:var(--sp-10);max-width:54ch}
.hero-cta{display:flex;gap:var(--sp-4);flex-wrap:wrap;margin-bottom:var(--sp-12)}

.hero-trust{
  display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-4);
  padding-top:var(--sp-8);border-top:1px dashed var(--border-medium);
}
.hero-trust-item{
  display:flex;align-items:center;gap:var(--sp-2);
  font-size:.84rem;color:var(--text-500);font-weight:500;
}
.hero-trust-item .check{
  width:18px;height:18px;border-radius:50%;
  background:linear-gradient(135deg,var(--green-500),var(--green-700));
  display:grid;place-items:center;color:#fff;
  font-size:.58rem;font-weight:900;flex-shrink:0;
}

.hero-visual{position:relative}
.hero-visual img{
  width:100%;max-width:560px;margin-left:auto;
  border-radius:var(--r-2xl);box-shadow:var(--sh-xl);
}

.hero-stat-card{
  position:absolute;
  background:rgba(255,255,255,.96);backdrop-filter:blur(16px);
  border:1px solid var(--border-light);border-radius:var(--r-lg);
  padding:var(--sp-4) var(--sp-5);box-shadow:var(--sh-md);
  display:flex;align-items:center;gap:var(--sp-3);
}
.hero-stat-card.card-1{bottom:10%;left:-8%;animation:floatCard 4s ease-in-out infinite}
.hero-stat-card.card-2{top:8%;right:-5%;animation:floatCard 4s ease-in-out infinite 2s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.hero-stat-card .icon-wrap{
  width:40px;height:40px;border-radius:var(--r-md);
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  display:grid;place-items:center;color:#fff;flex-shrink:0;
}
.hero-stat-card .icon-wrap svg{width:20px;height:20px}
.hero-stat-card strong{
  display:block;font-family:var(--font-display);
  font-size:1.1rem;font-weight:800;color:var(--text-900);line-height:1;
}
.hero-stat-card span{font-size:.78rem;color:var(--text-300)}

/* inner hero */
.hero.inner{padding:90px 0 64px}
.hero.inner::before{
  background:
    radial-gradient(ellipse 700px 350px at 100% 0%,rgba(0,88,152,.08),transparent 55%),
    radial-gradient(ellipse 500px 280px at 0% 100%,rgba(8,168,80,.06),transparent 55%);
}
.hero.inner h1{
  font-size:clamp(2rem,4.2vw,3rem);
  background:linear-gradient(135deg,var(--text-900) 0%,var(--blue-600) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.hero.inner .hero-grid{grid-template-columns:1.2fr 1fr}
@media(max-width:960px){.hero.inner .hero-grid{grid-template-columns:1fr}}

.hero-meta{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:var(--sp-6);margin-top:var(--sp-10);
  padding-top:var(--sp-8);border-top:1px solid var(--border-light);
}
@media(max-width:580px){.hero-meta{grid-template-columns:1fr;gap:var(--sp-4)}}
.hero-meta .mono{color:var(--green-600);font-weight:700;font-size:.73rem;letter-spacing:.12em;text-transform:uppercase}
.hero-meta strong{display:block;color:var(--text-900);font-size:1.05rem;margin-top:4px}
.hero-meta span{color:var(--text-300);font-size:.86rem}

.hero-illus img{width:100%;max-width:540px;margin-left:auto;border-radius:var(--r-2xl)}

/* ================================================================
   7. STATS BAR
   ================================================================ */
.stats,.stats-bar{
  display:grid;grid-template-columns:repeat(4,1fr);
  border:1px solid var(--border-light);border-radius:var(--r-xl);
  background:var(--surface-white);overflow:hidden;box-shadow:var(--sh-md);
}
.stat,.stat-cell{
  padding:40px 28px;border-right:1px solid var(--border-light);
  text-align:center;position:relative;transition:background var(--t-fast);
}
.stat:last-child,.stat-cell:last-child{border-right:none}
.stat::before,.stat-cell::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue-600),var(--green-500));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-slow) var(--ease);
}
.stat:hover,.stat-cell:hover{background:var(--blue-50)}
.stat:hover::before,.stat-cell:hover::before{transform:scaleX(1)}

.stat-value{
  font-family:var(--font-display);
  font-size:clamp(2.4rem,4vw,3.2rem);
  font-weight:800;letter-spacing:-.03em;line-height:1;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-400));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-value .unit{
  font-size:1.6rem;margin-left:3px;
  background:linear-gradient(135deg,var(--green-600),var(--green-400));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.stat-label{color:var(--text-300);font-size:.9rem;margin-top:12px}

@media(max-width:860px){
  .stats,.stats-bar{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2n),.stat-cell:nth-child(2n){border-right:none}
  .stat:nth-child(-n+2),.stat-cell:nth-child(-n+2){border-bottom:1px solid var(--border-light)}
}

/* ================================================================
   8. CARDS
   ================================================================ */
.card{
  display:block;background:var(--surface-white);
  border:1px solid var(--border-light);border-radius:var(--r-xl);
  padding:32px;position:relative;color:inherit;text-decoration:none;
  transition:border-color var(--t-base),transform var(--t-base) var(--ease),
             box-shadow var(--t-base) var(--ease);
  box-shadow:var(--sh-xs);overflow:hidden;
}
.card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue-600) 0%,var(--green-500) 100%);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-slow) var(--ease);
}
.card:hover{
  border-color:rgba(0,88,152,.20);transform:translateY(-6px);
  box-shadow:var(--sh-lg);text-decoration:none;color:inherit;
}
.card:hover::before{transform:scaleX(1)}

.card-icon{
  width:56px;height:56px;border-radius:14px;
  display:grid;place-items:center;margin-bottom:22px;
  background:var(--blue-50);color:var(--blue-600);
  box-shadow:0 4px 12px rgba(0,88,152,.12);
  transition:all var(--t-base) var(--ease-spr);
}
.card-icon.green{background:var(--green-50);color:var(--green-600);box-shadow:0 4px 12px rgba(8,168,80,.12)}
.card-icon svg{width:26px;height:26px}
.card:hover .card-icon{
  background:linear-gradient(135deg,var(--blue-600),var(--blue-400));
  color:#fff;box-shadow:0 8px 24px rgba(0,88,152,.30);
  transform:scale(1.08) rotate(-3deg);
}
.card:hover .card-icon.green{
  background:linear-gradient(135deg,var(--green-500),var(--green-700));
  color:#fff;box-shadow:0 8px 24px rgba(8,168,80,.28);
}
.card h3{margin-bottom:10px;color:var(--text-900);font-size:1.12rem}
.card p{color:var(--text-500);font-size:.94rem;margin-bottom:20px}
.card .card-link{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--blue-600);font-size:.90rem;font-weight:600;
  transition:gap var(--t-base) var(--ease-spr);
}
.card:hover .card-link{gap:14px}

.tag-row{display:flex;flex-wrap:wrap;gap:var(--sp-2);margin-top:14px}
.tag{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.06em;
  padding:4px 10px;background:var(--chrome-100);border:1px solid var(--chrome-200);
  border-radius:var(--r-full);color:var(--text-300);text-transform:uppercase;
}
.tag.blue {background:var(--blue-50); border-color:rgba(0,88,152,.20); color:var(--blue-600)}
.tag.green{background:var(--green-50);border-color:rgba(8,168,80,.20); color:var(--green-700)}

/* ================================================================
   9. FEATURE LISTS
   ================================================================ */
.feature-list{list-style:none}
.feature-list li{
  position:relative;padding:13px 0 13px 36px;
  color:var(--text-700);border-top:1px solid var(--border-light);font-size:.96rem;
}
.feature-list li:first-child{border-top:none}
.feature-list li::before{
  content:"";position:absolute;left:0;top:22px;
  width:20px;height:1.5px;background:var(--green-500);border-radius:2px;
}
.feature-list.check li{padding-left:38px}
.feature-list.check li::before{
  content:"✓";width:22px;height:22px;
  background:linear-gradient(135deg,var(--green-500),var(--green-700));
  color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.68rem;font-weight:900;top:14px;
  box-shadow:0 2px 8px rgba(8,168,80,.22);
}
.feature-list.cross li{padding-left:38px}
.feature-list.cross li::before{
  content:"✕";width:22px;height:22px;
  background:rgba(220,53,69,.08);border:1.5px solid rgba(220,53,69,.35);
  color:#C83E4D;border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-size:.7rem;font-weight:800;top:14px;
}
.section.dark .feature-list li{color:rgba(255,255,255,.88);border-top-color:rgba(255,255,255,.10)}
.section.dark .feature-list.check li::before{background:linear-gradient(135deg,var(--green-400),var(--green-600))}

/* ================================================================
   10. STEPS
   ================================================================ */
.steps{counter-reset:step}
.step{
  display:grid;grid-template-columns:96px 1fr;
  gap:var(--sp-6);padding:32px 0;border-top:1px solid var(--border-light);align-items:start;
}
.step:last-child{border-bottom:1px solid var(--border-light)}
.step-num{
  font-family:var(--font-mono);font-size:.74rem;font-weight:700;
  color:var(--green-600);letter-spacing:.14em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;padding-top:4px;
}
.step-num::before{
  content:"";width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--green-50),var(--green-100));
  border:2px solid var(--green-500);flex-shrink:0;
  box-shadow:0 3px 10px rgba(8,168,80,.16);display:block;
}
.step h3{margin-bottom:8px;color:var(--text-900)}
.step p{color:var(--text-500);margin-bottom:0}
@media(max-width:580px){.step{grid-template-columns:1fr;gap:10px}.step-num{padding-top:0}}

/* ================================================================
   11. CTA BAND
   ================================================================ */
.cta-band{
  position:relative;
  background:
    radial-gradient(ellipse 900px 500px at 100% -10%,rgba(8,168,80,.22),transparent 55%),
    radial-gradient(ellipse 700px 400px at 0% 110%,  rgba(0,88,152,.20),transparent 55%),
    linear-gradient(135deg,var(--blue-900) 0%,var(--blue-800) 40%,var(--blue-700) 100%);
  color:#fff;border-radius:var(--r-2xl);
  padding:clamp(48px,7vw,80px) clamp(32px,5vw,64px);
  text-align:center;overflow:hidden;box-shadow:var(--sh-xl);
}
.cta-band::before{
  content:"";position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:24px 24px;pointer-events:none;
}
.cta-band::after{
  content:"";position:absolute;right:5%;top:50%;transform:translateY(-50%);
  width:140px;height:140px;
  background:url("img/cta-emblem.svg") center/contain no-repeat;
  opacity:.14;pointer-events:none;
}
.cta-band>*{position:relative;z-index:1}
.cta-band h2{
  color:#fff;max-width:22ch;margin:0 auto var(--sp-4);
  font-size:clamp(1.7rem,3.5vw,2.6rem);
}
.cta-band .lead{
  color:rgba(255,255,255,.88);max-width:58ch;
  margin:0 auto var(--sp-8);font-size:1.08rem;
}
.cta-band .btn-row{display:flex;gap:var(--sp-4);justify-content:center;flex-wrap:wrap}

/* ================================================================
   12. QUOTE / TESTIMONIAL
   ================================================================ */
.quote{
  background:var(--surface-white);border:1px solid var(--border-light);
  border-radius:var(--r-xl);padding:36px;position:relative;
  box-shadow:var(--sh-sm);transition:box-shadow var(--t-base),transform var(--t-base) var(--ease);
}
.quote::before{
  content:"\201C";position:absolute;top:-8px;left:24px;
  font-family:Georgia,serif;font-size:6rem;line-height:1;
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;opacity:.48;
}
.quote:hover{box-shadow:var(--sh-lg);transform:translateY(-4px)}
.quote p{color:var(--text-700);font-size:1rem;line-height:1.72;margin:var(--sp-4) 0 var(--sp-6)}
.quote-author{
  display:flex;align-items:center;gap:var(--sp-3);
  border-top:1px solid var(--border-light);padding-top:var(--sp-4);
}
.quote-author .avatar{
  width:46px;height:46px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  display:grid;place-items:center;color:#fff;
  font-weight:700;font-size:.92rem;flex-shrink:0;
  box-shadow:0 3px 10px rgba(0,88,152,.26);
}
.quote-author strong{display:block;color:var(--text-900);font-size:.94rem}
.quote-author span{color:var(--text-300);font-size:.82rem}
.stars{color:var(--green-500);letter-spacing:2px;font-size:.85rem;margin-bottom:4px}

.quote-band{
  background:linear-gradient(135deg,var(--blue-50),var(--green-50));
  border:1px solid var(--border-light);border-radius:var(--r-2xl);
  padding:clamp(40px,6vw,64px);text-align:center;
}
.quote-band p{
  font-family:var(--font-display);font-size:clamp(1.4rem,2.6vw,2rem);
  font-weight:600;line-height:1.42;color:var(--text-900);
  max-width:780px;margin:0 auto;
}
.quote-band .author{display:block;margin-top:var(--sp-6);color:var(--text-300);font-size:.92rem;font-weight:500}

/* ================================================================
   13. PRICING
   ================================================================ */
.pricing-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;
}
@media(max-width:1080px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:580px) {.pricing-grid{grid-template-columns:1fr}}

.price-card{
  background:var(--surface-white);border:1.5px solid var(--border-light);
  border-radius:var(--r-xl);padding:32px 28px;
  display:flex;flex-direction:column;position:relative;
  transition:all var(--t-base) var(--ease);box-shadow:var(--sh-xs);overflow:hidden;
}
.price-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--blue-600),var(--green-500));
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--t-slow) var(--ease);
}
.price-card:hover{border-color:rgba(0,88,152,.22);transform:translateY(-6px);box-shadow:var(--sh-lg)}
.price-card:hover::before{transform:scaleX(1)}
.price-card.featured{
  border-color:var(--green-500);border-width:2px;
  background:linear-gradient(180deg,var(--green-50) 0%,var(--surface-white) 40%);
  padding-top:54px;
}
.price-card.featured::before{background:linear-gradient(90deg,var(--green-500),var(--green-300));transform:scaleX(1)}
.price-card.featured::after{
  content:"\2B50  Most Popular";position:absolute;top:0;left:0;right:0;
  background:linear-gradient(135deg,var(--green-600),var(--green-500));
  color:#fff;padding:9px 16px;
  font-size:.72rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;
  text-align:center;
  box-shadow:0 3px 12px rgba(8,168,80,.28);
}
.price-card .price-tag{
  font-family:var(--font-mono);font-size:.68rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--green-600);font-weight:600;
}
.price-card h3{font-size:1.18rem;margin:8px 0 4px;color:var(--text-900)}
.price-card .price-sub{color:var(--text-300);font-size:.84rem;margin-bottom:24px}
.price-amt{
  font-family:var(--font-display);font-size:2.4rem;font-weight:800;
  letter-spacing:-.03em;line-height:1;
  background:linear-gradient(135deg,var(--blue-600),var(--blue-400));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.price-amt .currency{font-size:.9rem;-webkit-text-fill-color:var(--text-300);margin-right:4px}
.price-amt .per{font-size:.8rem;-webkit-text-fill-color:var(--text-300);margin-left:4px}
.price-card .feature-list{margin:24px 0;flex-grow:1}
.price-card .feature-list li{font-size:.88rem;padding:10px 0 10px 36px}
.price-card .btn{width:100%;justify-content:center}
.discount-pill{
  display:inline-block;font-family:var(--font-mono);font-size:.70rem;
  background:var(--green-50);color:var(--green-700);padding:3px 10px;
  border-radius:var(--r-sm);font-weight:700;border:1px solid rgba(8,168,80,.22);
}

/* ================================================================
   14. CREDENTIALS ROW
   ================================================================ */
.cred-row{
  display:grid;grid-template-columns:repeat(6,1fr);
  border:1px solid var(--border-light);border-radius:var(--r-xl);
  background:var(--surface-white);overflow:hidden;box-shadow:var(--sh-sm);
}
@media(max-width:900px){.cred-row{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.cred-row{grid-template-columns:repeat(2,1fr)}}
.cred{
  padding:28px 16px;border-right:1px solid var(--border-light);
  text-align:center;font-family:var(--font-mono);font-size:.80rem;
  color:var(--text-900);font-weight:600;
  display:flex;flex-direction:column;align-items:center;gap:12px;
  transition:background var(--t-fast);cursor:default;
}
.cred:hover{background:var(--blue-50)}
.cred:last-child{border-right:none}
.cred .cred-mark{
  width:46px;height:46px;border-radius:var(--r-md);
  background:var(--blue-50);border:1.5px solid rgba(0,88,152,.22);
  color:var(--blue-600);display:grid;place-items:center;
  font-size:.68rem;font-weight:800;letter-spacing:.04em;
  box-shadow:0 2px 8px rgba(0,88,152,.10);
  transition:all var(--t-base) var(--ease-spr);
}
.cred:hover .cred-mark{
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  color:#fff;border-color:transparent;transform:scale(1.08);
}
.cred:nth-child(2n) .cred-mark{
  background:var(--green-50);border-color:rgba(8,168,80,.22);color:var(--green-700);
}
.cred:nth-child(2n):hover .cred-mark{
  background:linear-gradient(135deg,var(--green-500),var(--green-700));
  color:#fff;border-color:transparent;
}

/* ================================================================
   15. COMPARE TABLE
   ================================================================ */
.compare-table{
  width:100%;border-collapse:collapse;font-size:.92rem;
  border:1px solid var(--border-light);border-radius:var(--r-xl);
  overflow:hidden;background:var(--surface-white);box-shadow:var(--sh-sm);
}
.compare-table th,.compare-table td{
  padding:15px 20px;text-align:left;border-bottom:1px solid var(--border-light);color:var(--text-700);
}
.compare-table th{
  background:linear-gradient(90deg,var(--blue-50),var(--green-50));
  color:var(--blue-700);font-weight:700;font-family:var(--font-mono);
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
}
.compare-table tr:last-child td{border-bottom:none}
.compare-table tr:hover td{background:var(--blue-50)}
.compare-table td.num{font-family:var(--font-mono);color:var(--blue-600);font-weight:700}
.compare-table .highlight{color:var(--blue-600);font-weight:700}

/* ================================================================
   16. FORMS
   ================================================================ */
.form-row{display:grid;gap:var(--sp-4)}
.form-row.two{grid-template-columns:1fr 1fr}
@media(max-width:580px){.form-row.two{grid-template-columns:1fr}}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:.84rem;font-weight:600;color:var(--text-700);letter-spacing:-.01em}
.field input,.field textarea,.field select{
  background:var(--surface-white);border:1.5px solid var(--border-medium);
  color:var(--text-900);padding:13px 16px;border-radius:var(--r-md);
  font-family:var(--font-sans);font-size:.95rem;outline:none;
  transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
.field input:focus,.field textarea:focus,.field select:focus{
  border-color:var(--blue-600);box-shadow:0 0 0 4px rgba(0,88,152,.12);
}
.field input:hover,.field textarea:hover,.field select:hover{border-color:var(--border-strong)}
.field textarea{min-height:140px;resize:vertical}

/* ================================================================
   17. FOOTER
   ================================================================ */
.site-footer{
  background:
    radial-gradient(ellipse 900px 500px at 100% 0%,  rgba(8,168,80,.10),transparent 55%),
    radial-gradient(ellipse 700px 400px at 0% 100%,  rgba(0,88,152,.15),transparent 55%),
    var(--blue-950);
  color:rgba(255,255,255,.78);padding:88px 0 36px;position:relative;overflow:hidden;
}
.site-footer::before{
  content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,
    var(--blue-500) 0%,var(--green-400) 30%,var(--green-300) 50%,
    var(--green-400) 70%,var(--blue-400) 100%);
}

img.footer-logo{
  height:80px !important;width:auto !important;object-fit:contain;
  background:rgba(255,255,255,.96);border-radius:var(--r-lg);
  padding:8px 14px;box-shadow:0 6px 24px rgba(0,0,0,.22);
  transition:transform var(--t-base) var(--ease-spr),box-shadow var(--t-base);
}
.footer-about .brand:hover img.footer-logo{transform:scale(1.05);box-shadow:0 12px 32px rgba(0,0,0,.30)}
.footer-about .brand img{height:auto}

.footer-grid{
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:clamp(32px,5vw,56px);
}
@media(max-width:860px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr;gap:32px}}
.footer-grid h4{
  font-family:var(--font-mono);font-size:.70rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--green-300);margin-bottom:20px;font-weight:700;
}
.footer-grid ul{list-style:none}
.footer-grid li{margin-bottom:11px}
.footer-grid a{
  color:rgba(255,255,255,.68);font-size:.91rem;
  transition:color var(--t-fast),padding-left var(--t-fast) var(--ease);
}
.footer-grid a:hover{color:#fff;padding-left:5px}
.footer-about p{
  color:rgba(255,255,255,.62);font-size:.90rem;
  max-width:34ch;margin-top:var(--sp-4);line-height:1.65;
}
.footer-contact-item{
  display:flex;align-items:flex-start;gap:var(--sp-3);
  margin-bottom:var(--sp-3);font-size:.90rem;color:rgba(255,255,255,.68);
}
.footer-contact-item svg{width:16px;height:16px;flex-shrink:0;margin-top:3px;color:var(--green-400)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.10);margin-top:64px;padding-top:28px;
  display:flex;justify-content:space-between;flex-wrap:wrap;
  gap:var(--sp-4);font-size:.83rem;color:rgba(255,255,255,.44);
}
.footer-bottom a{color:rgba(255,255,255,.62)}
.footer-bottom a:hover{color:var(--green-300);padding-left:0}
.socials{display:flex;gap:var(--sp-2)}
.socials a{
  width:38px;height:38px;border:1px solid rgba(255,255,255,.16);
  border-radius:var(--r-md);display:grid;place-items:center;
  color:rgba(255,255,255,.70);transition:all var(--t-base) var(--ease-spr);
}
.socials a:hover{
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  border-color:transparent;color:#fff;
  transform:translateY(-2px);box-shadow:0 6px 16px rgba(0,88,152,.28);
}
.socials svg{width:16px;height:16px}

/* ================================================================
   18. MISC & UTILITIES
   ================================================================ */
.crumbs{font-size:.82rem;color:var(--text-300);margin-bottom:var(--sp-4)}
.crumbs a{color:var(--text-300)}
.crumbs a:hover{color:var(--blue-600)}
.crumbs .sep{margin:0 var(--sp-2);color:var(--chrome-300)}

.divider{
  height:1px;
  background:linear-gradient(90deg,transparent,var(--border-medium),transparent);
  margin:var(--sp-12) 0;
}

.illus-frame{
  background:linear-gradient(135deg,var(--blue-50),var(--green-50));
  border:1px solid var(--border-light);border-radius:var(--r-2xl);
  overflow:hidden;padding:clamp(24px,4vw,44px);box-shadow:var(--sh-md);
}

/* ================================================================
   19. SCROLL REVEAL & ANIMATIONS
   ================================================================ */
.scroll-fade{
  opacity:0;transform:translateY(22px);
  transition:opacity var(--t-slow) var(--ease),transform var(--t-slow) var(--ease);
}
.scroll-fade.in{opacity:1;transform:none}

.stagger>*{transition-delay:calc(var(--i,0) * 60ms)}
.stagger>*:nth-child(1){--i:0}.stagger>*:nth-child(2){--i:1}
.stagger>*:nth-child(3){--i:2}.stagger>*:nth-child(4){--i:3}
.stagger>*:nth-child(5){--i:4}.stagger>*:nth-child(6){--i:5}

/* ================================================================
   20. UTILITY SPACING
   ================================================================ */
.mt-0{margin-top:0 !important}.mt-2{margin-top:var(--sp-2) !important}
.mt-4{margin-top:var(--sp-4) !important}.mt-6{margin-top:var(--sp-6) !important}
.mt-8{margin-top:var(--sp-8) !important}.mt-10{margin-top:var(--sp-10)!important}
.mb-0{margin-bottom:0 !important}.mb-2{margin-bottom:var(--sp-2) !important}
.mb-4{margin-bottom:var(--sp-4) !important}.mb-6{margin-bottom:var(--sp-6) !important}

/* ================================================================
   21. RESPONSIVE POLISH
   ================================================================ */
@media(max-width:960px){
  img.nav-logo{height:54px !important}
  img.footer-logo{height:68px !important}
  .hero-stat-card{display:none}
  .cta-band::after{display:none}
  /* Prevent hero visual with absolute-positioned stat cards from creating overflow */
  .hero-visual{overflow:hidden}
  /* Ensure header never creates horizontal scroll */
  .site-header{max-width:100vw;overflow:hidden}
  .nav{overflow:hidden}
}
@media(max-width:600px){
  img.nav-logo{height:46px !important}
  img.footer-logo{height:60px !important}
  .nav{height:72px}
  .mobile-sheet{inset:72px 0 0 0}
  /* Compact nav-cta on small screens — only toggle visible */
  .nav-cta{gap:var(--sp-2)}
  /* Prevent any wide element causing horizontal bleed */
  .container{padding-left:16px;padding-right:16px}
  .section{padding-left:0;padding-right:0}
  /* Prevent cta-band from bleeding */
  .cta-band{border-radius:var(--r-lg)}
  /* Stats bar on very small screens */
  .stats,.stats-bar{grid-template-columns:1fr 1fr}
}

@media print{
  .site-header,.site-footer,.cta-band,
  .hero::before,.hero::after{display:none}
  body{font-size:12pt;color:#000}
  a{color:#000}
}

/* ================================================================
   22. BACKWARDS COMPATIBILITY & MISSING ALIASES
   ================================================================ */

/* "canvas" was the old subtle-background class */
.section.canvas { background: var(--surface-light); }

/* Gradient accent heading span */
.text-green { color: var(--green-600) !important; }

/* Script font (used in some pages) — Pacifico loaded via <link> in HTML head */
.script {
  font-family: "Pacifico","Brush Script MT",cursive;
  font-style: italic; font-weight: 400; color: var(--blue-600); letter-spacing: 0;
}

/* Dot pattern bg used in some pages */
.section.dark .btn-ghost {
  background: rgba(255,255,255,.10);color:#fff;border-color:rgba(255,255,255,.25);
}
.section.dark .btn-ghost:hover{border-color:var(--green-400);color:var(--green-300);background:rgba(255,255,255,.14)}

/* Hero badge (used in premium hero variant) */
.hero-badge{
  display:inline-flex;align-items:center;gap:var(--sp-3);
  background:linear-gradient(135deg,var(--blue-50),var(--green-50));
  border:1px solid rgba(0,88,152,.14);border-radius:var(--r-full);
  padding:7px 16px 7px 10px;margin-bottom:var(--sp-6);
}
.hero-badge .dot{
  width:28px;height:28px;border-radius:50%;
  background:linear-gradient(135deg,var(--blue-600),var(--green-500));
  display:grid;place-items:center;flex-shrink:0;
}
.hero-badge span{
  font-family:var(--font-mono);font-size:.70rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--blue-700);font-weight:600;
}

/* ================================================================
   23. EYEBROW PLAIN VARIANT (restored)
   ================================================================ */
.eyebrow.plain {
  background: transparent;
  border-color: transparent;
  padding-left: 0;
  color: var(--text-300);
  box-shadow: none;
}
.eyebrow.plain::before { background: var(--green-500); }

/* Overflow protection on split layouts */
.split > * { min-width: 0; overflow-wrap: break-word; word-break: break-word; }
.illus-frame { overflow: hidden; }
.hero-illus { overflow: hidden; min-width: 0; }

/* Independence section — ensure cross-list stays inside box */
.feature-list.cross { overflow: hidden; }
.feature-list li { overflow-wrap: break-word; word-break: break-word; }

/* Eyebrow inside hero illus frame — clip it */
.hero-illus .illus-frame img { max-width: 100%; }
