/* ╔════════════════════════════════════════════════════════════════╗
   ║ Inner-page chrome — shared across events, restaurants, good-   ║
   ║ news, best-of, insider, towns, and town hubs.                  ║
   ╚════════════════════════════════════════════════════════════════╝ */

/* ── Breadcrumb ─────────────────────────────────────────────────── */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--s-3);
}
.breadcrumb a { color: var(--muted); text-decoration: none; }
.breadcrumb a:hover { color: var(--accent-deep); }
.breadcrumb svg { color: var(--muted-2); }

/* ── Page hero ──────────────────────────────────────────────────── */
.page-hero {
  padding-block: var(--s-12) var(--s-10);
  border-bottom: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.page-hero--lift {
  background:
    radial-gradient(ellipse 50% 35% at 90% 0%, rgba(226,207,159,0.32), transparent 65%),
    linear-gradient(180deg, var(--paper) 0%, var(--paper-2) 100%);
}
.page-hero--ink {
  background:
    radial-gradient(ellipse 60% 50% at 18% 0%, rgba(255,225,180,0.10), transparent 60%),
    linear-gradient(170deg, #061620 0%, var(--ink) 50%, var(--sound-deep) 100%);
  color: var(--paper);
  border-bottom-color: transparent;
}
.page-hero--ink h1, .page-hero--ink .lead { color: var(--paper); }
.page-hero--ink .eyebrow { color: var(--sand); }
.page-hero--ink .breadcrumb { color: rgba(251,246,236,0.65); }
.page-hero--ink .breadcrumb a { color: rgba(251,246,236,0.65); }
.page-hero--ink .breadcrumb a:hover { color: var(--paper); }

.page-hero__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: var(--gutter-lg);
  align-items: end;
}
.page-hero__grid--center { grid-template-columns: 1fr; max-width: 56ch; }
.page-hero__copy { padding-bottom: 6px; }
.page-hero h1 {
  font-size: clamp(2.25rem, 4.5vw, 4rem);
  letter-spacing: -0.02em;
  line-height: 1.0;
  margin-top: var(--s-3);
  text-wrap: balance;
}
.page-hero .lead {
  margin-top: var(--s-4);
  max-width: 56ch;
}
.page-hero__cta { margin-top: var(--s-5); display: flex; gap: var(--s-3); flex-wrap: wrap; }

.page-hero__img {
  position: relative;
  border-radius: var(--r-3);
  overflow: hidden;
  box-shadow: var(--sh-3);
  aspect-ratio: 4 / 3;
}
.page-hero__img .img { height: 100%; }

@media (max-width: 900px) {
  .page-hero { padding-block: var(--s-8); }
  .page-hero__grid { grid-template-columns: 1fr; }
  .page-hero__img { order: -1; aspect-ratio: 16 / 9; }
}

/* ── Filter bar ─────────────────────────────────────────────────── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: var(--s-2);
  flex-wrap: wrap;
  padding: var(--s-3);
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  position: sticky;
  top: 80px;
  z-index: 20;
  box-shadow: var(--sh-1);
}
.filter-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--ff-sans);
  font-size: var(--fs-13);
  font-weight: 500;
  padding: 8px 14px;
  border-radius: var(--r-pill);
  background: var(--paper-2);
  color: var(--ink-2);
  border: 1px solid transparent;
  text-decoration: none;
  cursor: pointer;
  transition: background 120ms ease, color 120ms ease;
}
.filter-pill:hover { background: var(--sand-pale); color: var(--ink); }
.filter-pill[aria-pressed="true"], .filter-pill--active { background: var(--ink); color: var(--paper); }
.filter-pill__caret { color: var(--muted-2); }
.filter-pill__count {
  margin-left: 2px;
  font-family: var(--ff-mono);
  color: var(--muted);
  font-size: var(--fs-12);
}
.filter-pill[aria-pressed="true"] .filter-pill__count,
.filter-pill--active .filter-pill__count { color: rgba(251,246,236,0.6); }

.filter-bar__group { display: flex; align-items: center; gap: var(--s-2); flex-wrap: wrap; }
.filter-bar__divider {
  width: 1px;
  height: 24px;
  background: var(--line);
}
.filter-bar__search {
  flex: 1;
  min-width: 200px;
  position: relative;
}
.filter-bar__search input {
  width: 100%;
  font-family: var(--ff-sans);
  font-size: var(--fs-14);
  padding: 10px 14px 10px 36px;
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  background: var(--paper-2);
  color: var(--ink);
}
.filter-bar__search input:focus { outline: 2px solid var(--accent); outline-offset: -2px; background: var(--paper); }
.filter-bar__search svg { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--muted); }
.filter-bar__count {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  color: var(--muted);
  letter-spacing: 0.04em;
  margin-left: auto;
}
@media (max-width: 700px) {
  .filter-bar { position: static; flex-direction: column; align-items: stretch; }
  .filter-bar__group { overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; margin-inline: -4px; padding-inline: 4px; }
  .filter-bar__divider { display: none; }
  .filter-bar__count { margin-left: 0; text-align: right; }
}

/* ── Pagination ─────────────────────────────────────────────────── */
.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--s-2);
  margin-top: var(--s-10);
  font-family: var(--ff-mono);
  font-size: var(--fs-13);
  letter-spacing: 0.04em;
}
.pagination a, .pagination span {
  min-width: 36px;
  height: 36px;
  padding: 0 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-2);
  border: 1px solid var(--line);
  color: var(--ink-2);
  text-decoration: none;
  background: var(--paper);
}
.pagination a:hover { border-color: var(--ink); background: var(--paper-2); }
.pagination .is-current { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.pagination .pg-ellipsis { border: 0; background: transparent; color: var(--muted); }

/* ── Article (good-news detail, restaurant review) ──────────────── */
.article {
  max-width: 72ch;
  margin: 0 auto;
}
.article__hero {
  aspect-ratio: 16 / 9;
  border-radius: var(--r-3);
  overflow: hidden;
  position: relative;
  margin-bottom: var(--s-6);
}
.article__hero .img { height: 100%; }
.article__head { margin-bottom: var(--s-6); }
.article h1 {
  font-size: clamp(2rem, 3vw + 1rem, 3rem);
  line-height: 1.05;
  margin-top: var(--s-3);
}
.article__byline {
  display: flex;
  gap: var(--s-4);
  align-items: center;
  margin-top: var(--s-4);
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}
.article__body {
  font-family: var(--ff-display);
  font-size: var(--fs-18);
  line-height: 1.6;
  color: var(--ink-2);
}
.article__body p { margin: 0 0 var(--s-4); }
.article__body p:first-of-type::first-letter {
  font-size: 4rem;
  font-weight: 700;
  float: left;
  line-height: 0.85;
  padding: 0.1em 0.1em 0 0;
  color: var(--accent);
  font-family: var(--ff-display);
}
.article__body blockquote {
  margin: var(--s-5) 0;
  padding-left: var(--s-4);
  border-left: 3px solid var(--accent);
  font-style: italic;
  color: var(--ink);
}

/* ── Detail meta strip (restaurant detail, etc.) ────────────────── */
.detail-meta {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-4) var(--s-6);
  padding: var(--s-4) var(--s-5);
  background: var(--paper-2);
  border-radius: var(--r-2);
  border: 1px solid var(--line);
  margin: var(--s-5) 0;
}
.detail-meta dt {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2px;
}
.detail-meta dd {
  font-family: var(--ff-sans);
  font-size: var(--fs-15);
  color: var(--ink);
  font-weight: 500;
  margin: 0;
}

