/* ================================================================
   BASE — reset, layout, sidebar, topnav, login, mobile nav
   Colours are driven by design tokens (see css/theme.css).
   ================================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{font-family:'Open Sans',sans-serif;background:var(--c-bg);color:var(--c-ink);font-size:14px;line-height:1.5}

/* Плавная смена темы (light/dark/psb): анимируем ТОЛЬКО цветовые свойства
   крупных поверхностей — transform/hover-анимации не затрагиваются. Canvas
   графиков перерисовывается мгновенно под новую палитру (killCharts). */
#sidebar,#topnav,#main,#content,.card,.card-dark,.card-white,.card-mid,.modal,.tbl,.tbl th,.tbl td,.fsel,.inp,.btn-p,.btn-s{
  transition:background-color .25s ease,border-color .25s ease,color .25s ease}
@media(prefers-reduced-motion:reduce){
  #sidebar,#topnav,#main,#content,.card,.card-dark,.card-white,.card-mid,.modal,.tbl,.tbl th,.tbl td,.fsel,.inp,.btn-p,.btn-s{transition:none}}

::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--c-scroll);border-radius:4px}

/* ── SIDEBAR ─────────────────────────────────────────────────── */
#sidebar{position:fixed;top:0;left:0;bottom:0;width:176px;background:var(--c-dark);display:flex;flex-direction:column;z-index:100;overflow-y:auto;transition:transform .3s ease}
.slink{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:8px;color:var(--c-text-2);font-size:13px;cursor:pointer;transition:all .15s;margin-bottom:2px;border:none;background:transparent;width:100%;text-align:left;white-space:nowrap;font-family:'Open Sans',sans-serif}
.slink:hover{background:rgba(255,255,255,.06);color:#C9D1C8}
.slink.active{background:var(--c-dark-2);color:#fff}
.slink svg{flex-shrink:0;opacity:.75}
.slink.active svg{opacity:1}
.snav-label{font-size:10px;font-weight:600;letter-spacing:.06em;color:var(--c-snav);text-transform:uppercase;padding:10px 8px 4px}

/* ── MAIN LAYOUT ─────────────────────────────────────────────── */
#main{margin-left:176px;min-height:100vh;display:flex;flex-direction:column}

/* ── TOP NAV ─────────────────────────────────────────────────── */
#topnav{position:sticky;top:0;z-index:50;background:var(--c-bg);border-bottom:1px solid var(--c-border);display:flex;align-items:center;gap:8px;padding:10px 24px;flex-wrap:wrap}
.tnbtn{display:flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:13px;border:1.5px solid var(--c-border-2);background:transparent;cursor:pointer;color:var(--c-ink-soft);transition:all .15s;font-weight:500;font-family:'Open Sans',sans-serif}
.tnbtn:hover{background:var(--c-hover)}
.tnbtn.active{background:var(--c-dark);border-color:var(--c-dark);color:#fff}
/* Топ-нав «Направить заявку» — единый оранжевый primary CTA (token --c-cta).
   Заливается всегда (default/active одинаково оранжевые), чтобы ключевое
   действие распознавалось мгновенно и было консистентно с остальными
   точками CTA. cta-модификатор перекрывает базовый/active фон tnbtn. */
.tnbtn.cta,.tnbtn.cta.active{background:var(--c-cta);border-color:var(--c-cta);color:#fff;font-weight:600}
.tnbtn.cta:hover{background:var(--c-cta-hover);border-color:var(--c-cta-hover)}
.tnbtn.cta:active{background:var(--c-cta-active);border-color:var(--c-cta-active)}
.tnico{width:34px;height:34px;border-radius:8px;border:1.5px solid var(--c-border-2);display:flex;align-items:center;justify-content:center;cursor:pointer;background:transparent;transition:background .15s;color:var(--c-ink);padding:0;font-family:'Open Sans',sans-serif}
.tnico:hover{background:var(--c-hover)}

/* ── CONTENT ─────────────────────────────────────────────────── */
#content{flex:1;padding:24px}

/* ── LOGIN ───────────────────────────────────────────────────── */
#login-screen{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}
.ll{background:var(--c-bg);padding:48px;display:flex;flex-direction:column}
.lr{background:linear-gradient(135deg,#627068,#232B2F);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:48px;color:#E2E9DF}
.rtab{padding:8px 0;font-size:16px;color:var(--c-text-3);cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;background:none;border-left:none;border-right:none;border-top:none;font-family:'Open Sans',sans-serif}
.rtab.active{color:var(--c-ink);border-bottom-color:var(--c-ink);font-weight:500}
.ropt{display:flex;align-items:center;gap:10px;cursor:pointer}
.rcirc{width:20px;height:20px;border:2px solid var(--c-track);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:border-color .15s}
.rcirc.sel{border-color:var(--c-ink)}
.rdot{width:10px;height:10px;border-radius:50%;background:var(--c-ink)}

/* ── MOBILE NAV ──────────────────────────────────────────────── */
#mnav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--c-dark);border-top:1px solid var(--c-dark-2);padding:8px 0 env(safe-area-inset-bottom,12px)}
.mnbtn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;cursor:pointer;color:var(--c-text-2);font-size:10px;font-family:'Open Sans',sans-serif;padding:4px 2px;transition:color .15s}
.mnbtn.active{color:var(--c-brand)}

/* ── GRID HELPERS ────────────────────────────────────────────── */
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.det-kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.det-smr{display:flex;gap:0;align-items:stretch}
.det-sdiv{background:var(--c-surface-2)}
.gpipe-top{display:grid;grid-template-columns:3fr 1fr;gap:16px;margin-bottom:16px}
.gpipe-bot{display:grid;grid-template-columns:2fr 1fr;gap:16px}

/* ── MATRIX PRODUCT GRID ────────────────────────────────────── */
/* Two equal panels: Базовые | Рисковые — collapses on very small screens */
.mat-prod-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ── MOTIVATION GRID ─────────────────────────────────────────── */
/* Ряд 1 «Свод»: АВ (широкий компенсатор) + Бонусные баллы + РКО + Зарплатный проект + Кредиты.
   АВ = 1.6fr поглощает лишнюю ширину, остальные четыре — компактные равные 1fr.
   АВ и Бонусные баллы — card-dark (одинаковая тёмная заливка); остальные три — светлые card. */
.mot-row1{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:16px;margin-bottom:16px}
.mot-kpi-grid{display:grid;grid-template-columns:repeat(3,1fr);column-gap:28px;align-items:end;margin-top:24px}

/* Структура комиссионного дохода: donut (слева) + аккордеон (справа) */
.mot-comm{display:flex;align-items:flex-start;gap:0}

/* Эффективность партнёров: donut+агрегаты (слева) · легенда (центр) · аккордеон (справа) */
.prt-perf{display:grid;grid-template-columns:320px minmax(200px,1fr) minmax(260px,1.05fr);align-items:start;gap:0}
.prt-perf .pp-legend,.prt-perf .pp-acc{margin-left:28px;padding-left:28px;border-left:1.5px solid rgba(255,255,255,.1)}
/* Светлая тема виджета (МСБЛ → Финансы): разделители зон под light card (#C9D1C8),
   как у .struct-chan. Класс .light применяется ТОЛЬКО к светлому варианту —
   тёмный виджет «Эффективность партнёров» не затрагивается. */
.prt-perf.light .pp-legend,.prt-perf.light .pp-acc{border-left-color:var(--c-border)}

/* Каналы · Обзор — единый виджет «Структура каналов»: donut (слева ~37%) +
   панель с табами Заявки/Продажи (справа ~63%). Светлая тема, корпоративная
   сетка. Адаптив (≤1023px) — диаграмма сверху, панель снизу. */
.chan-mix{display:grid;grid-template-columns:minmax(0,0.6fr) minmax(0,1fr);align-items:stretch}
.chan-mix .cm-pie{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4px 28px 4px 4px;min-width:0}
.chan-mix .cm-panel{display:flex;flex-direction:column;min-width:0;padding-left:28px;border-left:1.5px solid var(--c-border)}
.chan-mix .cm-list{display:flex;flex-direction:column;gap:2px}
.chan-mix .cm-row{display:grid;grid-template-columns:12px minmax(64px,1.1fr) minmax(0,2fr) 46px 54px;align-items:center;gap:12px;padding:9px 8px;border-radius:9px;cursor:pointer;transition:background .14s}
.chan-mix .cm-row:hover{background:var(--c-hover-soft)}
.chan-mix .cm-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.chan-mix .cm-name{font-size:13px;font-weight:600;color:var(--c-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.chan-mix .cm-bar{height:10px;background:var(--c-track);border-radius:6px;overflow:hidden}
.chan-mix .cm-bar i{display:block;height:100%;border-radius:6px;transform-origin:left;animation:cmBarGrow .55s cubic-bezier(.22,.61,.36,1)}
.chan-mix .cm-val{font-size:14px;font-weight:700;color:var(--c-ink);text-align:right;font-variant-numeric:tabular-nums}
.chan-mix .cm-pct{font-size:12px;font-weight:600;color:var(--c-text-2);text-align:right;font-variant-numeric:tabular-nums}

/* Распределение по каналам (структура банка): donut (слева) + список каналов (центр) + flyout-детализация (справа), светлая тема */
.struct-chan{display:flex;align-items:flex-start;gap:0}
.struct-chan .sc-donut{width:320px;flex-shrink:0}
.struct-chan .sc-acc{flex:1;min-width:240px;margin-left:28px;padding-left:28px;border-left:1.5px solid var(--c-border)}
.struct-chan .sc-detail{flex:1.05;min-width:240px;align-self:stretch;margin-left:24px;padding-left:24px;border-left:1.5px solid var(--c-border);overflow:hidden}

/* Leaders: conditions 2-col layout */
.ldrs-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px;align-items:stretch}
.ldrs-res-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}

/* Leaders «Как выиграть»: пошаговый таймлайн (4 этапа).
   Живёт на тёмной карточке MSBLiders; палитра = зелёный акцент + нейтраль,
   читается и на светлой, и на тёмной теме. Desktop — горизонтальный таймлайн,
   ≤767px — вертикальный. Hover — подсветка + подъём + свечение ноды (CSS). */
.ldr-tl{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.ldr-tl::before{content:"";position:absolute;top:26px;left:12.5%;right:12.5%;height:2px;z-index:0;
  background:linear-gradient(90deg,rgba(var(--ldr-acc-rgb,77,179,77),.12),rgba(var(--ldr-acc-rgb,77,179,77),.5),rgba(var(--ldr-acc-rgb,77,179,77),.12))}
.ldr-tl-step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center;padding:0 4px;cursor:default}
.ldr-tl-node{position:relative;width:52px;height:52px;border-radius:16px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  color:var(--ldr-acc,#4DB34D);background:rgba(var(--ldr-acc-rgb,77,179,77),.13);box-shadow:inset 0 0 0 1px rgba(var(--ldr-acc-rgb,77,179,77),.3);margin-bottom:14px;
  transition:transform .22s ease,background .22s ease,box-shadow .22s ease}
.ldr-tl-step:hover .ldr-tl-node{transform:translateY(-4px) scale(1.06);background:rgba(var(--ldr-acc-rgb,77,179,77),.24);
  box-shadow:0 8px 20px rgba(0,0,0,.32),0 0 18px rgba(var(--ldr-acc-rgb,77,179,77),.45),inset 0 0 0 1px rgba(var(--ldr-acc-rgb,77,179,77),.6)}
.ldr-tl-num{position:absolute;top:-7px;right:-7px;width:22px;height:22px;border-radius:50%;background:var(--ldr-acc,#4DB34D);color:#fff;
  font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px rgba(0,0,0,.35)}
.ldr-tl-title{font-size:13px;font-weight:700;color:#fff;margin-bottom:5px;letter-spacing:-.01em}
.ldr-tl-desc{font-size:11.5px;line-height:1.5;color:rgba(255,255,255,.5);max-width:210px}
@media(max-width:767px){
  .ldr-tl{grid-template-columns:1fr;gap:0}
  .ldr-tl::before{top:40px;bottom:40px;left:25px;right:auto;width:2px;height:auto;
    background:linear-gradient(180deg,rgba(var(--ldr-acc-rgb,77,179,77),.12),rgba(var(--ldr-acc-rgb,77,179,77),.5),rgba(var(--ldr-acc-rgb,77,179,77),.12))}
  .ldr-tl-step{flex-direction:row;align-items:flex-start;text-align:left;gap:16px;padding:14px 0}
  .ldr-tl-node{margin-bottom:0}
  .ldr-tl-desc{max-width:none}
}

/* Prizes grid: 6-col base with responsive spans */
.prz-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:767px){
  #sidebar{transform:translateX(-100%)}
  #sidebar.open{transform:translateX(0)}
  #main{margin-left:0;padding-bottom:68px}
  #mnav{display:flex;justify-content:space-around;align-items:center}
  #content{padding:16px}
  #topnav{padding:10px 16px}
  #login-screen{grid-template-columns:1fr}
  .lr{display:none}
  .tbl{display:block;overflow-x:auto}
  .ldrs-grid{grid-template-columns:1fr;gap:20px}
  .ldrs-res-grid{grid-template-columns:1fr}
  .prz-grid .prz-lg{grid-column:span 6!important}
  .prz-grid .prz-sm{grid-column:span 3!important}
}
@media(max-width:1023px){.mot-row1{grid-template-columns:1fr 1fr}}
@media(max-width:480px){
  .prz-grid .prz-sm{grid-column:span 6!important}
  .mat-prod-grid{grid-template-columns:1fr}
  .mot-kpi-grid{grid-template-columns:repeat(2,1fr);gap:16px}
}
@media(max-width:1023px){.g3{grid-template-columns:1fr 1fr}.g4{grid-template-columns:1fr 1fr}.det-kpi-grid{grid-template-columns:repeat(2,1fr)}}
/* Планшет/мобайл: диаграмма сверху, аккордеон снизу */
@media(max-width:1023px){
  .mot-comm{flex-direction:column;align-items:stretch}
  .mot-comm .mc-donut{margin:0 auto}
  .mot-comm .mc-acc{margin-left:0;padding-left:0;border-left:none;border-top:1.5px solid rgba(255,255,255,.1);padding-top:18px;margin-top:18px;min-width:0}
  .prt-perf{grid-template-columns:1fr}
  .prt-perf .pp-donut-zone{margin:0 auto;max-width:100%}
  .prt-perf .pp-donut-zone>div{max-width:100%}
  .prt-perf .pp-legend,.prt-perf .pp-acc{margin-left:0;padding-left:0;border-left:none;border-top:1.5px solid rgba(255,255,255,.1);padding-top:18px;margin-top:18px;min-width:0}
  .prt-perf.light .pp-legend,.prt-perf.light .pp-acc{border-top-color:var(--c-border)}
  .struct-chan{flex-direction:column;align-items:stretch}
  .struct-chan .sc-donut{width:auto;margin:0 auto;max-width:100%}
  .struct-chan .sc-donut>div{max-width:100%}
  .struct-chan .sc-acc,.struct-chan .sc-detail{margin-left:0;padding-left:0;border-left:none;border-top:1.5px solid var(--c-border);padding-top:18px;margin-top:18px;min-width:0}
  .chan-mix{grid-template-columns:1fr}
  .chan-mix .cm-pie{padding:4px 4px 18px}
  .chan-mix .cm-panel{padding-left:0;padding-top:18px;border-left:none;border-top:1.5px solid var(--c-border)}
}
@media(max-width:767px){.det-smr{flex-direction:column;gap:14px}.det-sdiv{display:none}}
@media(max-width:639px){.g2,.g3,.g4,.gpipe-top,.gpipe-bot,.mot-row1{grid-template-columns:1fr}}
@media(max-width:479px){.mval{font-size:22px}.mval-lg{font-size:30px}.reward-val{font-size:36px}}
