/* /account/agent — show.html.erb
 *
 * Figma work-file screens #6a (empty state, 137:3210) and #6b (active chat,
 * 137:4243), assembled from the Input AI Chat (152:5729) and AI Agent
 * Conversation List Item (137:4109) component sets. Rail (Conversations +
 * Documents) beside the chat column — Björn moved it to the right (the Figma
 * has it on the left); radius is corner-radius-xs (4px) throughout.
 */

/* ============ Page layout ============ */
.agent-page {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-24);
  height: calc(100vh - 9rem); /* Note: viewport minus nav clearance + bottom gutter */
}
@media (min-width: 64rem) {
  .agent-page { flex-direction: row; gap: var(--spacing-32); }
}

/* ============ Right rail (desktop) ============ */
/* `order: 1` places the rail after the chat column (chat stays first in the
   DOM for reading order). The Figma puts it on the left; Björn moved it right. */
.agent-sidebar { display: none; }
@media (min-width: 64rem) {
  .agent-sidebar {
    display: block;
    order: 1;
    width: 20rem; /* Note: Figma sidebar = 320px */
    flex-shrink: 0;
    overflow-y: auto;
  }
}

.agent-sidebar-divider {
  border: 0;
  border-top: var(--stroke-weight-1) solid var(--border-default);
  margin-block: var(--spacing-8);
}

.agent-sidebar-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8);
  padding: var(--spacing-8) 0 var(--spacing-8) var(--spacing-8);
}

.agent-sidebar-heading {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  line-height: 1;
  letter-spacing: var(--font-letter-spacing-wider);
  color: var(--text-primary);
}

.agent-sidebar-count {
  color: var(--text-tertiary);
  font-weight: var(--font-weight-600);
}

/* The grey New / Upload buttons keep their auto width; the upload form wrapper
   must not introduce its own box (the <label> is the button). */
.agent-upload-form { display: contents; }
.agent-sidebar-action { cursor: pointer; }

.agent-sidebar-list {
  & > * + * { margin-top: var(--spacing-4); }
}

.agent-sidebar-empty {
  text-align: center;
  color: var(--text-tertiary);
  font-size: var(--font-size-14);
  line-height: 1.25rem;
  padding-block: var(--spacing-24);
}

.agent-sidebar-empty-hint {
  font-size: var(--font-size-12);
  line-height: 1rem;
  margin-top: var(--spacing-4);
}

/* ============ List item — conversations + documents ============ */
/* AI Agent Conversation List Item (137:4109). */
.agent-item {
  position: relative;
  border-radius: var(--corner-radius-xs);
}
.agent-item:hover { background-color: var(--background-hover); }
.agent-item--active { background-image: var(--brand-gradient); }

.agent-item-button {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-4);
  width: 100%;
  text-align: left;
  padding: var(--spacing-4) var(--spacing-8);
}

.agent-item-title {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  line-height: 1.25;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.agent-item-meta {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-400);
  line-height: 1;
  color: var(--text-tertiary);
}
.agent-item:hover .agent-item-meta { color: var(--text-secondary); }
.agent-item--active .agent-item-meta { color: var(--text-primary); }

/* Row actions (trash / download) — revealed on hover, top-right. */
.agent-item-actions {
  display: none;
  position: absolute;
  top: var(--spacing-4);
  right: var(--spacing-4);
  align-items: center;
  gap: var(--spacing-2);
  background-color: inherit; /* mask the truncated title underneath */
}
.agent-item:hover .agent-item-actions,
.agent-item--active .agent-item-actions { display: flex; }

.agent-item-action {
  padding: var(--spacing-4);
  border-radius: var(--corner-radius-xs);
  color: var(--symbol-default);
}
.agent-item-action:hover { color: var(--text-primary); }
.agent-item--active .agent-item-action { color: var(--text-primary); }

.agent-item-action-icon { width: 1rem; height: 1rem; }

