/* ════════════════════════════════════════════════════════════════════════
   Marketplace Panel — design system «terminal» (dense). Light + dark.
   ════════════════════════════════════════════════════════════════════════ */
:root{
  --bg:#F4F6FB;
  --surface:#FFFFFF; --surface-2:#F1F4FA; --surface-3:#E8ECF5;
  --border:#E4E9F2; --border-2:#CFD7E6;
  --text:#0E1726; --text-2:#5B6678; --text-3:#97A1B4;
  --primary:#5B5BF6; --primary-h:#4848E0; --primary-bg:#EEEEFE;
  --success:#10B981; --success-bg:#E7FBF3; --success-text:#067A57;
  --warning:#F59E0B; --warning-bg:#FFF6E5; --warning-text:#9A6206;
  --danger:#F43F5E; --danger-bg:#FFEBEF; --danger-text:#B81F3C;
  --pos:#0EA66E; --neg:#E23B53;
  --wb:#8B5CF6; --wb-bg:#F1ECFE; --wb-text:#5B2BC4;
  --ym:#F59E0B; --ym-bg:#FFF3DE; --ym-text:#9A6206;
  --ds:#2F8BEA; --ds-bg:#E5F1FD; --ds-text:#155C9E;
  --chart-grid:rgba(20,30,60,.07); --chart-tick:#8B95A8;
  --shadow-sm:0 1px 2px rgba(20,30,60,.05);
  --shadow:0 2px 8px -2px rgba(20,30,60,.10),0 1px 3px rgba(20,30,60,.06);
  --shadow-md:0 10px 24px -8px rgba(20,30,60,.16),0 3px 8px -4px rgba(20,30,60,.08);
  --shadow-lg:0 22px 48px -16px rgba(20,30,60,.26);
  --r:9px; --r-lg:14px; --r-xl:18px; --sidebar-w:230px;
  --font:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
html[data-theme="dark"]{
  --bg:#0A0E1A;
  --surface:#121829; --surface-2:#1A2236; --surface-3:#222C44;
  --border:#26304a; --border-2:#33405e;
  --text:#EAF0FB; --text-2:#9AA7BE; --text-3:#5F6E88;
  --primary:#7C7CFF; --primary-h:#9090FF; --primary-bg:#1E2142;
  --success:#2DD4A7; --success-bg:#0E2C28; --success-text:#4FE0BC;
  --warning:#FBBF44; --warning-bg:#2E2611; --warning-text:#FBBF44;
  --danger:#FB6F86; --danger-bg:#321722; --danger-text:#FB6F86;
  --pos:#3DDC97; --neg:#FF6B82;
  --wb:#A98BFF; --wb-bg:#231C46; --wb-text:#C9B6FF;
  --ym:#FBBF44; --ym-bg:#2E2611; --ym-text:#FFD680;
  --ds:#52A8FF; --ds-bg:#13283F; --ds-text:#8FCBFF;
  --chart-grid:rgba(180,200,255,.08); --chart-tick:#6B7790;
  --shadow-sm:0 1px 2px rgba(0,0,0,.4);
  --shadow:0 2px 10px -2px rgba(0,0,0,.5);
  --shadow-md:0 12px 28px -10px rgba(0,0,0,.6);
  --shadow-lg:0 24px 54px -18px rgba(0,0,0,.7);
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
html,body{height:100%;background:var(--bg);color:var(--text);font-family:var(--font);font-size:13px;line-height:1.45;-webkit-font-smoothing:antialiased;}
body{transition:background .25s,color .2s;}
button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit;}
:focus{outline:none;}
:focus-visible{outline:2px solid var(--primary);outline-offset:2px;border-radius:5px;}
a{color:var(--primary);text-decoration:none;}
::selection{background:rgba(91,91,246,.22);}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:6px;border:3px solid transparent;background-clip:padding-box;}
::-webkit-scrollbar-thumb:hover{background:var(--text-3);background-clip:padding-box;}

