/* =========================================================================
   main.css — Design System for hometheaterinstallers.net
   Anti-vibe-coded: 8pt grid, consistent radius, disciplined palette
   ========================================================================= */

@tailwind base;
@tailwind components;
@tailwind utilities;

/* ---------------------------------------------------------------------------
   Design Tokens
   --------------------------------------------------------------------------- */
:root {
  /* Astrowind Theme Variables */
  --aw-font-sans: 'Inter Variable', sans-serif;
  --aw-font-serif: 'Inter Variable', serif;
  --aw-font-heading: 'Inter Variable', sans-serif;

  --aw-color-primary: rgb(30 64 175); /* blue-800 */
  --aw-color-secondary: rgb(30 58 138); /* blue-900 */
  --aw-color-accent: rgb(109 40 217); /* violet-700 */

  --aw-color-text-heading: rgb(0 0 0);
  --aw-color-text-default: rgb(16 16 16);
  --aw-color-text-muted: rgb(16 16 16 / 66%);

  /* Old Colors — clean light palette suitable for all ages (phasing out) */
  --color-bg: #F8FAFC;
  --color-surface: #FFFFFF;
  --color-surface-hover: #F1F5F9;
  --color-border: #E2E8F0;
  --color-text: #0F172A;
  --color-text-muted: #64748B;
  --color-primary: #2563EB;
  --color-primary-hover: #1D4ED8;
  --color-accent: #EA580C;
  --color-success: #16A34A;
  --color-danger: #DC2626;
  --color-white: #FFFFFF;

  /* Semantic surface aliases used by the current design system */
  --color-background-primary: #FFFFFF;
  --color-background-secondary: #F8FAFC;
  --color-background-tertiary: #F1F5F9;
  --color-text-primary: #0F172A;
  --color-text-secondary: #475569;
  --color-text-tertiary: #64748B;
  --color-text-info: #2563EB;
  --color-border-primary: #94A3B8;
  --color-border-secondary: #CBD5E1;
  --color-border-tertiary: #E2E8F0;

  /* Typography */
  --font-body: 'Inter Variable', ui-sans-serif, system-ui, -apple-system, sans-serif;
  --font-heading: 'Inter Variable', ui-sans-serif, system-ui, -apple-system, sans-serif;

  /* Spacing — 8pt grid */
  --sp-1: 8px;
  --sp-2: 16px;
  --sp-3: 24px;
  --sp-4: 32px;
  --sp-5: 40px;
  --sp-6: 48px;
  --sp-8: 64px;
  --sp-12: 96px;

  /* Radius — standardized */
  --radius: 8px;

  /* Shadow — one style */
  --shadow: 0 1px 3px rgba(0,0,0,0.3), 0 1px 2px rgba(0,0,0,0.2);

  /* Transitions */
  --transition-fast: 150ms ease;
  --transition-normal: 250ms ease;

  /* Layout */
  --max-width: 1200px;
  --sidebar-width: 320px;
}

/* ---------------------------------------------------------------------------
   Base
   --------------------------------------------------------------------------- */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-heading);
  font-weight: 600;
  color: var(--color-text);
  margin: 0 0 var(--sp-2) 0;
  line-height: 1.2;
}

h1 { font-size: var(--text-2xl); margin-bottom: var(--sp-3); }
h2 { font-size: var(--text-xl); line-height: 1.3; }
h3 { font-size: var(--text-lg); line-height: 1.3; }
h4 { font-size: var(--text-base); }

p {
  margin: 0 0 var(--sp-2) 0;
  color: var(--color-text);
}

ul, ol {
  margin: 0 0 var(--sp-2) 0;
  padding-left: var(--sp-3);
}

li { margin-bottom: var(--sp-1); }

/* ---------------------------------------------------------------------------
   Site Header
   --------------------------------------------------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}

.header-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--sp-2) var(--sp-3);
  display: flex;
  align-items: center;
  gap: var(--sp-2);
}

.site-logo {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  color: var(--color-text);
  font-weight: 600;
  font-size: var(--text-base);
  white-space: nowrap;
  flex-shrink: 0;
}

.site-logo:hover { color: var(--color-primary); }

.logo-text {
  display: none;
}

@media (min-width: 768px) {
  .logo-text { display: inline; }
}

/* Header search */
.header-search {
  display: flex;
  flex: 1;
  max-width: 400px;
  margin-left: auto;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}

.header-search input {
  flex: 1;
  background: transparent;
  border: none;
  padding: var(--sp-1) var(--sp-2);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  outline: none;
}

.header-search input::placeholder { color: var(--color-text-muted); }

