/* ─── Imports ──────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Inter:wght@300;400;500&display=swap');

/* ─── Base ─────────────────────────────────────────────── */
body {
  --rr-phase-bg-a: rgba(255, 182, 98, 0.08);
  --rr-phase-bg-b: rgba(255, 128, 72, 0.04);
  --rr-phase-bg-c: rgba(86, 106, 172, 0.05);
  --rr-phase-bg-d: rgba(255, 208, 136, 0.03);
  --rr-phase-tail: #07070e;
  --rr-ambient-orb-1: #d9a867;
  --rr-ambient-orb-2: #8f5d36;
  --rr-ambient-orb-3: #f0b86d;
  --rr-ambient-orb-1-opacity: 0.1;
  --rr-ambient-orb-2-opacity: 0.08;
  --rr-ambient-orb-3-opacity: 0.05;
  background-color: var(--color-bg);
  background-image:
    radial-gradient(circle at 82% 2%, var(--rr-phase-bg-a), transparent 42%),
    radial-gradient(circle at 22% 100%, var(--rr-phase-bg-b), transparent 50%),
    radial-gradient(circle at 0% 22%, var(--rr-phase-bg-c), transparent 52%),
    radial-gradient(circle at 60% 0%, var(--rr-phase-bg-d), transparent 56%),
    linear-gradient(180deg, rgba(5, 6, 12, 0.98) 0%, var(--rr-phase-tail) 100%);
  transition: background-color var(--transition-ambient), background-image var(--transition-ambient);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-weight: 300;
  min-height: 100dvh;
  overflow: hidden;
  position: relative;
}

body[data-station-timephase-known="true"][data-station-timephase="day"],
body[data-station-timephase-known="true"][data-station-timephase="dawn"],
body[data-station-timephase-known="true"][data-station-timephase="dusk"] {
  --rr-phase-bg-a: rgba(255, 186, 102, 0.1);
  --rr-phase-bg-b: rgba(255, 134, 78, 0.05);
  --rr-phase-bg-c: rgba(76, 92, 156, 0.04);
  --rr-phase-bg-d: rgba(255, 214, 150, 0.035);
  --rr-phase-tail: #07070e;
  --rr-ambient-orb-1: #d8a769;
  --rr-ambient-orb-2: #9a6338;
  --rr-ambient-orb-3: #efb467;
  --rr-ambient-orb-1-opacity: 0.11;
  --rr-ambient-orb-2-opacity: 0.08;
  --rr-ambient-orb-3-opacity: 0.055;
}

body[data-station-timephase-known="true"][data-station-timephase="night"] {
  --rr-phase-bg-a: rgba(82, 204, 208, 0.18);
  --rr-phase-bg-b: rgba(78, 172, 224, 0.008);
  --rr-phase-bg-c: rgba(58, 132, 184, 0.008);
  --rr-phase-bg-d: rgba(86, 220, 166, 0.12);
  --rr-phase-tail: #0a2027;
  --rr-ambient-orb-1: #3a86a8;
  --rr-ambient-orb-2: #2f9285;
  --rr-ambient-orb-3: #46bc92;
  --rr-ambient-orb-1-opacity: 0.008;
  --rr-ambient-orb-2-opacity: 0.145;
  --rr-ambient-orb-3-opacity: 0.06;
}

/* ─── Ambient Background ───────────────────────────────── */
.ambient-bg {
  position: fixed;
  inset: 0;
  z-index: var(--z-bg);
  overflow: hidden;
}

.ambient-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0;
  transition: background-color var(--transition-ambient),
              opacity var(--transition-ambient),
              transform var(--transition-ambient);
  will-change: transform, opacity, background-color;
  pointer-events: none;
}

.ambient-orb--1 {
  width: min(70vw, 600px);
  height: min(70vw, 600px);
  top: -20%;
  left: -10%;
  background: var(--rr-ambient-orb-1, var(--color-accent));
  opacity: var(--rr-ambient-orb-1-opacity, 0.12);
  animation: orbFloat1 20s ease-in-out infinite;
}

.ambient-orb--2 {
  width: min(50vw, 440px);
  height: min(50vw, 440px);
  bottom: -15%;
  right: -10%;
  background: var(--rr-ambient-orb-2, var(--color-accent-secondary));
  opacity: var(--rr-ambient-orb-2-opacity, 0.1);
  animation: orbFloat2 25s ease-in-out infinite;
}

.ambient-orb--3 {
  width: min(35vw, 300px);
  height: min(35vw, 300px);
  top: 40%;
  left: 50%;
  transform: translateX(-50%);
  background: var(--rr-ambient-orb-3, var(--color-accent));
  opacity: var(--rr-ambient-orb-3-opacity, 0.06);
  animation: orbFloat3 18s ease-in-out infinite;
}

@keyframes orbFloat1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33%       { transform: translate(4%, 6%) scale(1.05); }
  66%       { transform: translate(-3%, 3%) scale(0.97); }
}

@keyframes orbFloat2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  40%       { transform: translate(-5%, -4%) scale(1.08); }
  70%       { transform: translate(3%, -7%) scale(0.95); }
}

@keyframes orbFloat3 {
  0%, 100% { transform: translateX(-50%) scale(1); }
  50%       { transform: translateX(-50%) scale(1.12); }
}

/* ─── Start Overlay ────────────────────────────────────── */
.start-overlay {
  position: fixed;
  inset: 0;
  z-index: var(--z-overlay);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--color-bg);
  cursor: pointer;
  transition: opacity 0.8s ease;
}

.start-overlay.hidden {
  opacity: 0;
  pointer-events: none;
}

.start-overlay__logo {
  font-family: var(--font-display);
  font-size: clamp(2rem, 6vw, 3.5rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  margin-bottom: var(--space-lg);
}

.start-overlay__hint {
  font-size: 0.8rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  animation: pulse-fade 2s ease-in-out infinite;
}

.start-overlay__globe {
  font-size: 3rem;
  margin-bottom: var(--space-xl);
  opacity: 0.6;
  animation: spin-slow 8s linear infinite;
}

@keyframes spin-slow {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

@keyframes pulse-fade {
  0%, 100% { opacity: 0.3; }
  50% { opacity: 0.8; }
}

/* ─── Main Layout ──────────────────────────────────────── */
.app {
  position: relative;
  z-index: var(--z-content);
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-lg) var(--space-md);
  max-width: 100%;
}

/* ─── Top Bar (Nav) ────────────────────────────────────── */
.topbar {
  width: 100%;
  max-width: var(--max-width);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-sm) 0;
}

.topbar__logo {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  color: var(--color-text-secondary);
  transition: color var(--transition-base);
}

.topbar__logo:hover {
  color: var(--color-text-primary);
}

.topbar__nav {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}

.topbar__link {
  font-size: 0.75rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
  padding: var(--space-xs) var(--space-sm);
}

.topbar__link:hover {
  color: var(--color-text-secondary);
}

/* ─── Player Stage ─────────────────────────────────────── */
.player-stage {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: var(--max-width);
  text-align: center;
  gap: var(--space-lg);
  padding: var(--space-xl) 0;
}

/* Playing indicator */
.playing-indicator {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  color: var(--color-text-muted);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  transition: opacity var(--transition-base);
}

.playing-indicator__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-accent);
  box-shadow: 0 0 8px var(--color-accent);
  transition: background var(--transition-ambient),
              box-shadow var(--transition-ambient);
}