/* ── Login ── */
#login{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;background:var(--bg);}
#login.hidden{display:none;}
.login-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);padding:38px 34px;box-shadow:var(--shadow-lg);}
.login-brand{display:flex;align-items:center;gap:12px;margin-bottom:26px;}
.login-mark{width:42px;height:42px;border-radius:11px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.login-brand h1{font-size:16px;font-weight:700;letter-spacing:-.02em;}
.login-brand p{font-size:11px;color:var(--text-3);font-weight:500;}
.login-title{font-size:22px;font-weight:800;letter-spacing:-.025em;margin-bottom:5px;}
.login-sub{font-size:13px;color:var(--text-2);margin-bottom:24px;}
.field-label{font-size:12px;font-weight:600;color:var(--text-2);margin-bottom:5px;display:block;}
.field-inp{width:100%;background:var(--surface-2);border:1.5px solid var(--border);border-radius:9px;padding:11px 13px;font-size:14px;transition:border-color .15s,box-shadow .15s,background .15s;margin-bottom:13px;}
.field-inp:focus{border-color:var(--primary);background:var(--surface);box-shadow:0 0 0 4px rgba(91,91,246,.14);}
.field-inp.err{border-color:var(--danger);}
.login-err{font-size:12px;color:var(--danger);min-height:18px;margin-bottom:6px;font-weight:600;}
.btn-primary{width:100%;background:var(--primary);color:#fff;border:none;border-radius:9px;padding:12px;font-size:14px;font-weight:700;cursor:pointer;transition:filter .15s,transform .05s;}
.btn-primary:hover{filter:brightness(1.08);}
.btn-primary:active{transform:translateY(1px);}
.btn-primary:disabled{opacity:.55;cursor:default;}

/* ── App shell ── */
#app{display:none;min-height:100vh;}
#app.ready{display:flex;}
#sidebar{width:var(--sidebar-w);flex-shrink:0;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:60;transition:transform .22s;}
.sb-head{display:flex;align-items:center;gap:10px;padding:16px 16px 14px;border-bottom:1px solid var(--border);}
.sb-mark{width:32px;height:32px;border-radius:9px;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.sb-head h2{font-size:14px;font-weight:800;letter-spacing:-.02em;}
.sb-head p{font-size:10.5px;color:var(--text-3);font-weight:500;}
.sb-nav{flex:1;overflow-y:auto;padding:10px 9px;}
.sb-group-label{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:12px 8px 5px;}
.sb-group-label:first-child{padding-top:2px;}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:11px;cursor:pointer;color:var(--text-2);font-weight:500;font-size:13px;transition:background .12s,color .12s;margin-bottom:2px;position:relative;}
.sb-item:hover{background:var(--surface-2);color:var(--text);}
.sb-item.active{background:var(--primary-bg);color:var(--primary);font-weight:700;}
.sb-item svg{flex-shrink:0;opacity:.9;}
.sb-item .dot{width:6px;height:6px;border-radius:50%;margin-left:auto;flex-shrink:0;}
.sb-sec .dot svg{transition:transform .2s;}
.sb-sec.expanded .dot svg{transform:rotate(90deg);}
.sb-sub{margin:1px 0 3px 13px;border-left:1.5px solid var(--border);padding-left:5px;}
.sb-item.sb-mp{font-size:12.5px;padding:6px 9px;}
.sb-item.sb-mp .dot{margin-left:0;}
.sb-foot{border-top:1px solid var(--border);padding:10px 12px;}
.sb-user{display:flex;align-items:center;gap:10px;padding:6px 4px;}
.sb-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0;}
.sb-user-info{flex:1;min-width:0;}
.sb-user-info b{font-size:12.5px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-user-info span{font-size:10.5px;color:var(--text-3);}
.sb-logout{background:none;border:none;color:var(--text-3);cursor:pointer;padding:6px;border-radius:7px;display:flex;transition:background .12s,color .12s;}
.sb-logout:hover{background:var(--danger-bg);color:var(--danger);}

#main{flex:1;margin-left:var(--sidebar-w);min-width:0;display:flex;flex-direction:column;background:var(--bg);}
.topbar{position:sticky;top:0;z-index:40;background:var(--surface);border-bottom:1px solid var(--border);padding:11px 22px;display:flex;align-items:center;gap:14px;}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:6px;border-radius:7px;color:var(--text-2);}
.menu-btn:hover{background:var(--surface-2);}
.topbar h1{font-size:16px;font-weight:800;letter-spacing:-.025em;flex:1;}
.period-bar{display:flex;gap:2px;background:var(--surface-2);padding:3px;border-radius:9px;flex-wrap:wrap;}
.period-bar button{background:none;border:none;cursor:pointer;padding:5px 11px;border-radius:7px;font-size:12px;font-weight:600;color:var(--text-2);transition:all .13s;white-space:nowrap;}
.period-bar button:hover{color:var(--text);}
.period-bar button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm);}
.ov-refresh-btn{display:none;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:var(--surface);color:var(--text);font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .12s,border-color .12s,opacity .12s;}
.ov-refresh-btn:hover:not(:disabled){background:var(--surface-2);border-color:var(--border-2);}
.ov-refresh-btn:disabled{opacity:.55;cursor:wait;}
.ov-refresh-note{font-size:10.5px;color:var(--text-3);font-weight:500;white-space:nowrap;max-width:170px;overflow:hidden;text-overflow:ellipsis;}
.theme-toggle{background:var(--surface-2);border:1px solid var(--border);cursor:pointer;width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;color:var(--text-2);transition:all .16s;flex-shrink:0;}
.theme-toggle:hover{color:var(--primary);border-color:var(--border-2);background:var(--surface-3);}
.theme-toggle .ti-sun{display:none;}
html[data-theme="dark"] .theme-toggle .ti-moon{display:none;}
html[data-theme="dark"] .theme-toggle .ti-sun{display:block;}
.content{flex:1;padding:18px 22px 48px;max-width:1560px;width:100%;}
.overlay{display:none;position:fixed;inset:0;background:rgba(8,12,24,.5);z-index:55;}
.overlay.show{display:block;}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);margin-bottom:16px;overflow:hidden;}
.card-head{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--border);flex-wrap:wrap;}
.card-head h3{font-size:13.5px;font-weight:700;letter-spacing:-.01em;}
.card-head .grow{flex:1;}
.chip-ic{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.card-body{padding:14px 16px;}
.card-body.flush{padding:0;}

/* ── KPI row (dense) ── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(168px,1fr));gap:11px;}
.kpi{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:15px;box-shadow:var(--shadow-sm);position:relative;transition:transform .13s,box-shadow .13s,border-color .13s;}
.kpi.clickable{cursor:pointer;}
.kpi.clickable:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-2);}
.kpi.clickable:active{transform:translateY(0);}
.kpi-top{display:flex;flex-direction:column-reverse;align-items:flex-start;gap:10px;margin-bottom:7px;}
.kpi-label{font-size:11.5px;font-weight:600;color:var(--text-2);}
.kpi-icon{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.kpi-icon.blue{background:var(--ds-bg);color:var(--ds);}
.kpi-icon.purple{background:var(--wb-bg);color:var(--wb);}
.kpi-icon.amber{background:var(--ym-bg);color:var(--ym);}
.kpi-icon.green{background:var(--success-bg);color:var(--success);}
.kpi-icon.red{background:var(--danger-bg);color:var(--danger);}
.kpi-icon.gray{background:var(--surface-2);color:var(--text-2);}
.kpi:has(.kpi-icon.green){background:var(--success-bg);border-color:transparent;}
.kpi:has(.kpi-icon.green) .kpi-icon.green{background:var(--surface);}
.kpi:has(.kpi-icon.green) .kpi-label{color:var(--success-text);}
.kpi-value{font-size:22px;font-weight:800;letter-spacing:-.03em;line-height:1.1;font-variant-numeric:tabular-nums;}
.kpi-value.sm{font-size:18px;}
.kpi-sub{font-size:11.5px;color:var(--text-2);margin-top:5px;display:flex;align-items:center;gap:4px;font-weight:600;}
.kpi-sub.pos{color:var(--pos);}
.kpi-sub.neg{color:var(--neg);}
.kpi .chev{position:absolute;right:12px;bottom:11px;color:var(--text-3);opacity:0;transition:opacity .13s,transform .13s;}
.kpi.clickable:hover .chev{opacity:1;transform:translateX(2px);}
.pos{color:var(--pos);}.neg{color:var(--neg);}.muted{color:var(--text-3);}
.kpi.acc-wb{border-top:3px solid var(--wb);}
.kpi.acc-ym{border-top:3px solid var(--ym);}
.kpi.acc-ds{border-top:3px solid var(--ds);}
.kpi-detail{grid-column:1/-1;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-lg);padding:14px 16px;animation:slideDown .22s ease;}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:translateY(0);}}
.kpi-detail h5{font-size:12.5px;font-weight:700;margin-bottom:10px;display:flex;align-items:center;gap:7px;}
.kpi-detail .close{margin-left:auto;cursor:pointer;color:var(--text-3);background:none;border:none;padding:3px;border-radius:5px;display:flex;}
.kpi-detail .close:hover{background:var(--surface-3);color:var(--text);}
.kpi-detail .fees-note{margin:0 0 9px;font-size:11px;color:var(--text-3);line-height:1.4;}
.kpi-detail .detail-row.bold .nm,.kpi-detail .detail-row.bold .vl{font-weight:800;}
.detail-list{display:flex;flex-direction:column;gap:1px;}
.detail-row{display:flex;align-items:center;gap:9px;padding:6px 9px;border-radius:7px;font-size:12.5px;}
.detail-row:hover{background:var(--surface);}
.detail-row .nm{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.detail-row .vl{font-weight:700;font-variant-numeric:tabular-nums;white-space:nowrap;}
.detail-bar{height:5px;border-radius:3px;background:var(--surface-3);overflow:hidden;flex:0 0 100px;}
.detail-bar i{display:block;height:100%;border-radius:3px;background:var(--primary);}

/* ── Charts ── */
.chart-wrap{position:relative;width:100%;}
.chart-legend{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:10px;font-size:12px;color:var(--text-2);font-weight:600;}
.chart-legend span.lg{display:flex;align-items:center;gap:6px;cursor:pointer;user-select:none;transition:opacity .15s;}
.chart-legend span.lg.off{opacity:.4;}
.chart-legend i{width:10px;height:10px;border-radius:3px;display:inline-block;}

/* ── Buttons / inputs ── */
.btn{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:7px 13px;font-size:12.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .13s;color:var(--text);}
.btn:hover{background:var(--surface-2);border-color:var(--border-2);}
.btn:active{transform:translateY(1px);}
.btn:disabled{opacity:.55;cursor:default;}
.btn.sm{padding:5px 10px;font-size:12px;}
.btn.solid{background:var(--primary);color:#fff;border:none;}
.btn.solid:hover{filter:brightness(1.08);}
.btn.ghost{background:transparent;border-color:transparent;}
.btn.ghost:hover{background:var(--surface-2);}
.search{display:flex;align-items:center;gap:7px;background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:6px 11px;min-width:190px;transition:border-color .13s,box-shadow .13s;}
.search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px rgba(91,91,246,.12);}
.search svg{color:var(--text-3);flex-shrink:0;}
.search input{background:none;border:none;flex:1;font-size:13px;min-width:0;}
.search input::placeholder{color:var(--text-3);}
.seg{display:inline-flex;background:var(--surface-2);padding:3px;border-radius:8px;gap:2px;}
.seg button{background:none;border:none;cursor:pointer;padding:5px 11px;border-radius:6px;font-size:12px;font-weight:600;color:var(--text-2);display:flex;align-items:center;gap:5px;transition:all .13s;}
.seg button.active{background:var(--surface);color:var(--primary);box-shadow:var(--shadow-sm);}
.stats-actions{margin:-2px 0 14px;display:flex;gap:7px;flex-wrap:wrap;}
.cost-inp{background:var(--surface);border:1.5px solid var(--border);border-radius:7px;padding:5px 8px;font-size:12.5px;font-variant-numeric:tabular-nums;transition:border-color .13s,box-shadow .13s;text-align:right;}
.cost-inp:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(91,91,246,.12);}
.cost-inp.saved{border-color:var(--success);}

