:root {
  --color-bg: #f6f8fb;
  --color-line: #dbe3ee;
  --color-text: #14233b;
  --color-muted: #5a6b85;
  --color-accent: #1453b8;
  --color-accent-ink: #0e3e8c;
  --color-surface: #ffffff;
  --color-surface-2: #eef3fa;
  --color-good: #0f7a4f;
  --text-sm: 0.9rem;
  --text-base: 1.0625rem;
  --text-lg: 1.35rem;
  --text-xl: 2rem;
  --text-display: 3.25rem;
  --space-xs: 4px; --space-sm: 8px; --space-md: 16px; --space-lg: 32px; --space-xl: 64px;
  --radius-sm: 4px; --radius-md: 8px; --radius-lg: 14px; --radius-pill: 999px;
  --shadow: 0 1px 2px rgba(20, 35, 59, 0.06), 0 10px 26px rgba(20, 35, 59, 0.07);
  --font-display: "Inter", system-ui, -apple-system, Segoe UI, sans-serif;
  --font-body: "Inter", system-ui, -apple-system, Segoe UI, sans-serif;
  --font-mono: ui-monospace, "SF Mono", Menlo, monospace;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font-body); font-size: var(--text-base); line-height: 1.6; background: var(--color-bg); color: var(--color-text); overflow-wrap: break-word; }
a { color: var(--color-accent); }
h1, h2, h3 { font-family: var(--font-display); line-height: 1.15; letter-spacing: -0.01em; }
img { max-width: 100%; }
.skip { position: absolute; left: -9999px; top: 0; background: var(--color-accent); color: #fff; padding: var(--space-sm) var(--space-md); border-radius: var(--radius-sm); z-index: 10; }
.skip:focus { left: var(--space-md); top: var(--space-md); }

.container { max-width: 1100px; margin: 0 auto; padding: 0 var(--space-lg); }
.prose { max-width: 720px; margin: 0 auto; padding: var(--space-xl) var(--space-lg); }
.prose h1 { font-size: var(--text-xl); margin: 0 0 var(--space-md); }
.prose h2 { font-size: var(--text-lg); margin: var(--space-xl) 0 var(--space-sm); }
.prose .muted { color: var(--color-muted); font-size: var(--text-sm); }
.prose ul { padding-left: 1.2em; }
.prose details { border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); margin: var(--space-sm) 0; background: var(--color-surface); }
.prose summary { cursor: pointer; font-weight: 600; }
.prose code { overflow-wrap: anywhere; }

.topbar { border-bottom: 1px solid var(--color-line); background: var(--color-surface); position: sticky; top: 0; z-index: 5; }
.topbar .container { display: flex; align-items: center; gap: var(--space-md); padding-top: var(--space-md); padding-bottom: var(--space-md); }
.brand { display: flex; align-items: center; gap: var(--space-sm); text-decoration: none; color: var(--color-text); font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); }
.brand img { width: 30px; height: 30px; }
.nav { margin-left: auto; display: flex; gap: var(--space-lg); }
.nav a { text-decoration: none; color: var(--color-muted); font-size: var(--text-sm); }
.nav a:hover, .nav a[aria-current="page"] { color: var(--color-text); }

