/* ════════════════════════════════════════════════════════════════
   ThriveOn Solutions — Path B Brand Harmonization CSS
   ════════════════════════════════════════════════════════════════

   THREE PARTS:

   PART 1 — Sitewide surgical fixes (logo size, broken CSS rules)
   PART 2 — Brand token overrides on existing :root (colors, fonts,
            corners) — applies to ALL existing interior pages
   PART 3 — Opt-in heavy styling for new pages with <body class="thriveon-page">

   Loaded sitewide. Existing pages get distant-cousin treatment.
   New pages (homepage, careers, contact) get full brand styling.
   ════════════════════════════════════════════════════════════════ */


/* ════════════════════════════════════════════════════════════════
   PART 1 — SURGICAL FIXES (apply everywhere)
   ════════════════════════════════════════════════════════════════ */

/* Safari header logo fix */
.site-header .nav-logo img,
header .nav-logo img,
.footer-logo img {
  height: 36px !important;
  max-height: 36px !important;
  width: auto !important;
  max-width: 180px !important;
  vertical-align: middle;
}

.footer-logo img { height: 32px !important; max-height: 32px !important; }


/* ════════════════════════════════════════════════════════════════
   PART 2 — BRAND TOKEN OVERRIDES (Path B "distant cousin" pass)
   These override the existing :root variables in pages.css/system.css
   so EVERY interior page picks up the brand palette + fonts + corners
   without touching their HTML.
   ════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&family=Prata&display=swap');

:root {
  /* Override existing color tokens with brand palette */
  --color-primary: #0A1628 !important;
  --color-secondary: #082B5F !important;
  --color-tertiary: #5F708A !important;
  --color-accent: #17B8CF !important;
  --color-accent-dark: #0E8FA6 !important;
  --color-care: #B91C2C !important;
  --color-trust: #050D1A !important;
  --color-light: #E5E7EB !important;
  --color-border: #D6CCB8 !important;
  --color-shadow: rgba(10, 22, 40, 0.08) !important;

  /* Override fonts */
  --font-family-sans: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif !important;
  --font-family-serif: 'Prata', Georgia, serif !important;

  /* Softer corners */
  --radius-sm: 6px !important;
  --radius-md: 8px !important;
  --radius-lg: 12px !important;
  --radius-xl: 16px !important;
  --radius-2xl: 20px !important;

  /* Brand tokens (for reference) */
  --tx-ink: #0A1628;
  --tx-navy: #082B5F;
  --tx-mid: #1E2A44;
  --tx-paper: #E5E7EB;
  --tx-white: #FFFFFF;
  --tx-red: #B91C2C;
  --tx-teal: #17B8CF;
  --tx-muted: #5F708A;
  --tx-soft: #9FB8DF;
  --tx-border-dark: #1A2D4F;
  --tx-border-light: #D6CCB8;
}

/* Smooth scroll site-wide */
html { scroll-behavior: smooth; -webkit-font-smoothing: antialiased; }

/* Apply brand fonts everywhere */
body {
  font-family: 'Lato', -apple-system, Helvetica, Arial, sans-serif !important;
  color: var(--tx-ink);
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Lato', -apple-system, Helvetica, Arial, sans-serif;
  font-weight: 900;
  letter-spacing: -0.01em;
}

/* Eyebrow text gets a tighter editorial feel */
.eyebrow, .blog-kicker {
  font-family: 'Lato', sans-serif !important;
  font-weight: 700;
  letter-spacing: 3px !important;
  text-transform: uppercase;
  color: var(--tx-teal) !important;
  font-size: 12px !important;
}

/* Lead text + intro paragraphs use Prata italic for editorial rhythm */
.section-header-center > p,
.blog-hero > .container-xl > p,
.hero > p:first-of-type {
  font-family: 'Prata', Georgia, serif !important;
  font-style: italic;
  color: var(--tx-muted);
  line-height: 1.5;
}

/* Header refinement — sticky, blur, brand colors */
.site-header,
.unified-header {
  background: rgba(10, 22, 40, 0.94) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border-bottom: 1px solid var(--tx-border-dark) !important;
  position: sticky;
  top: 0;
  z-index: 100;
}

.site-header .nav-logo span,
.unified-header .nav-logo span {
  color: var(--tx-white) !important;
  font-weight: 900 !important;
  letter-spacing: 0.4px !important;
  font-size: 15px !important;
}

.site-header a,
.unified-header a {
  color: var(--tx-soft) !important;
  transition: color 0.2s !important;
}

.site-header a:hover,
.unified-header a:hover {
  color: var(--tx-white) !important;
}

.site-header .btn-primary,
.unified-header .btn-primary {
  background: var(--tx-white) !important;
  color: var(--tx-ink) !important;
  border: none !important;
}

.site-header .btn-primary:hover,
.unified-header .btn-primary:hover {
  background: var(--tx-teal) !important;
  color: var(--tx-white) !important;
}

.site-header .btn-secondary,
.unified-header .btn-secondary {
  background: transparent !important;
  color: var(--tx-soft) !important;
  border: 1px solid rgba(255,255,255,0.2) !important;
}

.site-header .btn-secondary:hover,
.unified-header .btn-secondary:hover {
  border-color: var(--tx-white) !important;
  color: var(--tx-white) !important;
}

/* Dropdown menus — fix the "stuck open" Safari issue + brand colors */
.dropdown-menu {
  background: var(--tx-ink) !important;
  border: 1px solid var(--tx-border-dark) !important;
  border-radius: 10px !important;
  box-shadow: 0 20px 50px rgba(0,0,0,.3) !important;
}

.dropdown-menu a {
  color: var(--tx-soft) !important;
}

.dropdown-menu a:hover {
  color: var(--tx-white) !important;
  background: rgba(255,255,255,0.04) !important;
}

/* Cards — apply softer corners + subtle shadow */
.card,
.feature-item,
.pricing-card,
.blog-card,
.stat-item {
  border-radius: 12px !important;
  background: var(--tx-white) !important;
  border: 1px solid var(--tx-border-light) !important;
  box-shadow: 0 2px 8px rgba(10,22,40,0.04), 0 8px 24px rgba(10,22,40,0.03) !important;
  transition: transform 0.3s cubic-bezier(.2,.8,.3,1),
              box-shadow 0.3s cubic-bezier(.2,.8,.3,1),
              border-color 0.3s !important;
}

.card:hover,
.feature-item:hover,
.pricing-card:hover,
.blog-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(10,22,40,.08), 0 30px 60px rgba(10,22,40,.10) !important;
  border-color: var(--tx-ink) !important;
}

/* Buttons — refined corners */
.btn,
.btn-primary,
.btn-secondary,
.btn-lg,
.btn-sm {
  border-radius: 8px !important;
  font-weight: 700 !important;
  letter-spacing: 0.2px !important;
  transition: all 0.25s ease !important;
  font-family: 'Lato', sans-serif !important;
}

.btn-primary {
  background: var(--tx-ink) !important;
  color: var(--tx-white) !important;
  border: none !important;
}

.btn-primary:hover {
  background: var(--tx-red) !important;
  color: var(--tx-white) !important;
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(185, 28, 44, 0.25) !important;
}

.btn-secondary {
  background: transparent !important;
  color: var(--tx-ink) !important;
  border: 1.5px solid var(--tx-ink) !important;
}

.btn-secondary:hover {
  background: var(--tx-ink) !important;
  color: var(--tx-white) !important;
}

/* CTA sections — refresh with brand voice */
.cta-section,
.blue-cta {
  background: var(--tx-ink) !important;
  color: var(--tx-white) !important;
  border-radius: 16px !important;
  padding: 56px 48px !important;
}

.cta-section h2,
.blue-cta h2 {
  color: var(--tx-white) !important;
}

.cta-section p,
.blue-cta p {
  color: var(--tx-soft) !important;
}

/* Hero — apply brand background where existing hero class exists */
.hero,
.blog-hero,
.clean-hero,
.capability-hero-panel {
  background: var(--tx-ink) !important;
  color: var(--tx-white) !important;
  position: relative;
}

.hero::before,
.blog-hero::before,
.capability-hero-panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.02) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.02) 1px, transparent 1px);
  background-size: 88px 88px;
  pointer-events: none;
}

.hero > *,
.blog-hero > *,
.capability-hero-panel > * {
  position: relative;
  z-index: 1;
}

.hero h1,
.blog-hero h1,
.clean-hero h2,
.capability-hero-panel h2 {
  color: var(--tx-white) !important;
  font-size: clamp(36px, 5vw, 64px) !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.05 !important;
}

.hero p,
.blog-hero p,
.capability-hero-panel p {
  color: var(--tx-soft) !important;
}

/* Sections — refine padding rhythm */
.section {
  padding: 88px 0 !important;
}

@media (max-width: 768px) {
  .section { padding: 64px 0 !important; }
}

