/* ============================================================
   TaxOwl Advisors — Theme v2 (matches Web Style Guide v1.0)
   Indigo + Inter. Calm professionalism. Advisory tone.
   ============================================================ */

:root{
  /* Colors — primary palette */
  --primary:#5A7D66;
  --primary-hover:#4F6F5A;
  --primary-pressed:#43604E;
  --primary-subtle:#E5EDE8;
  --primary-on-subtle:#43604E;

  /* Colors — neutrals */
  --bg-base:#FFFFFF;
  --bg-subtle:#F6F8FB;
  --bg-inverse:#16235A;
  --text-primary:#1B1D1F;
  --text-secondary:#3D4F6B;
  --text-tertiary:#6B7280;
  --border-subtle:#E5E9F0;

  /* Colors — status */
  --success:#10B981;
  --warning:#F59E0B;
  --danger:#EF4444;
  --info:#88A892;

  /* Legacy variable aliases (keep existing inline CSS working) */
  --navy:#1B1D1F;
  --navy-ink:#16235A;
  --navy-2:#3D4F6B;
  --indigo:#5A7D66;
  --indigo-2:#4F6F5A;
  --indigo-tint:#E5EDE8;
  --gold:#88A892;
  --gold-soft:#E5EDE8;
  --bg:#F6F8FB;
  --bg-cool:#F6F8FB;
  --line:#E5E9F0;
  --green:#10B981;
  --red:#EF4444;
  --amber:#F59E0B;
  --muted:#6B7280;
  --serif:'Inter','-apple-system','BlinkMacSystemFont','Segoe UI',Roboto,sans-serif;
  --sans:'Inter','-apple-system','BlinkMacSystemFont','Segoe UI',Roboto,sans-serif;

  /* Typography */
  --ff-base:'Inter','-apple-system','BlinkMacSystemFont','Segoe UI',Roboto,sans-serif;
  --fs-display:5rem;
  --fs-h1:3rem;
  --fs-h2:1.875rem;
  --fs-h3:1.5rem;
  --fs-h4:1.25rem;
  --fs-lead:1.125rem;
  --fs-body:1rem;
  --fs-body-sm:0.875rem;
  --fs-caption:0.75rem;
  --fw-regular:400;
  --fw-medium:500;
  --fw-semibold:600;
  --fw-bold:700;
  --fw-extrabold:800;
  --lh-tight:1.1;
  --lh-snug:1.2;
  --lh-normal:1.6;
  --ls-tight:-0.02em;
  --ls-normal:0;
  --ls-wider:0.16em;

  /* Spacing — 4-pt base */
  --space-1:0.25rem;
  --space-2:0.5rem;
  --space-3:0.75rem;
  --space-4:1rem;
  --space-6:1.5rem;
  --space-8:2rem;
  --space-12:3rem;
  --space-16:4rem;
  --space-24:6rem;

  /* Radius */
  --r-sm:6px;
  --r-md:10px;
  --r-lg:14px;
}

/* ============ BASE ============ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--ff-base) !important;
  font-size:var(--fs-body);
  line-height:var(--lh-normal);
  color:var(--text-primary);
  background:var(--bg-base);
  -webkit-font-smoothing:antialiased;
  font-feature-settings:"ss01","kern";
  margin:0;
}
a{color:var(--primary);text-decoration:none}
a:hover{color:var(--primary-hover);text-decoration:underline}
img,svg{max-width:100%;display:block}
p{margin:0 0 var(--space-4)}

/* ============ TYPOGRAPHY UTILITY CLASSES ============ */
.t-display{font-size:var(--fs-display);font-weight:var(--fw-extrabold);line-height:var(--lh-tight);letter-spacing:var(--ls-tight);font-family:var(--ff-base)}
.t-h1{font-size:var(--fs-h1);font-weight:var(--fw-bold);line-height:var(--lh-snug);letter-spacing:var(--ls-tight);font-family:var(--ff-base)}
.t-h2{font-size:var(--fs-h2);font-weight:var(--fw-bold);line-height:var(--lh-snug);font-family:var(--ff-base)}
.t-h3{font-size:var(--fs-h3);font-weight:var(--fw-semibold);line-height:var(--lh-snug);font-family:var(--ff-base)}
.t-h4{font-size:var(--fs-h4);font-weight:var(--fw-semibold);line-height:var(--lh-snug);font-family:var(--ff-base)}
.t-lead{font-size:var(--fs-lead);font-weight:var(--fw-regular);line-height:var(--lh-normal);color:var(--text-secondary)}
.t-body{font-size:var(--fs-body);font-weight:var(--fw-regular);line-height:var(--lh-normal)}
.t-small{font-size:var(--fs-body-sm);font-weight:var(--fw-regular);line-height:var(--lh-normal)}
.t-caption{font-size:var(--fs-caption);font-weight:var(--fw-semibold);letter-spacing:var(--ls-wider);text-transform:uppercase}

