:root{--bg: #f6f7f9;--surface: #ffffff;--surface-2: #fafbfc;--border: #ecedf1;--border-strong: #dcdfe5;--text: #15171c;--text-soft: #3d434e;--muted: #79808d;--primary: #4f46e5;--primary-dark: #4338ca;--primary-soft: #eef1ff;--danger: #e5484d;--danger-soft: #fdf0f0;--ok: #16a34a;--ok-soft: #ecfdf3;--warn: #f59e0b;--sidebar: #ffffff;--sidebar-text: #5d6573;--sidebar-width: 250px;--radius: 10px;--radius-sm: 7px;--radius-lg: 14px;--shadow-xs: 0 1px 2px rgba(16, 24, 40, .05);--shadow: 0 1px 3px rgba(16, 24, 40, .06), 0 1px 2px rgba(16, 24, 40, .04);--shadow-md: 0 6px 18px rgba(16, 24, 40, .08);--shadow-lg: 0 18px 50px rgba(16, 24, 40, .18);--ring: 0 0 0 3px rgba(79, 70, 229, .16);--ease: .16s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;color:var(--text);background:var(--bg);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button{font-family:inherit}::selection{background:#4f46e529}.num,.value,.kpi-card .value,table.grid td.num,.dash-table td.num{font-variant-numeric:tabular-nums}*{scrollbar-width:thin;scrollbar-color:#d4d8df transparent}*::-webkit-scrollbar{width:10px;height:10px}*::-webkit-scrollbar-thumb{background:#d4d8df;border-radius:999px;border:3px solid transparent;background-clip:content-box}*::-webkit-scrollbar-thumb:hover{background:#c2c7d0;background-clip:content-box}svg{display:block}.app-shell{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 14px;transition:width var(--ease)}.sidebar .brand{display:flex;align-items:center;gap:11px;padding:6px 8px 20px;white-space:nowrap;overflow:hidden}.brand-mark{width:34px;height:34px;flex-shrink:0;border-radius:9px;background:linear-gradient(140deg,#6366f1,#4f46e5 55%,#7c3aed);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:16px;box-shadow:0 4px 12px #4f46e559}.brand-text{display:flex;flex-direction:column;line-height:1.2}.brand-text b{font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.01em}.brand-text small{font-size:11px;color:var(--muted);font-weight:500}.brand-logo{height:34px;width:auto;max-width:188px;object-fit:contain;display:block}.brand-mark-img{display:none;width:40px;height:40px;object-fit:contain}.app-shell.collapsed .brand-logo{display:none}.app-shell.collapsed .brand-mark-img{display:block}.nav-section{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:#9aa1ad;padding:6px 12px 7px}.nav-item{position:relative;display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;color:var(--sidebar-text);font-weight:530;font-size:13.5px;cursor:pointer;margin-bottom:2px;white-space:nowrap;transition:background var(--ease),color var(--ease)}.nav-item:hover{background:var(--surface-2);color:var(--text)}.nav-item.active{background:var(--primary-soft);color:var(--primary-dark);font-weight:600}.nav-item.active:before{content:"";position:absolute;left:-14px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--primary)}.nav-item .icon{flex-shrink:0;display:flex}.sidebar .spacer{flex:1}.user-box{padding:12px;border-top:1px solid var(--border);margin-top:6px;display:flex;flex-direction:column;gap:4px}.user-box .who{display:flex;align-items:center;gap:10px;min-width:0}.avatar{width:32px;height:32px;flex-shrink:0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12.5px;font-weight:700;color:#fff;text-transform:uppercase}.user-box .who .meta{min-width:0}.user-box b{color:var(--text);display:block;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-shell.collapsed{--sidebar-width: 74px}.app-shell.collapsed .sidebar{padding:16px 12px}.app-shell.collapsed .brand{justify-content:center;padding:6px 0 20px}.app-shell.collapsed .brand-text,.app-shell.collapsed .nav-item .label,.app-shell.collapsed .nav-section,.app-shell.collapsed .user-box .meta,.app-shell.collapsed .user-box .btn span,.app-shell.collapsed .tag-role{display:none}.app-shell.collapsed .nav-item{justify-content:center;padding:10px;gap:0}.app-shell.collapsed .nav-item.active:before{display:none}.app-shell.collapsed .user-box{align-items:center}.app-shell.collapsed .user-box .who{justify-content:center}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{height:58px;flex-shrink:0;background:#fffc;-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 22px;gap:14px}.topbar h1{font-size:17px;margin:0;font-weight:680;letter-spacing:-.015em}.icon-toggle{border:none;background:transparent;cursor:pointer;width:34px;height:34px;border-radius:8px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:background var(--ease),color var(--ease)}.icon-toggle:hover{background:var(--surface-2);color:var(--text)}.content{flex:1;overflow:auto;padding:24px}.content>*{animation:fade-in .24s var(--ease)}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text-soft);cursor:pointer;font-weight:550;font-size:13px;white-space:nowrap;transition:background var(--ease),border-color var(--ease),color var(--ease),box-shadow var(--ease),transform var(--ease)}.btn:hover{background:var(--surface-2);border-color:#cfd3da;color:var(--text)}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:focus-visible{outline:none;box-shadow:var(--ring)}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 1px 2px #4f46e54d}.btn-primary:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{background:#d23b40;border-color:#d23b40;color:#fff}.btn-ghost{border-color:transparent;background:transparent}.btn-ghost:hover{background:var(--surface-2)}.btn-sm{padding:6px 11px;font-size:12.5px;gap:6px}.btn .icon{flex-shrink:0}.input,.select{width:100%;padding:8px 11px;border:1px solid var(--border-strong);border-radius:var(--radius-sm);background:#fff;color:var(--text);font-size:13px;outline:none;transition:border-color var(--ease),box-shadow var(--ease)}.input::placeholder{color:#aab0bb}.input:hover,.select:hover{border-color:#cfd3da}.input:focus,.select:focus{border-color:var(--primary);box-shadow:var(--ring)}label.field{display:block;margin-bottom:14px}label.field>span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px;font-weight:550}.search-field{position:relative;flex:1;min-width:220px;max-width:380px}.search-field .s-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}.search-field .input{padding-left:34px}.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.toolbar .grow{flex:1}.seg{display:inline-flex;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px}.seg button{border:none;background:transparent;cursor:pointer;padding:5px 13px;font-size:12.5px;font-weight:560;color:var(--muted);border-radius:5px;transition:background var(--ease),color var(--ease)}.seg button:hover{color:var(--text)}.seg button.active{background:#fff;color:var(--text);box-shadow:var(--shadow-xs)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-pad{padding:18px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:auto;box-shadow:var(--shadow)}table.grid{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}table.grid thead th{position:sticky;top:0;z-index:2;background:var(--surface-2);text-align:left;font-weight:600;color:#5b6473;font-size:11.5px;letter-spacing:.01em;padding:10px 12px;border-bottom:1px solid var(--border);white-space:nowrap;-webkit-user-select:none;user-select:none}table.grid thead th.sortable{cursor:pointer;transition:background var(--ease),color var(--ease)}table.grid thead th.sortable:hover{background:#eef0f4;color:var(--text)}table.grid thead tr.filter-row th{position:sticky;top:37px;z-index:1;background:#fff;padding:6px 7px;border-bottom:1px solid var(--border)}table.grid tbody td{padding:0;border-bottom:1px solid var(--border);vertical-align:middle;max-width:280px}table.grid tbody tr{transition:background var(--ease)}table.grid tbody tr:last-child td{border-bottom:none}table.grid tbody tr:hover{background:var(--surface-2)}table.grid tbody tr.selected{background:var(--primary-soft)}table.grid tbody tr.selected:hover{background:#e6eaff}table.grid tbody tr.archived{opacity:.62}.cell{padding:9px 12px;min-height:36px;cursor:text;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell.cell-empty{color:#c4c9d2}.cell.readonly{cursor:default;color:var(--muted)}.cell-input{width:100%;border:none;padding:8px 11px;font:inherit;outline:2px solid var(--primary);background:#fff;border-radius:4px}.cell-select{width:100%;border:none;padding:7px 9px;font:inherit;outline:2px solid var(--primary);background:#fff;border-radius:4px}td.num .cell,td.num .cell-input{text-align:right}.sort-ind{display:inline-flex;vertical-align:middle;color:var(--primary);margin-left:4px}.th-filter{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-size:12px;outline:none;background:#fff;transition:border-color var(--ease),box-shadow var(--ease)}.th-filter:focus{border-color:var(--primary);box-shadow:var(--ring)}.row-actions{display:flex;gap:2px;align-items:center}.icon-btn{border:none;background:transparent;cursor:pointer;padding:6px;border-radius:6px;color:var(--muted);line-height:0;display:inline-flex;transition:background var(--ease),color var(--ease)}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.icon-btn.danger:hover{background:var(--danger-soft);color:var(--danger)}.icon-btn:disabled{opacity:.35;cursor:not-allowed}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;color:#fff;white-space:nowrap;line-height:1.4}.badge-select{border:none;background:transparent;font:inherit;cursor:pointer;outline:2px solid var(--primary);border-radius:6px;padding:4px}input[type=checkbox].cb{width:16px;height:16px;cursor:pointer;accent-color:var(--primary);border-radius:4px}.bulk-bar{display:flex;align-items:center;gap:12px;background:var(--text);color:#fff;padding:9px 14px;border-radius:var(--radius);margin-bottom:14px;box-shadow:var(--shadow-md);animation:fade-in .2s var(--ease)}.bulk-bar .select{width:auto;min-width:160px;background:#ffffff14;border-color:#ffffff29;color:#fff}.bulk-bar .select:hover{border-color:#ffffff4d}.bulk-bar .select option{color:var(--text)}.bulk-bar .btn{background:#ffffff1a;border-color:#ffffff2e;color:#fff}.bulk-bar .btn:hover{background:#ffffff2e;color:#fff}.bulk-bar .btn-danger{background:var(--danger);border-color:var(--danger)}.bulk-bar .btn-danger:hover{background:#d23b40}.bulk-bar b{font-weight:700}.bulk-count{display:inline-flex;align-items:center;gap:7px;font-size:13px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a66;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:50;padding:20px;animation:fade-in .16s var(--ease)}.modal{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px;max-height:88vh;overflow:auto;animation:modal-pop .2s var(--ease)}@keyframes modal-pop{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}.modal.wide{max-width:820px}.modal-head{padding:17px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.modal-head h3{margin:0;font-size:16px;font-weight:650;letter-spacing:-.01em}.modal-body{padding:22px}.modal-foot{padding:15px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px;background:var(--surface-2);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.col-row{display:flex;align-items:center;gap:10px;padding:8px;border-radius:8px;border:1px solid transparent;transition:background var(--ease),box-shadow var(--ease),opacity var(--ease)}.col-row+.col-row{margin-top:1px}.col-row:hover{background:var(--surface-2)}.col-row.dragging{opacity:.45;background:var(--surface-2)}.col-row.drag-over{background:var(--primary-soft);box-shadow:inset 0 0 0 1px #4f46e566}.col-grip{display:flex;color:#b7bdc7;cursor:grab;padding:2px;touch-action:none}.col-grip:active{cursor:grabbing}.col-row:hover .col-grip{color:var(--muted)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px;margin-bottom:22px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);transition:box-shadow var(--ease),transform var(--ease),border-color var(--ease)}.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--border-strong)}.kpi-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.kpi-card .label{color:var(--muted);font-size:12px;font-weight:550}.kpi-card .value{font-size:26px;font-weight:720;letter-spacing:-.02em;line-height:1.1}.kpi-icon{width:34px;height:34px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--muted)}.kpi-card.accent .kpi-icon{background:var(--primary-soft);color:var(--primary)}.kpi-card.accent .value{color:var(--primary)}.kpi-card.win .kpi-icon{background:var(--ok-soft);color:var(--ok)}.kpi-card.win .value{color:var(--ok)}.kpi-card.lose .kpi-icon{background:var(--danger-soft);color:var(--danger)}.kpi-card.lose .value{color:var(--danger)}.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 980px){.charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow)}.chart-card h3{margin:0 0 16px;font-size:14px;font-weight:640;color:var(--text)}.dash-table{width:100%;border-collapse:collapse;font-size:13px}.dash-table th{text-align:left;color:var(--muted);font-weight:600;font-size:11.5px;padding:9px 10px;border-bottom:1px solid var(--border);white-space:nowrap}.dash-table td{padding:9px 10px;border-bottom:1px solid var(--border);white-space:nowrap}.dash-table td.num,.dash-table th.num{text-align:right}.dash-table tr:last-child td{border-bottom:none}.dash-table tbody tr{transition:background var(--ease)}.dash-table tbody tr:hover{background:var(--surface-2)}.conv-cell{display:inline-flex;align-items:center;gap:8px;justify-content:flex-end}.conv-track{width:56px;height:6px;background:#eef1f4;border-radius:999px;overflow:hidden}.conv-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:999px;transition:width .4s var(--ease)}.section-title{font-size:13px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin:28px 0 14px;display:flex;align-items:center;gap:9px}.section-title:after{content:"";flex:1;height:1px;background:var(--border)}.donut-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(165px,1fr));gap:14px}.donut-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:12px 10px 14px;text-align:center;box-shadow:var(--shadow);transition:box-shadow var(--ease),transform var(--ease)}.donut-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.donut-title{font-weight:600;font-size:13px;margin-top:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.donut-sub{font-size:11.5px;color:var(--muted);margin-top:4px}.donut-badge{display:inline-block;padding:2px 10px;border-radius:999px;font-size:12px;font-weight:600;color:#1f2733}.login-wrap{height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(1100px 600px at 15% 0%,rgba(124,58,237,.16),transparent 55%),radial-gradient(900px 600px at 100% 100%,rgba(79,70,229,.2),transparent 50%),#0b0d16;padding:20px}.login-card{background:#fff;border-radius:16px;box-shadow:var(--shadow-lg);width:100%;max-width:392px;padding:36px;animation:modal-pop .3s var(--ease)}.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:22px}.login-brand .brand-mark{width:40px;height:40px;font-size:18px}.login-brand .brand-logo{height:48px;max-width:280px}.login-card h2{margin:0;font-size:20px;font-weight:720;letter-spacing:-.02em}.login-card p.sub{margin:4px 0 24px;color:var(--muted);font-size:13px}.login-card .hint{margin-top:16px;font-size:12px;color:var(--muted);text-align:center}.muted{color:var(--muted)}.error-text{color:var(--danger);font-size:13px;margin:10px 0;padding:9px 12px;background:var(--danger-soft);border:1px solid #f6d5d5;border-radius:var(--radius-sm);display:flex;align-items:center;gap:8px}.spinner-page{display:flex;align-items:center;justify-content:center;height:100%;color:var(--muted)}.tag-role{font-size:11px;padding:2px 9px;border-radius:999px;background:var(--primary-soft);color:var(--primary-dark);font-weight:600;align-self:flex-start}.empty-state{text-align:center;padding:56px 20px;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.empty-state .empty-icon{width:52px;height:52px;border-radius:14px;background:var(--surface-2);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:#aab0bb}.pill-filters{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.history-item{padding:12px 0 12px 18px;border-bottom:1px solid var(--border);font-size:13px;position:relative}.history-item:before{content:"";position:absolute;left:0;top:17px;width:7px;height:7px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.history-item:last-child{border-bottom:none}.history-item .meta{color:var(--muted);font-size:12px;margin-bottom:4px}.history-item .change b{font-weight:600}.val-old{color:var(--danger);text-decoration:line-through}.val-new{color:var(--ok);font-weight:600}.toast-stack{position:fixed;bottom:22px;right:22px;display:flex;flex-direction:column;gap:10px;z-index:100}.toast{display:flex;align-items:center;gap:10px;background:var(--text);color:#fff;padding:11px 15px;border-radius:var(--radius);box-shadow:var(--shadow-lg);font-size:13px;font-weight:500;animation:toast-in .22s var(--ease);max-width:360px}@keyframes toast-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:none}}.toast .t-icon{display:flex;flex-shrink:0;color:#4ade80}.toast.err{background:#4b1113}.toast.err .t-icon{color:#fca5a5}.lang-switch{display:inline-flex;border:1px solid var(--border-strong);border-radius:var(--radius-sm);overflow:hidden}.lang-btn{border:none;background:#fff;padding:6px 12px;cursor:pointer;font-size:12px;font-weight:600;color:var(--muted);transition:background var(--ease),color var(--ease)}.lang-btn+.lang-btn{border-left:1px solid var(--border-strong)}.lang-btn:hover{background:var(--surface-2);color:var(--text)}.lang-btn.active{background:var(--primary);color:#fff}
