/* ============================
   ✅ GLOBAL PAGE SCROLL (FIX)
   ============================ */

html, body{
  height: 100%;
}

body{
  overflow-y: auto;     /* ✅ включаем скролл страницы */
  overflow-x: hidden;
}

/* если у тебя есть общий класс страницы (часто .dash) */
body.dash{
  overflow-y: auto;     /* ✅ на всякий случай */
  overflow-x: hidden;
}

/* если где-то есть контейнер, который "душит" скролл (часто .app/.container/.main) */
#app, .app, .page, .content, main{
  min-height: 100vh;    /* ✅ пусть растёт по контенту */
}

/* ============================
   ANALYSIS LAYOUT
   ============================ */

.analysis-shell{
  display: grid;
  grid-template-columns: 1.3fr 0.9fr;
  gap: 14px;
  padding: 14px;

  /* ✅ важно: не задаём height тут, чтобы страница могла увеличиваться */
  align-content: start;
}

.panel{
  padding: 14px;
}

.kpi-grid{
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.kpi-card{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 12px;
}

.kpi-label{ color: var(--muted); font-size: 12px; }
.kpi-val{ font-size: 20px; font-weight: 900; margin-top: 6px; }
.kpi-sub{ color: var(--muted); font-size: 12px; margin-top: 4px; }

.chart-card{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 12px;
  margin-bottom: 12px;
}

.chart-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 8px;
}
.chart-title{ font-weight: 900; }
.chart-actions{ display:flex; gap:8px; }

.btn.sm{ padding: 6px 10px; border-radius: 10px; font-size: 12px; }

.table-card{
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 14px;
  padding: 12px;
  margin-bottom: 12px;
}
.table-head{ display:flex; justify-content:space-between; margin-bottom: 8px; }
.table-title{ font-weight: 900; }

.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.muted{ color: var(--muted); }
.mini-list{ padding: 6px; }
.mini-title{ font-weight: 900; margin-bottom: 6px; }
.mini-items{ font-size: 13px; line-height: 1.4; }

/* ============================
   COLORS FOR CHARTS
   ============================ */

:root{
  --green: #22c55e;
  --red: #ef4444;
  --chart-grid: rgba(255,255,255,0.12);
  --pos: var(--green);
  --neg: var(--red);
  --chart-axis: rgba(255,255,255,0.55);
  --card-glow: rgba(255,255,255,0.06);
}

/* pro visual for KPI */
.kpi-card{
  position: relative;
  overflow: hidden;
}
.kpi-card::before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(600px 120px at 10% 0%, var(--card-glow), transparent 55%);
  pointer-events:none;
}
.kpi-card .kpi-val{
  letter-spacing: -0.02em;
}

.pos{ color: var(--pos); }
.neg{ color: var(--neg); }

/* chart hint/badges */
.chart-hint{
  color: var(--muted);
  font-size: 12px;
  margin-top: 6px;
  display:flex;
  justify-content:space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding: 4px 8px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.78);
  font-size: 12px;
  line-height: 1;
}

.badge.green{ border-color: rgba(34,197,94,0.35); color: rgba(34,197,94,0.9); background: rgba(34,197,94,0.08); }
.badge.red{ border-color: rgba(239,68,68,0.35); color: rgba(239,68,68,0.9); background: rgba(239,68,68,0.08); }

/* canvas */
canvas{
  width: 100%;
  display: block;
  border-radius: 12px;
  background: rgba(0,0,0,0.06);
}

/* tables */
.table-card table{
  width: 100%;
  border-collapse: collapse;
}
.table-card th,
.table-card td{
  padding: 8px 10px;
  border-top: 1px solid rgba(255,255,255,0.06);
  vertical-align: top;
}
.table-card thead th{
  border-top: none;
  color: rgba(255,255,255,0.72);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.table-card tbody tr:hover{
  background: rgba(255,255,255,0.03);
}

/* buttons */
.btn.sm{
  border: 1px solid rgba(255,255,255,0.10);
  background: rgba(255,255,255,0.04);
}
.btn.sm:hover{
  background: rgba(255,255,255,0.07);
}
.btn.sm:active{
  transform: translateY(1px);
}

/* ============================
   RESPONSIVE
   ============================ */

@media (max-width: 980px){
  .analysis-shell{
    grid-template-columns: 1fr;
  }
  .split{
    grid-template-columns: 1fr;
  }
  .kpi-grid{
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 520px){
  .kpi-grid{
    grid-template-columns: 1fr;
  }
}