/* ============ HEADING DEFAULTS — Inter, NOT serif ============ */
h1,h2,h3,h4{
  font-family:var(--ff-base) !important;
  color:var(--text-primary);
  margin:0 0 var(--space-4);
  line-height:var(--lh-snug) !important;
}
h1{font-size:var(--fs-h1) !important;font-weight:var(--fw-bold) !important;letter-spacing:var(--ls-tight) !important}
h2{font-size:var(--fs-h2) !important;font-weight:var(--fw-bold) !important;letter-spacing:var(--ls-normal) !important}
h3{font-size:var(--fs-h3) !important;font-weight:var(--fw-semibold) !important;letter-spacing:var(--ls-normal) !important}
h4{font-size:var(--fs-h4) !important;font-weight:var(--fw-semibold) !important}

@media (max-width:640px){
  h1{font-size:2.25rem !important}
  h2{font-size:1.5rem !important}
}

/* Remove the gold accent line that was wrong */
.hero h1::after,
section.hero h1::after,
.hero-inner h1::after,
h1::after{content:none !important;display:none !important}

/* ============ HERO ============ */
.hero{
  background:linear-gradient(180deg, var(--bg-subtle) 0%, var(--bg-base) 100%) !important;
  padding:var(--space-16) var(--space-6) var(--space-12) !important;
  position:relative;
}
.hero::before{content:none !important;display:none !important}
.hero-inner,.hero .container{max-width:1200px;margin:0 auto}
.hero h1,.hero .t-h1{font-size:var(--fs-h1) !important}
.hero p,.hero .t-lead{color:var(--text-secondary)}

/* Hero eyebrow — replaces all old eyebrow patterns */
.hero-eyebrow,
.eyebrow,
span.eyebrow,
.section-head .eyebrow,
.hero .eyebrow{
  display:inline-block !important;
  color:var(--primary) !important;
  font-family:var(--ff-base) !important;
  font-size:var(--fs-caption) !important;
  font-weight:var(--fw-bold) !important;
  letter-spacing:var(--ls-wider) !important;
  text-transform:uppercase !important;
  margin-bottom:var(--space-4) !important;
  background:transparent !important;
  padding:0 !important;
}

