/* ============================================================================
   Teryli Mobile — Design direction styles
   ============================================================================ */

/* NOTE: Inter + Cormorant Garamond are already loaded by styles.css (always
   present on the page), so this stylesheet no longer re-imports them.
   The token block below is scoped to .mob (not :root) so it CANNOT override
   the desktop site's identically-named variables. */

.mob {
  --navy:        #0F2538;
  --navy-deep:   #0A1B2A;
  --navy-soft:   #16314A;
  --leaf:        #67B156;
  --leaf-strong: #4E9B41;
  --leaf-soft:   #A8D08D;
  --cream-warm:  #F7F3EC;
  --cream-soft:  #FBF9F5;
  --cream-deep:  #EFE9DC;
  --paper:       #FFFFFF;
  --ink:         #0F2538;
  --ink-muted:   #5A6B7A;
  --ink-subtle:  #8895A2;
  --ink-on-navy: #E8E2D4;
  --ink-on-navy-muted: rgba(232, 226, 212, 0.62);
  --hair-cream:  rgba(15, 37, 56, 0.10);
  --hair-navy:   rgba(232, 226, 212, 0.12);
  --amber-ink:   #94591B;
  --amber-bg:    rgba(193, 131, 50, 0.10);
  --danger-ink:  #983D34;
  --f-serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --f-sans:  "Inter", system-ui, -apple-system, sans-serif;
}

/* ============================================================================
   Mobile screen scaffold (artboards render at 360/390/430/768)
   ============================================================================ */
.mob {
  font-family: var(--f-sans);
  background: var(--cream-warm);
  color: var(--ink);
  position: relative;
  overflow: hidden;
  width: 100%;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01" on, "cv11" on;
}
.mob *, .mob *::before, .mob *::after { box-sizing: border-box; }
.mob h1, .mob h2, .mob h3, .mob h4, .mob h5, .mob p, .mob ul, .mob ol { margin: 0; padding: 0; }
.mob ul, .mob ol { list-style: none; }
.mob a { color: inherit; text-decoration: none; }
.mob img { display: block; max-width: 100%; }

/* iOS status bar hint */
.mob-status {
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 22px 0 28px;
  font: 600 14px/1 "Inter", sans-serif;
  color: var(--navy);
  letter-spacing: -0.01em;
  position: relative;
  z-index: 2;
}
.mob-status .right { display: flex; align-items: center; gap: 5px; }
.mob-status .right svg { display: block; }

/* ============================================================================
   Mobile header
   ============================================================================ */
.m-nav {
  height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 20px;
  background: var(--cream-warm);
  border-bottom: 1px solid transparent;
}
.m-nav.scrolled { border-bottom-color: var(--hair-cream); }
.m-nav .brand img { height: 22px; width: auto; }
.m-nav .cta {
  font: 500 12.5px/1 var(--f-sans);
  color: var(--cream-soft);
  background: var(--navy);
  padding: 9px 14px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.m-nav .menu {
  width: 36px; height: 36px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  border: 1px solid var(--hair-cream);
  color: var(--navy);
}

/* Eyebrow */
.m-eyebrow {
  font: 500 10.5px/1.4 var(--f-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-muted);
  display: inline-flex;
  align-items: center;
  gap: 9px;
}
.m-eyebrow::before {
  content: "";
  width: 16px; height: 1px;
  background: currentColor;
  opacity: 0.55;
}
.section-navy .m-eyebrow { color: var(--ink-on-navy-muted); }

/* ============================================================================
   Mobile hero
   ============================================================================ */
.m-hero {
  padding: 20px 24px 36px;
  background: var(--cream-warm);
  position: relative;
}
.m-hero .h1 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 42px;
  line-height: 1.02;
  letter-spacing: -0.012em;
  color: var(--navy);
  margin: 14px 0 18px;
  text-wrap: balance;
}
.m-hero .h1 em {
  font-style: italic;
  font-weight: 500;
}
.m-hero .sub {
  font: 400 15.5px/1.5 var(--f-sans);
  color: var(--ink-muted);
  margin-bottom: 24px;
  text-wrap: pretty;
}
.m-cta-block {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.m-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 52px;
  padding: 0 22px;
  border-radius: 999px;
  font: 500 14.5px/1 var(--f-sans);
  letter-spacing: 0.005em;
  transition: transform 200ms ease;
}
.m-btn-primary {
  background: var(--navy);
  color: var(--cream-soft);
  box-shadow: 0 1px 2px rgba(15,37,56,0.08), 0 10px 24px rgba(15,37,56,0.10);
}
.m-btn-secondary {
  background: transparent;
  color: var(--navy);
  border: 1px solid var(--hair-cream);
}
.m-meta {
  margin-top: 14px;
  font: 400 12.5px/1.5 var(--f-sans);
  color: var(--ink-subtle);
  font-style: italic;
  text-align: center;
}

