/* ToWhom.ai — stationery aesthetic. */

:root {
  --color-paper:        #faf7f2;
  --color-card:         #ffffff;
  --color-card-sunk:    #f3eee6;
  --color-ink:          #1f1a14;
  --color-ink-muted:    #6b6357;
  --color-ink-faint:    #7a6f5c;
  --color-rule:         #e8e0d2;
  --color-rule-strong:  #c9bda6;
  --color-accent:       #1d3557;
  --color-accent-soft:  #e6ebf2;
  --color-success:      #2d5a3d;
  --color-warning:      #8b5a2b;
  --color-danger:       #8b2c2c;

  --font-display: 'Source Serif 4', 'Newsreader', Georgia, serif;
  --font-body:    'Manrope', 'Public Sans', -apple-system, 'Segoe UI', sans-serif;
  --font-mono:    'JetBrains Mono', 'Fira Code', Consolas, monospace;

  --text-xs:  12px;
  --text-sm:  14px;
  --text-base:16px;
  --text-lg:  18px;
  --text-xl:  22px;
  --text-2xl: 28px;
  --text-3xl: 36px;
  --text-4xl: 48px;
  --text-5xl: 64px;
  --text-6xl: 80px;

  --leading-tight: 1.15;
  --leading-snug:  1.3;
  --leading-normal:1.55;
  --leading-loose: 1.75;

  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 24px;
  --space-6: 32px;
  --space-7: 48px;
  --space-8: 64px;
  --space-9: 96px;
  --space-10:128px;

  --shadow-1: 0 1px 2px rgba(31,26,20,.04), 0 1px 1px rgba(31,26,20,.03);
  --radius-sm: 4px;
  --radius-md: 8px;
  --motion-fast: 120ms;
  --motion-normal: 200ms;
  --ease: cubic-bezier(0.2, 0, 0, 1);

  --measure: 68ch;
  --col-narrow: 720px;
  --col-wide:   1080px;
}

@media (prefers-color-scheme: dark) {
  :root {
    --color-paper:        #1a1814;
    --color-card:         #221f1a;
    --color-card-sunk:    #14120f;
    --color-ink:          #ebe4d4;
    --color-ink-muted:    #9c917e;
    --color-ink-faint:    #948b7c;
    --color-rule:         #2c2820;
    --color-rule-strong:  #4a4337;
    --color-accent:       #a8c1e0;
    --color-accent-soft:  #1f2a3a;
    --color-success:      #7ab38b;
    --color-warning:      #c79566;
    --color-danger:       #d68a8a;
  }
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  * { animation-duration: 0s !important; transition-duration: 0s !important; }
}

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

a {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color var(--motion-fast) var(--ease);
}
a:hover { color: var(--color-ink); }
a:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
  border-radius: var(--radius-sm);
}

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: var(--leading-tight);
  letter-spacing: -0.01em;
  margin: 0;
  color: var(--color-ink);
}

p { margin: 0; }
::selection { background: var(--color-accent-soft); color: var(--color-ink); }