.header-search button {
  background: transparent;
  border: none;
  padding: var(--sp-1);
  color: var(--color-text-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
}

.header-search button:hover { color: var(--color-primary); }

/* Menu toggle */
.menu-toggle {
  display: flex;
  background: none;
  border: none;
  color: var(--color-text-muted);
  cursor: pointer;
  padding: var(--sp-1);
}

.menu-toggle:hover { color: var(--color-text); }

@media (min-width: 768px) {
  .menu-toggle { display: none; }
}

/* Mobile nav */
.mobile-nav {
  display: none;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  padding: var(--sp-2) var(--sp-3);
}

.mobile-nav.open { display: block; }

@media (min-width: 768px) {
  .mobile-nav { display: none !important; }
}

.nav-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.nav-list li { margin-bottom: 0; }

.nav-list a {
  display: block;
  padding: var(--sp-1) 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  transition: color var(--transition-ui);
}

.nav-list a:hover,
.nav-list a.active { color: var(--color-primary); }

/* ---------------------------------------------------------------------------
   Main Content
   --------------------------------------------------------------------------- */
.site-main {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--sp-4) var(--sp-3);
  min-height: 60vh;
}

/* ---------------------------------------------------------------------------
   Footer
   --------------------------------------------------------------------------- */
.site-footer {
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  margin-top: var(--sp-8);
}

.footer-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: var(--sp-6) var(--sp-3) var(--sp-4);
}

.footer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: var(--sp-4);
  margin-bottom: var(--sp-4);
}

.footer-heading {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--color-text);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-2);
}

.footer-links {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-links li { margin-bottom: var(--space-half); }

.footer-links a {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  transition: color var(--transition-ui);
}

.footer-links a:hover { color: var(--color-primary); }

.footer-bottom {
  border-top: 1px solid var(--color-border);
  padding-top: var(--sp-3);
  text-align: center;
}

.footer-bottom p {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin: 0;
}

/* ---------------------------------------------------------------------------
   Breadcrumb
   --------------------------------------------------------------------------- */
.breadcrumb {
  margin-bottom: var(--sp-3);
}

.breadcrumb-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  font-size: var(--text-sm);
}

.breadcrumb-item {
  display: flex;
  align-items: center;
  margin-bottom: 0;
}

.breadcrumb-item a {
  color: var(--color-text-muted);
  transition: color var(--transition-ui);
}

.breadcrumb-item a:hover { color: var(--color-primary); }

.breadcrumb-sep {
  margin: 0 var(--sp-1);
  color: var(--color-border);
}

.breadcrumb-current {
  color: var(--color-text);
}

/* ---------------------------------------------------------------------------
   Hero Section (Homepage)
   --------------------------------------------------------------------------- */
.hero {
  text-align: center;
  padding: var(--sp-8) var(--sp-3) var(--sp-6);
  max-width: 800px;
  margin: 0 auto;
}

.hero h1 {
  font-size: var(--text-3xl);
  margin-bottom: var(--sp-2);
}

@media (min-width: 768px) {
  .hero h1 { font-size: var(--text-3xl); }
}

.hero-subtitle {
  font-size: var(--text-md);
  color: var(--color-text-muted);
  margin-bottom: var(--sp-4);
  line-height: 1.5;
}

.trust-row {
  display: flex;
  justify-content: center;
  gap: var(--sp-6);
  margin-top: var(--sp-4);
}

.trust-item {
  text-align: center;
}

.trust-number {
  display: block;
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--color-primary);
}

.trust-label {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ---------------------------------------------------------------------------
   Search Form
   --------------------------------------------------------------------------- */
.search-form {
  display: flex;
  gap: var(--sp-1);
  max-width: 640px;
  margin: 0 auto;
}

.search-form--large {
  flex-wrap: wrap;
}

.search-input-wrap {
  flex: 1;
  position: relative;
  display: flex;
  align-items: center;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  min-width: 200px;
}

.search-icon {
  position: absolute;
  left: var(--sp-2);
  color: var(--color-text-muted);
  pointer-events: none;
}

.search-input-wrap input {
  width: 100%;
  padding: 12px var(--sp-2) 12px 44px;
  background: transparent;
  border: none;
  color: var(--color-text);
  font-size: var(--text-base);
  font-family: var(--font-body);
  outline: none;
}

.search-input-wrap input::placeholder { color: var(--color-text-muted); }

.search-input-wrap input:focus {
  outline: none;
}

.search-input-wrap:focus-within {
  border-color: var(--color-primary);
}

.category-select {
  padding: 12px var(--sp-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  cursor: pointer;
  min-width: 180px;
}

.search-submit {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: 12px var(--sp-3);
  background: var(--color-primary);
  color: var(--color-white);
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-weight: 600;
  font-family: var(--font-body);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--transition-ui);
}

.search-submit:hover { background: var(--color-primary-hover); }

/* Autocomplete suggestions */
.search-suggestions {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-top: none;
  border-radius: 0 0 var(--radius) var(--radius);
  z-index: 100;
  max-height: 320px;
  overflow-y: auto;
}

.search-suggestions.open { display: block; }

.suggestion-item {
  display: block;
  padding: var(--sp-1) var(--sp-2);
  color: var(--color-text);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: background var(--transition-ui);
}

.suggestion-item:hover,
.suggestion-item.active {
  background: var(--color-surface-hover);
  color: var(--color-primary);
}

/* ---------------------------------------------------------------------------
   City / State / Silo Page Layouts
   --------------------------------------------------------------------------- */
.city-page {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--sp-4);
}

