/* ============================================================
   pages.css — KIC Mission Control per-page layouts
   ------------------------------------------------------------
   Loads after components.css. Holds only the layout patterns
   that are specific to one or two pages — dashboard grid,
   pipeline kanban, inbox row pattern, etc.
   
   Component-level styles (cards, chips, modals) live in
   components.css. If you find yourself repeating a pattern
   across more than two pages, promote it.
   ============================================================ */


/* ============================================================
   LOGIN
   Centred card, KIC wordmark above. No animation.
   ============================================================ */

.login {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--background);
  padding: var(--space-md);
}

.login__brand {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-xl);
}

.login__brand-mark {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: var(--space-sm);
  color: #C9A84C;  /* KIC gold — overrides currentColor for the logo SVG */
}

.login__brand-mark .icon {
  font-size: 64px;
  font-variation-settings: 'FILL' 1, 'wght' 400, 'GRAD' 0, 'opsz' 24;
}

.login__brand-name {
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--on-surface);
}

.login__brand-tag {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  font-weight: var(--font-label-caps-weight);
  text-transform: uppercase;
  color: var(--secondary);
}

.login__card {
  width: 100%;
  max-width: 420px;
  padding: var(--space-xl) var(--space-lg);
  background: var(--surface-container);
  border: 1px solid var(--primary-container);
  border-radius: var(--radius-lg);
}

.login__title {
  font-size: 22px;
  font-weight: 700;
  color: var(--primary);
  margin-bottom: var(--space-xs);
}

.login__sub {
  font-size: var(--font-body-base-size);
  color: var(--on-surface-variant);
  margin-bottom: var(--space-lg);
}

.login__form {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.login__footer {
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--outline-variant);
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: var(--on-surface-variant);
}

.login__copy {
  margin-top: var(--space-xl);
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  opacity: 0.6;
}

.login__error {
  color: var(--error);
  font-size: var(--font-body-base-size);
  text-align: center;
  margin: 0;
}


/* ============================================================
   PAGE WRAP — vertical rhythm for all page screens
   ============================================================ */

.page-wrap > * + * {
  margin-top: var(--space-lg);
}


/* ============================================================
   DASHBOARD
   Hero + 4-up action grid + 4-up stat grid + 2-col content +
   markets strip.
   ============================================================ */

.dashboard__action-grid,
.dashboard__stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-gutter);
  margin-bottom: var(--space-lg);
}

@media (max-width: 1024px) {
  .dashboard__action-grid,
  .dashboard__stat-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .dashboard__action-grid,
  .dashboard__stat-grid {
    grid-template-columns: 1fr;
  }
}

.dashboard__columns {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-gutter);
  margin-bottom: var(--space-lg);
}

@media (max-width: 1024px) {
  .dashboard__columns {
    grid-template-columns: 1fr;
  }
}

/* Recent-pipeline row — expandable list item, NOT a modal trigger */
.recent-row {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  border-bottom: 1px solid var(--outline-variant);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
}

.recent-row:hover {
  background: var(--surface-container-low);
}

.recent-row:last-child {
  border-bottom: 0;
}

.recent-row__accent {
  width: 3px;
  height: 36px;
  border-radius: 2px;
  background: var(--secondary);
  flex-shrink: 0;
}

.recent-row__accent--good     { background: var(--tertiary); }
.recent-row__accent--primary  { background: var(--primary-container); }
.recent-row__accent--bad      { background: var(--error); }
.recent-row__accent--info     { background: var(--secondary); }

.recent-row__main {
  flex: 1;
  min-width: 0;
}

.recent-row__title {
  font-size: var(--font-body-base-size);
  font-weight: 700;
  color: var(--on-surface);
  margin-bottom: 2px;
}

.recent-row__meta {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.recent-row__values {
  display: flex;
  gap: var(--space-lg);
  align-items: center;
}

.recent-row__value-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: 2px;
}

