/* Квадрат Труба — единый портал. Сметана + Маршрутка */
:root {
  --bg:#faf8f4; --bg-elev:#fff; --bg-soft:#f3efe7; --bg-tint:#ece6da;
  --text:#1a1814; --text-soft:#5a5448; --text-mute:#8a8478;
  --line:rgba(60,52,40,.13); --line-soft:rgba(60,52,40,.075);
  --accent:#5a6f7a; --accent-soft:#d6dde2; --accent-deep:#2f3d44;
  --ok:#6b8e7f; --warn:#c98850; --red:#b8654a; --info:#6b85a3;
  --sh-sm:0 1px 2px rgba(50,40,20,.04); --sh-md:0 4px 16px rgba(50,40,20,.06);
  --r:10px; --r-lg:16px; --r-xl:22px;
  --glass-bg:rgba(255,255,255,.36);
  --glass-bg-strong:rgba(255,255,255,.50);
  --glass-line:rgba(255,255,255,.24);
  --glass-line-dark:rgba(90,111,122,.11);
  --glass-shadow:0 18px 54px rgba(50,40,20,.09);
  --glass-highlight:rgba(255,255,255,.42);
  --ctl-h:28px;
  --ctl-r:10px;
  --ctl-bg:color-mix(in oklab,var(--glass-bg-strong) 62%,transparent);
  --ctl-line:color-mix(in oklab,var(--glass-line) 72%,transparent);
  --ctl-shadow:inset 0 1px 0 var(--glass-highlight);
}
[data-theme="dark"]{
  --bg:#0e1012; --bg-elev:#15181b; --bg-soft:#1b1e22; --bg-tint:#23272c;
  --text:#eef0f2; --text-soft:#a8acb2; --text-mute:#6c7077;
  --line:rgba(255,255,255,.09); --line-soft:rgba(255,255,255,.045);
  --accent:#8aa2ad; --accent-soft:#22303a; --accent-deep:#b8cdd6;
  --glass-bg:rgba(20,23,27,.40);
  --glass-bg-strong:rgba(28,32,37,.52);
  --glass-line:rgba(255,255,255,.085);
  --glass-line-dark:rgba(0,0,0,.28);
  --glass-shadow:0 22px 64px rgba(0,0,0,.30);
  --glass-highlight:rgba(255,255,255,.10);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Manrope',ui-sans-serif,system-ui,sans-serif;background:
  radial-gradient(circle at 16% 4%, color-mix(in oklab,var(--accent) 15%,transparent) 0, transparent 34vw),
  radial-gradient(circle at 86% 12%, color-mix(in oklab,var(--warn) 8%,transparent) 0, transparent 32vw),
  radial-gradient(circle at 48% 96%, color-mix(in oklab,var(--info) 10%,transparent) 0, transparent 36vw),
  linear-gradient(135deg,var(--bg),color-mix(in oklab,var(--bg) 88%,var(--bg-tint)));color:var(--text);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased;background-attachment:fixed;background-size:120% 120%,115% 115%,125% 125%,100% 100%}
@keyframes auroraBg{from{background-position:0% 0%,100% 0%,50% 100%,0 0}to{background-position:8% 5%,92% 9%,45% 92%,0 0}}
button{font-family:inherit;cursor:pointer;background:transparent;border:0;color:inherit}
input,select,textarea{font-family:inherit;color:var(--text);background:var(--bg)}
input.inp,
select.inp,
textarea.inp,
.input{
  min-height:var(--ctl-h);
  height:var(--ctl-h);
  border:1px solid var(--ctl-line);
  border-radius:var(--ctl-r);
  padding:0 12px;
  background:var(--ctl-bg);
  box-shadow:var(--ctl-shadow);
  backdrop-filter:blur(14px) saturate(1.08);
  -webkit-backdrop-filter:blur(14px) saturate(1.08);
  font-size:13px;
}
.input{outline:none}
textarea.inp,
textarea.input{height:auto;min-height:var(--ctl-h);padding-top:9px;padding-bottom:9px}
input.inp:focus,
select.inp:focus,
textarea.inp:focus,
.input:focus{
  outline:none;
  border-color:color-mix(in oklab,var(--accent) 55%,var(--glass-line));
}

.app{display:grid;grid-template-columns:228px 1fr;min-height:100vh;transition:grid-template-columns .25s ease}
.app.sb-collapsed{grid-template-columns:60px 1fr}
.app.sb-collapsed .sb{padding:18px 8px}
.app.sb-collapsed .sb-brand{justify-content:center;padding:4px 0 14px}
.app.sb-collapsed .sb-brand .name,
.app.sb-collapsed .sb-brand .sub,
.app.sb-collapsed .sb-item span:not(.badge),
.app.sb-collapsed .sb-item .badge,
.app.sb-collapsed .sb-user .who,
.app.sb-collapsed .sb-user .role{display:none}
.app.sb-collapsed .sb-item{justify-content:center;padding:9px 0}
.app.sb-collapsed .sb-user{justify-content:center;padding:12px 0 4px}
.sb-toggle{position:absolute;top:18px;right:10px;width:30px;height:30px;border-radius:var(--ctl-r);background:transparent;color:var(--text-mute);border:0;display:flex;align-items:center;justify-content:center;z-index:5;transition:background .15s,color .15s}
.sb-toggle:hover{background:var(--bg-tint);color:var(--text)}
/* В свёрнутом виде кнопка переезжает в топбар */
.app.sb-collapsed .sb-toggle{position:fixed;top:14px;left:72px;right:auto}

/* sidebar */
.sb{background:
  linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg)),
  color-mix(in oklab,var(--bg-soft) 58%,transparent);border-right:1px solid var(--glass-line);padding:18px 14px;display:flex;flex-direction:column;gap:2px;position:sticky;top:0;height:100vh;overflow-y:auto;overflow-x:visible;transition:padding .25s;box-shadow:var(--glass-shadow);backdrop-filter:blur(26px) saturate(1.25);-webkit-backdrop-filter:blur(26px) saturate(1.25)}