/* ── Empty / null state ─────────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: var(--s-12) var(--s-4);
  color: var(--muted);
}
.empty-state h3 { font-size: var(--fs-20); color: var(--ink); margin-bottom: 8px; }
.empty-state p { max-width: 40ch; margin: 0 auto; }

/* ── Detail page two-col layout (sidebar) ───────────────────────── */
.detail-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: var(--gutter-lg);
  align-items: start;
}
.detail-layout aside { position: sticky; top: 100px; display: flex; flex-direction: column; gap: var(--s-4); }
.aside-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
}
.aside-card h4 {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: var(--s-3);
  font-weight: 500;
}
@media (max-width: 900px) {
  .detail-layout { grid-template-columns: 1fr; }
  .detail-layout aside { position: static; }
}

/* ── Calendar list (events index) ───────────────────────────────── */
.cal-day {
  display: grid;
  grid-template-columns: 120px 1fr;
  gap: var(--gutter);
  padding: var(--s-6) 0;
  border-top: 1px solid var(--line);
}
.cal-day:first-of-type { border-top: 0; padding-top: 0; }
.cal-day__date {
  position: sticky;
  top: 160px;
  align-self: start;
}
.cal-day__weekday {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-deep);
  margin-bottom: 4px;
}
.cal-day__num {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: var(--fs-48);
  line-height: 0.9;
  color: var(--ink);
}
.cal-day__month {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 4px;
}
.cal-day__count {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  color: var(--muted);
  margin-top: var(--s-3);
}
.cal-day__events {
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
@media (max-width: 900px) {
  .cal-day { grid-template-columns: 1fr; padding: var(--s-5) 0; }
  .cal-day__date { position: static; display: flex; align-items: baseline; gap: var(--s-3); }
  .cal-day__weekday { margin-bottom: 0; }
  .cal-day__num { font-size: var(--fs-30); }
  .cal-day__month { margin-top: 0; }
  .cal-day__count { margin-top: 0; margin-left: auto; }
}

/* ── Best of: category card ─────────────────────────────────────── */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-4);
}
.cat-card {
  background: var(--paper);
  border: 1px solid var(--line);
  border-radius: var(--r-2);
  padding: var(--s-5);
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: var(--s-4);
  align-items: center;
  text-decoration: none;
  color: inherit;
  transition: border-color 120ms ease, box-shadow 120ms ease, transform 120ms ease;
}
.cat-card:hover { border-color: var(--ink); box-shadow: var(--sh-2); transform: translateY(-1px); }
.cat-card__medal {
  display: grid;
  place-items: center;
  width: 56px; height: 56px;
  background: radial-gradient(circle at 35% 30%, #f4d488 0%, #e0a64a 70%, #c08a2a 100%);
  color: var(--ink);
  border-radius: 50%;
  font-family: var(--ff-display);
  font-size: var(--fs-24);
  font-weight: 700;
  box-shadow: 0 4px 10px rgba(196, 89, 32, 0.22);
}
.cat-card__cat {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--accent-deep);
}
.cat-card__name {
  font-family: var(--ff-display);
  font-weight: 600;
  font-size: var(--fs-20);
  color: var(--ink);
  line-height: 1.15;
  margin-top: 4px;
}
.cat-card__town {
  font-size: var(--fs-13);
  color: var(--muted);
  margin-top: 4px;
}
.cat-card__cta {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.06em;
  color: var(--muted);
  text-align: right;
  white-space: nowrap;
}
@media (max-width: 700px) {
  .cat-grid { grid-template-columns: 1fr; }
  .cat-card { grid-template-columns: 48px 1fr; }
  .cat-card__cta { grid-column: 1 / -1; text-align: left; }
}

