:root{--bg-dark: #1a1b26;--bg-card: #1f2335;--bg-input: #24283b;--bg-hover: #292e42;--border-color: #3b4261;--text-primary: #c0caf5;--text-secondary: #7982a9;--text-muted: #565f89;--accent: #7aa2f7;--accent-hover: #89b4fa;--accent-glow: rgba(122, 162, 247, .3);--success: #9ece6a;--error: #f7768e;--warning: #e0af68;--purple: #bb9af7;--cyan: #7dcfff;--sidebar-width: 280px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--glass-bg: rgba(31, 35, 53, .8);--glass-border: rgba(59, 66, 97, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-dark);color:var(--text-primary);line-height:1.5}#root{min-height:100vh}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1b26,#24283b,#1a1b26);padding:20px;position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 30%,rgba(122,162,247,.08) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(187,154,247,.06) 0%,transparent 50%);animation:gradientMove 20s ease-in-out infinite}@keyframes gradientMove{0%,to{transform:translate(0)}50%{transform:translate(-5%,-5%)}}.login-container{width:100%;max-width:400px;position:relative;z-index:1}.login-card{background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:48px 40px;box-shadow:0 25px 50px -12px #0006,0 0 0 1px #7aa2f71a}.login-header{text-align:center;margin-bottom:36px}.logo-wrapper{width:72px;height:72px;background:linear-gradient(135deg,var(--accent),var(--purple));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;box-shadow:0 8px 32px #7aa2f74d}.login-header h1{font-size:28px;font-weight:700;margin-bottom:8px}.login-header p{color:var(--text-secondary);font-size:14px}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 18px;font-size:15px;color:var(--text-primary);transition:all .25s ease}.form-group input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:var(--bg-hover)}.form-group input::placeholder{color:var(--text-muted)}.form-group input:hover:not(:focus){border-color:var(--text-muted)}.error-alert{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:var(--error);font-size:14px}.login-footer{margin-top:24px;text-align:center}.login-footer p{color:var(--text-muted);font-size:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 24px;font-size:14px;font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .25s ease;letter-spacing:.3px}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--purple));color:#1a1b26;box-shadow:0 4px 16px #7aa2f74d}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #7aa2f766}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-secondary{background:var(--bg-input);border:1px solid var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}.btn-danger{background:#f7768e26;border:1px solid rgba(247,118,142,.3);color:var(--error)}.btn-danger:hover:not(:disabled){background:var(--error);border-color:var(--error);color:#1a1b26;box-shadow:0 4px 16px #f7768e4d}.btn-ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-muted);color:var(--text-primary)}.btn-full{width:100%}.btn-loading{display:flex;align-items:center;gap:8px}.spinner{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}.sidebar-header{padding:28px 24px;border-bottom:1px solid var(--glass-border)}.sidebar-logo{display:flex;align-items:center;gap:14px;font-size:22px;font-weight:700;color:var(--text-primary)}.sidebar-logo svg{background:linear-gradient(135deg,var(--accent),var(--purple));padding:8px;border-radius:var(--radius-md);box-shadow:0 4px 16px #7aa2f740}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.nav-btn{display:flex;align-items:center;gap:14px;width:100%;padding:14px 18px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:all .25s ease}.nav-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-btn.active{background:linear-gradient(135deg,#7aa2f726,#bb9af71a);color:var(--accent);box-shadow:inset 0 0 0 1px #7aa2f733}.nav-btn.active svg{filter:drop-shadow(0 0 4px rgba(122,162,247,.5))}.sidebar-footer{padding:16px;border-top:1px solid var(--border-color);display:flex;align-items:center;justify-content:space-between}.user-info{display:flex;align-items:center;gap:10px;font-size:14px}.user-avatar{width:36px;height:36px;background:var(--bg-input);border-radius:8px;display:flex;align-items:center;justify-content:center}.logout-btn{width:36px;height:36px;background:transparent;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.logout-btn:hover{background:#ef44441a;border-color:var(--error);color:var(--error)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:32px;min-height:100vh}.view{max-width:1200px;margin:0 auto}.view-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:32px}.view-header h1{font-size:28px;font-weight:700;margin-bottom:4px}.view-subtitle{color:var(--text-secondary);font-size:14px}.view-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:var(--text-secondary);gap:16px}.view-loading .spinner{width:32px;height:32px;border-width:3px;border-top-color:var(--accent)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:32px}.stat-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;display:flex;align-items:flex-start;gap:18px;transition:all .25s ease}.stat-card:hover{transform:translateY(-2px);border-color:#7aa2f74d;box-shadow:0 12px 40px #00000026}.stat-icon{width:52px;height:52px;background:linear-gradient(135deg,#7aa2f726,#7aa2f70d);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--accent);box-shadow:0 0 0 1px #7aa2f733}.stat-success .stat-icon{background:linear-gradient(135deg,#9ece6a26,#9ece6a0d);color:var(--success);box-shadow:0 0 0 1px #9ece6a33}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:700;line-height:1.2}.stat-label{font-size:14px;color:var(--text-secondary)}.card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:24px;transition:all .25s ease}.card:hover{border-color:#7aa2f74d;box-shadow:0 8px 32px #0003}.card-header{padding:20px 24px;border-bottom:1px solid var(--border-color)}.card-header h3{font-size:16px;font-weight:600;display:flex;align-items:center;gap:10px}.card-header h3 svg{color:var(--text-secondary)}.card-body{padding:24px}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media (max-width: 900px){.grid-2{grid-template-columns:1fr}}.upstream-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}.upstream-item{display:flex;flex-direction:column;gap:4px}.upstream-item .label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.upstream-item .value{font-size:16px;font-weight:600}.model-list{display:flex;flex-direction:column;gap:16px}.model-item{display:flex;flex-direction:column;gap:8px}.model-info{display:flex;justify-content:space-between;align-items:center}.model-name{font-size:14px;font-weight:500}.model-count{font-size:12px;color:var(--text-secondary)}.model-bar{height:6px;background:var(--bg-input);border-radius:3px;overflow:hidden}.model-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),#8b5cf6);border-radius:3px;transition:width .3s}.chart-bars{display:flex;align-items:flex-end;justify-content:space-between;height:150px;gap:4px;padding-top:20px}.chart-bar-container{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.chart-bar{width:100%;max-width:24px;background:linear-gradient(180deg,var(--accent),#8b5cf6);border-radius:4px 4px 0 0;min-height:4px;position:relative;margin-top:auto}.chart-tooltip{position:absolute;top:-24px;left:50%;transform:translate(-50%);font-size:10px;color:var(--text-secondary);opacity:0;transition:opacity .2s}.chart-bar:hover .chart-tooltip{opacity:1}.chart-label{font-size:10px;color:var(--text-muted);margin-top:8px}.text-muted{color:var(--text-muted);font-size:14px}.table-container{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}th{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}td{font-size:14px}tr:hover td{background:var(--bg-hover)}.badge{display:inline-flex;align-items:center;padding:4px 10px;font-size:12px;font-weight:500;border-radius:20px}.badge-success{background:#22c55e1a;color:var(--success)}.badge-error{background:#ef44441a;color:var(--error)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0a0a14d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-dialog{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:420px;max-height:85vh;overflow-y:auto;position:relative;box-shadow:0 25px 80px #00000080;animation:modalSlideIn .25s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-close-btn{position:absolute;top:16px;right:16px;width:32px;height:32px;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.modal-close-btn:hover{background:var(--error);border-color:var(--error);color:#fff}.modal-body{padding:28px}.modal-footer{padding:16px 24px;border-top:1px solid var(--border-color);display:flex;justify-content:flex-end;gap:12px}input,textarea,select{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:14px 16px;font-size:14px;color:var(--text-primary);width:100%;transition:all .25s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:var(--bg-hover)}input:hover:not(:focus),textarea:hover:not(:focus),select:hover:not(:focus){border-color:var(--text-muted)}input[type=datetime-local]{color-scheme:dark}input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}.form-grid{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.form-group.full-width{grid-column:1 / -1}.form-actions{display:flex;gap:12px;padding-top:8px}.custom-select{position:relative;width:100%}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;cursor:pointer;transition:all .25s ease;text-align:left}.custom-select-trigger:hover{border-color:var(--text-muted)}.custom-select-trigger.open{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);background:var(--bg-hover)}.select-arrow{transition:transform .25s ease;color:var(--text-secondary)}.select-arrow.rotated{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 16px 48px #0000004d;z-index:100;overflow:hidden;animation:dropdownFadeIn .2s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.custom-select-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--text-secondary);font-size:14px;cursor:pointer;transition:all .15s ease;text-align:left}.custom-select-option:hover{background:var(--bg-hover);color:var(--text-primary)}.custom-select-option.selected{background:#7aa2f71a;color:var(--accent)}.custom-select-option svg{color:var(--accent)}.toast-container{position:fixed;top:20px;right:20px;z-index:2000;display:flex;flex-direction:column;gap:10px}.toast{padding:14px 20px;border-radius:8px;font-size:14px;display:flex;align-items:center;gap:10px;animation:slideIn .3s ease;box-shadow:0 10px 40px #0000004d}.toast-success{background:var(--success);color:#fff}.toast-error{background:var(--error);color:#fff}.toast-info{background:var(--accent);color:#fff}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.log-list{display:flex;flex-direction:column}.log-item{padding:12px 16px;border-bottom:1px solid var(--border-color);font-size:13px;display:grid;grid-template-columns:180px 80px 1fr 100px;gap:16px;align-items:center}.log-item:hover{background:var(--bg-hover)}.log-time{color:var(--text-muted);font-family:monospace}.log-method{font-weight:600}.log-method.POST{color:var(--success)}.log-method.GET{color:var(--accent)}.log-path{font-family:monospace;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.log-status{text-align:right}.log-status.success{color:var(--success)}.log-status.error{color:var(--error)}.api-keys-list{display:flex;flex-direction:column;gap:16px}.api-key-card{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:20px;transition:all .25s ease}.api-key-card:hover{border-color:#7aa2f74d;box-shadow:0 4px 20px #00000026}.api-key-card.inactive{opacity:.6}.api-key-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.api-key-name{font-size:16px;font-weight:600;color:var(--text-primary)}.api-key-status{font-size:12px;font-weight:500;padding:4px 12px;border-radius:20px}.api-key-status.active{background:#9ece6a26;color:var(--success)}.api-key-status.inactive{background:#f7768e26;color:var(--error)}.api-key-value{display:flex;align-items:center;gap:10px;margin-bottom:14px}.api-key-value code{font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;background:var(--bg-dark);padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--cyan);flex:1}.btn-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.btn-icon:hover{background:var(--accent);border-color:var(--accent);color:var(--bg-dark)}.api-key-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:14px;font-size:13px;color:var(--text-secondary)}.api-key-meta span{display:flex;align-items:center;gap:6px}.api-key-actions{display:flex;gap:10px;padding-top:14px;border-top:1px solid var(--border-color)}.btn-sm{padding:8px 16px;font-size:13px;border-radius:var(--radius-sm)}.modal-content{padding:0}.modal-content h3{font-size:18px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.modal-content .form-group{margin-bottom:16px}.key-display{display:flex;align-items:center;gap:12px;margin:16px 0}.key-display code{flex:1;font-family:SF Mono,Monaco,Consolas,monospace;font-size:13px;background:var(--bg-dark);padding:14px 16px;border-radius:var(--radius-sm);border:1px solid var(--border-color);color:var(--cyan);word-break:break-all}.text-warning{color:var(--warning);font-size:13px;display:flex;align-items:flex-start;gap:8px;padding:12px;background:#e0af681a;border-radius:var(--radius-sm);border:1px solid rgba(224,175,104,.2)}.logs-table-container{max-height:400px;overflow-y:auto}.logs-table{width:100%;border-collapse:collapse;font-size:13px}.logs-table th{position:sticky;top:0;background:var(--bg-card);padding:12px;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.logs-table td{padding:10px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.logs-table tr:hover td{background:var(--bg-hover)}.logs-table .error{color:var(--error)}.confirm-modal{text-align:center;padding:8px 0}.confirm-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.confirm-icon.danger{background:#f7768e26;color:var(--error)}.confirm-icon.warning{background:#e0af6826;color:var(--warning)}.confirm-icon.success{background:#9ece6a26;color:var(--success)}.confirm-modal h3{font-size:20px;font-weight:600;margin-bottom:12px;color:var(--text-primary)}.confirm-modal p{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-bottom:24px}.confirm-actions{display:flex;gap:12px;justify-content:center}.confirm-actions .btn{min-width:120px}@media (max-width: 768px){.sidebar{transform:translate(-100%)}.main-content{margin-left:0;padding:20px}.view-header{flex-direction:column;gap:16px}.stats-grid{grid-template-columns:1fr}.log-item{grid-template-columns:1fr;gap:8px}}
