/* =========================================================================
   SkyAlmanac — design system
   Palette: night sky #0b1020, golden hour #f5b942, lunar silver.
   Fonts: Fraunces (display), Inter (body), Spline Sans Mono (data).
   ========================================================================= */

:root {
  --bg:        #0b1020;
  --bg-2:      #10162b;
  --panel:     #141b33;
  --panel-2:   #182142;
  --line:      rgba(185,194,221,0.14);
  --line-2:    rgba(185,194,221,0.22);
  --ink:       #e8ecf7;
  --ink-soft:  #aab3cf;
  --ink-mute:  #7d87a6;
  --gold:      #f5b942;
  --gold-soft: #f7cf7e;
  --gold-dim:  rgba(245,185,66,0.14);
  --blue:      #6ea0ff;
  --blue-dim:  rgba(110,160,255,0.16);
  --silver:    #c9d2ee;

  --serif: "Fraunces", Georgia, "Times New Roman", serif;
  --sans:  "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --mono:  "Spline Sans Mono", ui-monospace, "SF Mono", Menlo, monospace;

  --wrap: 1080px;
  --r:    14px;
  --r-sm: 10px;
}

* { box-sizing: border-box; }

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

body {
  margin: 0;
  background:
    radial-gradient(1200px 620px at 78% -8%, rgba(245,185,66,0.10), transparent 60%),
    radial-gradient(900px 520px at 8% 4%, rgba(110,160,255,0.10), transparent 55%),
    var(--bg);
  color: var(--ink);
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

.wrap { width: 100%; max-width: var(--wrap); margin: 0 auto; padding: 0 20px; }

a { color: var(--gold-soft); text-decoration: none; }
a:hover { text-decoration: underline; text-underline-offset: 3px; }

h1, h2, h3 { font-family: var(--serif); font-weight: 500; line-height: 1.15; letter-spacing: -0.01em; }

.muted { color: var(--ink-mute); }

.skip {
  position: absolute; left: -999px; top: 0; background: var(--gold); color: #1a1206;
  padding: 10px 16px; border-radius: 0 0 var(--r-sm) 0; z-index: 100; font-weight: 600;
}
.skip:focus { left: 0; }

:focus-visible { outline: 2px solid var(--gold); outline-offset: 3px; border-radius: 4px; }

/* --------------------------------------------------------------- header */
.site-head {
  position: sticky; top: 0; z-index: 40;
  background: rgba(11,16,32,0.82);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--line);
}
.head-inner { display: flex; align-items: center; gap: 22px; height: 66px; }
.brand { display: inline-flex; align-items: center; gap: 10px; color: var(--ink); font-weight: 600; }
.brand:hover { text-decoration: none; }
.brand-name { font-family: var(--serif); font-size: 1.16rem; letter-spacing: -0.01em; }
.brand.small .brand-name { font-size: 1rem; }
.brand-mark {
  width: 20px; height: 20px; border-radius: 50%;
  background:
    radial-gradient(circle at 68% 34%, var(--gold-soft), var(--gold) 42%, #6a4d12 90%);
  box-shadow: inset -5px -3px 6px rgba(0,0,0,0.45), 0 0 12px rgba(245,185,66,0.5);
  flex: none;
}
.site-nav { display: flex; gap: 4px; margin-left: auto; flex-wrap: wrap; }
.site-nav a {
  color: var(--ink-soft); font-size: 0.94rem; padding: 7px 11px; border-radius: 8px;
}
.site-nav a:hover { color: var(--ink); background: var(--panel); text-decoration: none; }
.site-nav a[aria-current="page"] { color: var(--gold); background: var(--gold-dim); }

/* --------------------------------------------------------------- crumbs */
.crumbs { border-bottom: 1px solid var(--line); font-size: 0.86rem; }
.crumbs .wrap { padding-top: 12px; padding-bottom: 12px; color: var(--ink-mute); }
.crumbs a { color: var(--ink-soft); }
.crumb-sep { margin: 0 8px; color: var(--ink-mute); }
.crumbs [aria-current="page"] { color: var(--ink); }

/* --------------------------------------------------------------- hero */
.hero { border-bottom: 1px solid var(--line); }
.hero-inner { padding: 64px 20px 56px; }
.eyebrow {
  font-family: var(--mono); text-transform: uppercase; letter-spacing: 0.18em;
  font-size: 0.72rem; color: var(--gold); margin: 0 0 18px;
}
.hero-title { font-size: clamp(2.1rem, 5vw, 3.5rem); margin: 0 0 20px; max-width: 16ch; }
.hero-lede { font-size: 1.15rem; color: var(--ink-soft); max-width: 60ch; margin: 0 0 32px; }
.hero-hint { font-size: 0.88rem; color: var(--ink-mute); margin: 12px 2px 0; }

/* --------------------------------------------------------------- locator */
.locator {
  display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap;
  background: var(--panel); border: 1px solid var(--line);
  padding: 16px; border-radius: var(--r); max-width: 640px;
}
.hero-locator .locator { max-width: 680px; }
.locator-field { display: flex; flex-direction: column; gap: 6px; flex: 1 1 180px; }
.locator-field label {
  font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink-mute);
}
.locator input {
  background: var(--bg-2); border: 1px solid var(--line-2); color: var(--ink);
  border-radius: var(--r-sm); padding: 12px 13px; font-size: 1rem; font-family: var(--sans);
  width: 100%; min-width: 0;
}
.locator input:focus { border-color: var(--gold); outline: none; }
.loc-date { color-scheme: dark; }

