:root{--primary: #4f46e5;--primary-600: #4338ca;--primary-700: #3730a3;--accent: #06b6d4;--positive: #0ea371;--negative: #e5484d;--warning: #d9930a;--info: #2f7fe0;--bg: #f4f5fa;--surface: #ffffff;--surface-2: #f8f9fc;--surface-3: #f1f3f9;--border: #e7e9f1;--border-strong: #d4d8e5;--text: #181b2a;--text-2: #595f73;--text-3: #8b91a4;--primary-soft: #eef0fe;--positive-soft: #e6f7ef;--negative-soft: #fdecec;--warning-soft: #fdf4e1;--info-soft: #eaf2fd;--accent-soft: #e2f7fb;--side-bg: #0e1430;--side-bg-2: #151c3c;--side-text: #a9b0cc;--side-text-active: #ffffff;--side-active: rgba(110, 120, 255, .18);--side-border: rgba(255, 255, 255, .07);--r-sm: 8px;--r: 12px;--r-lg: 16px;--shadow-sm: 0 1px 2px rgba(20, 24, 45, .05), 0 1px 3px rgba(20, 24, 45, .04);--shadow: 0 4px 14px rgba(20, 24, 45, .07);--shadow-lg: 0 12px 40px rgba(20, 24, 45, .18);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--mono: "Roboto Mono", ui-monospace, "SF Mono", Menlo, monospace;--sidebar-w: 250px;--topbar-h: 64px}[data-theme=dark]{--bg: #0a0d18;--surface: #131726;--surface-2: #1a1f31;--surface-3: #20263a;--border: #262c40;--border-strong: #353c54;--text: #eceef6;--text-2: #a4abc1;--text-3: #6e7589;--primary-soft: #1e224a;--positive-soft: #0d2b22;--negative-soft: #361b1f;--warning-soft: #332512;--info-soft: #15233c;--accent-soft: #0c2d35;--side-bg: #080b16;--side-bg-2: #0f1426;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow: 0 4px 14px rgba(0, 0, 0, .35);--shadow-lg: 0 12px 40px rgba(0, 0, 0, .55)}*,*:before,*:after{box-sizing:border-box}*{margin:0}html,body,#root{height:100%}body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:inherit}h1,h2,h3,h4{font-weight:600;line-height:1.25;letter-spacing:-.01em}::selection{background:var(--primary);color:#fff}.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}.num{font-variant-numeric:tabular-nums}.app{display:flex;min-height:100%}.sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--side-bg);border-right:1px solid var(--side-border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar__brand{display:flex;align-items:center;gap:11px;padding:18px 20px;color:#fff;border-bottom:1px solid var(--side-border)}.sidebar__logo{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;color:#fff;flex-shrink:0}.sidebar__title{font-size:15px;font-weight:700;color:#fff;letter-spacing:-.02em}.sidebar__subtitle{font-size:11px;color:var(--side-text);margin-top:1px}.nav{padding:12px;flex:1;overflow-y:auto}.nav__label{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#5d6592;padding:14px 12px 6px}.nav__item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--r-sm);color:var(--side-text);font-weight:500;font-size:13.5px;margin-bottom:2px;transition:background .12s,color .12s}.nav__item:hover{background:var(--side-bg-2);color:#e7eaf6}.nav__item.active{background:var(--side-active);color:var(--side-text-active)}.nav__item.active svg{color:#a5b4fc}.nav__item svg{width:18px;height:18px;flex-shrink:0}.nav__badge{margin-left:auto;font-size:11px;background:var(--primary);color:#fff;border-radius:99px;padding:1px 7px;font-weight:600}.sidebar__foot{padding:14px 16px;border-top:1px solid var(--side-border);font-size:11.5px;color:#6b7299}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:var(--topbar-h);display:flex;align-items:center;gap:16px;padding:0 28px;background:color-mix(in srgb,var(--surface) 85%,transparent);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20}.topbar__title{font-size:17px;font-weight:600}.topbar__crumb{font-size:12px;color:var(--text-3)}.topbar__spacer{flex:1}.topbar__search{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);border-radius:99px;padding:7px 14px;color:var(--text-3);width:240px;font-size:13px}.topbar__search input{border:none;background:none;outline:none;color:var(--text);width:100%}.content{padding:26px 28px 56px;max-width:1400px;width:100%}.page-head{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px;flex-wrap:wrap}.page-head h1{font-size:22px}.page-head p{color:var(--text-2);margin-top:4px;font-size:13.5px;max-width:720px}.page-head__actions{margin-left:auto;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--shadow-sm)}.card__head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--border)}.card__head h3{font-size:15px}.card__head .sub{font-size:12.5px;color:var(--text-3)}.card__head .spacer{flex:1}.card__body{padding:18px}.card__body--flush{padding:0}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:10px;min-width:0}.stat__top{display:flex;align-items:center;gap:10px}.stat__icon{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;flex-shrink:0}.stat__label{font-size:12.5px;color:var(--text-2);font-weight:500}.stat__value{font-size:23px;font-weight:700;letter-spacing:-.02em;font-variant-numeric:tabular-nums}.stat__value small{font-size:14px;font-weight:600;color:var(--text-3)}.stat__foot{font-size:12px;color:var(--text-3);display:flex;align-items:center;gap:6px}.icon-soft-primary{background:var(--primary-soft);color:var(--primary)}.icon-soft-positive{background:var(--positive-soft);color:var(--positive)}.icon-soft-negative{background:var(--negative-soft);color:var(--negative)}.icon-soft-warning{background:var(--warning-soft);color:var(--warning)}.icon-soft-info{background:var(--info-soft);color:var(--info)}.icon-soft-accent{background:var(--accent-soft);color:var(--accent)}.grid{display:grid;gap:16px}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.row{display:flex;gap:16px}.col{display:flex;flex-direction:column;gap:16px}.wrap{flex-wrap:wrap}.between{justify-content:space-between}.items-center{align-items:center}.gap-sm{gap:8px}.flex1{flex:1;min-width:0}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-16{margin-bottom:16px}@media (max-width: 1100px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.lg-stack{flex-direction:column}}@media (max-width: 720px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}.content{padding:18px 16px 48px}.sidebar{display:none}}.table-wrap{overflow-x:auto}table.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-weight:600;font-size:11.5px;letter-spacing:.03em;text-transform:uppercase;color:var(--text-3);padding:11px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);white-space:nowrap}.tbl tbody td{padding:12px 16px;border-bottom:1px solid var(--border);vertical-align:middle}.tbl tbody tr:last-child td{border-bottom:none}.tbl tbody tr:hover td{background:var(--surface-2)}.tbl .r{text-align:right;font-variant-numeric:tabular-nums}.tbl .c{text-align:center}.tbl tfoot td{padding:12px 16px;font-weight:600;border-top:2px solid var(--border-strong);background:var(--surface-2)}.cell-strong{font-weight:600}.cell-muted{color:var(--text-3)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:99px;white-space:nowrap}.badge--primary{background:var(--primary-soft);color:var(--primary)}.badge--positive{background:var(--positive-soft);color:var(--positive)}.badge--negative{background:var(--negative-soft);color:var(--negative)}.badge--warning{background:var(--warning-soft);color:var(--warning)}.badge--info{background:var(--info-soft);color:var(--info)}.badge--neutral{background:var(--surface-3);color:var(--text-2)}.badge--accent{background:var(--accent-soft);color:var(--accent)}.badge--dot:before{content:"";width:6px;height:6px;border-radius:99px;background:currentColor}.pos{color:var(--positive)}.neg{color:var(--negative)}.muted{color:var(--text-3)}.sec{color:var(--text-2)}.btn{display:inline-flex;align-items:center;gap:7px;justify-content:center;border:1px solid var(--border-strong);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--r-sm);font-weight:500;font-size:13.5px;transition:all .12s;white-space:nowrap}.btn:hover{background:var(--surface-2);border-color:var(--text-3)}.btn svg{width:16px;height:16px}.btn--primary{background:var(--primary);border-color:var(--primary);color:#fff}.btn--primary:hover{background:var(--primary-600);border-color:var(--primary-600)}.btn--ghost{border-color:transparent;background:transparent}.btn--ghost:hover{background:var(--surface-3)}.btn--sm{padding:5px 10px;font-size:12.5px}.btn--danger{color:var(--negative);border-color:var(--negative-soft)}.btn--danger:hover{background:var(--negative-soft)}.icon-btn{width:36px;height:36px;border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface);color:var(--text-2);display:grid;place-items:center}.icon-btn:hover{background:var(--surface-2);color:var(--text)}.seg{display:inline-flex;background:var(--surface-3);border-radius:var(--r-sm);padding:3px;gap:2px}.seg button{border:none;background:none;color:var(--text-2);padding:6px 13px;border-radius:6px;font-weight:500;font-size:13px}.seg button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:18px}.tabs button{border:none;background:none;color:var(--text-2);padding:10px 14px;font-weight:500;font-size:13.5px;border-bottom:2px solid transparent;margin-bottom:-1px}.tabs button.active{color:var(--primary);border-bottom-color:var(--primary)}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:12.5px;font-weight:500;color:var(--text-2)}.field .hint{font-size:11.5px;color:var(--text-3)}.input,.select{width:100%;padding:9px 12px;border-radius:var(--r-sm);border:1px solid var(--border-strong);background:var(--surface);color:var(--text);outline:none;transition:border .12s,box-shadow .12s}.input:focus,.select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft)}.input-group{display:flex;align-items:stretch}.input-group .input{border-radius:var(--r-sm) 0 0 var(--r-sm)}.input-group .addon{display:grid;place-items:center;padding:0 12px;font-size:13px;color:var(--text-2);background:var(--surface-3);border:1px solid var(--border-strong);border-left:none;border-radius:0 var(--r-sm) var(--r-sm) 0}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f122380;display:grid;place-items:start center;padding:48px 16px;z-index:100;overflow-y:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);width:100%;max-width:560px}.modal__head{display:flex;align-items:center;padding:18px 22px;border-bottom:1px solid var(--border)}.modal__head h3{font-size:16px}.modal__body{padding:22px}.modal__foot{padding:16px 22px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;gap:10px}.meter{height:8px;background:var(--surface-3);border-radius:99px;overflow:hidden}.meter>span{display:block;height:100%;border-radius:99px;background:var(--primary)}.kpi-row{display:flex;align-items:baseline;gap:8px}.dot{width:9px;height:9px;border-radius:99px;flex-shrink:0}.divider{height:1px;background:var(--border);margin:4px 0}.legend{display:flex;flex-direction:column;gap:10px}.legend__item{display:flex;align-items:center;gap:9px;font-size:13px}.legend__item .name{color:var(--text-2)}.legend__item .val{margin-left:auto;font-weight:600;font-variant-numeric:tabular-nums}.avatar{width:32px;height:32px;border-radius:99px;display:grid;place-items:center;font-size:12.5px;font-weight:600;color:#fff;flex-shrink:0}.member-cell{display:flex;align-items:center;gap:10px}.empty{text-align:center;padding:44px 20px;color:var(--text-3)}.empty svg{width:36px;height:36px;margin-bottom:12px;opacity:.6}.alert{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r);border:1px solid var(--border);background:var(--surface-2);font-size:13px}.alert--warning{background:var(--warning-soft);border-color:color-mix(in srgb,var(--warning) 25%,transparent)}.alert--warning svg{color:var(--warning)}.alert svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.tag-src{font-size:11px;padding:2px 7px;border-radius:6px;background:var(--surface-3);color:var(--text-2);font-weight:500}.switch{position:relative;width:40px;height:23px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.switch .track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:99px;transition:.18s}.switch .track:before{content:"";position:absolute;width:17px;height:17px;left:3px;top:3px;background:#fff;border-radius:99px;transition:.18s;box-shadow:var(--shadow-sm)}.switch input:checked+.track{background:var(--primary)}.switch input:checked+.track:before{transform:translate(17px)}.setting-row{display:flex;align-items:center;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.setting-row:last-child{border-bottom:none}.setting-row .txt{flex:1}.setting-row .txt b{font-weight:500;font-size:13.5px}.setting-row .txt span{display:block;color:var(--text-3);font-size:12.5px;margin-top:2px}.step{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid var(--border)}.step:last-child{border-bottom:none}.step__num{width:28px;height:28px;border-radius:99px;flex-shrink:0;display:grid;place-items:center;font-size:12px;font-weight:600}.toast{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:var(--r);padding:12px 16px;font-size:13.5px;font-weight:500;color:var(--text)}.toast svg{color:var(--positive)}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .9s linear infinite}.recharts-default-tooltip{background:var(--surface)!important;border:1px solid var(--border-strong)!important;border-radius:var(--r-sm)!important;box-shadow:var(--shadow)!important}.recharts-tooltip-label,.recharts-tooltip-item{color:var(--text)!important}.recharts-cartesian-axis-tick text{fill:var(--text-3);font-size:11px}.recharts-cartesian-grid line{stroke:var(--border)}