/* ── Tables (dense terminal) ── */
.tbl-wrap{overflow-x:auto;border-radius:var(--r);border:1px solid var(--border);}
table.data{width:100%;border-collapse:collapse;font-size:12.5px;}
table.data th{text-align:left;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);padding:9px 13px;background:var(--surface-2);white-space:nowrap;border-bottom:1px solid var(--border);}
table.data th.num{text-align:right;}
table.data th.sortable{cursor:pointer;user-select:none;}
table.data th.sortable:hover{color:var(--text-2);}
table.data th .arrow{color:var(--primary);margin-left:3px;}
table.data td{padding:8px 13px;border-bottom:1px solid var(--border);vertical-align:middle;}
table.data td.num{text-align:right;font-variant-numeric:tabular-nums;}
table.data tr:last-child td{border-bottom:none;}
table.data tbody tr{transition:background .1s;}
table.data tbody tr:hover{background:var(--surface-2);}
table.data tbody tr:nth-child(even){background:color-mix(in srgb,var(--surface-2) 45%,transparent);}
.t-name{font-weight:600;color:var(--text);}
.t-sub{font-size:11px;color:var(--text-3);font-weight:500;margin-top:1px;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;}
.badge.green{background:var(--success-bg);color:var(--success-text);}
.badge.amber{background:var(--warning-bg);color:var(--warning-text);}
.badge.red{background:var(--danger-bg);color:var(--danger-text);}
.badge.gray{background:var(--surface-2);color:var(--text-2);}
.badge.wb{background:var(--wb-bg);color:var(--wb-text);}
.badge.ym{background:var(--ym-bg);color:var(--ym-text);}
.badge.ds{background:var(--ds-bg);color:var(--ds-text);}
.mpill{display:inline-block;padding:2px 8px;border-radius:6px;font-size:11.5px;font-weight:700;font-variant-numeric:tabular-nums;}
.mpill.good{background:var(--success-bg);color:var(--success-text);}
.mpill.mid{background:var(--warning-bg);color:var(--warning-text);}
.mpill.bad{background:var(--danger-bg);color:var(--danger-text);}

