*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0B0F1A;--surface: #111827;--surface2: #1a2235;--border: #1f2d45;--border2: #2a3a55;--text: #E8EEF8;--text2: #8899BB;--text3: #4a5a7a;--accent: #E67E22;--accent2: #F0A047;--success: #27AE60;--danger: #C0392B;--warning: #F39C12;--info: #2980B9;--font-head: "Syne", sans-serif;--font-body: "DM Sans", sans-serif;--radius: 10px;--shadow: 0 4px 24px rgba(0,0,0,.35)}body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}h1,h2,h3,h4{font-family:var(--font-head)}a{color:var(--accent);text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}input,select,textarea{font-family:var(--font-body);color:var(--text);background:var(--surface2);border:1px solid var(--border2);border-radius:var(--radius);padding:8px 12px;font-size:13px;outline:none;width:100%}input:focus,select:focus,textarea:focus{border-color:var(--accent)}select option{background:var(--surface2)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius);border:none;font-weight:600;font-size:13px;transition:all .15s}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent2)}.btn-ghost{background:transparent;color:var(--text2);border:1px solid var(--border2)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:5px 12px;font-size:12px}.btn:disabled{opacity:.4;cursor:not-allowed}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.tag{display:inline-block;padding:2px 10px;border-radius:20px;font-size:11px;font-weight:700}.tag-success{background:#27ae6022;color:#27ae60;border:1px solid #27AE6044}.tag-danger{background:#c0392b22;color:#e74c3c;border:1px solid #C0392B44}.tag-warning{background:#f39c1222;color:#f39c12;border:1px solid #F39C1244}.tag-info{background:#2980b922;color:#5dade2;border:1px solid #2980B944}.tag-gray{background:#2a3a5522;color:var(--text2);border:1px solid var(--border2)}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:12px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.5px}.form-row{display:grid;gap:14px}.form-row-2{grid-template-columns:1fr 1fr}.form-row-3{grid-template-columns:1fr 1fr 1fr}table{width:100%;border-collapse:collapse;font-size:13px}thead tr{background:var(--surface2);position:sticky;top:0;z-index:5}th{padding:10px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border);white-space:nowrap}td{padding:10px 14px;border-bottom:1px solid var(--border)}tbody tr:hover{background:var(--surface2)}tbody tr:last-child td{border-bottom:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal{background:var(--surface);border:1px solid var(--border2);border-radius:14px;padding:28px;width:100%;max-width:580px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px}.modal-header h3{font-size:18px;font-family:var(--font-head)}.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;border-top:1px solid var(--border);padding-top:18px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-header h2{font-size:22px;font-family:var(--font-head)}.page-subtitle{color:var(--text2);font-size:13px;margin-top:3px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:var(--text3);gap:12px}.empty-state-icon{font-size:40px}.empty-state p{font-size:15px;font-weight:600;color:var(--text2)}.empty-state span{font-size:13px}@keyframes fadeIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:18px;height:18px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;display:inline-block}
