/*
Theme Name:  MSCS ORG Theme
Theme URI:   https://multistatecooperative.org
Description: Institutional authority variant for multistatecooperative.org. Inherits all templates from mscs-base-child — only CSS variables differ.
Author:      Metro Consultants
Author URI:  https://multistatecooperative.org
Template:    astra
Version:     1.0.1
License:     GPL-2.0-or-later
Text Domain: mscs-org-theme
*/

/*
 * ⚠️  DO NOT add component styles here.
 *     Add them to mscs-base-child/style.css instead.
 *     This file ONLY overrides CSS custom properties.
 */

/* Load base child styles */
/* === BASE CHILD CSS (inlined) === */
/* ============================================================
   DESIGN TOKEN SYSTEM
   All variant themes override only these variables.
   ============================================================ */
:root {
  /* Brand colours */
  --mscs-primary:        #1a2e5a;   /* overridden per variant */
  --mscs-primary-dark:   #111e3d;
  --mscs-secondary:      #c9a84c;   /* accent / CTA */
  --mscs-secondary-dark: #a8893a;
  --mscs-bg:             #f8f9fc;
  --mscs-surface:        #ffffff;
  --mscs-text:           #1a1a2e;
  --mscs-text-muted:     #5a6478;
  --mscs-border:         #e2e8f0;

  /* Hero */
  --mscs-hero-bg:        linear-gradient(135deg, #1a2e5a 0%, #111e3d 100%);
  --mscs-hero-text:      #ffffff;
  --mscs-hero-accent:    #c9a84c;

  /* CTA band */
  --mscs-cta-bg:         #1a2e5a;
  --mscs-cta-text:       #ffffff;
  --mscs-cta-btn-bg:     #c9a84c;
  --mscs-cta-btn-text:   #1a1a2e;

  /* Buttons */
  --mscs-btn-primary-bg:   #c9a84c;
  --mscs-btn-primary-text: #1a1a2e;
  --mscs-btn-outline-border: #c9a84c;
  --mscs-btn-outline-text:   #c9a84c;

  /* Typography */
  --mscs-font-heading: 'Playfair Display', Georgia, serif;
  --mscs-font-body:    'Source Sans 3', 'Source Sans Pro', sans-serif;
  --mscs-font-size-base: 16px;
  --mscs-line-height:    1.7;

  /* Spacing scale */
  --mscs-space-xs:  0.5rem;
  --mscs-space-sm:  1rem;
  --mscs-space-md:  2rem;
  --mscs-space-lg:  3.5rem;
  --mscs-space-xl:  5rem;

  /* Radius */
  --mscs-radius-sm: 4px;
  --mscs-radius-md: 8px;
  --mscs-radius-lg: 16px;

  /* Shadows */
  --mscs-shadow-sm: 0 1px 4px rgba(0,0,0,.08);
  --mscs-shadow-md: 0 4px 16px rgba(0,0,0,.10);
  --mscs-shadow-lg: 0 8px 32px rgba(0,0,0,.12);

  /* Transitions */
  --mscs-transition: 0.22s ease;
}

/* ============================================================
   BASE RESETS & BODY
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--mscs-font-body);
  font-size: var(--mscs-font-size-base);
  line-height: var(--mscs-line-height);
  color: var(--mscs-text);
  background-color: var(--mscs-bg);
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--mscs-font-heading);
  color: var(--mscs-primary);
  line-height: 1.25;
}

a {
  color: var(--mscs-primary);
  transition: color var(--mscs-transition);
}
a:hover { color: var(--mscs-secondary); text-decoration: none; }

img { max-width: 100%; height: auto; }

/* ============================================================
   TOP BAR (cities ticker + contact strip)
   ============================================================ */
.mscs-topbar {
  background: var(--mscs-primary);
  color: rgba(255,255,255,.85);
  font-size: .8rem;
  padding: .35rem 0;
  overflow: hidden;
}
.mscs-topbar a { color: rgba(255,255,255,.9); }
.mscs-topbar a:hover { color: var(--mscs-secondary); }

.mscs-topbar-scroll {
  white-space: nowrap;
  animation: mscsScroll 60s linear infinite;
}
@keyframes mscsScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ============================================================
   HEADER
   ============================================================ */
.site-header,
.ast-primary-header-bar {
  background: var(--mscs-surface) !important;
  box-shadow: var(--mscs-shadow-sm);
}

/* Logo */
.site-title a,
.ast-site-title-wrap a {
  font-family: var(--mscs-font-heading);
  color: var(--mscs-primary) !important;
  font-weight: 700;
}

/* Nav links */
.main-header-menu > .menu-item > a,
.ast-primary-menu > li > a {
  font-family: var(--mscs-font-body);
  font-weight: 600;
  color: var(--mscs-text) !important;
  font-size: .95rem;
  transition: color var(--mscs-transition);
}
.main-header-menu > .menu-item > a:hover,
.ast-primary-menu > li > a:hover,
.main-header-menu > .current-menu-item > a,
.ast-primary-menu > .current-menu-item > a {
  color: var(--mscs-secondary) !important;
}

/* CTA in header */
.ast-primary-menu .menu-item.mscs-header-cta > a {
  background: var(--mscs-secondary);
  color: var(--mscs-btn-primary-text) !important;
  padding: .45rem 1.1rem;
  border-radius: var(--mscs-radius-sm);
  transition: background var(--mscs-transition);
}
.ast-primary-menu .menu-item.mscs-header-cta > a:hover {
  background: var(--mscs-secondary-dark);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.mscs-hero {
  background: var(--mscs-hero-bg);
  color: var(--mscs-hero-text);
  padding: var(--mscs-space-xl) 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.mscs-hero h1 {
  font-family: var(--mscs-font-heading);
  color: var(--mscs-hero-text);
  font-size: clamp(2rem, 4vw, 3.2rem);
  margin-bottom: var(--mscs-space-sm);
}
.mscs-hero h1 em {
  font-style: normal;
  color: var(--mscs-hero-accent);
}

.mscs-hero p.lead {
  font-size: 1.15rem;
  opacity: .9;
  max-width: 620px;
  margin: 0 auto var(--mscs-space-md);
}

/* Hero CTA row */
.mscs-hero-ctas {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* Trust badges below hero */
.mscs-trust-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  padding: var(--mscs-space-sm) var(--mscs-space-md);
  background: var(--mscs-surface);
  border-bottom: 1px solid var(--mscs-border);
}
.mscs-trust-strip .badge {
  display: flex;
  align-items: center;
  gap: .4rem;
  font-size: .88rem;
  font-weight: 600;
  color: var(--mscs-primary);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.mscs-btn {
  display: inline-block;
  padding: .7rem 1.6rem;
  border-radius: var(--mscs-radius-sm);
  font-family: var(--mscs-font-body);
  font-weight: 700;
  font-size: .95rem;
  text-align: center;
  cursor: pointer;
  transition: all var(--mscs-transition);
  border: 2px solid transparent;
  text-decoration: none;
}

.mscs-btn-primary {
  background: var(--mscs-btn-primary-bg);
  color: var(--mscs-btn-primary-text) !important;
  border-color: var(--mscs-btn-primary-bg);
}
.mscs-btn-primary:hover {
  background: var(--mscs-secondary-dark);
  border-color: var(--mscs-secondary-dark);
  color: var(--mscs-btn-primary-text) !important;
  transform: translateY(-1px);
  box-shadow: var(--mscs-shadow-md);
}

.mscs-btn-outline {
  background: transparent;
  color: var(--mscs-btn-outline-text) !important;
  border-color: var(--mscs-btn-outline-border);
}
.mscs-btn-outline:hover {
  background: var(--mscs-btn-outline-border);
  color: var(--mscs-btn-primary-text) !important;
}

/* On dark bg — white outline variant */
.mscs-btn-outline-white {
  background: transparent;
  color: #fff !important;
  border-color: rgba(255,255,255,.7);
}
.mscs-btn-outline-white:hover {
  background: rgba(255,255,255,.12);
  border-color: #fff;
}

/* ============================================================
   SECTION LAYOUT HELPERS
   ============================================================ */
.mscs-section {
  padding: var(--mscs-space-lg) 0;
}
.mscs-section-alt {
  background: var(--mscs-bg);
}
.mscs-section-dark {
  background: var(--mscs-primary);
  color: #fff;
}
.mscs-section-dark h2,
.mscs-section-dark h3 {
  color: #fff;
}

.mscs-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 var(--mscs-space-md);
}

.mscs-section-header {
  text-align: center;
  margin-bottom: var(--mscs-space-md);
}
.mscs-section-header .eyebrow {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mscs-secondary);
  margin-bottom: .5rem;
}
.mscs-section-header h2 {
  font-size: clamp(1.6rem, 3vw, 2.4rem);
}
.mscs-section-header h2 em {
  font-style: normal;
  color: var(--mscs-secondary);
}

/* ============================================================
   STATS ROW
   ============================================================ */
.mscs-stats {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--mscs-space-md);
  margin-top: var(--mscs-space-md);
}
.mscs-stat {
  text-align: center;
}
.mscs-stat .number {
  font-family: var(--mscs-font-heading);
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--mscs-secondary);
  display: block;
  line-height: 1;
}
.mscs-stat .label {
  font-size: .85rem;
  color: var(--mscs-text-muted);
  margin-top: .3rem;
}

