/* ============================================================
   CCCC EDITORIAL — shared design system for Home/Restaurants/Cities
   ============================================================ */

.ed-page {
  --ink: #14121a;
  --cream: #f7f2e8;
  --bone: #eae3d2;
  --oxblood: #5a1e2a;
  --lime: #d8f35a;
  --violet: #7b4fe0;
  --hair: rgba(20,18,26,.12);
  --hair-strong: rgba(20,18,26,.32);
  --mute: rgba(20,18,26,.55);

  background: var(--cream);
  color: var(--ink);
  font-family: var(--font-body, 'Inter', system-ui, sans-serif);
}
[data-theme="dark"] .ed-page {
  --ink: #f7f2e8;
  --cream: #14121a;
  --bone: #22202a;
  --oxblood: #c46470;
  --hair: rgba(247,242,232,.12);
  --hair-strong: rgba(247,242,232,.32);
  --mute: rgba(247,242,232,.55);
  background: var(--cream);
  color: var(--ink);
}

/* Break out of the site's default wrap for full-bleed heroes */
.ed-page .ed-bleed {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
}

.ed-page .ed-wrap {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 1.75rem;
}

/* ── Type scale ──────────────────────────────── */
.ed-colossus {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif);
  font-size: clamp(4rem, 12vw, 9.5rem);
  font-weight: 900;
  letter-spacing: -0.04em;
  line-height: .9;
  color: var(--ink);
}
.ed-mast {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif);
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1;
}
.ed-section-head {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif);
  font-size: clamp(1.6rem, 3vw, 2.6rem);
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.05;
  margin: 0 0 1.5rem;
}
.ed-eyebrow {
  font-family: var(--font-mono, 'IBM Plex Mono', ui-monospace, monospace);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .18em;
  color: var(--mute);
  margin: 0 0 .4rem;
}
.ed-pull {
  font-family: var(--font-display, 'Playfair Display', Georgia, serif);
  font-style: italic;
  font-size: clamp(1.1rem, 1.8vw, 1.4rem);
  line-height: 1.4;
  color: var(--ink);
}
.ed-caption {
  font-family: var(--font-mono, 'IBM Plex Mono', ui-monospace, monospace);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mute);
}
.ed-mono {
  font-family: var(--font-mono, 'IBM Plex Mono', ui-monospace, monospace);
  font-size: .82rem;
}

/* ── Hero ────────────────────────────────────── */
.ed-hero {
  padding: clamp(3rem, 8vw, 6.5rem) 0 clamp(2rem, 5vw, 4rem);
  border-bottom: 1px solid var(--hair);
}
.ed-hero-inner {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(2rem, 5vw, 5rem);
  align-items: start;
}
@media (max-width: 860px) {
  .ed-hero-inner { grid-template-columns: 1fr; }
}

/* ── StatStrip ───────────────────────────────── */
.ed-stat-strip {
  display: flex;
  gap: 0;
  margin-top: 2rem;
  flex-wrap: wrap;
  border-top: 1px solid var(--hair-strong);
  border-bottom: 1px solid var(--hair-strong);
  padding: 1rem 0;
}
.ed-stat {
  padding: .25rem 1.25rem;
  border-right: 1px solid var(--hair);
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.ed-stat:first-child { padding-left: 0; }
.ed-stat:last-child { border-right: none; }
.ed-stat-num {
  font-family: var(--font-display, serif);
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.02em;
}
.ed-stat-lbl {
  font-family: var(--font-mono, monospace);
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mute);
}

/* ── ScoreMedallion ──────────────────────────── */
.ed-medal {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 4rem; height: 4rem;
  border-radius: 50%;
  border: 2px solid var(--ink);
  font-family: var(--font-display, serif);
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: -.04em;
  background: var(--cream);
  color: var(--ink);
  flex-shrink: 0;
}
.ed-medal.ed-medal-lg {
  width: 6.5rem; height: 6.5rem;
  font-size: 2.8rem;
}
.ed-medal.is-elite { background: var(--oxblood); color: #fff1d9; border-color: var(--oxblood); }
.ed-medal.is-great { background: var(--bone); }
.ed-medal.is-meh   { background: transparent; color: var(--mute); border-color: var(--hair-strong); }

/* ── FeatureCard ─────────────────────────────── */
.ed-feature {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--bone);
  border: 1px solid var(--hair);
  padding: 1.75rem;
  position: relative;
  transition: transform .18s ease, box-shadow .18s ease;
}
.ed-feature:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px -8px rgba(20,18,26,.25);
  text-decoration: none;
  color: inherit;
}
.ed-feature-banner {
  position: absolute;
  top: -1px; left: -1px;
  background: var(--oxblood);
  color: #fff1d9;
  font-family: var(--font-mono, monospace);
  font-size: .6rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  padding: .35rem .75rem;
  font-weight: 700;
}
.ed-feature-title {
  font-family: var(--font-display, serif);
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1.05;
  margin: 1.75rem 0 .4rem;
  letter-spacing: -.01em;
}
.ed-feature-meta {
  font-family: var(--font-mono, monospace);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--mute);
  margin-bottom: 1rem;
}
.ed-feature-quote {
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: 1.02rem;
  line-height: 1.45;
  color: var(--ink);
  border-left: 2px solid var(--oxblood);
  padding-left: .9rem;
  margin: 1rem 0 0;
}
.ed-feature .ed-medal {
  position: absolute;
  top: 1.25rem; right: 1.25rem;
}

