:root{
  /* Apple-style palette */
  --bg:#f5f5f7;
  --surface:#ffffff;
  --surface2:#fafafc;
  --border:rgba(0,0,0,0.10);
  --border2:rgba(0,0,0,0.18);
  --ink:#1d1d1f;
  --ink2:#424245;
  --muted:#86868b;
  --red:#e30000;      --lred:#fff2f4;   --dred:#b50000;
  --org:#f56300;      --lorg:#fff9f4;
  --yel:#ffe045;      --lyel:#fffef2;
  --grn:#03a10e;      --lgrn:#f5fff6;   --dgrn:#008009;
  --blu:#0071e3;      --lblu:#f0f4ff;
  --pur:#6e34c9;      --lpur:#f3eeff;
  --accent:#0071e3;   --accent-h:#0077ed;
  --surface-shadow:0 1px 4px rgba(0,0,0,0.08), 0 4px 16px rgba(0,0,0,0.04);
  --card-shadow:0 2px 8px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.04);
  --r:18px; --r-sm:10px; --r-xs:8px;
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'SF Pro Text','SF Pro Display',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);min-height:100vh;-webkit-font-smoothing:antialiased;font-size:17px;line-height:1.47;letter-spacing:-0.022em;font-synthesis:none;}

/* ── HEADER ── */
header{
  background:rgba(255,255,255,0.85);padding:0 32px;display:flex;align-items:center;justify-content:space-between;
  height:56px;position:sticky;top:0;z-index:100;
  border-bottom:1px solid var(--border);
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
}
.logo{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;font-weight:600;color:var(--ink);letter-spacing:-.3px;display:flex;align-items:center;gap:10px;}
.logo-icon{width:32px;height:32px;background:var(--ink);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:13px;font-weight:700;}
.logo em{color:var(--accent);font-style:normal;}
.hright{display:flex;align-items:center;gap:10px;}
.hdate{color:var(--muted);font-size:13px;font-weight:500;}
.wb-badge{
  background:var(--lblu);color:var(--accent);padding:5px 12px;border-radius:20px;
  font-size:12px;font-weight:700;letter-spacing:0;display:flex;align-items:center;gap:5px;
}

/* ── TABS ── */
.tabs{
  display:flex;background:rgba(255,255,255,0.85);border-bottom:1px solid var(--border);
  padding:0 32px;position:sticky;top:56px;z-index:99;overflow-x:auto;
  gap:2px;backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
}
.tab{
  padding:12px 16px;font-size:13px;font-weight:500;color:var(--muted);
  cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;
  white-space:nowrap;transition:all .18s;display:flex;align-items:center;gap:6px;
  letter-spacing:-.1px;
}
.tab:hover{color:var(--ink);}
.tab.on{color:var(--ink);border-bottom-color:var(--ink);font-weight:600;}
.tbadge{
  background:var(--lred);color:var(--red);border-radius:20px;
  padding:2px 7px;font-size:11px;font-weight:700;min-width:20px;text-align:center;
}
.tbadge.grn{background:var(--lgrn);color:var(--dgrn);}
.tbadge.org{background:var(--lorg);color:var(--org);}

/* ── GROUP FILTER ── */
.gf-bar{
  display:flex;flex-wrap:wrap;gap:8px;padding:0 0 16px;
}
.gf-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:7px 16px;border-radius:980px;border:none;
  background:rgba(0,0,0,0.06);font-family:inherit;
  font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;
  color:var(--ink2);
}
.gf-btn:hover{background:rgba(0,0,0,0.10);color:var(--ink);}
.gf-btn.on{background:var(--ink);color:#fff;}
.gf-btn.on .gf-cnt{background:rgba(255,255,255,.20);color:#fff;}
.gf-cnt{background:rgba(0,0,0,0.08);border-radius:980px;padding:1px 7px;font-size:11px;font-weight:600;transition:all .15s;color:var(--ink2);}

/* ── MAIN ── */
main{padding:24px 32px;max-width:1600px;margin:0 auto;}
.page{display:none;animation:fi .2s ease;}.page.on{display:block;}
@keyframes fi{from{opacity:0;transform:translateY(6px);}to{opacity:1;transform:translateY(0);}}

/* ── CONTROLS ── */
.ctrl-bar{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:16px 20px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;
  box-shadow:var(--surface-shadow);
}
.ctrl-group label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;}
.ctrl-group input,.ctrl-group select{
  padding:8px 12px;border:1px solid var(--border2);border-radius:var(--r-sm);
  font-family:inherit;font-size:13px;font-weight:400;
  background:var(--surface2);transition:border-color .15s,box-shadow .15s;min-width:140px;
}
.ctrl-group input:focus,.ctrl-group select:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,113,227,.15);}
.ctrl-group input[type=number]{width:90px;min-width:unset;}