/* ---------- Layout primitives ---------- */
.reading-column {
  max-width: var(--col-narrow);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
.wide-column {
  max-width: var(--col-wide);
  margin: 0 auto;
  padding: 0 var(--space-5);
}
@media (min-width: 768px) {
  .reading-column { padding: 0 var(--space-7); }
  .wide-column    { padding: 0 var(--space-7); }
}

/* ---------- Header / nav ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background-color: var(--color-paper);
  border-bottom: 1px solid var(--color-rule);
}
.site-nav {
  max-width: var(--col-wide);
  margin: 0 auto;
  padding: var(--space-4) var(--space-5);
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-5);
}
@media (min-width: 768px) {
  .site-nav { padding: var(--space-4) var(--space-7); }
}

.wordmark {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: -0.02em;
  color: var(--color-ink);
  text-decoration: none;
}
.wordmark-suffix {
  color: var(--color-ink-faint);
  font-weight: 400;
}

.nav-links {
  display: none;
  gap: var(--space-5);
  align-items: baseline;
}
@media (min-width: 1024px) {
  .nav-links { display: flex; }
}
.nav-links a {
  color: var(--color-ink-muted);
  text-decoration: none;
  font-size: var(--text-sm);
  border-bottom: 1px solid transparent;
  padding-bottom: 2px;
}
.nav-links a:hover {
  color: var(--color-ink);
  border-bottom-color: var(--color-rule-strong);
}
.nav-links a[aria-current="page"] {
  color: var(--color-ink);
  border-bottom-color: var(--color-rule-strong);
}

/* ---------- Section rhythm ---------- */
section {
  padding: var(--space-9) 0;
  border-bottom: 1px solid var(--color-rule);
}
@media (min-width: 768px) {
  section { padding: var(--space-10) 0; }
}
section:last-of-type { border-bottom: none; }

.section-label {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  margin-bottom: var(--space-5);
  letter-spacing: 0.02em;
}
.section-label::before {
  content: "§ ";
  color: var(--color-rule-strong);
}

/* ---------- Footer ---------- */
footer.site-footer {
  padding: var(--space-7) 0;
  border-top: 1px solid var(--color-rule);
}
.footer-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-5);
  justify-content: space-between;
  align-items: baseline;
  font-size: var(--text-sm);
  color: var(--color-ink-muted);
}
.footer-row .footer-links {
  display: flex;
  gap: var(--space-5);
  flex-wrap: wrap;
}
.footer-row a {
  color: var(--color-ink-muted);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.footer-row a:hover {
  color: var(--color-ink);
  border-bottom-color: var(--color-rule-strong);
}
.footer-mono {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
}

/* =============================================================
   Index (landing) — hero, recruiter quotes, principles, story,
   pages of the OS, reflection, FAQ, optional waitlist
   ============================================================= */

#hero {
  padding-top: var(--space-9);
  padding-bottom: var(--space-9);
  border-bottom: 1px solid var(--color-rule);
}
@media (min-width: 768px) {
  #hero {
    padding-top: var(--space-10);
    padding-bottom: var(--space-10);
  }
}
.hero-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  margin-bottom: var(--space-5);
}
.hero-eyebrow::before {
  content: "↳ ";
  color: var(--color-rule-strong);
}

h1.hero-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 7vw, 80px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-5);
}
.hero-title em {
  font-style: italic;
  color: var(--color-ink-muted);
  font-weight: 400;
}
.hero-lede {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: var(--leading-snug);
  color: var(--color-ink-muted);
  max-width: 30em;
  margin-bottom: var(--space-7);
}
.hero-cta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-4) var(--space-6);
  align-items: baseline;
}
.cta-primary {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--color-paper);
  background-color: var(--color-accent);
  padding: var(--space-3) var(--space-5);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-sm);
  text-decoration: none;
  transition: background-color var(--motion-fast) var(--ease);
}
.cta-primary:hover {
  color: var(--color-paper);
  background-color: var(--color-ink);
  border-color: var(--color-ink);
}
.cta-secondary {
  font-size: var(--text-base);
  color: var(--color-ink-muted);
  text-decoration: none;
  border-bottom: 1px solid var(--color-rule-strong);
  padding-bottom: 2px;
}
.cta-secondary:hover { color: var(--color-ink); }

.hero-postmark {
  margin-top: var(--space-9);
  display: flex;
  gap: var(--space-4);
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
}
.hero-postmark .stamp {
  border: 1px solid var(--color-rule-strong);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-sm);
  color: var(--color-ink-muted);
}

/* Recruiter quotes */
.recruiter-quotes {
  display: grid;
  gap: var(--space-7);
}
@media (min-width: 900px) {
  .recruiter-quotes {
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-7);
  }
}
figure.quote {
  margin: 0;
  padding: 0 0 0 var(--space-5);
  border-left: 2px solid var(--color-rule-strong);
}
figure.quote blockquote {
  margin: 0 0 var(--space-4) 0;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
  color: var(--color-ink);
}
figure.quote figcaption {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
}

.quotes-headline {
  font-size: clamp(28px, 4vw, 48px);
  margin-bottom: var(--space-4);
}
.quotes-subhead {
  color: var(--color-ink-muted);
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  max-width: 40em;
  margin-bottom: var(--space-8);
}

