/* vertical.css — shared styles for /verticals/* mini-landings */

body.vertical-page,
body.vertical-index {
  background: var(--slate-950);
  color: var(--slate-200);
}

.vertical-hero { padding: 4rem 1.25rem 4rem; }
.vertical-hero h1 { font-size: clamp(1.9rem, 4.5vw, 3.2rem); }
.vertical-hero h1 em { display: inline; font-size: 0.55em; font-style: italic; }

.block, .block-dark {
  padding: 4rem 1.25rem;
}
.block { background: var(--slate-900); color: var(--slate-200); }
.block-dark { background: var(--slate-950); color: var(--slate-200); }
.block-inner { max-width: 1100px; margin: 0 auto; }
.block h2 { color: #fff; font-size: 1.85rem; margin: 0 0 1rem; font-weight: 700; }
.block h3.subhead { color: var(--emerald-400); font-size: 1rem; margin: 2rem 0 0.75rem; text-transform: uppercase; letter-spacing: 0.08em; font-family: var(--font-mono); }
.block-lede { color: var(--slate-300); font-size: 1.05rem; line-height: 1.6; margin: 0 0 1.5rem; }
.block ul, .block ol, .block-dark ul, .block-dark ol { padding-left: 1.5rem; line-height: 1.7; }
.block li, .block-dark li { color: var(--slate-300); margin: 0.4rem 0; }
.block p, .block-dark p { line-height: 1.7; color: var(--slate-300); }

.canonical-list { list-style: none; padding-left: 0; }
.canonical-list li { padding: 0.6rem 0.9rem; background: var(--slate-800); border: 1px solid var(--slate-700); border-radius: 8px; margin: 0.4rem 0; }
.canonical-list li strong { color: var(--emerald-400); }

.repo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 1.25rem;
  margin-top: 2rem;
}
.repo-card {
  background: var(--slate-800);
  border: 1px solid var(--slate-700);
  border-radius: 12px;
  padding: 1.5rem;
  transition: border-color 120ms ease, transform 120ms ease;
}
.repo-card:hover {
  border-color: var(--emerald-500);
  transform: translateY(-2px);
}
.repo-shape {
  display: inline-block;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--emerald-400);
  font-family: var(--font-mono);
  margin-bottom: 0.6rem;
}
.repo-card h3 { margin: 0 0 0.6rem; font-size: 1rem; }
.repo-card h3 a { color: #fff; text-decoration: none; }
.repo-card h3 a:hover { color: var(--emerald-400); }
.repo-card h3 code { font-family: var(--font-mono); font-size: 0.92rem; color: inherit; background: transparent; padding: 0; }
.repo-card p { margin: 0; font-size: 0.9rem; line-height: 1.55; color: var(--slate-300); }

.vertical-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 1.25rem;
  margin-top: 1rem;
}
.vertical-card {
  display: block;
  background: var(--slate-800);
  border: 1px solid var(--slate-700);
  border-radius: 12px;
  padding: 1.75rem;
  text-decoration: none;
  color: inherit;
  transition: border-color 120ms ease, transform 120ms ease;
}
.vertical-card:hover { border-color: var(--emerald-500); transform: translateY(-2px); text-decoration: none; }
.vertical-card h3 { color: #fff; font-size: 1.2rem; margin: 0 0 0.6rem; }
.vertical-card-tagline { color: var(--slate-300); font-size: 0.85rem; line-height: 1.5; margin: 0 0 1rem; }
.vertical-card-buyer { color: var(--slate-400); font-size: 0.85rem; margin: 0 0 1rem; }
.vertical-card-buyer span { color: var(--emerald-400); font-family: var(--font-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; }
.vertical-card-cta { color: var(--emerald-400); font-weight: 600; font-size: 0.95rem; }

.shape-list { color: var(--slate-300); font-size: 1rem; }
.shape-list strong { color: var(--emerald-400); }

.footer {
  background: var(--slate-950);
  border-top: 1px solid var(--slate-800);
  padding: 2.5rem 1.25rem;
  color: var(--slate-400);
  text-align: center;
}
.footer-inner { max-width: 900px; margin: 0 auto; }
.footer p { margin: 0.5rem 0; }
.footer a { color: var(--emerald-400); }
.footer-fineprint { font-size: 0.8rem; color: var(--slate-500); }
