:root{--blue:#0b3d5c;--blue2:#176b9b;--light:#f3f7fb;--orange:#f36f21;--amber:#f39c12;--red:#c0392b;--green:#0a7d4f;--text:#102330;--muted:#607080;--line:#e3ebf2}*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:var(--light);color:var(--text)}a{color:var(--blue);text-decoration:none}.top{background:rgba(255,255,255,.96);box-shadow:0 3px 18px #0001;position:sticky;top:0;z-index:10;display:flex;align-items:center;justify-content:space-between;gap:22px;padding:12px 28px;backdrop-filter:blur(10px)}.brand-logo{display:flex;align-items:center;min-width:280px}.site-logo{display:block;width:min(520px,42vw);height:auto}.brand small{display:block;color:#657}.logo{background:var(--blue);color:#fff;border-radius:14px;padding:10px}nav{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:flex-end}nav a{font-weight:650}.container{max-width:1180px;margin:28px auto;padding:0 18px}.hero{background:linear-gradient(135deg,#0b3d5c,#176b9b);color:white;padding:56px;border-radius:28px;box-shadow:0 20px 50px #0b3d5c33;position:relative;overflow:hidden}.hero:after{content:"";position:absolute;right:-120px;bottom:-120px;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(243,111,33,.38),transparent 65%)}.hero h1{font-size:clamp(2rem,5vw,4rem);margin:.1em 0}.hero p{max-width:780px}.kicker{text-transform:uppercase;letter-spacing:.12em;color:#cfefff;font-weight:800}.btn,button{background:var(--blue);color:white;border:0;border-radius:12px;padding:12px 18px;font-weight:800;cursor:pointer;display:inline-block;box-shadow:0 8px 18px rgba(11,61,92,.14)}.btn:hover,button:hover{filter:brightness(1.05)}.btn.small{padding:8px 12px}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:18px}.cards{margin-top:22px}.card{background:white;border-radius:22px;padding:24px;box-shadow:0 12px 35px #00000012;margin:16px 0;border:1px solid rgba(227,235,242,.75)}.warn{padding:22px;border-radius:20px;margin:18px 0;color:white;box-shadow:0 18px 45px #0002}.warn.orange{background:linear-gradient(135deg,var(--amber),#f06c00)}.warn.red{background:linear-gradient(135deg,var(--red),#7f1d1d)}.warn.green{background:linear-gradient(135deg,var(--green),#075f3c)}.ok{background:#e7f6ef;color:var(--green);padding:18px;border-radius:16px;margin:18px 0}.form{display:grid;gap:14px;max-width:760px}.form input,.form textarea,.form select,input,textarea,select{width:100%;padding:12px;border:1px solid #ccd6df;border-radius:12px;background:#fff}.check{display:block;margin:8px 0}.check input{width:auto}.table{overflow:auto;background:white;border-radius:18px;box-shadow:0 12px 35px #00000012}table{width:100%;border-collapse:collapse}th,td{padding:12px 14px;border-bottom:1px solid #e8eef4;text-align:left;vertical-align:top}th{background:#f8fafc}.pill{padding:5px 9px;border-radius:999px;color:white;white-space:nowrap}.pill.storm{background:var(--red)}.pill.strong_wind{background:var(--amber)}.flash{max-width:1180px;margin:18px auto;background:#fff7df;border-left:6px solid var(--amber);padding:14px;border-radius:12px}.adminnav{background:white;padding:12px;border-radius:18px;margin-bottom:18px;box-shadow:0 8px 25px #0001;display:flex;gap:12px;flex-wrap:wrap}.adminnav a{font-weight:700}.big{display:block;font-size:2.4rem;font-weight:900;margin-top:10px}#map{height:620px;border-radius:22px;box-shadow:0 12px 35px #0002}.hint{color:var(--muted);font-size:.95rem}footer{padding:32px;text-align:center;color:var(--muted)}.footer-icon{width:56px;height:56px;object-fit:contain;opacity:.92}#cookie{position:fixed;right:18px;bottom:18px;background:white;border-radius:18px;padding:18px;max-width:360px;box-shadow:0 20px 70px #0003;z-index:20}.logo-panel{background:white;border-radius:22px;padding:18px;box-shadow:0 12px 35px #00000012;margin:18px 0}.logo-panel img{max-width:100%;height:auto;display:block}@media(max-width:980px){.top{display:block}.site-logo{width:min(620px,100%)}nav{margin-top:12px;justify-content:flex-start}}@media(max-width:780px){.top{padding:12px 16px}.hero{padding:28px}.container{margin:18px auto}.site-logo{width:100%}nav{gap:10px}nav a{font-size:.95rem}#map{height:460px}}
.grid.two{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.legal h2{margin-top:1.5rem}.legal p{line-height:1.65}.form label .hint{display:block;margin:.25rem 0 .35rem}.form section.card{max-width:none}.adminnav{position:relative}.adminnav a[href$="einstellungen.php"],.adminnav a[href$="templates.php"]{background:#eef6fb;border-radius:10px;padding:8px 10px}.danger{background:#8b1d1d}.success{background:#0a7d4f}

.official-lra-links{margin-top:1.5rem}
.info-link{display:block;border:1px solid #d8e2ea;border-radius:16px;padding:1rem;background:#fff;text-decoration:none;color:#123;box-shadow:0 8px 20px rgba(11,61,92,.08)}
.info-link:hover{transform:translateY(-1px);box-shadow:0 12px 28px rgba(11,61,92,.14)}
.badge{display:inline-block;border-radius:999px;padding:.28rem .55rem;font-weight:800;font-size:.85rem}.badge.ok{background:#e7f6ef;color:var(--green);padding:.28rem .55rem;margin:0}.badge.warn{background:#fff0d7;color:#9b5200;padding:.28rem .55rem;margin:0}.small{font-size:.9rem}.muted{color:var(--muted)}.btn.secondary{background:#eef6fb;color:var(--blue);box-shadow:none}.btn.danger,button.danger{background:#8b1d1d}.admin-grid-form fieldset{border:1px solid var(--line);border-radius:16px;padding:16px;margin:0}.admin-grid-form legend{font-weight:900;color:var(--blue);padding:0 .35rem}.form-actions{margin-top:.5rem}.danger-zone{border-color:#f0caca;background:#fffafa}.actions .btn{margin:0}

.kicker.dark{color:var(--blue);}
.lake-overview-intro{margin-top:24px;}
.lake-status-grid{align-items:stretch;}
.lake-status-card{background:#fff;border-radius:22px;padding:24px;box-shadow:0 12px 35px #00000012;margin:0;border:1px solid var(--line);position:relative;overflow:hidden;}
.lake-status-card:before{content:"";position:absolute;inset:0 0 auto 0;height:8px;background:#ccd6df;}
.lake-status-card.red:before{background:linear-gradient(90deg,var(--red),#7f1d1d);}
.lake-status-card.orange:before{background:linear-gradient(90deg,var(--amber),#f06c00);}
.lake-status-card.green:before{background:linear-gradient(90deg,var(--green),#075f3c);}
.lake-status-card.neutral:before{background:linear-gradient(90deg,#8aa1b3,#ccd6df);}
.lake-status-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start;margin-bottom:12px;}
.lake-status-head h3{margin:.1rem 0 0;font-size:1.45rem;}
.status-badge{display:inline-flex;align-items:center;border-radius:999px;padding:.42rem .7rem;font-weight:900;font-size:.9rem;color:#fff;white-space:nowrap;}
.status-badge.red{background:var(--red);}.status-badge.orange{background:var(--amber);}.status-badge.green{background:var(--green);}.status-badge.neutral{background:#607080;}
.lake-facts{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:16px 0;}
.lake-facts span{display:block;border:1px solid var(--line);border-radius:14px;background:#f8fafc;padding:12px;}
.lake-facts strong{display:block;color:var(--blue);font-size:.9rem;margin-bottom:4px;}
@media(max-width:640px){.lake-status-head{display:block}.status-badge{margin-top:10px}.lake-facts{grid-template-columns:1fr}}
.alert{border-radius:16px;padding:16px 18px;margin:16px 0;border:1px solid var(--line);background:#fff}.alert-error{border-color:#f1c6c0;background:#fff5f3;color:#7a1b12}.alert ul{margin:.5rem 0 0 1.2rem}.form-grid.two{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.fieldset{border:1px solid var(--line);border-radius:16px;padding:16px;margin:4px 0}.fieldset legend{font-weight:900;color:var(--blue);padding:0 .4rem}.form small{display:block;margin-top:5px;color:var(--muted)}.privacy-check{display:flex;align-items:flex-start;gap:10px;line-height:1.45;background:#f8fbfd;border:1px solid var(--line);border-radius:16px;padding:14px}.privacy-check input{margin-top:4px;flex:0 0 auto}@media(max-width:720px){.form-grid.two{grid-template-columns:1fr}}


.password-section{display:grid;gap:14px}.password-rules{border:1px solid var(--line);background:#f8fbfd;border-radius:16px;padding:14px 16px}.password-rules strong{display:block;color:var(--blue);margin-bottom:8px}.password-rules ul{list-style:none;margin:0;padding:0;display:grid;gap:7px}.password-rules li{position:relative;padding-left:28px;color:#8b1d1d;font-weight:650}.password-rules li:before{content:"✕";position:absolute;left:0;top:0;width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:#fff0f0;color:#8b1d1d;font-size:.8rem}.password-rules li.ok{color:var(--green)}.password-rules li.ok:before{content:"✓";background:#e7f6ef;color:var(--green)}.password-rules li.missing{color:#8b1d1d}

.required{color:#b42318;font-weight:700}.password-rules li.ok{color:#166534}.password-rules li.ok::before{content:"✓ ";font-weight:700}.password-rules li.missing{color:#7c2d12}.password-rules li.missing::before{content:"• ";}.registration-alert ul{margin:.5rem 0 0 1.2rem}.card-soft{background:#f8fbfd;border:1px solid #dbe7ef;border-radius:18px;padding:18px;margin:18px 0}
/* Version 1.0.11: Sturmwarn-Informationen zeigt nur Behördenlinks */
.official-links-only .official-link-card { min-height: 260px; }
.official-link-card .btn { margin-top: 10px; }

.footer-sources{font-size:.95rem;margin-top:8px}.footer-sources a{font-weight:700}
/* Version 1.0.11: Footer-Links für Datenquellen DWD und HND Bayern */

#cookie[hidden]{display:none}.footer-sources a,#open-cookie-settings{font-weight:700}.legal ul{line-height:1.65}.legal li{margin:.35rem 0}

/* Version 1.0.15: bessere Anzeige für automatisch abgerufene Messdaten */
.lake-measurement-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:0 0 16px}
.lake-measurement-meta span{display:block;border:1px solid var(--line);border-radius:14px;background:#fff;padding:10px 12px;font-size:.92rem;color:var(--text)}
.lake-measurement-meta strong{display:block;color:var(--blue);font-size:.85rem;margin-bottom:4px}
.measurements-table small{color:var(--muted)}
.badge.warn{background:#fff3cd;color:#7a4c00}.badge.ok{background:#e7f6ef;color:#075f3c}
@media(max-width:640px){.lake-measurement-meta{grid-template-columns:1fr}}

/* Version 1.0.20: Monitor-/Vollbildkarte */
.monitor-body{margin:0;background:#061a28;color:#fff;overflow:hidden;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.monitor-shell{height:100vh;width:100vw;display:grid;grid-template-rows:auto 1fr;background:#061a28}.monitor-banner{position:relative;z-index:900;padding:18px 26px 14px;box-shadow:0 10px 35px rgba(0,0,0,.35);border-bottom:1px solid rgba(255,255,255,.18)}.monitor-banner.red{background:linear-gradient(135deg,#7f1d1d,#c0392b)}.monitor-banner.orange{background:linear-gradient(135deg,#9b5200,#f39c12)}.monitor-banner.green{background:linear-gradient(135deg,#075f3c,#0a7d4f)}.monitor-banner.blue{background:linear-gradient(135deg,#0b3d5c,#176b9b)}.monitor-banner-main{display:flex;align-items:center;justify-content:space-between;gap:28px}.monitor-kicker{margin:0 0 3px;text-transform:uppercase;letter-spacing:.16em;font-size:.9rem;font-weight:900;opacity:.86}.monitor-banner h1{font-size:clamp(2.2rem,5vw,5rem);line-height:.95;margin:0;font-weight:950}.monitor-banner p{margin:.35rem 0 0;font-size:clamp(1rem,1.5vw,1.55rem);font-weight:700}.monitor-clock{text-align:right;min-width:230px}.monitor-clock span{display:block;font-size:clamp(2rem,4vw,4.2rem);line-height:1;font-weight:950;font-variant-numeric:tabular-nums}.monitor-clock small{display:block;margin-top:6px;opacity:.82;font-weight:750}.monitor-warning-ticker{display:flex;gap:10px;overflow:hidden;margin-top:12px;white-space:nowrap}.ticker-item{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:8px 13px;background:rgba(255,255,255,.18);font-size:1rem;font-weight:800}.ticker-item.red{background:rgba(255,255,255,.22)}.ticker-item.orange{background:rgba(255,255,255,.22)}.ticker-item.green{background:rgba(255,255,255,.20)}.ticker-item.blue{background:rgba(255,255,255,.18)}.monitor-map-wrap{position:relative;min-height:0}.monitor-map-wrap #monitor-map{position:absolute;inset:0;height:100%;width:100%;border-radius:0;box-shadow:none}.monitor-legend{position:absolute;left:22px;bottom:22px;z-index:800;background:rgba(255,255,255,.94);color:#102330;border-radius:18px;padding:14px 16px;display:flex;flex-direction:column;gap:9px;box-shadow:0 12px 35px rgba(0,0,0,.25);font-weight:850;max-width:min(720px,calc(100vw - 44px))}.monitor-legend-items{display:flex;gap:14px;flex-wrap:wrap}.monitor-legend-disclaimer{border-top:1px solid rgba(16,35,48,.18);padding-top:8px;font-size:.82rem;line-height:1.35;color:#30475a;font-weight:800}.monitor-help{position:absolute;right:22px;bottom:22px;z-index:800;background:rgba(6,26,40,.76);color:#fff;border:1px solid rgba(255,255,255,.18);border-radius:14px;padding:10px 13px;font-weight:750}.legend-dot{display:inline-block;width:13px;height:13px;border-radius:50%;margin-right:6px;vertical-align:-1px}.legend-dot.red{background:#c0392b}.legend-dot.orange{background:#f39c12}.legend-dot.green{background:#0a7d4f}.legend-dot.blue{background:#176b9b}.warning-light-marker,.monitor-light-marker{position:relative;display:block;width:34px;height:46px;filter:drop-shadow(0 8px 10px rgba(0,0,0,.22))}.monitor-light-marker{width:54px;height:70px}.warning-light-marker .lamp-head,.monitor-light-marker .lamp-head{position:absolute;left:50%;transform:translateX(-50%);top:3px;width:24px;height:28px;border-radius:9px 9px 5px 5px;background:var(--marker-color);border:3px solid #fff;box-shadow:0 0 0 3px rgba(0,0,0,.12),0 0 20px var(--marker-color)}.monitor-light-marker .lamp-head{width:38px;height:44px;border-radius:13px 13px 7px 7px;border-width:4px;box-shadow:0 0 0 4px rgba(0,0,0,.14),0 0 34px var(--marker-color)}.warning-light-marker .lamp-base,.monitor-light-marker .lamp-base{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:30px;height:13px;background:#263746;border-radius:4px}.monitor-light-marker .lamp-base{width:48px;height:18px;border-radius:6px}.warning-light-marker.active .lamp-head,.monitor-light-marker.active .lamp-head{animation:warningPulse 1.15s ease-in-out infinite}.monitor-light-marker .beam{position:absolute;left:50%;top:-5px;transform:translateX(-50%);width:58px;height:58px;border-radius:50%;background:radial-gradient(circle, color-mix(in srgb, var(--marker-color) 58%, transparent), transparent 68%);opacity:.62;animation:warningPulse 1.15s ease-in-out infinite}@keyframes warningPulse{0%,100%{opacity:.82;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.08)}}.popup-status.red{color:#c0392b;font-weight:900}.popup-status.orange{color:#9b5200;font-weight:900}.popup-status.green{color:#0a7d4f;font-weight:900}.popup-status.blue{color:#176b9b;font-weight:900}@media(max-width:900px){.monitor-banner-main{align-items:flex-start}.monitor-clock{min-width:150px}.monitor-legend{font-size:.9rem}.monitor-help{display:none}}

.privacy-inline-link{font-weight:800;text-decoration:underline;text-underline-offset:3px}.privacy-direct-note{margin:-8px 0 16px 42px;font-size:.95rem}.privacy-direct-note a{font-weight:700}


/* Version 1.0.25: öffentlicher Hinweis keine offizielle Warneinrichtung */
.public-disclaimer{max-width:1180px;margin:18px auto 0;padding:14px 18px;border-radius:16px;border:1px solid #f1c96f;background:#fff8df;color:#5d3b00;box-shadow:0 8px 24px rgba(93,59,0,.08);font-size:.97rem;line-height:1.45}
.public-disclaimer strong{color:#7a4c00}
.monitor-disclaimer{position:fixed;left:18px;top:10px;z-index:1200;background:rgba(255,255,255,.92);color:#102330;border:1px solid rgba(255,255,255,.45);border-radius:999px;padding:7px 13px;font-size:.86rem;font-weight:800;box-shadow:0 8px 24px rgba(0,0,0,.18);max-width:calc(100vw - 36px);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
@media(max-width:780px){.public-disclaimer{margin:12px 16px 0}.monitor-disclaimer{font-size:.72rem;left:8px;right:8px;max-width:none;text-align:center}}


/* Version 1.0.30: Monitor-Hinweis unter Farblegende */
.footer-warning{max-width:980px;margin:0 auto 12px;padding:12px 16px;border-radius:14px;border:1px solid #f1c96f;background:#fff8df;color:#5d3b00;line-height:1.45}
.footer-warning strong{color:#7a4c00}.leaflet-control-layers{border-radius:12px!important;box-shadow:0 8px 24px rgba(0,0,0,.18)!important}.warning-light-marker{width:24px;height:34px}.warning-light-marker .lamp-head{width:17px;height:21px;border-width:2px;border-radius:7px 7px 4px 4px;box-shadow:0 0 0 2px rgba(0,0,0,.12),0 0 14px var(--marker-color)}.warning-light-marker .lamp-base{width:22px;height:9px;border-radius:3px}.monitor-light-marker{width:38px;height:50px}.monitor-light-marker .lamp-head{width:27px;height:33px;border-width:3px;border-radius:10px 10px 6px 6px;box-shadow:0 0 0 3px rgba(0,0,0,.14),0 0 24px var(--marker-color)}.monitor-light-marker .lamp-base{width:34px;height:13px;border-radius:5px}.monitor-light-marker .beam{width:42px;height:42px;top:-3px}.monitor-disclaimer-footer{top:auto;bottom:10px;left:50%;right:auto;transform:translateX(-50%);max-width:calc(100vw - 36px)}.monitor-clock small#monitor-date{font-size:1rem;opacity:.9;margin-top:8px}
@media(max-width:780px){.footer-warning{margin-left:8px;margin-right:8px}.monitor-disclaimer-footer{left:8px;right:8px;transform:none}}

/* Admin log filters and pagination */
.admin-filter-form input[type="search"], .admin-filter-form input[type="date"], .admin-filter-form select { width:100%; }
.badge { display:inline-block; padding:.18rem .45rem; border-radius:999px; font-size:.78rem; font-weight:700; background:#e5e7eb; color:#111827; }
.badge-error { background:#fee2e2; color:#991b1b; }
.badge-warning, .badge-warn { background:#fef3c7; color:#92400e; }
.badge-info { background:#dbeafe; color:#1e40af; }
.badge-success, .badge-ok { background:#dcfce7; color:#166534; }
.pagination .btn { padding:.45rem .65rem; }


/* Version 1.0.0: Admin Auto-Logout oben rechts mit Zeitlinie */
.admin-session-timeout{position:fixed;right:18px;top:86px;z-index:1200;width:min(310px,calc(100vw - 36px));background:rgba(255,255,255,.96);border:1px solid rgba(11,61,92,.12);border-radius:18px;padding:12px 14px;box-shadow:0 16px 45px rgba(11,61,92,.18);backdrop-filter:blur(10px)}
.admin-session-timeout-row{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:8px}.admin-session-timeout-label{font-weight:900;color:var(--blue);font-size:.92rem}.admin-session-countdown{font-variant-numeric:tabular-nums;font-size:1.18rem;color:#102330}.admin-session-progress{height:8px;border-radius:999px;background:#e7eef5;overflow:hidden}.admin-session-progress span{display:block;height:100%;width:100%;border-radius:999px;background:linear-gradient(90deg,var(--green),var(--blue2));transition:width .35s linear,background .2s ease}.admin-session-deadline{display:block;margin-top:7px;color:var(--muted);font-weight:700}.admin-session-timeout.is-warning{border-color:#f39c12;background:#fff8e8}.admin-session-timeout.is-warning .admin-session-progress span{background:linear-gradient(90deg,#f39c12,#f36f21)}.admin-session-timeout.is-critical{border-color:#c0392b;background:#fff1f0}.admin-session-timeout.is-critical .admin-session-progress span{background:linear-gradient(90deg,#c0392b,#7f1d1d)}
@media(max-width:980px){.admin-session-timeout{top:auto;right:12px;bottom:12px;width:min(360px,calc(100vw - 24px))}}
.badge.error{background:#fee2e2;color:#991b1b;padding:.28rem .55rem;margin:0}


/* Version 1.0.0: Auto-Logout dezenter in der oberen Admin-Leiste */
.admin-topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;position:sticky;top:0;z-index:50;}
.admin-topbar-right{display:flex;align-items:center;justify-content:flex-end;gap:14px;min-width:0;}
.admin-topbar-right nav{margin:0;}
.admin-session-timeout.admin-session-timeout--topbar,
.admin-session-timeout{position:static!important;right:auto!important;top:auto!important;bottom:auto!important;z-index:auto!important;width:auto!important;min-width:112px;max-width:132px;background:transparent!important;border:0!important;border-radius:0!important;padding:0!important;box-shadow:none!important;backdrop-filter:none!important;color:var(--muted);align-self:center;}
.admin-session-timeout-main,.admin-session-timeout-row{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:5px!important;margin:0 0 3px 0!important;white-space:nowrap;line-height:1;}
.admin-session-timeout-label{font-size:.72rem!important;font-weight:650!important;color:#6b7f90!important;letter-spacing:.01em;}
.admin-session-countdown{font-size:.84rem!important;font-weight:800!important;color:#30475a!important;font-variant-numeric:tabular-nums;line-height:1;}
.admin-session-progress{height:2px!important;border-radius:999px!important;background:rgba(11,61,92,.12)!important;overflow:hidden!important;}
.admin-session-progress span{display:block;height:100%;width:100%;border-radius:999px;background:rgba(11,61,92,.42)!important;transition:width .35s linear,background .2s ease;}
.admin-session-deadline{display:none!important;}
.admin-session-timeout.is-warning{background:transparent!important;border:0!important;}
.admin-session-timeout.is-warning .admin-session-countdown{color:#9b5200!important;}
.admin-session-timeout.is-warning .admin-session-progress span{background:#d98500!important;}
.admin-session-timeout.is-critical{background:transparent!important;border:0!important;}
.admin-session-timeout.is-critical .admin-session-countdown{color:#a32020!important;}
.admin-session-timeout.is-critical .admin-session-progress span{background:#c0392b!important;}
@media(max-width:980px){.admin-topbar{display:block}.admin-topbar-right{margin-top:10px;display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-session-timeout.admin-session-timeout--topbar,.admin-session-timeout{min-width:92px;max-width:110px;flex:0 0 auto}.admin-session-timeout-label{display:none}.admin-session-countdown{font-size:.82rem!important}}
@media(max-width:640px){.admin-topbar-right{align-items:flex-start;flex-wrap:wrap}.admin-session-timeout.admin-session-timeout--topbar,.admin-session-timeout{order:2;margin-left:auto}.admin-topbar-right nav{order:1;width:100%;justify-content:flex-start}}

/* Version 1.0.0: Kennwort-Hinweise dezent, offen rot, erfüllt grün */
.password-rules-compact{background:#fff;border:1px solid #e6edf3;border-radius:14px;padding:10px 12px;box-shadow:none;margin-top:8px}
.password-rules-compact summary{cursor:pointer;color:#516171;font-weight:750;font-size:.92rem;list-style:none;display:flex;align-items:center;gap:8px}
.password-rules-compact summary::-webkit-details-marker{display:none}
.password-rules-compact summary:before{content:"i";display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#eef4f8;color:#516171;font-size:.74rem;font-weight:900}
.password-rules-compact ul{margin-top:10px;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:6px 12px}
.password-rules-compact li{color:#9f1d1d;font-weight:650;font-size:.9rem;line-height:1.35;padding-left:24px;transition:color .18s ease,opacity .18s ease}
.password-rules-compact li:before{content:"✕";width:16px;height:16px;background:#fff1f1;color:#9f1d1d;font-size:.66rem;font-weight:900;box-shadow:none}
.password-rules-compact li.missing{color:#9f1d1d;opacity:1}
.password-rules-compact li.missing:before{content:"✕";background:#fff1f1;color:#9f1d1d;font-weight:900}
.password-rules-compact li.ok{color:#167044;opacity:1;font-weight:750}
.password-rules-compact li.ok:before{content:"✓";background:#e7f6ef;color:#167044;font-weight:900}
.password-rules-compact.is-complete{border-color:#bfe7d1;background:#fbfffd}
.password-rules-compact.is-complete summary{color:#167044}
.password-rules-compact.is-complete summary:before{content:"✓";background:#e7f6ef;color:#167044}

/* Version 1.0.0: Benutzerkonto 2FA und Login-Historie */
.account-security-card .security-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:20px;align-items:start}.account-security-card h3{margin-top:0}.account-login-events .table-wrap{overflow:auto}.inline-form{margin-top:12px}.narrow{max-width:560px}@media(max-width:760px){.account-security-card .security-grid{grid-template-columns:1fr}}

/* Version 1.0.0: Einstellungen-Buttons sichtbar und robust */
.settings-tool-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-top:16px}
.settings-tool-button{display:block;padding:16px 18px;border:1px solid #d9e4ec;border-radius:16px;background:#fff;text-decoration:none;color:#102330;box-shadow:0 8px 24px rgba(11,61,92,.08);transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}
.settings-tool-button:hover,.settings-tool-button:focus{transform:translateY(-1px);box-shadow:0 12px 28px rgba(11,61,92,.14);border-color:#8eb8d4;outline:0}
.settings-tool-button strong{display:block;margin-bottom:6px;font-size:1.02rem;color:#0b3d5c}
.settings-tool-button span{display:block;color:#607281;font-size:.92rem;line-height:1.4}
.admin-settings-tools{margin-top:18px}.settings-tool-group+.settings-tool-group{margin-top:18px}


/* Benutzerkonto: dezente rot/grüne Schieber */
.toggle-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:.75rem;margin-top:.75rem}
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.8rem 1rem;border:1px solid #e5e7eb;border-radius:14px;background:#fff;font-weight:600}
.switch-row input{position:absolute;opacity:0;pointer-events:none}
.switch-ui{width:50px;height:26px;border-radius:999px;background:#dc2626;position:relative;flex:0 0 auto;box-shadow:inset 0 0 0 1px rgba(0,0,0,.08);transition:background .18s ease}
.switch-ui:before{content:"";position:absolute;width:20px;height:20px;left:3px;top:3px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(15,23,42,.25);transition:transform .18s ease}
.switch-row input:checked + .switch-ui{background:#16a34a}
.switch-row input:checked + .switch-ui:before{transform:translateX(24px)}
.switch-row:has(input:focus-visible){outline:3px solid rgba(37,99,235,.25);outline-offset:2px}
.security-status{border-radius:14px;padding:1rem;border:1px solid #bbf7d0;background:#f0fdf4;color:#14532d;display:grid;gap:.3rem}
.security-status strong{font-size:1.05rem}

/* Kundenkonto: kompakte Anmeldebox neben persönlichen Daten */
.account-top-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(280px,.85fr);gap:1.25rem;align-items:start;margin-bottom:1.25rem}
.account-personal-box,.account-login-summary-box{min-width:0}
.account-login-summary-box{border:1px solid #e5e7eb;border-radius:16px;background:#f8fafc;padding:1rem 1.1rem;box-shadow:0 6px 18px rgba(15,23,42,.04)}
.account-login-summary-box h2{margin-top:0;margin-bottom:.85rem;font-size:1.12rem}
.login-summary-list{display:grid;gap:.75rem}
.login-summary-item{border:1px solid #e5e7eb;border-radius:14px;background:#fff;padding:.85rem .9rem;display:grid;gap:.2rem}
.login-summary-label{font-size:.82rem;text-transform:uppercase;letter-spacing:.04em;color:#64748b;font-weight:700}
.login-summary-item strong{color:#0f172a;font-size:.98rem;line-height:1.35}
.login-summary-item small{color:#64748b;line-height:1.35}
.login-summary-item.has-warning{border-color:#fecaca;background:#fff7f7}
.login-summary-item.has-warning strong{color:#991b1b}
.login-summary-item.is-ok{border-color:#bbf7d0;background:#f7fef9}
.login-summary-item.is-ok strong{color:#166534}
.hint.compact{font-size:.86rem;margin:.8rem 0 0;color:#64748b}
@media(max-width:820px){.account-top-grid{grid-template-columns:1fr}.account-login-summary-box{order:2}}

/* Diagramme Messdaten */
.measurement-chart-card { margin-top: 1rem; }
.temperature-chart-card { margin-top: 1.25rem; }
.chart-header { display:flex; align-items:flex-start; justify-content:space-between; gap:1rem; flex-wrap:wrap; }
.chart-controls, .chart-lake-switch { display:flex; gap:.45rem; flex-wrap:wrap; align-items:center; }
.chart-lake-switch { margin:.75rem 0 .75rem; }
.chart-controls .btn, .chart-lake-switch .btn { border-radius:999px; }
.chart-controls .btn.active, .chart-lake-switch .btn.active { background:#0b6b3a; border-color:#0b6b3a; color:#fff; }
.chart-legend { display:flex; gap:1rem; flex-wrap:wrap; align-items:center; margin:0 0 .75rem; color:#475467; font-size:.92rem; }
.chart-legend span { display:inline-flex; align-items:center; gap:.35rem; }
.chart-legend-dot { width:.75rem; height:.75rem; border-radius:999px; display:inline-block; background:#0b6b3a; }
.chart-legend-dot.water-temperature { background:#0b6b3a; }
.chart-legend-dot.air-temperature { background:#c46a00; }
.chart-legend-dot.water-level { background:#0b6b3a; }
.measurement-chart-wrap { position:relative; min-height:320px; background:#f8fafc; border:1px solid #e5edf3; border-radius:18px; padding:.75rem; }
#water-level-chart, #temperature-chart { width:100%; display:block; cursor:crosshair; }
.chart-empty { position:absolute; inset:0; display:flex; align-items:center; justify-content:center; text-align:center; padding:1rem; }
.chart-meta { margin-top:.6rem; font-size:.92rem; }

.chart-tooltip { position:absolute; z-index:20; min-width:180px; max-width:260px; padding:.65rem .75rem; border-radius:14px; background:rgba(15,23,42,.94); color:#fff; box-shadow:0 16px 35px rgba(15,23,42,.22); pointer-events:none; font-size:.88rem; line-height:1.35; }
.chart-tooltip strong { display:block; color:#fff; }
.chart-tooltip small { display:block; margin:.1rem 0 .45rem; color:#cbd5e1; }
.chart-tooltip-row { display:flex; align-items:center; justify-content:space-between; gap:.85rem; border-top:1px solid rgba(255,255,255,.12); padding-top:.32rem; margin-top:.32rem; }
.chart-tooltip-row span { color:#e2e8f0; }
.chart-tooltip-row strong { color:#fff; white-space:nowrap; }
@media (max-width: 720px) {
  .chart-header { display:block; }
  .chart-controls { margin-top:.75rem; }
  .chart-controls .btn, .chart-lake-switch .btn { padding:.42rem .65rem; font-size:.86rem; }
}

/* Version 1.0.0: robuste Monitor-/Vollbildkarte-Links */
.monitor-open-actions{display:flex;flex-wrap:wrap;align-items:center;gap:10px;margin-top:14px}
.monitor-open-actions .btn{margin:0}.hint.small{font-size:.88rem;opacity:.82}.hint.small code{font-size:.86em;background:rgba(11,61,92,.08);padding:2px 5px;border-radius:6px}

/* Karten-/Header-Fix: öffentliche Karte bleibt unter dem sticky Header.
   Die Monitor-/Vollbildkarte ist davon ausgenommen und nutzt ihre eigene Standalone-Darstellung. */
.top{z-index:2000}
body:not(.monitor-body) #map{position:relative;z-index:0;isolation:isolate}
body:not(.monitor-body) .leaflet-container{z-index:0}




/* Version 1.0.0: Schnittstellen-Monitor */
.monitor-status-dot{display:inline-block;width:.75rem;height:.75rem;border-radius:999px;background:#94a3b8;margin-right:.35rem;vertical-align:-.05rem}.monitor-status-dot.up{background:#0b7a45}.monitor-status-dot.warn{background:#c46a00}.monitor-status-dot.down{background:#b42318}.monitor-status-dot.unknown{background:#94a3b8}.monitor-url{max-width:360px;word-break:break-all}.monitor-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}


/* Startseiten-Popup: Hinweis auf nicht-amtliche Warneinrichtung */
.home-disclaimer-popup[hidden]{display:none!important}
.home-disclaimer-popup{position:fixed;inset:0;z-index:4000;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(16,35,48,.58);backdrop-filter:blur(4px)}
.home-disclaimer-popup__box{position:relative;width:min(640px,100%);background:#fff;border-radius:24px;padding:28px;box-shadow:0 28px 90px rgba(0,0,0,.32);border:1px solid rgba(227,235,242,.95);line-height:1.55}
.home-disclaimer-popup__box h2{margin:.2rem 2.4rem .8rem 0;color:var(--blue)}
.home-disclaimer-popup__box p{margin:.5rem 0 0}.home-disclaimer-popup__box strong{color:#7a4c00}
.home-disclaimer-popup__close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:999px;padding:0;line-height:1;background:#eef6fb;color:var(--blue);box-shadow:none;font-size:1.35rem}
.home-disclaimer-popup__actions{display:flex;justify-content:flex-end;margin-top:20px}
@media(max-width:640px){.home-disclaimer-popup{padding:16px}.home-disclaimer-popup__box{padding:22px 18px}.home-disclaimer-popup__actions{justify-content:stretch}.home-disclaimer-popup__actions .btn{width:100%;text-align:center}}