/* ── SUMMARY CARDS ── */
.sum-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-bottom:20px;}
.sum-card{
  background:var(--surface);border-radius:var(--r);border:1px solid var(--border);
  padding:20px;position:relative;overflow:hidden;box-shadow:var(--card-shadow);
  transition:transform .2s cubic-bezier(.25,.46,.45,.94), box-shadow .2s;
}
.sum-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.10);}
.sum-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;border-radius:var(--r) var(--r) 0 0;}
.sc-red::before{background:var(--red);}.sc-org::before{background:var(--org);}
.sc-yel::before{background:var(--yel);}.sc-grn::before{background:var(--grn);}
.sc-blu::before{background:var(--accent);}
.sc-lbl{font-size:12px;font-weight:600;color:var(--muted);margin-bottom:8px;}
.sc-val{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:32px;line-height:1;color:var(--ink);letter-spacing:-.04em;font-weight:600;}
.sc-sub{font-size:12px;color:var(--muted);margin-top:6px;}
.wb-index-grid{display:grid;grid-template-columns:repeat(2,minmax(280px,1fr));gap:18px;margin-bottom:14px;}
.wb-index-card{
  background:#fff;border:1px solid rgba(0,0,0,.04);border-radius:22px;padding:26px 30px;
  min-height:112px;box-shadow:0 10px 28px rgba(18,22,33,.06);display:flex;align-items:flex-start;justify-content:space-between;gap:18px;
}
.wb-index-title{font-size:24px;line-height:1.1;font-weight:900;letter-spacing:-.03em;color:#111;margin-bottom:12px;}
.wb-index-desc{font-size:18px;line-height:1.22;font-weight:700;letter-spacing:-.03em;color:#111;max-width:720px;}
.wb-index-arrow{width:68px;height:68px;border-radius:14px;background:#f1f1f3;color:#111;display:flex;align-items:center;justify-content:center;flex:0 0 auto;font-size:42px;line-height:1;font-weight:300;}
@media(max-width:900px){
  .wb-index-grid{grid-template-columns:1fr;}
  .wb-index-card{padding:22px;min-height:96px;}
  .wb-index-title{font-size:21px;}
  .wb-index-desc{font-size:16px;}
  .wb-index-arrow{width:54px;height:54px;font-size:34px;}
}

/* ── TABLE ── */
.tw{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);box-shadow:var(--card-shadow);}
table{width:100%;border-collapse:collapse;font-size:13px;}
thead th{
  background:var(--surface2);color:var(--ink2);padding:11px 13px;
  text-align:left;font-size:11px;font-weight:700;letter-spacing:.5px;
  text-transform:uppercase;white-space:nowrap;border-bottom:1px solid var(--border);
}
thead th.sortable{cursor:pointer;user-select:none;}
thead th.sortable:hover{color:var(--accent);}
tbody tr{border-bottom:1px solid var(--border);transition:background .1s;}
tbody tr:hover{background:var(--surface2);}
tbody tr:last-child{border-bottom:none;}
td{padding:10px 13px;vertical-align:middle;}
.ta{font-family:ui-monospace,SFMono-Regular,'SF Mono',monospace;font-size:11px;color:var(--muted);}
.tn{font-weight:700;font-size:13px;color:var(--ink);}
.tc{font-size:11px;color:var(--muted);}
.copy-col{width:36px;text-align:center!important;padding-left:10px!important;padding-right:8px!important;}
.goods-copy-bar{
  display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;
  margin:0 0 14px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--r-sm);
  background:rgba(255,255,255,.82);box-shadow:var(--card-shadow);
}
.goods-copy-meta{font-size:12px;color:var(--muted);line-height:1.35;}
.irp-okrug-tip{position:relative;display:inline-block;cursor:help;text-decoration:underline dotted rgba(0,0,0,.28);text-underline-offset:4px;}
.irp-okrug-tip::after{content:attr(data-cities);position:absolute;left:0;bottom:calc(100% + 8px);z-index:80;width:max-content;max-width:360px;padding:10px 12px;border-radius:10px;background:#1f2937;color:#fff;font-size:12px;font-weight:600;line-height:1.45;white-space:normal;box-shadow:0 12px 32px rgba(0,0,0,.22);opacity:0;visibility:hidden;transform:translateY(4px);transition:opacity .12s,transform .12s,visibility .12s;pointer-events:none;}
.irp-okrug-tip::before{content:"";position:absolute;left:16px;bottom:calc(100% + 2px);z-index:81;border:6px solid transparent;border-top-color:#1f2937;opacity:0;visibility:hidden;transition:opacity .12s,visibility .12s;pointer-events:none;}
.irp-okrug-tip:hover::after,.irp-okrug-tip:hover::before{opacity:1;visibility:visible;transform:translateY(0);}
.goods-copy-meta strong{color:var(--ink);}
.goods-copy-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.goods-row-selected{background:rgba(0,113,227,.07)!important;}
tbody tr.goods-row-selected td{background:rgba(0,113,227,.07);}

/* ── BADGES ── */
.b{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;}
.b-r{background:var(--lred);color:var(--red);}
.b-o{background:var(--lorg);color:var(--org);}
.b-y{background:var(--lyel);color:var(--yel);}
.b-g{background:var(--lgrn);color:var(--dgrn);}
.b-b{background:var(--lblu);color:var(--blu);}
.b-p{background:var(--lpur);color:var(--pur);}
.b-x{background:var(--surface2);color:var(--muted);border:1px solid var(--border);}

/* ── COLORED CELLS ── */
.cell-red{background:var(--lred);color:var(--red);font-weight:800;text-align:center;border-radius:6px;padding:2px 7px;display:inline-block;}
.cell-org{background:var(--lorg);color:var(--org);font-weight:800;text-align:center;border-radius:6px;padding:2px 7px;display:inline-block;}
.cell-yel{background:var(--lyel);color:var(--yel);font-weight:700;text-align:center;border-radius:6px;padding:2px 7px;display:inline-block;}
.cell-grn{background:var(--lgrn);color:var(--dgrn);font-weight:700;text-align:center;border-radius:6px;padding:2px 7px;display:inline-block;}
.num{text-align:right;font-variant-numeric:tabular-nums;font-feature-settings:'tnum';}

/* ── TASK CARDS ── */
.tasks-grid{display:flex;flex-direction:column;gap:12px;}
.task-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;box-shadow:var(--card-shadow);}
.task-head{display:flex;align-items:center;padding:14px 20px;gap:12px;border-bottom:1px solid var(--border);}
.task-icon{font-size:22px;flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;border-radius:12px;}
.ti-red{background:var(--lred);} .ti-grn{background:var(--lgrn);} .ti-org{background:var(--lorg);}
.task-title{font-weight:700;font-size:15px;flex:1;color:var(--ink);}
.task-meta{font-size:12px;color:var(--muted);background:var(--surface2);padding:4px 10px;border-radius:20px;border:1px solid var(--border);}
.task-body{padding:0;}
.task-row{display:flex;align-items:center;padding:10px 20px;border-bottom:1px solid var(--border);gap:12px;font-size:13px;transition:background .1s;}
.task-row:last-child{border-bottom:none;}
.task-row:hover{background:var(--surface2);}
.tr-art{font-weight:700;min-width:200px;color:var(--ink);}
.tr-sku{font-family:monospace;font-size:11px;color:var(--muted);min-width:90px;}
.tr-detail{flex:1;color:var(--ink2);font-size:12px;}
.tr-val{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:16px;min-width:50px;text-align:right;}
.tr-unit{font-size:11px;color:var(--muted);min-width:30px;}
.done-row{opacity:.35;}
.done-row .tn,.done-row .tr-art{text-decoration:line-through;}

/* ── SECTION TITLE ── */
.stitle{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:17px;font-weight:600;letter-spacing:-.03em;margin-bottom:14px;display:flex;align-items:center;gap:10px;color:var(--ink);}
.dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;}

/* ── BUTTONS ── */
.btn{
  display:inline-flex;align-items:center;gap:6px;padding:8px 20px;
  border-radius:980px;font-family:inherit;
  font-size:13px;font-weight:500;cursor:pointer;border:none;
  transition:all .2s;letter-spacing:-.1px;
}
.br{background:var(--red);color:#fff;}.br:hover{opacity:.85;}
.bd{background:var(--ink);color:#fff;}.bd:hover{opacity:.85;}
.bg{background:var(--grn);color:#fff;}.bg:hover{opacity:.85;}
.ba{background:var(--accent);color:#fff;}.ba:hover{opacity:.85;}
.bo{background:rgba(0,0,0,0.06);border:none;color:var(--ink);}.bo:hover{background:rgba(0,0,0,0.10);}
.sm{padding:5px 14px;font-size:12px;}

/* ── PROGRESS ── */
.pw{background:var(--border);border-radius:20px;height:5px;overflow:hidden;min-width:60px;}
.pb{height:100%;border-radius:20px;transition:width .4s;}
.pb-r{background:var(--red);}.pb-o{background:var(--org);}.pb-y{background:var(--yel);}.pb-g{background:var(--grn);}

/* ── ALERTS ── */
.al{padding:12px 16px;border-radius:var(--r-sm);margin-bottom:14px;font-size:13px;font-weight:500;display:flex;align-items:flex-start;gap:10px;line-height:1.5;}
.al-r{background:var(--lred);border:1px solid #f5c0c0;color:#7a0000;}
.al-b{background:var(--lblu);border:1px solid #c0d4f5;color:#0d2f6b;}
.al-g{background:var(--lgrn);border:1px solid #b0e0c5;color:#063a1e;}

/* ── API BOX ── */
.api-box{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px;box-shadow:var(--card-shadow);}
.obt{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:14px;}

/* ── CHECKBOX ── */
.checkbox{
  width:18px;height:18px;accent-color:var(--accent);cursor:pointer;flex-shrink:0;
  border-radius:4px;
}

/* ── OKRUGA CELLS ── */
.okr-cell{text-align:center;padding:3px 6px;border-radius:3px;font-size:11px;font-weight:700;}


/* Task card borders */
.task-card.urgent { border-left: 3px solid var(--red); }
.task-card.success { border-left: 3px solid var(--grn); }
.task-card.warning { border-left: 3px solid var(--org); }
.task-head { background: var(--surface2); }

/* ── SIDEBAR LAYOUT ── */
.app-layout{display:flex;min-height:calc(100vh - 56px);}
.sidebar{
  width:240px;flex-shrink:0;background:rgba(250,250,252,0.90);
  border-right:1px solid var(--border);
  position:sticky;top:56px;height:calc(100vh - 56px);
  overflow-y:auto;display:flex;flex-direction:column;z-index:150;
  backdrop-filter:saturate(180%) blur(20px);
  -webkit-backdrop-filter:saturate(180%) blur(20px);
}
.nav-section{padding:8px 10px 4px;}
.nav-item{
  display:flex;align-items:center;gap:10px;padding:9px 12px;
  border-radius:var(--r-sm);cursor:pointer;transition:all .15s;
  font-size:13px;font-weight:500;color:var(--ink2);user-select:none;
}
.nav-item:hover{background:rgba(0,0,0,0.06);color:var(--ink);}
.nav-item.on{background:rgba(0,0,0,0.08);color:var(--ink);font-weight:600;}
.nav-icon{font-size:16px;width:24px;text-align:center;flex-shrink:0;}
.nav-label{flex:1;}
.nav-item-toggle{cursor:default;}
.nav-item-toggle:hover{background:rgba(0,0,0,0.06);color:var(--ink2);}
.nav-switch{
  position:relative;display:inline-flex;align-items:center;flex-shrink:0;
  width:40px;height:24px;cursor:pointer;
}
.nav-switch input{
  position:absolute;opacity:0;width:0;height:0;
}
.nav-switch-slider{
  position:relative;display:block;width:40px;height:24px;border-radius:999px;
  background:rgba(0,0,0,0.14);transition:background .18s ease;
}
.nav-switch-slider::before{
  content:'';position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;
  background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.18);transition:transform .18s ease;
}
.nav-switch input:checked + .nav-switch-slider{
  background:var(--accent);
}
.nav-switch input:checked + .nav-switch-slider::before{
  transform:translateX(16px);
}
.nav-switch input:focus-visible + .nav-switch-slider{
  box-shadow:0 0 0 3px rgba(0,113,227,.16);
}
.nav-badge{background:var(--lred);color:var(--red);border-radius:20px;padding:2px 7px;font-size:11px;font-weight:700;}
.nav-badge.grn{background:var(--lgrn);color:var(--dgrn);}
.nav-badge.org{background:var(--lorg);color:var(--org);}
.nav-divider{height:1px;background:var(--border);margin:4px 10px;}
.nav-arrow{font-size:10px;color:var(--muted);transition:transform .22s;flex-shrink:0;}
.nav-item.expanded .nav-arrow{transform:rotate(90deg);}
.nav-sub{overflow:hidden;max-height:0;transition:max-height .25s cubic-bezier(.25,.46,.45,.94);}
.nav-sub.open{max-height:300px;}
.nav-sub-item{
  display:flex;align-items:center;gap:8px;padding:8px 12px 8px 36px;
  border-radius:var(--r-sm);cursor:pointer;transition:all .15s;
  font-size:12.5px;font-weight:500;color:var(--ink2);user-select:none;
}
.nav-sub-item:hover{background:rgba(0,0,0,0.06);color:var(--ink);}
.nav-sub-item.on{background:rgba(0,0,0,0.08);color:var(--ink);font-weight:600;}
.sidebar-footer{margin-top:auto;padding:14px 20px;font-size:11px;color:var(--muted);border-top:1px solid var(--border);line-height:1.5;}
.debug-chip{
  position:fixed;bottom:8px;right:8px;background:rgba(16,16,16,.80);color:#39ff6d;
  font:11px ui-monospace,SFMono-Regular,'SF Mono',monospace;padding:8px 12px;border-radius:8px;
  z-index:9999;max-width:480px;line-height:1.6;box-shadow:0 10px 24px rgba(0,0,0,.18);
}

.content-area{flex:1;min-width:0;}
.section{display:none;}.section.on{display:block;animation:fi .2s ease;}
.sec-main{padding:24px 32px;max-width:1600px;margin:0 auto;}

/* ── MOBILE TOGGLE ── */
.mob-toggle{
  display:none;width:36px;height:36px;background:none;border:none;cursor:pointer;
  align-items:center;justify-content:center;border-radius:var(--r-sm);transition:background .15s;
  flex-shrink:0;
}
.mob-toggle:hover{background:var(--surface2);}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:140;}

@media(max-width:900px){
  .mob-toggle{display:flex;}
  .sidebar{
    position:fixed;top:0;left:0;bottom:0;height:100vh;
    transform:translateX(-100%);transition:transform .3s cubic-bezier(.25,.46,.45,.94);
    box-shadow:8px 0 40px rgba(0,0,0,.10);
  }
  .sidebar.open{transform:translateX(0);}
  .sidebar-overlay.open{display:block;}
  .app-layout{display:block;}
  .tabs{padding:0 16px !important;}
  .gf-bar{padding:0 0 12px !important;}
  main{padding:16px !important;}
  .sec-main{padding:16px !important;}
}

/* ── DASHBOARD ── */
.dash-page-header{margin-bottom:20px;}
.dash-page-title{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:22px;font-weight:600;letter-spacing:-.04em;color:var(--ink);display:flex;align-items:center;gap:10px;}
.dash-page-sub{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:5px;}

.sync-bar{
  display:flex;align-items:center;gap:10px;padding:10px 16px;
  background:var(--lblu);border:1px solid #c8d9f8;border-radius:var(--r-sm);
  margin-bottom:20px;font-size:12px;color:var(--blu);
}
.sync-bar.ok{background:var(--lgrn);border-color:#b0ddc5;color:var(--dgrn);}
.sync-bar.warn{background:var(--lyel);border-color:#f0d080;color:#7a5200;}
.sync-bar.err{background:var(--lred);border-color:#f0b0b0;color:#7a0000;}
.sync-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0;opacity:.7;}
.sync-text{flex:1;line-height:1.4;}
.sync-btn{
  background:var(--ink);color:#fff;border:none;padding:5px 14px;border-radius:980px;
  font-size:11px;font-weight:600;cursor:pointer;letter-spacing:.3px;white-space:nowrap;
  font-family:inherit;transition:background .15s;
}
.sync-btn:hover{background:#2c2f3a;}

.mc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(198px,1fr));gap:12px;margin-bottom:24px;}
.mc-card{
  background:var(--surface);border-radius:var(--r);border:1px solid var(--border);
  padding:16px;display:flex;flex-direction:column;
  box-shadow:0 1px 3px rgba(0,0,0,.04),0 4px 12px rgba(0,0,0,.03);
  transition:transform .15s,box-shadow .15s;cursor:pointer;
}
.mc-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.08);}
.mc-top{display:flex;align-items:flex-start;gap:10px;margin-bottom:14px;}
.mc-icon{
  width:42px;height:42px;border-radius:10px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:20px;
}
.mci-green{background:#e3f6ec;} .mci-blue{background:#e3eeff;} .mci-teal{background:#e0f4f2;}
.mci-red{background:#fff0f0;} .mci-orange{background:#fff3e0;} .mci-yellow{background:#fffbde;}
.mci-purple{background:#f2eaff;} .mci-gray{background:#f2f3f5;} .mci-indigo{background:#ede8ff;}
.mc-meta{flex:1;min-width:0;}
.mc-label{font-size:10.5px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;line-height:1.3;}
.mc-period{font-size:11px;color:var(--muted);margin-top:3px;}
.mc-badge{
  font-size:11px;font-weight:700;white-space:nowrap;padding:3px 8px;border-radius:20px;flex-shrink:0;
}
.mc-badge.up{background:var(--lgrn);color:var(--dgrn);}
.mc-badge.dn{background:var(--lred);color:var(--red);}
.mc-badge.nt{background:var(--surface2);color:var(--muted);border:1px solid var(--border);}
.mc-val{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:24px;font-weight:600;line-height:1.1;letter-spacing:-.04em;color:var(--ink);margin-bottom:4px;}
.mc-val.sm{font-size:20px;}
.mc-sub{font-size:12px;color:var(--muted);margin-bottom:12px;flex:1;}
.mc-bar{height:3px;background:var(--border);border-radius:20px;overflow:hidden;}
.mc-bar-fill{height:100%;border-radius:20px;transition:width .5s;}

/* ── DATE RANGE PICKER ── */
.drp-trigger{
  display:flex;align-items:center;gap:8px;padding:8px 12px;
  border:1.5px solid var(--border2);border-radius:var(--r-sm);
  background:var(--surface2);cursor:pointer;min-width:220px;
  font-family:inherit;font-size:13px;font-weight:500;
  transition:border-color .15s;user-select:none;
}
.drp-trigger:hover{border-color:var(--accent);background:#fff;}
.drp-popup{
  position:absolute;z-index:500;background:#fff;
  border:1px solid var(--border);border-radius:var(--r);
  box-shadow:0 8px 40px rgba(0,0,0,.14);
  padding:16px;min-width:600px;
}
.drp-months{display:flex;gap:24px;}
.drp-month{flex:1;min-width:240px;}
.drp-month-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.drp-month-title{font-size:14px;font-weight:700;color:var(--ink);}
.drp-nav{background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:var(--r-xs);color:var(--ink2);font-size:16px;transition:background .15s;}
.drp-nav:hover{background:var(--surface2);}
.drp-weekdays{display:grid;grid-template-columns:repeat(7,1fr);margin-bottom:4px;}
.drp-wd{text-align:center;font-size:11px;font-weight:600;color:var(--muted);padding:3px 0;}
.drp-days{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;}
.drp-day{
  text-align:center;padding:7px 4px;font-size:12px;font-weight:500;
  border-radius:50%;cursor:pointer;transition:background .1s, color .1s;
  color:var(--ink);user-select:none;position:relative;
}
.drp-day:empty{pointer-events:none;}
.drp-day.other-month{color:var(--muted);}
.drp-day:hover:not(.empty){background:var(--lblu);color:var(--accent);}
.drp-day.in-range{background:var(--lblu);border-radius:0;color:var(--accent);}
.drp-day.range-start,.drp-day.range-end{background:var(--accent)!important;color:#fff!important;border-radius:50%!important;}
.drp-day.range-start.has-end{border-radius:50% 0 0 50%!important;}
.drp-day.range-end.has-start{border-radius:0 50% 50% 0!important;}
.drp-day.today{font-weight:700;}
.drp-day.today:not(.range-start):not(.range-end)::after{content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);width:4px;height:4px;border-radius:50%;background:var(--accent);}
.drp-footer{display:flex;align-items:center;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--border);}
.drp-auto-label{display:flex;align-items:center;gap:6px;font-size:13px;cursor:pointer;color:var(--ink2);}
.drp-auto-label input{accent-color:var(--accent);width:16px;height:16px;}

/* ── TORGSTAT-STYLE GRID ── */
.tg-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px;}
@media(max-width:1200px){.tg-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){.tg-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.tg-grid{grid-template-columns:1fr;}}
.tg-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);
  padding:12px 14px;display:flex;flex-direction:column;gap:6px;
  box-shadow:0 1px 3px rgba(0,0,0,.04);position:relative;overflow:hidden;
}
.tg-card::after{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:var(--r-sm) 0 0 var(--r-sm);background:var(--border);}
.tg-card-profit::after{background:var(--grn);}
.tg-card-profit{background:#f6fff9;}
.tg-card-net::after{background:var(--accent);}
.tg-card-net{background:#f5f8ff;}
.tg-card-head{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.tg-card-label{font-size:11px;font-weight:700;color:var(--ink2);flex:1;line-height:1.3;}
.tg-chip{display:inline-flex;align-items:center;gap:2px;padding:2px 7px;border-radius:20px;font-size:11px;font-weight:700;white-space:nowrap;flex-shrink:0;}
.tg-chip-p{background:var(--lgrn);color:var(--dgrn);}
.tg-chip-dn{background:var(--lred);color:var(--red);}
.tg-chip-n{background:var(--surface2);color:var(--muted);}
.tg-main-val{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:20px;font-weight:600;letter-spacing:-.04em;color:var(--ink);line-height:1.2;}
.tg-sub{font-size:11px;color:var(--muted);margin-top:-2px;}
.tg-sub-row{font-size:11px;color:var(--muted);margin-top:2px;}
.tg-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border);padding-top:6px;margin-top:2px;}
.tg-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;font-size:11px;color:var(--ink2);gap:4px;}
.tg-row span:first-child{color:var(--muted);white-space:nowrap;}
.tg-row-r{display:flex;align-items:center;gap:4px;}
.tg-delta{font-size:10px;font-weight:700;padding:1px 5px;border-radius:10px;}
.tg-delta-p{background:var(--lgrn);color:var(--dgrn);}
.tg-delta-n{background:var(--lred);color:var(--red);}

/* ── DASHBOARD CHART ── */
.tg-chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:16px;margin-bottom:16px;box-shadow:0 1px 3px rgba(0,0,0,.04);}

/* ── STUB PAGE ── */
.stub-page{padding:64px 32px;text-align:center;background:var(--surface);border-radius:var(--r);border:1px solid var(--border);color:var(--muted);}
.stub-icon{font-size:52px;margin-bottom:14px;}
.stub-title{font-weight:700;font-size:17px;color:var(--ink2);margin-bottom:8px;}
.stub-desc{font-size:14px;line-height:1.6;max-width:420px;margin:0 auto 20px;}

/* ── ANALYTICS CARDS ── */
.an-filter{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px 20px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;box-shadow:var(--surface-shadow);}
.an-filter label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:5px;}
.an-filter select,.an-filter input[type=text]{padding:8px 12px;border:1.5px solid var(--border2);border-radius:var(--r-sm);font-family:inherit;font-size:13px;font-weight:500;background:var(--surface2);min-width:170px;transition:border-color .15s;}
.an-filter select:focus,.an-filter input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(26,110,245,.1);}
.an-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px;margin-bottom:20px;}
.an-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;gap:10px;transition:transform .15s,box-shadow .15s;}
.an-card:hover{transform:translateY(-2px);box-shadow:0 4px 20px rgba(0,0,0,.1);}
.an-card-title{font-size:12px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:6px;}
.an-card-title svg{width:16px;height:16px;fill:var(--muted);flex-shrink:0;}
.an-main-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.an-val{font-family:'SF Pro Display',-apple-system,BlinkMacSystemFont,sans-serif;font-size:22px;letter-spacing:-.5px;color:var(--ink);}
.an-chip{display:inline-flex;align-items:center;gap:3px;padding:3px 8px;border-radius:20px;font-size:11px;font-weight:700;}
.an-chip.up{background:var(--lgrn);color:var(--dgrn);}
.an-chip.dn{background:var(--lred);color:var(--red);}
.an-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--border);padding-top:10px;}
.an-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid var(--border);}
.an-row:last-child{border-bottom:none;}
.an-row-label{font-size:12px;color:var(--ink2);font-weight:500;}
.an-row-right{display:flex;align-items:center;gap:6px;}
.an-row-val{font-size:12px;font-weight:700;color:var(--ink);}
.an-row-delta{font-size:11px;font-weight:700;padding:1px 6px;border-radius:10px;}
.an-row-delta.pos{background:var(--lgrn);color:var(--dgrn);}
.an-row-delta.neg{background:var(--lred);color:var(--red);}
.an-row-delta.neu{background:var(--surface2);color:var(--muted);}
.an-toggle{display:flex;border:1.5px solid var(--border2);border-radius:var(--r-sm);overflow:hidden;}
.an-toggle button{padding:3px 10px;font-size:11px;font-weight:700;border:none;background:transparent;cursor:pointer;font-family:inherit;color:var(--muted);transition:all .15s;}
.an-toggle button.on{background:var(--accent);color:#fff;}
.an-sub-val{font-size:12px;font-weight:600;color:var(--muted);}

/* ── ORDERS PAGE ── */
.ord-tabs{display:flex;gap:0;border-bottom:2px solid var(--border);margin-bottom:16px;}
.ord-tab{padding:10px 18px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .18s;white-space:nowrap;}
.ord-tab:hover{color:var(--ink);}
.ord-tab.on{color:var(--accent);border-bottom-color:var(--accent);}
.ord-filter{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:12px 16px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;box-shadow:var(--surface-shadow);}
.ord-filter label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;}
.ord-filter select,.ord-filter input[type=text],.ord-filter input[type=date]{padding:7px 10px;border:1.5px solid var(--border2);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:var(--surface2);min-width:130px;}
.ord-filter select:focus,.ord-filter input:focus{outline:none;border-color:var(--accent);background:#fff;}
.order-lead-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:4px 0 2px;}
.order-lead-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;display:flex;flex-direction:column;gap:6px;}
.order-lead-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.order-lead-card strong{font-size:22px;font-weight:800;color:var(--ink);line-height:1.1;}
.order-lead-sub{font-size:12px;color:var(--muted);line-height:1.35;}
.charts-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px;}
@media(max-width:900px){.charts-row{grid-template-columns:1fr;}}
.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;box-shadow:var(--card-shadow);height:210px;}
.chart-card-title{font-size:12px;font-weight:700;color:var(--muted);margin-bottom:12px;display:flex;align-items:center;gap:6px;}
.ord-page{display:none;}.ord-page.on{display:block;}
.ord-tbar{display:flex;justify-content:space-between;align-items:center;padding:10px 0 8px;flex-wrap:wrap;gap:8px;}
.ord-tbar-left{display:flex;gap:8px;align-items:center;}
.ord-tbar-right{display:flex;gap:8px;}
.ord-table-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);background:var(--surface);box-shadow:var(--card-shadow);}
.ord-table{width:100%;border-collapse:collapse;font-size:12px;min-width:1200px;}
.ord-table thead th{background:var(--surface2);color:var(--ink2);padding:9px 10px;text-align:left;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;white-space:nowrap;border-bottom:1px solid var(--border);cursor:pointer;user-select:none;}
.ord-table thead th:hover{color:var(--accent);}
.ord-table tbody tr{border-bottom:1px solid var(--border);transition:background .1s;}
.ord-table tbody tr:hover{background:var(--surface2);}
.ord-table tbody tr:last-child{border-bottom:none;}
.ord-table td{padding:8px 10px;vertical-align:middle;white-space:nowrap;}
.ord-table tfoot td{padding:8px 10px;font-weight:700;font-size:12px;background:var(--surface2);border-top:2px solid var(--border);}
.ord-status{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;}
.ord-status.blue{background:var(--lblu);color:var(--blu);}
.ord-status.green{background:var(--lgrn);color:var(--dgrn);}
.ord-status.red{background:var(--lred);color:var(--red);}
.ord-search{padding:7px 10px;border:1.5px solid var(--border2);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:var(--surface2);min-width:200px;}
.ord-search:focus{outline:none;border-color:var(--accent);}
.ord-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 0;font-size:12px;color:var(--muted);}
.ord-page-btns{display:flex;gap:4px;}
.ord-page-btn{padding:4px 10px;border:1.5px solid var(--border);border-radius:var(--r-xs);background:var(--surface);font-family:inherit;font-size:12px;cursor:pointer;transition:all .15s;}
.ord-page-btn:hover,.ord-page-btn.on{background:var(--accent);color:#fff;border-color:var(--accent);}

/* ── PRINT ── */
@media print{header,.sidebar,.sidebar-overlay,.tabs,.ctrl-bar,.btn,.checkbox,.gf-bar{display:none!important;}.page,.section{display:block!important;}}

/* ═══════════════════════════════════════
   UNIT-ЭКОНОМИКА CALCULATOR
   ═══════════════════════════════════════ */
.ue-page-header{margin-bottom:18px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;font-family:Roboto,'Segoe UI',sans-serif;}
.ue-page-title{font-family:Roboto,'Segoe UI',sans-serif;font-size:22px;font-weight:700;letter-spacing:-.03em;color:var(--ink);display:flex;align-items:center;gap:10px;}
.ue-page-sub{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:4px;}
.ue-actions{display:flex;gap:8px;align-items:center;}

/* Global settings panel */
.ue-global{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--r);
  padding:16px 20px;margin-bottom:16px;box-shadow:var(--surface-shadow);font-family:Roboto,'Segoe UI',sans-serif;
}
.ue-global-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px;display:flex;align-items:center;gap:6px;}
.ue-global-row{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;}
.ue-field{display:flex;flex-direction:column;gap:4px;}
.ue-field label{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;}
.ue-input{
  padding:6px 10px;border:1px solid var(--border2);border-radius:var(--r-xs);
  font-family:inherit;font-size:13px;font-weight:500;background:var(--surface2);
  width:80px;transition:border-color .15s,box-shadow .15s;text-align:right;
}
.ue-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,113,227,.13);}
.ue-input.wide{width:110px;}

