:root{
  --bg:#eef1f6;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --brand:#2f3c63;
  --shadow:0 6px 22px rgba(17,24,39,.08);
  --radius:16px;
  --line:rgba(17,24,39,.08);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--text)}
a{color:inherit;text-decoration:none}

.header{
  background:var(--brand);
  color:#fff;
  padding:26px 18px 18px;
  text-align:center;
}
.header h1{margin:0;font-size:40px;letter-spacing:.2px}
.header .sub{margin-top:6px;opacity:.9}

.nav{
  margin-top:14px;
  display:flex;
  justify-content:center;
  gap:10px;
  flex-wrap:wrap;
}
.navbtn{
  display:inline-block;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.16);
  color:#fff;
  font-weight:600;
  font-size:13px;
  border:1px solid rgba(255,255,255,.16);
}
.navbtn.active{
  background:rgba(255,255,255,.28);
  border-color:rgba(255,255,255,.28);
}

.container{max-width:1100px;margin:18px auto 60px;padding:0 14px}

.grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
}
@media (max-width:980px){ .grid{grid-template-columns:repeat(2,1fr)} }
@media (max-width:640px){ .grid{grid-template-columns:1fr} }

.card{
  background:var(--card);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px 16px;
  position:relative;
}
.card.wide{margin-top:14px}
.cardtitle{font-weight:800;margin-bottom:10px}
.big{font-size:44px;font-weight:900;line-height:1.05;margin-bottom:10px}
.kv{
  display:grid;
  grid-template-columns:1fr auto;
  gap:6px 10px;
  font-size:13px;
  color:var(--muted);
}
.kv div:nth-child(2n){color:var(--text);font-weight:700}

.chartwrap{width:100%;height:320px}

/* ===== Windrose: oben rechts (statt unten rechts) ===== */
.windrosewrap{
  position:absolute;
  right:14px;
  top:14px;
  width:74px;
  height:74px;
  opacity:.65;
}
#windrose{width:74px;height:74px;transform-origin:50% 50%}

/* ===== UV Balken: farbige Skala + Marker (Design bleibt gleich, nur "reicher") ===== */
.uvbar{
  width:100%;
  height:10px;
  border-radius:999px;
  overflow:hidden;
  margin:8px 0 10px;
  background:rgba(17,24,39,.08);
}
#uvfill{
  height:100%;
  width:0%;
  background:rgba(17,24,39,.25);
}

/* UV-Skala (wie in Luft & UV) – hier als Hintergrund, uvfill bleibt vorhanden */
.uvbar.uvscale{
  position:relative;
  height:12px;
  background:
    linear-gradient(90deg,
      #22c55e 0% 20%,
      #facc15 20% 50%,
      #fb923c 50% 65%,
      #ef4444 65% 90%,
      #a855f7 90% 100%
    );
  box-shadow: inset 0 0 0 1px rgba(17,24,39,.10);
}
.uvbar.uvscale #uvfill{
  background:rgba(255,255,255,.22); /* ganz subtiler "fill", stört nicht */
}

/* Marker für UV */
.uvmarker{
  position:absolute;
  top:-6px;
  width:0;
  height:24px;
  left:0%;
  transform:translateX(-50%);
  pointer-events:none;
}
.uvmarker:before{
  content:"";
  position:absolute;
  top:0;
  left:-1px;
  width:2px;
  height:24px;
  background:rgba(17,24,39,.65);
  border-radius:2px;
}
.uvmarker:after{
  content:"";
  position:absolute;
  top:-2px;
  left:-6px;
  width:12px;
  height:12px;
  background:#fff;
  border:2px solid rgba(17,24,39,.55);
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}

