*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --navy:#1a3272;
  --navy-mid:#243d8a;
  --navy-light:#e8ecf7;
  --cyan:#00aeef;
  --cyan-light:#e0f6fd;
  --cyan-dark:#0090cc;
  --slate:#4a5568;
  --slate-light:#718096;
  --off-white:#f7f9fc;
  --white:#ffffff;
  --border:#d8e0ee;
  --text:#111827;
}

html{scroll-behavior:smooth}

body{
  font-family:'DM Sans',Calibri,sans-serif;
  color:var(--text);
  background:var(--white);
  font-size:16px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{font-family:'Syne',sans-serif}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:100;
  background:rgba(255,255,255,0.96);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
  padding:0 5%;
}
.nav-inner{
  max-width:1140px;margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
}
.nav-logo-img{display:flex;align-items:center;text-decoration:none;flex-shrink:0}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center}
.nav-links a{font-size:14px;font-weight:500;color:var(--slate);text-decoration:none;transition:color 0.2s}
.nav-links a:hover{color:var(--navy)}
.nav-cta{background:var(--navy)!important;color:var(--white)!important;padding:9px 20px;border-radius:6px;font-size:14px!important;font-weight:500!important;transition:background 0.2s!important}
.nav-cta:hover{background:var(--navy-mid)!important}

/* Dropdown */
.has-drop{position:relative}
.dropdown{
  display:none;position:absolute;top:100%;left:0;
  padding-top:10px;min-width:220px;z-index:200;
}
.dropdown-inner{
  background:var(--white);border:1px solid var(--border);
  border-radius:10px;list-style:none;padding:8px 0;
  box-shadow:0 8px 32px rgba(26,50,114,0.12);
  display:block;
}
.has-drop:hover .dropdown{display:block}
.dropdown li a{
  display:block;padding:9px 18px;
  font-size:13px;color:var(--slate);
  text-decoration:none;transition:background 0.15s,color 0.15s;
}
.dropdown li a:hover{background:var(--cyan-light);color:var(--navy)}
.nav-drop-toggle{cursor:pointer}

/* Mobile toggle */
.nav-toggle{
  display:none;flex-direction:column;gap:5px;
  background:none;border:none;cursor:pointer;padding:4px;
}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px}

/* ── PAGE HERO (inner pages) ── */
.page-hero{
  background:var(--navy);
  padding:60px 5% 56px;
  position:relative;overflow:hidden;
}
.page-hero::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(0,174,239,0.15) 0%,transparent 70%);
  pointer-events:none;
}
.page-hero-inner{max-width:1140px;margin:0 auto;position:relative;z-index:1}
.page-hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,174,239,0.15);border:1px solid rgba(0,174,239,0.35);
  border-radius:100px;padding:5px 14px;margin-bottom:20px;
  font-size:12px;color:#7de4ff;font-weight:500;letter-spacing:0.3px;
}
.page-hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--cyan);display:block;
}
.page-hero h1{
  font-size:clamp(30px,4vw,50px);font-weight:700;
  color:var(--white);line-height:1.1;margin-bottom:16px;
  letter-spacing:-0.3px;
}
.page-hero h1 em{font-style:normal;color:var(--cyan)}
.page-hero-sub{
  font-size:17px;color:rgba(255,255,255,0.65);
  max-width:600px;line-height:1.75;font-weight:300;
}

/* ── SECTIONS ── */
.section{padding:72px 5%}
.section-inner{max-width:1140px;margin:0 auto}
.section-light{background:var(--white)}
.section-tinted{background:var(--off-white)}
.section-navy{background:var(--navy)}

.eyebrow{
  font-size:11px;text-transform:uppercase;letter-spacing:1.5px;
  color:var(--cyan);font-weight:600;margin-bottom:10px;
}
.section-navy .eyebrow{color:var(--cyan)}

.section-title{
  font-size:clamp(22px,3vw,38px);font-weight:600;
  color:var(--navy);line-height:1.25;margin-bottom:14px;
  letter-spacing:-0.2px;
}
.section-navy .section-title{color:var(--white)}

.section-lead{
  font-size:17px;color:var(--slate);line-height:1.75;
  max-width:640px;font-weight:300;margin-bottom:48px;
}
.section-navy .section-lead{color:rgba(255,255,255,0.65)}

/* ── TWO-COL LAYOUT ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
.two-col-wide{display:grid;grid-template-columns:3fr 2fr;gap:64px;align-items:start}

/* ── PROSE CONTENT ── */
.prose h2{
  font-family:'Syne',sans-serif;font-size:22px;font-weight:600;
  color:var(--navy);margin:36px 0 12px;letter-spacing:0.2px;line-height:1.3;
}
.prose h3{
  font-family:'Syne',sans-serif;font-size:17px;font-weight:600;
  color:var(--navy);margin:28px 0 10px;letter-spacing:0.1px;line-height:1.35;
}
.prose p{color:var(--slate);line-height:1.8;margin-bottom:16px;font-weight:300}
.prose ul,.prose ol{padding-left:20px;margin-bottom:16px}
.prose li{color:var(--slate);line-height:1.8;margin-bottom:6px;font-weight:300}
.prose strong{color:var(--text);font-weight:500}

/* ── FEATURE LIST ── */
.feature-list{list-style:none;padding:0;display:flex;flex-direction:column;gap:14px}
.feature-list li{
  display:flex;gap:12px;align-items:flex-start;
  font-size:15px;color:var(--slate);font-weight:300;line-height:1.65;
}
.feature-list li::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:var(--cyan);flex-shrink:0;margin-top:7px;
}

/* ── CARDS ── */
.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px}

.card{
  background:var(--white);border:1px solid var(--border);
  border-radius:12px;padding:28px 24px;
  transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;
  position:relative;overflow:hidden;
}
.card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--cyan);transform:scaleX(0);transition:transform 0.25s;
}
.card:hover{border-color:var(--cyan);transform:translateY(-3px);box-shadow:0 12px 32px rgba(15,42,74,0.08)}
.card:hover::before{transform:scaleX(1)}

