@import "https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=Outfit:wght@300;400;500;600;700&display=swap";:root{--bg-primary:#06080d;--bg-secondary:#0c1018;--bg-tertiary:#121824;--bg-card:#0f1520;--bg-elevated:#161e2e;--bg-hover:#1a2438;--border-subtle:#ffffff0f;--border-default:#ffffff1a;--border-strong:#ffffff29;--text-primary:#e8ecf4;--text-secondary:#8894aa;--text-muted:#4a5568;--accent:#00e5c7;--accent-hover:#00f5d6;--accent-dim:#00e5c71a;--accent-glow:#00e5c733;--warning:#f0a030;--warning-dim:#f0a0301a;--danger:#f43f5e;--danger-dim:#f43f5e1a;--success:#10b981;--success-dim:#10b9811a;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 12px #00000080;--shadow-lg:0 8px 30px #0009;--font-sans:"Outfit", system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;height:100vh;font-size:14px;line-height:1.6;overflow:hidden}#root{height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-default);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}input,select,textarea{font-family:var(--font-sans);font-size:14px}::selection{background:var(--accent-dim);color:var(--accent)}.app-layout{height:100vh;display:flex}.sidebar{background:var(--bg-secondary);border-right:1px solid var(--border-subtle);z-index:10;flex-direction:column;width:240px;min-width:240px;padding:0;display:flex;position:relative}.sidebar:after{content:"";background:linear-gradient(to bottom, var(--accent-glow), transparent 50%);pointer-events:none;width:1px;position:absolute;top:0;bottom:0;right:0}.sidebar-logo{border-bottom:1px solid var(--border-subtle);padding:24px 20px 20px}.sidebar-logo h1{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.5px;align-items:center;gap:10px;font-size:18px;font-weight:700;display:flex}.sidebar-logo h1 span{color:var(--accent)}.sidebar-logo p{color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase;margin-top:4px;font-size:11px;font-weight:500}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;text-align:left;width:100%;font-size:13.5px;font-weight:500;font-family:var(--font-sans);background:0 0;border:1px solid #0000;align-items:center;gap:10px;padding:10px 12px;transition:all .15s;display:flex}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.active{background:var(--accent-dim);color:var(--accent);border-color:#00e5c726}.nav-item svg{opacity:.7;width:18px;height:18px}.nav-item.active svg{opacity:1}.sidebar-footer{border-top:1px solid var(--border-subtle);padding:16px}.btn-logout{border:1px solid var(--border-default);border-radius:var(--radius-sm);width:100%;color:var(--text-secondary);font-size:13px;font-family:var(--font-sans);cursor:pointer;background:0 0;align-items:center;gap:8px;padding:9px 12px;font-weight:500;transition:all .15s;display:flex}.btn-logout:hover{background:var(--danger-dim);border-color:var(--danger);color:var(--danger)}.main-content{flex:1;padding:32px;position:relative;overflow-y:auto}.main-content:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(at 50% 0,#00e5c70a 0%,#0000 70%);height:200px;position:fixed;top:0;left:240px;right:0}.content-inner{z-index:1;max-width:1200px;position:relative}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-header h2{color:var(--text-primary);letter-spacing:-.3px;font-size:22px;font-weight:600}.page-header-actions{gap:10px;display:flex}.btn{border-radius:var(--radius-sm);font-size:13px;font-weight:500;font-family:var(--font-sans);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:7px;padding:9px 16px;transition:all .15s;display:inline-flex}.btn-primary{background:var(--accent);color:#06080d;border-color:var(--accent);font-weight:600}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 0 20px #00e5c740}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-danger{background:var(--danger-dim);color:var(--danger);border-color:#f43f5e40}.btn-danger:hover{border-color:var(--danger);background:#f43f5e33}.btn-ghost{color:var(--text-secondary);background:0 0;border:none;padding:6px 10px}.btn-ghost:hover{color:var(--text-primary);background:var(--bg-elevated)}.btn-sm{padding:6px 12px;font-size:12px}.btn svg{width:15px;height:15px}.stats-bar{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:18px 20px;position:relative;overflow:hidden}.stat-card:before{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.accent:before{background:var(--accent)}.stat-card.warning:before{background:var(--warning)}.stat-card.success:before{background:var(--success)}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.2px;margin-bottom:6px;font-size:11px;font-weight:600}.stat-value{color:var(--text-primary);letter-spacing:-1px;font-size:28px;font-weight:700}.stat-card.accent .stat-value{color:var(--accent)}.stat-card.warning .stat-value{color:var(--warning)}.filters{align-items:center;gap:8px;margin-bottom:16px;display:flex}.filter-btn{cursor:pointer;background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-subtle);font-size:12px;font-weight:500;font-family:var(--font-sans);border-radius:20px;padding:6px 14px;transition:all .15s}.filter-btn:hover{border-color:var(--border-default);color:var(--text-primary)}.filter-btn.active{background:var(--accent-dim);color:var(--accent);border-color:#00e5c733}.search-input{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);width:220px;font-size:13px;font-family:var(--font-sans);margin-left:auto;padding:7px 12px 7px 34px;transition:all .15s;position:relative}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.search-input::placeholder{color:var(--text-muted)}.search-wrapper{margin-left:auto;position:relative}.search-wrapper svg{width:14px;height:14px;color:var(--text-muted);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.table-container{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden}.table-inner{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;text-align:left;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);padding:12px 16px;font-size:11px;font-weight:600}tbody td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);padding:14px 16px;font-size:13.5px}tbody tr{transition:background .12s}tbody tr:hover{background:var(--bg-elevated)}tbody tr:last-child td{border-bottom:none}.owner-cell{color:var(--text-primary);font-weight:500}.badge{letter-spacing:.3px;text-transform:capitalize;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-active{background:var(--success-dim);color:var(--success);border:1px solid #10b98133}.badge-disabled{background:var(--danger-dim);color:var(--danger);border:1px solid #f43f5e33}.badge-dot{border-radius:50%;width:6px;height:6px;display:inline-block}.badge-active .badge-dot{background:var(--success)}.badge-disabled .badge-dot{background:var(--danger)}.uses-display{font-family:var(--font-mono);color:var(--text-secondary);font-size:12px}.uses-current{color:var(--text-primary);font-weight:600}.uses-separator{color:var(--text-muted);margin:0 2px}.uses-max{color:var(--text-muted)}.uses-unlimited{color:var(--accent);letter-spacing:.5px;font-size:11px}.ip-list{flex-wrap:wrap;gap:6px;max-height:160px;margin-bottom:8px;display:flex;overflow-y:auto}.ip-list-empty{color:var(--text-muted);padding:8px 0;font-size:12.5px}.ip-tag{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:6px;align-items:center;gap:6px;padding:4px 8px 4px 10px;font-size:12px;display:inline-flex}.ip-tag-value{font-family:var(--font-mono);color:var(--text-primary);font-weight:500}.ip-tag-date{color:var(--text-muted);font-size:11px}.ip-tag-remove{width:18px;height:18px;color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:0;transition:all .15s;display:inline-flex}.ip-tag-remove:hover{color:var(--danger);background:#f43f5e1a}.ip-tag-remove:disabled{opacity:.4;cursor:not-allowed}.ip-add-row{align-items:center;gap:8px;display:flex}.ip-add-input{flex:1;min-width:0}.actions-cell{gap:4px;display:flex}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000b3;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.modal{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);width:460px;max-width:95vw;max-height:90vh;box-shadow:var(--shadow-lg);animation:.2s slideUp;overflow-y:auto}.modal-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-header h3{color:var(--text-primary);font-size:16px;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;align-items:center;padding:4px;transition:all .15s;display:flex}.modal-close:hover{color:var(--text-primary);background:var(--bg-elevated)}.modal-close svg{width:18px;height:18px}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid var(--border-subtle);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.form-group{margin-bottom:18px}.form-group:last-child{margin-bottom:0}.form-label{color:var(--text-secondary);letter-spacing:.3px;margin-bottom:6px;font-size:12px;font-weight:600;display:block}.form-input,.form-select{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:14px;font-family:var(--font-sans);padding:10px 14px;transition:all .15s}.form-input:focus,.form-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);outline:none}.form-input::placeholder{color:var(--text-muted)}.form-hint{color:var(--text-muted);margin-top:4px;font-size:11px}.form-input.mono{font-family:var(--font-mono);letter-spacing:.5px;font-size:13px}.key-reveal{background:var(--bg-primary);border:1px solid var(--accent);border-radius:var(--radius-md);margin-top:16px;padding:20px;position:relative;overflow:hidden}.key-reveal:before{content:"";background:linear-gradient(135deg, var(--accent-dim), transparent 60%);pointer-events:none;position:absolute;inset:0}.key-reveal-label{color:var(--accent);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:8px;font-size:11px;font-weight:700;position:relative}.key-reveal-value{font-family:var(--font-mono);color:var(--accent);letter-spacing:1.5px;word-break:break-all;font-size:15px;font-weight:600;position:relative}.key-reveal-warning{color:var(--warning);align-items:center;gap:6px;margin-top:10px;font-size:11.5px;display:flex;position:relative}.key-reveal-warning svg{flex-shrink:0;width:14px;height:14px}.login-page{background:var(--bg-primary);justify-content:center;align-items:center;height:100vh;display:flex;position:relative;overflow:hidden}.login-page:before{content:"";pointer-events:none;background:radial-gradient(circle,#00e5c70f 0%,#0000 70%);width:600px;height:600px;position:absolute;top:50%;left:50%;transform:translate(-50%,-60%)}.login-card{background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);z-index:1;width:380px;box-shadow:var(--shadow-lg);padding:36px 32px;position:relative}.login-logo{text-align:center;margin-bottom:28px}.login-logo h1{font-family:var(--font-mono);color:var(--text-primary);letter-spacing:-.5px;font-size:24px;font-weight:700}.login-logo h1 span{color:var(--accent)}.login-logo p{color:var(--text-muted);letter-spacing:2px;text-transform:uppercase;margin-top:4px;font-size:12px;font-weight:500}.login-error{background:var(--danger-dim);color:var(--danger);border-radius:var(--radius-sm);text-align:center;border:1px solid #f43f5e40;margin-bottom:16px;padding:10px 14px;font-size:13px}.login-submit{justify-content:center;width:100%;margin-top:8px;padding:11px;font-size:14px}.audit-entry{border-bottom:1px solid var(--border-subtle);gap:14px;padding:14px 0;display:flex}.audit-entry:last-child{border-bottom:none}.audit-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:6px}.audit-dot.create{background:var(--success)}.audit-dot.update{background:var(--accent)}.audit-dot.delete{background:var(--danger)}.audit-dot.validate{background:var(--text-muted)}.audit-dot.rotate{background:var(--warning)}.audit-content{flex:1;min-width:0}.audit-action{color:var(--text-primary);text-transform:capitalize;font-size:13px;font-weight:500}.audit-details{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);margin-top:2px}.audit-time{color:var(--text-muted);white-space:nowrap;margin-top:2px;font-size:11px}.toggle-wrapper{align-items:center;gap:8px;display:flex}.toggle{cursor:pointer;width:40px;height:22px;position:relative}.toggle input{display:none}.toggle-track{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:11px;transition:all .2s;position:absolute;inset:0}.toggle input:checked+.toggle-track{background:var(--accent-dim);border-color:var(--accent)}.toggle-thumb{background:var(--text-muted);border-radius:50%;width:16px;height:16px;transition:all .2s;position:absolute;top:3px;left:3px}.toggle input:checked~.toggle-thumb{background:var(--accent);left:21px}.toggle-label{color:var(--text-secondary);font-size:12.5px;font-weight:500}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state svg{opacity:.4;width:48px;height:48px;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:16px}.empty-state p{font-size:13px}.confirm-icon{background:var(--danger-dim);border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto 16px;display:flex}.confirm-icon svg{width:24px;height:24px;color:var(--danger)}.confirm-text{text-align:center;color:var(--text-secondary);font-size:14px;line-height:1.6}.confirm-text strong{color:var(--text-primary)}@keyframes rowIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.row-animate{animation:.25s both rowIn}.toast{background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);box-shadow:var(--shadow-lg);z-index:200;align-items:center;gap:10px;padding:14px 20px;font-size:13.5px;animation:.2s slideUp;display:flex;position:fixed;bottom:24px;right:24px}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--accent)}.toast svg{flex-shrink:0;width:18px;height:18px}.toast.success svg{color:var(--success)}.toast.error svg{color:var(--danger)}.toast.info svg{color:var(--accent)}.copy-btn{background:var(--accent-dim);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;font-size:11.5px;font-weight:600;font-family:var(--font-sans);border:1px solid #00e5c733;align-items:center;gap:5px;margin-top:10px;padding:6px 12px;transition:all .15s;display:inline-flex;position:relative}.copy-btn:hover{background:#00e5c733}.copy-btn svg{width:13px;height:13px}
