/* ============================================================================
   DESIGN TOKENS
   ============================================================================ */
:root {
  --c-ink:        oklch(15% 0.014 250);
  --c-ink-soft:   oklch(32% 0.012 250);
  --c-muted:      oklch(48% 0.010 250);
  --c-line:       oklch(88% 0.005 60);
  --c-line-soft:  oklch(93% 0.004 60);
  --c-bg:         oklch(99% 0.003 60);
  --c-bg-soft:    oklch(96.5% 0.006 60);
  --c-bg-warm:    oklch(94% 0.012 60);
  --c-bg-dark:    oklch(14% 0.020 250);
  --c-bg-darker:  oklch(10% 0.020 250);

  /* Dark-surface text — explicit, high contrast */
  --c-on-dark:        oklch(98% 0.003 60);
  --c-on-dark-soft:   oklch(85% 0.008 250);
  --c-on-dark-mute:   oklch(65% 0.012 250);
  --c-on-dark-line:   oklch(28% 0.014 250);

  /* Brand crimson — contrast-tuned per surface */
  --c-accent:        oklch(46% 0.20 18);
  --c-accent-hover:  oklch(40% 0.20 18);
  --c-accent-bright: oklch(60% 0.22 22);   /* for dark surfaces */
  --c-accent-soft:   oklch(96% 0.014 18);

  --font-serif: "Newsreader", "Iowan Old Style", Georgia, serif;
  --font-sans:  "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --font-mono:  "IBM Plex Mono", ui-monospace, "SF Mono", monospace;

  --container: 1280px;
  --reading:    680px;
}

/* ============================================================================
   RESET & BASE
   ============================================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { font-size: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1.0625rem;
  font-weight: 400;
  line-height: 1.6;
  color: var(--c-ink);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Headings — Newsreader, properly weighted, breathing letter-spacing */
h1, h2, h3, h4, h5 {
  font-family: var(--font-serif);
  font-variation-settings: "opsz" 72;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0;
  margin: 0 0 1rem;
  color: var(--c-ink);
}
h1 { font-size: clamp(3.25rem, 6.8vw, 6.5rem); font-weight: 600; letter-spacing: -0.005em; line-height: 1.05; }
h2 { font-size: clamp(2.25rem, 4.5vw, 3.75rem); font-weight: 600; letter-spacing: -0.003em; line-height: 1.08; margin-bottom: 1.5rem; }
h3 { font-size: 1.6rem; font-weight: 600; letter-spacing: 0.002em; line-height: 1.2; }
h4 { font-size: 1.15rem; font-family: var(--font-sans); font-weight: 600; letter-spacing: 0; }

p { margin: 0 0 1rem; max-width: var(--reading); }
strong { font-weight: 600; }

a { color: var(--c-ink); text-decoration: underline; text-decoration-color: var(--c-line); text-underline-offset: 4px; text-decoration-thickness: 1px; transition: text-decoration-color 0.15s, color 0.15s; }
a:hover { text-decoration-color: var(--c-accent); }

img { max-width: 100%; height: auto; display: block; }
button { font-family: inherit; cursor: pointer; }

/* ============================================================================
   LAYOUT
   ============================================================================ */
.container { max-width: var(--container); margin-inline: auto; padding-inline: 2rem; }
@media (max-width: 768px) { .container { padding-inline: 1.25rem; } }

.section { padding-block: 4.5rem; }
.section--wide { padding-block: 5.5rem; }
.section--tight { padding-block: 3rem; }
.section--soft { background: var(--c-bg-soft); }
.section--warm { background: var(--c-bg-warm); }
.section--dark { background: var(--c-bg-dark); color: var(--c-on-dark); }
.section--darker { background: var(--c-bg-darker); color: var(--c-on-dark); }

/* CRITICAL: explicit color overrides for dark sections */
.section--dark, .section--darker, .hero,
.section--dark p, .section--darker p, .hero p,
.section--dark li, .section--darker li, .hero li {
  color: var(--c-on-dark);
}
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4,
.section--darker h1, .section--darker h2, .section--darker h3, .section--darker h4,
.hero h1, .hero h2, .hero h3, .hero h4 {
  color: var(--c-on-dark);
}