.card-icon{
  width:42px;height:42px;background:var(--cyan-light);
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  margin-bottom:16px;
}
.card-icon svg{width:20px;height:20px;stroke:var(--cyan-dark);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

.card h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px}
.card p{font-size:14px;color:var(--slate);line-height:1.65;font-weight:300}

/* ── STAT CARDS ── */
.stats-row{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.stat-card{
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);
  border-radius:10px;padding:20px 24px;flex:1;min-width:140px;
}
.stat-num{font-family:'Syne',sans-serif;font-size:28px;font-weight:700;color:var(--white);line-height:1}
.stat-label{font-size:12px;color:rgba(255,255,255,0.5);margin-top:4px;font-weight:300}

/* ── COMPARISON TABLE ── */
.compare-wrap{overflow-x:auto}
.compare-table{width:100%;border-collapse:collapse;font-size:14px}
.compare-table th{
  background:var(--navy);color:var(--white);
  padding:14px 16px;text-align:left;
  font-family:'Syne',sans-serif;font-weight:600;font-size:13px;
}
.compare-table th:first-child{border-radius:8px 0 0 0}
.compare-table th:last-child{border-radius:0 8px 0 0}
.compare-table td{
  padding:12px 16px;border-bottom:1px solid var(--border);
  color:var(--slate);font-weight:300;vertical-align:top;
}
.compare-table tr:last-child td{border-bottom:none}
.compare-table tr:nth-child(even) td{background:var(--off-white)}
.compare-table td:first-child{font-weight:500;color:var(--text)}
.compare-table .highlight{background:var(--cyan-light)!important}
.compare-table .tick{color:var(--cyan);font-weight:700}

/* ── HIGHLIGHT BOX ── */
.highlight-box{
  background:var(--cyan-light);border:1px solid #99daf5;
  border-radius:12px;padding:28px 32px;
}
.highlight-box h3{font-size:17px;font-weight:700;color:var(--navy);margin-bottom:10px}
.highlight-box p,.highlight-box li{font-size:15px;color:var(--slate);font-weight:300;line-height:1.75}
.highlight-box ul{padding-left:18px}

/* ── DARK PANEL ── */
.dark-panel{
  background:rgba(255,255,255,0.05);
  border:1px solid rgba(255,255,255,0.1);
  border-radius:14px;padding:32px 28px;
}
.dark-panel h3{font-size:18px;font-weight:600;color:var(--white);margin-bottom:14px}
.dark-panel p{font-size:14px;color:rgba(255,255,255,0.6);line-height:1.75;font-weight:300}
.dark-panel ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:10px}
.dark-panel li{font-size:14px;color:rgba(255,255,255,0.6);font-weight:300;display:flex;gap:10px;align-items:flex-start}
.dark-panel li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--cyan);flex-shrink:0;margin-top:7px}

/* ── STEPS ── */
.steps{display:flex;flex-direction:column;gap:28px}
.step{display:flex;gap:20px;align-items:flex-start}
.step-num{
  width:36px;height:36px;border-radius:50%;
  background:var(--cyan);color:var(--white);
  font-family:'Syne',sans-serif;font-size:15px;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.step-body h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:4px}
.step-body p{font-size:14px;color:var(--slate);font-weight:300;line-height:1.65}
.section-navy .step-body h4{color:var(--white)}
.section-navy .step-body p{color:rgba(255,255,255,0.6)}

/* ── CTA STRIP ── */
.cta-strip{
  background:var(--cyan-light);
  border-top:1px solid #99daf5;border-bottom:1px solid #99daf5;
  padding:52px 5%;
}
.cta-inner{
  max-width:1140px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;
  gap:32px;flex-wrap:wrap;
}
.cta-text h2{font-size:24px;font-weight:700;color:var(--navy);margin-bottom:6px}
.cta-text p{font-size:15px;color:var(--slate);font-weight:300}
.btn-primary{
  background:var(--cyan);color:var(--white);
  padding:13px 28px;border-radius:7px;text-decoration:none;
  font-weight:500;font-size:15px;
  transition:background 0.2s,transform 0.15s;display:inline-block;
}
.btn-primary:hover{background:var(--cyan-dark);transform:translateY(-1px)}
.btn-navy{
  background:var(--navy);color:var(--white);
  padding:13px 28px;border-radius:7px;text-decoration:none;
  font-weight:500;font-size:15px;white-space:nowrap;
  transition:background 0.2s,transform 0.15s;display:inline-block;
}
.btn-navy:hover{background:var(--navy-mid);transform:translateY(-1px)}
.btn-ghost{
  background:transparent;color:var(--white);
  padding:13px 28px;border-radius:7px;text-decoration:none;
  font-weight:500;font-size:15px;white-space:nowrap;
  border:2px solid rgba(255,255,255,0.6);
  transition:background 0.2s,border-color 0.2s,transform 0.15s;display:inline-block;
}
.btn-ghost:hover{background:rgba(255,255,255,0.12);border-color:var(--white);transform:translateY(-1px)}

/* ── FOOTER ── */
footer{background:var(--navy);padding:52px 5% 32px;color:rgba(255,255,255,0.5)}
.footer-inner{max-width:1140px;margin:0 auto}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,0.08);
  margin-bottom:28px;
}
.footer-brand-img{margin-bottom:12px}
.footer-badges{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap}
.footer-desc{font-size:13px;line-height:1.7;font-weight:300;max-width:280px}
.footer-col h4{
  font-family:'Syne',sans-serif;font-size:12px;font-weight:600;
  color:var(--white);text-transform:uppercase;letter-spacing:0.8px;margin-bottom:16px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer-col ul a{font-size:13px;color:rgba(255,255,255,0.45);text-decoration:none;transition:color 0.2s;font-weight:300}
.footer-col ul a:hover{color:rgba(255,255,255,0.8)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:12px}
.footer-reg{font-size:12px;color:rgba(255,255,255,0.3);font-weight:300;line-height:1.6}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .two-col,.two-col-wide{grid-template-columns:1fr;gap:40px}
  .footer-top{grid-template-columns:1fr;gap:32px}
}
@media(max-width:768px){
  .nav-toggle{display:flex}
  .nav-links{
    display:none;flex-direction:column;gap:0;
    position:absolute;top:64px;left:0;right:0;
    background:var(--white);border-bottom:1px solid var(--border);
    padding:12px 5%;
  }
  .nav-links.open{display:flex}
  .nav-links li{width:100%;border-bottom:1px solid var(--border)}
  .nav-links li:last-child{border-bottom:none}
  .nav-links a{padding:12px 0;display:block}
  .dropdown{position:static;box-shadow:none;border:none;padding:0 0 0 16px}
  .has-drop:hover .dropdown{display:none}
  .has-drop.open .dropdown{display:block}
  .cards-grid{grid-template-columns:1fr}
  .stats-row{gap:12px}
}