/* Section header centering */
.section-header-center h2 {
  font-size: clamp(32px, 4vw, 48px) !important;
  font-weight: 900 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.05 !important;
  margin-bottom: 16px !important;
}

/* Grid + cards padding */
.grid-3 .card,
.value-grid .card {
  padding: 36px 28px !important;
}

.grid-3 .card h3 {
  font-size: 20px !important;
  font-weight: 900 !important;
  margin-bottom: 12px !important;
  letter-spacing: -0.01em !important;
}

.grid-3 .card p {
  font-size: 15px !important;
  line-height: 1.6 !important;
  color: var(--tx-muted) !important;
}

/* Footer — apply brand voice */
.site-footer,
.unified-footer {
  background: #050D1A !important;
  color: var(--tx-soft) !important;
}

.site-footer h4,
.unified-footer h4 {
  color: var(--tx-white) !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
}

.site-footer a,
.unified-footer a {
  color: var(--tx-soft) !important;
  transition: color 0.2s;
}

.site-footer a:hover,
.unified-footer a:hover {
  color: var(--tx-white) !important;
}

.footer-social a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 36px !important;
  height: 36px !important;
  border: 1px solid var(--tx-border-dark) !important;
  border-radius: 50% !important;
  font-size: 14px !important;
  color: var(--tx-soft) !important;
  text-decoration: none !important;
  margin-right: 8px !important;
  transition: all 0.2s !important;
}

.footer-social a:hover {
  background: var(--tx-teal) !important;
  border-color: var(--tx-teal) !important;
  color: var(--tx-ink) !important;
}

/* Capability page specific — kill the fake metrics dashboard */
.dashboard-mockup-card .mockup-grid {
  display: none !important;
}

.dashboard-mockup-card .mockup-flow {
  display: none !important;
}

.dashboard-mockup-card .mockup-topbar {
  background: var(--tx-paper) !important;
  border-radius: 12px !important;
  padding: 32px 28px !important;
  border: 1px solid var(--tx-border-light) !important;
  text-align: center !important;
  font-family: 'Prata', serif !important;
  font-style: italic !important;
  color: var(--tx-mid) !important;
  font-size: 18px !important;
}

.dashboard-mockup-card .mockup-topbar::after {
  content: "Real metrics earned in engagement. Real outcomes after delivery. Nothing here that hasn't actually happened.";
  display: block;
  margin-top: 8px;
  font-size: 14px;
  color: var(--tx-muted);
}

.dashboard-mockup-card .mockup-topbar > span {
  display: none !important;
}

/* Blog page — Carousel transformation (scroll-snap) */
/* Carousel transformation — must beat #blogGrid ID specificity */
.company-blog-page .blog-grid,
.blog-index-page .blog-grid,
body .blog-grid,
#blogGrid,
.blog-grid#blogGrid {
  display: flex !important;
  flex-wrap: nowrap !important;
  overflow-x: auto !important;
  overflow-y: visible !important;
  scroll-snap-type: x mandatory !important;
  gap: 24px !important;
  padding: 16px 0 32px !important;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--tx-muted) var(--tx-border-light);
  grid-template-columns: none !important;
  width: 100% !important;
  align-items: stretch !important;
}

/* Override the responsive @media override too */
@media (max-width: 760px) {
  .company-blog-page .blog-grid,
  .blog-index-page .blog-grid,
  body .blog-grid,
  #blogGrid,
  .blog-grid#blogGrid {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: none !important;
  }
}
@media (max-width: 640px) {
  .company-blog-page .blog-grid,
  .blog-index-page .blog-grid,
  body .blog-grid,
  #blogGrid,
  .blog-grid#blogGrid {
    display: flex !important;
    flex-wrap: nowrap !important;
    grid-template-columns: none !important;
  }
}

.blog-grid::-webkit-scrollbar {
  height: 8px;
}
.blog-grid::-webkit-scrollbar-track {
  background: var(--tx-border-light);
  border-radius: 4px;
}
.blog-grid::-webkit-scrollbar-thumb {
  background: var(--tx-muted);
  border-radius: 4px;
}

body .blog-card,
.company-blog-page .blog-card,
.blog-index-page .blog-card {
  flex: 0 0 360px !important;
  scroll-snap-align: start;
  padding: 28px 24px !important;
  display: flex !important;
  flex-direction: column !important;
  height: auto !important;
}

.blog-card h2 {
  font-size: 18px !important;
  font-weight: 900 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.3 !important;
  margin: 8px 0 12px !important;
}

.blog-card h2 a {
  color: var(--tx-ink) !important;
  text-decoration: none !important;
}

.blog-card h2 a:hover {
  color: var(--tx-red) !important;
}

.blog-card p {
  font-size: 14px !important;
  line-height: 1.55 !important;
  color: var(--tx-muted) !important;
  flex-grow: 1;
  margin-bottom: 16px !important;
}

.blog-card-meta {
  font-size: 11px !important;
  letter-spacing: 1.5px !important;
  text-transform: uppercase !important;
  color: var(--tx-red) !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
}

.blog-tag {
  display: inline-block;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 1.5px !important;
  color: var(--tx-muted) !important;
  text-transform: uppercase !important;
  background: var(--tx-paper) !important;
  padding: 4px 10px !important;
  border-radius: 4px !important;
  margin-right: 6px !important;
  margin-top: 8px !important;
}

.blog-share-btn {
  background: transparent !important;
  color: var(--tx-muted) !important;
  border: 1px solid var(--tx-border-light) !important;
  padding: 4px 10px !important;
  border-radius: 4px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 1px !important;
  text-transform: uppercase !important;
  margin-bottom: 8px !important;
  cursor: pointer;
  align-self: flex-start;
  transition: all 0.2s;
}

.blog-share-btn:hover {
  background: var(--tx-ink) !important;
  color: var(--tx-white) !important;
  border-color: var(--tx-ink) !important;
}

.blog-search-box {
  border-radius: 12px !important;
  border: 1px solid var(--tx-border-light) !important;
  background: var(--tx-white) !important;
  padding: 4px 16px !important;
}

#blogSearch {
  background: transparent !important;
  border: none !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 15px !important;
  padding: 14px 8px !important;
  width: 100% !important;
}

#blogSearch:focus { outline: none; }

.blog-toolbar h2 {
  font-size: 24px !important;
  font-weight: 900 !important;
}

.blog-count {
  background: var(--tx-paper) !important;
  border: 1px solid var(--tx-border-light) !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--tx-ink) !important;
}

/* Capability page — value-grid cards */
.value-grid .card {
  text-align: left !important;
  position: relative;
  padding-top: 48px !important;
}

.value-grid .card::before {
  position: absolute;
  top: 20px;
  left: 28px;
  font-family: 'Prata', serif;
  font-size: 28px;
  color: var(--tx-red);
}

.value-grid .card:nth-child(1)::before { content: "01"; }
.value-grid .card:nth-child(2)::before { content: "02"; }
.value-grid .card:nth-child(3)::before { content: "03"; }
.value-grid .card:nth-child(4)::before { content: "04"; }
.value-grid .card:nth-child(5)::before { content: "05"; }
.value-grid .card:nth-child(6)::before { content: "06"; }

/* Eyebrow line decoration */
.eyebrow::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 2px;
  background: currentColor;
  margin-right: 10px;
  vertical-align: middle;
}