.recent-row__value {
  font-size: var(--font-data-mono-size);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  color: var(--on-surface);
}

/* Bottom markets strip — single horizontal row of tickers */
.markets-strip {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-sm) var(--space-md);
  background: var(--surface-container-low);
  border-top: 1px solid var(--outline-variant);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  overflow-x: auto;
  white-space: nowrap;
}

.markets-strip__ticker {
  display: inline-flex;
  gap: var(--space-xs);
}

.markets-strip__name {
  color: var(--on-surface-variant);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.markets-strip__price {
  color: var(--on-surface);
  font-weight: 600;
}

.markets-strip__delta--up   { color: var(--tertiary); }
.markets-strip__delta--down { color: var(--error); }


/* ============================================================
   PIPELINE
   Kanban: 7 columns (one per status). Each column is a flex
   stack of deal cards. Horizontal scroll on narrow viewports.
   ============================================================ */

.pipeline__filter-bar {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-md);
  flex-wrap: wrap;
}

.pipeline__filter-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-right: var(--space-xs);
}

.kanban {
  display: flex;
  gap: var(--space-md);
  overflow-x: auto;
  padding-bottom: var(--space-md);
}

.kanban__column {
  flex: 0 0 280px;
  min-width: 0;
  width: 280px;
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.kanban__column-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-xs);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  font-weight: var(--font-label-caps-weight);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.kanban__column-count {
  font-variant-numeric: tabular-nums;
  color: var(--on-surface);
}

.kanban__column--invested .kanban__column-head { color: var(--tertiary); }
.kanban__column--rejected .kanban__column-head { color: var(--error); }

.kanban__column.drag-over {
  outline: 2px solid var(--primary-container);
  outline-offset: -2px;
  border-radius: var(--radius-lg);
  background: var(--surface-container-high);
}

/* Deal card — kanban tile */
.deal-card {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease);
}

.deal-card:hover {
  background: var(--surface-container-high);
  border-color: var(--outline);
}

.deal-card--dim {
  opacity: 0.5;
}

.deal-card.dragging {
  opacity: 0.35;
}

.deal-card__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-sm);
}

.deal-card__country {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.deal-card__country-flag {
  width: 12px;
  height: 8px;
  border-radius: 1px;
  display: inline-block;
  background: var(--surface-container-highest);
}

.deal-card__handle {
  color: var(--on-surface-variant);
  opacity: 0.5;
  cursor: grab;
}

.deal-card__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--on-surface);
  margin-bottom: var(--space-sm);
}

.deal-card__chips {
  display: flex;
  gap: var(--space-xs);
  flex-wrap: wrap;
  margin-bottom: var(--space-md);
}

.deal-card__foot {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding-top: var(--space-sm);
  border-top: 1px solid var(--outline-variant);
}

.deal-card__size-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: 2px;
}

.deal-card__size {
  font-size: var(--font-data-mono-size);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--on-surface);
}

/* Pipeline metrics strip — bottom of pipeline page */
.pipeline__metrics {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-gutter);
  padding-top: var(--space-md);
  border-top: 1px solid var(--outline-variant);
  margin-top: var(--space-lg);
}

@media (max-width: 1024px) {
  .pipeline__metrics {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* ============================================================
   INBOX
   List of parsed-email rows. Each row expands inline to show
   email body + parsed JSON side by side.
   ============================================================ */

.inbox__toolbar {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-sm) var(--space-md);
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-md);
}

.inbox__toolbar-action {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 6px var(--space-sm);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
  cursor: pointer;
  border-radius: var(--radius-default);
  transition: background var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease);
}

.inbox__toolbar-action:hover {
  color: var(--on-surface);
  background: var(--surface-container-high);
}

.inbox__toolbar-page {
  margin-left: auto;
  font-size: 12px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

/* Inbox row */
.inbox-row {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-sm);
  overflow: hidden;
}

.inbox-row--expanded {
  background: var(--surface-container-high);
}

