/* style.css — WeatherX dashboard.
 * Donker thema met cyan accent, half-circle wind gauge, ring gauges,
 * area/bar charts via SVG. Geen frameworks, alleen vanilla CSS.
 */

:root {
  /* OKLCH palet, getint richting koel-blauw (de wind-hue). Tonen blijven dicht
   * bij het oorspronkelijke cyan/oranje/paars dashboard maar zijn nu OKLCH-
   * gedefinieerd zodat ze perceptueel egaal samen werken met de Storm Glass
   * scène erachter. */

  /* Donkere lagen */
  --bg:           oklch(13% 0.020 250);
  --bg-card:      oklch(20% 0.020 240);
  --bg-card-2:    oklch(17% 0.022 245);
  --bg-deep:      oklch(11% 0.020 250);
  --bg-side:      oklch(13% 0.020 250);

  /* Glass-laag — gebruikt door de overlay onderaan voor cards, panels, stats */
  --bg-glass:        oklch(20% 0.020 240 / 0.62);
  --bg-glass-soft:   oklch(20% 0.020 240 / 0.42);
  --bg-glass-strong: oklch(18% 0.020 240 / 0.78);
  --border-glass:    oklch(70% 0.020 240 / 0.18);

  --border:       oklch(28% 0.018 240);
  --border-light: oklch(35% 0.020 240);
  --text:         oklch(96% 0.005 240);
  --text-muted:   oklch(70% 0.018 240);
  --text-faint:   oklch(56% 0.018 240);

  --cyan:    oklch(80% 0.150 210);
  --cyan-2:  oklch(68% 0.140 215);
  --cyan-glow: oklch(80% 0.150 210 / 0.45);
  --orange:  oklch(73% 0.160 55);
  --orange-glow: oklch(73% 0.160 55 / 0.45);
  --red:     oklch(64% 0.190 25);
  --green:   oklch(72% 0.155 145);
  --purple:  oklch(72% 0.130 290);
  --purple-glow: oklch(72% 0.130 290 / 0.45);
  --yellow:  oklch(82% 0.160 85);

  /* Gauge colors */
  --temp-color: var(--orange);
  --temp-glow:  var(--orange-glow);
  --hum-color:  var(--cyan);
  --hum-glow:   var(--cyan-glow);
  --baro-color: var(--purple);
  --baro-glow:  var(--purple-glow);
}

* { box-sizing: border-box; }
[hidden] { display: none !important; }

body {
  margin: 0;
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--bg);
  color: var(--text);
  font-size: 14px;
  line-height: 1.4;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'ss01', 'ss02';
}

.mono, .tabnum, .stat-value, .wind-center-value, .ring-value, .card-head-right,
.lt-time, .wfc-value, .sm-value, .rain-big, dl dd, .temp-feels {
  font-variant-numeric: tabular-nums;
}

/* ==================== LAYOUT ==================== */

.app {
  display: block;
  min-height: 100vh;
}

/* ==================== SIDEBAR (verborgen — voorlopig weg) ==================== */

.sidebar { display: none; }

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 12px 24px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}
.brand-logo {
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--cyan) 0%, var(--cyan-2) 100%);
  border-radius: 8px;
  color: #0a0f1c;
  box-shadow: 0 4px 12px var(--cyan-glow);
}
.brand-text {
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: 0.4px;
  background: linear-gradient(135deg, var(--cyan) 0%, var(--cyan-2) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  color: var(--text-muted);
  cursor: pointer;
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  min-height: 38px;
  transition: background 0.15s, color 0.15s;
}
.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; }
.nav-item:hover { background: var(--bg-card); color: var(--text); }
.nav-item.active {
  background: linear-gradient(90deg, rgba(34,211,238,0.12) 0%, transparent 100%);
  color: var(--cyan);
  border-left: 2px solid var(--cyan);
  padding-left: 10px;
}

.sidebar-foot { margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--border); }
.local-time {
  display: flex;
  gap: 10px;
  padding: 8px 12px;
  align-items: flex-start;
}
.lt-icon {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: rgba(34,211,238,0.1);
  color: var(--cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.lt-icon svg { width: 16px; height: 16px; }
.lt-label { font-size: 0.65rem; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.5px; }
.lt-time  { font-size: 1.05rem; font-weight: 600; color: var(--text); }
.lt-date  { font-size: 0.72rem; color: var(--text-muted); }

/* ==================== MAIN ==================== */

.main {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 1700px;
  margin: 0 auto;
  width: 100%;
  min-width: 0;
}

.page-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding-bottom: 8px;
}
.page-head h1 {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 600;
}
.head-sub {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-muted);
  font-size: 0.82rem;
  margin-top: 4px;
}
.dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 10px var(--green);
  animation: pulse 2s ease-in-out infinite;
}
.dot[data-state="offline"] { background: var(--red); box-shadow: 0 0 10px var(--red); }
@keyframes pulse { 0%,100% { opacity: 1; } 50% { opacity: 0.5; } }

