/* ============================================================
   DESIGN SYSTEM — Bootstrap 5 overrides + custom components
   Reference: design/references/general_style/DESIGN_STYLE_REFERENCE_MAIN.jpg
   ============================================================ */

/* Fraunces — editorial display serif used sparingly for italic accent words
   in headlines, section numerals, drop-caps. Loaded via Google Fonts CDN
   (one weight axis, italic only) because the use is limited and the file
   would otherwise dominate the self-hosted bundle for very few glyphs.
   font-display: swap means Inter renders first; the serif italic word
   swaps in without blocking. */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@1,9..144,300..900&display=swap');

/* Inter (variable font, weight 100–900) — self-hosted to keep Google Fonts off
   the critical path. unicode-range lets the browser fetch only the subset its
   page actually needs (latin for en/de/es/fr; latin-ext also for pl/cz/hu etc.). */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../fonts/inter-latin.260c81a4759b.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("../fonts/inter-latin-ext.1ad231aac0a8.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* --------- 1. TOKENS (CSS custom properties, override Bootstrap) ---------- */
/* Palette: B+ Lavender — white · plum · lavender · peach · sun · coral.
   Mint isolated as --ds-success (status only, never used in CTA/decor).
   Migration in progress — see claude_task/color_migration_lavender.md. */
:root {
  /* — Brand surfaces — */
  --ds-bg:              #FFFFFF;
  --ds-white:           #FFFFFF;
  --ds-surface-soft:    #F7F5FE;            /* lavender-tinted soft bg (sidebar, code, table-stripe) */

  --ds-plum:            #1F1B47;
  --ds-plum-hover:      #2A2658;
  --ds-plum-active:     #15123A;

  --ds-lavender:        #C8C2F5;
  --ds-lavender-hover:  #B5AEEE;
  --ds-lavender-active: #A29BE5;
  --ds-lavender-soft:   #D8D2F8;

  /* — Action accents — */
  --ds-peach:           #F4B58C;
  --ds-peach-hover:     #EFA877;
  --ds-peach-active:    #E89A66;

  --ds-coral:           #E5544D;
  --ds-coral-hover:     #D94740;
  --ds-coral-active:    #C53A33;

  --ds-sun:             #F5C518;
  --ds-sun-hover:       #E0B30E;
  --ds-sun-soft:        #FCEFB4;
  --ds-sun-deep:        #4A3A00;            /* text on yellow */

  /* — Status (isolated semantic) — */
  --ds-success:         #3DDC97;            /* checkmarks, valid state, positive delta */
  --ds-success-soft:    #C8F5DE;

  /* — Text & borders (plum-derived) — */
  --ds-muted:           rgba(31, 27, 71, .65);
  --ds-border:          rgba(31, 27, 71, .12);
  --ds-border-hover:    rgba(31, 27, 71, .24);

  /* radii */
  --ds-radius-sm:    .5rem;
  --ds-radius:       1rem;
  --ds-radius-lg:    1.5rem;
  --ds-radius-xl:    2rem;
  --ds-radius-pill:  999px;

  /* spacing scale (in rem; for use in custom utilities) */
  --ds-gap:          1rem;
  --ds-gap-lg:       1.5rem;
  --ds-gap-xl:       2.5rem;

  /* shadows — rebased to plum */
  --ds-shadow-sm:    0 1px 2px rgba(31, 27, 71, .04);
  --ds-shadow:       0 6px 24px rgba(31, 27, 71, .06);
  --ds-shadow-lg:    0 18px 48px rgba(31, 27, 71, .10);

  /* layout */
  --ds-sidebar-w:    88px;
  --ds-bottomnav-h:  72px;

  /* Bootstrap variable overrides (theme) */
  --bs-body-bg: var(--ds-bg);
  --bs-body-color: var(--ds-plum);
  --bs-body-font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --bs-body-font-weight: 400;
  --bs-body-font-size: 1rem;
  --bs-body-line-height: 1.55;
  --bs-border-radius: var(--ds-radius);
  --bs-border-radius-sm: var(--ds-radius-sm);
  --bs-border-radius-lg: var(--ds-radius-lg);
  --bs-border-radius-xl: var(--ds-radius-xl);
  --bs-border-radius-pill: var(--ds-radius-pill);
  --bs-border-color: var(--ds-border);

  --bs-primary: #1F1B47;
  --bs-primary-rgb: 31, 27, 71;
  --bs-success: #3DDC97;
  --bs-success-rgb: 61, 220, 151;
  --bs-warning: #F5C518;
  --bs-warning-rgb: 245, 197, 24;
  --bs-danger: #E5544D;
  --bs-danger-rgb: 229, 84, 77;
}

/* --------- 2. BASE TYPOGRAPHY ---------- */
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--bs-body-font-family);
  background: var(--bs-body-bg);
  color: var(--bs-body-color);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6, .ds-h1, .ds-h2, .ds-h3 {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.05;
  color: var(--ds-plum);
  margin: 0 0 .75rem;
}
.ds-display { font-size: clamp(2.5rem, 5.5vw, 5rem); font-weight: 900; letter-spacing: -.035em; line-height: .98; }
h1, .ds-h1 { font-size: clamp(2rem, 3.6vw, 3rem); }
h2, .ds-h2 { font-size: clamp(1.5rem, 2.4vw, 2rem); font-weight: 700; }
h3, .ds-h3 { font-size: 1.25rem; font-weight: 700; letter-spacing: -.01em; }
/* tighter heading for tool/calculator pages where the form is the hero */
.ds-page-title { font-size: clamp(1.625rem, 2.2vw, 2.125rem); font-weight: 800; letter-spacing: -.015em; line-height: 1.1; }

.ds-lead { font-size: 1rem; color: var(--ds-muted); line-height: 1.5; max-width: 36rem; }
.ds-mono-num { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }
.ds-eyebrow {
  font-size: .75rem; font-weight: 600; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ds-muted);
}

/* --------- 3. BUTTONS (extend Bootstrap .btn) ---------- */
.btn {
  font-weight: 600;
  border-radius: var(--ds-radius-pill);
  padding: .75rem 1.5rem;
  transition: transform .12s ease, background .15s ease, color .15s ease, box-shadow .15s ease;
}
.btn:active { transform: translateY(1px); }
.btn-lg { padding: 1rem 2rem; font-size: 1.0625rem; }
.btn-sm { padding: .5rem 1rem; font-size: .875rem; }

.btn-dark, .btn-primary {
  background: var(--ds-plum); color: var(--ds-white); border-color: var(--ds-plum);
}
.btn-dark:hover, .btn-primary:hover { background: var(--ds-plum-hover); border-color: var(--ds-plum-hover); color: var(--ds-white); }

/* Soft CTA — primary action button on calculators / forms / cookie banner. */
.btn-peach {
  background: var(--ds-peach); color: var(--ds-plum); border: 1px solid var(--ds-peach);
}
.btn-peach:hover { background: var(--ds-peach-hover); border-color: var(--ds-peach-hover); color: var(--ds-plum); }

/* Bold CTA — danger / strong action. */
.btn-coral {
  background: var(--ds-coral); color: var(--ds-white); border: 1px solid var(--ds-coral);
}
.btn-coral:hover { background: var(--ds-coral-hover); border-color: var(--ds-coral-hover); color: var(--ds-white); }

/* Sun — accent / status-warning button. */
.btn-sun {
  background: var(--ds-sun); color: var(--ds-sun-deep); border: 1px solid var(--ds-sun);
}
.btn-sun:hover { background: var(--ds-sun-hover); border-color: var(--ds-sun-hover); color: var(--ds-sun-deep); }

.btn-ghost {
  background: transparent; color: var(--ds-plum); border: 1px solid var(--ds-border);
}
.btn-ghost:hover { background: var(--ds-surface-soft); border-color: var(--ds-plum); color: var(--ds-plum); }

.btn-link-arrow {
  display: inline-flex; align-items: center; gap: .5rem;
  background: transparent; color: var(--ds-plum); padding: 0; font-weight: 600;
}
.btn-link-arrow::after { content: "→"; transition: transform .15s ease; }
.btn-link-arrow:hover::after { transform: translateX(3px); }

/* --------- 4. CARDS — 4 colour variants ---------- */
.ds-card {
  border-radius: var(--ds-radius-lg);
  padding: clamp(1rem, 3vw, 1.75rem);
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  box-shadow: var(--ds-shadow-sm);
  position: relative;
  overflow: hidden;
  min-width: 0; /* allow flex/grid children to shrink instead of overflow */
}
.ds-card--soft     { background: var(--ds-surface-soft); border-color: var(--ds-border); }
.ds-card--dark     { background: var(--ds-plum); color: var(--ds-white); border-color: var(--ds-plum); }
.ds-card--dark h1, .ds-card--dark h2, .ds-card--dark h3 { color: var(--ds-white); }
.ds-card--lavender { background: var(--ds-lavender); color: var(--ds-plum); border-color: var(--ds-lavender); }
.ds-card--peach    { background: var(--ds-peach); color: var(--ds-plum); border-color: var(--ds-peach); }
.ds-card--yellow   { background: var(--ds-sun); color: var(--ds-sun-deep); border-color: var(--ds-sun); }
.ds-card--lg     { padding: clamp(1.25rem, 3.5vw, 2.25rem); border-radius: var(--ds-radius-xl); }

/* decorative bubble in corner of accent card */
.ds-card__decor {
  position: absolute; right: -2rem; top: -2rem;
  width: 9rem; height: 9rem; border-radius: 50%;
  background: rgba(255,255,255,.18); pointer-events: none;
}
.ds-card--lavender .ds-card__decor { background: rgba(31,27,71,.08); }
.ds-card--peach .ds-card__decor    { background: rgba(31,27,71,.08); }
.ds-card--yellow .ds-card__decor   { background: rgba(74,58,0,.10); }

/* --------- 5. STAT / VALUE BLOCKS ---------- */
.ds-stat { display: flex; flex-direction: column; gap: .25rem; }
.ds-stat__value { font-size: 2.5rem; font-weight: 800; letter-spacing: -.02em; line-height: 1; }
.ds-stat__label { font-size: .8125rem; color: var(--ds-muted); font-weight: 500; }
/* Status-positive (mint isolated): KPI deltas, "+12 %" badges. */
.ds-stat__delta { font-size: .8125rem; font-weight: 600; color: var(--ds-success); display: inline-flex; align-items: center; gap: .25rem; }
.ds-stat__delta--down { color: var(--ds-coral); }

.ds-pill {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem 1rem; border-radius: var(--ds-radius-pill);
  background: var(--ds-white); border: 1px solid var(--ds-border);
  font-size: .875rem; font-weight: 500;
}
.ds-pill--lavender { background: var(--ds-lavender-soft); border-color: var(--ds-lavender-soft); color: var(--ds-plum); }
.ds-pill--yellow   { background: var(--ds-sun-soft); border-color: var(--ds-sun-soft); color: var(--ds-sun-deep); }
.ds-pill--dark     { background: var(--ds-plum); color: var(--ds-white); border-color: var(--ds-plum); }
.ds-pill--success  { background: var(--ds-success-soft); border-color: var(--ds-success-soft); color: var(--ds-plum); }
.ds-pill--coral    { background: var(--ds-coral); color: var(--ds-white); border-color: var(--ds-coral); }