@media (min-width: 1024px) {
  .city-page {
    grid-template-columns: minmax(0, 1fr) var(--sidebar-width);
  }
}

.city-main {
  min-width: 0;
}

.city-header { margin-bottom: var(--sp-3); }

.city-header h1 { margin-bottom: var(--sp-1); }

.city-count {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--sp-2);
}

.city-intro {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  line-height: 1.6;
}

.section-heading {
  margin-top: var(--sp-3);
  margin-bottom: var(--sp-3);
}

/* ---------------------------------------------------------------------------
   Listing Grid
   --------------------------------------------------------------------------- */
.listing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
}

@media (min-width: 640px) {
  .listing-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ---------------------------------------------------------------------------
   Listing Card
   --------------------------------------------------------------------------- */
.listing-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  transition: border-color var(--transition-ui), background var(--transition-ui);
}

.listing-card:hover {
  border-color: var(--color-primary);
  background: var(--color-surface-hover);
}

.listing-card.hidden { display: none; }

.card-image-link { display: block; }

.card-image-link .photo-main img,
.card-image-link .photo-placeholder {
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
}

.photo-placeholder {
  background: var(--color-bg);
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-body {
  padding: var(--sp-2);
}

.card-title {
  font-size: var(--text-base);
  font-weight: 600;
  margin-bottom: var(--sp-1);
}

.card-title a {
  color: var(--color-text);
  transition: color var(--transition-ui);
}

.card-title a:hover { color: var(--color-primary); }

.card-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-1);
}

.card-location,
.card-phone {
  display: flex;
  align-items: center;
  gap: 6px;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-half);
}

.card-phone a {
  color: var(--color-text-muted);
  transition: color var(--transition-ui);
}

.card-phone a:hover { color: var(--color-primary); }

/* ---------------------------------------------------------------------------
   Star Rating
   --------------------------------------------------------------------------- */
.star-rating {
  display: flex;
  align-items: center;
  gap: var(--space-half);
}

.star-icons {
  display: flex;
  gap: 1px;
}

.rating-value {
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-accent);
}

.rating-count {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.no-rating .rating-text {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ---------------------------------------------------------------------------
   Open Status
   --------------------------------------------------------------------------- */
.open-status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--text-sm);
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}

.is-open .status-dot { background: var(--color-success); }
.is-closed .status-dot { background: var(--color-danger); }
.unknown .status-dot { background: var(--color-text-muted); }

.status-text { color: var(--color-text); }
.is-open .status-text { color: var(--color-success); }
.is-closed .status-text { color: var(--color-danger); }

.status-hours {
  color: var(--color-text-muted);
  margin-left: 4px;
}

/* ---------------------------------------------------------------------------
   Filter Strip
   --------------------------------------------------------------------------- */
.filter-strip {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
  margin-bottom: var(--sp-3);
  min-height: 40px; /* Fixed height prevents CLS */
}

.filter-btn {
  padding: 6px var(--sp-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-family: var(--font-body);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--transition-ui), color var(--transition-ui), border-color var(--transition-ui);
}

.filter-btn:hover {
  border-color: var(--color-primary);
  color: var(--color-text);
}

.filter-btn.active {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-white);
}

/* ---------------------------------------------------------------------------
   City Sidebar
   --------------------------------------------------------------------------- */
.city-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.city-sidebar section,
.city-sidebar .byog-banner {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--sp-3);
}

.city-sidebar h2,
.city-sidebar h3 {
  font-size: var(--text-base);
  margin-bottom: var(--sp-2);
}