.playing-indicator__dot.active {
  animation: pulse-dot 2s ease-in-out infinite;
}

.playing-indicator__dot.paused {
  animation: none;
  opacity: 0.4;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(0.8); }
}

/* Station identity */
.station-identity {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
}

.station-name {
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 8vw, 5.5rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.03em;
  color: var(--color-text-primary);
  transition: opacity 0.4s ease, transform 0.4s ease;
  cursor: default;
  max-width: min(92vw, 860px);
  text-align: center;
  text-wrap: balance;
}

.station-name.is-long {
  font-size: clamp(2rem, 7vw, 4.4rem);
  line-height: 1.08;
}

.station-name.is-very-long {
  font-size: clamp(1.6rem, 5.8vw, 3.3rem);
  line-height: 1.1;
}

.station-name.is-ultra-long {
  font-size: clamp(1.3rem, 4.9vw, 2.6rem);
  line-height: 1.12;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.station-name.transitioning {
  opacity: 0;
  transform: translateY(-8px);
}

.station-location {
  font-size: clamp(0.75rem, 2vw, 0.9rem);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--color-text-secondary);
  transition: opacity 0.4s ease 0.1s;
}

.station-location.transitioning {
  opacity: 0;
}

.station-traffic {
  min-height: 1.1em;
  max-width: min(88vw, 760px);
  font-size: 0.72rem;
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
  line-height: 1.35;
  text-align: center;
}

.station-traffic[hidden] {
  display: none;
}

.station-listen-time {
  min-height: 1.05em;
  max-width: min(88vw, 760px);
  font-size: 0.68rem;
  color: rgba(255, 255, 255, 0.56);
  letter-spacing: 0.05em;
  line-height: 1.3;
  text-align: center;
}

.station-listen-time[hidden] {
  display: none;
}

.station-genre {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-full);
  font-size: 0.65rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  background: var(--color-surface);
  transition: border-color var(--transition-ambient);
}

/* Track metadata scroll */
.track-meta {
  width: 100%;
  overflow: hidden;
  height: 1.5rem;
  position: relative;
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
}

.track-meta__inner {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xl);
  white-space: nowrap;
  animation: marquee 24s linear infinite;
  will-change: transform;
}

.track-meta__item {
  font-size: 0.8rem;
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.track-meta__item::before {
  content: '•';
  opacity: 0.42;
  font-size: 0.7rem;
}

@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* Local time / mood label */
.station-context {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  font-size: 0.72rem;
  color: var(--color-text-secondary);
  letter-spacing: 0.08em;
}

.station-context__item {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
}

.station-context__item--travel {
  padding: 3px 9px;
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--border-radius-full);
  background: var(--color-surface);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 0.58rem;
  line-height: 1;
}

.station-context__item--travel[hidden] {
  display: none;
}

/* ─── Controls ─────────────────────────────────────────── */
.controls {
  width: 100%;
  max-width: var(--max-width);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  padding-bottom: var(--space-md);
}

/* Next Station — primary CTA */
.btn-next {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: 16px 40px;
  border-radius: var(--border-radius-full);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  color: var(--color-text-primary);
  font-family: var(--font-body);
  font-size: 0.85rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: background var(--transition-base),
              border-color var(--transition-base),
              transform var(--transition-fast),
              box-shadow var(--transition-base);
  overflow: hidden;
  cursor: pointer;
}

.btn-next::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, var(--color-accent-glow) 0%, transparent 70%);
  opacity: 0;
  transition: opacity var(--transition-base);
}

.btn-next:hover::before {
  opacity: 1;
}

.btn-next:hover {
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-1px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4), 0 0 24px var(--color-accent-glow);
}

.btn-next:active {
  transform: translateY(0);
}

.btn-next.loading {
  pointer-events: none;
}

.btn-next__icon {
  font-size: 1rem;
  transition: transform var(--transition-base);
}

.btn-next:hover .btn-next__icon {
  transform: translateX(3px);
}

/* Secondary controls row */
.controls-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-xl);
}

.like-wrap {
  display: inline-flex;
  align-items: center;
}

.like-votes {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  font-size: 0.68rem;
  color: var(--color-text-secondary);
  letter-spacing: 0.04em;
  text-transform: none;
  line-height: 1;
  white-space: nowrap;
  pointer-events: none;
}

.ctrl-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  color: var(--color-text-secondary);
  font-size: 1.1rem;
  transition: color var(--transition-fast),
              background var(--transition-fast),
              transform var(--transition-fast);
  position: relative;
}

.ctrl-btn:hover {
  color: var(--color-text-primary);
  background: var(--color-surface-hover);
}

.ctrl-btn:active {
  transform: scale(0.92);
}

.ctrl-btn--play {
  width: 56px;
  height: 56px;
  font-size: 1.2rem;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
}

.ctrl-btn--play:hover {
  border-color: rgba(255, 255, 255, 0.2);
  background: var(--color-surface-hover);
}

.ctrl-btn--like-badge {
  width: auto;
  min-width: 88px;
  height: 40px;
  padding: 0 12px;
  gap: 8px;
  border-radius: var(--border-radius-full);
  border: 1px solid var(--color-border);
  background: var(--color-surface);
}

.ctrl-btn--like-badge:hover {
  border-color: rgba(255, 255, 255, 0.2);
  background: var(--color-surface-hover);
}

.like-heart {
  font-size: 1rem;
  line-height: 1;
  color: var(--color-text-secondary);
  transition: color var(--transition-fast);
}

.ctrl-btn--like.liked {
  color: #ff6b9d;
}

.ctrl-btn--like.liked .like-heart {
  color: #ff6b9d;
}

.ctrl-btn--like.liked .like-votes {
  color: var(--color-text-primary);
}

/* Volume control */
.volume-wrap {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.volume-icon {
  color: var(--color-text-muted);
  font-size: 0.9rem;
  width: 20px;
  text-align: center;
}

.volume-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 80px;
  height: 3px;
  background: var(--color-border);
  border-radius: 2px;
  outline: none;
  cursor: pointer;
  transition: background var(--transition-fast);
}

.volume-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-text-secondary);
  cursor: pointer;
  transition: background var(--transition-fast), transform var(--transition-fast);
}

.volume-slider::-webkit-slider-thumb:hover {
  background: var(--color-text-primary);
  transform: scale(1.2);
}

.volume-slider::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: var(--color-text-secondary);
  border: none;
  cursor: pointer;
}

/* ─── Error / Loading States ───────────────────────────── */
.status-banner {
  position: fixed;
  bottom: var(--space-xl);
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: rgba(20, 18, 35, 0.9);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-md);
  padding: var(--space-sm) var(--space-lg);
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  letter-spacing: 0.05em;
  backdrop-filter: blur(12px);
  z-index: var(--z-overlay);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  white-space: nowrap;
  pointer-events: none;
}

.status-banner.visible {
  transform: translateX(-50%) translateY(0);
}

/* ─── Transition Curtain ───────────────────────────────── */
.transition-curtain {
  position: fixed;
  inset: 0;
  z-index: 50;
  background: var(--color-bg);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

.transition-curtain.active {
  opacity: 0.7;
  pointer-events: all;
}

/* ─── Liked stations toast ─────────────────────────────── */
.like-toast {
  position: fixed;
  top: var(--space-lg);
  left: 50%;
  transform: translateX(-50%) translateY(-60px);
  background: rgba(20, 18, 35, 0.95);
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-full);
  padding: 8px 20px;
  font-size: 0.75rem;
  color: var(--color-text-secondary);
  backdrop-filter: blur(12px);
  z-index: var(--z-overlay);
  transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
  pointer-events: none;
}

