:root{color-scheme:light;font-family:Inter,system-ui,sans-serif;background:#f8fafc;color:#0f172a}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:#f8fafc}input,button,select,textarea{font:inherit;border-radius:8px;border:1px solid #cbd5e1;padding:10px 12px;background:#fff;color:#0f172a}input:focus,select:focus,textarea:focus{outline:2px solid #93c5fd;border-color:#2563eb}button{cursor:pointer;background:#2563eb;border:none;color:#fff;font-weight:600}button:disabled{opacity:.6;cursor:not-allowed}.card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:24px;box-shadow:0 1px 2px #0f172a0f}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:#f1f5f9;border-right:1px solid #e2e8f0;padding:24px}.sidebar h1{font-size:18px;margin:0 0 8px;color:#0f172a}.sidebar p{color:#64748b;font-size:13px;margin:0 0 24px}.nav-item{display:block;padding:10px 12px;border-radius:8px;color:#475569;margin-bottom:6px}.nav-item.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a14}.main{padding:32px;background:#f8fafc}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.stat{padding:16px;border-radius:10px;background:#fff;border:1px solid #e2e8f0}.stat label{display:block;color:#64748b;font-size:12px;margin-bottom:8px}.stat strong{font-size:22px;color:#0f172a}.error{color:#dc2626;margin-top:12px}.success{color:#16a34a;margin-top:12px}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:#f8fafc}.login-form{width:100%;max-width:420px;display:grid;gap:12px}.badge{display:inline-block;padding:4px 8px;border-radius:999px;background:#dcfce7;color:#166534;font-size:12px}.nav-btn{width:100%;text-align:left;background:transparent;border:none;color:#475569;margin-bottom:6px}.nav-btn.active{background:#fff;color:#0f172a;box-shadow:0 1px 2px #0f172a14}.sidebar-note{color:#64748b;font-size:12px;margin-top:24px}.sidebar-email{font-size:13px;color:#64748b;margin-top:16px}.btn-logout{margin-top:12px;width:100%;background:#e2e8f0;color:#334155;border:none}.muted{color:#64748b}.info-box{margin-top:24px;padding:16px;border-radius:10px;background:#fff;border:1px solid #e2e8f0}.info-box p{margin:8px 0 0;color:#64748b;font-size:14px}.stat-grid.compact{margin:16px 0 24px}.table-wrap{overflow-x:auto;border:1px solid #e2e8f0;border-radius:12px;background:#fff}.data-table{width:100%;border-collapse:collapse;font-size:14px}.data-table th,.data-table td{padding:12px 14px;text-align:left;border-bottom:1px solid #e2e8f0}.data-table th{color:#64748b;font-weight:600;background:#f8fafc}.data-table tbody tr:hover{background:#f8fafc}.cell-sub{font-size:12px;color:#64748b;margin-top:2px}.badge.up{background:#dcfce7;color:#166534}.badge.down{background:#fee2e2;color:#991b1b}.badge.sm{font-size:11px;padding:2px 6px}.text-up{color:#16a34a}.text-down{color:#dc2626}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:8px}.server-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;margin-top:16px}.monitor-card{padding:16px;border-radius:12px;border:1px solid #e2e8f0;background:#fff}.monitor-card.up{border-color:#86efac}.monitor-card.down{border-color:#fca5a5}.monitor-card-head{display:flex;justify-content:space-between;align-items:center;font-weight:600}.monitor-meta{margin-top:8px;font-size:13px}.monitor-fail{margin-top:8px;color:#dc2626;font-size:13px}.monitor-time{margin-top:8px;color:#64748b;font-size:12px}.btn-secondary{background:#e2e8f0;color:#334155;border:none}.btn-secondary:hover{background:#cbd5e1}.step-list{list-style:none;padding:0;margin:12px 0 0;font-size:13px}.step-list li{padding:6px 0;border-bottom:1px solid #e2e8f0;color:#64748b}.step-list li.ok{color:#16a34a}.step-list li.error{color:#dc2626}.step-list li.running{color:#2563eb}.form-field{display:flex;flex-direction:column;gap:4px}.form-field label{font-size:12px;font-weight:600;color:#475569}.form-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.wizard{margin-top:16px;padding:16px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0}.wizard-title{font-size:14px;font-weight:700;margin:0 0 12px;color:#0f172a}.wizard-steps{list-style:none;padding:0;margin:0}.wizard-step{display:flex;gap:12px;padding:10px 12px;border-radius:8px;margin-bottom:6px;border:1px solid transparent}.wizard-step.done{background:#f0fdf4;border-color:#bbf7d0}.wizard-step.current{background:#eff6ff;border-color:#93c5fd}.wizard-step.pending{opacity:.7}.wizard-num{width:24px;height:24px;border-radius:999px;background:#e2e8f0;color:#475569;display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0}.wizard-step.done .wizard-num{background:#16a34a;color:#fff}.wizard-step.current .wizard-num{background:#2563eb;color:#fff}.wizard-body{flex:1}.wizard-body strong{display:block;font-size:13px;margin-bottom:2px}.wizard-body span{font-size:12px;color:#64748b}.toggle-row{display:flex;align-items:center;gap:12px;margin-top:12px;padding:12px;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.toggle{position:relative;width:44px;height:24px;background:#cbd5e1;border-radius:999px;border:none;padding:0;cursor:pointer}.toggle.on{background:#2563eb}.toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:999px;transition:left .15s;box-shadow:0 1px 2px #00000026}.toggle.on .toggle-knob{left:22px}.link-btn{background:none;border:none;color:#2563eb;padding:0;font-size:13px;font-weight:500;cursor:pointer;text-decoration:underline}.row-actions{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.server-detail{scroll-margin-top:16px}.server-wizard-layout{display:grid;grid-template-columns:240px 1fr;gap:20px;margin-top:16px;align-items:start}@media(max-width:960px){.server-wizard-layout{grid-template-columns:1fr}}.wizard-sidebar{position:sticky;top:16px;padding:12px;border-radius:10px;background:#f8fafc;border:1px solid #e2e8f0}.wizard-sidebar .wizard-steps{margin:0}.wizard-sidebar li{list-style:none;margin-bottom:4px}.wizard-link{width:100%;padding:0;border:none;background:transparent;color:inherit;font-weight:inherit;text-align:left;cursor:pointer}.wizard-link:hover .wizard-step.pending{background:#f1f5f9}.step-card{padding:16px;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;background:#fff;scroll-margin-top:16px}.step-card.current{border-color:#93c5fd;box-shadow:0 0 0 3px #eff6ff}.step-card.done{border-color:#bbf7d0;background:#fafdfa}.step-title{margin:0 0 8px;font-size:15px;color:#0f172a}.step-hint{margin:0 0 12px;font-size:13px}.step-actions{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.step-feedback{margin-top:12px;padding:10px 12px;border-radius:8px;font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.step-feedback.ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.step-feedback.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.deploy-log{margin-top:12px;padding-top:12px;border-top:1px solid #e2e8f0}.servers-block{background:#fff;border:1px solid #e2e8f0;border-radius:12px;overflow:hidden;box-shadow:0 1px 2px #0f172a0f}.servers-block-head{display:flex;flex-wrap:wrap;align-items:center;gap:16px;padding:20px 20px 16px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.servers-block-head>div:first-child{flex:1;min-width:200px}.servers-stats{display:flex;flex-wrap:wrap;gap:12px 16px;font-size:13px;color:#64748b}.servers-stats strong{color:#0f172a;margin-right:4px}.servers-new-form{padding:16px 20px;border-bottom:1px solid #e2e8f0;background:#fafbff}.servers-table{border:none;border-radius:0}.servers-table .data-table tbody tr{cursor:pointer}.servers-table .row-selected{background:#eff6ff!important}.cell-actions{white-space:nowrap;width:1%}.btn-sm{padding:6px 10px;font-size:12px;font-weight:600}.btn-danger{background:#fee2e2;color:#991b1b;border:none}.btn-danger:hover{background:#fecaca}.servers-block-detail{padding:20px}.servers-block-divider{padding-bottom:16px;margin-bottom:4px;border-bottom:1px solid #e2e8f0}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0f172a73;display:flex;align-items:flex-start;justify-content:center;padding:24px 16px;overflow-y:auto}.modal{background:#fff;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 20px 40px #0f172a26;width:100%;max-width:960px;max-height:calc(100vh - 48px);overflow-y:auto;padding:24px}.modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #e2e8f0;position:sticky;top:0;background:#fff;z-index:1}.modal-wizard .wizard-sidebar{position:static}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.spinner{display:inline-block;border:2px solid #e2e8f0;border-top-color:#2563eb;border-radius:999px;animation:spin .7s linear infinite;vertical-align:middle}.loading-block{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;color:#64748b}.btn-inner{display:inline-flex;align-items:center;gap:8px}.animate-in{animation:fadeSlideIn .28s ease-out}.page-content{animation:fadeSlideIn .22s ease-out}.stat-accent{background:linear-gradient(135deg,#eff6ff,#fff);border-color:#93c5fd}.toast{margin:12px 0;padding:10px 14px;border-radius:8px;font-size:14px}.toast.ok{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.toast.err{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.traffic-bar-wrap{position:relative;height:8px;background:#e2e8f0;border-radius:999px;min-width:80px;overflow:hidden}.traffic-bar{height:100%;background:linear-gradient(90deg,#2563eb,#3b82f6);border-radius:999px;transition:width .4s ease}.traffic-bar-label{display:block;font-size:11px;color:#64748b;margin-top:4px}.nav-btn{transition:background .15s ease,color .15s ease,box-shadow .15s ease}button{transition:background .15s ease,opacity .15s ease,transform .1s ease}button:active:not(:disabled){transform:scale(.98)}.stat{transition:box-shadow .2s ease,transform .2s ease}.stat:hover{box-shadow:0 4px 12px #0f172a14;transform:translateY(-1px)}.monitor-card{transition:border-color .2s ease,box-shadow .2s ease}.data-table tbody tr{transition:background .15s ease}.row-muted{opacity:.55}.routing-builtin-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;max-height:480px;overflow:auto}.mono-list code{font-size:11px;word-break:break-all}.routing-tabs button{min-width:140px}