/* circular ingredient-style pill from ingredients.jpg */
.ds-ingredient {
  width: 84px; height: 100px;
  border-radius: var(--ds-radius-pill);
  background: var(--ds-white); border: 1px solid var(--ds-border);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: .5rem; gap: .25rem;
}
.ds-ingredient__title { font-size: .75rem; font-weight: 600; }
.ds-ingredient__sub   { font-size: .625rem; color: var(--ds-muted); }
.ds-ingredient__value {
  margin-top: .25rem;
  width: 38px; height: 38px; border-radius: 50%;
  background: var(--ds-lavender-soft);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .75rem; font-weight: 700;
}

/* --------- 6. FORMS — extend Bootstrap form-control ---------- */
.form-label { font-weight: 600; font-size: .875rem; margin-bottom: .375rem; color: var(--ds-plum); }
.form-text  { color: var(--ds-muted); font-size: .8125rem; }

.form-control, .form-select {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius);
  padding: .875rem 1rem;
  font-size: 1rem;
  color: var(--ds-plum);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.form-control::placeholder { color: #A3A3A3; }
.form-control:focus, .form-select:focus {
  border-color: var(--ds-plum);
  box-shadow: 0 0 0 4px rgba(22,24,37,.08);
}
.form-control-lg, .form-select-lg {
  padding: 1.125rem 1.25rem; font-size: 1.125rem; border-radius: var(--ds-radius-lg);
}

/* number-style giant input for calculators */
.ds-input-amount {
  width: 100%;
  min-width: 0;
  border: 0;
  background: transparent;
  font-size: clamp(2rem, 6vw, 3rem);
  font-weight: 800;
  letter-spacing: -.02em;
  color: var(--ds-plum);
  text-align: center;
  padding: .5rem 0;
  font-variant-numeric: tabular-nums;
}
.ds-input-amount:focus { outline: none; }
.ds-input-amount-wrap {
  background: var(--ds-surface-soft);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  padding: clamp(1rem, 3vw, 1.5rem) 1rem;
  text-align: center;
  min-width: 0;
}
.ds-input-amount-wrap__currency { color: var(--ds-muted); font-weight: 600; font-size: .875rem; }

/* checkboxes & radios — bigger, cleaner */
.form-check-input {
  width: 1.25rem; height: 1.25rem;
  border: 1.5px solid var(--ds-border);
  margin-top: .15rem;
}
.form-check-input:checked {
  background-color: var(--ds-plum);
  border-color: var(--ds-plum);
}
.form-check-input:focus {
  border-color: var(--ds-plum);
  box-shadow: 0 0 0 3px rgba(22,24,37,.08);
}
.form-check-label { padding-left: .25rem; }

/* switch */
.form-switch .form-check-input {
  width: 2.5rem; height: 1.4rem;
  background-color: var(--ds-border);
  border-color: var(--ds-border);
}
.form-switch .form-check-input:checked {
  background-color: var(--ds-success);
  border-color: var(--ds-success);
}

/* range slider */
.form-range::-webkit-slider-thumb {
  background: var(--ds-plum);
  border: 4px solid var(--ds-white);
  box-shadow: 0 2px 6px rgba(22,24,37,.2);
  width: 1.5rem; height: 1.5rem;
}
.form-range::-moz-range-thumb {
  background: var(--ds-plum);
  border: 4px solid var(--ds-white);
  box-shadow: 0 2px 6px rgba(22,24,37,.2);
  width: 1.5rem; height: 1.5rem;
}
.form-range::-webkit-slider-runnable-track {
  background: var(--ds-border); height: .375rem; border-radius: 999px;
}
.form-range::-moz-range-track {
  background: var(--ds-border); height: .375rem; border-radius: 999px;
}

/* segmented control (radio buttons styled as pills) */
.ds-segmented {
  display: inline-flex; flex-wrap: wrap;
  max-width: 100%;
  padding: .25rem; background: var(--ds-surface-soft);
  border-radius: var(--ds-radius-pill);
  border: 1px solid var(--ds-border); gap: .25rem;
}
.ds-segmented input[type="radio"] { position: absolute; opacity: 0; pointer-events: none; }
.ds-segmented label {
  cursor: pointer; padding: .5rem 1rem; border-radius: var(--ds-radius-pill);
  font-size: .875rem; font-weight: 600; color: var(--ds-muted);
  transition: background .15s ease, color .15s ease;
}
.ds-segmented input[type="radio"]:checked + label {
  background: var(--ds-plum); color: var(--ds-white);
}

/* validation states */
.form-control.is-invalid, .form-select.is-invalid {
  border-color: var(--ds-coral);
  background-image: none;
  padding-right: 1rem;
}
.invalid-feedback { color: var(--ds-coral); font-size: .8125rem; font-weight: 500; }

/* form group spacing helper */
.ds-form-stack > * + * { margin-top: 1.25rem; }

/* --------- 7. LAYOUT — sidebar + bottom-nav ---------- */
.ds-app {
  display: grid;
  grid-template-columns: var(--ds-sidebar-w) minmax(0, 1fr);
  min-height: 100vh;
}
/* prevent horizontal scroll if any descendant accidentally overflows.
   Using `clip` (not `hidden`) so we don't establish a scroll container
   that would break `position: sticky` on the sidebar. */
html, body { overflow-x: clip; }
/* default min-width:auto on flex/grid items causes overflow — flatten it for Bootstrap cols */
.row > * { min-width: 0; }
.ds-sidebar {
  background: var(--ds-surface-soft);
  border-right: 1px solid var(--ds-border);
  padding: 1.5rem .75rem;
  display: flex; flex-direction: column; align-items: center; gap: .25rem;

  /* Sticky needs (1) a scroll context (we have it: body, since
     `overflow-x: clip` doesn't break it), (2) a parent taller than
     the sticky element. `.ds-app` is a CSS grid which by default
     stretches grid items to fill the row height — the sidebar would
     end up the same height as the page, leaving nothing for the
     sticky to scroll-against. `align-self: start` opts the sidebar
     out of stretch, so its height stays 100vh and `top: 0` actually
     pins it at the viewport top while the page scrolls below. */
  position: sticky;
  top: 0;
  align-self: start;
  height: 100vh;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.ds-sidebar__logo {
  width: 44px; height: 44px; border-radius: 12px;
  background: var(--ds-plum); color: var(--ds-white);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1rem; margin-bottom: 1.5rem;
  position: relative;
}
.ds-sidebar__logo::after {
  content: "";
  position: absolute;
  top: -3px; right: -3px;
  width: 12px; height: 12px;
  border-radius: 50%;
  background: var(--ds-peach);
  border: 2px solid var(--ds-surface-soft);
}
.ds-sidebar__nav { display: flex; flex-direction: column; gap: .25rem; flex: 1; width: 100%; }
.ds-sidebar__item {
  /* icon + label stacked vertically — wider tap target than the
     square 48px icon-only style we had before, with the label
     making each section discoverable without a hover tooltip. */
  width: 100%; min-height: 64px; padding: .5rem .25rem; border-radius: 14px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px; color: var(--ds-muted); text-decoration: none;
  font-size: .6875rem; font-weight: 500; line-height: 1.1;
  text-align: center;
  position: relative;
  transition: background .15s ease, color .15s ease;
}
.ds-sidebar__item:hover { background: rgba(22,24,37,.06); color: var(--ds-plum); }
.ds-sidebar__item.is-active { background: var(--ds-plum); color: var(--ds-white); }
.ds-sidebar__item svg { width: 26px; height: 26px; }
.ds-sidebar__label {
  display: block;
  max-width: 100%;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}

@media (max-height: 760px) and (min-width: 768px) {
  .ds-sidebar { padding-block: .75rem; }
  .ds-sidebar__logo {
    width: 38px;
    height: 38px;
    margin-bottom: .75rem;
  }
  .ds-sidebar__nav { gap: .15rem; }
  .ds-sidebar__item {
    min-height: 52px;
    padding-block: .35rem;
    font-size: .625rem;
  }
  .ds-sidebar__item svg {
    width: 22px;
    height: 22px;
  }
}

/* "Coming soon" categories — muted icon + label, small badge. */
.ds-sidebar__item--soon { color: var(--ds-muted); opacity: .75; }
.ds-sidebar__item--soon:hover { opacity: 1; }
.ds-sidebar__badge {
  position: absolute; top: 4px; right: 4px;
  background: var(--ds-peach); color: var(--ds-plum);
  font-size: .5625rem; font-weight: 700; line-height: 1;
  padding: 2px 5px; border-radius: 6px; text-transform: uppercase;
  letter-spacing: .02em;
}
.ds-sidebar__item.is-active .ds-sidebar__badge { background: var(--ds-white); }

.ds-sidebar__bottom { margin-top: auto; width: 100%; }

.ds-main {
  position: relative;
  min-width: 0;
  width: 100%;
  padding: .75rem clamp(1rem, 3vw, 2.5rem) 2rem;
  max-width: 100%;
}
/* Language switcher — dropdown trigger lives inside sidebar/bottom-nav */
.ds-lang-trigger { background: transparent; border: 0; cursor: pointer; }
.ds-lang-trigger.ds-bottomnav__item {
  /* button inherits from bottomnav__item but needs its own reset */
  padding: 0;
}

/* Generic top-layer dialog. Uses native <dialog>.showModal() so the
   CSS top-layer paints it above every stacking context on the page.
   Base (closed-state) styles only — positioning lives on .ds-dialog[open]. */
.ds-dialog {
  border: 0;
  border-radius: 14px;
  padding: 1.5rem;
  background: var(--ds-white);
  color: var(--ds-plum);
  box-shadow: 0 12px 32px rgba(22, 24, 37, .18);
  max-width: 360px;
  width: calc(100% - 2rem);
}
/* Explicit centre-of-viewport positioning for the *opened* state,
   defensively scoped via `[open]` so it applies whether the dialog was
   opened with .showModal() (modal, top-layer, :modal pseudo active) or
   with .setAttribute('open','') (the no-top-layer fallback). Without
   this, browsers that don't apply a strong UA `:modal` stylesheet leave
   the dialog at its DOM position — visually behind whatever sits at end
   of body (FAQ section). */
.ds-dialog[open] {
  position: fixed;
  /* `inset` first because it's a shorthand that overwrites top/right/
     bottom/left — putting it AFTER the explicit top/left would reset
     them to auto and the modal would end up top-left of the viewport. */
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  margin: 0;
  z-index: 99999;     /* belt-and-braces above non-top-layer fallback */
}
.ds-dialog::backdrop {
  background: rgba(22, 24, 37, .45);
  backdrop-filter: blur(2px);
}
.ds-dialog__title {
  margin: 0 0 1rem;
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--ds-plum);
  padding-right: 2rem;
}
.ds-dialog__close {
  position: absolute;
  top: .5rem;
  right: .625rem;
  width: 32px;
  height: 32px;
  background: transparent;
  border: 0;
  font-size: 1.5rem;
  line-height: 1;
  cursor: pointer;
  border-radius: 50%;
  color: var(--ds-muted);
}
.ds-dialog__close:hover { background: rgba(22, 24, 37, .06); color: var(--ds-plum); }

.ds-lang-dialog__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.ds-lang-dialog__list form { margin: 0; }
.ds-lang-dialog__item {
  width: 100%;
  background: transparent;
  border: 0;
  text-align: left;
  padding: .625rem .9rem;
  border-radius: 10px;
  font: inherit;
  font-weight: 500;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--ds-plum);
}
.ds-lang-dialog__item:hover:not(:disabled) { background: rgba(22, 24, 37, .05); }
.ds-lang-dialog__item.is-current { background: var(--ds-plum); color: var(--ds-white); }
.ds-lang-dialog__item:disabled { opacity: .5; cursor: not-allowed; }
.ds-container {
  width: 100%;
  max-width: 1200px;
  margin-inline: auto;
  /* match Bootstrap row gutter so negative .row margins do not overflow */
  padding-inline: clamp(.5rem, 2vw, 1.5rem);
}
.ds-container--narrow { max-width: 720px; margin-inline: auto; padding-inline: clamp(.5rem, 2vw, 1.5rem); }

