/* ─────────────────────────────────────────────────────────────────────────
   Rising Tide Management — "Contemporary Calm" brand system
   Single source of truth for design tokens, shared component primitives,
   and the global nav/footer chrome (markup injected by components.js).
   Linked from every page. Page-specific layout lives in each page's
   <style> block but MUST reference the --m- tokens below — never hardcode
   colors or reintroduce the old dark/copper palette.
   ───────────────────────────────────────────────────────────────────────── */

:root {
  /* ===== COLOR ===== */
  --m-ink:           #0E0E0C;
  --m-ink-soft:      #3A3A36;
  --m-muted:         rgba(14, 14, 12, 0.55);
  --m-paper:         #F5F4EE;
  --m-card:          #FFFFFF;
  --m-stone:         #E3DFD5;
  --m-hairline:      rgba(14, 14, 12, 0.06);

  --m-signal:        #2A4FE3;
  --m-signal-soft:   #E6EAFC;
  --m-gain:          #1B7A3F;
  --m-gain-soft:     #9DD3B0;
  --m-loss:          #C2422A;
  --m-loss-soft:     #E07A5F;
  --m-warning:       #C8A752;

  /* ===== TYPOGRAPHY ===== */
  --m-font-display:  "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --m-font-body:     "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  --m-font-mono:     "IBM Plex Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --m-size-display-xl:  84px;
  --m-size-display-lg:  64px;
  --m-size-display-md:  44px;
  --m-size-display-sm:  30px;
  --m-track-display:    -0.025em;
  --m-leading-display:  1.02;

  --m-size-body-lg:     18px;
  --m-size-body-md:     15px;
  --m-size-body-sm:     13px;
  --m-size-caption:     11px;
  --m-size-micro:       10px;
  --m-leading-body:     1.55;
  --m-track-caption:    0.14em;

  --m-weight-regular:   400;
  --m-weight-medium:    500;
  --m-weight-semibold:  600;
  --m-weight-bold:      700;

  /* ===== SPACING ===== */
  --m-space-1:    4px;
  --m-space-2:    8px;
  --m-space-3:    12px;
  --m-space-4:    16px;
  --m-space-5:    20px;
  --m-space-6:    24px;
  --m-space-7:    28px;
  --m-space-8:    32px;
  --m-space-10:   40px;
  --m-space-12:   48px;
  --m-space-16:   64px;
  --m-space-24:   96px;

  /* ===== RADIUS ===== */
  --m-radius-sm:   8px;
  --m-radius-md:   14px;
  --m-radius-lg:   22px;
  --m-radius-pill: 9999px;

  /* ===== ELEVATION ===== */
  --m-shadow-card:    0 1px 0 rgba(14,14,12,0.04), 0 0 0 1px var(--m-hairline);
  --m-shadow-pop:     0 8px 28px rgba(14,14,12,0.10), 0 0 0 1px var(--m-hairline);

  /* ===== MOTION ===== */
  --m-ease-out:      cubic-bezier(0.16, 1, 0.3, 1);
  --m-dur-fast:      120ms;
  --m-dur-base:      180ms;
  --m-dur-slow:      280ms;
}

/* ===== BASE RESET ===== */
*, *::before, *::after { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--m-paper);
  color: var(--m-ink);
  font-family: var(--m-font-body);
  font-size: var(--m-size-body-md);
  line-height: var(--m-leading-body);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6 {
  font-family: var(--m-font-display);
  font-weight: var(--m-weight-medium);
  letter-spacing: var(--m-track-display);
  line-height: var(--m-leading-display);
  margin: 0;
}

a { color: var(--m-signal); text-decoration: none; }

/* Numbers are first-class: mono everywhere */
.m-num, .m-mono { font-family: var(--m-font-mono); font-feature-settings: "tnum" 1; }

/* Uppercase tracked label — captions only, never headings/body */
.m-caption {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-micro);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: var(--m-muted);
}

/* ===== SHARED PRIMITIVES ===== */

/* Card — the atomic surface */
.m-card {
  background: var(--m-card);
  border-radius: var(--m-radius-lg);
  box-shadow: var(--m-shadow-card);
  padding: var(--m-space-7);
}