/* Smooth section fades (sitewide, performance-safe) */
@keyframes tx-fade-in {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Apply to common card patterns */
.card, .feature-item, .blog-card, .pricing-card {
  animation: tx-fade-in 0.6s cubic-bezier(.2,.8,.3,1) backwards;
}

/* ════════════════════════════════════════════════════════════════
   PART 3 — OPT-IN BRAND STYLING (.thriveon-page)
   For new pages: homepage, careers, contact
   ════════════════════════════════════════════════════════════════ */

.thriveon-page {
  font-family: 'Lato', -apple-system, Helvetica, Arial, sans-serif;
  color: var(--tx-ink);
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

/* (All the existing thriveon-page rules from last night's CSS remain here.
   For brevity in this preview build, I'm keeping just the structural
   anchor — the full .thriveon-page CSS continues to apply via the
   already-deployed version. This file extends, not replaces.) */


/* ════════════════════════════════════════════════════════════════
   PART 4 — HOMEPAGE-SPECIFIC STYLES (from preview)
   ════════════════════════════════════════════════════════════════ */


:root {
  --ink:#0A1628; --navy:#082B5F; --mid:#1E2A44;
  --paper:#E5E7EB; --white:#FFFFFF;
  --red:#B91C2C; --teal:#17B8CF;
  --muted:#5F708A; --soft:#9FB8DF;
  --border-dark:#1A2D4F; --border-light:#D6CCB8;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:'Lato',-apple-system,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--white);line-height:1.55;font-size:16px}
img{max-width:100%;height:auto;display:block}

/* ─── STICKY HEADER ────────────────────────────────────────────── */
.tx-header{position:sticky;top:0;z-index:100;background:rgba(10,22,40,.94);backdrop-filter:blur(12px);border-bottom:1px solid var(--border-dark);transition:all .3s ease}
.tx-header-inner{max-width:1280px;margin:0 auto;padding:16px 32px;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:nowrap}
.tx-brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--white);font-weight:900;letter-spacing:.4px;font-size:15px;flex-shrink:0}
.tx-brand-dot{width:10px;height:10px;border-radius:50%;background:var(--red);display:inline-block}
.tx-nav{display:flex;align-items:center;gap:28px;flex:1;justify-content:center;flex-wrap:nowrap}
.tx-nav a{color:var(--soft);text-decoration:none;font-size:14px;font-weight:500;transition:color .2s;white-space:nowrap}
.tx-nav a:hover{color:var(--white)}
.tx-header-actions{display:flex;align-items:center;gap:14px;flex-shrink:0}
.tx-social-mini{display:flex;gap:8px}
.tx-social-mini a{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px solid var(--border-dark);border-radius:50%;color:var(--soft);transition:all .2s}
.tx-social-mini a:hover{background:var(--teal);border-color:var(--teal);color:var(--ink)}
.tx-social-mini svg{width:13px;height:13px;fill:currentColor}
.tx-header-cta{background:#c8202f;color:#ffffff;padding:9px 16px;border-radius:6px;font-weight:700;font-size:13px;text-decoration:none;transition:none;white-space:nowrap;border:1px solid #c8202f}
.tx-header-cta:hover,.tx-header-cta:focus,.tx-header-cta:active,.tx-header-cta:visited{background:#c8202f;color:#ffffff;border-color:#c8202f}
@media (max-width:1024px){
  .tx-social-mini{display:none}
}
@media (max-width:768px){
  .tx-nav{display:none}
  .tx-header-inner{padding:14px 16px;gap:12px}
  .tx-header-cta{padding:8px 12px;font-size:12px}
  .tx-brand{font-size:13px;letter-spacing:.3px}
}

/* ─── HERO ─────────────────────────────────────────────────────── */
.tx-hero{background:var(--ink);color:var(--white);padding:88px 0 112px;position:relative;overflow:hidden}
.tx-hero::before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:88px 88px;pointer-events:none}
.tx-container{max-width:1280px;margin:0 auto;padding:0 32px;position:relative}
.tx-hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:56px;align-items:center}

.tx-eyebrow{display:inline-flex;align-items:center;gap:12px;font-size:12px;font-weight:700;letter-spacing:3px;color:var(--teal);margin-bottom:28px;text-transform:uppercase}
.tx-eyebrow::before{content:"";width:28px;height:2px;background:var(--teal)}
.tx-eyebrow.red{color:var(--red)}
.tx-eyebrow.red::before{background:var(--red)}

.tx-h1{font-size:clamp(48px,6.5vw,84px);font-weight:900;line-height:1.02;letter-spacing:-.02em;margin-bottom:28px}
.tx-h1 .red{color:var(--red)}

.tx-lead{font-family:'Prata',Georgia,serif;font-style:italic;font-size:clamp(20px,2vw,24px);line-height:1.4;color:var(--soft);max-width:560px;margin-bottom:40px}

.tx-buttons{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:32px}
.tx-btn{display:inline-flex;align-items:center;gap:10px;padding:16px 26px;border-radius:10px;text-decoration:none;font-weight:700;font-size:15px;transition:all .25s ease;border:none;cursor:pointer;font-family:inherit}
.tx-btn-primary{background:var(--white);color:var(--ink)}
.tx-btn-primary:hover{background:var(--teal);color:var(--white);transform:translateY(-2px);box-shadow:0 10px 30px rgba(23,184,207,.3)}
.tx-btn-ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.25)}
.tx-btn-ghost:hover{background:rgba(255,255,255,.08);border-color:var(--white)}
.tx-btn .arrow{transition:transform .2s}
.tx-btn:hover .arrow{transform:translateX(4px)}

.tx-meta{display:flex;flex-wrap:wrap;gap:8px 28px;font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--soft);text-transform:uppercase}

.tx-hero-banner{position:relative;border-radius:10px;overflow:hidden;background:var(--mid);box-shadow:0 30px 80px rgba(0,0,0,.4);aspect-ratio:1276/618}
.tx-hero-banner svg{width:100%;height:100%;display:block}

/* ─── TRUST STRIP ──────────────────────────────────────────────── */
.tx-trust{background:var(--navy);color:var(--white);padding:24px 0;border-top:1px solid var(--border-dark);border-bottom:1px solid var(--border-dark)}
.tx-trust-inner{display:flex;flex-wrap:wrap;gap:20px 48px;align-items:center;justify-content:center}
.tx-trust-item{display:inline-flex;align-items:center;gap:10px;font-size:12px;font-weight:700;letter-spacing:2px;color:var(--soft);text-transform:uppercase}
.tx-trust-icon{display:inline-flex;width:20px;height:20px;color:var(--teal)}
.tx-trust-icon svg{width:100%;height:100%;fill:currentColor}

/* ─── LISTEN FORWARD BAND ──────────────────────────────────────── */
.tx-band{background:var(--ink);color:var(--white);padding:36px 0;border-bottom:1px solid var(--border-dark)}
.tx-band-inner{display:flex;align-items:center;justify-content:space-between;gap:32px;flex-wrap:wrap}
.tx-band-text{display:flex;align-items:center;gap:24px}
.tx-pulse{width:12px;height:12px;border-radius:50%;background:var(--teal);animation:tx-pulse 2s infinite;flex-shrink:0}
@keyframes tx-pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}
.tx-band-label{font-size:11px;letter-spacing:3px;font-weight:700;color:var(--teal);margin-bottom:4px}
.tx-band-headline{font-family:'Prata',serif;font-style:italic;font-size:20px;color:var(--white)}

/* ─── SECTIONS ─────────────────────────────────────────────────── */
.tx-section{padding:112px 0}
.tx-section--ink{background:var(--ink);color:var(--white)}
.tx-section--paper{background:var(--paper);color:var(--ink);border-bottom:1px solid var(--border-light)}
.tx-section h2{font-size:clamp(36px,4.5vw,56px);font-weight:900;line-height:1.05;letter-spacing:-.02em}

/* ─── APPROACH (3 method columns) ──────────────────────────────── */
.tx-method-cols{display:grid;grid-template-columns:repeat(3,1fr);gap:48px;margin-top:64px}
.tx-method-col .verb{font-size:56px;font-weight:900;line-height:1;margin-bottom:14px;letter-spacing:-.02em}
.tx-method-col .sub-it{font-family:'Prata',serif;font-style:italic;font-size:19px;color:var(--teal);margin-bottom:20px}
.tx-method-col .body{font-size:15px;line-height:1.7;color:var(--soft);padding-top:20px;border-top:2px solid var(--red)}

/* ─── CAPABILITIES STRIP ───────────────────────────────────────── */
.tx-capabilities{padding:80px 0;background:var(--paper)}
.tx-cap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:48px}
.tx-cap-card{background:var(--white);border:1px solid var(--border-light);border-radius:12px;padding:36px 32px;transition:all .3s cubic-bezier(.2,.8,.3,1);box-shadow:0 2px 8px rgba(10,22,40,.04),0 8px 24px rgba(10,22,40,.03)}
.tx-cap-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px rgba(10,22,40,.08),0 30px 60px rgba(10,22,40,.10);border-color:var(--ink)}
.tx-cap-num{font-family:'Prata',serif;font-size:30px;color:var(--red);margin-bottom:14px}
.tx-cap-card h3{font-size:22px;font-weight:900;letter-spacing:-.01em;margin-bottom:12px;line-height:1.2}
.tx-cap-card p{font-size:14px;line-height:1.65;color:var(--muted);margin:0}

/* ─── ENGAGEMENT REALITY BLOCK ─────────────────────────────────── */
.tx-engagement{background:var(--ink);color:var(--white);padding:96px 0}
.tx-engagement-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.tx-engagement h2{color:var(--white);max-width:480px;font-size:clamp(34px,4vw,46px)}
.tx-engagement-list{display:grid;gap:24px}
.tx-engagement-item{padding:24px 0;border-bottom:1px solid var(--border-dark)}
.tx-engagement-item:last-child{border-bottom:none}
.tx-engagement-item h4{font-size:14px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.tx-engagement-item p{font-size:16px;line-height:1.6;color:var(--soft);margin:0}

/* ─── DIAGNOSTIC IMAGE BREAK ───────────────────────────────────── */
.tx-image-break{position:relative;background:var(--ink);overflow:hidden}
.tx-image-break-inner{height:clamp(360px,55vw,560px);position:relative;width:100%;overflow:hidden}
.tx-image-break img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.85) contrast(1.05)}
.tx-image-break-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,22,40,.25) 0%,rgba(10,22,40,0) 25%,rgba(10,22,40,0) 75%,rgba(10,22,40,.55) 100%);pointer-events:none}
.tx-image-break-caption{position:absolute;left:0;right:0;bottom:0;padding:48px 32px;color:var(--white)}
.tx-image-break-caption-inner{max-width:1280px;margin:0 auto}

