:root {
  --bg: #020805;
  --panel: rgba(4, 22, 18, 0.84);
  --panel-strong: rgba(2, 35, 30, 0.94);
  --line: rgba(86, 255, 206, 0.28);
  --line-strong: rgba(86, 255, 206, 0.65);
  --text: #ecfff9;
  --muted: #93cfc2;
  --cyan: #55ffcc;
  --green: #9cff4f;
  --blue: #65d9ff;
  --red: #ff5d7a;
  --yellow: #ffe66d;
  --shadow: 0 0 40px rgba(85, 255, 204, 0.13), inset 0 0 30px rgba(85, 255, 204, 0.04);
  --radius: 22px;
  --radius-sm: 14px;
  --max: 1180px;
  --font: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { min-height: 100%; background: var(--bg); color: var(--text); }
body {
  min-height: 100vh;
  margin: 0;
  font-family: var(--font);
  background:
    radial-gradient(circle at 12% 8%, rgba(85, 255, 204, 0.14), transparent 26rem),
    radial-gradient(circle at 90% 14%, rgba(101, 217, 255, 0.11), transparent 28rem),
    radial-gradient(circle at 45% 105%, rgba(156, 255, 79, 0.08), transparent 28rem),
    #020805;
  overflow-x: hidden;
}

button, input, input[type=search], select, textarea { font: inherit; }
button { cursor: pointer; }

.starfield {
  position: fixed;
  inset: 0;
  pointer-events: none;
  opacity: 0.42;
  background-image:
    radial-gradient(circle, rgba(255,255,255,.95) 0 1px, transparent 1.5px),
    radial-gradient(circle, rgba(85,255,204,.8) 0 1px, transparent 1.6px);
  background-size: 86px 86px, 137px 137px;
  animation: drift 24s linear infinite;
}

@keyframes drift {
  from { transform: translate3d(0,0,0); }
  to { transform: translate3d(-86px, 86px, 0); }
}

.app-shell {
  position: relative;
  z-index: 1;
  width: min(var(--max), calc(100% - 34px));
  margin: 0 auto;
  padding: 28px 0 48px;
}

.panel, .hero-panel, .dialog-card {
  border: 1px solid var(--line);
  background: linear-gradient(145deg, rgba(4, 22, 18, .88), rgba(2, 10, 9, .76));
  box-shadow: var(--shadow);
  border-radius: var(--radius);
  backdrop-filter: blur(14px);
}

.panel { padding: 20px; }
.panel-glow { position: relative; overflow: hidden; }
.panel-glow::after {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(115deg, transparent 0 30%, rgba(85,255,204,.18), transparent 68% 100%);
  pointer-events: none;
}

.hero-panel {
  min-height: 230px;
  display: grid;
  grid-template-columns: 1fr 230px;
  gap: 24px;
  align-items: center;
  padding: 34px;
}

.eyebrow, .card-label {
  margin: 0 0 8px;
  color: var(--cyan);
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 800;
  font-size: .73rem;
}

h1, h2 { margin: 0; line-height: 1.05; }
h1 {
  font-size: clamp(2.3rem, 6vw, 5.2rem);
  letter-spacing: -.06em;
  text-shadow: 0 0 28px rgba(85,255,204,.42);
}
h2 { font-size: 1.35rem; }
.hero-text { max-width: 720px; color: var(--muted); font-size: 1.05rem; line-height: 1.65; }

.hero-orb {
  width: 210px;
  height: 210px;
  border-radius: 50%;
  border: 1px solid rgba(85,255,204,.35);
  display: grid;
  place-items: center;
  background: radial-gradient(circle, rgba(85,255,204,.20), rgba(2,8,5,.2) 62%);
  box-shadow: 0 0 60px rgba(85,255,204,.25), inset 0 0 42px rgba(85,255,204,.15);
}
.hero-orb span {
  width: 62%;
  height: 62%;
  display: block;
  border-radius: 50%;
  border: 2px solid rgba(156,255,79,.55);
  box-shadow: 0 0 35px rgba(156,255,79,.32), inset 0 0 32px rgba(101,217,255,.22);
  animation: pulseOrb 2.8s ease-in-out infinite;
}
@keyframes pulseOrb { 50% { transform: scale(1.08); opacity: .72; } }

.control-grid, .dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 16px;
}
.dashboard-grid { grid-template-columns: 1.15fr .85fr; }

.auth-card, .action-card, .voice-card { min-height: 170px; }
.auth-card { display: flex; justify-content: space-between; gap: 12px; }
.auth-badge {
  align-self: start;
  border: 1px solid var(--line-strong);
  border-radius: 999px;
  padding: 7px 11px;
  color: var(--green);
  font-weight: 900;
  box-shadow: 0 0 18px rgba(156,255,79,.18);
}
.hint { margin: 12px 0 0; color: var(--muted); line-height: 1.45; font-size: .92rem; }

.jarvis-btn {
  border: 1px solid var(--line);
  color: var(--text);
  background: rgba(85, 255, 204, .08);
  border-radius: 999px;
  padding: 11px 15px;
  font-weight: 800;
  margin: 4px 5px 4px 0;
  box-shadow: 0 0 18px rgba(85,255,204,.08);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.jarvis-btn:hover { transform: translateY(-1px); border-color: var(--line-strong); background: rgba(85,255,204,.14); }
.jarvis-btn.primary { background: linear-gradient(135deg, rgba(85,255,204,.24), rgba(156,255,79,.17)); border-color: var(--line-strong); }
.jarvis-btn.ghost { background: rgba(255,255,255,.035); }
.jarvis-btn.danger { background: rgba(255, 93, 122, .12); border-color: rgba(255, 93, 122, .46); }
.jarvis-btn.compact { padding: 8px 12px; }

.switch-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 10px;
  margin: 6px 0 12px;
  color: var(--muted);
}
.switch-row input { position: absolute; opacity: 0; }
.switch-row i {
  position: relative;
  width: 54px;
  height: 30px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.05);
}
.switch-row i::before {
  content: "";
  position: absolute;
  width: 22px;
  height: 22px;
  top: 3px;
  left: 4px;
  border-radius: 50%;
  background: var(--muted);
  transition: transform .2s ease, background .2s ease;
}
.switch-row input:checked + i::before { transform: translateX(23px); background: var(--cyan); }

