:root{
  --bg: #0f1724;
  --card: #0b1220;
  --muted: #9aa4b2;
  --accent: #3b82f6;
  --accent-2: #22c55e;
  --text: #e6eef6;
  --glass: rgba(255,255,255,0.02);
  --border: rgba(255,255,255,0.06);
  --radius: 6px;
  /* Стрелка селекта: отступ от правого края ~5% + кастомная иконка (нативная игнорирует padding) */
  --select-chevron: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 16 16' fill='none'%3E%3Cpath d='M4 6l4 4 4-4' stroke='%239aa4b2' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* Simple reset */
*{box-sizing:border-box}
html,body{height:100%;}
/* Нативные календари (date/week и др.) — тёмный pop-up в Chrome/Edge/Safari, где поддерживается */
html{color-scheme:dark}
body{
  margin:0;
  font-family: "Helvetica Neue", Arial, sans-serif;
  background: #071827;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.35;
  min-height:100vh;
}

/* Страницы с shell: сайдбар на всю высоту окна, блок версии внизу сайдбара; скролл только в .main-content */
body:has(.app-layout){
  overflow:hidden;
  height:100%;
  max-height:100vh;
  max-height:100dvh;
}

.app-layout{
  display:flex;
  min-height:100vh;
  height:100%;
  max-height:100vh;
  max-height:100dvh;
  min-width:0;
  overflow:hidden;
}

.sidebar{
  width:220px;
  flex-shrink:0;
  background: var(--card);
  border-right:1px solid var(--border);
  padding:20px 16px;
  display:flex;
  flex-direction:column;
  gap:20px;
  transition:width 0.2s ease, padding 0.2s ease;
  height:100%;
  min-height:0;
  overflow:hidden;
}

.sidebar__header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

.sidebar__toggle{
  flex-shrink:0;
}

.sidebar__toggle svg{
  display:block;
}

.sidebar__brand{
  font-weight:700;
  font-size:18px;
  text-transform:uppercase;
  letter-spacing:1px;
  flex:1;
  min-width:0;
}

body.sidebar-collapsed .sidebar{
  width:52px;
  padding:16px 8px;
  overflow:hidden;
}

body.sidebar-collapsed .sidebar__brand{
  display:none;
}

body.sidebar-collapsed .sidebar__nav,
body.sidebar-collapsed .sidebar__version{
  display:none;
}

body.sidebar-collapsed .sidebar__header{
  justify-content:center;
}

.sidebar__nav{
  display:flex;
  flex-direction:column;
  gap:12px;
  flex:1;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
}

.sidebar__link{
  color:var(--text);
  text-decoration:none;
  padding:8px;
  border-radius:6px;
  background:transparent;
  border:1px solid transparent;
  font-size:16px;
}

.sidebar__link:hover{
  border-color:rgba(255,255,255,0.2);
}

.sidebar__version{
  flex-shrink:0;
  margin-top:0;
}

.sidebar__version-label{
  font-size:13px;
  color:var(--muted);
  margin-bottom:6px;
}

.sidebar__version-row{
  display:flex;
  align-items:center;
  gap:8px;
}

.sidebar__refresh-btn{
  background:var(--glass);
  border:1px solid var(--border);
  color:var(--text);
  padding:4px 10px;
  border-radius:6px;
  cursor:pointer;
  font-size:13px;
}

.main-content{
  flex:1;
  padding:18px 24px;
  display:flex;
  flex-direction:column;
  min-width:0;
  min-height:0;
  overflow-y:auto;
  overflow-x:hidden;
}

.app-header{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:12px;
}
.brand{
  font-weight:700;
  font-size:18px;
  color:var(--text);
}
.icon-btn{
  background:var(--glass);
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  border-radius:6px;
  cursor:pointer;
}

.container{
  max-width:1100px;
  margin:0 auto;
  padding:8px;
}
/* B2B: как на странице «Чат» — узкие поля, контент на всю ширину main-content */
body.b2b-page{
  overflow-x:hidden;
}
body.b2b-page .app-layout{
  min-width:0;
  max-width:100%;
}
body.b2b-page .main-content{
  padding:12px 12px;
  min-width:0;
  min-height:0;
  overflow-x:hidden;
  overflow-y:auto;
  max-width:100%;
}
body.b2b-page .container.b2b-layout{
  max-width:none;
  width:100%;
  margin:0;
  padding:0;
  box-sizing:border-box;
  min-width:0;
  max-width:100%;
}
body.b2b-page .b2b-layout .card{
  min-width:0;
  max-width:100%;
}

h1{
  font-size:30px;
  margin:6px 0 12px 0;
  font-weight:800;
  color:var(--text);
}

.chart-wrap{
  height:160px;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
  border-radius:8px;
  padding:8px;
  margin-bottom:8px;
  border:1px solid var(--border);
}
#chart-canvas{width:100%;height:100%;}
.player-report-grid{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.player-report-grid .chart-panel{
  flex:1;
  min-width:320px;
  max-width:calc(50% - 6px);
}
.player-report-grid .chart-wrap{
  height:320px;
}

.filters{margin:8px 0 12px 0;}
select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  padding:10px 12px;
  padding-inline-end:calc(14px + max(10px,5%));
  border-radius:6px;
  border:1px solid var(--border);
  background-color:transparent;
  background-image:var(--select-chevron);
  background-repeat:no-repeat;
  background-size:14px 14px;
  background-position:right max(10px,5%) center;
  color:var(--text);
  font-size:16px;
  cursor:pointer;
}

.tabs{display:flex;gap:8px;margin-bottom:12px;}
.tab-btn{
  background:transparent;
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  border-radius:6px;
  cursor:pointer;
  font-size:16px;
}
.tab-btn.active{background:rgba(59,130,246,0.12);border-color:var(--accent)}

.union-page-head{margin-bottom:18px}
.union-page-eyebrow{
  font-size:12px;
  font-weight:600;
  letter-spacing:0.06em;
  text-transform:uppercase;
  color:var(--muted);
  margin:0 0 10px;
}
.app-platform-switcher{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:14px 18px;
  margin-bottom:10px;
  padding:12px 14px;
  border:1px solid var(--border);
  border-radius:10px;
  background:linear-gradient(180deg, rgba(59,130,246,0.08), transparent);
}
.app-platform-switcher__label{
  font-size:14px;
  font-weight:600;
  color:var(--text);
  flex-shrink:0;
}
.app-platform-tabs{
  display:inline-flex;
  flex-wrap:wrap;
  gap:0;
  padding:4px;
  border-radius:8px;
  background:rgba(0,0,0,0.2);
  border:1px solid var(--border);
}
.app-platform-tab{
  appearance:none;
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:15px;
  font-weight:600;
  padding:10px 20px;
  border-radius:6px;
  cursor:pointer;
  transition:background .15s,color .15s;
}
.app-platform-tab:hover{color:var(--text)}
.app-platform-tab.active{
  background:rgba(59,130,246,0.25);
  color:var(--text);
  box-shadow:0 1px 2px rgba(0,0,0,0.2);
}
.app-page-title{font-size:1.65rem;font-weight:700;margin:6px 0 4px;line-height:1.2}
.app-page-lead{font-size:14px;line-height:1.45;margin:0 0 4px;max-width:52rem}

.report-view-tabs-wrap{margin-top:4px;margin-bottom:12px}
.report-view-tabs-label{
  display:block;
  font-size:12px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:6px;
}
.report-view-tabs.tabs{flex-wrap:wrap}

.result{margin-top:12px}
.upload-log-panel{
  margin-top:12px;
  padding:10px 12px;
  border:1px solid var(--border);
  border-radius:6px;
  background:linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
}
.upload-log-panel__title{
  font-size:13px;
  font-weight:600;
  color:var(--muted);
  margin-bottom:6px;
}
.upload-log-list{
  list-style:none;
  padding:0;
  margin:0;
}
.upload-log-item{
  font-size:13px;
  margin-bottom:4px;
}
.upload-log-item:last-child{
  margin-bottom:0;
}
.upload-log-item--info{
  color:var(--text);
}
.upload-log-item--warning{
  color:var(--accent-2);
  font-weight:600;
}
.upload-log-item--error{
  color:#f87171;
  font-weight:600;
}
.hidden{display:none !important}

.table-wrap{margin-top:8px;border:1px solid var(--border);border-radius:6px;padding:6px;background:linear-gradient(180deg, transparent, rgba(255,255,255,0.01))}
.data-table{width:100%;border-collapse:collapse;font-size:13px;color:var(--text)}
.data-table th,.data-table td{padding:6px 8px;border-bottom:1px dashed rgba(255,255,255,0.02)}
.data-table thead th{background:#071520;font-weight:600;text-align:left}
.data-table tfoot td{font-weight:700;background:#071520}
.data-table .num{text-align:right}
.data-table tbody tr:nth-child(even),
.group-table tbody tr:nth-child(even){
  background:#162431;
}
.data-table tbody td:nth-child(3),
.group-table tbody td:nth-child(3){
  cursor:pointer;
}
.group-table thead th{
  background:#071520;
}
.group-table tfoot td{
  background:#071520;
}

.rows-toggle{margin-top:6px}
.linklike{background:none;border:none;color:var(--accent);cursor:pointer;padding:4px}
.primary{background:var(--accent);border:none;color:#fff;padding:8px 10px;border-radius:6px;cursor:pointer}
.btn-secondary{
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border);
  color:var(--text);
  padding:8px 10px;
  border-radius:6px;
  cursor:pointer;
  font-size:14px;
}
.btn-secondary:hover{
  border-color:rgba(59,130,246,0.45);
  background:rgba(59,130,246,0.12);
}

.progress{
  margin-top:12px;
}
.progress-bar{
  width:100%;
  height:8px;
  border-radius:999px;
  overflow:hidden;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.04);
}
.progress-fill{
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  transition:width .15s ease;
}
.progress-text{
  margin-top:6px;
  text-align:right;
  font-size:13px;
  color:var(--muted);
}

.group-block{margin-top:12px;border-radius:6px;padding:8px;background:linear-gradient(180deg, rgba(255,255,255,0.01), transparent);border:1px solid var(--border)}
.group-heading{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.group-heading .label{font-weight:700;color:var(--text);font-size:22px;margin-bottom:10px;padding-left:5px}
.group-whales .group-heading .label{color:#55a95a}
.group-strong .group-heading .label{color:#4fa6ff}
.group-mid .group-heading .label{color:#f5a623}
.group-small .group-heading .label{color:#f48b11}
.group-tiny .group-heading .label{color:#a95ae2}
.group-dust .group-heading .label{color:#a95555}
.group-table{width:100%;border-collapse:collapse;margin-top:8px}
.group-table th,.group-table td{padding:6px 8px;border-bottom:1px dashed rgba(255,255,255,0.02)}
.group-table th,.group-table td{text-align:center}
.group-totals td{font-weight:700}
.group-kpis{display:flex;gap:12px;margin-top:8px;margin-bottom:20px}
.kpis{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.kpi{background:#051520;padding:8px;border-radius:6px;border:1px solid var(--border);flex:1;min-width:120px}
.kpi-title{font-size:16px;color:var(--muted);margin-bottom:6px}
.kpi-value{
  font-size:20px;
  font-weight:700;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.game-types{margin-bottom:8px;display:flex;flex-wrap:wrap;gap:6px}
.game-type-chip{border-radius:6px;padding:4px 12px;font-size:12px;font-weight:600;color:#fff;display:inline-flex;align-items:center;gap:6px}
.chip-heading{font-size:16px;font-weight:600;color:var(--muted);margin-bottom:4px}
.limit-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:28px}
.limit-chip{border-radius:6px;padding:4px 12px;font-size:14px;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);cursor:default}
.kpis{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.limit-chip{border-radius:6px;padding:4px 12px;font-size:14px;font-weight:600;color:var(--text);background:transparent;border:1px solid var(--border);cursor:default}

.heatmap-container{display:block}
.heatmap-row{display:flex;align-items:center;gap:12px;padding:6px 0;border-bottom:1px solid rgba(255,255,255,0.02)}
.heatmap-club{min-width:220px;color:var(--muted)}
.heatmap-weeks{display:flex;gap:4px;flex:1;flex-wrap:wrap}
.heatmap-cell{width:16px;height:16px;border-radius:4px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.02)}
.heatmap-cell.active{background:linear-gradient(180deg,var(--accent),var(--accent-2));box-shadow:0 0 6px rgba(34,197,94,0.12)}
.heatmap-tooltip{position:fixed;background:#071827;border:1px solid var(--border);padding:6px;border-radius:6px;color:var(--text);z-index:9999}

.modal{position:fixed;left:0;top:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:1000}
.modal-open{overflow:hidden;}
.modal-backdrop{position:absolute;left:0;top:0;width:100%;height:100%;background:rgba(0,0,0,0.85)}
.modal-content{position:relative;background:#08121a;padding:12px;border-radius:8px;min-width:320px;max-width:1200px;width:1000px;z-index:2;border:1px solid var(--border)}
.modal.open{display:flex}
.modal .modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.modal .modal-body{max-height:60vh;overflow:auto}
.modal .modal-footer{display:flex;gap:8px;justify-content:flex-end;margin-top:8px}
.modal .modal-footer.b2b-club-modal-footer{flex-direction:column;align-items:stretch;gap:0}
.b2b-club-modal-footer__actions{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:8px;margin-top:8px}
.b2b-save-progress{margin-bottom:2px}
.b2b-save-progress.hidden{display:none!important}
.b2b-save-progress:not(.hidden){margin-bottom:4px}
.b2b-save-progress__track{height:4px;border-radius:2px;background:rgba(148,163,184,0.28);overflow:hidden;margin-bottom:6px}
.b2b-save-progress__indeterminate{height:100%;width:38%;border-radius:2px;background:linear-gradient(90deg,var(--accent),#60a5fa);animation:b2b-save-progress-slide 1.05s ease-in-out infinite}
@keyframes b2b-save-progress-slide{0%{transform:translateX(-100%)}100%{transform:translateX(320%)}}
.b2b-save-progress__text{display:block;font-size:12px}
#b2b-modal-club.b2b-modal--busy .modal-backdrop,
#b2b-modal-club.b2b-modal--busy [data-close]{pointer-events:none}
#b2b-modal-club.b2b-modal--busy .btn-secondary[data-close]{opacity:.55}
.b2b-intro-filters-hint{font-size:13px;white-space:nowrap}
.modal-content.modal-compact{
  max-width:600px;
  width:600px;
}
.modal-content.modal-wide{
  max-width:920px;
  width:92vw;
}
/* Недельный отчёт по клубам: уже на 40% от modal-wide */
.modal-content.modal-wide.b2b-modal-weekly-batch{
  max-width:552px;
  width:min(55.2vw,552px);
}

.b2b-clubs-app-kpis{margin-top:4px;margin-bottom:4px}
.b2b-clubs-app-kpis .kpi.b2b-club-kpi{flex:0 1 auto;min-width:132px;max-width:280px;text-align:center}
.b2b-clubs-app-kpis .b2b-club-kpi .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi .kpi-value{
  text-align:center;
  width:100%;
}
.b2b-clubs-app-kpis .b2b-club-kpi--total .kpi-title{color:var(--muted)}
.b2b-clubs-app-kpis .b2b-club-kpi--total .kpi-value{color:var(--text)}
.b2b-clubs-app-kpis .b2b-club-kpi--neutral .kpi-title{color:var(--muted)}
.b2b-clubs-app-kpis .b2b-club-kpi--neutral .kpi-value{color:var(--text)}
/* Цвет только фона плашки; текст белый/основной; рамка как у остальных KPI */
.b2b-clubs-app-kpis .b2b-club-kpi--suprema,
.b2b-clubs-app-kpis .b2b-club-kpi--xpoker,
.b2b-clubs-app-kpis .b2b-club-kpi--pppoker,
.b2b-clubs-app-kpis .b2b-club-kpi--poker21,
.b2b-clubs-app-kpis .b2b-club-kpi--clubgg{
  border-color:var(--border);
}
.b2b-clubs-app-kpis .b2b-club-kpi--suprema .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi--suprema .kpi-value,
.b2b-clubs-app-kpis .b2b-club-kpi--xpoker .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi--xpoker .kpi-value,
.b2b-clubs-app-kpis .b2b-club-kpi--pppoker .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi--pppoker .kpi-value,
.b2b-clubs-app-kpis .b2b-club-kpi--poker21 .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi--poker21 .kpi-value,
.b2b-clubs-app-kpis .b2b-club-kpi--clubgg .kpi-title,
.b2b-clubs-app-kpis .b2b-club-kpi--clubgg .kpi-value{
  color:var(--text);
}
.b2b-clubs-app-kpis .b2b-club-kpi--suprema{background:rgba(251,146,60,0.2)}
.b2b-clubs-app-kpis .b2b-club-kpi--xpoker{background:rgba(56,189,248,0.18)}
.b2b-clubs-app-kpis .b2b-club-kpi--pppoker{background:rgba(74,222,128,0.18)}
.b2b-clubs-app-kpis .b2b-club-kpi--poker21{background:rgba(248,113,113,0.18)}
.b2b-clubs-app-kpis .b2b-club-kpi--clubgg{background:rgba(239,68,68,0.28)}
.b2b-clubs-app-kpis .b2b-club-kpi--usd-sum{
  border-color:var(--border);
  background:rgba(148,163,184,0.14);
}
.b2b-clubs-app-kpis .b2b-club-kpi--usd-sum .kpi-title{color:var(--muted)}
.b2b-clubs-app-kpis .b2b-club-kpi--usd-sum .kpi-value{color:var(--text)}
.b2b-intro-filters{display:flex;flex-wrap:wrap;align-items:center;gap:8px 12px;margin-top:12px}
/* Клубные сделки: фильтры в одну строку (узкие поля + гориз. прокрутка на узком экране) */
.b2b-intro-filters--clubs-compact{
  flex-wrap:nowrap;
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  gap:8px;
  padding-bottom:4px;
  max-width:100%;
}
.b2b-intro-filters--clubs-compact .b2b-clubs-daterange{flex-shrink:0}
.b2b-intro-filters--clubs-compact input.b2b-clubs-filter-date{
  min-width:9rem;
  max-width:11rem;
}
.b2b-intro-filters--clubs-compact .b2b-clubs-search{
  min-width:100px;
  max-width:min(200px,32vw);
  flex:0 1 160px;
}
.b2b-intro-filters--clubs-compact #b2b-clubs-filter-app,
.b2b-intro-filters--clubs-compact .b2b-clubs-filter-manager,
.b2b-intro-filters--clubs-compact .b2b-clubs-filter-source{
  min-width:108px;
  max-width:min(190px,30vw);
  flex:0 1 auto;
}
.b2b-clubs-daterange{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:6px 10px;
  padding:6px 12px;
  border:1px solid var(--border);
  border-radius:8px;
  background:linear-gradient(180deg, rgba(15,23,42,0.55), rgba(15,23,42,0.35));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}
.b2b-clubs-daterange-label{
  color:var(--muted);
  font-size:12px;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:0.06em;
}
.b2b-clubs-daterange-inputs{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.b2b-clubs-daterange-sep{color:var(--muted);opacity:0.85;user-select:none;font-size:13px}
input.b2b-clubs-filter-date{
  min-width:10.75rem;
  max-width:100%;
}
.b2b-intro-filters label{color:var(--muted);font-size:14px;display:inline-flex;align-items:center;gap:6px}
.b2b-intro-filters select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-color:var(--glass);
  background-image:var(--select-chevron);
  background-repeat:no-repeat;
  background-size:14px 14px;
  background-position:right max(8px,5%) center;
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  padding-inline-end:calc(12px + max(8px,5%));
  border-radius:6px;
  font-size:14px;
  font-family:inherit;
  color-scheme:dark;
  cursor:pointer;
}
.b2b-intro-filters input[type=date],
.b2b-intro-filters input[type=text],
.b2b-intro-filters input[type=search]{
  background:var(--glass);
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  border-radius:6px;
  font-size:14px;
  font-family:inherit;
  color-scheme:dark;
}
.b2b-clubs-search{min-width:200px;max-width:min(360px,100%);flex:1 1 220px}
.b2b-clubs-filter-manager{min-width:180px;max-width:min(280px,100%)}
.b2b-intro-filters input[type=date]::-webkit-calendar-picker-indicator{
  filter:invert(1);
  opacity:0.65;
  cursor:pointer;
}
.b2b-kpis{margin-top:16px;margin-bottom:0}
/* Плашка «Общие расходы» на странице рекламы: как kpis дэшборда, без растягивания на всю ширину */
.b2b-ad-kpis-row{margin-top:0;margin-bottom:12px}
.b2b-ad-kpi-total{flex:0 1 auto;min-width:200px;max-width:360px}
.b2b-kpi-tile{
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.b2b-kpi-text{flex:1;min-width:0;display:flex;flex-direction:column;align-items:stretch}
.b2b-kpi-text .kpi-title{margin-bottom:6px}
.b2b-kpi-more-btn{
  flex-shrink:0;
  align-self:center;
  margin:0;
  background:transparent;
  border:1px solid rgba(148,163,184,0.38);
  color:var(--text);
  font-size:13px;
  font-weight:500;
  padding:6px 12px;
  border-radius:6px;
  cursor:pointer;
  font-family:inherit;
  white-space:nowrap;
  line-height:1.2;
  transition:border-color 0.15s ease,background 0.15s ease;
}
.b2b-kpi-more-btn:hover{
  border-color:rgba(148,163,184,0.55);
  background:rgba(255,255,255,0.04);
}
.b2b-kpi-more-btn:focus-visible{
  outline:2px solid rgba(59,130,246,0.5);
  outline-offset:2px;
}
.b2b-modal-chart .modal-body{max-height:min(78vh,900px)}
.b2b-modal-kpis-row{margin-bottom:12px}
.b2b-chart-wrap{position:relative;height:240px;width:100%;margin-top:4px}
.b2b-chart-wrap--tall{height:320px}
.b2b-kpi-mini{min-width:140px;flex:0 1 auto}
.b2b-manager-totals-wrap .kpi{flex:0 1 200px}
.b2b-btn-columns-icon{display:inline-flex;align-items:center;justify-content:center;padding:8px}
.b2b-load-more-wrap{margin-top:12px;text-align:center}
.b2b-load-more-wrap.hidden{display:none !important}
.b2b-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px}
.b2b-toolbar h2{margin:0}
.b2b-toolbar__actions{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.b2b-modal-weekly-batch-body.b2b-form-grid{gap:0}
.b2b-modal-weekly-batch-body > .form-group:nth-child(-n+3){margin-bottom:10px}
.b2b-week-picker-shell{position:relative;display:block}
.b2b-week-input-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;opacity:0;pointer-events:none}
.b2b-week-picker-face{width:100%;text-align:left;padding:8px 10px;border:1px solid var(--border);border-radius:8px;background:var(--glass);color:var(--text);font:inherit;font-weight:500;line-height:1.4;cursor:pointer;transition:border-color 0.15s}
.b2b-week-picker-face:hover{border-color:var(--muted)}
.b2b-weekly-batch-clubs-list{list-style:none;margin:0;padding:4px 8px;max-height:min(52vh,420px);overflow:auto;border:1px solid var(--border);border-radius:8px;background:var(--glass)}
.b2b-weekly-batch-club-row{display:flex;align-items:center;justify-content:space-between;gap:10px 14px;padding:6px 2px;border-bottom:1px solid var(--border)}
.b2b-weekly-batch-club-row:last-child{border-bottom:none}
.b2b-weekly-batch-club-name{flex:1;min-width:0;font-weight:500;font-size:15px;display:flex;flex-wrap:wrap;align-items:center;gap:6px}
.b2b-weekly-batch-exists-badge{font-size:11px;font-weight:600;color:var(--accent-2);white-space:nowrap}
.b2b-weekly-batch-club-row--exists .b2b-weekly-batch-rake-field{opacity:0.92;cursor:not-allowed}
.b2b-weekly-batch-rake-field{
  display:flex;
  align-items:center;
  flex:0 0 180px;
  width:180px;
  max-width:180px;
  gap:6px;
  padding:6px 8px;
  border:1px solid var(--border);
  border-radius:6px;
  background:var(--glass);
  box-sizing:border-box;
}
.b2b-weekly-batch-rake-field .b2b-weekly-batch-rake{
  flex:1;
  min-width:0;
  border:none;
  background:transparent;
  padding:0;
  margin:0;
  font:inherit;
  font-size:14px;
  line-height:1.25;
  color:var(--text);
  color-scheme:dark;
}
.b2b-weekly-batch-rake-suffix{flex-shrink:0;font-size:13px;font-weight:600;color:var(--muted);line-height:1}
.b2b-weekly-batch-result{
  margin-top:12px;padding:12px 14px;border-radius:10px;border:1px solid var(--border);
  background:rgba(46,160,130,0.12);
}
.b2b-weekly-batch-result.b2b-weekly-batch-result--partial{
  background:rgba(210,160,60,0.14);
}
.b2b-weekly-batch-result.b2b-weekly-batch-result--error{
  background:rgba(200,80,80,0.14);
}
.b2b-weekly-batch-result-inner{display:flex;flex-direction:column;gap:10px;align-items:flex-start}
.b2b-weekly-batch-result-text{margin:0;font-size:15px;line-height:1.45;font-weight:600;color:var(--text)}
.b2b-weekly-batch-result-errors{
  margin:0;padding:0 0 0 18px;font-size:13px;line-height:1.4;color:var(--text);max-height:160px;overflow:auto;width:100%;box-sizing:border-box
}
.b2b-weekly-batch-result-errors li{margin:2px 0}
.b2b-filters select{
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
  background-color:var(--glass);
  background-image:var(--select-chevron);
  background-repeat:no-repeat;
  background-size:14px 14px;
  background-position:right max(8px,5%) center;
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  padding-inline-end:calc(12px + max(8px,5%));
  border-radius:6px;
  color-scheme:dark;
  cursor:pointer;
}
.b2b-filters input[type=date]{
  background:var(--glass);
  border:1px solid var(--border);
  color:var(--text);
  padding:6px 8px;
  border-radius:6px;
  color-scheme:dark;
}
.b2b-inline-check{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--muted)}
.b2b-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.b2b-form-grid--single{grid-template-columns:1fr}
.b2b-span-2{grid-column:span 2}
.b2b-columns-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}
.b2b-reports-scroll{
  overflow-x:auto;
  -webkit-overflow-scrolling:touch;
  width:100%;
  max-width:100%;
  min-width:0;
  display:block;
}
.b2b-reports-scroll .b2b-reports-table,
.b2b-reports-scroll .b2b-clubs-table{table-layout:fixed;width:max-content;min-width:100%}
/* как отчёты по неделям / group-table — заголовки и ячейки по центру */
.b2b-reports-scroll .b2b-reports-table thead th,
.b2b-reports-scroll .b2b-reports-table tbody td,
.b2b-reports-scroll .b2b-clubs-table thead th,
.b2b-reports-scroll .b2b-clubs-table tbody td{
  text-align:center;
}
.b2b-reports-scroll .b2b-reports-table th.b2b-th-resizable,
.b2b-reports-scroll .b2b-reports-table td,
.b2b-reports-scroll .b2b-clubs-table th.b2b-th-resizable,
.b2b-reports-scroll .b2b-clubs-table td{padding:8px 10px;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}
.b2b-reports-scroll .b2b-audit-table thead th,
.b2b-reports-scroll .b2b-audit-table tbody td{text-align:left}
.b2b-audit-desc{max-width:min(560px,95vw);white-space:normal;line-height:1.35;font-size:0.95em}
.b2b-th-resizable .b2b-th-label{display:block;overflow:hidden;text-overflow:ellipsis;padding-right:8px;text-align:center}
.b2b-resize-handle{position:absolute;top:0;right:0;width:10px;height:100%;cursor:col-resize;user-select:none;z-index:2;touch-action:none}
.b2b-resize-handle:hover{background:rgba(59,130,246,0.2)}
.b2b-col-modal-body{display:flex;flex-direction:column;gap:6px;max-height:min(60vh,420px);overflow-y:auto;padding-right:4px}
.b2b-col-sort-row{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:6px;border:1px solid var(--border);background:var(--glass)}
.b2b-col-sort-row.b2b-dragging{opacity:0.55}
.b2b-col-drag{cursor:grab;color:var(--muted);font-size:14px;line-height:1;user-select:none;flex-shrink:0}
.b2b-col-sort-row label{margin:0;flex:1;display:flex;align-items:center;gap:8px;cursor:pointer}
.modal-content.b2b-modal-columns-wrap.modal-compact{max-width:720px;width:92vw}
/* date inputs в модалке отчёта — тёмная тема (нативный виджет) */
body.b2b-page #b2b-modal-report input[type=date]{
  color-scheme:dark;
  background:var(--glass);
  color:var(--text);
}
body.b2b-page #b2b-modal-report input[type=date]::-webkit-calendar-picker-indicator{
  filter:invert(1);
  opacity:0.65;
  cursor:pointer;
}
/* Недельный выбор: тот же нативный виджет, что и у date */
body.b2b-page #b2b-modal-weekly-batch input[type=week],
body.b2b-page .b2b-week-input-hidden{
  color-scheme:dark;
}
.form-group--check{padding-top:24px}
.sidebar__link--active{border-color:rgba(59,130,246,0.5);background:rgba(59,130,246,0.12)}
.b2b-hint{font-size:0.85rem;margin:0 0 8px 0}

/* club modal chart controls */
.club-metric-tabs{display:flex;gap:8px;margin-bottom:8px}
.metric-tab{background:transparent;border:1px solid rgba(255,255,255,0.2);color:var(--text);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:14px}
.metric-tab.active{background:rgba(255,255,255,0.05);border-color:var(--accent);color:#fff}

/* main chart metric controls */
.chart-controls{display:flex;gap:8px;margin:8px 0 8px}
.chart-metric-tab{background:transparent;border:1px solid rgba(255,255,255,0.2);color:var(--text);padding:6px 10px;border-radius:6px;cursor:pointer;font-size:14px}
.chart-metric-tab.active{background:rgba(59,130,246,0.15);border-color:var(--accent);color:#fff}

button:disabled{opacity:0.6;cursor:not-allowed}

/* small screens */
@media (max-width:700px){
  .container{padding:10px}
  body.b2b-page .main-content{padding:10px 10px}
  h1{font-size:28px}
  .heatmap-club{min-width:120px}
  .chart-wrap{height:140px}
}

/* Страница чата на мобильном: сайдбар скрыт, контент на весь экран */
@media (max-width:768px){
  body.page-chat .sidebar{
    display:none
  }
  body.page-chat .main-content{
    flex:1;
    min-width:0;
  }
}

/* utility */
.no-frame{border:0;padding:0}

/* Card and form styles */
.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px 24px;
  margin-bottom:16px;
}

.card h1{
  font-size:24px;
  margin:0 0 8px 0;
  font-weight:700;
}

.card h2{
  font-size:20px;
  margin:0 0 12px 0;
  font-weight:700;
}.card p.muted{
  margin:0 0 20px 0;
  color:var(--muted);
  font-size:14px;
}

.form-inline{
  display:flex;
  flex-direction:column;
  gap:16px;
  margin-top:20px;
}

.form-group{
  display:flex;
  flex-direction:column;
  gap:8px;
}

.form-group label{
  font-size:14px;
  font-weight:500;
  color:var(--text);
}.form-group input{
  padding:10px 12px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  font-size:15px;
  transition:border-color 0.2s ease;
}

.form-group input::placeholder{
  color:var(--muted);
  opacity:0.6;
}

.form-group input:focus{
  outline:none;
  border-color:var(--accent);
  background:rgba(255,255,255,0.03);
}

.form-group input:hover:not(:focus){
  border-color:rgba(255,255,255,0.1);
}

.form-group textarea{
  padding:10px 12px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  font-size:15px;
  font-family:inherit;
  line-height:1.45;
  transition:border-color 0.2s ease;
  min-height:80px;
  resize:vertical;
}

.form-group textarea::placeholder{
  color:var(--muted);
  opacity:0.6;
}

.form-group textarea:focus{
  outline:none;
  border-color:var(--accent);
  background:rgba(255,255,255,0.03);
}

.form-group textarea:hover:not(:focus){
  border-color:rgba(255,255,255,0.1);
}

#user-create-message{
  font-size:14px;
  min-height:20px;
  margin-top:12px;
}

#user-create-message:not(:empty){
  padding:10px 14px;
  border-radius:var(--radius);
  border:1px solid;
}#user-create-message.success{
  background:rgba(34,197,94,0.1);
  border-color:rgba(34,197,94,0.2);
  color:#86efac;
}#user-create-message.error{
  background:rgba(239,68,68,0.1);
  border-color:rgba(239,68,68,0.2);
  color:#fca5a5;
}

/* Users page */
.users-actions-cell{
  text-align:right;
  white-space:nowrap;
}

.user-edit-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:4px 10px;
  font-size:13px;
}.user-edit-btn span{
  font-size:14px;
}

/* Analytics */
.analytics-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.analytics-quick{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.analytics-quick-btn{
  background:transparent;
  border:1px solid rgba(255,255,255,0.2);
  color:var(--text);
  padding:6px 10px;
  border-radius:6px;
  cursor:pointer;
  font-size:13px;
}

.analytics-quick-btn.active{
  background:rgba(59,130,246,0.15);
  border-color:var(--accent);
  color:#fff;
}.analytics-filters{
  margin-top:8px;
  margin-bottom:12px;
}

.analytics-date-range{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}

.analytics-date-range input{
  padding:8px 10px;
  background:var(--glass);
  border:1px solid var(--border);
  border-radius:6px;
  color:var(--text);
}

.analytics-date-sep{
  color:var(--muted);
}.analytics-accounts{
  margin-top:8px;
  margin-bottom:16px;
}

.analytics-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.analytics-chip{
  border:1px solid var(--border);
  background:transparent;
  color:var(--text);
  padding:6px 10px;
  border-radius:999px;
  font-size:13px;
  cursor:pointer;
}.analytics-chip.active{
  background:rgba(59,130,246,0.15);
  border-color:var(--accent);
  color:#fff;
}

.analytics-chart{
  position:relative;
  min-height:320px;
}

.analytics-empty{
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  padding:10px 0 4px;
  text-align:center;
}

.analytics-leads-summary{
  margin-top:16px;
  padding-top:12px;
  border-top:1px solid var(--border);
}

#analytics-leads-summary-subtitle{
  margin-bottom:8px;
}

.analytics-total-pill{
  display:inline-flex;
  align-items:center;
  margin-bottom:10px;
  padding:6px 10px;
  border:1px solid var(--border);
  border-radius:999px;
  background:rgba(59,130,246,0.12);
  color:var(--text);
  font-size:13px;
  font-weight:600;
}.analytics-summary-row{
  cursor:pointer;
}

.analytics-summary-row:hover{
  background:rgba(59,130,246,0.12);
}

.analytics-dialogs-modal-content{
  width:min(980px, 94vw);
  max-width:980px;
}

.analytics-dialog-title{
  font-weight:600;
}

.analytics-dialog-row{
  cursor:pointer;
}

.analytics-dialog-row:hover{
  background:rgba(59,130,246,0.12);
}

/* Модалка недельных отчётов: вложенный input не наследует рамку .form-group input */
.b2b-modal-weekly-batch-body .b2b-weekly-batch-rake-field .b2b-weekly-batch-rake,
.b2b-modal-weekly-batch-body .b2b-weekly-batch-rake-field .b2b-weekly-batch-rake:hover:not(:focus),
.b2b-modal-weekly-batch-body .b2b-weekly-batch-rake-field .b2b-weekly-batch-rake:focus{
  padding:0;
  border:none;
  background:transparent;
  box-shadow:none;
  outline:none;
}
.b2b-modal-weekly-batch-body .b2b-weekly-batch-rake-field:focus-within{
  border-color:var(--accent);
  background:rgba(255,255,255,0.03);
}
