:root{--bg:#0f1117;--bg2:#161b27;--bg3:#1e2535;--border:hsla(0,0%,100%,.07);--border2:hsla(0,0%,100%,.12);--text:#f0f2f5;--text2:#8b92a5;--text3:#4a5268;--accent:#d42b2b;--accent2:#f44;--blue:#2563eb;--blue2:#3b82f6;--green:#16a34a;--green2:#22c55e;--amber:#d97706;--amber2:#f59e0b;--font:"DM Sans",sans-serif;--mono:"DM Mono",monospace;--radius:10px;--radius-lg:16px;--shadow:0 4px 24px rgba(0,0,0,.4)}*{box-sizing:border-box;margin:0;padding:0}#root,body,html{height:100%}body{-webkit-font-smoothing:antialiased;background:#0f1117;background:var(--bg);color:#f0f2f5;color:var(--text);font-family:DM Sans,sans-serif;font-family:var(--font);font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer}button,input,select,textarea{font-family:DM Sans,sans-serif;font-family:var(--font)}.layout{display:flex;height:100vh;overflow:hidden}.sidebar{background:#161b27;background:var(--bg2);border-right:1px solid hsla(0,0%,100%,.07);border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;width:240px}.sidebar-logo{border-bottom:1px solid hsla(0,0%,100%,.07);border-bottom:1px solid var(--border);padding:24px 20px 20px}.sidebar-logo img{height:32px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:12px 8px}.nav-item{align-items:center;background:none;border:none;border-radius:10px;border-radius:var(--radius);color:#8b92a5;color:var(--text2);cursor:pointer;display:flex;font-size:13.5px;font-weight:500;gap:10px;padding:9px 12px;text-align:left;transition:all .15s;width:100%}.nav-item:hover{background:#1e2535;background:var(--bg3);color:#f0f2f5;color:var(--text)}.nav-item.active{background:rgba(212,43,43,.15);color:#ff6b6b}.nav-item .icon{flex-shrink:0;height:18px;width:18px}.nav-badge{background:#d42b2b;background:var(--accent);border-radius:20px;color:#fff;font-size:10px;font-weight:700;margin-left:auto;padding:2px 6px}.sidebar-footer{border-top:1px solid hsla(0,0%,100%,.07);border-top:1px solid var(--border);padding:16px}.sidebar-user{gap:10px}.avatar,.sidebar-user{align-items:center;display:flex}.avatar{background:#d42b2b;background:var(--accent);border-radius:50%;color:#fff;flex-shrink:0;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-user-info .name{font-size:13px;font-weight:600}.sidebar-user-info .role{color:#4a5268;color:var(--text3);font-size:11px}.main{display:flex;flex:1 1;flex-direction:column;overflow-y:auto}.topbar{align-items:center;background:#161b27;background:var(--bg2);border-bottom:1px solid hsla(0,0%,100%,.07);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:16px 28px;position:sticky;top:0;z-index:10}.topbar-title{font-size:17px;font-weight:700}.topbar-actions{display:flex;gap:8px}.page{flex:1 1;padding:28px}.card{background:#161b27;background:var(--bg2);border:1px solid hsla(0,0%,100%,.07);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);padding:20px}.card-sm{padding:16px}.stat-card{background:#161b27;background:var(--bg2);border:1px solid hsla(0,0%,100%,.07);border:1px solid var(--border);border-radius:16px;border-radius:var(--radius-lg);padding:20px 24px}.stat-card .val{font-size:32px;font-weight:700;line-height:1;margin-bottom:6px}.stat-card .lbl{color:#8b92a5;color:var(--text2);font-size:12px;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.stat-card .delta{font-size:12px;margin-top:8px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr);margin-bottom:24px}.btn{align-items:center;border:none;border-radius:10px;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:8px 16px;transition:all .15s}.btn-primary{background:#d42b2b;background:var(--accent);color:#fff}.btn-primary:hover{background:#f44;background:var(--accent2)}.btn-secondary{background:#1e2535;background:var(--bg3);border:1px solid hsla(0,0%,100%,.12);border:1px solid var(--border2);color:#f0f2f5;color:var(--text)}.btn-secondary:hover{background:#252d42;border-color:hsla(0,0%,100%,.12);border-color:var(--border2)}.btn-success{background:#16a34a;background:var(--green);color:#fff}.btn-success:hover{background:#22c55e;background:var(--green2)}.btn-sm{font-size:12px;padding:5px 11px}.btn-ghost{background:none;border:none;color:#8b92a5;color:var(--text2)}.btn-ghost:hover{color:#f0f2f5;color:var(--text)}.btn-danger{background:rgba(212,43,43,.15);border:1px solid rgba(212,43,43,.3);color:#ff6b6b}.btn-danger:hover{background:rgba(212,43,43,.25)}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}th{color:#4a5268;color:var(--text3);font-size:11px;font-weight:600;letter-spacing:.06em;padding:10px 14px;text-align:left;text-transform:uppercase}td,th{border-bottom:1px solid hsla(0,0%,100%,.07);border-bottom:1px solid var(--border)}td{font-size:13.5px;padding:13px 14px}tr:last-child td{border-bottom:none}tr:hover td{background:hsla(0,0%,100%,.02)}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;gap:4px;padding:3px 9px}.badge-green{background:rgba(22,163,74,.15);color:#4ade80}.badge-red{background:rgba(212,43,43,.15);color:#ff6b6b}.badge-amber{background:rgba(217,119,6,.15);color:#fbbf24}.badge-blue{background:rgba(37,99,235,.15);color:#60a5fa}.badge-gray{background:hsla(0,0%,100%,.06);color:#8b92a5;color:var(--text2)}.dot{background:currentColor;border-radius:50%;display:inline-block;height:6px;width:6px}.form-group{margin-bottom:16px}.form-label{color:#8b92a5;color:var(--text2);display:block;font-size:12px;font-weight:600;letter-spacing:.04em;margin-bottom:6px;text-transform:uppercase}.form-input{background:#1e2535;background:var(--bg3);border:1px solid hsla(0,0%,100%,.12);border:1px solid var(--border2);border-radius:10px;border-radius:var(--radius);color:#f0f2f5;color:var(--text);font-size:14px;outline:none;padding:9px 13px;transition:border .15s;width:100%}.form-input:focus{border-color:#3b82f6;border-color:var(--blue2)}.form-select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%238b92a5' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.form-row{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.modal-overlay{align-items:center;background:rgba(0,0,0,.7);display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:100}.modal{background:#161b27;background:var(--bg2);border:1px solid hsla(0,0%,100%,.12);border:1px solid var(--border2);border-radius:16px;border-radius:var(--radius-lg);max-height:90vh;max-width:520px;overflow-y:auto;width:100%}.modal-header{align-items:center;border-bottom:1px solid hsla(0,0%,100%,.07);border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px 16px}.modal-title{font-size:16px;font-weight:700}.modal-body{padding:20px 24px}.modal-footer{border-top:1px solid hsla(0,0%,100%,.07);border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end;padding:16px 24px}.divider{background:hsla(0,0%,100%,.07);background:var(--border);height:1px;margin:20px 0}.empty{color:#4a5268;color:var(--text3);padding:60px 20px;text-align:center}.empty .icon{font-size:40px;margin-bottom:12px}.empty p{font-size:14px}.section-title{color:#4a5268;color:var(--text3);font-size:12px;font-weight:700;letter-spacing:.08em;margin-bottom:12px;text-transform:uppercase}.tag{background:#1e2535;background:var(--bg3);border:1px solid hsla(0,0%,100%,.07);border:1px solid var(--border);border-radius:6px;display:inline-block;font-size:11px;padding:2px 8px}.mono,.tag{color:#8b92a5;color:var(--text2)}.mono{font-family:DM Mono,monospace;font-family:var(--mono);font-size:12px}.alert{border-radius:10px;border-radius:var(--radius);font-size:13px;margin-bottom:16px;padding:12px 16px}.alert-success{background:rgba(22,163,74,.15);border:1px solid rgba(34,197,94,.2);color:#4ade80}.alert-error{background:rgba(212,43,43,.15);border:1px solid rgba(212,43,43,.2);color:#ff6b6b}.spinner{animation:spin .6s linear infinite;border:2px solid hsla(0,0%,100%,.12);border-top-color:#d42b2b;border:2px solid var(--border2);border-radius:50%;border-top-color:var(--accent);height:20px;width:20px}@keyframes spin{to{transform:rotate(1turn)}}.skeleton{animation:shimmer 1.2s infinite;background:linear-gradient(90deg,#1e2535 25%,#161b27 50%,#1e2535 75%);background:linear-gradient(90deg,var(--bg3) 25%,var(--bg2) 50%,var(--bg3) 75%);background-size:200% 100%;border-radius:10px;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}
/*# sourceMappingURL=main.3909b8b4.css.map*/