/* mobile bottom nav */
.ds-bottomnav {
  display: none;
  position: fixed; left: 0; right: 0; bottom: 0;
  height: var(--ds-bottomnav-h);
  background: var(--ds-white);
  border-top: 1px solid var(--ds-border);
  z-index: 100;
  padding: .25rem .5rem env(safe-area-inset-bottom);
}
.ds-bottomnav__inner { display: flex; height: 100%; align-items: stretch; justify-content: space-around; }
.ds-bottomnav__item {
  flex: 1; display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 2px; color: var(--ds-muted); text-decoration: none; font-size: .6875rem; font-weight: 500;
  border-radius: 12px;
  min-width: 0;
  text-align: center;
  line-height: 1.1;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: manual;
}
.ds-bottomnav__item svg { width: 22px; height: 22px; }
.ds-bottomnav__item.is-active { color: var(--ds-plum); }
.ds-bottomnav__item.is-active svg { color: var(--ds-peach); }

/* "More" trigger inside the bottom-nav is a <button> — needs the
   same visual reset as the language-trigger. */
.ds-bottomnav__more {
  background: transparent; border: 0; padding: 0; cursor: pointer;
  font-family: inherit;
}

/* "More" offcanvas (bottom sheet on mobile). Bootstrap base does most
   of the work; we just round the top corners and tighten typography. */
.ds-more-sheet {
  border-top-left-radius: 18px;
  border-top-right-radius: 18px;
  height: auto;
  max-height: min(92vh, 34rem);
}
.ds-more-sheet .offcanvas-header { padding: .75rem 1rem .25rem; }
.ds-more-sheet .offcanvas-body {
  flex: 0 1 auto;
  overflow: visible;
  padding: .25rem .75rem calc(.75rem + env(safe-area-inset-bottom));
}
.ds-more-title { font-size: 1rem; }
.ds-more-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 2px;
}
.ds-more-link {
  display: flex; align-items: center; gap: .75rem;
  padding: .65rem .75rem; border-radius: 10px;
  color: var(--ds-plum); text-decoration: none; font-weight: 500;
}
.ds-more-link:hover { background: rgba(31, 27, 71, .06); color: var(--ds-plum); }
.ds-more-link svg { width: 22px; height: 22px; flex-shrink: 0; }
.ds-more-langs { padding-top: .35rem; margin-top: .35rem; border-top: 1px solid var(--ds-border); }
.ds-more-langs .ds-lang-trigger {
  display: flex; align-items: center; gap: .75rem;
  padding: .65rem .75rem; border-radius: 10px; width: 100%;
  color: var(--ds-plum); flex-direction: row; height: auto; min-height: 0;
}
.ds-more-langs .ds-lang-trigger span { font-size: 1rem; font-weight: 500; }
.ds-more-langs .ds-lang-trigger svg { width: 22px; height: 22px; }

/* ---------- Inline term explainers ---------- */
.ds-term-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.15rem;
  height: 1.15rem;
  margin-left: .3rem;
  border: 1px solid rgba(31, 27, 71, .18);
  border-radius: 999px;
  background: var(--ds-white);
  color: var(--ds-plum);
  font-size: .72rem;
  font-weight: 800;
  line-height: 1;
  vertical-align: middle;
  cursor: pointer;
}
.ds-term-help:hover,
.ds-term-help:focus {
  border-color: var(--ds-coral);
  color: var(--ds-coral);
  outline: none;
}
.ds-term-help:focus-visible {
  box-shadow: 0 0 0 3px rgba(229, 84, 77, .18);
}
.ds-term-modal .modal-content {
  border: 1px solid var(--ds-border);
  border-radius: 14px;
}
.ds-term-modal .modal-header { padding: .9rem 1rem .6rem; }
.ds-term-modal .modal-body {
  padding: .75rem 1rem 1rem;
  color: var(--ds-muted);
  line-height: 1.55;
}

/* ---------- Hub: Glossary block ---------- */
.ds-glossary__list { display: grid; grid-template-columns: 1fr; gap: 1.25rem; margin: 0; }
@media (min-width: 768px) {
  .ds-glossary__list { grid-template-columns: 1fr 1fr; gap: 1.5rem 2rem; }
}
.ds-glossary__item {
  position: relative;
  overflow: hidden;
  padding: 1.15rem;
  border: 1px solid rgba(200, 194, 245, .85);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(216, 210, 248, .44), rgba(255,255,255,.92) 48%),
    var(--ds-white);
  box-shadow: 0 14px 34px rgba(31, 27, 71, .06);
}
.ds-glossary__item::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 5px;
  background: var(--ds-coral);
}
.ds-glossary__term {
  margin: 0 0 .85rem;
  display: flex;
  align-items: baseline;
  gap: .65rem;
  flex-wrap: wrap;
}
.ds-glossary__def-label,
.ds-glossary__example-label {
  color: var(--ds-muted);
  font-size: .66rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.ds-glossary__term-text {
  display: inline;
  padding: .08em .28em .12em;
  border-radius: .3em;
  background: rgba(216, 210, 248, .88);
  box-shadow: inset 0 -2px 0 rgba(126, 103, 219, .5);
  color: var(--ds-plum);
  font-size: 1.12rem;
  font-weight: 800;
}
.ds-glossary__def { margin: 0; color: var(--ds-muted); font-size: .9375rem; line-height: 1.55; }
.ds-glossary__def p:last-child { margin-bottom: 0; }
.ds-glossary__def .ds-prose {
  max-width: none;
  margin-top: .2rem;
}
.ds-glossary__def .ds-prose p {
  margin-bottom: 0;
  color: var(--ds-plum-hover);
  line-height: 1.58;
}
.ds-glossary__example {
  margin-top: .85rem;
  padding: .75rem .85rem;
  border-radius: 10px;
  background: rgba(244, 181, 140, .22);
  border: 1px solid rgba(244, 181, 140, .44);
}
.ds-glossary__example p {
  margin: .25rem 0 0;
  color: var(--ds-plum);
  font-size: .92rem;
  line-height: 1.5;
}

/* ---------- Hub: Coming-soon roadmap ---------- */
.ds-roadmap__list { list-style: none; padding: 0; margin: 1rem 0 0; display: flex; flex-direction: column; gap: .75rem; }
.ds-roadmap__item {
  padding: 1rem 1.25rem; border: 1px dashed var(--ds-border); border-radius: 12px;
  background: var(--ds-surface-soft);
}
.ds-roadmap__head { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.ds-roadmap__name { font-weight: 600; color: var(--ds-plum); }
.ds-roadmap__eta {
  background: var(--ds-peach); color: var(--ds-plum);
  font-size: .6875rem; font-weight: 600;
  padding: 2px 8px; border-radius: 6px; text-transform: uppercase;
  letter-spacing: .02em;
}
.ds-roadmap__desc { margin: .35rem 0 0; color: var(--ds-muted); font-size: .9375rem; }

/* responsive — collapse sidebar on mobile, show bottom nav */
@media (max-width: 768px) {
  .ds-app { grid-template-columns: minmax(0, 1fr); }
  .ds-sidebar { display: none; }
  .ds-bottomnav { display: block; }
  .ds-main { padding: .5rem 1rem calc(var(--ds-bottomnav-h) + 1.5rem); }
  .ds-input-amount { font-size: 2.25rem; }
  .ds-stat__value { font-size: 2rem; }
}

/* --------- 8. HERO + DECOR ---------- */
.ds-hero { padding: 4rem 0 3rem; text-align: center; }
.ds-hero__title { max-width: 18ch; margin-inline: auto; }
.ds-hero__sub { margin: 1.25rem auto 2rem; }

/* decorative pixel grid (squares, sparkles) — purely visual */
.ds-decor-grid {
  position: relative; width: 220px; height: 180px; pointer-events: none;
}
.ds-decor-grid span {
  position: absolute; width: 36px; height: 36px;
  border-radius: 8px; background: var(--ds-surface-soft);
  border: 1px solid var(--ds-border);
}
.ds-decor-grid span.is-mint   { background: var(--ds-peach); border-color: var(--ds-peach); }
.ds-decor-grid span.is-yellow { background: var(--ds-sun); border-color: var(--ds-sun); }

/* compact decoration for page headers — sits on the right side of an H1 */
.ds-header-decor {
  position: relative;
  width: 140px; height: 80px;
  pointer-events: none;
  flex-shrink: 0;
}
.ds-header-decor span {
  position: absolute; width: 22px; height: 22px;
  border-radius: 6px;
  background: var(--ds-surface-soft);
  border: 1px solid var(--ds-border);
}
.ds-header-decor span.is-mint   { background: var(--ds-peach);   border-color: var(--ds-peach); }
.ds-header-decor span.is-yellow { background: var(--ds-sun); border-color: var(--ds-sun); }
@media (max-width: 768px) { .ds-header-decor { display: none; } }

/* --------- 9. CHARTS (CSS placeholders) ---------- */
.ds-bars {
  display: flex; align-items: end; gap: .75rem;
  height: 180px; padding: 1rem 0;
}
.ds-bars__bar {
  flex: 1; background: var(--ds-surface-soft); border-radius: 12px 12px 4px 4px;
  position: relative; min-width: 28px;
  transition: background .15s ease;
}
.ds-bars__bar.is-active { background: var(--ds-peach); }
.ds-bars__bar::after {
  content: attr(data-label); position: absolute; bottom: -1.4rem; left: 50%;
  transform: translateX(-50%); font-size: .75rem; color: var(--ds-muted);
}

.ds-gauge {
  --pct: 65;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: conic-gradient(var(--ds-peach) calc(var(--pct) * 1%), var(--ds-surface-soft) 0);
  display: inline-grid; place-items: center;
  position: relative;
}
.ds-gauge::before {
  content: ""; position: absolute; inset: 14px; border-radius: 50%; background: var(--ds-white);
}
.ds-gauge__inner { position: relative; text-align: center; }
.ds-gauge__value { font-size: 1.875rem; font-weight: 800; line-height: 1; }
.ds-gauge__label { font-size: .75rem; color: var(--ds-muted); margin-top: .25rem; }

/* --------- 10. ARTICLE / PROSE typography ---------- */
.ds-prose { max-width: 65ch; }
.ds-prose p { margin-bottom: 1rem; line-height: 1.7; color: var(--ds-plum-hover); }
.ds-prose h2 { margin-top: 2.5rem; margin-bottom: 1rem; }
.ds-prose h3 { margin-top: 1.75rem; margin-bottom: .5rem; }
.ds-prose ul, .ds-prose ol { padding-left: 1.25rem; margin-bottom: 1rem; line-height: 1.7; color: var(--ds-plum-hover); }
.ds-prose li + li { margin-top: .25rem; }
.ds-prose blockquote {
  border-left: 4px solid var(--ds-peach);
  padding: .25rem 0 .25rem 1.25rem;
  margin: 1.5rem 0;
  font-size: 1.125rem; color: var(--ds-plum); font-style: italic;
}
.ds-prose a { color: var(--ds-plum); text-decoration: underline; text-decoration-thickness: 2px; text-underline-offset: 3px; }
.ds-prose a:hover { color: var(--ds-muted); }
.ds-prose code {
  background: var(--ds-surface-soft); padding: .15rem .4rem;
  border-radius: 6px; font-size: .9em;
}
.ds-prose pre {
  background: var(--ds-plum); color: var(--ds-surface-soft);
  padding: 1rem 1.25rem;
  border-radius: var(--ds-radius);
  overflow-x: auto;
  font-size: .875rem;
  line-height: 1.55;
  margin: 1.25rem 0;
}
.ds-prose pre code {
  background: transparent; color: inherit; padding: 0;
  font-size: inherit;
}
.ds-prose table {
  width: 100%;
  border-collapse: collapse;
  margin: 1.25rem 0;
  font-size: .9375rem;
}
.ds-prose thead { background: var(--ds-surface-soft); }
.ds-prose th {
  font-weight: 700;
  text-align: left;
  padding: .75rem 1rem;
  border-bottom: 2px solid var(--ds-border);
  color: var(--ds-plum);
}
.ds-prose td {
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--ds-border);
  color: var(--ds-plum-hover);
}
.ds-prose tbody tr:last-child td { border-bottom: 0; }
.ds-prose tbody tr:hover td { background: var(--ds-surface-soft); }

/* --------- 10b. FAQ accordion — each item is its own card-button ---------- */
.ds-faq {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}
.ds-faq__item {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius);
  transition: border-color .15s ease, box-shadow .15s ease;
}
.ds-faq__item:hover { border-color: var(--ds-plum); }
.ds-faq__item[open] {
  border-color: var(--ds-plum);
  box-shadow: var(--ds-shadow-sm);
}