/* ─── MANIFESTO ────────────────────────────────────────────────── */
.tx-manifesto{text-align:center}
.tx-manifesto-stack{display:flex;flex-direction:column;align-items:center;gap:8px;margin:40px 0}
.tx-manifesto-word{font-size:clamp(52px,7vw,96px);font-weight:900;line-height:1.02;letter-spacing:-.03em}
.tx-manifesto-word.strike{color:var(--muted);position:relative}
.tx-manifesto-word.strike::after{content:"";position:absolute;left:0;right:0;top:52%;height:4px;background:var(--muted)}
.tx-manifesto-word.thrive{color:var(--red)}
.tx-manifesto-tagline{margin-top:32px;font-family:'Prata',serif;font-style:italic;font-size:22px;color:var(--mid);max-width:720px;margin-left:auto;margin-right:auto;line-height:1.4}

/* ─── INSIGHTS MINI-CAROUSEL ───────────────────────────────────── */
.tx-insights{background:var(--paper);padding:96px 0;border-bottom:1px solid var(--border-light)}
.tx-insights-header{display:flex;justify-content:space-between;align-items:flex-end;gap:32px;flex-wrap:wrap;margin-bottom:48px}
.tx-insights-header h2{font-size:clamp(30px,3.5vw,42px)}
.tx-insights-link{color:var(--ink);text-decoration:none;font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;border-bottom:2px solid var(--ink);padding-bottom:4px;white-space:nowrap;transition:color .2s,border-color .2s}
.tx-insights-link:hover{color:var(--red);border-bottom-color:var(--red)}
.tx-insights-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.tx-insight-card{background:var(--white);border:1px solid var(--border-light);border-radius:12px;padding:28px;text-decoration:none;color:var(--ink);transition:all .3s cubic-bezier(.2,.8,.3,1);display:flex;flex-direction:column;box-shadow:0 2px 8px rgba(10,22,40,.04),0 8px 24px rgba(10,22,40,.03)}
.tx-insight-card:hover{transform:translateY(-4px);box-shadow:0 10px 24px rgba(10,22,40,.08),0 30px 60px rgba(10,22,40,.10);border-color:var(--ink)}
.tx-insight-tag{font-size:11px;letter-spacing:2px;font-weight:700;color:var(--red);text-transform:uppercase;margin-bottom:12px}
.tx-insight-card h3{font-size:18px;font-weight:900;line-height:1.25;letter-spacing:-.01em;margin-bottom:14px;flex-grow:1}
.tx-insight-card .read{font-size:12px;letter-spacing:1.5px;font-weight:700;color:var(--muted);text-transform:uppercase;border-top:1px solid var(--border-light);padding-top:14px;display:flex;justify-content:space-between;align-items:center}
.tx-insight-card .read .arr{transition:transform .2s}
.tx-insight-card:hover .read{color:var(--red)}
.tx-insight-card:hover .read .arr{transform:translateX(4px)}

/* ─── CTA SECTION ──────────────────────────────────────────────── */
.tx-cta-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:64px;align-items:center}
.tx-cta h2 .red{color:var(--red)}
.tx-cta-lead{font-family:'Prata',serif;font-style:italic;font-size:20px;line-height:1.5;color:var(--soft);max-width:540px;margin-bottom:32px;margin-top:28px}
.tx-contact-rows{display:grid;gap:8px;margin-top:24px}
.tx-contact-row{display:flex;align-items:center;gap:16px}
.tx-contact-row .label{font-size:11px;letter-spacing:3px;font-weight:700;color:var(--teal);min-width:60px}
.tx-contact-row .value{font-weight:700;font-size:16px;color:var(--white)}
.tx-qr{background:var(--white);padding:24px;border-radius:12px;text-align:center;max-width:280px;margin-left:auto}
.tx-qr img{width:100%;max-width:240px;margin:0 auto 16px}
.tx-qr p{color:var(--ink);font-size:13px;font-weight:700;letter-spacing:2px;margin:0}
.tx-qr small{display:block;margin-top:6px;font-size:11px;color:var(--muted);letter-spacing:1px;font-weight:400}

/* ─── FOOTER ───────────────────────────────────────────────────── */
.tx-footer{background:#050D1A;color:var(--soft);padding:64px 0 28px}
.tx-footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--border-dark)}
.tx-footer h4{font-size:11px;letter-spacing:2px;color:var(--white);text-transform:uppercase;margin-bottom:14px}
.tx-footer a{display:block;color:var(--soft);text-decoration:none;font-size:14px;margin-bottom:8px;transition:color .2s}
.tx-footer a:hover{color:var(--white)}
.tx-footer-brand p{max-width:340px;font-size:14px;line-height:1.55;margin-bottom:16px}
.tx-social{display:flex;gap:10px;flex-wrap:wrap}
.tx-social a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border:1px solid var(--border-dark);border-radius:50%;margin-bottom:0;color:var(--soft)}
.tx-social a:hover{background:var(--teal);border-color:var(--teal);color:var(--ink)}
.tx-social svg{width:14px;height:14px;fill:currentColor}
.tx-footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;font-size:12px;flex-wrap:wrap;gap:12px}


/* Smooth section fade-ins — subtle, professional, no theater */
@keyframes tx-fade-up{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
.tx-fade{opacity:0;animation:tx-fade-up .8s cubic-bezier(.2,.8,.3,1) forwards}
.tx-fade-delay-1{animation-delay:.1s}
.tx-fade-delay-2{animation-delay:.2s}
.tx-fade-delay-3{animation-delay:.3s}

/* Smoother section padding — softer transitions between ink and paper */
.tx-section + .tx-section--paper,.tx-capabilities + .tx-image-break{position:relative}

/* ─── RESPONSIVE ───────────────────────────────────────────────── */
@media (max-width:960px){
  .tx-hero-grid,.tx-cta-grid,.tx-footer-grid,.tx-engagement-grid{grid-template-columns:1fr}
  .tx-method-cols,.tx-cap-grid,.tx-insights-grid{grid-template-columns:1fr;gap:24px}
  .tx-section,.tx-hero,.tx-engagement,.tx-insights{padding-top:72px;padding-bottom:80px}
  .tx-band-inner{flex-direction:column;text-align:center}
  .tx-qr{margin:0 auto}
}
@media (max-width:600px){
  .tx-container{padding:0 20px}
  .tx-h1{font-size:clamp(40px,9vw,56px)}
  .tx-manifesto-word{font-size:clamp(46px,13vw,72px)}
  .tx-header-inner{padding:14px 16px}
}


/* ════════════════════════════════════════════════════════════════
   PART 5 — ENTERPRISE PATCH v6 (sitewide consistency layer)
   Centralized to avoid page-specific hacks. Loaded on every page.
   Palette enforcement: Navy / Red / Chalk / Teal / White only.
   ════════════════════════════════════════════════════════════════ */

:root {
  /* Path-B v6 canonical palette */
  --to-navy:  #081a3a;
  --to-red:   #c8202f;
  --to-chalk: #E5E7EB;
  --to-teal:  #17B8CF;
  --to-white: #ffffff;

  /* Ink + soft text on navy */
  --to-ink:        #081a3a;
  --to-on-navy:    #ffffff;
  --to-soft-white: rgba(255,255,255,0.78);
  --to-soft-navy:  rgba(8,26,58,0.72);
}

/* ───── 5.1 Legacy header (.site-header.unified-header) ─────
   Force the brand identity (red-dot + THRIVEON SOLUTIONS wordmark)
   without restructuring DOM. Keeps menus, dropdowns, toggle intact. */
.site-header.unified-header {
  background: var(--to-navy) !important;
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}
.site-header.unified-header .nav-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
}
.site-header.unified-header .nav-logo img {
  display: none !important;
}
.site-header.unified-header .nav-logo::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--to-red);
  flex-shrink: 0;
}
.site-header.unified-header .nav-logo span {
  font-family: 'Lato', -apple-system, sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .4px !important;
  font-weight: 900 !important;
  font-size: 15px !important;
  color: var(--to-white) !important;
}
.site-header.unified-header .nav-links > li > a,
.site-header.unified-header .nav-dropdown-toggle {
  color: rgba(255,255,255,0.85) !important;
  font-weight: 500 !important;
  transition: color .2s !important;
}
.site-header.unified-header .nav-links > li > a:hover,
.site-header.unified-header .nav-dropdown-toggle:hover {
  color: var(--to-red) !important;
}
.site-header.unified-header .dropdown-menu {
  background: var(--to-navy) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}