.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--sans); font-size: 0.98rem; font-weight: 600; cursor: pointer;
  padding: 12px 20px; border-radius: var(--r-sm); border: 1px solid transparent;
  transition: transform .05s ease, background .15s ease;
}
.btn:hover { text-decoration: none; }
.btn:active { transform: translateY(1px); }
.btn-go { background: var(--gold); color: #1a1206; }
.btn-go:hover { background: var(--gold-soft); }
.btn.ghost { background: transparent; border-color: var(--line-2); color: var(--ink-soft); }
.btn.ghost:hover { border-color: var(--gold); color: var(--ink); }

/* --------------------------------------------------------------- sections */
.section { padding: 52px 20px; }
.section-title { font-size: 1.5rem; margin: 0 0 26px; }

.cards { display: grid; grid-template-columns: repeat(auto-fill, minmax(250px, 1fr)); gap: 16px; }
.card {
  display: flex; flex-direction: column; gap: 8px;
  background: var(--panel); border: 1px solid var(--line);
  border-radius: var(--r); padding: 22px; color: var(--ink);
  transition: border-color .15s ease, transform .12s ease, background .15s ease;
}
.card:hover { border-color: var(--line-2); transform: translateY(-2px); text-decoration: none; background: var(--panel-2); }
.card-kicker { font-family: var(--mono); font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); }
.card-h { font-family: var(--serif); font-size: 1.3rem; }
.card-p { color: var(--ink-soft); font-size: 0.95rem; }
.card-now { margin-top: auto; padding-top: 10px; font-family: var(--mono); font-size: 0.8rem; color: var(--ink-mute); border-top: 1px solid var(--line); }

/* city chips */
.city-chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.city-chips a {
  display: inline-block; padding: 7px 13px; border-radius: 999px;
  background: var(--panel); border: 1px solid var(--line); color: var(--ink-soft); font-size: 0.9rem;
}
.city-chips a:hover { border-color: var(--gold); color: var(--ink); text-decoration: none; }
.city-chips.big a { padding: 9px 16px; font-size: 0.96rem; }

