.btn-primary,.btn-primary-lg{display:inline-flex;align-items:center;justify-content:center;background:var(--green);color:#04140a;font-weight:600;border:none;border-radius:8px;text-decoration:none;transition:background .15s ease,opacity .15s ease}.btn-primary{padding:8px 16px;font-size:13px}.btn-primary-lg{padding:12px 22px;font-size:14px;width:100%}.btn-primary:hover,.btn-primary-lg:hover{background:#2dd36f}.btn-primary-lg:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border-2);border-radius:8px;padding:7px 14px;font-size:13px;transition:color .15s ease,border-color .15s ease}.btn-ghost:hover{color:var(--text);border-color:var(--text-3)}.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:transparent;border:1px solid var(--border-2);border-radius:8px;color:var(--text-2);transition:color .15s ease,border-color .15s ease}.theme-toggle:hover{color:var(--text);border-color:var(--text-3)}.route-loading{height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-3);font-size:14px}.auth-page{position:relative;min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg)}.auth-toggle{position:absolute;top:20px;right:20px}.auth-alt{font-size:13px;color:var(--text-3);text-align:center;margin-top:4px}.auth-alt a{color:var(--green);text-decoration:none;font-weight:600}.auth-alt a:hover{text-decoration:underline}.auth-card{width:100%;max-width:380px;background:var(--bg-2);border:1px solid var(--border);border-radius:16px;padding:36px 32px;display:flex;flex-direction:column;gap:14px}.auth-brand{font-size:13px;font-weight:700;letter-spacing:1px;color:var(--green);text-transform:uppercase;text-decoration:none}.auth-title{font-size:22px;font-weight:700;margin-top:4px}.auth-sub{font-size:13px;color:var(--text-3);margin-bottom:6px}.auth-label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--text-2);font-weight:500}.auth-input{background:var(--bg);border:1px solid var(--border-2);border-radius:8px;padding:10px 12px;color:var(--text);font-size:14px;outline:none;transition:border-color .15s ease}.auth-input:focus{border-color:var(--green-dim)}.auth-error{background:var(--red-bg);border:1px solid #45191c;color:var(--red);border-radius:8px;padding:9px 12px;font-size:13px}.panel-shell{display:flex;height:100%}.panel-sidebar{width:220px;flex-shrink:0;background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:20px 14px}.panel-brand{display:flex;flex-direction:column;padding:0 8px 20px}.panel-brand-title{font-size:19px;font-weight:700}.panel-brand-sub{font-size:11px;color:var(--text-3);letter-spacing:1px;text-transform:uppercase}.panel-nav{display:flex;flex-direction:column;gap:2px}.panel-nav-item{display:block;padding:9px 12px;border-radius:8px;color:var(--text-2);text-decoration:none;font-size:13.5px;transition:background .12s ease,color .12s ease}.panel-nav-item:hover{background:var(--bg-3);color:var(--text)}.panel-nav-item.active{background:var(--green-bg);color:var(--green)}.panel-main{flex:1;display:flex;flex-direction:column;min-width:0}.panel-topbar{height:56px;flex-shrink:0;border-bottom:1px solid var(--border);background:var(--bg-2);display:flex;align-items:center;justify-content:space-between;padding:0 22px}.panel-topbar-actions,.panel-user{display:flex;align-items:center;gap:10px}.panel-user-email{font-size:13px;color:var(--text-2)}.panel-role-tag{font-size:11px;padding:3px 8px;border-radius:6px;background:var(--bg-4);color:var(--text-3)}.panel-role-tag.is-admin{background:var(--green-bg);color:var(--green)}.panel-content{flex:1;overflow-y:auto;padding:28px 26px}.page-wrap{max-width:880px}.page-title{font-size:22px;font-weight:700}.page-sub{font-size:13.5px;color:var(--text-3);margin:6px 0 22px}.card-soft{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:28px;color:var(--text-2);font-size:13.5px}.badge-soon{display:inline-block;background:var(--bg-4);color:var(--blue);font-size:11px;font-weight:600;padding:3px 9px;border-radius:6px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.landing{min-height:100%;display:flex;flex-direction:column;background:radial-gradient(circle at 50% -10%,#11261c 0%,var(--bg) 55%)}.landing-header{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;max-width:1080px;width:100%;margin:0 auto}.landing-logo{font-size:20px;font-weight:700}.landing-hero{text-align:center;max-width:720px;margin:0 auto;padding:64px 24px 48px}.landing-eyebrow{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--green);font-weight:600}.landing-title{font-size:40px;font-weight:800;line-height:1.2;margin:16px 0}.landing-lead{font-size:15px;color:var(--text-2);max-width:520px;margin:0 auto 26px}.landing-cta{display:flex;justify-content:center}.landing-cta .btn-primary-lg{width:auto}.landing-features{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1000px;width:100%;margin:0 auto;padding:24px}.landing-feature{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:22px}.landing-feature h3{font-size:15px;font-weight:600;margin-bottom:8px}.landing-feature p{font-size:13px;color:var(--text-3)}.landing-footer{margin-top:auto;text-align:center;padding:28px;font-size:12px;color:var(--text-4)}.page-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.conn-new{display:flex;gap:10px;margin-bottom:20px}.conn-new .auth-input{flex:1;max-width:360px}.conn-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px;margin-top:16px}.conn-card{background:var(--bg-2);border:1px solid var(--border);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:10px}.conn-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.conn-id{font-family:var(--font-mono);font-size:14px;font-weight:600}.conn-badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:100px;white-space:nowrap}.conn-badge.st-ok{background:var(--green-bg);color:var(--green)}.conn-badge.st-warn{background:var(--warn-bg);color:var(--warn)}.conn-badge.st-info{background:var(--blue-bg);color:var(--blue)}.conn-badge.st-off{background:var(--bg-4);color:var(--text-3)}.conn-meta{display:flex;flex-direction:column;gap:2px;font-size:12px;color:var(--text-3)}.conn-actions{display:flex;gap:8px;margin-top:4px}.btn-primary-sm,.btn-danger-sm{border:none;border-radius:7px;padding:7px 14px;font-size:12.5px;font-weight:600}.btn-primary-sm{background:var(--green);color:#04140a}.btn-primary-sm:hover{background:#2dd36f}.btn-danger-sm{background:var(--red-bg);color:var(--red);border:1px solid #45191c}.btn-danger-sm:hover{background:#2a0c0c}.btn-primary-sm:disabled,.btn-danger-sm:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#000000a6;display:flex;align-items:center;justify-content:center;padding:20px;z-index:50}.modal-box{background:var(--bg-2);border:1px solid var(--border-2);border-radius:14px;padding:22px;width:100%;max-width:380px}.modal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.modal-head h3{font-size:15px;font-weight:600;font-family:var(--font-mono)}.modal-x{background:transparent;border:none;color:var(--text-3);font-size:16px}.modal-x:hover{color:var(--text)}.modal-msg{font-size:13px;color:var(--text-3);text-align:center}.qr-area{display:flex;flex-direction:column;align-items:center;gap:12px}.qr-img{width:240px;height:240px;border-radius:10px;background:#fff;padding:8px}.modal-result{text-align:center;display:flex;flex-direction:column;gap:8px;padding:12px 0}.modal-result strong{font-size:15px}.modal-result p{font-size:13px;color:var(--text-3)}.modal-result.ok strong{color:var(--green)}.modal-result.err strong{color:var(--red)}.modal-result .btn-primary,.modal-result .btn-ghost{align-self:center;margin-top:6px}.data-table{width:100%;border-collapse:collapse;background:var(--bg-2);border:1px solid var(--border);border-radius:12px;overflow:hidden;font-size:13px}.data-table th{text-align:left;padding:11px 14px;background:var(--bg-3);color:var(--text-3);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.data-table td{padding:11px 14px;border-top:1px solid var(--border);color:var(--text-2)}.data-table tbody tr:hover{background:var(--bg-3)}.row-actions{display:flex;gap:12px}.btn-link{background:transparent;border:none;color:var(--blue);font-size:12.5px;padding:0}.btn-link:hover{text-decoration:underline}.btn-link.danger{color:var(--red)}.check-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2);cursor:pointer}.check-row input{width:15px;height:15px;accent-color:var(--green)}.conn-picker{display:flex;flex-direction:column;gap:7px;max-height:150px;overflow-y:auto;background:var(--bg);border:1px solid var(--border-2);border-radius:8px;padding:10px 12px}.conn-picker-empty{font-size:12px;color:var(--text-3)}.modal-form{max-width:420px;max-height:88vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}@media(max-width:720px){.landing-title{font-size:30px}.landing-features{grid-template-columns:1fr}.panel-sidebar{width:180px}.conn-grid{grid-template-columns:1fr}}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--bg: #0a0c10;--bg-2: #0f1117;--bg-3: #161b27;--bg-4: #1c2230;--border: #1e2736;--border-2: #2a3547;--text: #e2e8f0;--text-2: #94a3b8;--text-3: #64748b;--text-4: #3d4f68;--green: #22c55e;--green-dim:#16a34a;--green-bg: #052e16;--blue: #60a5fa;--blue-bg: #0f2240;--red: #f87171;--red-bg: #1f0808}body{font-family:var(--font-sans);font-size:13.5px;line-height:1.6;background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased}.layout{display:flex;min-height:100vh}.main-col{display:flex;flex-direction:column;flex:1;min-width:0}.content{flex:1;overflow-y:auto;padding:32px 36px}.page{display:flex;flex-direction:column;gap:14px;max-width:760px}.sidebar{width:220px;background:var(--bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;padding:24px 14px;gap:24px}.sidebar-brand{display:flex;align-items:baseline;gap:8px;padding:0 6px}.brand-title{font-size:17px;font-weight:700;color:var(--green);letter-spacing:-.3px}.brand-sub{font-size:11px;color:var(--text-4);font-weight:500}.nav{display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:9px;background:none;border:none;color:var(--text-3);font-family:var(--font-sans);font-size:13px;font-weight:500;padding:8px 10px;border-radius:7px;cursor:pointer;text-align:left;width:100%;transition:background .12s,color .12s}.nav-item:hover{background:var(--bg-4);color:var(--text-2)}.nav-item.active{background:var(--green-bg);color:var(--green)}.topbar{display:flex;align-items:center;gap:16px;padding:0 24px;height:60px;background:var(--bg-2);border-bottom:1px solid var(--border);flex-shrink:0}.topbar-inputs{display:flex;align-items:center;gap:10px}.topbar-field{display:flex;flex-direction:column;gap:3px}.topbar-label{font-size:9.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-4);line-height:1}.topbar-input{background:var(--bg-4);border:1px solid var(--border-2);border-radius:6px;color:var(--text);font-family:var(--font-mono);font-size:12px;padding:5px 9px;outline:none;width:200px;transition:border-color .15s}.topbar-input::placeholder{color:var(--text-4)}.topbar-input:focus{border-color:var(--green-dim)}.topbar-divider{width:1px;height:30px;background:var(--border-2);flex-shrink:0}.token-nav-wrap{position:relative}.nav-item-alert{color:var(--red)!important}.nav-item-alert:hover{background:var(--red-bg)!important;color:var(--red)!important}.token-alert-dot{width:6px;height:6px;border-radius:50%;background:var(--red);box-shadow:0 0 5px #f8717188;margin-left:auto;flex-shrink:0}.token-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:var(--bg-3);border:1px solid var(--border-2);border-radius:9px;padding:12px 14px;display:flex;flex-direction:column;gap:8px;z-index:100;box-shadow:0 8px 24px #0005;width:270px}.token-input-row{display:flex;align-items:center;gap:6px}.token-secret-input{flex:1;font-family:var(--font-mono);letter-spacing:.05em}.btn-eye{background:var(--bg-4);border:1px solid var(--border-2);border-radius:6px;color:var(--text-3);cursor:pointer;padding:6px 8px;display:flex;align-items:center;flex-shrink:0;transition:color .12s,background .12s}.btn-eye:hover{color:var(--text-2);background:var(--border-2)}.api-status-card{display:flex;flex-direction:column;gap:2px;flex-shrink:0}.api-status-row1{display:flex;align-items:center;gap:7px}.api-status-row2{display:flex;align-items:center;gap:6px}.api-url-text{font-family:var(--font-mono);font-size:11.5px;color:var(--text-2)}.version-pill{font-family:var(--font-mono);font-size:11px;color:var(--text-4)}.status-label{font-size:10.5px;font-weight:700;letter-spacing:.07em}.status-label.online{color:var(--green)}.status-label.offline{color:var(--red)}.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--green);box-shadow:0 0 6px #22c55e88}.status-dot.offline{background:var(--red);box-shadow:0 0 6px #f8717188}.last-check{font-size:10.5px;color:var(--text-4);flex:1}.btn-reload{background:none;border:none;color:var(--text-4);cursor:pointer;padding:2px;display:flex;align-items:center;transition:color .15s}.btn-reload:hover{color:var(--text-2)}.spinning{animation:spin .7s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.card{background:var(--bg-3);border:1px solid var(--border);border-radius:10px;padding:18px 20px}.card-title{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}.action-row{margin-bottom:14px}.action-top{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.method{font-family:var(--font-mono);font-size:10.5px;font-weight:600;padding:3px 8px;border-radius:5px;flex-shrink:0}.method-get{background:var(--green-bg);color:var(--green)}.method-post{background:var(--blue-bg);color:var(--blue)}.path{font-family:var(--font-mono);font-size:12.5px;color:var(--text-2);flex:1}.input{background:var(--bg-2);border:1px solid var(--border);border-radius:7px;color:var(--text);font-family:var(--font-sans);font-size:13px;padding:8px 11px;outline:none;width:100%;transition:border-color .15s}.input::placeholder{color:var(--text-4)}.input:focus{border-color:var(--green-dim)}.input-small{width:70px;flex-shrink:0}.textarea{resize:vertical;font-family:var(--font-sans);line-height:1.6}.fields{display:flex;flex-direction:column;gap:10px;margin-bottom:12px}.btn-primary{background:var(--green);color:#050f09;border:none;border-radius:7px;font-family:var(--font-sans);font-size:13px;font-weight:600;padding:8px 18px;cursor:pointer;flex-shrink:0;transition:opacity .15s}.btn-primary:disabled{opacity:.45;cursor:not-allowed}.btn-primary:hover:not(:disabled){opacity:.85}.btn-secondary{background:var(--bg-4);color:var(--text-2);border:1px solid var(--border-2);border-radius:7px;font-family:var(--font-sans);font-size:13px;padding:8px 14px;cursor:pointer;flex-shrink:0;transition:background .12s}.btn-secondary:hover{background:var(--border-2)}.btn-danger{background:#3b0a0a;color:var(--red);border:1px solid #6b1a1a;border-radius:7px;font-family:var(--font-sans);font-size:13px;font-weight:600;padding:8px 16px;cursor:pointer;flex-shrink:0;transition:opacity .15s}.btn-danger:hover{opacity:.85}.btn-toggle{display:flex;align-items:center;gap:8px;background:var(--bg-4);color:var(--text-2);border:1px solid var(--border-2);border-radius:7px;font-family:var(--font-sans);font-size:12.5px;font-weight:500;padding:7px 14px;cursor:pointer;transition:background .12s,color .12s}.btn-toggle.active{background:var(--green-bg);color:var(--green);border-color:var(--green-dim)}.btn-toggle:hover{background:var(--border-2)}.logs-toolbar{display:flex;flex-direction:column;gap:10px;margin-bottom:14px}.auto-toggle{display:flex}.polling-badge{font-family:var(--font-mono);font-size:10.5px;background:var(--green-bg);color:var(--green);padding:2px 8px;border-radius:20px;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.45}}.file-row{display:flex;align-items:center;gap:12px}.file-name{font-size:12px;color:var(--text-3);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.response-box{margin:0;padding:12px 14px;border-radius:8px;font-family:var(--font-mono);font-size:12px;line-height:1.7;overflow-x:auto;white-space:pre-wrap;word-break:break-all}.response-success{background:var(--green-bg);color:#86efac;border:1px solid #14532d}.response-error{background:var(--red-bg);color:#fca5a5;border:1px solid #7f1d1d}.logs-box{background:var(--bg-2);color:var(--text-3);border:1px solid var(--border);max-height:600px;overflow-y:auto}.qr-wrap{text-align:center;padding:20px 0 10px}.qr-img{width:196px;height:196px;border-radius:10px;border:3px solid var(--green)}.qr-hint{font-size:12px;color:var(--text-3);margin-top:10px}.version-tag{font-family:var(--font-mono);font-size:12px;color:var(--green);margin-bottom:10px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--bg: #0a0c10;--bg-2: #0f1117;--bg-3: #161b27;--bg-4: #1c2230;--border: #1e2736;--border-2: #2a3547;--text: #e2e8f0;--text-2: #94a3b8;--text-3: #64748b;--green: #22c55e;--green-dim:#16a34a;--green-bg: #052e16;--blue: #60a5fa;--blue-bg: #0f2240;--warn: #fbbf24;--warn-bg: #3a2a06;--red: #f87171;--red-bg: #1f0808}:root[data-theme=light]{--bg: #f1f5f9;--bg-2: #ffffff;--bg-3: #f8fafc;--bg-4: #eef2f7;--border: #e2e8f0;--border-2: #cbd5e1;--text: #0f172a;--text-2: #475569;--text-3: #64748b;--green: #16a34a;--green-dim:#15803d;--green-bg: #dcfce7;--blue: #2563eb;--blue-bg: #dbeafe;--warn: #b45309;--warn-bg: #fef3c7;--red: #dc2626;--red-bg: #fee2e2}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:14px;line-height:1.6;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;transition:background-color .2s ease,color .2s ease}a{color:inherit}button{font-family:inherit;cursor:pointer}input,button,textarea{font-family:inherit}