/* ============================================================
   SERVICES GRID
   ============================================================ */
.mscs-services-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--mscs-space-md);
}

.mscs-service-card {
  background: var(--mscs-surface);
  border: 1px solid var(--mscs-border);
  border-radius: var(--mscs-radius-md);
  padding: var(--mscs-space-md);
  transition: all var(--mscs-transition);
}
.mscs-service-card:hover {
  box-shadow: var(--mscs-shadow-md);
  transform: translateY(-3px);
  border-color: var(--mscs-secondary);
}
.mscs-service-card .icon {
  font-size: 2rem;
  margin-bottom: .75rem;
}
.mscs-service-card h3 {
  font-size: 1.05rem;
  margin-bottom: .5rem;
}
.mscs-service-card p { font-size: .9rem; color: var(--mscs-text-muted); }
.mscs-service-card a.learn-more {
  font-size: .85rem;
  font-weight: 700;
  color: var(--mscs-secondary);
  display: inline-block;
  margin-top: .75rem;
}

/* ============================================================
   TEAM / ADVISORY BOARD
   ============================================================ */
.mscs-team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--mscs-space-md);
}
.mscs-team-card {
  text-align: center;
  padding: var(--mscs-space-sm);
}
.mscs-team-card .avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--mscs-primary);
  color: #fff;
  font-family: var(--mscs-font-heading);
  font-size: 1.5rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--mscs-space-sm);
}
.mscs-team-card .avatar img {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
}
.mscs-team-card h4 { font-size: 1rem; margin-bottom: .25rem; }
.mscs-team-card .role { font-size: .8rem; color: var(--mscs-secondary); font-weight: 700; }
.mscs-team-card .bio { font-size: .82rem; color: var(--mscs-text-muted); margin-top: .5rem; }

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.mscs-steps {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--mscs-space-md);
  counter-reset: steps;
}
.mscs-step {
  position: relative;
  padding-top: 3.5rem;
}
.mscs-step::before {
  counter-increment: steps;
  content: counter(steps);
  position: absolute;
  top: 0; left: 0;
  width: 2.6rem;
  height: 2.6rem;
  background: var(--mscs-secondary);
  color: var(--mscs-btn-primary-text);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.1rem;
}
.mscs-step h4 { font-size: 1rem; margin-bottom: .4rem; }
.mscs-step p  { font-size: .88rem; color: var(--mscs-text-muted); }

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.mscs-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: var(--mscs-space-md);
}
.mscs-testimonial {
  background: var(--mscs-surface);
  border: 1px solid var(--mscs-border);
  border-radius: var(--mscs-radius-md);
  padding: var(--mscs-space-md);
  box-shadow: var(--mscs-shadow-sm);
}
.mscs-testimonial .stars { color: #f59e0b; margin-bottom: .75rem; font-size: 1.1rem; }
.mscs-testimonial blockquote {
  font-size: .9rem;
  color: var(--mscs-text);
  margin: 0 0 .75rem;
  font-style: italic;
}
.mscs-testimonial .source {
  font-size: .8rem;
  color: var(--mscs-text-muted);
  font-weight: 600;
}

/* ============================================================
   CTA BAND
   ============================================================ */
.mscs-cta-band {
  background: var(--mscs-cta-bg);
  color: var(--mscs-cta-text);
  padding: var(--mscs-space-lg) 0;
  text-align: center;
}
.mscs-cta-band h2 {
  color: var(--mscs-cta-text);
  font-size: clamp(1.5rem, 2.5vw, 2.2rem);
  margin-bottom: var(--mscs-space-sm);
}
.mscs-cta-band h2 em {
  font-style: normal;
  color: var(--mscs-secondary);
}
.mscs-cta-band p {
  opacity: .85;
  margin-bottom: var(--mscs-space-md);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}
.mscs-cta-band .mscs-cta-btns {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.mscs-cta-band .phone {
  margin-top: var(--mscs-space-sm);
  font-size: 1rem;
  opacity: .85;
}
.mscs-cta-band .phone a { color: var(--mscs-secondary); font-weight: 700; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer,
#colophon {
  background: var(--mscs-primary-dark) !important;
  color: rgba(255,255,255,.75);
  padding: var(--mscs-space-lg) 0 var(--mscs-space-sm);
}

.mscs-footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1.5fr;
  gap: var(--mscs-space-md);
  margin-bottom: var(--mscs-space-md);
}

.mscs-footer-col h4 {
  color: #fff;
  font-size: .9rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: var(--mscs-space-sm);
}
.mscs-footer-col p,
.mscs-footer-col li,
.mscs-footer-col address {
  font-size: .85rem;
  line-height: 1.8;
  color: rgba(255,255,255,.65);
}
.mscs-footer-col ul { list-style: none; padding: 0; margin: 0; }
.mscs-footer-col a {
  color: rgba(255,255,255,.65);
  transition: color var(--mscs-transition);
}
.mscs-footer-col a:hover { color: var(--mscs-secondary); }

.mscs-footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: var(--mscs-space-sm);
  text-align: center;
  font-size: .8rem;
  color: rgba(255,255,255,.45);
}

