/*
Theme Name: Norwyn
Theme URI: https://marketfacts.example
Author: MarketFacts Advisory Services Inc.
Description: Bespoke premium theme for MarketFacts — independent equity research. Navy/gold institutional banking palette, editorial typography, trust-first layout. Design direction per docs/design-system.md + docs/ux-blueprint.md (stack-agnostic, ported from the Next.js mockups).
Version: 0.1.0
Requires at least: 6.4
Requires PHP: 8.1
Text Domain: marketfacts
*/

/* ==========================================================================
   DESIGN TOKENS — the one source of truth for colour/type/space.
   Do NOT hardcode these values per-template; always use the var().
   ========================================================================== */
:root {
  /* Colour — warm editorial-broadsheet palette (Norwyn) */
  --ink:        #0E2032;   /* deep warm navy — nav, footer, hero, closers */
  --ink-2:      #1B3149;   /* raised navy surface (instrument card) */
  --ink-line:   rgba(227, 221, 209, 0.12);
  --secondary:  #7A5A2C;   /* deep brass — links (warm palette is brass-forward, not blue) */
  --brass:      #B0894F;   /* brass accent — ONE CTA per view */
  --brass-soft: #C7A56A;   /* lighter brass on dark surfaces */
  --brass-deep: #7A5A2C;

  --paper:      #FAF8F3;   /* warm paper — primary reading surface */
  --paper-2:    #F3EFE6;   /* sunk paper — alternating band / trust strip */
  --card:       #FFFFFF;
  --fg:         #2A2E35;   /* warm near-black body text */
  --muted:      #F3EFE6;
  --muted-fg:   #6C6558;   /* warm taupe — secondary text */
  --border:     #E3DDD1;   /* warm hairline */

  --on-ink:     #F4F1EA;
  --on-ink-mut: #9DB0C4;

  /* Verdict palette — restrained, warm. Always paired with icon/shape + label. */
  --buy:    #3E6B54;   /* durable — restrained green */
  --hold:   #B0894F;   /* steady — brass */
  --avoid:  #9C4A3C;   /* watch — restrained clay-red */

  /* Typography */
  --serif: 'Libre Bodoni', Georgia, serif;      /* editorial headlines */
  --sans:  'Public Sans', system-ui, -apple-system, sans-serif;
  --mono:  'IBM Plex Mono', ui-monospace, monospace;

  --fs-h1:      clamp(34px, 5vw, 54px);
  --fs-h2:      clamp(24px, 3.4vw, 38px);
  --fs-h3:      21px;
  --fs-body:    17px;
  --fs-small:   14px;
  --fs-eyebrow: 11px;
  --lh-headline: 1.1;
  --lh-body:     1.6;

  /* Spacing rhythm (8px base) */
  --s-1: 4px;  --s-2: 8px;  --s-3: 12px; --s-4: 16px; --s-5: 24px;
  --s-6: 32px; --s-7: 48px; --s-8: 64px; --s-9: 88px;

  /* Shape / layout */
  --r-1: 2px;
  --r-2: 5px;
  --container: 1160px;
  --gutter: 40px;
  --section-y: var(--s-9);
  --transition: 150ms ease;
}

@media (max-width: 720px) {
  :root { --gutter: 22px; --section-y: 56px; --fs-body: 16px; }
}

/* ── Base reset ─────────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: var(--fs-body);
  line-height: var(--lh-body);
  color: var(--fg);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3, h4 { font-family: var(--serif); font-weight: 600; line-height: var(--lh-headline); margin: 0; }
p { margin: 0; }
a { color: var(--secondary); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--brass); }
img { max-width: 100%; height: auto; }
:focus-visible { outline: 2px solid var(--brass); outline-offset: 2px; }

.container { max-width: var(--container); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }

/* Shared bits */
.eyebrow {
  font-family: var(--mono); font-size: var(--fs-eyebrow); text-transform: uppercase;
  letter-spacing: 0.2em; color: var(--brass); display: block;
}
.eyebrow--on-ink { color: var(--brass-soft); }

