.app {
  min-height: 100vh;
  background: var(--neu-bg);
  display: flex;
  flex-direction: column;
}

/* ── HEADER ─────────────────────────────── */
.neu-header {
  height: 60.5px;
  background: var(--neu-surface);
  border-bottom: 1px solid var(--neu-border);
  box-shadow: var(--neu-shadow-hairline);
  padding: 0 17.5px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: sticky; top: 0; z-index: 10000;
}
.neu-header__brand {
  display:flex; align-items:center; gap: 10.5px;
}
.neu-header__wordmark {
  display: flex; align-items: center; gap: 10.5px;
}
.neu-header__back {
  display: none;
  align-items: center; gap: 4px;
  background: transparent; border: none; padding: 4px 6px 4px 0;
  color: var(--neu-fg-1);
  font: 500 14px/20px var(--neu-font-sans);
  letter-spacing: -0.150px;
  cursor: pointer;
  border-radius: 6.75px;
}
.neu-header__back:active { transform: scale(0.97); }

.neu-header__actions {
  display: flex; align-items: center; gap: 10px;
}

.segmented-control {
  display: inline-flex;
  gap: 0;
  align-items: stretch;
  border: 1px solid var(--neu-border-soft);
  border-radius: 8.75px;
  background: var(--neu-surface);
  overflow: hidden;
  height: 32px;
}
.units-selector .lang-selector__btn { min-width: 58px; }
.temperature-selector .lang-selector__btn { min-width: 34px; }
.lang-selector__label {
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-right: 1px solid var(--neu-border-soft);
  font: 600 11.5px/1 var(--neu-font-sans);
  color: #8A94A6;
  white-space: nowrap;
}
.lang-selector__btn {
  appearance: none;
  background: transparent;
  border: none;
  padding: 0 10px;
  font: 600 11.5px/1 var(--neu-font-sans);
  letter-spacing: 0.2px;
  color: var(--neu-fg-3);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}
.lang-selector__btn + .lang-selector__btn {
  border-left: 1px solid var(--neu-border-soft);
}
.lang-selector__btn:hover { color: var(--neu-fg-1); }
.lang-selector__btn.is-active {
  background: var(--neu-accent);
  color: #fff;
}

.settings-menu {
  position: relative;
}
.settings-menu__button {
  width: 38px;
  height: 34px;
  border: 1px solid var(--neu-border-soft);
  border-radius: 8.75px;
  background: var(--neu-surface);
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  cursor: pointer;
  box-shadow: var(--neu-shadow-hairline);
}
.settings-menu__button:hover {
  background: #F8FAFC;
}
.settings-menu__burger {
  display: none;
  width: 18px;
  height: 2px;
  border-radius: 9999px;
  background: var(--neu-fg-1);
}
.settings-menu__button.is-open {
  border-color: rgba(0,122,255,0.4);
  box-shadow: 0 0 0 3px rgba(0,122,255,0.12), var(--neu-shadow-hairline);
}
.settings-menu__gear {
  display: block;
}
.settings-menu__panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 60;
  padding: 10px;
  border: 1px solid var(--neu-border);
  border-radius: 10px;
  background: var(--neu-surface);
  box-shadow: 0 12px 32px rgba(0,0,0,0.12), 0 2px 6px rgba(0,0,0,0.06);
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 300px;
}
.settings-menu__panel .segmented-control {
  width: 100%;
  height: 38px;
}
.settings-menu__panel .lang-selector__label {
  padding: 0 12px;
  font-size: 12px;
}
.settings-menu__panel .lang-selector__btn {
  flex: 1 1 0;
  min-width: 0;
  padding: 0;
  font-size: 12px;
}
.settings-menu__download.neu-btn-primary {
  width: 100%;
  box-sizing: border-box;
  text-align: center;
  display: none;
}