.site-header.unified-header .dropdown-menu a {
  color: rgba(255,255,255,0.82) !important;
}
.site-header.unified-header .dropdown-menu a:hover {
  color: var(--to-white) !important;
  background: rgba(200,32,47,0.18) !important;
}
.site-header.unified-header .btn-primary {
  background: var(--to-white) !important;
  color: var(--to-navy) !important;
  border: none !important;
}
.site-header.unified-header .btn-primary:hover {
  background: var(--to-red) !important;
  color: var(--to-white) !important;
}
.site-header.unified-header .btn-secondary {
  background: transparent !important;
  color: var(--to-white) !important;
  border: 1px solid rgba(255,255,255,0.28) !important;
}
.site-header.unified-header .btn-secondary:hover {
  border-color: var(--to-red) !important;
  color: var(--to-red) !important;
}
.site-header.unified-header .menu-toggle {
  color: var(--to-white) !important;
  background: transparent !important;
}

/* ───── 5.2 Legacy footer harmonization ─────
   Footer headings: teal. Body links: white. Hover: red. */
.site-footer.unified-footer {
  background: #050d1a !important;
  color: rgba(255,255,255,0.72) !important;
  border-top: 1px solid rgba(255,255,255,0.06) !important;
}
.site-footer.unified-footer .footer-logo img {
  display: none !important;
}
.site-footer.unified-footer .footer-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  margin-bottom: 16px !important;
}
.site-footer.unified-footer .footer-logo::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--to-red);
  flex-shrink: 0;
}
.site-footer.unified-footer .footer-logo span {
  font-family: 'Lato', sans-serif !important;
  text-transform: uppercase !important;
  letter-spacing: .4px !important;
  font-weight: 900 !important;
  font-size: 15px !important;
  color: var(--to-white) !important;
}
.site-footer.unified-footer h4 {
  color: var(--to-teal) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  margin: 0 0 14px !important;
}
.site-footer.unified-footer a {
  color: rgba(255,255,255,0.78) !important;
  text-decoration: none !important;
  transition: color .2s !important;
}
.site-footer.unified-footer a:hover {
  color: var(--to-red) !important;
}
.site-footer.unified-footer .footer-brand p,
.site-footer.unified-footer .footer-note {
  color: rgba(255,255,255,0.78) !important;
}
.site-footer.unified-footer .footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.08) !important;
  color: rgba(255,255,255,0.55) !important;
}
.site-footer.unified-footer .footer-bottom a {
  color: rgba(255,255,255,0.55) !important;
}
.site-footer.unified-footer .footer-bottom a:hover {
  color: var(--to-red) !important;
}

/* tx-footer (newer template): force teal headings + red hover */
.tx-footer h4 { color: var(--to-teal) !important; letter-spacing: 0.16em !important; }
.tx-footer a:hover { color: var(--to-red) !important; }
.tx-footer-brand p { color: rgba(255,255,255,0.82) !important; }

/* tx-header: red hover accent (preserve existing) */
.tx-header .tx-nav a:hover { color: var(--to-white) !important; }
.tx-header .tx-nav a { color: rgba(255,255,255,0.82) !important; }
.tx-header { background: rgba(8,26,58,0.94) !important; }

/* ───── 5.3 CAREERS PAGE ─────
   White cards on chalk; navy titles; subtle shadow; red metadata. */
.tx-jobs {
  display: grid;
  gap: 16px;
  margin-top: 40px;
}
.tx-job-card {
  display: grid;
  grid-template-columns: 64px 1fr 32px;
  gap: 24px;
  align-items: center;
  background: var(--to-white) !important;
  color: var(--to-navy) !important;
  padding: 28px 32px;
  border-radius: 12px;
  border: 1px solid rgba(8,26,58,0.08);
  box-shadow: 0 1px 2px rgba(8,26,58,0.04), 0 8px 24px rgba(8,26,58,0.05);
  text-decoration: none !important;
  transition: transform .25s cubic-bezier(.2,.8,.3,1), box-shadow .25s, border-color .25s;
}
.tx-job-card:hover {
  transform: translateY(-3px);
  border-color: var(--to-red) !important;
  box-shadow: 0 14px 36px rgba(8,26,58,0.10);
}
.tx-job-num {
  font-family: 'Prata', Georgia, serif;
  font-size: 28px;
  color: var(--to-red);
  line-height: 1;
}
.tx-job-role {
  font-size: 20px;
  font-weight: 900;
  color: var(--to-navy);
  letter-spacing: -0.01em;
  margin-bottom: 6px;
}
.tx-job-meta {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--to-red);
  font-weight: 700;
}
.tx-job-arrow {
  font-size: 22px;
  color: var(--to-navy);
  transition: transform .2s, color .2s;
  text-align: right;
}
.tx-job-card:hover .tx-job-arrow {
  color: var(--to-red);
  transform: translateX(4px);
}
@media (max-width: 640px) {
  .tx-job-card {
    grid-template-columns: 48px 1fr 24px;
    gap: 16px;
    padding: 22px 20px;
  }
  .tx-job-num { font-size: 22px; }
  .tx-job-role { font-size: 17px; }
}

/* Careers hero: ensure white hero text reads correctly on navy */
body.thriveon-page .tx-hero .tx-h1 { color: var(--to-white) !important; }
body.thriveon-page .tx-hero .tx-h1 .red { color: var(--to-red) !important; }
body.thriveon-page .tx-hero .tx-lead { color: rgba(255,255,255,0.85) !important; }

/* Section--paper override → use chalk */
.tx-section--paper { background: var(--to-chalk) !important; color: var(--to-navy) !important; }
.tx-section--paper h2, .tx-section--paper .tx-eyebrow { color: var(--to-navy) !important; }
.tx-section--paper .tx-eyebrow.red { color: var(--to-red) !important; }

/* ───── 5.4 CONTACT PAGE ─────
   White form card, navy labels, enterprise input styling, navy submit → red hover. */
.tx-form { margin-top: 24px; display: grid; gap: 18px; }
.tx-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 640px) { .tx-form-row { grid-template-columns: 1fr; } }
.tx-form label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--to-navy);
  margin-bottom: 6px;
}
.tx-form input[type="text"],
.tx-form input[type="email"],
.tx-form input[type="tel"],
.tx-form select,
.tx-form textarea {
  width: 100%;
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  color: var(--to-navy);
  background: #fafafa;
  border: 1px solid rgba(8,26,58,0.14);
  border-radius: 8px;
  padding: 12px 14px;
  transition: border-color .2s, background .2s, box-shadow .2s;
  -webkit-appearance: none;
  appearance: none;
}
.tx-form textarea {
  min-height: 130px;
  resize: vertical;
  line-height: 1.55;
}
.tx-form select {
  background-image:
    linear-gradient(45deg, transparent 50%, var(--to-navy) 50%),
    linear-gradient(135deg, var(--to-navy) 50%, transparent 50%);
  background-position: calc(100% - 18px) 50%, calc(100% - 12px) 50%;
  background-size: 6px 6px, 6px 6px;
  background-repeat: no-repeat;
  padding-right: 36px;
}
.tx-form input:focus,
.tx-form select:focus,
.tx-form textarea:focus {
  outline: none;
  border-color: var(--to-navy);
  background: #fff;
  box-shadow: 0 0 0 3px rgba(8,26,58,0.10);
}
.tx-form-submit {
  margin-top: 8px;
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
  border: none !important;
  align-self: flex-start;
}
.tx-form-submit:hover {
  background: var(--to-red) !important;
  color: var(--to-white) !important;
  transform: translateY(-1px);
  box-shadow: 0 10px 24px rgba(200,32,47,0.25);
}

/* Contact page: white form card consistency */
body.thriveon-page .tx-hero-grid > div[style*="background"] {
  background: var(--to-white) !important;
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
}
body.thriveon-page .tx-hero-grid > div[style*="background"] h2 { color: var(--to-navy) !important; }
body.thriveon-page .tx-hero-grid > div[style*="background"] > p { color: var(--to-soft-navy) !important; }

/* ───── 5.5 INSIGHTS / BLOG ─────
   Container width 1180px; hero clamp; body line-height; H2 top margin;
   editorial lead paragraph (italic Georgia, red left bar);
   white cards on chalk. */
.blog-hero,
section.blog-hero {
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
  padding: 96px 0 72px !important;
}
.blog-hero .container-xl,
.blog-hero > .container-xl { max-width: 1180px !important; }
.blog-hero h1 {
  font-size: clamp(32px, 3.8vw, 52px) !important;
  font-weight: 900 !important;
  line-height: 1.08 !important;
  letter-spacing: -0.02em !important;
  color: var(--to-white) !important;
  margin-bottom: 16px;
}
.blog-hero p,
.blog-hero > .container-xl > p {
  color: rgba(255,255,255,0.82) !important;
  font-size: 17px;
  line-height: 1.6;
  max-width: 760px;
}
.blog-kicker {
  color: var(--to-red) !important;
  font-weight: 700;
  letter-spacing: 0.22em;
  font-size: 12px;
  text-transform: uppercase;
  margin-bottom: 18px;
  display: inline-block;
}

