*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-root: #070c18;--bg-surface: #0d1425;--bg-card: #0f1923;--bg-card2: #141e2e;--bg-input: #0b1120;--border: #1a2744;--border-hi: #243552;--border-glow: rgba(59,130,246,.45);--accent: #3b82f6;--accent-dim: rgba(59,130,246,.14);--accent-glow: rgba(59,130,246,.2);--success: #10b981;--success-dim: rgba(16,185,129,.14);--success-glow: rgba(16,185,129,.2);--warn: #f59e0b;--warn-dim: rgba(245,158,11,.14);--warn-glow: rgba(245,158,11,.2);--danger: #ef4444;--danger-dim: rgba(239,68,68,.14);--danger-glow: rgba(239,68,68,.2);--purple: #8b5cf6;--purple-dim: rgba(139,92,246,.14);--teal: #14b8a6;--teal-dim: rgba(20,184,166,.14);--text-1: #f1f5f9;--text-2: #94a3b8;--text-3: #475569;--text-4: #2d3f58;--r: 6px;--r-sm: 4px;--r-lg: 12px;--shadow-card: 0 4px 24px rgba(0,0,0,.45), 0 1px 3px rgba(0,0,0,.3);--shadow-glow: 0 0 24px var(--accent-glow), 0 4px 16px rgba(0,0,0,.5)}html{font-size:14px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,sans-serif;background:var(--bg-root);color:var(--text-1);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{font-family:inherit}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes pulse-ring{0%,to{box-shadow:0 0 0 0 var(--success-glow)}50%{box-shadow:0 0 0 4px transparent}}@keyframes pulse-ring-r{0%,to{box-shadow:0 0 0 0 var(--danger-glow)}50%{box-shadow:0 0 0 4px transparent}}@keyframes pulse-ring-y{0%,to{box-shadow:0 0 0 0 var(--warn-glow)}50%{box-shadow:0 0 0 4px transparent}}@keyframes counter-in{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}.layout{min-height:100vh;display:flex;flex-direction:column}.main{flex:1;padding:28px 32px;max-width:1440px;width:100%;margin:0 auto}.navbar{background:var(--bg-surface);border-bottom:1px solid var(--border);height:58px;display:flex;align-items:center;padding:0 28px;gap:28px;position:sticky;top:0;z-index:200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.navbar-brand{font-size:15px;font-weight:700;white-space:nowrap;display:flex;align-items:center;gap:8px;flex-shrink:0}.navbar-brand .icon{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#1d4ed8);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;box-shadow:0 0 12px var(--accent-glow)}.navbar-brand span{color:var(--accent)}.navbar-nav{display:flex;gap:2px;flex:1}.nav-link{padding:6px 13px;border-radius:var(--r-sm);color:var(--text-2);font-size:13px;font-weight:500;transition:all .15s;cursor:pointer;border:none;background:none;position:relative;display:inline-flex;align-items:center;gap:6px}.nav-link:hover{color:var(--text-1);background:#ffffff0a}.nav-link.active{color:var(--accent);background:var(--accent-dim)}.navbar-logout{margin-left:auto;padding:5px 12px;border-radius:var(--r-sm);background:transparent;border:1px solid var(--border-hi);color:var(--text-2);font-size:12px;cursor:pointer;transition:all .15s;flex-shrink:0}.navbar-logout:hover{background:var(--danger-dim);border-color:var(--danger);color:var(--danger)}.nav-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;padding:0 4px;border-radius:99px;font-size:10px;font-weight:700;background:var(--danger);color:#fff;line-height:1;animation:counter-in .2s ease}.page-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;animation:fadeUp .25s ease}.page-title{font-size:20px;font-weight:700;letter-spacing:-.3px}.skeleton{background:linear-gradient(90deg,var(--bg-card) 0%,var(--bg-card2) 50%,var(--bg-card) 100%);background-size:600px 100%;animation:shimmer 1.4s infinite linear;border-radius:var(--r)}.skeleton-text{height:13px;width:80%;margin-bottom:8px;border-radius:4px}.skeleton-value{height:38px;width:60%;border-radius:4px;margin-top:4px}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:22px 20px;box-shadow:var(--shadow-card);transition:border-color .2s,box-shadow .2s,transform .15s;animation:fadeUp .3s ease both;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--r-lg);opacity:0;transition:opacity .2s;pointer-events:none}.stat-card:hover{transform:translateY(-2px)}.stat-card:hover:before{opacity:1}.stat-card-blue:hover{border-color:var(--border-glow);box-shadow:var(--shadow-glow)}.stat-card-blue:before{background:radial-gradient(ellipse at top left,var(--accent-glow) 0%,transparent 60%)}.stat-card-green:hover{border-color:#10b98173;box-shadow:0 0 24px var(--success-glow),0 4px 16px #00000080}.stat-card-green:before{background:radial-gradient(ellipse at top left,var(--success-glow) 0%,transparent 60%)}.stat-card-orange:hover{border-color:#f59e0b73;box-shadow:0 0 24px var(--warn-glow),0 4px 16px #00000080}.stat-card-orange:before{background:radial-gradient(ellipse at top left,var(--warn-glow) 0%,transparent 60%)}.stat-card-red:hover{border-color:#ef444473;box-shadow:0 0 24px var(--danger-glow),0 4px 16px #00000080}.stat-card-red:before{background:radial-gradient(ellipse at top left,var(--danger-glow) 0%,transparent 60%)}.stat-card .label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.7px;color:var(--text-3);margin-bottom:14px}.stat-card .value{font-size:40px;font-weight:800;line-height:1;letter-spacing:-1px;font-variant-numeric:tabular-nums}.stat-card .value-sub{font-size:12px;color:var(--text-3);margin-top:8px}.c-blue{color:var(--accent)}.c-green{color:var(--success)}.c-orange{color:var(--warn)}.c-red{color:var(--danger)}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-card);animation:fadeUp .35s ease both}.chart-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-3);margin-bottom:24px}.chart-bars{display:flex;align-items:flex-end;gap:20px;height:140px}.chart-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;height:100%;justify-content:flex-end}.chart-bar{width:100%;max-width:80px;border-radius:5px 5px 0 0;transition:height .6s cubic-bezier(.34,1.56,.64,1);min-height:3px;position:relative}.chart-bar:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:linear-gradient(to bottom,rgba(255,255,255,.1),transparent)}.chart-bar-n{font-size:22px;font-weight:800;line-height:1}.chart-bar-lbl{font-size:11px;color:var(--text-3);text-transform:capitalize;margin-top:4px;font-weight:500}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-card);animation:fadeUp .3s ease both}.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r);font-size:13px;font-weight:600;cursor:pointer;border:none;transition:all .15s;white-space:nowrap}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-sm{padding:4px 10px;font-size:12px}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow)}.btn-primary:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 14px var(--accent-glow);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-2);border:1px solid var(--border-hi)}.btn-ghost:hover:not(:disabled){background:#ffffff0a;color:var(--text-1);border-color:var(--border-glow)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover:not(:disabled){background:var(--danger);color:#fff}.btn-warn{background:var(--warn-dim);color:var(--warn);border:1px solid rgba(245,158,11,.25)}.btn-warn:hover:not(:disabled){background:var(--warn);color:#000}.btn-success{background:var(--success-dim);color:var(--success);border:1px solid rgba(16,185,129,.3)}.btn-success:hover:not(:disabled){background:var(--success);color:#fff}.table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);overflow-x:auto;box-shadow:var(--shadow-card);animation:fadeUp .3s ease both}table{width:100%;border-collapse:collapse}th{padding:11px 14px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-3);border-bottom:1px solid var(--border);white-space:nowrap;background:var(--bg-card);position:sticky;top:0;z-index:1}td{padding:12px 14px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}tr:last-child td{border-bottom:none}tbody tr{transition:background .1s}tbody tr:hover td{background:#3b82f60a}.td-mono{font-family:SF Mono,Fira Mono,monospace;font-size:12px}.td-actions{display:flex;gap:5px;align-items:center}.text-muted{color:var(--text-2)}.text-dim{color:var(--text-3)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;white-space:nowrap}.badge-green{background:var(--success-dim);color:var(--success)}.badge-yellow{background:var(--warn-dim);color:var(--warn)}.badge-red{background:var(--danger-dim);color:var(--danger)}.badge-blue{background:var(--accent-dim);color:var(--accent)}.badge-purple{background:var(--purple-dim);color:var(--purple)}.badge-teal{background:var(--teal-dim);color:var(--teal)}.badge-gray{background:#4755692e;color:var(--text-2)}.dot{width:7px;height:7px;border-radius:50%;display:inline-block;flex-shrink:0}.dot-green{background:var(--success);animation:pulse-ring 2s ease-in-out infinite}.dot-red{background:var(--danger);animation:pulse-ring-r 2s ease-in-out infinite}.dot-yellow{background:var(--warn);animation:pulse-ring-y 2s ease-in-out infinite}.dot-gray{background:var(--text-3)}.form-group{display:flex;flex-direction:column;gap:5px}.form-label{font-size:12px;font-weight:600;color:var(--text-2)}.form-control{background:var(--bg-input);border:1px solid var(--border-hi);border-radius:var(--r);color:var(--text-1);padding:8px 11px;font-size:13px;outline:none;width:100%;transition:border-color .15s,box-shadow .15s;font-family:inherit}.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:70px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--text-4);border-bottom:1px solid var(--border);padding-bottom:6px;margin-bottom:2px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;z-index:400;display:flex;align-items:center;justify-content:center;padding:24px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:fadeUp .15s ease}.modal{background:var(--bg-surface);border:1px solid var(--border-hi);border-radius:var(--r-lg);padding:28px;width:100%;max-width:620px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #000000b3,0 0 0 1px #3b82f60d}.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-title{font-size:16px;font-weight:700;letter-spacing:-.2px}.modal-close{background:none;border:none;color:var(--text-3);font-size:22px;cursor:pointer;line-height:1;padding:2px;transition:color .15s}.modal-close:hover{color:var(--text-1)}.modal-body{display:flex;flex-direction:column;gap:14px}.modal-ftr{display:flex;justify-content:flex-end;gap:8px;margin-top:24px;padding-top:16px;border-top:1px solid var(--border)}.login-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-root);background-image:radial-gradient(ellipse at 20% 30%,rgba(59,130,246,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(139,92,246,.05) 0%,transparent 50%)}.login-card{background:var(--bg-surface);border:1px solid var(--border-hi);border-radius:18px;padding:44px;width:100%;max-width:400px;box-shadow:0 20px 60px #0009,0 0 0 1px #3b82f60d;animation:fadeUp .3s ease}.login-brand{text-align:center;margin-bottom:36px}.login-brand .icon{width:52px;height:52px;background:linear-gradient(135deg,var(--accent),#1d4ed8);border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:900;color:#fff;margin:0 auto 16px;box-shadow:0 0 24px var(--accent-glow)}.login-brand h1{font-size:20px;font-weight:700;letter-spacing:-.3px}.login-brand h1 span{color:var(--accent)}.login-brand p{color:var(--text-3);font-size:13px;margin-top:6px}.login-form{display:flex;flex-direction:column;gap:16px}.login-err{background:var(--danger-dim);border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:10px 14px;border-radius:var(--r);font-size:13px}.refresh-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;font-size:12px;color:var(--text-2)}.refresh-stats{display:flex;gap:20px}.refresh-stats b{color:var(--text-1)}.empty{text-align:center;padding:64px 24px;color:var(--text-2)}.empty p{margin-top:8px;font-size:13px}.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .55s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;align-items:center;justify-content:center;padding:64px}.search-input{background:var(--bg-input);border:1px solid var(--border-hi);border-radius:var(--r);color:var(--text-1);padding:7px 12px;font-size:13px;outline:none;width:240px;transition:border-color .15s,box-shadow .15s}.search-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.search-input::placeholder{color:var(--text-3)}.alert{padding:10px 14px;border-radius:var(--r);font-size:13px;margin-bottom:16px;animation:fadeUp .2s ease}.alert-err{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(239,68,68,.3)}.alert-ok{background:var(--success-dim);color:var(--success);border:1px solid rgba(16,185,129,.3)}.section-divider{border:none;border-top:1px solid var(--border);margin:20px 0}.navbar-avatar{display:flex;align-items:center;gap:8px;background:none;border:none;cursor:pointer;padding:5px 8px;border-radius:var(--r);color:var(--text-2);font-size:13px;font-weight:500;transition:background .15s,color .15s}.navbar-avatar:hover{background:#ffffff0d;color:var(--text-1)}.avatar-initials{width:30px;height:30px;background:linear-gradient(135deg,var(--accent),#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;color:#fff;flex-shrink:0}.avatar-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.avatar-dropdown{position:absolute;top:calc(100% + 6px);right:0;width:220px;background:var(--bg-surface);border:1px solid var(--border-hi);border-radius:var(--r-lg);box-shadow:0 8px 32px #00000080,0 2px 8px #0000004d;z-index:500;animation:fadeUp .15s ease;overflow:hidden}.avatar-dropdown-user{display:flex;align-items:center;gap:10px;padding:14px 14px 12px}.avatar-initials-lg{width:36px;height:36px;flex-shrink:0;background:linear-gradient(135deg,var(--accent),#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff}.avatar-dropdown-sep{border:none;border-top:1px solid var(--border);margin:0}.avatar-dropdown-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;color:var(--text-2);font-size:13px;cursor:pointer;text-align:left;transition:background .12s,color .12s}.avatar-dropdown-item:hover{background:#ffffff0a;color:var(--text-1)}.avatar-dropdown-item.danger{color:var(--danger)}.avatar-dropdown-item.danger:hover{background:var(--danger-dim);color:var(--danger)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes toastOut{0%{opacity:1}80%{opacity:1}to{opacity:0}}.toast{position:fixed;bottom:28px;right:28px;z-index:9000;padding:12px 20px;border-radius:var(--r-lg);font-size:13px;font-weight:600;min-width:200px;box-shadow:0 8px 24px #0006;animation:toastIn .2s ease,toastOut 3.2s ease forwards;pointer-events:none}.toast-ok{background:var(--success);color:#fff}.toast-err{background:var(--danger);color:#fff}.toast-warn{background:var(--warn);color:#000}