/* Principles list (What worked) */
.principles {
  list-style: none;
  padding: 0;
  margin: 0;
  counter-reset: pr;
}
.principles li {
  counter-increment: pr;
  padding: var(--space-6) 0;
  border-bottom: 1px dashed var(--color-rule);
  display: grid;
  grid-template-columns: 3rem 1fr;
  gap: var(--space-5);
  align-items: baseline;
}
.principles li:last-child { border-bottom: none; }
.principles li::before {
  content: counter(pr, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-ink-faint);
}
.principles h3 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  margin-bottom: var(--space-2);
}
.principles p {
  color: var(--color-ink-muted);
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  max-width: 56ch;
}

/* Story / timeline */
.story-headline {
  font-size: clamp(28px, 4vw, 48px);
  margin-bottom: var(--space-4);
}
.story-lede {
  color: var(--color-ink-muted);
  font-size: var(--text-lg);
  line-height: var(--leading-normal);
  max-width: 40em;
  margin-bottom: var(--space-8);
}
.timeline {
  border-left: 1px solid var(--color-rule-strong);
  padding-left: var(--space-6);
  display: grid;
  gap: var(--space-7);
}
.timeline-entry { position: relative; }
.timeline-entry::before {
  content: "";
  position: absolute;
  left: calc(var(--space-6) * -1 - 5px);
  top: 0.7em;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--color-paper);
  border: 1px solid var(--color-rule-strong);
}
.timeline-entry.is-key::before {
  background: var(--color-accent);
  border-color: var(--color-accent);
}
.timeline-entry p {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  line-height: var(--leading-snug);
  color: var(--color-ink);
  max-width: 32em;
}
.timeline-entry .small {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink-muted);
  margin-top: var(--space-2);
}

.result-card {
  margin-top: var(--space-5);
  padding: var(--space-6);
  background: var(--color-card-sunk);
  border: 1px solid var(--color-rule);
  border-radius: var(--radius-md);
  max-width: 36em;
}
.result-card .stat-line {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-ink-faint);
  margin-bottom: var(--space-3);
  letter-spacing: 0.02em;
}
.result-card .stat-headline {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: var(--leading-snug);
  color: var(--color-ink);
  margin-bottom: var(--space-3);
}
.result-card .stat-foot {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-ink-muted);
}

/* Pages of the OS */
.pages {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-rule);
}
.page {
  padding: var(--space-7) 0;
  border-bottom: 1px solid var(--color-rule);
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}
@media (min-width: 768px) {
  .page {
    grid-template-columns: 220px 1fr;
    gap: var(--space-7);
    padding: var(--space-8) 0;
  }
}
.page-index {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-ink-faint);
  letter-spacing: 0.02em;
}
.page-index .num {
  color: var(--color-ink);
  font-weight: 500;
}
.page h3 {
  font-family: var(--font-display);
  font-size: var(--text-3xl);
  font-weight: 500;
  margin-bottom: var(--space-3);
  line-height: var(--leading-tight);
}
.page p.intro {
  font-size: var(--text-lg);
  color: var(--color-ink-muted);
  line-height: var(--leading-normal);
  max-width: 48ch;
  margin-bottom: var(--space-5);
}
.page ul.spec {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: var(--space-2);
}
.page ul.spec li {
  font-family: var(--font-body);
  color: var(--color-ink);
  font-size: var(--text-base);
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-3);
  align-items: baseline;
}
.page ul.spec li::before {
  content: "—";
  color: var(--color-rule-strong);
  font-family: var(--font-mono);
}

/* Reflection / sunk-paper callout */
.reflection {
  background: var(--color-card-sunk);
  border-top: 1px solid var(--color-rule);
  border-bottom: 1px solid var(--color-rule);
}
.reflection .reading-column { padding-top: var(--space-9); padding-bottom: var(--space-9); }
.reflection p {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  line-height: var(--leading-snug);
  color: var(--color-ink);
  max-width: 32em;
}
.reflection p + p { margin-top: var(--space-5); }
.reflection .sign {
  margin-top: var(--space-7);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-ink-faint);
}
.reflection .sign::before { content: "— "; }