.btn {
  display: inline-block; font-family: var(--mono); font-size: 11.5px; text-transform: uppercase;
  letter-spacing: 0.11em; padding: 12px 20px; border-radius: var(--r-1); border: 1px solid transparent;
  cursor: pointer; transition: all var(--transition);
}
.btn-primary { background: var(--brass); color: var(--ink); font-weight: 500; }
.btn-primary:hover { background: var(--brass-soft); color: var(--ink); }
.btn-ghost { border-color: #33465A; color: var(--on-ink); background: transparent; }
.btn-ghost:hover { border-color: var(--brass-soft); color: var(--on-ink); }

/* ── Ticker (top strip) — illustrative until FMP is wired server-side ────── */
.mkt-ticker { background: var(--ink); color: #DDE6EF; border-bottom: 1px solid var(--ink-line); overflow: hidden; position: relative; }
.mkt-ticker .tlabel {
  position: absolute; left: 0; top: 0; bottom: 0; z-index: 3; display: flex; align-items: center;
  padding: 0 16px; background: var(--brass-deep); color: #FBF6EC; font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; white-space: nowrap;
}
.ticker__track {
  display: flex; white-space: nowrap; font-family: var(--mono); font-size: 12px;
  padding: 9px 0 9px 150px; width: max-content; animation: mf-scroll 46s linear infinite;
}
.mkt-ticker:hover .ticker__track { animation-play-state: paused; }
.tk { padding: 0 20px; display: inline-flex; gap: 9px; align-items: baseline; border-right: 1px solid var(--ink-line); }
.tk b { color: #F4F1EA; font-weight: 600; letter-spacing: 0.02em; }
.tk .v { color: #B7C4D3; }
.tk .up { color: #7FB89A; } .tk .down { color: #D0846E; }
@keyframes mf-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }
@media (prefers-reduced-motion: reduce) { .ticker__track { animation: none; padding-left: 150px; } }

/* ── Utility bar ─────────────────────────────────────────────────────────── */
.util { background: var(--ink-2); color: var(--on-ink-mut); font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; }
.util .container { display: flex; justify-content: space-between; align-items: center; height: 34px; text-transform: uppercase; }
.util .dot { width: 6px; height: 6px; border-radius: 50%; background: #7FB89A; display: inline-block; margin-right: 7px; vertical-align: middle; }
.util a { color: var(--on-ink-mut); }
.util a:hover { color: #F4F1EA; }

/* ── Site header ────────────────────────────────────────────────────────── */
.site-header { background: var(--ink); }
.site-header .container { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; padding-bottom: 14px; }
.brand { display: flex; align-items: center; gap: 9px; }
.brand-mark { width: 15px; height: 15px; border: 2px solid var(--brass); border-radius: 50%; }
.brand-name { font-family: var(--serif); color: var(--on-ink); font-size: 17px; font-weight: 600; }
.brand-name:hover { color: var(--on-ink); }
.main-nav { display: flex; align-items: center; gap: 18px; font-size: 12.5px; }
.main-nav a { color: #CBD5E1; }
.main-nav a:hover { color: var(--brass-soft); }
.main-nav .nav-muted { color: var(--on-ink-mut); }
.main-nav .nav-login {
  background: var(--brass); color: var(--ink); padding: 6px 13px; border-radius: var(--r-1);
  font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 500;
}
.main-nav .nav-login:hover { background: var(--brass-soft); color: var(--ink); }

/* Hamburger toggle — hidden on desktop, shown on mobile */
.nav-toggle {
  display: none; background: none; border: 0; cursor: pointer; padding: 8px; margin: -8px -8px -8px 0;
}
.nav-toggle .bar {
  display: block; width: 22px; height: 2px; background: var(--on-ink);
  transition: transform var(--transition), opacity var(--transition);
}
.nav-toggle .bar + .bar { margin-top: 5px; }
.nav-toggle[aria-expanded="true"] .bar:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] .bar:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] .bar:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

@media (max-width: 820px) {
  .site-header .container { flex-wrap: wrap; }
  .nav-toggle { display: block; }
  .main-nav {
    display: none; flex-basis: 100%; flex-direction: column; align-items: stretch;
    gap: 0; margin-top: 12px;
  }
  .main-nav.is-open { display: flex; }
  .main-nav a {
    padding: 13px 0; border-top: 1px solid var(--ink-line); font-size: 15px;
  }
  .main-nav .nav-login {
    text-align: center; margin-top: 14px; padding: 12px; font-size: 12px; border-top: 0;
  }
}

/* ── Hero ───────────────────────────────────────────────────────────────── */
.hero { background: var(--ink); }
.hero .container { padding-top: 40px; padding-bottom: 46px; display: grid; grid-template-columns: 1.25fr 1fr; gap: 26px; align-items: center; }
.hero h1 { color: var(--on-ink); margin: 14px 0 16px; }
.hero h1 em { color: var(--brass-soft); font-weight: 500; }
.hero .pledge { color: #CBD5E1; font-size: 15px; margin-bottom: 24px; max-width: 42ch; }
.hero-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.hero-actions .aside-note { color: var(--on-ink-mut); font-size: 12.5px; }
.hero-actions .aside-note a { color: #E2E8F0; border-bottom: 1px solid #33465A; }

.verdict-card { background: var(--ink-2); border: 1px solid var(--ink-line); border-radius: var(--r-2); padding: 18px; }
.verdict-card .v-eyebrow { font-family: var(--mono); color: var(--brass-soft); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.18em; margin-bottom: 12px; }
.verdict-card .ticker-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 14px; }
.verdict-card .ticker { font-family: var(--mono); color: var(--on-ink); font-size: 18px; font-weight: 500; }
.verdict-card .company { color: var(--on-ink-mut); font-size: 12px; }
.verdict-card .gauge { display: flex; justify-content: center; margin: 6px 0 16px; }
.verdict-card .thesis { font-family: var(--serif); color: #E2E8F0; font-size: 13.5px; font-style: italic; line-height: 1.5; margin-bottom: 14px; }
.verdict-card .meta-row { display: flex; align-items: center; justify-content: space-between; }
.verdict-card time { font-family: var(--mono); color: var(--on-ink-mut); font-size: 11px; }

.chip { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; }
.chip .dot { width: 7px; height: 7px; border-radius: 50%; }
.chip--buy { color: #2E5340; } .chip--buy .dot { background: var(--buy); }
.chip--hold { color: #7A5A2C; } .chip--hold .dot { background: var(--hold); }
.chip--avoid { color: #7C3A2E; } .chip--avoid .dot { border: 1.5px solid var(--avoid); background: transparent; }

/* ── Trust strip ────────────────────────────────────────────────────────── */
.trust-strip { background: var(--paper-2); border-bottom: 0.5px solid var(--border); }
.trust-strip .container { display: flex; align-items: center; justify-content: center; gap: 24px; flex-wrap: wrap; padding: 11px var(--gutter); font-size: 11.5px; color: var(--muted-fg); }
.trust-strip strong { color: var(--ink); }
.trust-strip .sep { color: var(--border); }

/* ── Sections ───────────────────────────────────────────────────────────── */
section.band { padding: var(--section-y) 0; }
.band--paper { background: var(--paper); }
.band--card  { background: var(--card); border-top: 0.5px solid var(--border); }
.band--alt   { background: var(--paper-2); border-top: 0.5px solid var(--border); }
.band--ink   { background: var(--ink); text-align: center; }
.band h2 { font-size: var(--fs-h2); color: var(--ink); margin: 6px 0; }
.band--ink h2 { color: var(--on-ink); }
.lead { color: var(--muted-fg); font-size: 13.5px; max-width: 66ch; margin-top: 6px; }

/* Record ledger */
.record-summary { display: flex; align-items: center; gap: 14px; margin: 20px 0 18px; }
.record-bar { display: flex; height: 9px; flex: 1; border-radius: var(--r-1); overflow: hidden; border: 0.5px solid var(--border); }
.record-bar .seg-buy { background: var(--buy); } .record-bar .seg-hold { background: var(--hold); } .record-bar .seg-avoid { background: var(--avoid); }
.record-ratio { font-family: var(--mono); font-size: 10.5px; color: var(--muted-fg); white-space: nowrap; }

.ledger { background: var(--card); border: 0.5px solid var(--border); border-radius: var(--r-2); overflow: hidden; }
.ledger .row { display: grid; grid-template-columns: 0.8fr 1.5fr 0.9fr 1.2fr 1.2fr; gap: 10px; padding: 11px 16px; align-items: center; font-size: 12.5px; border-bottom: 0.5px solid #F1F5F9; }
.ledger .row.head { font-family: var(--mono); font-size: 9.5px; text-transform: uppercase; letter-spacing: 0.1em; color: #94A3B8; border-bottom: 0.5px solid var(--border); }
.ledger .row:last-child { border-bottom: 0; }
.ledger .t-ticker { font-family: var(--mono); font-weight: 500; }
.ledger .t-company { color: #475569; }
.ledger .t-date { font-family: var(--mono); color: #94A3B8; font-size: 11px; }
.ledger .outcome { display: flex; align-items: center; justify-content: flex-end; gap: 7px; }
.ledger .outcome .val { font-family: var(--mono); font-size: 11.5px; font-weight: 500; }
.ledger .outcome .val.gain { color: #2E5340; } .ledger .outcome .val.loss { color: #7C3A2E; }
.illustrative { display: flex; align-items: center; justify-content: space-between; margin-top: 12px; }
.illustrative span { font-family: var(--mono); color: var(--muted-fg); font-size: 10px; }
.illustrative a { font-family: var(--mono); color: var(--secondary); font-size: 11px; }

/* Rich coverage table — ticker · sector · category · verdict · outcome+sparkline */
.ledger--rich .row { grid-template-columns: 1.7fr 1.15fr 1.1fr 0.9fr 1.2fr; }
.ledger--rich .row:hover { background: var(--paper-2); }
.ledger--rich .row.head:hover { background: transparent; }
.ledger--rich .t-company { display: flex; flex-direction: column; color: var(--fg); }
.ledger--rich .t-company .co-name { font-family: var(--serif); font-size: 15px; color: var(--ink); line-height: 1.2; }
.ledger--rich .t-company .t-ticker { font-family: var(--mono); font-size: 10.5px; color: var(--muted-fg); letter-spacing: 0.04em; margin-top: 2px; font-weight: 400; }
.ledger--rich .t-sector { font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.07em; color: var(--muted-fg); }
.ledger--rich .t-cat { font-family: var(--mono); font-size: 10.5px; color: var(--brass-deep); letter-spacing: 0.03em; }
.ledger--rich .outcome { gap: 12px; }
.ledger--rich .outcome .spark { flex: none; }

/* Research-cadence chart */
.chart-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 28px; }
.chart-head h2 { max-width: 20ch; }
.chart-head p { color: var(--on-ink-mut); max-width: 42ch; font-size: 14px; margin: 8px 0 0; }
.chartcard { background: var(--ink-2); border: 1px solid var(--ink-line); border-radius: var(--r-2); padding: 26px 28px; }
.cadence-chart { display: block; height: 220px; width: 100%; }
.chart-axis { display: flex; justify-content: space-between; margin-top: 12px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; color: var(--on-ink-mut); }

/* Offer grid */
.offer-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; margin-top: 20px; }
.offer-cell { border-left: 2px solid var(--border); padding: 4px 0 4px 16px; }
.offer-cell.accent { border-left-color: var(--brass); }
.offer-cell .num { font-family: var(--mono); font-size: 10px; color: #94A3B8; text-transform: uppercase; letter-spacing: 0.1em; margin-bottom: 6px; }
.offer-cell h3 { font-size: 16px; color: var(--ink); margin-bottom: 5px; }
.offer-cell p { font-size: 12.5px; color: var(--muted-fg); }

/* Analyst + proof */
.analyst .container { display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: center; }
.analyst .portrait { width: 96px; height: 112px; background: var(--ink-2); border: 1px solid var(--border); border-radius: 4px; display: flex; align-items: flex-end; justify-content: center; }
.analyst .quote { font-family: var(--serif); font-size: 19px; font-style: italic; line-height: 1.45; color: var(--ink); margin-bottom: 12px; }
.analyst .byline { font-family: var(--mono); font-size: 11px; color: var(--muted-fg); letter-spacing: 0.03em; }
.analyst .member-proof { margin-top: 14px; padding-top: 14px; border-top: 0.5px solid #DDE3EA; font-size: 12.5px; color: #475569; font-style: italic; }
.analyst .member-proof .who { font-style: normal; color: #94A3B8; }

/* Closer */
.band--ink .lead { color: #CBD5E1; margin: 10px auto 22px; text-align: center; }
.band--ink .fineprint { margin-top: 14px; font-family: var(--mono); font-size: 11px; color: var(--on-ink-mut); }

/* ── Footer ─────────────────────────────────────────────────────────────── */
.site-footer { background: var(--ink); color: var(--on-ink-mut); padding: var(--s-7) 0; border-top: 1px solid var(--ink-line); font-size: 12.5px; }
.site-footer a { color: #CBD5E1; }
.site-footer .compliance { max-width: 80ch; line-height: 1.7; }

/* ── Generic content (posts/pages) ──────────────────────────────────────── */
.entry { padding: var(--section-y) 0; }
.entry .container { max-width: 760px; }
.entry h1 { font-size: var(--fs-h1); color: var(--ink); margin-bottom: var(--s-4); }
.entry-body { font-size: 18px; line-height: 1.75; }
.entry-body h2, .entry-body h3 { margin: var(--s-6) 0 var(--s-3); color: var(--ink); }
.entry-body p { margin-bottom: var(--s-5); }

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width: 820px) {
  .hero .container { grid-template-columns: 1fr; }
  .analyst .container { grid-template-columns: 1fr; }
  .offer-grid { grid-template-columns: 1fr; }
  .hide-sm { display: none; }
  .chart-head { flex-direction: column; align-items: flex-start; gap: 10px; }
  .ledger--rich .row { grid-template-columns: 1.6fr 0.9fr 1.05fr; }
  .ledger--rich .outcome .spark { display: none; }
}
