:root{--bg: oklch(.985 .004 85);--bg-elev: oklch(1 0 0);--bg-soft: oklch(.975 .006 85);--bg-muted: oklch(.97 .005 85);--line: oklch(.92 .008 85);--line-strong: oklch(.88 .01 85);--text: oklch(.2 .012 80);--text-2: oklch(.42 .01 80);--text-3: oklch(.6 .008 80);--primary: oklch(.62 .16 50);--primary-2: oklch(.52 .18 50);--primary-soft:oklch(.95 .05 60);--success: oklch(.55 .12 150);--success-soft:oklch(.96 .04 150);--warn: oklch(.62 .14 75);--warn-soft: oklch(.96 .05 80);--neg: oklch(.55 .17 28);--neg-soft: oklch(.96 .04 28);--accent: oklch(.62 .16 50);--accent-soft: oklch(.95 .05 60);--radius-xs: 6px;--radius-sm: 8px;--radius: 10px;--radius-lg: 14px;--shadow-sm: 0 1px 0 rgba(20,15,10,.04), 0 1px 2px rgba(20,15,10,.05);--shadow: 0 4px 16px -4px rgba(20,15,10,.1), 0 2px 4px -2px rgba(20,15,10,.04);--shadow-lg: 0 20px 40px -12px rgba(20,15,10,.18), 0 8px 16px -8px rgba(20,15,10,.08);--font: "Geist", -apple-system, BlinkMacSystemFont, "Helvetica Neue", Arial, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"ss01" on,"cv11" on;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{font-family:inherit}table{border-collapse:collapse}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}.app-shell{display:grid;grid-template-columns:228px 1fr;min-height:100vh}.sidebar{background:var(--bg-elev);color:var(--text-2);border-right:1px solid var(--line);display:flex;flex-direction:column;height:100vh;position:sticky;top:0}.sidebar .brand{padding:16px 16px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--line)}.sidebar .brand .brand-name{font-weight:700;font-size:15px;color:var(--text);letter-spacing:-.01em}.sidebar .brand .brand-tag{font-size:11px;color:var(--text-3)}.sidebar .switcher{padding:10px 12px;border-bottom:1px solid var(--line)}.switcher-label{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-3);margin-bottom:5px}.switcher-select{width:100%;background:var(--bg-soft);border:1px solid var(--line);color:var(--text);border-radius:7px;padding:7px 10px;font-size:12.5px;font-family:inherit}.switcher-select:focus{outline:none;border-color:var(--primary)}.sidebar nav{padding:6px 8px;flex:1;overflow-y:auto}.nav-section{margin-top:8px}.nav-section-title{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:5px 10px}.nav-item{display:flex;align-items:center;gap:9px;padding:7px 10px;border-radius:7px;color:var(--text-2);cursor:pointer;font-size:13px;font-weight:400;margin:1px 0;transition:background .1s}.nav-item:hover{background:var(--bg-soft);color:var(--text)}.nav-item.active{background:#f1eee9;color:var(--text);font-weight:500}.nav-item .ic{width:16px;height:16px;opacity:.85}.sidebar .promo{margin:10px;padding:12px;border-radius:10px;background:linear-gradient(135deg,var(--primary-2),var(--primary));color:#fff;font-size:12px}.sidebar .promo .promo-title{font-weight:700;margin-bottom:4px}.sidebar .promo button{margin-top:8px;background:#ffffffeb;color:var(--primary-2);border:none;border-radius:6px;padding:5px 10px;font-weight:600;font-size:11.5px;cursor:pointer}.topbar{display:flex;align-items:center;gap:12px;padding:10px 22px;background:var(--bg-elev);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}.topbar .search{flex:1;display:flex;align-items:center;gap:8px;background:var(--bg-soft);border:1px solid var(--line);border-radius:8px;padding:7px 11px;max-width:440px}.topbar .search input{flex:1;border:none;background:transparent;outline:none;font-size:13px;color:var(--text);font-family:inherit}.topbar .icon-btn{width:34px;height:34px;border-radius:8px;border:1px solid var(--line);background:var(--bg-elev);display:flex;align-items:center;justify-content:center;cursor:pointer}.topbar .icon-btn:hover{background:var(--bg-soft)}.topbar .user{display:flex;align-items:center;gap:9px;padding:4px 8px 4px 4px;border-radius:8px;cursor:pointer}.topbar .user:hover{background:var(--bg-soft)}.topbar .avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--primary-2),var(--primary));color:#fff;font-weight:600;font-size:12px;display:flex;align-items:center;justify-content:center}.topbar .user-meta{line-height:1.15}.topbar .user-meta .nm{font-weight:600;font-size:13px;color:var(--text)}.topbar .user-meta .rl{font-size:11px;color:var(--text-2)}.main{display:flex;flex-direction:column;min-width:0}.content{padding:24px 28px;max-width:1480px;margin:0 auto;width:100%}.card{background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:16px 18px}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;gap:12px;flex-wrap:wrap}.section-head h2{font-size:15px;font-weight:600;margin:0;letter-spacing:-.005em}.section-head .sub{font-size:12px;color:var(--text-2)}.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:7px;border:1px solid var(--line-strong);background:var(--bg-elev);color:var(--text);font-weight:500;font-size:13px;cursor:pointer;transition:background .12s;font-family:inherit}.btn:hover{background:var(--bg-soft)}.btn.primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn.primary:hover{background:var(--primary-2);border-color:var(--primary-2)}.btn.ghost{border-color:transparent;background:transparent}.btn.ghost:hover{background:var(--bg-soft)}.btn.danger{background:var(--neg);color:#fff;border-color:var(--neg)}.btn.success{background:var(--success);color:#fff;border-color:var(--success)}.btn.sm{padding:5px 9px;font-size:12px;border-radius:6px}.chip{display:inline-flex;align-items:center;gap:5px;padding:3px 8px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--line);font-size:11.5px;font-weight:500;color:var(--text-2)}.chip.active{background:var(--primary-soft);color:var(--primary-2);border-color:#f8c19c}.chip.pill-ok{background:var(--success-soft);color:var(--success);border-color:#bce3c3}.chip.pill-warn{background:var(--warn-soft);color:var(--warn);border-color:#f4d29b}.chip.pill-neg{background:var(--neg-soft);color:var(--neg);border-color:#fdc9c2}.chip.pill-info{background:#e6f4ff;background:oklch(.96 .03 240);color:#2579ab;border-color:#bbddf6}.chip.pill-purple{background:#f1f0ff;background:oklch(.96 .03 290);color:#7260bd;border-color:#d6d2fd}.chip.pill-gray{background:var(--bg-soft);color:var(--text-2);border-color:var(--line)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block}.dot.ok{background:var(--success)}.dot.warn{background:var(--warn)}.dot.neg{background:var(--neg)}.dot.info{background:var(--primary)}.dot.gray{background:var(--text-3)}.progress{width:100%;height:5px;background:var(--bg-soft);border-radius:999px;overflow:hidden}.progress>i{display:block;height:100%;background:var(--primary);border-radius:999px}.progress.success>i{background:var(--success)}.progress.warn>i{background:var(--warn)}.progress.neg>i{background:var(--neg)}.tbl{width:100%;font-size:13px}.tbl th{text-align:left;font-weight:500;color:var(--text-2);font-size:11px;text-transform:uppercase;letter-spacing:.05em;padding:9px 12px;background:var(--bg-soft);border-bottom:1px solid var(--line)}.tbl td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}.tbl tbody tr:hover{background:var(--bg-muted)}.tbl td.num,.tbl th.num{text-align:right;font-variant-numeric:tabular-nums}.tbl .mono{font-family:Geist Mono,ui-monospace,SF Mono,Menlo,monospace}.input,.select{width:100%;padding:7px 10px;border:1px solid var(--line-strong);border-radius:7px;background:var(--bg-elev);font-size:13px;color:var(--text);font-family:inherit}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #cf630d1f}.field{display:block;margin-bottom:12px}.field label{display:block;font-size:12px;font-weight:500;color:var(--text-2);margin-bottom:5px}.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.kpi{padding:16px 18px;background:var(--bg-elev);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.kpi .lbl{font-size:11px;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;font-weight:500}.kpi .val{font-size:23px;font-weight:700;margin-top:4px;letter-spacing:-.02em;color:var(--text)}.kpi .sub{font-size:12px;color:var(--text-2);margin-top:4px}.kpi .delta{font-size:12px;font-weight:600}.kpi .delta.up{color:var(--success)}.kpi .delta.dn{color:var(--neg)}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1.05fr}.login-left{background:var(--bg-elev);border-right:1px solid var(--line);padding:52px 56px;display:flex;flex-direction:column;justify-content:space-between}.login-left h1{font-size:32px;font-weight:600;letter-spacing:-.025em;line-height:1.08;margin:20px 0 12px;color:var(--text)}.login-left p{font-size:14px;color:var(--text-2);max-width:400px;line-height:1.6}.login-left .quote{font-size:12.5px;color:var(--text-3);border-left:2px solid var(--line-strong);padding-left:12px}.login-right{display:flex;align-items:center;justify-content:center;padding:48px;background:radial-gradient(ellipse at 70% 30%,oklch(.95 .06 60 / .45),transparent 60%),radial-gradient(ellipse at 30% 80%,oklch(.92 .08 50 / .3),transparent 55%),var(--bg);position:relative;overflow:hidden}.login-card{width:100%;max-width:360px}.login-card h2{font-size:20px;font-weight:600;margin:0 0 5px;letter-spacing:-.01em}.login-card .desc{color:var(--text-2);font-size:13px;margin-bottom:18px}.login-card .err{color:var(--neg);font-size:12.5px;margin-bottom:10px}.login-card .meta{font-size:11px;color:var(--text-3);margin-top:14px}.spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--line-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.spinner.lg{width:28px;height:28px;border-width:3px}@keyframes spin{to{transform:rotate(360deg)}}.center{display:flex;align-items:center;justify-content:center}.full-loader{min-height:100vh;display:flex;align-items:center;justify-content:center;gap:10px;color:var(--text-2)}.tabs{display:flex;gap:2px;border-bottom:1px solid var(--line);margin-bottom:16px}.tab{padding:8px 14px;font-size:13px;font-weight:500;color:var(--text-2);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab:hover:not(.active){color:var(--text)}.filter-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:14px}.filter-row .chip{cursor:pointer}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.sparkline{width:100%;height:36px}.striped{background:repeating-linear-gradient(135deg,var(--bg-soft) 0 8px,transparent 8px 16px);border:1px dashed var(--line-strong);border-radius:10px;color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:13px;min-height:120px}.drawer-backdrop,.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#19161073;z-index:80}.drawer{position:fixed;top:0;right:0;bottom:0;width:100%;max-width:560px;background:var(--bg-elev);z-index:90;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}.drawer-header{padding:16px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.drawer-header h3{margin:0;font-size:15px;font-weight:600}.drawer-body{flex:1;overflow-y:auto;padding:18px 22px}.drawer-footer{padding:12px 22px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:10px}.steps{display:flex;gap:6px;margin-bottom:16px}.step{flex:1;padding:9px 6px;border-radius:7px;background:var(--bg-soft);color:var(--text-2);font-size:11.5px;text-align:center}.step.active{background:var(--primary-soft);color:var(--primary-2);font-weight:600}.step.done{background:var(--success-soft);color:var(--success)}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:92%;max-width:380px;background:var(--bg-elev);border-radius:16px;z-index:90;box-shadow:var(--shadow-lg);overflow:hidden}.phone-frame{width:100%;aspect-ratio:9/19;background:var(--bg);padding:16px;overflow-y:auto}.placeholder{padding:36px;text-align:center;color:var(--text-3);font-size:13px}@media (max-width: 1100px){.kpi-row{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 800px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.login-wrap{grid-template-columns:1fr}.login-left{display:none}.kpi-row,.grid-2,.grid-3{grid-template-columns:1fr}.content{padding:16px}}.cf-chart{display:flex;align-items:flex-end;gap:8px;height:190px;padding:10px 4px}.cf-bar{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.cf-bar .bars{display:flex;gap:2px;height:100%;align-items:flex-end;width:100%}.cf-bar .bars i{flex:1;border-radius:3px 3px 0 0;min-height:4px}.cf-bar .bars i.in{background:var(--success)}.cf-bar .bars i.out{background:var(--neg)}.cf-bar .lbl{font-size:10px;color:var(--text-3)}.donut-wrap{display:flex;align-items:center;justify-content:center;padding:12px}.legend-row{display:flex;align-items:center;gap:8px;font-size:12px;margin-bottom:6px}.legend-row i{width:10px;height:10px;border-radius:3px}.row{display:flex;align-items:center;gap:8px}.between{display:flex;align-items:center;justify-content:space-between;gap:12px}.right{display:flex;justify-content:flex-end}.muted{color:var(--text-2)}.mono{font-family:Geist Mono,ui-monospace,SF Mono,Menlo,monospace;font-feature-settings:"zero" on,"tnum" on}.text-xs{font-size:11.5px}.text-sm{font-size:13px}.text-lg{font-size:16px}.bold{font-weight:600}.numeric{font-variant-numeric:tabular-nums}.scroll-x{overflow-x:auto}.toast-stack{position:fixed;bottom:24px;right:24px;z-index:200;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 14px;border-radius:8px;font-size:13px;font-weight:500;min-width:260px;max-width:380px;pointer-events:all;box-shadow:0 4px 20px #00000024;animation:toast-in .22s ease}.toast-success{background:#e0fae4;color:#003312;color:oklch(.28 .1 150);border:1px solid oklch(.88 .08 150)}.toast-error{background:#fff0ef;background:oklch(.97 .04 20);color:#650015;color:oklch(.32 .14 20);border:1px solid oklch(.9 .08 20)}.toast-info{background:#e6f4ff;background:oklch(.96 .04 240);color:#002c45;color:oklch(.28 .1 240);border:1px solid oklch(.88 .08 240)}.toast-warn{background:#fff3e4;background:oklch(.97 .05 75);color:#472d00;color:oklch(.32 .12 75);border:1px solid oklch(.9 .08 75)}.toast-close{background:none;border:none;cursor:pointer;font-size:17px;line-height:1;opacity:.55;padding:0 2px;color:inherit;font-family:inherit}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