input[type=search], select, textarea {
  width: 100%;
  color: var(--text);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,.22);
  padding: 11px 12px;
  outline: none;
}
input[type=search]:focus, select:focus, textarea:focus { border-color: var(--line-strong); box-shadow: 0 0 0 3px rgba(85,255,204,.08); }

.status-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 16px 0;
}
.status-chip {
  border: 1px solid rgba(85,255,204,.2);
  background: rgba(0,0,0,.22);
  border-radius: 999px;
  padding: 12px 15px;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
}
.status-chip strong { color: var(--text); }

.panel-head { display: flex; justify-content: space-between; gap: 14px; align-items: flex-start; margin-bottom: 16px; }
.wrap-head { align-items: center; flex-wrap: wrap; }
.weather-code { font-size: 3rem; filter: drop-shadow(0 0 16px rgba(85,255,204,.35)); }
.current-main { display: grid; gap: 4px; margin: 18px 0; }
.current-main strong { font-size: clamp(3.8rem, 10vw, 6.8rem); line-height: .86; letter-spacing: -.08em; }
.current-main span { color: var(--muted); font-size: 1.05rem; }
.metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 10px;
}
.metric-grid div, .forecast-card, .pollen-item, 
.astro-calendar-note {
  color: var(--muted);
  margin: -4px 0 12px;
  font-size: .86rem;
  line-height: 1.45;
}

.school-holiday-label {
  display: block;
  margin-top: 4px;
  padding: 3px 6px;
  border-radius: 9px;
  border: 1px solid rgba(255,184,77,.26);
  background: linear-gradient(135deg, rgba(255,184,77,.14), rgba(85,255,204,.04));
  color: var(--orange, #ffb84d);
  font-size: .69rem;
  line-height: 1.22;
  font-weight: 900;
}
.calendar-day.is-school-holiday {
  box-shadow: inset 0 0 0 1px rgba(255,184,77,.10), 0 0 18px rgba(255,184,77,.05);
}

.astro-label {
  display: block;
  margin-top: 4px;
  padding: 3px 6px;
  border-radius: 9px;
  border: 1px solid rgba(85,255,204,.20);
  background: linear-gradient(135deg, rgba(85,255,204,.11), rgba(156,255,79,.06));
  color: var(--cyan);
  font-size: .69rem;
  line-height: 1.22;
  font-weight: 800;
}
.calendar-day.has-astro {
  box-shadow: inset 0 0 0 1px rgba(85,255,204,.08), 0 0 18px rgba(85,255,204,.05);
}

.calendar-entry-list {
  display: grid;
  gap: 8px;
  margin: 8px 0 14px;
}
.calendar-entry-list.empty-state {
  border: 1px dashed rgba(85,255,204,.20);
  border-radius: var(--radius-sm);
  padding: 12px;
  color: var(--muted);
  background: rgba(0,0,0,.18);
}
.calendar-entry-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,.22);
  padding: 11px;
}
.calendar-entry-item strong {
  color: var(--cyan);
  display: block;
  font-size: .84rem;
  margin-bottom: 4px;
}
.calendar-entry-item p {
  margin: 0;
  color: var(--text);
  line-height: 1.45;
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}
.calendar-entry-item.urgency-low { border-color: rgba(85,255,204,.20); }
.calendar-entry-item.urgency-normal { border-color: rgba(156,255,79,.22); }
.calendar-entry-item.urgency-high { border-color: rgba(255,184,77,.32); }
.calendar-entry-item.urgency-urgent { border-color: rgba(255,91,91,.42); }

.day-holiday-hint span {
  display: block;
}
.day-holiday-hint span + span {
  margin-top: 5px;
}

.calendar-day {
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,.20);
}
.metric-grid div { padding: 13px; }
.metric-grid span { display:block; color: var(--muted); font-size: .85rem; margin-bottom: 4px; }
.metric-grid strong { color: var(--cyan); line-height: 1.25; overflow-wrap: anywhere; }
.metric-grid .metric-wide { grid-column: span 2; }
.place-subtitle { margin: 7px 0 0; color: var(--muted); line-height: 1.35; font-size: .95rem; max-width: 42rem; }
.osm-attribution { font-size: .78rem; opacity: .86; }
.status-chip strong { overflow-wrap: anywhere; text-align: right; }

.pulse-dot {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 0 0 rgba(156,255,79,.7);
  animation: ping 1.8s infinite;
}
@keyframes ping { 70% { box-shadow: 0 0 0 18px rgba(156,255,79,0); } 100% { box-shadow: 0 0 0 0 rgba(156,255,79,0); } }

.pollen-list { display: grid; gap: 10px; }
.pollen-item { padding: 12px; display: flex; justify-content: space-between; gap: 12px; align-items: center; }
.pollen-item strong { color: var(--cyan); }
.pollen-level { border-radius: 999px; padding: 5px 10px; border: 1px solid var(--line); color: var(--text); font-size: .82rem; }
.level-none { color: var(--muted); }
.level-low { color: var(--green); }
.level-medium { color: var(--yellow); }
.level-high { color: var(--red); }