/* ============================================================================
   Product peek — phone-native panel
   ============================================================================ */
.m-peek {
  margin: 24px 0 0;
  background: var(--paper);
  border: 1px solid var(--hair-cream);
  border-radius: 18px;
  box-shadow: 0 2px 6px rgba(15,37,56,0.04), 0 18px 44px rgba(15,37,56,0.08);
  overflow: hidden;
}
.m-peek-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid var(--hair-cream);
}
.m-peek-head .crumbs {
  font: 500 11.5px/1 var(--f-sans);
  color: var(--ink-subtle);
}
.m-peek-head .crumbs strong {
  color: var(--ink);
  font-weight: 600;
}
.m-peek-head .live {
  font: 500 10px/1 var(--f-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--leaf-strong);
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.m-peek-head .live::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--leaf);
}

.m-chips {
  display: flex;
  gap: 6px;
  padding: 12px 16px;
  overflow-x: auto;
  border-bottom: 1px solid var(--hair-cream);
  scrollbar-width: none;
}
.m-chips::-webkit-scrollbar { display: none; }
.m-chip {
  flex: 0 0 auto;
  font: 500 11.5px/1 var(--f-sans);
  padding: 7px 11px;
  border-radius: 999px;
  background: var(--paper);
  border: 1px solid var(--hair-cream);
  color: var(--ink-muted);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.m-chip.is-active {
  background: var(--navy);
  color: var(--cream-soft);
  border-color: var(--navy);
}
.m-chip.is-warn {
  color: var(--amber-ink);
  background: var(--amber-bg);
  border-color: rgba(193,131,50,0.18);
}
.m-chip .dot {
  width: 5px; height: 5px; border-radius: 50%; background: currentColor;
}

.m-row {
  display: grid;
  grid-template-columns: 12px 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--hair-cream);
}
.m-row:last-child { border-bottom: 0; }
.m-row .flag {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--leaf);
}
.m-row .flag.warn { background: #C18332; }
.m-row .flag.danger { background: #C8453A; }
.m-row .name {
  font: 600 14px/1.2 var(--f-sans);
  color: var(--navy);
}
.m-row .name small {
  display: block;
  font: 400 11.5px/1.4 var(--f-sans);
  color: var(--ink-subtle);
  margin-top: 2px;
  font-weight: 400;
}
.m-row .pill {
  font: 500 10.5px/1.3 var(--f-sans);
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(103,177,86,0.12);
  color: var(--leaf-strong);
  white-space: nowrap;
}
.m-row .pill.amber { background: var(--amber-bg); color: var(--amber-ink); }
.m-row .pill.danger { background: rgba(200,69,58,0.10); color: var(--danger-ink); }
.m-row .pill.muted { background: rgba(15,37,56,0.06); color: var(--ink-muted); }
.m-row .readiness {
  margin-top: 8px;
  display: flex;
  align-items: center;
  gap: 8px;
  grid-column: 2 / -1;
}
.m-row .bar {
  flex: 1;
  height: 3px;
  border-radius: 999px;
  background: rgba(15,37,56,0.08);
  overflow: hidden;
}
.m-row .bar > i {
  display: block;
  height: 100%;
  background: var(--leaf);
  border-radius: 999px;
}
.m-row .bar.warn > i { background: #C18332; }
.m-row .bar.danger > i { background: #C8453A; }
.m-row .ready-meta {
  font: 500 11px/1 var(--f-sans);
  color: var(--ink-subtle);
  letter-spacing: 0.02em;
}

/* ============================================================================
   Section: Problem
   ============================================================================ */
.m-section {
  padding: 56px 24px;
}
.m-section.cream-soft { background: var(--cream-soft); }
.m-section.navy { background: var(--navy); color: var(--ink-on-navy); }
.m-section.navy h1, .m-section.navy h2, .m-section.navy h3, .m-section.navy h4 {
  color: var(--cream-soft);
}

.m-h-section {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 32px;
  line-height: 1.08;
  letter-spacing: -0.005em;
  color: var(--navy);
  margin: 14px 0 0;
  text-wrap: pretty;
}
.m-section.navy .m-h-section { color: var(--cream-soft); }
.m-lede {
  margin-top: 14px;
  font: 400 15px/1.6 var(--f-sans);
  color: var(--ink-muted);
}
.m-section.navy .m-lede { color: var(--ink-on-navy-muted); }

.m-pullquote {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.22;
  letter-spacing: -0.003em;
  color: var(--navy);
  margin: 18px 0 28px;
  text-wrap: pretty;
}
.m-pullquote em {
  font-style: italic;
  color: var(--leaf-strong);
  font-weight: 500;
}

/* Problem list */
.m-prob {
  list-style: none;
  border-top: 1px solid var(--hair-cream);
  margin-top: 22px;
}
.m-prob li {
  display: grid;
  grid-template-columns: 24px 1fr;
  gap: 12px;
  padding: 20px 0;
  border-bottom: 1px solid var(--hair-cream);
  align-items: baseline;
}
.m-prob .n {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 16px;
  color: var(--leaf-strong);
}
.m-prob .t {
  font: 500 15px/1.45 var(--f-sans);
  color: var(--navy);
}
.m-prob .d {
  font: 400 13.5px/1.55 var(--f-sans);
  color: var(--ink-muted);
  margin-top: 4px;
}

/* Helps — navy stack */
.m-helps-stack {
  margin-top: 28px;
  border-top: 1px solid var(--hair-navy);
}
.m-help {
  padding: 24px 0;
  border-bottom: 1px solid var(--hair-navy);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.m-help .num {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 15px;
  color: var(--leaf-soft);
}
.m-help h3 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 22px;
  line-height: 1.18;
  color: var(--cream-soft);
}
.m-help .rule {
  width: 22px;
  height: 1px;
  background: var(--leaf-soft);
  opacity: 0.55;
}
.m-help p {
  font: 400 13.5px/1.55 var(--f-sans);
  color: var(--ink-on-navy-muted);
}

/* ============================================================================
   Product modules — mobile-native
   ============================================================================ */
.m-mod {
  background: var(--paper);
  border: 1px solid var(--hair-cream);
  border-radius: 18px;
  overflow: hidden;
  margin-top: 16px;
  box-shadow: 0 1px 2px rgba(15,37,56,0.03), 0 10px 28px rgba(15,37,56,0.06);
}
.m-mod-cap {
  padding: 12px 16px 0;
}
.m-mod-cap .num {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 13px;
  color: var(--leaf-strong);
}
.m-mod-cap .ttl {
  font: 500 16px/1.3 var(--f-sans);
  color: var(--navy);
  margin-top: 2px;
}
.m-mod-cap .blurb {
  font: 400 13px/1.5 var(--f-sans);
  color: var(--ink-muted);
  margin-top: 4px;
}

/* Mod 1 — Transition risk */
.m-risk-head {
  padding: 14px 16px 12px;
  border-top: 1px solid var(--hair-cream);
  margin-top: 14px;
  background: var(--cream-soft);
}
.m-risk-head .who {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 20px;
  color: var(--navy);
  line-height: 1.1;
}
.m-risk-head .meta {
  font: 400 12px/1.4 var(--f-sans);
  color: var(--ink-subtle);
  margin-top: 4px;
}
.m-risk-head .days {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--amber-bg);
  color: var(--amber-ink);
  font: 500 11.5px/1 var(--f-sans);
}
.m-risk-head .days::before {
  content: "";
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
}
.m-risk-list {
  padding: 6px 16px 14px;
}
.m-risk-list .eye {
  font: 500 10px/1 var(--f-sans);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-subtle);
  padding: 14px 0 10px;
}
.m-risk-list li {
  display: grid;
  grid-template-columns: 14px 1fr auto;
  gap: 10px;
  align-items: baseline;
  padding: 10px 0;
  border-top: 1px solid var(--hair-cream);
  font: 400 13.5px/1.4 var(--f-sans);
  color: var(--navy);
}
.m-risk-list li .marker {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(15,37,56,0.18);
  margin-top: 5px;
}
.m-risk-list li.warn .marker { background: #C18332; }
.m-risk-list li .when {
  font: 400 11.5px/1.2 var(--f-sans);
  color: var(--ink-subtle);
}

/* Mod 2 — Program directory */
.m-dir {
  padding: 6px 16px 14px;
}
.m-dir-card {
  padding: 14px 0;
  border-top: 1px solid var(--hair-cream);
  display: grid;
  grid-template-columns: 36px 1fr auto;
  gap: 12px;
  align-items: center;
}
.m-dir-card:first-of-type { border-top: 0; }
.m-dir-card .mark {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--cream-warm);
  color: var(--navy);
  font: 600 11px/1 var(--f-sans);
  letter-spacing: 0.03em;
  display: grid;
  place-items: center;
  border: 1px solid var(--hair-cream);
}
.m-dir-card .name {
  font: 600 14px/1.3 var(--f-sans);
  color: var(--navy);
}
.m-dir-card .meta {
  font: 400 11.5px/1.4 var(--f-sans);
  color: var(--ink-subtle);
  margin-top: 2px;
}
.m-dir-card .fit {
  font: 500 11px/1 var(--f-sans);
  color: var(--leaf-strong);
  background: rgba(103,177,86,0.10);
  padding: 5px 9px;
  border-radius: 999px;
  white-space: nowrap;
}
.m-dir-card .fit.muted { color: var(--ink-muted); background: rgba(15,37,56,0.06); }

/* Mod 3 — Outreach timeline */
.m-tl {
  padding: 8px 16px 16px;
}
.m-tl-item {
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 12px;
  padding: 14px 0;
  position: relative;
}
.m-tl-item::before {
  content: "";
  position: absolute;
  left: 8px;
  top: 24px;
  bottom: -14px;
  width: 1px;
  background: var(--hair-cream);
}
.m-tl-item:last-child::before { display: none; }
.m-tl-item .dot {
  width: 9px; height: 9px;
  border-radius: 50%;
  background: var(--leaf);
  margin-top: 6px;
  margin-left: 4px;
  position: relative;
  z-index: 1;
  border: 2px solid var(--paper);
  box-shadow: 0 0 0 1px var(--hair-cream);
}
.m-tl-item .dot.muted { background: var(--ink-subtle); }
.m-tl-item .dot.danger { background: #C8453A; }
.m-tl-item .when {
  font: 400 11px/1 var(--f-sans);
  color: var(--ink-subtle);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.m-tl-item .who {
  font: 600 13.5px/1.3 var(--f-sans);
  color: var(--navy);
}
.m-tl-item .body {
  font: 400 13px/1.5 var(--f-sans);
  color: var(--ink-muted);
  margin-top: 3px;
}
.m-tl-item .pill {
  display: inline-flex;
  font: 500 10.5px/1.3 var(--f-sans);
  padding: 3px 8px;
  border-radius: 999px;
  background: rgba(103,177,86,0.12);
  color: var(--leaf-strong);
  margin-top: 6px;
}
.m-tl-item .pill.amber { background: var(--amber-bg); color: var(--amber-ink); }
.m-tl-item .pill.danger { background: rgba(200,69,58,0.10); color: var(--danger-ink); }

/* Founder note — break the rhythm */
.m-founder {
  background: var(--cream-soft);
  padding: 64px 28px;
  position: relative;
}
.m-founder .leaf {
  width: 22px;
  opacity: 0.55;
  margin: 0 auto 24px;
  display: block;
}
.m-founder blockquote {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 26px;
  line-height: 1.25;
  letter-spacing: -0.002em;
  color: var(--navy);
  text-wrap: pretty;
  text-align: center;
}
.m-founder blockquote em {
  font-style: italic;
  color: var(--leaf-strong);
}
.m-founder .sig {
  margin-top: 28px;
  text-align: center;
  font: 400 12.5px/1.5 var(--f-sans);
  color: var(--ink-subtle);
}
.m-founder .sig strong {
  display: block;
  font-weight: 600;
  color: var(--navy);
  font-size: 13.5px;
  letter-spacing: 0.005em;
}

/* What Teryli is / is not */
.m-isnot {
  margin-top: 28px;
  display: grid;
  gap: 18px;
}
.m-isnot-col {
  padding: 22px;
  border-radius: 18px;
  border: 1px solid var(--hair-cream);
  background: var(--paper);
}
.m-isnot-col.is { background: var(--cream-soft); }
.m-isnot-col h3 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 20px;
  color: var(--navy);
  margin-bottom: 12px;
}
.m-isnot-col ul li {
  display: grid;
  grid-template-columns: 16px 1fr;
  gap: 10px;
  align-items: baseline;
  padding: 10px 0;
  border-top: 1px solid var(--hair-cream);
  font: 400 13.5px/1.45 var(--f-sans);
  color: var(--navy);
}
.m-isnot-col ul li:first-child { border-top: 0; }
.m-isnot-col svg { width: 12px; height: 12px; margin-top: 4px; }
.m-isnot-col.not svg { color: var(--ink-subtle); }
.m-isnot-col.is svg { color: var(--leaf-strong); }

/* Why it's different — compact navy */
.m-different {
  margin-top: 22px;
  display: grid;
  gap: 0;
  border-top: 1px solid var(--hair-navy);
}
.m-different .dp {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: 14px;
  padding: 22px 0;
  border-bottom: 1px solid var(--hair-navy);
}
.m-different .dp .lbl {
  font-family: var(--f-serif);
  font-style: italic;
  font-weight: 500;
  font-size: 15px;
  color: var(--leaf-soft);
}
.m-different .dp h4 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 19px;
  color: var(--cream-soft);
  margin-bottom: 4px;
  line-height: 1.18;
}
.m-different .dp p {
  font: 400 13px/1.55 var(--f-sans);
  color: var(--ink-on-navy-muted);
}

/* CTA card */
.m-cta {
  margin-top: 24px;
  background: var(--paper);
  border: 1px solid var(--hair-cream);
  border-radius: 18px;
  padding: 28px 22px 22px;
  position: relative;
  overflow: hidden;
}
.m-cta .leaf-wm {
  position: absolute;
  top: -20px; right: -24px;
  width: 130px;
  opacity: 0.07;
  pointer-events: none;
}
.m-cta .label {
  font-family: var(--f-serif);
  font-style: italic;
  font-size: 14px;
  color: var(--leaf-strong);
}
.m-cta h2 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 28px;
  line-height: 1.1;
  color: var(--navy);
  margin: 6px 0 12px;
  letter-spacing: -0.005em;
}
.m-cta p {
  font: 400 14.5px/1.55 var(--f-sans);
  color: var(--ink-muted);
  margin-bottom: 22px;
}
.m-contact-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 18px;
}
.m-contact {
  display: grid;
  grid-template-columns: 40px 1fr 14px;
  align-items: center;
  gap: 14px;
  padding: 14px;
  border: 1px solid var(--hair-cream);
  border-radius: 14px;
  background: var(--cream-soft);
  transition: background 200ms ease;
}
.m-contact.primary {
  background: var(--navy);
  color: var(--cream-soft);
  border-color: var(--navy);
}
.m-contact.primary .ic {
  background: rgba(255,255,255,0.10);
  color: var(--cream-soft);
}
.m-contact .ic {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: var(--cream-warm);
  color: var(--navy);
  display: grid;
  place-items: center;
}
.m-contact .lbl {
  font: 500 11px/1 var(--f-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-subtle);
  margin-bottom: 4px;
}
.m-contact.primary .lbl { color: rgba(232,226,212,0.7); }
.m-contact .val {
  font: 500 14.5px/1.3 var(--f-sans);
  color: var(--navy);
}
.m-contact.primary .val { color: var(--cream-soft); }
.m-contact .arr { color: var(--ink-subtle); }
.m-contact.primary .arr { color: var(--leaf-soft); }
.m-cta .signoff {
  margin-top: 22px;
  padding-top: 18px;
  border-top: 1px solid var(--hair-cream);
  font: 400 12px/1.5 var(--f-sans);
  color: var(--ink-subtle);
  text-align: center;
}
.m-cta .signoff strong { color: var(--navy); font-weight: 600; }

