/* ============================================================
   MyCoffeeTrip — Acid Lime editorial design system
   ============================================================ */

/* ---- Fonts (overridable via tweaks on :root) ---- */
:root {
  --font-display: "Bodoni Moda", "Times New Roman", serif;
  --font-sans: "Hanken Grotesk", system-ui, sans-serif;
  --font-mono: "Spline Sans Mono", ui-monospace, monospace;

  /* Brand constants */
  --lime: #D8FF3E;
  --lime-ink: #1A2400;

  /* Semantic — LIGHT (paper) is default */
  --bg: #F6F3EC;
  --bg-raised: #FCFBF6;
  --bg-sunken: #EFEBE0;
  --text: #0E0E0C;
  --text-2: #6B6B63;
  --accent: #D8FF3E;
  --on-accent: #0E0E0C;
  --link: #1A2400;
  --hairline: rgba(14, 14, 12, 0.12);
  --hairline-strong: rgba(14, 14, 12, 0.24);
  --shadow: 0 1px 2px rgba(14,14,12,.05), 0 12px 32px -12px rgba(14,14,12,.16);
  --shadow-sm: 0 1px 2px rgba(14,14,12,.06);

  /* faux-map ground */
  --map-ground: #ECE8DC;
  --map-road: #FBFAF5;
  --map-water: #DDE6CF;

  color-scheme: light;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 17px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background .35s ease, color .35s ease;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }

::selection { background: var(--lime); color: var(--lime-ink); }

/* ---------- Typography ---------- */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--text-2);
  font-weight: 500;
}
.display {
  font-family: var(--font-display);
  font-weight: 600;
  line-height: 1.02;
  letter-spacing: -0.01em;
  margin: 0;
}
.serif { font-family: var(--font-display); }
.mono { font-family: var(--font-mono); }

/* Editorial prose */
.prose { max-width: 64ch; }
.prose p { margin: 0 0 1.15em; text-wrap: pretty; }
.prose p:first-child { margin-top: 0; }
.prose .lead {
  font-family: var(--font-display);
  font-size: 1.4em;
  line-height: 1.42;
  font-weight: 500;
}
.prose h3 {
  font-family: var(--font-display);
  font-size: 1.55em;
  font-weight: 600;
  margin: 1.8em 0 .5em;
}

/* ---------- Layout helpers ---------- */
.wrap { width: 100%; max-width: 1240px; margin: 0 auto; padding: 0 24px; }
.wrap-narrow { max-width: 820px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .04em;
  padding: 11px 18px;
  border-radius: 2px;
  border: 1px solid var(--text);
  background: transparent; color: var(--text);
  cursor: pointer;
  transition: background .18s ease, color .18s ease, border-color .18s ease, transform .12s ease;
  text-transform: uppercase;
}
.btn:hover { background: var(--text); color: var(--bg); }
.btn:active { transform: translateY(1px); }
.btn--lime { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.btn--lime:hover { background: var(--text); border-color: var(--text); color: var(--bg); }
.btn--ghost { border-color: var(--hairline-strong); }
.btn--sm { padding: 8px 13px; font-size: 12px; }

/* ---------- Pills / chips ---------- */
.chip {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono);
  font-size: 12.5px; letter-spacing: .02em;
  padding: 7px 12px; border-radius: 100px;
  border: 1px solid var(--hairline-strong);
  background: var(--bg-raised); color: var(--text);
  cursor: pointer; white-space: nowrap;
  transition: all .15s ease;
}
.chip:hover { border-color: var(--text); }
.chip[data-on="true"] { background: var(--accent); border-color: var(--accent); color: var(--on-accent); }
.chip .ic { width: 15px; height: 15px; }

/* ---------- Fact badges ---------- */
.facts { display: flex; flex-wrap: wrap; gap: 8px; }
.fact {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 13.5px;
  padding: 9px 13px; border-radius: 2px;
  border: 1px solid var(--hairline);
  background: var(--bg-raised);
}
.fact .ic { width: 17px; height: 17px; color: var(--text-2); flex: none; }
.fact b { font-weight: 600; }
.fact .k { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-2); }

/* ---------- Cards ---------- */
.card {
  background: var(--bg-raised);
  border: 1px solid var(--hairline);
  border-radius: 3px;
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease, box-shadow .2s ease;
}
a.card:hover, .card.is-link:hover { border-color: var(--text); transform: translateY(-2px); box-shadow: var(--shadow); }