.sb::before{content:"";position:absolute;inset:0 0 auto 0;height:180px;background:linear-gradient(180deg,var(--glass-highlight),transparent);opacity:.55;pointer-events:none}
.sb::after{content:"";position:absolute;top:0;right:0;width:1px;height:100%;background:linear-gradient(180deg,var(--glass-highlight),transparent 55%,var(--glass-line-dark));pointer-events:none}
.sb-brand{display:flex;align-items:center;gap:10px;padding:8px 4px;border:0;background:transparent;margin-bottom:12px;cursor:pointer;border-radius:0;transition:opacity .15s;width:100%;position:relative;box-shadow:none}
.sb-brand:hover{background:transparent;border-color:transparent;box-shadow:none;opacity:.78}
.sb-brand .mark{height:30px;display:flex;align-items:center}
.sb-brand .mark img{height:100%;width:auto;object-fit:contain;display:block}
.app.sb-collapsed .sb-brand .mark{height:32px;justify-content:center;width:100%}
.app.sb-collapsed .sb-brand .mark img{height:32px;width:32px;object-fit:contain}
.sb-brand .name{font-weight:800;font-size:13px;letter-spacing:.05em;line-height:1.05}
.sb-brand .sub{font-size:10.5px;color:var(--text-mute);letter-spacing:.06em;text-transform:uppercase;margin-top:3px}
.sb-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;color:var(--text-soft);cursor:pointer;font-size:13.5px;font-weight:500;width:100%;text-align:left;transition:background .12s,color .12s,box-shadow .12s,transform .12s;position:relative}
.sb-item:hover{background:color-mix(in oklab,var(--glass-bg-strong) 76%,transparent);color:var(--text);box-shadow:inset 0 1px 0 var(--glass-highlight)}
.sb-item.active{background:linear-gradient(180deg,color-mix(in oklab,var(--text) 92%,var(--accent)),var(--text));color:var(--bg);box-shadow:0 10px 24px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.18)}
.sb-ico{width:16px;height:16px;opacity:.7;flex-shrink:0}
.sb-item.active .sb-ico{opacity:1}
.sb-item .badge{margin-left:auto;font-size:11px;background:var(--bg-tint);color:var(--text-soft);padding:1px 7px;border-radius:999px;font-weight:600;font-variant-numeric:tabular-nums}
.sb-item.active .badge{background:rgba(255,255,255,.15);color:var(--bg)}
.sb-user{margin-top:auto;display:flex;align-items:center;gap:10px;padding:12px 8px 4px}
.sb-user .av{width:30px;height:30px;border-radius:50%;background:linear-gradient(145deg,var(--accent),var(--accent-deep));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 8px 18px rgba(0,0,0,.18);overflow:hidden;flex-shrink:0}
.sb-user .av img{width:100%;height:100%;object-fit:cover;display:block}
.sb-user .who{font-size:12.5px;font-weight:600}
.sb-user .role{font-size:11px;color:var(--text-mute)}

/* topbar */
.main{display:flex;flex-direction:column;min-width:0}
.tb{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;border-bottom:1px solid color-mix(in oklab,var(--glass-line) 62%,transparent);background:linear-gradient(180deg,var(--glass-bg-strong),var(--glass-bg));position:sticky;top:0;z-index:10;backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2);box-shadow:0 10px 30px rgba(0,0,0,.045)}
.tb h1{margin:0;font-size:20px;font-weight:700;letter-spacing:-.01em}
.tb .crumb{font-size:12px;color:var(--text-mute);margin-bottom:2px}
.tb-act{display:flex;align-items:center;gap:10px}
.search{display:flex;align-items:center;gap:8px;background:var(--ctl-bg);border:1px solid var(--ctl-line);border-radius:var(--ctl-r);padding:0 12px;width:260px;height:var(--ctl-h);min-height:var(--ctl-h);font-size:13px;box-shadow:var(--ctl-shadow);backdrop-filter:blur(16px) saturate(1.15);-webkit-backdrop-filter:blur(16px) saturate(1.15)}
.search input{border:0;background:transparent;outline:none;flex:1}
.search .kbd{font-size:11px;color:var(--text-mute);padding:1px 6px;background:var(--bg-tint);border-radius:4px}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:var(--ctl-h);min-height:var(--ctl-h);padding:0 14px;border:1px solid var(--ctl-line);border-radius:var(--ctl-r);background:var(--ctl-bg);color:var(--text);font-size:13px;font-weight:500;line-height:1;transition:all .12s;box-shadow:var(--ctl-shadow);white-space:nowrap}
.btn:hover{background:color-mix(in oklab,var(--glass-bg-strong) 82%,var(--bg-soft));transform:translateY(-1px)}
.btn-pri{background:var(--text);color:var(--bg);border-color:var(--text)}
.btn-acc{background:color-mix(in oklab,var(--accent) 26%,var(--ctl-bg));color:var(--text);border-color:color-mix(in oklab,var(--accent) 42%,var(--ctl-line))}
.btn-acc:hover{background:color-mix(in oklab,var(--accent) 34%,var(--ctl-bg))}
.btn-gh{background:transparent;border-color:transparent}
.btn-gh:hover{background:var(--bg-soft)}
.btn-sm{height:var(--ctl-h);min-height:var(--ctl-h);padding:0 12px;font-size:12px}
.icon-btn{width:var(--ctl-h);height:var(--ctl-h);display:flex;align-items:center;justify-content:center;border-radius:var(--ctl-r);border:1px solid var(--ctl-line);background:var(--ctl-bg);color:var(--text-soft);box-shadow:var(--ctl-shadow)}
.icon-btn:hover{background:var(--bg-soft);color:var(--text)}

.body{padding:22px 28px 60px}

/* cards */
.card{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r-lg);overflow:hidden;border:1px solid color-mix(in oklab,var(--text) 8%,transparent);box-shadow:0 8px 28px rgba(0,0,0,.08),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(18px) saturate(1.12);-webkit-backdrop-filter:blur(18px) saturate(1.12)}
.card-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid color-mix(in oklab,var(--glass-line) 42%,transparent)}
.card-hd h3{margin:0;font-size:14px;font-weight:600}
.card-hd .meta{font-size:12px;color:var(--text-mute)}
.card-bd{padding:14px 18px}

/* tags */
.tag{display:inline-flex;padding:2px 9px;border-radius:999px;font-size:11px;font-weight:600;background:var(--bg-tint);color:var(--text-soft);white-space:nowrap}
.tag-ok{background:color-mix(in oklab,var(--ok) 22%,var(--bg-elev));color:var(--ok)}
.tag-warn{background:color-mix(in oklab,var(--warn) 22%,var(--bg-elev));color:var(--warn)}
.tag-red{background:color-mix(in oklab,var(--red) 22%,var(--bg-elev));color:var(--red)}
.tag-info{background:color-mix(in oklab,var(--info) 22%,var(--bg-elev));color:var(--info)}
.tag-acc{background:var(--accent-soft);color:var(--accent-deep)}

/* dashboard alerts row */
.alerts{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin-bottom:18px}
.alert{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r);padding:14px 14px 12px;cursor:pointer;display:flex;flex-direction:column;gap:6px;transition:all .12s;position:relative;overflow:hidden;border:1px solid color-mix(in oklab,var(--text) 7%,transparent);box-shadow:0 4px 14px rgba(0,0,0,.06),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(16px) saturate(1.16);-webkit-backdrop-filter:blur(16px) saturate(1.16)}
.alert:hover{box-shadow:0 6px 20px rgba(0,0,0,.09),inset 0 1px 0 var(--glass-highlight);transform:translateY(-1px)}
.alert .lab{font-size:12px;color:var(--text-soft);line-height:1.3}
.alert .v{font-size:24px;font-weight:700;letter-spacing:-.01em;line-height:1;font-variant-numeric:tabular-nums}
.alert.zero{opacity:.45}
.alert .pip{position:absolute;left:0;top:0;bottom:0;width:3px}
.alert.warn .pip{background:var(--warn)}
.alert.red .pip{background:var(--red)}
.alert.info .pip{background:var(--info)}
.alert.ok .pip{background:var(--ok)}