.nearby-list,
.related-cat-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.nearby-list li,
.related-cat-list li {
  margin-bottom: var(--sp-1);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.nearby-list a,
.related-cat-list a {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  transition: color var(--transition-ui);
}

.nearby-list a:hover,
.related-cat-list a:hover { color: var(--color-primary); }

.nearby-count {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.sidebar-back-link {
  display: block;
  text-align: center;
  padding: var(--sp-1) 0;
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: 500;
}

/* ---------------------------------------------------------------------------
   BYOG Banner
   --------------------------------------------------------------------------- */
.byog-inner {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.byog-content h3 {
  font-size: var(--text-base);
  margin-bottom: var(--sp-1);
}

.byog-content p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin: 0;
}

.byog-cta {
  display: inline-block;
  padding: var(--sp-1) var(--sp-2);
  background: var(--color-accent);
  color: var(--color-bg);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: 600;
  text-align: center;
  transition: opacity var(--transition-ui);
}

.byog-cta:hover {
  opacity: 0.9;
  color: var(--color-bg);
}

/* ---------------------------------------------------------------------------
   City / State Grid Cards
   --------------------------------------------------------------------------- */
.city-grid,
.category-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.city-card,
.category-card,
.state-card {
  display: flex;
  flex-direction: column;
  padding: var(--sp-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  transition: border-color var(--transition-ui), background var(--transition-ui);
}

.city-card:hover,
.category-card:hover,
.state-card:hover {
  border-color: var(--color-primary);
  background: var(--color-surface-hover);
  color: var(--color-text);
}

.city-card-name,
.category-card-name,
.state-card-name {
  font-weight: 600;
  font-size: var(--text-base);
  color: var(--color-text);
}

.city-card-count,
.category-card-count,
.state-card-count {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-top: var(--space-half);
}

.state-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--sp-1);
  margin-bottom: var(--sp-4);
}

.state-grid--compact {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

.state-link {
  display: block;
  padding: var(--sp-1) var(--sp-2);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  border-radius: var(--radius-md);
  transition: color var(--transition-ui), background var(--transition-ui);
}

.state-link:hover {
  color: var(--color-primary);
  background: var(--color-surface);
}

/* ---------------------------------------------------------------------------
   Home Sections
   --------------------------------------------------------------------------- */
.home-section {
  padding: var(--sp-6) 0;
}

.home-section--alt {
  background: var(--color-surface);
  margin-left: calc(-1 * var(--sp-3));
  margin-right: calc(-1 * var(--sp-3));
  padding-left: var(--sp-3);
  padding-right: var(--sp-3);
}

@media (max-width: 640px) {
  .home-section--alt {
    margin-left: calc(-1 * var(--space-2));
    margin-right: calc(-1 * var(--space-2));
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }
}

.section-inner {
  max-width: var(--max-width);
  margin: 0 auto;
}

.section-inner h2 {
  margin-bottom: var(--sp-3);
}

/* Steps grid */
.steps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-3);
}

.step-card {
  padding: var(--sp-3);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.step-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: var(--color-primary);
  color: var(--color-white);
  font-weight: 700;
  font-size: var(--text-base);
  border-radius: 50%;
  margin-bottom: var(--sp-2);
}

.step-card h3 { margin-bottom: var(--sp-1); }
.step-card p { color: var(--color-text-muted); font-size: var(--text-sm); margin: 0; }

/* Why grid */
.why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-3);
}

.why-item {
  padding: var(--sp-3);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.why-item h3 { margin-bottom: var(--sp-1); }
.why-item p { color: var(--color-text-muted); font-size: var(--text-sm); margin: 0; }

/* Featured grid */
.featured-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--sp-2);
}

.featured-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-half);
  padding: var(--sp-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-ui);
}

.featured-card:hover { border-color: var(--color-primary); }

.featured-title {
  font-weight: 600;
  color: var(--color-text);
}

.featured-location {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.featured-rating {
  font-size: var(--text-sm);
  color: var(--color-accent);
}

/* ---------------------------------------------------------------------------
   Listing Detail Page
   --------------------------------------------------------------------------- */
.listing-detail {
  max-width: var(--max-width);
}

.listing-detail h1 {
  font-size: var(--text-xl);
  margin-bottom: var(--sp-2);
}

.listing-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--sp-2);
  margin-bottom: var(--sp-3);
}

.listing-category-badge {
  padding: 4px var(--sp-1);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.listing-photos {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: var(--sp-2);
  margin-bottom: var(--sp-4);
}

.listing-photos .photo-main img {
  width: 100%;
  border-radius: var(--radius-md);
  aspect-ratio: 16/9;
  object-fit: cover;
}

.listing-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}

@media (min-width: 1024px) {
  .listing-body {
    grid-template-columns: 1fr 280px;
  }
}

.listing-main { min-width: 0; }

.listing-contact {
  margin-bottom: var(--sp-4);
}

.listing-contact h2 {
  margin-bottom: var(--sp-2);
}

.contact-address,
.contact-phone,
.contact-website,
.contact-maps {
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin-bottom: var(--sp-1);
}

.contact-phone a,
.contact-website a,
.contact-maps a {
  color: var(--color-primary);
  transition: color var(--transition-ui);
}

.contact-phone a:hover,
.contact-website a:hover,
.contact-maps a:hover { color: var(--color-primary-hover); }

/* SAB Notice */
.sab-notice {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-1);
  padding: var(--sp-2);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--sp-2);
}