/* ----- Rain-badge in header (verschijnt alleen als rain_rate > 0) ----- */
.rain-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px 3px 4px;
  background: rgba(34,211,238,0.12);
  border: 1px solid rgba(34,211,238,0.4);
  border-radius: 14px;
  margin-left: 6px;
  font-size: 0.78rem;
  color: var(--cyan);
  font-weight: 600;
  animation: rain-badge-pulse 2.4s ease-in-out infinite;
}
.rain-badge[data-heavy="true"] {
  background: rgba(56,189,248,0.2);
  border-color: var(--cyan);
  color: #67e8f9;
}
.rain-badge-icon { width: 22px; height: 22px; flex-shrink: 0; }
.rain-badge-drops path {
  animation: rain-drop-fall 1.4s ease-in infinite;
  transform-origin: center;
}
.rain-badge-rate {
  font-variant-numeric: tabular-nums;
  color: var(--text-muted);
  font-weight: 500;
  font-size: 0.72rem;
  margin-left: 2px;
}
@keyframes rain-badge-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34,211,238,0); }
  50%      { box-shadow: 0 0 12px 2px rgba(34,211,238,0.35); }
}
@keyframes rain-drop-fall {
  0%   { transform: translateY(-6px); opacity: 0; }
  20%  { opacity: 1; }
  100% { transform: translateY(4px); opacity: 0; }
}