.inbox-row__head {
  display: grid;
  grid-template-columns: auto 2fr 1fr 1fr 1fr auto auto;
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
}

.inbox-row__head:hover {
  background: var(--surface-container-high);
}

.inbox-row__check {
  cursor: pointer;
}

.inbox-row__title {
  font-size: var(--font-body-base-size);
  font-weight: 700;
  color: var(--on-surface);
}

.inbox-row__sub {
  font-size: 12px;
  color: var(--on-surface-variant);
  margin-top: 2px;
}

.inbox-row__col-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.inbox-row__col-value {
  font-size: var(--font-body-base-size);
  color: var(--on-surface);
  margin-top: 2px;
}

.inbox-row__col-value--muted {
  font-style: italic;
  color: var(--on-surface-variant);
}

.inbox-row__caret {
  color: var(--on-surface-variant);
  transition: transform var(--t-fast) var(--ease);
}

.inbox-row--expanded .inbox-row__caret {
  transform: rotate(180deg);
}

/* Expanded body — two columns: email body left, parsed JSON right */
.inbox-row__expand {
  padding: 0 var(--space-md) var(--space-md);
}

.inbox-row__panes {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  background: var(--surface);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-default);
  overflow: hidden;
}

@media (max-width: 1024px) {
  .inbox-row__panes {
    grid-template-columns: 1fr;
  }
}

.inbox-row__pane {
  padding: var(--space-md);
}

.inbox-row__pane + .inbox-row__pane {
  border-left: 1px solid var(--outline-variant);
}

.inbox-row__expand { display: none; }
.inbox-row--expanded .inbox-row__expand { display: block; }

.inbox-row__pane-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-sm);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  padding-bottom: var(--space-xs);
  border-bottom: 1px solid var(--outline-variant);
}

.inbox-row__pane-body {
  font-size: 12px;
  line-height: 1.6;
  color: var(--on-surface);
  white-space: pre-wrap;
  word-break: break-word;
}

.inbox-row__pane-body--mono {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  color: var(--secondary);
}

/* Floating widget — scanner efficiency overlay (Stitch design) */
.scanner-stat {
  position: fixed;
  right: var(--space-md);
  bottom: var(--space-md);
  width: 240px;
  padding: var(--space-md);
  background: var(--surface-container-high);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  z-index: var(--z-sticky);
}

.scanner-stat__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-xs);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.scanner-stat__row-value {
  font-size: 12px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--tertiary);
}


/* ============================================================
   RELATIONSHIPS (CRM)
   Hero + 4 stat cards + tabs + tab body. Uses .table for the
   contacts grid.
   ============================================================ */

.crm__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-gutter);
  margin-bottom: var(--space-lg);
}

@media (max-width: 1024px) { .crm__stats { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .crm__stats { grid-template-columns: 1fr; } }

.crm__hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-lg);
  margin-bottom: var(--space-lg);
}

.crm__hero-actions {
  display: flex;
  gap: var(--space-sm);
}

/* Activity feed (tab) */
.activity-feed__day {
  margin-bottom: var(--space-lg);
}

.activity-feed__day-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  font-weight: var(--font-label-caps-weight);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: var(--space-sm);
}

.activity-feed__entry {
  display: flex;
  gap: var(--space-md);
  padding: var(--space-md);
  border-left: 2px solid var(--outline-variant);
  margin-bottom: var(--space-xs);
}

.activity-feed__entry--good { border-left-color: var(--tertiary); }
.activity-feed__entry--primary { border-left-color: var(--primary-container); }
.activity-feed__entry--info { border-left-color: var(--secondary); }


/* ============================================================
   STUDIO
   Tab-bar with 4 sub-tabs. Documents tab = left rail + editor.
   ============================================================ */

.studio__tabs {
  margin-bottom: var(--space-lg);
}

.studio-doc {
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: var(--space-md);
  height: calc(100vh - var(--topbar-height) - 200px);
}