.forecast-panel, .calendar-panel { margin-top: 16px; }
.forecast-list {
  display: grid;
  grid-template-columns: repeat(7, minmax(140px, 1fr));
  gap: 12px;
}
.forecast-card { padding: 14px; min-height: 236px; display: flex; flex-direction: column; gap: 8px; }
.forecast-card time { color: var(--muted); font-size: .88rem; }
.forecast-card .forecast-icon { font-size: 2.2rem; }
.forecast-temp { font-size: 1.55rem; font-weight: 900; }
.forecast-meta { display: grid; gap: 5px; color: var(--muted); font-size: .9rem; }
.forecast-pollen { margin-top: auto; padding-top: 7px; border-top: 1px solid rgba(85,255,204,.12); color: var(--cyan); font-size: .86rem; }
.empty-state { color: var(--muted); padding: 14px; }

.calendar-title { color: var(--cyan); font-size: 1.15rem; font-weight: 900; margin-bottom: 12px; }
.weekday-row, .calendar-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 8px; }
.weekday-row { color: var(--muted); text-align: center; margin-bottom: 8px; font-weight: 800; }
.calendar-day {
  min-height: 112px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  color: var(--text);
  position: relative;
}
.calendar-day:hover { border-color: var(--line-strong); }
.calendar-day.is-other { opacity: .35; }
.calendar-day.is-today { box-shadow: inset 0 0 0 2px rgba(156,255,79,.45), 0 0 22px rgba(156,255,79,.08); }
.calendar-day.has-entry::after {
  content: "";
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--cyan);
  box-shadow: 0 0 12px rgba(85,255,204,.8);
  position: absolute;
  top: 12px;
  right: 12px;
}
.day-number { font-weight: 900; color: var(--cyan); }
.day-note-preview { color: var(--muted); font-size: .82rem; line-height: 1.25; overflow: hidden; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; }


/* v1.15.0 · Kalender Datenschutz-Hinweis & Feiertage */
.calendar-status {
  margin: -4px 0 12px;
  padding: 10px 12px;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: 14px;
  color: var(--muted);
  background: rgba(2,18,14,.48);
  font-size: .9rem;
  line-height: 1.45;
}
.calendar-day.is-holiday {
  border-color: rgba(156,255,79,.42);
  background: linear-gradient(180deg, rgba(156,255,79,.11), rgba(85,255,204,.035));
  box-shadow: inset 0 0 0 1px rgba(156,255,79,.10), 0 0 18px rgba(156,255,79,.07);
}
.calendar-day.is-holiday .day-number { color: var(--green); }
.holiday-label,
.day-entry-preview {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  border-radius: 999px;
  padding: 3px 7px;
  font-size: .74rem;
  line-height: 1.2;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.holiday-label {
  color: var(--green);
  border: 1px solid rgba(156,255,79,.30);
  background: rgba(156,255,79,.08);
}
.day-entry-preview {
  color: var(--cyan);
  border: 1px solid rgba(85,255,204,.26);
  background: rgba(85,255,204,.075);
}

/* v1.19.0 · Kalender-Dringlichkeit / Farbkopplung */
.calendar-day.has-entry.urgency-low::after,
.urgency-badge.urgency-low {
  background: rgba(85, 255, 204, .10);
  border-color: rgba(85, 255, 204, .34);
  color: var(--cyan);
}
.calendar-day.has-entry.urgency-normal::after,
.urgency-badge.urgency-normal {
  background: rgba(156, 255, 79, .10);
  border-color: rgba(156, 255, 79, .34);
  color: var(--green);
}
.calendar-day.has-entry.urgency-high::after,
.urgency-badge.urgency-high {
  background: rgba(255, 184, 77, .14);
  border-color: rgba(255, 184, 77, .44);
  color: #ffcf7a;
}
.calendar-day.has-entry.urgency-urgent::after,
.urgency-badge.urgency-urgent {
  background: rgba(255, 91, 91, .16);
  border-color: rgba(255, 91, 91, .52);
  color: #ff8a8a;
}
.calendar-day.has-entry.urgency-normal::after { background: var(--green); box-shadow: 0 0 12px rgba(156,255,79,.8); }
.calendar-day.has-entry.urgency-high::after { background: #ffb84d; box-shadow: 0 0 14px rgba(255,184,77,.8); }
.calendar-day.has-entry.urgency-urgent::after { background: #ff5b5b; box-shadow: 0 0 16px rgba(255,91,91,.9); }
.calendar-day.has-entry.urgency-low::after { background: var(--cyan); box-shadow: 0 0 12px rgba(85,255,204,.8); }
.calendar-day.has-entry.urgency-high { border-color: rgba(255, 184, 77, .32); }
.calendar-day.has-entry.urgency-urgent { border-color: rgba(255, 91, 91, .40); }
.urgency-select {
  width: 100%;
  margin: 0 0 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  color: var(--text);
  background: rgba(0, 0, 0, .42);
  outline: none;
}
.urgency-select:focus {
  border-color: var(--line-strong);
  box-shadow: 0 0 0 3px rgba(85,255,204,.08);
}
.day-holiday-hint {
  margin-top: 5px;
  color: var(--muted);
  font-size: .9rem;
}
.day-holiday-hint.is-active {
  color: var(--green);
  text-shadow: 0 0 10px rgba(156,255,79,.22);
}

.day-dialog {
  width: min(960px, calc(100% - 28px));
  border: none;
  background: transparent;
  padding: 0;
  color: var(--text);
}
.day-dialog::backdrop { background: rgba(0, 0, 0, .74); backdrop-filter: blur(4px); }
.dialog-card { padding: 22px; }
.note-label { display: block; color: var(--muted); margin-bottom: 8px; }
.draw-toolbar { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; color: var(--muted); margin: 14px 0; }
.draw-toolbar input { vertical-align: middle; }
#drawCanvas {
  width: 100%;
  height: auto;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background:
    linear-gradient(rgba(85,255,204,.04), rgba(85,255,204,.04)),
    rgba(0,0,0,.38);
  touch-action: none;
}
.dialog-actions { display: flex; justify-content: flex-end; gap: 8px; margin-top: 14px; flex-wrap: wrap; }

/* v1.2.0 · SEO-/Cover-Erweiterung + Wind-/Luftdruck-Metriken */
.hero-panel-cover {
  grid-template-columns: minmax(280px, .86fr) minmax(420px, 1.14fr);
  min-height: 420px;
  isolation: isolate;
}

.hero-panel-cover::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(2,8,5,.92), rgba(2,8,5,.44) 48%, rgba(2,8,5,.20)),
    radial-gradient(circle at 78% 30%, rgba(85,255,204,.15), transparent 22rem);
  pointer-events: none;
  z-index: 0;
}

