/* GENERATED by tools/build-css.mjs — do not edit. Source: fonts.css + tokens.css + components.css */

/* ===== fonts.css ===== */
/* Brand webfonts for the Dizain design system.
   tokens.css references "Fraunces" (display/serif) and "Inter" (sans/UI); this
   loads both from Google Fonts so designs render in-brand. Kept separate from
   tokens.css so the font source can be swapped for self-hosted woff2 later
   without touching the token definitions. */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap');


/* ===== tokens.css ===== */
/* design-system/tokens.css
   CSS custom-property mirror of tokens.ts. Single source of truth for runtime styling.
   Brand intent: calm, clinical-warm, editorial, premium. Teal is the one brand color;
   stone/slate are neutrals; amber is a sparing accent. Keep in sync with tokens.ts. */

:root {
  /* Brand */
  --color-brand: #0F766E;
  --color-brand-hover: #115E59;
  --color-brand-tint: #F0FDFA;
  --color-brand-on: #FFFFFF;

  /* Neutrals */
  --color-ink: #0F172A;
  --color-body: #334155;
  --color-muted: #64748B;

  /* Surfaces */
  --color-surface-base: #FAFAF9;
  --color-surface-raised: #F5F5F4;
  --color-surface-card: #FFFFFF;
  --color-border: #E7E5E4;

  /* Accent (sparing) */
  --color-accent: #D97706;
  --color-accent-tint: #FEF3C7;

  /* Feedback (calm; crisis UI uses brand teal, not alarm red) */
  --color-success: #15803D;
  --color-warning: #B45309;
  --color-danger: #B91C1C;
  --color-focus-ring: #14B8A6;

  /* Type */
  --font-display: "Space Grotesk", "Geist", system-ui, sans-serif;
  --font-sans: "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --fs-display: 3.75rem;
  --fs-h1: 3rem;
  --fs-h2: 2.25rem;
  --fs-h3: 1.5rem;
  --fs-body-lg: 1.125rem;
  --fs-body: 1rem;
  --fs-caption: 0.8125rem;

  --lh-tight: 1.1;
  --lh-snug: 1.25;
  --lh-normal: 1.6;

  --tracking-display: -0.02em;
  --measure: 70ch;

  /* Spacing — 8pt grid */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-6: 24px;
  --space-8: 32px;
  --space-12: 48px;
  --space-16: 64px;
  --space-24: 96px;
  --space-32: 128px;

  /* Radius */
  --radius-sm: 8px;
  --radius-md: 12px;
  --radius-lg: 16px;
  --radius-pill: 999px;

  /* Shadow — soft, layered, low-opacity */
  --shadow-sm: 0 1px 2px rgba(15,23,42,0.04), 0 1px 1px rgba(15,23,42,0.03);
  --shadow-md: 0 4px 12px rgba(15,23,42,0.06), 0 2px 4px rgba(15,23,42,0.04);
  --shadow-lg: 0 12px 32px rgba(15,23,42,0.08), 0 4px 8px rgba(15,23,42,0.04);

  /* Motion */
  --duration-fast: 150ms;
  --duration-base: 200ms;
  --duration-slow: 250ms;
  --easing-standard: cubic-bezier(0.16, 1, 0.3, 1);
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --duration-fast: 0ms;
    --duration-base: 0ms;
    --duration-slow: 0ms;
  }
}


/* ===== components.css ===== */
/* design-system/components.css
   Component styles for {{BRAND}}. Built entirely on tokens.css variables.
   Aesthetic: calm clinical-warm, editorial, premium. Boldness is spent in ONE place — the
   serif display type + the "spine + node" eyebrow signature (a point -> a path: where you
   stand and the next step). Everything else stays quiet. All selectors are `.rs-` prefixed
   to avoid specificity collisions. */