/* ── RankRail ────────────────────────────────── */
.ed-rail {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 1fr);
  gap: 1.25rem;
  overflow-x: auto;
  padding: .25rem .25rem 1.25rem;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
}
.ed-rail::-webkit-scrollbar { height: 8px; }
.ed-rail::-webkit-scrollbar-thumb { background: var(--hair-strong); }
.ed-rail-card {
  display: flex;
  flex-direction: column;
  padding: 1.25rem;
  border: 1px solid var(--hair);
  background: var(--cream);
  text-decoration: none;
  color: inherit;
  scroll-snap-align: start;
  position: relative;
  min-height: 160px;
  transition: background .15s ease;
}
.ed-rail-card:hover { background: var(--bone); text-decoration: none; color: inherit; }
.ed-rail-rank {
  font-family: var(--font-display, serif);
  font-size: 3.5rem;
  font-weight: 900;
  line-height: 1;
  color: var(--hair-strong);
  letter-spacing: -.04em;
}
.ed-rail-name {
  font-family: var(--font-display, serif);
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.15;
  margin: .5rem 0 .25rem;
}
.ed-rail-sub {
  font-family: var(--font-mono, monospace);
  font-size: .66rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--mute);
}
.ed-rail-score {
  position: absolute;
  top: 1rem; right: 1rem;
  font-family: var(--font-display, serif);
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -.02em;
}

/* ── PostageStamp ────────────────────────────── */
.ed-stamp {
  display: block;
  text-decoration: none;
  color: inherit;
  background: var(--bone);
  padding: 1.4rem 1.25rem 1.2rem;
  position: relative;
  --dot-size: 10px;
  --dot-bg: var(--cream);
  -webkit-mask-image:
    radial-gradient(circle at var(--dot-size) 50%, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at calc(100% - var(--dot-size)) 50%, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at 50% 0, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at 50% 100%, transparent var(--dot-size), #000 var(--dot-size)),
    linear-gradient(#000,#000);
          mask-image:
    radial-gradient(circle at var(--dot-size) 50%, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at calc(100% - var(--dot-size)) 50%, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at 50% 0, transparent var(--dot-size), #000 var(--dot-size)),
    radial-gradient(circle at 50% 100%, transparent var(--dot-size), #000 var(--dot-size)),
    linear-gradient(#000,#000);
  transition: transform .18s ease;
}
.ed-stamp:hover {
  transform: rotate(-1.5deg) translateY(-2px);
  text-decoration: none; color: inherit;
}
.ed-stamp-count {
  font-family: var(--font-display, serif);
  font-size: 3.4rem;
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.04em;
}
.ed-stamp-count-lbl {
  font-family: var(--font-mono, monospace);
  font-size: .58rem;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--mute);
  display: block;
  margin-bottom: .75rem;
}
.ed-stamp-name {
  font-family: var(--font-display, serif);
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.1;
  margin: .4rem 0 .15rem;
}
.ed-stamp-country {
  font-family: var(--font-mono, monospace);
  font-size: .62rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mute);
}
.ed-stamp-foot {
  margin-top: .85rem;
  padding-top: .55rem;
  border-top: 1px dashed var(--hair-strong);
  font-family: var(--font-mono, monospace);
  font-size: .65rem;
  color: var(--mute);
  line-height: 1.3;
}
.ed-stamp.is-return {
  opacity: .72;
  position: relative;
}
.ed-stamp.is-return::after {
  content: 'RETURN';
  position: absolute;
  top: 30%; left: 10%;
  transform: rotate(-8deg);
  font-family: var(--font-mono, monospace);
  font-weight: 800;
  font-size: 1.5rem;
  letter-spacing: .15em;
  color: var(--oxblood);
  border: 3px solid var(--oxblood);
  padding: .2rem .5rem;
  opacity: .55;
  pointer-events: none;
}

/* ── ReceiptTicket (visit excerpt) ───────────── */
.ed-receipt {
  background: #fefdfb;
  color: #222;
  font-family: var(--font-mono, monospace);
  padding: 1rem 1.1rem;
  max-width: 280px;
  position: relative;
  font-size: .8rem;
  line-height: 1.4;
}
.ed-receipt::before, .ed-receipt::after {
  content: '';
  position: absolute;
  left: 0; right: 0;
  height: 8px;
  background: repeating-conic-gradient(#e8e4de 0% 25%, transparent 0% 50%) 0 0 / 8px 8px;
}
.ed-receipt::before { top: -4px; }
.ed-receipt::after  { bottom: -4px; }
.ed-receipt-head {
  text-align: center;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .82rem;
  margin-bottom: .4rem;
}
.ed-receipt-row {
  display: flex; justify-content: space-between;
  border-bottom: 1px dotted #bbb;
  padding: .15rem 0;
}
.ed-receipt-row:last-child { border-bottom: none; }

/* ── QuoteBlock ──────────────────────────────── */
.ed-quote {
  padding: 2rem 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  margin: 2rem 0;
}
.ed-quote-text {
  font-family: var(--font-display, serif);
  font-size: clamp(1.4rem, 2.6vw, 2rem);
  font-style: italic;
  line-height: 1.3;
  color: var(--ink);
}
.ed-quote-cite {
  font-family: var(--font-mono, monospace);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--mute);
  margin-top: 1rem;
}
.ed-quote-cite a { color: var(--ink); border-bottom: 1px solid var(--hair-strong); text-decoration: none; }
.ed-quote-cite a:hover { border-color: var(--oxblood); color: var(--oxblood); }

/* ── Section layouts ─────────────────────────── */
.ed-section {
  padding: clamp(3rem, 7vw, 6rem) 0;
  border-top: 1px solid var(--hair);
}
.ed-section-head-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1.5rem;
  gap: 2rem;
  flex-wrap: wrap;
}
.ed-section-head-row .ed-section-head { margin: 0; }

.ed-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.ed-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.25rem;
}
.ed-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}
@media (max-width: 860px) {
  .ed-grid-3, .ed-grid-4, .ed-grid-2 { grid-template-columns: 1fr; }
}