/* Eyebrow — mono cap, replaces AI pill-badge */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-accent);
  display: inline-flex;
  align-items: center;
  gap: 0.85em;
  margin-bottom: 1.5rem;
}
.eyebrow::before {
  content: "";
  width: 32px;
  height: 1px;
  background: currentColor;
}
.section--dark .eyebrow, .section--darker .eyebrow, .hero .eyebrow { color: var(--c-accent-bright); }

/* Buttons — solid, confident */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 0.65em;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.005em;
  padding: 0.95em 1.6em;
  border-radius: 2px;
  text-decoration: none;
  transition: background 0.15s, color 0.15s, border-color 0.15s, transform 0.15s;
  border: 1.5px solid transparent;
  cursor: pointer;
  white-space: nowrap;
}
.btn--primary { background: var(--c-accent); color: var(--c-on-dark); border-color: var(--c-accent); }
.btn--primary:hover { background: var(--c-accent-hover); border-color: var(--c-accent-hover); transform: translateY(-1px); }

.btn--ghost { background: transparent; color: var(--c-ink); border-color: var(--c-ink); }
.btn--ghost:hover { background: var(--c-ink); color: var(--c-on-dark); }

.section--dark .btn--primary, .section--darker .btn--primary, .hero .btn--primary {
  background: var(--c-accent-bright); border-color: var(--c-accent-bright); color: var(--c-bg);
}
.section--dark .btn--primary:hover, .section--darker .btn--primary:hover, .hero .btn--primary:hover {
  background: var(--c-on-dark); color: var(--c-bg-dark); border-color: var(--c-on-dark);
}
.section--dark .btn--ghost, .section--darker .btn--ghost, .hero .btn--ghost {
  color: var(--c-on-dark); border-color: var(--c-on-dark);
}
.section--dark .btn--ghost:hover, .section--darker .btn--ghost:hover, .hero .btn--ghost:hover {
  background: var(--c-on-dark); color: var(--c-bg-dark);
}

.btn__arrow { transition: transform 0.15s; font-weight: 400; }
.btn:hover .btn__arrow { transform: translateX(3px); }

/* ============================================================================
   NAV
   ============================================================================ */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--c-bg);
  border-bottom: 1px solid var(--c-line);
}
.nav__inner {
  max-width: var(--container);
  margin-inline: auto;
  padding: 1.15rem 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.nav__brand {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  color: var(--c-ink);
  line-height: 1;
}
.nav__brand img {
  height: 80px;
  width: auto;
  display: block;
}
@media (max-width: 768px) {
  .nav__brand img { height: 56px; }
}
@media (max-width: 480px) {
  .nav__brand img { height: 48px; }
}
.nav__menu { display: flex; align-items: center; gap: 2.25rem; list-style: none; padding: 0; margin: 0; }
.nav__menu > li { position: relative; }
.nav__menu > li > a {
  font-size: 0.93rem;
  font-weight: 500;
  text-decoration: none;
  color: var(--c-ink-soft);
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  padding: 0.5rem 0;
}
.nav__menu > li > a:hover { color: var(--c-ink); }

/* Services dropdown */
.nav__chevron { font-size: 0.7em; opacity: 0.55; transition: transform .18s, opacity .18s; line-height: 1; }
.nav__item--has-children:hover .nav__chevron,
.nav__item--has-children:focus-within .nav__chevron { transform: rotate(180deg); opacity: 1; }
.nav__item--has-children::after {
  /* invisible hover bridge — cursor traveling down to submenu stays inside hover region */
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: 100%;
  height: 0.85rem;
}
.nav__submenu {
  position: absolute;
  top: calc(100% + 0.85rem); left: 0;
  min-width: 320px;
  padding: 0.6rem 0;
  margin: 0;
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  list-style: none;
  box-shadow: 0 14px 44px oklch(15% 0.014 250 / 0.08);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-4px);
  transition: opacity .18s, transform .18s, visibility 0s .18s;
}
.nav__item--has-children:hover .nav__submenu,
.nav__item--has-children:focus-within .nav__submenu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  transition: opacity .18s, transform .18s, visibility 0s;
}
.nav__submenu a {
  display: flex;
  align-items: center;
  gap: 0.5em;
  padding: 0.65rem 1.5rem;
  font-size: 0.93rem;
  font-weight: 500;
  color: var(--c-ink-soft);
  text-decoration: none;
  white-space: nowrap;
  transition: color .15s, background .15s;
}
.nav__submenu a:hover { color: var(--c-ink); background: var(--c-bg-soft); }
.nav__submenu li:first-child a {
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--c-muted);
  border-bottom: 1px solid var(--c-line-soft);
  padding-bottom: 0.85rem;
  margin-bottom: 0.35rem;
}