/* Merged from style-additions.css */
/* ═══════════════════════════════════════════════════════════════════
   ADDITIONS TO style.css
   Add these rules to the bottom of your existing style.css
   ═══════════════════════════════════════════════════════════════════ */

/* ── LAYOUT FIX: prevent horizontal scroll pushing layout ── */
html, body {
  max-width: 100%;
  overflow-x: hidden; /* Use overflow-x:hidden on html AND body, not overflow:hidden */
}
/* Remove the old: body { overflow: hidden; } — that breaks scrolling on inner pages */

/* ── PORTAL BAR ────────────────────────────────────────────── */
.portal-bar {
  background: #0a1530;
  border-bottom: 1px solid rgba(0,174,239,0.15);
  padding: 0 5%;
  position: relative;
  z-index: 200; /* sits above everything */
}

.portal-bar-inner {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 36px;
  gap: 16px;
}

.portal-bar-label {
  font-size: 11px;
  font-weight: 500;
  color: rgba(255,255,255,0.3);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  white-space: nowrap;
}

.portal-bar-links {
  display: flex;
  align-items: center;
  gap: 8px;
}

.portal-link {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  text-decoration: none;
  padding: 4px 8px;
  border-radius: 4px;
  transition: color 0.15s, background 0.15s;
  white-space: nowrap;
}

.portal-link svg {
  width: 12px;
  height: 12px;
  flex-shrink: 0;
}

.portal-link:hover {
  color: rgba(255,255,255,0.9);
  background: rgba(255,255,255,0.06);
}

.portal-link-highlight {
  color: var(--cyan) !important;
  border: 1px solid rgba(0,174,239,0.3);
}

.portal-link-highlight:hover {
  background: rgba(0,174,239,0.1) !important;
  color: var(--cyan) !important;
}

.portal-divider {
  color: rgba(255,255,255,0.15);
  font-size: 12px;
  user-select: none;
}

/* Adjust nav top when portal bar is present */
nav {
  top: 36px !important; /* accounts for portal bar height */
}

/* ── BLOG INDEX ─────────────────────────────────────────────── */
.blog-featured-card {
  display: grid;
  grid-template-columns: 1fr;
  background: var(--navy-light);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 40px 48px;
  text-decoration: none;
  margin-bottom: 40px;
  transition: box-shadow 0.2s, border-color 0.2s;
  position: relative;
  overflow: hidden;
}

.blog-featured-card::before {
  content: 'Featured';
  position: absolute;
  top: 20px; right: 24px;
  font-size: 10px;
  font-weight: 700;
  color: var(--cyan-dark);
  text-transform: uppercase;
  letter-spacing: 1px;
  background: var(--cyan-light);
  padding: 3px 10px;
  border-radius: 100px;
}

.blog-featured-card:hover {
  box-shadow: 0 12px 40px rgba(26,50,114,0.1);
  border-color: var(--cyan);
}

.blog-featured-card h2 {
  font-family: 'Syne', 'Outfit', sans-serif;
  font-size: clamp(20px, 3vw, 32px);
  font-weight: 700;
  color: var(--navy);
  margin: 12px 0 12px;
  line-height: 1.2;
  letter-spacing: -0.3px;
}

.blog-featured-card p {
  font-size: 16px;
  color: var(--slate);
  line-height: 1.75;
  font-weight: 300;
  max-width: 640px;
  margin-bottom: 16px;
}

.blog-read-link {
  font-size: 14px;
  font-weight: 600;
  color: var(--cyan-dark);
}

.blog-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 24px;
}

.blog-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px 24px;
  text-decoration: none;
  display: block;
  transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}

.blog-card:hover {
  border-color: var(--cyan);
  transform: translateY(-3px);
  box-shadow: 0 10px 32px rgba(26,50,114,0.08);
}

.blog-card h3 {
  font-size: 17px;
  font-weight: 700;
  color: var(--navy);
  margin: 10px 0 8px;
  line-height: 1.35;
}

.blog-card p {
  font-size: 14px;
  color: var(--slate);
  line-height: 1.65;
  font-weight: 300;
}

.blog-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.blog-tag {
  display: inline-flex;
  padding: 2px 10px;
  background: var(--cyan-light);
  border: 1px solid rgba(0,174,239,0.25);
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  color: var(--cyan-dark);
  text-transform: capitalize;
  letter-spacing: 0.3px;
}

.blog-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.blog-date, .blog-author, .blog-reading {
  font-size: 12px;
  color: var(--slate-light);
  font-weight: 400;
}

.blog-date::before { content: '📅 '; font-size: 11px; }
.blog-author::before { content: '✍ '; font-size: 11px; }
.blog-reading::before { content: '⏱ '; font-size: 11px; }

.blog-empty {
  text-align: center;
  padding: 60px 0;
  color: var(--slate-light);
  font-size: 15px;
}

/* ── BLOG POST ──────────────────────────────────────────────── */
.blog-post-main {}

.blog-post-hero {
  background: var(--navy);
  padding: 60px 5% 56px;
  position: relative;
  overflow: hidden;
}

