:root{--bg:#0b1220;--card:#162645;--card2:#12213f;--text:#f3f6ff;--muted:#c6d2ff;--line:rgba(255,255,255,.14);--accent:#38d36f;--warn:#ffb020;--bad:#ff4d4f;--chartText:#eaf0ff;--grid:rgba(255,255,255,.12);--btn:#1f335e;--btnHover:#274074;}
*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;color:var(--text)}
.bg{background:radial-gradient(1200px 600px at 20% 10%, #16305f 0%, rgba(22,48,95,0) 60%),radial-gradient(900px 600px at 80% 20%, #1b5a4a 0%, rgba(27,90,74,0) 55%),linear-gradient(180deg,#0a1020 0%, #0b1220 100%)}

a{color:inherit}

.pin-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}
.card{width:min(420px,100%);background:rgba(15,27,51,.92);border:1px solid var(--line);border-radius:18px;padding:20px;box-shadow:0 14px 50px rgba(0,0,0,.45)}
.h1{font-size:22px;font-weight:800;margin:0 0 6px}
.muted{color:var(--muted)}
.tiny{font-size:12px;margin-top:14px}
.alert{margin:12px 0;padding:10px 12px;border-radius:12px;background:rgba(255,77,79,.12);border:1px solid rgba(255,77,79,.25)}

input.pin{width:100%;padding:14px 14px;border-radius:14px;border:1px solid var(--line);background:rgba(0,0,0,.25);color:var(--text);font-size:18px;outline:none;margin-top:14px}
input.pin:focus{border-color:rgba(56,211,111,.55);box-shadow:0 0 0 4px rgba(56,211,111,.12)}
button.btn{width:100%;margin-top:12px;padding:12px 14px;border-radius:14px;border:0;background:linear-gradient(180deg,#3fe07a,#2bb95c);color:#062010;font-weight:800;font-size:15px;cursor:pointer}
button.btn:hover{filter:brightness(1.04)}

/* dashboard */
.topbar{position:sticky;top:0;z-index:20;background:rgba(11,18,32,.78);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-inner{max-width:1200px;margin:0 auto;display:flex;gap:12px;align-items:center;justify-content:space-between;padding:14px 16px}
.brand{display:flex;gap:10px;align-items:center}
.dot{width:10px;height:10px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 6px rgba(56,211,111,.10)}
.brand h2{margin:0;font-size:16px;letter-spacing:.3px}
.actions{display:flex;gap:10px;align-items:center}
.btn2{padding:9px 12px;border-radius:12px;border:1px solid var(--line);background:rgba(0,0,0,.25);color:var(--text);text-decoration:none;font-weight:700;font-size:13px}
.btn2:hover{border-color:rgba(255,255,255,.18)}

.container{max-width:1200px;margin:0 auto;padding:16px}

.tabs{display:flex;flex-wrap:wrap;gap:8px;margin:10px 0 14px}
.tab{padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:var(--btn);color:var(--chartText);cursor:pointer;font-weight:800;font-size:13px}
.tab.active{background:rgba(56,211,111,.25);border-color:rgba(56,211,111,.55);color:var(--text)}
.tab:hover{background:var(--btnHover)}

.grid{display:grid;grid-template-columns:repeat(12,1fr);gap:12px}
.panel{grid-column:span 12;background:rgba(22,38,69,.88);border:1px solid var(--line);border-radius:18px;overflow:hidden}
.panel-h{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--line);background:rgba(0,0,0,.15)}
.panel-title{font-weight:900;font-size:13px;letter-spacing:.3px}
.badges{display:flex;gap:8px;flex-wrap:wrap}
.badge{font-size:12px;padding:4px 8px;border-radius:999px;border:1px solid var(--line);color:var(--muted)}

.cards{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;padding:12px}
.card2{grid-column:span 12;background:rgba(13,23,48,.55);border:1px solid var(--line);border-radius:16px;padding:10px}
.card2 h3{margin:0 0 8px;font-size:13px}
.canvas-wrap{height:260px}

@media(min-width:900px){
  .card2{grid-column:span 6}
  .card2.wide{grid-column:span 12}
}

.smallnote{color:var(--muted);font-size:12px;margin:10px 2px}



.statusline{display:flex;align-items:center;gap:10px;margin:10px 0 14px;padding:10px 12px;border-radius:14px;border:1px solid var(--line);background:rgba(255,255,255,.05);color:var(--chartText);font-size:13px}
.statusline .dot{width:10px;height:10px;border-radius:999px;background:var(--accent);box-shadow:0 0 0 3px rgba(56,211,111,.18)}
.statusline .warn{color:var(--warn);font-weight:800}
.errpill{margin-left:auto;padding:6px 10px;border-radius:999px;border:1px solid rgba(255,77,79,.45);background:rgba(255,77,79,.12);color:#ffd6d7;font-weight:800;font-size:12px}