/* Footer */
.m-foot {
  background: var(--navy);
  color: var(--ink-on-navy);
  padding: 40px 24px 28px;
}
.m-foot .brand img { height: 22px; }
.m-foot .blurb {
  font: 400 13px/1.55 var(--f-sans);
  color: var(--ink-on-navy-muted);
  margin: 16px 0 28px;
  max-width: 30ch;
}
.m-foot .cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 16px;
  border-top: 1px solid var(--hair-navy);
  padding-top: 24px;
}
.m-foot .col h5 {
  font: 500 10.5px/1 var(--f-sans);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-on-navy-muted);
  margin-bottom: 12px;
}
.m-foot .col li {
  font: 400 13px/1 var(--f-sans);
  color: var(--cream-soft);
  padding: 7px 0;
}
.m-foot .baseline {
  margin-top: 28px;
  padding-top: 20px;
  border-top: 1px solid var(--hair-navy);
  display: flex;
  justify-content: space-between;
  font: 400 11px/1 var(--f-sans);
  color: var(--ink-on-navy-muted);
}
.m-foot .baseline a { padding: 0 6px; }

/* Leaf rule */
.m-leaf-rule {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--leaf);
  margin: 36px 0;
}
.m-leaf-rule::before, .m-leaf-rule::after {
  content: "";
  flex: 1;
  height: 1px;
  background: currentColor;
  opacity: 0.32;
}