/* ── Index Rows (archive list) ───────────────── */
.ed-index-row {
  display: grid;
  grid-template-columns: 4.5rem 1fr auto 4.5rem;
  gap: 1.5rem;
  align-items: center;
  padding: 1.35rem 0;
  border-bottom: 1px solid var(--hair);
  text-decoration: none;
  color: inherit;
  transition: background .12s ease;
}
.ed-index-row:hover {
  background: var(--bone);
  color: inherit; text-decoration: none;
  box-shadow: inset 4px 0 0 var(--oxblood);
  padding-left: .75rem;
}
.ed-index-rank {
  font-family: var(--font-display, serif);
  font-size: 2.4rem;
  font-weight: 900;
  color: var(--hair-strong);
  letter-spacing: -.03em;
  line-height: 1;
}
.ed-index-title {
  font-family: var(--font-display, serif);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -.01em;
  line-height: 1.1;
  margin-bottom: .25rem;
}
.ed-index-sub {
  font-family: var(--font-mono, monospace);
  font-size: .68rem;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: var(--mute);
}
.ed-index-quote {
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: .88rem;
  color: var(--mute);
  max-width: 300px;
  line-height: 1.4;
}
@media (max-width: 640px) {
  .ed-index-row { grid-template-columns: 3rem 1fr 3.5rem; gap: .85rem; }
  .ed-index-quote { display: none; }
}

/* ── DotMap ──────────────────────────────────── */
.ed-dotmap {
  display: grid;
  grid-template-columns: repeat(32, 1fr);
  gap: 4px;
  padding: 1.5rem 0;
}
.ed-dotmap-cell {
  aspect-ratio: 1;
  display: flex; align-items: center; justify-content: center;
}
.ed-dotmap-dot {
  width: 100%; height: 100%;
  border-radius: 50%;
  background: var(--ink);
  opacity: .15;
}
.ed-dotmap-dot.is-city { opacity: 1; background: var(--oxblood); }

/* ── Marquee ─────────────────────────────────── */
.ed-marquee {
  overflow: hidden;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
  padding: .85rem 0;
  background: var(--ink);
  color: var(--cream);
}
.ed-marquee-track {
  display: inline-flex;
  gap: 3rem;
  animation: ed-marquee 45s linear infinite;
  white-space: nowrap;
  will-change: transform;
}
.ed-marquee-item {
  font-family: var(--font-display, serif);
  font-style: italic;
  font-size: 1.1rem;
  opacity: .9;
}
.ed-marquee-dot {
  font-family: var(--font-mono, monospace);
  color: var(--lime);
  opacity: .5;
}
@keyframes ed-marquee { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── Region header ───────────────────────────── */
.ed-region {
  margin-top: 2.5rem;
}
.ed-region-head {
  display: flex;
  align-items: baseline;
  gap: 1rem;
  padding-bottom: .75rem;
  border-bottom: 2px solid var(--ink);
  margin-bottom: 1.25rem;
}
.ed-region-glyph { font-size: 1.8rem; opacity: .85; }
.ed-region-name {
  font-family: var(--font-display, serif);
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -.01em;
}
.ed-region-cnt {
  font-family: var(--font-mono, monospace);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--mute);
  margin-left: auto;
}

