@charset "UTF-8";:root{--color-primary: #4762fe;--color-primary-hover: #3950d4;--color-primary-soft: #edf0ff;--color-bg: #f6f7f9;--color-surface: #ffffff;--color-surface-2: #f3f4f7;--color-border: #e8eaee;--color-text: #1c1f26;--color-text-secondary: #707684;--color-text-tertiary: #9aa0ac;--color-danger: #f04438;--color-danger-soft: #feeceb;--color-success: #17b26a;--color-success-soft: #e7f8f0;--color-teal: #19b89d;--color-warning: #f5a524;--color-overlay: rgba(28, 31, 38, .55);--color-toast: #21242d;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-pill: 999px;--shadow-sm: 0 1px 2px rgba(16, 24, 40, .05);--shadow-md: 0 4px 16px rgba(16, 24, 40, .08);--shadow-lg: 0 12px 32px rgba(16, 24, 40, .16);--sidebar-width: 264px;--topbar-height: 64px}*{box-sizing:border-box}html,body{height:100%;margin:0}body{font-family:Inter,Helvetica Neue,Arial,sans-serif;font-size:14px;line-height:1.45;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}h1,h2,h3,h4{margin:0 0 8px;font-weight:600;color:var(--color-text)}h1{font-size:26px;font-weight:700}h2{font-size:20px}h3{font-size:16px}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:9px 18px;border:1px solid transparent;border-radius:var(--radius-sm);font:inherit;font-weight:600;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-primary-soft);color:var(--color-primary)}.btn-secondary:hover:not(:disabled){background:#dde3ff}.btn-outline{background:var(--color-surface);color:var(--color-primary);border-color:#c8d0f5}.btn-outline:hover:not(:disabled){border-color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-surface-2);color:var(--color-text)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#d63a2f}.btn-danger-outline{background:var(--color-surface);color:var(--color-danger);border-color:#f8b9b4}.btn-danger-outline:hover:not(:disabled){border-color:var(--color-danger)}.btn-gradient{background:linear-gradient(90deg,#35c2b0,#4762fe);color:#fff}.btn-pill{border-radius:var(--radius-pill)}.btn-sm{padding:6px 13px;font-size:13px}.btn-lg{padding:12px 26px;font-size:15px}.btn-block{width:100%}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.field label{font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--color-text-secondary)}.field .hint{font-size:12px;color:var(--color-text-tertiary);text-transform:none;letter-spacing:0}.field .error{font-size:12px;color:var(--color-danger)}.input,input[type=text],input[type=email],input[type=password],input[type=number],input[type=datetime-local],input[type=date],select,textarea{width:100%;padding:10px 14px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font:inherit;color:var(--color-text);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=datetime-local]:focus,input[type=date]:focus,select:focus,textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #4762fe24}.input::placeholder,input[type=text]::placeholder,input[type=email]::placeholder,input[type=password]::placeholder,input[type=number]::placeholder,input[type=datetime-local]::placeholder,input[type=date]::placeholder,select::placeholder,textarea::placeholder{color:var(--color-text-tertiary)}.input.ng-invalid.ng-touched,input[type=text].ng-invalid.ng-touched,input[type=email].ng-invalid.ng-touched,input[type=password].ng-invalid.ng-touched,input[type=number].ng-invalid.ng-touched,input[type=datetime-local].ng-invalid.ng-touched,input[type=date].ng-invalid.ng-touched,select.ng-invalid.ng-touched,textarea.ng-invalid.ng-touched{border-color:var(--color-danger)}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.modal-backdrop{position:fixed;inset:0;background:var(--color-overlay);display:flex;align-items:center;justify-content:center;z-index:100;padding:24px}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:calc(100vh - 48px);overflow:auto;padding:24px 28px}.modal .modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.modal .modal-head .modal-close{border:none;background:transparent;font-size:18px;color:var(--color-text-tertiary);cursor:pointer;line-height:1}.modal .modal-head .modal-close:hover{color:var(--color-text)}.modal .modal-title{font-size:17px;font-weight:700}.modal .modal-sub{color:var(--color-text-secondary);font-size:13px;margin:0 0 16px}.modal .modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:22px}.toast{position:fixed;top:76px;right:24px;z-index:200;background:var(--color-surface);border:1.5px solid var(--color-teal);color:var(--color-text);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:14px 20px;display:flex;align-items:center;gap:10px;font-weight:500}.toast .toast-check{color:var(--color-teal)}.toast.toast-dark{background:var(--color-toast);border-color:var(--color-toast);color:#fff}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:var(--radius-pill);font-size:12px;font-weight:500}.badge.online{background:var(--color-success-soft);color:var(--color-success)}.badge.offline{background:var(--color-danger-soft);color:var(--color-danger)}.badge.neutral{background:var(--color-surface-2);color:var(--color-text-secondary)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.online{background:var(--color-success)}.dot.offline{background:var(--color-danger)}.spinner{width:22px;height:22px;border:3px solid var(--color-primary-soft);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:64px 24px;color:var(--color-text-secondary);text-align:center}.page{padding:28px 36px;max-width:1480px;margin:0 auto}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.page-header .page-sub{color:var(--color-text-secondary);margin:2px 0 0}.breadcrumbs{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-text-tertiary);margin-bottom:10px}.breadcrumbs a{color:var(--color-text-tertiary)}.breadcrumbs .sep{opacity:.6}.breadcrumbs .current{color:var(--color-text-secondary)}.switch{position:relative;display:inline-block;width:42px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .slider{position:absolute;inset:0;background:#d8dbe2;border-radius:var(--radius-pill);transition:background .15s ease;cursor:pointer}.switch .slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .15s ease;box-shadow:var(--shadow-sm)}.switch input:checked+.slider{background:var(--color-primary)}.switch input:checked+.slider:before{transform:translate(18px)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--color-border);margin-bottom:22px}.tabs .tab{border:none;background:transparent;font:inherit;font-weight:500;color:var(--color-text-secondary);padding:10px 14px;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs .tab:hover{color:var(--color-text)}.tabs .tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.option-row{display:flex;align-items:flex-start;gap:12px;width:100%;text-align:left;padding:14px 16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);font:inherit;cursor:pointer;margin-bottom:10px}.option-row:hover{border-color:#c8d0f5}.option-row.selected{border-color:var(--color-primary);background:#f7f9ff}.option-row:disabled{opacity:.55;cursor:not-allowed}.option-row .option-icon{width:34px;height:34px;border-radius:50%;background:var(--color-primary-soft);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.option-row .option-body{flex:1;display:flex;flex-direction:column;gap:2px}.option-row .option-body .option-title{font-weight:600}.option-row .option-body .option-sub{font-size:12px;color:var(--color-text-secondary)}.option-row .option-meta{font-size:12px;color:var(--color-text-tertiary);white-space:nowrap}