/* image frame with reserved ratio to avoid CLS */
.frame { position: relative; background: var(--bg-sunken); overflow: hidden; }
.frame > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.frame--fallback { background:
  radial-gradient(120% 120% at 20% 0%, #6f5743 0%, #4a3a2c 45%, #2c241c 100%); }
.frame--fallback::after {
  content: attr(data-label);
  position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase;
  color: rgba(246,243,236,.5);
}

/* ---------- Divider ---------- */
.rule { height: 1px; background: var(--hairline); border: 0; margin: 0; }

/* ---------- Stars ---------- */
.stars { display: inline-flex; align-items: center; gap: 2px; line-height: 0; }
.stars svg { display: block; }
.star-bg { color: var(--hairline-strong); }
.star-fg { color: var(--accent); }
/* dark outline so lime stars stay legible on the cream background (contrast AA) */
.star-fg path { stroke: var(--lime-ink); stroke-width: 2.4; paint-order: stroke; stroke-linejoin: round; }

/* ---------- Award badge ---------- */
.award {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .03em;
  padding: 7px 12px 7px 10px; border-radius: 100px;
  background: var(--accent); color: var(--on-accent);
  font-weight: 600;
}
.award .ic { width: 15px; height: 15px; }
.award--stamp {
  background: transparent; color: var(--text);
  border: 1.5px solid var(--text); border-radius: 2px;
  text-transform: uppercase;
}
.award--seal {
  background: transparent; color: var(--text);
  border: 1.5px dashed var(--accent);
}

/* ---------- Wishlist tag ---------- */
.wish-tag {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em;
  padding: 6px 11px; border-radius: 100px;
  border: 1px dashed var(--hairline-strong); color: var(--text-2);
  text-transform: uppercase;
}

/* ---------- TL;DR pull ---------- */
.tldr {
  border-left: 3px solid var(--accent);
  padding: 4px 0 4px 20px;
  font-family: var(--font-display);
  font-size: 1.45rem; line-height: 1.4; font-weight: 500;
}

/* ---------- Header ---------- */
.site-head {
  position: sticky; top: 0; z-index: 40;
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: saturate(1.2) blur(10px);
  border-bottom: 1px solid var(--hairline);
}
.site-head__row { display: flex; align-items: center; gap: 22px; height: 64px; }
.brand { display: flex; align-items: baseline; gap: 0; font-family: var(--font-display); font-weight: 600; font-size: 21px; letter-spacing: -.01em; }
.brand .dot { color: var(--accent); }
.nav { display: flex; gap: 4px; margin-left: 8px; }
.nav a {
  font-family: var(--font-mono); font-size: 13px; letter-spacing: .03em;
  padding: 8px 12px; border-radius: 2px; color: var(--text-2);
  transition: color .15s ease, background .15s ease;
}
.nav a:hover { color: var(--text); }
.nav a[data-active="true"] { color: var(--text); }
.nav a[data-active="true"]::after {
  content: ""; display: block; height: 2px; background: var(--accent);
  margin-top: 5px; border-radius: 2px;
}
.head-tools { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.icon-btn {
  display: inline-grid; place-items: center; width: 38px; height: 38px;
  border: 1px solid var(--hairline-strong); border-radius: 2px;
  background: transparent; color: var(--text); cursor: pointer;
  transition: all .15s ease;
}
.icon-btn:hover { border-color: var(--text); }
.icon-btn .ic { width: 18px; height: 18px; }

.lang {
  display: inline-flex; border: 1px solid var(--hairline-strong); border-radius: 2px; overflow: hidden;
}
.lang button {
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .04em;
  padding: 7px 9px; border: 0; background: transparent; color: var(--text-2); cursor: pointer;
}
.lang button[data-on="true"] { background: var(--text); color: var(--bg); }

/* language dropdown (7 languages) */
.langsel { position: relative; }
.langsel-btn {
  display: inline-flex; align-items: center; gap: 7px;
  font-family: var(--font-mono); font-size: 12px; letter-spacing: .03em;
  padding: 8px 11px; border: 1px solid var(--hairline-strong); border-radius: 2px;
  background: transparent; color: var(--text); cursor: pointer; transition: border-color .15s ease;
}
.langsel-btn:hover { border-color: var(--text); }
.langsel-btn .ic { width: 15px; height: 15px; color: var(--text-2); }
.langsel-menu {
  position: absolute; right: 0; top: calc(100% + 6px); z-index: 50; min-width: 130px;
  list-style: none; margin: 0; padding: 6px; background: var(--bg-raised);
  border: 1px solid var(--hairline-strong); border-radius: 4px; box-shadow: var(--shadow);
}
.langsel-menu li {
  font-family: var(--font-mono); font-size: 12.5px; letter-spacing: .03em;
  padding: 9px 12px; border-radius: 2px; cursor: pointer; color: var(--text-2);
  display: flex; align-items: center; gap: 8px;
}
.langsel-menu li:hover { background: var(--bg-sunken); color: var(--text); }
.langsel-menu li[data-on="true"] { color: var(--text); }
.langsel-menu li[data-on="true"]::before { content: "●"; color: var(--accent); font-size: 9px; }
.langsel-menu li:not([data-on="true"])::before { content: ""; width: 9px; }

/* skip link + focus visibility (accessibility) */
.skip-link {
  position: fixed; top: 8px; left: 8px; z-index: 200; transform: translateY(-150%);
  background: var(--text); color: var(--bg); padding: 10px 16px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 13px; transition: transform .15s ease;
}
.skip-link:focus { transform: translateY(0); }
:focus-visible { outline: 2px solid var(--lime-ink); outline-offset: 2px; border-radius: 2px; }
.btn:focus-visible, .chip:focus-visible { outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) { * { animation-duration: .001ms !important; transition-duration: .001ms !important; } }

/* mobile menu */
.menu-toggle { display: none; position: relative; }
.menu-toggle__btn {
  list-style: none; cursor: pointer; width: 38px; height: 38px;
  display: grid; place-items: center; color: var(--text);
  border: 1px solid var(--hairline-strong); border-radius: 2px; background: var(--bg-raised);
}
.menu-toggle__btn::-webkit-details-marker { display: none; }
.menu-toggle__btn:hover { border-color: var(--text); }
.menu-panel {
  position: absolute; right: 0; top: calc(100% + 6px); z-index: 50; min-width: 180px;
  display: flex; flex-direction: column; padding: 6px; background: var(--bg-raised);
  border: 1px solid var(--hairline-strong); border-radius: 4px; box-shadow: var(--shadow);
}
.menu-panel a { padding: 11px 13px; border-radius: 2px; color: var(--text-2); text-decoration: none; font-size: 15px; }
.menu-panel a:hover { background: var(--bg-sunken); color: var(--text); }
.menu-panel a[data-active="true"] { color: var(--text); }

/* ---------- Footer ---------- */
.site-foot { border-top: 1px solid var(--hairline); margin-top: 80px; padding: 56px 0 40px; }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 32px; }
.foot-grid h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-2); margin: 0 0 14px; font-weight: 500; }
.foot-grid a { display: block; padding: 5px 0; color: var(--text-2); font-size: 14.5px; }
.foot-grid a:hover { color: var(--text); }

