:root{--bg:#f7f7f4;--panel:#fff;--panel-muted:#f0f4f7;--text:#182026;--muted:#66717b;--line:#d9e0e5;--accent:#0f766e;--accent-strong:#0b5f59;--danger:#b42318;--ok:#15803d;--warn:#b91c1c}*{box-sizing:border-box}body{background:var(--bg);color:var(--text);margin:0;font-family:Arial,Helvetica,sans-serif}button,input,select{font:inherit}.shell{grid-template-columns:240px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);color:#fff;background:#101820;padding:20px 16px}.brand{color:#fff;align-items:center;gap:10px;margin-bottom:28px;font-size:20px;font-weight:700;text-decoration:none;display:inline-flex}.brand img{object-fit:cover;border-radius:8px;width:34px;height:34px}.nav{gap:8px;display:grid}.nav a,.nav-button{color:#d6dee5;border-radius:6px;align-items:center;gap:10px;padding:10px 12px;text-decoration:none;display:flex}.nav-button{cursor:pointer;background:0 0;border:0;width:100%}.nav a:hover,.nav-button:hover{color:#fff;background:#ffffff14}.content{padding:24px}.topbar{justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.page-title{margin:0;font-size:24px;line-height:1.2}.subtle{color:var(--muted);margin-top:4px;font-size:13px}.loading-line{color:var(--muted)}.filters{flex-wrap:wrap;align-items:end;gap:10px;margin-bottom:18px;display:flex}.form-row{flex-wrap:wrap;align-items:end;gap:10px;padding:14px 16px;display:flex}.field{flex-direction:column;gap:6px;min-width:0;display:flex}.field label{color:var(--muted);min-height:16px;font-size:13px;line-height:16px}.field input,.field select{border:1px solid var(--line);background:#fff;border-radius:6px;width:100%;min-width:0;height:38px;padding:8px 10px}.field-wide{min-width:min(420px,100%)}.field-wide select{width:100%}.multi-select{min-height:132px}.filter-actions{align-items:end;min-height:60px;display:flex}.check-field{min-height:38px;color:var(--text);align-items:center;gap:8px;font-size:14px;display:flex}.check-field input[type=checkbox]{width:16px;min-width:0;height:16px;min-height:0;accent-color:var(--accent);border-radius:3px;flex:none;margin:0;padding:0}.check-option{color:var(--text);align-items:flex-start;gap:10px;font-size:14px;line-height:1.25;display:inline-flex}.check-option input[type=checkbox]{width:16px;min-width:0;height:16px;min-height:0;accent-color:var(--accent);border-radius:3px;flex:none;margin:2px 0 0;padding:0}.check-option span{gap:2px;display:grid}.check-option strong{font-weight:600}.check-option small{color:var(--muted);font-size:12px}.button{color:#fff;background:var(--accent);cursor:pointer;border:0;border-radius:6px;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:8px 12px;display:inline-flex}.button:hover{background:var(--accent-strong)}.button.secondary{color:var(--text);background:#e8edf0}.button.secondary:hover{background:#dbe3e8}.button.danger{color:#fff;background:var(--danger)}.button.danger:hover{background:#951d12}.badge{text-transform:uppercase;letter-spacing:.04em;border-radius:999px;margin-left:8px;padding:2px 6px;font-size:11px;font-weight:700;display:inline-block}.badge-warn{color:#7f1d1d;background:#fee2e2}.badge-ok{color:#14532d;background:#dcfce7}.spin{animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.test-banner{border-radius:6px;align-items:flex-start;gap:10px;padding:10px 12px;font-size:13px;line-height:1.4;display:flex}.test-banner code{background:#0000000f;border-radius:3px;padding:1px 5px}.test-banner-running{background:var(--panel-muted);color:var(--muted)}.test-banner-ok{color:#14532d;background:#dcfce7}.test-banner-error{color:#7f1d1d;background:#fee2e2}.spacer{flex:1}.muted{color:var(--muted)}.empty-row{text-align:center;color:var(--muted);padding:24px}.hint{color:var(--muted);font-size:12px}.metrics{grid-template-columns:repeat(4,minmax(160px,1fr));gap:12px;margin-bottom:18px;display:grid}.tenant-card-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;display:grid}.tenant-card{min-height:144px;color:var(--text);background:var(--panel);border:1px solid var(--line);border-radius:8px;gap:8px;padding:18px;text-decoration:none;display:grid;position:relative}.tenant-card:hover{border-color:#9fb3c1}.tenant-card strong{font-size:18px}.tenant-card span{color:var(--muted);font-size:13px}.tenant-card em{color:var(--muted);align-self:end;font-size:13px;font-style:normal}.status-dot{border-radius:50%;width:11px;height:11px;position:absolute;top:14px;right:14px}.status-dot.active{background:var(--ok);animation:1.8s infinite pulse-ok;box-shadow:0 0 #15803d80}.status-dot.inactive{background:var(--warn);animation:1.8s infinite pulse-warn;box-shadow:0 0 #b91c1c73}@keyframes pulse-ok{70%{box-shadow:0 0 0 8px #15803d00}to{box-shadow:0 0 #15803d00}}@keyframes pulse-warn{70%{box-shadow:0 0 0 8px #b91c1c00}to{box-shadow:0 0 #b91c1c00}}.metric{background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:14px}.metric span{color:var(--muted);font-size:13px}.metric strong{margin-top:8px;font-size:22px;display:block}.panel{background:var(--panel);border:1px solid var(--line);border-radius:8px;overflow:hidden}.section-gap{margin-bottom:16px}.panel-title{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;font-weight:700;display:flex}.panel-title .subtle{margin-top:0;font-weight:500}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--line);text-align:left;padding:10px 12px;font-size:14px}th{color:var(--muted);background:var(--panel-muted);font-weight:600}th.num,td.num{text-align:right;font-variant-numeric:tabular-nums}.status-pill{border-radius:6px;align-items:center;gap:6px;min-height:26px;padding:4px 8px;font-size:13px;font-weight:700;display:inline-flex}.status-pill.active{color:#14532d;background:#dcfce7}.status-pill.inactive{color:#7f1d1d;background:#fee2e2}.row-actions{flex-wrap:wrap;gap:8px;display:flex}.login-page{place-items:center;min-height:100vh;padding:20px;display:grid}.login-box{background:var(--panel);border:1px solid var(--line);border-radius:8px;width:min(380px,100%);padding:22px}.login-brand{align-items:center;gap:12px;margin-bottom:20px;display:flex}.login-brand img{object-fit:cover;border-radius:10px;width:44px;height:44px}.login-box h1{margin:0;font-size:22px}.login-box form{gap:14px;display:grid}.error{color:var(--danger);font-size:14px}.back-link{color:var(--muted);align-items:center;gap:4px;margin-bottom:4px;font-size:13px;text-decoration:none;display:inline-flex}.back-link:hover{color:var(--accent-strong);text-decoration:underline}.dot-sep{margin-left:4px}.saved-flash{color:var(--accent-strong);background:#dcfce7;border:1px solid #bbf7d0;border-radius:999px;align-self:center;padding:4px 10px;font-size:12px;font-weight:600}.system-pill{border:1px solid var(--line);min-height:32px;color:var(--muted);white-space:nowrap;background:#fff;border-radius:999px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:700;display:inline-flex}.system-pill.ok{color:#14532d;background:#dcfce7;border-color:#bbf7d0}.system-pill.danger{color:#7f1d1d;background:#fee2e2;border-color:#fecaca}.system-pill.muted-pill{background:var(--panel-muted)}.page-tabs{border-bottom:1px solid var(--line);gap:2px;margin-bottom:14px;display:flex}.page-tabs .tab{color:var(--muted);cursor:pointer;background:0 0;border:0;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 14px;font-size:14px;font-weight:600;display:inline-flex}.page-tabs .tab:hover:not(:disabled){color:var(--text)}.page-tabs .tab.active{color:var(--accent-strong);border-bottom-color:var(--accent)}.page-tabs .tab:disabled{cursor:not-allowed;opacity:.5}.editor-panel{padding:20px}.editor-grid{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px 24px;max-width:800px;display:grid}.editor-grid .field>input{width:100%}.editor-grid .check-option{margin-top:4px}.editor-check{grid-column:1/-1}.inline-error{color:#7f1d1d;background:#fee2e2;border-radius:6px;padding:10px 12px;font-size:13px}.xl-modal-overlay{z-index:60;background:#0f172094;justify-content:center;align-items:center;padding:28px;display:flex;position:fixed;inset:0}.xl-modal{background:var(--panel);border:1px solid #d9e0e5e6;border-radius:12px;flex-direction:column;width:min(1280px,100vw - 56px);max-height:calc(100vh - 56px);display:flex;overflow:hidden;box-shadow:0 24px 70px #00000047}.xl-modal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:18px;padding:18px 22px;display:flex}.xl-modal-header h2{margin:0;font-size:18px;line-height:1.25}.xl-modal-header p{color:var(--muted);margin:4px 0 0;font-size:13px}.connector-form{flex-direction:column;flex:1;min-height:0;display:flex}.xl-modal-body{flex:1;gap:16px;padding:20px 22px;display:grid;overflow:auto}.xl-modal-footer{border-top:1px solid var(--line);background:var(--panel-muted);align-items:center;gap:8px;padding:14px 22px;display:flex}.connector-grid{grid-template-columns:repeat(12,minmax(0,1fr));align-items:start;gap:16px;display:grid}.connector-grid .field>input{width:100%;min-width:0}.connector-id,.connector-type,.connector-port{grid-column:span 2}.connector-name,.connector-database,.connector-user,.connector-socks,.connector-interval,.connector-active{grid-column:span 3}.connector-host{grid-column:span 5}.connector-password{grid-column:span 4}.connector-port input{text-align:right}.connector-active{align-self:end;min-height:38px}.ds-panel{gap:16px;display:grid}.ds-toolbar{justify-content:space-between;align-items:center;gap:16px;display:flex}.ds-form{gap:14px;padding:14px 16px;display:grid}.ds-form .panel-title{margin:-14px -16px 4px}.ds-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.ds-form-actions{align-items:center;gap:8px;display:flex}.ds-table{table-layout:auto;width:100%}.ds-table th,.ds-table td{vertical-align:middle}.ds-conn{gap:2px;min-width:220px;display:grid}.ds-conn-host{font-family:var(--mono,ui-monospace, SFMono-Regular, Menlo, monospace);font-size:13px}.ds-conn-port{color:var(--muted)}.ds-conn-meta{color:var(--muted);flex-wrap:wrap;gap:12px;font-size:12px;display:flex}.ds-conn-label{text-transform:uppercase;letter-spacing:.04em;opacity:.7;margin-right:2px;font-size:10px}.ds-actions-col{white-space:nowrap;width:1%}.ds-actions{flex-wrap:nowrap;justify-content:flex-end}.button.icon-only{padding:6px 8px}.button.icon-only span{display:none}@media (max-width:980px){.editor-grid,.connector-grid{grid-template-columns:1fr}.connector-id,.connector-name,.connector-type,.connector-host,.connector-port,.connector-database,.connector-user,.connector-password,.connector-socks,.connector-interval,.connector-active,.editor-check{grid-column:1/-1}}@media (max-width:720px){.xl-modal-overlay{align-items:stretch;padding:10px}.xl-modal{width:100%;max-height:calc(100vh - 20px)}.xl-modal-header,.xl-modal-body,.xl-modal-footer{padding-left:14px;padding-right:14px}.xl-modal-footer{flex-wrap:wrap}}.filter-card{background:var(--panel);border:1px solid var(--line);border-radius:8px;margin-bottom:18px;padding:14px 16px}.filter-grid{grid-template-columns:180px 180px minmax(280px,1fr);align-items:start;gap:14px;display:grid}.field-grow{min-width:0}@media (max-width:820px){.filter-grid{grid-template-columns:1fr 1fr}.field-grow{grid-column:1/-1}}.typeahead-field{gap:6px;display:grid}.typeahead-label{color:var(--muted);font-size:13px}.typeahead{position:relative}.typeahead-control{border:1px solid var(--line);cursor:text;background:#fff;border-radius:6px;flex-wrap:wrap;align-items:center;gap:6px;min-height:38px;padding:5px 36px 5px 32px;display:flex;position:relative}.typeahead.open .typeahead-control,.typeahead-control:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px #0f766e1f}.typeahead-icon{color:var(--muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.typeahead-clear{width:22px;height:22px;color:var(--muted);cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:6px;transform:translateY(-50%)}.typeahead-clear:hover{color:var(--text);background:#eef2f5}.typeahead-input{background:0 0;border:0;outline:none;flex:120px;min-width:80px;padding:4px 0;font-size:14px}.chip{max-width:260px;color:var(--accent-strong);background:#e6f4f1;border-radius:999px;align-items:center;gap:4px;padding:3px 4px 3px 10px;font-size:13px;line-height:1.2;display:inline-flex}.chip-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.chip-remove{width:18px;height:18px;color:var(--accent-strong);cursor:pointer;background:0 0;border:0;border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.chip-remove:hover{background:#0f766e2e}.typeahead-dropdown{border:1px solid var(--line);z-index:30;background:#fff;border-radius:8px;max-height:280px;padding:4px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:auto;box-shadow:0 8px 24px #0f17201f}.typeahead-option{cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:8px 10px;font-size:14px;display:flex}.typeahead-option.active,.typeahead-option:hover{background:var(--panel-muted)}.typeahead-option-label{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.typeahead-option-hint{color:var(--muted);white-space:nowrap;font-size:12px}.typeahead-empty{color:var(--muted);text-align:center;padding:12px;font-size:14px}.typeahead-footer{margin-top:2px}@media (max-width:820px){.shell{grid-template-columns:1fr}.sidebar{border-right:0;border-bottom:1px solid var(--line)}.metrics{grid-template-columns:1fr 1fr}}@media (max-width:520px){.metrics{grid-template-columns:1fr}.content{padding:16px}}
