*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f1117;--bg-card:#1a1d27;--bg-hover:#242836;--border:#2a2e3a;--text:#e4e6eb;--text-muted:#8b8fa3;--primary:#4f8ff7;--primary-hover:#3a7ce0;--success:#34c759;--warning:#ffa726;--danger:#ef5350;--orange:#ff9800;--radius:8px;--font:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--mono:"JetBrains Mono", "Fira Code", "Cascadia Code", monospace}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}code,.mono{font-family:var(--mono);font-size:13px}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--bg-card);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 24px;display:flex}.app-header h1{font-size:16px;font-weight:600}.header-logo{height:24px}.header-brand{color:inherit;align-items:center;gap:8px;text-decoration:none;display:flex}.header-brand:hover{opacity:.9;text-decoration:none}.header-left{align-items:center;gap:24px;display:flex}.header-nav{gap:4px;display:flex}.nav-link{color:var(--text-muted);border-radius:6px;padding:4px 10px;font-size:13px;text-decoration:none}.nav-link:hover{color:var(--text);background:var(--bg-hover);text-decoration:none}.nav-link.active{color:var(--primary);background:#4f8ff71a}.success-message{color:var(--success);padding:8px 0;font-size:13px}.number-input{text-align:right;width:100px}.user-menu{position:relative}.user-avatar{background:var(--primary);color:#fff;cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:600;transition:opacity .15s;display:flex}.user-avatar:hover{opacity:.85}.user-dropdown{z-index:200;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;min-width:220px;position:absolute;top:42px;right:0;box-shadow:0 8px 24px #0000004d}.user-dropdown-header{padding:12px 14px}.user-dropdown-email{color:var(--text);word-break:break-all;font-size:13px}.user-dropdown-role{color:var(--text-muted);margin-top:2px;font-size:11px}.user-dropdown-divider{background:var(--border);height:1px}.user-dropdown-item{text-align:left;width:100%;color:var(--text);cursor:pointer;background:0 0;border:none;padding:10px 14px;font-size:13px;display:block}.user-dropdown-item:hover{background:var(--bg-hover)}.user-dropdown-signout{color:var(--danger)}.app-main{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:24px}.app-footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:12px 24px;font-size:11px}.page{flex-direction:column;gap:20px;display:flex}.page-header{justify-content:space-between;align-items:center;display:flex}.back-link{color:var(--text-muted);font-size:13px}.loading,.empty-state{text-align:center;color:var(--text-muted);padding:40px}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn:hover{text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-success{background:var(--success);color:#fff}.btn-danger{background:var(--danger);color:#fff}.btn-sm{padding:4px 10px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-group{gap:6px;display:flex}.btn-link{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:13px}.btn-link:hover{color:var(--primary)}.no-wrap{white-space:nowrap}.audit-detail{color:var(--text-muted);word-break:break-word;max-width:400px;font-size:12px}.audit-detail span{margin-bottom:2px;margin-right:12px;display:inline-block}.btn-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-size:20px}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);padding:10px 12px;font-size:12px;font-weight:500}.data-table td{border-bottom:1px solid var(--border);padding:12px}.data-table tr:hover td{background:var(--bg-hover)}.data-table .number{text-align:right;font-variant-numeric:tabular-nums}.data-table .sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table .sortable-th:hover{color:var(--text)}.table-scroll{border:1px solid var(--border);border-radius:var(--radius);max-height:500px;overflow-y:auto}.table-scroll .data-table thead th{background:var(--bg-card);z-index:1;position:sticky;top:0}.search-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:360px;color:var(--text);margin-bottom:12px;padding:8px 12px;font-size:13px}.search-input:focus{border-color:var(--primary);outline:none}.usage-bar-container{background:var(--bg-hover);vertical-align:middle;border-radius:3px;width:80px;height:6px;margin-right:8px;display:inline-block;overflow:hidden}.usage-bar-container.large{border:1px solid var(--border);background:#ffffff14;width:100%;height:12px;margin:8px 0}.usage-bar{background:var(--success);border-radius:3px;height:100%;transition:width .3s}.usage-bar.warning{background:var(--warning)}.usage-bar.critical{background:var(--danger)}.usage-pct{color:var(--text-muted);font-size:12px}.badge{text-transform:capitalize;border-radius:12px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-block}.badge-green{color:var(--success);background:#34c75926}.badge-yellow{color:var(--warning);background:#ffa72626}.badge-orange{color:var(--orange);background:#ff980026}.badge-red{color:var(--danger);background:#ef535026}.badge-gray{background:var(--bg-hover);color:var(--text-muted)}.detail-header{justify-content:space-between;align-items:flex-start;display:flex}.detail-actions{gap:8px;display:flex}.detail-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;display:grid}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}.card h3{text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:8px;font-size:12px}.big-number{font-variant-numeric:tabular-nums;font-size:28px;font-weight:600}.label{color:var(--text-muted);font-size:12px}.threshold-list{flex-direction:column;gap:4px;font-size:13px;display:flex}.section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.section-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.section h3{font-size:14px;font-weight:600}.new-key-banner{border:1px solid var(--primary);border-radius:var(--radius);background:#4f8ff71a;margin-bottom:16px;padding:16px}.new-key-banner strong{margin-bottom:12px;display:block}.key-details{font-family:var(--mono);flex-direction:column;gap:8px;margin-bottom:12px;font-size:13px;display:flex}.secret-row{flex-wrap:wrap;align-items:flex-start;gap:8px;display:flex}.secret-value{word-break:break-all;flex:1;min-width:0}.success-banner{border:1px solid var(--success);border-radius:var(--radius);text-align:center;background:#34c7591a;padding:20px}.success-banner h2{margin-bottom:8px}.form{max-width:640px}.form-group{flex-direction:column;gap:4px;margin-bottom:16px;display:flex}.form-group label{color:var(--text-muted);font-size:13px;font-weight:500}.form-group input,.form-group select{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:8px 12px;font-size:14px}.form-group input:focus{border-color:var(--primary);outline:none}.warning-banner{border:1px solid var(--warning);border-radius:var(--radius);color:var(--warning);background:#ffa7261f;margin-bottom:16px;padding:12px 16px;font-size:13px}.hint{color:var(--text-muted);font-size:12px}.form-row{gap:16px;display:flex}.form-row .form-group{flex:1}.form-actions{gap:12px;margin-top:8px;display:flex}fieldset{border:1px solid var(--border);border-radius:var(--radius);margin-bottom:16px;padding:16px}legend{color:var(--text-muted);padding:0 8px;font-size:13px;font-weight:500}.error-message{color:var(--danger);padding:8px 0;font-size:13px}.key-gen-controls{align-items:center;gap:8px;display:flex}.select-input{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:6px 10px;font-size:13px}.select-input:focus{border-color:var(--primary);outline:none}.inline-input{color:var(--text);background:0 0;border:1px solid #0000;border-radius:4px;width:140px;padding:4px 6px;font-size:13px}.inline-input:hover{border-color:var(--border)}.inline-input:focus{border-color:var(--primary);background:var(--bg);outline:none}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;padding:40px}.login-card h1{text-align:center;margin-bottom:4px;font-size:20px}.login-card .subtitle{color:var(--text-muted);text-align:center;margin-bottom:24px}.login-logo{height:32px;margin:0 auto 12px;display:block}.login-card .btn{justify-content:center;width:100%;margin-top:8px}.modal-overlay{z-index:100;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;width:100%;max-width:520px;max-height:90vh;padding:24px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.text-warning{color:var(--warning)}.text-danger{color:var(--danger);font-weight:500}.sparkline{cursor:pointer;align-items:flex-end;gap:3px;height:32px;margin-top:8px;padding:2px 0;display:flex}.sparkline:hover .sparkline-bar{opacity:.8}.sparkline-bar{background:var(--primary);border-radius:2px 2px 0 0;flex:1;min-height:2px;transition:opacity .15s}.sparkline-danger{background:var(--danger)}.history-chart{align-items:flex-end;gap:6px;height:160px;padding:0 4px;display:flex}.history-bar-col{flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex}.history-bar-value{color:var(--text-muted);margin-bottom:4px;font-size:10px}.history-bar-track{flex:1;justify-content:center;align-items:flex-end;width:100%;display:flex}.history-bar{background:var(--primary);border-radius:3px 3px 0 0;width:100%;max-width:40px;min-height:2px}.history-bar-danger{background:var(--danger)}.history-bar-stacked{border-radius:3px 3px 0 0;flex-direction:column-reverse;width:100%;max-width:40px;min-height:2px;display:flex;overflow:hidden}.history-bar-stacked .bar-segment{width:100%;min-height:1px}.history-bar-danger .bar-segment{background:var(--danger)!important}.history-bar-label{color:var(--text-muted);white-space:nowrap;margin-top:6px;font-size:10px}.history-bar-col{cursor:pointer}.history-bar-col:hover .history-bar{opacity:.8}.history-bar-col:hover .history-bar-stacked .bar-segment{opacity:.85}.history-bar-col.selected .history-bar-label{color:var(--primary);font-weight:500}.history-bar-selected{outline:2px solid var(--primary);outline-offset:1px}.chart-legend{flex-wrap:wrap;gap:12px;margin-top:12px;display:flex}.legend-item{color:var(--text-muted);align-items:center;gap:5px;font-size:11px;display:flex}.legend-swatch{border-radius:2px;flex-shrink:0;width:10px;height:10px}.row-clickable{cursor:pointer}.row-clickable:hover td{background:var(--bg-hover)}.row-selected td{background:#4f8ff71a!important}.detail-section-title{color:var(--text-muted);margin-bottom:8px;font-size:13px}.modal-wide{max-width:620px}.warning-banner{border:1px solid var(--warning);border-radius:var(--radius);color:var(--warning);background:#ffa7261f;margin-bottom:16px;padding:10px 14px;font-size:13px;font-weight:500}.key-field{margin-bottom:14px}.key-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:12px;display:block}.key-value-row{align-items:flex-start;gap:8px;display:flex}.key-value{background:var(--bg);border:1px solid var(--border);word-break:break-all;border-radius:4px;flex:1;min-width:0;padding:8px 10px;font-size:13px}.select-input.full-width{width:100%}
