/* HNW-AdvisorListen — site styles. Plain CSS, no build step.
   Design tokens + component classes captured from the live site.
   Class vocabulary used by lib/hnw_lib.php and all generators/. */

:root {
  --background:#f9fcff; --foreground:#071727;
  --card:#ffffff; --card-foreground:#071727;
  --primary:#004b97; --primary-foreground:#f9fcff;
  --secondary:#ebf3f9; --secondary-foreground:#102239;
  --muted:#ebf3f9; --muted-foreground:#576574;
  --accent:#3fbf86; --accent-foreground:#00170b;
  --destructive:#e62b34; --destructive-foreground:#f9fcff;
  --amber:#f99c00; --amber-ink:#9a6200;
  --border:#dbe2e9; --input:#e2e9f0; --ring:#3072c1;
  --radius:0.75rem;
  --font-sans:ui-sans-serif,system-ui,-apple-system,"Segoe UI",Inter,sans-serif;
  --font-serif:ui-serif,Georgia,"Iowan Old Style",serif;
  --wrap:1152px;
}

*,*::before,*::after{box-sizing:border-box;border-color:var(--border)}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--background);color:var(--foreground);
  font-family:var(--font-sans);line-height:1.55;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-serif);letter-spacing:-.01em;line-height:1.1;margin:0}
a{color:inherit;text-decoration:none}
p{margin:0}
img,svg{display:block}
::selection{background:color-mix(in srgb,var(--primary) 18%,transparent)}

.wrap{max-width:var(--wrap);margin:0 auto;padding-left:1.25rem;padding-right:1.25rem}
.muted{color:var(--muted-foreground)}
.section{padding-top:4rem;padding-bottom:4rem}
.center{text-align:center}

/* ── header ───────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--background) 85%,transparent);
  backdrop-filter:saturate(1.1) blur(8px);border-bottom:1px solid color-mix(in srgb,var(--border) 70%,transparent)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:4rem;gap:1.5rem}
.brand{display:inline-flex;align-items:center;gap:.5rem}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;
  border-radius:.55rem;background:var(--primary);color:var(--primary-foreground)}
.brand-name{font-weight:600;font-size:1.125rem;letter-spacing:-.01em}
.nav-links{display:flex;align-items:center;gap:.25rem;flex-wrap:wrap}
.nav-link{padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;font-weight:500;color:var(--muted-foreground)}
.nav-link:hover{color:var(--foreground)}
.nav-link.active{background:var(--secondary);color:var(--foreground)}

/* ── footer ───────────────────────────────────────────────── */
.site-footer{margin-top:5rem;border-top:1px solid var(--border);background:color-mix(in srgb,var(--secondary) 40%,var(--background))}
.footer-grid{display:grid;gap:2.5rem;padding-top:3rem;padding-bottom:3rem;grid-template-columns:1fr}
.footer-about{max-width:24rem}
.footer-about .muted{margin-top:.75rem;font-size:.9rem}
.foot-h{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-foreground);margin:0 0 .75rem}
.foot-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}
.foot-list a:hover{color:var(--primary)}
.footer-bottom{display:flex;flex-direction:column;gap:.25rem;padding-top:1.25rem;padding-bottom:1.25rem;
  border-top:1px solid var(--border);font-size:.75rem;color:var(--muted-foreground)}
@media(min-width:760px){
  .footer-grid{grid-template-columns:2fr 1fr 1fr}
  .footer-bottom{flex-direction:row;align-items:center;justify-content:space-between}
}

/* ── typography helpers ───────────────────────────────────── */
.kicker{font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.14em;color:var(--primary);margin:0}
.lead{color:var(--muted-foreground);font-size:1.05rem;margin-top:1rem}
.h1{font-size:clamp(2.4rem,5vw,3.6rem);font-weight:700}
.h2{font-size:clamp(1.7rem,3vw,2.1rem);font-weight:700}
.eyebrow{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-foreground)}