.hero { padding: var(--space-xl) 0 var(--space-lg); }
.hero h1 { font-size: var(--text-display); margin: 0 0 var(--space-md); }
.hero .lead { font-size: var(--text-lg); color: var(--color-muted); max-width: 60ch; margin: 0 0 var(--space-lg); }
.btn { display: inline-block; padding: 12px 22px; border-radius: var(--radius-md); background: var(--color-accent); color: #fff; text-decoration: none; font-family: var(--font-display); font-weight: 600; border: 0; cursor: pointer; font-size: var(--text-base); }
.btn:hover { background: var(--color-accent-ink); }
.btn.small { padding: 8px 14px; font-size: var(--text-sm); }

.note { background: var(--color-surface-2); border: 1px solid var(--color-line); border-radius: var(--radius-md); padding: var(--space-sm) var(--space-md); font-size: var(--text-sm); color: var(--color-muted); margin: var(--space-md) 0; }

.toolbar { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-md); padding: var(--space-md); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
.field { display: grid; gap: 4px; }
.field label { font-size: var(--text-sm); color: var(--color-muted); }
.field input, .field select, .field textarea { padding: 10px 12px; border: 1px solid var(--color-line); border-radius: var(--radius-md); background: var(--color-bg); color: var(--color-text); font: inherit; font-size: var(--text-sm); width: 100%; }
.field textarea { resize: vertical; }
.field input:focus, .field select:focus, .field textarea:focus { outline: 2px solid var(--color-accent); outline-offset: 1px; }
@media (max-width: 760px) { .toolbar { grid-template-columns: 1fr 1fr; } }

.results-meta { display: flex; align-items: center; justify-content: space-between; gap: var(--space-md); margin: var(--space-lg) 0 var(--space-md); flex-wrap: wrap; }
.results-meta h2 { margin: 0; font-size: var(--text-lg); }
.results-meta .count { color: var(--color-muted); font-size: var(--text-sm); }

.grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: var(--space-md); }
.card { border: 1px solid var(--color-line); border-radius: var(--radius-lg); background: var(--color-surface); padding: var(--space-md); display: flex; flex-direction: column; gap: var(--space-sm); box-shadow: var(--shadow); }
.card .top { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-sm); }
.card h3 { margin: 0; font-size: var(--text-lg); }
.card .op { color: var(--color-muted); font-size: var(--text-sm); margin: 0; }
.price { text-align: right; white-space: nowrap; }
.price .amt { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); color: var(--color-accent); }
.price .per { display: block; font-size: 0.72rem; color: var(--color-muted); }
.tags { display: flex; flex-wrap: wrap; gap: 6px; }
.tag { font-size: 0.78rem; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--color-surface-2); color: var(--color-muted); }
.tag.type { background: var(--color-accent); color: #fff; }
.tag.ok { background: #e3f3ec; color: var(--color-good); }
.card .access { font-size: var(--text-sm); color: var(--color-text); margin: 0; }
.card .blurb { font-size: var(--text-sm); color: var(--color-muted); margin: 0; }
.card .actions { display: flex; align-items: center; justify-content: space-between; gap: var(--space-sm); margin-top: auto; padding-top: var(--space-sm); }
.card .compare-toggle { display: flex; align-items: center; gap: var(--space-sm); font-size: var(--text-sm); color: var(--color-muted); }

.empty { padding: var(--space-xl); text-align: center; color: var(--color-muted); border: 1px dashed var(--color-line); border-radius: var(--radius-lg); }

.compare-bar { position: sticky; bottom: 0; background: var(--color-text); color: #fff; border-radius: var(--radius-lg); padding: var(--space-sm) var(--space-md); display: flex; align-items: center; gap: var(--space-md); margin-top: var(--space-lg); box-shadow: var(--shadow); flex-wrap: wrap; }
.compare-bar .names { flex: 1; font-size: var(--text-sm); }
.compare-bar .link { background: none; border: 0; color: #fff; text-decoration: underline; cursor: pointer; font: inherit; font-size: var(--text-sm); }
.compare-wrap { overflow-x: auto; margin: var(--space-lg) 0; border: 1px solid var(--color-line); border-radius: var(--radius-lg); }
table.compare { width: 100%; border-collapse: collapse; font-size: var(--text-sm); background: var(--color-surface); }
table.compare th, table.compare td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--color-line); }
table.compare thead th { background: var(--color-surface-2); font-family: var(--font-display); }
table.compare td.best { color: var(--color-good); font-weight: 700; }
table.compare th[scope="row"] { color: var(--color-muted); font-weight: 400; }

.section { padding: var(--space-xl) 0; }
.section h2 { font-size: var(--text-xl); margin: 0 0 var(--space-md); }
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); }
.feature { border: 1px solid var(--color-line); border-radius: var(--radius-lg); padding: var(--space-md); background: var(--color-surface); }
.feature h3 { margin: 0 0 var(--space-xs); font-size: var(--text-lg); }
.feature p { margin: 0; color: var(--color-muted); font-size: var(--text-sm); }