/* ============ SECTION ============ */
.section{padding:var(--space-16) var(--space-6)}
.section-alt{background:var(--bg-subtle)}
.section-inverse{background:var(--bg-inverse);color:#fff}
.section-inverse h1,.section-inverse h2,.section-inverse h3,.section-inverse h4{color:#fff !important}
.section-inverse p,.section-inverse .t-lead,.section-inverse .t-body{color:rgba(255,255,255,0.85)}

.container{max-width:1200px;margin:0 auto;padding-inline:var(--space-6)}

/* ============ BUTTONS ============ */
.btn,a.btn,button.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:var(--space-3) var(--space-6);
  border-radius:var(--r-md);
  font-family:var(--ff-base);
  font-weight:var(--fw-semibold);
  font-size:var(--fs-body);
  line-height:1;
  text-decoration:none;
  cursor:pointer;
  border:1px solid transparent;
  transition:all 0.18s ease;
}
.btn-primary,
.nav-links a.btn-primary,
a.btn-primary,
button.btn-primary{
  background:var(--primary) !important;
  color:#fff !important;
  border-color:var(--primary) !important;
  font-weight:var(--fw-semibold) !important;
  box-shadow:0 1px 2px rgba(90,125,102,0.2) !important;
}
.btn-primary:hover,
.nav-links a.btn-primary:hover,
a.btn-primary:hover{
  background:var(--primary-hover) !important;
  border-color:var(--primary-hover) !important;
  color:#fff !important;
  text-decoration:none !important;
  box-shadow:0 4px 12px rgba(90,125,102,0.35) !important;
}
.btn-primary:active,a.btn-primary:active{background:var(--primary-pressed) !important;border-color:var(--primary-pressed) !important}
.btn-primary:disabled,a.btn-primary:disabled,button.btn-primary:disabled{opacity:0.5;cursor:not-allowed}

.btn-secondary,a.btn-secondary,button.btn-secondary{
  background:var(--bg-base);
  color:var(--text-primary);
  border:1px solid var(--border-subtle);
}
.btn-secondary:hover{background:var(--bg-subtle);border-color:var(--text-secondary);text-decoration:none}

.btn-ghost,a.btn-ghost,button.btn-ghost{
  background:transparent;
  color:var(--text-primary);
  border-color:transparent;
}
.btn-ghost:hover{background:var(--bg-subtle);text-decoration:none}

.btn-gold,a.btn-gold{
  background:var(--primary) !important;
  color:#fff !important;
  border-color:var(--primary) !important;
}
.btn-gold:hover,a.btn-gold:hover{background:var(--primary-hover) !important;text-decoration:none !important}

.btn-outline{background:transparent;color:var(--primary);border-color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff;text-decoration:none}

.btn-lg{padding:var(--space-4) var(--space-8);font-size:var(--fs-lead)}
.btn-sm{padding:var(--space-2) var(--space-4);font-size:var(--fs-body-sm)}

/* ============ CARDS ============ */
.card{background:var(--bg-base);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:var(--space-6)}
.card-elevated{box-shadow:0 4px 18px rgba(15,23,42,0.06)}
.card-interactive{cursor:pointer;transition:transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease}
.card-interactive:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(15,23,42,0.08);border-color:var(--primary)}