.like-toast.visible {
  transform: translateX(-50%) translateY(0);
}

/* ─── Visualizer bars ──────────────────────────────────── */
.visualizer {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 20px;
  opacity: 0;
  transition: opacity var(--transition-base);
}

.visualizer.active {
  opacity: 1;
}

.visualizer__bar {
  width: 3px;
  border-radius: 2px;
  background: var(--color-accent);
  transition: background var(--transition-ambient);
  transform-origin: bottom;
  animation: bar-bounce 0s ease-in-out infinite alternate;
}

.visualizer__bar:nth-child(1) { animation-duration: 0.7s; }
.visualizer__bar:nth-child(2) { animation-duration: 0.9s; }
.visualizer__bar:nth-child(3) { animation-duration: 0.6s; }
.visualizer__bar:nth-child(4) { animation-duration: 1.1s; }
.visualizer__bar:nth-child(5) { animation-duration: 0.8s; }

@keyframes bar-bounce {
  from { transform: scaleY(0.15); }
  to   { transform: scaleY(1); }
}

/* ─── Responsive ───────────────────────────────────────── */
@media (max-width: 480px) {
  .app {
    padding: var(--space-md) var(--space-md);
  }

  .volume-wrap {
    display: none;
  }

  .controls-row {
    gap: var(--space-lg);
  }

  .like-votes {
    min-width: 24px;
    font-size: 0.6rem;
  }

  .ctrl-btn--like-badge {
    min-width: 78px;
    height: 36px;
    padding: 0 10px;
  }

  .station-context {
    flex-direction: column;
    gap: var(--space-sm);
  }
}

@media (max-height: 600px) {
  .player-stage {
    gap: var(--space-md);
    padding: var(--space-md) 0;
  }

  .station-name {
    font-size: clamp(2rem, 6vw, 3.5rem);
  }

  .track-meta {
    display: none;
  }
}

/* ─── Weather widget ───────────────────────────────────── */
.weather-widget {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 4px 12px 4px 6px;
  border: 1px solid var(--color-border);
  border-radius: var(--border-radius-full);
  background: rgba(18, 16, 32, 0.7);
  backdrop-filter: blur(10px);
  font-size: 0.7rem;
  color: var(--color-text-secondary);
  letter-spacing: 0.06em;
  opacity: 0;
  transition: opacity 0.7s ease;
  pointer-events: none;
  white-space: nowrap;
}

.weather-widget.visible {
  opacity: 1;
}

.weather-widget__icon {
  font-size: 0.8rem;
  line-height: 1;
}

.weather-widget__temp {
  color: var(--color-text-primary);
  font-weight: 400;
}

.weather-widget__cond {
  color: var(--color-text-secondary);
}

/* ─── Weather canvas (particles) ───────────────────────── */
.weather-canvas {
  position: fixed;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  filter: blur(var(--wx-canvas-blur, 0px));
  transition: opacity 0.9s ease, filter 1s ease;
  will-change: opacity, filter;
}

.weather-canvas.active {
  opacity: var(--wx-canvas-opacity, 0.85);
}

/* ─── Weather overlay (preset layers) ──────────────────── */
.weather-overlay {
  --wx-celestial-x: 78%;
  --wx-celestial-y: 12%;
  --wx-celestial-scale: 1;
  --wx-horizon-y: 6px;
  --wx-horizon-scale: 1.02;
  position: fixed;
  inset: 0;
  z-index: 2;
  pointer-events: none;
  overflow: hidden;
}

.weather-overlay__layer {
  position: absolute;
  inset: -4%;
  opacity: 0;
  transition: opacity 0.95s ease, transform 1.1s ease, filter 1.1s ease;
  will-change: opacity, transform, filter;
}

.weather-overlay__tint {
  inset: 0;
  background:
    radial-gradient(circle at 18% 12%, rgba(74, 112, 190, 0.09), transparent 52%),
    radial-gradient(circle at 84% 88%, rgba(255, 183, 94, 0.04), transparent 55%);
}

.weather-overlay__skycycle {
  inset: 0;
  background:
    radial-gradient(ellipse 120% 88% at 50% -8%, rgba(140, 182, 255, 0.14), transparent 62%),
    linear-gradient(to bottom, rgba(155, 187, 247, 0.06), rgba(121, 148, 202, 0.02) 42%, transparent 80%);
  filter: blur(6px) saturate(1.02);
  opacity: 0;
}

.weather-overlay__clouds {
  inset: -8% -10% -2%;
  background:
    radial-gradient(ellipse 26% 14% at 16% 16%, rgba(195, 212, 242, 0.09), transparent 72%),
    radial-gradient(ellipse 34% 16% at 34% 13%, rgba(188, 204, 235, 0.08), transparent 72%),
    radial-gradient(ellipse 30% 15% at 56% 18%, rgba(180, 197, 230, 0.07), transparent 72%),
    radial-gradient(ellipse 36% 17% at 78% 14%, rgba(176, 191, 226, 0.08), transparent 72%),
    radial-gradient(ellipse 58% 20% at 46% 28%, rgba(164, 181, 216, 0.06), transparent 74%);
  filter: blur(12px) saturate(0.86);
  transform: translateX(-1.6%) scale(1.02);
  opacity: 0;
  animation: wx-clouds-drift 34s ease-in-out infinite alternate;
}

.weather-overlay__stars {
  inset: 0;
  opacity: 0;
  filter: blur(0.15px) saturate(0.95);
  mix-blend-mode: screen;
  -webkit-mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.86) 56%, rgba(0, 0, 0, 0.24) 84%, transparent 100%);
  mask-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.96) 0%, rgba(0, 0, 0, 0.86) 56%, rgba(0, 0, 0, 0.24) 84%, transparent 100%);
}

.weather-overlay__stars::before,
.weather-overlay__stars::after {
  content: "";
  position: absolute;
  inset: -4%;
  background-repeat: repeat;
  will-change: transform, opacity;
}

.weather-overlay__stars::before {
  background-image:
    radial-gradient(circle, rgba(241, 247, 255, 0.85) 0 0.8px, transparent 1.35px),
    radial-gradient(circle, rgba(193, 214, 255, 0.8) 0 0.95px, transparent 1.45px),
    radial-gradient(circle, rgba(255, 239, 212, 0.7) 0 0.7px, transparent 1.25px);
  background-size: 138px 138px, 186px 186px, 232px 232px;
  background-position: 0 0, 42px 68px, 86px 18px;
  animation: wx-stars-drift-a 80s linear infinite, wx-stars-twinkle-a 12s ease-in-out infinite;
}

.weather-overlay__stars::after {
  background-image:
    radial-gradient(circle, rgba(220, 232, 255, 0.72) 0 0.75px, transparent 1.3px),
    radial-gradient(circle, rgba(255, 229, 196, 0.58) 0 0.65px, transparent 1.15px),
    radial-gradient(circle, rgba(212, 224, 255, 0.54) 0 0.55px, transparent 1px);
  background-size: 116px 116px, 172px 172px, 254px 254px;
  background-position: 18px 34px, 78px 6px, 26px 92px;
  animation: wx-stars-drift-b 104s linear infinite, wx-stars-twinkle-b 9.5s ease-in-out infinite;
}

