:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;padding:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative;overflow:hidden;padding:1rem}.login-bg-shapes{position:absolute;inset:0;overflow:hidden;pointer-events:none}.login-shape{position:absolute;border-radius:50%;filter:blur(80px);opacity:.4;animation:float 20s ease-in-out infinite}.login-shape-1{width:400px;height:400px;background:linear-gradient(135deg,#6366f1,#8b5cf6);top:-100px;left:-100px;animation-delay:0s}.login-shape-2{width:350px;height:350px;background:linear-gradient(135deg,#3b82f6,#06b6d4);bottom:-80px;right:-80px;animation-delay:-7s}.login-shape-3{width:250px;height:250px;background:linear-gradient(135deg,#ec4899,#f43f5e);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes float{0%,to{transform:translate(0) scale(1)}25%{transform:translate(30px,-30px) scale(1.05)}50%{transform:translate(-20px,20px) scale(.95)}75%{transform:translate(-30px,-20px) scale(1.02)}}.login-card{position:relative;z-index:10;background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:24px;padding:3rem 2.5rem;max-width:420px;width:100%;box-shadow:0 25px 50px -12px #00000080,0 0 0 1px #ffffff0d inset;animation:slideUp .6s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-brand{text-align:center;margin-bottom:2rem}.login-logo{width:64px;height:64px;margin:0 auto 1.25rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:16px;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px -10px #6366f180;animation:pulse 3s ease-in-out infinite}@keyframes pulse{0%,to{box-shadow:0 10px 30px -10px #6366f180}50%{box-shadow:0 10px 40px -5px #6366f1b3}}.login-logo svg{width:32px;height:32px;color:#fff}.login-title{font-size:1.875rem;font-weight:700;color:#fff;margin:0 0 .5rem;letter-spacing:-.025em}.login-subtitle{font-size:.9375rem;color:#fff9;margin:0;font-weight:400}.login-divider{display:flex;align-items:center;gap:1rem;margin-bottom:1.75rem}.login-divider span{flex:1;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent)}.login-divider p{font-size:.75rem;color:#fff6;text-transform:uppercase;letter-spacing:.1em;margin:0;white-space:nowrap}.login-features{list-style:none;padding:0;margin:0 0 2rem;display:flex;flex-direction:column;gap:.875rem}.login-features li{display:flex;align-items:center;gap:.75rem;color:#fffc;font-size:.9375rem}.login-features li svg{width:20px;height:20px;color:#22c55e;flex-shrink:0}.login-auth-section{text-align:center;padding:1.5rem;background:#ffffff05;border-radius:16px;border:1px solid rgba(255,255,255,.05);margin-bottom:1.5rem}.login-cta{font-size:.875rem;color:#ffffffb3;margin:0 0 1.25rem}.login-google-wrapper{display:flex;justify-content:center;transform:scale(1.1);transition:transform .2s ease}.login-google-wrapper:hover{transform:scale(1.15)}.login-footer{text-align:center;font-size:.8125rem;color:#fff6;margin:0}.login-footer strong{color:#fff9;font-weight:600}@media(max-width:480px){.login-card{padding:2rem 1.5rem;border-radius:20px}.login-title{font-size:1.5rem}.login-logo{width:56px;height:56px}.login-logo svg{width:28px;height:28px}.login-shape-1{width:250px;height:250px}.login-shape-2{width:200px;height:200px}.login-shape-3{width:150px;height:150px}}.key-row{border-bottom:1px solid rgba(255,255,255,.06);transition:all .2s ease}.key-row:hover{background:#3b82f614}.key-row:last-child{border-bottom:none}.key-cell{padding:.875rem .75rem;color:#ffffffd9;font-size:.875rem;vertical-align:middle}.key-cell-center{text-align:center}.key-cell-right{text-align:right}.key-cell-date{font-size:.8125rem;color:#94a3b8cc}.key-cell-alias{font-weight:500}.key-alias-content{display:flex;align-items:center;gap:.75rem}.key-icon{width:32px;height:32px;background:linear-gradient(135deg,#3b82f633,#8b5cf633);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.key-icon svg{width:16px;height:16px;color:#3b82f6}.key-cell-spend{font-weight:600}.spend-value{color:#22c55e;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace}.budget-value{color:#f59e0b;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace;font-weight:500}.limit-value{color:#a78bfa;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace}.key-badge{display:inline-block;padding:.25rem .625rem;border-radius:6px;font-size:.75rem;font-weight:500}.key-badge-success{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.key-badge-warning{background:#f59e0b26;color:#fbbf24;border:1px solid rgba(245,158,11,.3)}.key-status{display:inline-block;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em}.key-status-active{background:#22c55e26;color:#4ade80}.key-status-blocked{background:#ef444426;color:#f87171}.duration-badge{display:inline-block;padding:.25rem .5rem;background:#8b5cf626;color:#a78bfa;border-radius:4px;font-size:.75rem;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace}.key-dash{color:#94a3b866}.key-row-loading{background:#ffffff05}.key-loading-content{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem 0;color:#94a3b899}.key-spinner{width:20px;height:20px;border:2px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:key-spin .8s linear infinite}@keyframes key-spin{to{transform:rotate(360deg)}}.key-row-error{background:#ef44440d}.key-cell-error{display:flex;align-items:center;gap:.5rem;padding:.875rem .75rem;color:#fca5a5}.key-cell-error svg{width:18px;height:18px;flex-shrink:0}.key-error-detail{color:#fca5a599;font-size:.75rem;margin-left:auto;font-family:SF Mono,Monaco,Inconsolata,Fira Mono,monospace}.key-row-empty{color:#94a3b880}.key-row:hover .spend-value{color:#4ade80}.key-row:hover .budget-value{color:#fbbf24}.key-row:hover .limit-value{color:#c4b5fd}.key-row:hover .key-icon{background:linear-gradient(135deg,#3b82f64d,#8b5cf64d)}.dashboard-container{min-height:100vh;background:linear-gradient(135deg,#0a0f1c,#1a1f3c,#0d1225);position:relative;overflow:hidden}.dashboard-bg-element{position:absolute;border-radius:50%;filter:blur(80px);opacity:.3;animation:float 20s ease-in-out infinite}.dashboard-bg-element-1{width:600px;height:600px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);top:-200px;right:-200px;animation-delay:0s}.dashboard-bg-element-2{width:400px;height:400px;background:linear-gradient(135deg,#06b6d4,#3b82f6);bottom:-100px;left:-100px;animation-delay:-7s}.dashboard-bg-element-3{width:300px;height:300px;background:linear-gradient(135deg,#8b5cf6,#ec4899);top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:-14s}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-30px) rotate(5deg)}}.dashboard-content{position:relative;z-index:1;padding:1.5rem;min-height:95vh;display:flex;flex-direction:column}.dashboard-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:#ffffff0d;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;margin-bottom:1.5rem}.dashboard-brand{display:flex;align-items:center;gap:1rem}.dashboard-logo{width:48px;height:48px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:12px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 32px #3b82f64d}.dashboard-logo svg{width:28px;height:28px;color:#fff}.dashboard-brand-text h1{font-size:1.5rem;font-weight:700;color:#fff;margin:0;background:linear-gradient(135deg,#fff,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-subtitle{font-size:.75rem;color:#94a3b8cc;text-transform:uppercase;letter-spacing:.1em}.dashboard-user-section{display:flex;align-items:center;gap:1.5rem}.dashboard-user-info{display:flex;flex-direction:column;align-items:flex-end}.dashboard-user-name{font-size:.875rem;font-weight:600;color:#fff}.dashboard-user-email{font-size:.75rem;color:#94a3b8cc}.dashboard-logout-btn{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #ef44444d}.dashboard-logout-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #ef444466}.dashboard-logout-btn svg{width:18px;height:18px}.dashboard-main{flex:1;display:flex;flex-direction:column}.dashboard-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.dashboard-title{display:flex;align-items:center;gap:.75rem;font-size:1.5rem;font-weight:700;color:#fff;margin:0}.dashboard-title svg{width:28px;height:28px;color:#3b82f6}.dashboard-stats{display:flex;gap:1rem}.dashboard-stat{display:flex;flex-direction:column;align-items:center;padding:.75rem 1.5rem;background:#ffffff0d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);border-radius:12px}.dashboard-stat-value{font-size:1.5rem;font-weight:700;color:#3b82f6}.dashboard-stat-label{font-size:.75rem;color:#94a3b8cc;text-transform:uppercase;letter-spacing:.05em}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b8cc}.dashboard-spinner{width:48px;height:48px;border:3px solid rgba(59,130,246,.2);border-top-color:#3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.dashboard-error{display:flex;align-items:center;gap:.75rem;padding:1rem 1.5rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:12px;color:#fca5a5}.dashboard-error svg{width:24px;height:24px;flex-shrink:0}.dashboard-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem;color:#94a3b899}.dashboard-empty svg{width:64px;height:64px;margin-bottom:1rem;opacity:.5}.dashboard-table-container{flex:1;overflow:auto;background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:16px;margin-bottom:1rem}.dashboard-table{width:100%;border-collapse:collapse;min-width:1200px}.dashboard-table thead{position:sticky;top:0;z-index:10}.dashboard-table thead tr{background:linear-gradient(135deg,#3b82f633,#8b5cf633);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.dashboard-table th{padding:1rem .75rem;font-size:.75rem;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(255,255,255,.1);white-space:nowrap}.dashboard-table th.text-left{text-align:left}.dashboard-table th.text-right{text-align:right}.dashboard-table th.text-center{text-align:center}.dashboard-pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;padding:1rem;background:#ffffff08;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);border-radius:12px}.pagination-btn{display:flex;align-items:center;gap:.375rem;padding:.5rem 1rem;background:#3b82f633;color:#fff;border:1px solid rgba(59,130,246,.3);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#3b82f666;border-color:#3b82f680;transform:translateY(-1px)}.pagination-btn:disabled{opacity:.4;cursor:not-allowed}.pagination-btn svg{width:16px;height:16px}.pagination-info{padding:0 1.5rem;font-size:.875rem;color:#fffc}.pagination-info strong{color:#3b82f6}.pagination-total{color:#94a3b899;margin-left:.5rem}@media(max-width:768px){.dashboard-content{padding:1rem}.dashboard-header{flex-direction:column;gap:1rem;padding:1rem}.dashboard-brand{width:100%;justify-content:center}.dashboard-user-section{width:100%;justify-content:space-between}.dashboard-user-info{align-items:flex-start}.dashboard-title-row{flex-direction:column;gap:1rem;align-items:flex-start}.dashboard-pagination{flex-wrap:wrap;gap:.5rem}.pagination-btn{padding:.5rem .75rem;font-size:.75rem}.pagination-info{width:100%;text-align:center;order:-1;padding:.5rem 0}}#root{width:100%;height:100vh;margin:0;padding:0}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(prefers-reduced-motion:no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