/* dashboard 2-col */
.g-12{display:grid;grid-template-columns:1.5fr 1fr;gap:14px}
.g-12 > *{min-width:0}
.dash-kpis{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:14px;margin-bottom:14px}
.dash-chart{margin-top:0}
.dash-chart-legend{display:flex;flex-wrap:wrap;gap:8px 14px;margin-bottom:12px}
.dash-chart-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-soft);white-space:nowrap}
.dash-chart-legend-item i{width:9px;height:9px;border-radius:50%;display:inline-block;box-shadow:0 0 0 2px color-mix(in oklab,currentColor 12%,transparent)}
.dash-chart-scroll{width:100%;overflow:hidden}
.dash-chart-svg{display:block;width:100%;height:auto;min-height:260px}
.dash-chart-grid{stroke:var(--line-soft);stroke-width:1}
.dash-chart-day{stroke:color-mix(in oklab,var(--line-soft) 55%,transparent);stroke-width:1}
.dash-chart-axis{fill:var(--text-mute);font-size:11px;font-family:'Manrope',ui-sans-serif,system-ui,sans-serif}

/* tasks */
.task{display:flex;gap:10px;align-items:center;padding:10px 18px;border-top:1px solid var(--line-soft);font-size:13px}
.task:first-child{border-top:0}
.task .cb{width:14px;height:14px;border:1.5px solid var(--text-mute);border-radius:4px;flex-shrink:0}
.task .due{font-size:11px;color:var(--text-mute);margin-left:auto;white-space:nowrap}
.task .pp{width:6px;height:6px;border-radius:50%}
.pp.high{background:var(--red)} .pp.med{background:var(--warn)} .pp.low{background:var(--ok)}

/* feed */
.feed-row{display:flex;gap:10px;padding:10px 18px;border-top:1px solid var(--line-soft);font-size:13px;align-items:flex-start}
.feed-row:first-child{border-top:0}
.feed-row .who{font-weight:600;flex-shrink:0}
.feed-row .what{color:var(--text-soft)}
.feed-row .tgt{color:var(--accent-deep);font-weight:500}
.feed-row .when{font-size:11px;color:var(--text-mute);margin-left:auto;white-space:nowrap}

/* kanban */
.kb{display:grid;grid-template-columns:repeat(var(--kb-cols,6), minmax(180px,1fr));gap:10px;overflow-x:auto;padding-bottom:10px}
.kb-col{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r);min-height:120px;min-width:0;display:flex;flex-direction:column;border:1px solid color-mix(in oklab,var(--text) 7%,transparent);box-shadow:0 4px 16px rgba(0,0,0,.05),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(16px) saturate(1.12);-webkit-backdrop-filter:blur(16px) saturate(1.12)}
.kb-hd{display:flex;align-items:center;gap:6px;padding:10px 12px;font-size:12px;font-weight:600;color:var(--text-soft)}
.kb-hd .cnt{font-size:11px;background:var(--bg-tint);color:var(--text-soft);padding:1px 7px;border-radius:999px;font-weight:600}
.kb-list{display:flex;flex-direction:column;gap:8px;padding:0 8px 10px}
.kb-card{background:color-mix(in oklab,var(--glass-bg-strong) 70%,transparent);border-radius:var(--r);padding:10px;min-width:0;cursor:pointer;transition:all .12s;border:1px solid color-mix(in oklab,var(--text) 6%,transparent);box-shadow:0 2px 8px rgba(0,0,0,.05),inset 0 1px 0 color-mix(in oklab,var(--glass-highlight) 70%,transparent)}
.kb-card:hover{box-shadow:0 4px 14px rgba(0,0,0,.1),inset 0 1px 0 var(--glass-highlight);transform:translateY(-1px)}
.kb-card .id{font-family:'JetBrains Mono',monospace;font-size:10.5px;color:var(--text-mute);font-weight:600}
.kb-card .nm{font-weight:600;font-size:13px;margin-top:2px;line-height:1.25}
.kb-card .cl{font-size:11.5px;color:var(--text-mute);margin-top:3px}
.kb-card .ft{display:flex;justify-content:space-between;align-items:center;margin-top:8px;padding-top:8px;border-top:1px solid color-mix(in oklab,var(--line-soft) 52%,transparent);font-size:11px;color:var(--text-soft)}
.kb-card .sum{font-weight:700;font-variant-numeric:tabular-nums}

/* compact kanban preview on dashboard */
.kb-mini{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;font-size:11px}
.kb-mini-col{background:var(--bg-soft);border-radius:var(--r);padding:8px;text-align:center}
.kb-mini-col .v{font-size:18px;font-weight:700;line-height:1}
.kb-mini-col .l{color:var(--text-mute);font-size:10px;margin-top:4px;line-height:1.2}

/* table */
.tbl{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}
.tbl th{text-align:left;font-weight:600;font-size:11px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.06em;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--bg-soft)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line-soft)}
.tbl tr:hover td{background:var(--bg-soft);cursor:pointer}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
.tbl .nm{font-weight:600}

/* product card grid */
.prods{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.pc{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r-lg);overflow:hidden;cursor:pointer;transition:all .15s;box-shadow:0 6px 20px rgba(0,0,0,.06),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(14px) saturate(1.08);-webkit-backdrop-filter:blur(14px) saturate(1.08)}
.pc:hover{transform:translateY(-2px);box-shadow:var(--sh-md)}
.pc-cov{aspect-ratio:4/3;position:relative;overflow:hidden}
.pc-cov .glow{position:absolute;inset:0;background:radial-gradient(ellipse 70% 60% at 50% 70%,var(--g,transparent),transparent 70%);opacity:.85}
.pc-cov .hdr{position:absolute;top:10px;left:12px;right:10px;display:flex;align-items:flex-start;justify-content:space-between;gap:8px;z-index:2}
.pc-cov .id{font:600 11px/1 'JetBrains Mono',monospace;color:rgba(255,255,255,.75);letter-spacing:.06em;background:rgba(0,0,0,.35);padding:4px 7px;border-radius:4px;backdrop-filter:blur(4px)}
.pc-bd{padding:12px}
.pc-bd .nm{font-weight:700;font-size:13.5px}
.pc-bd .meta{font-size:11.5px;color:var(--text-mute);margin-top:2px}
.pc-bd .row{display:flex;justify-content:space-between;align-items:end;margin-top:10px;padding-top:10px;border-top:1px solid var(--line-soft)}
.pc-bd .price{font-weight:700;font-size:14px}

/* product detail / tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--line);margin-bottom:18px}
.tab{padding:10px 16px;font-size:13.5px;font-weight:500;color:var(--text-mute);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;display:flex;align-items:center;gap:8px}
.tab:hover{color:var(--text)}
.tab.act{color:var(--text);border-bottom-color:var(--accent);font-weight:600}
.tab .dot{width:6px;height:6px;border-radius:50%;background:var(--warn)}

/* product hero */
.ph{display:flex;gap:18px;align-items:flex-start;padding:18px;background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r-lg);margin-bottom:18px;box-shadow:0 6px 20px rgba(0,0,0,.05),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(16px) saturate(1.08);-webkit-backdrop-filter:blur(16px) saturate(1.08)}
.ph-cov{width:96px;height:96px;border-radius:12px;overflow:hidden;position:relative;flex-shrink:0}
.ph-cov .glow{position:absolute;inset:0;background:radial-gradient(ellipse 80% 70% at 50% 70%,var(--g,transparent),transparent 70%)}
.ph .info{flex:1;min-width:0}
.ph .info h2{margin:6px 0 4px;font-size:22px;letter-spacing:-.01em}
.ph .info .meta{font-size:12.5px;color:var(--text-soft);display:flex;gap:14px;flex-wrap:wrap}
.ph .info .meta b{color:var(--text);font-weight:600}
.ph .progress{display:flex;gap:6px;margin-top:10px}
.ph-act{display:flex;flex-direction:column;gap:6px;align-items:flex-end}