/* Metric tile — recessed card-in-card */
.m-metric {
  background: var(--m-paper);
  border-radius: var(--m-radius-md);
  padding: 14px 16px;
}
.m-metric-label {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-micro);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: var(--m-muted);
}
.m-metric-value {
  font-family: var(--m-font-mono);
  font-weight: var(--m-weight-medium);
  font-size: 26px;
  letter-spacing: -0.02em;
  margin-top: 6px;
  color: var(--m-ink);
}
.m-metric-value.is-gain { color: var(--m-gain); }
.m-metric-value.is-loss { color: var(--m-loss); }

/* Status pill */
.m-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--m-space-2);
  padding: 6px 12px;
  border-radius: var(--m-radius-pill);
  background: var(--m-signal-soft);
  font-family: var(--m-font-mono);
  font-size: var(--m-size-caption);
  color: var(--m-signal);
}
.m-pill::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: var(--m-radius-pill);
  background: currentColor;
}

/* Buttons */
.m-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--m-space-2);
  padding: 12px 20px;
  border-radius: var(--m-radius-pill);
  font-family: var(--m-font-body);
  font-weight: var(--m-weight-semibold);
  font-size: 14px;
  border: none;
  cursor: pointer;
  background: var(--m-ink);
  color: var(--m-paper);
  transition: opacity var(--m-dur-fast) var(--m-ease-out);
}
.m-btn:hover { opacity: 0.88; }
.m-btn-secondary {
  background: transparent;
  color: var(--m-ink);
  border: 1px solid rgba(14, 14, 12, 0.20);
}
.m-btn-secondary:hover { opacity: 1; background: rgba(14, 14, 12, 0.04); }
.m-btn-tertiary {
  background: transparent;
  color: var(--m-signal);
  padding: 0;
  border-radius: 0;
}
.m-btn-tertiary:hover { text-decoration: underline; text-underline-position: from-font; }

/* Allocation bar row */
.m-alloc-row {
  display: grid;
  grid-template-columns: 1fr 60px 38px;
  gap: var(--m-space-3);
  align-items: center;
  padding: 7px 0;
}
.m-alloc-row > span:first-child {
  font-weight: var(--m-weight-medium);
  font-size: var(--m-size-body-sm);
}
.m-alloc-track {
  height: 6px;
  background: var(--m-paper);
  border-radius: var(--m-radius-pill);
  overflow: hidden;
}
.m-alloc-fill { height: 100%; border-radius: var(--m-radius-pill); }
.m-alloc-pct {
  font-family: var(--m-font-mono);
  font-size: 12px;
  text-align: right;
  color: var(--m-ink);
}

/* Table / list — no chrome */
.m-list-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 9px 0;
  border-bottom: 1px solid var(--m-hairline);
  transition: background var(--m-dur-fast) var(--m-ease-out);
}
.m-list-row:hover { background: rgba(14, 14, 12, 0.025); }

/* Inputs (Contact/forms pattern) */
.m-input, .m-select, .m-textarea {
  width: 100%;
  background: var(--m-card);
  border: 1px solid var(--m-hairline);
  border-radius: var(--m-radius-sm);
  padding: 12px 14px;
  font-family: var(--m-font-body);
  font-size: var(--m-size-body-md);
  color: var(--m-ink);
  transition: border-color var(--m-dur-fast) var(--m-ease-out),
              box-shadow var(--m-dur-fast) var(--m-ease-out);
}
.m-input:focus, .m-select:focus, .m-textarea:focus {
  outline: none;
  border-color: var(--m-signal);
  box-shadow: 0 0 0 3px var(--m-signal-soft);
}
.m-field-label {
  display: block;
  font-family: var(--m-font-mono);
  font-size: var(--m-size-caption);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: var(--m-muted);
  margin-bottom: var(--m-space-2);
}

/* FAQ (shared across product pages) */
.m-faq-list {
  margin-top: var(--m-space-8);
  border-top: 1px solid var(--m-hairline);
}
.m-faq-item {
  border-bottom: 1px solid var(--m-hairline);
  padding: var(--m-space-6) 0;
}
.m-faq-q {
  font-family: var(--m-font-display);
  font-size: var(--m-size-body-lg);
  font-weight: var(--m-weight-semibold);
  line-height: 1.3;
  color: var(--m-ink);
  margin: 0 0 var(--m-space-3);
}
.m-faq-a {
  font-size: var(--m-size-body-md);
  color: var(--m-ink-soft);
  line-height: var(--m-leading-body);
  margin: 0;
}
.m-faq-a a, .m-faq-a a:visited {
  color: var(--m-signal);
  text-decoration: underline;
  text-underline-position: from-font;
}