/* ── page hero (interior pages) ───────────────────────────── */
.page-hero{background:color-mix(in srgb,var(--secondary) 40%,var(--background));border-bottom:1px solid var(--border)}
.page-hero .wrap{padding-top:3.5rem;padding-bottom:3.5rem}
.page-hero h1{margin-top:.75rem;font-size:clamp(2.1rem,4.4vw,3.1rem);font-weight:700;max-width:48rem}
.page-hero .lead{max-width:44rem}

/* ── buttons ──────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;cursor:pointer;
  border-radius:.5rem;font-size:.9rem;font-weight:500;padding:.6rem 1.1rem;border:1px solid transparent;
  transition:background .15s,color .15s,border-color .15s;line-height:1}
.btn-primary{background:var(--primary);color:var(--primary-foreground)}
.btn-primary:hover{background:color-mix(in srgb,var(--primary) 90%,#000)}
.btn-outline{background:var(--card);color:var(--foreground);border-color:var(--input)}
.btn-outline:hover{background:var(--secondary)}
.btn-lg{padding:.8rem 1.5rem;font-size:1rem}

/* ── cards & grids ────────────────────────────────────────── */
.card{background:var(--card);color:var(--card-foreground);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:0 1px 2px rgba(7,23,39,.04)}
.pad{padding:1.5rem}
.grid{display:grid;gap:1.25rem;grid-template-columns:1fr}
@media(min-width:680px){.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(2,1fr)}.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1000px){.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}}

/* ── badges ───────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.3rem;border-radius:999px;padding:.15rem .6rem;
  font-size:.72rem;font-weight:600;border:1px solid transparent;text-transform:capitalize}
.badge-outline{border-color:var(--border);color:var(--foreground);background:transparent}
.badge-secondary{background:var(--secondary);color:var(--secondary-foreground)}
.sent-negative{background:color-mix(in srgb,var(--destructive) 12%,#fff);color:var(--destructive)}
.sent-mixed{background:color-mix(in srgb,var(--amber) 16%,#fff);color:var(--amber-ink)}
.sent-neutral{background:var(--muted);color:var(--muted-foreground)}
.sent-positive{background:color-mix(in srgb,var(--accent) 16%,#fff);color:var(--accent-foreground)}
.flag-caution{background:color-mix(in srgb,var(--destructive) 12%,#fff);color:var(--destructive)}
.flag-watch{background:color-mix(in srgb,var(--amber) 16%,#fff);color:var(--amber-ink)}
.flag-none{background:var(--muted);color:var(--muted-foreground)}

/* ── signal card ──────────────────────────────────────────── */
.signal-card{display:flex;flex-direction:column;padding:1.25rem}
.signal-top{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem}
.signal-score-wrap{text-align:right;line-height:1}
.signal-score{font-size:1.9rem;font-weight:700;font-variant-numeric:tabular-nums}
.signal-score.s-high{color:var(--destructive)}
.signal-score.s-mid{color:var(--amber)}
.signal-score.s-low{color:var(--primary)}
.signal-score-label{margin-top:.25rem;font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--muted-foreground)}
.signal-topic{margin-top:.75rem;font-size:1.125rem;font-weight:600;line-height:1.25;font-family:var(--font-serif)}
.signal-badges{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-top:.75rem}
.vol{display:inline-flex;align-items:center;gap:.25rem;font-size:.72rem;font-weight:600;color:var(--muted-foreground)}
.vol.trend-up{color:var(--accent-foreground)}
.vol.trend-down{color:var(--destructive)}
.vol.trend-flat{color:var(--muted-foreground)}
.signal-meta{margin:1rem 0 0;display:flex;flex-direction:column;gap:.7rem}
.signal-meta dt{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-foreground)}
.signal-meta dd{margin:.15rem 0 0;font-size:.9rem}
.signal-foot{margin-top:1rem;padding-top:.75rem;border-top:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;gap:.75rem;font-size:.8rem}
.guide-link{display:inline-flex;align-items:center;gap:.4rem;font-weight:500;color:var(--primary)}
.guide-link:hover{text-decoration:underline}
.sponsored{color:var(--muted-foreground);font-size:.75rem}
.sponsored strong{color:var(--foreground)}
.open-brief{color:var(--muted-foreground);font-weight:500;font-size:.75rem}
.open-brief:hover{color:var(--primary)}