/* --------------------------------------------------------------- page */
.page { padding: 8px 0 60px; }
.page.narrow .wrap { max-width: 760px; }
.page-head { padding: 40px 0 12px; }
.page-head h1 { font-size: clamp(1.9rem, 4vw, 2.8rem); margin: 6px 0 14px; }
.lede { font-size: 1.12rem; color: var(--ink-soft); max-width: 62ch; margin: 0; }
.page section { margin-top: 40px; }
.page section:first-of-type { margin-top: 28px; }

.notice {
  background: var(--gold-dim); border: 1px solid rgba(245,185,66,0.35);
  color: var(--gold-soft); border-radius: var(--r); padding: 16px 18px; line-height: 1.6; font-size: 0.96rem;
}
.notice code { font-family: var(--mono); background: rgba(0,0,0,0.28); padding: 1px 6px; border-radius: 5px; color: var(--ink); font-size: 0.86em; }
.notice strong { color: var(--ink); }

/* --------------------------------------------------------------- sun arc */
.arc-block {
  background: linear-gradient(180deg, var(--bg-2), var(--panel));
  border: 1px solid var(--line); border-radius: var(--r); padding: 18px 18px 12px;
}
.sun-arc { width: 100%; height: auto; display: block; }
.sun-arc .band-gold { fill: rgba(245,185,66,0.16); }
.sun-arc .band-blue { fill: rgba(110,160,255,0.15); }
.sun-arc .sky-area { fill: rgba(233,236,247,0.03); }
.sun-arc .sun-path { fill: none; stroke: var(--gold); stroke-width: 2.4; stroke-linecap: round; }
.sun-arc .horizon { stroke: var(--line-2); stroke-width: 1; stroke-dasharray: 4 5; }
.sun-arc .marker { fill: var(--gold); stroke: #1a1206; stroke-width: 1; }
.sun-arc .tick { stroke: var(--line-2); stroke-width: 1; }
.sun-arc .tick-label { fill: var(--ink-mute); font-family: var(--mono); font-size: 11px; }
.sun-arc .now-line { stroke: var(--silver); stroke-width: 1; stroke-dasharray: 2 4; }
.sun-arc .now-sun { fill: #fff; stroke: var(--gold); stroke-width: 2; filter: drop-shadow(0 0 5px rgba(245,185,66,0.9)); }

.arc-legend { display: flex; flex-wrap: wrap; gap: 16px; padding: 12px 4px 4px; }
.lg { font-family: var(--mono); font-size: 0.76rem; color: var(--ink-soft); display: inline-flex; align-items: center; gap: 7px; }
.lg::before { content: ""; width: 12px; height: 12px; border-radius: 3px; display: inline-block; }
.lg-gold::before { background: rgba(245,185,66,0.55); }
.lg-blue::before { background: rgba(110,160,255,0.55); }
.lg-day::before  { background: rgba(233,236,247,0.14); }
.lg-now::before  { background: #fff; border-radius: 50%; box-shadow: 0 0 5px var(--gold); }

/* golden cards */
.golden-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.gcard { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 22px; }
.gcard.gold { border-color: rgba(245,185,66,0.3); background: linear-gradient(180deg, var(--gold-dim), var(--panel)); }
.gcard-label { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--gold); margin: 0 0 8px; }
.gcard-time { font-family: var(--mono); font-size: 1.7rem; color: var(--ink); margin: 0 0 6px; font-weight: 500; }
.gcard-sub { color: var(--ink-soft); font-size: 0.92rem; margin: 0; }

/* weather (filled by JS) */
.weather:empty { display: none; }
.weather { background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 16px 18px; }
.weather .wx-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.weather .wx-label { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-mute); }
.weather .wx-val { font-family: var(--mono); font-size: 1.1rem; color: var(--ink); }
.weather .wx-note { color: var(--ink-soft); font-size: 0.9rem; }

/* times grid */
.times-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.times-grid.two { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
.tg-item { background: var(--panel); padding: 15px 16px; display: flex; flex-direction: column; gap: 4px; }
.tg-item.gold { background: linear-gradient(180deg, var(--gold-dim), var(--panel)); }
.tg-item.blue { background: linear-gradient(180deg, var(--blue-dim), var(--panel)); }
.tg-l { font-size: 0.82rem; color: var(--ink-mute); }
.tg-v { font-family: var(--mono); font-size: 1.12rem; color: var(--ink); }
.times-grid.newmoons { margin-top: 16px; }
.newmoons .section-title { grid-column: 1 / -1; background: var(--bg); padding: 4px 2px; border: 0; }

/* date nav */
.date-nav { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.date-nav .quick { display: flex; gap: 8px; flex-wrap: wrap; }
.date-nav .quick a { font-family: var(--mono); font-size: 0.82rem; color: var(--ink-soft); padding: 6px 12px; border-radius: 999px; border: 1px solid var(--line); }
.date-nav .quick a:hover { border-color: var(--gold); color: var(--ink); text-decoration: none; }

.picker-block h2 { font-size: 1.35rem; margin: 0 0 16px; }

/* faq */
.faq h2 { font-size: 1.5rem; margin: 0 0 18px; }
.faq details { border: 1px solid var(--line); border-radius: var(--r-sm); margin-bottom: 10px; background: var(--panel); overflow: hidden; }
.faq summary { cursor: pointer; padding: 15px 18px; font-weight: 600; color: var(--ink); list-style: none; position: relative; }
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; position: absolute; right: 18px; color: var(--gold); font-family: var(--mono); }
.faq details[open] summary::after { content: "–"; }
.faq details p { margin: 0; padding: 0 18px 16px; color: var(--ink-soft); }

/* crosslinks */
.crosslinks h2, .othercities h2 { font-size: 1.4rem; margin: 0 0 18px; }
.cl-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(230px, 1fr)); gap: 14px; }
.cl { display: flex; flex-direction: column; gap: 4px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 18px; color: var(--ink); }
.cl:hover { border-color: var(--gold); text-decoration: none; transform: translateY(-2px); }
.cl span { font-family: var(--serif); font-size: 1.1rem; }
.cl small { color: var(--ink-mute); font-size: 0.86rem; }