/* ---------- Catalog ---------- */
.catalog { display: grid; grid-template-columns: 1fr; }
.cat-toolbar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; padding: 16px 0; }
.search {
  display: flex; align-items: center; gap: 9px; flex: 1; min-width: 220px;
  border: 1px solid var(--hairline-strong); border-radius: 2px; padding: 9px 13px;
  background: var(--bg-raised);
}
.search input { border: 0; background: transparent; color: var(--text); font-family: var(--font-sans); font-size: 15px; width: 100%; outline: none; }
.search .ic { width: 17px; height: 17px; color: var(--text-2); }

.cat-split { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr); gap: 0; align-items: start; }
.cat-list { padding-right: 28px; }
.cat-map-col { position: sticky; top: 64px; height: calc(100vh - 64px); }

.section-label {
  display: flex; align-items: center; gap: 14px;
  font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--text-2); margin: 22px 0 14px;
}
.section-label::after { content: ""; flex: 1; height: 1px; background: var(--hairline); }

/* list rows */
.cafe-row { display: grid; grid-template-columns: 66px 1fr auto; gap: 16px; padding: 14px 0; border-bottom: 1px solid var(--hairline); align-items: center; cursor: pointer; transition: background .15s ease; }
.cafe-row:hover { background: var(--bg-raised); }
.cafe-row__thumb { position: relative; width: 66px; }
.cafe-row__thumb .frame { aspect-ratio: 3 / 4; border-radius: 3px; }
.cafe-row.is-wish .cafe-row__thumb .frame { filter: grayscale(.5); opacity: .85; }
.cafe-row__award { position: absolute; top: 5px; left: 5px; width: 22px; height: 22px; display: grid; place-items: center; border-radius: 50%; background: var(--accent); color: var(--on-accent); box-shadow: var(--shadow-sm); }
.cafe-row__award .ic { width: 13px; height: 13px; }

/* wishlist treatment variants (tweak: wishStyle) */
[data-wish="marker"] .cafe-row.is-wish .cafe-row__thumb .frame { filter: none; opacity: 1; }
[data-wish="faded"] .cafe-row.is-wish { opacity: .62; }
[data-wish="faded"] .cafe-row.is-wish:hover { opacity: 1; }
[data-wish="faded"] .cafe-card .frame { opacity: .8; }
.cafe-row__meta { min-width: 0; }
.cafe-row__name { font-family: var(--font-display); font-size: 19px; font-weight: 600; display: flex; align-items: center; gap: 9px; }
.cafe-row__sub { color: var(--text-2); font-size: 13.5px; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-top: 3px; }
.dot-sep::before { content: "·"; margin-right: 10px; color: var(--hairline-strong); }

/* reviewed/wishlist marker icon */
.type-dot { width: 24px; height: 24px; display: inline-grid; place-items: center; flex: none; }

/* score badge */
.score {
  font-family: var(--font-display); font-weight: 600; font-size: 20px;
  display: inline-flex; align-items: center; gap: 6px;
}
.score .pip { width: 8px; height: 8px; border-radius: 50%; background: var(--accent); }

/* ---------- Real map (MapLibre) ---------- */
.map { position: relative; width: 100%; height: 100%; border-left: 1px solid var(--hairline); background: var(--map-ground); overflow: hidden; }
.map-canvas { position: absolute; inset: 0; }
.maplibregl-map { font-family: var(--font-sans); }
.maplibregl-ctrl-attrib { font-size: 10px; }