/* Blog index list container width */
.company-blog-page main .container-xl,
.blog-index-page main .container-xl,
main .container-xl { max-width: 1180px; }

/* Blog post body — typography polish */
.post-article {
  max-width: 1180px !important;
  padding-top: 56px !important;
  padding-bottom: 80px !important;
}
.post-article h1 {
  font-size: clamp(32px, 3.8vw, 52px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em;
  color: var(--to-navy) !important;
  margin-bottom: 18px;
}
.post-article .post-meta-line,
.post-article .post-share-actions {
  color: var(--to-red);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 700;
}
.post-article .post-back {
  display: inline-block;
  color: var(--to-navy) !important;
  text-decoration: none !important;
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 24px;
  border-bottom: 2px solid transparent;
  padding-bottom: 2px;
  transition: border-color .2s, color .2s;
}
.post-article .post-back:hover {
  color: var(--to-red) !important;
  border-bottom-color: var(--to-red);
}
.post-body { line-height: 1.85 !important; color: #1a233a; font-size: 17px; }
.post-body p { margin: 0 0 18px; }
.post-body h2 {
  margin-top: 64px !important;
  margin-bottom: 18px !important;
  font-size: clamp(24px, 2.4vw, 32px) !important;
  line-height: 1.2;
  color: var(--to-navy) !important;
  letter-spacing: -0.01em;
}
.post-body h3 {
  margin-top: 40px;
  margin-bottom: 12px;
  font-size: 20px;
  color: var(--to-navy);
}
/* Lead paragraph — italic Georgia + red left bar (first paragraph after intro) */
.post-body > p:first-of-type {
  font-family: 'Prata', Georgia, serif;
  font-style: italic;
  font-size: 19px;
  line-height: 1.6;
  color: var(--to-navy);
  border-left: 3px solid var(--to-red);
  padding: 4px 0 4px 18px;
  margin-bottom: 28px;
}
.post-body a {
  color: var(--to-red);
  text-decoration: underline;
  text-underline-offset: 3px;
}
.post-body a:hover { color: var(--to-navy); }
.post-body ul, .post-body ol { padding-left: 24px; margin: 0 0 22px; }
.post-body li { margin-bottom: 8px; line-height: 1.75; }
.post-body strong { color: var(--to-navy); }
.post-body hr {
  border: none;
  border-top: 1px solid rgba(8,26,58,0.10);
  margin: 40px 0;
}

/* Blog cards: white on chalk */
.company-blog-page main,
.blog-index-page main { background: var(--to-chalk); }
.blog-card {
  background: var(--to-white) !important;
  border: 1px solid rgba(8,26,58,0.06) !important;
  border-radius: 12px !important;
  box-shadow: 0 1px 2px rgba(8,26,58,0.03), 0 8px 24px rgba(8,26,58,0.05) !important;
}
.blog-card:hover { border-color: var(--to-red) !important; }

/* Insights index page — give the bare hero some polish */
main .breadcrumb {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  gap: 8px;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--to-red);
  font-weight: 700;
}
main .breadcrumb li + li::before {
  content: "·";
  margin-right: 8px;
  color: rgba(8,26,58,0.4);
}
main .breadcrumb a {
  color: var(--to-navy);
  text-decoration: none;
}
main .breadcrumb a:hover { color: var(--to-red); }

/* ───── 5.6 SCHEDULE / DEMO PAGE ─────
   Chalk background, red-dot accent above H1, framed iframe, rounded corners. */
.demo-page-clean,
.refined-demo-page,
main.demo-page-clean { background: var(--to-chalk); }
.demo-contact-hero {
  background: var(--to-chalk) !important;
  color: var(--to-navy) !important;
  padding: 88px 0 56px !important;
}
.demo-contact-hero .container-xl { max-width: 1180px !important; }
.demo-contact-hero h1 {
  color: var(--to-navy) !important;
  font-size: clamp(34px, 4.2vw, 52px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.02em;
  margin-bottom: 18px;
  position: relative;
}
.demo-contact-hero .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: var(--to-red) !important;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 22px;
}
.demo-contact-hero .eyebrow::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--to-red);
  display: inline-block;
}
.demo-contact-hero .hero-lead { color: var(--to-soft-navy) !important; font-size: 17px; line-height: 1.65; }
.demo-contact-hero .contact-hero-actions .btn-primary {
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
  border: none !important;
}
.demo-contact-hero .contact-hero-actions .btn-primary:hover {
  background: var(--to-red) !important;
}
.demo-contact-hero .contact-hero-actions .btn-secondary {
  background: transparent !important;
  color: var(--to-navy) !important;
  border: 1.5px solid var(--to-navy) !important;
}
.demo-contact-hero .contact-hero-actions .btn-secondary:hover {
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
}

/* Demo embed / iframe framing */
.demo-page-clean iframe,
.refined-demo-page iframe,
main.demo-page-clean .booking-embed,
main.refined-demo-page .booking-embed {
  width: 100%;
  border-radius: 12px;
  border: 1px solid rgba(8,26,58,0.10);
  background: var(--to-white);
  box-shadow: 0 20px 60px rgba(8,26,58,0.10);
}

/* Form panels on demo page */
.contact-form-panel.demo-form-panel,
.demo-page-clean .contact-form-panel {
  background: var(--to-white) !important;
  border-radius: 12px;
  box-shadow: 0 20px 60px rgba(8,26,58,0.08);
  padding: 36px 32px !important;
}
.demo-page-clean .form-input,
.demo-page-clean .form-textarea,
.refined-demo-page .form-input,
.refined-demo-page .form-textarea {
  background: #fafafa !important;
  border: 1px solid rgba(8,26,58,0.14) !important;
  border-radius: 8px !important;
  color: var(--to-navy) !important;
  font-family: 'Lato', sans-serif !important;
  font-size: 15px !important;
  padding: 12px 14px !important;
  transition: border-color .2s, box-shadow .2s, background .2s;
  -webkit-appearance: none;
  appearance: none;
}
.demo-page-clean .form-input:focus,
.demo-page-clean .form-textarea:focus,
.refined-demo-page .form-input:focus,
.refined-demo-page .form-textarea:focus {
  outline: none;
  border-color: var(--to-navy) !important;
  background: #fff !important;
  box-shadow: 0 0 0 3px rgba(8,26,58,0.10) !important;
}
.demo-page-clean .form-label,
.refined-demo-page .form-label {
  color: var(--to-navy) !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
}
.demo-page-clean .contact-submit,
.refined-demo-page .contact-submit,
.demo-submit {
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
  border: none !important;
}
.demo-page-clean .contact-submit:hover,
.refined-demo-page .contact-submit:hover,
.demo-submit:hover {
  background: var(--to-red) !important;
  color: var(--to-white) !important;
}
.demo-page-clean .contact-info-card,
.refined-demo-page .contact-info-card {
  background: var(--to-white);
  border: 1px solid rgba(8,26,58,0.08);
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 1px 2px rgba(8,26,58,0.03);
}
.demo-page-clean .contact-info-card.dark-card,
.refined-demo-page .contact-info-card.dark-card {
  background: var(--to-navy);
  color: var(--to-white);
  border-color: transparent;
}
.demo-page-clean .contact-info-card.dark-card h3 { color: var(--to-white); }
.demo-page-clean .contact-info-card.dark-card p { color: rgba(255,255,255,0.82); }
.demo-page-clean .contact-info-card.dark-card a {
  color: var(--to-teal);
  text-decoration: none;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
}
.demo-page-clean .contact-info-card.dark-card a:hover { color: var(--to-white); }

/* ───── 5.7 ABOUT PAGE ─────
   Align hero properly within consistent max-width.
   Keep existing centered layout intent. PRESERVE award section. */