/* --------------------------------------------------------------- prose */
.prose { max-width: 68ch; }
.prose h2 { font-size: 1.5rem; margin: 0 0 14px; }
.prose h3 { font-size: 1.2rem; margin: 26px 0 10px; }
.prose p { color: var(--ink-soft); margin: 0 0 16px; }

/* --------------------------------------------------------------- moon */
.moon-block { display: flex; gap: 32px; align-items: center; flex-wrap: wrap; background: linear-gradient(180deg, var(--bg-2), var(--panel)); border: 1px solid var(--line); border-radius: var(--r); padding: 28px; }
.moon-figure { flex: none; }
.moon-disk { display: block; filter: drop-shadow(0 0 26px rgba(201,210,238,0.18)); }
.moon-facts { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 28px; flex: 1 1 260px; }
.fact { display: flex; flex-direction: column; gap: 2px; }
.fact-l { font-size: 0.78rem; color: var(--ink-mute); }
.fact-v { font-family: var(--mono); font-size: 1.1rem; color: var(--ink); }

/* --------------------------------------------------------------- fullmoon */
.year-nav { display: flex; gap: 12px; }
.month-jump { display: flex; flex-wrap: wrap; gap: 6px; }
.month-jump a { font-family: var(--mono); font-size: 0.8rem; text-transform: capitalize; padding: 6px 12px; border-radius: 8px; border: 1px solid var(--line); color: var(--ink-soft); }
.month-jump a:hover { border-color: var(--gold); color: var(--ink); text-decoration: none; }
.month-jump a.off { color: var(--ink-mute); opacity: 0.5; }
.fullmoon-list { display: grid; gap: 12px; }
.fm-month { border: 1px solid var(--line); border-radius: var(--r); padding: 18px 20px; background: var(--panel); scroll-margin-top: 84px; }
.fm-month h2 { font-size: 1.2rem; margin: 0 0 10px; }
.fm-month .muted { margin: 0; font-size: 0.92rem; }
.fm-row { display: flex; align-items: center; gap: 16px; padding: 6px 0; }
.fm-row + .fm-row { border-top: 1px solid var(--line); margin-top: 6px; }
.fm-disk { flex: none; }
.fm-disk .moon-disk { filter: none; }
.fm-date { margin: 0; font-family: var(--mono); font-size: 1rem; color: var(--ink); }
.fm-name { margin: 2px 0 0; color: var(--gold-soft); font-size: 0.9rem; }