.mlwrap { cursor: pointer; will-change: transform; appearance: none; -webkit-appearance: none; background: none; border: 0; padding: 0; line-height: 0; }
.mappop { min-width: 150px; font-family: var(--font-sans); }
.mappop__name { font-family: var(--font-display); font-weight: 600; font-size: 16px; line-height: 1.2; color: var(--text); }
.mappop__type { font-size: 12.5px; color: var(--text-2); margin-top: 2px; }
.mappop__btns { display: flex; gap: 6px; margin-top: 10px; }
.mappop__btns .btn { flex: 1; justify-content: center; }
.maplibregl-popup-content { border-radius: 12px; padding: 13px 15px; box-shadow: 0 6px 22px rgba(0,0,0,.18); }
.maplibregl-popup-tip { display: none; }
.mlpin {
  width: 30px; height: 30px; border-radius: 50% 50% 50% 2px; transform: rotate(45deg);
  background: var(--accent); border: 2px solid #0E0E0C;
  display: grid; place-items: center; box-shadow: 0 3px 8px rgba(0,0,0,.32);
  transition: transform .14s ease;
}
.mlwrap:hover .mlpin { transform: rotate(45deg) scale(1.14); }
.mlpin .lbl { transform: rotate(-45deg); font-family: var(--font-mono); font-weight: 600; font-size: 11px; color: var(--on-accent); }
.mlwrap.is-wish .mlpin { background: var(--bg-raised); border: 2px dashed var(--text-2); box-shadow: none; }
.mlwrap.is-wish .mlpin .lbl { color: var(--text-2); }
.mlwrap.is-active .mlpin { box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 55%, transparent), 0 3px 8px rgba(0,0,0,.32); }

.map-overlay { position: absolute; left: 14px; bottom: 14px; z-index: 2; display: flex; gap: 14px; align-items: center; background: var(--bg-raised); border: 1px solid var(--hairline); border-radius: 2px; padding: 8px 12px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .04em; color: var(--text-2); }
.map-overlay .lg { display: inline-flex; align-items: center; gap: 7px; }
.map-overlay .lg::before { content: ""; width: 11px; height: 11px; border-radius: 50%; }
.map-overlay .lg--rev::before { background: var(--accent); border: 1.5px solid var(--lime-ink); }
.map-overlay .lg--wish::before { background: transparent; border: 1.5px dashed var(--text-2); }

/* ---------- Review detail ---------- */
/* ---------- Review detail ---------- */
.rev-text { font-size: 18px; line-height: 1.62; margin: 22px 0 0; max-width: 62ch; color: var(--text); text-wrap: pretty; }

.ph-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)); gap: 12px; margin-top: 34px; }
.ph-item { margin: 0; }
.ph-item picture { display: block; }
.ph-item img { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; border-radius: 8px; display: block; background: var(--bg-sunken); }
.ph-item figcaption { font-size: 12.5px; line-height: 1.4; color: var(--text-2); margin-top: 7px; }
.ph-item--video { grid-column: span 2; }
.ph-item video { width: 100%; aspect-ratio: 3 / 4; object-fit: cover; border-radius: 8px; display: block; background: #000; }

/* portrait phone media — secondary, not a hero */
.media-block { margin: 36px 0 4px; }
.media-head { display: flex; align-items: baseline; gap: 14px; margin-bottom: 16px; }
.media-count { font-size: 11.5px; letter-spacing: .04em; color: var(--text-2); }
.media-rail { display: flex; gap: 12px; overflow-x: auto; padding-bottom: 6px; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; }
.media-item { position: relative; margin: 0; flex: 0 0 auto; width: 168px; scroll-snap-align: start; }
.media-item .frame { aspect-ratio: 3 / 4; border-radius: 4px; }
.media-item figcaption { font-size: 12px; color: var(--text-2); margin-top: 7px; font-style: italic; line-height: 1.35; }
.media-play { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 44px; height: 44px; display: grid; place-items: center; border-radius: 50%; background: rgba(14,14,12,.5); color: #fff; backdrop-filter: blur(2px); pointer-events: none; }
.media-play .ic { width: 26px; height: 26px; }
.media-badge { position: absolute; top: 8px; left: 8px; background: var(--accent); color: var(--on-accent); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; padding: 3px 7px; border-radius: 100px; font-weight: 600; }
.hero-gallery { display: grid; grid-template-columns: 2fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; height: 480px; }
.hero-gallery .frame:first-child { grid-row: 1 / span 2; }
.hero-gallery .frame { border-radius: 3px; }

.rev-head { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: end; margin: 28px 0 0; }
.rev-title { font-family: var(--font-display); font-weight: 600; font-size: clamp(38px, 6vw, 68px); line-height: .98; letter-spacing: -.02em; }
.rev-sub { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; color: var(--text-2); margin-top: 14px; font-size: 14.5px; }

.rev-grid { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 56px; margin-top: 44px; align-items: start; }
.rev-aside { position: sticky; top: 84px; display: flex; flex-direction: column; gap: 22px; }

/* rating panel */
.rating-panel { border: 1px solid var(--hairline); border-radius: 3px; background: var(--bg-raised); padding: 22px; }
.rating-overall { display: flex; align-items: baseline; gap: 12px; padding-bottom: 16px; border-bottom: 1px solid var(--hairline); margin-bottom: 16px; }
.rating-overall .num { font-family: var(--font-display); font-weight: 600; font-size: 52px; line-height: 1; }
.rating-overall .outof { color: var(--text-2); font-family: var(--font-mono); font-size: 13px; }
.cat-rows { display: flex; flex-direction: column; gap: 13px; }
.cat-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; }
.cat-row .label { display: flex; align-items: center; gap: 9px; font-size: 14px; }
.cat-row .label .ic { width: 17px; height: 17px; color: var(--text-2); }
/* bars variant */
.bar-track { height: 8px; border-radius: 100px; background: var(--hairline); overflow: hidden; }
.bar-fill { height: 100%; background: var(--accent); border-radius: 100px; }
.cat-row--bar { grid-template-columns: 116px 1fr 34px; }
.cat-row--bar .val { font-family: var(--font-mono); font-size: 13px; text-align: right; }
/* big number grid variant */
.cat-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: 3px; overflow: hidden; }
.cat-cell { background: var(--bg-raised); padding: 16px; }
.cat-cell .ic { width: 18px; height: 18px; color: var(--text-2); }
.cat-cell .k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2); margin: 8px 0 2px; }
.cat-cell .n { font-family: var(--font-display); font-size: 30px; font-weight: 600; }

