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

:root{
  /* Colors — primary palette */
  --primary:#6366F1;
  --primary-hover:#4F52E0;
  --primary-pressed:#3F42BD;
  --primary-subtle:#E5E7FB;
  --primary-on-subtle:#3F42BD;

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

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

  /* Legacy variable aliases (keep existing inline CSS working) */
  --navy:#1B1D1F;
  --navy-ink:#00194A;
  --navy-2:#3D4F6B;
  --indigo:#6366F1;
  --indigo-2:#4F52E0;
  --indigo-tint:#E5E7FB;
  --gold:#6366F1;
  --gold-soft:#E5E7FB;
  --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;
  text-align:left !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(99,102,241,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(99,102,241,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(99,102,241,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(99,102,241,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 ============ */
.nav,header.nav,nav.nav{background:var(--bg-base);border-bottom:1px solid var(--border-subtle)}
.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}

/* ============ 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}