/* ── Insider pricing table ──────────────────────────────────────── */
.compare {
  width: 100%;
  border-collapse: collapse;
  margin-top: var(--s-6);
  border-radius: var(--r-2);
  overflow: hidden;
  border: 1px solid var(--line);
}
.compare th, .compare td {
  padding: 14px 18px;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.compare th {
  font-family: var(--ff-mono);
  font-size: var(--fs-12);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  font-weight: 500;
  background: var(--paper-2);
}
.compare td.has-check { color: var(--positive); font-weight: 700; }
.compare td.no-check { color: var(--muted); }
.compare th.feat-col { text-align: center; }
.compare td.feat-col { text-align: center; width: 140px; }
.compare th.featured { background: var(--accent); color: #fff; }
.compare tr:last-child td { border-bottom: 0; }

/* ── Town hub header ────────────────────────────────────────────── */
.town-hub-strip {
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--r-2);
  padding: var(--s-4) var(--s-5);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
}
.town-hub-strip__eyebrow { font-family: var(--ff-mono); font-size: var(--fs-12); letter-spacing: 0.12em; text-transform: uppercase; color: var(--sand); }
.town-hub-strip__title { font-family: var(--ff-display); font-weight: 600; font-size: var(--fs-20); }
.town-hub-strip__meta { display: flex; gap: var(--s-3); font-family: var(--ff-mono); font-size: var(--fs-12); color: var(--sand-pale); }

/* ── Insider tier comparison page (large) ───────────────────────── */
.tier-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-5);
}
.tier-grid .tier { padding: var(--s-6) var(--s-5); }
.tier-grid .tier__price { font-size: var(--fs-48); }
@media (max-width: 700px) { .tier-grid { grid-template-columns: 1fr; } }
