@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;1,9..144,400;1,9..144,500;1,9..144,600&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

/* ==========================================================================
   Mind the Margins — launch site
   Tokens lifted verbatim from the Claude Design system
   (mind-the-margins-design-system). Components reproduced from the
   compiled _ds bundle (Button, Input, Select, TrueMarginLedger, Badge).
   ========================================================================== */

:root {
  /* ---- Base palette ---- */
  --mtm-ink: #16241F;
  --mtm-forest: #3E5C45;
  --mtm-sage: #8A9A6B;
  --mtm-ochre: #C67B3A;
  --mtm-oat: #F1EADB;
  --mtm-bone: #FAF6EC;
  --mtm-sand: #E7DECB;
  --mtm-line: #DED3BE;
  --mtm-muted: #6E7468;

  /* ---- Tints & supporting steps ---- */
  --mtm-forest-700: #2F4736;
  --mtm-forest-100: #E4E8DC;
  --mtm-ochre-600: #AE6A2E;
  --mtm-ochre-100: #F3E2D0;
  --mtm-sage-100: #ECEFE0;
  --mtm-cream-on-ink: #EFE7D6;

  /* ---- Text-safe accent variants ---- */
  --mtm-ochre-text: #9A5016;
  --mtm-sage-light: #C4D2A8;

  /* ---- Semantic: surfaces ---- */
  --surface-page: var(--mtm-oat);
  --surface-sunken: var(--mtm-sand);
  --surface-card: var(--mtm-bone);
  --surface-inverse: var(--mtm-ink);
  --surface-brand: var(--mtm-forest);

  /* ---- Semantic: text ---- */
  --text-strong: var(--mtm-ink);
  --text-body: #2A352E;
  --text-muted: var(--mtm-muted);
  --text-on-inverse: var(--mtm-cream-on-ink);
  --text-on-brand: var(--mtm-oat);
  --text-link: var(--mtm-forest);
  --text-accent: var(--mtm-ochre-text);
  --text-accent-on-dark: var(--mtm-sage-light);

  /* ---- Semantic: lines & borders ---- */
  --border-hair: var(--mtm-line);
  --border-strong: var(--mtm-ink);

  /* ---- Semantic: interactive (primary = forest) ---- */
  --action-bg: var(--mtm-forest);
  --action-bg-hover: var(--mtm-ink);
  --action-fg: var(--mtm-oat);
  --accent-bg: var(--mtm-ochre);
  --accent-bg-hover: var(--mtm-ochre-600);
  --accent-fg: #FFFFFF;
  --focus-ring: var(--mtm-forest);

  /* ---- Status ---- */
  --status-positive: #3E5C45;
  --status-positive-bg: #E4E8DC;
  --status-warning: #C67B3A;
  --status-warning-bg: #F3E2D0;
  --status-danger: #A8442F;
  --status-danger-bg: #F0DBD2;

  /* ---- Type ---- */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-sans: 'Hanken Grotesk', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  /* ---- Radii ---- */
  --radius-sm: 8px;
  --radius-lg: 16px;
  --radius-mark: 14px;
  --radius-pill: 999px;

  /* ---- Shadows ---- */
  --shadow-md: 0 24px 50px -28px rgba(22, 36, 31, .40);
  --shadow-focus: 0 0 0 3px rgba(62, 92, 69, .30);

  /* ---- Motion ---- */
  --ease-standard: cubic-bezier(.22, .61, .36, 1);
  --dur: 200ms;
}

/* --------------------------------------------------------------------------
   Reset / base
   -------------------------------------------------------------------------- */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--mtm-oat);
  color: var(--mtm-ink);
  font-family: var(--font-sans);
  font-size: 18px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; }
a { color: inherit; }
h1, h2, h3, h4, p, blockquote, figure { margin: 0; }
:focus-visible { outline: 2px solid var(--focus-ring); outline-offset: 2px; }

.wrap { max-width: 1140px; margin: 0 auto; padding: 0 28px; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 12px;
  font-size: 12.5px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: var(--mtm-forest);
}
.eyebrow::before { content: ""; width: 22px; height: 2px; background: var(--mtm-ochre-text); }
.eyebrow.on-dark { color: var(--mtm-sage-light); }
.eyebrow.on-dark::before { background: var(--mtm-ochre); }
em.accent { font-style: italic; color: var(--mtm-forest); }
em.accent-dark { font-style: italic; color: var(--mtm-sage-light); }

/* Centered ledger rule (margin line motif) */
.mtm-ruled { position: relative; }
.mtm-ruled::before {
  content: ""; position: absolute; top: 0; bottom: 0;
  left: max(16px, calc(50% - 570px)); width: 1px;
  background: var(--mtm-sage); opacity: .4;
}
@media (max-width: 720px) { .mtm-ruled::before { display: none; } }

