:root{color:#1a1a1a;font-family:system-ui,sans-serif}body{background:#f6f7f9;margin:0}.app>header{background:#fff;border-bottom:1px solid #e3e6ea;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.app>header nav{align-items:center;gap:12px;display:flex}main{max-width:820px;margin:32px auto;padding:0 20px}.card{background:#fff;border:1px solid #e3e6ea;border-radius:10px;flex-direction:column;gap:10px;max-width:320px;margin:64px auto;padding:24px;display:flex}.row{gap:8px;margin-bottom:16px;display:flex}input{border:1px solid #cdd2d8;border-radius:6px;padding:8px 10px;font-size:14px}button{color:#fff;cursor:pointer;background:#2563eb;border:0;border-radius:6px;padding:8px 14px;font-size:14px}button:hover{background:#1d4ed8}table{border-collapse:collapse;background:#fff;border:1px solid #e3e6ea;border-radius:8px;width:100%;overflow:hidden}th,td{text-align:left;border-bottom:1px solid #eef0f3;padding:10px 12px;font-size:14px}th{background:#f0f2f5}.error{color:#c0392b;font-size:13px}button.ghost{color:#2563eb;background:#fff;border:1px solid #cdd2d8}button.ghost:hover{background:#f0f2f5}button.danger{background:#dc2626}button.danger:hover{background:#b91c1c}td input{width:100%}select{background:#fff;border:1px solid #cdd2d8;border-radius:6px;padding:8px 10px;font-size:14px}.badge{border-radius:10px;padding:2px 8px;font-size:12px}.badge.on{color:#166534;background:#dcfce7}.badge.off{color:#6b7280;background:#f0f2f5}.row.wrap{flex-wrap:wrap}.nav-user{color:#6b7280;padding:0 4px;font-size:13px}.modal{background:#fff;border-radius:10px;min-width:320px;max-width:420px;padding:24px;box-shadow:0 8px 32px #0003}.modal h3{margin:0 0 12px;font-size:15px}.flash-bar-wrap{align-items:center;gap:8px;margin-top:8px;display:flex}.flash-bar-wrap>div{background:#2563eb;border-radius:4px;height:8px;transition:width .2s}.flash-bar-wrap>span{color:#6b7280;white-space:nowrap;font-size:12px}.error pre{white-space:pre-wrap;word-break:break-all;margin:4px 0 0;font-size:11px}.flash-prereq{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;margin:12px 0 20px;padding:14px 16px;font-size:14px}.flash-prereq strong{margin-bottom:8px;display:block}.flash-prereq ol{margin:0 0 12px 18px;padding:0}.flash-prereq li{margin-bottom:6px}.flash-prereq ul{margin:4px 0 0 16px}.flash-prereq code{background:#fef3c7;border-radius:4px;padding:1px 5px;font-size:12px}.provision-panels{grid-template-columns:1fr 1fr 1fr;gap:20px;margin-top:8px;display:grid}@media (width<=900px){.provision-panels{grid-template-columns:1fr 1fr}}@media (width<=600px){.provision-panels{grid-template-columns:1fr}}.provision-panel{background:#fff;border:1px solid #e3e6ea;border-radius:10px;padding:18px 20px}.panel-title{color:#111;margin-bottom:14px;font-size:15px;font-weight:600}.panel-row{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:10px;display:flex}.provision-panels .disabled{opacity:.4;pointer-events:none}.provision-steps{flex-direction:column;gap:12px;margin-top:20px;display:flex}.step{background:#fff;border:1px solid #e3e6ea;border-radius:8px;gap:14px;padding:14px 16px;display:flex}.step.active{background:#eff6ff;border-color:#2563eb}.step.done{background:#f0fdf4;border-color:#bbf7d0}.step.disabled{opacity:.45;pointer-events:none}.step-num{color:#fff;background:#2563eb;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:700;display:flex}.step.done .step-num{background:#16a34a}.step.disabled .step-num{background:#9ca3af}.step>div{flex:1}.step strong{font-size:14px}.step p{color:#6b7280;margin:4px 0 10px;font-size:13px}.notice{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;margin-bottom:16px;padding:10px 14px;font-size:14px}.notice code{background:#dcfce7;border-radius:4px;padding:2px 6px;font-family:monospace}.tabs{gap:.5rem;margin:1rem 0;display:flex}.tab{color:#1a1a1a;cursor:pointer;background:#f0f2f5;border:1px solid #ccc;border-radius:6px;padding:.35rem .8rem}.tab.active{color:#fff;background:#1a1a1a;border-color:#1a1a1a}.sev{text-transform:uppercase;color:#fff;border-radius:999px;padding:.1rem .5rem;font-size:.75rem}.sev-info{background:#2b6cb0}.sev-warning{background:#d69e2e}.sev-critical{background:#c53030}.alert-list{flex-direction:column;gap:.5rem;padding:0;list-style:none;display:flex}.alert-card{border:1px solid #eee;border-radius:8px;align-items:flex-start;gap:.75rem;padding:.6rem .8rem;display:flex}.alert-msg{font-weight:600}.muted{color:#777}.small{font-size:.8rem}.grid{border-collapse:collapse;width:100%}.grid th,.grid td{text-align:left;border-bottom:1px solid #eee;padding:.4rem .6rem}.actions{gap:.4rem;display:flex}.ghost{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:6px;padding:.2rem .5rem}.ghost.danger{color:#fff;background:#c53030;border-color:#c53030}.form-err{color:#c53030}.nav-alerts{position:relative}.nav-alert-count{color:#fff;background:#c53030;border-radius:999px;justify-content:center;align-items:center;min-width:1.1rem;height:1.1rem;padding:0 .25rem;font-size:.7rem;display:inline-flex;position:absolute;top:-.5rem;right:-.9rem}.modal-backdrop{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:10px;width:min(440px,92vw);max-height:90vh;padding:1.25rem;overflow:auto}.rule-form label{margin:.5rem 0;display:block}.rule-form label.inline{align-items:center;gap:.4rem;display:flex}.rule-form input,.rule-form select{width:100%;padding:.35rem}.rule-form .row{gap:.75rem;display:flex}.rule-form .row>label,.rule-form .row>button{flex:1}