/* ── Overview matrix table ── */
.ovm-wrap{overflow-x:auto;}
table.ovm{width:100%;border-collapse:collapse;font-size:13px;}
table.ovm th{text-align:right;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--text-3);padding:10px 14px;background:var(--surface-2);white-space:nowrap;border-bottom:1px solid var(--border);}
table.ovm th:first-child{text-align:left;}
table.ovm td{padding:11px 14px;border-bottom:1px solid var(--border);text-align:right;font-variant-numeric:tabular-nums;font-weight:600;white-space:nowrap;}
table.ovm td:first-child{text-align:left;}
table.ovm tbody tr{cursor:pointer;transition:background .1s;}
table.ovm tbody tr:hover{background:var(--surface-2);}
table.ovm tr.ovm-total td{border-top:2px solid var(--border-2);border-bottom:none;background:var(--surface-2);font-weight:800;cursor:default;font-size:13.5px;}
table.ovm tr.ovm-total:hover{background:var(--surface-2);}
.ovm-mp{display:inline-flex;align-items:center;gap:8px;font-weight:700;}
.ovm-mp .dot{width:8px;height:24px;border-radius:4px;}
.ovm-err{font-size:11px;color:var(--text-3);font-weight:500;}

/* ── Product groups (prices) ── */
.cat-controls{display:flex;align-items:center;gap:9px;flex-wrap:wrap;margin-bottom:14px;}
.prod-groups{display:flex;flex-direction:column;gap:12px;}
.prod-group{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface);}
.prod-group-head{display:flex;align-items:center;gap:10px;padding:11px 14px;cursor:pointer;background:var(--surface-2);transition:background .12s;}
.prod-group-head:hover{background:var(--surface-3);}
.prod-group-head .cat-mark{width:8px;height:24px;border-radius:4px;flex-shrink:0;}
.prod-group-head .chevr{transition:transform .2s;color:var(--text-3);display:flex;}
.prod-group.collapsed .chevr{transform:rotate(-90deg);}
.prod-group-title{font-weight:700;font-size:13px;}
.prod-group-meta{font-size:11.5px;color:var(--text-3);font-weight:500;}
.prod-group-stat{margin-left:auto;display:flex;gap:14px;align-items:center;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;}
.prod-group-body{padding:12px 14px;}
.prod-group.collapsed .prod-group-body{display:none;}
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:11px;}
.prod-group-titles{display:flex;flex-direction:column;min-width:0;}
.cat-badge-nocost{margin-left:8px;flex-shrink:0;font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--warning-bg);color:var(--warning-text);}
.prod-card{position:relative;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r);padding:12px 13px;transition:border-color .13s,box-shadow .13s;}
.prod-card:hover{border-color:var(--border-2);box-shadow:var(--shadow-sm);}
.prod-card.loss{border-left:3px solid var(--danger);}
.prod-hide{position:absolute;top:8px;right:8px;width:26px;height:26px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-3);border-radius:6px;cursor:pointer;opacity:0;transition:opacity .12s,background .12s,color .12s;}
.prod-card:hover .prod-hide{opacity:1;}
.prod-hide:hover{background:var(--surface-3);color:var(--danger);}
.prod-card-name{font-weight:700;font-size:13px;line-height:1.3;margin-bottom:2px;padding-right:26px;}
.prod-card-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:4px 0;font-size:12.5px;}
.prod-card-row .lbl{color:var(--text-2);}
.prod-card-row .val{font-weight:600;font-variant-numeric:tabular-nums;}
.prod-card-actions{margin-top:9px;display:flex;gap:7px;}