/* --------------------------------------------------------------------------
   Buttons  (reproduced from _ds Button.jsx)
   -------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-sans); font-weight: 600; font-size: 15px; line-height: 1;
  padding: 12px 22px; border-radius: var(--radius-pill);
  border: 1px solid transparent; cursor: pointer; text-decoration: none;
  transition: background var(--dur) var(--ease-standard), transform 120ms var(--ease-standard);
}
.btn:active { transform: translateY(1px); }
.btn--sm { padding: 9px 18px; font-size: 14px; }
.btn--lg { padding: 14px 28px; font-size: 16px; }
.btn--block { width: 100%; }
.btn--primary { background: var(--action-bg); color: var(--action-fg); border-color: var(--action-bg); }
.btn--primary:hover { background: var(--action-bg-hover); transform: translateY(-1px); }
.btn--ghost { background: transparent; color: var(--mtm-forest); border-color: var(--mtm-forest); }
.btn--ghost:hover { background: color-mix(in srgb, var(--mtm-forest) 8%, transparent); transform: translateY(-1px); }
.btn--accent { background: var(--accent-bg); color: var(--accent-fg); border-color: var(--accent-bg); }
.btn--accent:hover { background: var(--accent-bg-hover); transform: translateY(-1px); }

/* --------------------------------------------------------------------------
   Form fields  (reproduced from _ds Input.jsx / Select.jsx)
   -------------------------------------------------------------------------- */
.field { display: flex; flex-direction: column; gap: 6px; font-family: var(--font-sans); }
.field > label { font-size: 13px; font-weight: 600; color: var(--text-strong); }
.field__hint { font-size: 13px; color: var(--text-muted); }
.field__error { font-size: 13px; color: var(--status-danger); font-weight: 500; min-height: 0; }
.field .control {
  display: flex; align-items: center; gap: 8px;
  background: var(--surface-card); border: 1px solid var(--border-hair);
  border-radius: var(--radius-sm); padding: 0 12px;
  transition: border-color var(--dur), box-shadow var(--dur);
}
.field .control:focus-within { border-color: var(--mtm-forest); box-shadow: var(--shadow-focus); }
.field.has-error .control { border-color: var(--status-danger); }
.field .affix { color: var(--text-muted); font-size: 15px; }
.field input,
.field textarea,
.field select {
  flex: 1; width: 100%; border: none; outline: none; background: transparent;
  font-family: var(--font-sans); font-size: 15px; color: var(--text-body);
  padding: 11px 0;
}
.field textarea {
  padding: 11px 12px; resize: vertical;
  border: 1px solid var(--border-hair); border-radius: var(--radius-sm);
  background: var(--surface-card);
  transition: border-color var(--dur), box-shadow var(--dur);
}
.field textarea:focus { border-color: var(--mtm-forest); box-shadow: var(--shadow-focus); }
.field .select-wrap { position: relative; }
.field select {
  appearance: none; -webkit-appearance: none; cursor: pointer;
  border: 1px solid var(--border-hair); border-radius: var(--radius-sm);
  background: var(--surface-card); padding: 11px 38px 11px 12px;
  transition: border-color var(--dur), box-shadow var(--dur);
}
.field select:focus { border-color: var(--mtm-forest); box-shadow: var(--shadow-focus); }
.field .select-wrap::after {
  content: ""; position: absolute; right: 14px; top: 50%; width: 9px; height: 9px;
  margin-top: -6px; border-right: 1.6px solid var(--mtm-muted);
  border-bottom: 1.6px solid var(--mtm-muted); transform: rotate(45deg);
  pointer-events: none;
}

/* --------------------------------------------------------------------------
   Header / nav
   -------------------------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(241, 234, 219, .9); backdrop-filter: saturate(1.1) blur(8px);
  border-bottom: 1px solid rgba(138, 154, 107, .4);
}
.site-header .bar {
  max-width: 1140px; margin: 0 auto; padding: 14px 28px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.brand-logo { height: 34px; width: auto; cursor: pointer; }
.nav-links { display: flex; align-items: center; gap: 30px; }
.nav-link {
  background: none; border: none; cursor: pointer; padding: 0;
  font-family: var(--font-sans); font-size: 14.5px; font-weight: 500;
  color: rgba(22, 36, 31, .78); white-space: nowrap;
  transition: color var(--dur) var(--ease-standard);
}
.nav-link:hover { color: var(--mtm-ink); }
.burger {
  display: none; cursor: pointer; width: 42px; height: 38px;
  align-items: center; justify-content: center; background: none;
  border: 1px solid rgba(138, 154, 107, .55); border-radius: 8px;
}
.mobile-menu { display: none; border-top: 1px solid rgba(138, 154, 107, .4); background: var(--mtm-oat); }
.mobile-menu.open { display: block; }
.mobile-menu .inner { max-width: 1140px; margin: 0 auto; padding: 6px 24px 18px; display: flex; flex-direction: column; gap: 2px; }
.mobile-menu .nav-link { padding: 13px 2px; font-size: 16px; color: var(--mtm-ink); text-align: left; border-bottom: 1px solid rgba(138, 154, 107, .25); }
.mobile-menu .btn { margin-top: 14px; }

/* --------------------------------------------------------------------------
   Views
   -------------------------------------------------------------------------- */
