*{margin:0;padding:0;box-sizing:border-box}:root{--bg-base: #09090b;--bg-surface: #18181b;--bg-elevated: #27272a;--bg-hover: #2a2a2e;--bg-selected: rgba(59, 130, 246, .08);--bg-overlay: rgba(0, 0, 0, .6);--text-primary: #f4f4f5;--text-secondary: #d4d4d8;--text-muted: #a1a1aa;--text-ghost: #71717a;--accent: #3b82f6;--accent-hover: #60a5fa;--accent-subtle: rgba(59, 130, 246, .12);--ok: #22c55e;--ok-subtle: rgba(34, 197, 94, .1);--ok-glow: rgba(34, 197, 94, .4);--warn: #eab308;--warn-subtle: rgba(234, 179, 8, .1);--fail: #ef4444;--fail-subtle: rgba(239, 68, 68, .1);--fail-glow: rgba(239, 68, 68, .4);--border: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--border-active: rgba(255, 255, 255, .16);--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(59, 130, 246, .2);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans KR", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", "Consolas", monospace;--ease-out: cubic-bezier(.16, 1, .3, 1);--duration-fast: .1s;--duration-normal: .2s}body{font-family:var(--font-sans);background:var(--bg-base);color:var(--text-primary);min-height:100vh;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 32px;height:56px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px) saturate(180%);backdrop-filter:blur(12px) saturate(180%);background:#18181bd9}.header h1{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.4px;display:flex;align-items:center;gap:12px}.header-dot{width:9px;height:9px;background:var(--ok);border-radius:50%;box-shadow:0 0 10px var(--ok-glow);animation:pulse 2.5s ease-in-out infinite;flex-shrink:0}.header .info{font-size:12px;color:var(--text-muted);letter-spacing:.5px;font-weight:500;display:flex;align-items:center;gap:8px}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.tabs{display:flex;background:var(--bg-surface);border-bottom:1px solid var(--border);padding:0 32px;gap:4px}.tab{font-family:inherit;font-size:inherit;background:none;border:none;padding:12px 20px;cursor:pointer;border-bottom:2px solid transparent;color:var(--text-muted);font-size:13px;font-weight:600;transition:all var(--duration-normal) var(--ease-out);-webkit-user-select:none;user-select:none;letter-spacing:.2px;display:flex;align-items:center;gap:8px}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--text-primary);border-bottom-color:var(--accent)}.main{padding:28px 32px;flex:1}.panel{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.panel-header{padding:16px 24px;border-bottom:1px solid var(--border);font-size:13px;font-weight:600;color:var(--text-primary);display:flex;align-items:center;justify-content:space-between}.panel-header .filter-tag{font-weight:400;font-size:11px;color:var(--accent);background:var(--accent-subtle);padding:2px 8px;border-radius:var(--radius-full);margin-left:10px}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:24px}.toolbar select,.toolbar input[type=text]{background:var(--bg-surface);border:1px solid var(--border-light);color:var(--text-primary);padding:0 14px;border-radius:var(--radius);font-size:13px;font-family:var(--font-sans);transition:all var(--duration-fast);outline:none;height:38px}.toolbar select:hover,.toolbar input[type=text]:hover{border-color:var(--border-active)}.toolbar select:focus,.toolbar input[type=text]:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.toolbar input[type=text]::placeholder{color:var(--text-ghost)}.btn{padding:0 18px;height:38px;border:none;border-radius:var(--radius);font-size:13px;font-family:var(--font-sans);cursor:pointer;font-weight:600;transition:all var(--duration-normal) var(--ease-out);display:inline-flex;align-items:center;gap:7px;white-space:nowrap}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0) scale(.98)}.btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;box-shadow:0 2px 8px #22c55e40}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #22c55e59}.btn-success{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px #3b82f640}.btn-success:hover:not(:disabled){box-shadow:0 4px 16px #3b82f659}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef444440}.btn-danger:hover:not(:disabled){box-shadow:0 4px 16px #ef444459}.btn-warn{background:linear-gradient(135deg,#eab308,#ca8a04);color:#000;font-weight:700;box-shadow:0 2px 8px #eab30840}.btn-warn:hover:not(:disabled){box-shadow:0 4px 16px #eab30859}.btn-success{background:linear-gradient(135deg,var(--ok),#16a34a);color:#fff;font-weight:700}.btn-ghost{background:transparent;border:1px solid var(--border-light);color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-active)}.btn-sm{height:30px;padding:0 12px;font-size:12px;border-radius:6px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px;table-layout:fixed}thead th{background:var(--bg-elevated);padding:0 16px;height:42px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.6px;color:var(--text-secondary);border-bottom:1px solid var(--border);white-space:nowrap;position:sticky;top:0;z-index:1}tbody td{padding:0 16px;height:48px;border-bottom:1px solid var(--border);white-space:nowrap;font-size:13px;font-variant-numeric:tabular-nums;color:var(--text-primary);vertical-align:middle;transition:background var(--duration-fast),color var(--duration-fast)}tbody tr{transition:background var(--duration-fast)}tbody tr:hover td{background:var(--bg-hover);color:var(--text-primary)}tbody tr.selected td{background:var(--bg-selected)}tbody tr:last-child td{border-bottom:none}tbody tr.region-header td{background:var(--bg-secondary, #1a1a2e);border-bottom:1px solid var(--border);padding-top:10px;padding-bottom:10px}tbody tr.region-header:hover td{background:var(--bg-hover)}table.monitor-table th:nth-child(1),table.monitor-table td:nth-child(1){width:48px;text-align:center}table.monitor-table th:nth-child(2),table.monitor-table td:nth-child(2){width:160px}table.monitor-table th:nth-child(3),table.monitor-table td:nth-child(3){width:180px}table.monitor-table th:nth-child(4),table.monitor-table td:nth-child(4){width:100px}table.monitor-table th:nth-child(5),table.monitor-table td:nth-child(5){width:120px;text-align:center}table.monitor-table th:nth-child(6),table.monitor-table td:nth-child(6){width:140px;text-align:center}table.monitor-table th:nth-child(7),table.monitor-table td:nth-child(7){width:120px;text-align:center}table.monitor-table th:last-child,table.monitor-table td:last-child{width:170px}table.manage-table th:nth-child(1),table.manage-table td:nth-child(1){width:48px;text-align:center}table.manage-table th:nth-child(2),table.manage-table td:nth-child(2){width:140px}table.manage-table th:nth-child(3),table.manage-table td:nth-child(3){width:150px}table.manage-table th:nth-child(4),table.manage-table td:nth-child(4){width:100px}table.manage-table th:nth-child(5),table.manage-table td:nth-child(5){width:110px}table.manage-table th:nth-child(6),table.manage-table td:nth-child(6){width:100px}table.manage-table th:nth-child(7),table.manage-table td:nth-child(7){width:90px;text-align:center}table.manage-table th:last-child,table.manage-table td:last-child{width:140px}.checkbox-wrap{display:flex;align-items:center;justify-content:center}.checkbox-wrap input[type=checkbox]{-moz-appearance:none;appearance:none;-webkit-appearance:none;width:18px;height:18px;border:2px solid var(--border-active);border-radius:5px;background:transparent;cursor:pointer;position:relative;transition:all .15s var(--ease-out);flex-shrink:0}.checkbox-wrap input[type=checkbox]:hover{border-color:var(--accent);background:var(--accent-subtle)}.checkbox-wrap input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.checkbox-wrap input[type=checkbox]:checked:after{content:"";position:absolute;left:4px;top:1px;width:6px;height:10px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}.badge{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:600;letter-spacing:.1px;line-height:1}.badge:before{content:"";width:7px;height:7px;border-radius:50%;flex-shrink:0}.badge.ok{background:var(--ok-subtle);color:var(--ok)}.badge.ok:before{background:var(--ok);box-shadow:0 0 6px var(--ok-glow)}.badge.fail{background:var(--fail-subtle);color:var(--fail)}.badge.fail:before{background:var(--fail);box-shadow:0 0 6px var(--fail-glow)}.badge.warn{background:var(--warn-subtle);color:var(--warn)}.badge.warn:before{background:var(--warn)}.badge.unknown{background:#71717a14;color:var(--text-muted)}.badge.unknown:before{background:var(--text-muted)}.summary{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:24px}.summary-item{font-family:inherit;font-size:inherit;text-align:left;color:inherit;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;display:flex;flex-direction:column;gap:10px;transition:all var(--duration-normal) var(--ease-out);position:relative;overflow:hidden;cursor:pointer}.summary-item:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;opacity:0;transition:opacity var(--duration-normal)}.summary-item:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px;opacity:0;transition:all var(--duration-normal) var(--ease-out)}.summary-item:hover{border-color:var(--border-light);background:var(--bg-elevated);transform:translateY(-2px);box-shadow:var(--shadow-md)}.summary-item:hover:after{opacity:1}.summary-item.summary-active{border-color:var(--accent);background:var(--accent-subtle)}.summary-item.summary-active:after{opacity:1}.summary-item:nth-child(1):after{background:linear-gradient(90deg,var(--accent),var(--accent-hover))}.summary-item:nth-child(2):after{background:linear-gradient(90deg,#22c55e,#4ade80)}.summary-item:nth-child(3):after{background:linear-gradient(90deg,#ef4444,#f87171)}.summary-item:nth-child(4):after{background:linear-gradient(90deg,#ef4444,#f87171)}.summary-item:nth-child(5):after{background:linear-gradient(90deg,#ef4444,#f87171)}.summary-label{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-secondary);font-weight:600;display:flex;align-items:center;gap:8px}.summary-count{font-size:36px;font-weight:800;font-variant-numeric:tabular-nums;line-height:1;letter-spacing:-1.5px;font-family:var(--font-sans)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;vertical-align:middle;flex-shrink:0}.dot-ok{background:var(--ok);box-shadow:0 0 8px var(--ok-glow)}.dot-fail{background:var(--fail);box-shadow:0 0 8px var(--fail-glow)}.last-checked{margin-bottom:14px;font-size:13px;color:var(--text-muted);display:flex;align-items:center;gap:8px}.last-checked .live-dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.last-checked .live-dot.checking{background:var(--warn);animation:pulse 1.5s ease-in-out infinite}.last-checked .live-dot.done{background:var(--ok)}.progress-toast{position:fixed;bottom:28px;right:32px;background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:18px 24px;box-shadow:var(--shadow-lg);z-index:100;min-width:240px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);animation:toast-enter .3s var(--ease-out)}.progress-toast-title{font-size:13px;font-weight:600;margin-bottom:10px;display:flex;align-items:center;gap:8px;color:var(--text-primary)}.progress-bar-bg{background:var(--border);border-radius:var(--radius-full);height:6px;overflow:hidden;margin-bottom:8px}.progress-bar-fill{height:100%;border-radius:var(--radius-full);background:linear-gradient(90deg,var(--ok),#4ade80);transition:width .3s var(--ease-out);position:relative}.progress-bar-fill:after{content:"";position:absolute;top:0;right:0;bottom:0;width:30px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2));border-radius:var(--radius-full)}.progress-toast-count{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}@keyframes toast-enter{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group{margin-bottom:18px}.form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select{width:100%;background:var(--bg-base);border:1px solid var(--border-light);color:var(--text-primary);padding:0 14px;border-radius:var(--radius);font-size:14px;font-family:var(--font-sans);transition:all var(--duration-fast);outline:none;height:42px}.form-group input:hover,.form-group select:hover{border-color:var(--border-active)}.form-group input:focus,.form-group select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-subtle)}.form-group input:disabled{opacity:.4;cursor:not-allowed}.form-group input::placeholder{color:var(--text-ghost)}.form-hint{font-size:12px;color:var(--text-muted);margin-top:6px;line-height:1.5}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.modal-overlay{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-overlay);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;align-items:center;justify-content:center}.modal-overlay.active{display:flex}.modal{background:var(--bg-surface);border:1px solid var(--border-light);border-radius:var(--radius-xl);width:520px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-enter .25s var(--ease-out)}.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.modal-header h3{font-size:17px;font-weight:700;letter-spacing:-.3px}.modal-close{background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);transition:all var(--duration-fast)}.modal-close:hover{background:var(--bg-elevated);color:var(--text-primary)}.modal-body{padding:24px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}@keyframes modal-enter{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.detail-section{padding:20px 24px;border-bottom:1px solid var(--border)}.detail-section:last-child{border-bottom:none}.detail-section-title{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:16px}.detail-info-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.detail-info-label{font-size:11px;color:var(--text-muted);margin-bottom:4px;font-weight:600}.detail-info-value{font-size:14px;color:var(--text-primary)}.status-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#ffffff05;border-radius:var(--radius);border:1px solid var(--border);transition:background var(--duration-fast)}.status-row:hover{background:#ffffff0a}.status-row-label{font-size:13px;color:var(--text-primary);font-weight:500;flex-shrink:0}.status-row-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status-row-error{font-size:11px;color:var(--text-muted);max-width:280px;text-align:right;line-height:1.5;word-break:keep-all;overflow-wrap:break-word}.metric-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.metric-card{padding:14px 16px;border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:all var(--duration-fast)}.metric-card:hover{transform:translateY(-1px)}.metric-card.ok{background:var(--ok-subtle);border-color:#22c55e26}.metric-card.fail{background:var(--fail-subtle);border-color:#ef444426}.metric-card.none{background:#ffffff05}.metric-card-label{font-size:11px;color:var(--text-muted);margin-bottom:6px;font-weight:600}.metric-card-value{font-size:14px;font-weight:700}.metric-card.ok .metric-card-value{color:var(--ok)}.metric-card.fail .metric-card-value{color:var(--fail)}.metric-card.none .metric-card-value{color:var(--text-muted)}.import-guide{background:var(--bg-base);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;margin-bottom:18px}.import-guide-title{font-size:13px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.import-guide ol{font-size:13px;color:var(--text-secondary);padding-left:18px;line-height:1.9}.import-guide strong{color:var(--text-primary)}.import-guide .hint{font-size:11px;color:var(--text-muted)}.import-table{width:100%;font-size:12px;border-collapse:collapse;table-layout:fixed}.import-table th{background:var(--bg-elevated);text-align:left;padding:8px 12px;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border)}.import-table td{padding:8px 12px;border-bottom:1px solid var(--border);color:var(--text-secondary)}.import-table tr:last-child td{border-bottom:none}.import-table .required{color:var(--fail);font-weight:600}.import-example{font-size:12px;color:var(--text-secondary);background:var(--bg-base);padding:14px 16px;border-radius:var(--radius);line-height:1.8;overflow-x:auto;border:1px solid var(--border);font-family:var(--font-mono)}.import-section-title{font-size:13px;font-weight:600;margin-bottom:10px;color:var(--text-primary)}.import-hint{font-size:11px;color:var(--text-muted);margin-top:8px;line-height:1.5}.file-upload{border:2px dashed var(--border-active);border-radius:var(--radius-lg);padding:36px;text-align:center;cursor:pointer;transition:all var(--duration-normal) var(--ease-out);background:var(--bg-base)}.file-upload:hover{border-color:var(--accent);background:var(--accent-subtle);transform:translateY(-1px)}.file-upload input[type=file]{display:none}.file-upload-text{font-size:14px;margin-bottom:4px;font-weight:500}.file-upload-hint{font-size:12px;color:var(--text-muted)}.loading{text-align:center;padding:60px;color:var(--text-secondary)}.spinner{display:inline-block;width:28px;height:28px;border:3px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}details{border:1px solid var(--border-light);border-radius:var(--radius);padding:4px 14px;background:var(--bg-base)}details summary{cursor:pointer;font-size:13px;color:var(--text-muted);padding:10px 0;-webkit-user-select:none;user-select:none;font-weight:500;transition:color var(--duration-fast)}details summary:hover{color:var(--text-secondary)}details[open]{padding-bottom:12px}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.empty-state{text-align:center;padding:72px 24px;color:var(--text-muted)}.empty-state p{font-size:14px;line-height:1.7}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.3}.footer{margin-top:auto;border-top:1px solid var(--border);padding:20px 32px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:12px;color:var(--text-muted)}.footer-separator{color:var(--border-active)}.footer a{color:var(--text-muted);text-decoration:none;transition:color var(--duration-fast)}.footer a:hover{color:var(--text-secondary)}@media (max-width: 1200px){.summary{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.summary{grid-template-columns:repeat(2,1fr)}.main{padding:16px}.header,.tabs{padding:0 16px}}.toast-container{position:fixed;top:16px;right:16px;z-index:9999;display:flex;flex-direction:column;gap:8px;max-width:400px}.toast{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;border-radius:8px;font-size:13px;line-height:1.5;animation:toast-in .2s ease-out;box-shadow:0 4px 12px #0000004d}.toast-success{background:#166534;color:#f0fdf4;border:1px solid #22c55e33}.toast-error{background:#7f1d1d;color:#fef2f2;border:1px solid #ef444433}.toast-info{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.toast-close{background:none;border:none;color:inherit;cursor:pointer;font-size:16px;opacity:.6;padding:0 2px}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-base);padding:16px}.login-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:20px}.login-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:8px;color:var(--text-primary)}.login-header h1{font-size:20px;font-weight:700}.login-header p{font-size:13px;color:var(--text-muted)}.login-error{background:#ef44441a;border:1px solid rgba(239,68,68,.2);color:var(--fail);padding:10px 14px;border-radius:var(--radius);font-size:13px;text-align:center}.login-btn{width:100%;padding:12px;font-size:14px;font-weight:600;margin-top:4px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#3b82f6,#6366f1);border:none;border-radius:var(--radius);color:#fff;cursor:pointer;transition:opacity .15s}.login-btn:hover{opacity:.9}.login-btn:disabled{opacity:.5;cursor:not-allowed}.header-right{display:flex;align-items:center;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:12px}.stats-2{grid-template-columns:repeat(2,1fr)}.stats-4{grid-template-columns:repeat(4,1fr)}.stats-5{grid-template-columns:repeat(5,1fr)}.stat-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center}.stat-card-accent{border-color:var(--accent);background:var(--accent-subtle)}.stat-card-clickable{cursor:pointer;transition:border-color var(--duration-fast),background var(--duration-fast);font-family:inherit;color:inherit;width:100%}.stat-card-clickable:hover{border-color:var(--accent);background:var(--bg-hover)}.stat-value{font-size:28px;font-weight:700;line-height:1.2;font-variant-numeric:tabular-nums}.stat-label{font-size:12px;color:var(--text-muted);margin-top:4px}.stat-sub{font-size:11px;color:var(--text-ghost);margin-top:4px}.stat-waiting{color:var(--text-muted)}.stat-installed{color:var(--accent)}.stat-migrated{color:var(--ok)}.monitor-stats{display:flex;flex-direction:column;gap:8px;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:12px}.monitor-stats-label{font-size:13px;color:var(--text-secondary);font-weight:500}.monitor-cards{display:grid;grid-template-columns:repeat(7,1fr);gap:12px}.monitor-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px;text-align:center;cursor:pointer;transition:all var(--duration-fast);font-family:inherit;color:inherit;width:100%}.monitor-card:hover{border-color:var(--text-muted);background:var(--bg-hover)}.monitor-card.mc-active{border-color:var(--accent);background:var(--accent-subtle)}.mc-value{font-size:28px;font-weight:700;font-variant-numeric:tabular-nums;line-height:1.2}.mc-label{font-size:12px;color:var(--text-muted);margin-top:4px}.mc-total{font-size:16px;font-weight:400;color:var(--text-ghost)}.monitor-card.mc-ok .mc-value{color:var(--ok)}.monitor-card.mc-ok.mc-active{border-color:var(--ok);background:var(--ok-subtle)}.monitor-card.mc-fail .mc-value{color:var(--fail)}.monitor-card.mc-fail.mc-active{border-color:var(--fail);background:var(--fail-subtle)}@media (max-width: 900px){.monitor-cards{grid-template-columns:repeat(3,1fr)}}.monitor-stats-empty{font-size:12px;color:var(--text-ghost)}@media (max-width: 900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.stat-value{font-size:22px}}table.site-table{width:100%;border-collapse:collapse;table-layout:fixed}table.site-table th,table.site-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}table.site-table thead th{font-size:12px;font-weight:600;color:var(--text-secondary);background:var(--bg-elevated);border-bottom:2px solid var(--border);position:sticky;top:0;z-index:1}table.site-table .col-name{text-align:left}table.site-table .col-dot{width:44px;text-align:center;border-left:1px solid var(--border)}table.site-table .col-status{width:90px;text-align:center;border-left:1px solid var(--border)}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;vertical-align:middle}.dot-ok{background:var(--ok);box-shadow:0 0 6px var(--ok-glow)}.dot-fail{background:var(--fail);box-shadow:0 0 6px #ef444466}.dot-skip{background:var(--text-ghost)}.dot-none{background:var(--border);opacity:.3}table.site-table .col-num{width:100px;text-align:right;font-variant-numeric:tabular-nums;border-left:1px solid var(--border)}table.site-table .col-accent{color:var(--accent);font-weight:600}.row-indent-0{display:flex;align-items:center;gap:6px;font-weight:600}.row-indent-1{display:flex;align-items:center;gap:6px;padding-left:28px}.row-indent-2{padding-left:56px;display:flex;align-items:center;gap:4px}tr.row-region{cursor:pointer;background:var(--bg-elevated)}tr.row-region:hover{background:var(--bg-hover)}tr.row-city{cursor:pointer}tr.row-city:hover{background:var(--bg-hover)}tr.row-city td{color:var(--text-secondary)}tr.row-site{cursor:pointer}tr.row-site:hover{background:var(--accent-subtle)}tr.row-active{background:var(--accent-subtle)!important}tr.row-active td:first-child{box-shadow:inset 3px 0 0 var(--accent)}.badge-sm{font-size:10px;padding:2px 8px}.site-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:16px;width:680px;max-width:95vw;max-height:85vh;overflow-y:auto;box-shadow:0 24px 80px #0009}.site-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:28px 28px 20px;border-bottom:1px solid var(--border)}.site-modal-header h2{font-size:22px;font-weight:700;margin-bottom:8px}.site-modal-address{font-size:14px;color:var(--text-muted);margin-bottom:14px}.site-modal-tags{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.site-modal-tags .badge{font-size:12px;padding:4px 12px}.site-modal-info{font-size:14px;color:var(--text-secondary);font-weight:500}.site-modal-actions{display:flex;gap:10px;padding:16px 28px;border-bottom:1px solid var(--border);background:var(--bg-elevated)}.site-modal-nodes{padding:20px 28px 28px}.site-modal-nodes h3{font-size:15px;font-weight:600;margin-bottom:16px;color:var(--text-secondary)}.site-modal-empty{padding:40px 0;text-align:center;color:var(--text-muted);font-size:14px}.site-modal-memo{display:flex;flex-direction:column;padding:16px 28px;border-bottom:1px solid var(--border)}.site-modal-memo h3{font-size:15px;font-weight:600;margin-bottom:10px;color:var(--text-secondary)}.site-modal-memo textarea{width:100%;background:var(--bg-elevated);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:13px;padding:10px 12px;resize:vertical;font-family:inherit;line-height:1.5}.site-modal-memo textarea:focus{outline:none;border-color:var(--accent)}.site-modal-memo textarea::placeholder{color:var(--text-ghost)}.node-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:10px;padding:14px 16px;margin-bottom:10px;transition:border-color var(--duration-fast)}.node-card-selected{border-color:var(--accent);background:var(--accent-subtle)}.node-card-header{display:flex;align-items:flex-start;gap:10px}.node-card-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.node-card-field{display:flex;align-items:center;gap:8px}.node-card-label{font-size:11px;color:var(--text-ghost);width:40px;flex-shrink:0;font-weight:600}.node-card-value{font-family:var(--font-mono);font-size:14px;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-copy{font-size:11px;color:var(--text-muted);background:none;border:1px solid var(--border);border-radius:4px;padding:1px 8px;cursor:pointer;flex-shrink:0;transition:color var(--duration-fast),border-color var(--duration-fast)}.btn-copy:hover{color:var(--accent);border-color:var(--accent)}.node-card-status{display:flex;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);flex-wrap:wrap}.node-card-time{font-size:12px;color:var(--text-ghost);margin-left:auto}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}