/* Feature Badges */
.feature-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-1);
  margin-bottom: var(--sp-4);
}

.feature-badge {
  padding: 4px 12px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* Hours Table */
.hours-badge {
  margin-bottom: var(--sp-4);
}

.hours-label {
  margin-top: 0;
  margin-bottom: var(--space-2);
  color: var(--color-text);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
}

.hours-table {
  width: 100%;
  border-collapse: collapse;
}

.hours-table td {
  padding: 6px 0;
  font-size: var(--text-sm);
  border-bottom: 1px solid var(--color-border);
}

.hours-day {
  color: var(--color-text-muted);
  width: 120px;
}

.hours-time { color: var(--color-text); }

.hours-today .hours-day,
.hours-today .hours-time {
  color: var(--color-primary);
  font-weight: 500;
}

/* Reviews */
.review-block { margin-bottom: var(--sp-4); }
.review-block-label {
  margin-top: 0;
  margin-bottom: var(--space-2);
  color: var(--color-text);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  line-height: var(--leading-snug);
}

.review-list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.review-item {
  padding: var(--sp-3);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.review-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: var(--sp-1);
}

.review-author {
  font-weight: 500;
  font-size: var(--text-base);
  color: var(--color-text);
}

.review-time {
  display: block;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.review-text {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text);
  margin: 0;
}

/* Listing Sidebar */
.listing-sidebar {
  position: sticky;
  top: 80px;
}

.listing-sidebar h3 {
  font-size: var(--text-base);
  margin-bottom: var(--sp-2);
}

.related-list {
  list-style: none;
  padding: 0;
  margin: 0 0 var(--sp-2) 0;
}

.related-list li {
  margin-bottom: var(--sp-1);
}

.related-list a {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--sp-1);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  transition: background var(--transition-ui), color var(--transition-ui);
}

.related-list a:hover {
  background: var(--color-surface);
  color: var(--color-primary);
}

.related-title { flex: 1; }

.related-rating {
  font-size: var(--text-sm);
  color: var(--color-accent);
  white-space: nowrap;
}

.back-to-city {
  display: block;
  text-align: center;
  padding: var(--sp-1);
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: 500;
}

/* ---------------------------------------------------------------------------
   Static Pages
   --------------------------------------------------------------------------- */
.static-page {
  max-width: 720px;
  margin: 0 auto;
}

.static-page h1 { margin-bottom: var(--sp-4); }

.static-page section {
  margin-bottom: var(--sp-4);
}

.static-page h2 {
  font-size: var(--text-lg);
  margin-bottom: var(--sp-2);
}

.static-page ul {
  padding-left: var(--sp-3);
}

.static-page li {
  margin-bottom: var(--sp-1);
  color: var(--color-text);
}

.policy-date {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--sp-4);
}

.contact-options {
  display: grid;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
}

.contact-option {
  padding: var(--sp-3);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}

.contact-option h3 { margin-bottom: var(--sp-1); }
.contact-option p { color: var(--color-text-muted); margin: 0; font-size: var(--text-sm); }

.contact-email {
  font-size: var(--text-base);
}

/* Guides placeholder */
.guides-placeholder {
  font-size: var(--text-md);
  color: var(--color-text-muted);
  margin-bottom: var(--sp-3);
}

/* State page */
.state-page .state-summary {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin-bottom: var(--sp-4);
}

.state-related,
.state-neighbors {
  margin-top: var(--sp-4);
}

.neighbor-list {
  list-style: none;
  padding: 0;
}

.neighbor-list li { margin-bottom: var(--sp-1); }

.neighbor-list a {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.neighbor-list a:hover { color: var(--color-primary); }

/* Silo page */
.silo-page .silo-summary {
  color: var(--color-text-muted);
  font-size: var(--text-base);
  margin-bottom: var(--sp-4);
}

.silo-top-cities,
.silo-states {
  margin-bottom: var(--sp-4);
}

/* Search page */
.search-page {
  max-width: 720px;
  margin: 0 auto;
}

.search-query {
  font-size: var(--text-md);
  margin-bottom: var(--sp-3);
}

.search-tip {
  color: var(--color-text-muted);
  margin-bottom: var(--sp-4);
}

.search-suggestions-page ul {
  list-style: none;
  padding: 0;
}

.search-suggestions-page li {
  margin-bottom: var(--sp-1);
}

.search-suggestions-page a {
  color: var(--color-primary);
}

/* Ad slot */
.ad-slot {
  margin: var(--sp-4) 0;
  min-height: 90px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
}


/* ========================
   ANTI-VIBE DESIGN SYSTEM OVERRIDES
   ======================== */
/* ── Typography system ─────────────────────────────────────────────
   Applied globally. Components do not redefine these.
*/

body {
  font-family: var(--font-body);
  font-size: var(--text-base);
  font-weight: var(--weight-regular);
  line-height: var(--leading-normal);
  letter-spacing: -0.025em;
  color: var(--color-text-primary);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Heading scale — one definition, used everywhere */
h1 {
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  margin: 0 0 var(--space-1) 0;
  letter-spacing: -0.05em;
}

h2 {
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-heading);
  margin: 0 0 var(--space-1) 0;
  letter-spacing: -0.05em;
}

h3 {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  line-height: var(--leading-snug);
  margin: 0 0 var(--space-half) 0;
  letter-spacing: -0.025em;
}

/* H1 on homepage hero only */
.hero-h1 {
  font-size: var(--text-3xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-display);
  letter-spacing: -0.05em;
}

/* Section label — the small uppercase label above a content block.
   Used consistently everywhere a section needs a title.
   One definition. Applied via class="section-label" in all components.
*/
.section-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--color-text-tertiary);
  margin: 0 0 var(--space-1) 0;
}

