/* 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 next to layout toggle — avoid low-contrast grey if tokens drift */
.asky-page-title {
  color: var(--mantine-color-text);
}

/*
 * Forecasts matrix wrapper — full-width Mantine grids inside the page column.
 */
.asky-canvas-matrix {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

.asky-canvas-matrix .mantine-Grid-root {
  align-items: stretch;
  width: 100%;
}

/*
 * Top figure row: two equal columns (figures only). Session ☰ lives in ``.asky-shell-actions`` (shell).
 */
.asky-canvas-row0 {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

/* Center placeholder slots (and future figures) within each column when row height > slot height */
.asky-canvas-row0__plot {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 0;
}

@media (max-width: 47.99em) {
  .asky-canvas-row0 {
    display: flex;
    flex-direction: column;
    gap: var(--mantine-spacing-sm);
  }
}

@media (min-width: 48em) {
  .asky-canvas-row0 {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    grid-template-rows: auto;
    gap: var(--mantine-spacing-sm);
    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: 240px;
  }
}

/* Shell: tabs row — ☰ session menu aligns right via ``asky-shell-actions`` */
.asky-nav-row {
  width: 100%;
  min-width: 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 both cards to the same height (see shared.py ``_BOTTOM_ROW_CARD_MIN_H``). */
.asky-bottom-row.mantine-Grid-root {
  align-items: stretch;
}

.asky-bottom-row > .mantine-GridCol-root {
  display: flex;
  min-width: 0;
}

.asky-bottom-row .asky-context-controls-card,
.asky-bottom-row .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: image + caption centered as one block */
.asky-placeholder-stack {
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
}

/* 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: 180px;
  object-fit: contain;
  flex-shrink: 0;
  margin-left: auto;
  margin-right: auto;
}

/* Figure placeholders — no Plotly on first paint */
.asky-plot-slot {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--mantine-color-default-border, var(--mantine-color-gray-4));
  border-radius: var(--mantine-radius-md);
  box-sizing: border-box;
}

[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: 210px;
  object-fit: contain;
  flex-shrink: 0;
}