.ds-faq__summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
  padding: 1.125rem 1.25rem;
  cursor: pointer;
  font-weight: 600;
  font-size: 1rem;
  color: var(--ds-plum);
  list-style: none;             /* Firefox */
  user-select: none;
  border-radius: var(--ds-radius);
}
.ds-faq__summary::-webkit-details-marker { display: none; }  /* Safari/Chrome */

.ds-faq__icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--ds-surface-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  transition: transform .25s ease, background .15s ease;
}
.ds-faq__icon::before,
.ds-faq__icon::after {
  content: "";
  position: absolute;
  background: var(--ds-plum);
  border-radius: 2px;
}
.ds-faq__icon::before { width: 11px; height: 2px; }   /* horizontal bar */
.ds-faq__icon::after  { width: 2px; height: 11px; }   /* vertical bar */

.ds-faq__item[open] > .ds-faq__summary .ds-faq__icon {
  background: var(--ds-peach);
  transform: rotate(45deg);
}

.ds-faq__body {
  padding: .25rem 1.25rem 1.25rem;
  margin: 0;
  color: var(--ds-plum-hover);
  line-height: 1.7;
  max-width: 65ch;
  font-size: .9375rem;
}

@media (max-width: 576px) {
  .ds-faq__summary { padding: 1rem 1rem; font-size: .9375rem; gap: 1rem; }
  .ds-faq__body    { padding: .25rem 1rem 1rem; }
}

/* --------- 10c. HTMX loading state + Alpine cloak ---------- */
/* Hide-before-JS rules — must be in <head> so they apply before any element
   renders. Alpine x-cloak hides Alpine-controlled markup until init;
   .htmx-indicator hides loading spinners until HTMX is mid-request. */
[x-cloak]       { display: none !important; }
.htmx-indicator { display: none; }
.htmx-request   .htmx-indicator { display: inline-block; }
.htmx-request   button[type="submit"] {
  pointer-events: none;
  opacity: .65;
}
.ds-spinner {
  display: inline-block;
  width: 1em;
  height: 1em;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: ds-spin .65s linear infinite;
  vertical-align: -.15em;
  margin-right: .5em;
}
@keyframes ds-spin { to { transform: rotate(360deg); } }

/* --------- 10d. SITE FOOTER ---------- */
.ds-footer {
  margin-top: 4rem;
  padding: 2rem 0 2.5rem;
  border-top: 1px solid var(--ds-border);
  color: var(--ds-muted);
  font-size: .875rem;
}
.ds-footer__cols {
  display: grid; gap: 1.5rem 2rem;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  margin-bottom: 1.25rem;
}
.ds-footer__brand { font-weight: 800; color: var(--ds-plum); font-size: 1.05rem; margin-bottom: .35rem; letter-spacing: -.02em; }
.ds-footer__tagline { margin: 0; line-height: 1.45; max-width: 26ch; }
.ds-footer__head {
  font-size: .72rem; font-weight: 700; color: var(--ds-plum);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: .5rem;
}
.ds-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .35rem; }
.ds-footer__list a, .ds-footer__btn {
  color: var(--ds-muted); text-decoration: none;
  background: transparent; border: 0; padding: 0; font: inherit; cursor: pointer;
}
.ds-footer__list a:hover, .ds-footer__btn:hover { color: var(--ds-plum); text-decoration: underline; }
.ds-footer__divider { height: 1px; background: var(--ds-border); margin: 1.25rem 0 1rem; }
.ds-footer__copy { text-align: center; color: var(--ds-muted); font-size: .78rem; margin: .75rem 0 0; }

@media (max-width: 768px) {
  .ds-footer { padding-bottom: calc(var(--ds-bottomnav-h) + 1rem); }
}

/* --------- 11. UTILITIES ---------- */
.ds-bg-cream { background: var(--ds-bg); }
.ds-bg-white { background: var(--ds-white); }
.ds-bg-ink   { background: var(--ds-plum); color: var(--ds-white); }
.ds-bg-mint  { background: var(--ds-peach); }
.ds-bg-yellow{ background: var(--ds-sun); }
.ds-text-muted { color: var(--ds-muted); }
.ds-benefit-highlight {
  display: inline;
  padding: .06em .22em .08em;
  border-radius: .28em;
  background: rgba(216, 210, 248, .76);
  box-shadow: inset 0 -2px 0 rgba(126, 103, 219, .55);
  color: var(--ds-plum);
  font-weight: 700;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
}
.ds-kpi--hero .ds-benefit-highlight {
  background: rgba(244, 181, 140, .78);
  box-shadow: inset 0 -2px 0 rgba(255, 255, 255, .42);
  color: var(--ds-white);
}
.ds-calc-note .ds-benefit-highlight { font-weight: 800; }
.ds-live-data {
  border-color: rgba(126, 103, 219, .28);
  box-shadow: inset 4px 0 0 rgba(126, 103, 219, .72), var(--ds-shadow);
}
.ds-live-data__stat {
  min-width: 0;
}
.ds-live-data__value {
  display: inline-block;
  margin-top: .12rem;
}
.ds-rounded   { border-radius: var(--ds-radius); }
.ds-rounded-lg{ border-radius: var(--ds-radius-lg); }
.ds-rounded-xl{ border-radius: var(--ds-radius-xl); }
.ds-shadow    { box-shadow: var(--ds-shadow); }
.ds-shadow-lg { box-shadow: var(--ds-shadow-lg); }
.ds-divider   { height: 1px; background: var(--ds-border); margin: 1.5rem 0; }

/* avatar */
.ds-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--ds-surface-soft); border: 2px solid var(--ds-white);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .875rem; color: var(--ds-plum); overflow: hidden;
}
.ds-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ds-avatar-stack { display: inline-flex; }
.ds-avatar-stack .ds-avatar + .ds-avatar { margin-left: -10px; }

/* --------- 12. RATING WIDGET ---------- */
.ds-rating { padding: 1rem 1.25rem; }
.ds-rating__head { margin-bottom: .25rem; }
.ds-rating__prompt { font-size: .9rem; color: var(--ds-muted); max-width: 56ch; }
.ds-rating__stars {
  display: inline-flex; gap: .25rem; padding: 0; margin: 0; border: 0;
  font-size: 1.75rem; line-height: 1;
}
.ds-rating__star {
  background: none; border: 0; padding: .15rem .25rem; cursor: pointer;
  color: #C9C4B5; transition: color .15s ease, transform .1s ease;
  font-size: inherit; line-height: 1;
}
.ds-rating__star:hover,
.ds-rating__star:focus-visible { color: var(--ds-sun); outline: none; transform: scale(1.08); }
/* On hover of any star, fill itself + all preceding siblings — natural
   "rate up to N" affordance without JS. */