/* Astra footer override */
.ast-small-footer { display: none !important; }

/* ============================================================
   PRICING TABLE (services page)
   ============================================================ */
.mscs-pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: var(--mscs-space-md);
  align-items: start;
}
.mscs-pricing-card {
  background: var(--mscs-surface);
  border: 1px solid var(--mscs-border);
  border-radius: var(--mscs-radius-md);
  padding: var(--mscs-space-md);
  transition: box-shadow var(--mscs-transition);
}
.mscs-pricing-card.featured {
  border-color: var(--mscs-secondary);
  box-shadow: var(--mscs-shadow-md);
}
.mscs-pricing-card .price {
  font-family: var(--mscs-font-heading);
  font-size: 2rem;
  font-weight: 700;
  color: var(--mscs-primary);
}
.mscs-pricing-card .price sub { font-size: .8rem; font-weight: 400; }
.mscs-pricing-card ul { margin: var(--mscs-space-sm) 0; padding-left: 1.2rem; }
.mscs-pricing-card li { font-size: .88rem; margin-bottom: .3rem; }

/* ============================================================
   WHATSAPP FLOATING BUTTON
   ============================================================ */
.mscs-wa-float {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  z-index: 9999;
  width: 54px;
  height: 54px;
  background: #25d366;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 12px rgba(0,0,0,.25);
  transition: transform var(--mscs-transition), box-shadow var(--mscs-transition);
  text-decoration: none;
}
.mscs-wa-float:hover {
  transform: scale(1.1);
  box-shadow: 0 6px 20px rgba(0,0,0,.3);
}
.mscs-wa-float svg { width: 28px; height: 28px; fill: #fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 900px) {
  .mscs-footer-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .mscs-footer-grid { grid-template-columns: 1fr; }
  .mscs-hero h1 { font-size: 1.75rem; }
  .mscs-section { padding: var(--mscs-space-md) 0; }
  .mscs-hero { padding: var(--mscs-space-lg) 0; }
  .mscs-hero-ctas { flex-direction: column; align-items: center; }
  .mscs-cta-band .mscs-cta-btns { flex-direction: column; align-items: center; }
}