.about-page .clean-hero,
.about-page .about-hero {
  background: var(--to-navy) !important;
  color: var(--to-white) !important;
  padding: 96px 0 72px !important;
}
.about-page .about-centered-hero { padding: 96px 0 72px !important; }
.about-page .about-hero .container-xl,
.about-page .clean-hero .container-xl { max-width: 1180px !important; }
.about-page .about-hero h1,
.about-page .clean-hero h1 {
  font-size: clamp(34px, 4.4vw, 56px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.02em;
  color: var(--to-white) !important;
  max-width: 920px;
  margin-left: auto;
  margin-right: auto;
}
.about-page .about-hero p,
.about-page .clean-hero p {
  color: rgba(255,255,255,0.88) !important;
  font-size: 18px;
  line-height: 1.6;
  max-width: 760px;
  margin-left: auto;
  margin-right: auto;
}
.about-page .about-hero .eyebrow,
.about-page .clean-hero .eyebrow {
  color: var(--to-red) !important;
  letter-spacing: 0.22em !important;
  font-size: 12px !important;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.about-page .about-hero .btn-primary,
.about-page .clean-hero .btn-primary {
  background: var(--to-white) !important;
  color: var(--to-navy) !important;
  border: none !important;
  margin-top: 28px;
}
.about-page .about-hero .btn-primary:hover,
.about-page .clean-hero .btn-primary:hover {
  background: var(--to-red) !important;
  color: var(--to-white) !important;
  transform: translateY(-1px);
}
/* Award section preserved — only consistent max-width + spacing rhythm. */
.about-page .award-section { padding: 80px 0 !important; }
.about-page .award-section .container-xl { max-width: 1180px !important; }

/* ───── 5.8 PALETTE NORMALIZATION ─────
   Touched-area heading colors stay within palette. */
body.thriveon-page .tx-section--paper h2 .red,
.tx-section--paper .red { color: var(--to-red) !important; }

/* tx- buttons hover refinement */
.tx-btn-primary:hover { background: var(--to-red) !important; color: var(--to-white) !important; }
.tx-header-cta:hover { background: #c8202f !important; color: #ffffff !important; }

/* ───── 5.9 EMPTY-SPACE CLEANUP (safe selectors only) ─────
   Removes empty <p>, generic empty divs, triple <br>, double <hr>, stray body > br.
   Does NOT touch framework wrappers, CMS containers, or anything with class/id. */
p:empty { display: none !important; }
div:empty:not([class]):not([id]):not([data-keep]) { display: none !important; }
span:empty:not([class]):not([id]) { display: none !important; }
br + br + br { display: none !important; }
hr + hr { display: none !important; }
body > br { display: none !important; }

/* ───── 5.10 ACCESSIBILITY + MOTION ─────
   Respect reduced motion. Keep focus rings visible. */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
    scroll-behavior: auto !important;
  }
}
:focus-visible {
  outline: 2px solid var(--to-red);
  outline-offset: 2px;
}

/* ───── 5.11 SAFETY: protect existing good UI ─────
   Logo image inside .tx-* templates remains untouched (no img there).
   Existing animations on .tx-fade, .tx-pulse remain unchanged. */


/* ════════════════════════════════════════════════════════════════
   PART 6 — REVIEW ROUND 2 PATCHES (v7)
   Resolves explicit feedback: chalk-gray, CTA contrast, bulletproof
   red-dot logo, unified footer & header rules, careers tile cards,
   schedule page polish.
   ════════════════════════════════════════════════════════════════ */

/* ───── 6.1 Token re-write: "chalk" is now COOL GRAY, not beige ───── */
:root {
  --to-chalk:        #E5E7EB;   /* chalk gray (replaces beige) */
  --to-chalk-soft:   #EEF0F3;   /* extra-soft for layered backgrounds */
  --to-chalk-border: #D6D9DE;

  /* Override the legacy paper/beige tokens too so old pages convert. */
  --tx-paper: #E5E7EB !important;
  --color-light: #E5E7EB !important;
  --color-border: #D6D9DE !important;
}
/* Anywhere the old beige showed up by hex, force chalk gray. */
:root, html, body { --paper: #E5E7EB !important; }
:root { --paper-color: #E5E7EB; }

/* Replace the beige hex anywhere a known beige value was painted directly. */
.tx-section--paper,
.tx-capabilities,
.tx-insights,
section[style*="F4F1EC"],
[style*="f4f1ec"],
[style*="#F4F1EC"],
[style*="#f1e9dc"] {
  background-color: var(--to-chalk) !important;
}

/* ───── 6.2 CTA contrast (Start a conversation) — bulletproof ─────
   SOLID red + white, no hover state change (per latest review). */
body header.tx-header .tx-header-actions a.tx-header-cta,
body header.tx-header .tx-header-actions a.tx-header-cta:link,
body header.tx-header .tx-header-actions a.tx-header-cta:visited,
body header.tx-header .tx-header-actions a.tx-header-cta:hover,
body header.tx-header .tx-header-actions a.tx-header-cta:focus,
body header.tx-header .tx-header-actions a.tx-header-cta:focus-visible,
body header.tx-header .tx-header-actions a.tx-header-cta:active,
.tx-header-cta,
.tx-header-cta:visited,
.tx-header-cta:link,
.tx-header-cta:hover,
.tx-header-cta:focus,
.tx-header-cta:focus-visible,
.tx-header-cta:active {
  background: #c8202f !important;
  background-color: #c8202f !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  border: 1px solid #c8202f !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  transform: none !important;
  box-shadow: none !important;
  text-decoration: none !important;
  transition: none !important;
}

/* Same lockdown for any legacy in-header primary button. */
header .btn-primary,
header .btn.btn-primary,
header a.btn-primary,
header .btn-primary:hover,
header .btn.btn-primary:hover,
header a.btn-primary:hover {
  background: var(--to-red) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
  border-color: var(--to-red) !important;
}

/* ───── 6.3 Bulletproof red-dot logo override ─────
   Old logo.png is gone. Any leftover <img> inside .nav-logo/.footer-logo
   is hidden across all selectors / specificities. The red dot is injected
   via the .tx-brand-dot span shipped in our canonical header/footer markup. */
.nav-logo img,
.footer-logo img,
.site-header .nav-logo img,
header img[src*="logo.png"],
footer img[src*="logo.png"],
img[alt*="ThriveOn"][src*="logo.png"],
img[src="/assets/images/logo.png"] {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
  visibility: hidden !important;
}

/* If legacy .nav-logo wrapper survives anywhere, inject red-dot pseudo. */
.nav-logo,
.footer-logo {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
}
.nav-logo::before,
.footer-logo::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--to-red);
  flex-shrink: 0;
}

/* ───── 6.4 Canonical tx-footer styling (unified across site) ─────
   Six-column grid (brand + Product/Company/Solutions/Insights/Contact)
   on desktop; collapses gracefully on tablet & mobile. */
.tx-footer {
  background: #06101f !important;
  color: rgba(255,255,255,0.72);
  padding: 72px 0 28px !important;
  font-family: 'Lato', -apple-system, sans-serif;
  -webkit-font-smoothing: antialiased;
}
.tx-footer .tx-container { max-width: 1280px; padding: 0 32px; }
.tx-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr 1.2fr !important;
  gap: 48px;
  padding-bottom: 44px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.tx-footer .tx-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #fff;
  text-decoration: none;
  font-weight: 900;
  letter-spacing: 0.4px;
  font-size: 15px;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.tx-footer .tx-brand-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--to-red); display: inline-block; flex-shrink: 0;
}
.tx-footer-tag {
  color: rgba(255,255,255,0.7);
  font-size: 14px;
  line-height: 1.65;
  max-width: 340px;
  margin: 0 0 22px;
}
.tx-footer h4 {
  color: var(--to-teal) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  margin: 0 0 16px !important;
}
.tx-footer a {
  display: block;
  color: rgba(255,255,255,0.78) !important;
  text-decoration: none !important;
  font-size: 14px;
  margin-bottom: 10px;
  transition: color .2s;
}
.tx-footer a:hover { color: var(--to-red) !important; }
.tx-footer .tx-social {
  display: flex;
  gap: 10px;
  margin-top: 4px;
}
.tx-footer .tx-social a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin: 0;
  border: 1px solid rgba(255,255,255,0.16);
  border-radius: 50%;
  color: rgba(255,255,255,0.78);
}
.tx-footer .tx-social a:hover {
  background: var(--to-red);
  border-color: var(--to-red);
  color: #fff !important;
}
.tx-footer .tx-social svg {
  width: 14px;
  height: 14px;
  fill: currentColor;
}
.tx-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 22px;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
  flex-wrap: wrap;
  gap: 10px;
}
@media (max-width: 1100px) {
  .tx-footer-grid { grid-template-columns: 2fr 1fr 1fr 1fr !important; }
  .tx-footer-grid > div:nth-child(5),
  .tx-footer-grid > div:nth-child(6) {
    grid-column: span 2;
  }
}
@media (max-width: 760px) {
  .tx-footer-grid { grid-template-columns: 1fr !important; gap: 32px; }
  .tx-footer-grid > div { grid-column: auto !important; }
  .tx-footer-bottom { flex-direction: column; text-align: center; }
}

/* Make sure any LEGACY footer that somehow survived a replace becomes invisible.
   (We already replaced all 97; this is defense-in-depth.) */
footer.site-footer:not(.tx-footer),
footer.unified-footer:not(.tx-footer) { display: none !important; }

/* ───── 6.5 Header: nav, brand dot, contrast ─────
   Always navy bg with white text. Red-dot brand always visible. */