.ds-rating__stars:hover .ds-rating__star { color: var(--ds-sun); }
.ds-rating__stars .ds-rating__star:hover ~ .ds-rating__star { color: #C9C4B5; }
.ds-rating__star.is-filled { color: var(--ds-sun); }
.ds-rating--done .ds-rating__star { cursor: default; }
.ds-rating__meta { color: var(--ds-muted); }

/* ============================================================
   13. EDITORIAL LAYER — magazine typography & layout
   Used sparingly for landing hero, page kickers, article body.
   Pairs Fraunces (italic display serif) with Inter; the serif
   never carries body weight, only accent words and numerals.
   ============================================================ */

/* — Serif utility ('It.' / italic-only accent) — */
/* Fraunces is optically ~8–10% smaller than Inter at equal font-size because
   its x-height is lower. We compensate two ways: (1) font-size-adjust matches
   x-heights in modern browsers (Chrome 127+, FF 118+, Safari 17+);
   (2) explicit 1.08em fallback for older engines. Combined effect: serif
   italic accents read as the same size as the surrounding Inter glyphs. */
.ds-serif,
em.ds-serif {
  font-family: 'Fraunces', 'Iowan Old Style', 'Apple Garamond', Georgia, serif;
  font-style: italic;
  font-weight: 500;
  letter-spacing: -.01em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  font-variation-settings: "opsz" 144, "SOFT" 50;
}

/* — Display, editorial. Stacked, ultra-tight, max-weight. — */
.ds-display-mag {
  font-family: 'Inter', sans-serif;
  font-weight: 900;
  font-size: clamp(2.75rem, 9vw, 7.5rem);
  line-height: .9;
  letter-spacing: -.045em;
  color: var(--ds-plum);
  margin: 0;
}
.ds-display-mag em,
.ds-display-mag .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.025em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  color: var(--ds-coral);             /* peach-coral accent by default */
}
.ds-display-mag--plum em { color: var(--ds-plum); }
.ds-display-mag--peach em { color: var(--ds-peach-active); }
.ds-display-mag .ds-line { display: block; }
.ds-display-mag .ds-line--indent { padding-left: clamp(1.5rem, 8vw, 6rem); }
.ds-display-mag .ds-line--outdent { padding-left: 0; margin-left: clamp(-1rem, -3vw, -.5rem); }

.ds-landing-hero {
  margin-top: .25rem;
}
.ds-landing-hero .ds-display-mag {
  font-size: clamp(2.25rem, 7vw, 5.75rem);
}
.ds-landing-hero__lead {
  font-size: 1.0625rem;
  max-width: 44ch;
}
@media (max-width: 575.98px) {
  .ds-landing-hero .btn {
    width: 100%;
    max-width: 100%;
    justify-content: center;
    white-space: normal;
    text-align: center;
  }
  .ds-landing-hero .btn-lg {
    padding: .875rem 1rem;
    font-size: 1rem;
  }
}
.ds-landing-marquee {
  margin-top: 1.25rem;
}
.ds-landing-index .ds-section-head {
  margin-top: 2.25rem;
  margin-bottom: 1rem;
}
.ds-decision-path {
  margin-top: 1.5rem;
  padding: 1rem;
  border: 1px solid rgba(126, 103, 219, .28);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(216, 210, 248, .52), rgba(255,255,255,.94) 54%),
    var(--ds-white);
}
.ds-decision-path__head {
  display: flex;
  gap: .85rem;
  align-items: flex-start;
  margin-bottom: .9rem;
}
.ds-decision-path__title {
  margin: 0 0 .2rem;
  color: var(--ds-plum);
  font-size: 1.05rem;
  font-weight: 850;
  letter-spacing: 0;
}
.ds-decision-path__intro {
  margin: 0;
  color: var(--ds-muted);
  font-size: .94rem;
  line-height: 1.45;
}
.ds-decision-path__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
}
.ds-decision-path__item {
  display: flex;
  flex-direction: column;
  gap: .28rem;
  min-height: 100%;
  padding: .9rem;
  border: 1px solid rgba(31, 27, 71, .12);
  border-radius: 8px;
  background: rgba(255,255,255,.82);
  color: var(--ds-plum);
  text-decoration: none;
}
.ds-decision-path__item:hover {
  border-color: var(--ds-coral);
  color: var(--ds-plum);
  transform: translateY(-1px);
}
.ds-decision-path__label {
  font-weight: 800;
  line-height: 1.22;
}
.ds-decision-path__text {
  color: var(--ds-muted);
  font-size: .88rem;
  line-height: 1.38;
}
@media (max-width: 767.98px) {
  .ds-decision-path__grid { grid-template-columns: 1fr; }
}
.ds-finder {
  margin-top: 1.5rem;
  padding: 1rem;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  background: var(--ds-surface-soft);
}
.ds-finder__head {
  display: flex;
  align-items: center;
  gap: .85rem;
  margin-bottom: .85rem;
}
.ds-finder__title {
  font-size: 1.125rem;
  letter-spacing: 0;
  margin: 0;
}
.ds-finder__controls {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem;
  margin-bottom: .9rem;
}
.ds-finder__chip {
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-pill);
  background: var(--ds-white);
  color: var(--ds-plum);
  padding: .45rem .75rem;
  font: inherit;
  font-size: .8125rem;
  font-weight: 700;
  cursor: pointer;
}
.ds-finder__chip:hover,
.ds-finder__chip:focus-visible,
.ds-finder__chip.is-active {
  background: var(--ds-plum);
  border-color: var(--ds-plum);
  color: var(--ds-white);
  outline: none;
}
.ds-finder__results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .5rem;
}
.ds-finder__result {
  min-width: 0;
  padding: .75rem .85rem;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-sm);
  background: var(--ds-white);
  color: var(--ds-plum);
  text-decoration: none;
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.ds-finder__result:hover,
.ds-finder__result:focus-visible {
  border-color: var(--ds-plum);
  color: var(--ds-plum);
  outline: none;
}
.ds-finder__result span {
  font-size: .9rem;
  font-weight: 750;
  line-height: 1.2;
}
.ds-finder__result small {
  color: var(--ds-muted);
  font-size: .75rem;
  line-height: 1.25;
}
@media (max-width: 900px) {
  .ds-finder__results { grid-template-columns: 1fr; }
}

/* — Oversized section numerals (01, 02, …) — */
.ds-section-num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(3rem, 8vw, 6rem);
  line-height: .85;
  letter-spacing: -.04em;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
  display: inline-block;
}
.ds-section-num--muted { color: var(--ds-border-hover); }
.ds-section-num--plum  { color: var(--ds-plum); }

/* — Section head: tiny eyebrow + giant numeral + serif title row — */
.ds-section-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: end;
  gap: 1rem 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--ds-plum);
  margin: 3.5rem 0 2rem;
}
.ds-section-head__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(2.25rem, 5vw, 3.75rem);
  line-height: 1;
  color: var(--ds-coral);
  letter-spacing: -.03em;
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-section-head__title {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  font-size: clamp(1.25rem, 2.4vw, 2rem);
  letter-spacing: -.02em;
  line-height: 1.05;
  color: var(--ds-plum);
  margin: 0;
}
.ds-section-head__title em,
.ds-section-head__title .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.015em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-section-head__meta {
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ds-muted);
  white-space: nowrap;
}
@media (max-width: 640px) {
  .ds-section-head { grid-template-columns: auto 1fr; gap: .75rem 1rem; }
  .ds-section-head__meta { grid-column: 1 / -1; }
}

/* — Kicker: horizontal rule with a label inset (editorial divider) — */
.ds-kicker {
  display: flex; align-items: center; gap: 1rem;
  font-size: .75rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-plum);
  margin: 0 0 1.25rem;
}
.ds-kicker::before {
  content: ""; flex: 0 0 2.5rem;
  height: 2px; background: var(--ds-plum);
}
.ds-kicker--end::after {
  content: ""; flex: 1; height: 1px; background: var(--ds-border);
}
.ds-kicker__dot {
  width: .5rem; height: .5rem; border-radius: 50%;
  background: var(--ds-coral);
  animation: ds-pulse 1.8s ease-in-out infinite;
}
@keyframes ds-pulse {
  0%, 100% { opacity: .5; transform: scale(.85); }
  50%      { opacity: 1; transform: scale(1.1); }
}

/* — Marquee ticker (continuous horizontal scroll) — */
.ds-marquee {
  position: relative;
  overflow: hidden;
  background: var(--ds-plum);
  color: var(--ds-white);
  border-radius: 999px;
  padding: .75rem 0;
  /* fade edges so items appear to slide out of nothing */
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 5%, #000 95%, transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, #000 5%, #000 95%, transparent 100%);
}
.ds-marquee__track {
  display: flex; gap: 3rem; width: max-content;
  animation: ds-marquee-scroll 38s linear infinite;
  will-change: transform;
}
.ds-marquee:hover .ds-marquee__track { animation-play-state: paused; }
.ds-marquee__item {
  display: inline-flex; align-items: center; gap: .85rem;
  font-size: .9375rem; font-weight: 500; letter-spacing: -.005em;
  white-space: nowrap;
}
.ds-marquee__item em,
.ds-marquee__item .ds-serif {
  font-family: 'Inter', sans-serif;
  font-style: normal;
  font-weight: 700;
  color: var(--ds-peach);
  font-size: .8125rem;
  letter-spacing: .08em;
  margin-right: .15rem;
}
.ds-marquee__sep {
  display: inline-block; width: 6px; height: 6px; border-radius: 50%;
  background: var(--ds-peach); opacity: .8;
}
@keyframes ds-marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
  .ds-marquee__track { animation: none; }
}

/* — Editorial numbered index row — used for calculator list, articles list — */
.ds-index {
  border-top: 1px solid var(--ds-plum);
  display: flex; flex-direction: column;
}
.ds-index__row {
  display: grid;
  grid-template-columns: minmax(3.5rem, auto) 1fr auto;
  align-items: baseline;
  gap: 1rem 1.5rem;
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--ds-border);
  color: var(--ds-plum);
  text-decoration: none;
  position: relative;
  transition: padding-left .25s ease, background .2s ease;
}
.ds-index__row:hover,
.ds-index__row:focus-visible {
  padding-left: 1rem;
  background: linear-gradient(to right, var(--ds-lavender-soft), transparent 70%);
  color: var(--ds-plum);
  outline: none;
}
.ds-index__row::before {
  content: ""; position: absolute;
  left: 0; top: 50%; transform: translate(-110%, -50%);
  width: 1.5rem; height: 1px; background: var(--ds-plum);
  opacity: 0; transition: opacity .25s ease, transform .25s ease;
}
.ds-index__row:hover::before {
  opacity: 1; transform: translate(-10%, -50%);
}
.ds-index__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.5rem, 3.5vw, 2.5rem);
  line-height: 1;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  font-variation-settings: "opsz" 144, "SOFT" 100;
  align-self: center;
  transition: color .2s ease;
}
.ds-index__row:hover .ds-index__num { color: var(--ds-coral-hover); }
.ds-index__main { min-width: 0; }
.ds-index__title {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: clamp(1.125rem, 2vw, 1.625rem);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--ds-plum);
  margin: 0 0 .35rem;
}
.ds-index__title em,
.ds-index__title .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.01em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-index__sub {
  display: block;
  font-size: .9375rem; line-height: 1.5;
  color: var(--ds-muted);
  max-width: 56ch;
  margin: 0;
}
.ds-index__tags {
  display: flex; gap: .35rem; margin-top: .5rem; flex-wrap: wrap;
}
.ds-index__tag {
  font-size: .6875rem; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ds-muted);
}
.ds-index__badge {
  display: inline-flex;
  align-items: center;
  min-height: 1.5rem;
  padding: .2rem .5rem;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-pill);
  background: var(--ds-white);
  color: var(--ds-plum);
  font-size: .6875rem;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
}
.ds-index__badge--topic {
  background: var(--ds-lavender-soft);
  border-color: transparent;
}
.ds-index__arrow {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-size: 1.5rem;
  color: var(--ds-peach-active);
  align-self: center;
  transition: transform .25s ease, color .2s ease;
}
.ds-index__row:hover .ds-index__arrow { color: var(--ds-coral); }
.ds-index__row:hover .ds-index__arrow { transform: translateX(.4rem); }
@media (max-width: 640px) {
  .ds-index__row { grid-template-columns: auto 1fr; gap: .5rem 1rem; padding: 1.25rem 0; }
  .ds-index__row:hover { padding-left: .35rem; }
  .ds-index__arrow { grid-column: 2; justify-self: end; }
}