.neu-btn-primary {
  background: var(--neu-accent);
  color: #fff;
  border: none;
  border-radius: 8.75px;
  padding: 8px 17.5px;
  font: 500 12.25px/17.5px var(--neu-font-sans);
  letter-spacing: -0.018px;
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
  transition: background 0.15s ease, transform 0.15s ease;
}
.neu-btn-primary:hover { background: #006AE0; }
.neu-btn-primary:active { transform: scale(0.97); }
.neu-btn-primary--light {
  background: #fff;
  color: var(--neu-fg-1);
  border: 1px solid var(--neu-border);
  box-shadow: var(--neu-shadow-hairline);
}
.neu-btn-primary--light:hover { background: #F8FAFC; }
.neu-btn-primary--dark { background: #000; }
.neu-btn-primary--dark:hover { background: #1a1a1a; }

/* ── MAIN SHELL ─────────────────────────── */
.main {
  display: flex;
  flex: 1;
  min-height: 0;
}

/* ── SIDEBAR ────────────────────────────── */
.neu-sidebar {
  width: 296px;
  flex-shrink: 0;
  background: var(--neu-surface);
  border-right: 1px solid var(--neu-border);
  display: flex;
  flex-direction: column;
  height: calc(100vh - 60.5px);
  position: sticky; top: 60.5px;
}
.neu-sidebar__head {
  padding: 14px;
  border-bottom: 1px solid var(--neu-border);
  display: flex; flex-direction: column; gap: 10.5px;
  position: relative;
}
.neu-sidebar__title {
  display: flex; align-items: center; gap: 7px;
  white-space: nowrap;
}
.neu-sidebar__title .neu-h4 { white-space: nowrap; }

.neu-sidebar__search {
  width: 100%;
  height: 33.5px;
  background: #FFFFFF;
  border: 1px solid var(--neu-border);
  box-shadow: var(--neu-shadow-hairline);
  border-radius: 6.75px;
  padding: 0 10.5px;
  display: flex;
  align-items: center;
  gap: 7px;
}
.neu-sidebar__search input {
  min-width: 0;
  flex: 1;
  border: 0;
  outline: 0;
  background: transparent;
  font: 400 12.25px/17.5px var(--neu-font-sans);
  letter-spacing: -0.018px;
  color: var(--neu-fg-1);
  appearance: none;
}
.neu-sidebar__search input::placeholder { color: var(--neu-fg-4); }
.neu-sidebar__search:focus-within {
  border-color: rgba(0,122,255,0.55);
  box-shadow: 0 0 0 3px rgba(0,122,255,0.12), var(--neu-shadow-hairline);
}

.neu-combobox {
  width: 100%;
  background: #FFFFFF;
  border: 1px solid var(--neu-border);
  box-shadow: var(--neu-shadow-hairline);
  border-radius: 6.75px;
  padding: 7px 10.5px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer;
  font: 400 12.25px/17.5px var(--neu-font-sans);
  letter-spacing: -0.018px;
  color: var(--neu-fg-1);
}
.neu-combobox__lbl { color: var(--neu-fg-1); }
.neu-combobox__ct  { color: var(--neu-fg-4); font-size: 10.5px; margin-left: 7px; font-variant-numeric: tabular-nums; }
.neu-combobox__ch  { margin-left: auto; opacity: 0.5; }

.neu-combobox__menu {
  position: absolute;
  top: calc(100% - 6px);
  left: 14px; right: 14px;
  max-height: 380px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.12), 0 2px 6px rgba(0,0,0,0.06);
  z-index: 50;
  padding: 6px 0;
}
.neu-combobox__section {
  font: 600 10.5px/1.2 var(--neu-font-sans);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  color: var(--neu-fg-4);
  padding: 10px 12px 4px;
}
.neu-combobox__opt {
  width: 100%;
  background: transparent;
  border: none;
  padding: 7px 12px;
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer;
  font: 400 12.25px/17.5px var(--neu-font-sans);
  color: var(--neu-fg-1);
  text-align: left;
}
.neu-combobox__opt:hover { background: var(--neu-bg); }
.neu-combobox__opt.is-sel { background: rgba(0,122,255,0.08); color: #007AFF; font-weight: 500; }
.neu-combobox__opt--country {
  margin-top: 6px;
  color: var(--neu-fg-4);
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
}
.neu-combobox__opt--country .neu-combobox__opt-ct {
  font-size: 12.25px;
  font-weight: 500;
  letter-spacing: 0;
}
.neu-combobox__opt--nested { padding-left: 24px; }
.neu-combobox__opt-ct {
  color: var(--neu-fg-4);
  font-size: 10.5px;
  font-variant-numeric: tabular-nums;
}
.neu-combobox__opt.is-sel .neu-combobox__opt-ct { color: #007AFF; }

.neu-sidebar__list {
  flex: 1; overflow-y: auto;
  padding: 12.25px;
  display: flex; flex-direction: column; gap: 12.25px;
}
.neu-sidebar__group {
  font: 500 11px/1.2 var(--neu-font-sans);
  letter-spacing: 0.3px;
  color: var(--neu-fg-3);
  padding: 4px 4px 2px;
  border-bottom: 1px solid var(--neu-border);
  margin-top: 4px;
}
.neu-sidebar__group-country {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--neu-fg-2);
}
.neu-sidebar__group:first-child { margin-top: 0; }

.neu-sidebar__empty {
  padding: 18px 8px;
  text-align: center;
  font: 400 12.25px/17.5px var(--neu-font-sans);
  letter-spacing: -0.018px;
  color: var(--neu-fg-4);
}

.app--loading {
  min-height: 100vh;
  display: grid; place-items: center;
  background: var(--neu-bg);
}
.loading-pill {
  font: 500 14px/1 var(--neu-font-sans);
  color: var(--neu-fg-3);
  padding: 12px 20px;
  border-radius: 999px;
  background: #fff;
  box-shadow: var(--neu-shadow-float);
}

/* ── RESORT CARD (sidebar) ──────────────── */
.resort-card {
  position: relative;
  width: 100%;
  height: 140px;
  min-height: 140px;
  display: block;
  box-sizing: border-box;
  border-radius: 12.75px;
  overflow: hidden;
  padding: 0;
  margin: 0;
  border: 6px solid transparent;
  background: #eee;
  cursor: pointer;
  font: inherit;
  color: inherit;
  text-align: left;
  appearance: none;
  -webkit-appearance: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.resort-card:hover { box-shadow: var(--neu-shadow-float); }
.resort-card.is-active { border-color: var(--neu-accent); box-shadow: var(--neu-shadow-float); }

.resort-card__bg   {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform: scale(1);
  transition: transform 600ms cubic-bezier(0.22, 1, 0.36, 1);
}
.resort-card:hover .resort-card__bg { transform: scale(1.08); }
.resort-card__grad {
  position:absolute; inset:0;
  background: linear-gradient(
    rgba(0,0,0,0) 0%,
    rgba(0,0,0,0.25) 55%,
    rgba(0,0,0,0.7) 100%);
}
.resort-card__logo {
  position:absolute; top:7px; left:7px;
  width: 35px; height: 35px;
  background: rgba(255,255,255,0.9);
  border-radius: 8.75px;
  display: flex; align-items:center; justify-content:center;
}
.resort-card__logo img { width: 24.5px; height: 24.5px; object-fit: contain; }
.resort-card__meta {
  position:absolute; bottom: 7px; left: 8.75px; right: 8.75px;
  text-align: left;
}
.resort-card .resort-card__meta .neu-h3 {
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 15px;
  line-height: 20px;
  max-width: 100%;
}
.resort-card__region {
  font: 400 10.5px/14px var(--neu-font-sans);
  color: rgba(255,255,255,0.9);
  letter-spacing: 0.092px;
  margin-top: 1.75px;
}
.resort-card__stats {
  font: 400 10.5px/14px var(--neu-font-sans);
  color: rgba(255,255,255,0.8);
  letter-spacing: 0.092px;
  margin-top: 1.75px;
}

/* ── CONTENT COLUMN ─────────────────────── */
.content {
  flex: 1;
  padding: 17.5px 28px 60px;
  max-width: 1400px;
  margin: 0 auto;
  width: 100%;
  display: flex; flex-direction: column;
  gap: 17.5px;
}

/* ── FOOTER ─────────────────────────────── */
.site-footer {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) minmax(0, 2fr);
  gap: 28px;
  padding: 24px 0 0;
  margin-top: 14px;
  background: transparent;
  border-top: 1px solid var(--neu-border);
}
.site-footer__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  align-self: start;
  width: fit-content;
  color: var(--neu-fg-1);
  font: 700 15px/20px var(--neu-font-sans);
  letter-spacing: 0;
  text-decoration: none;
}
.site-footer__columns {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 22px;
}
.site-footer__column {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.site-footer__heading {
  color: var(--neu-fg-1);
  font: 700 12px/16px var(--neu-font-sans);
  letter-spacing: 0.2px;
  margin-bottom: 2px;
}
.site-footer__link {
  width: fit-content;
  color: var(--neu-fg-4);
  font: 500 12.25px/17.5px var(--neu-font-sans);
  letter-spacing: 0;
  text-decoration: none;
  transition: color 0.12s ease;
}
.site-footer__link:hover {
  color: var(--neu-accent-ink);
}

/* ── RESORT HEADER ──────────────────────── */
.resort-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 0;
  gap: 14px;
}
.resort-header__left { display: flex; gap: 10.5px; align-items: center; }
.resort-header__actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 10px;
}
.resort-header__logo {
  width: 98px; height: 98px;
  background: var(--neu-surface);
  border: 1px solid var(--neu-border-soft);
  border-radius: 12.75px;
  box-shadow: var(--neu-shadow-hairline);
  display: flex; align-items:center; justify-content:center;
}
.resort-header__logo img { width: 86px; height: 86px; object-fit: contain; }
.resort-header__title { font-size: 32px; line-height: 1.15; letter-spacing: -0.6px; margin-bottom: 2px; }
.resort-header__subtitle { font-size: 20px; line-height: 1.2; color: var(--neu-fg-4); }

.resort-3d__backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.7);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  animation: fadeIn 200ms ease;
}
@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
.resort-3d__modal {
  width: min(1100px, 92vw);
  height: min(720px, 88vh);
  background: #fff;
  border-radius: 16px;
  display: flex; flex-direction: column;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
}
.resort-3d__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--neu-border-soft);
  flex-shrink: 0;
}
.resort-3d__close {
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--neu-border-soft);
  background: #fff;
  font-size: 22px; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.resort-3d__close:hover { background: var(--neu-bg); }