@media (max-width: 1024px) {
  .studio-doc {
    grid-template-columns: 1fr;
    height: auto;
  }
}

.studio-doc__rail {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
  overflow-y: auto;
}

.studio-doc__rail-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-sm);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  font-weight: var(--font-label-caps-weight);
  text-transform: uppercase;
  color: var(--on-surface-variant);
}

.studio-doc__template {
  padding: var(--space-md);
  border-radius: var(--radius-default);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease);
  margin-bottom: var(--space-xs);
}

.studio-doc__template:hover {
  background: var(--surface-container-high);
}

.studio-doc__template--active {
  background: var(--surface-container-high);
  border-left: 3px solid var(--primary-container);
  padding-left: 13px;
}

.studio-doc__template-name {
  font-size: var(--font-body-base-size);
  font-weight: 600;
  color: var(--on-surface);
}

.studio-doc__template-meta {
  font-size: 11px;
  color: var(--on-surface-variant);
  margin-top: 2px;
  display: flex;
  gap: var(--space-sm);
}

.studio-doc__editor {
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.studio-doc__editor-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-sm) var(--space-md);
  border-bottom: 1px solid var(--outline-variant);
  background: var(--surface-container-high);
}

.studio-doc__editor-body {
  flex: 1;
  display: grid;
  grid-template-columns: 40px 1fr;
  overflow-y: auto;
}

.studio-doc__editor-gutter {
  background: var(--surface-container-low);
  font-family: var(--font-mono);
  font-size: 12px;
  font-variant-numeric: tabular-nums;
  color: var(--on-surface-variant);
  padding: var(--space-md) 0;
  text-align: right;
  user-select: none;
}

.studio-doc__editor-gutter span {
  display: block;
  padding-right: var(--space-sm);
}

.studio-doc__editor-text {
  padding: var(--space-md);
  font-size: var(--font-body-base-size);
  line-height: 1.7;
  color: var(--on-surface);
}


/* ============================================================
   DEAL DETAILS modal-as-page (full-bleed)
   ============================================================ */

.deal-details__hero {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-lg);
  padding: var(--space-lg);
  background: var(--surface-container-high);
  border: 1px solid var(--outline-variant);
  border-left: 4px solid var(--primary-container);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
}

.deal-details__title {
  font-size: 28px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;
  color: var(--on-surface);
  margin-bottom: var(--space-md);
}

.deal-details__metrics {
  display: flex;
  gap: var(--space-lg);
}

.deal-details__metric-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  font-weight: var(--font-label-caps-weight);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: 2px;
}

.deal-details__metric-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--primary);
  font-variant-numeric: tabular-nums;
}

.deal-details__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  align-items: flex-end;
}

.deal-details__layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-lg);
}

@media (max-width: 1024px) {
  .deal-details__layout { grid-template-columns: 1fr; }
}

.deal-details__field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

.deal-details__field-label {
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: 2px;
}

.deal-details__field-value {
  font-size: var(--font-body-base-size);
  font-weight: 600;
  color: var(--on-surface);
}


/* ============================================================
   NEW DEAL form
   2-column form with origin badge if launched from inbox.
   ============================================================ */

.new-deal__origin {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  padding: 4px 10px;
  background: var(--surface-container-high);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-default);
  font-size: var(--font-label-caps-size);
  letter-spacing: var(--font-label-caps-track);
  text-transform: uppercase;
  color: var(--on-surface-variant);
  margin-bottom: var(--space-sm);
}

.new-deal__form {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md);
}

@media (max-width: 768px) {
  .new-deal__form { grid-template-columns: 1fr; }
}

.new-deal__field--full {
  grid-column: 1 / -1;
}


/* ============================================================
   DOCUMENT VIEWER — full page
   ============================================================ */

.doc-viewer__header {
  display: flex;
  align-items: center;
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-default);
  padding: var(--space-md) var(--space-lg);
  margin-bottom: var(--space-md);
  gap: var(--space-md);
}

.doc-viewer__layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
}