[data-view] { display: none; }
[data-view].active { display: block; }

/* Hero — statement */
.hero {
  padding-top: 84px; padding-bottom: 76px; text-align: center;
}
.hero .inner { max-width: 900px; margin: 0 auto; padding: 0 28px; }
.hero h1 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(48px, 9vw, 104px); line-height: 1.04;
  letter-spacing: -.028em; margin-top: 24px;
}
.hero h1 em { font-style: italic; color: var(--mtm-forest); }
.hero .lede {
  font-size: clamp(18px, 2.3vw, 23px); line-height: 1.5; max-width: 46ch;
  margin: 24px auto 0; color: rgba(22, 36, 31, .86);
}
.hero .cta-row { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; justify-content: center; margin-top: 34px; }
.hero .fineprint { font-size: 14px; color: var(--mtm-forest); margin-top: 18px; }

/* Hero ledger strip */
.ledger-strip {
  display: flex; align-items: stretch; justify-content: center; flex-wrap: wrap;
  margin-top: 54px; background: var(--mtm-bone);
  border: 1px solid rgba(138, 154, 107, .55); border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: 0 1px 0 rgba(22, 36, 31, .06), 0 14px 30px -22px rgba(22, 36, 31, .4);
}
.ledger-strip .cell { flex: 1; min-width: 160px; padding: 26px 30px; text-align: left; }
.ledger-strip .cell + .cell { border-left: 1px solid rgba(138, 154, 107, .45); }
.ledger-strip .cell.keep { background: var(--mtm-forest-100); }
.ledger-strip .k { font-size: 11.5px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase; color: var(--mtm-muted); }
.ledger-strip .cell.keep .k { color: var(--mtm-forest); }
.ledger-strip .v { font-family: var(--font-display); font-size: 40px; color: var(--mtm-ink); margin-top: 6px; }
.ledger-strip .v.cost { color: var(--mtm-ochre-text); }
.ledger-strip .v.keep { color: var(--mtm-forest); font-weight: 600; }

/* Section scaffolding */
.section { padding-block: 74px; }
.section h2 {
  font-family: var(--font-display); font-weight: 500;
  font-size: clamp(30px, 4.2vw, 44px); line-height: 1.08; letter-spacing: -.02em;
  margin-top: 18px;
}
.section.dark { background: var(--mtm-ink); color: var(--mtm-cream-on-ink); }
.section.dark h2 { color: var(--mtm-bone); }
.section.dark h2 em, .section.dark .lede em { font-style: italic; color: var(--mtm-sage-light); }
.section .center { text-align: center; max-width: 60ch; margin-inline: auto; }
.section .center .lede { margin-top: 14px; font-size: 16px; color: rgba(250, 246, 236, .74); }

/* Problem grid */
.problem h2 { max-width: 62ch; }
.problem h2 em { font-style: italic; color: var(--mtm-forest); }
.cost-grid {
  display: grid; grid-template-columns: repeat(5, 1fr); margin-top: 40px;
  border-top: 1px solid rgba(138, 154, 107, .5);
}
.cost-grid .cost { padding: 22px 28px; border-right: 1px solid rgba(138, 154, 107, .35); }
.cost-grid .cost:first-child { padding-left: 0; }
.cost-grid .cost:last-child { padding-right: 0; border-right: none; }
.cost .num { font-family: var(--font-display); font-size: 15px; color: var(--mtm-ochre-text); font-style: italic; }
.cost .h { font-family: var(--font-display); font-size: 19px; margin-top: 8px; text-wrap: balance; }
.cost p { font-size: 14px; margin-top: 7px; color: rgba(22, 36, 31, .78); line-height: 1.45; }