/* ============================================================
   ASTRA OVERRIDES — keep Astra from fighting our styles
   ============================================================ */
.ast-container { max-width: 1140px !important; }
.entry-content, .post-content { max-width: none; }
/* Remove Astra default button colours so ours win */
.ast-theme-button,
.wp-block-button .wp-block-button__link,
button[type="submit"] {
  background-color: var(--mscs-btn-primary-bg) !important;
  color: var(--mscs-btn-primary-text) !important;
  border-radius: var(--mscs-radius-sm) !important;
}
/* === END BASE CHILD CSS === */

/* ============================================================
   ORG THEME — INSTITUTIONAL AUTHORITY
   Palette: Deep Navy · Antique Gold · Warm White
   Typography: Playfair Display (headings) · Source Serif 4 (body)
   Personality: Government authority, gravitas, trust
   ============================================================ */
:root {
  /* ---- Core palette ---- */
  --mscs-primary:        #0d1f4e;   /* deep government navy */
  --mscs-primary-dark:   #071030;
  --mscs-secondary:      #b8922a;   /* antique gold — authoritative, not flashy */
  --mscs-secondary-dark: #96751f;

  /* ---- Surfaces ---- */
  --mscs-bg:      #f4f5f8;          /* warm off-white — feels like quality paper */
  --mscs-surface: #ffffff;
  --mscs-border:  #d8dde8;

  /* ---- Text ---- */
  --mscs-text:       #12192e;
  --mscs-text-muted: #4a5568;

  /* ---- Hero ---- */
  --mscs-hero-bg:     linear-gradient(160deg, #0d1f4e 0%, #071030 60%, #0a1840 100%);
  --mscs-hero-text:   #f0f2f8;
  --mscs-hero-accent: #d4aa45;      /* slightly brighter gold on dark */

  /* ---- CTA band ---- */
  --mscs-cta-bg:       #0d1f4e;
  --mscs-cta-text:     #f0f2f8;
  --mscs-cta-btn-bg:   #b8922a;
  --mscs-cta-btn-text: #ffffff;

  /* ---- Buttons ---- */
  --mscs-btn-primary-bg:    #b8922a;
  --mscs-btn-primary-text:  #ffffff;
  --mscs-btn-outline-border: #b8922a;
  --mscs-btn-outline-text:   #b8922a;

  /* ---- Typography ---- */
  --mscs-font-heading: 'Playfair Display', 'Times New Roman', Georgia, serif;
  --mscs-font-body:    'Source Serif 4', 'Georgia', serif;  /* body serif = institutional gravitas */
  --mscs-font-size-base: 16px;
  --mscs-line-height:    1.75;

  /* ---- Radius — sharper = more formal ---- */
  --mscs-radius-sm: 2px;
  --mscs-radius-md: 4px;
  --mscs-radius-lg: 8px;
}

/* ============================================================
   ORG-SPECIFIC OVERRIDES
   These go beyond variables — structural tweaks for authority feel
   ============================================================ */

/* --- Top bar: darker, more official --- */
.mscs-topbar {
  background: #071030;
  border-bottom: 2px solid var(--mscs-secondary);
  font-size: .78rem;
  letter-spacing: .02em;
}

/* --- Header: add a bottom rule for authority --- */
.site-header,
.ast-primary-header-bar {
  border-bottom: 3px solid var(--mscs-secondary) !important;
}

/* --- Nav: serif nav links feel more official --- */
.main-header-menu > .menu-item > a,
.ast-primary-menu > li > a {
  font-family: var(--mscs-font-heading) !important;
  font-size: .9rem !important;
  letter-spacing: .04em;
  text-transform: uppercase;
}

/* --- Hero: add a subtle decorative rule under heading --- */
.mscs-hero h1::after {
  content: '';
  display: block;
  width: 80px;
  height: 3px;
  background: var(--mscs-hero-accent);
  margin: 1rem auto 0;
}

/* --- Hero: add crest/seal watermark feel --- */
.mscs-hero {
  border-bottom: 4px solid var(--mscs-secondary);
  position: relative;
}
.mscs-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(
      45deg,
      rgba(255,255,255,.015) 0px,
      rgba(255,255,255,.015) 1px,
      transparent 1px,
      transparent 12px
    );
  pointer-events: none;
}