/* ----- Vallende-druppels overlay op rain-card ----- */
.rain-overlay {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  opacity: 0;
  transition: opacity 0.6s ease;
  z-index: 0;
}
.card-rain-active .rain-overlay { opacity: 1; }
.rain-overlay .rd {
  position: absolute;
  top: -8px;
  width: 2px;
  height: 12px;
  border-radius: 2px;
  background: linear-gradient(180deg, transparent 0%, #22d3ee 60%, #67e8f9 100%);
  opacity: 0;
  animation: rd-fall 1.8s linear infinite;
  filter: drop-shadow(0 0 3px rgba(34,211,238,0.5));
}
.card-rain-active.heavy .rain-overlay .rd { animation-duration: 1.1s; }
@keyframes rd-fall {
  0%   { transform: translateY(0);   opacity: 0; }
  10%  { opacity: 0.9; }
  90%  { opacity: 0.9; }
  100% { transform: translateY(220px); opacity: 0; }
}

/* Paraplu-overlay rechtsboven in rain-mini — zichtbaar zodra regen actief */
.rain-umbrella {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 24px;
  height: 24px;
  color: var(--cyan);
  z-index: 2;
  filter: drop-shadow(0 0 6px rgba(34,211,238,0.7));
  animation: umbrella-bob 2.2s ease-in-out infinite;
  pointer-events: none;
}
@keyframes umbrella-bob {
  0%, 100% { transform: translateY(0) rotate(-3deg); }
  50%      { transform: translateY(-3px) rotate(3deg); }
}

/* ==================== PAGE-TABS ==================== */

.page-tabs {
  display: flex;
  gap: 4px;
  padding: 6px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  /* Onderkant strak — verbindt visueel met de content eronder */
  border-bottom: none;
  border-radius: 12px 12px 0 0;
  margin: 8px 0 0 0;
  flex-wrap: wrap;
}
/* Sticky zodat de tabs zichtbaar blijven bij scrollen */
.page-tabs {
  position: sticky;
  top: 0;
  z-index: 50;
  backdrop-filter: blur(6px);
}
.page-tab {
  background: transparent;
  border: none;
  color: var(--text-muted);
  padding: 9px 22px;
  font-family: inherit;
  font-size: 0.92rem;
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  border-radius: 8px;
  min-height: 38px;
  transition: background 0.15s, color 0.15s;
}
.page-tab:hover { color: var(--text); background: rgba(255,255,255,0.03); }
.page-tab.active {
  background: linear-gradient(135deg, var(--cyan) 0%, var(--cyan-2) 100%);
  color: #0a0f1c;
  box-shadow: 0 2px 8px var(--cyan-glow);
}

/* Verberg secties die niet bij actieve pagina horen */
[data-page-section][hidden] { display: none !important; }

/* Eerste zichtbare data-page-section (gemarkeerd door JS) sluit strak aan
   op de tab-bar: geen top-margin en strakke bovenrand. */
[data-page-section].first-on-page {
  margin-top: 0 !important;
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.head-controls {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.head-title h1 {
  margin: 0;
  font-size: 1.6rem;
  font-weight: 700;
  background: linear-gradient(90deg, var(--cyan) 0%, #67e8f9 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.3px;
}

.header-clock {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  padding: 4px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  min-height: 50px;
  justify-content: center;
  min-width: 110px;
}
.hc-time {
  font-size: 1.15rem;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  line-height: 1.1;
  letter-spacing: 0.5px;
}
.hc-date {
  font-size: 0.7rem;
  color: var(--text-muted);
  letter-spacing: 0.3px;
  font-weight: 500;
  text-transform: capitalize;
}

.rate-selector {
  display: flex;
  flex-direction: column;
  gap: 3px;
  padding: 6px 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  cursor: pointer;
  min-height: 50px;
  justify-content: center;
}
.rate-label {
  font-size: 0.6rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.7px;
  font-weight: 500;
}
.rate-selector select {
  background: transparent;
  border: none;
  color: var(--cyan);
  font-size: 0.85rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  padding: 0;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  padding-right: 16px;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2322d3ee' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 10px;
}
.rate-selector select option {
  background: var(--bg-card);
  color: var(--text);
}

/* Taal-toggle in de header */
.lang-toggle {
  display: flex;
  gap: 2px;
  padding: 3px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  min-height: 50px;
  align-items: center;
}
.lang-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 700;
  font-family: inherit;
  letter-spacing: 0.5px;
  cursor: pointer;
  border-radius: 7px;
  min-height: 36px;
  min-width: 36px;
  transition: background 0.15s, color 0.15s;
}
.lang-btn:hover { color: var(--text); }
.lang-btn.active {
  background: var(--cyan-2);
  color: #0a0f1c;
}

.locale {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 8px 16px;
}
.locale-forecast { width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; }
.locale-forecast svg { width: 36px; height: 36px; }
.locale-place { font-size: 0.9rem; font-weight: 500; }
.locale-coords { font-size: 0.72rem; color: var(--text-muted); }

/* ==================== CARDS ==================== */

.card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px;
  position: relative;
  overflow: hidden;
}

/* Watermark — diffuus icoon achter de card-inhoud */
.card-watermark {
  position: absolute;
  bottom: -30px;
  right: -25px;
  width: 180px;
  height: 180px;
  opacity: 0.045;
  pointer-events: none;
  z-index: 0;
  filter: blur(0.5px);
}
.card-wind .card-watermark {
  width: 187px;
  height: 187px;
  top: -10px;
  left: -35px;
  bottom: auto;
  right: auto;
  opacity: 0.055;
}
.card-gauge .card-watermark { width: 160px; height: 160px; bottom: -25px; right: -20px; }
.card-chart .card-watermark { width: 140px; height: 140px; bottom: -20px; right: -15px; opacity: 0.06; }
.card-mini .card-watermark {
  width: 130px;
  height: 130px;
  bottom: -18px;
  right: -18px;
  opacity: 0.09;
}
/* Thermometer in temp-card: 15% kleiner + ~20px omhoog */
.gauge-temp .card-watermark { width: 110px; height: 110px; bottom: 2px; }
/* Druppel in vochtigheid-card: 20% kleiner + ~20px omhoog */
.gauge-hum  .card-watermark { width: 104px; height: 104px; bottom: 2px; }
/* Barometer-dial in luchtdruk-card: nog 15% kleiner + iets naar links */
.gauge-baro .card-watermark { width: 80px; height: 80px; bottom: 2px; right: -6px; }
/* Regen-cluster in regen-card: 10% kleiner */
.gauge-rain .card-watermark { width: 117px; height: 117px; }

/* Zorg dat de inhoud bovenop het watermark blijft */
.card > .card-head,
.card > .ring-gauge,
.card > .ring-text,
.card > .ring-range,
.card > .wind-gauge-wrap,
.card > .gauge-sub,
.card > .chart-wrap,
.card > .chart-foot,
.card > .wind-foot {
  position: relative;
  z-index: 1;
}

.card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 12px;
}
.card-head h3 {
  margin: 0;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
}
.card-head-right {
  font-size: 0.85rem;
  color: var(--text);
  font-weight: 500;
  padding: 4px 10px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 6px;
}

/* ==================== TOP ROW (wind + 6 mini-gauges) ==================== */

.top-row {
  display: grid;
  grid-template-columns: minmax(380px, 1.4fr) minmax(0, 2fr);
  gap: 16px;
}

.mini-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 1fr 1fr;
  gap: 12px;
}