/* Calculator */
.calc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; margin-top: 46px; align-items: start; }
.calc-card { background: var(--mtm-bone); border-radius: var(--radius-lg); padding: 30px; }
.calc-inputs { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.calc-out { background: var(--mtm-bone); border: 1px solid rgba(138, 154, 107, .55); border-radius: var(--radius-lg); padding: 28px 30px; }
.calc-out .top { display: flex; align-items: baseline; justify-content: space-between; padding-bottom: 14px; border-bottom: 1.5px solid rgba(138, 154, 107, .45); }
.calc-out .top .lbl { font-family: var(--font-display); font-size: 21px; color: var(--mtm-ink); }
.calc-out .top .amt { font-family: var(--font-display); font-size: 28px; color: var(--mtm-ink); font-variant-numeric: tabular-nums; }
.calc-out .line { display: flex; align-items: baseline; justify-content: space-between; padding: 9px 0; border-bottom: 1px dotted rgba(138, 154, 107, .5); color: rgba(22, 36, 31, .8); }
.calc-out .line:last-of-type { border-bottom: none; }
.calc-out .line .neg { font-variant-numeric: tabular-nums; color: var(--mtm-ochre-text); font-weight: 600; white-space: nowrap; }
.calc-out .keep { display: flex; align-items: baseline; justify-content: space-between; margin-top: 16px; padding-top: 16px; border-top: 1.5px solid var(--mtm-ink); }
.calc-out .keep .lbl { font-family: var(--font-display); font-size: 18px; color: var(--mtm-ink); }
.calc-out .keep .amt { font-family: var(--font-display); font-size: 34px; font-weight: 600; font-variant-numeric: tabular-nums; }
.calc-out .chip { margin-top: 16px; display: inline-flex; align-items: center; gap: 8px; padding: 7px 14px; border-radius: var(--radius-pill); font-size: 13.5px; font-weight: 600; }
.calc-out .chip .dot { width: 8px; height: 8px; border-radius: 999px; }

/* How-it-works strip (home, dark) */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 38px; margin-top: 50px; }
.step .label { display: block; font-family: var(--font-display); font-size: 17px; color: var(--mtm-ochre); padding-bottom: 14px; margin-bottom: 18px; border-bottom: 1px solid rgba(138, 154, 107, .55); }
.step h3 { font-family: var(--font-display); font-weight: 500; font-size: 25px; color: var(--mtm-bone); line-height: 1.1; }
.step h3 em { font-style: italic; color: var(--mtm-sage-light); }
.step p { margin-top: 12px; font-size: 15.5px; color: rgba(250, 246, 236, .78); line-height: 1.55; }

/* Quote */
.quote { background: var(--mtm-forest); text-align: center; padding-block: 74px; }
.quote blockquote { margin: 0 auto; font-family: var(--font-display); font-weight: 500; font-size: clamp(26px, 4vw, 40px); line-height: 1.2; color: var(--mtm-bone); max-width: 20ch; }
.quote blockquote em { font-style: italic; color: var(--mtm-sage-light); }
.quote .cite { margin-top: 22px; font-size: 12.5px; font-weight: 600; letter-spacing: .14em; text-transform: uppercase; color: var(--mtm-sage-light); }

/* Founding CTA card */
.founding { background: var(--mtm-oat); padding-block: 74px; }
.founding .card {
  background: var(--mtm-bone); border: 1.5px solid var(--mtm-ochre); border-radius: var(--radius-lg);
  padding: 40px; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 28px;
}
.founding .kicker { font-size: 12.5px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; color: var(--mtm-ochre-text); }
.founding h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(26px, 3.5vw, 36px); margin-top: 10px; letter-spacing: -.01em; }
.founding p { margin-top: 12px; font-size: 16px; max-width: 46ch; color: rgba(22, 36, 31, .84); line-height: 1.5; }