.resort-3d__modal model-viewer { flex: 1; }

.neu-card.resort-3d-viewer { position: relative; padding: 0; overflow: hidden; gap: 0; }
.resort-3d-viewer__stage {
  position: relative;
  height: 400px;
  min-height: 400px;
  flex: 0 0 400px;
  background: #fff;
}
.resort-3d-viewer:fullscreen { padding: 0; border-radius: 0; background: #fff; }
.resort-3d-viewer:fullscreen .resort-3d-viewer__stage {
  height: 100vh;
  min-height: 100vh;
  flex: 1 1 100vh;
}
.resort-3d-viewer__gate {
  position: absolute;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 12px;
  background: rgba(255,255,255,0.62);
  backdrop-filter: blur(4px);
}
.resort-3d-viewer__ar-banner {
  width: min(176px, 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 12px 18px;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  background: rgba(255,255,255,0.96);
  box-shadow: var(--neu-shadow-hairline);
  color: var(--neu-fg-1);
  font: 600 15px/20px var(--neu-font-sans);
  text-align: center;
  text-decoration: none;
  transition: background 0.15s ease, transform 0.15s ease;
}
.resort-3d-viewer__qr {
  width: 118px;
  height: 118px;
  display: block;
  border-radius: 4px;
  object-fit: contain;
}
.resort-3d-viewer__ar-banner:hover { background: #F8FAFC; }
.resort-3d-viewer__ar-banner:active { transform: scale(0.995); }
.resort-3d-viewer__full {
  position: absolute;
  bottom: 12px; right: 12px;
  min-width: 32px; height: 32px;
  padding: 0 10px;
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  cursor: pointer;
  box-shadow: var(--neu-shadow-hairline);
  z-index: 1000;
  font: 500 12px/1 var(--neu-font-sans);
  color: var(--neu-fg-1);
}
.fullscreen-icon {
  flex: 0 0 auto;
}
.resort-3d-viewer__copy {
  position: absolute;
  bottom: 12px; left: 12px;
  font: 500 10px/1 var(--neu-font-sans);
  color: var(--neu-fg-4);
  letter-spacing: 0.2px;
  user-select: none;
  pointer-events: none;
  z-index: 1000;
}

.resort-header__logo--fallback { background: #EFF6FF; border-color: #DBEAFE; }

/* ── CARDS (generic) ─────────────────────── */
.neu-card {
  background: var(--neu-surface);
  border: 1px solid var(--neu-border-soft);
  border-radius: 12.75px;
  box-shadow: var(--neu-shadow-hairline);
  padding: 17.5px;
  position: relative;
  display: flex; flex-direction: column;
  gap: 14px;
}

/* ── GRID ───────────────────────────────── */
/* Single 3-col grid so top row (photo span 2 + stats) aligns perfectly
   with bottom row (webcams + forecast + trail). */
.grid-main {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: 420px auto;
  gap: 17.5px;
  align-items: stretch;
}
.grid-main > :nth-child(1) { grid-column: span 2; }

.grid-maps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 17.5px;
  align-items: stretch;
}
.grid-maps > :nth-child(1) { grid-column: span 2; }
.grid-maps .region-map__canvas {
  height: 100%;
  min-height: 400px;
  flex: 1 1 auto;
}

.neu-card.snowfall-map { padding: 0; gap: 0; overflow: hidden; }
.snowfall-map .neu-h4 { padding: 14px 18px 12px; border-bottom: 1px solid var(--neu-border-soft); }
.snowfall-map__frame {
  width: 100%;
  height: 500px;
  border: none;
  display: block;
}

.neu-card.webcams { padding: 0; gap: 0; overflow: hidden; }
.webcams .neu-h4 { padding: 14px 18px 12px; border-bottom: 1px solid var(--neu-border-soft); }
.webcams__stage {
  position: relative;
  background: #000;
}
.webcams__cam {
  width: 100%;
  height: 245px;
  border: none;
  display: block;
  background: #000;
}
.webcams__nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 150ms ease, transform 150ms ease;
}
.webcams__nav:hover { background: rgba(0, 0, 0, 0.85); }
.webcams__nav:active { transform: translateY(-50%) scale(0.94); }
.webcams__nav--prev { left: 10px; }
.webcams__nav--next { right: 10px; }
.webcams__dots {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 12px;
}
.webcams__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--neu-border);
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background 150ms ease, transform 150ms ease;
}
.webcams__dot:hover { background: var(--neu-fg-3); }
.webcams__dot--active {
  background: #000;
  transform: scale(1.2);
}
.webcams__empty {
  padding: 24px 18px;
  color: var(--neu-fg-3);
  font-size: 13px;
}