/* pros cons */
.proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; }
.pc h4 { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-2); margin: 0 0 12px; }
.pc ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 9px; }
.pc li { display: grid; grid-template-columns: 20px 1fr; gap: 10px; font-size: 15px; align-items: start; }
.pc li .ic { width: 17px; height: 17px; margin-top: 3px; }
.pc--pro li .ic { color: var(--lime-ink); }
.pc--con li .ic { color: var(--text-2); }

/* QA */
.qa { display: flex; flex-direction: column; }
.qa details { border-bottom: 1px solid var(--hairline); padding: 4px 0; }
.qa summary { list-style: none; cursor: pointer; padding: 16px 0; font-family: var(--font-display); font-size: 19px; font-weight: 500; display: flex; justify-content: space-between; gap: 16px; align-items: center; }
.qa summary::-webkit-details-marker { display: none; }
.qa summary .pm { font-family: var(--font-mono); color: var(--text-2); transition: transform .2s ease; }
.qa details[open] summary .pm { transform: rotate(45deg); }
.qa .ans { padding: 0 0 18px; color: var(--text-2); max-width: 60ch; }

/* fact table */
.spec { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: 3px; overflow: hidden; }
.spec-row { background: var(--bg-raised); padding: 14px 16px; }
.spec-row .k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2); }
.spec-row .v { font-size: 15px; margin-top: 4px; display: flex; align-items: center; gap: 8px; }
.spec-row .v .ic { width: 16px; height: 16px; color: var(--text-2); }

/* section heads in article */
.sec-h { font-family: var(--font-mono); font-size: 11.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-2); margin: 0 0 18px; display: flex; align-items: center; gap: 14px; }
.sec-h::after { content: ""; flex: 1; height: 1px; background: var(--hairline); }
.block { margin: 52px 0; }

/* gallery captioned */
.gallery-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
.gallery-strip figure { margin: 0; }
.gallery-strip figcaption { font-size: 12.5px; color: var(--text-2); margin-top: 7px; font-style: italic; }

/* ---------- Homepage ---------- */
.home-hero { padding: 56px 0 40px; }
.home-hero h1 { font-family: var(--font-display); font-weight: 600; font-size: clamp(44px, 8vw, 104px); line-height: .94; letter-spacing: -.025em; margin: 0; }
.home-hero h1 em { font-style: italic; }
.home-hero .mark { background: linear-gradient(transparent 62%, var(--accent) 62%, var(--accent) 92%, transparent 92%); }
.lede { max-width: 56ch; font-size: 19px; color: var(--text-2); margin: 22px 0 28px; }

/* home compact stats + search */
.home-stats { display: flex; flex-wrap: wrap; gap: 22px; margin-top: 18px; }
.home-stat { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; color: var(--text-2); }
.home-stat b { font-family: var(--font-display); font-size: 22px; font-weight: 600; color: var(--text); letter-spacing: 0; }

.home-search {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1.2fr auto; gap: 12px; align-items: end;
  border: 1px solid var(--hairline-strong); background: var(--bg-raised); border-radius: 4px; padding: 20px;
  box-shadow: var(--shadow-sm);
}
.home-search .field { display: flex; flex-direction: column; gap: 7px; min-width: 0; }
.home-search .field > span { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2); }
.home-search select, .home-search input {
  width: 100%; padding: 11px 12px; border: 1px solid var(--hairline-strong); border-radius: 2px;
  background: var(--bg); color: var(--text); font-family: var(--font-sans); font-size: 14.5px; outline: none;
  transition: border-color .15s ease;
}
.home-search select:focus, .home-search input:focus { border-color: var(--text); }
.home-search select:disabled { opacity: .5; }
.home-search .acts { display: flex; gap: 8px; }
.home-search .acts .btn { white-space: nowrap; }
@media (max-width: 860px) {
  .home-search { grid-template-columns: 1fr 1fr; }
  .home-search .acts { grid-column: 1 / -1; }
  .home-search .acts .btn { flex: 1; justify-content: center; }
}
@media (max-width: 480px) { .home-search { grid-template-columns: 1fr; } }