/* progress chips */
.pchip{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;background:var(--bg-soft);border:1px solid var(--line);font-size:11.5px;color:var(--text-mute);font-weight:500}
.pchip.done{background:color-mix(in oklab,var(--ok) 20%,var(--bg-elev));color:var(--ok);border-color:transparent}
.pchip.cur{background:var(--accent-soft);color:var(--accent-deep);border-color:transparent;font-weight:700}

/* split editor */
.split{display:grid;grid-template-columns:1fr 340px;gap:18px;align-items:start}
.dd-layout{display:grid;grid-template-columns:300px 1fr;gap:18px;align-items:start}
.split-r{position:sticky;top:72px;display:flex;flex-direction:column;gap:14px}

/* form */
.fld{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.fld label{font-size:11.5px;font-weight:600;color:var(--text-mute);text-transform:uppercase;letter-spacing:.05em}
.fld input,.fld select,.fld textarea{height:var(--ctl-h);min-height:var(--ctl-h);padding:0 12px;border:1px solid var(--ctl-line);border-radius:var(--ctl-r);background:var(--ctl-bg);color:var(--text);font-size:13px;outline:none;width:100%;box-shadow:var(--ctl-shadow)}
.fld textarea{height:auto;min-height:var(--ctl-h);padding-top:9px;padding-bottom:9px}
.fld input:focus,.fld select:focus{border-color:var(--accent)}
.fld-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fld-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}

/* explain box (AI) */
.ai{display:flex;gap:10px;padding:12px;background:linear-gradient(135deg,var(--accent-soft),transparent);border:1px solid var(--accent-soft);border-radius:var(--r);font-size:12.5px;color:var(--text-soft);align-items:flex-start;margin-bottom:14px}
.ai .badge{font-size:10px;font-weight:700;background:var(--accent);color:#fff;padding:2px 7px;border-radius:999px;letter-spacing:.05em;flex-shrink:0;margin-top:1px}
.ai b{color:var(--text)}

/* cost panel */
.cp{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r-lg);overflow:hidden;box-shadow:0 6px 20px rgba(0,0,0,.05),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(16px) saturate(1.08);-webkit-backdrop-filter:blur(16px) saturate(1.08)}
.cp-s{padding:14px 18px;border-bottom:1px solid color-mix(in oklab,var(--line-soft) 52%,transparent)}
.cp-s:last-child{border-bottom:0}
.cp-h{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);margin-bottom:10px}
.cp-l{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:13px}
.cp-l .l{color:var(--text-soft)} .cp-l .v{font-weight:600;font-variant-numeric:tabular-nums}
.cp-l.tot{padding-top:10px;margin-top:6px;border-top:1px solid var(--line-soft);font-weight:700}
.cp-grand{font-size:22px;font-weight:800;letter-spacing:-.01em;color:var(--accent-deep);font-variant-numeric:tabular-nums}

/* tc constructor */
.stage{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-radius:var(--r-lg);overflow:hidden;margin-bottom:12px;box-shadow:0 4px 14px rgba(0,0,0,.045),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(16px) saturate(1.08);-webkit-backdrop-filter:blur(16px) saturate(1.08)}
.stg-hd{display:flex;align-items:center;gap:14px;padding:12px 16px;border-bottom:1px solid color-mix(in oklab,var(--line-soft) 52%,transparent);background:color-mix(in oklab,var(--glass-bg-strong) 45%,transparent);flex-wrap:wrap}
.stg-meta{display:flex;gap:14px;font-size:11.5px;color:var(--text-mute);white-space:nowrap}
.stg-num{width:24px;height:24px;border-radius:var(--ctl-r);background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}
.stg-name{flex:1;font-weight:600;font-size:14px;min-width:120px}
.stg-meta{display:flex;gap:14px;font-size:11.5px;color:var(--text-mute)}
.stg-meta b{color:var(--text);font-weight:600;font-variant-numeric:tabular-nums}
.op-row{display:grid;grid-template-columns:minmax(0,1fr) 148px;gap:8px;padding:10px 16px;border-top:1px solid var(--line-soft);font-size:13px;align-items:start;overflow:visible}
.op-row:first-child{border-top:0}
.op-row .op-main{min-width:0}
.op-row .nm{font-weight:500}
.op-row .nt{font-size:11px;color:var(--text-mute);margin-top:4px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.op-row .nt .chip{background:var(--bg-soft);padding:2px 8px;border-radius:4px;white-space:nowrap;line-height:1.4}
.op-row .nt .chip-num{font-variant-numeric:tabular-nums;color:var(--text-soft)}
.add-stg{padding:13px;border:1.5px dashed var(--line);border-radius:var(--r-lg);width:100%;color:var(--text-mute);font-size:13px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px}
.add-stg:hover{border-color:var(--accent);color:var(--accent);background:color-mix(in oklab,var(--accent) 5%,transparent)}

/* pill */
.pill{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:28px;min-height:28px;padding:0 12px;background:var(--ctl-bg);border:1px solid var(--ctl-line);border-radius:var(--ctl-r);font-size:12px;color:var(--text-soft);cursor:pointer;box-shadow:var(--ctl-shadow);line-height:1}
.pill:hover{border-color:var(--accent);color:var(--accent-deep)}

.searchable-select-trigger,
.deal-edit-input,
.deal-edit-display{
  min-height:var(--ctl-h);
  height:var(--ctl-h);
  border:1px solid var(--ctl-line);
  border-radius:var(--ctl-r);
  background:var(--ctl-bg);
  box-shadow:var(--ctl-shadow);
  color:var(--text);
  font-size:13px;
  width:100%;
  outline:none;
}
.deal-passport-form{display:flex;flex-direction:column;gap:10px}
.deal-edit-input{padding:0 12px;font-weight:600}
.deal-edit-display{display:flex;align-items:center;padding:0 12px;font-weight:600;cursor:text;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.deal-date-input,.deal-date-display{width:118px;flex:0 0 118px;color:var(--text-mute);font-weight:500}
.deal-manager-select{appearance:auto;cursor:pointer}
.searchable-select-trigger:focus,
.deal-edit-input:focus{border-color:color-mix(in oklab,var(--accent) 55%,var(--glass-line))}
.profile-form{display:flex;flex-direction:column;gap:10px;min-width:320px}
.profile-avatar-row{display:flex;align-items:center;gap:14px;margin-bottom:6px}
.profile-avatar{width:58px;height:58px;border-radius:18px;background:var(--ctl-bg);border:1px solid var(--ctl-line);box-shadow:var(--ctl-shadow);display:flex;align-items:center;justify-content:center;overflow:hidden;cursor:pointer;color:var(--text);font-weight:800}
.profile-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.profile-avatar span{font-size:18px}

/* mode switch */
.mode-sw{display:inline-flex;align-items:center;height:var(--ctl-h);min-height:var(--ctl-h);background:var(--ctl-bg);border:1px solid var(--ctl-line);border-radius:var(--ctl-r);padding:3px;gap:0;box-shadow:var(--ctl-shadow)}
.mode-sw button{height:calc(var(--ctl-h) - 8px);padding:0 14px;font-size:12.5px;font-weight:500;color:var(--text-mute);border-radius:calc(var(--ctl-r) - 3px);line-height:1;display:inline-flex;align-items:center;justify-content:center;white-space:nowrap}
.mode-sw button.act{background:color-mix(in oklab,var(--glass-bg-strong) 72%,var(--bg-soft));color:var(--text);box-shadow:var(--sh-sm)}

/* warn list inside cards */
.warn-list .w-row{display:flex;gap:10px;align-items:center;padding:9px 18px;border-top:1px solid var(--line-soft);font-size:12.5px}
.warn-list .w-row:first-child{border-top:0}
.warn-list .pip{width:6px;height:6px;border-radius:50%}
.pip-warn{background:var(--warn)} .pip-red{background:var(--red)} .pip-info{background:var(--info)}
.warn-list .lk{margin-left:auto;color:var(--accent-deep);font-weight:600;font-size:12px}

/* AI chat for techcards */
.chat{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border:1px solid var(--glass-line);border-radius:var(--r-lg);height:520px;display:flex;flex-direction:column;box-shadow:inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(18px) saturate(1.18);-webkit-backdrop-filter:blur(18px) saturate(1.18)}
.chat-msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:12px}
.msg{max-width:78%;padding:10px 14px;border-radius:14px;font-size:13.5px;line-height:1.45}
.msg.ai{background:var(--bg-soft);align-self:flex-start;border-bottom-left-radius:4px}
.msg.me{background:var(--accent);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.msg .badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-deep);margin-bottom:4px;display:block}
.msg.me .badge{color:rgba(255,255,255,.85)}
.chat-actions{display:flex;flex-wrap:wrap;gap:6px;padding:12px 18px;border-top:1px solid var(--line)}
.chat-input{display:flex;gap:8px;padding:12px 18px;border-top:1px solid var(--line)}
.chat-input input{flex:1;padding:10px 14px;border:1px solid color-mix(in oklab,var(--glass-line) 60%,transparent);border-radius:var(--ctl-r);background:color-mix(in oklab,var(--glass-bg-strong) 56%,transparent);outline:none;font-size:13.5px;box-shadow:inset 0 1px 0 var(--glass-highlight)}