/* FAQ */
.faq-list {
  display: grid;
  gap: 0;
  border-top: 1px solid var(--color-rule);
}
.faq-item {
  border-bottom: 1px solid var(--color-rule);
  padding: var(--space-5) 0;
}
.faq-item summary {
  cursor: pointer;
  list-style: none;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--color-ink);
  display: flex;
  justify-content: space-between;
  gap: var(--space-5);
  align-items: baseline;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-family: var(--font-mono);
  font-size: var(--text-2xl);
  color: var(--color-ink-faint);
  transition: transform var(--motion-normal) var(--ease);
}
.faq-item[open] summary::after { content: "−"; }
.faq-item .answer {
  margin-top: var(--space-4);
  max-width: 56ch;
  color: var(--color-ink-muted);
  font-size: var(--text-base);
  line-height: var(--leading-normal);
}

/* =============================================================
   Legal pages (impressum, privacy) — long-form prose
   ============================================================= */

.legal-header {
  padding-top: var(--space-8);
  padding-bottom: var(--space-7);
  border-bottom: 1px solid var(--color-rule);
}
.legal-body {
  padding-top: var(--space-8);
  padding-bottom: var(--space-9);
}
.legal-breadcrumb {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  margin-bottom: var(--space-5);
  display: flex;
  gap: var(--space-2);
  align-items: baseline;
  flex-wrap: wrap;
}
.legal-breadcrumb a {
  color: var(--color-ink-muted);
  text-decoration: none;
  border-bottom: 1px solid transparent;
}
.legal-breadcrumb a:hover {
  color: var(--color-ink);
  border-bottom-color: var(--color-rule-strong);
}
.legal-breadcrumb .sep {
  color: var(--color-rule-strong);
}
.legal-breadcrumb .here {
  color: var(--color-ink);
}

.legal-title {
  font-family: var(--font-display);
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 500;
  line-height: 1.05;
  letter-spacing: -0.02em;
  margin-bottom: var(--space-3);
}
.legal-subtitle {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(18px, 1.8vw, 22px);
  line-height: var(--leading-snug);
  color: var(--color-ink-muted);
  max-width: 40em;
}
.legal-meta {
  margin-top: var(--space-5);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
}

article.prose {
  max-width: var(--measure);
  font-size: var(--text-base);
  line-height: var(--leading-loose);
  color: var(--color-ink);
}
article.prose h2 {
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  letter-spacing: -0.01em;
  margin-top: var(--space-7);
  margin-bottom: var(--space-4);
  line-height: var(--leading-tight);
}
article.prose h2:first-child { margin-top: 0; }
article.prose h3 {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  margin-top: var(--space-6);
  margin-bottom: var(--space-3);
}
article.prose p {
  margin-bottom: var(--space-4);
  color: var(--color-ink);
}
article.prose p:last-child { margin-bottom: 0; }
article.prose ul, article.prose ol {
  margin: 0 0 var(--space-5) 0;
  padding-left: var(--space-5);
}
article.prose li {
  margin-bottom: var(--space-2);
  line-height: var(--leading-normal);
}
article.prose ul li::marker { color: var(--color-rule-strong); }
article.prose ol li::marker { color: var(--color-ink-faint); font-family: var(--font-mono); }
article.prose strong {
  font-weight: 600;
  color: var(--color-ink);
}
article.prose em {
  font-style: italic;
  color: var(--color-ink-muted);
}
article.prose code {
  font-family: var(--font-mono);
  font-size: 0.95em;
  background: var(--color-card-sunk);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
}
article.prose a {
  color: var(--color-accent);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  word-break: break-word;
}
article.prose hr {
  border: 0;
  border-top: 1px solid var(--color-rule);
  margin: var(--space-8) 0;
}
article.prose dl {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-1) var(--space-5);
  margin: 0 0 var(--space-4) 0;
}
@media (min-width: 600px) {
  article.prose dl {
    grid-template-columns: 12em 1fr;
  }
}
article.prose dt {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  letter-spacing: 0.02em;
  align-self: baseline;
  padding-top: 0.4em;
}
article.prose dd {
  margin: 0 0 var(--space-3) 0;
  color: var(--color-ink);
}