.card-mini {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 10px 12px;
  gap: 3px;
  min-height: 0;
  position: relative;
  overflow: hidden;
}
.gauge-uv       { --gauge-color: #fbbf24; --gauge-glow: rgba(251,191,36,0.4); }
.gauge-rain     { --gauge-color: #22d3ee; --gauge-glow: var(--cyan-glow); }
.gauge-forecast { --gauge-color: #38bdf8; --gauge-glow: var(--cyan-glow); }
.gauge-aqi      { --gauge-color: #22c55e; --gauge-glow: rgba(34,197,94,0.4); }
/* 7e tile (AQI) overspant alle 3 kolommen onderaan */
.mini-grid .mini-wide { grid-column: 1 / -1; flex-direction: row; align-items: center; gap: 16px; padding-left: 18px; padding-right: 18px; }
.mini-grid .mini-wide .mini-label { writing-mode: vertical-rl; transform: rotate(180deg); align-self: stretch; padding-top: 8px; }
.mini-grid .mini-wide .mini-ring { width: 120px; height: 120px; flex-shrink: 0; }
.mini-grid .mini-wide .mini-sub { flex: 1; text-align: left; font-size: 0.85rem; white-space: normal; max-width: none; }
.mini-grid .mini-wide .mini-hilo { flex-shrink: 0; }

.mini-label {
  font-size: 0.58rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  font-weight: 600;
  text-align: center;
  position: relative;
  z-index: 1;
}

.mini-ring {
  position: relative;
  width: 145px;
  height: 145px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1;
}
.mini-ring svg { width: 100%; height: 100%; display: block; }
.mini-ring .ring-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.mini-ring .ring-value {
  font-size: 2.1rem;
  font-weight: 300;
  color: var(--gauge-color);
  text-shadow: 0 0 18px var(--gauge-glow);
  line-height: 1;
  letter-spacing: -1.5px;
  font-variant-numeric: tabular-nums;
}
.mini-ring .ring-unit {
  font-size: 0.6rem;
  color: var(--text-faint);
  margin-top: 4px;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  font-weight: 500;
}

.mini-sub {
  font-size: 0.68rem;
  color: var(--text-muted);
  font-weight: 500;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 100%;
  position: relative;
  z-index: 1;
}
.mini-hilo {
  font-size: 0.6rem;
  color: var(--text-faint);
  font-weight: 400;
  letter-spacing: 0.3px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  display: flex;
  gap: 8px;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.mini-hilo .hi { color: #fb923c; }
.mini-hilo .lo { color: #38bdf8; }

.mini-forecast {
  width: 130px;
  height: 130px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.mini-forecast svg {
  width: 110px;
  height: 110px;
  filter: drop-shadow(0 0 14px rgba(56,189,248,0.3));
}

/* ==================== FORECAST BANNER ==================== */

.forecast-banner {
  display: flex;
  align-items: center;
  gap: 12px;
  background: linear-gradient(90deg, rgba(56,189,248,0.08) 0%, transparent 100%);
  border: 1px solid var(--border);
  border-left: 3px solid var(--cyan);
  border-radius: 10px;
  padding: 10px 16px;
}
.fb-icon { flex: 0 0 36px; display: flex; align-items: center; }
.fb-icon svg { width: 36px; height: 36px; }
.fb-text { display: flex; gap: 10px; align-items: baseline; flex-wrap: wrap; min-width: 0; }
.fb-label {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--cyan);
  white-space: nowrap;
}
.fb-rule {
  font-size: 0.82rem;
  color: var(--text-muted);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* --- Wind hero --- */

.card-wind {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: linear-gradient(135deg, #0e1622 0%, #111827 100%);
}

.wind-gauge-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 16/11;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
}
#wind-gauge { width: 100%; height: 100%; }
#wind-gauge svg { width: 100%; height: 100%; display: block; }

.wind-center-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.wind-center-label {
  font-size: 0.6rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 2px;
  font-weight: 500;
}
.wind-center-value {
  font-size: 3rem;
  font-weight: 300;
  line-height: 1;
  color: var(--cyan);
  text-shadow: 0 0 18px var(--cyan-glow), 0 2px 6px rgba(0,0,0,0.5);
  letter-spacing: -1.5px;
}
.wind-center-unit {
  font-size: 0.7rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-top: 6px;
  font-weight: 500;
}
.wind-center-gust {
  margin-top: 8px;
  font-size: 0.75rem;
  color: var(--text-muted);
  letter-spacing: 0.3px;
  font-variant-numeric: tabular-nums;
}
.wind-center-altunits {
  margin-top: 4px;
  font-size: 0.68rem;
  color: var(--text-faint);
  letter-spacing: 0.3px;
  font-variant-numeric: tabular-nums;
  display: flex;
  gap: 10px;
  align-items: center;
}
.wind-center-altunits span {
  position: relative;
}
.wind-center-altunits span:not(:last-child)::after {
  content: '·';
  position: absolute;
  right: -7px;
  color: var(--border-light);
}

.wind-foot {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
  margin-top: 4px;
}
.wind-foot-cell {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 6px 10px;
  background: var(--bg-deep);
  border-radius: 8px;
  border: 1px solid var(--border);
  min-height: 50px;
  overflow: hidden;
}
/* De wrapper-div tussen icon en label/value; moet min-width:0 hebben anders
   weigert flex te shrinken en lopen langere bft-teksten buiten de cel. */
.wind-foot-cell > div {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.wfc-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: rgba(34,211,238,0.08);
  color: var(--cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.wfc-icon svg { width: 16px; height: 16px; }
.wfc-label {
  font-size: 0.6rem;
  color: var(--text-faint);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.wfc-value {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: flex;
  align-items: baseline;
  gap: 6px;
  min-width: 0;
}
.wfc-value > span { display: inline-block; }
.wfc-value > #bft-num,
.wfc-value > #wind-dir-detail { flex-shrink: 0; }
.wfc-sub {
  font-size: 0.72rem;
  color: var(--text-muted);
  font-weight: 400;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}

/* --- Ring gauges (temp / hum / baro) --- slanker en eleganter --- */

.card-gauge {
  display: flex;
  flex-direction: column;
  align-items: stretch;
}
.gauge-temp { --gauge-color: var(--temp-color); --gauge-glow: var(--temp-glow); }
.gauge-hum  { --gauge-color: var(--hum-color);  --gauge-glow: var(--hum-glow); }
.gauge-baro { --gauge-color: var(--baro-color); --gauge-glow: var(--baro-glow); }

.ring-gauge {
  position: relative;
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 180px;
  padding: 8px 0;
}
.ring-gauge svg { width: 100%; height: auto; max-width: 200px; max-height: 200px; display: block; }
.ring-gauge .ring-text {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}
.ring-value {
  font-size: 2.1rem;
  font-weight: 300;
  color: var(--gauge-color);
  text-shadow: 0 0 18px var(--gauge-glow);
  line-height: 1;
  letter-spacing: -1px;
  font-variant-numeric: tabular-nums;
}
.ring-unit  {
  font-size: 0.7rem;
  color: var(--text-faint);
  margin-top: 6px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  font-weight: 500;
}
.ring-range {
  position: absolute;
  bottom: 8px;
  left: 0; right: 0;
  display: flex;
  justify-content: space-between;
  padding: 0 22px;
  font-size: 0.55rem;
  color: var(--text-faint);
  letter-spacing: 0.5px;
  pointer-events: none;
}

.gauge-sub {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 12px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-top: 8px;
  font-size: 0.78rem;
  color: var(--text-muted);
}
.gauge-sub b { color: var(--text); font-weight: 600; }

/* ==================== MID ROW (charts + forecast) ==================== */

.mid-row {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 16px;
}
.card-chart .chart-wrap { width: 100%; height: 120px; }
.card-chart .chart-wrap svg { width: 100%; height: 100%; display: block; }
.card-chart .card-head-right { color: var(--cyan); font-weight: 600; font-size: 0.95rem; }

.chart-foot {
  display: flex;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
  font-size: 0.78rem;
  color: var(--text-muted);
}
.chart-foot b { color: var(--text); font-weight: 600; }

.card-forecast {
  display: flex;
  flex-direction: column;
  background: linear-gradient(135deg, #0e1622 0%, #1a2335 100%);
}
.forecast-icon-big {
  display: flex;
  justify-content: center;
  align-items: center;
  margin: 8px 0;
}
.forecast-icon-big svg { width: 80px; height: 80px; filter: drop-shadow(0 4px 12px rgba(0,0,0,0.4)); }
.forecast-label {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cyan);
  margin-bottom: 4px;
  text-align: center;
}
.forecast-rule {
  margin: 0;
  font-size: 0.8rem;
  color: var(--text-muted);
  line-height: 1.4;
  text-align: center;
}

/* ==================== STATS BAR ==================== */

.stats-bar {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 8px;
  padding: 12px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 12px;
}
.stat-mini {
  display: flex;
  gap: 10px;
  align-items: center;
  padding: 8px 10px;
  border-radius: 8px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  min-width: 0;
}
.sm-icon {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  background: rgba(34,211,238,0.08);
  color: var(--cyan);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sm-icon svg { width: 15px; height: 15px; }
.stat-mini > div:last-child { min-width: 0; flex: 1; display: flex; flex-direction: column; }
.sm-label { font-size: 0.58rem; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.4px; white-space: nowrap; font-weight: 500; }
.sm-value { font-size: 0.82rem; font-weight: 500; color: var(--text); white-space: nowrap; }

/* ==================== PANELS (sidebar nav) ==================== */

.panel {
  /* Verborgen tot sidebar-nav activeert */
}
.filter-bar { display: flex; gap: 8px; align-items: center; }
.filter-bar input[type="search"] {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 12px;
  border-radius: 6px;
  min-height: 32px;
  font-size: 0.85rem;
}
.filter-bar button {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
  min-height: 32px;
  font-size: 0.85rem;
}
.filter-bar button[data-active="true"] { background: var(--cyan-2); border-color: var(--cyan-2); color: #0a0f1c; }

/* ==================== SENSOR-TOOLBAR (categorieën + presets) ==================== */

.sensor-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin: 12px 0;
  flex-wrap: wrap;
  align-items: center;
}
.category-tabs {
  display: flex;
  gap: 4px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 3px;
  flex-wrap: wrap;
}
.cat-tab {
  background: transparent;
  border: none;
  color: var(--text-muted);
  padding: 6px 12px;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.3px;
  cursor: pointer;
  border-radius: 5px;
  min-height: 30px;
  transition: background 0.12s, color 0.12s;
}
.cat-tab:hover { color: var(--text); }
.cat-tab.active { background: var(--cyan-2); color: #0a0f1c; }

.preset-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 3px 8px 3px 14px;
}
.preset-label {
  font-size: 0.72rem;
  color: var(--text-muted);
  letter-spacing: 0.4px;
  text-transform: uppercase;
  font-weight: 600;
}
.preset-btn {
  background: transparent;
  border: none;
  color: var(--text);
  padding: 5px 12px;
  font-family: inherit;
  font-size: 0.78rem;
  font-weight: 600;
  cursor: pointer;
  border-radius: 5px;
  min-height: 28px;
  transition: background 0.12s;
}
.preset-btn:hover { background: rgba(34,211,238,0.12); color: var(--cyan); }

/* ==================== BULK-BAR ==================== */

.bulk-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: linear-gradient(90deg, rgba(34,211,238,0.12) 0%, transparent 100%);
  border: 1px solid var(--cyan);
  border-radius: 10px;
  margin-bottom: 12px;
}
.bulk-count { color: var(--text); font-size: 0.85rem; }
.bulk-count b { color: var(--cyan); font-size: 1.05rem; font-weight: 700; padding-right: 2px; }
.bulk-bar button {
  background: var(--bg-card);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 6px 14px;
  border-radius: 6px;
  font-family: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  min-height: 32px;
}
.bulk-bar button:hover { border-color: var(--cyan); color: var(--cyan); }
#bulk-edit-btn {
  background: var(--cyan-2);
  border-color: var(--cyan-2);
  color: #0a0f1c;
}
#bulk-edit-btn:hover { background: var(--cyan); color: #0a0f1c; border-color: var(--cyan); }

.sensor-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
  margin-top: 12px;
}

/* Selectie + stat-badge in sensor-tile */
.tile { position: relative; }
.tile.selected {
  border-color: var(--cyan);
  background: rgba(34,211,238,0.08);
  box-shadow: 0 0 0 2px rgba(34,211,238,0.25);
}
.tile-checkbox {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 18px;
  height: 18px;
  border: 1.5px solid var(--border-light);
  border-radius: 4px;
  background: var(--bg-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 0.75rem;
  color: transparent;
  transition: all 0.12s;
}
.tile-checkbox:hover { border-color: var(--cyan); }
.tile.selected .tile-checkbox {
  background: var(--cyan-2);
  border-color: var(--cyan-2);
  color: #0a0f1c;
}
.tile-stat-badge {
  display: inline-block;
  font-size: 0.6rem;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 4px;
  letter-spacing: 0.3px;
  margin-left: 6px;
}
.tile-stat-badge.low    { background: rgba(34,197,94,0.18);  color: #4ade80; }
.tile-stat-badge.med    { background: rgba(251,191,36,0.18); color: #facc15; }
.tile-stat-badge.high   { background: rgba(239,68,68,0.18);  color: #f87171; }
.tile-mode-badge {
  display: inline-block;
  font-size: 0.58rem;
  font-weight: 600;
  padding: 2px 5px;
  border-radius: 3px;
  margin-left: 4px;
  letter-spacing: 0.2px;
  text-transform: uppercase;
}
.tile-mode-badge.change-only { background: rgba(167,139,250,0.18); color: #c4b5fd; }
.tile-mode-badge.always      { background: rgba(251,146,60,0.18); color: #fdba74; }
.tile-mode-badge.off         { background: rgba(100,116,139,0.25); color: var(--text-faint); }
.tile {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 12px;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.tile:hover { background: var(--bg-card-2); border-color: var(--cyan); }
.tile-label { font-size: 0.65rem; color: var(--text-faint); text-transform: uppercase; letter-spacing: 0.4px; }
.tile-value { font-size: 1.05rem; font-weight: 600; font-variant-numeric: tabular-nums; line-height: 1.2; }
.tile-value .unit { font-size: 0.7rem; color: var(--text-muted); margin-left: 2px; font-weight: 400; }
.tile-footer { font-size: 0.62rem; color: var(--text-faint); margin-top: auto; }
.tile.disabled { opacity: 0.45; }
.tile.dashed .tile-value { color: var(--text-muted); }

/* High/low table */

.period-tabs {
  display: flex;
  gap: 4px;
  background: var(--bg-deep);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 3px;
}
.period-tab {
  background: transparent;
  border: none;
  color: var(--text-muted);
  padding: 5px 14px;
  font-size: 0.75rem;
  font-weight: 600;
  cursor: pointer;
  border-radius: 5px;
  letter-spacing: 0.3px;
  font-family: inherit;
  min-height: 28px;
  transition: background 0.15s, color 0.15s;
}
.period-tab:hover { color: var(--text); }
.period-tab.active {
  background: var(--cyan-2);
  color: #0a0f1c;
}

.period-picker {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  color: var(--cyan);
  font-family: inherit;
  font-weight: 600;
  font-size: 0.78rem;
  letter-spacing: 0.3px;
  padding: 4px 22px 4px 10px;
  border-radius: 8px;
  min-height: 32px;
  cursor: pointer;
  outline: none;
  appearance: none;
  -webkit-appearance: none;
  background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%2322d3ee' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 10px;
  margin-left: 8px;
}
.period-picker:hover { border-color: var(--cyan); }
.period-picker option { background: var(--bg-card); color: var(--text); }

.hilow-table-wrap { overflow-x: auto; }
.hilow-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
  font-variant-numeric: tabular-nums;
}
.hilow-table th, .hilow-table td {
  text-align: right;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
}
.hilow-table th, .hilow-table th:first-child { text-align: left; }
.hilow-table td:first-child { text-align: left; color: var(--text); }
.hilow-table th {
  color: var(--text-faint);
  font-weight: 500;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.hilow-table td.hi { color: var(--orange); font-weight: 600; }
.hilow-table td.lo { color: var(--cyan); font-weight: 600; }
.hilow-table td.time { color: var(--text-faint); font-size: 0.78rem; }
.hilow-table tbody tr:hover { background: rgba(255,255,255,0.02); }

/* ==================== MODAL ==================== */

.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 100;
  padding: 16px;
}
.modal {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 14px;
  width: 100%;
  max-width: 500px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: 0 20px 40px rgba(0,0,0,0.5);
}
.modal-head { display: flex; justify-content: space-between; align-items: center; padding: 14px 18px; border-bottom: 1px solid var(--border); }
.modal-head h3 { margin: 0; font-size: 0.95rem; }
.close-btn {
  background: transparent;
  border: none;
  color: var(--text-muted);
  font-size: 1.5rem;
  cursor: pointer;
  width: 32px; height: 32px;
  border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
}
.close-btn:hover { background: var(--bg-deep); color: var(--text); }
.modal-body { padding: 18px; display: flex; flex-direction: column; gap: 14px; }
.field { display: flex; flex-direction: column; gap: 5px; }
.field label { font-size: 0.78rem; color: var(--text-muted); }
.field input[type="text"], .field input[type="number"], .field select {
  background: var(--bg-deep);
  border: 1px solid var(--border);
  color: var(--text);
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.95rem;
  min-height: 34px;
  font-family: inherit;
  cursor: pointer;
  outline: none;
}
.field select option { background: var(--bg-card); color: var(--text); }
.field small { color: var(--text-muted); font-size: 0.72rem; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.checkbox { display: inline-flex; align-items: center; gap: 8px; font-size: 0.85rem; cursor: pointer; min-height: 32px; }
.checkbox input { width: 16px; height: 16px; cursor: pointer; }
.hint { color: var(--text-muted); font-size: 0.72rem; margin-left: 4px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 6px; }
.btn-primary, .btn-secondary {
  padding: 8px 16px;
  border-radius: 6px;
  border: 1px solid var(--border);
  font-size: 0.9rem;
  cursor: pointer;
  min-height: 36px;
}
.btn-primary { background: var(--cyan-2); border-color: var(--cyan-2); color: #0a0f1c; font-weight: 600; }
.btn-primary:hover { background: var(--cyan); }
.btn-secondary { background: var(--bg-deep); color: var(--text); }
.btn-secondary:hover { background: var(--bg-card-2); }
.save-flash {
  margin: 0;
  padding: 6px 10px;
  background: rgba(34,197,94,0.15);
  border: 1px solid var(--green);
  color: var(--green);
  border-radius: 6px;
  text-align: center;
  font-size: 0.85rem;
}

/* ==================== RESPONSIVE ==================== */

@media (max-width: 1280px) {
  .top-row { grid-template-columns: minmax(340px, 1.3fr) minmax(0, 2fr); gap: 12px; }
  .mid-row { grid-template-columns: 1fr 1.6fr; gap: 12px; }
  .stats-bar { grid-template-columns: repeat(4, 1fr); }
  .mini-ring { width: 128px; height: 128px; }
  .mini-ring .ring-value { font-size: 1.8rem; }
  .mini-forecast { width: 130px; height: 130px; }
  .mini-forecast svg { width: 110px; height: 110px; }
}

@media (max-width: 1024px) {
  .top-row { grid-template-columns: 1fr; }
  .mini-grid { grid-template-columns: repeat(3, 1fr); }
  .mid-row { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .main { padding: 14px; gap: 12px; }
  .top-row, .mid-row { grid-template-columns: 1fr; gap: 12px; }
  .mini-grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(3, 1fr); }
  .page-head { flex-wrap: wrap; }
  .stats-bar { grid-template-columns: repeat(2, 1fr); }
  .wind-center-value { font-size: 2.6rem; }
  h1 { font-size: 1.3rem; }
  .modal { width: calc(100vw - 32px); }
}

@media (max-width: 480px) {
  .stats-bar { grid-template-columns: 1fr 1fr; }
  .field-row { grid-template-columns: 1fr; }
  .header-clock { min-width: 0; padding: 4px 10px; }
  .hc-time { font-size: 1rem; }
}

/* ============================================================
   STORM GLASS OVERLAY — voegt een live WebGL atmosfeer-scène toe achter het
   dashboard. Cards krijgen een subtiel glass-effect (backdrop-filter) zodat ze
   boven de scène lijken te zweven zonder leesbaarheid op te offeren.
   Zelfde shader/scripts als /wow, alleen wow had eigen layout.
   ============================================================ */

/* Body wordt transparant zodat de canvas (z-index 0) en static-sky (z-index -1)
 * zichtbaar zijn. html behoudt de donkere kleur als allerlaatste fallback voor
 * het geval er ook geen static-sky paint. */
html { background: var(--bg-deep); }
body { background: transparent; }

#storm-glass-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  display: block;
  pointer-events: none;
}

/* CSS-only fallback voor wanneer WebGL faalt of reduced-motion aanstaat.
 * Storm-glass.js zet body.gl-active als de scène draait → static-sky uit. */
.static-sky {
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(120% 80% at 50% -10%, oklch(36% 0.080 240) 0%, transparent 55%),
    radial-gradient(80% 60% at 80% 100%, oklch(28% 0.090 280) 0%, transparent 60%),
    linear-gradient(180deg, oklch(15% 0.020 240) 0%, oklch(10% 0.022 250) 100%);
}
body.gl-active .static-sky { opacity: 0; }

/* App zit boven de scène */
.app, .modal-backdrop { position: relative; z-index: 1; }

/* Subtiel glass op alle data-cards. Alpha bewust hoog (cijfers blijven scherp)
 * en blur klein. Door de OKLCH tokens hierboven zijn de hex-kleuren al weg
 * — de tinten in glow's en accents komen ongewijzigd door. */
.card {
  background: var(--bg-glass);
  border-color: var(--border-glass);
  backdrop-filter: blur(14px) saturate(135%);
  -webkit-backdrop-filter: blur(14px) saturate(135%);
}

/* Wind- en forecast-cards hadden eigen gradient — vertaal naar glass-variant */
.card-wind {
  background: linear-gradient(135deg,
    oklch(17% 0.022 245 / 0.62) 0%,
    oklch(20% 0.020 240 / 0.62) 100%);
}
.card-forecast {
  background: linear-gradient(135deg,
    oklch(17% 0.022 245 / 0.62) 0%,
    oklch(24% 0.025 250 / 0.62) 100%);
}

/* Top-bar containers krijgen ook een vleugje glass */
.header-clock, .rate-selector, .lang-toggle, .locale {
  background: var(--bg-glass-soft);
  border-color: var(--border-glass);
  backdrop-filter: blur(10px) saturate(130%);
  -webkit-backdrop-filter: blur(10px) saturate(130%);
}

/* Stats-bar buitenrand glass; .stat-mini cellen erin blijven solid donker
 * voor leesbaarheid */
.stats-bar {
  background: var(--bg-glass-soft);
  border-color: var(--border-glass);
  backdrop-filter: blur(10px) saturate(130%);
  -webkit-backdrop-filter: blur(10px) saturate(130%);
}

/* Forecast-banner ook glass (had al een subtle gradient erover) */
.forecast-banner {
  background: linear-gradient(90deg,
    oklch(75% 0.090 215 / 0.10) 0%,
    transparent 100%),
    var(--bg-glass-soft);
  border-color: var(--border-glass);
  backdrop-filter: blur(10px) saturate(130%);
  -webkit-backdrop-filter: blur(10px) saturate(130%);
}

/* Browsers zonder backdrop-filter krijgen iets donkerders zodat cards niet
 * onleesbaar door de scène heen kijken */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .card,
  .card-wind,
  .card-forecast,
  .header-clock, .rate-selector, .lang-toggle, .locale,
  .stats-bar,
  .forecast-banner {
    background: var(--bg-card);
  }
}

/* Reduced-motion: de canvas-loop wordt door storm-glass.js zelf gestopt.
 * Hier zorgen we alleen dat onze nieuwe CSS-animations rustig zijn. */
@media (prefers-reduced-motion: reduce) {
  .dot, .rain-badge, .rain-badge-drops path, .rain-overlay .rd, .rain-umbrella {
    animation: none !important;
  }
}