/* ===== Luftfeuchtigkeit Komfortbalken (30–60% angenehm) ===== */
.humbar{
  position:relative;
  height:12px;
  border-radius:999px;
  overflow:hidden;
  margin:6px 0 12px;
  background:
    linear-gradient(90deg,
      #fb923c 0% 30%,     /* zu trocken */
      #22c55e 30% 60%,    /* komfort */
      #facc15 60% 70%,    /* eher feucht */
      #ef4444 70% 100%    /* sehr feucht */
    );
  box-shadow: inset 0 0 0 1px rgba(17,24,39,.10);
}
.hummarker{
  position:absolute;
  top:-6px;
  width:0;
  height:24px;
  left:0%;
  transform:translateX(-50%);
  pointer-events:none;
}
.hummarker:before{
  content:"";
  position:absolute;
  top:0;
  left:-1px;
  width:2px;
  height:24px;
  background:rgba(17,24,39,.65);
  border-radius:2px;
}
.hummarker:after{
  content:"";
  position:absolute;
  top:-2px;
  left:-6px;
  width:12px;
  height:12px;
  background:#fff;
  border:2px solid rgba(17,24,39,.55);
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}

/* ===== Tabellen-Seiten (Heute/Monat/Jahr/AllTime) ===== */
.pagewrap{max-width:1100px;margin:18px auto 60px;padding:0 14px}
.pagetitle{font-size:22px;font-weight:900;margin:8px 0 14px;text-align:center}

.tablecard{padding:0}
.tablehead{
  padding:14px 16px;
  font-weight:900;
  border-bottom:1px solid var(--line);
}
.tablewrap{overflow:auto}
table{
  width:100%;
  border-collapse:collapse;
  font-size:14px;
}
th,td{padding:10px 12px;border-bottom:1px solid var(--line);text-align:left;white-space:nowrap}
th{color:var(--muted);font-weight:800;background:rgba(17,24,39,.02)}
td.num{text-align:right;font-variant-numeric:tabular-nums}
td.small{color:var(--muted);font-size:12px}
.section{margin-top:14px}
/* ===== Live: kleiner Untertitel im Luftfeuchtigkeit-Block ===== */
.subhead{
  margin-top:6px;
  margin-bottom:6px;
  font-weight:900;
  color:var(--text);
}

/* ===== Live: EU/EEA AQI Balken (wie Luft & UV), innerhalb kv als Vollbreite ===== */
.kv .kvfull{
  grid-column: 1 / -1;
}

/* EU/EEA Skala für PM2.5 NowCast */
.aqbar{
  position:relative;
  height:12px;
  border-radius:999px;
  overflow:hidden;
  background:
    linear-gradient(90deg,
      #3b82f6 0% 10%,   /* Sehr gut */
      #22c55e 10% 20%,  /* Gut */
      #facc15 20% 25%,  /* Mässig */
      #fb923c 25% 50%,  /* Schlecht */
      #ef4444 50% 75%,  /* Sehr schlecht */
      #a855f7 75% 100%  /* Extrem */
    );
  box-shadow: inset 0 0 0 1px rgba(17,24,39,.10);
  margin:8px 0 2px;
}

.aqmarker{
  position:absolute;
  top:-6px;
  width:0;
  height:24px;
  left:0%;
  transform:translateX(-50%);
  pointer-events:none;
}
.aqmarker:before{
  content:"";
  position:absolute;
  top:0;
  left:-1px;
  width:2px;
  height:24px;
  background:rgba(17,24,39,.65);
  border-radius:2px;
}
.aqmarker:after{
  content:"";
  position:absolute;
  top:-2px;
  left:-6px;
  width:12px;
  height:12px;
  background:#fff;
  border:2px solid rgba(17,24,39,.55);
  border-radius:999px;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
}
.big-heute{
  font-size:13px;
  font-weight:700;
  color:var(--muted);
  margin-left:2px;
}
/* ===== 24h Tabellen: Header-Spalten exakt wie Body ausrichten ===== */
th.num{ text-align:right; font-variant-numeric:tabular-nums; }
th.small{ text-align:left; font-size:12px; color:var(--muted); }
td.small{ font-size:12px; color:var(--muted); }