/* density */
[data-density="compact"] .body{padding:14px 22px 40px}
[data-density="compact"] .alert{padding:10px 12px 9px}
[data-density="compact"] .alert .v{font-size:20px}
[data-density="compact"] .task,[data-density="compact"] .feed-row{padding:7px 18px}
[data-density="compact"] .tbl td{padding:8px 14px}
[data-density="compact"] .op-row{padding:7px 16px}

/* dual-list (settings, refs) */
.refs{display:grid;grid-template-columns:240px 1fr;gap:14px;align-items:start}
.refs-side{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border:1px solid color-mix(in oklab,var(--glass-line) 52%,transparent);border-radius:var(--r-lg);padding:8px;position:sticky;top:72px;align-self:start;min-height:calc(100vh - 132px);box-shadow:inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(18px) saturate(1.12);-webkit-backdrop-filter:blur(18px) saturate(1.12)}
.refs-side .grp{font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text-mute);padding:10px 10px 4px}
.refs-side button{display:block;width:100%;text-align:left;padding:7px 10px;font-size:13px;color:var(--text-soft);border-radius:var(--ctl-r)}
.refs-side button:hover{background:color-mix(in oklab,var(--glass-bg-strong) 74%,transparent);color:var(--text)}
.refs-side button.act{background:var(--text);color:var(--bg);font-weight:600;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}

/* modals + toasts */
.mdl-bg{position:fixed;inset:0;background:rgba(0,0,0,.38);backdrop-filter:blur(10px) saturate(1.12);-webkit-backdrop-filter:blur(10px) saturate(1.12);z-index:200;display:flex;align-items:center;justify-content:center;padding:40px;animation:f .15s ease both}
.mdl{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border:1px solid color-mix(in oklab,var(--glass-line) 60%,transparent);border-radius:var(--r-lg);width:100%;max-width:520px;max-height:88vh;overflow:auto;box-shadow:0 24px 70px rgba(0,0,0,.34),inset 0 1px 0 var(--glass-highlight);animation:mdlIn .18s ease both;backdrop-filter:blur(22px) saturate(1.16);-webkit-backdrop-filter:blur(22px) saturate(1.16)}
.mdl.wide{max-width:780px}
@keyframes mdlIn{from{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:none}}
.mdl-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 18px;border-bottom:1px solid color-mix(in oklab,var(--glass-line) 46%,transparent)}
.mdl-hd h3{margin:0;font-size:15px;letter-spacing:-.01em}
.mdl-x{background:none;border:0;color:var(--text-mute);font-size:22px;line-height:1;cursor:pointer;padding:4px 8px;border-radius:var(--ctl-r)}
.mdl-x:hover{background:var(--bg-tint);color:var(--text)}
.mdl-bd{padding:18px}
.mdl-ft{display:flex;gap:8px;justify-content:flex-end;padding:14px 18px;border-top:1px solid color-mix(in oklab,var(--glass-line) 46%,transparent);background:color-mix(in oklab,var(--glass-bg-strong) 42%,transparent)}
.mdl-drop{border:2px dashed var(--glass-line);border-radius:var(--r-lg);padding:30px;text-align:center;color:var(--text-soft);background:color-mix(in oklab,var(--glass-bg) 76%,transparent)}
.np-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}.np-drop{border:2px dashed var(--glass-line);border-radius:var(--r-lg);padding:24px;text-align:center;color:var(--text-soft);background:color-mix(in oklab,var(--glass-bg) 76%,transparent);cursor:pointer;display:flex;flex-direction:column;gap:6px;align-items:center;justify-content:center;min-height:200px}
.np-drop:hover{border-color:var(--accent)}
.np-thumb{width:100%;display:flex;flex-direction:column;gap:8px}
.np-thumb img{width:100%;max-height:200px;object-fit:cover;border-radius:var(--r)}
.np-thumb-ft{display:flex;align-items:center;gap:8px;justify-content:space-between;font-size:12px;color:var(--text-mute)}
.np-thumb-ft .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:60%}
.dots{display:inline-flex;gap:3px;margin-left:4px}
.dots i{width:4px;height:4px;border-radius:50%;background:var(--accent);display:inline-block;animation:dotsB 1s infinite ease-in-out}
.dots i:nth-child(2){animation-delay:.15s}
.dots i:nth-child(3){animation-delay:.3s}
@keyframes dotsB{0%,80%,100%{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-2px)}}
@media (max-width: 720px){ .np-grid{grid-template-columns:1fr} }

