*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0f;--bg-surface:#13131a;--bg-card:#1a1a24;--bg-hover:#22222e;--border:#2a2a3a;--border-light:#333345;--accent:#6366f1;--accent-hover:#7c7ff5;--accent-dim:#6366f126;--text:#e8e8f0;--text-muted:#6b6b8a;--text-dim:#44445a;--success:#22c55e;--warning:#f59e0b;--danger:#ef4444;--info:#38bdf8;--internal:#a855f7;--sidebar-w:220px;--bg2:var(--bg-surface);--bg3:var(--bg-hover);--text2:var(--text);--text3:var(--text-muted);--radius-lg:10px}[data-theme=light]{--bg:#f0f0f7;--bg-surface:#fff;--bg-card:#f7f7fc;--bg-hover:#eaeaf4;--border:#d0d0e4;--border-light:#c0c0d8;--accent-dim:#6366f11f;--text:#1a1a2e;--text-muted:#6060a0;--text-dim:#9090b8}#root,body,html{background:#0a0a0f;background:var(--bg);color:#e8e8f0;color:var(--text);font-family:Inter,system-ui,-apple-system,sans-serif;font-size:14px;line-height:1.5;min-height:100%;transition:background .2s,color .2s}.login-title,.page-title,.sidebar-logo-name,.syne,.tool-name,.tools-title{font-family:Syne,system-ui,sans-serif}.hidden{display:none!important}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-thumb{background:#2a2a3a;background:var(--border);border-radius:3px}.badge{align-items:center;border-radius:99px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;letter-spacing:.04em;padding:2px 8px;text-transform:uppercase}.badge-accent{background:#6366f12e;border:1px solid #6366f159;color:#7c7ff5;color:var(--accent-hover)}.badge-success{background:#22c55e26;border:1px solid #22c55e4d;color:#22c55e;color:var(--success)}.badge-warning{background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b;color:var(--warning)}.badge-danger{background:#ef444426;border:1px solid #ef44444d;color:#ef4444;color:var(--danger)}.badge-muted{background:#6b6b8a1f;border:1px solid #6b6b8a40;color:#6b6b8a;color:var(--text-muted)}.badge-internal{background:#a855f726;border:1px solid #a855f74d;color:#a855f7;color:var(--internal)}.badge-info{background:#38bdf81f;border:1px solid #38bdf840;color:#38bdf8;color:var(--info)}.btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:600;gap:7px;justify-content:center;padding:9px 16px;transition:background .15s,opacity .15s,transform .1s;white-space:nowrap}.btn:active{transform:scale(.98)}.btn-primary{background:#6366f1;background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:#7c7ff5;background:var(--accent-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-ghost{background:#0000;border:1px solid #2a2a3a;border:1px solid var(--border);color:#6b6b8a;color:var(--text-muted);padding:7px 14px}.btn-ghost:hover{background:#1a1a24;background:var(--bg-card);color:#e8e8f0;color:var(--text)}.btn-danger{background:#ef444426;border:1px solid #ef44444d;color:#ef4444;color:var(--danger)}.btn-danger:hover{background:#ef444440}.btn-sm{font-size:12px;padding:5px 10px}.btn-icon{border-radius:6px;padding:7px}.form-group{margin-bottom:14px}.form-label{color:#6b6b8a;color:var(--text-muted);display:block;font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:5px;text-transform:uppercase}.form-input,.form-select{background:#1a1a24;background:var(--bg-card);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:8px;color:#e8e8f0;color:var(--text);font-family:inherit;font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.form-input:focus,.form-select:focus{border-color:#6366f1;border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.form-input::placeholder{color:#6b6b8a;color:var(--text-muted)}.form-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.field-label{color:#6b6b8a;color:var(--text-muted);display:block;font-size:12px;font-weight:600;letter-spacing:.06em;margin-bottom:5px;text-transform:uppercase}.field-input{background:#1a1a24;background:var(--bg-card);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:8px;color:#e8e8f0;color:var(--text);font-family:inherit;font-size:13px;outline:none;padding:9px 12px;transition:border-color .15s,box-shadow .15s;width:100%}.field-input:focus{border-color:#6366f1;border-color:var(--accent);box-shadow:0 0 0 3px #6366f133}.field-input::placeholder{color:#6b6b8a;color:var(--text-muted)}.spinner{animation:spin .7s linear infinite;border:2px solid #fff3;border-radius:50%;border-top:2px solid var(--accent);display:inline-block;height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.toast-container{bottom:24px;display:flex;flex-direction:column;gap:8px;position:fixed;right:24px;z-index:8000}.toast{animation:toastIn .2s ease;background:#1a1a24;background:var(--bg-card);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:10px;box-shadow:0 8px 32px #00000080;color:#e8e8f0;color:var(--text);font-size:13px;max-width:360px;padding:12px 16px}.toast.success{border-color:#22c55e66;color:#22c55e;color:var(--success)}.toast.error{border-color:#ef444466;color:#ef4444;color:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.screen-login{align-items:center;background:radial-gradient(ellipse 60% 50% at 50% -10%,#6366f12e 0,#0000 70%),#0a0a0f;background:radial-gradient(ellipse 60% 50% at 50% -10%,#6366f12e 0,#0000 70%),var(--bg);display:flex;justify-content:center;min-height:100vh;padding:24px}.login-card{background:#13131a;background:var(--bg-surface);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:16px;box-shadow:0 24px 64px #0009;max-width:400px;padding:40px 36px;width:100%}.login-logo{gap:10px;margin-bottom:28px}.login-logo,.login-logo-icon{align-items:center;display:flex}.login-logo-icon{background:linear-gradient(135deg,#6366f1,#818cf8);background:linear-gradient(135deg,var(--accent),#818cf8);border-radius:10px;flex-shrink:0;height:38px;justify-content:center;width:38px}.login-logo-text{font-size:18px;font-weight:700;letter-spacing:-.02em}.login-logo-sub{color:#6b6b8a;color:var(--text-muted);font-size:11px;font-weight:500;letter-spacing:.06em;margin-top:1px;text-transform:uppercase}.login-title{font-size:22px;font-weight:700;letter-spacing:-.02em;margin-bottom:6px}.login-subtitle{color:#6b6b8a;color:var(--text-muted);font-size:13px;margin-bottom:28px}.login-error{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#ef4444;color:var(--danger);font-size:13px;margin-top:12px;padding:10px 14px}.login-redirect-hint{background:#5b6af01f;border:1px solid #5b6af04d;border-radius:8px;color:#6b6b8a;color:var(--text-muted);font-size:12px;margin-top:12px;padding:10px 12px;text-align:center}.screen-app{display:flex;min-height:100vh}.sidebar{background:linear-gradient(180deg,#13131a,#0e0e17);background:linear-gradient(180deg,var(--bg-surface) 0,#0e0e17 100%);border-right:1px solid #2a2a3a;border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;width:220px;width:var(--sidebar-w);z-index:100}.sidebar-logo{align-items:center;border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border);display:flex;gap:10px;padding:20px 16px 16px}.sidebar-logo-name{font-size:15px;font-weight:700;letter-spacing:-.01em}.sidebar-logo-tag{color:#6b6b8a;color:var(--text-muted);font-size:10px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.sidebar-nav{flex:1 1;overflow-y:auto;padding:12px 8px}.nav-section-title{color:#44445a;color:var(--text-dim);font-size:10px;font-weight:700;letter-spacing:.08em;margin-top:4px;padding:8px 8px 4px;text-transform:uppercase}.nav-item{align-items:center;border-radius:8px;color:#6b6b8a;color:var(--text-muted);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;margin-bottom:2px;padding:9px 10px;text-decoration:none;transition:background .12s,color .12s;white-space:nowrap}.nav-item:hover{background:#22222e;background:var(--bg-hover);color:#e8e8f0;color:var(--text)}.nav-item.active{background:#6366f126;background:var(--accent-dim);color:#7c7ff5;color:var(--accent-hover)}.nav-item .nav-icon{flex-shrink:0;opacity:.7;width:16px}.nav-item.active .nav-icon{opacity:1}.sidebar-footer{border-top:1px solid #2a2a3a;border-top:1px solid var(--border);padding:12px 12px 16px}.sidebar-user{align-items:center;background:#1a1a24;background:var(--bg-card);border-radius:8px;cursor:pointer;display:flex;gap:10px;margin-bottom:8px;padding:8px;transition:background .15s}.sidebar-user:hover{background:#22222e;background:var(--bg-hover)}.user-avatar{align-items:center;background:#6366f126;background:var(--accent-dim);background-position:50%;background-size:cover;border:1px solid #6366f1;border:1px solid var(--accent);border-radius:50%;color:#7c7ff5;color:var(--accent-hover);display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:30px;justify-content:center;width:30px}.user-info{flex:1 1;min-width:0}.user-name{color:#e8e8f0;color:var(--text);font-size:12px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#6b6b8a;color:var(--text-muted);font-size:11px}.app-main{display:flex;flex:1 1;flex-direction:column;margin-left:220px;margin-left:var(--sidebar-w);min-height:100vh}.page-header{background:#13131a;background:var(--bg-surface);border-bottom:1px solid #2a2a3a;border-bottom:1px solid var(--border);padding:28px 32px 0}.page-title{font-size:20px;font-weight:700;letter-spacing:-.02em;margin-bottom:4px}.page-subtitle{color:#6b6b8a;color:var(--text-muted);font-size:13px;margin-bottom:20px}.page-content{flex:1 1;padding:28px 32px}.tools-header{align-items:flex-end;display:flex;justify-content:space-between;margin-bottom:24px}.tools-title{font-size:18px;font-weight:700;letter-spacing:-.01em}.tools-sub{color:#6b6b8a;color:var(--text-muted);font-size:13px;margin-top:3px}.tool-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}.tool-card{background:#13131a;background:var(--bg-surface);border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:14px;cursor:pointer;overflow:hidden;padding:20px;position:relative;transition:border-color .15s,transform .12s,box-shadow .15s}.tool-card:before{background:#6366f1;background:var(--card-accent,var(--accent));content:"";inset:0;opacity:0;pointer-events:none;position:absolute;transition:opacity .15s}.tool-card:hover:before{opacity:.03}.tool-card:hover{border-color:#333345;border-color:var(--border-light);box-shadow:0 6px 24px #0000004d;transform:translateY(-1px)}.tool-card.locked{cursor:default;opacity:.65}.tool-card.locked:hover{box-shadow:none;transform:none}.tool-card.locked:hover:before{opacity:0}.tool-card-top{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:14px}.tool-icon{align-items:center;border-radius:12px;display:flex;font-size:20px;height:44px;justify-content:center;width:44px}.tool-dot{border-radius:50%;height:8px;margin-top:4px;width:8px}.dot-active{background:#22c55e;background:var(--success);box-shadow:0 0 6px #22c55e80}.dot-locked{background:#44445a;background:var(--text-dim)}.dot-soon{background:#f59e0b;background:var(--warning)}.dot-live{animation:livePulse 2s ease-in-out infinite;background:#22c55e;box-shadow:0 0 7px #22c55e99}.dot-degraded{background:#f59e0b;box-shadow:0 0 7px #f59e0b80}.dot-down{background:#ef4444;box-shadow:0 0 7px #ef444480}@keyframes livePulse{0%,to{box-shadow:0 0 5px #22c55e80}50%{box-shadow:0 0 12px #22c55ee6}}.tool-name{font-size:15px;font-weight:700;margin-bottom:6px}.tool-desc{color:#6b6b8a;color:var(--text-muted);font-size:12px;line-height:1.55;margin-bottom:12px}.tool-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:12px}.tool-footer{align-items:center;display:flex;justify-content:space-between}.tool-action{color:#6b6b8a;color:var(--text-muted);font-size:12px;font-weight:600}.tool-card:not(.locked):hover .tool-action{color:#7c7ff5;color:var(--accent-hover)}.mod-pill{border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.04em;padding:2px 8px;text-transform:uppercase}.mod-prod{background:#22c55e26;border:1px solid #22c55e4d;color:#22c55e;color:var(--success)}.mod-qual{background:#f59e0b26;border:1px solid #f59e0b4d;color:#f59e0b;color:var(--warning)}.mod-dev{background:#38bdf81f;border:1px solid #38bdf840;color:#38bdf8;color:var(--info)}.skeleton{animation:pulse 1.5s ease-in-out infinite;background:#1a1a24;background:var(--bg-card);border-radius:6px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.theme-toggle{align-items:center;background:none;border:1px solid #2a2a3a;border:1px solid var(--border);border-radius:8px;color:#6b6b8a;color:var(--text-muted);cursor:pointer;display:flex;font-size:12px;gap:5px;padding:5px 8px;transition:border-color .15s,color .15s}.theme-toggle:hover{border-color:#6366f1;border-color:var(--accent);color:#6366f1;color:var(--accent)}.stub-card{background:#13131a;background:var(--bg-surface);border:1px dashed #2a2a3a;border:1px dashed var(--border);border-radius:14px;margin:40px auto;max-width:560px;padding:60px 32px;text-align:center}.stub-icon{font-size:40px;margin-bottom:12px}.stub-title{font-size:18px;font-weight:700;margin-bottom:6px}.stub-desc{color:#6b6b8a;color:var(--text-muted);font-size:13px;line-height:1.6}@media (max-width:768px){.sidebar{transform:translateX(-100%);transition:transform .25s}.app-main{margin-left:0}.form-row,.tool-grid{grid-template-columns:1fr}}
/*# sourceMappingURL=main.7546e74b.css.map*/