.weather-overlay__horizon {
  inset: auto -6% -4% -6%;
  height: 46%;
  background:
    radial-gradient(ellipse 60% 34% at 50% 100%, rgba(255, 178, 112, 0.16), transparent 72%),
    linear-gradient(to top, rgba(255, 168, 116, 0.08), transparent 54%);
  filter: blur(14px);
  transform: translateY(var(--wx-horizon-y)) scale(var(--wx-horizon-scale));
  opacity: 0;
  animation: wx-horizon-breathe 18s ease-in-out infinite;
}

.weather-overlay__celestial {
  inset: auto;
  left: var(--wx-celestial-x);
  top: var(--wx-celestial-y);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 35% 35%, rgba(255, 247, 214, 0.94) 0 14%, rgba(255, 218, 136, 0.82) 28%, rgba(255, 168, 84, 0.32) 58%, rgba(255, 142, 70, 0.06) 76%, transparent 82%);
  filter: blur(0.9px) drop-shadow(0 0 14px rgba(255, 206, 126, 0.18));
  transform: translate(-50%, -50%) scale(var(--wx-celestial-scale));
  transform-origin: center;
  opacity: 0;
  animation: wx-celestial-drift 28s ease-in-out infinite;
  will-change: transform, opacity, filter;
}

.weather-overlay__sun {
  background:
    radial-gradient(ellipse 50% 38% at 84% 2%, rgba(255, 219, 132, 0.18) 0%, rgba(255, 170, 76, 0.12) 34%, rgba(255, 120, 42, 0.05) 62%, transparent 78%),
    radial-gradient(circle at 79% 7%, rgba(255, 239, 184, 0.22) 0%, rgba(255, 208, 118, 0.12) 24%, transparent 52%);
  filter: blur(8px) saturate(1.05);
  transform: scale(1.02);
  opacity: 0;
  animation: none;
}

.weather-overlay__haze {
  inset: -2%;
  background:
    radial-gradient(ellipse 140% 90% at 50% 120%, rgba(199, 218, 255, 0.08) 0%, rgba(193, 212, 246, 0.04) 44%, transparent 72%),
    linear-gradient(to bottom, rgba(205, 221, 255, 0.05), transparent 42%);
  filter: blur(12px);
}

.weather-overlay__wind {
  inset: -8% -10%;
  background:
    repeating-linear-gradient(
      -6deg,
      rgba(205, 222, 255, 0) 0 16px,
      rgba(205, 222, 255, 0.018) 16px 18px,
      rgba(205, 222, 255, 0) 18px 34px
    );
  filter: blur(3px);
  transform: translateX(-2%);
  animation: wx-wind-sheet 10s linear infinite;
}

.weather-overlay__fog {
  inset: auto -10% auto -10%;
  height: 38%;
  border-radius: 999px;
  background:
    radial-gradient(ellipse at center, rgba(211, 221, 235, 0.13) 0%, rgba(195, 206, 223, 0.08) 44%, rgba(180, 190, 208, 0.02) 72%, transparent 84%);
  filter: blur(18px);
  transform: translateX(0);
}

.weather-overlay__fog--1 {
  top: 24%;
  animation: wx-fog-band-1 18s ease-in-out infinite alternate;
}

.weather-overlay__fog--2 {
  top: 44%;
  height: 34%;
  opacity: 0;
  animation: wx-fog-band-2 24s ease-in-out infinite alternate;
}

.weather-overlay__fog--3 {
  top: 62%;
  height: 28%;
  opacity: 0;
  animation: wx-fog-band-3 20s ease-in-out infinite alternate;
}

.weather-overlay__contrast {
  inset: 0;
  background: rgba(35, 40, 54, 0.03);
  backdrop-filter: saturate(0.96) contrast(0.98);
}

.weather-overlay__vignette {
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(7, 8, 12, 0.15) 100%);
}

.weather-overlay[data-preset="neutral"] .weather-overlay__tint {
  opacity: 0.2;
}

.weather-overlay[data-preset="neutral"] .weather-overlay__vignette {
  opacity: 0.12;
}

.weather-overlay[data-timephase="day"] .weather-overlay__skycycle {
  opacity: 0.18;
  filter: blur(6px) saturate(1.02);
}

.weather-overlay[data-timephase="day"] .weather-overlay__clouds {
  opacity: 0.04;
}

.weather-overlay[data-timephase="day"] .weather-overlay__horizon {
  opacity: 0.1;
  --wx-horizon-y: 5px;
  --wx-horizon-scale: 1.01;
}

.weather-overlay[data-timephase="day"] .weather-overlay__celestial {
  opacity: 0.1;
  background:
    radial-gradient(circle at 35% 35%, rgba(255, 248, 214, 0.96) 0 13%, rgba(255, 218, 128, 0.88) 28%, rgba(255, 168, 70, 0.34) 57%, rgba(255, 136, 62, 0.05) 78%, transparent 84%);
  filter: blur(1.05px) drop-shadow(0 0 14px rgba(255, 179, 92, 0.15));
}

.weather-overlay[data-timephase="dawn"] .weather-overlay__skycycle {
  opacity: 0.32;
  background:
    radial-gradient(ellipse 130% 96% at 50% -2%, rgba(134, 168, 255, 0.16), transparent 64%),
    linear-gradient(to bottom, rgba(123, 160, 255, 0.07), rgba(255, 181, 132, 0.04) 46%, transparent 82%);
  filter: blur(7px) saturate(1.06);
}

.weather-overlay[data-timephase="dawn"] .weather-overlay__clouds {
  opacity: 0.09;
}

.weather-overlay[data-timephase="dawn"] .weather-overlay__horizon {
  opacity: 0.32;
  background:
    radial-gradient(ellipse 68% 36% at 50% 100%, rgba(255, 191, 132, 0.2), transparent 72%),
    radial-gradient(ellipse 46% 28% at 58% 102%, rgba(255, 147, 105, 0.16), transparent 70%),
    linear-gradient(to top, rgba(255, 170, 122, 0.09), transparent 58%);
  --wx-horizon-y: 2px;
  --wx-horizon-scale: 1.02;
}

.weather-overlay[data-timephase="dawn"] .weather-overlay__celestial {
  opacity: 0.16;
  background:
    radial-gradient(circle at 35% 35%, rgba(255, 242, 206, 0.98) 0 15%, rgba(255, 206, 126, 0.92) 30%, rgba(255, 143, 74, 0.48) 62%, rgba(255, 118, 76, 0.08) 80%, transparent 86%);
  filter: blur(1px) drop-shadow(0 0 16px rgba(255, 156, 88, 0.22));
}

.weather-overlay[data-timephase="dusk"] .weather-overlay__skycycle {
  opacity: 0.28;
  background:
    radial-gradient(ellipse 120% 88% at 50% -5%, rgba(122, 145, 234, 0.12), transparent 64%),
    linear-gradient(to bottom, rgba(112, 130, 214, 0.05), rgba(255, 142, 112, 0.05) 44%, transparent 82%);
  filter: blur(7px) saturate(0.98);
}

.weather-overlay[data-timephase="dusk"] .weather-overlay__clouds {
  opacity: 0.08;
}

