*,:before,:after{box-sizing:border-box}html,body,#app{height:100%}body{color:var(--c-text);background:var(--c-bg);-webkit-font-smoothing:antialiased;text-rendering:optimizelegibility;margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.5}a{color:var(--c-accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--c-scroll);border-radius:8px}::-webkit-scrollbar-thumb:hover{background:var(--c-scroll-hover)}:root[data-theme=dark]{--c-bg:#0f1422;--c-bg-2:#131a2c;--c-surface:#1a2238;--c-surface-2:#212c46;--c-border:#2a3554;--c-border-strong:#364571;--c-text:#e6ecff;--c-text-muted:#8b97b8;--c-text-dim:#5d6a8c;--c-accent:#6c7cff;--c-accent-hover:#5867f0;--c-accent-soft:#6c7cff26;--c-success:#2dd4a4;--c-success-soft:#2dd4a426;--c-danger:#ff5d6c;--c-danger-soft:#ff5d6c26;--c-warn:#ffb84d;--c-warn-soft:#ffb84d26;--c-info:#4dadff;--c-info-soft:#4dadff26;--c-scroll:#2a3554;--c-scroll-hover:#3d4c75;--shadow-sm:0 1px 2px #00000040;--shadow-md:0 4px 16px #00000059;--shadow-lg:0 12px 32px #00000073;--gradient-brand:linear-gradient(135deg, #6c7cff 0%, #9b6cff 100%)}:root[data-theme=light]{--c-bg:#f5f7fb;--c-bg-2:#eef1f8;--c-surface:#fff;--c-surface-2:#f8fafc;--c-border:#e2e7f0;--c-border-strong:#c9d1e0;--c-text:#131a2c;--c-text-muted:#5a6580;--c-text-dim:#8a93ad;--c-accent:#5867f0;--c-accent-hover:#4453e0;--c-accent-soft:#5867f01f;--c-success:#15a97c;--c-success-soft:#15a97c1f;--c-danger:#e23a4d;--c-danger-soft:#e23a4d1f;--c-warn:#d98b00;--c-warn-soft:#d98b001f;--c-info:#1f8fff;--c-info-soft:#1f8fff1f;--c-scroll:#d3d9e6;--c-scroll-hover:#b8c1d4;--shadow-sm:0 1px 2px #0f14220f;--shadow-md:0 4px 16px #0f142214;--shadow-lg:0 12px 32px #0f14221f;--gradient-brand:linear-gradient(135deg, #5867f0 0%, #8b5cf6 100%)}.page{flex-direction:column;gap:20px;min-height:100%;padding:24px 28px;display:flex}.card{background:var(--c-surface);border:1px solid var(--c-border);box-shadow:var(--shadow-sm);border-radius:14px;padding:18px 20px}.toolbar{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));align-items:end;gap:14px;display:grid}.toolbar .toolbar-actions{justify-content:flex-end;align-items:end;gap:8px;display:flex}.h1{color:var(--c-text);margin:0;font-size:22px;font-weight:700}.h2{color:var(--c-text);margin:0;font-size:18px;font-weight:600}.muted{color:var(--c-text-muted)}.dim{color:var(--c-text-dim);font-size:12px}.title-gradient{background:var(--gradient-brand);color:#0000;-webkit-background-clip:text;background-clip:text}.btn{background:var(--c-surface-2);color:var(--c-text);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn:hover:not(:disabled){background:var(--c-bg-2);border-color:var(--c-border-strong)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--c-accent);color:#fff;border-color:var(--c-accent)}.btn-primary:hover:not(:disabled){background:var(--c-accent-hover);border-color:var(--c-accent-hover)}.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn-danger:hover:not(:disabled){filter:brightness(1.05)}.btn-ghost{border-color:var(--c-border);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--c-surface-2)}.btn-icon{width:34px;height:34px;color:var(--c-text-muted);background:0 0;border-color:#0000;border-radius:8px;padding:0}.btn-icon:hover:not(:disabled){background:var(--c-surface-2);color:var(--c-text)}.btn-sm{border-radius:8px;padding:6px 10px;font-size:13px}.field{flex-direction:column;gap:6px;display:flex}.field-label{color:var(--c-text-muted);font-size:12px;font-weight:500}.field-error{color:var(--c-danger);font-size:12px}.input,.select,.textarea{background:var(--c-surface-2);border:1px solid var(--c-border);width:100%;color:var(--c-text);border-radius:10px;outline:none;padding:10px 12px;transition:border .15s,box-shadow .15s}.input::placeholder,.textarea::placeholder{color:var(--c-text-dim)}.input:focus,.select:focus,.textarea:focus{border-color:var(--c-accent);box-shadow:0 0 0 3px var(--c-accent-soft)}.textarea{resize:vertical;min-height:96px;font-family:inherit}.input-icon{position:relative}.input-icon .input{padding-left:38px}.input-icon .input-icon-el{color:var(--c-text-dim);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.badge{background:var(--c-surface-2);color:var(--c-text);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;display:inline-flex}.badge-success{background:var(--c-success-soft);color:var(--c-success)}.badge-danger{background:var(--c-danger-soft);color:var(--c-danger)}.badge-warn{background:var(--c-warn-soft);color:var(--c-warn)}.badge-info{background:var(--c-info-soft);color:var(--c-info)}.badge-dot:before{content:"";background:currentColor;border-radius:50%;width:6px;height:6px}.table-wrap{border:1px solid var(--c-border);border-radius:12px;overflow-x:auto}.table{border-collapse:collapse;width:100%;min-width:600px}.table thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--c-text-muted);background:var(--c-surface-2);border-bottom:1px solid var(--c-border);white-space:nowrap;z-index:1;padding:12px 16px;font-size:11px;font-weight:600;position:sticky;top:0}.table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.table thead th.sortable:hover{color:var(--c-text)}.table thead th .sort-ind{opacity:.5;margin-left:4px}.table thead th .sort-ind.active{opacity:1;color:var(--c-accent)}.table tbody td{border-bottom:1px solid var(--c-border);background:var(--c-surface);color:var(--c-text);vertical-align:middle;padding:14px 16px}.table tbody tr:last-child td{border-bottom:none}.table tbody tr:hover td{background:var(--c-surface-2)}.table .row-actions{justify-content:flex-end;gap:4px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#080c168c;justify-content:center;align-items:center;padding:16px;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--c-surface);border:1px solid var(--c-border);width:min(640px,100%);max-height:calc(100vh - 32px);box-shadow:var(--shadow-lg);border-radius:16px;flex-direction:column;animation:.18s slideUp;display:flex;overflow:hidden}.modal-lg{width:min(880px,100%)}.modal-header{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-body{padding:20px 22px;overflow-y:auto}.modal-footer{border-top:1px solid var(--c-border);background:var(--c-surface-2);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;display:grid}.form-grid .full{grid-column:1/-1}.form-sections{flex-direction:column;gap:22px;display:flex}.form-section{flex-direction:column;gap:12px;display:flex}.form-section-head{border-bottom:1px dashed var(--c-border);align-items:center;gap:10px;padding-bottom:6px;display:flex}.form-section-head .num{background:var(--c-accent-soft);width:22px;height:22px;color:var(--c-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:700;display:inline-flex}.form-section-title{color:var(--c-text);font-size:13px;font-weight:600}.form-section-hint{color:var(--c-text-muted);margin-left:auto;font-size:12px}.form-row{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.toasts{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:20px;right:20px}.toast{border:1px solid var(--c-border);background:var(--c-surface);min-width:240px;box-shadow:var(--shadow-md);border-radius:10px;align-items:center;gap:10px;padding:12px 16px;animation:.18s slideUp;display:flex}.toast-success{border-left:3px solid var(--c-success)}.toast-error{border-left:3px solid var(--c-danger)}.toast-info{border-left:3px solid var(--c-info)}.spinner{border:2px solid var(--c-border-strong);border-top-color:var(--c-accent);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner-lg{border-width:3px;width:36px;height:36px}@keyframes spin{to{transform:rotate(360deg)}}.center-pad{color:var(--c-text-muted);justify-content:center;align-items:center;padding:60px 0;display:flex}.row{align-items:center;gap:8px;display:flex}.row-between{justify-content:space-between;align-items:center;gap:8px;display:flex}.gap-sm{gap:6px}.grow{flex:1}.no-wrap{white-space:nowrap}.ellipsis{text-overflow:ellipsis;white-space:nowrap;max-width:280px;overflow:hidden}.avatar{background:var(--c-surface-2);width:32px;height:32px;color:var(--c-text-muted);border-radius:50%;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.avatar-lg{width:64px;height:64px;font-size:18px}.pagination{color:var(--c-text-muted);justify-content:space-between;align-items:center;padding:14px 4px 4px;font-size:13px;display:flex}.pagination .pages{gap:6px;display:flex}.empty{text-align:center;color:var(--c-text-muted);flex-direction:column;align-items:center;gap:8px;padding:60px 20px;display:flex}.empty .empty-icon{opacity:.6;font-size:32px}.tabs{background:var(--c-surface-2);border-radius:10px;gap:4px;padding:4px;display:flex}.tabs button{color:var(--c-text-muted);background:0 0;border:0;border-radius:7px;flex:1;padding:7px 12px;font-size:13px;font-weight:500;transition:all .15s}.tabs button.active{background:var(--c-surface);color:var(--c-text);box-shadow:var(--shadow-sm)}.chips{flex-wrap:wrap;gap:6px;display:flex}.chip{background:var(--c-accent-soft);color:var(--c-accent);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:13px;display:inline-flex}.chip button{color:inherit;cursor:pointer;background:0 0;border:0;padding:0;font-size:14px;line-height:1}@media (width<=768px){.page{padding:16px}.card{border-radius:12px;padding:14px}.h1{font-size:18px}.toolbar{grid-template-columns:1fr}.toolbar .toolbar-actions{justify-content:stretch}.toolbar .toolbar-actions .btn{flex:1}}:root{--p-brand:#2553ff;--p-brand-strong:#1e40ff;--p-brand-deep:#1635c8;--p-bg:#f4f6fb;--p-bg-soft:#eef2f9;--p-surface:#fff;--p-border:#e3e8f1;--p-border-soft:#eef1f7;--p-text:#0f172a;--p-text-muted:#5b6478;--p-text-dim:#8893a8;--p-success:#16a37a;--p-success-soft:#e6f7f0;--p-warn:#c97000;--p-warn-soft:#fdf1dd;--p-danger:#b91c1c;--p-danger-soft:#fee2e2;--p-shadow-sm:0 1px 2px #0f172a0f;--p-shadow-md:0 8px 24px #0f172a14}.p-container{width:100%;max-width:1440px;margin:0 auto;padding:0 clamp(16px,3vw,40px)}@media (width>=1600px){.p-container{max-width:1480px}}.p-page{min-width:0;padding:clamp(20px,3vw,36px) 0 60px}.p-btn{background:var(--p-surface);height:42px;color:var(--p-text);cursor:pointer;white-space:nowrap;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:0 18px;font-family:inherit;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,border-color .15s,transform 50ms;display:inline-flex}.p-btn:hover{text-decoration:none}.p-btn:active:not(:disabled){transform:translateY(1px)}.p-btn:disabled{opacity:.55;cursor:not-allowed}.p-btn-primary{background:var(--p-brand);color:#fff;border-color:var(--p-brand)}.p-btn-primary:hover:not(:disabled){background:var(--p-brand-strong);border-color:var(--p-brand-strong)}.p-btn-ghost{border-color:var(--p-border);background:0 0}.p-btn-ghost:hover:not(:disabled){background:var(--p-bg-soft)}.p-btn-danger{background:var(--p-danger);color:#fff;border-color:var(--p-danger)}.p-btn-sm{height:34px;padding:0 12px;font-size:13px}.p-input,.p-select,.p-textarea{border:1px solid var(--p-border);background:var(--p-surface);width:100%;height:42px;color:var(--p-text);border-radius:10px;outline:none;padding:0 14px;font-family:inherit;font-size:14px;transition:border-color .15s,box-shadow .15s}.p-textarea{resize:vertical;height:auto;min-height:110px;padding:12px 14px;line-height:1.5}.p-input::placeholder,.p-textarea::placeholder{color:var(--p-text-dim)}.p-input:focus,.p-select:focus,.p-textarea:focus{border-color:var(--p-brand);box-shadow:0 0 0 3px #2553ff1a}.p-input:disabled,.p-select:disabled,.p-textarea:disabled{background:var(--p-bg-soft);color:var(--p-text-dim);cursor:not-allowed}.p-field{flex-direction:column;gap:6px;min-width:0;display:flex}.p-label{color:var(--p-text);font-size:13px;font-weight:700}.p-hint{color:var(--p-text-muted);font-size:12px}.p-error{color:var(--p-danger);font-size:12px}.p-card{background:var(--p-surface);border:1px solid var(--p-border);border-radius:16px;padding:clamp(16px,2.4vw,22px)}.p-h1{letter-spacing:-.02em;color:var(--p-text);margin:0;font-size:clamp(24px,3vw,36px);font-weight:800;line-height:1.2}.p-h2{color:var(--p-text);margin:0;font-size:clamp(18px,2vw,22px);font-weight:700;line-height:1.3}.p-muted{color:var(--p-text-muted)}.p-dim{color:var(--p-text-dim);font-size:13px}.p-status{white-space:nowrap;border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.p-status-on{background:var(--p-success-soft);color:var(--p-success)}.p-status-off{background:var(--p-danger-soft);color:var(--p-danger)}.p-status-warn{background:var(--p-warn-soft);color:var(--p-warn)}.p-spinner{border:3px solid #cdd6e9;border-top-color:var(--p-brand);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite pSpin}.p-spinner-sm{border-width:2px;width:14px;height:14px}@keyframes pSpin{to{transform:rotate(360deg)}}.p-empty{background:var(--p-surface);border:1px dashed var(--p-border);color:var(--p-text-muted);border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:80px 20px;display:flex}.p-empty-icon{opacity:.5;font-size:32px}.p-cards{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;display:grid}.p-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.p-grow{flex:1;min-width:0}.p-stack{flex-direction:column;gap:12px;min-width:0;display:flex}.p-stack-lg{gap:24px}
