:root{
  --page-bg-1: #0c3338; --page-bg-2: #0a2a30; --page-bg-3: #062126;
  --surface-0: #082025; --surface-1: #0e353c; --surface-2: #134148; --surface-3: #1a4f57; --surface-4: #225f68;
  --grad-card-top: #154851; --grad-card-bot: #0a2e34;
  --grad-pill-top: #0d3a42; --grad-pill-bot: #051d22;
  --grad-btn-top:  #1c5560; --grad-btn-bot:  #0c3239;
  --grad-cell-top: #1b525c; --grad-cell-bot: #0c333a;
  --text-1: #f0fafb; --text-2: #b8d8da; --text-3: #7ea6aa; --text-4: #506e72;
  --border-1: rgba(180, 230, 235, 0.08); --border-2: rgba(180, 230, 235, 0.16); --border-3: rgba(180, 230, 235, 0.30);
  --violet: #d4c4ff; --violet-dim: #a394f5; --yellow: #ffe680; --yellow-dim: #f4c542;
  --mint: #b8f4c5; --mint-soft: #c8e8e4;
  --green-ok: #6fdc8c; --amber-warn: #ffc857; --red-risk: #ff8b73; --red-crit: #ff6262;
  --font-display: 'Fraunces', Georgia, serif;
  --font-body:    'Inter', system-ui, -apple-system, Segoe UI, sans-serif;
  --text-xs:   clamp(0.72rem, 0.68rem + 0.18vw, 0.8rem);
  --text-sm:   clamp(0.82rem, 0.78rem + 0.22vw, 0.92rem);
  --text-base: clamp(0.92rem, 0.88rem + 0.22vw, 1rem);
  --text-lg:   clamp(1.1rem, 1.02rem + 0.35vw, 1.3rem);
  --text-xl:   clamp(1.35rem, 1.2rem + 0.6vw, 1.65rem);
  --text-2xl:  clamp(1.7rem, 1.45rem + 1vw, 2.2rem);
  --sp-1: .5rem; --sp-2: 1rem; --sp-3: 1.5rem; --sp-4: 2rem; --sp-6: 3rem; --sp-8: 4rem;
  --r-sm: 10px; --r-md: 16px; --r-lg: 22px; --r-xl: 28px; --r-pill: 9999px;
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

*, *::before, *::after { box-sizing: border-box; min-width: 0; }
html {
  scroll-behavior: smooth;
  overflow-x: hidden;
  background-color: #062126;
}
body{
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: 1.55;
  color: var(--text-1);
  -webkit-font-smoothing: antialiased;
  background:
    radial-gradient(70% 55% at 50% 15%, rgba(28,86,96,0.85) 0%, rgba(28,86,96,0) 65%),
    radial-gradient(50% 40% at 12% 90%, rgba(8,32,38,0.9) 0%, rgba(8,32,38,0) 65%),
    radial-gradient(50% 45% at 95% 95%, rgba(8,32,38,0.9) 0%, rgba(8,32,38,0) 65%),
    linear-gradient(180deg, #0c3338 0%, #0a2a30 55%, #062126 100%);
  background-attachment: fixed;
  background-color: #062126;
  min-height: 100svh;
  overflow-x: hidden;
}
h1, h2, h3, h4 {
  font-family: var(--font-display); font-weight: 400; letter-spacing: -0.02em; line-height: 1.1; margin: 0; text-wrap: balance;
}
p { margin: 0; color: var(--text-2); }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; }
img, svg { display: block; max-width: 100%; }

/* SCROLLBARS */
html{ scrollbar-width: thin; scrollbar-color: var(--surface-3) #062126; }
*{ scrollbar-width: thin; scrollbar-color: var(--surface-3) #062126; }
html::-webkit-scrollbar, body::-webkit-scrollbar, ::-webkit-scrollbar{
  width: 6px; height: 6px; background-color: #062126;
}
html::-webkit-scrollbar-track, body::-webkit-scrollbar-track, ::-webkit-scrollbar-track,
html::-webkit-scrollbar-track-piece, body::-webkit-scrollbar-track-piece, ::-webkit-scrollbar-track-piece{
  background-color: #062126; border: 0; box-shadow: none;
}
html::-webkit-scrollbar-thumb, body::-webkit-scrollbar-thumb, ::-webkit-scrollbar-thumb{
  background-color: var(--surface-3); border-radius: var(--r-pill); border: 0; transition: background-color .2s var(--ease-out);
}
html::-webkit-scrollbar-thumb:hover, body::-webkit-scrollbar-thumb:hover, ::-webkit-scrollbar-thumb:hover{
  background-color: var(--surface-4);
}
html::-webkit-scrollbar-corner, body::-webkit-scrollbar-corner, ::-webkit-scrollbar-corner,
html::-webkit-scrollbar-button, body::-webkit-scrollbar-button, ::-webkit-scrollbar-button{
  background-color: #062126; display: none; width: 0; height: 0;
}

/* APP LAYOUT
   ┌──────────────────────────────────────────┐
   │              header (topbar)             │  ← full-width
   ├──────────┬───────────────────────────────┤
   │ sidebar  │            main               │  ← sidebar UNDER header
   └──────────┴───────────────────────────────┘
*/
.app{
  display: grid;
  grid-template-areas:
    "header"
    "main";
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto 1fr;
  min-height: 100svh; gap: var(--sp-3); padding: var(--sp-3); max-width: 100%;
}
/* Sidebar теперь всегда оверлей - main не реагирует на показ/скрытие меню */

/* Высота шапки - используется для позиционирования сайдбара под ней */
:root{ --header-h: 56px; }

/* SIDEBAR - fixed overlay на всех размерах. Уезжает за левый край через transform.
   Сайдбар стартует НИЖЕ хэдера, чтобы не накладываться на него. */
.sidebar{
  position: fixed;
  top: calc(var(--sp-3) + var(--header-h) + var(--sp-2));
  left: var(--sp-3);
  bottom: var(--sp-2);
  width: 260px;
  background: linear-gradient(180deg, #0d3a42 0%, #051d22 100%);
  border: 1px solid var(--border-2); border-radius: var(--r-xl);
  padding: 12px 10px 14px;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 24px 60px -30px rgba(0,0,0,0.8);
  overflow-y: auto; scrollbar-width: thin;
  z-index: 90;
  transform: translateX(0);
  transition: transform .3s var(--ease-out);
}
/* Компактные разделы внутри сайдбара - чтобы все 14 пунктов влезали без скролла */
.sidebar .brand{ padding: 4px 10px 12px; margin-bottom: 6px; }
.sidebar .nav-section{ padding: 8px 4px 4px; }
.sidebar .nav-label{ padding: 0 6px 4px; font-size: 0.62rem; }
.sidebar .nav-item{ padding: 7px 10px; font-size: 0.85rem; margin-bottom: 1px; gap: 8px; }
.sidebar .nav-item .nav-icon{ width: 18px; height: 18px; }
.app.sidebar-hidden .sidebar{
  transform: translateX(calc(-100% - var(--sp-3) - 12px));
  pointer-events: none;
}

/* Кнопка закрытия sidebar - видна только в оверлей-режиме (мобила) */
.sidebar-close{
  display: none;
  position: absolute;
  top: 12px; right: 12px;
  width: 36px; height: 36px; border-radius: 50%;
  background: linear-gradient(180deg, #1c5560 0%, #0c3239 100%);
  border: 1px solid var(--border-2);
  color: var(--text-1);
  font-size: 1.4rem; line-height: 1;
  align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
  z-index: 110;
  box-shadow: 0 1px 0 rgba(255,255,255,0.08) inset, 0 6px 14px -6px rgba(0,0,0,0.5);
  transition: background .2s var(--ease-out), transform .15s var(--ease-out);
}
.sidebar-close:hover{ background: linear-gradient(180deg, #236872 0%, #0d3a42 100%); }
.sidebar-close:active{ transform: scale(0.94); }
.sidebar.open .sidebar-close{ display: inline-flex; }

.brand{
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px var(--sp-3);
  border-bottom: 1px solid var(--border-1);
  margin-bottom: var(--sp-2);
}
.brand-dot{
  width: 32px; height: 32px; border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--yellow) 0%, var(--yellow-dim) 70%);
  box-shadow: 0 0 24px rgba(244,197,66,.4);
}
.brand-logo{
  width: 59px; height: 59px;
  border-radius: 12px;
  object-fit: contain;
  display: block;
  flex-shrink: 0;
}
.brand-name{ font-family: var(--font-display); font-size: 1.2rem; }
.brand-name small{ display:block; color: var(--text-3); font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; font-family: var(--font-body); font-weight: 500;}

.nav-section{ padding: var(--sp-2) 8px 8px; }
.nav-label{ font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase; color: var(--text-4); padding: 0 8px 8px; font-weight: 600; }
.nav-item{
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 12px;
  color: var(--text-2); font-size: 0.9rem; margin-bottom: 2px;
  transition: background .2s var(--ease-out), color .2s var(--ease-out);
  border: 1px solid transparent; cursor: pointer;
}
.nav-item:hover{ background: rgba(255,255,255,0.04); color: var(--text-1); }
.nav-item.active{
  background: linear-gradient(180deg, #1c5560 0%, #0c3239 100%);
  color: var(--text-1); border-color: var(--border-2); font-weight: 500;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.nav-item .ic{ width: 22px; height: 22px; display: inline-flex; align-items: center; justify-content: center; color: var(--text-3); flex-shrink: 0; }
.nav-item.active .ic{ color: var(--mint-soft); }
.nav-item .badge{ margin-left: auto; background: var(--red-risk); color: #0a0a0c; font-size: 0.65rem; font-weight: 700; padding: 2px 7px; border-radius: var(--r-pill); }

/* MAIN */
.main{ grid-area: main; min-width: 0; max-width: 100%; overflow-x: clip; }

/* topbar (header) - занимает всю ширину поверх sidebar+main
   Сетка 1fr / auto / 1fr - название компании геометрически по центру,
   независимо от ширины левой/правой групп. */
.topbar{
  grid-area: header;
  position: relative;
  z-index: 120;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--sp-2);
  padding: 6px 8px 6px 18px;
  background: linear-gradient(180deg, #0d3a42 0%, #051d22 100%);
  border: 1px solid var(--border-2); border-radius: var(--r-pill);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset, 0 12px 30px -16px rgba(0,0,0,0.7);
}
.topbar > .burger{ justify-self: start; }
.topbar > .crumbs{
  justify-self: center;
  text-align: center;
  font-size: 0.95rem;
  color: var(--text-2);
  white-space: nowrap;
}
.topbar > .topbar-right{
  justify-self: end;
  display: flex; align-items: center; gap: var(--sp-2);
}
.topbar .crumbs strong{ color: var(--text-1); font-weight: 600; letter-spacing: 0.01em; }

.period-pill, .user-pill{
  display: inline-flex; align-items: center; gap: 10px;
  background: linear-gradient(180deg, #1c5560 0%, #0c3239 100%);
  border: 1px solid var(--border-2); border-radius: var(--r-pill);
  padding: 8px 14px; font-size: 0.85rem;
  box-shadow: 0 1px 0 rgba(255,255,255,0.06) inset;
}
.period-pill svg{ width: 14px; height: 14px; color: var(--text-3); }
.user-pill{ padding: 5px 14px 5px 5px; }
.avatar{
  width: 32px; height: 32px; border-radius: 50%;
  background: linear-gradient(135deg, var(--yellow) 0%, var(--violet) 100%);
  color: #0a0a0c; font-weight: 600; font-size: 0.8rem;
  display: inline-flex; align-items: center; justify-content: center;
}
.user-pill .meta small{ display:block; color: var(--text-3); font-size: 0.72rem; line-height: 1;}
.user-pill .meta{ line-height: 1.2; }

/* SECTIONS */
section.view{ display: none; }
section.view.active{ display: block; animation: fadeIn .35s var(--ease-out); }
@keyframes fadeIn{ from{ opacity:0; transform: translateY(8px);} to{ opacity:1; transform: translateY(0);} }

.section-head{
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-areas:
    "eyebrow .   buttons"
    "h1      h1  h1"
    "desc    desc desc";
  column-gap: var(--sp-3);
  row-gap: var(--sp-1);
  margin-bottom: var(--sp-3);
  align-items: end;
}
/* «Распаковываем» внутренний wrapper <div>, чтобы eyebrow/h1/desc
   стали прямыми grid-элементами .section-head */
.section-head > div:first-child{ display: contents; }
.section-head .eyebrow{ grid-area: eyebrow; margin-bottom: 0; }
.section-head h1{
  grid-area: h1;
  font-size: var(--text-2xl);
  font-weight: 300;
  max-width: none;
  width: 100%;
  text-align: center;
  margin: var(--sp-2) 0 0;
}
.section-head h1 em{ font-style: italic; color: var(--mint-soft); }
.section-head .desc{
  grid-area: desc;
  color: var(--text-3);
  font-size: 0.92rem;
  max-width: none;
  width: 100%;
  margin-top: 8px;
}
.section-head > div:last-child{ grid-area: buttons; }

.eyebrow{ font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--text-3); font-weight: 500; margin-bottom: 8px; }

/* COMPONENTS — Variant 1 visual layer */
/* Large content cards → Card 1 (kpi-glass-card: soft teal glass) */
.card{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid rgba(190, 245, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.26) 0%,
    rgba(14, 66, 72, 0.22) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  backdrop-filter: blur(16px) saturate(120%);
  padding: var(--sp-3);
  box-shadow: none;
  color: rgba(245, 248, 250, 0.94);
  transition: background 180ms ease, border-color 180ms ease;
}
.card::before{
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.07)  0%,
    rgba(255, 255, 255, 0.018) 24%,
    rgba(255, 255, 255, 0)     100%
  );
}
.card::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: radial-gradient(
    circle at 50% 0%,
    rgba(140, 240, 235, 0.07)  0%,
    rgba(140, 240, 235, 0.025) 26%,
    rgba(140, 240, 235, 0)     58%
  );
}
.card:hover{
  border-color: rgba(190, 245, 255, 0.22);
  background: linear-gradient(
    180deg,
    rgba(22, 94, 100, 0.30) 0%,
    rgba(14, 68, 74,  0.24) 100%
  );
}
.card > *{ position: relative; z-index: 1; }

.card-head{ display: flex; align-items: center; justify-content: space-between; margin-bottom: var(--sp-3); gap: var(--sp-2); flex-wrap: wrap; }
.card-head h3{ font-family: var(--font-body); font-weight: 400; font-size: 1.05rem; letter-spacing: -0.01em; color: rgba(245, 250, 250, 0.94); }
.card-head .sub{ color: rgba(210, 230, 232, 0.58); font-size: 0.82rem; font-weight: 400; }

.kpi-grid{ display: grid; grid-template-columns: repeat(auto-fit, minmax(min(220px,100%), 1fr)); gap: var(--sp-2); }

/* Small KPI cards → Card 2 (kpi-metal-card: графитовое стекло) */
.kpi{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-md);
  border: 1px solid rgba(220, 232, 235, 0.18);
  background: linear-gradient(
    135deg,
    rgba(58, 70, 72, 0.36) 0%,
    rgba(24, 42, 46, 0.34) 34%,
    rgba(13, 55, 61, 0.30) 68%,
    rgba(44, 56, 58, 0.32) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(115%);
  backdrop-filter: blur(16px) saturate(115%);
  padding: 16px;
  box-shadow: none;
  color: rgba(245, 248, 250, 0.94);
  transition: background 180ms ease, border-color 180ms ease;
}
.kpi::before{
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.10)  0%,
      rgba(255, 255, 255, 0.035) 22%,
      rgba(255, 255, 255, 0)     48%
    ),
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.025) 0%,
      rgba(255, 255, 255, 0)     18%,
      rgba(255, 255, 255, 0.035) 42%,
      rgba(255, 255, 255, 0)     66%,
      rgba(255, 255, 255, 0.025) 100%
    );
}
.kpi::after{
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
  background: repeating-linear-gradient(
    115deg,
    rgba(255, 255, 255, 0.018) 0px,
    rgba(255, 255, 255, 0.018) 1px,
    rgba(255, 255, 255, 0)     1px,
    rgba(255, 255, 255, 0)     7px
  );
  opacity: 0.45;
}
.kpi > *{ position: relative; z-index: 1; }
.kpi:hover{
  transform: none;
  border-color: rgba(225, 242, 245, 0.26);
  background: linear-gradient(
    135deg,
    rgba(68, 80, 82, 0.38) 0%,
    rgba(28, 48, 52, 0.36) 34%,
    rgba(15, 62, 68, 0.32) 68%,
    rgba(50, 62, 64, 0.34) 100%
  );
}
.kpi .label{ font-size: 0.78rem; color: var(--text-3); margin-bottom: 8px; display: flex; align-items: flex-start; gap: 6px; line-height: 1.3; }
/* Центрируем иконку по центру ПЕРВОЙ строки, независимо от количества строк.
   Сдвиг = (line-height − icon-height) / 2 = (1em × 1.3 − 20px) / 2. */
.kpi .label .card-status-icon{ align-self: flex-start; margin-top: calc((1em * 1.3 - 20px) / 2); }
.kpi .label > span{ flex: 1; min-width: 0; }
.kpi .value{ font-family: var(--font-display); font-size: 1.75rem; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; text-align: center; }
.kpi .value small{ font-family: var(--font-body); font-size: 0.7em; color: var(--text-3); font-weight: 400; margin-left: 4px;}
.kpi .deltas{ display: flex; justify-content: center; gap: 10px; margin-top: 6px; font-size: 0.78rem; font-variant-numeric: tabular-nums;}
.kpi .deltas span{ color: var(--text-3); }
.kpi .deltas .up{ color: var(--green-ok); }
.kpi .deltas .down{ color: var(--red-risk); }
.kpi .conclusion{ margin-top: 12px; padding-top: 10px; border-top: 1px dashed var(--border-1); font-size: 0.78rem; color: var(--text-2); line-height: 1.4; }

.status-dot{ width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.s-ok    { background: var(--green-ok);    box-shadow: 0 0 8px rgba(111,220,140,.5); }
.s-warn  { background: var(--amber-warn);  box-shadow: 0 0 8px rgba(255,200,87,.5); }
.s-risk  { background: var(--red-risk);    box-shadow: 0 0 8px rgba(255,139,115,.5); }
.s-crit  { background: var(--red-crit);    box-shadow: 0 0 12px rgba(255,98,98,.7); animation: pulse 1.8s infinite; }
@keyframes pulse { 0%,100%{ opacity: 1;} 50%{ opacity: .4; } }

.tag{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: var(--r-pill);
  font-size: 0.72rem; font-weight: 500;
  border: 1px solid var(--border-2); background: rgba(255,255,255,0.04); color: var(--text-2);
}
.tag.ok   { color: var(--green-ok);   border-color: rgba(111,220,140,0.3); background: rgba(111,220,140,0.08);}
.tag.warn { color: var(--amber-warn); border-color: rgba(255,200,87,0.3);  background: rgba(255,200,87,0.08);}
.tag.risk { color: var(--red-risk);   border-color: rgba(255,139,115,0.3); background: rgba(255,139,115,0.08);}
.tag.crit { color: var(--red-crit);   border-color: rgba(255,98,98,0.3);   background: rgba(255,98,98,0.10);}
.tag.violet{color: var(--violet);     border-color: rgba(212,196,255,0.3); background: rgba(212,196,255,0.08);}

.table{ width: 100%; border-collapse: collapse; font-size: 0.82rem; table-layout: auto; }
.table th, .table td{ text-align: left; padding: 9px 8px; border-bottom: 1px solid var(--border-1); vertical-align: top; }
.table th{ font-weight: 500; font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-3); padding-top: 6px; padding-bottom: 8px; white-space: nowrap; }
.table td{ color: var(--text-2); font-variant-numeric: tabular-nums; }
.table td strong{ color: var(--text-1); font-weight: 500; }
.table th.num, .table td.num{ text-align: right; white-space: nowrap; padding-left: 6px; padding-right: 6px; }
.table th:first-child, .table td:first-child{ padding-left: 4px; }
.table th:last-child,  .table td:last-child { padding-right: 4px; }
.table td small{ display: block; color: var(--text-3); font-size: 0.74rem; margin-top: 2px; line-height: 1.35; }
/* Unit suffixes (ТЫС / МЛН и т.п.) — мельче цифр, inline */
.table td.num small,
.table td .num small,
.value small,
.kpi-card-value small,
.kpi-metal-value small,
.scenario .num small{
  display: inline;
  margin: 0;
  font-size: 0.75em;
  font-weight: 400;
  color: inherit;
  opacity: 0.78;
  letter-spacing: 0.02em;
  line-height: inherit;
}
.table tr:last-child td{ border-bottom: 0; }
.table tr:hover td{ background: rgba(255,255,255,0.02); }
.table .num{ text-align: right; font-variant-numeric: tabular-nums; }
.table .pos{ color: var(--green-ok); }
.table .neg{ color: var(--red-risk); }

.scroll-x{ overflow-x: auto; margin: 0; padding: 0; }
.scroll-x .table{ min-width: 0; }
/* Только для широких финансовых таблиц (P&L и т.п.) - оставляем bleed-edge скролл */
.scroll-x.wide{ margin: 0 calc(-1 * var(--sp-3)); padding: 0 var(--sp-3); }
.scroll-x.wide .table{ min-width: 720px; }

/* Progress 2 — 24 сегментированных пилюли (как .segment-progress в Variant 1) */
.bar-h{
  height: 6px;
  background: rgba(190, 245, 255, 0.16);
  overflow: hidden;
  position: relative;
  /* Сегментация: каждая ячейка 100%/24, пилюля занимает 76% ячейки, остальное — зазор */
  -webkit-mask-image: repeating-linear-gradient(
    to right,
    #000 0,
    #000 calc(100% / 24 * 0.76),
    transparent calc(100% / 24 * 0.76),
    transparent calc(100% / 24)
  );
  mask-image: repeating-linear-gradient(
    to right,
    #000 0,
    #000 calc(100% / 24 * 0.76),
    transparent calc(100% / 24 * 0.76),
    transparent calc(100% / 24)
  );
}
.bar-h > i{
  display: block;
  height: 100%;
  background: linear-gradient(
    180deg,
    rgba(210, 255, 235, 0.94) 0%,
    rgba(120, 228, 172, 0.88) 100%
  );
}
/* Сохраняем оригинальные цвета вариантов */
.bar-h.warn > i{ background: linear-gradient(90deg, var(--amber-warn) 0%, var(--yellow-dim) 100%); }
.bar-h.risk > i{ background: linear-gradient(90deg, var(--red-risk) 0%, var(--red-crit) 100%); }
.bar-h.violet > i{ background: linear-gradient(90deg, var(--violet) 0%, var(--violet-dim) 100%); }

.row-2{ display: grid; gap: var(--sp-3); grid-template-columns: 1fr; margin-top: var(--sp-3); }
.row-3{ display: grid; gap: var(--sp-3); grid-template-columns: 1fr; margin-top: var(--sp-3); }
@media (min-width: 880px){ .row-2{ grid-template-columns: 1fr 1fr; } .row-3{ grid-template-columns: repeat(3, 1fr); } }
.row-2.uneven{ grid-template-columns: 1fr; }
@media (min-width: 1100px){ .row-2.uneven{ grid-template-columns: 1.45fr 1fr; } }

.vbars{ display: grid; grid-template-columns: repeat(12, 1fr); align-items: end; gap: 6px; height: 200px; margin-top: var(--sp-2); }
.vbars > .col{ display: flex; flex-direction: column; align-items: center; gap: 6px; height: 100%; }
.vbars .bar{
  width: 70%; border-radius: var(--r-pill);
  background: linear-gradient(180deg, rgba(210, 255, 235, 0.94) 0%, rgba(120, 228, 172, 0.88) 100%);
  border: 1px solid rgba(190, 245, 255, 0.18); position: relative;
  box-shadow: none;
  transition: transform .25s var(--ease-spring);
}
.vbars .col:hover .bar{ transform: scaleY(1.04); transform-origin: bottom; }
.vbars .bar.accent{ background: linear-gradient(180deg, #d4c4ff 0%, #b8a3ff 100%); border-color: rgba(190, 245, 255, 0.20); box-shadow: none; }
.vbars .bar.warn{ background: linear-gradient(180deg, #ffe680 0%, #f4c542 100%); border-color: rgba(190, 245, 255, 0.20); box-shadow: none; }
.vbars .lbl{ color: var(--text-4); font-size: 0.72rem; font-variant-numeric: tabular-nums; }

.alert{
  position: relative;
  display: flex; gap: 14px; align-items: flex-start;
  padding: 14px 16px; border-radius: var(--r-md);
  background: rgba(255,200,87,0.06); border: 1px solid rgba(255,200,87,0.20);
  -webkit-backdrop-filter: blur(10px) saturate(115%);
  backdrop-filter: blur(10px) saturate(115%);
  margin-bottom: 10px;
}
.alert.risk{ background: rgba(255,139,115,0.06); border-color: rgba(255,139,115,0.25); }
.alert.crit{ background: rgba(255,98,98,0.08); border-color: rgba(255,98,98,0.30); }
.alert.ok{ background: rgba(111,220,140,0.06); border-color: rgba(111,220,140,0.25); }
.alert .ico{ width: 28px; height: 28px; border-radius: 50%; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; font-size: 0.85rem; font-weight: 700;}
.alert.warn .ico{ background: rgba(255,200,87,0.2); color: var(--amber-warn); }
.alert.risk .ico{ background: rgba(255,139,115,0.2); color: var(--red-risk); }
.alert.crit .ico{ background: rgba(255,98,98,0.2); color: var(--red-crit); }
.alert.ok .ico{ background: rgba(111,220,140,0.2); color: var(--green-ok); }
.alert .body{ flex: 1;}
.alert .body h4{ font-family: var(--font-body); font-size: 0.92rem; font-weight: 600; margin-bottom: 4px;}
.alert .body p{ font-size: 0.85rem; }
.alert .body .meta{ font-size: 0.74rem; color: var(--text-3); margin-top: 6px; display: flex; gap: 12px; flex-wrap: wrap;}

.insight{
  position: relative;
  background: linear-gradient(180deg, rgba(212,196,255,0.08) 0%, rgba(212,196,255,0.02) 100%);
  border: 1px solid rgba(212,196,255,0.18); border-radius: var(--r-md);
  -webkit-backdrop-filter: blur(10px) saturate(115%);
  backdrop-filter: blur(10px) saturate(115%);
  padding: 14px 16px; display: flex; gap: 12px; align-items: flex-start;
}
.insight .ico{
  width: 28px; height: 28px; border-radius: 50%;
  background: linear-gradient(135deg, var(--violet) 0%, var(--violet-dim) 100%);
  color: #1a0e3a; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0; font-size: 0.78rem;
}
.insight h4{ font-family: var(--font-body); font-size: 0.92rem; font-weight: 600; margin-bottom: 4px;}
.insight p{ font-size: 0.85rem; color: var(--text-2); }

/* ── BUTTONS — Variant 1 glass style (соответствует buttons-1/buttons-2 из 05/) ── */
.btn{
  position: relative;
  overflow: hidden;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  padding: 10px 20px; border-radius: var(--r-pill);
  font-size: 0.86rem; font-weight: 500;
  letter-spacing: -0.02em;
  line-height: 1;
  border: 1px solid rgba(190, 245, 255, 0.18);
  background: rgba(16, 76, 82, 0.24);
  color: rgba(245, 250, 250, 0.55);
  -webkit-backdrop-filter: blur(12px) saturate(125%);
  backdrop-filter: blur(12px) saturate(125%);
  box-shadow: none;
  text-shadow: none;
  filter: none;
  transition: background 180ms ease, border-color 180ms ease, color 180ms ease;
  min-height: 38px;
  cursor: pointer;
  appearance: none;
  -webkit-appearance: none;
}
.btn::before{
  content: "";
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.085) 0%,
    rgba(255, 255, 255, 0.025) 32%,
    rgba(255, 255, 255, 0)     100%
  );
}
.btn > *{ position: relative; z-index: 1; }
.btn:hover{
  background: rgba(20, 86, 92, 0.28);
  border-color: rgba(190, 245, 255, 0.25);
  transform: none;
  box-shadow: none;
}
.btn:active{
  transform: none;
  background: rgba(22, 92, 98, 0.30);
  border-color: rgba(210, 250, 255, 0.30);
}

.btn-primary{
  color: rgba(255, 255, 255, 0.96);
  background: linear-gradient(
    90deg,
    rgba(105, 218, 213, 0.20) 0%,
    rgba(67, 166, 169, 0.15) 45%,
    rgba(18, 82, 88,  0.30) 100%
  );
  border-color: rgba(190, 245, 255, 0.36);
  box-shadow: none;
}
.btn-primary:hover{
  background: linear-gradient(
    90deg,
    rgba(105, 218, 213, 0.19) 0%,
    rgba(67, 166, 169, 0.14) 45%,
    rgba(18, 82, 88,  0.29) 100%
  );
  border-color: rgba(210, 250, 255, 0.34);
}
.btn-primary:active{
  background: linear-gradient(
    90deg,
    rgba(105, 218, 213, 0.21) 0%,
    rgba(67, 166, 169, 0.16) 45%,
    rgba(18, 82, 88,  0.32) 100%
  );
}

.btn-ghost{
  background: transparent;
  border-color: transparent;
  color: var(--text-2);
  box-shadow: none;
  -webkit-backdrop-filter: none;
  backdrop-filter: none;
}
.btn-ghost::before{ display: none; }
.btn-ghost:hover{
  background: rgba(16, 76, 82, 0.24);
  border-color: rgba(190, 245, 255, 0.18);
  color: rgba(245, 250, 250, 0.78);
  -webkit-backdrop-filter: blur(12px) saturate(125%);
  backdrop-filter: blur(12px) saturate(125%);
  transform: none;
}

.btn:focus{ outline: none; }
.btn:focus-visible{
  outline: 1px solid rgba(210, 250, 255, 0.34);
  outline-offset: 3px;
}

.ai-chat{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid rgba(190, 245, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.26) 0%,
    rgba(14, 66, 72, 0.22) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  backdrop-filter: blur(16px) saturate(120%);
  box-shadow: none;
  padding: var(--sp-3);
}
.ai-msg{ display: flex; gap: 12px; margin-bottom: var(--sp-2); padding-bottom: var(--sp-2); border-bottom: 1px dashed var(--border-1); }
.ai-msg:last-child{ border-bottom: 0; margin-bottom: 0; padding-bottom: 0;}
.ai-msg .who{ width: 32px; height: 32px; border-radius: 50%; flex-shrink: 0; display: inline-flex; align-items: center; justify-content: center; font-weight: 700; font-size: 0.8rem; }
.ai-msg .who.u{ background: var(--surface-3); color: var(--text-1);}
.ai-msg .who.a{ background: linear-gradient(135deg, var(--violet) 0%, var(--violet-dim) 100%); color: #1a0e3a;}
.ai-msg .body{ flex: 1; font-size: 0.9rem;}
.ai-msg.user .body{ color: var(--text-1); font-weight: 500;}
.ai-msg.assistant .body p{ margin-bottom: 6px; }
.ai-msg.assistant .body ul{ margin: 6px 0; padding-left: 18px; color: var(--text-2); }
.ai-msg.assistant .body ul li{ margin-bottom: 4px; font-size: 0.86rem;}

.ai-input{
  display: flex; gap: 10px; margin-top: var(--sp-3);
  background: rgba(16, 76, 82, 0.24);
  border: 1px solid rgba(190, 245, 255, 0.18);
  border-radius: var(--r-pill);
  padding: 5px 5px 5px 18px; align-items: center;
  -webkit-backdrop-filter: blur(12px) saturate(125%);
  backdrop-filter: blur(12px) saturate(125%);
}
.ai-input input{ flex: 1; background: transparent; border: 0; outline: none; color: var(--text-1); font: inherit; }
.ai-input input::placeholder{ color: var(--text-4); }

.prompt-chip{
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px; border-radius: var(--r-pill);
  border: 1px solid rgba(190, 245, 255, 0.18);
  background: rgba(16, 76, 82, 0.24);
  -webkit-backdrop-filter: blur(12px) saturate(125%);
  backdrop-filter: blur(12px) saturate(125%);
  font-size: 0.8rem; color: var(--text-2);
  margin: 0 6px 6px 0; cursor: pointer;
  transition: background .2s var(--ease-out), color .2s var(--ease-out), border-color .2s var(--ease-out);
}
.prompt-chip:hover{ background: rgba(20, 86, 92, 0.28); border-color: rgba(190, 245, 255, 0.25); color: rgba(245, 250, 250, 0.94);}

/* .scenario — внутри .card уже получает Card 1; standalone .scenario тоже Card 1 */
.scenario{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid rgba(190, 245, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.26) 0%,
    rgba(14, 66, 72, 0.22) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  backdrop-filter: blur(16px) saturate(120%);
  padding: var(--sp-3);
  box-shadow: none;
}
.scenario h3{ font-family: var(--font-body); font-weight: 400; font-size: 1rem; margin-bottom: 6px;}
.scenario .num{ font-family: var(--font-display); font-size: 1.8rem; letter-spacing: -0.02em; margin: 8px 0; }
.scenario .num.pos{ color: var(--green-ok);}
.scenario .num.neg{ color: var(--red-risk);}

.report{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-lg);
  border: 1px solid rgba(190, 245, 255, 0.14);
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.26) 0%,
    rgba(14, 66, 72, 0.22) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  backdrop-filter: blur(16px) saturate(120%);
  padding: var(--sp-3); display: flex; flex-direction: column; gap: var(--sp-2);
  box-shadow: none;
  transition: border-color .25s var(--ease-out), background .25s var(--ease-out);
}
.report:hover{
  border-color: rgba(190, 245, 255, 0.22);
  background: linear-gradient(
    180deg,
    rgba(22, 94, 100, 0.30) 0%,
    rgba(14, 68, 74,  0.24) 100%
  );
}
.report h3{ font-family: var(--font-body); font-weight: 600; font-size: 1.05rem;}
.report .for{ color: var(--text-3); font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.1em;}
.report ul{ font-size: 0.84rem; color: var(--text-2); padding-left: 18px; margin: 0;}
.report ul li{ margin-bottom: 4px;}
/* Кнопка «Открыть» прижимается к низу карточки - все кнопки на одной горизонтали.
   Светлый шрифт для лучшей читаемости. */
.report .btn{
  margin-top: auto;
  align-self: stretch;
  color: rgba(245, 250, 250, 0.94);
  font-weight: 500;
}
.report .btn:hover{
  color: rgba(255, 255, 255, 0.98);
}

.spark{ display: inline-flex; align-items: flex-end; gap: 2px; height: 22px;}
.spark i{ width: 3px; background: var(--mint-soft); border-radius: 2px; opacity: .7; }
.spark.down i{ background: var(--red-risk); }
.spark.warn i{ background: var(--amber-warn);}

.dist{ display: grid; gap: 10px; font-size: 0.84rem; }
.dist .row{ display: grid; grid-template-columns: 140px 1fr 70px; align-items: center; gap: 10px;}
.dist .row .name{ color: var(--text-2); }
.dist .row .val{ text-align: right; color: var(--text-1); font-variant-numeric: tabular-nums;}
@media (max-width: 540px){ .dist .row{ grid-template-columns: 1fr 50px;} .dist .row .name{ grid-column: 1 / -1; margin-bottom: -4px;}}

.pl-row{
  display: grid; grid-template-columns: 1fr repeat(5, 90px);
  gap: 8px; padding: 9px 6px; border-bottom: 1px solid var(--border-1);
  font-size: 0.85rem; align-items: center; font-variant-numeric: tabular-nums;
}
.pl-row.head{ font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-3); border-bottom: 1px solid var(--border-2); }
.pl-row.total{ background: rgba(255,255,255,0.02); border-bottom: 1px solid var(--border-2); font-weight: 600; color: var(--text-1);}
.pl-row.subtotal{ font-weight: 500; color: var(--text-1); background: rgba(255,255,255,0.01);}
.pl-row .lbl{ color: var(--text-2);}
.pl-row.head .lbl{ color: var(--text-3);}
.pl-row .num{ text-align: right; }
.pl-row .num.pos{ color: var(--green-ok);}
.pl-row .num.neg{ color: var(--red-risk);}
@media (max-width: 720px){ .pl-row{ grid-template-columns: 1fr 80px 80px; } .pl-row .hide-mobile{ display: none;} }

/* BURGER - видим на ВСЕХ размерах экрана */
.burger{
  display: inline-flex;
  width: 38px; height: 38px; border-radius: 50%;
  background: linear-gradient(180deg, #1c5560 0%, #0c3239 100%);
  border: 1px solid var(--border-2);
  color: var(--text-1);
  align-items: center; justify-content: center;
  font-size: 1.2rem; flex-shrink: 0; padding: 0;
  position: relative; z-index: 105;
  cursor: pointer; user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: background .2s var(--ease-out), border-color .2s var(--ease-out), transform .15s var(--ease-out);
}
.burger:hover{ background: linear-gradient(180deg, #236872 0%, #0d3a42 100%); border-color: var(--border-3); }
.burger:active{ transform: scale(0.94); }

/* Перекл. иконок ≡ / × - только логика, дизайн не меняется */
.burger .burger-icon{ display: none; line-height: 1; }
.burger .burger-icon:not(.close){ display: inline-block; }
.burger[aria-expanded="true"] .burger-icon:not(.close),
.burger.is-open .burger-icon:not(.close){ display: none; }
.burger[aria-expanded="true"] .burger-icon.close,
.burger.is-open .burger-icon.close{
  display: inline-block;
  font-size: 1.4rem;
  margin-top: -2px;
}

/* Backdrop отключён - sidebar не блокирует страницу */
.sidebar-backdrop{ display: none !important; }

/* RESPONSIVE */
@media (max-width: 1180px){
  .app{ gap: var(--sp-2); padding: var(--sp-2);}
  .sidebar{ padding: var(--sp-2) 10px; width: 240px;}
  .nav-label{ font-size: 0.62rem; }
  .nav-item{ font-size: 0.85rem; padding: 9px 10px;}
}

@media (max-width: 980px){
  /* На мобиле sidebar - оверлей, который выезжает поверх контента.
     header остаётся на всю ширину, main под ним. */
  .app{
    grid-template-areas: "header" "main";
    grid-template-columns: minmax(0, 1fr);
    padding: 10px; gap: var(--sp-2);
  }
  /* Мобила: сайдбар по умолчанию закрыт, открывается классом .open.
     Стартует под хэдером - не накладывается на топбар. */
  .sidebar{
    position: fixed;
    top: calc(10px + var(--header-h) + 10px);
    left: 0; bottom: 0;
    max-height: calc(100svh - 10px - var(--header-h) - 10px);
    border-radius: 0 var(--r-md) var(--r-md) 0;
    transform: translateX(-110%);
    transition: transform .3s var(--ease-out);
    z-index: 90; width: 280px;
  }
  .sidebar.open{ transform: translateX(0); }

  .topbar{ padding: 6px 6px 6px 12px; gap: 8px; }
  .topbar > .crumbs{ font-size: 0.85rem; min-width: 0; }
  .period-pill{ padding: 7px 12px; font-size: 0.78rem;}
  .user-pill{ padding: 4px 12px 4px 4px; }
  .user-pill .meta{ display: none;}

  .section-head{ gap: var(--sp-2); margin-bottom: var(--sp-2);}
  .section-head h1{ font-size: 1.5rem;}
  .section-head .desc{ font-size: 0.86rem;}

  .kpi .value{ font-size: 1.5rem;}
  .kpi .label{ font-size: 0.72rem;}
  .kpi .conclusion{ font-size: 0.74rem;}

  .vbars{ height: 160px; gap: 4px;}
  .vbars .lbl{ font-size: 0.65rem;}

  .card{ padding: var(--sp-2);}
  .card-head{ margin-bottom: var(--sp-2);}
  .card-head h3{ font-size: 0.98rem;}

  .pl-row{ padding: 8px 4px; font-size: 0.78rem;}
  .pl-row.head{ font-size: 0.65rem;}

  .scroll-x{ margin: 0 calc(-1 * var(--sp-2)); padding: 0 var(--sp-2);}
}

@media (max-width: 640px){
  body{ font-size: 0.92rem;}
  .app{ padding: 8px; gap: 8px;}

  /* На узких экранах прячем правый блок (период + пользователь),
     чтобы центральное название не убегало вправо */
  .topbar{
    padding: 5px 5px 5px 10px; border-radius: var(--r-md);
    grid-template-columns: auto 1fr;
  }
  .topbar > .topbar-right{ display: none; }
  .topbar > .crumbs{ font-size: 0.82rem; }

  .section-head{
    grid-template-columns: 1fr;
    grid-template-areas:
      "eyebrow"
      "h1"
      "desc"
      "buttons";
    align-items: stretch;
  }
  .section-head h1{ font-size: 1.3rem; margin-top: var(--sp-1); }
  .section-head > div:last-child{ display: flex; gap: 8px; flex-wrap: wrap;}
  .section-head .btn{ flex: 1;}

  .kpi-grid{ grid-template-columns: repeat(auto-fit, minmax(min(160px,100%), 1fr)); gap: 8px;}
  .kpi{ padding: 12px;}
  .kpi .value{ font-size: 1.3rem;}
  .kpi .label{ font-size: 0.7rem;}
  .kpi .conclusion{ display: none;}
  .kpi .deltas{ font-size: 0.7rem;}

  .vbars{ height: 130px;}

  .ai-input{ flex-wrap: wrap; padding: 8px; border-radius: var(--r-md);}
  .ai-input input{ flex-basis: 100%; padding: 8px 4px;}
  .ai-input .btn{ flex: 1;}

  .row-3{ grid-template-columns: 1fr; }

  .scenario .num{ font-size: 1.5rem;}
}

@media (max-width: 380px){
  .kpi-grid{ grid-template-columns: 1fr;}
  .kpi{ padding: 14px;}
  .kpi .conclusion{ display: block;}
  .topbar .crumbs strong{ font-size: 0.85rem;}
  .vbars{ height: 100px;}
}

@media (min-width: 1600px){ .app{ max-width: 1600px; margin-inline: auto;} }

@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{ animation-duration: 0.01ms !important; transition-duration: 0.01ms !important;}
}

/* ============================================================
   MODERN SVG CHART SYSTEM (charts.js) — Variant 1 visual (Graph 1)
   ============================================================ */
.chart-host{
  position: relative;
  margin-top: var(--sp-2);
  min-height: 200px;
}
.modern-chart{
  width: 100%;
  height: 240px;
  max-height: 280px;
  display: block;
  overflow: visible;
}
.modern-chart.modern-donut{
  height: auto;
  max-width: 260px;
  margin: 0 auto;
}
/* Grid: только горизонтали — Graph 1 */
.modern-chart .chart-grid line{
  stroke: rgba(190, 245, 255, 0.075);
  stroke-width: 1;
}
.modern-chart .chart-baseline{
  stroke: rgba(190, 245, 255, 0.16);
  stroke-width: 1;
  stroke-dasharray: 3 4;
}
/* Линия и точки — flat mint, без glow (Graph 1) */
.modern-chart .chart-line{
  stroke-width: 3 !important;
  filter: none !important;
}
.modern-chart .chart-area{ opacity: 1; }
.modern-chart .chart-last-point{ filter: none !important; }
/* X-метки */
.modern-chart .chart-x-labels text{
  font-variant-numeric: tabular-nums;
  fill: rgba(220, 238, 240, 0.88);
}
/* Guide line на hover */
.modern-chart .chart-guide{
  stroke: rgba(190, 245, 255, 0.20);
  stroke-width: 1;
  stroke-dasharray: 3 4;
  pointer-events: none;
}
/* Glass tooltip — Graph 1 (soft teal glass) */
.chart-tooltip{
  position: absolute;
  pointer-events: none;
  padding: 8px 12px;
  border-radius: 12px;
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.62) 0%,
    rgba(14, 66, 72, 0.62) 100%
  );
  border: 1px solid rgba(190, 245, 255, 0.16);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  backdrop-filter: blur(14px) saturate(120%);
  box-shadow: none;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: rgba(245, 250, 250, 0.94);
  z-index: 50;
  transition: opacity .15s var(--ease-out);
  min-width: 90px;
  text-align: center;
}
.chart-tooltip .tt-label{
  color: rgba(210, 230, 232, 0.66);
  font-size: 0.68rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-bottom: 3px;
}
.chart-tooltip .tt-value{
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: rgba(245, 250, 250, 0.94);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
/* Легенды */
.chart-legend{
  margin-top: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.chart-legend .legend-row{
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 8px;
  font-size: 0.85rem;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  transition: background .2s var(--ease-out);
}
.chart-legend .legend-row:hover{ background: rgba(255,255,255,.03); }
.chart-legend .legend-row .dot{ width: 12px; height: 12px; border-radius: 4px; }
.chart-legend-row{
  display: flex;
  gap: 18px;
  margin-top: 10px;
  font-size: 0.8rem;
  color: var(--text-3);
  justify-content: center;
  flex-wrap: wrap;
}
.chart-legend-item{
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-variant-numeric: tabular-nums;
}
.chart-legend-item i{
  display: inline-block;
  width: 18px; height: 3px;
  border-radius: 2px;
}
/* Hover area (flat — без glow) */
.modern-chart:hover .chart-area{ opacity: 1; }
.chart-host:hover .chart-line{ filter: none !important; }

/* CHARTS - circular, donut, radial, line/area, animated bars */
.charts-grid{ display: grid; grid-template-columns: 1fr; gap: var(--sp-3); margin-top: var(--sp-3); }
@media (min-width: 900px){ .charts-grid{ grid-template-columns: 1.2fr 1fr; } }
@media (min-width: 1280px){ .charts-grid{ grid-template-columns: 1.2fr 1fr 0.9fr; } }

.radial-row{ display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--sp-2); margin-top: var(--sp-3); }
.radial{
  position: relative;
  overflow: hidden;
  border-radius: var(--r-md);
  border: 1px solid rgba(220, 232, 235, 0.18);
  background: linear-gradient(
    135deg,
    rgba(58, 70, 72, 0.36) 0%,
    rgba(24, 42, 46, 0.34) 34%,
    rgba(13, 55, 61, 0.30) 68%,
    rgba(44, 56, 58, 0.32) 100%
  );
  -webkit-backdrop-filter: blur(16px) saturate(115%);
  backdrop-filter: blur(16px) saturate(115%);
  padding: 16px; display: flex; flex-direction: column; align-items: center; gap: 8px;
  box-shadow: none; text-align: center;
  transition: border-color .25s var(--ease-out), background .25s var(--ease-out);
}
.radial:hover{
  border-color: rgba(225, 242, 245, 0.26);
  background: linear-gradient(
    135deg,
    rgba(68, 80, 82, 0.38) 0%,
    rgba(28, 48, 52, 0.36) 34%,
    rgba(15, 62, 68, 0.32) 68%,
    rgba(50, 62, 64, 0.34) 100%
  );
}
.radial .wrap{ position: relative; display: inline-flex; align-items: center; justify-content: center; }
.radial svg{ width: 120px; height: 120px; display: block; transform: rotate(-90deg); }
.radial .ring-track{ stroke: rgba(180,230,235,0.10); fill: none; stroke-width: 10; }
.radial .ring-fill{
  fill: none; stroke-width: 10; stroke-linecap: round;
  stroke-dasharray: 314.16; stroke-dashoffset: 314.16;
  transition: stroke-dashoffset 1.5s var(--ease-out);
}
.radial .ring-fill.mint   { stroke: url(#grad-mint); }
.radial .ring-fill.violet { stroke: url(#grad-violet); }
.radial .ring-fill.yellow { stroke: url(#grad-yellow); }
.radial .ring-fill.coral  { stroke: url(#grad-coral); }
.radial .center-text{ position: absolute; pointer-events: none; display: flex; flex-direction: column; align-items: center; }
.radial .center-text .num{ font-family: var(--font-display); font-size: 1.55rem; letter-spacing: -0.02em; color: var(--text-1); font-variant-numeric: tabular-nums; }
.radial .center-text .pct{ font-family: var(--font-body); font-size: 0.75rem; color: var(--text-3); }
.radial .lbl{ font-size: 0.82rem; color: var(--text-2); font-weight: 500; }
.radial .sub{ font-size: 0.72rem; color: var(--text-4); }

.donut-chart{ display: flex; align-items: center; gap: var(--sp-3); flex-wrap: wrap; justify-content: center;}
.donut-wrap{ position: relative; display: inline-flex; align-items: center; justify-content: center;}
.donut-chart svg.donut-svg{ width: 200px; height: 200px; flex-shrink: 0; }
.donut-chart .donut-center{ position: absolute; display: flex; flex-direction: column; align-items: center; pointer-events: none; text-align: center; }
.donut-chart .donut-center .num{ font-family: var(--font-display); font-size: 1.55rem; letter-spacing: -0.02em; color: var(--text-1); font-variant-numeric: tabular-nums; }
.donut-chart .donut-center .lab{ font-size: 0.66rem; color: var(--text-3); text-transform: uppercase; letter-spacing: 0.18em; }
.donut-slice{
  fill: none; stroke-width: 26; stroke-linecap: butt;
  transform-origin: 100px 100px; transform: rotate(-90deg);
  stroke-dasharray: 0 999;
  transition: stroke-dasharray 1.4s var(--ease-out), stroke-width .2s var(--ease-out), opacity .2s var(--ease-out);
  cursor: pointer;
}
.donut-slice:hover{ stroke-width: 30; }
.donut-chart .legend{ display: grid; gap: 6px; font-size: 0.85rem; flex: 1; min-width: 180px; }
.donut-chart .legend-row{ display: grid; grid-template-columns: 14px 1fr auto; align-items: center; gap: 10px; padding: 7px 8px; border-radius: 8px; border-bottom: 1px dashed var(--border-1); transition: background .2s var(--ease-out); cursor: pointer; }
.donut-chart .legend-row:last-child{ border-bottom: 0; }
.donut-chart .legend-row:hover{ background: rgba(255,255,255,0.04); }
.donut-chart .legend-row .dot{ width: 12px; height: 12px; border-radius: 4px; }
.donut-chart .legend-row .name{ color: var(--text-2); }
.donut-chart .legend-row .val{ color: var(--text-1); font-variant-numeric: tabular-nums; font-weight: 500; font-size: 0.85rem; }

.line-chart{ position: relative; width: 100%; }
.line-chart svg{ width: 100%; height: 220px; display: block; overflow: visible; }
.line-chart .grid-line{ stroke: rgba(180,230,235,0.07); stroke-width: 1; stroke-dasharray: 2 5; }
.line-chart .area-fill{ opacity: 0; animation: chart-fade-in .9s 1s var(--ease-out) forwards; }
.line-chart .line-path{
  fill: none; stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
  stroke-dasharray: 2000; stroke-dashoffset: 2000;
  animation: line-draw 2s var(--ease-out) forwards;
}
.line-chart .line-path.mint  { stroke: var(--mint-soft); filter: none; }
.line-chart .line-path.violet{ stroke: var(--violet); filter: none; }
.line-chart .line-path.yellow{ stroke: var(--yellow); filter: none; }
.line-chart .dot{ fill: var(--mint-soft); opacity: 0; animation: chart-fade-in .4s var(--ease-out) forwards; transition: r .2s var(--ease-out); cursor: pointer; }
.line-chart .dot:hover{ r: 7; }
.line-chart .dot.violet{ fill: var(--violet); }
@keyframes line-draw{ to{ stroke-dashoffset: 0; } }
@keyframes chart-fade-in{ to{ opacity: 1; } }
.line-chart .tip{
  position: absolute;
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.62) 0%,
    rgba(14, 66, 72, 0.62) 100%
  );
  border: 1px solid rgba(190, 245, 255, 0.16);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  backdrop-filter: blur(14px) saturate(120%);
  border-radius: var(--r-pill);
  padding: 4px 12px; font-size: 0.78rem; color: var(--text-1);
  font-variant-numeric: tabular-nums; pointer-events: none;
  transform: translate(-50%, calc(-100% - 10px));
  opacity: 0; transition: opacity .2s var(--ease-out);
  white-space: nowrap; z-index: 5;
  box-shadow: none;
}
.line-chart .tip.show{ opacity: 1; }
.line-chart .legend-inline{ display: flex; gap: 18px; font-size: 0.78rem; color: var(--text-3); margin-top: 8px; flex-wrap: wrap; }
.line-chart .legend-inline span{ display: inline-flex; align-items: center; gap: 6px; }
.line-chart .legend-inline i{ width: 12px; height: 3px; border-radius: 2px; display: inline-block; }

.aging-list{ display: grid; gap: 12px; }
.aging-row{ display: grid; grid-template-columns: 110px 1fr 90px; align-items: center; gap: 12px; font-size: 0.85rem; }
.aging-row .name{ color: var(--text-2); }
.aging-row .val{ text-align: right; color: var(--text-1); font-variant-numeric: tabular-nums; font-weight: 500; }
.aging-row .bar{ height: 16px; border-radius: var(--r-pill); background: rgba(190, 245, 255, 0.16); overflow: hidden; position: relative; }
.aging-row .bar > i{
  display: block; height: 100%; border-radius: var(--r-pill);
  width: 0; opacity: 0; animation: bar-grow 1.2s var(--ease-out) forwards;
  background: linear-gradient(180deg, rgba(210, 255, 235, 0.94) 0%, rgba(120, 228, 172, 0.88) 100%);
}
.aging-row.warn .bar > i{ background: linear-gradient(90deg, var(--amber-warn) 0%, var(--yellow-dim) 100%); }
.aging-row.risk .bar > i{ background: linear-gradient(90deg, var(--red-risk) 0%, var(--red-crit) 100%); }
.aging-row.violet .bar > i{ background: linear-gradient(90deg, var(--violet) 0%, var(--violet-dim) 100%); }
@keyframes bar-grow{ from{ width: 0; opacity: 0;} to{ width: var(--bar-w, 50%); opacity: 1;} }
@media (max-width: 540px){ .aging-row{ grid-template-columns: 1fr 70px;} .aging-row .name{ grid-column: 1 / -1; margin-bottom: -6px;} }

.plan-fact-list{ display: grid; gap: 12px; }
.pf-item{ display: grid; grid-template-columns: 130px 1fr 84px; align-items: center; gap: 12px; font-size: 0.85rem; }
.pf-item .name{ color: var(--text-2);}
.pf-item .val{ text-align: right; font-variant-numeric: tabular-nums; color: var(--text-1); font-weight: 500;}
.pf-item .val.pos{ color: var(--green-ok); }
.pf-item .val.neg{ color: var(--red-risk); }
.pf-item .stack{ position: relative; height: 22px; background: rgba(190, 245, 255, 0.16); border-radius: var(--r-pill); overflow: hidden;}
.pf-item .stack .plan{ position: absolute; top: 0; bottom: 0; left: 0; border-radius: var(--r-pill); width: 0; background: linear-gradient(90deg, rgba(190, 245, 255, 0.22) 0%, rgba(120, 190, 205, 0.12) 100%); animation: bar-grow 1.2s var(--ease-out) forwards; }
.pf-item .stack .fact{ position: absolute; left: 0; top: 25%; bottom: 25%; border-radius: var(--r-pill); width: 0; background: linear-gradient(180deg, rgba(210, 255, 235, 0.94) 0%, rgba(120, 228, 172, 0.88) 100%); box-shadow: none; animation: bar-grow 1.4s .15s var(--ease-out) forwards; }
.pf-item.over .stack .fact { background: linear-gradient(90deg, var(--violet) 0%, var(--violet-dim) 100%); box-shadow: 0 0 12px rgba(212,196,255,0.35); }
.pf-item.under .stack .fact{ background: linear-gradient(90deg, var(--amber-warn) 0%, var(--yellow-dim) 100%); box-shadow: 0 0 12px rgba(255,200,87,0.30); }
@media (max-width: 540px){ .pf-item{ grid-template-columns: 1fr 70px;} .pf-item .stack{ grid-column: 1 / -1;} .pf-item .name{ font-size: 0.8rem;} }

.risk-pyramid{ display: grid; gap: 10px; }
.risk-tier{ display: grid; grid-template-columns: 100px 1fr 36px; align-items: center; gap: 10px; font-size: 0.85rem;}
.risk-tier .label{ color: var(--text-2); display: inline-flex; align-items: center; gap: 8px; }
.risk-tier .count{ text-align: right; color: var(--text-1); font-variant-numeric: tabular-nums; font-weight: 600; font-family: var(--font-display); font-size: 1rem;}
.risk-tier .bar{ height: 22px; border-radius: var(--r-pill); position: relative; overflow: hidden; background: rgba(190, 245, 255, 0.16);}
.risk-tier .bar > i{ display: block; height: 100%; border-radius: var(--r-pill); width: 0; animation: bar-grow 1.2s var(--ease-out) forwards; }
.risk-tier.crit .bar > i{ background: linear-gradient(90deg, var(--red-crit) 0%, var(--red-risk) 100%); box-shadow: none;}
.risk-tier.risk .bar > i{ background: linear-gradient(90deg, var(--red-risk) 0%, #ffb39c 100%); }
.risk-tier.warn .bar > i{ background: linear-gradient(90deg, var(--amber-warn) 0%, var(--yellow-dim) 100%); }
.risk-tier.ok   .bar > i{ background: linear-gradient(180deg, rgba(210, 255, 235, 0.94) 0%, rgba(120, 228, 172, 0.88) 100%); }


/* ====== Дополнительные стили после переноса данных МебельСтрой-Поволжье ====== */

/* .dist .row alias: новый разметочный класс */
.dist-row{
  display: grid; grid-template-columns: 200px 1fr 130px;
  align-items: center; gap: 12px;
  font-size: 0.86rem;
  padding: 4px 0;
}
.dist-row .name{ color: var(--text-2); }
.dist-row .val{ text-align: right; color: var(--text-1); font-variant-numeric: tabular-nums; font-weight: 500; }
@media (max-width: 640px){
  .dist-row{ grid-template-columns: 1fr 80px; }
  .dist-row .name{ grid-column: 1 / -1; margin-bottom: -2px; }
  .dist-row .bar-h{ grid-column: 1; }
}

/* vbars без .col-обёртки - поддержка плоской разметки (Progress 2 visual) */
.vbars{ display: flex; align-items: flex-end; gap: 6px; height: 200px; margin-top: var(--sp-2); padding-bottom: 22px; }
.vbars > .bar{
  flex: 1; min-width: 12px; max-width: 60px;
  background: linear-gradient(180deg, rgba(210, 255, 235, 0.94) 0%, rgba(120, 228, 172, 0.88) 100%);
  border-radius: 6px 6px 2px 2px;
  position: relative;
  transition: transform .2s var(--ease-out), filter .2s var(--ease-out);
  cursor: default;
  border: 1px solid rgba(190, 245, 255, 0.18);
  box-shadow: none;
}
.vbars > .bar:hover{ transform: scaleY(1.04); transform-origin: bottom; filter: brightness(1.08); }
.vbars > .bar.violet{ background: linear-gradient(180deg, #d4c4ff 0%, #a394f5 100%); box-shadow: none; }
.vbars > .bar.warn{ background: linear-gradient(180deg, #ffe680 0%, #f4c542 100%); box-shadow: none; }
.vbars > .bar .lbl{
  position: absolute; bottom: -20px; left: 50%; transform: translateX(-50%);
  color: var(--text-4); font-size: 0.7rem; font-variant-numeric: tabular-nums; white-space: nowrap;
}

/* chips: готовые вопросы в AI-секции */
.chips{ display: flex; flex-wrap: wrap; gap: 8px; }
.chip{
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: var(--r-pill);
  font-size: 0.82rem;
  background: rgba(255,255,255,0.04); color: var(--text-2);
  border: 1px solid var(--border-2);
  cursor: pointer; user-select: none;
  transition: background .2s, color .2s, border-color .2s;
}
.chip:hover{ background: rgba(255,255,255,0.08); color: var(--text-1); border-color: var(--border-3); }

/* ai-thread: список инсайтов */
.ai-thread .ai-msg{
  display: block;
  padding: 12px 0;
  border-bottom: 1px dashed var(--border-1);
}
.ai-thread .ai-msg:last-child{ border-bottom: 0; }
.ai-thread .ai-msg .topic{
  font-family: var(--font-body); font-weight: 600;
  color: var(--mint-soft); font-size: 0.85rem;
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 4px;
}
.ai-thread .ai-msg .text{ color: var(--text-2); font-size: 0.9rem; line-height: 1.55; }

/* risks-list: вертикальный список карточек */
.risks-list{ display: grid; gap: var(--sp-2); margin-top: var(--sp-3); }
.risks-list .alert{ margin: 0; }

/* ============================================================
   ICON SYSTEM - sprite + utility classes
   Использование: <svg class="nav-icon" aria-hidden="true"><use href="#icon-..."></use></svg>
   ============================================================ */
.icon,
.nav-icon,
.card-icon,
.kpi-icon,
.icon-inline,
.badge-icon{
  display: inline-block;
  flex-shrink: 0;
  vertical-align: middle;
  color: rgba(255,255,255,.72);
  transition: transform .35s var(--ease-out), color .35s var(--ease-out), filter .35s var(--ease-out);
}
.icon       { width: 18px; height: 18px; }
.nav-icon   { width: 22px; height: 22px; color: #ffe680; filter: drop-shadow(0 0 10px rgba(255,230,128,.18)); }
.card-icon  { width: 26px; height: 26px; color: #7fffd4; filter: drop-shadow(0 0 12px rgba(127,255,212,.16)); }
.card-icon.lg{ width: 28px; height: 28px; }
.kpi-icon   { width: 30px; height: 30px; color: #ffe680; filter: drop-shadow(0 0 14px rgba(255,230,128,.22)); }
.icon-inline{ width: 16px; height: 16px; vertical-align: -3px; margin-right: 4px; }
.badge-icon { width: 14px; height: 14px; }

/* Color tints */
.icon--accent   { color: #ffe680; filter: drop-shadow(0 0 10px rgba(255,230,128,.22)); }
.icon--analytics{ color: #7fffd4; filter: drop-shadow(0 0 12px rgba(127,255,212,.18)); }
.icon--warn     { color: #f4c542; filter: drop-shadow(0 0 10px rgba(244,197,66,.22)); }
.icon--crit     { color: #ff6b6b; filter: drop-shadow(0 0 10px rgba(255,107,107,.22)); }
.icon--ok       { color: #6fdc8c; filter: drop-shadow(0 0 10px rgba(111,220,140,.20)); }
.icon--violet   { color: var(--violet); filter: drop-shadow(0 0 12px rgba(212,196,255,.18)); }
.icon--mute     { color: rgba(255,255,255,.72); filter: none; }

/* Sidebar hover/active states for icons */
.nav-item:hover .nav-icon { transform: translateY(-1px); filter: drop-shadow(0 0 14px rgba(255,230,128,.32)); }
.nav-item.active .nav-icon{ color: var(--mint-soft); filter: drop-shadow(0 0 14px rgba(200,232,228,.32)); }

/* Card-head: icon + title inline */
.card-head h3,
.card-head h4{ display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 400; }

.card:hover .card-icon{ transform: translateY(-1px); }

/* KPI: place icon top-right inside the card */
.kpi{ position: relative; }
.kpi .kpi-icon{ position: absolute; top: 14px; right: 14px; opacity: .85; }
.kpi:hover .kpi-icon{ transform: translateY(-2px); opacity: 1; }

/* Risks: header row with icon + title + level tag */
.alert > h4{ display: inline-flex; align-items: center; gap: 10px; }

/* Inside buttons / chips / tags */
.btn .icon, .btn-primary .icon, .btn-ghost .icon{ width: 16px; height: 16px; margin-right: 6px; vertical-align: -3px; }
.chip .icon { width: 14px; height: 14px; margin-right: 6px; vertical-align: -2px; }
.tag .icon  { width: 12px; height: 12px; margin-right: 4px; vertical-align: -1px; }

/* AI message bubbles */
.ai-msg .icon-inline{ color: var(--violet-dim); }

/* Responsive: mobile sidebar - center icons */
@media (max-width: 980px){
  .nav-item .nav-icon{ width: 20px; height: 20px; }
}

/* ============================================================
   CARD STATUS ICON SYSTEM
   Иконка вместо цветной точки/маркера слева в заголовке.
   Цвет наследуется через currentColor от родителя со status-классом.
   ============================================================ */
.card-title,
.card-head,
.card-head h3,
.card-head h4,
.kpi-title,
.alert > h4,
.alert-title,
.risk-title{
  display: flex;
  align-items: center;
  gap: 10px;
}

.card-status-icon{
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: currentColor;
  opacity: .95;
  filter: drop-shadow(0 0 8px color-mix(in srgb, currentColor 26%, transparent));
  transition:
    transform .24s cubic-bezier(0.16, 1, 0.3, 1),
    opacity   .24s cubic-bezier(0.16, 1, 0.3, 1),
    filter    .24s cubic-bezier(0.16, 1, 0.3, 1);
}
.kpi .card-status-icon{
  width: 20px;
  height: 20px;
  flex-basis: 20px;
}
.card:hover .card-status-icon,
.kpi:hover  .card-status-icon,
.alert:hover .card-status-icon{
  transform: translateY(-1px);
  opacity: 1;
}

/* Статус-цвета */
.status-ok,
.tag-ok,
.risk-ok          { color: #66f29a; }
.status-warn,
.tag-warn,
.risk-warn        { color: #f4c542; }
.status-crit,
.status-risk,
.tag-crit,
.tag-risk,
.risk-crit        { color: #ff6b6b; }
.status-muted     { color: rgba(190, 235, 232, .72); }

/* Старые точки/маркеры - скрываем */
.card-dot,
.kpi-dot,
.status-dot,
.title-dot{ display: none !important; }

/* Сохраняем нормальный цвет KPI-надписи */
.kpi .label.status-ok,
.kpi .label.status-warn,
.kpi .label.status-crit,
.kpi .label.status-muted{
  /* иконка наследует color */
}
.kpi .label > span:not(.card-status-icon){ color: var(--text-3); }

/* Заголовки карточек */
.card-head h3,
.card-head h4{
  font-family: var(--font-body);
  font-weight: 400;
}px; vertical-align: -3px; margin-right: 4px; }
.badge-icon { width: 14px; height: 14px; }

/* Color tints */
.icon--accent   { color: #ffe680; filter: drop-shadow(0 0 10px rgba(255,230,128,.22)); }
.icon--analytics{ color: #7fffd4; filter: drop-shadow(0 0 12px rgba(127,255,212,.18)); }
.icon--warn     { color: #f4c542; filter: drop-shadow(0 0 10px rgba(244,197,66,.22)); }
.icon--crit     { color: #ff6b6b; filter: drop-shadow(0 0 10px rgba(255,107,107,.22)); }
.icon--ok       { color: #6fdc8c; filter: drop-shadow(0 0 10px rgba(111,220,140,.20)); }
.icon--violet   { color: var(--violet); filter: drop-shadow(0 0 12px rgba(212,196,255,.18)); }
.icon--mute     { color: rgba(255,255,255,.72); filter: none; }

/* Sidebar hover/active states for icons */
.nav-item:hover .nav-icon { transform: translateY(-1px); filter: drop-shadow(0 0 14px rgba(255,230,128,.32)); }
.nav-item.active .nav-icon{ color: var(--mint-soft); filter: drop-shadow(0 0 14px rgba(200,232,228,.32)); }

/* Card-head: icon + title inline */
.card-head h3,
.card-head h4{ display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 600; }

.card:hover .card-icon{ transform: translateY(-1px); }

/* KPI: place icon top-right inside the card */
.kpi{ position: relative; }
.kpi .kpi-icon{ position: absolute; top: 14px; right: 14px; opacity: .85; }
.kpi:hover .kpi-icon{ transform: translateY(-2px); opacity: 1; }

/* Risks: header row with icon + title + level tag */
.alert > h4{ display: inline-flex; align-items: center; gap: 10px; }

/* Inside buttons / chips / tags */
.btn .icon, .btn-primary .icon, .btn-ghost .icon{ width: 16px; height: 16px; margin-right: 6px; vertical-align: -3px; }
.chip .icon { width: 14px; height: 14px; margin-right: 6px; vertical-align: -2px; }
.tag .icon  { width: 12px; height: 12px; margin-right: 4px; vertical-align: -1px; }

/* AI message bubbles */
.ai-msg .icon-inline{ color: var(--violet-dim); }

/* Responsive: mobile sidebar - center icons */
@media (max-width: 980px){
  .nav-item .nav-icon{ width: 20px; height: 20px; }
}

/* ============================================================
   CARD STATUS ICON SYSTEM
   Иконка вместо цветной точки/маркера слева в заголовке.
   Цвет наследуется через currentColor от родителя со status-классом.
   ============================================================ */
.card-title,
.card-head,
.card-head h3,
.card-head h4,
.kpi-title,
.alert > h4,
.alert-title,
.risk-title{
  display: flex;
  align-items: center;
  gap: 10px;
}
/* .kpi .label с переносом текста - иконка прижата к верху, к первой строке (см. правило выше на ~302) */

.card-status-icon{
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: currentColor;
  opacity: .95;
  filter: drop-shadow(0 0 8px color-mix(in srgb, currentColor 26%, transparent));
  transition:
    transform .24s cubic-bezier(0.16, 1, 0.3, 1),
    opacity   .24s cubic-bezier(0.16, 1, 0.3, 1),
    filter    .24s cubic-bezier(0.16, 1, 0.3, 1);
}
.kpi .card-status-icon{
  width: 20px;
  height: 20px;
  flex-basis: 20px;
}
.card:hover .card-status-icon,
.kpi:hover  .card-status-icon,
.alert:hover .card-status-icon{
  transform: translateY(-1px);
  opacity: 1;
}

/* Статус-цвета - задаются на родителе (.label / h3 / h4) и наследуются иконкой */
.status-ok,
.tag-ok,
.risk-ok          { color: #66f29a; }
.status-warn,
.tag-warn,
.risk-warn        { color: #f4c542; }
.status-crit,
.status-risk,
.tag-crit,
.tag-risk,
.risk-crit        { color: #ff6b6b; }
.status-muted     { color: rgba(190, 235, 232, .72); }

/* Старые точки/маркеры - скрываем */
.card-dot,
.kpi-dot,
.status-dot,
.title-dot{ display: none !important; }

/* Сохраняем нормальный цвет KPI-надписи (текст не должен окрашиваться статусом) */
.kpi .label.status-ok,
.kpi .label.status-warn,
.kpi .label.status-crit,
.kpi .label.status-muted{
  /* иконка наследует color, текст возвращаем к нейтральному */
}
.kpi .label > span:not(.card-status-icon){ color: var(--text-3); }

/* Заголовки карточек: иконка слева, без верхнего правого дубля */
.card-head h3,
.card-head h4{
  font-family: var(--font-body);
  font-weight: 600;
}

/* ============================================================
   MODERN SVG CHART SYSTEM — Variant 1 visual (Graph 1)
   ============================================================ */
.chart-host{
  position: relative;
  margin-top: var(--sp-2);
  min-height: 200px;
}
.modern-chart{
  width: 100%;
  height: 240px;
  max-height: 280px;
  display: block;
  overflow: visible;
}
.modern-chart.modern-donut{
  height: auto;
  max-width: 260px;
  margin: 0 auto;
}
/* Grid: только горизонтали, едва видимы — Graph 1 */
.modern-chart .chart-grid line{
  stroke: rgba(190, 245, 255, 0.075);
  stroke-width: 1;
}
.modern-chart .chart-baseline{
  stroke: rgba(190, 245, 255, 0.16);
  stroke-width: 1;
  stroke-dasharray: 3 4;
}
/* Линия area-чарта — flat mint, без glow (Graph 1) */
.modern-chart .chart-line{
  stroke-width: 3 !important;
  filter: none !important;
}
.modern-chart .chart-area{
  opacity: 1;
}
.modern-chart .chart-last-point{
  filter: none !important;
}
/* X-метки */
.modern-chart .chart-x-labels text{
  font-variant-numeric: tabular-nums;
  fill: rgba(220, 238, 240, 0.88);
}
/* Guide line на hover */
.modern-chart .chart-guide{
  stroke: rgba(190, 245, 255, 0.20);
  stroke-width: 1;
  stroke-dasharray: 3 4;
  pointer-events: none;
}
/* Glass tooltip — Graph 1 (soft teal glass) */
.chart-tooltip{
  position: absolute;
  pointer-events: none;
  padding: 8px 12px;
  border-radius: 12px;
  background: linear-gradient(
    180deg,
    rgba(20, 88, 94, 0.62) 0%,
    rgba(14, 66, 72, 0.62) 100%
  );
  border: 1px solid rgba(190, 245, 255, 0.16);
  -webkit-backdrop-filter: blur(14px) saturate(120%);
  backdrop-filter: blur(14px) saturate(120%);
  box-shadow: none;
  font-family: var(--font-body);
  font-size: 0.78rem;
  color: rgba(245, 250, 250, 0.94);
  z-index: 50;
  transition: opacity .15s var(--ease-out);
  min-width: 90px;
  text-align: center;
}
.chart-tooltip .tt-label{
  color: var(--text-3);
  font-size: 0.68rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  margin-bottom: 3px;
}
.chart-tooltip .tt-value{
  font-family: var(--font-display);
  font-size: 1.05rem;
  color: var(--text-1);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}
/* Легенды */
.chart-legend{
  margin-top: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.chart-legend .legend-row{
  display: grid;
  grid-template-columns: 14px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 6px 8px;
  border-radius: 8px;
  font-size: 0.85rem;
  color: var(--text-2);
  font-variant-numeric: tabular-nums;
  transition: background .2s var(--ease-out);
}
.chart-legend .legend-row:hover{ background: rgba(255,255,255,.03); }
.chart-legend .legend-row .dot{
  width: 12px; height: 12px; border-radius: 4px;
}
.chart-legend-row{
  display: flex;
  gap: 18px;
  margin-top: 10px;
  font-size: 0.8rem;
  color: var(--text-3);
  justify-content: center;
  flex-wrap: wrap;
}
.chart-legend-item{
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-variant-numeric: tabular-nums;
}
.chart-legend-item i{
  display: inline-block;
  width: 18px; height: 3px;
  border-radius: 2px;
}
/* Hover-усиление area-чарта (flat Graph 1 — без glow) */
.modern-chart:hover .chart-area{ opacity: 1; }
.chart-host:hover .chart-line{ filter: none !important; }
px; vertical-align: -3px; margin-right: 4px; }
.badge-icon { width: 14px; height: 14px; }

/* Color tints */
.icon--accent   { color: #ffe680; filter: drop-shadow(0 0 10px rgba(255,230,128,.22)); }
.icon--analytics{ color: #7fffd4; filter: drop-shadow(0 0 12px rgba(127,255,212,.18)); }
.icon--warn     { color: #f4c542; filter: drop-shadow(0 0 10px rgba(244,197,66,.22)); }
.icon--crit     { color: #ff6b6b; filter: drop-shadow(0 0 10px rgba(255,107,107,.22)); }
.icon--ok       { color: #6fdc8c; filter: drop-shadow(0 0 10px rgba(111,220,140,.20)); }
.icon--violet   { color: var(--violet); filter: drop-shadow(0 0 12px rgba(212,196,255,.18)); }
.icon--mute     { color: rgba(255,255,255,.72); filter: none; }

/* Sidebar hover/active states for icons */
.nav-item:hover .nav-icon { transform: translateY(-1px); filter: drop-shadow(0 0 14px rgba(255,230,128,.32)); }
.nav-item.active .nav-icon{ color: var(--mint-soft); filter: drop-shadow(0 0 14px rgba(200,232,228,.32)); }

/* Card-head: icon + title inline */
.card-head h3,
.card-head h4{ display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-body); font-weight: 400; }

.card:hover .card-icon{ transform: translateY(-1px); }

/* KPI: place icon top-right inside the card */
.kpi{ position: relative; }
.kpi .kpi-icon{ position: absolute; top: 14px; right: 14px; opacity: .85; }
.kpi:hover .kpi-icon{ transform: translateY(-2px); opacity: 1; }

/* Risks: header row with icon + title + level tag */
.alert > h4{ display: inline-flex; align-items: center; gap: 10px; }

/* Inside buttons / chips / tags */
.btn .icon, .btn-primary .icon, .btn-ghost .icon{ width: 16px; height: 16px; margin-right: 6px; vertical-align: -3px; }
.chip .icon { width: 14px; height: 14px; margin-right: 6px; vertical-align: -2px; }
.tag .icon  { width: 12px; height: 12px; margin-right: 4px; vertical-align: -1px; }

/* AI message bubbles */
.ai-msg .icon-inline{ color: var(--violet-dim); }

/* Responsive: mobile sidebar - center icons */
@media (max-width: 980px){
  .nav-item .nav-icon{ width: 20px; height: 20px; }
}

/* ============================================================
   CARD STATUS ICON SYSTEM
   Иконка вместо цветной точки/маркера слева в заголовке.
   ============================================================ */
.card-title,
.card-head,
.card-head h3,
.card-head h4,
.kpi-title,
.alert > h4,
.alert-title,
.risk-title{
  display: flex;
  align-items: center;
  gap: 10px;
}

.card-status-icon{
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: currentColor;
  opacity: .95;
  filter: drop-shadow(0 0 8px color-mix(in srgb, currentColor 26%, transparent));
  transition:
    transform .24s cubic-bezier(0.16, 1, 0.3, 1),
    opacity   .24s cubic-bezier(0.16, 1, 0.3, 1),
    filter    .24s cubic-bezier(0.16, 1, 0.3, 1);
}
.kpi .card-status-icon{
  width: 20px;
  height: 20px;
  flex-basis: 20px;
}
.card:hover .card-status-icon,
.kpi:hover  .card-status-icon,
.alert:hover .card-status-icon{
  transform: translateY(-1px);
  opacity: 1;
}

/* Status colors */
.status-ok,
.tag-ok,
.risk-ok          { color: #66f29a; }
.status-warn,
.tag-warn,
.risk-warn        { color: #f4c542; }
.status-crit,
.status-risk,
.tag-crit,
.tag-risk,
.risk-crit        { color: #ff6b6b; }
.status-muted     { color: rgba(190, 235, 232, .72); }

/* Hide legacy dots */
.card-dot,
.kpi-dot,
.status-dot,
.title-dot{ display: none !important; }

.kpi .label > span:not(.card-status-icon){ color: var(--text-3); }

/* Card headings */
.card-head h3,
.card-head h4{
  font-family: var(--font-body);
  font-weight: 400;
}
1px);
  opacity: 1;
}

/* Status colors */
.status-ok,
.tag-ok,
.risk-ok          { color: #66f29a; }
.status-warn,
.tag-warn,
.risk-warn        { color: #f4c542; }
.status-crit,
.status-risk,
.tag-crit,
.tag-risk,
.risk-crit        { color: #ff6b6b; }
.status-muted     { color: rgba(190, 235, 232, .72); }

/* Hide legacy dots */
.card-dot,
.kpi-dot,
.status-dot,
.title-dot{ display: none !important; }

.kpi .label > span:not(.card-status-icon){ color: var(--text-3); }

/* Card headings */
.card-head h3,
.card-head h4{
  font-family: var(--font-body);
  font-weight: 400;
}


/* ============================================================
 * Стадия 3: PRINT MODE для отчётов
 * Активируется при window.print() (Ctrl+P). Превращает тёмный
 * UI в светлый читаемый документ. Только @media print.
 * ============================================================ */
@media print {
  /* Базовый сброс — белый фон, чёрный текст */
  html, body {
    background: #fff !important;
    color: #111 !important;
    font-size: 11pt;
  }
  body * {
    background: transparent !important;
    color: #111 !important;
    box-shadow: none !important;
    text-shadow: none !important;
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  /* Скрываем все интерфейсные элементы */
  .sidebar, #sidebar, #sidebar-backdrop,
  .header3, .top-nav, .main-nav-btn, .sub-nav-btn,
  .company-period, .nav-item, .burger, #burger,
  .pwd-gate, .upload-modal, #uploadModal,
  .report-modal__backdrop, .report-modal__close, .report-modal__print,
  .section-head .btn, .btn,
  .app-bg, .ambient, .glow, .pageBg {
    display: none !important;
  }
  /* Контейнер app — без отступов */
  .app3, #sections-slot, .view {
    padding: 0 !important;
    margin: 0 !important;
    min-height: auto !important;
  }
  /* Скрываем все секции, кроме открытой модалки отчёта */
  .view { display: none !important; }
  /* Модалка отчёта — превращаем в обычный документ */
  .report-modal, #reportModal {
    position: static !important;
    inset: auto !important;
    display: block !important;
    height: auto !important;
    width: 100% !important;
    overflow: visible !important;
    animation: none !important;
  }
  .report-modal[hidden], #reportModal[hidden] {
    display: none !important;
  }
  .report-modal__panel {
    position: static !important;
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    box-shadow: none !important;
    padding: 0 !important;
    animation: none !important;
    overflow: visible !important;
  }
  .report-modal__panel::before,
  .report-modal__panel::after { display: none !important; }
  .report-modal__body {
    padding: 16px 0 !important;
    overflow: visible !important;
    max-height: none !important;
  }
  /* Шапка отчёта */
  .report-modal__for {
    color: #555 !important;
    font-size: 10pt;
    margin-bottom: 8px;
  }
  .report-modal__title {
    color: #111 !important;
    border-bottom: 2px solid #111;
    padding-bottom: 6px;
    margin: 0 0 16px 0;
    font-size: 18pt;
  }
  /* Заголовки секций отчёта */
  .report-content h3 {
    color: #111 !important;
    border-bottom: 1px solid #999;
    padding-bottom: 4px;
    margin-top: 14pt;
    page-break-after: avoid;
    font-size: 13pt;
  }
  /* Таблицы */
  table.table {
    width: 100% !important;
    border-collapse: collapse !important;
    page-break-inside: avoid;
    margin: 6pt 0;
  }
  table.table th, table.table td {
    border: 1px solid #999 !important;
    padding: 4px 6px !important;
    color: #111 !important;
    font-size: 9.5pt;
  }
  table.table th {
    background: #f0f0f0 !important;
    font-weight: 600;
  }
  .scroll-x {
    overflow: visible !important;
    width: 100% !important;
  }
  /* KPI карточки в отчёте */
  .kpi-grid {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 6pt !important;
    page-break-inside: avoid;
    margin-bottom: 8pt;
  }
  .kpi {
    border: 1px solid #999 !important;
    padding: 8pt !important;
    background: #fafafa !important;
    page-break-inside: avoid;
    border-radius: 0 !important;
  }
  .kpi .label, .kpi .label span {
    color: #555 !important;
    font-size: 9pt;
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }
  .kpi .value {
    color: #111 !important;
    font-size: 14pt;
    font-weight: 700;
    margin: 2pt 0;
  }
  .kpi .conclusion {
    color: #555 !important;
    font-size: 8.5pt;
    margin-top: 2pt;
  }
  /* Списки */
  ul {
    page-break-inside: avoid;
  }
  /* Рекомендации */
  .report-content li {
    page-break-inside: avoid;
    margin-bottom: 8pt;
  }
  /* Цвета по severity — оставляем чтобы было видно */
  .status-ok, .tag.ok, [style*="#5cdcd0"] { color: #1a7a4c !important; }
  .status-warn, .tag.warn, [style*="#ffb84d"] { color: #b8761a !important; }
  .status-crit, .tag.crit, [style*="#ff6b6b"] { color: #b32020 !important; }
  /* Графики SVG */
  svg { max-width: 100% !important; height: auto !important; }
  /* Управление страницами */
  @page {
    size: A4 portrait;
    margin: 14mm 12mm;
  }
  .report-section { page-break-inside: avoid; }
}
