/* =========================================================================
   Housecarl marketing — overrides over /housecarl-chrome/*.css.
   Only marketing-specific surface adjustments live here. All tokens, chrome,
   and primitives come from the design pack (loaded in base.html).
   ========================================================================= */

/* Marketing density tweak: a touch more breathing room than console default */
body[data-mode="marketing"][data-density="standard"] {
  --row: 32px;
  --cell-y: 8px;
  --cell-x: 12px;
}

/* Wordmark adjustments for the marketing masthead (mascot-less, larger) */
.masthead .wordmark .m1 {
  font-size: 30px;
  letter-spacing: -.015em;
}
.masthead .wordmark .m2 {
  font-style: italic;
  font-size: 14px;
  color: var(--fg2);
}
.masthead-meta {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: .14em;
  color: var(--fg2);
  text-transform: uppercase;
}

/* Pre-release / advisory banner (used on doc pages via doc-base.html) */
.advisory {
  background: var(--rust);
  color: var(--off-white);
  border-bottom: 1px solid #000;
  padding: 6px 0;
}
.advisory .wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-3);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  font-weight: 700;
}
.advisory .dot { color: var(--muted-gold); }

/* =========================================================================
   Hero — landing page
   ========================================================================= */

.hero {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: var(--s-7);
  padding: var(--s-7) 0 var(--s-7);
  border-bottom: 3px double var(--iron-900);
  align-items: stretch;
}
.hero__lede h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--size-5xl);
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 0 0 var(--s-3);
}
.hero__lede h1 em {
  font-style: italic;
  color: var(--copper-orange);
}
.hero__sub {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--size-lg);
  line-height: var(--lh-snug);
  color: var(--fg2);
  max-width: 36ch;
  margin: 0 0 var(--s-5);
}
.hero__cta {
  display: flex;
  gap: var(--s-2);
  flex-wrap: wrap;
  margin-top: var(--s-5);
}
.hero__cta .btn--primary { padding: 12px 22px; font-size: 14px; }
.hero__metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-4);
  margin-top: var(--s-7);
  padding-top: var(--s-5);
  border-top: 1px solid var(--rule);
}
.hero__metric { font-family: var(--font-serif); }
.hero__metric .v {
  display: block;
  font-weight: 700;
  font-size: var(--size-xl);
  color: var(--ink);
  letter-spacing: -.005em;
}
.hero__metric .k {
  display: block;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--fg2);
  margin-top: 2px;
}

.hero__plate {
  background: var(--ink);
  color: var(--off-white);
  border-left: var(--bw-heavy) solid var(--copper-orange);
  padding: var(--s-5);
  font-family: var(--font-mono);
  font-size: var(--size-sm);
  line-height: var(--lh-snug);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 380px;
}
.hero__plate .head {
  font-size: 10px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--muted-gold);
  margin-bottom: var(--s-3);
}
.hero__plate pre {
  margin: 0;
  font-family: var(--font-mono);
  color: var(--fg-on-dark);
  white-space: pre;
  overflow-x: auto;
}
.hero__plate .prompt  { color: var(--copper-orange); }
.hero__plate .comment { color: #8A8579; font-style: italic; }
.hero__plate .keyword { color: var(--muted-gold); }
.hero__plate .ok      { color: #85B89B; }
.hero__plate .deny    { color: #D86B27; }
.hero__plate .foot {
  margin-top: var(--s-4);
  padding-top: var(--s-3);
  border-top: 1px solid rgba(255,255,255,.12);
  display: flex;
  justify-content: space-between;
  font-size: 10px;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #8A8579;
}

/* =========================================================================
   Marketing sections (bands of content separated by paper/dark)
   ========================================================================= */

.band {
  padding: var(--s-7) 0;
  border-bottom: 1px solid var(--rule);
}
.band--paper { background: var(--bg-paper); }
.band--dark {
  background: var(--iron-900);
  color: var(--off-white);
  border-bottom-color: #000;
}
.band--dark h2,
.band--dark h3 { color: var(--off-white); }
.band--dark .eyebrow { color: var(--muted-gold); }
.band__head {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--s-7);
  margin-bottom: var(--s-6);
  align-items: baseline;
}
.band__head .eyebrow { padding-top: 6px; }
.band__head h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--size-3xl);
  line-height: 1.15;
  letter-spacing: -.01em;
  margin: 0;
  max-width: 24ch;
}