/* Meta text — rating counts, distances, secondary info */
.meta-text {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-snug);
}

/* Intro/description text below a page H1 */
.page-intro {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
  max-width: 62ch;
  margin: 0;
}

@media (min-width: 768px) {
  h1 {
    font-size: var(--text-3xl);
  }

  h2 {
    font-size: var(--text-2xl);
    line-height: var(--leading-heading-desktop);
  }

  .hero h1.hero-h1 {
    font-size: var(--text-4xl);
    line-height: var(--leading-display);
  }
}

/* Review text — needs extra line height for readability */
.review-text {
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  color: var(--color-text-secondary);
}

/* ── Page container ────────────────────────────────────────────────*/
.container {
  width: 100%;
  max-width: var(--width-container);
  margin-inline: auto;
  padding-inline: var(--space-3);
}

@media (max-width: 640px) {
  .container { padding-inline: var(--space-2); }
}

/* ── Section spacing ───────────────────────────────────────────────
   Every major page section uses margin-bottom from the scale.
   Never use arbitrary values.
*/
.section { margin-bottom: var(--space-5); }
.section-tight { margin-bottom: var(--space-4); }

/* ── Card internal padding ─────────────────────────────────────────
   All cards use the same internal padding.
   Never override this per-card.
*/
.card-body { padding: var(--space-2) var(--space-3); }
.card-body-sm { padding: var(--space-1) var(--space-2); }

/* ── Button system ─────────────────────────────────────────────────
   All buttons use the same padding, radius, font-size, and height.
   Variants only change color. Never change shape or size.
*/
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  padding: 0 var(--space-2);
  height: 36px;                       /* fixed height — never change */
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  line-height: 1;
  text-decoration: none;
  border: 0.5px solid transparent;
  cursor: pointer;
  transition: background var(--transition-ui), border-color var(--transition-ui),
              color var(--transition-ui);
  white-space: nowrap;
  flex-shrink: 0;
}

.btn i { font-size: 15px; }

/* Primary — call to action */
.btn-primary {
  background: var(--color-text-primary);
  color: var(--color-background-primary);
  border-color: var(--color-text-primary);
}
.btn-primary:hover {
  background: var(--color-text-secondary);
  border-color: var(--color-text-secondary);
}

/* Secondary — default action */
.btn-secondary {
  background: var(--color-background-secondary);
  color: var(--color-text-primary);
  border-color: var(--color-border-secondary);
}
.btn-secondary:hover {
  background: var(--color-background-tertiary);
  border-color: var(--color-border-primary);
}

/* Call button — green semantic */
.btn-call {
  background: var(--color-action-call-bg);
  color: var(--color-action-call);
  border-color: var(--color-action-call-border);
}
.btn-call:hover { background: var(--color-action-call-hover); }

/* Directions button — blue semantic */
.btn-directions {
  background: var(--color-action-map-bg);
  color: var(--color-action-map);
  border-color: var(--color-action-map-border);
}
.btn-directions:hover { background: var(--color-action-map-hover); }

/* Focus state — all buttons */
.btn:focus-visible {
  outline: 2px solid var(--color-text-info);
  outline-offset: 2px;
}

/* Small button variant — used in sidebars */
.btn-sm {
  height: 30px;
  padding: 0 var(--space-1);
  font-size: var(--text-xs);
}

/* ── Card system ───────────────────────────────────────────────────
   All cards share the same border, background, and radius.
   Featured cards get --shadow-card. Regular cards do not.
   No transform on hover. No aggressive shadow on hover.
*/
.card {
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-tertiary);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: border-color var(--transition-ui);
}

.card:hover {
  border-color: var(--color-border-secondary);
  /* That is the only hover change. No transform. No shadow change. */
}