.ds-index--compact {
  border-top-color: var(--ds-border);
}
.ds-index--compact .ds-index__row {
  padding: .9rem 0;
  grid-template-columns: minmax(2.25rem, auto) 1fr auto;
  gap: .65rem 1rem;
}
.ds-index--compact .ds-index__num {
  font-size: clamp(1.2rem, 2vw, 1.65rem);
}
.ds-index--compact .ds-index__title {
  font-size: clamp(1rem, 1.35vw, 1.2rem);
  letter-spacing: 0;
  line-height: 1.18;
}
.ds-index--compact .ds-index__sub {
  font-size: .85rem;
  line-height: 1.35;
  max-width: 48ch;
}
.ds-index--compact .ds-index__tags {
  margin-top: .45rem;
}
.ds-index--badged {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 2rem;
}
.ds-index--badged .ds-index__row:nth-child(2) {
  border-top: 0;
}
@media (max-width: 900px) {
  .ds-index--badged {
    display: flex;
  }
}
@media (max-width: 640px) {
  .ds-index--compact .ds-index__row {
    grid-template-columns: auto 1fr;
    padding: 1rem 0;
  }
}

.ds-hub-head {
  margin-bottom: 1.75rem;
}
.ds-hub-head--illustrated {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(17rem, .75fr);
  gap: 1.5rem;
  align-items: center;
}
.ds-hub-head__copy {
  min-width: 0;
}
.ds-category-illo {
  min-width: 0;
  justify-self: end;
  width: min(100%, 26rem);
  aspect-ratio: 21 / 13;
}
.ds-category-illo svg {
  display: block;
  width: 100%;
  height: 100%;
}
.ds-category-illo .paper {
  fill: var(--ds-white);
  stroke: var(--ds-border);
  stroke-width: 2;
}
.ds-category-illo .ink,
.ds-category-illo .line {
  fill: none;
  stroke: var(--ds-plum);
  stroke-width: 8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ds-category-illo .line {
  stroke-width: 5;
  opacity: .75;
}
.ds-category-illo .lav { fill: var(--ds-lavender-soft); }
.ds-category-illo .peach { fill: var(--ds-peach); }
.ds-category-illo .coral {
  fill: none;
  stroke: var(--ds-coral);
  stroke-width: 9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.ds-category-illo .sun { fill: var(--ds-sun); }
@media (max-width: 900px) {
  .ds-hub-head--illustrated { grid-template-columns: 1fr; }
  .ds-category-illo {
    justify-self: start;
    width: min(100%, 22rem);
  }
}
.ds-hub-action-band {
  margin: 2rem 0;
  padding: 1.25rem clamp(1rem, 2vw, 1.5rem);
  background: var(--ds-white);
  border: 1px solid var(--ds-plum);
  border-radius: var(--ds-radius-xl);
}
.ds-hub-action-band--soft {
  border-color: var(--ds-border);
  background: var(--ds-surface-soft);
}
.ds-hub-action-band .ds-section-head {
  margin-top: 0;
}
.ds-action-list {
  margin-top: .75rem;
}
.ds-index--actions {
  border-top-color: var(--ds-border);
}
.ds-index--actions .ds-index__row {
  padding: 1rem 0;
  grid-template-columns: minmax(2.5rem, auto) 1fr auto;
}
.ds-index--actions .ds-index__num {
  font-size: clamp(1.35rem, 2.2vw, 1.85rem);
}
.ds-index--actions .ds-index__title {
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  letter-spacing: 0;
  overflow-wrap: normal;
  word-break: normal;
}
.ds-index--actions .ds-index__sub {
  font-size: .875rem;
  line-height: 1.4;
}

/* — Magazine asymmetric grid: one tall feature card + two stacked — */
.ds-grid-mag {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  grid-template-rows: auto auto;
  gap: 1.25rem;
}
.ds-grid-mag > :nth-child(1) { grid-row: 1 / span 2; }
@media (max-width: 768px) {
  .ds-grid-mag { grid-template-columns: 1fr; }
  .ds-grid-mag > :nth-child(1) { grid-row: auto; }
}

/* — Editorial card: outlined, corner numeral, hover-shift — */
.ds-card--editorial {
  background: var(--ds-white);
  border: 1px solid var(--ds-plum);
  border-radius: var(--ds-radius-lg);
  padding: 1.75rem 1.5rem 1.5rem;
  position: relative;
  overflow: hidden;
  transition: transform .25s ease, box-shadow .25s ease;
  display: flex; flex-direction: column; gap: 1rem;
  min-height: 220px;
}
.ds-card--editorial:hover {
  transform: translate(-3px, -3px);
  box-shadow: 4px 4px 0 0 var(--ds-plum);
}
.ds-card--editorial__num {
  position: absolute;
  top: .85rem; right: 1.1rem;
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 1.75rem;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  opacity: .95;
  font-variation-settings: "opsz" 144;
}
.ds-card--editorial--tall { min-height: 100%; padding: 2.25rem 2rem 2rem; }
.ds-card--editorial--filled {
  background: var(--ds-plum);
  color: var(--ds-white);
  border-color: var(--ds-plum);
}
.ds-card--editorial--filled .ds-card--editorial__num { color: var(--ds-peach); opacity: .9; }
.ds-card--editorial--filled .ds-card--editorial__title { color: var(--ds-white); }
.ds-card--editorial--filled .ds-card--editorial__sub { color: rgba(255,255,255,.7); }
.ds-card--editorial--filled:hover { box-shadow: 4px 4px 0 0 var(--ds-peach); }
.ds-card--editorial--peach { background: var(--ds-peach); border-color: var(--ds-peach); }
.ds-card--editorial--peach:hover { box-shadow: 4px 4px 0 0 var(--ds-plum); }
.ds-card--editorial--lavender {
  background: var(--ds-lavender);
  border-color: var(--ds-lavender);
  color: var(--ds-plum);
}
.ds-card--editorial--lavender:hover { box-shadow: 4px 4px 0 0 var(--ds-plum); }
.ds-card--editorial--lavender .ds-card--editorial__num { color: var(--ds-plum); opacity: .55; }
.ds-card--editorial--lavender .ds-card--editorial__title em,
.ds-card--editorial--lavender .ds-card--editorial__title .ds-serif { color: var(--ds-plum); }
.ds-card--editorial--lavender-soft {
  background: var(--ds-lavender-soft);
  border-color: var(--ds-lavender-soft);
  color: var(--ds-plum);
}
.ds-card--editorial--lavender-soft:hover { box-shadow: 4px 4px 0 0 var(--ds-plum); }
.ds-card--editorial--lavender-soft .ds-card--editorial__num { color: var(--ds-coral); opacity: .9; }
.ds-card--editorial__eyebrow {
  font-size: .6875rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: inherit; opacity: .65;
}
.ds-content-icon {
  width: 2.35rem;
  height: 2.35rem;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-sm);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ds-plum);
  background: var(--ds-white);
}
.ds-content-icon svg {
  width: 1.25rem;
  height: 1.25rem;
}
.ds-content-icon--light {
  border-color: rgba(255,255,255,.2);
  color: var(--ds-white);
  background: rgba(255,255,255,.08);
}
.ds-card--editorial__title {
  font-family: 'Inter', sans-serif;
  font-size: clamp(1.25rem, 2vw, 1.75rem);
  font-weight: 800;
  letter-spacing: -.02em;
  line-height: 1.1;
  color: var(--ds-plum);
  margin: 0;
}
.ds-card--editorial__title em,
.ds-card--editorial__title .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-card--editorial--filled .ds-card--editorial__title em,
.ds-card--editorial--filled .ds-card--editorial__title .ds-serif { color: var(--ds-peach); }
.ds-card--editorial--peach .ds-card--editorial__title em,
.ds-card--editorial--peach .ds-card--editorial__title .ds-serif { color: var(--ds-plum); }
.ds-card--editorial--peach .ds-card--editorial__num { color: var(--ds-plum); opacity: .8; }
.ds-card--editorial__sub {
  font-size: .9375rem; line-height: 1.5;
  color: var(--ds-muted);
  margin: 0;
}
.ds-card--editorial__foot {
  margin-top: auto; padding-top: 1rem;
  border-top: 1px solid var(--ds-border);
  display: flex; align-items: center; justify-content: space-between;
  font-size: .8125rem; font-weight: 600; color: var(--ds-plum);
  letter-spacing: -.005em;
}
.ds-card--editorial--filled .ds-card--editorial__foot {
  border-top-color: rgba(255,255,255,.15);
  color: var(--ds-white);
}

/* — Article drop-cap — first letter of .ds-prose's first <p> — */
.ds-prose--editorial > p:first-of-type::first-letter,
.ds-prose .ds-dropcap::first-letter {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  font-size: 4.5em;
  float: left;
  line-height: .85;
  padding: .35rem .5rem 0 0;
  margin: .15rem .15rem 0 0;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}

/* — Editorial article header — */
.ds-article-head {
  margin-bottom: 2.5rem;
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--ds-plum);
}
.ds-article-head__kicker {
  font-size: .75rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-coral);
  margin-bottom: 1rem;
}
.ds-article-head__title {
  font-family: 'Inter', sans-serif;
  font-weight: 900;
  font-size: clamp(2rem, 5.5vw, 4rem);
  line-height: 1;
  letter-spacing: -.035em;
  color: var(--ds-plum);
  margin: 0 0 1rem;
}
.ds-article-head__title em,
.ds-article-head__title .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.025em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-article-head__deck {
  font-family: 'Inter', sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: clamp(1.125rem, 1.8vw, 1.375rem);
  line-height: 1.45;
  color: var(--ds-plum);
  max-width: 56ch;
  margin: 1.25rem 0 1rem;
  letter-spacing: -.005em;
}

/* — Editorial calculator-page header — */
.ds-calc-head {
  margin-bottom: 1rem;
  padding-bottom: .9rem;
  border-bottom: 1px solid var(--ds-plum);
}
.ds-calc-head__row {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: .6rem;
}
.ds-calc-head__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 1.95rem;
  line-height: 1;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  font-size-adjust: 0.52;
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-calc-head__rule { flex: 1; height: 1px; background: var(--ds-border); }
.ds-calc-head__title {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  font-size: clamp(1.6rem, 3vw, 2.35rem);
  line-height: 1.08;
  letter-spacing: 0;
  color: var(--ds-plum);
  margin: 0 0 .5rem;
}
.ds-calc-head__lead {
  font-size: 1rem;
  color: var(--ds-plum);
  max-width: 46ch;
  line-height: 1.45;
}
.ds-calc-head__lead--wide { max-width: 64ch; }
.ds-calc-head__title em,
.ds-calc-head__title .ds-serif {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 400;
  letter-spacing: -.02em;
  font-size: 1.08em;
  font-size-adjust: 0.52;
  color: var(--ds-coral);
  font-variation-settings: "opsz" 144, "SOFT" 100;
}