.site-footer { margin-top: var(--space-xl); border-top: 1px solid var(--color-line); background: var(--color-surface); }
.site-footer .container { padding-top: var(--space-lg); padding-bottom: var(--space-lg); display: flex; flex-wrap: wrap; gap: var(--space-md) var(--space-xl); justify-content: space-between; color: var(--color-muted); font-size: var(--text-sm); }
.site-footer nav { display: flex; flex-wrap: wrap; gap: var(--space-md); }
.site-footer a { color: var(--color-muted); }
.site-footer a:hover { color: var(--color-text); }
.site-footer .legal { max-width: 48ch; }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; }

@media (max-width: 600px) {
  .topbar .container { flex-wrap: wrap; row-gap: var(--space-sm); }
  .nav { margin-left: 0; width: 100%; gap: var(--space-md); flex-wrap: wrap; }
  .hero h1 { font-size: 2.2rem; }
  .container { padding-left: var(--space-md); padding-right: var(--space-md); }
  .prose { padding-left: var(--space-md); padding-right: var(--space-md); }
}

/* SEO "at a glance" quick answers */
.quickanswers { padding-top: var(--space-lg); }
.ataglance { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-md); margin: var(--space-md) 0; padding: 0; }
.ataglance > div { border: 1px solid var(--color-line, #dbe3ef); border-radius: 12px; padding: var(--space-md); background: var(--color-surface, #fff); }
.ataglance dt { font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.04em; color: var(--color-muted, #5a6b82); margin-bottom: 4px; }
.ataglance dd { margin: 0; }

/* =========================================================================
 * Parking cost estimator (/estimate.html) + homepage hero teaser.
 * Scoped .est-* styles only; reuses the site tokens (--color-accent #1453b8,
 * surfaces, lines, spacing, radii) and the shared .btn / .field / .note.
 * Desktop (>=768px): a real <table class="est-table">. Mobile (<768px): the
 * same table collapses to stacked cards via display:block + data-label rows.
 * ========================================================================= */

/* --- Homepage hero teaser card --- */
.est-hero { margin: var(--space-lg) 0; padding: var(--space-md) var(--space-lg); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); box-shadow: var(--shadow); max-width: 720px; }
.est-hero-title { margin: 0 0 var(--space-xs); font-size: var(--text-lg); }
.est-hero-lead { margin: 0 0 var(--space-md); font-size: var(--text-sm); }
.est-hero-fields { display: grid; grid-template-columns: 1fr 1fr auto; gap: var(--space-md); align-items: end; }
.est-hero-fields .btn { white-space: nowrap; }
@media (max-width: 600px) { .est-hero-fields { grid-template-columns: 1fr; } .est-hero-fields .btn { width: 100%; } }

/* --- Estimator controls (inputs + sort) on /estimate.html --- */
.est-controls { margin: var(--space-lg) 0 var(--space-md); }
.est-fields { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--space-md); padding: var(--space-md); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); box-shadow: var(--shadow); }
@media (max-width: 700px) { .est-fields { grid-template-columns: 1fr; } }

/* --- Results summary + duration badge --- */
.est-summary { display: flex; align-items: center; gap: var(--space-md); flex-wrap: wrap; margin: var(--space-lg) 0 var(--space-md); }
.est-duration-badge { display: inline-block; font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); background: var(--color-surface-2); color: var(--color-text); padding: 6px 14px; border-radius: var(--radius-pill); border: 1px solid var(--color-line); }
.est-summary-note { font-size: var(--text-sm); }