/* ── home hero ────────────────────────────────────────────── */
.hero{background:color-mix(in srgb,var(--secondary) 40%,var(--background))}
.hero .wrap{display:grid;gap:3rem;padding-top:4rem;padding-bottom:4rem;grid-template-columns:1fr}
.hero h1{font-size:clamp(2.6rem,5.5vw,3.75rem);font-weight:700;line-height:1.04;margin-top:1.25rem}
.hero h1 .accent{color:var(--primary)}
.hero .lead{max-width:36rem;font-size:1.125rem}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem;margin-top:2rem}
@media(min-width:1000px){.hero .wrap{grid-template-columns:1.15fr .85fr;padding-top:6rem;padding-bottom:6rem}}

/* pill chip */
.chip{display:inline-flex;align-items:center;gap:.4rem;border-radius:999px;background:var(--secondary);
  color:var(--secondary-foreground);padding:.35rem .8rem;font-size:.8rem;font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:1.5rem}
.chip-outline{border:1px solid var(--border);background:transparent;color:var(--muted-foreground);font-weight:500}

/* small label list */
.label{font-size:.66rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-foreground)}
.quote{border-left:2px solid var(--accent);padding-left:.75rem;font-style:italic;font-size:.9rem;color:color-mix(in srgb,var(--foreground) 90%,transparent)}
.bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem;font-size:.9rem}
.bullets li{display:flex;gap:.5rem}
.bullets li::before{content:"";flex:0 0 auto;width:.4rem;height:.4rem;border-radius:999px;background:var(--accent);margin-top:.5rem}
.stack{display:flex;flex-direction:column;gap:.75rem}
.section-head{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.hide-sm{display:none}
@media(min-width:680px){.hide-sm{display:inline-flex}}

/* search + filters (signal board) */
.toolbar{display:flex;flex-direction:column;gap:1rem}
@media(min-width:1000px){.toolbar{flex-direction:row;align-items:center;justify-content:space-between}}
.search{position:relative;max-width:24rem;width:100%}
.search input{width:100%;height:2.75rem;border:1px solid var(--input);border-radius:.5rem;background:var(--card);
  padding:0 .75rem 0 2.25rem;font-size:.9rem;color:var(--foreground)}
.search input:focus{outline:2px solid var(--ring);outline-offset:0}
.search svg{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);color:var(--muted-foreground)}
.filters{display:flex;flex-wrap:wrap;gap:.5rem}
.filter{cursor:pointer;border:1px solid var(--border);background:transparent;color:var(--muted-foreground);
  border-radius:999px;padding:.4rem .75rem;font-size:.75rem;font-weight:500}
.filter:hover{color:var(--foreground)}
.filter.active{background:var(--primary);border-color:var(--primary);color:var(--primary-foreground)}
.count{margin-top:1.5rem;font-size:.875rem;color:var(--muted-foreground)}
.count strong{color:var(--foreground)}

/* pricing */
.price{font-size:1.9rem;font-weight:700;margin-top:.25rem}
.price small{font-size:.9rem;font-weight:500;color:var(--muted-foreground)}
.tier-popular{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}
.feature-list{list-style:none;margin:1rem 0 0;padding:0;display:flex;flex-direction:column;gap:.55rem;font-size:.875rem}
.feature-list li{display:flex;gap:.5rem;align-items:flex-start}
.feature-list svg{flex:0 0 auto;color:var(--accent);margin-top:.15rem}

/* article / playbook detail */
.article{max-width:48rem;margin:0 auto}
.article section{margin-top:2rem}
.article h2{font-family:var(--font-sans);font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted-foreground)}
.article .body{margin-top:.5rem;font-size:.95rem;line-height:1.6;color:color-mix(in srgb,var(--foreground) 92%,transparent)}
.numbered{list-style:none;margin:.5rem 0 0;padding:0;display:flex;flex-direction:column;gap:.6rem}
.numbered li{display:flex;gap:.75rem;align-items:flex-start}
.num{flex:0 0 auto;width:1.5rem;height:1.5rem;border-radius:999px;background:var(--secondary);color:var(--primary);
  font-size:.75rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center}