.doc-viewer__toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  border-bottom: 1px solid var(--outline-variant);
}

.doc-viewer__body {
  padding: var(--space-lg) var(--space-xl);
  max-height: 70vh;
  overflow-y: auto;
  font-size: 14px;
  line-height: 1.7;
  color: var(--on-surface);
}

.doc-viewer__section-heading {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--secondary);
  text-transform: none;
  letter-spacing: 0.02em;
  margin: var(--space-lg) 0 var(--space-md) 0;
}

.doc-viewer__section-heading:first-child {
  margin-top: 0;
}

.doc-viewer__paragraph {
  margin: 0 0 var(--space-md) 0;
  color: var(--on-surface);
}

.doc-viewer__actionbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-default);
  padding: var(--space-md) var(--space-lg);
}


/* ============================================================
   SETTINGS
   Tab-bar with 4 sub-tabs (Account, Connections, Audit, About)
   ============================================================ */

.settings__layout {
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: var(--space-lg);
}

@media (max-width: 1024px) {
  .settings__layout { grid-template-columns: 1fr; }
}

.connection-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-md);
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-sm);
}

.connection-row__main {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}

.connection-row__name {
  font-size: var(--font-body-base-size);
  font-weight: 600;
  color: var(--on-surface);
}

.connection-row__sub {
  font-size: 11px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--on-surface-variant);
}


/* ============================================================
   HELP page
   Reuses base + components + simple typographic page styles.
   ============================================================ */

.help__container {
  max-width: 800px;
  margin: 0 auto;
}

.help__toc {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-md) var(--space-lg);
  padding: var(--space-lg);
  background: var(--surface-container);
  border: 1px solid var(--outline-variant);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-xl);
}

.help__toc-item {
  font-size: var(--font-body-base-size);
  color: var(--secondary);
  cursor: pointer;
  transition: color var(--t-fast) var(--ease);
}

.help__toc-item:hover { color: var(--primary); }

.help__section {
  margin-bottom: var(--space-xl);
}

.help__section h2 {
  font-size: 22px;
  font-weight: 700;
  color: var(--on-surface);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--outline-variant);
}

.help__section h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--primary);
  margin-top: var(--space-lg);
  margin-bottom: var(--space-sm);
}

.help__section p {
  margin-bottom: var(--space-md);
  line-height: 1.7;
  color: var(--on-surface);
}

/* Callout boxes — info/warn/note */
.callout {
  padding: var(--space-md);
  border-left: 3px solid var(--secondary);
  background: rgba(137, 206, 255, 0.06);
  border-radius: 0 var(--radius-default) var(--radius-default) 0;
  margin: var(--space-md) 0;
}

.callout--warn { border-left-color: var(--primary-container); background: rgba(249, 115, 22, 0.06); }
.callout--bad  { border-left-color: var(--error); background: rgba(255, 180, 171, 0.06); }
.callout--good { border-left-color: var(--tertiary); background: rgba(78, 222, 163, 0.06); }


/* ============================================================
   MOBILE BOTTOM NAV
   Below 768px: replaces the desktop sidebar.
   ============================================================ */

.bottom-nav {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  height: 64px;
  background: var(--surface-container);
  border-top: 1px solid var(--outline-variant);
  z-index: var(--z-sidebar);
  justify-content: space-around;
  padding: 0 var(--space-sm);
}

.bottom-nav__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  flex: 1;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: var(--on-surface-variant);
  cursor: pointer;
  transition: color var(--t-fast) var(--ease);
}

.bottom-nav__item:hover { color: var(--on-surface); }

.bottom-nav__item--active { color: var(--primary-container); }

.bottom-nav__item .icon { font-size: 20px; }

@media (max-width: 768px) {
  .sidebar { display: none; }
  .topbar { width: 100%; }
  .bottom-nav { display: flex; }
  .topbar .input-search { display: none; }
  .topbar__icon-btn:not([data-action]) { display: none; }
}