.tx-header {
  background: rgba(8,26,58,0.97) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,0.08) !important;
}
.tx-header .tx-brand,
.tx-header .tx-brand:hover {
  color: #ffffff !important;
}
.tx-header .tx-brand-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--to-red);
  display: inline-block;
  flex-shrink: 0;
}
.tx-header .tx-nav a {
  color: rgba(255,255,255,0.82) !important;
  font-size: 14px;
  font-weight: 500;
}
.tx-header .tx-nav a:hover { color: var(--to-red) !important; }
.tx-header .tx-nav { gap: 24px; }
/* Tighten the header so 6 nav links + CTA fit cleanly. */
.tx-header-inner { max-width: 1280px; padding: 14px 28px !important; gap: 20px !important; }
@media (max-width: 1100px) {
  .tx-header .tx-nav { gap: 18px; }
  .tx-header .tx-nav a { font-size: 13px; }
}

/* If a legacy unified-header survived anywhere (defense-in-depth), hide it. */
header.site-header:not(.tx-header),
header.unified-header:not(.tx-header) { display: none !important; }

/* ───── 6.6 Hero / lead "Start a conversation" CTA inside body ─────
   tx-btn-primary visible everywhere. */
.tx-btn-primary {
  background: var(--to-white) !important;
  color: var(--to-navy) !important;
  -webkit-text-fill-color: var(--to-navy) !important;
  border: none !important;
}
.tx-btn-primary:hover {
  background: var(--to-red) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

/* On chalk sections, primary button uses navy (reverse contrast). */
.tx-section--paper .tx-btn-primary,
.tx-capabilities .tx-btn-primary {
  background: var(--to-navy) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}
.tx-section--paper .tx-btn-primary:hover,
.tx-capabilities .tx-btn-primary:hover {
  background: var(--to-red) !important;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff !important;
}

/* ───── 6.7 CAREERS — tile-card grid (blog-style) ───── */
.tx-roles-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 44px;
}
.tx-role-card {
  background: #ffffff;
  border: 1px solid rgba(8,26,58,0.06);
  border-radius: 14px;
  padding: 32px 28px;
  text-decoration: none !important;
  color: var(--to-navy);
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 1px 2px rgba(8,26,58,0.04), 0 10px 28px rgba(8,26,58,0.06);
  transition: transform .25s cubic-bezier(.2,.8,.3,1), box-shadow .25s, border-color .25s;
  position: relative;
}
.tx-role-card:hover {
  transform: translateY(-4px);
  border-color: var(--to-red);
  box-shadow: 0 14px 36px rgba(8,26,58,0.10), 0 30px 60px rgba(8,26,58,0.06);
}
.tx-role-card .tx-role-meta {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--to-red);
}
.tx-role-card .tx-role-title {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: var(--to-navy);
  margin: 0;
}
.tx-role-card .tx-role-desc {
  font-size: 14.5px;
  line-height: 1.6;
  color: rgba(8,26,58,0.72);
  margin: 0;
  flex-grow: 1;
}
.tx-role-card .tx-role-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}
.tx-role-card .tx-tag {
  display: inline-block;
  background: var(--to-chalk);
  color: var(--to-navy);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 6px 10px;
  border-radius: 999px;
}
.tx-role-card .tx-role-cta {
  margin-top: 14px;
  padding-top: 16px;
  border-top: 1px solid rgba(8,26,58,0.10);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--to-navy);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tx-role-card:hover .tx-role-cta { color: var(--to-red); }
.tx-role-card .arrow { transition: transform .2s; }
.tx-role-card:hover .arrow { transform: translateX(4px); }
@media (max-width: 920px) { .tx-roles-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .tx-roles-grid { grid-template-columns: 1fr; } }

/* ───── 6.8 SCHEDULE / DEMO PAGE — branded layout ───── */
.tx-schedule-card {
  background: var(--to-white);
  color: var(--to-navy);
  padding: 36px 32px;
  border-radius: 14px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
}
.tx-schedule-card h2 { color: var(--to-navy); }
.tx-check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; }
.tx-check-list li {
  display: flex; align-items: center; gap: 12px;
  font-size: 15px; color: var(--to-navy);
  padding: 10px 0;
  border-bottom: 1px solid rgba(8,26,58,0.06);
}
.tx-check-list li:last-child { border-bottom: none; }
.tx-check {
  display: inline-flex; align-items: center; justify-content: center;
  width: 20px; height: 20px; border-radius: 50%;
  background: var(--to-red); color: #fff;
  font-size: 11px; font-weight: 900;
  flex-shrink: 0;
}

.tx-schedule-grid {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 48px;
  align-items: start;
}
@media (max-width: 920px) { .tx-schedule-grid { grid-template-columns: 1fr; gap: 28px; } }

.tx-schedule-info { display: grid; gap: 18px; }
.tx-step {
  background: #ffffff;
  border: 1px solid rgba(8,26,58,0.06);
  border-radius: 12px;
  padding: 22px 24px;
  display: flex;
  gap: 18px;
  align-items: flex-start;
}
.tx-step-num {
  font-family: 'Prata', Georgia, serif;
  font-size: 24px;
  color: var(--to-red);
  line-height: 1;
  min-width: 40px;
}
.tx-step h3 {
  margin: 0 0 6px;
  font-size: 17px;
  font-weight: 900;
  color: var(--to-navy);
}
.tx-step p {
  margin: 0;
  font-size: 14px;
  line-height: 1.6;
  color: rgba(8,26,58,0.72);
}
.tx-step-dark {
  background: var(--to-navy);
  color: var(--to-white);
  display: block;
}
.tx-step-dark h3 { color: var(--to-white); margin-bottom: 8px; }
.tx-step-dark p { color: rgba(255,255,255,0.78); margin-bottom: 12px; }
.tx-step-dark a {
  color: var(--to-teal);
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 12px;
  text-decoration: none;
}
.tx-step-dark a:hover { color: #fff; }

.tx-form-panel {
  background: #ffffff;
  border-radius: 14px;
  padding: 36px 32px;
  box-shadow: 0 30px 80px rgba(8,26,58,0.08);
}
@media (max-width: 560px) { .tx-form-panel { padding: 24px 20px; } }

/* ───── 6.9 Strip legacy chrome bleeding through (sitewide safety) ─────
   Old skip-link kept (a11y), but old page-specific overrides hidden. */
.contact-hero-card { /* legacy demo white card — now redundant */ display: none !important; }

/* Hide any legacy footer wedge anchors leftover */
.footer-bottom-links { gap: 12px !important; }

/* ───── 6.10 Replace any beige residue in body backgrounds ───── */
body, html { background: #ffffff; }
.about-page .award-section,
section.blog-search-panel,
.tx-section--paper { background: var(--to-chalk) !important; }

/* ───── 6.11 Make the legacy unified-* selectors no-op since chrome was replaced. ───── */
/* (Defensive only — replacement was already applied.) */

/* End of v7 patch */


/* ════════════════════════════════════════════════════════════════
   PART 7 — REVIEW ROUND 3 (v8): font standardization + chalk backstop
   ════════════════════════════════════════════════════════════════ */

/* ───── 7.1 Brand fonts sitewide (Lato body, Prata editorial) ───── */
html, body,
body * {
  font-family: 'Lato', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
}
/* Editorial accents stay Prata where the design specifies */
.tx-lead,
.tx-band-headline,
.tx-cta-lead,
.tx-manifesto-tagline,
.tx-step-num,
.tx-cap-num,
.tx-job-num,
.tx-role-card .tx-role-meta + .tx-role-title,
.section-header-center > p,
.blog-hero > .container-xl > p,
.hero > p:first-of-type,
.post-body > p:first-of-type,
.tx-manifesto-tagline,
.tx-method-col .sub-it,
.tx-eyebrow.serif,
.prata, .serif, .editorial-italic {
  font-family: 'Prata', Georgia, serif;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Lato', -apple-system, sans-serif;
  font-weight: 900;
}

/* SVG text nodes (e.g. hero banner) keep their declared fonts. */
svg, svg * { font-family: inherit; }

/* ───── 7.2 Aggressive chalk-gray backstop for blog + careers pages ─────
   Replaces any leftover beige cascade with chalk gray. */
body.company-blog-page,
body.blog-index-page,
body.company-blog-page main,
body.blog-index-page main,
main:has(.blog-grid),
main:has(.blog-search-panel),
main:has(.post-article),
main:has(.tx-roles-grid),
main:has(.tx-jobs),
.company-blog-page .blog-search-panel,
.company-blog-page .blog-grid,
.blog-index-page .blog-search-panel,
.blog-index-page .blog-grid,
.post-article {
  background: var(--to-chalk) !important;
}

/* Body bg defaults stay white; the chalk wraps content sections via :has(). */
body { background: #ffffff; }

/* Careers section paper override (defense-in-depth) */
section.tx-section--paper { background: var(--to-chalk) !important; }

/* Blog hero stays navy as designed; everything beneath rides chalk. */

/* End of v8 patch */


