@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";
:root{--bg-primary:#060a13;--bg-secondary:#0c1220;--bg-card:#0f172acc;--bg-card-hover:#141e37e6;--bg-input:#0f172a99;--bg-overlay:#0009;--border-subtle:#384e774d;--border-medium:#384e7780;--border-accent:#3b82f666;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--text-accent:#60a5fa;--accent-blue:#3b82f6;--accent-blue-light:#60a5fa;--accent-blue-glow:#3b82f633;--accent-emerald:#10b981;--accent-emerald-glow:#10b98133;--accent-purple:#8b5cf6;--accent-purple-glow:#8b5cf633;--accent-amber:#f59e0b;--accent-amber-glow:#f59e0b33;--accent-rose:#f43f5e;--accent-rose-glow:#f43f5e33;--gradient-blue:linear-gradient(135deg, #3b82f6, #2563eb);--gradient-emerald:linear-gradient(135deg, #10b981, #059669);--gradient-purple:linear-gradient(135deg, #8b5cf6, #7c3aed);--gradient-hero:linear-gradient(135deg, #3b82f61a, #8b5cf60d);--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow-blue:0 0 20px #3b82f626;--shadow-glow-emerald:0 0 20px #10b98126;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.4s ease;--sidebar-width:260px;--sidebar-collapsed:72px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;line-height:1.6}a{color:var(--text-accent);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--accent-blue-light)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-subtle);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-medium)}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";background:radial-gradient(circle,#3b82f614,#0000 70%);border-radius:50%;width:600px;height:600px;animation:20s ease-in-out infinite float;position:absolute;top:-200px;right:-200px}.login-page:after{content:"";background:radial-gradient(circle,#8b5cf60f,#0000 70%);border-radius:50%;width:500px;height:500px;animation:25s ease-in-out infinite reverse float;position:absolute;bottom:-150px;left:-150px}@keyframes float{0%,to{transform:translate(0)}25%{transform:translate(30px,-20px)}50%{transform:translate(-20px,30px)}75%{transform:translate(20px,20px)}}.login-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:100%;max-width:420px;box-shadow:var(--shadow-lg);z-index:1;padding:40px;animation:.5s slideUp;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-card h1{background:linear-gradient(135deg, var(--text-primary), var(--accent-blue-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:4px;font-size:1.75rem;font-weight:700}.login-card .subtitle{color:var(--text-muted);margin-bottom:32px;font-size:.875rem}.form-group{margin-bottom:20px}.form-group label{color:var(--text-secondary);letter-spacing:.02em;margin-bottom:6px;font-size:.8125rem;font-weight:500;display:block}.form-input{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-fast);outline:none;padding:12px 16px;font-family:inherit;font-size:.9375rem}.form-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-glow)}.form-input::placeholder{color:var(--text-muted)}.form-select{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:all var(--transition-fast);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2394a3b8' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;outline:none;padding:12px 16px;font-family:inherit;font-size:.9375rem}.form-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--accent-blue-glow)}.form-select option{background:var(--bg-secondary);color:var(--text-primary)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;outline:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:.9375rem;font-weight:600;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-blue);color:#fff;box-shadow:var(--shadow-glow-blue)}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 0 30px #3b82f640}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-subtle)}.btn-secondary:hover:not(:disabled){background:var(--bg-card-hover);border-color:var(--border-medium)}.btn-success{background:var(--gradient-emerald);color:#fff;box-shadow:var(--shadow-glow-emerald)}.btn-success:hover:not(:disabled){transform:translateY(-1px)}.btn-danger{color:var(--accent-rose);border:1px solid var(--accent-rose);background:0 0}.btn-danger:hover:not(:disabled){background:#f43f5e1a}.btn-sm{padding:8px 16px;font-size:.8125rem}.btn-full{width:100%}.btn-icon{border-radius:var(--radius-sm);padding:8px}.dashboard-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:100;height:100vh;transition:width var(--transition-base);flex-direction:column;display:flex;position:fixed;top:0;left:0}.sidebar-header{border-bottom:1px solid var(--border-subtle);align-items:center;gap:12px;padding:20px 24px;display:flex}.sidebar-logo{background:var(--gradient-blue);border-radius:var(--radius-md);color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.125rem;font-weight:800;display:flex}.sidebar-brand{color:var(--text-primary);font-size:1.0625rem;font-weight:700;line-height:1.2}.sidebar-brand small{color:var(--text-muted);letter-spacing:.04em;font-size:.6875rem;font-weight:400;display:block}.sidebar-nav{flex:1;padding:16px 12px;overflow-y:auto}.sidebar-section-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:12px 12px 8px;font-size:.6875rem;font-weight:600}.sidebar-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast);align-items:center;gap:12px;margin-bottom:2px;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex}.sidebar-link:hover{color:var(--text-primary);background:#3b82f614}.sidebar-link.active{color:var(--accent-blue-light);background:#3b82f61f}.sidebar-link svg,.sidebar-link .icon{opacity:.7;flex-shrink:0;width:20px;height:20px}.sidebar-link.active svg,.sidebar-link.active .icon{opacity:1}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:16px}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh}.topbar{border-bottom:1px solid var(--border-subtle);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:50;background:#060a13cc;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:0}.topbar-title{font-size:1.125rem;font-weight:600}.topbar-actions{align-items:center;gap:12px;display:flex}.topbar-user{color:var(--text-secondary);align-items:center;gap:8px;font-size:.8125rem;display:flex}.page-content{max-width:1400px;padding:32px}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:24px}.card:hover{border-color:var(--border-medium)}.card-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.card-title{font-size:1.0625rem;font-weight:600}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:32px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);padding:24px;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.stat-card.blue:before{background:var(--gradient-blue)}.stat-card.emerald:before{background:var(--gradient-emerald)}.stat-card.purple:before{background:var(--gradient-purple)}.stat-card.amber:before{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;font-size:.8125rem;font-weight:500}.stat-value{font-size:2rem;font-weight:700;line-height:1}.stat-card.blue .stat-value{color:var(--accent-blue-light)}.stat-card.emerald .stat-value{color:var(--accent-emerald)}.stat-card.purple .stat-value{color:var(--accent-purple)}.stat-card.amber .stat-value{color:var(--accent-amber)}.table-wrapper{overflow-x:auto}.table{border-collapse:collapse;width:100%}.table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border-subtle);white-space:nowrap;padding:12px 16px;font-size:.75rem;font-weight:600}.table td{color:var(--text-secondary);vertical-align:middle;border-bottom:1px solid #384e7726;padding:14px 16px;font-size:.875rem}.table tr:hover td{background:#3b82f608}.table td.primary{color:var(--text-primary);font-weight:500}.badge{letter-spacing:.02em;border-radius:999px;align-items:center;padding:4px 10px;font-size:.75rem;font-weight:600;display:inline-flex}.badge-active{color:var(--accent-emerald);background:#10b98126;border:1px solid #10b98140}.badge-inactive{color:var(--text-muted);background:#64748b26;border:1px solid #64748b40}.badge-revoked{color:var(--accent-rose);background:#f43f5e26;border:1px solid #f43f5e40}.badge-admin{color:var(--accent-purple);background:#8b5cf626;border:1px solid #8b5cf640}.badge-api{color:var(--accent-blue-light);background:#3b82f626;border:1px solid #3b82f640}.upload-zone{border:2px dashed var(--border-subtle);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition-base);padding:48px;position:relative}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent-blue);background:var(--accent-blue-glow)}.upload-zone .upload-icon{opacity:.5;margin-bottom:16px;font-size:3rem}.upload-zone .upload-text{color:var(--text-secondary);margin-bottom:8px;font-size:1rem}.upload-zone .upload-hint{color:var(--text-muted);font-size:.8125rem}.upload-zone input[type=file]{opacity:0;cursor:pointer;position:absolute;inset:0}.upload-zone.has-file{border-color:var(--accent-emerald);background:#10b9810a;border-style:solid}.upload-zone.has-file input[type=file]{display:none}.upload-result{background:var(--bg-card);border:1px solid var(--accent-emerald);border-radius:var(--radius-lg);padding:24px;animation:.3s slideUp}.upload-result .result-header{align-items:center;gap:12px;margin-bottom:16px;display:flex}.upload-result .result-header .check{background:var(--accent-emerald);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.result-meta{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:16px;display:grid}.result-meta-item{border-radius:var(--radius-md);background:#0f172a80;padding:12px}.result-meta-item .label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:4px;font-size:.6875rem}.result-meta-item .value{color:var(--text-primary);word-break:break-all;font-size:.875rem;font-weight:500}.url-copy-group{gap:8px;display:flex}.url-copy-group input{flex:1}.modal-overlay{background:var(--bg-overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;padding:32px;animation:.25s slideUp;overflow-y:auto}.modal h2{margin-bottom:24px;font-size:1.25rem;font-weight:600}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.alert{border-radius:var(--radius-md);align-items:center;gap:10px;margin-bottom:20px;padding:14px 18px;font-size:.875rem;animation:.2s slideUp;display:flex}.alert-error{color:var(--accent-rose);background:#f43f5e1a;border:1px solid #f43f5e4d}.alert-success{color:var(--accent-emerald);background:#10b9811a;border:1px solid #10b9814d}.alert-warning{color:var(--accent-amber);background:#f59e0b1a;border:1px solid #f59e0b4d}.spinner{border:2px solid #0000;border-top-color:currentColor;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-overlay{z-index:2000;background:#060a13d9;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;position:fixed;inset:0}.loading-overlay .spinner{width:40px;height:40px;color:var(--accent-blue);border-width:3px}.progress-bar{background:var(--bg-input);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:var(--gradient-blue);height:100%;transition:width var(--transition-base);border-radius:3px}.empty-state{text-align:center;color:var(--text-muted);padding:48px 24px}.empty-state .empty-icon{opacity:.4;margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:1.125rem;font-weight:600}.empty-state p{margin-bottom:20px;font-size:.875rem}.size-reduction{color:var(--accent-emerald);font-weight:600}.api-key-display{border:1px solid var(--accent-amber);border-radius:var(--radius-md);background:#0f172a80;margin:16px 0;padding:16px}.api-key-display code{color:var(--accent-amber);word-break:break-all;border-radius:var(--radius-sm);background:#0000004d;padding:8px;font-family:JetBrains Mono,Fira Code,monospace;font-size:.875rem;display:block}@media (max-width:768px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}.page-content{padding:16px}.stats-grid{grid-template-columns:1fr}.modal{margin:16px}.login-card{margin:16px;padding:24px}}.toast{background:var(--accent-emerald);color:#fff;border-radius:var(--radius-md);z-index:3000;padding:12px 20px;font-size:.875rem;font-weight:500;animation:.3s slideUp,.3s 2s forwards fadeOut;position:fixed;bottom:24px;right:24px}@keyframes fadeOut{to{opacity:0;transform:translateY(10px)}}.grid-2{grid-template-columns:repeat(2,1fr);gap:20px;display:grid}@media (max-width:768px){.grid-2{grid-template-columns:1fr}}.project-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);padding:24px;position:relative}.project-card:hover{border-color:var(--accent-blue);box-shadow:var(--shadow-glow-blue);transform:translateY(-2px)}.project-card .project-name{color:var(--text-primary);margin-bottom:4px;font-size:1.0625rem;font-weight:600}.project-card .project-slug{color:var(--text-muted);font-family:JetBrains Mono,monospace;font-size:.8125rem}.project-card .project-meta{align-items:center;gap:12px;margin-top:12px;display:flex}.tabs{border-bottom:1px solid var(--border-subtle);gap:4px;margin-bottom:24px;display:flex}.tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000;padding:12px 20px;font-family:inherit;font-size:.875rem;font-weight:500}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--accent-blue-light);border-bottom-color:var(--accent-blue)}.filter-section{flex-direction:column;gap:4px;display:flex}.filter-row{flex-direction:column;gap:8px;display:flex}.filter-label{color:var(--text-secondary);letter-spacing:.02em;font-size:.8125rem;font-weight:600}.filter-label-sm{color:var(--text-muted);margin-bottom:4px;font-size:.75rem;font-weight:500}.filter-chips{flex-wrap:wrap;gap:8px;display:flex}.filter-chip{color:var(--text-secondary);background:var(--bg-input);border:1px solid var(--border-subtle);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border-radius:999px;outline:none;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:.8125rem;font-weight:500;display:inline-flex}.filter-chip:hover{color:var(--text-primary);border-color:var(--border-medium);background:var(--bg-card-hover);transform:translateY(-1px)}.filter-chip.active{color:#fff;background:var(--gradient-blue);border-color:var(--accent-blue);box-shadow:0 0 12px #3b82f640}.filter-chip-icon{font-size:.875rem}.filter-date-range{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.filter-date-group{flex-direction:column;display:flex}.filter-date-separator{color:var(--text-muted);padding-bottom:12px;font-size:1.25rem}.filter-controls{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.search-box{flex:1;min-width:200px;max-width:320px;position:relative}.search-box .search-icon{pointer-events:none;z-index:1;font-size:.875rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.inline-edit{align-items:center;gap:6px;display:flex}.inline-edit-input{min-width:160px;padding:6px 10px!important;font-size:.8125rem!important}.action-buttons{gap:4px;display:flex}.bulk-actions{border-radius:var(--radius-md);background:#3b82f614;border:1px solid #3b82f633;align-items:center;gap:12px;margin-bottom:16px;padding:12px 20px;animation:.2s slideUp;display:flex}.bulk-count{color:var(--accent-blue-light);margin-right:auto;font-size:.875rem;font-weight:600}.table-checkbox{width:16px;height:16px;accent-color:var(--accent-blue);cursor:pointer}.table tr.row-selected td{background:#3b82f60f}.filename-text{text-overflow:ellipsis;white-space:nowrap;vertical-align:middle;max-width:220px;display:inline-block;overflow:hidden}@media (max-width:768px){.filter-chips{gap:6px}.filter-chip{padding:6px 12px;font-size:.75rem}.filter-controls{flex-direction:column}.search-box{max-width:100%}.filename-text{max-width:120px}.action-buttons{flex-wrap:wrap}}
