
/* ==============================================
   SPF INNER PAGES — SHARED CSS
   Appended to GeneratePress Customizer CSS
   ============================================== */

/* --- CSS Custom Properties --- */
body { --spf-teal: #1A7FA8; --spf-teal-dk: hsl(197,71%,38%); --spf-navy: hsl(220,10%,30%); --spf-navy-dk: hsl(220,12%,22%); --spf-warm: hsl(30,8%,97%); --spf-bg-lt: #f7f8f9; --spf-border: hsl(220,10%,90%); --spf-text: hsl(220,15%,25%); --spf-muted: #6b7280; }

/* --- Page layout resets (all pages incl. home) --- */
body.page { background: #f7f8f9 !important; }
body.page:not(.home) .entry-header { display: none !important; }
body.page .entry-content { padding: 0 !important; max-width: 100% !important; margin: 0 !important; }
body.page .inside-article { padding: 0 !important; max-width: 100% !important; background: transparent !important; }
body.page .site-main { padding-top: 0 !important; }
body.page .content-area { padding-top: 0 !important; }

/* --- GeneratePress full-width override (all pages) --- */
body.page .grid-container:not(.inside-header) { max-width:100% !important; padding-left:0 !important; padding-right:0 !important; }
body.page .site-content { padding-top:0 !important; padding-bottom:0 !important; display:block !important; }
body.page #primary, body.page .content-area { padding-top:0 !important; padding-bottom:0 !important; width:100% !important; max-width:100% !important; float:none !important; }
body.page #main { padding-top:0 !important; margin-top:0 !important; max-width:100% !important; }
body.page #right-sidebar, body.page #left-sidebar, body.page .sidebar.widget-area { display:none !important; }

/* --- WP Cover-block alignfull (homepage hero) --- */
body.page .wp-block-cover.alignfull, body.page .alignfull { max-width:100% !important; width:100% !important; margin-left:0 !important; margin-right:0 !important; }
body.home .spf-hero.wp-block-cover { min-height: 85vh !important; }
body.home .spf-hero.wp-block-cover, body.home .wp-block-cover.spf-hero { min-height: 640px !important; }
@media (min-width: 900px) { body.home .spf-hero.wp-block-cover { min-height: 85vh !important; } }

/* --- Header nav link colors (high contrast on grey) --- */
.main-navigation, .main-navigation .main-nav > ul, .main-navigation ul ul { background-color: transparent !important; }
.main-navigation .main-nav ul li a,
.main-navigation .menu-toggle,
.main-navigation .main-nav ul li.menu-item-has-children .dropdown-menu-toggle,
#site-navigation .main-nav ul li a { color:#ffffff !important; font-weight:600 !important; }
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.sfHover > a,
.main-navigation .main-nav ul li[class*="current-menu"] > a,
#site-navigation .main-nav ul li:hover > a { color: hsl(197,71%,60%) !important; background-color: transparent !important; }

/* ==============================================
   SPF INNER PAGES — SHARED CSS
   Appended to GeneratePress Customizer CSS
   ============================================== */

/* --- CSS Custom Properties --- */
body { --spf-teal: #1A7FA8; --spf-teal-dk: hsl(197,71%,38%); --spf-navy: hsl(220,10%,30%); --spf-navy-dk: hsl(220,12%,22%); --spf-warm: hsl(30,8%,97%); --spf-bg-lt: #f7f8f9; --spf-border: hsl(220,10%,90%); --spf-text: hsl(220,15%,25%); --spf-muted: #6b7280; }

/* --- Page layout resets (all pages incl. home) --- */
body.page { background: #f7f8f9 !important; }
body.page:not(.home) .entry-header { display: none !important; }
body.page .entry-content { padding: 0 !important; max-width: 100% !important; margin: 0 !important; }
body.page .inside-article { padding: 0 !important; max-width: 100% !important; background: transparent !important; }
body.page .site-main { padding-top: 0 !important; }
body.page .content-area { padding-top: 0 !important; }

/* --- GeneratePress full-width override (all pages) --- */
body.page .grid-container:not(.inside-header) { max-width:100% !important; padding-left:0 !important; padding-right:0 !important; }
body.page .site-content { padding-top:0 !important; padding-bottom:0 !important; display:block !important; }
body.page #primary, body.page .content-area { padding-top:0 !important; padding-bottom:0 !important; width:100% !important; max-width:100% !important; float:none !important; }
body.page #main { padding-top:0 !important; margin-top:0 !important; max-width:100% !important; }
body.page #right-sidebar, body.page #left-sidebar, body.page .sidebar.widget-area { display:none !important; }

/* --- WP Cover-block alignfull (homepage hero) --- */
body.page .wp-block-cover.alignfull, body.page .alignfull { max-width:100% !important; width:100% !important; margin-left:0 !important; margin-right:0 !important; }
body.home .spf-hero.wp-block-cover { min-height: 85vh !important; }
body.home .spf-hero.wp-block-cover, body.home .wp-block-cover.spf-hero { min-height: 640px !important; }
@media (min-width: 900px) { body.home .spf-hero.wp-block-cover { min-height: 85vh !important; } }

/* --- Header nav link colors (high contrast on grey) --- */
.main-navigation, .main-navigation .main-nav > ul, .main-navigation ul ul { background-color: transparent !important; }
.main-navigation .main-nav ul li a,
.main-navigation .menu-toggle,
.main-navigation .main-nav ul li.menu-item-has-children .dropdown-menu-toggle,
#site-navigation .main-nav ul li a { color:#ffffff !important; font-weight:600 !important; }
.main-navigation .main-nav ul li:hover > a,
.main-navigation .main-nav ul li.sfHover > a,
.main-navigation .main-nav ul li[class*="current-menu"] > a,
#site-navigation .main-nav ul li:hover > a { color: hsl(197,71%,60%) !important; background-color: transparent !important; }
.inside-header, .site-header { color:#ffffff; }

/* --- FOOTER styling (dark navy, edge-to-edge) --- */
.site-footer, .site-footer .footer-widgets, .site-footer .site-info { background: hsl(220,12%,22%) !important; color: rgba(255,255,255,0.72) !important; }
.site-footer .grid-container, .site-footer .inside-site-info { max-width:1200px !important; padding-left:2rem !important; padding-right:2rem !important; margin:0 auto !important; }
.site-footer .footer-widgets { padding: 4rem 0 2rem !important; }
.site-footer .footer-widgets-container, .site-footer .inside-footer-widgets { display: block !important; }
.site-footer .footer-widget-2, .site-footer .footer-widget-3, .site-footer .footer-widget-4, .site-footer .footer-widget-5 { display: none !important; }
.site-footer .footer-widget-1 { width: 100% !important; }
.site-footer .widget.inner-padding { padding: 0 !important; }
.spf-footer-inner { display: grid !important; grid-template-columns: 1.5fr 1fr 1fr 1fr !important; gap: 3rem !important; max-width: 1400px !important; margin: 0 auto !important; padding: 0 2rem !important; box-sizing: border-box !important; }
@media (max-width: 900px) { .spf-footer-inner { grid-template-columns: 1fr 1fr !important; } }
@media (max-width: 600px) { .spf-footer-inner { grid-template-columns: 1fr !important; } }
.site-footer .spf-footer-col-heading, .site-footer .widget-title, .site-footer h2, .site-footer h3, .site-footer h4 { color: var(--spf-teal) !important; font-size: 0.75rem !important; font-weight: 700 !important; letter-spacing: 0.15em !important; text-transform: uppercase !important; margin: 0 0 1.25rem !important; }
.spf-footer-links { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.spf-footer-links li { margin-bottom: 0.6rem !important; font-size: 0.92rem !important; }
.spf-footer-logo { display:flex; align-items:center; gap:0.7rem; margin-bottom:1rem; color:#fff; }
.spf-footer-logo-text, .spf-footer-logo-top, .spf-footer-logo-bottom { color:#fff !important; font-weight:700 !important; letter-spacing:0.02em !important; }
.spf-footer-tagline { color: rgba(255,255,255,0.6) !important; font-size: 0.92rem !important; line-height: 1.6 !important; }
.spf-footer-cta-btn { display:inline-block !important; background: var(--spf-teal) !important; color:#fff !important; padding: 0.65rem 1.5rem !important; border-radius: 0.25rem !important; font-weight: 700 !important; font-size: 0.8rem !important; letter-spacing: 0.08em !important; text-transform: uppercase !important; margin-top: 0.75rem !important; }
.spf-footer-cta-btn:hover { background: var(--spf-teal-dk) !important; color:#fff !important; }
.spf-footer-bar, .spf-footer-bar-links { color: rgba(255,255,255,0.5) !important; font-size: 0.82rem !important; }
.site-footer a { color: rgba(255,255,255,0.72) !important; text-decoration: none !important; font-weight: 400 !important; transition: color 0.2s; }
.site-footer a:hover { color: var(--spf-teal) !important; }
.site-footer p { color: rgba(255,255,255,0.62) !important; font-size: 0.92rem !important; line-height: 1.65 !important; margin: 0 0 0.75rem !important; }
.site-footer .site-info { border-top: 1px solid rgba(255,255,255,0.08) !important; padding: 1.5rem 0 !important; font-size: 0.82rem !important; color: rgba(255,255,255,0.45) !important; }
.site-footer .site-info .copyright-bar { text-align: center !important; }
.site-footer .site-info a { color: rgba(255,255,255,0.6) !important; }

/* --- HERO: inner pages --- */
.spf-inner-hero { position:relative; min-height:620px; display:flex; align-items:center; background-size:cover; background-position:center; background-repeat:no-repeat; overflow:hidden; }
@media (min-width: 1200px) { .spf-inner-hero { min-height:680px; } }
.spf-inner-hero::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(22,28,40,0.87) 0%,rgba(22,28,40,0.60) 100%); z-index:1; }
.spf-inner-hero-content { position:relative; z-index:2; max-width:1200px; margin:0 auto; padding:7rem 2rem 5rem; width:100%; }
.spf-hero-eyebrow { display:inline-block; font-size:0.72rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--spf-teal); margin-bottom:1rem; }
.spf-hero-title { font-size:clamp(1.75rem,3.8vw,2.6rem); font-weight:800; color:#fff; line-height:1.45; margin:0 0 1rem; max-width:720px; }
.spf-hero-sub { font-size:1.05rem; color:rgba(255,255,255,0.78); max-width:580px; line-height:1.65; margin:0; }

/* --- SECTION CONTAINER --- */
.spf-section { padding:5rem 2rem; }
.spf-section-inner { max-width:1200px; margin:0 auto; }
.spf-section--white { background:#fff; }
.spf-section--gray { background:var(--spf-warm); }
.spf-section--dark { background:var(--spf-navy-dk); color:#fff; }
.spf-section--navy { background:var(--spf-navy); color:#fff; }

/* --- SECTION HEADER --- */
.spf-section-header { margin-bottom:3rem; }
.spf-section-header--center { text-align:center; }
.spf-section-header--center .spf-section-subtitle { margin:0 auto; }
.spf-section-eyebrow { display:inline-block; font-size:0.7rem; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--spf-teal); margin-bottom:0.6rem; }
.spf-section-title { font-size:clamp(1.7rem,3.5vw,2.4rem); font-weight:800; color:var(--spf-navy); line-height:1.2; margin:0 0 0.85rem; }
.spf-section--dark .spf-section-title, .spf-section--navy .spf-section-title { color:#fff; }
.spf-section-subtitle { font-size:1rem; color:var(--spf-muted); max-width:620px; line-height:1.7; margin:0; }
.spf-section--dark .spf-section-subtitle, .spf-section--navy .spf-section-subtitle { color:rgba(255,255,255,0.68); }
.spf-divider { width:3rem; height:3px; background:var(--spf-teal); border:none; margin:1rem 0; }

/* --- CARDS GRID --- */
.spf-cards-grid { display:grid; gap:1.5rem; }
.spf-cards-grid--2 { grid-template-columns:repeat(2,1fr); }
.spf-cards-grid--3 { grid-template-columns:repeat(3,1fr); }
.spf-cards-grid--4 { grid-template-columns:repeat(4,1fr); }
.spf-card { background:#fff; border:1px solid var(--spf-border); border-radius:0.5rem; padding:1.75rem; transition:box-shadow 0.2s ease; }
.spf-card:hover { box-shadow:0 8px 28px rgba(0,0,0,0.07); }
.spf-card--dark { background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.10); }
.spf-card--teal-top { border-top:3px solid var(--spf-teal); }
.spf-card-icon { width:44px; height:44px; background:rgba(26,167,207,0.12); border-radius:0.4rem; display:flex; align-items:center; justify-content:center; margin-bottom:1.1rem; color:var(--spf-teal); font-size:1.2rem; font-weight:700; }
.spf-card-label { font-size:0.7rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--spf-teal); margin-bottom:0.4rem; }
.spf-card-title { font-size:1.05rem; font-weight:700; color:var(--spf-navy); margin:0 0 0.6rem; line-height:1.3; }
.spf-card--dark .spf-card-title { color:#fff; }
.spf-card-text { font-size:0.88rem; color:var(--spf-muted); line-height:1.65; margin:0; }
.spf-card--dark .spf-card-text { color:rgba(255,255,255,0.62); }

/* --- TWO-COLUMN LAYOUT --- */
.spf-two-col { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.spf-two-col--60-40 { grid-template-columns:1.5fr 1fr; }
.spf-two-col--40-60 { grid-template-columns:1fr 1.5fr; }
.spf-col-img { border-radius:0.5rem; overflow:hidden; }
.spf-col-img img { width:100%; height:100%; object-fit:cover; display:block; }
/* --- STAT ROW --- */
.spf-stats-row { display:flex; gap:3rem; flex-wrap:wrap; margin-top:2rem; }
.spf-stat { flex:1; min-width:120px; }
.spf-stat-num { font-size:2.4rem; font-weight:800; color:var(--spf-teal); line-height:1; margin-bottom:0.2rem; }
.spf-stat-label { font-size:0.8rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--spf-muted); font-weight:600; }

/* --- PROCESS / STEPS --- */
.spf-steps { display:grid; gap:2rem; }
.spf-steps--row { grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); }
.spf-step { display:grid; grid-template-columns:auto 1fr; gap:1.25rem; align-items:start; }
.spf-step--row { display:block; text-align:center; }
.spf-step-num { width:2.4rem; height:2.4rem; background:var(--spf-teal); color:#fff; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:0.82rem; font-weight:700; flex-shrink:0; }
.spf-step--row .spf-step-num { margin:0 auto 1rem; }
.spf-step-title { font-size:1rem; font-weight:700; color:var(--spf-navy); margin:0 0 0.4rem; }
.spf-section--dark .spf-step-title, .spf-section--navy .spf-step-title { color:#fff; }
.spf-step-text { font-size:0.87rem; color:var(--spf-muted); line-height:1.6; margin:0; }
.spf-section--dark .spf-step-text, .spf-section--navy .spf-step-text { color:rgba(255,255,255,0.62); }

/* --- BIO / TEAM --- */
.spf-bio { background:#fff; border:1px solid var(--spf-border); border-radius:0.5rem; padding:2rem; display:flex; gap:1.75rem; align-items:flex-start; }
.spf-bio-avatar { width:96px; height:96px; border-radius:50%; object-fit:cover; flex-shrink:0; border:3px solid var(--spf-border); }
.spf-bio-name { font-size:1.1rem; font-weight:700; color:var(--spf-navy); margin:0 0 0.2rem; }
.spf-bio-role { font-size:0.75rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--spf-teal); margin:0 0 0.85rem; }
.spf-bio-text { font-size:0.88rem; color:var(--spf-muted); line-height:1.7; margin:0; }

/* --- QUOTE --- */
.spf-quote-block { border-left:3px solid var(--spf-teal); padding:1.25rem 1.5rem; background:var(--spf-warm); border-radius:0 0.5rem 0.5rem 0; }
.spf-quote-text { font-size:1.05rem; font-style:italic; color:var(--spf-navy); line-height:1.65; margin:0 0 0.75rem; }
.spf-quote-attr { font-size:0.82rem; font-weight:700; color:var(--spf-muted); font-style:normal; }

/* --- TAGS / BADGES --- */
.spf-tag { display:inline-block; background:rgba(26,167,207,0.10); color:var(--spf-teal); font-size:0.72rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:0.28rem 0.7rem; border-radius:2rem; }
.spf-tag--dark { background:rgba(255,255,255,0.10); color:rgba(255,255,255,0.82); }

/* --- TECH / LOGO GRID --- */
.spf-tech-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(120px,1fr)); gap:0.85rem; }
.spf-tech-item { background:#fff; border:1px solid var(--spf-border); border-radius:0.4rem; padding:1rem 0.75rem; text-align:center; font-size:0.82rem; font-weight:600; color:var(--spf-navy); transition:border-color 0.2s; }
.spf-tech-item:hover { border-color:var(--spf-teal); }

/* --- COMPANY GRID --- */
.spf-company-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:1.25rem; }
.spf-company-card { background:#fff; border:1px solid var(--spf-border); border-radius:0.5rem; padding:1.5rem; transition:box-shadow 0.2s; }
.spf-company-card:hover { box-shadow:0 6px 20px rgba(0,0,0,0.07); }
.spf-company-tag { font-size:0.68rem; font-weight:700; letter-spacing:0.1em; text-transform:uppercase; color:var(--spf-teal); margin-bottom:0.5rem; }
.spf-company-name { font-size:1rem; font-weight:700; color:var(--spf-navy); margin:0 0 0.4rem; }
.spf-company-desc { font-size:0.83rem; color:var(--spf-muted); line-height:1.55; margin:0; }

/* --- CTA BANNER --- */
.spf-cta-banner { background:var(--spf-navy-dk); padding:5rem 2rem; text-align:center; }
.spf-cta-inner { max-width:700px; margin:0 auto; }
.spf-cta-title { font-size:clamp(1.75rem,3vw,2.25rem); font-weight:800; color:#fff; margin:0 0 0.85rem; line-height:1.2; }
.spf-cta-sub { font-size:1rem; color:rgba(255,255,255,0.7); margin:0 0 2rem; line-height:1.65; }
.spf-cta-btn { display:inline-block; background:var(--spf-teal); color:#fff !important; font-size:0.85rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; padding:0.85rem 2.25rem; border-radius:0.25rem; text-decoration:none !important; transition:background 0.2s; }
.spf-cta-btn:hover { background:var(--spf-teal-dk); color:#fff !important; }

/* --- TESTIMONIAL --- */
.spf-testimonial { background:#fff; border:1px solid var(--spf-border); border-radius:0.5rem; padding:1.75rem; }
.spf-testimonial-text { font-size:0.95rem; color:var(--spf-navy); line-height:1.7; font-style:italic; margin:0 0 1rem; }
.spf-testimonial-author { font-size:0.82rem; font-weight:700; color:var(--spf-teal); }

/* --- MEMBERSHIP TIERS --- */
.spf-tiers { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.spf-tier { background:#fff; border:1px solid var(--spf-border); border-radius:0.5rem; padding:2rem; text-align:center; }
.spf-tier--featured { border-color:var(--spf-teal); box-shadow:0 0 0 2px rgba(26,167,207,0.2); }
.spf-tier-label { font-size:0.7rem; font-weight:700; letter-spacing:0.15em; text-transform:uppercase; color:var(--spf-teal); margin-bottom:0.5rem; }
.spf-tier-name { font-size:1.25rem; font-weight:800; color:var(--spf-navy); margin:0 0 1rem; }
.spf-tier-price { font-size:2rem; font-weight:800; color:var(--spf-navy); margin:0 0 1.5rem; }
.spf-tier-features { list-style:none; padding:0; margin:0; text-align:left; font-size:0.87rem; color:var(--spf-muted); line-height:2; }

/* --- NOTICE BANNER --- */
.spf-notice { background:rgba(26,167,207,0.08); border:1px solid rgba(26,167,207,0.25); border-radius:0.4rem; padding:1rem 1.25rem; font-size:0.88rem; color:var(--spf-navy); margin-bottom:2rem; }

/* --- CONTACT --- */
.spf-contact-grid { display:grid; grid-template-columns:1fr 1.5fr; gap:4rem; align-items:start; }
.spf-contact-info-item { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.75rem; }
.spf-contact-icon { width:40px; height:40px; background:rgba(26,167,207,0.10); border-radius:0.4rem; display:flex; align-items:center; justify-content:center; color:var(--spf-teal); flex-shrink:0; font-size:1.1rem; }
.spf-contact-label { font-size:0.75rem; font-weight:700; text-transform:uppercase; letter-spacing:0.1em; color:var(--spf-muted); margin:0 0 0.25rem; }
.spf-contact-value { font-size:0.92rem; color:var(--spf-navy); font-weight:500; margin:0; }

/* --- INLINE LINK STYLE --- */
.spf-link { color:var(--spf-teal) !important; text-decoration:none; font-weight:600; }
.spf-link:hover { text-decoration:underline; }

/* --- RESPONSIVE (tablet) --- */
@media (max-width: 900px) {
  .spf-cards-grid--4 { grid-template-columns:repeat(2,1fr); }
  .spf-cards-grid--3 { grid-template-columns:repeat(2,1fr); }
  .spf-two-col, .spf-two-col--60-40, .spf-two-col--40-60 { grid-template-columns:1fr; gap:2rem; }
  .spf-tiers { grid-template-columns:1fr; }
  .spf-contact-grid { grid-template-columns:1fr; }
  .spf-inner-hero-content { padding:5rem 1.5rem 3.5rem; }
}
@media (max-width: 600px) {
  .spf-cards-grid--2, .spf-cards-grid--3, .spf-cards-grid--4 { grid-template-columns:1fr; }
  .spf-section { padding:3rem 1.25rem; }
  .spf-bio { flex-direction:column; }
  .spf-stats-row { gap:1.5rem; }
}

/* REMOVE GAP ABOVE FOOTER */
body, body.page { background-color: rgb(49, 54, 63) !important; }

/* FOOTER CTA BUTTONS - match header CTA style */
.spf-cta-btn, .spf-footer-cta-btn { background: rgb(35,160,209) !important; color: #fff !important; padding: 0.55rem 1.25rem !important; border-radius: 4px !important; font-size: 0.72rem !important; font-weight: 700 !important; text-transform: none !important; letter-spacing: 0.02em !important; display: inline-block !important; text-decoration: none !important; }
.spf-cta-btn:hover, .spf-footer-cta-btn:hover { background: rgb(20,140,190) !important; color: #fff !important; }

/* FOOTER CTA spacing + bold */
.spf-footer-cta-btn { margin-bottom: 1.25rem !important; font-weight: 700 !important; }

/* FOOTER CTA bold override */
.site-footer a.spf-footer-cta-btn { font-weight: 700 !important; }

/* HEADER LAYOUT FIX */
.site-header { overflow-x: clip !important; overflow-y: visible !important; max-width: 100vw !important; }
.site-header .inside-header.grid-container {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 1rem !important;
  padding-right: 1rem !important;
  box-sizing: border-box !important;
}
@media (min-width: 769px) {
  .mobile-menu-control-wrapper { display: none !important; }
}

/* old NAV LINK FONT SIZE removed — see consolidated rule below */

/* FOOTER WORDMARK LEFT ALIGN */
.spf-footer-brand { margin-left: -12px !important; }


/* === VISUAL POLISH PASS — April 16 === */

/* HIDE HOMEPAGE "Home" ENTRY HEADER */
body.home .entry-header { display: none !important; }

/* NAV LINKS: consolidated — fit all links in one row */
@media (min-width: 769px) {
  .main-navigation .main-nav ul li a {
    font-size: 0.82rem !important;
    padding-left: 0.45rem !important;
    padding-right: 0.45rem !important;
    white-space: nowrap !important;
  }
  .main-navigation.sub-menu-right {
    flex: 1 1 auto !important;
    justify-content: flex-end !important;
  }
  .inside-navigation.grid-container {
    max-width: none !important;
    padding: 0 !important;
  }
  li.nav-cta-button {
    margin-left: 1rem !important;
  }
  li.nav-cta-button > a,
  .nav-cta-button > a {
    background: var(--spf-teal) !important;
    color: #fff !important;
    border-radius: 4px !important;
    padding: 0.55rem 1.25rem !important;
    font-weight: 700 !important;
    line-height: 1.5 !important;
    letter-spacing: 0.02em !important;
    font-size: 0.82rem !important;
    display: inline-block !important;
  }
  li.nav-cta-button > a:hover,
  .nav-cta-button > a:hover {
    background: var(--spf-teal-dk) !important;
    color: #fff !important;
  }
}

/* FIX FULL-WIDTH */
body.page .site-content, body.page .site-content .content-area,
body.page .site-content #primary, body.page .inside-article,
body.page .entry-content {
  width: 100% !important; max-width: 100% !important; overflow-x: hidden !important;
}
.site-content .grid-container { max-width: 100% !important; padding-left: 0 !important; padding-right: 0 !important; }

/* NAV/HEADER: single-row layout (consolidated) */
.main-navigation .main-nav > ul { display: flex !important; flex-wrap: nowrap !important; align-items: center !important; }
.main-navigation .main-nav > ul > li { flex-shrink: 0 !important; }
.site-header .site-branding, .site-header .site-logo { max-width: none !important; flex-shrink: 1 !important; min-width: 0 !important; }
.site-header .site-branding .main-title { font-size: 0.95rem !important; white-space: nowrap !important; }
.site-header .inside-header { display: flex !important; align-items: center !important; flex-wrap: nowrap !important; }
.main-navigation { flex: 1 !important; display: flex !important; justify-content: flex-end !important; }

/* WHITE GAP fix */
body.home .wp-block-cover + div, body.home .wp-block-cover + .spf-section { margin-top: 0 !important; padding-top: 4rem !important; }
body.home .entry-content > *:first-child + * { margin-top: 0 !important; }
body.home .entry-content { gap: 0 !important; }

/* HERO: "People-First" in teal and larger */
.spf-hero-title .spf-hero-people-first { color: var(--spf-teal) !important; font-size: 1.68em !important; display: block !important; }

/* OUR MISSION: two-column layout */
.spf-mission-two-col { display: grid !important; grid-template-columns: 1.2fr 1fr !important; gap: 3rem !important; align-items: center !important; }
.spf-mission-img { display: block !important; }
.spf-mission-img img { width: 100% !important; height: auto !important; display: block !important; filter: grayscale(0.2) !important; }
@media (max-width: 600px) { .spf-mission-two-col { grid-template-columns: 1fr !important; } }

/* REDUCE white gap between hero and mission */
body.home .entry-content > section.spf-section--white:first-of-type { padding-top: 3.5rem !important; }


/* === INNER PAGE POLISH — April 16 === */

/* INNER PAGES: tighter section spacing (80px -> 60px) */
body.page:not(.home) .spf-section {
  padding-top: 3.75rem !important;
  padding-bottom: 3.75rem !important;
}

/* INNER PAGES: hero should start right below header with no gap */
body.page:not(.home) .spf-inner-hero {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* INNER PAGES: remove gap between hero and first section */
body.page:not(.home) .entry-content > .spf-inner-hero + .spf-section {
  margin-top: 0 !important;
}

/* INNER PAGES: tighten gap between consecutive gray sections */
body.page:not(.home) .spf-section--gray + .spf-section--gray {
  padding-top: 0 !important;
}

/* INNER PAGES: CTA banner full edge-to-edge */
body.page:not(.home) .spf-cta-banner {
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
  max-width: 100vw !important;
}

/* INNER PAGES: dark sections full edge-to-edge */
body.page:not(.home) .spf-section--dark,
body.page:not(.home) .spf-section--navy {
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
  max-width: 100vw !important;
}

/* INNER PAGES: card grid — even spacing on 2-col grids */
body.page:not(.home) .spf-cards-grid--2 {
  gap: 1.5rem !important;
}

/* INNER PAGES: teal-top card — keep as top border */
body.page:not(.home) .spf-card--teal-top {
  border-top: 3px solid var(--spf-teal) !important;
  border-left: 0.6px solid #e3e5e8 !important;
}

/* INNER PAGES: bio card layout tighter */
body.page:not(.home) .spf-bio {
  padding: 1.5rem !important;
}

/* INNER PAGES: section titles slightly smaller for density */
body.page:not(.home) .spf-section-title {
  font-size: clamp(1.5rem, 2vw + 0.5rem, 2.1rem) !important;
}


/* === WHO WE ARE: Manifesto + Values side-by-side fix === */
/* Override the 900px collapse — keep two-col down to 700px for this page */
@media (max-width: 900px) and (min-width: 701px) {
  .spf-two-col,
  .spf-two-col--60-40,
  .spf-two-col--40-60 {
    grid-template-columns: 1.2fr 1fr !important;
    gap: 2rem !important;
  }
}
@media (max-width: 700px) {
  .spf-two-col,
  .spf-two-col--60-40,
  .spf-two-col--40-60 {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }
}

/* Values header: left-align when side-by-side */
@media (min-width: 701px) {
  .spf-two-col .spf-section-header--center {
    text-align: left !important;
  }
  .spf-two-col .spf-section-header--center .spf-section-eyebrow {
    text-align: left !important;
  }
}

/* === HOMEPAGE POLISH PASS 2 — April 16 === */

/* Stats bar horizontal layout */
.spf-stats-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: space-evenly !important;
  align-items: center !important;
  gap: 2rem !important;
  text-align: center !important;
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding: 1rem 2rem !important;
}
.spf-stats-grid .spf-stat {
  flex: 1 1 120px !important;
  min-width: 120px !important;
  text-align: center !important;
}
.spf-stats-grid .spf-stat-number,
.spf-stats-grid .spf-stat .spf-stat-num {
  font-size: 2.5rem !important;
  font-weight: 800 !important;
  color: var(--spf-teal) !important;
  line-height: 1.1 !important;
}
.spf-stats-grid .spf-stat-label {
  font-size: 0.78rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: rgba(255,255,255,0.6) !important;
  margin-top: 0.25rem !important;
}

/* Subscribe button ghost/outline style */
.spf-hero .wp-block-button:nth-child(2) .wp-block-button__link,
a.wp-block-button__link[href*="subscribe"],
.entry-content .wp-block-buttons .wp-block-button:last-child .wp-block-button__link {
  background: transparent !important;
  border: 1.5px solid rgba(255,255,255,0.5) !important;
  color: #fff !important;
}
.entry-content .wp-block-buttons .wp-block-button:last-child .wp-block-button__link:hover {
  background: rgba(255,255,255,0.1) !important;
  border-color: #fff !important;
}

/* old nav sizing removed — see consolidated rule above */

/* === LOGO & FOOTER POLISH — April 17 === */

/* === LOGO WORDMARK — stacked, no chevron === */
.site-header .main-title {
  position: relative !important;
  display: flex !important;
  align-items: flex-end !important;
  padding-bottom: 0.55rem !important;
}
.site-header .main-title a {
  font-size: 0 !important;
  color: transparent !important;
  text-decoration: none !important;
  display: inline-block !important;
  position: relative !important;
  padding-left: 0 !important;
  line-height: 1 !important;
}
/* STRATEGYPLUS */
.site-header .main-title a::after {
  content: "STRATEGYPLUS" !important;
  display: block !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: 0.08em !important;
  line-height: 1 !important;
}
/* FINANCE - smaller, below with gap */
.site-header .main-title::after {
  content: "FINANCE" !important;
  position: absolute !important;
  left: 0 !important;
  bottom: -0.25rem !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: #fff !important;
  letter-spacing: 0.25em !important;
  line-height: 1 !important;
}

/* FOOTER: hide entire GeneratePress site-info bar */
.site-info {
  display: none !important;
}

/* Prevent horizontal scrollbar */
html, body { overflow-x: hidden !important; }

/* FIX: center .spf-container on Coaching & Talent pages */
.spf-container {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  box-sizing: border-box !important;
}

/* FIX: center footer bar (copyright / privacy / terms) */
.spf-footer-bar {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
  box-sizing: border-box !important;
  text-align: center !important;
}

/* FIXED HEADER — persistent on scroll */
.site-header {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 999 !important;
}
.admin-bar .site-header {
  top: 32px !important;
}
@media (max-width: 782px) {
  .admin-bar .site-header {
    top: 46px !important;
  }
}
/* Push page content below fixed header */
.site-content {
  padding-top: 115px !important;
}
body.page .site-content {
  padding-top: 115px !important;
}

/* HERO SECTION FIXES */
/* (1) Make "FINANCE" in eyebrow white */
.spf-eyebrow-finance {
  color: #fff !important;
}
/* (2) Reduce space between People-First and Strategic Finance */
.spf-hero-title {
  line-height: 1.05 !important;
}
.spf-hero-people-first {
  display: block !important;
  margin-bottom: -2.2rem !important;
  line-height: 1 !important;
}
/* (3) Equal spacing above and below descriptor text */
.spf-hero-sub {
  margin-top: 1.2rem !important;
  margin-bottom: 1.2rem !important;
}

/* HERO: full-screen on landing */
body.home .spf-inner-hero {
  min-height: calc(100vh + 96px) !important;
  display: flex !important;
  align-items: center !important;
  padding-top: 115px !important;
}
.admin-bar.home .spf-inner-hero {
  padding-top: 147px !important;
}
/* FIX: remove right/bottom margin on .site-main for homepage */
body.home .site-main {
  margin: 0 !important;
}
/* FIX: no padding-top gap on homepage (hero goes under fixed header) */
body.home .site-content {
  padding-top: 0 !important;
}

/* MISSION CHEVRON: smaller, aligned with statement, hero-toned filter */
.spf-mission-img {
  align-self: start !important;
  margin-top: 2.5rem !important;
}
.spf-mission-img img {
  max-width: 85% !important;
  height: auto !important;
  filter: grayscale(100%) !important;
}

/* FOOTER: hide green triangle SVG in logo */
.spf-footer-logo > svg {
  display: none !important;
}
/* FOOTER: more spacing between social icon links */
.spf-footer-social {
  display: flex !important;
  gap: 1.2rem !important;
  flex-wrap: wrap !important;
}
.spf-footer-social a {
  margin: 0 !important;
}
/* FOOTER: spacing above copyright and between copyright/privacy links */
.spf-footer-bar {
  padding-top: 2rem !important;
  margin-top: 1.5rem !important;
  border-top: 1px solid rgba(255,255,255,0.12) !important;
}
.spf-footer-bar > span {
  display: block !important;
  margin-bottom: 1rem !important;
}
.spf-footer-bar-links {
  margin-top: 0.5rem !important;
}
.spf-footer-bar-links a {
  margin: 0 0.75rem !important;
}

/* FOOTER LOGO: stacked wordmark matching header style */
.spf-footer-logo {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 0 !important;
  line-height: 1 !important;
}
.spf-footer-logo-text {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 0.15rem !important;
}
.spf-footer-logo-top {
  display: block !important;
  font-size: 1.3rem !important;
  font-weight: 700 !important;
  color: #fff !important;
  letter-spacing: 0.08em !important;
  line-height: 1 !important;
}
.spf-footer-logo-bottom {
  display: block !important;
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  color: #fff !important;
  letter-spacing: 0.25em !important;
  line-height: 1 !important;
}
/* FOOTER: align content with page left edge */
.spf-footer-inner {
  max-width: 1200px !important;
  margin: 0 auto !important;
  padding-left: 2rem !important;
  padding-right: 2rem !important;
}

/* CTA BANNER: match button size to reference */
.spf-cta-banner .spf-cta-btn {
  padding: 16px 32px !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  border-radius: 4px !important;
}

/* HERO: Subscribe button — transparent with border */
.spf-cta-btn.spf-cta-btn--outline {
  background-color: transparent !important;
  border: 2px solid #fff !important;
  color: #fff !important;
}
.spf-cta-btn.spf-cta-btn--outline:hover {
  background-color: rgba(255,255,255,0.15) !important;
}

/* FOOTER: social icons two-row layout */
.spf-social-row {
  display: flex !important;
  gap: 1.2rem !important;
  flex-wrap: wrap !important;
}
.spf-footer-social {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.8rem !important;
}

/* FOOTER BAR: copyright left, privacy/terms right on same line */
.spf-footer-bar {
  display: flex !important;
  justify-content: space-between !important;
  align-items: center !important;
  flex-wrap: wrap !important;
}
.spf-footer-bar > span {
  display: inline !important;
  margin-bottom: 0 !important;
}
.spf-footer-bar-links {
  margin-top: 0 !important;
}

/* WHO WE ARE: taller hero showing desk at bottom */
.page-id-16 .spf-inner-hero {
  min-height: 780px !important;
  background-position: center bottom !important;
}

/* WHO WE ARE: OUR VALUES single-column stacked layout */
.page-id-16 .spf-cards-grid--2 {
  grid-template-columns: 1fr !important;
  gap: 1rem !important;
}
.page-id-16 .spf-section-header--center {
  text-align: left !important;
}
.page-id-16 .spf-section-header--center .spf-section-eyebrow {
  text-align: left !important;
}

/* WHO WE ARE: align Manifesto and Values columns at top */
.page-id-16 .spf-two-col--60-40 {
  align-items: start !important;
}

/* SITE-WIDE: increase content width to 1600px */
.grid-container {
  max-width: 1400px !important;
}
.spf-section-inner {
  max-width: 1400px !important;
}
.spf-footer-inner {
  max-width: 1400px !important;
}

/* SITE-WIDE: fix asymmetric site-main margin */
.site-main {
  margin-right: 0 !important;
}

/* HEADER: align with content sections */
.site-header .inside-header.grid-container {
  max-width: none !important;
  padding-left: max(2rem, calc((100% - 1400px) / 2 + 10px)) !important;
  padding-right: max(2rem, calc((100% - 1400px) / 2)) !important;
  justify-content: space-between !important;
}

/* HEADER: push nav links and CTA to right edge */
.main-navigation .main-nav > ul {
  justify-content: flex-end !important;
}

/* HEADER: remove auto margins on inside-navigation so nav fills width */
.main-navigation .inside-navigation.grid-container {
  margin: 0 !important;
  max-width: 100% !important;
}


/* RESPONSIVE: fix edges at narrow viewports */
@media (max-width: 1440px) {
  .spf-footer-brand {
    margin-left: 0 !important;
  }
  .spf-footer-inner {
    padding-left: 3rem !important;
    padding-right: 3rem !important;
  }
}



/* =============================================
   MOBILE NAV: Raise hamburger breakpoint to 1024px
   ============================================= */
@media (max-width: 1024px) {
  /* Show hamburger button in header */
  .has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle {
    display: inline-flex !important;
    align-items: center;
  }
  .mobile-menu-control-wrapper {
    display: block !important;
  }

  /* Hide desktop nav links until toggled */
  .main-navigation:not(.slideout-navigation):not(.toggled) .main-nav > ul,
  .has-inline-mobile-toggle #site-navigation:not(.toggled) .inside-navigation > :not(.navigation-search):not(.main-nav) {
    display: none !important;
  }
  #site-navigation:not(.toggled) .main-nav > ul {
    display: none !important;
  }

  /* When toggled open, show nav as vertical dropdown */
  #site-navigation.toggled .main-nav > ul {
    display: block !important;
    flex-direction: column;
  }
  #site-navigation.toggled .main-nav > ul > li {
    width: 100%;
    text-align: left;
  }
  #site-navigation.toggled .main-nav > ul > li a {
    padding: 12px 20px;
  }

  /* Nav alignment for inline header */
  .nav-align-right:not(.toggled) .inside-navigation {
    display: none !important;
  }
  #site-navigation.toggled .inside-navigation {
    display: block !important;
  }
}

/* Override: ensure mobile wrapper stays hidden above 1024px */
@media (min-width: 1025px) {
  .mobile-menu-control-wrapper {
    display: none !important;
  }
  #site-navigation .main-nav > ul {
    display: flex !important;
  }
}


/* =============================================
   MOBILE NAV: Raise hamburger breakpoint to 1024px
   ============================================= */
@media (max-width: 1024px) {
  /* Show hamburger button in header */
  .has-inline-mobile-toggle .mobile-menu-control-wrapper .menu-toggle {
    display: inline-flex !important;
    align-items: center;
  }
  .mobile-menu-control-wrapper {
    display: block !important;
  }

  /* Hide desktop nav links until toggled */
  .main-navigation:not(.slideout-navigation):not(.toggled) .main-nav > ul,
  .has-inline-mobile-toggle #site-navigation:not(.toggled) .inside-navigation > :not(.navigation-search):not(.main-nav) {
    display: none !important;
  }
  #site-navigation:not(.toggled) .main-nav > ul {
    display: none !important;
  }

  /* When toggled open, show nav as vertical dropdown */
  #site-navigation.toggled .main-nav > ul {
    display: block !important;
    flex-direction: column;
  }
  #site-navigation.toggled .main-nav > ul > li {
    width: 100%;
    text-align: left;
  }
  #site-navigation.toggled .main-nav > ul > li a {
    padding: 12px 20px;
  }

  /* Nav alignment for inline header */
  .nav-align-right:not(.toggled) .inside-navigation {
    display: none !important;
  }
  #site-navigation.toggled .inside-navigation {
    display: block !important;
  }
}

/* Override: ensure mobile wrapper stays hidden above 1024px */
@media (min-width: 1025px) {
  .mobile-menu-control-wrapper {
    display: none !important;
  }
  #site-navigation .main-nav > ul {
    display: flex !important;
  }
}

/* MOBILE HEADER: logo left, hamburger far right */
@media (max-width: 1024px) {
  .site-header .inside-header {
    position: relative !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }
  .site-header .mobile-menu-control-wrapper {
    position: absolute !important;
    right: 20px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    margin: 0 !important;
  }
  .site-header .site-branding {
    margin-right: 0 !important;
  }
  /* Position toggled nav below header */
  #site-navigation {
    position: absolute !important;
    width: 100% !important;
    top: 100%;
    left: 0;
    z-index: 999;
    clear: both;
  }
  #site-navigation.toggled {
    background: var(--spf-navy-dk, #0d1b2a) !important;
  }
}

/* MOBILE MENU: toggled state display */
@media (max-width: 1024px) {
  #site-navigation.toggled {
    display: block !important;
    position: absolute !important;
    width: 100% !important;
    top: 100% !important;
    left: 0 !important;
    z-index: 9999 !important;
    background: var(--spf-navy-dk, #0d1b2a) !important;
    box-shadow: 0 4px 12px rgba(0,0,0,.3);
  }
  #site-navigation.toggled .inside-navigation {
    display: block !important;
  }
  #site-navigation.toggled .main-nav > ul {
    display: block !important;
  }
  #site-navigation.toggled .main-nav > ul > li {
    display: block !important;
    width: 100% !important;
    float: none !important;
  }
  #site-navigation.toggled .main-nav > ul > li > a {
    display: block !important;
    padding: 14px 20px !important;
    color: #fff !important;
    border-bottom: 1px solid rgba(255,255,255,.08);
    font-size: .85rem !important;
  }
  #site-navigation.toggled .main-nav > ul > li > a:hover {
    background: rgba(255,255,255,.05) !important;
    color: var(--spf-teal, #3AABCC) !important;
  }
  /* Style the CTA in mobile menu */
  #site-navigation.toggled .main-nav > ul > li:last-child > a {
    background: var(--spf-teal, #3AABCC) !important;
    color: #fff !important;
    margin: 10px 20px !important;
    border-radius: .5rem !important;
    text-align: center !important;
    border-bottom: none !important;
  }
}

