
:root{--bg:#071328;--panel:#0a1830;--panel2:#091a34;--border:rgba(255,255,255,.08);--muted:#9fb0c7;--text:#f4f7fb;--brand:#1f74ff;--danger:#8f2230;--amber:#8a6500;--green:#153f2d;--blue:#12335e}
*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text)}a{color:inherit;text-decoration:none}.muted{color:var(--muted)}
.portal-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}.sidebar{background:var(--panel2);border-right:1px solid var(--border);padding:20px;position:sticky;top:0;height:100vh;overflow:auto}.brand{display:flex;gap:14px;align-items:center;margin-bottom:18px}.brand img{width:68px;height:auto;filter:drop-shadow(0 4px 14px rgba(0,0,0,.35))}.brand h1{font-size:1.05rem;margin:0}.userbox{padding:14px;border-radius:16px;background:rgba(255,255,255,.04);margin-bottom:18px}.role{display:inline-block;margin-top:8px;padding:5px 10px;border-radius:999px;background:#143766;color:#cfe2ff;font-size:.78rem}.nav-btn{width:100%;text-align:left;border:1px solid rgba(255,255,255,.08);background:transparent;color:#eaf1fb;padding:12px 14px;border-radius:14px;margin-bottom:10px;cursor:pointer}.nav-btn.active,.nav-btn:hover{background:#12335e}.content{padding:24px}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:18px}.topbar h2{margin:0;font-size:1.5rem}.actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.lang-switcher{display:flex;gap:8px;align-items:center}.lang-btn{border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.03);color:#fff;padding:8px 10px;border-radius:12px;cursor:pointer;font-size:.92rem}.lang-btn.active{background:#143766}
.hero{display:flex;justify-content:space-between;gap:20px;align-items:center;flex-wrap:wrap;background:linear-gradient(135deg,#0f2d55,#0c1f3d);border:1px solid var(--border);border-radius:24px;padding:20px 22px;margin-bottom:16px;box-shadow:0 16px 40px rgba(0,0,0,.22)}.hero h3{margin:0 0 6px;font-size:1.35rem}.hero p{margin:0;color:#c8d5e6}.hero-stats{display:flex;gap:14px;flex-wrap:wrap}.hero-stats>div{min-width:150px;padding:14px 16px;border-radius:18px;background:rgba(255,255,255,.06)}.hero-stats strong{display:block;font-size:1.15rem;margin-bottom:4px}
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:16px}.card,.panel{background:var(--panel);border:1px solid var(--border);border-radius:24px;box-shadow:0 14px 32px rgba(0,0,0,.2)}.card{padding:18px}.card strong{display:block;font-size:2rem;margin-top:8px}.panel{padding:18px}.section{display:none}.section.active{display:block}.legend{display:flex;gap:16px;flex-wrap:wrap;margin-top:10px}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.base-dot{background:#ff5c5c}.rover-dot{background:#36b3ff}.rover-stale-dot{background:#8bc5ff}.grid-2{display:grid;grid-template-columns:1.1fr .9fr;gap:16px}#portalMap{min-height:520px;border-radius:18px;overflow:hidden}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.07);vertical-align:top;text-align:left}th{font-size:.82rem;color:#95abc4;text-transform:uppercase;letter-spacing:.04em}tbody tr:hover{background:rgba(255,255,255,.02)}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px}.toolbar label{font-size:.9rem;color:#d8e3f2}.toolbar select,.toolbar input{background:#081323;border:1px solid rgba(255,255,255,.1);color:#eef5ff;border-radius:12px;padding:10px 12px}
.btn{border:none;background:#153a67;color:#fff;padding:10px 14px;border-radius:12px;cursor:pointer}.btn.primary{background:var(--brand)}.btn.danger{background:var(--danger)}.btn.amber{background:var(--amber)}.btn.xs{padding:7px 10px;font-size:.82rem;border-radius:10px}.row-actions{display:flex;gap:8px;flex-wrap:wrap}.form-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}.form-grid .full{grid-column:1/-1}.form-grid input,.form-grid select{width:100%;background:#081323;border:1px solid rgba(255,255,255,.1);color:#eef5ff;border-radius:14px;padding:11px 12px}.form-actions{display:flex;gap:10px;flex-wrap:wrap}.toggle-inline{display:flex;align-items:center;gap:8px;padding:0 4px;color:#d8e3f2}.pill{display:inline-block;padding:5px 10px;border-radius:999px;font-size:.78rem;font-weight:600;background:#1b2a42;color:#d8e3f2}.pill.green{background:var(--green);color:#abf5c8}.pill.red{background:#4d1f26;color:#ffc2cb}.pill.blue{background:var(--blue);color:#b7d7ff}.pill.amber{background:#5d4717;color:#ffe39a}
.leaflet-div-icon{background:transparent!important;border:none!important}.marker{display:block}.marker div{width:100%;height:100%;border-radius:50%;border:2px solid rgba(255,255,255,.88);box-shadow:0 0 0 3px rgba(0,0,0,.18),0 0 18px rgba(0,0,0,.24)}.base-marker div{background:#ff5c5c}.rover-marker div{background:#36b3ff}.rover-stale-marker div{background:#8bc5ff}.notice{padding:12px 14px;border-radius:14px;background:rgba(255,95,95,.12);border:1px solid rgba(255,95,95,.35);color:#ffd4d4;margin-bottom:14px}
.login-shell{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top,#0d2950 0%,#071328 50%,#061124 100%);position:relative;overflow:hidden}.login-shell::before{content:'';position:absolute;inset:-10%;background:url('/static/rolavi-logo.png') center/65% no-repeat;opacity:.05;filter:grayscale(1);pointer-events:none}.login-topbar{position:absolute;top:18px;right:18px;display:flex;gap:8px;z-index:2}.login-card{position:relative;z-index:2;width:min(100%,480px);background:rgba(10,24,48,.92);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:28px;padding:28px;box-shadow:0 28px 60px rgba(0,0,0,.35)}.login-brand{text-align:center;margin-bottom:18px}.login-brand img{width:min(72%,260px);height:auto;display:block;margin:0 auto 16px;filter:drop-shadow(0 6px 20px rgba(0,0,0,.28))}.login-brand h1{margin:0 0 8px;font-size:2rem}.login-brand p{margin:0}.login-form{display:grid;gap:12px}.login-form input{width:100%;background:#081323;border:1px solid rgba(255,255,255,.1);color:#eef5ff;border-radius:14px;padding:13px 14px;font-size:1rem}.login-footer{margin-top:14px;text-align:center}
@media (max-width:1100px){.grid-2{grid-template-columns:1fr}.portal-shell{grid-template-columns:1fr}.sidebar{position:relative;height:auto}.content{padding:16px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width:700px){.form-grid{grid-template-columns:1fr}.hero{padding:16px}.brand img{width:56px}#portalMap{min-height:340px}.login-card{padding:22px}.login-brand h1{font-size:1.7rem}.actions{width:100%;justify-content:space-between}}


.led-badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;font-size:.86rem;font-weight:700;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.04)}
.led-dot{width:10px;height:10px;border-radius:50%;display:inline-block;box-shadow:0 0 0 3px rgba(255,255,255,.06)}
.led-badge.live{color:#d7ffe2;background:rgba(51,201,109,.14);border-color:rgba(51,201,109,.36)}
.led-badge.live .led-dot{background:#33c96d;box-shadow:0 0 10px rgba(51,201,109,.75)}
.led-badge.down{color:#ffd9d9;background:rgba(255,92,92,.12);border-color:rgba(255,92,92,.32)}
.led-badge.down .led-dot{background:#ff5c5c;box-shadow:0 0 10px rgba(255,92,92,.75)}
#portalMap .leaflet-interactive{cursor:pointer}