/* Conversation overflow disclosure */
.agent-convo-overflow { margin-top: var(--spacing-4); }

.agent-convo-overflow-toggle {
  cursor: pointer;
  list-style: none;
  font-size: var(--font-size-12);
  line-height: 1rem;
  color: var(--text-tertiary);
  padding: var(--spacing-4) var(--spacing-8);

  &::-webkit-details-marker { display: none; }
  &:hover { color: var(--text-primary); }
}
.agent-convo-overflow[open] .agent-convo-overflow-more { display: none; }
.agent-convo-overflow:not([open]) .agent-convo-overflow-less { display: none; }
.agent-convo-overflow-list > * + * { margin-top: var(--spacing-4); }
.agent-convo-overflow-list { margin-top: var(--spacing-4); }

/* ============ Chat column ============ */
.agent-chat {
  flex: 1 1 0%;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
}

/* Shared content measure — Figma chat content is 740px in an 848px column. */
.agent-empty-inner,
.agent-thread-inner,
.agent-topbar,
.agent-composer,
.agent-composer-wrap .agent-paywall-card {
  width: 100%;
  max-width: 46.25rem; /* Note: Figma chat content width = 740px */
  margin-inline: auto;
}

/* ---- Empty state ---- */
.agent-empty {
  flex: 1 1 0%;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
}

.agent-empty-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-48);
}

.agent-empty-title {
  font-size: var(--font-size-32);
  font-weight: var(--font-weight-700);
  line-height: 1.15;
  letter-spacing: var(--font-letter-spacing-tight);
  color: var(--text-primary);
  text-align: center;
}

/* ---- Active thread ---- */
.agent-thread {
  flex: 1 1 0%;
  overflow-y: auto;
  min-height: 0;
}

.agent-thread-inner {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-24);
  padding-bottom: var(--spacing-16);
}

/* Sticky title bar fading the messages scrolling beneath it. */
.agent-topbar {
  position: sticky;
  top: 0;
  z-index: 1;
  padding-bottom: var(--spacing-16);
  background-image: linear-gradient(var(--background-base), transparent);
}

.agent-topbar-title {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-600);
  line-height: 1.15;
  color: var(--text-primary);
}

/* Thinking / Documenting status pill (Figma "Frame 134"). */
.agent-status {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-4);
  border-radius: var(--corner-radius-xs);
  background-color: var(--background-base);
  color: var(--text-secondary);
}

.agent-status-icon { width: 1.25rem; height: 1.25rem; flex-shrink: 0; }

.agent-status-label {
  font-size: var(--font-size-16);
  line-height: 1.25;
}

/* ---- Composer (Input AI Chat 152:5729) ---- */
.agent-composer-wrap { flex-shrink: 0; padding-top: var(--spacing-16); }

.agent-composer {
  display: flex;
  align-items: flex-end;
  gap: var(--spacing-8);
  padding: var(--spacing-12) var(--spacing-8) var(--spacing-12) var(--spacing-16);
  border-radius: var(--corner-radius-xs);
  border: var(--stroke-weight-1) solid transparent;
  background-color: var(--background-surface-2);
  transition: background-color 150ms cubic-bezier(0.4, 0, 0.2, 1), border-color 150ms cubic-bezier(0.4, 0, 0.2, 1);
}
.agent-composer:focus-within {
  background-color: var(--background-hover);
  border-color: var(--border-strong);
}

.agent-composer-input {
  flex: 1 1 0%;
  resize: none;
  border: 0;
  background: transparent;
  /* Floor at the Figma multi-row content height (116px) so the empty field reads
     as the 140px box; chat#autoGrow grows it from here, capped at 200px. */
  min-height: 7.25rem;
  padding: var(--spacing-2) 0;
  color: var(--text-primary);
  font-size: var(--font-size-16);
  line-height: 1.25;

  &::placeholder { color: var(--text-secondary); }
  &:focus { outline: none; }
  &:disabled { opacity: 0.5; cursor: not-allowed; }
}