/* How-it-works page */
.how-hero { padding-top: 64px; padding-bottom: 20px; }
.how-hero h1 { font-family: var(--font-display); font-weight: 500; font-size: clamp(38px, 6vw, 68px); line-height: 1.06; letter-spacing: -.025em; margin-top: 20px; max-width: 18ch; }
.how-hero h1 em { font-style: italic; color: var(--mtm-forest); }
.how-hero .lede { font-size: clamp(18px, 2.1vw, 21px); line-height: 1.5; max-width: 52ch; margin-top: 20px; color: rgba(22, 36, 31, .86); }
.how-rows { padding-block: 56px; }
.how-rows .inner { max-width: 1140px; margin: 0 auto; padding: 0 28px; }
.how-row { display: grid; grid-template-columns: 120px 1fr; gap: 32px; padding: 36px 0; border-top: 1px solid rgba(138, 154, 107, .5); }
.how-rows .how-row:last-child { border-bottom: 1px solid rgba(138, 154, 107, .5); }
.how-row .rn { font-family: var(--font-display); font-style: italic; font-size: 44px; color: var(--mtm-ochre-text); }
.how-row h3 { font-family: var(--font-display); font-weight: 500; font-size: 28px; }
.how-row p { margin-top: 12px; font-size: 17px; line-height: 1.55; max-width: 60ch; color: rgba(22, 36, 31, .82); }
.how-cta { background: var(--mtm-ink); padding-block: 64px; text-align: center; }
.how-cta .inner { max-width: 920px; margin: 0 auto; padding: 0 28px; }
.how-cta h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(26px, 3.6vw, 38px); color: var(--mtm-bone); line-height: 1.12; }
.how-cta p { margin-top: 14px; font-size: 17px; color: rgba(250, 246, 236, .76); max-width: 48ch; margin-inline: auto; }
.how-cta .cta-row { margin-top: 28px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

/* Apply page */
.apply { padding-top: 60px; padding-bottom: 64px; min-height: 60vh; }
.apply .inner { max-width: 760px; margin: 0 auto; padding: 0 28px; }
.apply h1 { font-family: var(--font-display); font-weight: 500; font-size: clamp(34px, 5vw, 52px); line-height: 1.08; letter-spacing: -.02em; margin-top: 18px; max-width: 18ch; }
.apply h1 em { font-style: italic; color: var(--mtm-forest); }
.apply .lede { font-size: 18px; line-height: 1.5; max-width: 50ch; margin-top: 16px; color: rgba(22, 36, 31, .86); }
.apply-form { background: var(--mtm-bone); border: 1px solid rgba(138, 154, 107, .55); border-radius: var(--radius-lg); padding: 32px; margin-top: 32px; display: flex; flex-direction: column; gap: 18px; }
.apply-form .note { font-size: 13px; color: var(--mtm-muted); text-align: center; margin: 0; }
.apply-success { text-align: center; padding-top: 20px; }
.apply-success .tick { width: 64px; height: 64px; border-radius: 999px; background: var(--mtm-forest-100); display: flex; align-items: center; justify-content: center; margin: 0 auto; }
.apply-success h1 { margin-top: 24px; }
.apply-success p { font-size: 18px; line-height: 1.5; max-width: 44ch; margin: 16px auto 0; color: rgba(22, 36, 31, .86); }
.apply-success .cta-row { margin-top: 30px; display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; overflow: hidden; }

/* Footer */
.site-footer { background: var(--mtm-forest); color: var(--mtm-oat); padding-block: 52px; }
.site-footer .cols { max-width: 1140px; margin: 0 auto; padding: 0 28px; display: flex; justify-content: space-between; gap: 36px; flex-wrap: wrap; align-items: flex-start; }
.site-footer .logo { height: 40px; width: auto; }
.site-footer .word { font-family: var(--font-display); font-size: 18px; color: var(--mtm-bone); margin-top: 16px; }
.site-footer .word em { font-style: italic; color: var(--mtm-sage-light); }
.site-footer .tag { margin-top: 10px; font-size: 14px; color: rgba(241, 234, 219, .88); }
.site-footer h4 { font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--mtm-sage-light); margin: 0 0 14px; }
.site-footer .flink { display: block; background: none; border: none; padding: 0; text-align: left; cursor: pointer; font-family: var(--font-sans); font-size: 15px; color: var(--mtm-oat); margin-bottom: 9px; }
.site-footer .flink:hover { color: var(--mtm-bone); }
.site-footer .legal { max-width: 1140px; margin: 36px auto 0; padding: 20px 28px 0; border-top: 1px solid rgba(241, 234, 219, .25); font-size: 13px; color: rgba(241, 234, 219, .8); }
.site-footer .legal a { text-decoration: none; }

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media (max-width: 900px) {
  .cost-grid { grid-template-columns: 1fr 1fr; row-gap: 28px; }
  .cost-grid .cost { border-right: none; padding-left: 0; padding-right: 28px; }
  .calc-grid { grid-template-columns: 1fr; }
  .nav-links { display: none; }
  .burger { display: inline-flex; }
}
@media (max-width: 760px) {
  .steps { grid-template-columns: 1fr; }
  .how-row { grid-template-columns: 56px 1fr; gap: 18px; }
  .how-row .rn { font-size: 34px; }
}
@media (max-width: 560px) {
  .cost-grid { grid-template-columns: 1fr; }
  .calc-inputs { grid-template-columns: 1fr; }
  .wrap, .site-header .bar { padding-left: 20px; padding-right: 20px; }
}
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { transition: none !important; }
}