/* "Paused" badge */
.nav__badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.6rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--c-accent);
  background: var(--c-accent-soft);
  border: 1px solid var(--c-accent);
  padding: 0.12em 0.5em;
  border-radius: 2px;
  margin-left: 0.4em;
  vertical-align: 0.06em;
  line-height: 1.3;
}

.nav__cta { font-size: 0.9rem; padding: 0.65em 1.25em; }

/* Mobile hamburger toggle */
.nav__toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--c-line);
  width: 44px; height: 44px;
  padding: 0; margin-left: 1rem;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  cursor: pointer;
  border-radius: 3px;
  transition: border-color .15s;
}
.nav__toggle:hover { border-color: var(--c-ink); }
.nav__toggle-bar {
  width: 18px;
  height: 1.5px;
  background: var(--c-ink);
  transition: transform .2s, opacity .2s;
}
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] .nav__toggle-bar:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

@media (max-width: 960px) {
  .nav { position: sticky; top: 0; }
  .nav__inner { padding: 0.9rem 1.15rem; gap: 0.85rem; }
  .nav__cta { display: none; }
  .nav__toggle { display: inline-flex; }
  .nav__primary {
    position: absolute;
    top: 100%;
    left: 0; right: 0;
    background: var(--c-bg);
    border-top: 1px solid var(--c-line);
    border-bottom: 1px solid var(--c-line);
    max-height: calc(100vh - 100%);
    overflow-y: auto;
    transform: translateY(-8px);
    opacity: 0;
    visibility: hidden;
    transition: transform .22s ease-out, opacity .18s ease-out, visibility 0s .22s;
    pointer-events: none;
    z-index: 99;
  }
  .nav__primary.is-open {
    transform: translateY(0);
    opacity: 1;
    visibility: visible;
    transition: transform .22s ease-out, opacity .18s ease-out, visibility 0s;
    pointer-events: auto;
    box-shadow: 0 14px 44px oklch(15% 0.014 250 / 0.10);
  }
  .nav__menu { flex-direction: column; align-items: stretch; gap: 0; padding: 0.5rem 0; }
  .nav__menu > li > a { padding: 1rem 1.25rem; font-size: 1.02rem; border-bottom: 1px solid var(--c-line-soft); min-height: 48px; }
  .nav__item--has-children::after { display: none; }
  .nav__submenu {
    position: static;
    border: 0;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    min-width: 0;
    padding: 0 0 0.5rem;
    background: var(--c-bg-soft);
  }
  .nav__submenu a { padding: 0.85rem 2rem; font-size: 0.95rem; min-height: 44px; }
  .nav__submenu li:first-child a {
    background: transparent;
    padding-top: 1rem;
    padding-bottom: 0.55rem;
  }
}

/* Smaller-screen typography + spacing */
@media (max-width: 600px) {
  h1 { font-size: clamp(2.25rem, 9vw, 3rem); line-height: 1.1; }
  h2 { font-size: clamp(1.75rem, 6vw, 2.5rem); line-height: 1.12; }
  h3 { font-size: 1.35rem; }
  .container { padding-inline: 1.1rem; }
  .section { padding-block: 3rem; }
  .section--wide { padding-block: 3.5rem; }
  .nav__brand img { height: 44px; }
}
@media (max-width: 380px) {
  h1 { font-size: 2rem; }
  .nav__inner { padding: 0.75rem 0.9rem; }
}

/* ============================================================================
   SECTION HEADING
   ============================================================================ */
.section-head {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: 4rem;
  margin-bottom: 3rem;
  align-items: end;
}
.section-head h2 { max-width: 14ch; margin-bottom: 0; }
.section-head__intro {
  font-size: 1.2rem;
  line-height: 1.55;
  color: var(--c-ink-soft);
  max-width: 56ch;
  margin: 0;
  font-weight: 400;
}
.section--dark .section-head__intro, .section--darker .section-head__intro {
  color: var(--c-on-dark-soft);
}
@media (max-width: 768px) {
  .section-head { grid-template-columns: 1fr; gap: 1.5rem; margin-bottom: 3rem; }
}