/* ── PHOTO ──────────────────────────────── */
.photo-carousel {
  border-radius: 14px;
  overflow: hidden;
  height: 100%;
  min-height: 280px;
  border: 1px solid var(--neu-border-soft);
  box-shadow: var(--neu-shadow-hairline);
}
.photo-carousel img {
  width: 100%; height: 100%; object-fit: cover; object-position: top; display:block;
  animation: photo-fade-in 600ms cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes photo-fade-in {
  from { opacity: 0; transform: scale(1.04); }
  to   { opacity: 1; transform: scale(1); }
}

/* ── STATS ──────────────────────────────── */
.neu-card--stats { gap: 12px; }
.stats-row {
  display: grid;
  grid-template-columns: 45% 55%;
  align-items: center;
  gap: 12px;
  padding: 4px 0;
}
.stats-donut { position: relative; width: 100%; max-width: 176px; aspect-ratio: 1 / 1; margin: 0 auto; }
.stats-donut svg { width: 100%; height: 100%; overflow: visible; display: block; }
.stats-donut__seg {
  transition: stroke-dasharray 700ms cubic-bezier(0.22, 1, 0.36, 1),
              stroke-dashoffset 700ms cubic-bezier(0.22, 1, 0.36, 1),
              stroke 400ms ease;
}
.stats-donut__center {
  position: absolute; inset: 0;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align: center;
  gap: 0;
  line-height: 1;
}
.stats-donut__center .neu-display {
  color: #000;
  font-weight: 900;
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.5px;
}
.stats-donut__center-lbl {
  color: var(--neu-fg-3);
  font: 500 12px/1 var(--neu-font-sans);
  margin-top: 4px;
}
.stats-legend { display:flex; flex-direction:column; gap: 5px; }
.stats-legend__row { display:flex; align-items:center; gap: 10px; }
.stats-legend__sq {
  display:inline-flex; align-items:center; justify-content:center;
  width: 30px; height: 28px;
  border-radius: 8px;
  color: #fff;
  font: 600 14px/1 var(--neu-font-sans);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
  letter-spacing: -0.1px;
  padding: 0 4px;
}
/* Decimal km values (US/Canada km mode) need smaller text to keep the square padded. */
.stats-legend__sq--sm {
  font-size: 13.5px;
  letter-spacing: -0.2px;
}
/* US/Canada km mode: wider squares + larger row gap. Scoped to the parent
   so the EU/RoW count mode stays at the original sizing. */
.stats-legend--km { gap: 10px; }
.stats-legend--km .stats-legend__sq { width: 40px; height: 30px; }
.stats-legend__row .neu-body {
  font: 500 14px/1.2 var(--neu-font-sans);
  color: #000;
  letter-spacing: -0.1px;
}

.stats-donut__num {
  fill: #fff;
  font: 600 3.4px/1 var(--neu-font-sans);
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}

.stats-kvs {
  border-top: 1px solid var(--neu-border);
  padding-top: 14px;
  display: flex; flex-direction: column; gap: 10px;
}
.kv {
  display: flex; justify-content: space-between; align-items: center;
  gap: 10px;
  font: 400 12.25px/17.5px var(--neu-font-sans);
  color: var(--neu-fg-4);
  letter-spacing: -0.018px;
}
.kv > :first-child { white-space: nowrap; }
.kv > :last-child {
  color: var(--neu-fg-1);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}
.kv__link { color: var(--neu-accent-ink) !important; }

/* ── SKI INSURANCE (Intermundial ad) ────── */
.ski-insurance__link {
  position: relative;
  display: block;
  height: 245px;
  border-radius: 8.75px;
  background: var(--neu-surface-3);
  text-decoration: none;
  overflow: hidden;
}
.ski-insurance__link img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: left bottom;
  display: block;
  transition: transform 0.4s ease;
}
.ski-insurance__link:hover img { transform: scale(1.03); }
.ski-insurance__overlay {
  position: absolute;
  top: 18px;
  left: 18px;
  right: 50%;
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: #fff;
  pointer-events: none;
  text-shadow: 0 1px 8px rgba(0, 0, 0, 0.25);
}
.ski-insurance__pct {
  font: 700 66px/1 var(--neu-font-sans);
  letter-spacing: -1.8px;
}
.ski-insurance__text {
  font: 500 15px/1.2 var(--neu-font-sans);
  letter-spacing: -0.2px;
  white-space: pre-line;
}