/* ===== BRAND MARK (adapted square monogram) ===== */
/* Ink rounded square + paper "R" + signal-blue dot. Markup in components.js. */
.m-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--m-ink);
  color: var(--m-paper);
  border-radius: var(--m-radius-md);
  font-family: var(--m-font-display);
  font-weight: var(--m-weight-semibold);
  letter-spacing: -0.02em;
  flex-shrink: 0;
  width: 56px;
  height: 56px;
  font-size: 28px;
}
.m-mark::after {
  content: "";
  width: 5px;
  height: 5px;
  border-radius: var(--m-radius-pill);
  background: var(--m-signal);
  align-self: flex-end;
  margin-left: 2px;
  margin-bottom: 14px;
}
.m-mark--nav  { width: 32px; height: 32px; font-size: 16px; border-radius: 9px; }
.m-mark--nav::after  { width: 4px; height: 4px; margin-bottom: 8px; }
.m-mark--footer { width: 56px; height: 56px; font-size: 28px; background: var(--m-ink-soft); }
.m-mark--footer::after { margin-bottom: 14px; }

/* ═══════════════════════════════════════════════════════════════════════
   GLOBAL NAV — sticky 64px card bar + bottom hairline
   ═══════════════════════════════════════════════════════════════════════ */
#nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: var(--m-card);
  border-bottom: 1px solid var(--m-hairline);
}
#nav .container {
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 var(--m-space-16);
}
@media (max-width: 980px) { #nav .container { padding: 0 var(--m-space-12); } }
.nav-inner {
  height: 64px;
  display: flex;
  align-items: center;
  gap: var(--m-space-8);
}
.nav-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--m-space-3);
  text-decoration: none;
  color: var(--m-ink);
}
.nav-logo-main {
  font-family: var(--m-font-display);
  font-weight: var(--m-weight-semibold);
  font-size: 18px;
  letter-spacing: -0.01em;
  color: var(--m-ink);
}
.nav-logo-sub {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-micro);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: var(--m-muted);
}
.nav-links {
  list-style: none;
  margin: 0;
  padding: 0;
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--m-space-7);
}
.nav-links > li > a {
  font-family: var(--m-font-body);
  font-weight: var(--m-weight-medium);
  font-size: var(--m-size-body-md);
  color: var(--m-ink-soft);
  text-decoration: none;
  transition: color var(--m-dur-fast) var(--m-ease-out);
}
.nav-links > li > a:hover { color: var(--m-ink); }
.nav-cta {
  color: var(--m-signal) !important;
  font-weight: var(--m-weight-semibold) !important;
}
.nav-cta:hover { text-decoration: underline; text-underline-position: from-font; }