.ds-why-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: .85rem;
  align-items: start;
  margin-top: .9rem;
  padding: .95rem 1rem;
  border: 1px solid rgba(126, 103, 219, .26);
  border-left: 5px solid var(--ds-coral);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(216, 210, 248, .62), rgba(255, 246, 229, .78)),
    var(--ds-white);
  box-shadow: 0 12px 30px rgba(31, 27, 71, .07);
}
.ds-why-card__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: var(--ds-plum);
  color: var(--ds-white);
  font-weight: 900;
  line-height: 1;
  box-shadow: 0 6px 16px rgba(31, 27, 71, .18);
}
.ds-why-card__title {
  margin: 0 0 .25rem;
  color: var(--ds-plum);
  font-size: .92rem;
  font-weight: 850;
  line-height: 1.2;
  letter-spacing: 0;
}
.ds-why-card__body {
  margin: 0;
  color: var(--ds-plum);
  font-size: .925rem;
  line-height: 1.45;
}

.ds-sensitivity {
  padding: 1rem;
  border: 1px solid rgba(126, 103, 219, .3);
  border-radius: 8px;
  background: var(--ds-surface-soft);
}
.ds-sensitivity__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .7rem;
}
.ds-sensitivity__title {
  margin: 0;
  color: var(--ds-plum);
  font-size: 1rem;
  font-weight: 850;
  letter-spacing: 0;
}
.ds-sensitivity__value {
  color: var(--ds-coral);
  font-weight: 850;
  font-variant-numeric: tabular-nums;
}
.ds-sensitivity__range {
  width: 100%;
  accent-color: var(--ds-coral);
}
.ds-sensitivity__note {
  color: var(--ds-muted);
  font-size: .85rem;
  line-height: 1.45;
}

/* — Editorial pull-quote / manifesto block — */
.ds-manifesto {
  border-top: 2px solid var(--ds-coral);
  border-bottom: 2px solid var(--ds-coral);
  background: var(--ds-lavender-soft);
  padding: 3rem clamp(1.25rem, 4vw, 3rem);
  margin: 4rem 0;
  text-align: left;
  position: relative;
  border-radius: 2px;
}
.ds-manifesto::before {
  content: "";
  position: absolute;
  top: -8px; left: clamp(1.25rem, 4vw, 3rem);
  width: 8rem; height: 14px;
  background: var(--ds-coral);
}
.ds-manifesto__kicker {
  font-size: .75rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-coral);
  margin-bottom: 1.25rem;
}
.ds-manifesto__body {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(1.75rem, 4.5vw, 3rem);
  line-height: 1.1;
  letter-spacing: -.02em;
  color: var(--ds-plum);
  max-width: 22ch;
  margin: 0;
  font-size-adjust: 0.52;
  font-variation-settings: "opsz" 144, "SOFT" 100;
}
.ds-manifesto__body strong {
  font-style: normal;
  font-family: 'Inter', sans-serif;
  font-weight: 900;
  font-size: .94em;             /* compensate the +08% serif bump so Inter+Fraunces read same size */
  letter-spacing: -.035em;
  color: var(--ds-coral);
  font-size-adjust: none;
}
.ds-manifesto__body em {
  color: var(--ds-coral);
}

.ds-testimonials {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}
.ds-testimonial {
  min-width: 0;
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  padding: 1.25rem;
  display: flex;
  flex-direction: column;
  gap: .9rem;
}
.ds-testimonial__quote {
  margin: 0;
  color: var(--ds-plum);
  font-size: 1rem;
  font-weight: 650;
  line-height: 1.35;
}
.ds-testimonial__quote::before {
  content: "\"";
  color: var(--ds-coral);
}
.ds-testimonial__quote::after {
  content: "\"";
  color: var(--ds-coral);
}
.ds-testimonial__meta {
  margin: auto 0 0;
  padding-top: .75rem;
  border-top: 1px solid var(--ds-border);
  color: var(--ds-muted);
  font-size: .8125rem;
  line-height: 1.35;
}
@media (max-width: 900px) {
  .ds-testimonials {
    grid-template-columns: 1fr;
  }
}
.ds-manifesto__foot {
  margin-top: 1.5rem;
  display: flex; align-items: center; gap: 1rem;
  font-size: .8125rem; color: var(--ds-muted);
}
.ds-manifesto__foot::before {
  content: ""; width: 2.5rem; height: 1px; background: var(--ds-plum);
}

/* — Hairline meta-strip (date · author · reading time) — */
.ds-meta-strip {
  display: flex; flex-wrap: wrap; gap: 1.25rem;
  align-items: center;
  font-size: .75rem; font-weight: 600; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ds-muted);
  padding: .75rem 0;
  border-bottom: 1px solid var(--ds-border);
  margin-bottom: 2rem;
}
.ds-meta-strip__item { display: inline-flex; align-items: center; gap: .5rem; }
.ds-meta-strip__item strong { color: var(--ds-plum); font-weight: 700; }

/* ============================================================
   14. CALCULATOR — form + result blocks
   Brand-unified KPI cards (1 hero + supporting quiet rows),
   editorial chart frame, empty-state and next-step primitives.
   ============================================================ */

/* — Section head used above result block & form — */
.ds-result-head {
  display: flex; align-items: baseline; gap: .85rem;
  margin: 0 0 .75rem;
  padding-bottom: .45rem;
  border-bottom: 1px solid var(--ds-plum);
}
.ds-result-head__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 1.5rem;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  line-height: 1;
}
.ds-result-head__title {
  font-family: 'Inter', sans-serif;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ds-plum);
  margin: 0;
}
.ds-result-head__meta {
  margin-left: auto;
  font-size: .6875rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ds-muted);
}

/* — Asymmetric KPI grid: hero on the left, 2 quiet on the right (md+) — */
.ds-kpi-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 1rem;
}
.ds-kpi-grid__hero { grid-row: 1 / span 2; }
.ds-kpi-grid__side { display: flex; flex-direction: column; gap: 1rem; }
@media (max-width: 768px) {
  .ds-kpi-grid { grid-template-columns: 1fr; }
  .ds-kpi-grid__hero { grid-row: auto; }
}

/* — KPI card: base — */
.ds-kpi {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  padding: 1rem 1.15rem;
  display: flex; flex-direction: column; gap: .5rem;
  position: relative; overflow: hidden;
  min-width: 0;
}
.ds-kpi__eyebrow {
  font-size: .6875rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-muted);
}
.ds-kpi__value {
  font-family: 'Inter', sans-serif;
  font-weight: 800;
  letter-spacing: -.025em;
  line-height: 1;
  color: var(--ds-plum);
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
}
.ds-kpi__unit {
  font-weight: 500;
  font-size: .75em;
  color: var(--ds-muted);
  margin-left: .15em;
}
.ds-kpi__sub {
  font-size: .8125rem;
  color: var(--ds-muted);
  margin: 0;
  line-height: 1.4;
}
.ds-kpi__sub strong { color: var(--ds-plum); font-weight: 700; }

/* hero variant: bigger, filled plum, peach value */
.ds-kpi--hero {
  background: var(--ds-plum);
  color: var(--ds-white);
  border-color: var(--ds-plum);
  padding: 1.45rem 1.5rem;
  gap: .6rem;
  min-height: 100%;
}
.ds-kpi--hero .ds-kpi__eyebrow { color: var(--ds-peach); opacity: 1; }
.ds-kpi--hero .ds-kpi__value {
  color: var(--ds-white);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  letter-spacing: -.035em;
}
.ds-kpi--hero .ds-kpi__unit { color: rgba(255,255,255,.55); }
.ds-kpi--hero .ds-kpi__sub { color: rgba(255,255,255,.7); font-size: .9375rem; }
.ds-kpi--hero .ds-kpi__sub strong { color: var(--ds-peach); }
.ds-kpi--hero::after {
  content: "";
  position: absolute;
  top: 1.25rem; right: 1.25rem;
  width: .5rem; height: .5rem; border-radius: 50%;
  background: var(--ds-peach);
}

/* coral hero — alternative for "gap to close" type primary metrics */
.ds-kpi--coral { background: var(--ds-coral); border-color: var(--ds-coral); color: var(--ds-white); }
.ds-kpi--coral .ds-kpi__value { color: var(--ds-white); }
.ds-kpi--coral .ds-kpi__eyebrow { color: rgba(255,255,255,.85); }
.ds-kpi--coral .ds-kpi__sub     { color: rgba(255,255,255,.85); }

/* quiet variant for side cards: hairline only */
.ds-kpi--quiet { padding: 1rem 1.25rem; }
.ds-kpi--quiet .ds-kpi__value { font-size: clamp(1.5rem, 2.2vw, 1.875rem); }

/* lavender variants — secondary accent for visual breathing room */
.ds-kpi--lavender {
  background: var(--ds-lavender-soft);
  border-color: var(--ds-lavender-soft);
}
.ds-kpi--lavender .ds-kpi__eyebrow { color: var(--ds-plum); opacity: .55; }
.ds-kpi--lavender-strong {
  background: var(--ds-lavender);
  border-color: var(--ds-lavender);
}
.ds-kpi--lavender-strong .ds-kpi__eyebrow { color: var(--ds-plum); opacity: .65; }

/* sun variant — for "warning" / heads-up scores */
.ds-kpi--sun {
  background: var(--ds-sun);
  border-color: var(--ds-sun);
  color: var(--ds-sun-deep);
}
.ds-kpi--sun .ds-kpi__value   { color: var(--ds-sun-deep); }
.ds-kpi--sun .ds-kpi__eyebrow { color: rgba(74,58,0,.65); }
.ds-kpi--sun .ds-kpi__sub     { color: rgba(74,58,0,.85); }
.ds-kpi--sun .ds-kpi__sub strong { color: var(--ds-sun-deep); }
.ds-kpi--sun::after {
  content: ""; position: absolute;
  top: 1.25rem; right: 1.25rem;
  width: .5rem; height: .5rem; border-radius: 50%;
  background: var(--ds-sun-deep);
}

/* peach variant — for "positive growth" type metrics */
.ds-kpi--peach {
  background: var(--ds-peach);
  border-color: var(--ds-peach);
  color: var(--ds-plum);
}
.ds-kpi--peach .ds-kpi__value { color: var(--ds-plum); }
.ds-kpi--peach .ds-kpi__eyebrow { color: rgba(31,27,71,.7); }