.blog-post-hero::before {
  content: '';
  position: absolute;
  top: -60px; right: -60px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(0,174,239,0.12) 0%, transparent 70%);
  pointer-events: none;
}

.blog-hero-inner {
  max-width: 800px;
  margin: 0 auto;
  position: relative; z-index: 1;
}

.blog-hero-inner h1 {
  font-family: 'Syne', 'Outfit', sans-serif;
  font-size: clamp(26px, 4vw, 44px);
  font-weight: 700;
  color: var(--white);
  line-height: 1.15;
  letter-spacing: -0.3px;
  margin: 16px 0 20px;
}

.blog-post-body {
  max-width: 1140px;
  margin: 0 auto;
  padding: 56px 5%;
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: 56px;
  align-items: start;
}

/* Blog content typography */
.blog-content h2 {
  font-family: 'Syne', 'Outfit', sans-serif;
  font-size: 22px;
  font-weight: 700;
  color: var(--navy);
  margin: 40px 0 14px;
  letter-spacing: -0.2px;
  line-height: 1.3;
}

.blog-content h3 {
  font-family: 'Syne', 'Outfit', sans-serif;
  font-size: 18px;
  font-weight: 600;
  color: var(--navy);
  margin: 28px 0 10px;
}

.blog-content p {
  font-size: 16px;
  color: var(--slate);
  line-height: 1.85;
  margin-bottom: 20px;
  font-weight: 300;
}