.hero-panel-cover > * { position: relative; z-index: 1; }
.hero-panel-cover .hero-copy { align-self: center; }

.hero-feature-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
  margin-top: 20px;
}

.hero-feature-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  border: 1px solid rgba(85,255,204,.34);
  border-radius: 999px;
  padding: 7px 12px;
  color: var(--text);
  background: rgba(0,0,0,.26);
  box-shadow: 0 0 18px rgba(85,255,204,.06);
  font-weight: 800;
  font-size: .88rem;
}

.hero-cover-frame {
  margin: 0;
  align-self: stretch;
  display: grid;
  align-content: center;
  gap: 10px;
}

.hero-cover-frame picture {
  display: block;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(85,255,204,.38);
  background: rgba(0,0,0,.28);
  box-shadow:
    0 0 44px rgba(85,255,204,.16),
    0 0 80px rgba(101,217,255,.08),
    inset 0 0 22px rgba(85,255,204,.06);
}

.hero-cover-frame img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  transform: scale(1.01);
}

.hero-cover-frame figcaption {
  color: var(--muted);
  text-align: right;
  font-size: .86rem;
  letter-spacing: .04em;
}

/* v1.3.0 · Komfort-, Sonnen- und Luftqualitäts-Erweiterung */
.status-strip { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); }
.dashboard-grid { align-items: stretch; }
.air-panel, .insight-panel { min-height: 260px; }
.air-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(85,255,204,.35);
  border-radius: 50%;
  color: var(--cyan);
  box-shadow: 0 0 22px rgba(85,255,204,.12), inset 0 0 16px rgba(85,255,204,.08);
  font-weight: 900;
}
.air-list, .insight-list { display: grid; gap: 10px; }
.air-item, .insight-item {
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: rgba(0,0,0,.20);
  padding: 12px;
}
.air-item {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 10px;
}
.air-item span:first-child, .insight-item span { color: var(--muted); }
.air-item strong { color: var(--cyan); }
.insight-item { display: grid; gap: 5px; }
.insight-item strong { color: var(--green); }
.current-weather { grid-row: span 2; }
.forecast-card { min-height: 282px; }

/* v1.4.0 · Allergie- & Smog-Radar */
.allergy-panel, .smog-panel, .score-panel { min-height: 300px; }
.allergy-settings {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0 0 14px;
}
.check-chip {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(85,255,204,.24);
  border-radius: 999px;
  padding: 8px 11px;
  color: var(--muted);
  background: rgba(0,0,0,.22);
  font-weight: 800;
  font-size: .86rem;
  user-select: none;
}
.check-chip input {
  width: 16px;
  height: 16px;
  accent-color: var(--cyan);
}
.check-chip:has(input:checked) {
  border-color: var(--line-strong);
  color: var(--text);
  box-shadow: 0 0 18px rgba(85,255,204,.10), inset 0 0 18px rgba(85,255,204,.05);
}
.check-chip.wide { flex-basis: 100%; justify-content: center; }
.radar-box { display: grid; gap: 12px; }
.radar-headline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border: 1px solid rgba(85,255,204,.18);
  border-radius: var(--radius-sm);
  padding: 12px;
  background: rgba(0,0,0,.22);
}
.radar-headline strong { color: var(--cyan); }
.radar-note {
  margin: 0;
  color: var(--yellow);
  border: 1px solid rgba(255,230,109,.22);
  border-radius: var(--radius-sm);
  padding: 10px;
  background: rgba(255,230,109,.06);
  font-size: .9rem;
}
.radar-list { display: grid; gap: 8px; }
.radar-row {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(85,255,204,.14);
  border-radius: var(--radius-sm);
  padding: 10px 11px;
  background: rgba(0,0,0,.18);
}
.radar-row span { color: var(--muted); }
.radar-row strong { color: var(--cyan); }
.radar-row i { font-style: normal; }
.smog-meter {
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  border: 1px solid rgba(85,255,204,.20);
  background: rgba(0,0,0,.28);
}
.smog-meter span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(156,255,79,.85), rgba(255,230,109,.88), rgba(255,93,122,.9));
  box-shadow: 0 0 16px rgba(85,255,204,.18);
}
.score-list { display: grid; gap: 10px; }
.score-item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  padding: 12px;
  background: rgba(0,0,0,.20);
}
.score-item div { display: grid; gap: 4px; }
.score-item strong { color: var(--green); }
.score-item span { color: var(--muted); font-size: .88rem; }
.score-item b { color: var(--cyan); font-size: 1.3rem; }
.score-item i {
  grid-column: 1 / -1;
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(85,255,204,.14);
}
.score-item i span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(255,93,122,.9), rgba(255,230,109,.85), rgba(85,255,204,.9));
}
.ventilation-advice {
  margin: 14px 0 0;
  color: var(--text);
  line-height: 1.45;
  border: 1px solid rgba(156,255,79,.22);
  border-radius: var(--radius-sm);
  background: rgba(156,255,79,.06);
  padding: 12px;
}