/* OpPicker */
.op-pick{position:relative;display:inline-block}
.op-pick-pop{position:absolute;top:calc(100% + 6px);right:0;width:420px;max-width:90vw;background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border:1px solid color-mix(in oklab,var(--glass-line) 58%,transparent);border-radius:var(--r-lg);box-shadow:0 16px 40px rgba(0,0,0,.26);z-index:50;overflow:hidden;animation:mdlIn .14s ease both;backdrop-filter:blur(18px) saturate(1.12);-webkit-backdrop-filter:blur(18px) saturate(1.12)}
.op-pick-search{display:flex;gap:8px;padding:10px;border-bottom:1px solid var(--line-soft)}
.op-pick-search input{flex:1;padding:8px 10px;border:1px solid color-mix(in oklab,var(--glass-line) 60%,transparent);border-radius:var(--ctl-r);background:color-mix(in oklab,var(--glass-bg-strong) 54%,transparent);color:var(--text);font-size:13px;outline:none}
.op-pick-search input:focus{border-color:var(--accent)}
.op-pick-tabs{display:flex;gap:0;padding:6px 8px 0;flex-wrap:wrap;border-bottom:1px solid var(--line-soft)}
.op-pick-tabs .tab{padding:6px 10px;font-size:12px;border-radius:var(--ctl-r) var(--ctl-r) 0 0;background:none;border:0;color:var(--text-soft);cursor:pointer}
.op-pick-tabs .tab.on{color:var(--text);background:var(--bg-tint)}
.op-pick-list{max-height:320px;overflow-y:auto}
.op-pick-empty{padding:18px;text-align:center;color:var(--text-mute);font-size:12.5px}
.op-pick-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;padding:9px 12px;background:none;border:0;border-bottom:1px solid var(--line-soft);text-align:left;color:var(--text);font-size:13px;cursor:pointer}
.op-pick-row:hover{background:var(--bg-tint)}
.op-pick-row .nm{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.op-pick-row .meta{display:flex;gap:4px;flex-shrink:0}

/* Команда — карточки */
.team-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}
.team-card{padding:14px;border-radius:var(--r-lg);background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));display:flex;flex-direction:column;gap:10px;box-shadow:0 4px 14px rgba(0,0,0,.06),inset 0 1px 0 var(--glass-highlight);backdrop-filter:blur(14px) saturate(1.08);-webkit-backdrop-filter:blur(14px) saturate(1.08)}
.team-card-hd{display:flex;align-items:center;gap:10px}
.team-av{width:36px;height:36px;border-radius:50%;background:var(--bg-tint);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-soft);font-size:13px;flex-shrink:0}
.team-card-hd .nm{font-weight:600;font-size:13.5px;line-height:1.2}
.team-card-hd .em{font-size:11.5px;color:var(--text-mute);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.team-perms{display:flex;flex-wrap:wrap;gap:4px}
.team-perm{font-size:11px;padding:3px 7px;border-radius:99px;background:var(--bg-tint);color:var(--text-soft)}
.team-card-ft{display:flex;gap:6px;justify-content:flex-end;padding-top:6px;border-top:1px solid var(--line-soft)}

/* Полный список доступов в модалке */
.perm-list{display:flex;flex-direction:column;gap:4px;margin-top:8px}
.perm-row{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border-radius:var(--r)}
.perm-row:hover{background:var(--bg-tint)}
.perm-row label{font-size:13px;cursor:pointer;flex:1}
.perm-row .desc{font-size:11.5px;color:var(--text-mute)}

/* Drill-down ref card */
.ref-row{cursor:pointer}
.ref-row:hover{background:var(--bg-tint)}
.dd-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 22px;margin-top:6px}
.dd-grid .k{font-size:11.5px;color:var(--text-mute);text-transform:uppercase;letter-spacing:.04em;margin-bottom:2px}
.dd-grid .v{font-size:14px;color:var(--text);font-weight:500}
.dd-grid .v.num{font-variant-numeric:tabular-nums}
.dd-sect{margin-top:18px;padding-top:14px;border-top:1px solid var(--line-soft)}
.dd-sect h4{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-mute);font-weight:600}
@media (max-width: 600px){ .dd-grid{grid-template-columns:1fr} }
.toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:8px;z-index:12000;pointer-events:none}
.toast{background:var(--bg-elev);border:1px solid var(--line);border-left:3px solid var(--accent);border-radius:var(--r);padding:10px 14px;font-size:13px;box-shadow:0 8px 24px rgba(0,0,0,.25);animation:tIn .2s ease both;max-width:340px}
.toast.ok{border-left-color:var(--ok)}
.toast.warn{border-left-color:var(--warn)}
@keyframes tIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

/* clickable KPI alerts */
.alert{cursor:pointer;transition:all .15s}
.alert:hover{transform:translateY(-1px);border-color:var(--accent)}

/* misc */
.empty{text-align:center;padding:50px 20px;color:var(--text-mute)}
.empty h4{color:var(--text);margin:0 0 6px}
.fade{animation:f .2s ease both}
@keyframes f{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
@keyframes spin{to{transform:rotate(360deg)}}
.bar{height:6px;background:var(--bg-tint);border-radius:3px;overflow:hidden}
.bar > span{display:block;height:100%;background:var(--accent);border-radius:3px}

/* Performance layer: прозрачность оставляем, но тяжёлый blur включаем только
   на постоянных навигационных слоях. Карточек на странице может быть сотни. */
.card,
.alert,
.kb-col,
.kb-card,
.pc,
.ph,
.cp,
.stage,
.chat,
.refs-side,
.team-card,
.op-pick-pop,
.mdl,
.search,
input.inp,
select.inp,
textarea.inp,
.input,
.chat-input input{
  backdrop-filter:none;
  -webkit-backdrop-filter:none;
}

/* ==================================================================== */
/*  MINIMAL LOOK — без рамок и фонов, разделители вместо боксов          */
/* ==================================================================== */
[data-look="minimal"] {
  --line:rgba(255,255,255,.075);       /* тоньше и тише в тёмной */
  --line-soft:rgba(255,255,255,.035);
  --bg-soft:rgba(255,255,255,.035);
  --bg-elev:rgba(255,255,255,.045);
  --bg-tint:#1a1d20;
  --r:10px; --r-lg:16px;
}
[data-look="minimal"][data-theme="light"]{
  --line:rgba(60,52,40,.11);
  --line-soft:rgba(60,52,40,.055);
  --bg-soft:rgba(255,255,255,.28);
  --bg-elev:rgba(255,255,255,.34);
}

/* убрать карточные обводки и фоны — оставить только верхний разделитель */
[data-look="minimal"] .card,
[data-look="minimal"] .stage,
[data-look="minimal"] .pc,
[data-look="minimal"] .ph,
[data-look="minimal"] .cp,
[data-look="minimal"] .chat,
[data-look="minimal"] .refs-side {
  background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));
  border:1px solid color-mix(in oklab,var(--glass-line) 48%,transparent);
  border-radius:var(--r-lg);
  box-shadow:inset 0 1px 0 var(--glass-highlight);
}
[data-look="minimal"] .card-hd,
[data-look="minimal"] .stg-hd,
[data-look="minimal"] .cp-s {
  background:transparent;
  border-bottom:1px solid var(--line-soft);
  padding-left:0;
  padding-right:0;
}
[data-look="minimal"] .card-bd,
[data-look="minimal"] .cp-s {
  padding-left:0;
  padding-right:0;
}
/* секции отделяются пустотой и тонкой линией сверху, а не рамкой */
[data-look="minimal"] .card,
[data-look="minimal"] .stage {
  margin-bottom:18px;
  padding-bottom:2px;
  border-bottom:1px solid color-mix(in oklab,var(--glass-line) 48%,transparent);
}
[data-look="minimal"] .card:last-of-type,
[data-look="minimal"] .stage:last-of-type {
  border-bottom:0;
}

