:root{--paper: #0d0b18;--paper-2: #15121f;--bg: #07060d;--bg-soft: #0d0b18;--card: #100d1c;--panel: #13101f;--surface: rgba(255,255,255,.03);--surface-2: rgba(255,255,255,.05);--ink: #ECEAF6;--ink-soft: #c9c5e0;--muted: #9a96b8;--faint: #6c6890;--line: rgba(255,255,255,.08);--line-strong: rgba(255,255,255,.16);--clay: #8b5cf6;--clay-deep: #a78bfa;--clay-soft: rgba(139,92,246,.16);--violet: #8b5cf6;--violet-bright: #a78bfa;--cyan: #22d3ee;--pink: #f472b6;--grad: linear-gradient(110deg, #a78bfa 0%, #22d3ee 55%, #f472b6 110%);--glow: 0 0 40px rgba(139,92,246,.45);--pos: #34d399;--pos-soft: rgba(52,211,153,.14);--warn: #fbbf24;--warn-soft: rgba(251,191,36,.14);--danger: #fb7185;--danger-soft: rgba(251,113,133,.14);--info: #22d3ee;--info-soft: rgba(34,211,238,.14);--display: "Space Grotesk", system-ui, sans-serif;--ui: "Inter", system-ui, sans-serif;--mono: "JetBrains Mono", ui-monospace, monospace;--r: 13px;--r-sm: 9px;--shadow: 0 1px 2px rgba(0,0,0,.4), 0 12px 30px -10px rgba(0,0,0,.6);--shadow-lg: 0 2px 8px rgba(0,0,0,.45), 0 30px 70px -24px rgba(0,0,0,.75);--ease: cubic-bezier(.22,.61,.36,1);--sidebar-w: 248px;--max-w: 1320px}@media(prefers-color-scheme:light){:root:not([data-theme=dark]){--bg: #f6f6fb;--bg-soft: #eceef6;--paper: #eef0f7;--paper-2: #e6e8f2;--card: #ffffff;--panel: #fbfbfe;--surface: rgba(17,12,46,.03);--surface-2: rgba(17,12,46,.05);--ink: #191636;--ink-soft: #3a3658;--muted: #5c5878;--faint: #8a86a0;--line: rgba(17,12,46,.1);--line-strong: rgba(17,12,46,.17);--clay: #7c3aed;--clay-deep: #6d28d9;--clay-soft: rgba(124,58,237,.12);--pos: #0f9d6b;--pos-soft: rgba(16,185,129,.12);--warn: #b45309;--warn-soft: rgba(245,158,11,.14);--danger: #be123c;--danger-soft: rgba(244,63,94,.12);--info: #0e7490;--info-soft: rgba(34,211,238,.16);--violet: #7c3aed;--violet-bright: #8b5cf6;--cyan: #0ea5b9;--pink: #db2777;--grad: linear-gradient(110deg, #7c3aed 0%, #0ea5b9 55%, #db2777 110%);--glow: 0 0 30px rgba(124,58,237,.22);--shadow: 0 1px 2px rgba(20,16,60,.05), 0 6px 22px -8px rgba(20,16,60,.14);--shadow-lg: 0 2px 6px rgba(20,16,60,.06), 0 24px 54px -22px rgba(20,16,60,.22)}}:root[data-theme=light]{--bg: #f6f6fb;--bg-soft: #eceef6;--paper: #eef0f7;--paper-2: #e6e8f2;--card: #ffffff;--panel: #fbfbfe;--surface: rgba(17,12,46,.03);--surface-2: rgba(17,12,46,.05);--ink: #191636;--ink-soft: #3a3658;--muted: #5c5878;--faint: #8a86a0;--line: rgba(17,12,46,.1);--line-strong: rgba(17,12,46,.17);--clay: #7c3aed;--clay-deep: #6d28d9;--clay-soft: rgba(124,58,237,.12);--pos: #0f9d6b;--pos-soft: rgba(16,185,129,.12);--warn: #b45309;--warn-soft: rgba(245,158,11,.14);--danger: #be123c;--danger-soft: rgba(244,63,94,.12);--info: #0e7490;--info-soft: rgba(34,211,238,.16);--violet: #7c3aed;--violet-bright: #8b5cf6;--cyan: #0ea5b9;--pink: #db2777;--grad: linear-gradient(110deg, #7c3aed 0%, #0ea5b9 55%, #db2777 110%);--glow: 0 0 30px rgba(124,58,237,.22);--shadow: 0 1px 2px rgba(20,16,60,.05), 0 6px 22px -8px rgba(20,16,60,.14);--shadow-lg: 0 2px 6px rgba(20,16,60,.06), 0 24px 54px -22px rgba(20,16,60,.22)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background:var(--bg);color:var(--ink);font-family:var(--ui);-webkit-font-smoothing:antialiased;line-height:1.5}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;background:radial-gradient(60% 50% at 12% -5%,rgba(139,92,246,.2),transparent 60%),radial-gradient(48% 48% at 92% 8%,rgba(34,211,238,.12),transparent 60%),radial-gradient(55% 55% at 78% 105%,rgba(244,114,182,.1),transparent 60%),var(--bg)}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) body:before{background:radial-gradient(60% 50% at 12% -5%,rgba(124,58,237,.08),transparent 60%),radial-gradient(48% 48% at 92% 8%,rgba(14,165,185,.06),transparent 60%),radial-gradient(55% 55% at 78% 105%,rgba(219,39,119,.05),transparent 60%),var(--bg)}}:root[data-theme=light] body:before{background:radial-gradient(60% 50% at 12% -5%,rgba(124,58,237,.08),transparent 60%),radial-gradient(48% 48% at 92% 8%,rgba(14,165,185,.06),transparent 60%),radial-gradient(55% 55% at 78% 105%,rgba(219,39,119,.05),transparent 60%),var(--bg)}::selection{background:var(--violet);color:#fff}h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.02em}button{font-family:inherit}a{color:inherit;text-decoration:none}.mono{font-family:var(--mono)}.tnum{font-variant-numeric:tabular-nums}.eyebrow{font-family:var(--mono);font-size:10.5px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}.app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100%}.main{display:flex;flex-direction:column;min-width:0}.scroll{flex:1;overflow-y:auto;padding:26px 30px 60px}.scroll-inner{max-width:var(--max-w);margin:0 auto}.sidebar{background:linear-gradient(180deg,#0c0a16,#08070f);color:var(--ink-soft);border-right:1px solid var(--line);display:flex;flex-direction:column;gap:4px;padding:20px 14px;position:sticky;top:0;height:100vh}.sb-logo{font-family:var(--display);font-size:23px;font-weight:600;padding:6px 10px 16px;color:var(--ink)}.sb-logo b{font-weight:600}.sb-logo .dot{color:var(--clay-deep)}.sb-group{margin-top:14px}.sb-group>.lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);padding:4px 10px 7px}.sb-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 10px;border:none;background:transparent;color:var(--muted);border-radius:var(--r-sm);cursor:pointer;font-size:13.5px;font-weight:500;position:relative;transition:background .15s var(--ease),color .15s var(--ease)}.sb-item:hover{background:#ffffff0d;color:var(--ink)}.sb-item.active{background:var(--clay-soft);color:var(--ink);font-weight:600;box-shadow:inset 0 0 0 1px #8b5cf640}.sb-item.active:before{content:"";position:absolute;left:-14px;top:7px;bottom:7px;width:3px;background:var(--grad);border-radius:0 3px 3px 0;box-shadow:var(--glow)}.sb-item .ico{flex:none;opacity:.85}.sb-badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;background:#ffffff14;color:var(--ink-soft);padding:1px 7px;border-radius:20px}.sb-badge.clay{background:var(--clay);color:#fff}.sb-item.active .sb-badge{background:var(--clay-soft);color:var(--clay-deep)}.sb-foot{margin-top:auto;padding-top:12px;border-top:1px solid var(--line)}.sb-user{display:flex;align-items:center;gap:10px;padding:8px 10px}.sb-user .av{width:30px;height:30px;border-radius:9px;background:var(--grad);color:#0a0814;display:grid;place-items:center;font-weight:700;font-size:13px}.sb-user .nm{font-size:13px;font-weight:600;color:var(--ink)}.sb-user .rl{font-size:11px;color:var(--muted)}.topbar{display:flex;align-items:center;gap:16px;padding:16px 30px;border-bottom:1px solid var(--line);background:#07060d99;-webkit-backdrop-filter:blur(12px) saturate(140%);backdrop-filter:blur(12px) saturate(140%);position:sticky;top:0;z-index:10}.net-banner{text-align:center;font-size:12.5px;font-weight:600;padding:7px 16px}.net-banner.off{background:var(--warn-soft);color:var(--warn)}.net-banner.sync{background:var(--info-soft);color:var(--info)}.demo-banner{background:var(--grad);color:#0a0814;text-align:center;font-size:12.5px;font-weight:600;padding:7px 16px}.demo-banner a{color:#0a0814;text-decoration:underline;font-weight:700}.tb-menu{display:none}.tb-head{min-width:0}.tb-crumb{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}.tb-title{font-family:var(--display);font-size:22px;font-weight:600;margin-top:1px}.tb-right{margin-left:auto;display:flex;align-items:center;gap:10px}.tb-search{display:flex;align-items:center;gap:8px;padding:8px 11px;background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-sm);color:var(--muted);font-size:13px;cursor:text;min-width:200px}.tb-search kbd{margin-left:auto;font-family:var(--mono);font-size:10px;color:var(--faint);border:1px solid var(--line-strong);border-radius:5px;padding:1px 5px}.tb-bell{position:relative;width:38px;height:38px;border-radius:var(--r-sm);border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink-soft);display:grid;place-items:center;cursor:pointer;transition:border-color .15s,box-shadow .15s}.tb-bell:hover{border-color:var(--violet-bright);box-shadow:var(--glow)}.tb-bell .pip{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--pink);border:1.5px solid var(--bg)}.tb-btn{display:inline-flex;align-items:center;gap:7px;padding:9px 14px;border-radius:var(--r-sm);font-size:13px;font-weight:600;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);transition:transform .15s var(--ease),box-shadow .15s var(--ease),background .15s,border-color .15s}.tb-btn:hover{transform:translateY(-1px);border-color:var(--violet-bright);box-shadow:var(--glow)}.tb-btn.primary{background:var(--grad);border-color:transparent;color:#0a0814}.tb-btn.primary:hover{box-shadow:0 8px 30px #8b5cf68c}.sb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#03020899;z-index:40}.grid{display:grid;gap:16px}.kpi-grid{grid-template-columns:repeat(4,1fr)}.dash-2{grid-template-columns:1.6fr 1fr}@media(max-width:900px){.dash-2{grid-template-columns:1fr}}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:18px}.card-h{display:flex;align-items:baseline;gap:10px;margin-bottom:14px}.card-h .t{font-family:var(--display);font-size:16px;font-weight:600}.card-h .n{margin-left:auto;font-size:12px;color:var(--faint)}.kpi .lab{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}.kpi .val{font-family:var(--display);font-size:30px;font-weight:700;margin-top:7px;letter-spacing:-.02em;background:var(--grad);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.kpi .delta{display:inline-flex;align-items:center;gap:4px;margin-top:8px;font-size:12px;font-weight:600;font-family:var(--mono)}.kpi .delta.up{color:var(--pos)}.kpi .delta.down{color:var(--danger)}.kpi .delta.flat{color:var(--faint)}.badge{display:inline-flex;align-items:center;gap:5px;font-family:var(--mono);font-size:10.5px;font-weight:600;padding:3px 9px;border-radius:20px;letter-spacing:.02em}.badge.pos{background:var(--pos-soft);color:var(--pos)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.badge.clay{background:var(--clay-soft);color:var(--clay-deep)}.badge.neutral{background:var(--surface-2);color:var(--muted)}.act{display:flex;gap:11px;padding:11px 0;border-top:1px dashed var(--line)}.act:first-child{border-top:none}.act .dot{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center}.act .txt{font-size:13px}.act .txt b{font-weight:600}.act .when{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:2px}.alert{display:flex;align-items:center;gap:12px;padding:13px 16px;border-radius:var(--r);font-size:13px}.alert.warn{background:var(--warn-soft);color:var(--warn);border:1px solid rgba(251,191,36,.25)}.alert b{font-weight:700}.bars{display:flex;align-items:flex-end;gap:14px;height:200px;padding-top:8px}.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}.bar-v{font-family:var(--mono);font-size:10.5px;color:var(--muted);margin-bottom:6px;font-variant-numeric:tabular-nums}.bar-track{flex:1;width:100%;display:flex;align-items:flex-end}.bar-fill{width:100%;background:linear-gradient(180deg,var(--violet-bright),var(--violet));border-radius:6px 6px 0 0;min-height:4px;transition:height .6s var(--ease);box-shadow:0 0 18px #8b5cf666}.bar-fill.partial{background:repeating-linear-gradient(45deg,var(--line-strong),var(--line-strong) 5px,var(--surface-2) 5px,var(--surface-2) 10px);box-shadow:none}.bar-m{font-family:var(--mono);font-size:10.5px;color:var(--faint);margin-top:8px;text-transform:uppercase;letter-spacing:.06em}.gauge{position:relative;display:grid;place-items:center;margin:0 auto}.gauge-c{position:absolute;text-align:center}.gauge-pct{font-family:var(--display);font-size:30px;font-weight:600}.gauge-lab{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--faint)}.area{display:block}.donut-wrap{display:flex;align-items:center;gap:18px}.donut-leg{list-style:none;display:flex;flex-direction:column;gap:8px}.donut-leg li{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-soft)}.donut-leg .sw{width:11px;height:11px;border-radius:3px}.donut-leg b{margin-left:auto;font-family:var(--mono);font-weight:600}.tbl-bar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.seg{display:inline-flex;gap:3px;background:var(--surface);border:1px solid var(--line);padding:3px;border-radius:10px}.seg button{border:none;background:transparent;font-family:var(--ui);font-size:13px;font-weight:600;color:var(--muted);padding:6px 14px;border-radius:8px;cursor:pointer;transition:.12s var(--ease)}.seg button.on{background:var(--clay-soft);color:var(--ink);box-shadow:inset 0 0 0 1px #8b5cf64d}.tbl-count{margin-left:auto;font-family:var(--mono);font-size:11.5px;color:var(--faint)}.tbl-wrap{overflow-x:auto}.tbl{width:100%;border-collapse:collapse;min-width:720px}.tbl th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);font-weight:600;padding:0 14px 11px}.tbl th.r,.tbl td.r{text-align:right}.tbl td{padding:12px 14px;border-top:1px solid var(--line);font-size:13.5px;vertical-align:middle}.tbl tbody tr:hover td{background:#ffffff0a}.cell-client{display:flex;align-items:center;gap:11px}.cell-client .av{width:34px;height:34px;border-radius:10px;color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;flex:none}.cell-client .nm{font-weight:600}.cell-client .tr{font-size:11.5px;color:var(--muted)}.site-link{font-family:var(--mono);font-size:12px;color:var(--info)}.site-link.demo{color:var(--faint)}.visits{display:flex;align-items:center;gap:9px;justify-content:flex-end}.visits .v{font-family:var(--mono);font-variant-numeric:tabular-nums}.trend{font-family:var(--mono);font-size:11px;font-weight:600}.trend.up{color:var(--pos)}.trend.down{color:var(--danger)}.trend.flat{color:var(--faint)}.row-menu{border:none;background:transparent;color:var(--muted);cursor:pointer;font-size:18px;line-height:1;border-radius:7px;padding:2px 8px}.row-menu:hover{background:var(--surface-2);color:var(--ink)}.kpi-3{grid-template-columns:repeat(3,1fr)}@media(max-width:900px){.kpi-3{grid-template-columns:1fr}}.ech{display:flex;align-items:center;gap:18px;padding:16px 20px;background:linear-gradient(180deg,var(--clay-soft),var(--card));border:1px solid var(--line);border-radius:var(--r);flex-wrap:wrap}.ech-steps{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.ech-step{text-align:center;padding:4px 10px}.ech-step .pc{font-family:var(--display);font-size:22px;font-weight:600;color:var(--clay-deep);line-height:1}.ech-step .lb{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-top:4px}.ech-arrow{color:var(--clay);opacity:.6}.ech-plus{font-family:var(--mono);font-size:12px;color:var(--muted);padding:0 4px}.ech-tags{margin-left:auto;display:flex;gap:8px;flex-wrap:wrap}.pipeline{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.pcol-h{display:flex;align-items:center;gap:8px;padding:2px 4px 10px}.pcol-h .t{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}.pcol-h .c{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--faint);background:var(--surface-2);border-radius:20px;padding:1px 8px}.pcol{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:10px;min-height:90px}.doc-card{background:var(--card);border:1px solid var(--line);border-radius:var(--r-sm);box-shadow:var(--shadow);padding:13px}.doc-card+.doc-card{margin-top:10px}.doc-top{display:flex;align-items:center;gap:8px;margin-bottom:9px}.doc-top .num{font-family:var(--mono);font-size:10.5px;color:var(--muted)}.doc-card .client{font-weight:600;font-size:13.5px}.doc-card .jalon{font-size:12px;color:var(--muted);margin-top:1px}.doc-card .amt{font-family:var(--display);font-size:22px;font-weight:600;margin-top:9px;letter-spacing:-.01em}.doc-card .amt small{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--muted);letter-spacing:0}.doc-card .due{font-family:var(--mono);font-size:10.5px;color:var(--faint);display:flex;align-items:center;gap:5px;margin-top:8px}.doc-card .due.late{color:var(--danger)}.pcol-empty{font-size:12px;color:var(--faint);text-align:center;padding:18px 0}@media(max-width:1100px){.pipeline{grid-template-columns:repeat(2,1fr)}}@media(max-width:620px){.pipeline{grid-template-columns:1fr}}.partbar{width:100px;height:7px;background:var(--surface-2);border-radius:4px;overflow:hidden;display:inline-block;vertical-align:middle}.partbar>i{display:block;height:100%;background:var(--grad);border-radius:4px}.range-toggle{margin-left:auto}.pdf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#030208cc;z-index:80;overflow:auto;padding:24px}.pdf-toolbar{display:flex;gap:10px;justify-content:flex-end;max-width:800px;margin:0 auto 16px}.pdf-sheet{background:#fff;max-width:800px;margin:0 auto;padding:46px 44px;box-shadow:var(--shadow-lg);color:#231f1b;font-size:13px}.pdf-head{display:flex;justify-content:space-between;gap:20px;border-bottom:2px solid #231F1B;padding-bottom:16px}.pdf-logo{font-family:var(--display);font-size:26px;font-weight:700;color:#231f1b}.pdf-logo span{color:#bd5c3a}.pdf-meta{font-size:11px;color:#7a7268;margin-top:6px;line-height:1.5}.pdf-doc{text-align:right}.pdf-type{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:#bd5c3a}.pdf-num{font-family:var(--mono);font-size:18px;font-weight:600;color:#231f1b}.pdf-dates{font-size:10.5px;color:#7a7268;margin-top:4px}.pdf-client{margin:22px 0;color:#231f1b}.pdf-client .lbl,.pdf-ech .lbl{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:#a39b8f;margin-bottom:4px}.pdf-table{width:100%;border-collapse:collapse;margin-top:8px;color:#231f1b}.pdf-table th{text-align:left;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#7a7268;border-bottom:1px solid #D6CEBF;padding:8px 6px}.pdf-table th:nth-child(n+2),.pdf-table td:nth-child(n+2){text-align:right}.pdf-table td{padding:9px 6px;border-bottom:1px solid #E4DED3;font-variant-numeric:tabular-nums}.pdf-total{display:flex;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:2px solid #231F1B;font-size:15px;color:#231f1b}.pdf-total b{font-family:var(--display);font-size:20px}.pdf-ech{margin-top:22px;color:#231f1b}.pdf-ech-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed #E4DED3;font-size:12.5px}.pdf-pay{margin-top:22px;background:#f0ece3;border:1px solid #E4DED3;border-radius:8px;padding:12px 16px;font-size:13px;line-height:1.7;color:#231f1b}.pdf-foot{margin-top:22px;font-size:10.5px;color:#7a7268;border-top:1px solid #E4DED3;padding-top:12px;line-height:1.6}@media print{.no-print{display:none!important}body *{visibility:hidden}.pdf-overlay,.pdf-overlay *{visibility:visible}.pdf-overlay{position:absolute;inset:auto;top:0;left:0;width:100%;padding:0;background:#fff;overflow:visible}.pdf-sheet{box-shadow:none;max-width:none;margin:0;padding:0}@page{margin:16mm}}.inc-list{list-style:none;margin:2px 0 0;padding:0}.inc-list li{font-size:12.5px;color:var(--muted);padding:3px 0 3px 18px;position:relative}.inc-list li:before{content:"✓";position:absolute;left:0;color:var(--clay);font-weight:700}.ate-sec h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--clay);font-weight:600;padding:14px 0 6px}.ate-item{display:flex;align-items:center;gap:11px;padding:9px 0;border-top:1px dashed var(--line)}.ate-sec .ate-item:first-of-type{border-top:none}.ate-cb{width:18px;height:18px;flex:none;accent-color:var(--clay);cursor:pointer}.ate-lbl{flex:1;font-size:13.5px}.ate-price{font-family:var(--mono);font-size:12.5px;color:var(--muted);white-space:nowrap}.ate-qty{display:flex;align-items:center;gap:2px}.ate-qty button{width:24px;height:26px;border:1px solid var(--line-strong);background:var(--surface-2);border-radius:6px;cursor:pointer;color:var(--ink-soft);line-height:1}.ate-qty input{width:30px;text-align:center;border:none;font-family:var(--mono);font-weight:600;background:transparent}.ate-qty input:focus{outline:none}.sum-hero{background:linear-gradient(180deg,var(--pos-soft),var(--card));border-radius:var(--r-sm);padding:13px;margin-bottom:12px}.sum-line{display:flex;justify-content:space-between;gap:12px;font-size:13px;padding:4px 0;color:var(--ink)}.sum-line .mono{font-family:var(--mono)}.sum-line.muted{color:var(--muted);font-size:12.5px}.sum-line.grand{font-family:var(--display);font-size:18px;font-weight:700;padding-top:8px;margin-top:6px;border-top:1px solid var(--line)}.dt-head{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.av.lg{width:52px;height:52px;border-radius:14px;color:#fff;display:grid;place-items:center;font-weight:600;font-size:18px;font-family:var(--ui);flex:none}.info-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:11px 0;border-top:1px dashed var(--line);font-size:13.5px}.info-row:first-of-type{border-top:none}.info-row>span:first-child{color:var(--muted)}.row-click{cursor:pointer}.modal-ov{position:fixed;top:0;right:0;bottom:0;left:0;background:#03020899;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:60;display:grid;place-items:center;padding:20px}.modal{width:100%;background:var(--panel);border:1px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--shadow-lg);max-height:90vh;display:flex;flex-direction:column}.modal-h{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line)}.modal-h h3{font-family:var(--display);font-size:17px;font-weight:600}.modal-x{margin-left:auto;border:none;background:transparent;font-size:22px;line-height:1;color:var(--muted);cursor:pointer;border-radius:7px;width:30px;height:30px}.modal-x:hover{background:var(--surface-2);color:var(--ink)}.modal-b{padding:18px 20px;overflow-y:auto}.modal-f{display:flex;gap:10px;justify-content:flex-end;padding:14px 20px;border-top:1px solid var(--line)}.form{display:grid;gap:14px}.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:12px}@media(max-width:480px){.form .row2{grid-template-columns:1fr}}.fld select,.fld textarea{width:100%;font-family:var(--ui);font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 12px}.fld select:focus,.fld textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px #8b5cf640;background:var(--surface-2)}.btn{font-family:var(--ui);font-size:13.5px;font-weight:600;border-radius:var(--r-sm);padding:10px 16px;cursor:pointer;border:1px solid var(--line-strong);background:var(--surface-2);color:var(--ink);transition:border-color .15s,box-shadow .15s,color .15s}.btn:hover{border-color:var(--violet-bright);color:var(--ink);box-shadow:var(--glow)}.btn.primary{background:var(--grad);border-color:transparent;color:#0a0814}.btn.primary:hover{box-shadow:0 8px 30px #8b5cf68c;color:#0a0814}.btn.danger{color:var(--danger);border-color:#fb71854d;background:var(--danger-soft)}.btn.danger:hover{background:#fb718533;border-color:var(--danger);box-shadow:none}.form-err{font-size:12.5px;color:var(--danger);background:var(--danger-soft);border-radius:var(--r-sm);padding:8px 11px}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;position:relative;overflow:hidden;background:radial-gradient(80% 60% at 50% -10%,rgba(139,92,246,.3),transparent 60%),radial-gradient(60% 50% at 85% 100%,rgba(34,211,238,.16),transparent 60%),var(--bg)}.login-canvas{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;pointer-events:none;opacity:.9}.cursor-glow{position:fixed;top:0;left:0;width:460px;height:460px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,.16),transparent 65%);transform:translate(-50%,-50%);pointer-events:none;z-index:0;will-change:transform}@media(hover:none),(prefers-reduced-motion:reduce){.cursor-glow{display:none}}.login-card{position:relative;z-index:1;width:100%;max-width:360px;background:#13101fb8;border:1px solid var(--line-strong);border-radius:var(--r);box-shadow:var(--shadow-lg);-webkit-backdrop-filter:blur(16px) saturate(140%);backdrop-filter:blur(16px) saturate(140%);padding:30px 28px;display:flex;flex-direction:column;gap:14px}.login-logo{font-family:var(--display);font-size:30px;font-weight:600;text-align:center;color:var(--ink)}.login-logo .dot{color:var(--clay-deep)}.login-sub{text-align:center;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-top:-8px;margin-bottom:6px}.fld span{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:5px}.fld input{width:100%;font-family:var(--ui);font-size:14px;color:var(--ink);background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 12px}.fld input:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px #8b5cf640;background:var(--surface-2)}.login-err{font-size:12.5px;color:var(--danger);background:var(--danger-soft);border-radius:var(--r-sm);padding:8px 11px}.login-btn{margin-top:4px;background:var(--grad);color:#0a0814;border:none;border-radius:var(--r-sm);padding:11px;font-family:var(--ui);font-size:14px;font-weight:700;cursor:pointer;transition:box-shadow .15s var(--ease),transform .15s var(--ease)}.login-btn:hover{box-shadow:0 8px 30px #8b5cf68c;transform:translateY(-1px)}.login-btn:disabled{opacity:.6;cursor:default}.login-foot{text-align:center;font-size:10.5px;color:var(--faint);margin-top:2px}.state{display:grid;place-items:center;min-height:40vh;color:var(--muted);font-size:13.5px}.state.err{color:var(--danger)}.placeholder{display:grid;place-items:center;min-height:50vh;text-align:center;color:var(--muted)}.placeholder .pg{font-family:var(--display);font-size:22px;color:var(--ink);margin-bottom:6px}@media(max-width:1100px){.kpi-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:900px){.app{grid-template-columns:1fr}.sidebar{position:fixed;left:0;top:0;z-index:50;transform:translate(-100%);transition:transform .25s var(--ease);width:80%;max-width:280px}.sidebar.open{transform:none}.scroll{padding:20px 16px 48px}.topbar{padding:14px 16px}.tb-menu{display:grid}}@media(max-width:560px){.kpi-grid{grid-template-columns:1fr}.tb-search{display:none}}@media(prefers-color-scheme:light){:root:not([data-theme=dark]) .sidebar{background:linear-gradient(180deg,#fff,#f3f3fa);color:var(--ink-soft);border-right:1px solid var(--line)}:root:not([data-theme=dark]) .sb-item:hover{background:#110c2e0d}:root:not([data-theme=dark]) .sb-badge{background:#110c2e0f}:root:not([data-theme=dark]) .topbar{background:#fff9}:root:not([data-theme=dark]) .sb-overlay{background:#110c2e59}:root:not([data-theme=dark]) .tbl tbody tr:hover td{background:#110c2e0a}:root:not([data-theme=dark]) .modal-ov{background:#110c2e59}:root:not([data-theme=dark]) .pdf-overlay{background:#110c2e80}:root:not([data-theme=dark]) .login-card{background:#ffffffd1}:root:not([data-theme=dark]) .sb-user .av,:root:not([data-theme=dark]) .tb-btn.primary,:root:not([data-theme=dark]) .btn.primary,:root:not([data-theme=dark]) .login-btn,:root:not([data-theme=dark]) .demo-banner,:root:not([data-theme=dark]) .demo-banner a{color:#fff}:root:not([data-theme=dark]) .btn.primary:hover{color:#fff}}:root[data-theme=light] .sidebar{background:linear-gradient(180deg,#fff,#f3f3fa);color:var(--ink-soft);border-right:1px solid var(--line)}:root[data-theme=light] .sb-item:hover{background:#110c2e0d}:root[data-theme=light] .sb-badge{background:#110c2e0f}:root[data-theme=light] .topbar{background:#fff9}:root[data-theme=light] .sb-overlay{background:#110c2e59}:root[data-theme=light] .tbl tbody tr:hover td{background:#110c2e0a}:root[data-theme=light] .modal-ov{background:#110c2e59}:root[data-theme=light] .pdf-overlay{background:#110c2e80}:root[data-theme=light] .login-card{background:#ffffffd1}:root[data-theme=light] .sb-user .av,:root[data-theme=light] .tb-btn.primary,:root[data-theme=light] .btn.primary,:root[data-theme=light] .login-btn,:root[data-theme=light] .demo-banner,:root[data-theme=light] .demo-banner a{color:#fff}:root[data-theme=light] .btn.primary:hover{color:#fff}