/* MOBILE HEADER: fix overflow clipping mobile dropdown */
@media (max-width: 1024px) {
  .site-header,
  header#masthead {
    overflow: visible !important;
  }
}

/* MOBILE MENU: lock body scroll when menu open (CSS-only via :has) */
@media (max-width: 1024px) {
  html:has(#site-navigation.toggled),
  body:has(#site-navigation.toggled) {
    overflow: hidden !important;
    height: 100% !important;
    position: relative !important;
  }
  #site-navigation.toggled {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    max-height: none !important;
    overflow-y: scroll !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
    z-index: 99999 !important;
    background: var(--spf-navy-dk, #0d1b2a) !important;
    padding-top: 70px !important;
    padding-bottom: 40px !important;
    box-sizing: border-box !important;
    touch-action: pan-y !important;
  }
  #site-navigation.toggled .inside-navigation {
    min-height: 100% !important;
    overflow-y: visible !important;
  }
  #site-navigation.toggled .main-nav > ul {
    overflow-y: visible !important;
  }
  #site-navigation.toggled .main-nav > ul > li:first-child > a {
    border-top: 1px solid rgba(255,255,255,.08);
  }
}

/* INNER PAGES: remove gap between header and hero (not home page) */
body.page:not(.home) .site-content,
body.single .site-content {
  padding-top: 0 !important;
}