/* product card в списке — только обложка + текст без бокса */
[data-look="minimal"] .pc{cursor:pointer;transition:opacity .15s;border-bottom:0}
[data-look="minimal"] .pc:hover{transform:none;box-shadow:none;opacity:.85}
[data-look="minimal"] .pc-cov{border-radius:6px;aspect-ratio:1/1}
[data-look="minimal"] .pc-bd{padding:10px 0 0}
[data-look="minimal"] .pc-bd .row{border-top:0;padding-top:6px;margin-top:6px}

/* таблицы — без зебры и фона у заголовков */
[data-look="minimal"] .tbl th{background:transparent;text-transform:none;letter-spacing:0;font-size:12px;color:var(--text-mute);padding:8px 0}
[data-look="minimal"] .tbl td{padding:9px 0}
[data-look="minimal"] .tbl tr:hover td{background:transparent;color:var(--accent-deep)}

/* строки внутри карточек (задачи/фид/операции) — без отступов слева */
[data-look="minimal"] .task,
[data-look="minimal"] .feed-row,
[data-look="minimal"] .warn-list .w-row,
[data-look="minimal"] .op-row {
  padding-left:0;
  padding-right:0;
}

/* well/info-блоки — без рамки и фона */
[data-look="minimal"] .ai{background:transparent;border:0;padding:10px 0;border-top:1px solid var(--line-soft);border-radius:0}
[data-look="minimal"] .ai .badge{background:transparent;color:var(--accent-deep);padding:0;border:0;font-weight:700;letter-spacing:.06em}

/* инпуты форм — единый компактный glass-стиль во всех разделах */
[data-look="minimal"] .fld input,
[data-look="minimal"] .fld select,
[data-look="minimal"] .fld textarea {
  background:var(--ctl-bg);
  border:1px solid var(--ctl-line);
  border-radius:var(--ctl-r);
  padding-left:12px;
  padding-right:12px;
  box-shadow:var(--ctl-shadow);
}
[data-look="minimal"] .fld input:focus,
[data-look="minimal"] .fld select:focus{border-color:var(--accent)}

/* кнопки — фон убираем, оставляем границу-линию или чистый текст */
[data-look="minimal"] .btn{background:transparent;border:1px solid var(--line)}
[data-look="minimal"] .btn:hover{background:var(--bg-tint)}
[data-look="minimal"] .icon-btn{background:transparent;border:0}
[data-look="minimal"] .icon-btn:hover{background:var(--bg-tint)}
[data-look="minimal"] .pill{min-height:30px;padding:0 12px;background:var(--ctl-bg);border:1px solid var(--ctl-line);border-radius:var(--ctl-r);box-shadow:var(--ctl-shadow);color:var(--text-soft)}
[data-look="minimal"] .pill:hover{border-color:var(--accent);color:var(--accent-deep)}
[data-look="minimal"] .mode-sw{height:var(--ctl-h);min-height:var(--ctl-h);background:var(--ctl-bg);border:1px solid var(--ctl-line);border-radius:var(--ctl-r);padding:3px;gap:0;box-shadow:var(--ctl-shadow)}
[data-look="minimal"] .mode-sw button{height:calc(var(--ctl-h) - 8px);padding:0 14px;border-radius:calc(var(--ctl-r) - 3px);border-bottom:0;margin-bottom:0}
[data-look="minimal"] .mode-sw button.act{background:color-mix(in oklab,var(--glass-bg-strong) 72%,var(--bg-soft));box-shadow:var(--sh-sm);color:var(--text)}

/* навигация остаётся стеклянной даже в минимальном режиме */
[data-look="minimal"] .sb{background:linear-gradient(145deg,var(--glass-bg-strong),var(--glass-bg));border-right:1px solid color-mix(in oklab,var(--glass-line) 60%,transparent);box-shadow:var(--glass-shadow);backdrop-filter:blur(26px) saturate(1.25);-webkit-backdrop-filter:blur(26px) saturate(1.25)}
[data-look="minimal"] .sb-brand{border:0;background:transparent;box-shadow:none}
[data-look="minimal"] .sb-user{border-top:0}
[data-look="minimal"] .sb-item.active{background:linear-gradient(180deg,color-mix(in oklab,var(--text) 92%,var(--accent)),var(--text));color:var(--bg);font-weight:700}
[data-look="minimal"] .sb-item.active::before{content:"";position:absolute;left:-14px;top:9px;bottom:9px;width:2px;background:var(--accent);border-radius:1px}
[data-look="minimal"] .sb-item{position:relative}
[data-look="minimal"] .sb-item.active .badge{background:rgba(255,255,255,.15);color:var(--bg)}

/* topbar — тот же стеклянный материал, чтобы меню и шапка читались единым слоем */
[data-look="minimal"] .tb{border-bottom:1px solid color-mix(in oklab,var(--glass-line) 62%,transparent);background:linear-gradient(180deg,var(--glass-bg-strong),var(--glass-bg));backdrop-filter:blur(22px) saturate(1.2);-webkit-backdrop-filter:blur(22px) saturate(1.2)}

/* tabs — линия одна, без двойных рамок */
[data-look="minimal"] .tabs{border-bottom-color:var(--line-soft)}

/* dashed добавления — стиль чище */
[data-look="minimal"] .add-stg{border-style:dashed;border-color:var(--line);background:transparent}

/* progress chips — без обводки */
[data-look="minimal"] .pchip{background:transparent;border:0;color:var(--text-mute);padding:4px 0}
[data-look="minimal"] .pchip.done,
[data-look="minimal"] .pchip.cur{background:transparent;padding:4px 0}

/* теги статуса — оставляем цветные, чтобы статус читался */
/* (по запросу — статусы цветные сохраняются) */