.blog-content a {
  color: var(--cyan-dark);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.blog-content ul, .blog-content ol {
  padding-left: 24px;
  margin-bottom: 20px;
}

.blog-content li {
  font-size: 16px;
  color: var(--slate);
  line-height: 1.8;
  margin-bottom: 8px;
  font-weight: 300;
}

.blog-content strong { color: var(--text); font-weight: 600; }

.blog-content blockquote {
  border-left: 3px solid var(--cyan);
  padding: 16px 24px;
  background: var(--cyan-light);
  border-radius: 0 8px 8px 0;
  margin: 24px 0;
  font-style: italic;
  color: var(--slate);
}

.blog-content code {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 13px;
  font-family: monospace;
}

.blog-content pre {
  background: var(--navy);
  color: rgba(255,255,255,0.85);
  border-radius: 10px;
  padding: 24px;
  overflow-x: auto;
  margin: 24px 0;
}

.blog-content pre code {
  background: none;
  border: none;
  padding: 0;
  color: inherit;
  font-size: 14px;
}

/* Blog sidebar */
.blog-sidebar {
  position: sticky;
  top: 120px; /* clears portal bar + nav */
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.blog-sidebar-card {
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 24px;
}

.blog-sidebar-card h3 {
  font-size: 15px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 10px;
}

.blog-sidebar-card p {
  font-size: 13px;
  color: var(--slate);
  line-height: 1.65;
  margin-bottom: 14px;
  font-weight: 300;
}

.blog-sidebar-list {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.blog-sidebar-list a {
  font-size: 13px;
  color: var(--slate);
  text-decoration: none;
  line-height: 1.5;
  transition: color 0.15s;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.blog-sidebar-list a::before {
  content: '→';
  color: var(--cyan);
  flex-shrink: 0;
  font-size: 12px;
  margin-top: 1px;
}

.blog-sidebar-list a:hover { color: var(--navy); }

.btn-sm {
  padding: 9px 18px !important;
  font-size: 13px !important;
}

/* ── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width: 900px) {
  .blog-post-body {
    grid-template-columns: 1fr;
  }
  .blog-sidebar {
    position: static;
  }
  .blog-featured-card {
    padding: 28px 24px;
  }
  .portal-bar-label {
    display: none; /* hide label on mobile, keep links */
  }
}

@media (max-width: 600px) {
  .portal-bar-inner {
    justify-content: center;
  }
  .portal-divider {
    display: none;
  }
  .portal-bar-links {
    gap: 4px;
  }
}


/* --- Homepage layout fixes --- */
.hero{
  position:relative;
  min-height:clamp(460px,62vh,660px);
  display:flex;
  align-items:center;
  overflow:hidden;
  background:linear-gradient(135deg,#06163d 0%, #0d255f 55%, #12367f 100%);
  isolation:isolate;
}
.hero-bg,.hero-particles{position:absolute;inset:0}
.hero-bg video{width:100%;height:100%;object-fit:cover;opacity:.22}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(6,22,61,.88) 0%,rgba(6,22,61,.78) 38%,rgba(6,22,61,.48) 100%);z-index:0}
.hero-inner{
  position:relative;z-index:1;
  width:min(1140px,100%);
  margin:0 auto;
  padding:clamp(56px,8vw,92px) 5% clamp(44px,6vw,64px);
  color:var(--white);
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border:1px solid rgba(255,255,255,.18);border-radius:999px;
  background:rgba(255,255,255,.08);backdrop-filter:blur(8px);
  color:rgba(255,255,255,.92);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  margin-bottom:20px;
}
.hero h1{font-family:'Outfit',sans-serif;font-size:clamp(40px,7vw,76px);line-height:.98;letter-spacing:-.04em;max-width:9ch;margin:0 0 18px;color:var(--white)}
.hero h1 em,.hero h1 i{font-style:normal;color:var(--cyan)}
.hero-sub{font-size:clamp(18px,2.15vw,22px);line-height:1.7;max-width:760px;color:rgba(255,255,255,.82);margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.trust-strip{background:#fff;border-bottom:1px solid var(--border)}
.trust-inner{width:min(1140px,100%);margin:0 auto;padding:18px 5%;display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:space-between}
.trust-label{font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--navy)}
.trust-items{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.trust-item{display:flex;align-items:baseline;gap:8px}
.trust-num{font-size:20px;font-weight:700;color:var(--navy)}
.trust-desc{font-size:14px;color:var(--slate)}
.trust-divider{width:1px;height:26px;background:var(--border)}
.services{padding:88px 5%;background:linear-gradient(180deg,#f8fbff 0%,#fff 100%)}
.services-header,.about-grid,.accred-inner,.cta-inner{width:min(1140px,100%);margin:0 auto}
.services-header{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(280px,.9fr);gap:28px;align-items:end;margin-bottom:34px}
.services-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.service-card{display:block;padding:28px;border:1px solid var(--border);border-radius:24px;background:#fff;text-decoration:none;color:inherit;box-shadow:0 12px 32px rgba(11,28,66,.06);transition:transform .2s,box-shadow .2s,border-color .2s}
.service-card:hover{transform:translateY(-4px);box-shadow:0 18px 36px rgba(11,28,66,.1);border-color:rgba(0,174,239,.35)}
.service-card h3{font-family:'Outfit',sans-serif;font-size:28px;line-height:1.15;color:var(--navy);margin:0 0 12px}
.service-card p{color:var(--slate);margin:0 0 18px}
.service-icon{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:var(--navy-light);color:var(--navy);margin-bottom:18px}
.service-icon svg{width:28px;height:28px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
.service-link{font-weight:700;color:var(--cyan-dark)}
.about{padding:92px 5%;background:#fff}
.about-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(320px,.9fr);gap:34px;align-items:start}
.about-body{font-size:17px;color:var(--slate);margin-bottom:18px}
.about-pillars{display:grid;gap:16px;margin-top:28px}
.pillar{display:flex;gap:14px;align-items:flex-start;padding:18px 20px;border-radius:18px;background:#f8fbff;border:1px solid var(--border)}
.pillar-dot{width:12px;height:12px;border-radius:999px;background:var(--cyan);margin-top:7px;flex:0 0 auto;box-shadow:0 0 0 6px rgba(0,174,239,.12)}
.pillar-text{display:grid;gap:5px}.pillar-text span{color:var(--slate)}
.about-visual{padding:30px;border-radius:28px;background:linear-gradient(180deg,#102b68 0%,#081937 100%);box-shadow:0 20px 48px rgba(10,28,66,.18);color:#fff;position:sticky;top:108px}
.about-quote{font-family:'Outfit',sans-serif;font-size:32px;line-height:1.1;letter-spacing:-.03em;margin-bottom:24px}.about-quote em{color:var(--cyan);font-style:normal}
.testimonial-text{font-size:16px;line-height:1.8;color:rgba(255,255,255,.82);margin-bottom:22px}.testimonial-author{display:grid;gap:3px}.testimonial-author span{color:rgba(255,255,255,.7)}
.accreditations{padding:0 5% 88px;background:#fff}
.accred-inner{padding:28px;border:1px solid var(--border);border-radius:28px;background:linear-gradient(180deg,#fff 0%,#f8fbff 100%);box-shadow:0 12px 32px rgba(11,28,66,.05)}
.accred-header p{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--navy);margin-bottom:18px}
.accred-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:16px}
.accred-item{padding:18px;border-radius:20px;background:#fff;border:1px solid var(--border);display:grid;gap:14px;justify-items:start;align-content:start;min-height:136px}
.accred-badge{height:52px;display:flex;align-items:center}.accred-badge img{max-height:48px;width:auto;display:block}
.accred-label{font-size:14px;line-height:1.5;color:var(--slate);font-weight:600}
.cta-strip{padding:32px 5% 90px;background:#fff}.cta-inner{display:flex;align-items:center;justify-content:space-between;gap:26px;width:min(1040px,100%);margin:0 auto;padding:38px 42px;border-radius:30px;background:linear-gradient(180deg,#f7fbff 0%,#eef6ff 100%);border:1px solid rgba(16,43,104,.10);color:var(--navy);box-shadow:0 18px 42px rgba(10,28,66,.08)}
.cta-text h2{font-family:'Outfit',sans-serif;font-size:clamp(30px,4vw,42px);line-height:1.06;letter-spacing:-.03em;margin-bottom:10px;color:var(--navy)}.cta-text p{font-size:17px;color:var(--slate);max-width:640px}
@keyframes floatParticle{0%{transform:translateY(0);opacity:0}10%,90%{opacity:.55}100%{transform:translateY(-420px);opacity:0}}
.particle{position:absolute;bottom:-40px;border-radius:999px;background:rgba(255,255,255,.4);box-shadow:0 0 0 8px rgba(255,255,255,.06);animation-name:floatParticle;animation-timing-function:linear;animation-iteration-count:infinite}
@media (max-width:980px){.services-grid,.services-header,.about-grid{grid-template-columns:1fr}.about-visual{position:static}.cta-inner,.trust-inner{align-items:flex-start}.cta-inner{flex-direction:column}.trust-divider{display:none}.trust-items{gap:14px 18px}}
@media (max-width:720px){nav,.portal-bar,.services,.about,.accreditations,.cta-strip{padding-left:20px;padding-right:20px}.services-header,.about-grid,.accred-inner,.cta-inner{width:100%;padding-left:0;padding-right:0}.hero-inner{width:100%;padding-left:20px;padding-right:20px;box-sizing:border-box}.trust-strip{padding-left:20px;padding-right:20px}.trust-inner{width:100%;padding-left:0;padding-right:0;box-sizing:border-box}.hero{min-height:500px}.hero h1{max-width:100%;font-size:clamp(32px,9vw,52px)}.service-card,.accred-item{padding:22px}.cta-inner{padding:26px}.hero-actions{width:100%;flex-direction:column}.hero-actions a{width:100%;text-align:center;box-sizing:border-box;flex:none}.portal-bar-inner{height:auto;padding:8px 0;align-items:flex-start}.portal-bar-links{flex-wrap:wrap}}


/* --- Brand lockup refinements --- */
.brand-lockup{
  display:inline-flex;
  align-items:center;
  gap:12px;
  text-decoration:none;
  min-width:0;
}
.brand-icon{
  display:block;
  width:auto;
  height:48px;
  flex:0 0 auto;
}
.brand-text{
  display:flex;
  flex-direction:column;
  line-height:0.95;
  min-width:0;
}
.brand-name{
  font-family:'Outfit',sans-serif;
  font-size:clamp(26px,2.2vw,34px);
  font-weight:500;
  letter-spacing:-0.04em;
  color:var(--text);
  white-space:nowrap;
}
.brand-sub{
  font-family:'Outfit',sans-serif;
  font-size:clamp(14px,1.2vw,20px);
  font-weight:500;
  letter-spacing:-0.04em;
  color:var(--text);
  margin-left:auto;
  white-space:nowrap;
}
.brand-lockup-footer .brand-name,
.brand-lockup-footer .brand-sub{
  color:var(--white);
}
.nav-logo-img{
  flex:0 1 auto;
  min-width:0;
  max-width:100%;
}
.nav-inner{
  gap:24px;
}
.nav-links{
  margin-left:auto;
}
.cta-strip{
  padding:0 5% 90px;
  background:#fff;
}
.cta-inner{
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  gap:24px 32px;
  padding:34px 36px;
  border-radius:30px;
  background:linear-gradient(135deg,#071634 0%,#102b68 100%);
  color:#fff;
  box-shadow:0 20px 50px rgba(10,28,66,.18);
}
.cta-text{
  min-width:0;
}
.cta-text h2{
  font-family:'Outfit',sans-serif;
  font-size:clamp(26px,3.3vw,40px);
  line-height:1.08;
  letter-spacing:-.03em;
  margin-bottom:10px;
  max-width:20ch;
  text-wrap:balance;
}
.cta-text p{
  font-size:17px;
  color:rgba(255,255,255,.82);
  max-width:58ch;
}
.cta-inner .btn-navy{
  background:#fff;
  color:var(--navy);
  justify-self:end;
  white-space:nowrap;
  flex-shrink:0;
}
.cta-inner .btn-navy:hover{
  background:#eef5ff;
}
@media (max-width:980px){
  .cta-inner{
    grid-template-columns:1fr;
    align-items:flex-start;
  }
  .cta-inner .btn-navy{
    justify-self:start;
  }
}
@media (max-width:720px){
  .brand-icon{height:42px}
  .brand-name{font-size:28px}
  .brand-sub{font-size:16px}
  .nav-inner{gap:16px}
  .cta-inner{
    padding:24px;
    border-radius:22px;
  }
  .cta-text h2{
    max-width:none;
  }
}


/* --- Footer wordmark and CTA refinements --- */
.footer-brand-wordmark{
  display:inline-flex;
  align-items:center;
  justify-content:flex-start;
  padding:12px 16px;
  background:rgba(255,255,255,.96);
  border-radius:18px;
  box-shadow:0 10px 30px rgba(0,0,0,.16);
  text-decoration:none;
  margin-bottom:16px;
}
.footer-wordmark{
  display:block;
  width:auto;
  height:68px;
  max-width:min(100%, 320px);
}
.footer-desc{
  max-width:360px;
}
.cta-strip{
  display:flex;
  justify-content:center;
  padding:0 5% 90px;
  background:#fff;
}
.cta-inner{
  width:min(960px,100%);
  grid-template-columns:1fr;
  justify-items:center;
  text-align:center;
  gap:18px;
  padding:38px 42px;
  background:linear-gradient(135deg,#eaf6ff 0%,#dff1ff 100%);
  color:var(--navy);
  box-shadow:0 18px 45px rgba(10,28,66,.10);
}
.cta-text{
  display:grid;
  gap:10px;
  justify-items:center;
}
.cta-text h2{
  color:var(--navy);
  max-width:18ch;
  margin-bottom:0;
}
.cta-text p{
  color:var(--slate);
  max-width:42ch;
  margin:0 auto;
}
.cta-inner .btn-navy{
  justify-self:center;
  background:var(--navy);
  color:#fff;
  box-shadow:0 10px 24px rgba(16,43,104,.16);
}
.cta-inner .btn-navy:hover{
  background:#123574;
  color:#fff;
}
@media (max-width:720px){
  .footer-brand-wordmark{padding:10px 12px;border-radius:14px;}
  .footer-wordmark{height:50px;max-width:240px;}
  .cta-inner{padding:28px 22px;}
}

/* --- Blog post defaults for CMS posts --- */
.blog-content > :first-child{margin-top:0;}
.blog-content hr{border:none;border-top:1px solid var(--border);margin:32px 0;}
.blog-content img{max-width:100%;height:auto;border-radius:18px;margin:24px 0;}


/* --- Final polish pass --- */
.cta-strip .btn-navy{box-shadow:none}
.cta-strip .btn-navy:hover{transform:translateY(-1px)}
.footer-brand-wordmark .footer-wordmark{max-width:220px;height:auto}


/* --- Final nav + logo + CTA adjustments --- */
#main-nav{
  position:sticky;
  top:0;
  z-index:600;
  background:rgba(255,255,255,.98);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  transition:box-shadow .2s ease, border-color .2s ease;
}
#main-nav.scrolled{
  box-shadow:0 12px 28px rgba(10,28,66,.08);
}
.nav-inner{
  height:76px;
}
.brand-lockup{
  gap:0;
}
.brand-wordmark-nav{
  display:block;
  height:52px;
  width:auto;
  max-width:min(100%, 280px);
}
.footer-brand-wordmark{
  padding:10px 14px;
}
.footer-wordmark{
  height:58px;
  width:auto;
  max-width:min(100%, 280px);
}
.cta-strip{
  padding:56px 5% 110px;
}
.cta-inner{
  width:min(1140px,100%);
  padding:46px 56px;
}
@media (max-width:720px){
  .nav-inner{height:70px;}
  .brand-wordmark-nav{height:42px;max-width:220px;}
  .footer-wordmark{height:48px;max-width:220px;}
  .cta-strip{padding-top:40px;padding-bottom:84px;}
  .cta-inner{padding:30px 24px;}
}


/* --- Locked header refinement --- */
html{scroll-padding-top:120px}
body{padding-top:112px}

.portal-bar{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:950;
  box-shadow:0 1px 0 rgba(255,255,255,0.04);
}

#main-nav{
  position:fixed;
  top:36px;
  left:0;
  right:0;
  width:100%;
  z-index:900;
  background:rgba(255,255,255,0.97);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(26,50,114,0.08);
  transition:box-shadow .22s ease, background-color .22s ease, transform .22s ease;
}

#main-nav.scrolled{
  box-shadow:0 12px 28px rgba(10,28,66,0.10);
  background:rgba(255,255,255,0.99);
}

.nav-inner{
  height:72px;
}

.brand-wordmark-nav{
  height:48px;
  max-width:min(100%, 250px);
}

.nav-links{
  gap:24px;
}

.nav-links a{
  font-weight:600;
}

@media (max-width:768px){
  body{padding-top:120px}

  .portal-bar-inner{
    height:auto;
    min-height:36px;
    padding:6px 0;
  }

  #main-nav{
    top:48px;
  }

  .nav-inner{
    height:72px;
  }

  .nav-links{
    position:fixed;
    top:120px;
    left:0;
    right:0;
    max-height:calc(100dvh - 120px);
    overflow-y:auto;
    padding:14px 20px 18px;
    box-shadow:0 14px 34px rgba(10,28,66,0.10);
  }

  .brand-wordmark-nav{
    height:42px;
    max-width:210px;
  }
}


/* --- Blog page alignment refinements --- */
.blog-post-shell{
  padding-bottom:24px;
}
.blog-tags-hero{
  margin-bottom:18px;
}
.blog-meta-hero{
  margin-top:12px;
}
.blog-post-section{
  padding-top:24px;
}
.blog-post-grid{
  align-items:start;
}
.blog-content{
  min-width:0;
}
.blog-content.prose h2:first-child,
.blog-content.prose h3:first-child,
.blog-content.prose > p:first-child{
  margin-top:0;
}
.blog-content.prose{
  background:#fff;
  border:1px solid var(--border);
  border-radius:24px;
  padding:34px;
  box-shadow:0 12px 32px rgba(11,28,66,.05);
}
.blog-content.prose p,
.blog-content.prose li{
  font-size:16px;
}
.blog-content.prose h2{
  font-size:26px;
  margin-top:32px;
}
.blog-content.prose h3{
  font-size:20px;
  margin-top:24px;
}
.blog-sidebar-main{
  position:sticky;
  top:120px;
  display:grid;
  gap:20px;
}
.blog-related-box ul{
  list-style:none;
  padding:0;
  margin:0;
}
.blog-sidebar-list li + li{
  margin-top:12px;
}
.blog-sidebar-list a{
  text-decoration:none;
  color:var(--navy);
  font-weight:500;
}
.blog-sidebar-list a:hover{
  color:var(--cyan-dark);
}
@media (max-width: 980px){
  .blog-sidebar-main{
    position:static;
  }
}
@media (max-width: 720px){
  .blog-content.prose{
    padding:24px;
    border-radius:18px;
  }
}


/* ═══════════════════════════════════════════════════════════════════
   MOBILE FIXES — content boxes, overflow, grids
   ═══════════════════════════════════════════════════════════════════ */

/* Ensure nothing bleeds past viewport width */
*, *::before, *::after {
  max-width: 100%;
}
/* But don't constrain flex/grid children or SVGs */
img, svg, video, canvas, iframe {
  max-width: 100%;
  height: auto;
}

@media (max-width: 768px) {

  /* Section padding — tighter on mobile */
  .section-inner,
  .page-hero-inner,
  .blog-hero-inner,
  .blog-post-body {
    padding-left: 20px !important;
    padding-right: 20px !important;
    width: 100% !important;
    box-sizing: border-box;
  }

  /* Cards grid — single column */
  .cards-grid,
  .accred-grid,
  .services-grid,
  .two-col,
  .two-col-wide {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* Blog grid — single column with safe min */
  .blog-grid {
    grid-template-columns: 1fr !important;
  }

  /* Blog post — drop sidebar below content */
  .blog-post-body,
  .blog-post-grid {
    grid-template-columns: 1fr !important;
    gap: 32px !important;
    padding: 32px 20px !important;
  }

  /* Blog featured card — prevent overflow */
  .blog-featured-card {
    padding: 24px 20px !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    border-radius: 12px !important;
  }

  /* Service + accred cards */
  .service-card,
  .accred-item,
  .blog-sidebar-card {
    padding: 20px !important;
    border-radius: 16px !important;
  }

  /* CTA strip — safe padding */
  .cta-inner {
    padding: 28px 20px !important;
    border-radius: 18px !important;
    text-align: left !important;
  }

  /* Blog prose box */
  .blog-content.prose {
    padding: 20px !important;
    border-radius: 14px !important;
  }

  /* About visual card */
  .about-visual {
    border-radius: 18px !important;
    padding: 22px !important;
  }

  /* Stats row — wrap and shrink */
  .stats-row {
    flex-wrap: wrap !important;
    gap: 10px !important;
  }

  /* Accred grid — 2 columns on small, 1 if very small */
  .accred-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  /* Hero sub text — don't let it overflow */
  .hero-sub {
    max-width: 100% !important;
    font-size: 16px !important;
  }

  /* Page hero text */
  .page-hero-inner h1 {
    font-size: clamp(24px, 7vw, 36px) !important;
  }

  /* Comparison table — horizontal scroll only inside wrapper */
  .compare-wrap {
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    margin: 0 -20px;
    padding: 0 20px;
  }

  /* Sidebar — unstick on mobile */
  .blog-sidebar,
  .blog-sidebar-main {
    position: static !important;
  }

}

@media (max-width: 480px) {

  /* Accred grid — single column on very small screens */
  .accred-grid {
    grid-template-columns: 1fr !important;
  }

  /* Portal bar — stack links */
  .portal-bar-links {
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 4px !important;
  }

  .portal-divider {
    display: none !important;
  }

  /* Hero actions — full width buttons */
  .hero-actions {
    flex-direction: column !important;
  }

  .hero-actions a {
    width: 100% !important;
    text-align: center !important;
  }

}


/* ── MOBILE HERO FIX ─────────────────────────────────────────────── */
@media (max-width: 720px) {

  /* Restore padding that was stripped — this was causing flush-left content */
  .hero-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box;
    width: 100% !important;
  }

  /* Trust strip */
  .trust-inner {
    padding-left: 20px !important;
    padding-right: 20px !important;
    box-sizing: border-box;
    width: 100% !important;
  }

  /* Hero title — slightly smaller so it fits comfortably */
  .hero h1 {
    font-size: clamp(32px, 9vw, 52px) !important;
    max-width: 100% !important;
  }

  /* Hero subtitle */
  .hero-sub {
    font-size: 16px !important;
    max-width: 100% !important;
  }

  /* Hero buttons — stack vertically, full width */
  .hero-actions {
    flex-direction: column !important;
    width: 100% !important;
    gap: 10px !important;
  }

  .hero-actions a {
    width: 100% !important;
    text-align: center !important;
    box-sizing: border-box !important;
    flex: none !important;
  }

  /* Hero badge */
  .hero-badge {
    max-width: 100% !important;
    white-space: normal !important;
    word-break: break-word !important;
  }

}


/* ── CONTACT PAGE ────────────────────────────────────────────────── */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 56px;
  align-items: start;
  padding-top: 56px;
  padding-bottom: 80px;
}

.contact-form-title {
  font-family: 'Outfit', sans-serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 8px;
  letter-spacing: -0.3px;
}

.contact-form-sub {
  font-size: 15px;
  color: var(--slate);
  margin-bottom: 32px;
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.form-row { display: flex; flex-direction: column; gap: 20px; }
.form-row-two { flex-direction: row; }

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}

.form-group label {
  font-size: 13px;
  font-weight: 600;
  color: var(--navy);
  letter-spacing: 0.2px;
}

.required { color: var(--cyan-dark); }

.form-group input,
.form-group textarea {
  padding: 12px 16px;
  border: 1.5px solid var(--border);
  border-radius: 10px;
  font-size: 15px;
  font-family: 'DM Sans', sans-serif;
  color: var(--text);
  background: var(--white);
  transition: border-color 0.2s, box-shadow 0.2s;
  width: 100%;
  box-sizing: border-box;
}

.form-group input:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--cyan);
  box-shadow: 0 0 0 3px rgba(0,174,239,0.12);
}

.form-group textarea { resize: vertical; min-height: 130px; }

.btn-full { width: 100%; justify-content: center; }

.form-alert {
  padding: 14px 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
}

.form-alert-error {
  background: #fff0f0;
  border: 1px solid #fca5a5;
  color: #dc2626;
}

.form-alert-success {
  background: #f0fdf4;
  border: 1px solid #86efac;
  color: #16a34a;
}

/* Contact details sidebar */
.contact-details {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: sticky;
  top: 120px;
}

.contact-detail-card {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 20px;
  background: var(--off-white);
  border: 1px solid var(--border);
  border-radius: 14px;
}

.contact-detail-icon {
  width: 42px;
  height: 42px;
  border-radius: 10px;
  background: var(--navy-light);
  color: var(--navy);
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.contact-detail-icon svg {
  width: 20px;
  height: 20px;
}

.contact-detail-card h3 {
  font-size: 13px;
  font-weight: 700;
  color: var(--navy);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.contact-detail-card a,
.contact-detail-card p {
  font-size: 14px;
  color: var(--slate);
  text-decoration: none;
  line-height: 1.6;
}

.contact-detail-card a:hover { color: var(--cyan-dark); }

.contact-support-box {
  padding: 20px;
  background: var(--navy);
  border-radius: 14px;
  text-align: center;
}

.contact-support-box p {
  color: rgba(255,255,255,0.7);
  font-size: 13px;
  margin-bottom: 12px;
}

.btn-outline-navy {
  display: inline-block;
  padding: 10px 20px;
  border: 1.5px solid rgba(255,255,255,0.3);
  border-radius: 8px;
  color: var(--white) !important;
  font-size: 13px;
  font-weight: 600;
  text-decoration: none;
  transition: background 0.2s, border-color 0.2s;
}

.btn-outline-navy:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.5);
}

/* Mobile contact */
@media (max-width: 768px) {
  .contact-grid {
    grid-template-columns: 1fr;
    gap: 40px;
    padding-top: 36px;
    padding-bottom: 56px;
  }

  .form-row-two {
    flex-direction: column;
  }

  .contact-details {
    position: static;
  }
}

/* ── FOOTER CERT STRIP ── */
.footer-cert-strip {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  padding: 16px 0 8px;
  border-top: 1px solid rgba(255,255,255,0.08);
  margin-top: 16px;
}
.footer-cert-item {
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0.75;
  transition: opacity 0.2s;
  text-decoration: none;
}
.footer-cert-item:hover { opacity: 1; }
.footer-cert-item.footer-cert-img img {
  height: 52px;
  width: auto;
  display: block;
  border-radius: 6px;
}
.footer-cert-item.footer-cert-ico img {
  height: 44px;
  border-radius: 6px;
}
/* iframes in footer — fixed size, no interaction passthrough issues */
.footer-cert-item iframe {
  display: block;
  pointer-events: none;
}


/* --- Blog layout refinements --- */
.blog-post-grid{
  grid-template-columns:minmax(0, 720px) minmax(220px, 260px);
  justify-content:center;
  gap:40px;
}
.blog-post-section .section-inner{
  max-width:1040px;
}
.blog-content.prose{
  max-width:720px;
}
.blog-sidebar-main{
  gap:16px;
}
.blog-sidebar-main .highlight-box{
  padding:22px;
}
.blog-post-cta{
  padding-top:12px;
}
@media (max-width: 1100px){
  .blog-post-grid{
    grid-template-columns:minmax(0, 1fr) 240px;
    gap:32px;
  }
  .blog-post-section .section-inner{
    max-width:980px;
  }
}
@media (max-width: 980px){
  .blog-post-grid{
    grid-template-columns:1fr;
  }
  .blog-content.prose{
    max-width:none;
  }
}