/* ---------- Typography ---------- */
.rs-display {
  font-family: var(--font-display);
  font-size: clamp(2.5rem, 1.6rem + 4.2vw, var(--fs-display));
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-display);
  font-weight: 600;
  color: var(--color-ink);
  margin: 0;
}
.rs-h1 { font-family: var(--font-display); font-size: clamp(2rem, 1.4rem + 2.6vw, var(--fs-h1)); line-height: var(--lh-snug); letter-spacing: var(--tracking-display); font-weight: 600; color: var(--color-ink); margin: 0; }
.rs-h2 { font-family: var(--font-display); font-size: clamp(1.6rem, 1.2rem + 1.6vw, var(--fs-h2)); line-height: var(--lh-snug); letter-spacing: var(--tracking-display); font-weight: 600; color: var(--color-ink); margin: 0; }
.rs-h3 { font-family: var(--font-display); font-size: var(--fs-h3); line-height: var(--lh-snug); font-weight: 600; color: var(--color-ink); margin: 0; }
.rs-lead { font-family: var(--font-sans); font-size: var(--fs-body-lg); line-height: var(--lh-normal); color: var(--color-body); margin: 0; }
.rs-body { font-family: var(--font-sans); font-size: var(--fs-body); line-height: var(--lh-normal); color: var(--color-body); margin: 0; }
.rs-caption { font-family: var(--font-sans); font-size: var(--fs-caption); line-height: var(--lh-normal); color: var(--color-muted); margin: 0; }
.rs-measure { max-width: var(--measure); }

/* ---------- Signature: eyebrow (spine + node) ---------- */
.rs-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  font-weight: 600;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  color: var(--color-brand);
}
.rs-eyebrow__mark { position: relative; display: inline-block; width: 30px; height: 6px; flex: none; }
.rs-eyebrow__mark::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 6px; height: 6px; border-radius: var(--radius-pill); background: var(--color-brand); }
.rs-eyebrow__mark::after { content: ""; position: absolute; left: 9px; right: 0; top: 50%; height: 1px; background: var(--color-brand); opacity: 0.45; }

/* ---------- Layout ---------- */
.rs-container { width: 100%; max-width: 1120px; margin-inline: auto; padding-inline: var(--space-6); }
.rs-section { padding-block: var(--space-24); }
.rs-section--hero { padding-block: var(--space-32); }
.rs-section__head { display: flex; flex-direction: column; gap: var(--space-4); max-width: var(--measure); margin-bottom: var(--space-12); }

/* ---------- Button ---------- */
.rs-btn {
  font-family: var(--font-sans);
  font-size: var(--fs-body);
  font-weight: 600;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 14px 22px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--duration-fast) var(--easing-standard),
    background var(--duration-base) var(--easing-standard),
    box-shadow var(--duration-base) var(--easing-standard),
    border-color var(--duration-base) var(--easing-standard),
    color var(--duration-base) var(--easing-standard);
}
.rs-btn:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }
.rs-btn--primary { background: var(--color-brand); color: var(--color-brand-on); box-shadow: var(--shadow-sm); }
.rs-btn--primary:hover { background: var(--color-brand-hover); transform: translateY(-1px); box-shadow: var(--shadow-md); }
.rs-btn--secondary { background: var(--color-surface-card); color: var(--color-ink); border-color: var(--color-border); }
.rs-btn--secondary:hover { border-color: var(--color-brand); color: var(--color-brand); }
.rs-btn--ghost { background: transparent; color: var(--color-ink); }
.rs-btn--ghost:hover { background: var(--color-surface-raised); }
.rs-btn--lg { padding: 17px 28px; font-size: var(--fs-body-lg); }
.rs-btn--pill { border-radius: var(--radius-pill); }
.rs-btn[disabled] { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }

/* ---------- Card ---------- */
.rs-card { background: var(--color-surface-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: var(--space-8); }
.rs-card--interactive { transition: transform var(--duration-base) var(--easing-standard), box-shadow var(--duration-base) var(--easing-standard); }
.rs-card--interactive:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* ---------- Nav ---------- */
.rs-nav { position: sticky; top: 0; z-index: 50; border-bottom: 1px solid var(--color-border); background: var(--color-surface-base); }
@supports (backdrop-filter: blur(10px)) {
  .rs-nav { background: color-mix(in srgb, var(--color-surface-base) 82%, transparent); backdrop-filter: saturate(1.4) blur(10px); }
}
.rs-nav__inner { display: flex; align-items: center; gap: var(--space-8); height: 68px; }
.rs-nav__brand { font-family: var(--font-display); font-size: 1.25rem; font-weight: 600; letter-spacing: var(--tracking-display); color: var(--color-ink); text-decoration: none; }
.rs-nav__links { display: flex; align-items: center; gap: var(--space-6); margin-inline-start: auto; }
.rs-nav__link { font-family: var(--font-sans); font-size: var(--fs-body); color: var(--color-muted); text-decoration: none; transition: color var(--duration-base) var(--easing-standard); }
.rs-nav__link:hover { color: var(--color-ink); }
.rs-nav__help { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-sans); font-size: var(--fs-body); font-weight: 600; color: var(--color-brand); text-decoration: none; }
.rs-nav__help::before { content: ""; width: 6px; height: 6px; border-radius: var(--radius-pill); background: var(--color-brand); }

/* ---------- Badge / chip ---------- */
.rs-badge { display: inline-flex; align-items: center; gap: var(--space-2); font-family: var(--font-sans); font-size: var(--fs-caption); font-weight: 600; padding: 5px 11px; border-radius: var(--radius-pill); }
.rs-badge--brand { background: var(--color-brand-tint); color: var(--color-brand-hover); }
.rs-badge--accent { background: var(--color-accent-tint); color: #92400E; }
.rs-badge--quiet { background: var(--color-surface-raised); color: var(--color-muted); }

/* ---------- Field ---------- */
.rs-field { display: flex; flex-direction: column; gap: var(--space-2); }
.rs-field__label { font-family: var(--font-sans); font-size: var(--fs-caption); font-weight: 600; color: var(--color-ink); }
.rs-field__input { font-family: var(--font-sans); font-size: var(--fs-body); color: var(--color-ink); background: var(--color-surface-card); border: 1px solid var(--color-border); border-radius: var(--radius-md); padding: 12px 14px; transition: border-color var(--duration-base) var(--easing-standard), box-shadow var(--duration-base) var(--easing-standard); }
.rs-field__input::placeholder { color: var(--color-muted); }
.rs-field__input:focus-visible { outline: none; border-color: var(--color-brand); box-shadow: 0 0 0 3px var(--color-brand-tint); }
.rs-field__help { font-family: var(--font-sans); font-size: var(--fs-caption); color: var(--color-muted); }
.rs-field--error .rs-field__input { border-color: var(--color-danger); }
.rs-field--error .rs-field__help { color: var(--color-danger); }

/* ---------- Pricing ---------- */
.rs-price { position: relative; display: flex; flex-direction: column; gap: var(--space-6); background: var(--color-surface-card); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-8); box-shadow: var(--shadow-sm); }
.rs-price--featured { border-color: var(--color-brand); box-shadow: var(--shadow-md); }
.rs-price--featured::before { content: ""; position: absolute; inset-inline: 0; top: 0; height: 3px; background: var(--color-brand); border-radius: var(--radius-lg) var(--radius-lg) 0 0; }
.rs-price__amount { font-family: var(--font-display); font-size: var(--fs-h1); line-height: 1; letter-spacing: var(--tracking-display); color: var(--color-ink); }
.rs-price__period { font-family: var(--font-sans); font-size: var(--fs-body); color: var(--color-muted); }
.rs-price__features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: var(--space-3); }
.rs-price__feature { display: flex; gap: var(--space-3); font-family: var(--font-sans); font-size: var(--fs-body); line-height: var(--lh-normal); color: var(--color-body); }
.rs-price__check { flex: none; color: var(--color-brand); margin-top: 3px; }