.agent-composer-send {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--spacing-32);
  height: var(--spacing-32);
  border: 0;
  border-radius: var(--corner-radius-xs);
  background-image: var(--brand-gradient);
  color: var(--text-light);
  cursor: pointer;

  &:hover { background-image: var(--brand-gradient-hover); }
  &:disabled { opacity: 0.5; cursor: not-allowed; }
}

.agent-composer-send-icon { width: var(--spacing-16); height: var(--spacing-16); }

/* ---- Paywall (over cap) ---- */
.agent-paywall-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--spacing-12);
  text-align: center;
  padding: var(--spacing-24);
  border-radius: var(--corner-radius-xs);
  background-color: var(--background-surface-1);
  color: var(--text-secondary);
}

/* ============ Mobile docs strip (desktop shows docs in the sidebar) ============ */
.agent-docs-mobile { flex-shrink: 0; }
@media (min-width: 64rem) {
  .agent-docs-mobile { display: none; }
}

.agent-docs-mobile-scroller {
  display: flex;
  gap: var(--spacing-8);
  overflow-x: auto;
  padding-bottom: var(--spacing-4);
}

.agent-doc-chip {
  flex-shrink: 0;
  border-radius: var(--corner-radius-xs);
  background-color: var(--background-surface-2);
  padding: var(--spacing-4) var(--spacing-12);
}

.agent-doc-chip-label {
  font-size: var(--font-size-14);
  font-weight: var(--font-weight-500);
  color: var(--text-primary);
  white-space: nowrap;
}

.agent-upload-chip-form { flex-shrink: 0; }

.agent-upload-chip {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  border-radius: var(--corner-radius-xs);
  border: var(--stroke-weight-1) dashed var(--border-default);
  background-color: var(--background-surface-2);
  padding: var(--spacing-4) var(--spacing-12);
  cursor: pointer;
}

.agent-upload-chip-icon { width: var(--spacing-16); height: var(--spacing-16); color: var(--symbol-default); }

.agent-upload-chip-text {
  font-size: var(--font-size-14);
  color: var(--text-secondary);
  white-space: nowrap;
}

/* ============ Document modal ============ */
.agent-doc-image, .agent-doc-pdf { border-radius: var(--corner-radius-xs); }
.agent-doc-image { max-width: 100%; }
.agent-doc-pdf { width: 100%; }
.agent-doc-prose { max-width: none; }

.agent-modal {
  position: fixed;
  inset: var(--spacing-0);
  z-index: 50;
  margin: var(--spacing-0);
  height: 100%;
  width: 100%;
  max-height: 100%;
  max-width: 100%;
  background-color: transparent;
  padding: var(--spacing-0);

  &::backdrop { background-color: rgb(0 0 0 / 0.5); }
}

.agent-modal-shell {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100%;
  padding: var(--spacing-16);
}

.agent-modal-card {
  background-color: var(--background-surface-1);
  border-radius: var(--corner-radius-xs);
  max-width: 42rem; /* Note: bespoke modal width */
  width: 100%;
  max-height: 85vh;
  display: flex;
  flex-direction: column;
}

.agent-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-16) var(--spacing-24);
  border-bottom: var(--stroke-weight-1) solid var(--border-default);
}

.agent-modal-title {
  font-size: var(--font-size-16);
  font-weight: var(--font-weight-600);
  color: var(--text-primary);
}

.agent-modal-actions { display: flex; align-items: center; gap: var(--spacing-4); }

.agent-modal-action-button--download,
.agent-modal-action-button--close {
  padding: var(--spacing-4);
  border-radius: var(--corner-radius-xs);
  color: var(--symbol-default);

  &:hover { color: var(--text-primary); background-color: var(--background-hover); }
}

.agent-modal-action-icon { width: 1.25rem; height: 1.25rem; }

.agent-modal-body {
  padding: var(--spacing-16) var(--spacing-24);
  overflow-y: auto;
  flex: 1 1 0%;
}
