/*
 * Viewport + Dash root: full browser width. (Half-screen layouts often come from a flex sibling or
 * Mantine max-width; we also moved ``dcc.Store`` out of the layout flex column in ``shell.py``.)
 */
html,
body {
  width: 100%;
  max-width: none;
  margin: 0;
  box-sizing: border-box;
}

/*
 * Cap content width on very wide monitors so the dashboard sits centered with balanced side margins.
 * Override in DevTools or a later rule: ``--asky-shell-content-max-width: none`` for full-bleed.
 */
:root {
  --asky-shell-content-max-width: 1680px;
}

#react-entry-point,
._dash-app-content {
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
}

/* First paint + hydrated tree — Dash keeps a wrapper ``div`` under ``#react-entry-point`` */
#react-entry-point > div {
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
}

/*
 * Dash Pages renders each route into ``#_pages_content``. If this outlet does not stretch,
 * multipage layouts look like a narrow column with empty space on the right.
 */
#_pages_content {
  width: 100% !important;
  max-width: none !important;
  min-width: 0 !important;
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  align-self: stretch !important;
}

/* Dash layout root — matches ``full_layout`` wrapper in ``app.py`` */
.asky-app-root {
  width: 100%;
  max-width: none;
  min-width: 0;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/*
 * MantineProvider follows Location — provider + first inner wrapper must span width (Mantine may
 * inject nodes with max-width from theme defaults).
 */
.asky-app-root > div:last-child {
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
  flex: 1 1 auto;
  align-self: stretch;
}

.asky-app-root > div:last-child > div:first-child {
  width: 100% !important;
  max-width: none !important;
  min-width: 0;
  box-sizing: border-box;
}

/* Chat transcript scroll — fills remaining card height (flex chain from viewport shell) */
.asky-chat-scroll-wrap {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.asky-chat-scroll-wrap .mantine-ScrollArea-root {
  flex: 1 1 auto;
  min-height: 0;
}

/* Conversation panel on Forecasts — subtle frame; stronger when typing/focused inside */
.asky-chat-conversation {
  border: 1px solid var(--mantine-color-default-border, var(--mantine-color-gray-4));
  border-radius: var(--mantine-radius-md);
  padding: var(--mantine-spacing-md);
  min-width: 0;
  transition:
    border-color 0.15s ease,
    box-shadow 0.15s ease;
}

.asky-chat-conversation:focus-within {
  border-color: var(--mantine-color-blue-filled);
  box-shadow: 0 0 0 1px var(--mantine-color-blue-filled);
}

/* Empty state */
.asky-chat-empty {
  text-align: center;
  padding-top: var(--mantine-spacing-xl);
  padding-bottom: var(--mantine-spacing-xl);
}

[data-mantine-color-scheme="light"] .asky-chat-empty {
  color: var(--mantine-color-gray-7);
}

[data-mantine-color-scheme="dark"] .asky-chat-empty {
  color: var(--mantine-color-gray-5);
}

/*
 * Message bubbles — colors track Mantine theme via data-mantine-color-scheme.
 * User = blue (your messages). Assistant = teal (distinct from blue).
 */
.asky-chat-bubble {
  border-radius: var(--mantine-radius-md);
  border-style: solid;
  border-width: 1px;
  box-shadow: var(--mantine-shadow-xs);
}

/* ----- Light scheme ----- */
[data-mantine-color-scheme="light"] .asky-chat-bubble--user {
  background-color: var(--mantine-color-blue-1);
  color: var(--mantine-color-dark-9);
  border-color: var(--mantine-color-blue-4);
}

[data-mantine-color-scheme="light"] .asky-chat-bubble__label--user {
  color: var(--mantine-color-blue-8);
}

[data-mantine-color-scheme="light"] .asky-chat-bubble--assistant {
  background-color: var(--mantine-color-teal-0);
  color: var(--mantine-color-teal-9);
  border-color: var(--mantine-color-teal-4);
}

[data-mantine-color-scheme="light"] .asky-chat-bubble__label--assistant {
  color: var(--mantine-color-teal-8);
}

/* ----- Dark scheme (high contrast body text on saturated fills) ----- */
[data-mantine-color-scheme="dark"] .asky-chat-bubble--user {
  background-color: var(--mantine-color-blue-9);
  color: var(--mantine-color-blue-0);
  border-color: var(--mantine-color-blue-6);
}

[data-mantine-color-scheme="dark"] .asky-chat-bubble__label--user {
  color: var(--mantine-color-blue-3);
}

[data-mantine-color-scheme="dark"] .asky-chat-bubble--assistant {
  background-color: var(--mantine-color-teal-9);
  color: var(--mantine-color-teal-0);
  border-color: var(--mantine-color-teal-7);
}

[data-mantine-color-scheme="dark"] .asky-chat-bubble__label--assistant {
  color: var(--mantine-color-teal-3);
}

/* Fallback if scheme attribute is missing (use OS preference) */
@media (prefers-color-scheme: dark) {
  :root:not([data-mantine-color-scheme]) .asky-chat-bubble--user {
    background-color: var(--mantine-color-blue-9);
    color: var(--mantine-color-blue-0);
    border-color: var(--mantine-color-blue-6);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble__label--user {
    color: var(--mantine-color-blue-3);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble--assistant {
    background-color: var(--mantine-color-teal-9);
    color: var(--mantine-color-teal-0);
    border-color: var(--mantine-color-teal-7);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble__label--assistant {
    color: var(--mantine-color-teal-3);
  }
}

@media (prefers-color-scheme: light) {
  :root:not([data-mantine-color-scheme]) .asky-chat-bubble--user {
    background-color: var(--mantine-color-blue-1);
    color: var(--mantine-color-dark-9);
    border-color: var(--mantine-color-blue-4);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble__label--user {
    color: var(--mantine-color-blue-8);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble--assistant {
    background-color: var(--mantine-color-teal-0);
    color: var(--mantine-color-teal-9);
    border-color: var(--mantine-color-teal-4);
  }

  :root:not([data-mantine-color-scheme]) .asky-chat-bubble__label--assistant {
    color: var(--mantine-color-teal-8);
  }
}

.asky-chat-bubble__label {
  display: block;
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 0.35rem;
}

.asky-chat-bubble__body {
  font-size: var(--mantine-font-size-sm);
  line-height: 1.55;
  white-space: pre-wrap;
  word-break: break-word;
}

/* Forecasts canvas matrix — left accordion column height */
.asky-left-column {
  overflow: auto;
}

/*
 * Left accordion (m[0,0]) — Mantine v7 may hash classes; substring selectors stay stable.
 * Dark mode: collapsed section titles must read as near-white (labels often ignore parent color).
 */
.asky-left-column [class*="Accordion-label"] {
  font-weight: 600;
}

[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="false"],
[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="false"] [class*="Accordion-label"] {
  color: var(--mantine-color-white, #fff);
}

[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="true"],
[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="true"] [class*="Accordion-label"] {
  color: var(--mantine-color-gray-0);
}

[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-control"][aria-expanded="false"],
[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-control"][aria-expanded="false"] [class*="Accordion-label"] {
  color: var(--mantine-color-dark-6);
}

[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-control"][aria-expanded="true"],
[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-control"][aria-expanded="true"] [class*="Accordion-label"] {
  color: var(--mantine-color-dark-9);
}

.asky-left-column [class*="Accordion-chevron"] {
  color: var(--mantine-color-dimmed);
}

[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="false"] [class*="Accordion-chevron"] {
  color: rgba(255, 255, 255, 0.72);
}

[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-control"][aria-expanded="true"] [class*="Accordion-chevron"] {
  color: rgba(255, 255, 255, 0.85);
}

/* Mantine sometimes omits aria-expanded on the control; item ``data-active`` marks the open panel */
[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-item"]:not([data-active]) [class*="Accordion-control"],
[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-item"]:not([data-active]) [class*="Accordion-label"] {
  color: var(--mantine-color-white, #fff);
}

[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-item"][data-active] [class*="Accordion-control"],
[data-mantine-color-scheme="dark"] .asky-left-column [class*="Accordion-item"][data-active] [class*="Accordion-label"] {
  color: var(--mantine-color-gray-0);
}

[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-item"]:not([data-active]) [class*="Accordion-control"],
[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-item"]:not([data-active]) [class*="Accordion-label"] {
  color: var(--mantine-color-dark-6);
}

[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-item"][data-active] [class*="Accordion-control"],
[data-mantine-color-scheme="light"] .asky-left-column [class*="Accordion-item"][data-active] [class*="Accordion-label"] {
  color: var(--mantine-color-dark-9);
}

.asky-left-column [class*="Accordion-panel"] {
  color: var(--mantine-color-text);
}

/* Forecasts page title — avoid low-contrast grey if tokens drift */
.asky-page-title {
  color: var(--mantine-color-text);
}

/*
 * Shell + Forecasts canvas — viewport fill using flex + CSS Grid ``fr`` rows (no magic px heights).
 * Mirrors Mantine AppShell “main grows below header”; spacing uses Mantine tokens (--mantine-spacing-*).
 *
 * Use height + overflow clipping on the shell (not min-height alone) so the canvas cannot extend under
 * the nav row when the matrix wants more space than fits on screen.
 */
.asky-shell-root {
  display: flex;
  flex-direction: column;
  height: 100dvh;
  max-height: 100dvh;
  min-height: 0;
  overflow: hidden;
  box-sizing: border-box;
  width: 100%;
  max-width: none;
}

.asky-shell-root > .asky-layout-root {
  flex: 1 1 0;
  min-height: 0;
  max-height: 100%;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-width: 0;
}

/* Layout root: flex column; inner ``asky-shell-container`` is plain ``html.Div`` (no Mantine Container max-width). */
.asky-layout-root {
  flex: 1 1 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

.asky-layout-root > .asky-shell-container {
  flex: 1 1 0;
  min-height: 0;
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: min(var(--asky-shell-content-max-width), 100%);
  margin-left: auto;
  margin-right: auto;
  box-sizing: border-box;
  padding-top: var(--mantine-spacing-xs);
  padding-bottom: var(--mantine-spacing-md);
  padding-left: clamp(0.35rem, 1.1vw, 0.75rem);
  padding-right: clamp(0.35rem, 1.1vw, 0.75rem);
}

.asky-page-fill {
  flex: 1 1 0;
  min-height: 0;
  max-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  width: 100%;
  align-self: stretch;
}

/* Dash page outlet — fill container so charts are not left-narrow with empty space on the right */
.asky-page-fill > div {
  flex: 1 1 0;
  min-height: 0;
  max-height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  width: 100%;
  max-width: none;
  align-self: stretch;
}

/* Forecasts: matrix fills width; hidden stores stay out of the flex budget */
.asky-tab-canvas-page {
  flex: 1 1 0;
  min-height: 0;
  max-height: 100%;
  width: 100%;
  align-self: stretch;
  display: flex;
  flex-direction: column;
  gap: var(--mantine-spacing-sm);
}

.asky-tab-canvas-page > *:first-child {
  flex: 1 1 auto;
  min-height: 0;
}

.asky-tab-canvas-page > *:not(:first-child) {
  flex: 0 0 auto;
}

/* UC1 API result: compact <details> — disclosure chevron + summary on one line */
.asky-uc1-response > summary {
  list-style: none;
}
.asky-uc1-response > summary::-webkit-details-marker {
  display: none;
}
.asky-uc1-response > summary::before {
  content: "\25B6  ";
  display: inline-block;
  font-size: 0.7em;
  opacity: 0.75;
  margin-right: 0.15rem;
}
.asky-uc1-response[open] > summary::before {
  content: "\25BC  ";
}

/*
 * Forecasts matrix — centered shell width; Stack holds row0 (figures) + row1 (30/70 context/chat).
 * Vertical split between bands: slightly smaller top band so context + chat get more height (``4fr`` / ``6fr``).
 */
.asky-canvas-matrix {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.asky-canvas-matrix--fill {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

/* Vertical split: top figures row / bottom context+chat row */
.asky-canvas-matrix--fill > div {
  flex: 1 1 auto;
  min-height: 0;
  display: grid;
  grid-template-rows: minmax(0, 4fr) minmax(0, 6fr);
  gap: 4px;
  align-content: stretch;
}

/*
 * Top figure row: two equal columns (figures only).
 */
.asky-canvas-row0 {
  width: 100%;
  min-width: 0;
  min-height: 0;
  height: 100%;
  box-sizing: border-box;
}

/* Figure cells fill the grid row; center content when shorter than the row */
.asky-canvas-row0__plot {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: stretch;
  min-width: 0;
  min-height: 0;
}

/* Match plot-1 / plot-2 outer shells so both columns size and align the same */
.asky-canvas-row0__figure-shell {
  box-sizing: border-box;
  position: relative;
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
  min-height: min(280px, 42dvh);
}

.asky-canvas-row0 .asky-plot-slot {
  align-self: stretch;
  width: 100%;
  min-height: 0;
}

/*
 * Figure row — two equal columns (50% / 50%) for ``sm`` (~36em) and up; stack on narrow screens.
 */
@media (max-width: 35.99em) {
  .asky-canvas-row0 {
    display: flex;
    flex-direction: column;
    gap: var(--mantine-spacing-xs);
  }
}

@media (min-width: 36em) {
  .asky-canvas-row0 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto;
    gap: var(--mantine-spacing-xs);
    align-items: stretch;
  }

  .asky-canvas-row0__plot--1 {
    grid-column: 1;
    grid-row: 1;
    min-width: 0;
  }

  .asky-canvas-row0__plot--2 {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
  }

  .asky-canvas-row0 .asky-plot-slot__img {
    max-height: min(48dvh, 100%);
  }
}

/*
 * Bottom row — 30% context + 70% chat (``3fr`` / ``7fr``); full row width; stack when narrow.
 */
.asky-canvas-row1 {
  width: 100%;
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 3fr) minmax(0, 7fr);
  gap: var(--mantine-spacing-xs);
  align-items: stretch;
  box-sizing: border-box;
}

@media (max-width: 35.99em) {
  .asky-canvas-row1 {
    grid-template-columns: minmax(0, 1fr);
  }
}

.asky-canvas-row1__cell {
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

/* Shell: one row — title + tabs + ☰ (left cluster), Documentation (right); never shrink behind canvas */
.asky-nav-row {
  width: 100%;
  min-width: 0;
  flex-shrink: 0;
}

.asky-shell-actions .asky-session-menu {
  display: flex;
  align-items: center;
}

/* Compact layout: ``<details>`` slide-out for session/settings (``md+`` overlay; stacked on small screens) */
.asky-visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.asky-session-details__summary {
  list-style: none;
}

.asky-session-details__summary::-webkit-details-marker {
  display: none;
}

@media (min-width: 48em) {
  .asky-session-details__summary {
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.75rem;
    height: 2.75rem;
    border-radius: var(--mantine-radius-md);
    border: 1px solid var(--mantine-color-default-border, var(--mantine-color-gray-4));
    background-color: var(--mantine-color-default-hover, rgba(0, 0, 0, 0.05));
    color: var(--mantine-color-text);
    transition: background-color 0.15s ease;
  }

  .asky-session-details__summary:hover {
    background-color: var(--mantine-color-default-hover, rgba(0, 0, 0, 0.08));
  }

  details.asky-session-details[open]::before {
    content: "";
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.38);
    z-index: 399;
  }

  details.asky-session-details[open] > .asky-session-details__summary {
    position: relative;
    z-index: 402;
  }

  .asky-session-details__panel {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: min(22rem, 92vw);
    z-index: 401;
    overflow-y: auto;
    padding: var(--mantine-spacing-md);
    background-color: var(--mantine-color-body);
    border-right: 1px solid var(--mantine-color-default-border, var(--mantine-color-gray-4));
    box-shadow: var(--mantine-shadow-xl);
    max-height: 100vh;
  }

  .asky-left-column--popover {
    max-height: calc(100vh - 2rem);
    overflow-y: auto;
  }
}

@media (max-width: 47.99em) {
  .asky-session-details__panel {
    margin-top: var(--mantine-spacing-sm);
    padding-top: var(--mantine-spacing-sm);
    border-top: 1px dashed var(--mantine-color-default-border, var(--mantine-color-gray-4));
  }
}

/* Bottom row: stretch cards to the grid row height (from ``fr`` split on ``.asky-canvas-matrix--fill``). */
.asky-canvas-row1 .asky-context-controls-card,
.asky-canvas-row1 .asky-chat-card {
  flex: 1 1 auto;
  width: 100%;
}

/* Lower row — context slot; scroll when agents inject many controls */
.asky-context-controls-card {
  min-width: 0;
}

/* Center placeholder (and short content) in the body below the card title */
.asky-context-controls-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: safe center;
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}

/* Shared by Forecasts figure + context stacks: horizontal center; vertical alignment from Mantine ``justify`` */
.asky-placeholder-stack {
  align-items: center;
  box-sizing: border-box;
}

/* Figure stencil: top-align within tall plot cells (avoids floating mid-row empty space) */
.asky-placeholder-stack--figure {
  justify-content: flex-start;
}

/* Context placeholder (matches figure stencil style until widgets mount) */
.asky-context-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: var(--mantine-spacing-xs);
  text-align: center;
  width: 100%;
  min-width: 0;
  border: 1px dashed var(--mantine-color-default-border, var(--mantine-color-gray-4));
  border-radius: var(--mantine-radius-md);
  padding: var(--mantine-spacing-md);
  box-sizing: border-box;
}

[data-mantine-color-scheme="light"] .asky-context-placeholder {
  background-color: var(--mantine-color-body, var(--mantine-color-gray-0));
}

[data-mantine-color-scheme="dark"] .asky-context-placeholder {
  background-color: var(--mantine-color-dark-6, var(--mantine-color-dark-7));
}

.asky-context-placeholder__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(28dvh, 100%);
  object-fit: contain;
  flex-shrink: 0;
  margin-left: auto;
  margin-right: auto;
}

/* Figure placeholders — no Plotly on first paint; top-align so tall grid rows do not float content mid-air */
.asky-plot-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: var(--mantine-spacing-xs) var(--mantine-spacing-xs) var(--mantine-spacing-xs);
  border: 1px dashed var(--mantine-color-default-border, var(--mantine-color-gray-4));
  border-radius: var(--mantine-radius-md);
  box-sizing: border-box;
  min-height: 0;
}

[data-mantine-color-scheme="light"] .asky-plot-slot {
  background-color: var(--mantine-color-body, var(--mantine-color-gray-0));
}

[data-mantine-color-scheme="dark"] .asky-plot-slot {
  background-color: var(--mantine-color-dark-6, var(--mantine-color-dark-7));
}

.asky-plot-slot__img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  max-height: min(48dvh, 100%);
  object-fit: contain;
  flex-shrink: 0;
}