/* Rechtliches Footer-Modul */
.app-footer {
  width: min(1180px, calc(100% - 28px));
  margin: 22px auto 36px;
  padding: 18px;
  border: 1px solid rgba(85, 255, 204, 0.28);
  border-radius: 22px;
  background: linear-gradient(135deg, rgba(0, 20, 16, 0.92), rgba(0, 8, 12, 0.88));
  box-shadow: 0 0 28px rgba(0, 255, 180, 0.08), inset 0 0 18px rgba(85, 255, 204, 0.04);
  color: rgba(231, 255, 247, 0.86);
}
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: center;
}
.app-footer strong {
  color: #55ffcc;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.app-footer p {
  margin: 6px 0 0;
  line-height: 1.55;
}
.legal-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}
.legal-links a,
.legal-back-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 9px 12px;
  border: 1px solid rgba(85, 255, 204, 0.35);
  border-radius: 999px;
  color: #bfffee;
  background: rgba(3, 28, 22, 0.78);
  text-decoration: none;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}
.legal-links a:hover,
.legal-back-link:hover {
  transform: translateY(-1px);
  border-color: rgba(130, 255, 192, 0.75);
  box-shadow: 0 0 16px rgba(85, 255, 204, 0.18);
}
.footer-note {
  margin-top: 14px !important;
  font-size: 0.92rem;
  color: rgba(194, 255, 237, 0.72);
}
.legal-page main {
  width: min(980px, calc(100% - 28px));
  margin: 0 auto 46px;
}
.legal-hero {
  margin: 28px auto 18px;
  padding: 22px;
  border-radius: 24px;
  border: 1px solid rgba(85, 255, 204, 0.32);
  background: radial-gradient(circle at top left, rgba(85, 255, 204, 0.14), transparent 34%), rgba(0, 13, 14, 0.9);
}
.legal-hero h1 {
  margin: 8px 0;
  color: #eafff8;
}
.legal-section {
  margin: 16px 0;
  padding: 18px;
  border: 1px solid rgba(85, 255, 204, 0.22);
  border-radius: 18px;
  background: rgba(0, 15, 14, 0.78);
}
.legal-section h2 {
  margin-top: 0;
  color: #55ffcc;
}
.legal-section h3 {
  color: #9dffe5;
}
.legal-section li {
  margin: 6px 0;
}
.legal-warning {
  border-color: rgba(255, 213, 96, 0.42);
  background: rgba(36, 26, 0, 0.38);
}
.legal-muted {
  color: rgba(231, 255, 247, 0.68);
  font-size: 0.93rem;
}


/* v1.19.0 · Allergie-Auswahl DB-Status */
.allergy-storage-hint {
  margin: -4px 0 12px;
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.4;
  border: 1px solid rgba(85,255,204,.18);
  border-radius: 14px;
  padding: 8px 10px;
  background: rgba(85,255,204,.045);
}
.allergy-storage-hint.danger {
  color: var(--red);
  border-color: rgba(255,91,122,.35);
  background: rgba(255,91,122,.065);
}


/* v1.19.0 · robuster Kalender-Farbfix */
.calendar-day.has-entry {
  --entry-color: var(--green);
  --entry-glow: rgba(156,255,79,.22);
  border-left: 4px solid var(--entry-color);
  background: linear-gradient(180deg, var(--entry-bg, rgba(156,255,79,.07)), rgba(2,18,14,.46));
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.025), 0 0 18px var(--entry-glow);
}
.calendar-day.has-entry.urgency-low {
  --entry-color: var(--cyan);
  --entry-bg: rgba(85,255,204,.08);
  --entry-glow: rgba(85,255,204,.20);
}
.calendar-day.has-entry.urgency-normal {
  --entry-color: var(--green);
  --entry-bg: rgba(156,255,79,.08);
  --entry-glow: rgba(156,255,79,.20);
}
.calendar-day.has-entry.urgency-high {
  --entry-color: #ffb84d;
  --entry-bg: rgba(255,184,77,.10);
  --entry-glow: rgba(255,184,77,.24);
}
.calendar-day.has-entry.urgency-urgent {
  --entry-color: #ff5b5b;
  --entry-bg: rgba(255,91,91,.12);
  --entry-glow: rgba(255,91,91,.28);
}
.calendar-day.has-entry::after {
  background: var(--entry-color);
  box-shadow: 0 0 14px var(--entry-color);
}
.calendar-day.has-entry .day-entry-preview {
  border-color: color-mix(in srgb, var(--entry-color) 44%, transparent);
  color: var(--entry-color);
  background: color-mix(in srgb, var(--entry-color) 12%, transparent);
}
.day-dialog[data-urgency="low"] .dialog-card { border-color: rgba(85,255,204,.32); box-shadow: 0 0 30px rgba(85,255,204,.10); }
.day-dialog[data-urgency="normal"] .dialog-card { border-color: rgba(156,255,79,.32); box-shadow: 0 0 30px rgba(156,255,79,.10); }
.day-dialog[data-urgency="high"] .dialog-card { border-color: rgba(255,184,77,.42); box-shadow: 0 0 34px rgba(255,184,77,.14); }
.day-dialog[data-urgency="urgent"] .dialog-card { border-color: rgba(255,91,91,.50); box-shadow: 0 0 36px rgba(255,91,91,.16); }


/* v1.20.0 · Jarvis Hamburger-Schnellnavigation */
.hamburger-toggle {
  position: fixed;
  top: 18px;
  right: 18px;
  z-index: 70;
  width: 68px;
  min-height: 54px;
  display: grid;
  place-items: center;
  gap: 3px;
  padding: 8px 9px 7px;
  color: var(--text);
  border: 1px solid rgba(85,255,204,.42);
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(2,18,15,.92), rgba(0,0,0,.68));
  box-shadow: 0 0 28px rgba(85,255,204,.18), inset 0 0 18px rgba(85,255,204,.045);
  backdrop-filter: blur(16px);
}
.hamburger-toggle span {
  width: 28px;
  height: 2px;
  display: block;
  border-radius: 99px;
  background: linear-gradient(90deg, var(--green), var(--cyan));
  box-shadow: 0 0 10px rgba(85,255,204,.5);
  transition: transform .18s ease, opacity .18s ease;
}
.hamburger-toggle b {
  font-size: .62rem;
  line-height: 1;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
}
.quick-nav-open .hamburger-toggle span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.quick-nav-open .hamburger-toggle span:nth-child(2) { opacity: 0; }
.quick-nav-open .hamburger-toggle span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }
.quick-nav-open .hamburger-toggle b { color: var(--cyan); }