/* Table wrapper */
.ue-table-wrap{
  overflow:auto;max-height:calc(100vh - 250px);border-radius:var(--r);border:1px solid var(--border);
  background:var(--surface);box-shadow:var(--card-shadow);position:relative;
  --ue-head-row-1:48px;--ue-head-row-2:70px;--ue-sticky-left:236px;
}
.ue-table{width:100%;border-collapse:separate;border-spacing:0;font-size:12px;min-width:2600px;font-family:Roboto,'Segoe UI',sans-serif;}
.ue-table thead th{
  background:var(--surface2);color:var(--ink2);padding:9px 8px;
  text-align:center;font-size:10px;font-weight:700;letter-spacing:.35px;
  text-transform:uppercase;white-space:nowrap;border-bottom:1px solid #d6d6d6;
  position:sticky;top:0;z-index:2;box-sizing:border-box;background-clip:padding-box;
}
.ue-table thead tr:first-child th{top:0;z-index:5;height:var(--ue-head-row-1);padding-top:10px;padding-bottom:10px;}
.ue-table thead tr:nth-child(2) th{top:var(--ue-head-row-1);z-index:4;height:var(--ue-head-row-2);}
.ue-table thead th[rowspan="2"]{
  top:0;height:calc(var(--ue-head-row-1) + var(--ue-head-row-2));
  vertical-align:middle;z-index:6;
}
.ue-table thead th.th-left{text-align:left;padding-left:12px;}
.ue-table thead th.ue-sticky-left-col{
  min-width:var(--ue-sticky-left);width:var(--ue-sticky-left);max-width:var(--ue-sticky-left);
  position:sticky;left:0;background:#434343!important;color:#fff!important;z-index:7;
  border-right:3px solid #d4d4d4;
}
.ue-table thead tr:first-child th.ue-sticky-left-col{top:0;z-index:8;}
.ue-table thead tr:nth-child(2) th.ue-sticky-left-col{top:var(--ue-head-row-1);z-index:8;}
.ue-table thead th.th-grp-in,.ue-table thead th.th-grp-out{color:#fff;border-right:1px solid rgba(255,255,255,.18);}
.ue-hd-name{background:#434343!important;color:#fff!important;}
.ue-hd-cost{background:#660000!important;color:#fff!important;}
.ue-hd-market{background:#20124d!important;color:#fff!important;}
.ue-hd-api{background:#274e13!important;color:#fff!important;}
.ue-hd-soft{background:#dbffdb!important;color:#17320f!important;}
.ue-hd-roi{background:#97ff97!important;color:#16310d!important;font-weight:800!important;}
.ue-hd-total{background:#b7b7b7!important;color:#1f1f1f!important;font-weight:800!important;}
.ue-hd-deep{background:#195429!important;color:#fff!important;}
.ue-sep-r{border-right:2px solid #d4d4d4!important;}
.ue-table tbody tr{transition:background .1s;}
.ue-table tbody tr:hover{background:#eef5ff;}
.ue-table td{
  padding:7px 6px;vertical-align:middle;text-align:center;border-right:1px solid #ececec;
  border-bottom:1px solid var(--border);font-weight:500;background:var(--surface);
}
.ue-table td.td-name{
  text-align:left;padding-left:12px;min-width:var(--ue-sticky-left);width:var(--ue-sticky-left);max-width:var(--ue-sticky-left);
  position:sticky;left:0;z-index:2;background:var(--surface);border-right:3px solid #e6e6e6;
}
.ue-table tbody tr:hover td.td-name{background:#e2edff;}
.ue-table tbody tr:hover td{background:#eef5ff;}

/* Editable cell inputs */
.ue-cell-input{
  width:72px;padding:4px 6px;border:1px solid transparent;border-radius:6px;
  font-family:inherit;font-size:12px;font-weight:500;text-align:right;
  background:transparent;transition:border-color .15s,background .15s;color:var(--ink);
}
.ue-cell-input.wide{width:82px;}
.ue-cell-input.narrow{width:60px;}
.ue-cell-input:hover{border-color:var(--border2);background:var(--surface2);}
.ue-cell-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 2px rgba(0,113,227,.12);}
.ue-name-input{
  width:100%;min-width:140px;padding:4px 6px;border:1px solid transparent;border-radius:6px;
  font-family:inherit;font-size:12px;font-weight:600;text-align:left;
  background:transparent;transition:border-color .15s;color:var(--ink);
}
.ue-name-input:hover{border-color:var(--border2);background:var(--surface2);}
.ue-name-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 2px rgba(0,113,227,.12);}

/* Computed output cells */
.ue-out{font-weight:700;font-size:12px;font-variant-numeric:tabular-nums;}
.ue-out-pos{color:var(--dgrn);}
.ue-out-neg{color:var(--red);}

/* Pill cells for margin / ROI */
.ue-pill{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:700;min-width:52px;}
.ue-pill-pos{background:var(--lgrn);color:var(--dgrn);}
.ue-pill-neg{background:var(--lred);color:var(--red);}
.ue-pill-zero{background:var(--surface2);color:var(--muted);}
.ue-note{margin-top:10px;font-size:11px;color:var(--muted);line-height:1.65;}
.ue-note strong{color:var(--ink);}
.ue-hint{font-size:11px;color:var(--muted);}
.ue-type{display:flex;flex-direction:column;gap:2px;}
.ue-type-main{font-size:12px;font-weight:600;color:var(--ink);}
.ue-type-sub{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;}
.ue-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;font-size:10px;font-weight:700;letter-spacing:.3px;}
.ue-badge-api{background:#eef4ff;color:var(--accent);}
.ue-badge-empty{background:var(--surface2);color:var(--muted);}
.ue-toggle-btn{min-width:176px;}
.ue-collapsed .ue-global{display:none;}
.ue-collapsed .ue-in-col,
.ue-collapsed .ue-in-group{display:none;}
.ue-collapsed .ue-table{min-width:1550px;}

/* Delete row button */
.ue-del-btn{background:none;border:none;cursor:pointer;color:var(--muted);font-size:15px;padding:2px 4px;border-radius:4px;transition:color .15s,background .15s;line-height:1;}
.ue-del-btn:hover{color:var(--red);background:var(--lred);}

/* Section group header in table */
.ue-table thead .th-section-in{background:#eef4ff;}
.ue-table thead .th-section-out{background:#edfff2;}

/* Mobile responsiveness */
@media(max-width:900px){
  .ue-global-row{gap:8px;}
  .ue-input{width:70px;}
  .ue-table{min-width:1200px;}
  .ue-table-wrap{max-height:calc(100vh - 210px);--ue-head-row-1:44px;--ue-head-row-2:64px;--ue-sticky-left:220px;}
}

/* ===== СЕБЕСТОИМОСТЬ ===== */
.sebest-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap;}
.sebest-toolbar input{padding:7px 12px;border:1px solid var(--border2);border-radius:var(--r-sm);font-family:inherit;font-size:13px;background:var(--surface2);min-width:200px;}
.sebest-toolbar input:focus{outline:none;border-color:var(--accent);background:#fff;}
.sebest-upload-area{border:2px dashed var(--border2);border-radius:var(--r);padding:20px 24px;text-align:center;cursor:pointer;transition:border-color .15s;background:var(--surface2);}
.sebest-upload-area:hover{border-color:var(--accent);background:var(--lblu);}
.sebest-upload-area p{margin:6px 0 0;font-size:12px;color:var(--muted);}
.sebest-cost-input{width:90px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--r-xs);font-family:inherit;font-size:13px;text-align:right;background:var(--surface2);transition:border-color .15s;}
.sebest-cost-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,113,227,.12);}
.sebest-cost-input.filled{border-color:var(--grn);background:var(--lgrn);}
.sebest-promo-input{width:110px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--r-xs);font-family:inherit;font-size:13px;text-align:right;background:var(--surface2);transition:border-color .15s;}
.sebest-promo-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,113,227,.12);}
.sebest-promo-input.filled{border-color:#d7831f;background:#fff3df;}
.sebest-stock-input{width:82px;padding:4px 8px;border:1px solid var(--border);border-radius:var(--r-xs);font-family:inherit;font-size:13px;text-align:right;background:var(--surface2);transition:border-color .15s;}
.sebest-stock-input:focus{outline:none;border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(0,113,227,.12);}
.sebest-stock-input.filled{border-color:#4b7f1b;background:#eef7df;}
.sebest-stats{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;}
.sebest-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 16px;font-size:12px;color:var(--muted);min-width:150px;}
.sebest-stat strong{display:block;font-size:16px;font-weight:600;color:var(--ink);margin-top:2px;}
.settings-health-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;}
.settings-health-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);padding:12px 14px;min-height:74px;display:flex;flex-direction:column;justify-content:space-between;}
.settings-health-label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;}
.settings-health-card strong{font-size:17px;font-weight:700;color:var(--ink);line-height:1.2;}
.settings-warnings{margin-top:14px;padding:14px 16px;border:1px solid #f0c49b;background:#fff7ef;border-radius:var(--r-sm);}
.settings-warnings-title{font-size:12px;font-weight:800;color:#8a4e00;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;}
.settings-warnings-list{margin:0;padding-left:18px;color:#6f4c16;font-size:13px;line-height:1.6;}
.settings-warnings-list li+li{margin-top:4px;}
.own-stock-preview{display:grid;gap:8px;}
.own-stock-preview-item{display:flex;justify-content:space-between;gap:12px;padding:10px 12px;border:1px solid #f0d7b7;background:#fff;border-radius:10px;font-size:13px;}
.own-stock-preview-art{font-weight:700;color:var(--ink);}
.own-stock-preview-meta{color:#7b5a23;}

/* ===== ABC-анализ ===== */
.abc-wrap { padding: 20px 0; }
.abc-filter-row { display:flex; gap:10px; align-items:center; flex-wrap:wrap; margin-bottom:16px; }
.abc-filter-row select,.abc-filter-row input { height:34px; padding:0 10px; border:1px solid var(--border); border-radius:8px; background:var(--surface); color:var(--text); font-size:13px; outline:none; }
.abc-filter-row button { height:34px; padding:0 16px; border-radius:8px; border:none; background:var(--accent); color:#fff; font-size:13px; cursor:pointer; }
.abc-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--border); }
.abc-table { border-collapse:collapse; min-width:1400px; width:100%; font-size:12px; }
.abc-table th { background:var(--surface2,#f5f5f5); color:var(--text-muted,#888); font-weight:600; font-size:11px; text-transform:uppercase; letter-spacing:.3px; padding:9px 10px; text-align:center; border-bottom:1px solid var(--border); white-space:nowrap; position:sticky; top:0; z-index:1; cursor:pointer; user-select:none; }
.abc-table th:hover { color:var(--accent); }
.abc-table th .sort-icon { margin-left:3px; opacity:.4; }
.abc-table th.sorted .sort-icon { opacity:1; color:var(--accent); }
.abc-table td { padding:8px 10px; border-bottom:1px solid var(--border); text-align:center; white-space:nowrap; vertical-align:middle; }
.abc-table tr:last-child td { border-bottom:none; }
.abc-table tr:hover td { background:rgba(var(--accent-rgb,99,102,241),.05); }
.abc-table td.td-left { text-align:left; }
.abc-table td.td-rev { background:rgba(255,200,0,.1); font-weight:600; }
.abc-table td.td-profit { background:rgba(34,197,94,.1); font-weight:600; color:#16a34a; }
.abc-table td.td-profit.neg { color:#dc2626; background:rgba(220,38,38,.07); }
.abc-badge { display:inline-flex; align-items:center; justify-content:center; width:36px; height:22px; border-radius:6px; font-size:11px; font-weight:700; letter-spacing:.5px; }
.abc-badge.AA { background:#22c55e22; color:#16a34a; }
.abc-badge.AB { background:#86efac44; color:#15803d; }
.abc-badge.BA { background:#fbbf2422; color:#b45309; }
.abc-badge.BB { background:#fcd34d33; color:#92400e; }
.abc-badge.BC { background:#fed7aa33; color:#c2410c; }
.abc-badge.CA { background:#f87171; color:#fff; }
.abc-badge.CB { background:#fca5a5; color:#991b1b; }
.abc-badge.CC { background:#fecaca; color:#b91c1c; }
.abc-badge.AC { background:#a3e63522; color:#3f6212; }
.abc-num { color:var(--text-muted,#888); font-size:11px; }
.abc-art { color:var(--text); font-size:12px; }
.abc-sku { color:var(--text-muted,#888); font-size:11px; }
.abc-pct-bar { display:flex; align-items:center; gap:5px; justify-content:center; }
.abc-bar { height:4px; border-radius:2px; background:var(--accent); min-width:2px; max-width:60px; }
.abc-totals td { background:var(--surface2,#f5f5f5)!important; font-weight:700; border-top:2px solid var(--border); }

/* ===== Динамика ===== */
.dyn-filter-row { display:flex; gap:8px; align-items:center; flex-wrap:wrap; margin-bottom:14px; }
.dyn-filter-row select,.dyn-filter-row input { height:34px; padding:0 10px; border:1px solid var(--border); border-radius:8px; background:var(--surface); color:var(--text); font-size:13px; outline:none; min-width:120px; }
.dyn-filter-row input { min-width:160px; }
.dyn-filter-row label { font-size:12px; color:var(--text-muted); }
.dyn-wrap { padding:20px 0; }
.dyn-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--border); }
.dyn-table { border-collapse:collapse; font-size:12px; width:100%; min-width:1100px; }
.dyn-table th { background:var(--surface2,#f5f5f5); color:var(--text-muted,#888); font-weight:600; font-size:11px; padding:9px 8px; text-align:center; border-bottom:1px solid var(--border); white-space:nowrap; position:sticky; top:0; z-index:1; }
.dyn-table th.th-left { text-align:left; }
.dyn-table td { padding:7px 8px; border-bottom:1px solid var(--border); text-align:center; white-space:nowrap; vertical-align:middle; }
.dyn-table tr:last-child td { border-bottom:none; }
.dyn-table tr:hover td { background:rgba(var(--accent-rgb,99,102,241),.04); }
.dyn-table td.td-left { text-align:left; }
.dyn-table td.td-total { font-weight:700; background:rgba(var(--accent-rgb,99,102,241),.06); }
.dyn-table td.td-period { }
.dyn-table td.td-period.hi { background:rgba(34,197,94,.12); }
.dyn-table td.td-period.lo { background:rgba(239,68,68,.08); }
.dyn-table tfoot td { background:var(--surface2,#f5f5f5)!important; font-weight:700; border-top:2px solid var(--border); }
.dyn-spark { display:flex; gap:2px; align-items:flex-end; height:24px; padding:2px 0; }
.dyn-spark-bar { width:8px; border-radius:2px 2px 0 0; background:var(--accent); min-height:2px; opacity:.75; }
.dyn-img { width:32px; height:32px; border-radius:6px; object-fit:cover; background:#eee; }
.dyn-art { font-size:11px; color:var(--text-muted); }
.dyn-name { font-size:12px; max-width:160px; overflow:hidden; text-overflow:ellipsis; }
.dyn-metric-label { font-size:11px; color:var(--text-muted); white-space:nowrap; }
.dyn-zero { color:var(--border); }

/* ===== План-Факт ===== */
.pf-toolbar { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:14px; }
.pf-toolbar select { height:34px; padding:0 10px; border:1px solid var(--border); border-radius:8px; background:var(--surface); color:var(--text); font-size:13px; outline:none; }
.pf-toolbar button { height:34px; padding:0 14px; border-radius:8px; border:1px solid var(--border); background:var(--surface); color:var(--text); font-size:13px; cursor:pointer; display:flex; align-items:center; gap:5px; }
.pf-toolbar button.pf-import { background:var(--accent); color:#fff; border-color:var(--accent); font-weight:600; }
.pf-toolbar button:hover { opacity:.85; }
.pf-wrap { padding:20px 0; }
.pf-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--border); }
.pf-table { border-collapse:collapse; font-size:12px; width:100%; min-width:1400px; }
.pf-table th { background:var(--surface2,#f5f5f5); color:var(--text-muted,#888); font-weight:600; font-size:11px; padding:8px 7px; text-align:center; border-bottom:1px solid var(--border); white-space:nowrap; position:sticky; top:0; z-index:1; }
.pf-table th.th-period { background:var(--accent); color:#fff; border-bottom:none; }
.pf-table th.th-left { text-align:left; }
.pf-table td { padding:6px 7px; border-bottom:1px solid var(--border); text-align:center; white-space:nowrap; vertical-align:middle; font-size:12px; }
.pf-table tr:last-child td { border-bottom:none; }
.pf-table tr:hover td { background:rgba(var(--accent-rgb,99,102,241),.04); }
.pf-table td.td-left { text-align:left; }
.pf-table tfoot td { background:var(--surface2,#f5f5f5)!important; font-weight:700; border-top:2px solid var(--border); }
.pf-plan-cell { display:flex; align-items:center; justify-content:center; gap:4px; }
.pf-plan-val { min-width:50px; }
.pf-edit-btn { background:none; border:none; cursor:pointer; color:var(--text-muted); padding:0 2px; font-size:13px; opacity:.5; }
.pf-edit-btn:hover { opacity:1; color:var(--accent); }
.pf-plan-input { width:70px; height:24px; border:1px solid var(--accent); border-radius:4px; text-align:center; font-size:12px; padding:0 4px; background:var(--surface); color:var(--text); outline:none; }
.pf-fact { font-weight:500; }
.pf-pct { font-size:11px; font-weight:600; }
.pf-pct.ov { color:#16a34a; }
.pf-pct.un { color:#dc2626; }
.pf-pct.zero { color:var(--text-muted); }
.pf-forecast { background:rgba(var(--accent-rgb,99,102,241),.08)!important; font-weight:600; }
/* Import Modal */
.pf-modal-overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:1000; display:flex; align-items:center; justify-content:center; }
.pf-modal { background:var(--surface); border-radius:16px; padding:28px; width:460px; max-width:95vw; box-shadow:0 20px 60px rgba(0,0,0,.25); position:relative; }
.pf-modal h3 { margin:0 0 16px; font-size:18px; font-weight:700; }
.pf-modal-close { position:absolute; top:16px; right:16px; background:none; border:none; font-size:20px; cursor:pointer; color:var(--text-muted); }
.pf-modal-tabs { display:flex; gap:6px; margin-bottom:16px; }
.pf-modal-tab { padding:6px 14px; border-radius:8px; border:1px solid var(--border); background:var(--surface); color:var(--text); font-size:13px; cursor:pointer; }
.pf-modal-tab.on { background:var(--accent); color:#fff; border-color:var(--accent); }
.pf-modal-instructions { font-size:13px; line-height:1.6; color:var(--text-muted); margin-bottom:16px; }
.pf-modal-instructions a { color:var(--accent); text-decoration:underline; cursor:pointer; }
.pf-modal-instructions ul { margin:8px 0 0 16px; padding:0; }
.pf-modal-instructions li { margin-bottom:4px; }
.pf-dropzone { border:2px dashed var(--border); border-radius:12px; padding:36px 20px; text-align:center; font-size:14px; color:var(--text-muted); cursor:pointer; transition:border-color .2s; }
.pf-dropzone:hover { border-color:var(--accent); color:var(--text); }

/* ===== Финансовые отчёты ===== */
.fin-tabs { display:flex; gap:0; border-bottom:2px solid var(--border); margin-bottom:20px; }
.fin-tab { padding:10px 18px; font-size:13px; font-weight:600; border:none; background:none; cursor:pointer; color:var(--text-muted); border-bottom:2px solid transparent; margin-bottom:-2px; transition:color .2s; }
.fin-tab.on { color:var(--accent); border-bottom-color:var(--accent); }
.fin-tab:hover { color:var(--text); }
.fin-page { display:none; }
.fin-page.on { display:block; }
.fin-toolbar { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:16px; }
.fin-toolbar select,.fin-toolbar input { height:32px; padding:0 10px; border:1px solid var(--border); border-radius:8px; background:var(--surface); color:var(--text); font-size:13px; outline:none; }
.fin-toolbar button { height:32px; padding:0 12px; border-radius:8px; border:1px solid var(--border); background:var(--surface); color:var(--text); font-size:13px; cursor:pointer; }
.fin-toolbar button:hover { opacity:.8; }
.fin-table-wrap { overflow-x:auto; border-radius:12px; border:1px solid var(--border); }
.fin-table { border-collapse:collapse; font-size:12px; width:100%; min-width:900px; }
.fin-table th { background:var(--surface2,#f4f4f6); color:var(--text-muted); font-weight:600; font-size:11px; padding:8px 8px; text-align:center; border-bottom:1px solid var(--border); white-space:nowrap; position:sticky; top:0; z-index:1; }
.fin-table th.th-left { text-align:left; min-width:200px; }
.fin-table th.th-week { background:var(--accent); color:#fff; font-size:10px; }
.fin-table td { padding:6px 8px; border-bottom:1px solid var(--border); text-align:right; white-space:nowrap; font-size:12px; vertical-align:middle; }
.fin-table td.td-label { text-align:left; padding-left:10px; font-weight:500; }
.fin-table td.td-label.indent { padding-left:24px; color:var(--text-muted); font-weight:400; }
.fin-table td.td-total { font-weight:700; }
.fin-table tr.row-section td { background:var(--surface2,#f4f4f6); font-weight:700; font-size:11px; color:var(--text-muted); text-transform:uppercase; letter-spacing:.4px; }
.fin-table tr.row-result td { background:rgba(var(--accent-rgb,99,102,241),.07); font-weight:700; }
.fin-table tr.row-result.green td { background:rgba(34,197,94,.08); }
.fin-table tr.row-result.red td { color:#dc2626; }
.fin-table tr:hover td { background:rgba(var(--accent-rgb,99,102,241),.04); }
.fin-table tr.row-section:hover td { background:var(--surface2,#f4f4f6); }
.fin-dyn { font-size:10px; font-weight:600; }
.fin-dyn.pos { color:#16a34a; }
.fin-dyn.neg { color:#dc2626; }
.fin-dyn.neu { color:var(--text-muted); }
.fin-share { font-size:10px; color:var(--text-muted); }
.fin-val-wrap { display:flex; flex-direction:column; align-items:flex-end; gap:1px; }
.fin-placeholder { padding:40px; text-align:center; color:var(--text-muted); font-size:14px; }
.fin-extra-box{margin-top:18px;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--card-shadow);}
.fin-extra-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;}
.fin-extra-title{font-size:14px;font-weight:800;color:var(--ink);margin-bottom:4px;}
.fin-extra-sub{font-size:12px;color:var(--muted);line-height:1.45;max-width:760px;}
.fin-penalty-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:14px;}
.fin-penalty-card{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;}
.fin-penalty-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.fin-penalty-card strong{font-size:22px;font-weight:800;color:var(--ink);}
.fin-penalty-sub{font-size:12px;color:var(--muted);}
.fin-penalty-chart-wrap{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:14px;}
.fin-penalty-table-wrap{overflow:auto;border:1px solid var(--border);border-radius:10px;}
.fin-penalty-table{width:100%;border-collapse:collapse;font-size:12px;}
.fin-penalty-table th,.fin-penalty-table td{padding:8px 10px;border-bottom:1px solid var(--border);}
.fin-penalty-table th{background:var(--surface2);font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;text-align:left;}
.fin-penalty-table td:last-child,.fin-penalty-table th:last-child{text-align:right;}
