:root{--c-bg:#f0f2f5;--c-surface:#fff;--c-border:#d8dde4;--c-border-strong:#c5ccd6;--c-text:#1a2332;--c-muted:#5c6778;--c-primary:#1a56a8;--c-primary-dark:#144785;--c-primary-soft:#e8f0fa;--c-sidebar:#fff;--c-sidebar-text:#3d4a5c;--c-sidebar-active:#e8f0fa;--c-success:#157347;--c-success-soft:#e6f4ec;--c-warning:#b45309;--c-warning-soft:#fef6e8;--c-danger:#b42318;--c-danger-soft:#fcebea;--c-info:#0b6e7a;--c-info-soft:#e6f6f8;--radius:8px;--radius-sm:6px;--shadow:0 1px 2px #1a23320f;--shadow-lg:0 8px 24px #1a23321a;--sidebar-w:252px;--font:"IBM Plex Sans", "Segoe UI", system-ui, -apple-system, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:var(--font);background:var(--c-bg);color:var(--c-text);-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}h1,h2,h3,h4{font-weight:650;line-height:1.25}.btn{border-radius:var(--radius-sm);white-space:nowrap;background:var(--c-surface);color:var(--c-text);border:1px solid #0000;border-color:var(--c-border);justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-size:13.5px;font-weight:550;transition:all .15s;display:inline-flex}.btn:hover{background:#f8fafc}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}.btn-primary:hover{background:var(--c-primary-dark)}.btn-danger{background:var(--c-danger);color:#fff;border-color:var(--c-danger)}.btn-danger:hover{filter:brightness(.93)}.btn-success{background:var(--c-success);color:#fff;border-color:var(--c-success)}.btn-ghost{background:0 0;border-color:#0000}.btn-ghost:hover{background:#f1f5f9}.btn-sm{padding:6px 11px;font-size:12.5px}.btn-block{width:100%}.btn-icon{padding:6px 8px}.btn-logout{gap:6px}.field{margin-bottom:16px}.field label{color:#334155;margin-bottom:6px;font-size:13px;font-weight:550;display:block}.field .req{color:var(--c-danger)}.input,.select,.textarea{border:1px solid var(--c-border);border-radius:var(--radius-sm);width:100%;color:var(--c-text);background:#fff;padding:10px 12px;font-family:inherit;font-size:14px;transition:border .15s,box-shadow .15s}.input:focus,.select:focus,.textarea:focus{border-color:var(--c-primary);box-shadow:0 0 0 3px var(--c-primary-soft);outline:none}.textarea{resize:vertical;min-height:80px}.field-error{color:var(--c-danger);margin-top:4px;font-size:12px}.form-grid{grid-template-columns:repeat(2,1fr);gap:0 18px;display:grid}@media (width<=640px){.form-grid{grid-template-columns:1fr}}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:20px}.card-header{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.card-header h3{font-size:15px}.stat-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;display:grid}.stat{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:6px;padding:18px;display:flex}.stat .stat-label{color:var(--c-muted);text-transform:uppercase;letter-spacing:.03em;font-size:12.5px;font-weight:550}.stat .stat-value{font-size:28px;font-weight:700}.stat .stat-icon{border-radius:var(--radius-sm);background:var(--c-primary-soft);width:36px;height:36px;color:var(--c-primary);place-items:center;margin-bottom:4px;display:grid}.table-wrap{overflow-x:auto}table.data{border-collapse:collapse;width:100%;font-size:13.5px}table.data th{text-align:left;color:var(--c-muted);border-bottom:1px solid var(--c-border);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;background:#f8fafc;padding:11px 14px;font-size:12px;font-weight:600}table.data td{border-bottom:1px solid var(--c-border);vertical-align:middle;padding:11px 14px}table.data tbody tr:hover{background:#f8fafc}table.data tbody tr:last-child td{border-bottom:none}.table-empty{text-align:center;color:var(--c-muted);padding:40px}.badge{border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.badge.gray{color:#475569;background:#f1f5f9}.badge.blue{background:var(--c-primary-soft);color:var(--c-primary-dark)}.badge.green{background:var(--c-success-soft);color:var(--c-success)}.badge.amber{background:var(--c-warning-soft);color:var(--c-warning)}.badge.red{background:var(--c-danger-soft);color:var(--c-danger)}.badge.cyan{background:var(--c-info-soft);color:var(--c-info)}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;top:18px;right:18px}.toast{border-radius:var(--radius-sm);color:#fff;min-width:280px;max-width:380px;box-shadow:var(--shadow-lg);align-items:flex-start;gap:10px;padding:13px 16px;font-size:13.5px;animation:.2s slideIn;display:flex}.toast.success{background:var(--c-success)}.toast.error{background:var(--c-danger)}.toast.warning{background:var(--c-warning)}.toast.info{background:var(--c-primary)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.modal-backdrop{z-index:1000;background:#1a233266;justify-content:center;align-items:flex-start;padding:40px 16px;display:flex;position:fixed;inset:0;overflow-y:auto}.modal{border-radius:var(--radius);box-shadow:var(--shadow-lg);background:#fff;width:100%;max-width:560px;margin:auto 0;animation:.2s slideIn}.modal.lg{max-width:820px}.modal-header{border-bottom:1px solid var(--c-border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-body{padding:22px}.modal-footer{border-top:1px solid var(--c-border);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.app-shell{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-w);background:var(--c-sidebar);color:var(--c-sidebar-text);border-right:1px solid var(--c-border);z-index:50;flex-direction:column;flex-shrink:0;display:flex;position:fixed;inset:0 auto 0 0}.sidebar .brand{color:var(--c-text);border-bottom:1px solid var(--c-border);letter-spacing:-.02em;align-items:center;gap:10px;padding:18px 20px;font-size:15px;font-weight:700;display:flex}.sidebar .brand .logo{border-radius:var(--radius-sm);background:var(--c-primary);color:#fff;place-items:center;width:32px;height:32px;display:grid}.sidebar .brand-text{line-height:1.2}.sidebar nav{scrollbar-width:thin;scrollbar-color:var(--c-border-strong) transparent;flex:1;padding:10px 12px;overflow-y:auto}.sidebar nav::-webkit-scrollbar{width:6px}.sidebar nav::-webkit-scrollbar-track{background:0 0}.sidebar nav::-webkit-scrollbar-thumb{background:var(--c-border-strong);border-radius:999px}.sidebar nav::-webkit-scrollbar-thumb:hover{background:var(--c-muted)}.sidebar .nav-section{text-transform:uppercase;letter-spacing:.06em;color:var(--c-muted);padding:16px 10px 6px;font-size:10.5px;font-weight:600}.sidebar a.nav-link{border-radius:var(--radius-sm);color:var(--c-sidebar-text);border:1px solid #0000;align-items:center;gap:10px;margin-bottom:2px;padding:8px 10px;font-size:13.5px;font-weight:500;transition:background .12s,color .12s,border-color .12s;display:flex}.sidebar a.nav-link:hover{color:var(--c-text);background:#f4f6f9}.sidebar a.nav-link.router-link-active{background:var(--c-sidebar-active);color:var(--c-primary);border-color:#c5d9ef;font-weight:600}.sidebar a.nav-link .nav-ico{opacity:.85;justify-content:center;align-items:center;width:20px;display:flex}.sidebar a.nav-link.router-link-active .nav-ico{opacity:1;color:var(--c-primary)}.main{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--c-surface);border-bottom:1px solid var(--c-border);z-index:40;justify-content:space-between;align-items:center;height:56px;padding:0 22px;display:flex;position:sticky;top:0}.topbar .page-title{color:var(--c-text);letter-spacing:-.01em;font-size:16px;font-weight:600}.topbar .user-chip{align-items:center;gap:8px;display:flex}.topbar .user-name{font-size:13px;font-weight:600;line-height:1.2}.topbar .user-role{color:var(--c-muted);font-size:11.5px;line-height:1.2}.topbar .user-meta{text-align:right}.user-profile-link:hover .user-name{color:var(--c-primary)}.avatar{background:var(--c-primary);color:#fff;border-radius:50%;place-items:center;width:34px;height:34px;font-size:13px;font-weight:600;display:grid}.content{flex:1;padding:24px}.menu-toggle,.sidebar-overlay{display:none}@media (width<=900px){.sidebar{box-shadow:var(--shadow-lg);transition:transform .22s;transform:translate(-100%)}.sidebar.open{transform:none}.main{margin-left:0}.menu-toggle{display:inline-flex}.sidebar-overlay{z-index:45;background:#1a233259;animation:.2s fadeIn;display:block;position:fixed;inset:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:20px;display:flex}.page-header h1{letter-spacing:-.02em;font-size:21px;font-weight:700}.page-header p{color:var(--c-muted);margin-top:2px;font-size:13.5px}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.toolbar .spacer{flex:1}.row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.muted{color:var(--c-muted)}.text-right{text-align:right}.mt-2{margin-top:8px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.grid-2{grid-template-columns:1fr 1fr;gap:18px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}@media (width<=800px){.grid-2,.grid-3{grid-template-columns:1fr}}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:8px}.gap-3{gap:12px}.actions{gap:6px;display:flex}.remove-line .lbl{display:none}.search-input{min-width:220px}.pagination{justify-content:flex-end;align-items:center;gap:6px;padding:14px;display:flex}.pagination button{min-width:34px}.spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin}.spinner.dark{border-color:var(--c-border);border-top-color:var(--c-primary)}.loading-center{justify-content:center;padding:50px;display:flex}@keyframes spin{to{transform:rotate(360deg)}}.login-wrap{background:var(--c-bg);background-image:linear-gradient(#1a56a80a 0%,#0000 40%),repeating-linear-gradient(-45deg,#0000,#0000 12px,#1a233205 12px 13px);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:32px 28px}.login-brand{text-align:center;margin-bottom:28px}.login-logo{border-radius:var(--radius);background:var(--c-primary);color:#fff;place-items:center;width:52px;height:52px;margin:0 auto 14px;display:grid}.login-card h1{letter-spacing:-.02em;margin-bottom:6px;font-size:20px;font-weight:700}.login-card .sub{color:var(--c-muted);font-size:13.5px}.import-modal .import-steps{color:#334155;margin:0 0 0 18px;font-size:13px;line-height:1.55}.import-modal .import-steps li{margin-bottom:4px}.btn-link{color:var(--c-primary);font-weight:600;font-size:inherit;cursor:pointer;background:0 0;border:none;padding:0;text-decoration:underline}.btn-link:disabled{opacity:.6;cursor:not-allowed}.import-dropzone{border:2px dashed var(--c-border-strong);border-radius:var(--radius);text-align:center;cursor:pointer;color:var(--c-muted);padding:28px 20px;transition:border-color .15s,background .15s}.import-dropzone.over,.import-dropzone.filled{border-color:var(--c-primary);background:var(--c-primary-soft);color:var(--c-text)}.import-dropzone .dz-title{margin-top:10px;font-size:14px;font-weight:600}.import-dropzone .dz-sub{margin-top:4px;font-size:12px}.import-progress-head{justify-content:space-between;margin-bottom:6px;display:flex}.import-progress-bar{background:#e8ecf1;border-radius:999px;height:6px;overflow:hidden}.import-progress-fill{background:var(--c-primary);height:100%;transition:width .15s}.import-log{border:1px solid var(--c-border);border-radius:var(--radius-sm);background:#fafbfc;max-height:160px;margin-top:10px;font-size:12px;overflow-y:auto}.import-log-line{border-bottom:1px solid #eef1f5;padding:6px 10px}.import-log-line.ok{color:#157347}.import-log-line.err{color:var(--c-danger);font-weight:500}.import-errors ul{max-height:200px;margin:0;padding-left:18px;font-size:13px;overflow-y:auto}.import-errors li{color:#334155;margin-bottom:6px}@media (width<=768px){.content{padding:14px 13px 32px}body{font-size:14.5px}.topbar{gap:8px;height:56px;padding:0 12px}.topbar .page-title{font-size:16px}.topbar .user-chip{gap:6px}.topbar .user-chip .user-meta{display:none}.menu-toggle{padding:6px 10px}.sidebar{--sidebar-w:min(82vw, 300px);width:min(82vw,300px)}.sidebar a.nav-link{padding:13px 14px;font-size:15px}.sidebar .nav-section{padding:16px 14px 6px}.page-header{gap:10px;margin-bottom:16px}.page-header h1{font-size:19px}.page-header>.row,.page-header>.actions{width:100%}.page-header .btn,.page-header .row>.btn{flex:auto}.toolbar{gap:8px}.toolbar>*{flex:100%;min-width:0;max-width:none!important}.toolbar .spacer{display:none}.search-input{width:100%;min-width:0}.toolbar .btn{flex:100%}.input,.select,.textarea{padding:12px 13px;font-size:16px}.btn{padding:11px 16px;font-size:14px}.btn-sm{padding:9px 12px;font-size:13px}table.data-cards thead{display:none}table.data-cards,table.data-cards tbody,table.data-cards tr,table.data-cards td{width:100%;display:block}.table-wrap{overflow-x:visible}table.data-cards tr{border:1px solid var(--c-border);border-radius:var(--radius-sm);background:#fff;margin-bottom:12px;padding:4px 2px}table.data-cards tbody tr:hover{background:#fff}table.data-cards tbody tr:last-child td{border-bottom:1px solid #f1f5f9}table.data-cards td{text-align:right;border:none;border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:14px;min-height:44px;padding:10px 14px;display:flex}table.data-cards td:last-child{border-bottom:none}table.data-cards td:before{content:attr(data-label);text-align:left;color:var(--c-muted);text-transform:uppercase;letter-spacing:.03em;flex:0 0 38%;font-size:11px;font-weight:600}table.data-cards td[data-label=""]{justify-content:flex-end}table.data-cards td[data-label=""]:before{display:none}table.data-cards .actions{flex-wrap:wrap;justify-content:flex-end;gap:8px}table.data-cards .actions .btn{flex:auto;min-width:88px}table.data-cards tr.empty-row{background:0 0;border:none}table.data-cards td.empty-cell{text-align:center;border:none;display:block}table.data-cards td.empty-cell:before{display:none}table.data-cards.stacked td{text-align:left;flex-direction:column;align-items:stretch;gap:6px}table.data-cards.stacked td:before{flex:none;margin-bottom:2px}table.data-cards.stacked td .select,table.data-cards.stacked td .input{width:100%!important}.remove-line{width:100%}.remove-line .x{display:none}.remove-line .lbl{display:inline}.pagination{flex-wrap:wrap;justify-content:center;gap:8px;padding:12px}.pagination button{min-width:42px;min-height:40px}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px}.stat{padding:14px}.stat .stat-value{font-size:22px}.stat .stat-label{font-size:11px}.modal-backdrop{align-items:flex-end;padding:0}.modal{border-radius:16px 16px 0 0;max-width:100%;max-height:92vh;margin:0;overflow-y:auto}.modal.lg{max-width:100%}.modal-header{z-index:1;background:#fff;padding:16px;position:sticky;top:0}.modal-body{padding:16px}.modal-footer{background:#fff;flex-direction:column;gap:8px;padding:14px 16px;position:sticky;bottom:0}.modal-footer .btn{width:100%}.card-pad{padding:16px}.card-header{padding:14px 16px}.toast-container{top:10px;left:10px;right:10px}.toast{min-width:0;max-width:100%}}@media (width<=380px){.stat-grid{grid-template-columns:1fr}table.data-cards td:before{flex-basis:42%}}