/* ── States ── */
.loader{display:flex;align-items:center;justify-content:center;gap:10px;padding:42px 18px;color:var(--text-3);font-size:13px;font-weight:500;}
.spinner{width:18px;height:18px;border:2.5px solid var(--border-2);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
.empty{text-align:center;padding:40px 18px;color:var(--text-3);}
.empty svg{margin-bottom:10px;opacity:.55;}
.empty p{font-size:13px;font-weight:500;}
.err-box{background:var(--danger-bg);border:1px solid var(--danger);color:var(--danger-text);border-radius:var(--r);padding:12px 14px;font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:9px;}
.err-box.warn{background:var(--warning-bg);border-color:var(--warning);color:var(--warning-text);}
.meter{height:7px;border-radius:4px;background:var(--surface-3);overflow:hidden;margin-top:7px;}
.meter i{display:block;height:100%;border-radius:4px;background:var(--primary);transition:width .4s;}

/* ── Toasts ── */
#toasts{position:fixed;top:16px;right:16px;z-index:2000;display:flex;flex-direction:column;gap:9px;max-width:340px;}
.toast{background:var(--surface);border:1px solid var(--border);border-radius:11px;padding:11px 14px;box-shadow:var(--shadow-lg);font-size:12.5px;font-weight:600;display:flex;align-items:center;gap:10px;animation:toastIn .25s ease;border-left:4px solid var(--text-3);}
.toast.success{border-left-color:var(--success);}
.toast.error{border-left-color:var(--danger);}
.toast.info{border-left-color:var(--primary);}
@keyframes toastIn{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}

/* ── Layout helpers ── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.grid-2>.card{margin-bottom:0;}
.sec-title{font-size:14px;font-weight:800;letter-spacing:-.02em;margin:2px 2px 12px;display:flex;align-items:center;gap:8px;}

@media(max-width:980px){.grid-2{grid-template-columns:1fr;}}
@media(max-width:900px){
  #sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg);}
  #sidebar.open{transform:translateX(0);}
  #main{margin-left:0;}
  .menu-btn{display:flex;}
  .content{padding:14px 13px 40px;}
  .topbar{padding:9px 13px;}
  .period-bar{order:3;width:100%;}
}