/* ============================================================================
   FOOTER
   ============================================================================ */
.footer, body.cbv-v5 .footer { background: var(--c-bg-darker) !important; color: var(--c-on-dark-soft) !important; padding-block: 5rem 2rem; }
.footer * { color: inherit; }
.footer__top {
  max-width: var(--container);
  margin-inline: auto;
  padding-inline: 2rem;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid var(--c-on-dark-line);
}
.footer__brand h3 {
  font-family: var(--font-serif);
  font-variation-settings: "opsz" 72;
  font-weight: 600;
  font-size: 1.75rem;
  color: var(--c-on-dark);
  margin-bottom: 1rem;
  letter-spacing: 0.005em;
}
.footer__brand p { font-size: 0.95rem; max-width: 38ch; color: var(--c-on-dark-mute); line-height: 1.6; }
.footer__col h4 {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-on-dark-mute);
  margin-bottom: 1.5rem;
  font-weight: 500;
}
.footer__col ul { list-style: none; padding: 0; margin: 0; }
.footer__col li { margin-bottom: 0.85rem; }
.footer__col a { font-size: 0.93rem; color: var(--c-on-dark); text-decoration: none; font-weight: 400; }
.footer__col a:hover { color: var(--c-accent-bright); }
.footer__bottom {
  max-width: var(--container);
  margin-inline: auto;
  padding: 2rem 2rem 0;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 2.5rem;
  flex-wrap: wrap;
  font-size: 0.78rem;
}
.footer__legal { color: var(--c-on-dark-mute); font-weight: 500; }
.footer__disclaimer { max-width: 72ch; line-height: 1.6; color: var(--c-on-dark-mute); font-size: 0.78rem; }
.footer__disclaimer strong { color: var(--c-on-dark); }
@media (max-width: 768px) {
  .footer, body.cbv-v5 .footer { padding-block: 2.75rem 1.5rem !important; }
  .footer__top {
    grid-template-columns: 1fr;
    gap: 1.75rem;
    padding-inline: 1.5rem;
    padding-bottom: 1.75rem;
  }
  .footer__brand h3 { font-size: 1.4rem; margin-bottom: 0.5rem; }
  .footer__brand p { font-size: 0.9rem; line-height: 1.55; }
  .footer__col h4 { margin-bottom: 0.85rem; }
  .footer__col li { margin-bottom: 0.5rem; }
  .footer__col a { font-size: 0.9rem; }
  .footer__bottom {
    padding: 1.5rem 1.5rem 0;
    gap: 1rem;
    flex-direction: column;
  }
}

/* ============================================================================
   ACCESSIBILITY
   ============================================================================ */
:focus-visible { outline: 2px solid var(--c-accent); outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}
/* ============================================================================
   ASTRA THEME OVERRIDES — required because wp_head() injects Astra global CSS
   that targets body / h1-h6 / .ast-* containers with higher specificity.
   ============================================================================ */
body, body.ast-separate-container {
  background: var(--c-bg) !important;
  background-image: none !important;
  color: var(--c-ink) !important;
}
/* Force section colors over Astra's global h1-h6 #3a3a3a rule */
.hero h1, .hero h2, .hero h3, .hero h4,
.section--dark h1, .section--dark h2, .section--dark h3, .section--dark h4,
.section--darker h1, .section--darker h2, .section--darker h3, .section--darker h4 {
  color: var(--c-on-dark) !important;
}
/* Standard sections — keep ink color over Astra's grey */
.section h1, .section h2, .section h3,
main h1, main h2, main h3 {
  color: var(--c-ink);
}
/* Inside dark sections, lede / supporting text */
.hero p, .hero .hero__lede,
.section--dark p, .section--darker p {
  color: var(--c-on-dark-soft) !important;
}
/* Astra forces .site-content padding; cancel for our full-bleed sections */
.site-content, .site-content > .ast-container,
.ast-page-builder-template .site-content > .ast-container {
  max-width: none !important;
  padding: 0 !important;
}
/* Prevent Astra from boxing our content */
.cbv-v5 .entry-content { margin: 0; padding: 0; }
/* Hide any default WP/Astra page title that may render at the top */
.cbv-v5 .entry-header, .cbv-v5 .ast-archive-description, .cbv-v5 .ast-page-builder-title-bar { display: none !important; }