.card-featured {
  border: 1.5px solid var(--color-action-map-border);
  box-shadow: var(--shadow-card);
}

/* ── Badge system ──────────────────────────────────────────────────
   All inline badges use the same base, with semantic variants.
   Border-radius is always 999px for pills, --radius-sm for tags.
*/
.badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  line-height: 1;
  white-space: nowrap;
  border: 0.5px solid transparent;
}

.badge-pill { border-radius: 999px; }
.badge-tag  { border-radius: var(--radius-sm); }

/* Open/closed — status badges */
.badge-open   { background: #EAF3DE; color: #27500A; border-color: #C0DD97; }
.badge-closed { background: #FCEBEB; color: #791F1F; border-color: #F09595; }

/* Brand chip */
.badge-brand {
  background: var(--color-brand-chip-bg);
  color: var(--color-brand-chip-text);
  border-color: var(--color-brand-chip-border);
}

/* Feature chip — neutral */
.badge-feature {
  background: var(--color-background-secondary);
  color: var(--color-text-secondary);
  border-color: var(--color-border-tertiary);
  border-radius: var(--radius-sm);
}

/* ── Filter strip ──────────────────────────────────────────────────
   Filter buttons are identical in shape to .badge-pill but larger.
   Active state changes background. No transform on click.
*/
.filter-strip {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.filter-btn {
  display: inline-flex;
  align-items: center;
  height: 32px;
  padding: 0 var(--space-2);
  border-radius: 999px;
  font-size: var(--text-sm);
  font-weight: var(--weight-regular);
  color: var(--color-text-secondary);
  background: var(--color-background-secondary);
  border: 0.5px solid var(--color-border-secondary);
  cursor: pointer;
  transition: background var(--transition-ui), color var(--transition-ui),
              border-color var(--transition-ui);
  white-space: nowrap;
}

.filter-btn:hover {
  background: var(--color-background-tertiary);
  color: var(--color-text-primary);
  border-color: var(--color-border-primary);
}

.filter-btn.active {
  background: var(--color-text-primary);
  color: var(--color-background-primary);
  border-color: var(--color-text-primary);
  font-weight: var(--weight-medium);
}

/* Mobile: horizontally scrollable, no wrap */
@media (max-width: 640px) {
  .filter-strip {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 2px;
    scrollbar-width: none;
  }
  .filter-strip::-webkit-scrollbar { display: none; }
}

/* ── Breadcrumb ────────────────────────────────────────────────────
   One consistent breadcrumb style. Used on every page.
*/
.breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
  margin-bottom: var(--space-3);
}

.breadcrumb a {
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-ui);
}
.breadcrumb a:hover { color: var(--color-text-primary); }

.breadcrumb-sep {
  color: var(--color-text-tertiary);
  font-size: 12px;
  user-select: none;
}

.breadcrumb-current {
  color: var(--color-text-primary);
  font-weight: var(--weight-medium);
}

/* ── City grid ─────────────────────────────────────────────────────
   Used on state pages and silo root pages.
   Consistent link card — no border radius variation.
*/
.city-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-1);
}

.city-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-1) var(--space-2);
  background: var(--color-background-secondary);
  border: 0.5px solid var(--color-border-tertiary);
  border-radius: var(--radius-md);
  text-decoration: none;
  transition: border-color var(--transition-ui), background var(--transition-ui);
}

.city-link:hover {
  border-color: var(--color-border-secondary);
  background: var(--color-background-primary);
}

.city-link-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
}

.city-link-count {
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
  flex-shrink: 0;
}

/* ── Directory page layout ─────────────────────────────────────────
   City and state pages: main content + sidebar.
   On mobile: stacked, sidebar below.
   On desktop: sidebar pinned to the right.
*/
.directory-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
  align-items: start;
}

@media (min-width: 1024px) {
  .directory-layout {
    grid-template-columns: 1fr 240px;
    gap: var(--space-5);
  }
}

/* ── Sidebar ────────────────────────────────────────────────────── */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.sidebar-block {
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-tertiary);
  border-radius: var(--radius-lg);
  padding: var(--space-2) var(--space-3);
}

.sidebar-block + .sidebar-block { margin-top: 0; } /* gap handles it */

/* ── Navigation ────────────────────────────────────────────────────
   Solid background. No backdrop-filter blur.
   Full-width border-bottom separates from content.
   No box-shadow — the border is the separator.
*/
.site-nav {
  background: var(--color-background-primary);
  border-bottom: 0.5px solid var(--color-border-tertiary);
  position: sticky;
  top: 0;
  z-index: var(--z-nav);
}