.quick-nav-backdrop {
  position: fixed;
  inset: 0;
  z-index: 64;
  background: rgba(0,0,0,.46);
  backdrop-filter: blur(3px);
}
.quick-nav {
  position: fixed;
  top: 82px;
  right: 18px;
  width: min(360px, calc(100vw - 30px));
  z-index: 72;
}
.quick-nav-card {
  border: 1px solid rgba(85,255,204,.38);
  border-radius: 24px;
  background:
    radial-gradient(circle at top right, rgba(85,255,204,.16), transparent 18rem),
    linear-gradient(145deg, rgba(4,22,18,.96), rgba(0,5,5,.94));
  box-shadow: 0 24px 70px rgba(0,0,0,.62), 0 0 34px rgba(85,255,204,.16);
  padding: 16px;
  max-height: min(76vh, 680px);
  overflow: auto;
}
.quick-nav-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(85,255,204,.18);
  margin-bottom: 12px;
}
.quick-nav-head strong {
  display: block;
  font-size: 1.2rem;
  color: var(--text);
}
.quick-nav-close {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid rgba(85,255,204,.32);
  color: var(--cyan);
  background: rgba(85,255,204,.06);
  font-size: 1.35rem;
  line-height: 1;
}
.quick-nav-links {
  display: grid;
  gap: 8px;
}
.quick-nav-links a {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-decoration: none;
  color: var(--text);
  border: 1px solid rgba(85,255,204,.16);
  border-radius: 16px;
  padding: 11px 12px;
  background: rgba(255,255,255,.035);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.quick-nav-links a::after {
  content: "›";
  color: var(--cyan);
  font-weight: 900;
  font-size: 1.1rem;
}
.quick-nav-links a:hover,
.quick-nav-links a:focus-visible {
  transform: translateX(-2px);
  border-color: rgba(85,255,204,.42);
  background: rgba(85,255,204,.08);
  outline: none;
}
#start:focus,
#steuerung:focus,
#datenstatus:focus,
#dashboard:focus,
#jetzt:focus,
#pollen:focus,
#luft:focus,
#allergie:focus,
#smog:focus,
#scores:focus,
#hinweise:focus,
#vorhersage:focus,
#kalender:focus,
#rechtliches:focus {
  outline: 2px solid rgba(85,255,204,.28);
  outline-offset: 5px;
}


/* v1.21.0 · Finale Statuskarten statt runder Datenkreise */
.status-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(165px, 1fr)) !important;
  gap: 12px;
  margin: 16px 0 24px;
}
.status-chip {
  position: relative;
  overflow: hidden;
  min-height: 76px;
  border-radius: 18px !important;
  padding: 13px 14px;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  align-items: center;
  justify-content: initial;
  gap: 11px;
  border: 1px solid rgba(85,255,204,.22);
  background:
    radial-gradient(circle at 85% 15%, rgba(85,255,204,.12), transparent 34%),
    linear-gradient(145deg, rgba(0,28,26,.88), rgba(0,7,10,.78));
  box-shadow: 0 0 18px rgba(0,255,180,.055), inset 0 0 18px rgba(85,255,204,.035);
  color: var(--muted);
}
.status-chip::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: linear-gradient(180deg, var(--cyan), var(--green));
  opacity: .95;
}
.status-chip::after {
  content: "";
  position: absolute;
  right: -34px;
  bottom: -38px;
  width: 90px;
  height: 90px;
  border: 1px solid rgba(85,255,204,.10);
  border-radius: 50%;
  pointer-events: none;
}
.status-symbol {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: rgba(0,255,180,.07);
  border: 1px solid rgba(85,255,204,.18);
  filter: drop-shadow(0 0 10px rgba(85,255,204,.14));
}
.status-copy { min-width: 0; }
.status-chip .status-label {
  display: block;
  margin: 0 0 4px;
  font-size: .80rem;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(190,255,246,.75);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.status-chip strong {
  display: block;
  color: var(--text);
  font-size: clamp(1rem, 1.2vw, 1.16rem);
  line-height: 1.18;
  text-align: left !important;
  overflow-wrap: normal !important;
  word-break: normal !important;
  white-space: normal;
}
.status-pollen strong,
.status-air strong {
  font-size: clamp(.95rem, 1.05vw, 1.05rem);
}


/* v1.25.0 · Ortssuche & Favoriten */
.location-search-module {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(85,255,204,.14);
}
.location-search-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 8px;
  align-items: center;
}
.location-search-row .jarvis-btn { margin: 0; white-space: nowrap; }
.location-search-results,
.favorite-locations-list {
  display: grid;
  gap: 9px;
  margin-top: 12px;
}
.location-search-results.empty-state,
.favorite-locations-list.empty-state {
  border: 1px dashed rgba(85,255,204,.18);
  border-radius: 16px;
  background: rgba(0,0,0,.16);
}
.location-search-results.danger { color: var(--red); }
.location-result-card,
.favorite-location-card {
  border: 1px solid rgba(85,255,204,.18);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(0,0,0,.28), rgba(85,255,204,.045));
  padding: 11px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}