/* ---------- Search bar + autocomplete ---------- */
.searchbar { position: relative; }
.searchbar-row {
  display: flex; align-items: center; gap: 8px;
  border: 1px solid var(--hairline-strong); background: var(--bg-raised); border-radius: 3px;
  padding: 8px 8px 8px 14px; box-shadow: var(--shadow-sm);
}
.searchbar--lg .searchbar-row { padding: 11px 11px 11px 16px; }
.searchbar .sb-ic { width: 19px; height: 19px; color: var(--text-2); flex: none; }
.searchbar input { flex: 1; min-width: 0; border: 0; background: transparent; color: var(--text); font-family: var(--font-sans); font-size: 16px; outline: none; }
.searchbar--lg input { font-size: 18px; }
.searchbar .sb-near { flex: none; }
.searchbar .sb-go { flex: none; }
.sb-clear {
  display: inline-flex; align-items: center; gap: 5px; flex: none;
  border: 0; background: transparent; color: var(--text-2); cursor: pointer;
  font-size: 12px; letter-spacing: .03em; padding: 6px 8px; border-radius: 2px;
}
.sb-clear:hover { color: var(--text); }
.sb-clear .ic { width: 14px; height: 14px; }
@media (max-width: 600px) { .searchbar .sb-near span { display: none; } .searchbar .sb-near { padding: 8px 10px; } .sb-clear span, .sb-clear { } }

/* airy full-width autocomplete (ref: editorial index) */
.ac2 {
  position: absolute; top: calc(100% + 10px); left: 0; right: 0; z-index: 50;
  background: var(--bg-raised); border: 1px solid var(--hairline-strong); border-radius: 6px;
  box-shadow: var(--shadow); overflow: hidden; max-height: 72vh; overflow-y: auto;
  padding: 6px 0;
}
.ac2-group { padding: 10px 0; }
.ac2-group + .ac2-group { border-top: 1px solid var(--hairline); }
.ac2-head {
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-2);
  padding: 8px 24px 10px;
}
.ac2-hint { letter-spacing: .04em; text-transform: none; font-size: 11px; opacity: .8; }
.ac2-row {
  display: flex; align-items: center; gap: 16px; width: 100%; text-align: left;
  padding: 13px 24px; border: 0; background: transparent; color: var(--text); cursor: pointer;
  font-family: var(--font-sans); transition: background .12s ease;
}
.ac2-row:hover, .ac2-row:focus-visible { background: var(--bg-sunken); outline: none; }
.ac2-ic { flex: none; width: 24px; display: inline-grid; place-items: center; color: var(--text-2); }
.ac2-ic .ic { width: 19px; height: 19px; }
.ac2-main { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 3px; }
.ac2-name { font-size: 21px; font-weight: 600; line-height: 1.1; letter-spacing: -.01em; display: inline-flex; align-items: center; gap: 9px; }
.ac2-trophy { display: inline-grid; place-items: center; width: 21px; height: 21px; border-radius: 50%; background: var(--accent); color: var(--on-accent); flex: none; }
.ac2-trophy .ic { width: 12px; height: 12px; }
.ac2-tag { font-size: 11.5px; letter-spacing: .03em; color: var(--text-2); }
.ac2-act { flex: none; display: inline-flex; align-items: center; gap: 9px; font-size: 12px; letter-spacing: .04em; color: var(--text-2); }
.ac2-score { color: var(--text); font-weight: 600; font-size: 13px; }
.ac2-arrow { width: 15px; height: 15px; opacity: .55; }
.ac2-wish { color: var(--text-2); }
.ac2-empty { padding: 26px 24px 30px; color: var(--text-2); }
@media (max-width: 600px) {
  .ac2-row { padding: 12px 18px; gap: 12px; }
  .ac2-head { padding: 8px 18px 8px; }
  .ac2-name { font-size: 18px; }
}

