:root {
  --mint: #c5ecd6;
  --cream: #faf6ef;
  --charcoal: #0e1f17;
  --persimmon: #ff7a45;
  --muted-charcoal: #1c3329;
  --muted-gray: #4a4a4a;
  --label-gray: #5a6b62;
  --footer-text: #8aa698;
  --rule: #e6dfd1;
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  background: var(--cream);
  color: var(--charcoal);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.55;
}
a { color: var(--charcoal); }
a:hover { color: var(--persimmon); }

/* WORDMARK (matches index.html) */
.wordmark {
  font-weight: 700;
  letter-spacing: -0.03em;
  display: inline-flex;
  align-items: center;
  gap: 2px;
  line-height: 1;
  text-decoration: none;
}
.wordmark .dot {
  width: 0.21em;
  height: 0.21em;
  background: var(--persimmon);
  border-radius: 50%;
  display: inline-block;
  transform: translateY(0.32em);
}

/* NAV */
.legal-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 32px 56px;
  background: var(--cream);
}
.legal-nav .wordmark { font-size: 22px; color: var(--charcoal); }
.legal-nav-cta {
  font-size: 14px;
  font-weight: 500;
  padding: 9px 18px;
  border-radius: 999px;
  background: var(--charcoal);
  color: var(--mint);
  text-decoration: none;
  transition: background 200ms ease;
}
.legal-nav-cta:hover { background: var(--persimmon); color: var(--charcoal); }

/* HERO */
.legal-hero {
  padding: 64px 56px 48px;
  border-bottom: 1px solid var(--rule);
}
.legal-hero-inner {
  max-width: 720px;
  margin: 0 auto;
}
.legal-hero .label {
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--label-gray);
  font-weight: 600;
}
.legal-hero h1 {
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 700;
  letter-spacing: -0.035em;
  line-height: 1.05;
  margin-top: 14px;
}
.legal-hero .meta {
  margin-top: 18px;
  font-size: 14px;
  color: var(--muted-gray);
}

/* MAIN CONTENT */
.legal-main {
  padding: 56px 56px 96px;
}
.legal-content {
  max-width: 720px;
  margin: 0 auto;
  font-size: 16px;
  color: var(--charcoal);
}
.legal-content p,
.legal-content ul,
.legal-content ol { margin-top: 1em; }
.legal-content ul,
.legal-content ol { padding-left: 1.5em; }
.legal-content li { margin-top: 0.4em; }
.legal-content h2 {
  font-size: clamp(22px, 2vw, 26px);
  font-weight: 700;
  letter-spacing: -0.02em;
  margin-top: 2.5em;
  padding-top: 0.25em;
  scroll-margin-top: 24px;
}
.legal-content h2:first-child { margin-top: 0; }
.legal-content h3 {
  font-size: 17px;
  font-weight: 600;
  margin-top: 1.5em;
  letter-spacing: -0.01em;
}
.legal-content strong { font-weight: 600; }
.legal-content code {
  background: #efe9da;
  border-radius: 4px;
  padding: 1px 6px;
  font-size: 14px;
  font-family: ui-monospace, SFMono-Regular, monospace;
}
.legal-content hr {
  border: none;
  border-top: 1px solid var(--rule);
  margin: 3em 0;
}
.legal-content .callout {
  background: #fff;
  border-left: 3px solid var(--persimmon);
  padding: 16px 18px;
  border-radius: 4px;
  margin-top: 1.5em;
  font-size: 15px;
}
.legal-content .placeholder {
  background: #fff3eb;
  color: #b34a1a;
  padding: 0 4px;
  border-radius: 3px;
  font-weight: 500;
  font-size: 0.95em;
}

/* TABLE OF CONTENTS */
.legal-toc {
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: 20px 24px;
  margin-bottom: 40px;
}
.legal-toc .label {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--label-gray);
  font-weight: 600;
}
.legal-toc ol {
  list-style: decimal;
  padding-left: 1.25em;
  margin-top: 12px;
  font-size: 14px;
  columns: 2;
  column-gap: 24px;
}
.legal-toc li { margin-top: 6px; break-inside: avoid; }
.legal-toc a { text-decoration: none; color: var(--charcoal); }
.legal-toc a:hover { color: var(--persimmon); }

