:root{
  --bg:#0f1117; --panel:#171a23; --panel-2:#1e222e; --line:#2a2f3d;
  --text:#e7eaf0; --muted:#9aa3b2; --brand:#5b8cff;
  --green:#2ecc71; --green-bg:rgba(46,204,113,.12);
  --amber:#f5a623; --amber-bg:rgba(245,166,35,.12);
  --gray:#6b7280; --gray-bg:rgba(107,114,128,.14);
  --red:#ef5350; --radius:14px; --shadow:0 8px 30px rgba(0,0,0,.35);
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
     background:radial-gradient(1200px 600px at 80% -10%,#1b2030 0%,var(--bg) 55%);
     color:var(--text);min-height:100vh}
.hidden{display:none !important}
.demo-ribbon{position:fixed;top:14px;right:-46px;transform:rotate(45deg);background:var(--amber);
     color:#241c00;font-weight:700;font-size:12px;letter-spacing:.5px;padding:6px 60px;z-index:60;box-shadow:var(--shadow)}

/* ---------- Login ---------- */
#login-view{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}
.login-card{width:100%;max-width:380px;background:var(--panel);border:1px solid var(--line);
     border-radius:var(--radius);padding:34px 30px;box-shadow:var(--shadow);text-align:center}
.logo{display:inline-flex;align-items:center;gap:10px;font-weight:800;font-size:20px;margin-bottom:6px}
.logo .dot{width:26px;height:26px;border-radius:8px;background:linear-gradient(135deg,var(--brand),#8a5bff)}
.login-sub{color:var(--muted);font-size:14px;margin:4px 0 24px}
.field{text-align:left;margin-bottom:14px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.field input{width:100%;background:var(--panel-2);border:1px solid var(--line);border-radius:9px;
     padding:11px 12px;color:var(--text);font-size:15px}
.field input:focus{outline:none;border-color:var(--brand)}
.primary-btn{width:100%;cursor:pointer;background:var(--brand);color:#04122e;border:0;border-radius:10px;
     padding:12px 14px;font-size:15px;font-weight:700;margin-top:4px}
.primary-btn:hover{filter:brightness(1.06)}
.primary-btn:disabled{opacity:.6;cursor:not-allowed}
.login-error{color:#ff9a98;font-size:13px;margin-top:14px;min-height:18px}
.login-note{margin-top:18px;font-size:12px;color:var(--muted);line-height:1.5}

/* ---------- App shell ---------- */
header.bar{display:flex;align-items:center;justify-content:space-between;padding:14px 22px;
     border-bottom:1px solid var(--line);background:rgba(23,26,35,.7);backdrop-filter:blur(6px);
     position:sticky;top:0;z-index:30}
.user-chip{display:flex;align-items:center;gap:10px;font-size:14px}
.avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#8a5bff,var(--brand));
     display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}
.link-btn{background:none;border:1px solid var(--line);color:var(--muted);border-radius:8px;padding:6px 12px;font-size:13px;cursor:pointer}
.link-btn:hover{color:var(--text);border-color:var(--muted)}

main{max-width:1040px;margin:0 auto;padding:26px 22px 60px}
.sched-banner{display:flex;flex-wrap:wrap;align-items:center;gap:14px;background:var(--panel);
     border:1px solid var(--line);border-radius:12px;padding:14px 18px;margin-bottom:22px}
.sched-banner .pill{background:var(--panel-2);border:1px solid var(--line);border-radius:999px;padding:5px 12px;font-size:13px;color:var(--muted)}
.sched-banner b{color:var(--text)}
.next-evt{margin-left:auto;font-size:13px;color:var(--amber)}

.row-actions{display:flex;justify-content:space-between;align-items:center;margin:0 2px 14px}
.row-actions h2{font-size:16px;margin:0;font-weight:700}
.bulk{display:flex;gap:8px}
.bulk button{font-size:13px;border-radius:8px;padding:7px 12px;cursor:pointer;border:1px solid var(--line);background:var(--panel-2);color:var(--text)}
.bulk button:hover{border-color:var(--muted)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:16px}
.vm{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:14px}
.vm-top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.vm-name{font-weight:700;font-size:16px;display:flex;align-items:center;gap:8px}
.tag{font-size:11px;font-weight:700;letter-spacing:.4px;padding:3px 8px;border-radius:6px;text-transform:uppercase}
.tag.dev{background:rgba(91,140,255,.14);color:#9bb6ff}
.tag.qa{background:rgba(138,91,255,.14);color:#c0a6ff}
.vm-meta{font-size:13px;color:var(--muted);line-height:1.7}
.vm-meta code{color:#cfd6e4;background:var(--panel-2);padding:1px 6px;border-radius:5px;font-size:12px}

.status{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;padding:5px 11px;border-radius:999px}
.status .sdot{width:9px;height:9px;border-radius:50%}
.status.running{background:var(--green-bg);color:#7ee2a8}
.status.running .sdot{background:var(--green);box-shadow:0 0 0 3px rgba(46,204,113,.18)}
.status.deallocated,.status.stopped{background:var(--gray-bg);color:#aab2c0}
.status.deallocated .sdot,.status.stopped .sdot{background:var(--gray)}
.status.busy{background:var(--amber-bg);color:#f6c266}
.status.busy .sdot{background:var(--amber);animation:pulse 1s infinite}
.status.unknown{background:var(--gray-bg);color:#aab2c0}
@keyframes pulse{0%{opacity:1}50%{opacity:.3}100%{opacity:1}}

.snooze-note{font-size:12px;color:var(--amber);display:flex;align-items:center;gap:6px}
.vm-foot{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:2px}
.btn-group{display:flex;gap:8px}
.act-btn{cursor:pointer;border:0;border-radius:9px;padding:10px 16px;font-size:14px;font-weight:700;display:inline-flex;align-items:center;gap:8px;justify-content:center}
.act-btn.start{background:var(--green);color:#06351c}
.act-btn.stop{background:#3a2326;color:#ff9a98;border:1px solid #6e3a3a}
.act-btn.snooze{background:var(--panel-2);color:#f6c266;border:1px solid rgba(245,166,35,.4)}
.act-btn.start:hover{filter:brightness(1.06)}
.act-btn.stop:hover{background:#48282c}
.act-btn.snooze:hover{border-color:var(--amber)}
.act-btn:disabled{opacity:.55;cursor:not-allowed}
.spin{width:14px;height:14px;border:2px solid currentColor;border-right-color:transparent;border-radius:50%;animation:rot .7s linear infinite;display:inline-block}
@keyframes rot{to{transform:rotate(360deg)}}

/* ---------- Activity log ---------- */
.log{margin-top:30px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.log h3{margin:0;padding:14px 18px;font-size:14px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:8px}
.log ul{list-style:none;margin:0;padding:6px 0;max-height:230px;overflow:auto}
.log li{display:flex;gap:12px;padding:9px 18px;font-size:13px;border-bottom:1px solid rgba(42,47,61,.5)}
.log li:last-child{border-bottom:0}
.log .ts{color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}
.log .who{color:#9bb6ff}
.log .empty{color:var(--muted);padding:16px 18px;font-size:13px}

/* ---------- Modal ---------- */
.overlay{position:fixed;inset:0;background:rgba(6,8,13,.6);display:flex;align-items:center;justify-content:center;z-index:50;backdrop-filter:blur(3px)}
.modal{width:100%;max-width:420px;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;margin:18px}
.modal h3{margin:0 0 8px;font-size:18px}
.modal p{color:var(--muted);font-size:14px;line-height:1.6;margin:0 0 8px}
.modal .warn{background:var(--amber-bg);color:#f6c266;border:1px solid rgba(245,166,35,.3);border-radius:8px;padding:9px 12px;font-size:13px;margin:14px 0 18px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px}
.btn-ghost{background:none;border:1px solid var(--line);color:var(--text);border-radius:9px;padding:9px 16px;cursor:pointer}
.btn-ghost:hover{border-color:var(--muted)}
.btn-go{border:0;border-radius:9px;padding:9px 18px;cursor:pointer;font-weight:700}
.btn-go.start{background:var(--green);color:#06351c}
.btn-go.stop{background:var(--red);color:#fff}

/* ---------- Toast ---------- */
#toasts{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;gap:10px;z-index:70;align-items:center}
.toast{background:var(--panel-2);border:1px solid var(--line);border-left:4px solid var(--brand);padding:12px 18px;border-radius:10px;font-size:14px;box-shadow:var(--shadow);min-width:260px;animation:rise .25s ease}
.toast.ok{border-left-color:var(--green)}
.toast.warn{border-left-color:var(--amber)}
.toast.err{border-left-color:var(--red)}
@keyframes rise{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
