:root{--primary:#6a1b9a;--primary-dark:#4a148c;--secondary:#f3e5f5;--success:#4caf50;--warning:#ffc107;--error:#e53935;--text:#1a1a2e;--text-secondary:#557;--text-muted:#99b;--background:#faf5ff;--surface:#fff;--border:#e8d5f5;--white:#fff}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--background);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:14px}button{cursor:pointer;border:none;border-radius:8px;padding:8px 16px;font-family:inherit;font-size:14px;transition:opacity .15s,background .15s}button:disabled{opacity:.5;cursor:not-allowed}button:hover:not(:disabled){opacity:.88}input,select,textarea{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:8px;outline:none;padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--primary)}a{color:var(--primary);text-decoration:none}.btn-primary{background:var(--primary);color:var(--white);font-weight:700}.btn-secondary{background:var(--secondary);color:var(--primary);font-weight:600}.btn-danger{background:var(--error);color:var(--white);font-weight:600}.btn-icon-edit{cursor:pointer;background:var(--secondary);width:32px;height:32px;color:var(--primary);border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.btn-icon-edit svg{stroke:var(--primary)}.btn-icon-edit:hover{background:var(--primary)}.btn-icon-edit:hover svg{stroke:#fff}.btn-icon-delete{cursor:pointer;width:32px;height:32px;color:var(--error);background:#fde8e8;border:none;border-radius:8px;justify-content:center;align-items:center;transition:background .15s,color .15s;display:inline-flex}.btn-icon-delete svg{stroke:var(--error)}.btn-icon-delete:hover{background:var(--error)}.btn-icon-delete:hover svg{stroke:#fff}.btn-sm{padding:5px 12px;font-size:12px}.btn-icon{border:1px solid var(--border);color:var(--text-secondary);background:0 0;padding:5px 9px;font-size:15px}.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:16px}.badge{color:#fff;border-radius:999px;padding:2px 10px;font-size:11px;font-weight:700;display:inline-block}.tag{border:1px solid var(--border);background:var(--background);color:var(--text-secondary);cursor:pointer;white-space:nowrap;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:600;transition:all .15s;display:inline-block}.tag.active{background:var(--primary);border-color:var(--primary);color:#fff}.tag:hover:not(.active){border-color:var(--primary);color:var(--primary)}.form-group{flex-direction:column;gap:4px;margin-bottom:14px;display:flex}.form-group label{color:var(--text-secondary);font-size:12px;font-weight:600}.table-wrap{border:1px solid var(--border);border-radius:12px;overflow-x:auto}table{border-collapse:collapse;width:100%}th{background:var(--secondary);color:var(--primary);text-align:left;white-space:nowrap;padding:10px 14px;font-size:12px;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:10px 14px;font-size:13px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--background)}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:16px;width:100%;max-width:480px;max-height:90vh;padding:24px;overflow-y:auto;box-shadow:0 8px 32px #6a1b9a26}.modal h3{color:var(--primary);margin-bottom:16px;font-size:17px}.page{max-width:1100px;margin:0 auto;padding:24px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:20px;display:flex}.page-header h2{font-size:20px;font-weight:700}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin;display:inline-block}.spinner-center{justify-content:center;padding:48px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:var(--text-muted);padding:48px}.empty .emoji{margin-bottom:12px;font-size:48px;display:block}.chips{flex-wrap:wrap;gap:6px;display:flex}.alert{border-radius:8px;margin-bottom:12px;padding:12px 16px;font-size:13px}.alert-error{color:var(--error);background:#ffebee;border:1px solid #ffcdd2}.alert-success{color:#2e7d32;background:#e8f5e9;border:1px solid #c8e6c9}@media (width<=640px){.page{padding:12px}.hide-mobile{display:none}}.layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--primary-dark);flex-direction:column;flex-shrink:0;width:220px;height:100vh;transition:transform .25s;display:flex;overflow-y:auto}.sidebar-logo{border-bottom:1px solid #ffffff1f;align-items:center;gap:10px;padding:20px 16px 16px;display:flex}.sidebar-logo-icon{font-size:28px}.sidebar-title{color:#fff;font-size:15px;font-weight:700}.sidebar-sub{color:#ffffff8c;font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex}.nav-item{color:#ffffffbf;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff1a}.nav-item.active{color:#fff;background:#ffffff2e;font-weight:700}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-footer{border-top:1px solid #ffffff1f;justify-content:space-between;align-items:center;gap:8px;padding:12px 16px;display:flex}.sidebar-user{color:#ffffffb3;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;height:52px;padding:0 16px;display:flex}.topbar-title{color:var(--primary);font-size:15px;font-weight:600}.menu-btn{display:none}.main-content{flex:1;overflow-y:auto}.sidebar-overlay{z-index:99;background:#0006;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{z-index:100;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar-overlay{display:block}.menu-btn{display:flex!important}.topbar-title{font-size:14px}}.login-page{background:linear-gradient(135deg, var(--primary-dark) 0%, var(--primary) 100%);justify-content:center;align-items:center;min-height:100vh;padding:16px;display:flex}.login-card{background:var(--surface);text-align:center;border-radius:20px;width:100%;max-width:380px;padding:40px 36px;box-shadow:0 12px 40px #00000040}.login-logo{margin-bottom:8px;font-size:52px}.login-title{color:var(--primary);margin-bottom:4px;font-size:24px;font-weight:800}.login-sub{color:var(--text-muted);margin-bottom:24px;font-size:13px}.login-card .form-group{text-align:left}