/* INFO TABLE (used on company page) */
.info-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1em;
  font-size: 15px;
}
.info-table th,
.info-table td {
  text-align: left;
  padding: 12px 0;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.info-table th {
  width: 40%;
  font-weight: 600;
  color: var(--muted-gray);
}

/* FORMS (delete-account page) */
.legal-form {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 1.5em;
  padding: 24px;
  background: #fff;
  border: 1px solid var(--rule);
  border-radius: 10px;
}
.legal-form label {
  font-size: 13px;
  font-weight: 600;
  color: var(--muted-gray);
  margin-top: 8px;
}
.legal-form input,
.legal-form select,
.legal-form textarea {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 12px 14px;
  font-family: inherit;
  font-size: 15px;
  color: var(--charcoal);
  width: 100%;
  transition: border-color 200ms ease;
}
.legal-form input:focus,
.legal-form select:focus,
.legal-form textarea:focus {
  outline: none;
  border-color: var(--charcoal);
}
.legal-form textarea { resize: vertical; min-height: 100px; line-height: 1.5; }
.legal-form button {
  align-self: flex-start;
  margin-top: 12px;
  padding: 14px 24px;
  background: var(--charcoal);
  color: var(--mint);
  border: none;
  border-radius: 999px;
  font-family: inherit;
  font-weight: 500;
  font-size: 15px;
  cursor: pointer;
  transition: background 200ms ease;
}
.legal-form button:hover { background: var(--persimmon); color: var(--charcoal); }
.legal-form .honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; }
.legal-form-error,
.legal-form-success {
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 14px;
  margin-top: 12px;
}
.legal-form-error {
  background: #fff3eb;
  border-left: 2px solid var(--persimmon);
  color: var(--charcoal);
}
.legal-form-success {
  background: var(--mint);
  border-left: 2px solid var(--charcoal);
  color: var(--charcoal);
}

/* FOOTER (matches index.html) */
.legal-footer {
  background: var(--charcoal);
  color: var(--footer-text);
  padding: 40px 56px;
  font-size: 13px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  flex-wrap: wrap;
  gap: 24px;
}
.legal-footer .wordmark { color: var(--mint); font-size: 16px; }
.legal-footer .left { display: flex; flex-direction: column; gap: 6px; max-width: 28ch; }
.legal-footer .left .tagline { color: var(--footer-text); font-size: 12px; }
.legal-footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 28px;
  list-style: none;
}
.legal-footer-links a {
  color: var(--footer-text);
  text-decoration: none;
  transition: color 200ms ease;
}
.legal-footer-links a:hover { color: var(--mint); }
.legal-footer .copy { font-size: 12px; color: var(--footer-text); opacity: 0.7; }

/* PRIVACY STRIP (analytics disclosure, dismissible) */
.privacy-strip {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--charcoal);
  color: var(--mint);
  padding: 12px 16px 12px 20px;
  border-radius: 999px;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 14px;
  z-index: 50;
  max-width: calc(100% - 32px);
  box-shadow: 0 8px 24px rgba(14, 31, 23, 0.18);
}
.privacy-strip[hidden] { display: none; }
.privacy-strip a { color: var(--mint); text-decoration: underline; text-underline-offset: 2px; }
.privacy-strip a:hover { color: var(--persimmon); }
.privacy-strip button {
  background: transparent;
  border: 1px solid var(--mint);
  color: var(--mint);
  font-family: inherit;
  font-size: 12px;
  padding: 6px 12px;
  border-radius: 999px;
  cursor: pointer;
  transition: background 200ms ease, color 200ms ease;
}
.privacy-strip button:hover { background: var(--mint); color: var(--charcoal); }

/* RESPONSIVE */
@media (max-width: 640px) {
  .legal-nav,
  .legal-hero,
  .legal-main,
  .legal-footer { padding-left: 24px; padding-right: 24px; }
  .legal-hero { padding-top: 40px; padding-bottom: 32px; }
  .legal-main { padding-top: 36px; padding-bottom: 56px; }
  .legal-toc ol { columns: 1; }
  .info-table th { width: 35%; }
  .privacy-strip {
    bottom: 12px;
    font-size: 12px;
    padding: 10px 14px;
  }
}
@media (max-width: 400px) {
  .legal-footer { flex-direction: column; }
  .privacy-strip { flex-wrap: wrap; gap: 10px; }
}

/* PRINT */
@media print {
  .legal-nav,
  .legal-footer,
  .legal-toc,
  .privacy-strip { display: none; }
  .legal-hero { border-bottom: 1px solid #000; padding: 0 0 24px; }
  .legal-main { padding: 24px 0; }
  body { background: #fff; color: #000; font-size: 11pt; }
}