.site-nav-inner {
  max-width: var(--width-container);
  margin-inline: auto;
  padding-inline: var(--space-3);
  height: 56px;
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.site-nav-logo {
  font-size: var(--text-md);
  font-weight: var(--weight-medium);
  color: var(--color-text-primary);
  text-decoration: none;
  flex-shrink: 0;
}

.site-nav-search {
  flex: 1;
  max-width: 360px;
}

.site-nav-links {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-left: auto;
}

.site-nav-link {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  text-decoration: none;
  transition: color var(--transition-ui);
}
.site-nav-link:hover { color: var(--color-text-primary); }

/* Mobile nav: hide links, keep logo + search */
@media (max-width: 768px) {
  .site-nav-links { display: none; }
  .site-nav-search { max-width: none; }
}

/* ── Search input ──────────────────────────────────────────────────
   One input style used everywhere. Same height, radius, border.
   Never style the search input differently on different pages.
*/
.search-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}

.search-input {
  width: 100%;
  height: 40px;
  padding: 0 var(--space-2) 0 36px; /* left pad for icon */
  border: 0.5px solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  background: var(--color-background-secondary);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  transition: border-color var(--transition-ui), background var(--transition-ui);
  outline: none;
}

.search-input::placeholder { color: var(--color-text-tertiary); }

.search-input:focus {
  border-color: var(--color-border-primary);
  background: var(--color-background-primary);
}

.search-input-icon {
  position: absolute;
  left: var(--space-1);
  font-size: 16px;
  color: var(--color-text-tertiary);
  pointer-events: none;
}

/* Homepage search — larger */
.search-hero .search-input {
  height: 48px;
  padding-left: 42px;
  font-size: var(--text-base);
  border-radius: var(--radius-lg);
}

.search-hero .search-input-icon { font-size: 18px; left: 12px; }

/* Autocomplete dropdown */
.search-suggestions {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-card);
  z-index: var(--z-overlay);
  overflow: hidden;
  max-height: 320px;
  overflow-y: auto;
}

.search-suggestion-item {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-1) var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: background var(--transition-ui);
}

.search-suggestion-item:hover,
.search-suggestion-item.focused {
  background: var(--color-background-secondary);
}

.search-suggestion-item i {
  font-size: 14px;
  color: var(--color-text-tertiary);
  flex-shrink: 0;
}

.search-suggestion-count {
  margin-left: auto;
  font-size: var(--text-xs);
  color: var(--color-text-tertiary);
}

/* ── Expanded listing card ─────────────────────────────────────────
   Full replacement using design tokens throughout.
   No hardcoded spacing, radius, or color values.
*/
.expanded-card {
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-tertiary);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-4);
  scroll-margin-top: 72px; /* nav height + space-1 */
  transition: border-color var(--transition-ui);
}

.expanded-card:target {
  border-color: var(--color-border-secondary);
}

/* Header */
.ec-header {
  display: flex;
  align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3) var(--space-1);
}

.ec-rank {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  background: var(--color-background-secondary);
  border: 0.5px solid var(--color-border-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  color: var(--color-text-secondary);
  margin-top: 3px;
}

.ec-name {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--color-text-primary);
  margin: 0 0 var(--space-half) 0;
  line-height: var(--leading-snug);
  letter-spacing: -0.025em;
}

.ec-meta {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  flex-wrap: wrap;
}

.ec-no-image {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  height: 100px;
  background: var(--color-background-secondary);
  color: var(--color-text-tertiary);
  font-size: var(--text-sm);
}
.ec-no-image i { font-size: 22px; }

/* Info grid */
.ec-info-grid {
  display: grid;
  grid-template-columns: 1fr;
  padding: var(--space-2) var(--space-3);
  border-bottom: 0.5px solid var(--color-border-tertiary);
  gap: var(--space-2);
}

@media (min-width: 600px) {
  .ec-info-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-3);
  }
  .ec-hours-col {
    border-left: 0.5px solid var(--color-border-tertiary);
    padding-left: var(--space-3);
  }
}

/* Contact buttons */
.ec-contact-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-1);
  margin-bottom: var(--space-1);
}

/* Address */
.ec-address {
  display: flex;
  align-items: flex-start;
  gap: var(--space-1);
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}
.ec-address i { font-size: 14px; color: var(--color-text-tertiary); margin-top: 1px; flex-shrink: 0; }
.ec-address address { font-style: normal; line-height: var(--leading-snug); }

/* Brand chips */
.ec-brand-chips {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-half);
  margin-top: var(--space-half);
}

/* Features */
.ec-features {
  padding: var(--space-1) var(--space-3);
  border-bottom: 0.5px solid var(--color-border-tertiary);
}

/* Reviews */
.ec-reviews {
  padding: var(--space-2) var(--space-3);
}

/* Mobile adjustments */
@media (max-width: 599px) {
  .ec-header { padding: var(--space-2); }
  .ec-info-grid { padding: var(--space-2); }
  .ec-reviews { padding: var(--space-2); }
}