.location-result-card strong,
.favorite-location-card strong {
  display: block;
  color: var(--text);
  line-height: 1.25;
}
.location-result-card span,
.favorite-location-card span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.location-result-actions,
.favorite-location-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.favorite-location-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 15px;
}
.favorite-location-head strong { color: var(--cyan); }
.favorite-location-card.active {
  border-color: rgba(156,255,79,.52);
  box-shadow: 0 0 20px rgba(156,255,79,.12);
}
.favorite-location-card.active strong::after {
  content: " · aktiv";
  color: var(--green);
  font-size: .78rem;
}
.jarvis-btn:disabled {
  opacity: .48;
  cursor: not-allowed;
  transform: none;
}

.location-result-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 4px;
}
.location-result-meta i {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 2px 8px;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: 999px;
  background: rgba(85,255,204,.055);
  color: var(--muted);
  font-style: normal;
  line-height: 1.25;
}
.location-result-meta i:nth-child(n+3) {
  color: rgba(220,255,247,.86);
}


/* v1.26.0 · Jarvis-Sprachpaket im Header */
.control-grid {
  grid-template-columns: minmax(260px, .82fr) minmax(320px, 1.18fr);
}

.hero-voice-card {
  border: 1px solid rgba(85,255,204,.32);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(0,0,0,.42), rgba(4,34,29,.46)),
    rgba(0,0,0,.22);
  padding: 14px;
  box-shadow: 0 0 26px rgba(85,255,204,.10), inset 0 0 20px rgba(85,255,204,.035);
}

.hero-voice-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.hero-voice-head strong {
  display: block;
  color: var(--text);
  font-size: 1.05rem;
  letter-spacing: .02em;
}

.hero-voice-card .card-label {
  margin-bottom: 3px;
}

.hero-switch {
  margin: 0;
  grid-template-columns: auto auto;
  flex: 0 0 auto;
}

.hero-switch span {
  color: var(--green);
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-size: .74rem;
}

.hero-voice-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.hero-voice-controls select {
  min-height: 40px;
  padding-block: 8px;
}

.hero-voice-controls .jarvis-btn {
  margin: 0;
  white-space: nowrap;
}


/* v1.30.0 · Kalender-DB-Sync + optionales Skizzenfeld */
.calendar-sync-status {
  margin: 10px 0 12px;
  border: 1px solid rgba(85,255,204,.2);
  border-radius: 14px;
  padding: 10px 12px;
  color: var(--muted);
  background: rgba(0, 0, 0, .25);
  font-size: .92rem;
}
.calendar-sync-status.is-db {
  color: var(--green);
  border-color: rgba(156,255,79,.45);
  box-shadow: 0 0 18px rgba(156,255,79,.08);
}
.calendar-sync-status.is-local,
.calendar-sync-status.is-error {
  color: #ffcf7a;
  border-color: rgba(255,184,77,.48);
  box-shadow: 0 0 18px rgba(255,184,77,.08);
}
.sketch-details {
  margin-top: 12px;
  border: 1px solid rgba(85,255,204,.18);
  border-radius: 16px;
  background: rgba(0, 0, 0, .22);
  padding: 0;
  overflow: hidden;
}
.sketch-details > summary {
  cursor: pointer;
  padding: 12px 14px;
  color: var(--green);
  font-weight: 800;
  list-style: none;
}
.sketch-details > summary::-webkit-details-marker { display: none; }
.sketch-details[open] > summary {
  border-bottom: 1px solid rgba(85,255,204,.14);
  background: rgba(85,255,204,.04);
}
.sketch-hint { padding: 0 14px; margin-top: 12px; }
.sketch-details .draw-toolbar,
.sketch-details #drawCanvas { margin-left: 14px; margin-right: 14px; width: calc(100% - 28px); }
.sketch-details #drawCanvas { margin-bottom: 14px; }


/* v1.32.0 · Hauptseiten-Link im Header */
.hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 18px;
}

.hero-main-link {
  margin: 0;
  text-decoration: none;
  white-space: nowrap;
}

.hero-actions-note {
  color: var(--muted);
  font-size: .88rem;
  letter-spacing: .03em;
}

.quick-nav-main-link {
  border-color: rgba(156,255,79,.42) !important;
  background: linear-gradient(135deg, rgba(156,255,79,.13), rgba(85,255,204,.05)) !important;
  color: var(--green) !important;
  font-weight: 900;
}



/* v1.63 · Mobile Akkordeons */
.mobile-collapse {
  display: block;
}
.mobile-collapse > summary {
  display: none;
}
.current-region-grid {
  margin-bottom: 10px;
}
.hero-voice-details {
  margin-top: 8px;
}

/* v1.34.0 · Morgen-Slots, Wetterkarte & Radar */
.tomorrow-panel,
.weather-map-panel {
  margin-top: 16px;
}
.tomorrow-summary-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}


.tomorrow-panel-head {
  align-items: stretch;
}
.daypart-header-meta {
  min-width: 280px;
  margin-left: auto;
  padding: 14px 18px;
  border-radius: calc(var(--radius-sm) + 4px);
  border: 1px solid rgba(85,255,204,.22);
  background:
    radial-gradient(circle at top right, rgba(85,255,204,.16), transparent 38%),
    linear-gradient(135deg, rgba(7,18,18,.92), rgba(5,10,10,.74));
  box-shadow:
    inset 0 0 0 1px rgba(85,255,204,.06),
    0 0 24px rgba(85,255,204,.08);
  display: grid;
  justify-items: end;
  text-align: right;
  gap: 4px;
  position: relative;
  overflow: hidden;
}
.daypart-header-meta::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0 8%, rgba(85,255,204,.07) 8% 9%, transparent 9% 100%),
    linear-gradient(180deg, rgba(85,255,204,.02), transparent 30%);
  pointer-events: none;
}
.daypart-header-time,
.daypart-header-date,
.daypart-header-label,
.daypart-header-range {
  position: relative;
  z-index: 1;
}
.daypart-header-time {
  color: var(--cyan);
  font-size: clamp(2rem, 4vw, 2.8rem);
  font-weight: 950;
  letter-spacing: .12em;
  line-height: .95;
  text-shadow: 0 0 18px rgba(85,255,204,.24);
  font-variant-numeric: tabular-nums;
}
.daypart-header-date {
  color: rgba(230,255,250,.9);
  font-size: .9rem;
  text-transform: capitalize;
  letter-spacing: .04em;
}
.daypart-header-label {
  color: var(--green);
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .76rem;
  margin-top: 4px;
}
.daypart-header-range {
  color: var(--muted);
  font-size: .8rem;
  line-height: 1.35;
}