/* --------------------------------------------------------------- meteors */
.meteor-list { display: grid; gap: 12px; }
.meteor-card { display: flex; align-items: center; gap: 18px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 16px 20px; color: var(--ink); }
.meteor-card:hover { border-color: var(--gold); transform: translateX(2px); text-decoration: none; }
.mc-peak { flex: none; width: 62px; text-align: center; border-right: 1px solid var(--line); padding-right: 16px; }
.mc-day { display: block; font-family: var(--serif); font-size: 1.9rem; line-height: 1; color: var(--gold); }
.mc-mon { display: block; font-family: var(--mono); font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--ink-mute); margin-top: 4px; }
.mc-body { display: flex; flex-direction: column; gap: 3px; flex: 1; }
.mc-name { font-family: var(--serif); font-size: 1.25rem; }
.mc-meta { font-size: 0.88rem; color: var(--ink-soft); }
.mc-active { font-size: 0.82rem; color: var(--ink-mute); }
.mc-arrow { color: var(--ink-mute); font-size: 1.3rem; flex: none; }
.meteor-card:hover .mc-arrow { color: var(--gold); }

/* --------------------------------------------------------------- iss */
.iss-passes { display: grid; gap: 10px; }
.iss-loading { color: var(--ink-mute); font-family: var(--mono); font-size: 0.9rem; }
.iss-pass { display: grid; grid-template-columns: auto 1fr auto; gap: 6px 18px; align-items: center; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); padding: 14px 18px; }
.iss-when { font-family: var(--mono); font-size: 1.05rem; color: var(--ink); }
.iss-date { font-size: 0.82rem; color: var(--ink-mute); }
.iss-meta { font-size: 0.85rem; color: var(--ink-soft); grid-column: 1 / -1; }
.iss-el { font-family: var(--mono); font-size: 1.2rem; color: var(--gold); text-align: right; }
.iss-el small { display: block; font-size: 0.62rem; color: var(--ink-mute); letter-spacing: 0.1em; text-transform: uppercase; }

/* --------------------------------------------------------------- cities table */
.cities-table { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--r); overflow: hidden; }
.ct-row { display: flex; align-items: center; justify-content: space-between; gap: 16px; background: var(--panel); padding: 13px 18px; flex-wrap: wrap; }
.ct-name { font-weight: 600; }
.ct-links { display: flex; gap: 14px; font-size: 0.88rem; }
.ct-links a { color: var(--ink-soft); }

/* --------------------------------------------------------------- contact */
.contact-card { background: linear-gradient(180deg, var(--gold-dim), var(--panel)); border: 1px solid rgba(245,185,66,0.3); border-radius: var(--r); padding: 28px; }
.contact-label { font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin: 0 0 8px; }
.contact-email { font-family: var(--mono); font-size: 1.35rem; margin: 0 0 10px; word-break: break-word; }
.contact-email a { color: var(--ink); }

/* --------------------------------------------------------------- footer */
.site-foot { border-top: 1px solid var(--line); margin-top: 40px; background: var(--bg-2); }
.foot-inner { display: flex; gap: 40px; justify-content: space-between; flex-wrap: wrap; padding: 40px 20px 24px; }
.foot-col { max-width: 34ch; }
.foot-col .brand { margin-bottom: 8px; }
.foot-col p { margin: 0; font-size: 0.9rem; }
.foot-links { display: flex; flex-direction: column; gap: 8px; }
.foot-links a { color: var(--ink-soft); font-size: 0.92rem; }
.foot-bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 18px; padding-bottom: 28px; border-top: 1px solid var(--line); font-size: 0.82rem; }