/* ── Utility: browse band ────────────────────── */
.ed-browse {
  background: var(--ink);
  color: var(--cream);
  padding: clamp(2rem, 4vw, 3rem) 0;
}
.ed-browse .ed-section-head { color: var(--cream); }
.ed-browse-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: .75rem;
}
.ed-browse-tile {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.1rem 1.25rem;
  background: rgba(247,242,232,.05);
  border: 1px solid rgba(247,242,232,.18);
  color: var(--cream);
  text-decoration: none;
  font-family: var(--font-mono, monospace);
  font-size: .78rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  transition: background .15s;
}
.ed-browse-tile:hover { background: rgba(216,243,90,.15); color: var(--lime); text-decoration: none; }
.ed-browse-tile-arrow { font-family: serif; font-size: 1.2rem; }

/* ── Featured editorial block (Current Obsession / Latest Review) ── */
.ed-editorial {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(2rem, 5vw, 4rem);
  padding: clamp(3rem, 6vw, 5rem) 0;
  align-items: start;
}
@media (max-width: 860px) { .ed-editorial { grid-template-columns: 1fr; } }
.ed-editorial-title {
  font-family: var(--font-display, serif);
  font-size: clamp(2rem, 4.5vw, 3.6rem);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -.03em;
  margin: .4rem 0 1rem;
}
.ed-editorial-body {
  font-family: var(--font-display, serif);
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--ink);
}
.ed-editorial-body::first-letter {
  font-size: 3.8rem;
  font-weight: 900;
  float: left;
  line-height: .85;
  padding: .25rem .55rem 0 0;
  color: var(--oxblood);
  font-family: var(--font-display, serif);
}
.ed-editorial-aside {
  border-left: 2px solid var(--ink);
  padding-left: 1.5rem;
}
.ed-editorial-stat {
  font-family: var(--font-display, serif);
  font-size: 2.8rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: -.02em;
  margin-bottom: .25rem;
}
.ed-editorial-stat-lbl {
  font-family: var(--font-mono, monospace);
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mute);
  margin-bottom: 1.5rem;
  display: block;
}

/* ── Appetite sparkline (bars) ───────────────── */
.ed-sparkline {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 72px;
  padding: .75rem 0;
  border-top: 1px solid var(--hair);
  border-bottom: 1px solid var(--hair);
}
.ed-sparkline-bar {
  flex: 1;
  background: var(--ink);
  min-height: 3px;
  opacity: .7;
  transition: opacity .15s;
  position: relative;
}
.ed-sparkline-bar:hover { opacity: 1; background: var(--oxblood); }
.ed-sparkline-lbl {
  font-family: var(--font-mono, monospace);
  font-size: .55rem;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--mute);
}

/* ── Trophy case (city champions) ────────────── */
.ed-trophy {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}
.ed-trophy-card {
  padding: 1.1rem 1.25rem;
  background: var(--bone);
  border: 1px solid var(--hair);
  text-decoration: none;
  color: inherit;
  transition: transform .15s ease, box-shadow .15s ease;
  position: relative;
}
.ed-trophy-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 16px -6px rgba(20,18,26,.3);
  text-decoration: none; color: inherit;
}
.ed-trophy-city {
  font-family: var(--font-mono, monospace);
  font-size: .66rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: var(--mute);
  margin-bottom: .3rem;
}
.ed-trophy-rest {
  font-family: var(--font-display, serif);
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.15;
  margin-bottom: .5rem;
}
.ed-trophy-score {
  font-family: var(--font-display, serif);
  font-size: 1.6rem;
  font-weight: 800;
  color: var(--oxblood);
}

/* ── Large numeral for aside stats ──────────── */
.ed-big-num {
  font-family: var(--font-display, serif);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 900;
  line-height: .9;
  letter-spacing: -.03em;
  color: var(--ink);
}
.ed-big-num .ed-big-unit {
  font-size: .4em; opacity: .5; margin-left: .2em;
}

/* ── Utility ─────────────────────────────────── */
.ed-divider-oxblood { border-bottom: 1px solid var(--oxblood); }
.ed-stack { display: flex; flex-direction: column; gap: 2rem; }
.ed-muted { color: var(--mute); }
.ed-pad-y-lg { padding-top: clamp(2rem, 5vw, 4rem); padding-bottom: clamp(2rem, 5vw, 4rem); }