.weather-overlay[data-timephase="dusk"] .weather-overlay__horizon {
  opacity: 0.28;
  background:
    radial-gradient(ellipse 68% 34% at 50% 100%, rgba(255, 152, 114, 0.18), transparent 72%),
    radial-gradient(ellipse 52% 28% at 40% 102%, rgba(255, 106, 92, 0.14), transparent 68%),
    linear-gradient(to top, rgba(255, 127, 110, 0.08), transparent 56%);
  --wx-horizon-y: 3px;
  --wx-horizon-scale: 1.015;
}

.weather-overlay[data-timephase="dusk"] .weather-overlay__celestial {
  opacity: 0.13;
  background:
    radial-gradient(circle at 34% 34%, rgba(255, 228, 182, 0.95) 0 13%, rgba(255, 168, 102, 0.88) 28%, rgba(255, 103, 74, 0.4) 58%, rgba(255, 85, 72, 0.07) 78%, transparent 84%);
  filter: blur(1.05px) drop-shadow(0 0 14px rgba(255, 122, 92, 0.2));
}

.weather-overlay[data-timephase="night"] .weather-overlay__skycycle {
  opacity: 0.14;
  background:
    radial-gradient(ellipse 96% 84% at 88% -5%, rgba(132, 156, 255, 0.085), transparent 60%),
    radial-gradient(ellipse 62% 78% at 99% 15%, rgba(58, 190, 172, 0.05), transparent 68%),
    linear-gradient(to bottom, rgba(88, 112, 188, 0.012), rgba(53, 69, 115, 0.006) 48%, transparent 84%);
  filter: blur(8px) saturate(0.88);
}

.weather-overlay[data-timephase="night"] .weather-overlay__clouds {
  opacity: 0.06;
  filter: blur(14px) saturate(0.74) brightness(0.88);
}

.weather-overlay[data-timephase="night"] .weather-overlay__horizon {
  opacity: 0.12;
  background:
    radial-gradient(ellipse 62% 32% at 50% 100%, rgba(116, 132, 182, 0.1), transparent 72%),
    linear-gradient(to top, rgba(76, 95, 152, 0.03), transparent 58%);
  --wx-horizon-y: 7px;
  --wx-horizon-scale: 1.03;
}

.weather-overlay[data-timephase="night"] .weather-overlay__celestial {
  opacity: 0.12;
  width: 44px;
  height: 44px;
  background:
    radial-gradient(circle at 34% 34%, rgba(235, 243, 255, 0.92) 0 15%, rgba(198, 216, 255, 0.78) 34%, rgba(126, 152, 226, 0.22) 64%, transparent 84%),
    radial-gradient(circle at 63% 40%, rgba(6, 8, 14, 0.78) 0 36%, transparent 42%),
    radial-gradient(circle at 52% 52%, rgba(177, 198, 255, 0.08), transparent 72%);
  filter: blur(1.05px) saturate(0.85) drop-shadow(0 0 12px rgba(142, 170, 255, 0.14));
}

.weather-overlay[data-timephase="night"] .weather-overlay__stars {
  opacity: 0.24;
}

.weather-overlay[data-timephase="night"] .weather-overlay__vignette {
  background:
    radial-gradient(ellipse 82% 130% at -14% 52%, rgba(0, 0, 3, 0.98) 0%, rgba(0, 0, 3, 0.97) 18%, rgba(1, 2, 5, 0.9) 34%, rgba(1, 2, 5, 0.72) 50%, rgba(2, 4, 8, 0.38) 66%, transparent 82%),
    linear-gradient(90deg, rgba(0, 0, 2, 0.99) 0%, rgba(0, 0, 2, 0.98) 14%, rgba(1, 1, 4, 0.93) 24%, rgba(1, 2, 5, 0.82) 34%, rgba(2, 3, 7, 0.62) 44%, rgba(3, 5, 9, 0.36) 54%, rgba(4, 7, 11, 0.14) 64%, transparent 76%),
    radial-gradient(ellipse at center, transparent 50%, rgba(7, 8, 12, 0.15) 100%);
}

