:root{--primary: #2563eb;--primary-dark: #1d4ed8;--bg: #f4f6fb;--surface: #ffffff;--border: #e4e9f2;--text: #16203a;--muted: #6b7a93;--green: #16a34a;--red: #dc2626;--amber: #d97706;--sidebar: #0e1526;--sidebar-hover: #1a2440;--radius: 12px;--shadow: 0 1px 3px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04)}*{box-sizing:border-box;margin:0}body{font-family:Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:15px}a{color:var(--primary);text-decoration:none}.layout{display:flex;min-height:100vh}.sidebar{width:240px;background:var(--sidebar);color:#c6d0e2;padding:22px 0;flex-shrink:0;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar .brand{font-weight:700;color:#fff;padding:0 22px 6px;font-size:1.08rem;letter-spacing:.2px}.sidebar .brand small{display:block;font-weight:400;color:#7e8aa6;font-size:.72rem;margin-top:2px}.sidebar .nav-section{padding:18px 22px 6px;font-size:.68rem;text-transform:uppercase;letter-spacing:.8px;color:#5d6b88;font-weight:700}.sidebar a{display:flex;align-items:center;gap:10px;padding:10px 22px;color:#c6d0e2;font-size:.92rem;border-left:3px solid transparent}.sidebar a:hover{background:var(--sidebar-hover);color:#fff}.sidebar a.active{background:var(--sidebar-hover);color:#fff;border-left-color:var(--primary)}.sidebar .spacer{flex:1}.sidebar .icon{width:18px;text-align:center;opacity:.85}.main{flex:1;padding:30px 36px;max-width:1280px}.page-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:10px}h1{font-size:1.45rem;font-weight:700}h2{font-size:1.05rem;margin:20px 0 10px;font-weight:600}.card h2:first-child{margin-top:0}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:18px;box-shadow:var(--shadow)}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:1fr 1fr}.grid.cols-3{grid-template-columns:repeat(3,1fr)}@media(max-width:980px){.grid.cols-2,.grid.cols-3{grid-template-columns:1fr}}table{width:100%;border-collapse:collapse;font-size:.9rem}th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}th{color:var(--muted);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px}tr:last-child td{border-bottom:0}tbody tr:hover{background:#f8faff}button,.btn{background:var(--primary);color:#fff;border:0;border-radius:9px;padding:9px 16px;font-size:.9rem;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:background .15s,transform .05s}button:hover,.btn:hover{background:var(--primary-dark)}button:active{transform:translateY(1px)}button.secondary,.btn.secondary{background:#edf1f8;color:var(--text)}button.secondary:hover{background:#e0e7f2}button.danger{background:var(--red)}button.danger:hover{background:#b91c1c}button.success{background:var(--green)}button.success:hover{background:#15803d}button.ghost{background:transparent;color:var(--muted);padding:6px 10px}button.ghost:hover{background:#edf1f8;color:var(--text)}button:disabled{opacity:.55;cursor:wait}input,select,textarea{width:100%;padding:9px 12px;border:1.5px solid var(--border);border-radius:9px;font-size:.92rem;margin-bottom:12px;font-family:inherit;background:#fff;transition:border-color .15s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary)}label{font-size:.8rem;color:var(--muted);display:block;margin-bottom:5px;font-weight:600}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.73rem;font-weight:700}.badge.green{background:#dcfce7;color:#15803d}.badge.gray{background:#edf1f8;color:var(--muted)}.badge.amber{background:#fef3c7;color:#b45309}.badge.red{background:#fee2e2;color:#b91c1c}.badge.blue{background:#dbeafe;color:var(--primary-dark)}.swatch{width:48px;height:48px;border-radius:10px;border:1px solid var(--border)}.palette{display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap}.error{background:#fee2e2;color:#b91c1c;font-size:.88rem;padding:10px 14px;border-radius:9px;margin:10px 0}.muted{color:var(--muted);font-size:.85rem}.toolbar{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.preview-pane{border:1px solid var(--border);border-radius:10px;padding:14px;background:#fff;max-height:480px;overflow:auto;font-size:.9rem}.preview-frame{width:100%;height:520px;border:1px solid var(--border);border-radius:10px;background:#fff}.preview-label{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.preview-label .tag{font-size:.72rem;font-weight:800;letter-spacing:1px;color:var(--muted)}.preview-label .tag.after{color:var(--green)}.steps{display:flex;gap:6px;align-items:center;margin:14px 0 4px;flex-wrap:wrap}.step{display:flex;align-items:center;gap:7px;font-size:.82rem;color:var(--muted);padding:6px 12px;border-radius:999px;background:#edf1f8;font-weight:600}.step.done{background:#dcfce7;color:#15803d}.step.active{background:#dbeafe;color:var(--primary-dark)}.step-arrow{color:#c0cadb}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0a102080;display:flex;align-items:center;justify-content:center;z-index:90}.modal{background:#fff;border-radius:14px;padding:24px;width:480px;max-width:92vw;box-shadow:0 20px 50px #00000040}.modal h2{margin-top:0}.modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:14px}.toasts{position:fixed;bottom:22px;right:22px;z-index:100;display:flex;flex-direction:column;gap:9px}.toast{background:#16203a;color:#fff;border-radius:10px;padding:12px 18px;font-size:.88rem;box-shadow:0 8px 24px #00000040;max-width:380px;animation:toast-in .22s ease;border-left:4px solid var(--primary)}.toast.success{border-left-color:var(--green)}.toast.error{border-left-color:var(--red)}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1}}.progress-panel{background:#0e1526;color:#d7e0f2;border-radius:10px;padding:14px 18px;margin-top:14px;font-size:.86rem;font-family:Cascadia Code,Consolas,monospace}.progress-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-family:Segoe UI,system-ui,sans-serif}.progress-head .muted{color:#7e8aa6}.progress-step{display:flex;align-items:flex-start;gap:9px;padding:4px 0;color:#9fb0cc}.progress-step.done{color:#d7e0f2}.progress-step.running{color:#fff}.progress-step.failed{color:#fca5a5}.progress-step .step-icon{width:18px;text-align:center;flex-shrink:0}.pulse{width:10px;height:10px;border-radius:50%;background:#3b82f6;flex-shrink:0;margin:4px 4px 0;animation:pulse 1s ease infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.35;transform:scale(.75)}}.login-wrap{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0e1526,#1d2c52)}.login-box{width:400px}.login-box h1{color:var(--text)}.setting-row{display:grid;grid-template-columns:230px 1fr;gap:14px;align-items:start;padding:12px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:0}.setting-row .label b{display:block;font-size:.9rem}.setting-row .label span{font-size:.78rem;color:var(--muted)}.status-dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:6px}.status-dot.on{background:var(--green)}.status-dot.off{background:var(--red)}