/* --- Section eyebrow: formal small caps style --- */
.eyebrow {
  font-variant: small-caps;
  letter-spacing: .14em;
}

/* --- Service cards: square, border-heavy --- */
.mscs-service-card {
  border-left: 4px solid transparent;
  transition: border-color .2s, box-shadow .2s;
}
.mscs-service-card:hover {
  border-left-color: var(--mscs-secondary);
  transform: none;  /* no lift — authoritative = stable */
  box-shadow: var(--mscs-shadow-md);
}

/* --- Stats: larger, bolder numerals --- */
.mscs-stat .number {
  font-size: 3rem;
  color: var(--mscs-hero-accent);
}

/* --- Steps: numbered circles get a formal double-ring --- */
.mscs-step::before {
  background: transparent;
  border: 3px solid var(--mscs-secondary);
  color: var(--mscs-secondary);
  font-family: var(--mscs-font-heading);
}

/* --- Testimonials: formal quote style --- */
.mscs-testimonial blockquote::before {
  content: '\201C';
  font-family: var(--mscs-font-heading);
  font-size: 3rem;
  line-height: .5;
  color: var(--mscs-secondary);
  opacity: .4;
  display: block;
  margin-bottom: .5rem;
}

/* --- Footer: ruled columns --- */
.mscs-footer-col {
  border-right: 1px solid rgba(255,255,255,.08);
  padding-right: 1.5rem;
}
.mscs-footer-col:last-child { border-right: none; }

/* --- CTA band: formal centred rule --- */
.mscs-cta-band::before {
  content: '';
  display: block;
  width: 60px;
  height: 3px;
  background: var(--mscs-secondary);
  margin: 0 auto 1.5rem;
}

/* --- Body: slightly tighter for serif readability --- */
body { letter-spacing: .01em; }

/* --- Astra button override for serif look --- */
.ast-theme-button,
.wp-block-button .wp-block-button__link,
button[type="submit"] {
  font-family: var(--mscs-font-heading) !important;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .85rem !important;
}

/* ============================================================
   ORG RESPONSIVE TWEAKS
   ============================================================ */
@media (max-width: 640px) {
  .mscs-hero h1::after { margin: .75rem auto 0; }
  .mscs-footer-col { border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); padding-bottom: 1rem; }
}