.daypart-block {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}
.daypart-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  padding: 0 2px;
}
.daypart-title strong {
  color: var(--cyan);
  font-size: 1.02rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.daypart-title span {
  color: var(--muted);
  font-size: .86rem;
}
.tomorrow-card-head em {
  display: inline-flex;
  margin-top: 5px;
  padding: 2px 8px;
  border: 1px solid rgba(85,255,204,.15);
  border-radius: 999px;
  color: var(--cyan);
  background: rgba(85,255,204,.055);
  font-style: normal;
  font-size: .72rem;
}


.daypart-list .tomorrow-card {
  min-height: 218px;
}
.daypart-list .tomorrow-temp {
  font-size: 2rem;
}
.daypart-list .tomorrow-meta {
  font-size: .84rem;
}

.tomorrow-card {
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: linear-gradient(180deg, rgba(85,255,204,.07), rgba(0,0,0,.18));
  padding: 15px;
  display: grid;
  gap: 9px;
  min-height: 230px;
}
.tomorrow-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.tomorrow-card-head span,
.tomorrow-card-head time {
  display: block;
  color: var(--muted);
  font-size: .88rem;
}
.tomorrow-card-head b {
  font-size: 2.1rem;
  filter: drop-shadow(0 0 14px rgba(85,255,204,.3));
}
.tomorrow-card > strong {
  color: var(--text);
  font-size: 1.05rem;
}
.tomorrow-temp {
  color: var(--cyan);
  font-size: 2.25rem;
  font-weight: 950;
  letter-spacing: -.05em;
}
.tomorrow-meta {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: .9rem;
}
.map-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}
.weather-map-canvas {
  min-height: 430px;
  width: 100%;
  border: 1px solid rgba(85,255,204,.18);
  border-radius: var(--radius-sm);
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 50%, rgba(85,255,204,.12), transparent 16rem),
    rgba(0,0,0,.28);
  box-shadow: inset 0 0 0 1px rgba(156,255,79,.06), 0 0 28px rgba(85,255,204,.06);
}
.weather-map-status {
  margin: 10px 0 0;
  color: var(--cyan);
  font-size: .9rem;
  line-height: 1.4;
}

.radar-timeline {
  margin: 10px 0 0;
  display: grid;
  grid-template-columns: auto auto auto minmax(220px, 1fr);
  gap: 8px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(0,0,0,.34), rgba(85,255,204,.05));
}
.radar-slider-wrap {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: .84rem;
}
.radar-slider-wrap span {
  color: var(--cyan);
  font-weight: 800;
  letter-spacing: .01em;
}
.radar-slider-wrap input[type="range"] {
  width: 100%;
  accent-color: var(--cyan);
}
.radar-timeline .jarvis-btn[disabled],
.radar-slider-wrap input[disabled] {
  opacity: .45;
  cursor: not-allowed;
}


.radar-window-note {
  margin: 8px 0 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 12px;
  padding: 10px 12px;
  border: 1px solid rgba(156,255,79,.16);
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(156,255,79,.08), rgba(85,255,204,.04));
  color: var(--muted);
  font-size: .84rem;
  line-height: 1.45;
}
.radar-window-note strong {
  color: var(--lime);
  letter-spacing: .02em;
  text-transform: uppercase;
}

.radar-legend {
  margin: 10px 0 0;
  padding: 12px;
  border: 1px solid rgba(85,255,204,.16);
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, rgba(0,0,0,.30), rgba(85,255,204,.055));
  display: grid;
  gap: 8px;
}
.radar-legend-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: baseline;
  flex-wrap: wrap;
}
.radar-legend-head strong {
  color: var(--cyan);
  font-size: .95rem;
  letter-spacing: .02em;
}
.radar-legend-head span,
.radar-legend p {
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.45;
}
.radar-legend p {
  margin: 0;
}
.radar-legend-scale {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
}
.radar-legend-scale span {
  min-height: 13px;
  border-radius: 999px;
  background: var(--legend-color);
  box-shadow: 0 0 12px color-mix(in srgb, var(--legend-color), transparent 45%);
  border: 1px solid rgba(255,255,255,.22);
}
.radar-legend-labels {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
  color: var(--muted);
  font-size: .74rem;
  text-align: center;
}
.weather-map-canvas .leaflet-control-attribution,
.weather-map-canvas .leaflet-control-zoom a {
  background: rgba(3,19,15,.88);
  color: var(--text);
  border-color: rgba(85,255,204,.24);
}
.weather-map-canvas .leaflet-popup-content-wrapper,
.weather-map-canvas .leaflet-popup-tip {
  background: rgba(3,19,15,.96);
  color: var(--text);
  border: 1px solid rgba(85,255,204,.25);
  box-shadow: 0 0 24px rgba(85,255,204,.18);
}

.weather-map-canvas .leaflet-tile-pane .leaflet-layer:not(.rainviewer-tiles) {
  filter: none;
}
.weather-map-canvas .rainviewer-tiles {
  filter: contrast(1.45) saturate(1.8) brightness(1.08);
}
.weather-map-canvas .rainviewer-tiles img,
.weather-map-canvas .rainviewer-tiles .leaflet-tile {
  filter: contrast(1.45) saturate(1.8) brightness(1.08);
}