.nav-dropdown { position: relative; }
.nav-dropdown::after { content: ""; position: absolute; left: -20px; right: -20px; top: 100%; height: 14px; }
.nav-dropdown-trigger { display: inline-flex; align-items: center; gap: 5px; cursor: pointer; }
.nav-dropdown-trigger::after {
  content: ""; display: block; width: 5px; height: 5px;
  border-right: 1.5px solid currentColor; border-bottom: 1.5px solid currentColor;
  transform: rotate(45deg); opacity: 0.45; flex-shrink: 0;
  transition: transform var(--m-dur-fast) var(--m-ease-out);
}
.nav-dropdown:hover .nav-dropdown-trigger::after,
.nav-dropdown:focus-within .nav-dropdown-trigger::after { transform: rotate(-135deg); opacity: 0.8; }
.nav-dropdown-menu {
  position: absolute; top: calc(100% + 10px); left: 50%;
  transform: translateX(-50%) translateY(-4px);
  width: 660px; max-width: calc(100vw - 48px);
  background: var(--m-card);
  border-radius: var(--m-radius-lg);
  box-shadow: var(--m-shadow-pop);
  padding: var(--m-space-6);
  z-index: 200; opacity: 0; pointer-events: none;
  transition: opacity var(--m-dur-slow) var(--m-ease-out), transform var(--m-dur-slow) var(--m-ease-out);
  display: flex; flex-direction: column; gap: var(--m-space-4);
}
.nav-dropdown:hover .nav-dropdown-menu,
.nav-dropdown:focus-within .nav-dropdown-menu {
  opacity: 1; pointer-events: auto; transform: translateX(-50%) translateY(0);
}
.nav-dd-row2 { display: grid; grid-template-columns: 2fr 1fr; gap: var(--m-space-5); }
.nav-dd-group-label {
  font-family: var(--m-font-mono); font-size: 9px;
  letter-spacing: var(--m-track-caption); text-transform: uppercase;
  color: var(--m-muted);
  padding-bottom: var(--m-space-2); margin-bottom: 10px;
  border-bottom: 1px solid var(--m-hairline);
}
.nav-dd-items { display: flex; gap: var(--m-space-1); }
.nav-dd-item {
  display: flex; flex-direction: column; gap: 2px;
  padding: var(--m-space-2) 10px; text-decoration: none;
  border-radius: var(--m-radius-sm); flex: 1;
  transition: background var(--m-dur-fast) var(--m-ease-out);
}
.nav-dd-item:hover { background: var(--m-paper); }
.nav-dd-item-abbr {
  font-family: var(--m-font-mono); font-size: 12px;
  font-weight: var(--m-weight-medium); letter-spacing: 0.04em;
  color: var(--m-signal);
}
.nav-dd-item-name {
  font-size: var(--m-size-caption); color: var(--m-muted);
  line-height: 1.4; margin-top: 1px;
}

/* ═══════════════════════════════════════════════════════════════════════
   GLOBAL FOOTER — full-width ink inversion
   ═══════════════════════════════════════════════════════════════════════ */
footer {
  background: var(--m-ink);
  color: var(--m-paper);
  margin-top: var(--m-space-24);
}
footer .container {
  max-width: 1180px;
  margin: 0 auto;
  padding: var(--m-space-24) var(--m-space-16) var(--m-space-12);
}
@media (max-width: 980px) { footer .container { padding: var(--m-space-16) var(--m-space-12) var(--m-space-10); } }
.footer-inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: var(--m-space-12);
}
@media (max-width: 860px) { .footer-inner { grid-template-columns: 1fr 1fr; gap: var(--m-space-10); } }
.footer-logo {
  font-family: var(--m-font-display);
  font-weight: var(--m-weight-semibold);
  font-size: 22px;
  letter-spacing: -0.01em;
  color: var(--m-paper);
}
.footer-logo-sub {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-micro);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: rgba(245, 244, 238, 0.55);
  margin-top: 4px;
}
.footer-tagline {
  font-size: var(--m-size-body-md);
  color: rgba(245, 244, 238, 0.7);
  margin: var(--m-space-4) 0 0;
  max-width: 320px;
}
.footer-links-col h4 {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-micro);
  letter-spacing: var(--m-track-caption);
  text-transform: uppercase;
  color: rgba(245, 244, 238, 0.55);
  font-weight: var(--m-weight-regular);
  margin: 0 0 var(--m-space-4);
}
.footer-links-col ul { list-style: none; margin: 0; padding: 0; }
.footer-links-col li { margin-bottom: var(--m-space-3); }
.footer-links-col a {
  font-size: var(--m-size-body-md);
  color: rgba(245, 244, 238, 0.7);
  text-decoration: none;
  transition: color var(--m-dur-fast) var(--m-ease-out);
}
.footer-links-col a:hover { color: var(--m-paper); }
.footer-bottom {
  margin-top: var(--m-space-16);
  padding-top: var(--m-space-8);
  border-top: 1px solid rgba(245, 244, 238, 0.12);
}
.footer-legal {
  font-family: var(--m-font-body);
  font-size: var(--m-size-caption);
  line-height: 1.6;
  color: rgba(245, 244, 238, 0.5);
  margin: 0 0 var(--m-space-4);
}
.footer-legal a {
  color: rgba(245, 244, 238, 0.7);
  text-decoration: underline;
  text-decoration-color: rgba(245, 244, 238, 0.3);
}
.footer-legal a:hover { color: var(--m-paper); }
.footer-copy {
  font-family: var(--m-font-mono);
  font-size: var(--m-size-caption);
  letter-spacing: 0.04em;
  color: rgba(245, 244, 238, 0.4);
  margin: 0;
}
</content>
</invoke>