.audience-card,.feature-card,.cat-card,.role-card,.tier-card{
  background:var(--bg-base);
  border:1px solid var(--border-subtle);
  border-radius:var(--r-lg);
  transition:all 0.18s ease;
}
.audience-card:hover,.feature-card:hover,.cat-card:hover{
  border-color:var(--primary) !important;
  transform:translateY(-2px);
  box-shadow:0 8px 24px rgba(90,125,102,0.10);
}
.tier-card.featured{border-color:var(--primary) !important;border-width:2px !important}
.tier-card.featured::before{background:var(--primary) !important;color:#fff !important}

/* Layout exceptions for h3 inside cards */
.step h3{margin-top:40px !important;margin-bottom:var(--space-2) !important;font-size:var(--fs-body) !important;font-weight:var(--fw-semibold) !important}
.step-num{background:var(--primary) !important}
.audience-card h3,.feature-card h3,.cat-card h3,.role-card h3,.tier-card h3{margin-top:0 !important;font-size:var(--fs-h4) !important}

.audience-card .icon,.feature-card .num{color:var(--primary) !important}

/* ============ FORM FIELDS ============ */
.field{display:flex;flex-direction:column;gap:var(--space-2)}
.field label{font-size:var(--fs-body-sm);font-weight:var(--fw-semibold);color:var(--text-primary)}
.field input,.field select,.field textarea,
input,select,textarea{
  font-family:var(--ff-base);
  font-size:var(--fs-body);
  padding:var(--space-3) var(--space-4);
  border:1px solid var(--border-subtle);
  border-radius:var(--r-sm);
  background:var(--bg-base);
  color:var(--text-primary);
  transition:border-color 0.18s ease, box-shadow 0.18s ease;
}
.field input:focus,.field select:focus,.field textarea:focus,
input:focus,select:focus,textarea:focus{
  outline:none !important;
  border-color:var(--primary) !important;
  box-shadow:0 0 0 3px rgba(90,125,102,0.18) !important;
}
.field-help{font-size:var(--fs-caption);color:var(--text-tertiary);margin-top:var(--space-1)}

/* ============ BADGES + PILLS ============ */
.badge{display:inline-block;background:var(--bg-subtle);color:var(--text-secondary);font-size:var(--fs-caption);font-weight:var(--fw-semibold);padding:var(--space-1) var(--space-3);border-radius:var(--r-sm);letter-spacing:0.04em}
.badge-success{background:#D1FAE5;color:#065F46}
.badge-warning{background:#FEF3C7;color:#92400E}
.badge-danger{background:#FEE2E2;color:#991B1B}
.pill{display:inline-block;background:var(--primary-subtle);color:var(--primary-pressed);font-size:var(--fs-caption);font-weight:var(--fw-semibold);padding:var(--space-1) var(--space-3);border-radius:999px;letter-spacing:0.04em;text-transform:uppercase}
.pill-success{background:#D1FAE5;color:#065F46}
.pill-warning{background:#FEF3C7;color:#92400E}
.pill-danger{background:#FEE2E2;color:#991B1B}

/* ============ NAV ============ */
/* position:relative on the nav container is REQUIRED so the absolute-positioned
   mobile dropdown (.nav-links @ <820px) anchors to the header instead of <body>. */
header,.nav,header.nav,nav.nav{position:relative;background:var(--bg-base);border-bottom:1px solid var(--border-subtle)}
.nav-links{display:flex;gap:24px;align-items:center;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--text-primary);font-weight:var(--fw-semibold);font-size:var(--fs-body-sm)}
.nav-links a:hover{color:var(--primary);text-decoration:none}
/* Hamburger toggle — hidden on desktop, shown on mobile via @media below */
/* -webkit-tap-highlight-color suppresses the browser-default reddish tap overlay
   on iOS Safari / Android Chrome. Without it, tapping the hamburger flashes pink. */
/* WCAG 2.1 AA: 44x44px minimum touch target. padding:10px on .nav-toggle gives
   the click box ~44x44px once the 24px-wide span content is included. */
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:10px;-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy,#0F172A);margin:5px 0;transition:0.2s}
.nav-toggle:focus{outline:none}
.nav-toggle:focus-visible{outline:2px solid var(--primary,#88A892);outline-offset:2px;border-radius:4px}
.nav-toggle:active span{background:var(--primary,#88A892)}
@media (max-width:820px){
  header,.nav,header.nav,nav.nav{position:relative}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;background:#fff;border-bottom:1px solid var(--border-subtle,#E5E9F0);flex-direction:column;gap:0;padding:8px 0;z-index:50}
  .nav-links.open{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:14px 24px;border-bottom:1px solid var(--border-subtle,#E5E9F0)}
  .nav-links .btn{margin:12px 24px;text-align:center}
  .nav-toggle{display:block}
}

/* ============ FOOTER — use parent navy (bg-inverse) ============ */
footer{
  background:var(--bg-inverse) !important;
  color:rgba(255,255,255,0.85) !important;
  padding:var(--space-12) var(--space-6) var(--space-8) !important;
  border-top:none !important;
  font-family:var(--ff-base) !important;
  text-align:left !important;
  font-size:var(--fs-body) !important;
}
footer h4{
  color:#fff !important;
  font-size:var(--fs-caption) !important;
  text-transform:uppercase !important;
  letter-spacing:var(--ls-wider) !important;
  margin:0 0 var(--space-4) !important;
  font-family:var(--ff-base) !important;
  font-weight:var(--fw-bold) !important;
  text-align:left !important;
}
footer a{color:rgba(255,255,255,0.85) !important;text-decoration:none !important}
footer a:hover{color:#fff !important;text-decoration:underline !important}
footer .footer-inner{
  max-width:1200px !important;
  margin:0 auto !important;
  display:grid !important;
  grid-template-columns:1.5fr 1fr 1fr !important;
  gap:var(--space-8) !important;
  text-align:left !important;
}
footer ul{list-style:none !important;margin:0 !important;padding:0 !important;text-align:left !important}
footer ul li{margin-bottom:var(--space-2) !important;font-size:var(--fs-body-sm) !important;text-align:left !important}
footer .footer-tag{
  font-size:var(--fs-body-sm) !important;
  max-width:360px !important;
  margin-bottom:var(--space-4) !important;
  color:rgba(255,255,255,0.85) !important;
  text-align:left !important;
}
footer .footer-legal{
  max-width:1200px !important;
  margin:var(--space-8) auto 0 !important;
  padding-top:var(--space-6) !important;
  border-top:1px solid rgba(255,255,255,0.1) !important;
  font-size:var(--fs-caption) !important;
  color:rgba(255,255,255,0.65) !important;
  line-height:var(--lh-normal) !important;
  text-align:left !important;
}
footer .footer-legal p{margin:0 0 var(--space-2) !important;color:rgba(255,255,255,0.65) !important;text-align:left !important}
footer .footer-legal strong{color:rgba(255,255,255,0.95) !important}
@media (max-width:760px){
  footer .footer-inner{grid-template-columns:1fr !important;gap:var(--space-6) !important}
}

/* Legal pages — hide redundant eyebrows that mirror H2 */
body.legal-page .section-head .eyebrow,
body[data-page="legal"] .section-head .eyebrow{display:none !important}

/* Welcome banner / FM banner remap to indigo, not gold */
.fm-banner{
  background:linear-gradient(120deg, var(--primary-subtle) 0%, #FAFAFE 100%) !important;
  border-left-color:var(--primary) !important;
}
.fm-banner .fm-bolt{color:var(--primary) !important}
.fm-banner .fm-tag{background:var(--primary) !important;color:#fff !important}
.fm-counter{color:var(--primary) !important}

/* Coming soon pill on Books page — indigo, not gold */
.coming-pill{background:var(--primary) !important;color:#fff !important}

/* Calculator section title accent — indigo */
.calc-section-title{color:var(--primary) !important}

/* === Cookie consent banner (extracted from inline) === */
.taocc-banner{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);max-width:560px;width:calc(100% - 32px);background:#0F172A;color:#F1F5F9;padding:16px 22px;border-radius:12px;box-shadow:0 8px 32px rgba(0,0,0,0.32);z-index:99999;font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Helvetica,Arial,sans-serif;font-size:0.9rem;line-height:1.5;display:none}
.taocc-banner.show{display:flex;flex-wrap:wrap;align-items:center;gap:14px}
.taocc-banner p{margin:0;flex:1 1 320px;min-width:0}
.taocc-banner a{color:#A9C4B2;text-decoration:underline}
.taocc-banner .taocc-actions{display:flex;gap:8px;flex-shrink:0}
.taocc-banner button{font-family:inherit;font-size:0.86rem;font-weight:700;padding:9px 16px;border-radius:8px;border:none;cursor:pointer;transition:opacity 0.15s}
.taocc-banner button:hover{opacity:0.85}
.taocc-banner .taocc-decline{background:transparent;color:#F1F5F9;border:1px solid rgba(241,245,249,0.3)}
.taocc-banner .taocc-accept{background:#5A7D66;color:#fff}
@media (max-width:540px){.taocc-banner{padding:14px 18px;bottom:12px}.taocc-banner button{flex:1}.taocc-banner .taocc-actions{flex:1 1 100%}}

/* === Auto-extracted: foundational rules duplicated across all/most pages === */
*,*::before,*::after{box-sizing:border-box}
a:hover{text-decoration:underline}
.brand-logo{height:72px;width:auto;display:block}
/* ===== CANONICAL FOOTER v3 — DEFINITIVE ===== */
  /* Note: border-top was legacy gold #C8A14C — replaced 2026-05-14 with
     canonical Advisors indigo #16235A per v1.6 lockup memory. */
  footer{background:linear-gradient(135deg, #091322 0%, #0E1838 100%) !important;color:#CBD5E1 !important;padding:48px 24px 28px !important;border-top:2px solid #16235A !important;font-family:'Inter',-apple-system,sans-serif !important;text-align:left !important;font-size:0.95rem !important}
footer h4{color:#fff !important;font-size:0.78rem !important;text-transform:uppercase !important;letter-spacing:0.16em !important;margin:0 0 14px !important;font-family:'Inter',sans-serif !important;font-weight:600 !important;text-align:left !important}
footer a{color:#CBD5E1 !important;text-decoration:none !important}
footer a:hover{color:#fff !important;text-decoration:underline !important}
footer .footer-inner{max-width:1100px !important;margin:0 auto !important;display:grid !important;grid-template-columns:1.5fr 1fr 1fr !important;gap:36px !important;text-align:left !important}
footer ul{list-style:none !important;margin:0 !important;padding:0 !important;text-align:left !important}
footer ul li{margin-bottom:8px !important;font-size:0.9rem !important;text-align:left !important}
footer .footer-tag{font-size:0.9rem !important;max-width:360px !important;margin-bottom:16px !important;color:#CBD5E1 !important;text-align:left !important}
footer .footer-legal{max-width:1100px !important;margin:36px auto 0 !important;padding-top:20px !important;border-top:1px solid rgba(255,255,255,0.1) !important;font-size:0.78rem !important;color:#94A3B8 !important;line-height:1.7 !important;text-align:left !important}
footer .footer-legal p{margin:0 0 10px !important;color:#94A3B8 !important;text-align:left !important}
footer .footer-legal strong{color:#CBD5E1 !important}
@media (max-width:760px){footer .footer-inner{grid-template-columns:1fr !important;gap:28px !important}}
a{color:var(--indigo-2);text-decoration:none}
.nav-links a:hover{color:var(--indigo-2);text-decoration:none}
/* NOTE: do NOT redeclare `.nav-toggle{display:none}` here — the canonical
   declaration is at the top of this file (line ~310) inside a block that's
   followed by the @media (max-width:820px){.nav-toggle{display:block}} rule.
   A duplicate baseline AFTER that media query silently re-hides the
   hamburger on every mobile page (cascade source-order beats media query
   when specificity is equal). Spans-only rule below is safe to keep. */
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:0.2s}
footer a:hover{color:#fff}

/* === Skip-to-content link (a11y) === */
.skip-link{
  position:absolute;
  left:0;
  top:-44px;
  background:#19293C;
  color:#FFFFFF;
  padding:10px 18px;
  z-index:100000;
  text-decoration:none;
  font-weight:700;
  font-size:0.92rem;
  border-radius:0 0 6px 0;
  transition:top 0.15s ease;
}
.skip-link:focus,
.skip-link:focus-visible{
  top:0;
  outline:none;
}

/* === Focus-visible system (WCAG 2.4.7) === */
:focus-visible{
  outline:2px solid #16235A;
  outline-offset:2px;
  border-radius:2px;
}
button:focus-visible,
.btn:focus-visible,
a.btn:focus-visible,
a.btn-primary:focus-visible{
  outline:2px solid #16235A;
  outline-offset:3px;
}
input:focus-visible,
select:focus-visible,
textarea:focus-visible{
  outline:2px solid #16235A;
  outline-offset:0;
}
/* main itself shouldn't show a focus ring when scripted-focused */
main:focus,
main:focus-visible{
  outline:none;
}


@media (max-width:640px){.brand-logo{height:56px;width:auto}}

/* Footer brand line: pure sage on navy (dark-bg text exception, ~8:1) */
footer .footer-tagline{color:#88A892 !important}
