/* =========================================================================
   screens/panel.css — layout + sekcje specyficzne dla ekranu panelu.
   Mieszanka: struktura realnego panelu klienta + estetyka Codex premium.
   ========================================================================= */

/* Tytul ekranu + eyebrow (nad h1) */
.panel-title {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-inner);
  margin-bottom: var(--space-section);
}
.panel-title h1 {
  font-size: var(--fs-3xl);
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.01em;
}
.panel-title .eyebrow { margin-bottom: 8px; }
.panel-title .meta {
  font-size: var(--fs-sm);
  color: var(--text-tertiary);
  white-space: nowrap;
}
@media (max-width: 720px) {
  .panel-title {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .panel-title h1 { font-size: var(--fs-2xl); }
  .panel-title .meta { white-space: normal; }
}

/* KPI row — placowany na gorze main column */
.panel-kpi-row { margin-bottom: var(--space-section); }

/* Moduly srednie (Instalacja, Energia) — obok siebie na desktop.
   align-items: stretch + karty dziecka 100% wysokości = równy rozmiar boksów. */
.panel-modules {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-inner);
  margin-bottom: var(--space-section);
  align-items: stretch;
}
.panel-modules > * { display: flex; }
.panel-modules > * > .card { flex: 1; width: 100%; }
@media (max-width: 900px) {
  .panel-modules { grid-template-columns: 1fr; }
}

/* Charts — kazdy wykres w swojej karcie */
.panel-charts {
  display: flex;
  flex-direction: column;
  gap: var(--space-inner);
  margin-bottom: var(--space-section);
}

/* Tabele — w pionie */
.panel-tables {
  display: flex;
  flex-direction: column;
  gap: var(--space-inner);
}

/* Sidebar specifics — kontrolki + summary + CTA.
   Wyraźnie wyróżniony box (brand violet glass), żeby strefa konfiguracji była
   wizualnie odrębna od panelu wyników po lewej. Bez scrollbara — user
   scrolluje całą stronę, sticky pozycja i tak zapewnia widoczność. */
.panel-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-inner);
  padding: var(--space-inner);
  background:
    linear-gradient(180deg, rgba(168,85,247,0.05), rgba(168,85,247,0.02)),
    rgba(17,17,26,0.65);
  border: 1px solid rgba(168,85,247,0.22);
  border-radius: var(--radius-lg);
  box-shadow: 0 8px 24px rgba(0,0,0,0.35), inset 0 1px 0 rgba(255,255,255,0.03);
}
.panel-sidebar .sidebar-header {
  padding: 4px 2px 8px;
  border-bottom: 1px solid rgba(168,85,247,0.15);
  margin-bottom: 4px;
}
.panel-sidebar .sidebar-header .eyebrow {
  margin-bottom: 4px;
  color: var(--accent-primary);
}
.panel-sidebar .sidebar-header h3 {
  font-size: var(--fs-lg);
  font-weight: 700;
  color: var(--text-primary);
}

/* Sticky bottom KPI mobile — Gemini-UX P0 (release plan 2026-04-29 decyzja 5).
   Na ≤900px sidebar siedzi NA KONCU strony; user scrolluje przez wykresy +
   tabele + coverage zanim zobaczy wynik. Wyciagamy summary+cta-next z fluid
   layoutu i przyklejamy do dolu viewportu — slider w sidebarze powyzej i tak
   updateuje go przez store, wiec user widzi efekt w czasie rzeczywistym.
   Pozostawiamy oryginalny block w sidebarze dla desktop (pasek nieaktywny). */
@media (max-width: 900px) {
  .sidebar-conversion-block {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 50;
    padding: 12px 16px calc(12px + env(safe-area-inset-bottom, 0px));
    background:
      linear-gradient(180deg, rgba(17,17,26,0.85) 0%, rgba(10,10,15,0.96) 100%);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid rgba(168,85,247,0.28);
    box-shadow: 0 -8px 24px rgba(0,0,0,0.45);
    /* Kompresja: na desktop summary ma min-height 160px — na sticky barze za duzo. */
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  /* Spacer w sidebarze zeby content nie wpadal pod sticky pasek przy konxu strony.
     Wysokosc orientacyjna ~140px (summary 90 + cta 40 + padding 24 + safe-area). */
  .panel-sidebar { padding-bottom: 140px; }
  /* Wewnatrz sticky paska summary moze byc plaski (label + big w jednym wierszu). */
  .sidebar-conversion-block .summary {
    min-height: 0;
  }
  .sidebar-conversion-block .summary .label { min-height: 0; margin-bottom: 2px; }
  .sidebar-conversion-block .summary .big   { min-height: 0; font-size: var(--fs-2xl); }
  .sidebar-conversion-block .summary .hint  { min-height: 0; font-size: var(--fs-xs); }
}