/* --------------------------------------------------------------- responsive */
@media (max-width: 640px) {
  body { font-size: 16px; }
  .golden-cards { grid-template-columns: 1fr; }
  .moon-facts { grid-template-columns: 1fr 1fr; gap: 12px 18px; }
  .site-nav { display: none; }
  .head-inner { height: 58px; }
  .hero-inner { padding: 44px 20px 40px; }
  .gcard-time { font-size: 1.45rem; }
  .foot-inner { gap: 28px; }
}

@media (prefers-reduced-motion: reduce) {
  * { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

/* ---- Language switcher ---- */
.lang-switch { display: flex; gap: 2px; margin-left: 10px; align-items: center; }
.lang-switch a, .lang-switch span {
  font-family: var(--mono); font-size: 0.72rem; letter-spacing: 0.06em;
  padding: 5px 8px; border-radius: 7px; color: var(--ink-mute); text-decoration: none;
}
.lang-switch a:hover { color: var(--ink); background: var(--panel); }
.lang-switch span[aria-current="true"] { color: var(--gold); background: var(--gold-dim); }

/* ---- Country groups on the cities page ---- */
.cities-group { margin-top: 30px; }
.cities-group .section-title { margin-bottom: 12px; }

/* ---- Notice variants ---- */
.notice.good { border-color: rgba(120, 200, 150, 0.4); background: rgba(90, 170, 120, 0.12); }

/* ---- Ad slots (only render when configured) ---- */
.ad-slot { display: block; margin: 22px auto; max-width: var(--wrap, 960px); padding: 0 20px; text-align: center; }
.ad-slot.ad-header, .ad-slot.ad-footer { margin: 14px auto; }
.ad-label {
  display: block; font-family: var(--mono); font-size: 0.6rem; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--ink-mute); margin-bottom: 6px;
}

/* ---- Affiliate gear module ---- */
.gear { margin: 26px 0; padding: 20px 22px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--r); }
.gear h2 { margin: 0 0 12px; font-size: 1.1rem; }
.gear-list { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: 8px; }
.gear-list a {
  display: inline-block; padding: 8px 14px; border: 1px solid var(--line); border-radius: 999px;
  color: var(--ink); background: rgba(255,255,255,0.02); font-size: 0.92rem; text-decoration: none;
}
.gear-list a:hover { border-color: var(--gold); color: var(--gold); }
.gear-note { margin: 12px 0 0; font-size: 0.8rem; color: var(--ink-mute); }

/* ---- Cookie consent banner ---- */
.consent {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 50; margin: 0 auto; max-width: 640px;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--r);
  padding: 16px 18px; box-shadow: 0 10px 40px rgba(0,0,0,0.5);
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.consent[hidden] { display: none; }
.consent-text { margin: 0; flex: 1 1 260px; font-size: 0.9rem; color: var(--ink-soft); }
.consent-actions { display: flex; gap: 8px; }

@media (max-width: 720px) {
  .lang-switch { margin-left: auto; }
}

/* ---- Country selector (home) ---- */
.country-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 12px; }
.country-card {
  display: flex; flex-direction: column; gap: 4px; padding: 16px 18px;
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--r);
  color: var(--ink); text-decoration: none;
}
.country-card:hover { border-color: var(--gold); }
.country-flag { font-size: 1.7rem; line-height: 1; }
.country-name { font-weight: 600; }
.country-count { font-family: var(--mono); font-size: 0.78rem; color: var(--ink-mute); }
.cities-group { scroll-margin-top: 84px; }
.cities-group .country-flag { font-size: 1.15rem; vertical-align: -1px; }