/* INSIGHT HUB: stack content cards as single-column list on mobile */
@media (max-width: 768px) {
  .spf-section .spf-container > div > div:nth-child(2) {
    grid-template-columns: 1fr !important;
    gap: 1rem !important;
  }
}
/* INSIGHT HUB: tablet 2 columns */
@media (min-width: 769px) and (max-width: 1024px) {
  .spf-section .spf-container > div > div:nth-child(2) {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

/* INSIGHT HUB HERO: fix subscription box overflow on mobile */
@media (max-width: 768px) {
  .spf-inner-hero-content {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .spf-inner-hero-content > div:nth-child(2) {
    min-width: 0 !important;
    max-width: 100% !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 1.25rem !important;
  }
  .spf-inner-hero-content > div:nth-child(2) > div {
    flex-direction: column !important;
  }
  .spf-inner-hero-content > div:nth-child(2) > div > span {
    min-width: 0 !important;
    width: 100% !important;
  }
  .spf-inner-hero-content > div:nth-child(2) > div > a {
    text-align: center !important;
  }
}

/* PARTNERSHIPS: center the three partnership model steps */
.spf-steps.spf-steps--row {
  padding: 0 2rem !important;
}
.spf-steps.spf-steps--row > div {
  flex: 1 1 0 !important;
}
/* Hide empty trailing P inside steps flex */
.spf-steps.spf-steps--row > p:empty {
  display: none !important;
}
@media (max-width: 768px) {
  .spf-steps.spf-steps--row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 2rem !important;
    padding: 0 1.5rem !important;
  }
  .spf-steps.spf-steps--row > div {
    max-width: 320px !important;
    width: 100% !important;
  }
}


/* PARTNERSHIPS: center the three partnership model steps */
.spf-steps.spf-steps--row {
  padding-left: 3rem !important;
  padding-right: 3rem !important;
}
.spf-steps.spf-steps--row > div {
  flex: 1 1 0% !important;
  min-width: 0 !important;
}
.spf-steps.spf-steps--row > p:empty {
  display: none !important;
  flex: 0 !important;
}
@media (max-width: 768px) {
  .spf-steps.spf-steps--row {
    flex-direction: column !important;
    align-items: center !important;
    gap: 2rem !important;
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
  .spf-steps.spf-steps--row > div {
    max-width: 320px !important;
    width: 100% !important;
  }
}


/* PARTNERSHIPS: ProVisors card - move image below text on mobile */
@media (max-width: 768px) {
  .page-id-18 .spf-section--gray .spf-section-inner > div:nth-child(2) > div:first-child {
    order: 2 !important;
    flex: 1 1 100% !important;
    justify-content: center !important;
    padding: 1.5rem !important;
  }
  .page-id-18 .spf-section--gray .spf-section-inner > div:nth-child(2) > div:nth-child(2) {
    order: 1 !important;
  }
}


/* HOME: reduce chevron image size in Our Mission section */
.spf-mission-img img {
  max-width: 55% !important;
}


/* FOOTER: extend bottom bar line to 1400px */
.spf-footer-bar {
  max-width: 1400px !important;
}


/* WHAT WE DO: make all three service layer box top borders light blue */
.page-id-17 .spf-card {
  border-top-color: var(--spf-teal, #1A7FA8) !important;
}

/* PRIVACY POLICY: remove dark background filter, white content area */
body.page.page-id-26,
body.page-id-26,
.page-id-26,
body.page.page-id-27,
body.page-id-27,
.page-id-27 {
  background-color: #ffffff !important;
  background: #ffffff !important;
}
body.page.page-id-26 .site-content,
body.page-id-26 .site-content,
body.page-id-26 .site,
body.page.page-id-27 .site-content,
body.page-id-27 .site-content,
body.page-id-27 .site {
  background-color: #ffffff !important;
  background: #ffffff !important;
}
body.page.page-id-26 .inside-article,
body.page.page-id-26 .entry-content,
body.page.page-id-27 .inside-article,
body.page.page-id-27 .entry-content {
  max-width: 1400px !important;
  margin: 0 auto !important;
  padding: 2rem 2rem 4rem !important;
  color: #222 !important;
}
.page-id-26 .entry-content h1,
.page-id-27 .entry-content h1 {
  color: var(--spf-navy, #0a0f2c) !important;
  font-size: 2.2rem;
  margin-bottom: 0.5rem;
}
.page-id-26 .entry-content h2,
.page-id-27 .entry-content h2 {
  color: var(--spf-navy, #0a0f2c) !important;
  font-size: 1.5rem;
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
}
.page-id-26 .entry-content h3,
.page-id-27 .entry-content h3 {
  color: var(--spf-navy, #0a0f2c) !important;
  font-size: 1.2rem;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}
.page-id-26 .entry-content p,
.page-id-27 .entry-content p {
  line-height: 1.7;
  margin-bottom: 1rem;
  color: #333 !important;
}
/* PRIVACY POLICY: hide footer columns and CTA */
.page-id-26 .footer-widgets,
.page-id-27 .footer-widgets {
  display: none !important;
}
/* GDPR: Cookie consent bar */
.spf-cookie-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  background: var(--spf-navy, #0a0f2c);
  color: #ffffff;
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.5rem;
  z-index: 99999;
  font-size: 0.9rem;
  line-height: 1.5;
  box-shadow: 0 -2px 10px rgba(0,0,0,0.2);
  flex-wrap: wrap;
}
.spf-cookie-bar p {
  margin: 0;
  color: #ffffff !important;
  flex: 1;
  min-width: 280px;
}
.spf-cookie-bar a {
  color: var(--spf-teal, #1A7FA8) !important;
  text-decoration: underline;
}
.spf-cookie-bar-buttons {
  display: flex;
  gap: 0.75rem;
  flex-shrink: 0;
}
.spf-cookie-accept {
  background: var(--spf-teal, #1A7FA8);
  color: #ffffff;
  border: none;
  padding: 0.5rem 1.5rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  transition: background 0.2s;
}
.spf-cookie-accept:hover {
  background: #1b8ab5;
}
.spf-cookie-decline {
  background: transparent;
  color: #ffffff;
  border: 1px solid rgba(255,255,255,0.4);
  padding: 0.5rem 1.5rem;
  border-radius: 4px;
  cursor: pointer;
  font-size: 0.85rem;
  font-weight: 600;
  transition: border-color 0.2s;
}
.spf-cookie-decline:hover {
  border-color: #ffffff;
}
.spf-cookie-bar.hidden {
  display: none !important;
}

/* ====== OUR COMPANIES: Bottom Badge + Filter Bar ====== */

/* Card layout: flex column to push tag to bottom */
.spf-company-card {
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  padding-bottom: 2.5rem !important;
  min-height: 200px;
}
.spf-company-name { order: 1; }
.spf-company-desc { order: 2; flex: 1; }

/* Type label as bottom-edge badge */
.spf-company-tag {
  order: 3 !important;
  position: absolute !important;
  bottom: 0.75rem !important;
  left: 1.5rem !important;
  margin: 0 !important;
  padding: 0.2rem 0.65rem !important;
  font-size: 0.6rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: var(--spf-teal, #1A7FA8) !important;
  background: rgba(35, 160, 209, 0.08) !important;
  border: 1px solid rgba(35, 160, 209, 0.25) !important;
  border-radius: 999px !important;
  line-height: 1.4 !important;
  white-space: nowrap !important;
}

/* Filter bar above grid */
.spf-company-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 2rem;
  padding: 0 1rem;
}
.spf-company-filter-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.45rem 1.1rem;
  border-radius: 999px;
  border: 1px solid var(--spf-border, #e0e0e0);
  background: #ffffff;
  color: var(--spf-navy, #0a0f2c);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
  line-height: 1.4;
}
.spf-company-filter-btn:hover {
  border-color: var(--spf-teal, #1A7FA8);
  color: var(--spf-teal, #1A7FA8);
}
.spf-company-filter-btn.active {
  background: var(--spf-navy, #0a0f2c);
  color: #ffffff;
  border-color: var(--spf-navy, #0a0f2c);
}
.spf-company-filter-btn .spf-filter-count {
  font-weight: 400;
  opacity: 0.7;
}
.spf-company-filter-btn.active .spf-filter-count {
  opacity: 0.85;
}

/* Card hide/show animation for filtering */
.spf-company-card {
  transition: opacity 0.3s, transform 0.3s !important;
}
.spf-company-card.spf-hidden {
  display: none !important;
}


/* OUR COMPANIES: Multiple badges container */
.spf-company-badges {
  position: absolute !important;
  bottom: 0.75rem !important;
  left: 1.5rem !important;
  right: 1.5rem !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.35rem !important;
  order: 3 !important;
}
.spf-company-badges .spf-badge {
  display: inline-block;
  padding: 0.2rem 0.65rem;
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--spf-teal, #1A7FA8);
  background: rgba(35, 160, 209, 0.08);
  border: 1px solid rgba(35, 160, 209, 0.25);
  border-radius: 999px;
  line-height: 1.4;
  white-space: nowrap;
}
/* Hide original tag when badges are present */
.spf-company-card .spf-company-tag.spf-tag-replaced {
  display: none !important;
}


/* OUR COMPANIES: Condense filter bar to half-screen */
.spf-company-filter-bar {
  max-width: 50% !important;
  margin-left: auto !important;
  margin-right: auto !important;
}


/* OUR COMPANIES: Left-justify filter bar */
.spf-company-filter-bar {
  justify-content: flex-start !important;
}


/* OUR COMPANIES: Full-width filter bar, left-aligned */
.spf-company-filter-bar {
  max-width: 100% !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}


/* OUR COMPANIES: Half-width filter bar, left-aligned */
.spf-company-filter-bar {
  max-width: 50% !important;
  margin-left: 0 !important;
  margin-right: auto !important;
}


/* ====== CLIENT VOICES: Testimonial Carousel ====== */

/* Convert grid to carousel container */
.spf-testimonial-carousel {
  position: relative;
  max-width: 700px;
  margin: 0 auto;
  overflow: hidden;
}
.spf-testimonial-carousel .spf-testimonial {
  display: none;
  text-align: center;
  border: none;
  background: transparent;
  padding: 2rem 3rem;
  opacity: 0;
  transition: opacity 0.5s ease;
}
.spf-testimonial-carousel .spf-testimonial.spf-active {
  display: block;
  opacity: 1;
}
.spf-testimonial-carousel .spf-testimonial-text {
  font-size: 1.1rem;
  line-height: 1.8;
  margin-bottom: 1.25rem;
}
.spf-testimonial-carousel .spf-testimonial-author {
  font-size: 0.9rem;
}

/* Large open-quote decoration */
.spf-testimonial-carousel .spf-testimonial::before {
  content: '\201C';
  display: block;
  font-size: 4rem;
  line-height: 1;
  color: var(--spf-teal, #1A7FA8);
  opacity: 0.3;
  margin-bottom: -0.5rem;
  font-family: Georgia, serif;
}

/* Navigation arrows */
.spf-carousel-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  font-size: 1.8rem;
  color: var(--spf-teal, #1A7FA8);
  cursor: pointer;
  padding: 0.5rem;
  opacity: 0.5;
  transition: opacity 0.2s;
  z-index: 2;
  line-height: 1;
}
.spf-carousel-arrow:hover {
  opacity: 1;
}
.spf-carousel-arrow--prev { left: 0; }
.spf-carousel-arrow--next { right: 0; }

/* Dot indicators */
.spf-carousel-dots {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-top: 1.25rem;
}
.spf-carousel-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--spf-border, #e0e0e0);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: background 0.2s, transform 0.2s;
}
.spf-carousel-dot.spf-dot-active {
  background: var(--spf-teal, #1A7FA8);
  transform: scale(1.3);
}

/* Hide original grid layout when carousel is active */
.spf-cards-grid.spf-carousel-converted {
  display: block !important;
  grid-template-columns: none !important;
  gap: 0 !important;
}


/* What We Look For - box style on Talent page */
.spf-what-we-look-for {
  margin-top: 2.5rem !important;
  border-radius: 12px !important;
  max-width: 1100px;
  margin-left: auto !important;
  margin-right: auto !important;
  overflow: hidden;
}


/* ── Job posting page: top spacing so header doesn't overlap ── */
.role-hero {
  padding-top: 110px !important;
}

/* ── Footer copyright bar: prevent cut-off on mobile/iPad ── */
@media (max-width: 1024px) {
  .spf-footer-bar {
    padding-left: 1.5rem !important;
    padding-right: 1.5rem !important;
  }
}
@media (max-width: 600px) {
  .spf-footer-bar {
    padding-left: 1.25rem !important;
    padding-right: 1.25rem !important;
    flex-direction: column !important;
    gap: 0.5rem !important;
    text-align: center !important;
  }
}
/* ── Footer copyright bar: increase left indent ── */
.spf-footer-bar {
  padding-left: 52px !important;
}

/* ── Hero title: extra spacing between People-First and Strategic Finance on mobile ── */
.spf-hero-people-first {
  display: block;
  padding-bottom: 0.15em;
}
@media (max-width: 768px) {
  .spf-hero-title {
    line-height: 1.5 !important;
  }
  .spf-hero-people-first {
    padding-bottom: 0.25em;
  }
}

/* =============================================
   ACCESSIBILITY FIXES (WCAG 2.1 AA)
   ============================================= */

/* Fix: Footer copyright bar text contrast (4.35:1 → 5.14:1) */
.spf-footer-bar {
  color: rgba(255, 255, 255, 0.62) !important;
}


/* HUBSPOT NEWSLETTER FORM STYLING */
#hs-newsletter-form {
  width: 100%;
}
#hs-newsletter-form .hs-form {
  display: flex !important;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 8px;
}
#hs-newsletter-form .hs-form fieldset {
  max-width: none !important;
  flex: 1;
  min-width: 0;
}
#hs-newsletter-form .hs-form .hs-form-field {
  margin-bottom: 0 !important;
}
#hs-newsletter-form .hs-form .hs-form-field > label {
  display: none !important;
}
#hs-newsletter-form .hs-form .input {
  margin-right: 0 !important;
}
#hs-newsletter-form .hs-form input[type="text"],
#hs-newsletter-form .hs-form input[type="email"] {
  background: rgba(255,255,255,0.12) !important;
  border: 1px solid rgba(255,255,255,0.25) !important;
  border-radius: 6px !important;
  color: #fff !important;
  padding: 10px 14px !important;
  font-size: .9rem !important;
  width: 100% !important;
  box-sizing: border-box;
}
#hs-newsletter-form .hs-form input[type="text"]::placeholder,
#hs-newsletter-form .hs-form input[type="email"]::placeholder {
  color: rgba(255,255,255,0.5) !important;
}
#hs-newsletter-form .hs-form .hs-submit {
  flex-shrink: 0;
}
#hs-newsletter-form .hs-form .hs-button {
  background: var(--spf-teal) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 6px !important;
  padding: 10px 22px !important;
  font-weight: 600 !important;
  font-size: .9rem !important;
  cursor: pointer !important;
  white-space: nowrap;
  transition: background .2s;
}
#hs-newsletter-form .hs-form .hs-button:hover {
  background: #156d8f !important;
}
#hs-newsletter-form .hs-form .hs-error-msgs {
  color: #ff6b6b !important;
  font-size: .8rem !important;
  margin-top: 4px;
}
#hs-newsletter-form .hs-form .submitted-message {
  color: #4ade80 !important;
  font-size: .95rem;
}
@media (max-width: 600px) {
  #hs-newsletter-form .hs-form {
    flex-direction: column;
  }
  #hs-newsletter-form .hs-form fieldset,
  #hs-newsletter-form .hs-form .hs-submit {
    width: 100%;
  }
}