/* ============================================================================
   Annotation pins (on artboards) — design-canvas tooltips
   ============================================================================ */
.anno {
  position: absolute;
  display: flex;
  align-items: center;
  gap: 8px;
  pointer-events: none;
  z-index: 5;
}
.anno-pin {
  width: 22px; height: 22px;
  border-radius: 999px;
  background: #fef4a8;
  color: #5a4a2a;
  font: 600 11px/1 var(--f-sans);
  display: grid;
  place-items: center;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18), 0 0 0 2px rgba(255,255,255,0.6);
}
.anno-text {
  background: #fef4a8;
  color: #5a4a2a;
  font: 500 11px/1.35 var(--f-sans);
  padding: 6px 10px;
  border-radius: 6px;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(0,0,0,0.12);
}

/* ============================================================================
   Spec cards (for the type / spacing / dev notes section)
   ============================================================================ */
.spec {
  font-family: var(--f-sans);
  background: var(--paper);
  color: var(--ink);
  padding: 36px 32px;
  width: 100%;
  position: relative;
  overflow: hidden;
}
.spec h2 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 28px;
  letter-spacing: -0.005em;
  color: var(--navy);
  margin: 8px 0 22px;
  line-height: 1.1;
}
.spec .kicker {
  font: 500 10px/1 var(--f-sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-subtle);
}
.spec p { font: 400 13.5px/1.55 var(--f-sans); color: var(--ink-muted); margin: 0; }