.step{padding:1rem}
.step .eyebrow{margin-bottom:.25rem}
.callout{background:color-mix(in srgb,var(--secondary) 70%,#fff);border-radius:.6rem;padding:1rem;font-size:.95rem}
.email-box pre{white-space:pre-wrap;font-family:var(--font-sans);font-size:.9rem;margin:.5rem 0 0;color:color-mix(in srgb,var(--foreground) 92%,transparent)}

/* misc */
.divider{height:1px;background:var(--border);border:0;margin:0}
.contact-grid a{color:var(--primary);font-weight:500}
.contact-grid a:hover{text-decoration:underline}
.firewall{list-style:none;margin:.75rem 0 0;padding:0;display:flex;flex-direction:column;gap:.5rem;font-size:.9rem;color:var(--muted-foreground)}
.firewall li{padding-left:1.1rem;position:relative}
.firewall li::before{content:"·";position:absolute;left:.25rem;color:var(--primary);font-weight:700}

/* print-only CTA (shown only when the page is printed/saved to PDF) */
.print-cta{display:none}

/* In the News */
.news-card{display:flex;flex-direction:column}
.news-top{display:flex;align-items:center;justify-content:space-between;gap:.5rem}
.news-date{font-size:.72rem}
.news-title{margin:.6rem 0 0;font-size:1.05rem;line-height:1.25;font-family:var(--font-serif)}
.news-title a:hover{color:var(--primary);text-decoration:underline}
.news-take{margin-top:.5rem;font-size:.9rem;flex:1}
.news-foot{margin-top:.9rem;display:flex;align-items:center;justify-content:space-between;gap:.5rem;flex-wrap:wrap}
.roster{margin-top:1rem;font-size:.78rem;color:var(--muted-foreground)}

/* ── print / downloadable PDF ──────────────────────────────────────────────
   Fires on the "Download PDF" buttons (window.print) on the brief and playbook
   pages. Strips all site chrome and interactive CTAs so only the data prints,
   tightens the layout for paper, and repeats one small advisorlisten.com line
   at the bottom of every page. */
@media print {
  *,*::before,*::after{-webkit-print-color-adjust:exact;print-color-adjust:exact}
  html,body{background:#fff;color:#0b1521;font-size:10.5pt;line-height:1.45}
  @page{margin:15mm 14mm 20mm}

  /* hide chrome + every interactive CTA — keep only the content */
  .site-header,.site-footer,.nav-links,.btn,.toolbar,.search,.filters,.count,
  .signal-foot,.open-brief,.sponsored,.guide-link,script{display:none !important}

  main{padding:0 !important}
  .wrap{max-width:none !important;width:auto !important;margin:0 !important;padding:0 !important}
  .section{padding:0 !important}
  section.section,.article{margin-top:.6rem !important}

  /* interior hero → clean title block */
  .page-hero{background:#fff !important;border:0 !important}
  .page-hero .wrap{padding:0 0 .5rem !important}
  .page-hero h1{font-size:18pt;margin-top:.35rem}
  .lead{font-size:10.5pt;color:#33424f;margin-top:.35rem}

  /* data layout: 2 columns, cards stay intact across page breaks, no shadows */
  .grid{gap:.6rem !important}
  .grid-2,.grid-3,.grid-4{display:grid !important;grid-template-columns:repeat(2,1fr) !important}
  .card,.signal-card,.step,.callout,.email-box{box-shadow:none !important}
  .card,.signal-card{border:1px solid #cdd5dd !important}
  .pad,.signal-card{padding:.85rem !important}
  .card,.signal-card,.step,.quote,.callout,.email-box,.article>section{
    break-inside:avoid;page-break-inside:avoid}
  h1,h2,h3{break-after:avoid;page-break-after:avoid}

  /* playbook reads full width on paper */
  .article{max-width:none !important}
  .article section{margin-top:1rem !important}
  .email-box pre{white-space:pre-wrap}
  a{color:inherit !important;text-decoration:none !important}

  /* the one allowed CTA — small print, repeated at the bottom of every page */
  .print-cta{
    display:block !important;position:fixed;left:0;right:0;bottom:6mm;
    text-align:center;font-size:7.5pt;letter-spacing:.04em;color:#7a8794}
}
