/* Shared styling for The Auto Junkie content pages (About, Contact, Privacy,
   Terms). Mirrors the homepage's garage-magazine palette and typography so the
   supporting pages feel like part of the same publication. */
:root {
  --ink: #171716;
  --paper: #f5f1e8;
  --panel: #fffaf0;
  --line: #28251f;
  --muted: #6f695e;
  --red: #b52920;
  --green: #526048;
  --gold: #bd8d2f;
  --shadow: 0 18px 42px rgba(23, 23, 22, .12);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  color: var(--ink);
  background:
    linear-gradient(rgba(25, 24, 20, .035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(25, 24, 20, .03) 1px, transparent 1px),
    var(--paper);
  background-size: 32px 32px;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.65;
}

a { color: var(--red); }

.page {
  width: min(820px, calc(100% - 32px));
  margin: 0 auto;
}

.masthead {
  padding: 18px 0 14px;
  border-bottom: 3px solid var(--line);
  margin-bottom: 8px;
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  color: var(--muted);
  font: 800 11px/1.2 "Trebuchet MS", sans-serif;
  letter-spacing: .11em;
  text-transform: uppercase;
}

.brand {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 14px;
}

.brand a.wordmark {
  text-decoration: none;
  color: var(--ink);
  font: 800 1.9rem/1 "Trebuchet MS", sans-serif;
  text-transform: uppercase;
  letter-spacing: .03em;
}

.crumb {
  color: var(--muted);
  font: 800 11px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.crumb a { color: var(--muted); text-decoration: none; }
.crumb a:hover { color: var(--ink); }

main.prose {
  padding: 30px 0 10px;
}

.prose h1 {
  margin: 0 0 6px;
  font-size: clamp(2rem, 5vw, 3.2rem);
  line-height: 1;
  text-transform: uppercase;
  letter-spacing: .02em;
}

.prose .lede {
  margin: 0 0 26px;
  color: var(--muted);
  font-size: 1.12rem;
}

.prose h2 {
  margin: 34px 0 8px;
  font-size: clamp(1.3rem, 3vw, 1.7rem);
  text-transform: uppercase;
  letter-spacing: .01em;
}

.prose h3 {
  margin: 22px 0 6px;
  font-size: 1.12rem;
}

.prose p, .prose li { font-size: 1.04rem; }

.prose ul { padding-left: 20px; }
.prose li { margin-bottom: 6px; }

.prose .updated {
  display: inline-block;
  margin-bottom: 18px;
  padding: 5px 9px;
  border: 1px solid var(--line);
  background: var(--panel);
  color: var(--muted);
  font: 800 10px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.card {
  background: var(--panel);
  border: 1px solid var(--line);
  padding: 22px;
  box-shadow: 7px 7px 0 rgba(23, 23, 22, .08);
  margin: 18px 0;
}

/* Contact form */
.contact-form {
  display: grid;
  gap: 14px;
  margin-top: 8px;
}

.contact-form label {
  display: grid;
  gap: 6px;
  font: 800 12px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ink);
}

.contact-form input,
.contact-form textarea {
  border: 1px solid var(--line);
  background: #fffdf8;
  padding: 12px 13px;
  font: 1rem/1.4 Georgia, "Times New Roman", serif;
  color: var(--ink);
}

.contact-form input:focus,
.contact-form textarea:focus {
  outline: 2px solid var(--red);
  outline-offset: 1px;
}

.contact-form textarea { min-height: 150px; resize: vertical; }

.contact-form button {
  justify-self: start;
  cursor: pointer;
  border: 1px solid var(--line);
  background: var(--red);
  color: #fff8ea;
  padding: 12px 22px;
  font: 800 12px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: transform .2s ease, background .2s ease;
}

.contact-form button:hover { background: var(--ink); transform: translateY(-2px); }

.form-status {
  min-height: 18px;
  margin: 2px 0 0;
  font: 800 12px/1.4 "Trebuchet MS", sans-serif;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--green);
}

.hp { position: absolute; left: -9999px; }

/* Section label chip (shared with the homepage hero) */
.label {
  display: inline-block;
  width: fit-content;
  background: var(--red);
  color: #fff8ea;
  padding: 7px 10px;
  font: 800 12px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Source-First Aggregation board */
.source-board {
  margin: 30px 0 10px;
  background: var(--ink);
  color: var(--paper);
  padding: 26px;
  display: grid;
  grid-template-columns: .85fr 1.15fr;
  gap: 24px;
}

.source-board h2 {
  margin: 0;
  font-size: clamp(2rem, 4vw, 3.4rem);
  line-height: .9;
  text-transform: uppercase;
}

.source-board p { margin: 0; color: #d9cdb9; }

.source-list {
  columns: 2;
  margin: 14px 0 0;
  padding-left: 18px;
  color: #ede1cf;
}

.source-list li {
  break-inside: avoid;
  margin-bottom: 8px;
}

/* Ask the Junkie — AI concierge */
.ask {
  margin: 30px 0 10px;
  display: grid;
  grid-template-columns: .82fr 1.18fr;
  gap: 0;
  border: 1px solid var(--line);
  background: var(--ink);
  color: var(--paper);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.ask-intro {
  padding: clamp(22px, 3vw, 34px);
  border-right: 1px solid rgba(245, 241, 232, .16);
  display: grid;
  align-content: start;
  gap: 14px;
  background:
    linear-gradient(180deg, rgba(181, 41, 32, .22), rgba(23, 23, 22, 0) 55%),
    var(--ink);
}

.ask-intro .label {
  background: var(--gold);
  color: var(--ink);
}

.ask-intro h2 {
  margin: 0;
  font-size: clamp(1.9rem, 3.6vw, 3rem);
  line-height: .92;
  text-transform: uppercase;
}

.ask-intro p {
  margin: 0;
  color: #d9cdb9;
  font-size: 1rem;
}

.ask-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
}

.chip {
  cursor: pointer;
  border: 1px solid rgba(245, 241, 232, .4);
  background: transparent;
  color: var(--paper);
  padding: 7px 11px;
  font: 800 11px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .06em;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease;
}

.chip:hover {
  background: var(--paper);
  color: var(--ink);
}

.ask-panel {
  padding: clamp(22px, 3vw, 34px);
  display: grid;
  align-content: start;
  gap: 14px;
  background: #1d1c1a;
}

.ask-form {
  display: flex;
  gap: 10px;
}

.ask-form input {
  flex: 1;
  min-width: 0;
  border: 1px solid rgba(245, 241, 232, .35);
  background: #2a2825;
  color: var(--paper);
  padding: 13px 14px;
  font: 1rem/1.3 Georgia, "Times New Roman", serif;
}

.ask-form input::placeholder { color: #9d958a; }

.ask-form input:focus {
  outline: 2px solid var(--gold);
  outline-offset: 1px;
}

.ask-form button {
  cursor: pointer;
  border: 1px solid var(--gold);
  background: var(--gold);
  color: var(--ink);
  padding: 0 18px;
  font: 800 12px/1 "Trebuchet MS", sans-serif;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: background .2s ease, color .2s ease;
}

.ask-form button:hover:not(:disabled) {
  background: var(--paper);
  border-color: var(--paper);
}

.ask-form button:disabled {
  opacity: .55;
  cursor: wait;
}

.ask-answer {
  min-height: 132px;
  border: 1px dashed rgba(245, 241, 232, .28);
  background: rgba(245, 241, 232, .04);
  padding: 16px 18px;
  white-space: pre-wrap;
  font-size: 1.04rem;
  line-height: 1.6;
  color: #f0e8d8;
}

.ask-answer .placeholder {
  color: #948c81;
  font-style: italic;
}

.ask-disclaimer {
  margin: 0;
  color: #8f877c;
  font: 700 11px/1.5 "Trebuchet MS", sans-serif;
  letter-spacing: .05em;
  text-transform: uppercase;
}

.cursor::after {
  content: "▍";
  color: var(--gold);
  animation: blink 1s steps(2, start) infinite;
}

@keyframes blink { to { visibility: hidden; } }

@media (max-width: 720px) {
  .source-board,
  .ask {
    grid-template-columns: 1fr;
  }

  .source-list { columns: 1; }

  .ask-intro {
    border-right: none;
    border-bottom: 1px solid rgba(245, 241, 232, .16);
  }

  .ask-form { flex-direction: column; }

  .ask-form button { padding: 13px 18px; }
}

footer {
  border-top: 4px double var(--line);
  margin-top: 36px;
  padding: 22px 0 40px;
  color: var(--muted);
  font: 700 12px/1.7 "Trebuchet MS", sans-serif;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.footer-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 18px;
  margin-bottom: 12px;
}

.footer-nav a { color: var(--ink); text-decoration: none; }
.footer-nav a:hover { text-decoration: underline; }