/* ── TRAIL MAP ──────────────────────────── */
.trail {
  position: relative;
  height: 245px;
  border-radius: 8.75px;
  overflow: hidden;
  background: var(--neu-surface-3);
}
.trail img { width: 100%; height: 100%; object-fit: cover; display:block; }
.trail__btn {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  padding: 10.5px 21px;
  box-shadow: var(--neu-shadow-hairline);
  font: 500 14px/21px var(--neu-font-sans);
  letter-spacing: -0.150px;
  color: #000;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  white-space: nowrap;
  transition: background 0.15s ease, transform 0.15s ease;
}
.trail__btn:hover { background: #F8FAFC; }
.trail__btn:active { transform: translate(-50%, -50%) scale(0.97); }

/* ── REGION MAP ─────────────────────────── */
.region-map {
  position: relative;
  z-index: 0;
  padding: 0;
  overflow: hidden;
  gap: 0;
}
.region-map__banner {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: #fff;
  position: absolute;
  top: 12px; left: 12px;
  border-radius: 8.75px;
  border: 1px solid var(--neu-border);
  box-shadow: var(--neu-shadow-hairline);
  z-index: 1000;
}
.region-map__canvas {
  position: relative;
  height: 400px;
  min-height: 400px;
  flex: 0 0 400px;
  background: #EEF1F3;
}
.region-map:fullscreen { padding: 0; border-radius: 0; background: #EEF1F3; }
.region-map:fullscreen .region-map__canvas {
  height: 100vh;
  min-height: 100vh;
  flex: 1 1 100vh;
}
.region-map .leaflet-container {
  width: 100%; height: 100%;
  background: #EEF1F3;
  font: inherit;
}
.region-map .leaflet-control-attribution {
  background: rgba(255,255,255,0.8);
  font-size: 10px;
  color: var(--neu-fg-4);
  padding: 2px 6px;
  border-radius: 4px;
}
.region-map .pin-icon { background: none; border: none; }
.region-map .pin-icon .pin {
  position: relative;
  width: 66px; height: 90px;
  transform: none;
}
.region-map .pin-icon .pin--sel {
  transform: scale(1.15);
  transform-origin: 50% 100%;
}
.region-map__hint {
  position: absolute;
  bottom: 12px; left: 12px;
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  box-shadow: var(--neu-shadow-hairline);
  z-index: 500;
  font: 500 12px/1 var(--neu-font-sans);
  color: var(--neu-fg-2);
}
.region-map__full {
  position: absolute;
  bottom: 12px; right: 12px;
  min-width: 32px; height: 32px;
  padding: 0 10px;
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  display: flex; align-items: center; justify-content: center; gap: 7px;
  cursor: pointer;
  box-shadow: var(--neu-shadow-hairline);
  z-index: 1000;
  font: 500 12px/1 var(--neu-font-sans);
  color: var(--neu-fg-1);
}
.region-map__zoom {
  position: absolute; top: 12px; right: 12px;
  display: flex; flex-direction: column;
  background: #fff;
  border: 1px solid var(--neu-border);
  border-radius: 8.75px;
  overflow: hidden;
  box-shadow: var(--neu-shadow-hairline);
  z-index: 1000;
}
.region-map__zoom button {
  width: 32px; height: 32px;
  background: #fff; border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1px solid var(--neu-border-soft);
}
.region-map__zoom button:last-child { border-bottom: none; }

.pin {
  position: absolute;
  transform: translate(-50%, -100%);
  background: transparent; border: none; padding: 0; cursor: pointer;
  width: 66px; height: 90px;
  filter: drop-shadow(0 3px 4px rgba(0,0,0,0.22));
  transition: transform 0.15s ease, z-index 0s;
  z-index: 1;
}
.pin--sel { z-index: 2; transform: translate(-50%, -100%) scale(1.15); }
.pin__svg { position: absolute; inset: 0; width: 100%; height: 100%; display: block; }
.pin__well {
  position: absolute;
  top: 1px; left: 10px;
  width: 24px; height: 24px;
  background: #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  z-index: 2;
}
.pin__well img { width: 20px; height: 20px; object-fit: contain; }

.neu-sidebar .neu-h4 { font-size: 14px; }

/* ── RESPONSIVE ─────────────────────────── */

/* Tablet: tighter sidebar, photo full width above stats, weather/forecast + map 2+(full) */
@media (max-width: 1100px) {
  .neu-sidebar { width: 260px; }
  .grid-main {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-main > :nth-child(1), /* photo */
  .grid-main > :nth-child(2), /* stats */
  .grid-main > :nth-child(5)  /* trail */
  {
    grid-column: 1 / -1;
  }
  .photo-carousel { min-height: 320px; }
  .stats-row { grid-template-columns: 180px 1fr; }
  .stats-donut { width: 180px; height: 180px; }
  .content { padding: 14px 21px 50px; }

  .grid-maps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid-maps > :nth-child(1) { grid-column: auto; }
}

/* Mobile: sidebar stacks above, everything goes single-column */
@media (max-width: 768px) {
  .neu-header {
    padding: 0 14px;
    height: 54px;
    position: sticky;
  }
  .neu-header__brand { gap: 8px; }
  .neu-header__home {
    position: absolute;
    left: 50%;
    top: 50%;
    max-width: calc(100% - 176px);
    transform: translate(-50%, -50%);
    justify-content: center;
    gap: 8px;
    white-space: nowrap;
  }
  .neu-header__brand .neu-h2 { font-size: 16px; }
  .neu-btn-primary { padding: 7px 14px; font-size: 12px; }
  .neu-header__actions { gap: 8px; }
  .neu-header__download { display: none; }
  .settings-menu__button {
    width: 42px;
    height: 36px;
  }
  .settings-menu__gear { display: none; }
  .settings-menu__burger { display: block; }
  .settings-menu__panel { min-width: 232px; }
  .settings-menu__download.neu-btn-primary { display: block; }

  .main { flex-direction: column; }

  .neu-sidebar {
    width: 100%;
    position: static;
    height: calc(100vh - 54px);
    border-right: none;
    border-bottom: none;
  }
  .neu-sidebar__head { padding: 12px; }
  .neu-sidebar__list {
    padding: 12px;
    gap: 10px;
  }

  /* Master-detail navigation */
  .app--mobile-list .content { display: none; }
  .app--mobile-detail .neu-sidebar { display: none; }
  .app--mobile-detail .neu-header__wordmark { display: none; }
  .app--mobile-detail .neu-header__back { display: inline-flex; }

  .content {
    padding: 14px 12px 40px;
    gap: 14px;
  }

  .site-footer {
    grid-template-columns: 1fr;
    gap: 18px;
    padding: 18px;
  }
  .site-footer__columns {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .resort-header {
    padding: 0;
    flex-wrap: wrap;
    gap: 12px;
  }
  .resort-header__left { gap: 10px; }
  .resort-header__actions {
    width: 100%;
    justify-content: stretch;
  }
  .resort-header__actions .neu-btn-primary {
    flex: 1 1 160px;
    text-align: center;
  }
  .resort-header__logo { width: 98px; height: 98px; border-radius: 12.75px; }
  .resort-header__logo img { width: 86px; height: 86px; }
  .neu-card { padding: 14px; gap: 12px; }

  .grid-main { grid-template-columns: 1fr; grid-template-rows: auto; gap: 14px; }
  .grid-main > * { grid-column: auto !important; }

  .grid-maps { grid-template-columns: 1fr; gap: 14px; }
  .grid-maps > * { grid-column: auto !important; }

  .photo-carousel { min-height: 220px; max-height: 300px; border-radius: 12px; }

  .stats-row {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
    gap: 14px;
  }
  .stats-legend { width: 100%; max-width: 260px; }

  .webcams__cam { height: 240px; }

  .ski-insurance__link { height: 220px; }
  .ski-insurance__pct { font-size: 57px; }
  .ski-insurance__text { font-size: 13.5px; }

  .trail { height: 220px; }

  .region-map__canvas { height: 360px; min-height: 360px; flex: 0 0 360px; }
  .region-map__banner {
    top: 10px;
    left: 10px;
    padding: 8px 12px;
    max-width: calc(100% - 80px);
  }
  .region-map__zoom { top: 10px; right: 10px; }
}

/* Small phones */
@media (max-width: 420px) {
  .neu-header__brand .neu-h2 { font-size: 15px; }
  .neu-header__home { max-width: calc(100% - 138px); gap: 7px; }
  .neu-header__actions { gap: 6px; }
  .settings-menu__button { width: 38px; height: 34px; }
  .neu-header__actions .neu-btn-primary { padding: 6px 10px; font-size: 11px; white-space: nowrap; }
  .stats-kvs .kv { font-size: 11.5px; }
  .trail__btn { padding: 9px 16px; font-size: 13px; }
  .ski-insurance__overlay { top: 14px; left: 14px; }
  .ski-insurance__pct { font-size: 48px; }
  .ski-insurance__text { font-size: 12.5px; }
}

/* ── HEADER LOGO BUTTON ───────────────────── */
.neu-header__home {
  background: transparent;
  border: none;
  padding: 0;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 10.5px;
  color: inherit;
  font: inherit;
  transition: transform 120ms ease;
}
.neu-header__home:active { transform: scale(0.98); }

@media (max-width: 768px) {
  .neu-header__home { gap: 8px; }
  .neu-header__home:active { transform: translate(-50%, -50%) scale(0.98); }
}

@media (max-width: 420px) {
  .neu-header__home { gap: 7px; }
}

/* ── HOME VIEW ────────────────────────────── */
.home {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
  flex: 1 1 auto;
}
.home__title {
  font: 700 28px/34px var(--neu-font-sans);
  letter-spacing: -0.4px;
  color: var(--neu-fg-1);
  margin: 0;
}
.home__subtitle {
  font: 400 15px/22px var(--neu-font-sans);
  color: var(--neu-fg-4);
  margin: 0 0 8px;
  max-width: 60ch;
}
.home .region-map { flex: 1 1 auto; min-height: 70vh; }
.home .region-map__canvas { height: 100%; min-height: 70vh; flex: 1 1 auto; }

/* Mobile home: hide back button and let map dominate */
@media (max-width: 768px) {
  .app--mobile-home .neu-header__back { display: none; }
  .home { padding: 16px; }
  .home__title { font-size: 22px; line-height: 28px; }
  .home .region-map,
  .home .region-map__canvas { min-height: 60vh; }
}