/* ---------- Guides ---------- */
.guide-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.guide-mini {
  position: relative; aspect-ratio: 3/4; border-radius: 4px; overflow: hidden; cursor: pointer;
  border: 1px solid var(--hairline); padding: 0; text-align: left; transition: transform .2s ease, border-color .2s ease;
}
.guide-mini:hover { transform: translateY(-3px); border-color: var(--text); }
.guide-mini .frame { position: absolute; inset: 0; }
.guide-mini__scrim { position: absolute; inset: 0; background: linear-gradient(transparent 35%, rgba(14,14,12,.78)); }
.guide-mini__body { position: absolute; left: 12px; right: 12px; bottom: 12px; color: #F6F3EC; }
.guide-mini__name { font-size: 19px; font-weight: 600; line-height: 1.05; }
.guide-mini__meta { font-size: 10px; letter-spacing: .06em; text-transform: uppercase; opacity: .85; margin-top: 4px; }
@media (max-width: 980px) { .guide-strip { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .guide-strip { grid-template-columns: repeat(2, 1fr); } }
.guide-mini__name { font-size: 21px; }

.guide-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.guide-filter { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 26px; }
.guide-card { cursor: pointer; text-align: left; padding: 0; }
.guide-card .frame { aspect-ratio: 3 / 4; }
.guide-card__body { padding: 16px; }
.guide-card__name { font-size: 21px; font-weight: 600; line-height: 1.08; margin-top: 6px; }
@media (max-width: 980px) { .guide-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px) { .guide-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .guide-grid { grid-template-columns: 1fr; } }

.guide-hero { position: relative; height: 340px; border-radius: 4px; overflow: hidden; }
.guide-hero .frame { position: absolute; inset: 0; }
.guide-hero__scrim { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(14,14,12,.7), rgba(14,14,12,.15)); }
.guide-hero__body { position: absolute; left: 36px; bottom: 32px; right: 36px; color: #F6F3EC; }
.guide-hero__title { font-size: clamp(40px, 7vw, 84px); font-weight: 600; line-height: .96; letter-spacing: -.02em; margin: 0; }
@media (max-width: 560px) { .guide-hero { height: 240px; } .guide-hero__body { left: 20px; bottom: 20px; } }

.guide-intro { display: grid; grid-template-columns: 1.1fr 1fr; gap: 36px; align-items: start; }
@media (max-width: 860px) { .guide-intro { grid-template-columns: 1fr; gap: 24px; } }

.guide-group { font-family: var(--font-display); font-size: 19px; font-weight: 600; color: var(--text); margin: 28px 0 10px; padding-bottom: 8px; border-bottom: 1px solid var(--hairline); }
.guide-group:first-of-type { margin-top: 8px; }
.guide-list { display: flex; flex-direction: column; }
.guide-row {
  display: grid; grid-template-columns: 44px 150px 1fr auto; gap: 20px; align-items: center;
  width: 100%; text-align: left; padding: 18px 6px; border: 0; border-bottom: 1px solid var(--hairline);
  background: transparent; color: var(--text); cursor: pointer; transition: background .15s ease;
}
.guide-row:hover { background: var(--bg-raised); }
.guide-row__rank { font-size: 32px; font-weight: 600; color: var(--accent); -webkit-text-stroke: 1px var(--lime-ink); text-align: center; }
.guide-row__img { width: 150px; aspect-ratio: 3/2; border-radius: 3px; }
.guide-row__rate { text-align: right; }
@media (max-width: 720px) {
  .guide-row { grid-template-columns: 32px 1fr auto; gap: 14px; }
  .guide-row__img { display: none; }
  .guide-row__rank { font-size: 24px; }
}

.authority { display: flex; gap: 40px; flex-wrap: wrap; padding: 22px 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.stat .n { font-family: var(--font-display); font-weight: 600; font-size: 40px; line-height: 1; }
.stat .l { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-2); margin-top: 6px; }

.home-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
.cafe-card { display: flex; flex-direction: column; }
.cafe-card__media { position: relative; }
.cafe-card__media .frame { aspect-ratio: 3 / 4; }
.cafe-card__award { position: absolute; top: 10px; left: 10px; z-index: 2; max-width: calc(100% - 20px); }
.cafe-card__award .award { font-size: 10.5px; padding: 5px 9px 5px 8px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; box-shadow: var(--shadow-sm); }
.cafe-card__award .award .ic { width: 13px; height: 13px; flex: none; }
.cafe-card__body { padding: 14px; }
.cafe-card__name { font-family: var(--font-display); font-size: 19px; font-weight: 600; line-height: 1.12; display: flex; align-items: center; gap: 8px; }
.cafe-card__loc { color: var(--text-2); font-size: 13px; margin-top: 4px; }
.cafe-card__foot { display: flex; align-items: center; justify-content: space-between; margin-top: 12px; }
.rate-inline { display: inline-flex; align-items: center; gap: 8px; }
.rate-num { font-size: 13px; color: var(--text-2); }

.feature { display: grid; grid-template-columns: 1.3fr 1fr; gap: 0; border: 1px solid var(--hairline); border-radius: 4px; overflow: hidden; background: var(--bg-raised); }
.feature .frame { min-height: 420px; }
.feature__body { padding: 44px; display: flex; flex-direction: column; justify-content: center; }

.split-cta { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; }
.cta-card { padding: 38px; border: 1px solid var(--hairline); border-radius: 4px; min-height: 220px; display: flex; flex-direction: column; justify-content: space-between; transition: all .2s ease; }
.cta-card:hover { border-color: var(--text); }
.cta-card.dark { background: var(--ink, #0E0E0C); color: #F6F3EC; border-color: transparent; }
.cta-card h3 { font-family: var(--font-display); font-size: 30px; font-weight: 600; margin: 0; }

/* awards landing */
.award-hero { text-align: center; padding: 64px 0 36px; }
.crown-badge { display: inline-grid; place-items: center; width: 60px; height: 60px; border-radius: 50%; background: var(--accent); margin: 0 auto 18px; }
.crown-badge .ic { width: 32px; height: 32px; color: var(--lime-ink); }
.rank-list { display: flex; flex-direction: column; gap: 18px; max-width: 880px; margin: 0 auto; }
.rank-item { display: grid; grid-template-columns: 78px 200px 1fr; gap: 24px; align-items: center; padding: 22px; border: 1px solid var(--hairline); border-radius: 4px; background: var(--bg-raised); transition: all .2s ease; }
.rank-item:hover { border-color: var(--text); }
.rank-num { font-family: var(--font-display); font-weight: 600; font-size: 64px; line-height: 1; color: var(--accent); -webkit-text-stroke: 1px var(--lime-ink); }
.rank-item .frame { width: 200px; aspect-ratio: 5/4; border-radius: 3px; }
.rank-num.silver, .rank-num.bronze { color: var(--text-2); -webkit-text-stroke: 0; }

/* section spacing — vertical only; never clobber .wrap's horizontal padding */
.section { padding-top: 56px; padding-bottom: 56px; }
.section--top { padding-top: 40px; }
.section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; margin-bottom: 26px; }
.section-head h2 { font-family: var(--font-display); font-size: clamp(28px, 4vw, 42px); font-weight: 600; margin: 0; letter-spacing: -.01em; }
.section-head .eyebrow { margin-bottom: 8px; }

/* empty + loading states */
.empty { text-align: center; padding: 64px 24px; color: var(--text-2); }
.empty .ic { width: 40px; height: 40px; margin: 0 auto 16px; color: var(--hairline-strong); }
.skeleton { background: linear-gradient(90deg, var(--bg-sunken), var(--bg-raised), var(--bg-sunken)); background-size: 200% 100%; animation: sk 1.4s infinite; }
@keyframes sk { to { background-position: -200% 0; } }

/* cookie banner */
.cookie { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 60; max-width: 560px; margin: 0 auto; background: var(--bg-raised); border: 1px solid var(--hairline-strong); border-radius: 4px; padding: 16px 18px; display: flex; gap: 16px; align-items: center; box-shadow: var(--shadow); }
.cookie p { margin: 0; font-size: 13.5px; color: var(--text-2); }
.cookie .acts { display: flex; gap: 8px; margin-left: auto; flex: none; }

/* mobile view switch (catalog) */
.view-switch { display: none; }

/* breadcrumb */
.crumb { display: flex; gap: 8px; align-items: center; font-family: var(--font-mono); font-size: 12px; color: var(--text-2); padding: 18px 0 0; }
.crumb a:hover { color: var(--text); }
.crumb .sep { opacity: .5; }

/* home country quick-filter */
.home-countries { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; margin-top: 18px; }
.home-countries__label { font-size: 11px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-2); }
.home-countries__chips { display: flex; gap: 8px; flex-wrap: wrap; }
.chip-count { font-size: 11px; color: var(--text-2); background: var(--bg-sunken); padding: 1px 7px; border-radius: 100px; margin-left: 2px; }
.chip[data-on="true"] .chip-count { background: rgba(14,14,12,.18); color: var(--on-accent); }

/* ====================================================
   RESPONSIVE — mobile-first equal citizen
   ==================================================== */
@media (max-width: 1080px) {
  .rev-grid { grid-template-columns: 1fr; gap: 36px; }
  .rev-aside { position: static; }
  .feature { grid-template-columns: 1fr; }
  .feature .frame { min-height: 280px; }
  .home-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 860px) {
  body { font-size: 16px; }
  .nav, .lang { display: none; }
  .menu-toggle { display: inline-grid; }
  .home-grid { grid-template-columns: 1fr 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 28px; }
  .split-cta { grid-template-columns: 1fr; }
  .hero-gallery { grid-template-columns: 1fr 1fr; height: 320px; }
  .hero-gallery .frame:first-child { grid-column: 1 / span 2; grid-row: auto; }
  .hero-gallery .frame:nth-child(n+4) { display: none; }
  .rev-head { grid-template-columns: 1fr; }
  .proscons { grid-template-columns: 1fr; gap: 22px; }

  /* catalog: switch list <-> map */
  .cat-split { grid-template-columns: 1fr; }
  .cat-list { padding-right: 0; }
  .cat-map-col { position: fixed; inset: 64px 0 0; height: auto; z-index: 30; display: none; }
  .catalog[data-view="map"] .cat-map-col { display: block; }
  .catalog[data-view="map"] .cat-list { display: none; }
  .view-switch { display: inline-flex; position: fixed; bottom: 22px; left: 50%; transform: translateX(-50%); z-index: 35; background: var(--text); color: var(--bg); border-radius: 100px; padding: 5px; box-shadow: var(--shadow); }
  .view-switch button { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; text-transform: uppercase; border: 0; background: transparent; color: inherit; padding: 9px 18px; border-radius: 100px; cursor: pointer; }
  .view-switch button[data-on="true"] { background: var(--accent); color: var(--on-accent); }
}

@media (max-width: 560px) {
  .wrap { padding: 0 18px; }
  .home-grid { grid-template-columns: 1fr; }
  .cat-grid, .spec { grid-template-columns: 1fr; }
  .rank-item { grid-template-columns: 56px 1fr; }
  .rank-item .frame { display: none; }
  .gallery-strip { grid-template-columns: 1fr; }
  .authority { gap: 26px; }
  .stat .n { font-size: 32px; }
}

/* sensible default icon size; context rules (e.g. .chip .ic) override */
.ic { width: 1em; height: 1em; flex: none; vertical-align: -0.15em; }

/* keyboard-active row + hide clear when empty */
.ac2-row.is-active { background: var(--bg-sunken); }
.searchbar-row input:placeholder-shown ~ .sb-clear { display: none; }