/* Feature grid — "what you get" / "who it's for" */
.feature-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 0;
  border-top: 1px solid var(--rule);
  border-left: 1px solid var(--rule);
}
.feature {
  padding: var(--s-5);
  border-right: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--bg-card);
  position: relative;
}
.feature .num {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: .22em;
  color: var(--copper-orange);
  font-weight: 700;
}
.feature h3 {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: var(--size-md);
  margin: var(--s-2) 0 var(--s-2);
  color: var(--ink);
  letter-spacing: -.005em;
}
.feature p {
  font-family: var(--font-serif);
  font-size: var(--size-sm);
  line-height: var(--lh-loose);
  color: var(--fg2);
  margin: 0;
  max-width: 50ch;
}
.band--dark .feature {
  background: transparent;
  border-color: rgba(255,255,255,.12);
}
.band--dark .feature p { color: var(--fg-on-dark-2); }
.band--dark .feature h3 { color: var(--off-white); }

/* CTA strip near the bottom of the landing */
.cta-strip {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: var(--s-5);
  padding: var(--s-7) 0;
  border-top: 3px double var(--iron-900);
  border-bottom: 1px solid var(--rule);
}
.cta-strip__copy h2 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--size-2xl);
  margin: 0 0 var(--s-2);
  color: var(--ink);
}
.cta-strip__copy p {
  font-family: var(--font-serif);
  font-size: var(--size-md);
  color: var(--fg2);
  margin: 0;
  max-width: 60ch;
}
.cta-strip__actions { display: flex; gap: var(--s-2); }

/* =========================================================================
   News & taxonomy listings
   ========================================================================= */

/* Page-level header used on news/taxonomy listings (eyebrow + h1 + aside) */
.page-head {
  padding: var(--s-7) 0 var(--s-5);
  border-bottom: 3px double var(--iron-900);
  margin-bottom: var(--s-6);
}
.page-head .eyebrow { display: block; margin-bottom: var(--s-2); }
.page-head h1 {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: var(--size-3xl);
  line-height: var(--lh-tight);
  letter-spacing: -.01em;
  color: var(--ink);
  margin: 0;
  max-width: 28ch;
}
.page-head .aside {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--size-md);
  color: var(--fg2);
  margin-top: var(--s-3);
  max-width: 60ch;
}
.page-head .byline {
  font-family: var(--font-mono);
  font-size: var(--size-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg2);
  margin-top: var(--s-3);
}

/* Compact horizontal entry: mono date · title (link) · meta below */
.news-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--s-7);
}
.news-entry {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: var(--s-5);
  padding: var(--s-4) 0;
  border-bottom: 1px solid var(--rule);
  align-items: baseline;
}
.news-entry:first-child { border-top: 1px solid var(--rule); }
.news-entry__date {
  font-family: var(--font-mono);
  font-size: var(--size-xs);
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--fg2);
  white-space: nowrap;
}
.news-entry__body { min-width: 0; }
.news-entry__title {
  font-family: var(--font-serif);
  font-weight: 700;
  font-size: var(--size-lg);
  line-height: var(--lh-snug);
  margin: 0 0 var(--s-1);
  letter-spacing: -.005em;
}
.news-entry__title a {
  color: var(--ink);
  text-decoration: none;
}
.news-entry__title a:hover { color: var(--copper-orange); }
.news-entry__meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  align-items: center;
  font-family: var(--font-mono);
  font-size: var(--size-xs);
  color: var(--fg3);
  letter-spacing: .04em;
  margin-top: var(--s-2);
}
.news-entry__author {
  font-family: var(--font-serif);
  font-style: italic;
  font-size: var(--size-sm);
  color: var(--fg2);
  letter-spacing: 0;
  text-transform: none;
}

/* Single news post body */
.news-post {
  padding: var(--s-2) 0 var(--s-7);
}
.news-post__back {
  display: inline-block;
  margin-top: var(--s-6);
  font-family: var(--font-mono);
  font-size: var(--size-xs);
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--fg2);
  text-decoration: none;
}
.news-post__back:hover { color: var(--copper-orange); }
.news-post__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  align-items: center;
  margin-top: var(--s-6);
  padding-top: var(--s-4);
  border-top: 1px solid var(--rule);
}

/* Term/tag flow used by taxonomy_list.html */
.tag-flow {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
}
.tag-flow .tag {
  text-decoration: none;
}

/* Mobile collapse */
@media (max-width: 880px) {
  .hero { grid-template-columns: 1fr; }
  .hero__plate { min-height: 280px; }
  .band__head { grid-template-columns: 1fr; gap: var(--s-3); }
  .cta-strip { grid-template-columns: 1fr; }
  .news-entry { grid-template-columns: 1fr; gap: var(--s-1); }
}