.weather-overlay[data-timephase-known="false"] .weather-overlay__celestial,
.weather-overlay[data-timephase-known="false"] .weather-overlay__sun {
  opacity: 0 !important;
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__tint {
  opacity: 0.52;
  background:
    linear-gradient(to bottom, rgba(114, 124, 146, 0.22), rgba(96, 106, 128, 0.14) 32%, rgba(62, 70, 88, 0.05) 64%, transparent 86%),
    radial-gradient(ellipse 120% 78% at 52% -10%, rgba(182, 196, 224, 0.18), rgba(152, 166, 196, 0.08) 38%, transparent 68%),
    radial-gradient(circle at 18% 12%, rgba(74, 112, 190, 0.08), transparent 52%),
    radial-gradient(circle at 84% 88%, rgba(255, 183, 94, 0.015), transparent 55%);
  filter: saturate(0.74) hue-rotate(-9deg) brightness(0.96);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__skycycle {
  opacity: 0.1;
  filter: blur(8px) saturate(0.72) brightness(0.88);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__clouds {
  opacity: 0.4;
  background:
    radial-gradient(ellipse 34% 18% at 16% 16%, rgba(208, 218, 236, 0.14), transparent 74%),
    radial-gradient(ellipse 42% 20% at 34% 13%, rgba(201, 212, 232, 0.13), transparent 74%),
    radial-gradient(ellipse 40% 18% at 56% 18%, rgba(194, 206, 229, 0.12), transparent 74%),
    radial-gradient(ellipse 46% 20% at 78% 14%, rgba(188, 200, 226, 0.13), transparent 74%),
    radial-gradient(ellipse 72% 28% at 46% 28%, rgba(170, 183, 208, 0.1), transparent 76%),
    radial-gradient(ellipse 90% 32% at 52% 4%, rgba(158, 170, 195, 0.08), transparent 78%);
  filter: blur(16px) saturate(0.62) brightness(0.84);
  transform: translateX(-2.6%) scale(1.045);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__haze {
  opacity: 0.18;
  filter: blur(12px) saturate(0.82) brightness(0.96);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__horizon {
  opacity: 0.06;
  filter: blur(16px) saturate(0.78);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__celestial {
  opacity: 0.05;
  filter: blur(1.35px) saturate(0.62);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__contrast {
  opacity: 0.66;
  backdrop-filter: saturate(0.8) contrast(0.94);
}

.weather-overlay[data-preset="cloudy"] .weather-overlay__vignette {
  opacity: 0.24;
}

.weather-overlay[data-detail="cloudy-cold"] .weather-overlay__tint {
  opacity: 0.58;
  filter: saturate(0.68) hue-rotate(-14deg) brightness(0.94);
}

.weather-overlay[data-detail="cloudy-cold"] .weather-overlay__haze {
  opacity: 0.22;
}

.weather-overlay[data-detail="cloudy-cold"] .weather-overlay__clouds {
  opacity: 0.46;
  filter: blur(16px) saturate(0.62) brightness(0.84);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__tint,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__tint {
  opacity: 0.68;
  background:
    linear-gradient(to bottom, rgba(122, 130, 148, 0.3), rgba(104, 112, 132, 0.22) 36%, rgba(74, 82, 100, 0.1) 64%, rgba(52, 58, 74, 0.02) 84%, transparent 100%),
    radial-gradient(ellipse 132% 82% at 50% -12%, rgba(196, 208, 230, 0.22), rgba(164, 176, 202, 0.12) 38%, rgba(132, 144, 168, 0.04) 62%, transparent 74%),
    radial-gradient(circle at 84% 88%, rgba(255, 183, 94, 0.005), transparent 55%),
    radial-gradient(circle at 18% 12%, rgba(70, 102, 166, 0.06), transparent 52%);
  filter: saturate(0.62) hue-rotate(-12deg) brightness(0.92);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__skycycle,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__skycycle {
  opacity: 0.06;
  filter: blur(9px) saturate(0.6) brightness(0.82);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__clouds,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__clouds {
  opacity: 0.55;
  background:
    radial-gradient(ellipse 42% 22% at 14% 16%, rgba(219, 228, 242, 0.18), transparent 74%),
    radial-gradient(ellipse 48% 22% at 32% 13%, rgba(212, 222, 238, 0.17), transparent 74%),
    radial-gradient(ellipse 46% 20% at 53% 18%, rgba(206, 216, 234, 0.16), transparent 74%),
    radial-gradient(ellipse 54% 22% at 76% 15%, rgba(198, 209, 230, 0.17), transparent 74%),
    radial-gradient(ellipse 82% 28% at 48% 29%, rgba(176, 188, 211, 0.13), transparent 78%),
    radial-gradient(ellipse 112% 34% at 52% 6%, rgba(161, 172, 195, 0.12), transparent 80%),
    radial-gradient(ellipse 120% 42% at 50% -6%, rgba(132, 140, 158, 0.08), transparent 82%);
  filter: blur(19px) saturate(0.52) brightness(0.77);
  transform: translateX(-3.2%) scale(1.06);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__haze,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__haze {
  opacity: 0.26;
  filter: blur(13px) saturate(0.76) brightness(0.92);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__horizon,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__horizon {
  opacity: 0.03;
}

.weather-overlay[data-detail="overcast"] .weather-overlay__celestial,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__celestial {
  opacity: 0.02;
  filter: blur(1.6px) saturate(0.5);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__contrast,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__contrast {
  opacity: 0.78;
  backdrop-filter: saturate(0.74) contrast(0.92);
}

.weather-overlay[data-detail="overcast"] .weather-overlay__vignette,
.weather-overlay[data-detail="overcast-cold"] .weather-overlay__vignette {
  opacity: 0.34;
}

.weather-overlay[data-detail="overcast-cold"] .weather-overlay__tint {
  opacity: 0.72;
  filter: saturate(0.54) hue-rotate(-18deg) brightness(0.9);
}

.weather-overlay[data-preset="clear"] .weather-overlay__tint {
  opacity: 0.36;
  filter: saturate(1.02);
}

.weather-overlay[data-preset="clear"] .weather-overlay__sun {
  opacity: 0.86;
  animation: wx-sun-breathe 11s ease-in-out infinite;
}

.weather-overlay[data-preset="clear"] .weather-overlay__haze {
  opacity: 0.12;
}

.weather-overlay[data-detail="sunny"] .weather-overlay__sun {
  opacity: 0.9;
}

.weather-overlay[data-detail="sunny-hot"] .weather-overlay__tint {
  opacity: 0.46;
  filter: saturate(1.08) hue-rotate(2deg);
}

.weather-overlay[data-detail="sunny-hot"] .weather-overlay__sun {
  opacity: 1;
  filter: blur(1px) saturate(1.08);
  transform: scale(1.05);
  animation: wx-sun-breathe 10s ease-in-out infinite;
}

.weather-overlay[data-detail="sunny-hot"] .weather-overlay__haze {
  opacity: 0.22;
  filter: blur(10px) saturate(0.96);
}

.weather-overlay[data-detail="clear-cold"] .weather-overlay__tint {
  opacity: 0.28;
  filter: saturate(0.86) hue-rotate(-16deg);
}

.weather-overlay[data-detail="clear-cold"] .weather-overlay__sun {
  opacity: 0.52;
  animation: wx-sun-breathe 12s ease-in-out infinite;
}

.weather-overlay[data-preset="clear-night"] .weather-overlay__sun,
.weather-overlay[data-timephase="night"] .weather-overlay__sun {
  opacity: 0;
  animation: none;
}

.weather-overlay[data-preset="clear-night"] .weather-overlay__tint {
  opacity: 0.18;
  filter: saturate(0.76) hue-rotate(-8deg);
}

.weather-overlay[data-preset="clear-night"] .weather-overlay__vignette {
  opacity: 0.24;
}

.weather-overlay[data-preset="clear-night"] .weather-overlay__contrast {
  opacity: 0.22;
  backdrop-filter: saturate(0.95) contrast(0.99);
}

.weather-overlay[data-preset="clear-night"] .weather-overlay__haze {
  opacity: 0.14;
  filter: blur(10px) saturate(0.88) brightness(1.02);
}

.weather-overlay[data-preset="rain"] .weather-overlay__tint {
  opacity: 0.54;
  filter: saturate(0.86) hue-rotate(-12deg);
}

.weather-overlay[data-preset="rain"] .weather-overlay__clouds {
  opacity: 0.14;
  filter: blur(14px) saturate(0.72) brightness(0.9);
}

.weather-overlay[data-preset="rain"] .weather-overlay__haze {
  opacity: 0.28;
}

.weather-overlay[data-preset="rain"] .weather-overlay__contrast {
  opacity: 0.5;
  backdrop-filter: saturate(0.9) contrast(0.97);
}

.weather-overlay[data-preset="rain"] .weather-overlay__vignette {
  opacity: 0.18;
}

.weather-overlay[data-detail="drizzle"] .weather-overlay__tint {
  opacity: 0.44;
}

.weather-overlay[data-detail="drizzle"] .weather-overlay__haze {
  opacity: 0.18;
}

.weather-overlay[data-detail="heavy-rain"] .weather-overlay__tint {
  opacity: 0.68;
  filter: saturate(0.82) hue-rotate(-14deg);
}

.weather-overlay[data-detail="heavy-rain"] .weather-overlay__haze {
  opacity: 0.36;
}

.weather-overlay[data-detail="heavy-rain"] .weather-overlay__wind {
  opacity: 0.2;
}

.weather-overlay[data-detail="heavy-rain"] .weather-overlay__vignette {
  opacity: 0.28;
}

.weather-overlay[data-detail="sleet"] .weather-overlay__tint {
  opacity: 0.6;
  filter: saturate(0.78) hue-rotate(-18deg);
}

.weather-overlay[data-detail="sleet"] .weather-overlay__haze {
  opacity: 0.34;
}

.weather-overlay[data-preset="snow"] .weather-overlay__tint {
  opacity: 0.52;
  filter: saturate(0.82) hue-rotate(-18deg);
}

.weather-overlay[data-preset="snow"] .weather-overlay__clouds {
  opacity: 0.12;
  filter: blur(15px) saturate(0.78) brightness(1);
}

.weather-overlay[data-preset="snow"] .weather-overlay__haze {
  opacity: 0.62;
}

.weather-overlay[data-preset="snow"] .weather-overlay__contrast {
  opacity: 0.58;
  backdrop-filter: saturate(0.88) contrast(0.95);
}

.weather-overlay[data-preset="snow"] .weather-overlay__vignette {
  opacity: 0.22;
}

.weather-overlay[data-detail="heavy-snow"] .weather-overlay__tint {
  opacity: 0.62;
}

.weather-overlay[data-detail="heavy-snow"] .weather-overlay__haze {
  opacity: 0.72;
}

.weather-overlay[data-detail="hail"] .weather-overlay__wind {
  opacity: 0.26;
}

.weather-overlay[data-detail="hail"] .weather-overlay__contrast {
  opacity: 0.68;
}

.weather-overlay[data-preset="wind"] .weather-overlay__tint {
  opacity: 0.4;
  filter: saturate(0.86) hue-rotate(-9deg);
}

.weather-overlay[data-preset="wind"] .weather-overlay__clouds {
  opacity: 0.12;
  filter: blur(12px) saturate(0.8);
}

.weather-overlay[data-preset="wind"] .weather-overlay__wind {
  opacity: 0.68;
  filter: blur(2.4px);
}

.weather-overlay[data-preset="wind"] .weather-overlay__haze {
  opacity: 0.12;
}

.weather-overlay[data-preset="wind"] .weather-overlay__vignette {
  opacity: 0.2;
}

.weather-overlay[data-preset="fog"] .weather-overlay__tint {
  opacity: 0.34;
  filter: saturate(0.68) contrast(0.98);
}

.weather-overlay[data-preset="fog"] .weather-overlay__clouds {
  opacity: 0.08;
  filter: blur(18px) saturate(0.6);
}

.weather-overlay[data-preset="fog"] .weather-overlay__fog--1 {
  opacity: 0.82;
}

.weather-overlay[data-preset="fog"] .weather-overlay__fog--2 {
  opacity: 0.64;
}

.weather-overlay[data-preset="fog"] .weather-overlay__fog--3 {
  opacity: 0.46;
}

.weather-overlay[data-preset="fog"] .weather-overlay__contrast {
  opacity: 0.92;
  backdrop-filter: saturate(0.76) contrast(0.9);
}

.weather-overlay[data-preset="fog"] .weather-overlay__vignette {
  opacity: 0.66;
}

.weather-overlay[data-detail="mist"] .weather-overlay__fog--2 {
  opacity: 0.38;
}

.weather-overlay[data-detail="mist"] .weather-overlay__fog--3 {
  opacity: 0.24;
}

.weather-overlay[data-detail="mist"] .weather-overlay__contrast {
  backdrop-filter: saturate(0.84) contrast(0.94);
}

.weather-overlay[data-detail="fog-dense"] .weather-overlay__haze {
  opacity: 0.28;
}

.weather-overlay[data-detail="fog-dense"] .weather-overlay__vignette {
  opacity: 0.74;
}

.weather-overlay[data-preset="storm"] .weather-overlay__tint {
  opacity: 0.82;
  background:
    linear-gradient(to bottom, rgba(10, 14, 28, 0.56), rgba(9, 12, 22, 0.22) 58%, transparent 100%),
    radial-gradient(circle at 18% 8%, rgba(94, 124, 194, 0.16), transparent 52%),
    radial-gradient(circle at 82% 6%, rgba(132, 164, 222, 0.08), transparent 46%);
  filter: saturate(0.76) hue-rotate(-12deg) brightness(0.92);
}

.weather-overlay[data-preset="storm"] .weather-overlay__clouds {
  opacity: 0.26;
  filter: blur(18px) saturate(0.58) brightness(0.78);
  transform: translateX(-3%) scale(1.05);
}

.weather-overlay[data-preset="storm"] .weather-overlay__wind {
  opacity: 0.54;
  filter: blur(2.6px) saturate(0.8);
}

.weather-overlay[data-preset="storm"] .weather-overlay__haze {
  opacity: 0.34;
}

.weather-overlay[data-preset="storm"] .weather-overlay__contrast {
  opacity: 0.76;
  backdrop-filter: saturate(0.78) contrast(0.9);
}

.weather-overlay[data-preset="storm"] .weather-overlay__vignette {
  opacity: 0.58;
}

.weather-overlay[data-intensity="heavy"] .weather-overlay__haze {
  filter: blur(14px);
}

.weather-overlay[data-night="true"][data-preset="rain"] .weather-overlay__vignette,
.weather-overlay[data-night="true"][data-preset="wind"] .weather-overlay__vignette,
.weather-overlay[data-night="true"][data-preset="cloudy"] .weather-overlay__vignette {
  opacity: 0.28;
}

.weather-overlay[data-timephase="night"][data-preset="clear-night"] .weather-overlay__stars {
  opacity: 0.28;
}

.weather-overlay[data-timephase="night"][data-preset="cloudy"] .weather-overlay__stars {
  opacity: 0.1;
  filter: blur(0.25px) saturate(0.82);
}

.weather-overlay[data-timephase="night"][data-preset="wind"] .weather-overlay__stars {
  opacity: 0.12;
}

.weather-overlay[data-timephase="night"][data-preset="rain"] .weather-overlay__stars,
.weather-overlay[data-timephase="night"][data-preset="snow"] .weather-overlay__stars {
  opacity: 0.04;
  filter: blur(0.35px);
}

.weather-overlay[data-timephase="night"][data-preset="fog"] .weather-overlay__stars,
.weather-overlay[data-timephase="night"][data-preset="storm"] .weather-overlay__stars {
  opacity: 0;
}

@keyframes wx-sun-breathe {
  0%, 100% { opacity: 0.78; transform: scale(1.01); }
  50% { opacity: 0.9; transform: scale(1.04); }
}

@keyframes wx-stars-drift-a {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(-10px, 4px, 0); }
}

@keyframes wx-stars-drift-b {
  from { transform: translate3d(0, 0, 0); }
  to { transform: translate3d(8px, -5px, 0); }
}

@keyframes wx-stars-twinkle-a {
  0%, 100% { opacity: 0.7; }
  50% { opacity: 0.88; }
}

@keyframes wx-stars-twinkle-b {
  0%, 100% { opacity: 0.34; }
  50% { opacity: 0.52; }
}

@keyframes wx-clouds-drift {
  0% { transform: translateX(-2.2%) scale(1.02); }
  50% { transform: translateX(-0.6%) scale(1.025); }
  100% { transform: translateX(1.2%) scale(1.03); }
}

@keyframes wx-celestial-drift {
  0%, 100% { transform: translate(-50%, -50%) scale(var(--wx-celestial-scale)) translateY(0); }
  50% { transform: translate(-50%, -50%) scale(var(--wx-celestial-scale)) translateY(-1.5px); }
}

@keyframes wx-horizon-breathe {
  0%, 100% { transform: translateY(var(--wx-horizon-y)) scale(var(--wx-horizon-scale)); }
  50% { transform: translateY(calc(var(--wx-horizon-y) - 2px)) scale(calc(var(--wx-horizon-scale) + 0.005)); }
}

@keyframes wx-wind-sheet {
  from { transform: translateX(-3%); }
  to { transform: translateX(3%); }
}

@keyframes wx-fog-band-1 {
  from { transform: translateX(-2.5%); }
  to { transform: translateX(2%); }
}

@keyframes wx-fog-band-2 {
  from { transform: translateX(3%); }
  to { transform: translateX(-2%); }
}

@keyframes wx-fog-band-3 {
  from { transform: translateX(-1.2%); }
  to { transform: translateX(2.4%); }
}

/* ─── Weather people (player area only) ────────────────── */
.weather-people {
  --wxp-audio-bob: 0;
  --wxp-audio-tilt: 0;
  --wxp-audio-scale: 0;
  --wxp-audio-glow: 0;
  position: absolute;
  right: clamp(10px, 3vw, 30px);
  bottom: max(-4px, var(--space-xs));
  width: clamp(108px, 12vw, 168px);
  height: clamp(108px, 12vw, 168px);
  pointer-events: none;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 0.55s ease, transform 0.55s ease, filter 0.55s ease;
  z-index: 1;
}

.weather-people[data-ready="true"] {
  opacity: 0.94;
  transform: translateY(0);
}

.weather-people::before {
  content: '';
  position: absolute;
  right: 10%;
  bottom: 7%;
  width: 52%;
  height: 10%;
  background: radial-gradient(ellipse at center, rgba(8, 10, 16, 0.46), transparent 70%);
  filter: blur(8px);
  opacity: calc(0.56 + var(--wxp-audio-glow) * 0.1);
  transform: scaleX(calc(1 + var(--wxp-audio-scale) * 0.04));
  transition: opacity 120ms linear, transform 120ms linear;
}

.weather-people__scene {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: end end;
  padding: 0 clamp(2px, 0.5vw, 8px) clamp(6px, 0.8vw, 12px) 0;
  transform-origin: 70% 92%;
  animation: wxp-ambient-float 4.8s ease-in-out infinite;
  transition: transform 0.45s ease, opacity 0.35s ease, filter 0.35s ease;
  will-change: transform;
}

.weather-people__shell {
  width: 100%;
  height: 100%;
  transform-origin: 70% 92%;
  transform:
    translateY(calc(var(--wxp-audio-bob) * -2.2px))
    rotate(calc(var(--wxp-audio-tilt) * 0.7deg))
    scale(calc(1 + var(--wxp-audio-scale) * 0.018));
  transition: transform 90ms linear, filter 0.22s ease;
  will-change: transform;
}

.weather-people__img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: contain;
  opacity: 0;
  transform: scale(0.98);
  transition: opacity 0.2s ease, transform 0.35s ease, filter 0.35s ease;
  filter:
    drop-shadow(0 6px 10px rgba(6, 8, 16, 0.22))
    drop-shadow(0 0 10px rgba(150, 174, 226, 0.05));
}

.weather-people__img.is-ready {
  opacity: 1;
  transform: scale(1);
}

.weather-people[data-audio="on"] .weather-people__shell {
  filter: drop-shadow(0 0 10px rgba(154, 178, 230, 0.06));
}

.weather-people[data-scene="idle"] .weather-people__scene {
  animation-name: wxp-ambient-float;
}

.weather-people[data-scene="cloudy"] .weather-people__scene,
.weather-people[data-scene="fog"] .weather-people__scene,
.weather-people[data-scene="night"] .weather-people__scene {
  animation-name: wxp-calm-idle;
}

.weather-people[data-scene="rain"] .weather-people__scene {
  animation-name: wxp-rain-guard;
}

.weather-people[data-scene="storm"] .weather-people__scene {
  animation-name: wxp-storm-brace;
}

.weather-people[data-scene="snow"] .weather-people__scene,
.weather-people[data-scene="cold"] .weather-people__scene {
  animation-name: wxp-shiver;
}

.weather-people[data-scene="hot"] .weather-people__scene {
  animation-name: wxp-hot-lounge;
}

.weather-people[data-scene="wind"] .weather-people__scene {
  animation-name: wxp-wind-lean;
}

.weather-people[data-scene="fog"] .weather-people__img {
  filter:
    drop-shadow(0 6px 10px rgba(6, 8, 16, 0.18))
    saturate(0.92)
    opacity(0.96);
}

.weather-people[data-scene="night"] .weather-people__img {
  filter:
    drop-shadow(0 5px 10px rgba(6, 8, 16, 0.2))
    brightness(0.94)
    saturate(0.94);
}

.weather-people[data-base="heavy_rain"] .weather-people__scene,
.weather-people[data-base="thunderstorm"] .weather-people__scene {
  transform: translateX(-2px);
}

.weather-people[data-base="heavy_snow"] .weather-people__scene {
  transform: translateY(1px);
}

@keyframes wxp-ambient-float {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-2px) rotate(-0.4deg); }
}

@keyframes wxp-calm-idle {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-1px); }
}

@keyframes wxp-rain-guard {
  0%, 100% { transform: translateY(0) rotate(-1.2deg); }
  50% { transform: translateY(1px) rotate(-2deg); }
}

@keyframes wxp-storm-brace {
  0%, 100% { transform: translate(-1px, 0) rotate(-2.5deg); }
  50% { transform: translate(-3px, 1px) rotate(-4deg); }
}

@keyframes wxp-shiver {
  0%, 100% { transform: translateX(0) rotate(0deg); }
  20% { transform: translateX(-1px) rotate(-0.6deg); }
  40% { transform: translateX(1px) rotate(0.5deg); }
  60% { transform: translateX(-1.2px) rotate(-0.7deg); }
  80% { transform: translateX(1.1px) rotate(0.6deg); }
}

@keyframes wxp-hot-lounge {
  0%, 100% { transform: translate(2px, 5px) rotate(7deg); }
  50% { transform: translate(2px, 6px) rotate(8deg); }
}

@keyframes wxp-wind-lean {
  0%, 100% { transform: translate(-3px, 0) rotate(-5deg); }
  50% { transform: translate(-5px, 0.5px) rotate(-6.8deg); }
}

@media (max-width: 840px) {
  .weather-people {
    right: clamp(4px, 1.8vw, 12px);
    width: clamp(94px, 20vw, 128px);
    height: clamp(94px, 20vw, 128px);
    bottom: max(-6px, var(--space-xs));
  }
}

@media (max-width: 520px) {
  .weather-people {
    right: 2px;
    width: clamp(84px, 24vw, 108px);
    height: clamp(84px, 24vw, 108px);
    bottom: max(-10px, var(--space-xs));
  }
}

/* ─── Lightning flash ──────────────────────────────────── */
.lightning-flash {
  position: fixed;
  inset: 0;
  z-index: 3;
  pointer-events: none;
  background:
    radial-gradient(circle at 34% 18%, rgba(226, 238, 255, 0.32), transparent 42%),
    rgba(196, 216, 255, 0.18);
  opacity: 0;
  transition: opacity 0.03s linear;
}

.lightning-flash.active {
  opacity: 1;
}

/* ─── Reduced motion ───────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .ambient-orb,
  .track-meta__inner,
  .visualizer__bar,
  .start-overlay__globe,
  .weather-overlay__sun,
  .weather-overlay__clouds,
  .weather-overlay__stars::before,
  .weather-overlay__stars::after,
  .weather-overlay__celestial,
  .weather-overlay__horizon,
  .weather-overlay__wind,
  .weather-overlay__fog,
  .weather-people__scene {
    animation: none;
  }

  .playing-indicator__dot.active {
    animation: none;
    opacity: 1;
  }

  .weather-canvas {
    transition-duration: 0.2s;
    filter: none;
  }

  .weather-overlay__layer,
  .weather-people {
    transition-duration: 0.2s;
  }

  .weather-people__shell,
  .weather-people::before {
    transition: none;
    transform: none !important;
  }
}