/* — Editorial chart container — */
.ds-chart-frame {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  padding: 1.15rem 1.25rem 1rem;
  margin-top: .75rem;
  position: relative;
}
.ds-chart-frame__head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--ds-border);
}
.ds-chart-frame__title {
  font-size: 1.0625rem; font-weight: 700; letter-spacing: -.01em;
  color: var(--ds-plum); margin: 0;
}
.ds-chart-frame__legend {
  display: inline-flex; gap: 1rem;
  font-size: .75rem; color: var(--ds-muted); font-weight: 500;
}
.ds-chart-frame__legend span { display: inline-flex; align-items: center; gap: .35rem; }
.ds-chart-frame__legend span::before {
  content: ""; width: 12px; height: 2px; background: currentColor;
  display: inline-block;
}
.ds-chart-frame__legend .is-coral::before  { background: var(--ds-coral); width: 14px; height: 3px; border-radius: 2px; }
.ds-chart-frame__legend .is-plum::before   { background: transparent;
  border-top: 2px dashed var(--ds-plum); height: 0; width: 14px; }
.ds-chart-frame__canvas { position: relative; height: 260px; }
.ds-chart-frame__caption {
  margin: 1rem 0 0;
  font-size: .9375rem; line-height: 1.55; color: var(--ds-plum);
  max-width: 70ch;
}
.ds-chart-frame__caption strong { color: var(--ds-plum); font-weight: 700; }

/* — Next step (replaces success pill + link) — */
.ds-next-step {
  margin-top: 1rem;
  padding: .85rem 1rem;
  background: var(--ds-surface-soft);
  border-left: 3px solid var(--ds-coral);
  border-radius: 0 8px 8px 0;
  display: flex; align-items: center; gap: .85rem;
  font-size: .9375rem;
  line-height: 1.45;
  color: var(--ds-plum);
}
.ds-next-step__label {
  font-size: .6875rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-coral);
  white-space: nowrap;
  flex-shrink: 0;
}
.ds-next-step a {
  color: var(--ds-plum);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  font-weight: 600;
}
.ds-next-step a:hover { color: var(--ds-coral); }

/* — Form area (replaces ds-card around the form) — */
.ds-calc-form {
  background: var(--ds-white);
  border: 1px solid var(--ds-plum);
  border-radius: var(--ds-radius-xl);
  padding: clamp(1rem, 2.2vw, 1.45rem);
  position: relative;
}
.ds-calc-form__head {
  display: flex; align-items: baseline; gap: .75rem;
  padding-bottom: .75rem;
  margin-bottom: .9rem;
  border-bottom: 1px solid var(--ds-border);
}
.ds-calc-form__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 1.5rem;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  line-height: 1;
}
.ds-calc-form__title {
  font-size: .8125rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ds-plum);
  margin: 0;
}
.ds-calc-form__hint {
  margin-left: auto;
  font-size: .75rem; color: var(--ds-muted);
}

/* — Empty-result placeholder (before the user submits) — */
.ds-empty-result {
  margin-top: 1rem;
  padding: 1.5rem 1.25rem;
  border: 1px dashed var(--ds-lavender-active);
  border-radius: var(--ds-radius-xl);
  text-align: center;
  background:
    radial-gradient(ellipse at top, var(--ds-lavender-soft) 0%, transparent 70%);
}
.ds-empty-result__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: clamp(2.5rem, 6vw, 3.5rem);
  line-height: 1;
  color: var(--ds-coral);
  letter-spacing: -.04em;
  opacity: .55;
}
.ds-empty-result__eyebrow {
  font-size: .75rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-plum);
  margin-top: .75rem;
}
.ds-empty-result__hint {
  margin: .35rem 0 0;
  color: var(--ds-muted);
  font-size: .9375rem;
  line-height: 1.5;
  max-width: 44ch; margin-inline: auto;
}

/* — Email-capture editorial plate (replaces lavender card) — */
.ds-lead-capture {
  margin-top: 2rem;
  border: 1px solid var(--ds-plum);
  border-radius: var(--ds-radius-xl);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
}
.ds-lead-capture__copy {
  padding: 1.75rem 1.75rem 1.5rem;
  background: var(--ds-plum);
  color: var(--ds-white);
  display: flex; flex-direction: column; gap: .65rem;
  justify-content: center;
}
.ds-lead-capture__kicker {
  font-size: .6875rem; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: var(--ds-peach);
}
.ds-lead-capture__title {
  font-size: clamp(1.25rem, 2vw, 1.625rem);
  font-weight: 800; letter-spacing: -.02em; line-height: 1.1;
  color: var(--ds-white); margin: 0;
}
.ds-lead-capture__sub {
  font-size: .9375rem; line-height: 1.45;
  color: rgba(255,255,255,.75); margin: 0; max-width: 36ch;
}
.ds-lead-capture__form {
  padding: 1.75rem;
  background: var(--ds-white);
  display: flex; flex-direction: column; gap: .85rem;
}
@media (max-width: 720px) {
  .ds-lead-capture { grid-template-columns: 1fr; }
}

/* — Calculator banner header — used when there's no form (comparators).
   Replaces the 5+7 grid; spans the full width with main copy left,
   byline / pills right. Keeps editorial kicker + rule from .ds-calc-head. */
.ds-calc-banner {
  margin-bottom: 1.25rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--ds-plum);
}
.ds-calc-banner__head {
  display: flex; align-items: center; gap: 1rem;
  margin-bottom: 1rem;
}
.ds-calc-banner__body {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: 1.5rem;
  align-items: end;
}
.ds-calc-banner__main { min-width: 0; }
.ds-calc-banner__meta {
  display: flex; flex-direction: column; gap: .5rem;
  align-items: flex-start;
  padding-left: 1.5rem;
  border-left: 1px solid var(--ds-border);
}
@media (max-width: 768px) {
  .ds-calc-banner__body { grid-template-columns: 1fr; gap: 1.25rem; }
  .ds-calc-banner__meta { padding-left: 0; border-left: 0;
    padding-top: 1rem; border-top: 1px solid var(--ds-border); }
}

/* — Editorial payoff-order list (debt-free per-debt list) — */
.ds-payoff-list {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column;
  border-top: 1px solid var(--ds-border);
}
.ds-payoff-list__item {
  display: grid;
  grid-template-columns: 2.5rem 1fr auto;
  align-items: baseline;
  gap: 1rem;
  padding: .85rem 0;
  border-bottom: 1px solid var(--ds-border);
}
.ds-payoff-list__num {
  font-family: 'Fraunces', Georgia, serif;
  font-style: italic;
  font-weight: 300;
  font-size: 1.5rem;
  color: var(--ds-coral);
  letter-spacing: -.02em;
  line-height: 1;
  font-variation-settings: "opsz" 144;
}
.ds-payoff-list__name { font-weight: 600; color: var(--ds-plum); min-width: 0; word-break: break-word; }
.ds-payoff-list__when {
  font-size: .8125rem; color: var(--ds-muted); white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* — Stale-data warning plate — */
.ds-stale-warn {
  display: flex; align-items: flex-start; gap: .85rem;
  padding: .85rem 1rem;
  background: #FFF6E0;
  border: 1px solid var(--ds-sun);
  border-left: 3px solid var(--ds-sun-hover);
  border-radius: 8px;
  margin-bottom: 1rem;
}
.ds-stale-warn__icon {
  flex-shrink: 0;
  width: 1.5rem; height: 1.5rem;
  border-radius: 50%;
  background: var(--ds-sun);
  color: var(--ds-sun-deep);
  font-weight: 900;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: .875rem;
}
.ds-stale-warn__text {
  margin: 0;
  font-size: .8125rem; line-height: 1.45;
  color: var(--ds-sun-deep);
}
.ds-stale-warn__text strong { font-weight: 700; }

.ds-calc-note {
  padding: 1rem 1.15rem;
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  background: var(--ds-surface-soft);
  color: var(--ds-plum);
  font-size: .95rem;
  line-height: 1.45;
}

/* — Editorial comparison table — */
.ds-table-wrap {
  background: var(--ds-white);
  border: 1px solid var(--ds-border);
  border-radius: var(--ds-radius-lg);
  overflow: hidden;
  margin-top: 1rem;
}
.ds-table-wrap__head {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem .75rem;
  border-bottom: 1px solid var(--ds-border);
}
.ds-table-wrap__title {
  font-size: 1rem; font-weight: 700; color: var(--ds-plum);
  letter-spacing: -.005em; margin: 0;
}
.ds-table-wrap__meta {
  font-size: .6875rem; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--ds-muted);
}
.ds-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .9375rem;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1;
}
.ds-table thead th {
  font-size: .6875rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  color: var(--ds-muted);
  text-align: right;
  padding: .85rem 1.25rem;
  background: var(--ds-surface-soft);
  border-bottom: 1px solid var(--ds-border);
  white-space: nowrap;
}
.ds-table thead th:first-child { text-align: left; }
.ds-table tbody td,
.ds-table tbody th {
  padding: .85rem 1.25rem;
  border-bottom: 1px solid var(--ds-border);
  color: var(--ds-plum);
  text-align: right;
}
.ds-table tbody th {
  text-align: left;
  font-weight: 600;
  letter-spacing: -.005em;
}
.ds-table tbody tr:last-child td,
.ds-table tbody tr:last-child th { border-bottom: 0; }
.ds-table tbody tr:hover td,
.ds-table tbody tr:hover th { background: var(--ds-surface-soft); }
.ds-table tbody tr.is-primary {
  background: linear-gradient(to right, rgba(229,84,77,.06), transparent);
}
.ds-table tbody tr.is-primary th { color: var(--ds-coral); }
.ds-table tbody tr.is-primary th::before {
  content: "►"; color: var(--ds-coral); font-size: .6em;
  margin-right: .4em; vertical-align: 1px;
}
.ds-table tbody tr.is-aggregate {
  background: var(--ds-surface-soft);
  font-weight: 700;
}
.ds-table tbody tr.is-aggregate th { font-weight: 700; }
.ds-table__num { text-align: right; white-space: nowrap; }
.ds-table__num--up   { color: var(--ds-coral); }
.ds-table__num--down { color: var(--ds-success); }
.ds-table__empty { color: var(--ds-muted); }
@media (max-width: 640px) {
  .ds-table { font-size: .875rem; }
  .ds-table thead th,
  .ds-table tbody td,
  .ds-table tbody th { padding: .65rem .85rem; }
}

/* — Animated reveal for editorial sections (one-shot on page load) — */
@media (prefers-reduced-motion: no-preference) {
  .ds-reveal {
    animation: ds-reveal-up .9s cubic-bezier(.2,.7,.2,1) both;
  }
  .ds-reveal[data-delay="1"] { animation-delay: .08s; }
  .ds-reveal[data-delay="2"] { animation-delay: .16s; }
  .ds-reveal[data-delay="3"] { animation-delay: .24s; }
  .ds-reveal[data-delay="4"] { animation-delay: .32s; }
  .ds-reveal[data-delay="5"] { animation-delay: .40s; }
  @keyframes ds-reveal-up {
    from { opacity: 0; transform: translateY(18px); }
    to   { opacity: 1; transform: translateY(0); }
  }
}