/* Type scale spec */
.type-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 14px;
  padding: 14px 0;
  border-top: 1px solid var(--hair-cream);
  align-items: baseline;
}
.type-row .meta {
  font: 500 11px/1.3 var(--f-sans);
  color: var(--ink-subtle);
  letter-spacing: 0.01em;
}
.type-row .meta b { display: block; color: var(--navy); font-weight: 600; font-size: 12px; margin-bottom: 3px; }
.type-row .sample { color: var(--navy); }
.type-row .sample.serif { font-family: var(--f-serif); font-weight: 500; }
.type-row .sample em { font-style: italic; }

/* Spacing chart */
.space-row {
  display: grid;
  grid-template-columns: 56px 1fr 70px;
  gap: 14px;
  padding: 10px 0;
  align-items: center;
  border-top: 1px solid var(--hair-cream);
}
.space-row b { font: 600 12px/1 var(--f-sans); color: var(--navy); }
.space-row .bar {
  height: 8px;
  background: var(--navy);
  border-radius: 2px;
}
.space-row .px { font: 500 11px/1 var(--f-sans); color: var(--ink-subtle); text-align: right; }

/* Palette swatches */
.swatch-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.swatch {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--hair-cream);
}
.swatch .chip {
  height: 70px;
}
.swatch .meta {
  padding: 10px 12px;
  background: var(--paper);
}
.swatch .meta b {
  display: block;
  font: 600 12.5px/1.2 var(--f-sans);
  color: var(--navy);
}
.swatch .meta small {
  display: block;
  font: 400 11px/1.4 var(--f-sans);
  color: var(--ink-subtle);
  margin-top: 2px;
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
}

