:root{--paper: #F7F4EE;--paper-2: #F0ECE3;--bg: #F2F0EA;--card: #FCFAF6;--panel: #FBFAF6;--ink: #231F1B;--ink-soft: #3A352F;--muted: #7A7268;--faint: #A39B8F;--line: #E4DED3;--line-strong: #D6CEBF;--clay: #BD5C3A;--clay-deep: #9E4828;--clay-soft: #F3E2D8;--pos: #3F6B4E;--pos-soft: #E5EDE6;--warn: #B07A2E;--warn-soft: #F4EAD7;--danger: #AA463B;--danger-soft: #F3E2DD;--info: #4A5A77;--info-soft: #E6EAF0;--display: "Newsreader", Georgia, serif;--ui: "Hanken Grotesk", system-ui, sans-serif;--mono: "IBM Plex Mono", ui-monospace, monospace;--r: 13px;--r-sm: 9px;--shadow: 0 1px 2px rgba(35,31,27,.04), 0 6px 22px -8px rgba(35,31,27,.12);--shadow-lg: 0 2px 6px rgba(35,31,27,.05), 0 24px 54px -22px rgba(35,31,27,.28);--ease: cubic-bezier(.22,.61,.36,1);--sidebar-w: 248px;--max-w: 1320px}*{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}::selection{background:var(--clay);color:#fff}h1,h2,h3{font-family:var(--display);font-weight:600;letter-spacing:-.01em}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:var(--ink);color:#efe9e0;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}.sb-logo b{font-weight:600}.sb-logo .dot{color:var(--clay)}.sb-group{margin-top:14px}.sb-group>.lbl{font-family:var(--mono);font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:#8a8178;padding:4px 10px 7px}.sb-item{display:flex;align-items:center;gap:11px;width:100%;padding:9px 10px;border:none;background:transparent;color:#cfc7bc;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:#f4efe7}.sb-item.active{background:var(--paper);color:var(--ink);font-weight:600}.sb-item.active:before{content:"";position:absolute;left:-14px;top:7px;bottom:7px;width:3px;background:var(--clay);border-radius:0 3px 3px 0}.sb-item .ico{flex:none;opacity:.85}.sb-badge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;background:#ffffff1a;color:#efe9e0;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 rgba(255,255,255,.08)}.sb-user{display:flex;align-items:center;gap:10px;padding:8px 10px}.sb-user .av{width:30px;height:30px;border-radius:9px;background:var(--clay);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px}.sb-user .nm{font-size:13px;font-weight:600;color:#f4efe7}.sb-user .rl{font-size:11px;color:#9a9189}.topbar{display:flex;align-items:center;gap:16px;padding:16px 30px;border-bottom:1px solid var(--line);background:#f7f4eeb3;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);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:#6e4e15}.net-banner.sync{background:var(--info-soft);color:var(--info)}.demo-banner{background:var(--clay);color:#fff;text-align:center;font-size:12.5px;font-weight:500;padding:7px 16px}.demo-banner a{color:#fff;text-decoration:underline;font-weight:600}.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(--card);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(--card);color:var(--ink-soft);display:grid;place-items:center;cursor:pointer}.tb-bell .pip{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--clay);border:1.5px solid var(--card)}.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(--card);color:var(--ink);transition:transform .15s var(--ease),box-shadow .15s var(--ease),background .15s}.tb-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px -8px #bd5c3a80}.tb-btn.primary{background:var(--ink);border-color:var(--ink);color:#f7f4ee}.tb-btn.primary:hover{background:var(--clay);border-color:var(--clay)}.sb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#231f1b66;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:600;margin-top:7px;letter-spacing:-.02em}.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(--paper-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:#6e4e15}.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:var(--clay);border-radius:6px 6px 0 0;min-height:4px;transition:height .6s var(--ease)}.bar-fill.partial{background:repeating-linear-gradient(45deg,var(--line-strong),var(--line-strong) 5px,var(--paper-2) 5px,var(--paper-2) 10px)}.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(--paper-2);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(--card);color:var(--ink);box-shadow:0 1px 2px #231f1b1f}.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:var(--paper)}.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(--paper-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(--paper-2);border-radius:20px;padding:1px 8px}.pcol{background:var(--paper-2);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(--paper-2);border-radius:4px;overflow:hidden;display:inline-block;vertical-align:middle}.partbar>i{display:block;height:100%;background:var(--clay);border-radius:4px}.range-toggle{margin-left:auto}.pdf-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--paper-2);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 var(--ink);padding-bottom:16px}.pdf-logo{font-family:var(--display);font-size:26px;font-weight:700}.pdf-logo span{color:var(--clay)}.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:var(--clay)}.pdf-num{font-family:var(--mono);font-size:18px;font-weight:600}.pdf-dates{font-size:10.5px;color:#7a7268;margin-top:4px}.pdf-client{margin:22px 0}.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}.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 var(--line-strong);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 var(--line);font-variant-numeric:tabular-nums}.pdf-total{display:flex;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:2px solid var(--ink);font-size:15px}.pdf-total b{font-family:var(--display);font-size:20px}.pdf-ech{margin-top:22px}.pdf-ech-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line);font-size:12.5px}.pdf-pay{margin-top:22px;background:var(--paper-2);border:1px solid var(--line);border-radius:8px;padding:12px 16px;font-size:13px;line-height:1.7}.pdf-foot{margin-top:22px;font-size:10.5px;color:#7a7268;border-top:1px solid var(--line);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:#fff;border-radius:6px;cursor:pointer;color:var(--muted);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:#231f1b6b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;display:grid;place-items:center;padding:20px}.modal{width:100%;background:var(--card);border:1px solid var(--line);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(--paper-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(--paper);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(--clay);box-shadow:0 0 0 3px var(--clay-soft);background:#fff}.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(--card);color:var(--ink)}.btn:hover{border-color:var(--clay);color:var(--clay)}.btn.primary{background:var(--ink);border-color:var(--ink);color:var(--paper)}.btn.primary:hover{background:var(--clay);border-color:var(--clay);color:#fff}.btn.danger{color:var(--danger);border-color:var(--danger-soft)}.btn.danger:hover{background:var(--danger-soft);border-color:var(--danger)}.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;background:radial-gradient(120% 90% at 50% 0%,var(--clay-soft),transparent 60%),var(--paper)}.login-card{width:100%;max-width:360px;background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow-lg);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}.login-logo .dot{color:var(--clay)}.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(--paper);border:1px solid var(--line-strong);border-radius:var(--r-sm);padding:10px 12px}.fld input:focus{outline:none;border-color:var(--clay);box-shadow:0 0 0 3px var(--clay-soft);background:#fff}.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(--ink);color:var(--paper);border:none;border-radius:var(--r-sm);padding:11px;font-family:var(--ui);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s var(--ease)}.login-btn:hover{background:var(--clay)}.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}}