/* --- Results table (desktop) --- */
.est-table { width: 100%; border-collapse: collapse; background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); overflow: hidden; font-size: var(--text-sm); }
.est-table thead th { text-align: left; background: var(--color-surface-2); font-family: var(--font-display); font-size: var(--text-sm); padding: 10px 14px; border-bottom: 1px solid var(--color-line); }
.est-table td { padding: 14px; border-bottom: 1px solid var(--color-line); vertical-align: top; }
.est-table tbody tr:last-child td { border-bottom: 0; }
.est-cell-name .est-name { font-family: var(--font-display); font-weight: 700; font-size: var(--text-base); display: block; }
.est-cell .est-meta { display: block; margin-top: 6px; }
.est-total { font-family: var(--font-display); font-weight: 700; font-size: var(--text-lg); color: var(--color-accent); display: block; }
.est-per { display: block; font-size: 0.78rem; color: var(--color-muted); margin-top: 2px; }
.est-row-best { background: #eef6ff; }
.est-row-best td { border-top: 2px solid var(--color-accent); }

/* Best-value badge (accent) */
.est-badge-best { display: inline-block; font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em; background: var(--color-accent); color: #fff; padding: 2px 8px; border-radius: var(--radius-pill); vertical-align: middle; }

/* Parking type badge (+ covered/open) */
.est-type-badge { display: inline-block; font-size: 0.72rem; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--color-surface-2); color: var(--color-muted); border: 1px solid var(--color-line); }
.est-type-terminal { background: var(--color-accent); color: #fff; border-color: var(--color-accent); }
.est-type-valet { background: #efe9ff; color: #5b3bb8; border-color: #d9ccf7; }
.est-type-long-stay { background: #e3f3ec; color: var(--color-good); border-color: #bfe6d3; }
.est-type-off-site { background: #fff3e0; color: #a5610a; border-color: #f3dcb5; }

/* Amenities list */
.est-amenities { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 6px; }
.est-amenities li { font-size: 0.72rem; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--color-surface-2); color: var(--color-muted); }

/* Star rating */
.est-rating { display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.est-stars { color: #e6a700; letter-spacing: 1px; font-size: var(--text-base); }
.est-rating-num { color: var(--color-muted); font-size: var(--text-sm); }

/* Book Now button reuses .btn; keep it compact + full-width in card mode */
.est-book { padding: 8px 16px; font-size: var(--text-sm); }

.est-disclaimer { margin: var(--space-md) 0 0; font-size: var(--text-sm); }

/* --- Loading state --- */
.est-loading { color: var(--color-muted); font-size: var(--text-sm); margin: var(--space-md) 0 var(--space-sm); }
.est-shimmer { height: 56px; border-radius: var(--radius-md); margin-bottom: var(--space-sm); background: linear-gradient(90deg, var(--color-surface-2) 25%, #e6edf7 37%, var(--color-surface-2) 63%); background-size: 400% 100%; animation: est-shimmer 1.2s ease-in-out infinite; }
@keyframes est-shimmer { 0% { background-position: 100% 0; } 100% { background-position: 0 0; } }
@media (prefers-reduced-motion: reduce) { .est-shimmer { animation: none; } }

.est-empty { padding: var(--space-lg); text-align: center; color: var(--color-muted); border: 1px dashed var(--color-line); border-radius: var(--radius-lg); }

/* --- Mobile: collapse the table into stacked cards (<768px) --- */
@media (max-width: 767px) {
  .est-table, .est-table thead, .est-table tbody, .est-table tr, .est-table td { display: block; width: 100%; }
  .est-table { border: 0; background: transparent; overflow: visible; }
  .est-table thead { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); border: 0; } /* hide header row; use data-labels instead */
  .est-row.est-card, .est-table tbody tr { margin: 0 0 var(--space-md); background: var(--color-surface); border: 1px solid var(--color-line); border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
  .est-table td { border-bottom: 1px solid var(--color-line); padding: 10px 14px; display: flex; justify-content: space-between; gap: var(--space-md); align-items: baseline; }
  .est-table td::before { content: attr(data-label); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.03em; color: var(--color-muted); font-weight: 600; flex: 0 0 auto; }
  .est-table td.est-cell-name { flex-direction: column; align-items: flex-start; }
  .est-table td.est-cell-name::before { display: none; }
  .est-table td.est-cell-amenities { flex-direction: column; align-items: flex-start; }
  .est-table td.est-cell-book { justify-content: stretch; }
  .est-table td.est-cell-book::before { display: none; }
  .est-book { width: 100%; text-align: center; }
  .est-row-best { background: #eef6ff; }
  .est-row-best td:first-child { border-top: 3px solid var(--color-accent); }
}

/* Make the best-value card visually first/sticky-feeling when sorting by cheapest. */
.est-table-sticky-best .est-row-best { position: relative; }
.est-table-sticky-best .est-row-best::after { content: ""; }