/* Do / Don't */
.dd {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 8px;
}
.dd .col {
  padding: 16px;
  border-radius: 12px;
  border: 1px solid var(--hair-cream);
}
.dd .col.do { background: rgba(103,177,86,0.08); border-color: rgba(103,177,86,0.18); }
.dd .col.dont { background: rgba(200,69,58,0.05); border-color: rgba(200,69,58,0.18); }
.dd .col h4 {
  font: 600 11px/1 var(--f-sans);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 10px;
}
.dd .col.do h4 { color: var(--leaf-strong); }
.dd .col.dont h4 { color: var(--danger-ink); }
.dd .col ul li {
  font: 400 12.5px/1.5 var(--f-sans);
  color: var(--ink);
  padding: 6px 0;
  display: grid;
  grid-template-columns: 14px 1fr;
  gap: 8px;
  align-items: baseline;
}
.dd .col ul li::before {
  content: "";
  width: 5px; height: 5px;
  border-radius: 50%;
  background: currentColor;
  opacity: 0.45;
  margin-top: 6px;
  display: block;
}

/* Dev notes */
.dev-notes h3 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 18px;
  color: var(--navy);
  margin: 18px 0 8px;
}
.dev-notes p {
  font: 400 13px/1.55 var(--f-sans);
  color: var(--ink-muted);
  margin-bottom: 6px;
}
.dev-notes code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 12px;
  background: var(--cream-warm);
  padding: 1px 6px;
  border-radius: 4px;
  color: var(--navy);
}
.dev-notes ul li {
  font: 400 13px/1.5 var(--f-sans);
  color: var(--ink);
  padding: 4px 0 4px 14px;
  position: relative;
}
.dev-notes ul li::before {
  content: "";
  position: absolute;
  left: 0; top: 11px;
  width: 5px; height: 1px;
  background: var(--leaf);
}

/* Direction cover card */
.cover {
  background: var(--cream-warm);
  width: 100%;
  padding: 56px 44px;
  position: relative;
  overflow: hidden;
}
.cover .kicker {
  font: 500 11px/1 var(--f-sans);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--ink-subtle);
}
.cover h1 {
  font-family: var(--f-serif);
  font-weight: 500;
  font-size: 60px;
  line-height: 1.02;
  letter-spacing: -0.014em;
  color: var(--navy);
  margin: 18px 0 26px;
  text-wrap: balance;
}
.cover h1 em { font-style: italic; color: var(--leaf-strong); font-weight: 500; }
.cover p {
  font: 400 16px/1.55 var(--f-sans);
  color: var(--ink-muted);
  max-width: 46ch;
}
.cover .leaf {
  position: absolute;
  right: -40px; bottom: -50px;
  width: 280px;
  opacity: 0.08;
}
.cover .meta {
  margin-top: 56px;
  padding-top: 28px;
  border-top: 1px solid var(--hair-cream);
  display: flex;
  justify-content: space-between;
  font: 400 12px/1.4 var(--f-sans);
  color: var(--ink-subtle);
}
.cover .meta b { color: var(--navy); font-weight: 600; }