/* ── TC Print View ─────────────────────────────────────────── */
.tc-print-overlay{position:fixed;inset:0;background:#fff;color:#111;z-index:9000;overflow:auto}
.tc-print-doc{max-width:800px;margin:0 auto;padding:40px 32px;font-family:'Manrope',sans-serif}
@media print{
  .no-print{display:none !important}
  body>*{display:none !important}
  /* TC — полноэкранный оверлей техкарты */
  .tc-print-overlay{display:block !important;position:static}
  .tc-print-doc{padding:20px}
  /* КП — полноэкранный оверлей (portal → прямой дочерний body) */
  .kp-overlay{display:block !important;position:static !important;overflow:visible !important;
    background:white !important;inset:unset !important;width:100% !important}
  .kp-no-print{display:none !important}
  /* КП — публичный вид (kp-overlay внутри #root) */
  body>#root{display:block !important;overflow:visible !important}
  /* КП — печатаем открытую модалку */
  .mdl-bg{display:flex !important;background:#fff !important;position:static !important;
    padding:20px !important;align-items:flex-start !important;backdrop-filter:none !important}
  .mdl-bg .mdl{max-width:100% !important;max-height:none !important;box-shadow:none !important;
    border:none !important;overflow:visible !important}
  .mdl-bg .mdl-ft{display:none !important}
  .mdl-bg .mdl-x{display:none !important}
  .mdl-bg .mdl-hd{border-bottom:2px solid #222 !important}
}

/* ══════════════════════════════════════════════════════════════
   МОБИЛЬНАЯ ВЕРСИЯ  (≤ 768px)
   ══════════════════════════════════════════════════════════════ */

/* ── Оверлей под drawer-сайдбаром ── */
.sb-overlay{
  display:none;
  position:fixed;inset:0;
  background:rgba(0,0,0,.45);
  z-index:199;
  animation:fadeIn .2s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

@media (max-width: 768px) {

  /* Переключаем лэйаут: сайдбар уходит в оверлей */
  .app{
    grid-template-columns: 1fr !important;
    padding-bottom: 64px; /* место под bottom nav */
  }

  /* Сайдбар — drawer слева */
  .sb{
    position: fixed;
    top: 0; left: 0; bottom: 0;
    width: 240px;
    z-index: 200;
    transform: translateX(-100%);
    transition: transform .25s ease;
    height: 100dvh;
    box-shadow: 4px 0 24px rgba(0,0,0,.3);
  }
  /* Когда drawer открыт */
  .app.mb-open .sb{ transform: translateX(0); }
  .app.mb-open .sb-overlay{ display: block; }

  /* Скрываем toggle-кнопку внутри сайдбара на мобиле (она в topbar) */
  .sb .sb-toggle{ display: none !important; }

  /* Topbar: кнопка-гамбургер */
  .tb{ padding: 10px 14px; }
  .tb-hamburger{
    display: flex !important;
    align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border: none; background: none;
    color: var(--text);
    cursor: pointer;
    border-radius: 8px;
    flex-shrink: 0;
  }
  .tb-hamburger:hover{ background: var(--bg-tint); }

  /* Bottom navigation bar */
  .bottom-nav{
    display: flex !important;
    position: fixed;
    bottom: 0; left: 0; right: 0;
    height: 60px;
    background: linear-gradient(180deg,var(--glass-bg),var(--glass-bg-strong));
    border-top: 1px solid var(--glass-line);
    z-index: 100;
    padding: 0 4px;
    padding-bottom: env(safe-area-inset-bottom, 0);
    backdrop-filter: blur(22px) saturate(1.35);
    -webkit-backdrop-filter: blur(22px) saturate(1.35);
    box-shadow: 0 -14px 34px rgba(0,0,0,.18), inset 0 1px 0 var(--glass-highlight);
  }
  .bottom-nav-item{
    flex: 1;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 3px;
    background: none; border: none;
    color: var(--text-soft);
    font-size: 10px; font-weight: 500;
    cursor: pointer;
    border-radius: 8px;
    padding: 6px 4px;
    transition: color .15s, background .15s;
    position: relative;
  }
  .bottom-nav-item.active{ color: var(--accent-deep); background:color-mix(in oklab,var(--glass-bg-strong) 78%,transparent); box-shadow:inset 0 1px 0 var(--glass-highlight); }
  .bottom-nav-item .badge{
    position: absolute; top: 4px; right: 12px;
    background: var(--red); color: #fff;
    font-size: 9px; min-width: 16px; height: 16px;
    border-radius: 8px; display: flex; align-items: center; justify-content: center;
    padding: 0 3px;
  }

  /* Контент — полная ширина */
  .main{ min-width: 0; }

  /* Topbar — убираем правые кнопки на мобиле */
  .tb-right .tb-source{ display: none; }

  /* Padding контента — снизу место под bottom nav (60px) */
  main{ padding: 12px 12px 76px !important; }

  /* Главные двухколоночные layout'ы → одна колонка */
  .split, .g-12, .dash-kpis, .refs, .dd-layout{
    grid-template-columns: 1fr !important;
    display: grid !important;
  }
  .dash-chart-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .dash-chart-svg{min-width:720px}
  /* Карточки в 1 колонку */
  .fld-row, .fld-row3{
    grid-template-columns: 1fr !important;
  }
  .cp-grid{
    grid-template-columns: 1fr !important;
  }

  /* Канбан — горизонтальный скролл */
  .kb{
    grid-template-columns: repeat(var(--kb-cols,6), 240px) !important;
    overflow-x: auto;
    padding-bottom: 8px;
    -webkit-overflow-scrolling: touch;
  }
  .kb-col{ min-width: 200px; }

  /* Карточки изделий */
  .np-grid{ grid-template-columns: 1fr !important; }

  /* Таблицы — скролл */
  .tbl-wrap, .tbl-outer{ overflow-x: auto; -webkit-overflow-scrolling: touch; }
  table{ min-width: 500px; }

  /* Модалки — почти полный экран */
  .mdl{
    max-width: 100% !important;
    width: 100% !important;
    max-height: 90dvh !important;
    border-radius: var(--r-lg) var(--r-lg) 0 0 !important;
  }
  .mdl-bg{
    align-items: flex-end !important;
    padding: 0 !important;
  }
  .mdl.wide{ max-width: 100% !important; }

  /* Детальная страница: убираем grid расчёта, делаем колонку */
  .cp-outer{
    flex-direction: column !important;
  }
  .cp-left, .cp-right{
    min-width: 0 !important;
    width: 100% !important;
  }

  /* Chips изделий в сделке */
  .deal-prods{ flex-wrap: wrap; }

  /* Хлебные крошки */
  .crumb{ font-size: 12px; }

  /* Детальная карточка сделки / изделия */
  .card-hd{ flex-wrap: wrap; gap: 8px; }

  /* Скрываем неважные колонки таблиц */
  .tbl .hide-mob{ display: none !important; }

  /* Размер шрифта */
  body{ font-size: 14px; }
  .tb h2{ font-size: 16px; }
}

/* Планшет 769–1024 */
@media (min-width: 769px) and (max-width: 1024px) {
  .app{ grid-template-columns: 60px 1fr !important; }
  .app .sb{
    padding: 18px 8px;
    width: 60px;
  }
  .app .sb-brand{ justify-content:center; padding:4px 0 14px !important; }
  .app .sb-brand img{ width:32px !important; height:32px !important; object-fit:contain !important; }
  .app .sb-brand .name,
  .app .sb-brand .sub,
  .app .sb-item span:not(.badge),
  .app .sb-item .badge,
  .app .sb-user .who,
  .app .sb-user .role{ display: none; }
  .app .sb-item{ justify-content: center; padding: 9px 0; }
  .app .sb-user{ justify-content: center; padding: 12px 0 4px; }
}

/* На десктопе скрываем мобильные элементы */
@media (min-width: 769px) {
  .bottom-nav{ display: none !important; }
  .tb-hamburger{ display: none !important; }
  .sb-overlay{ display: none !important; }
}
