/* ============================================================
   landing.css — styles for UWP city landing pages (generated by
   landing/build_landing.py). Loaded only on landing pages, on top
   of main.css. Uses the same design tokens as main.css.
   ============================================================ */

/* Compact hero for landing pages */
.hero--compact { padding-block: var(--space-8) var(--space-6); }
.hero--compact h1 { margin-bottom: var(--space-3); }
.hero__lede {
  font-size: 1.15rem;
  line-height: 1.6;
  color: var(--color-text-muted);
  max-width: 60ch;
  margin-bottom: var(--space-4);
}
.hero--compact .btn { margin-right: var(--space-2); }

/* Alternate-background section */
.section--alt { background-color: var(--color-bg-mid); }

/* Local market-data stat cards */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: var(--space-3);
  margin-block: var(--space-4);
}
.stat {
  background-color: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm, 6px);
  padding: var(--space-3) var(--space-2);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.stat__num {
  font-family: var(--font-heading, 'Barlow Condensed', sans-serif);
  font-size: 2.1rem;
  font-weight: 700;
  line-height: 1;
  color: var(--color-amber);
}
.stat__label { font-size: 0.85rem; color: var(--color-text); font-weight: 500; }
.stat__sub { font-size: 0.75rem; color: var(--color-text-muted); }

.market__rail, .market__port { margin-top: var(--space-3); line-height: 1.6; }
.market__source { margin-top: var(--space-3); color: var(--color-text-muted); }

/* Check list (what we supply) */
.check-list { list-style: none; padding: 0; margin: var(--space-3) 0; display: grid; gap: var(--space-2); }
.check-list li {
  position: relative;
  padding-left: 1.9rem;
  line-height: 1.5;
}
.check-list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-amber);
  font-weight: 700;
}

/* Internal-link columns */
.link-cols {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
}
.link-list { list-style: none; padding: 0; margin: var(--space-2) 0; display: grid; gap: 0.6rem; }
.link-list a { color: var(--color-charcoal); text-decoration: none; border-bottom: 1px solid transparent; }
.link-list a:hover { color: var(--color-amber); border-bottom-color: var(--color-amber); }
.link-list--inline { grid-auto-flow: column; grid-template-columns: none; display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4); }

/* FAQ */
.faq-list { display: grid; gap: var(--space-3); margin-top: var(--space-3); max-width: 70ch; }
.faq-item { border-left: 3px solid var(--color-amber); padding-left: var(--space-3); }
.faq-item__q { font-size: 1.05rem; margin-bottom: 0.35rem; }
.faq-item__a { color: var(--color-text-muted); line-height: 1.6; margin: 0; }

@media (max-width: 600px) {
  .stat__num { font-size: 1.7rem; }
}

/* City directory (on /service-area/) + solutions grid (on /products/) */
.area-dir {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--space-4);
  margin-top: var(--space-3);
}
.area-dir__state { margin: 0 0 0.5rem; font-size: 1.05rem; color: var(--color-charcoal); }
.area-dir ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.4rem; }
.area-dir a { color: var(--color-charcoal); text-decoration: none; }
.area-dir a:hover { color: var(--color-amber); }