/* ---------- Accordion ---------- */
.rs-accordion { border-top: 1px solid var(--color-border); }
.rs-accordion__item { border-bottom: 1px solid var(--color-border); }
.rs-accordion__trigger { width: 100%; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-6) 0; background: none; border: none; cursor: pointer; text-align: left; font-family: var(--font-display); font-size: var(--fs-h3); color: var(--color-ink); }
.rs-accordion__trigger:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 3px; }
.rs-accordion__icon { flex: none; color: var(--color-brand); transition: transform var(--duration-base) var(--easing-standard); }
.rs-accordion__trigger[aria-expanded="true"] .rs-accordion__icon { transform: rotate(135deg); }
.rs-accordion__panel { padding-bottom: var(--space-6); max-width: var(--measure); font-family: var(--font-sans); font-size: var(--fs-body-lg); line-height: var(--lh-normal); color: var(--color-body); }

/* ---------- Crisis panel (safety-critical: calm, never gated) ---------- */
.rs-crisis { background: var(--color-brand-tint); border: 1px solid color-mix(in srgb, var(--color-brand) 22%, var(--color-border)); border-radius: var(--radius-lg); padding: var(--space-8); }
@supports not (background: color-mix(in srgb, red, blue)) { .rs-crisis { border-color: var(--color-brand); } }
.rs-crisis__head { display: flex; flex-direction: column; gap: var(--space-3); margin-bottom: var(--space-6); max-width: var(--measure); }
.rs-crisis__regions { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-bottom: var(--space-6); }
.rs-crisis__region { font-family: var(--font-sans); font-size: var(--fs-caption); font-weight: 600; padding: 7px 13px; border-radius: var(--radius-pill); border: 1px solid var(--color-border); background: var(--color-surface-card); color: var(--color-body); cursor: pointer; transition: background var(--duration-base) var(--easing-standard), color var(--duration-base) var(--easing-standard), border-color var(--duration-base) var(--easing-standard); }
.rs-crisis__region:hover { border-color: var(--color-brand); color: var(--color-brand-hover); }
.rs-crisis__region[aria-pressed="true"] { background: var(--color-brand); color: var(--color-brand-on); border-color: var(--color-brand); }
.rs-crisis__region:focus-visible { outline: 2px solid var(--color-focus-ring); outline-offset: 2px; }
.rs-crisis__lines { display: flex; flex-direction: column; gap: var(--space-4); }
.rs-crisis__line { display: flex; flex-direction: column; gap: 2px; }
.rs-crisis__label { font-family: var(--font-sans); font-size: var(--fs-caption); font-weight: 600; color: var(--color-ink); }
.rs-crisis__line a, .rs-crisis__value { font-family: var(--font-display); font-size: var(--fs-h3); line-height: var(--lh-snug); color: var(--color-brand-hover); text-decoration: none; }
.rs-crisis__line a:hover { text-decoration: underline; }
.rs-crisis__note { font-family: var(--font-sans); font-size: var(--fs-caption); color: var(--color-muted); }

/* ---------- Footer (deep slate, premium grounding) ---------- */
.rs-footer { background: var(--color-ink); color: #CBD5E1; padding-block: var(--space-16); }
.rs-footer__grid { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: var(--space-8); }
.rs-footer__brand { font-family: var(--font-display); font-size: 1.25rem; font-weight: 600; letter-spacing: var(--tracking-display); color: #FFFFFF; }
.rs-footer__tagline { font-family: var(--font-sans); font-size: var(--fs-body); color: #94A3B8; margin-top: var(--space-3); max-width: 32ch; }
.rs-footer__col-title { font-family: var(--font-sans); font-size: var(--fs-caption); font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: #94A3B8; margin-bottom: var(--space-4); }
.rs-footer__link { display: block; font-family: var(--font-sans); font-size: var(--fs-body); color: #CBD5E1; text-decoration: none; padding-block: 4px; transition: color var(--duration-base) var(--easing-standard); }
.rs-footer__link:hover { color: #FFFFFF; }
.rs-footer__fine { border-top: 1px solid #1E293B; margin-top: var(--space-12); padding-top: var(--space-6); display: flex; flex-direction: column; gap: var(--space-2); }
.rs-footer__fine p { font-family: var(--font-sans); font-size: var(--fs-caption); line-height: var(--lh-normal); color: #94A3B8; margin: 0; }
@media (max-width: 768px) { .rs-footer__grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .rs-footer__grid { grid-template-columns: 1fr; } }
