/*
 * RadarCRM Dashboard — layout & viewport optimization only.
 * Scoped to #sc-dashboard; does not affect other screens.
 */

/* ── Main shell: centered content rail when Dashboard is active ── */
main:has(#sc-dashboard.on) {
  justify-content: center;
  align-items: flex-start;
  padding: var(--space-2) var(--space-3);
}

#sc-dashboard.screen {
  max-width: min(1200px, 100%);
  width: 100%;
  margin: 0 auto;
}

/* ── Vertical rhythm (compressed for above-the-fold density) ── */
#sc-dashboard .page-title {
  margin-bottom: var(--space-2);
}

#sc-dashboard .dashboard-week-bar {
  margin-bottom: var(--space-2);
  padding: var(--space-2) var(--space-3);
}

#sc-dashboard .section-title {
  margin: var(--space-2) 0 var(--space-2);
  padding-bottom: 6px;
}

#sc-dashboard .dashboard-layout {
  display: flex;
  flex-direction: column;
  gap: 0;
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

/* ── KPI premium tokens (executive fintech — inverted per theme) ── */
:root,
[data-theme="dark"] {
  --kpi-surface: #FFFFFF;
  --kpi-surface-hover: #FAFBFD;
  --kpi-border: var(--brand-primary);
  --kpi-text: var(--brand-navy);
  --kpi-text-muted: #50627F;
  --kpi-accent: var(--brand-primary);
}

[data-theme="light"] {
  --kpi-surface: var(--brand-navy);
  --kpi-surface-hover: #172241;
  --kpi-border: var(--brand-primary);
  --kpi-text: #FFFFFF;
  --kpi-text-muted: rgba(255, 255, 255, 0.72);
  --kpi-accent: var(--brand-primary);
}

.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;
}

/* ── KPI grid — desktop: 4 equal columns, equal card heights ── */
#sc-dashboard .kpi-scroll-wrap {
  margin-bottom: var(--space-3);
  width: 100%;
}

#sc-dashboard .kpi-carousel-viewport {
  width: 100%;
}

#sc-dashboard .kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: 1fr;
  gap: var(--space-2);
  margin-bottom: 0;
}

#sc-dashboard .kpi {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 4.75rem;
  height: 100%;
  padding: var(--space-2) var(--space-3);
  background: var(--kpi-surface);
  border: 1px solid var(--kpi-border);
  border-radius: var(--r-card);
  box-shadow: 0 1px 2px rgba(18, 28, 45, 0.06);
  color: var(--kpi-text);
  transition:
    background 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.35s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.35s ease;
}

#sc-dashboard .kpi:hover {
  background: var(--kpi-surface-hover);
  box-shadow: 0 2px 8px rgba(18, 28, 45, 0.1);
}

#sc-dashboard .kpi .kv {
  font-family: 'Geist', 'Inter', system-ui, sans-serif;
  font-weight: 600;
  letter-spacing: -0.03em;
  font-variant-numeric: tabular-nums lining-nums;
  font-feature-settings: 'tnum' 1, 'lnum' 1;
  color: var(--kpi-text);
}

#sc-dashboard .kpi .kl,
#sc-dashboard .kpi .ksub {
  color: var(--kpi-text-muted);
}

#sc-dashboard .kpi.hero {
  border-color: var(--kpi-border);
  box-shadow: 0 1px 2px rgba(18, 28, 45, 0.06), 0 0 0 1px rgba(164, 198, 57, 0.22);
}

#sc-dashboard .kpi.hero .kv {
  color: var(--kpi-accent);
}

#sc-dashboard .kpi:focus-visible {
  outline: var(--focus-ring-width) solid var(--kpi-accent);
  outline-offset: var(--focus-ring-offset);
}

@media (min-width: 768px) {
  #sc-dashboard .kpi-carousel-nav {
    display: none;
  }
}

@media (min-width: 768px) and (max-width: 1023px) {
  #sc-dashboard .kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  main:has(#sc-dashboard.on) {
    padding: var(--space-2) var(--space-4);
  }

  #sc-dashboard .kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: var(--space-2);
  }

  #sc-dashboard .kpi {
    min-height: 4.5rem;
  }
}

/* ── Analytics row — 65 / 35 split on desktop ── */
#sc-dashboard .dashboard-analytics {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}

@media (min-width: 1024px) {
  #sc-dashboard .dashboard-analytics {
    display: grid;
    grid-template-columns: minmax(0, 1.85fr) minmax(0, 1fr);
    gap: var(--space-3);
    align-items: start;
  }
}

#sc-dashboard .dashboard-panel {
  min-width: 0;
}

#sc-dashboard .dashboard-panel--activity .dashboard-legend {
  margin-bottom: var(--space-2);
}

#sc-dashboard .dashboard-panel--sector {
  width: 100%;
}

#sc-dashboard .sem-row {
  margin-bottom: 5px;
  flex-wrap: wrap;
  gap: var(--space-1) var(--space-2);
}

#sc-dashboard .sem-row > div:last-child {
  flex: 1 1 100%;
  margin-left: 0 !important;
}

#sc-dashboard .sem-dots-more {
  font-size: var(--text-2xs);
  color: var(--mu);
}

#sc-dashboard .bar-row {
  margin-bottom: 5px;
  gap: var(--space-2);
}

#sc-dashboard .bar-label {
  flex: 0 1 9rem;
  min-width: 4.5rem;
  max-width: 36%;
}

#sc-dashboard .bar-wrap {
  min-width: 0;
}

#sc-dashboard .bar-val {
  flex-shrink: 0;
}

/* ── Mobile: horizontal KPI carousel + compressed analytics ── */
@media (max-width: 767px) {
  main:has(#sc-dashboard.on) {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
    overflow-x: hidden;
  }

  #sc-dashboard .page-title {
    margin-bottom: var(--space-1);
    font-size: var(--text-base);
  }

  #sc-dashboard .dashboard-week-bar {
    padding: var(--space-2);
    margin-bottom: var(--space-2);
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
  }

  #sc-dashboard .dashboard-week-bar .week-stat,
  #sc-dashboard .dashboard-week-bar .week-delta {
    font-size: var(--text-2xs);
    line-height: 1.35;
  }

  #sc-dashboard .kpi-scroll-wrap {
    margin-left: calc(-1 * var(--space-3));
    margin-right: calc(-1 * var(--space-3));
    margin-bottom: var(--space-2);
    padding: 0;
    overflow: hidden;
  }

  #sc-dashboard .kpi-carousel-viewport {
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    overscroll-behavior-x: contain;
    scrollbar-width: none;
    scroll-behavior: smooth;
    padding: 4px 0 2px;
  }

  #sc-dashboard .kpi-carousel-viewport::-webkit-scrollbar {
    display: none;
  }

  #sc-dashboard .kpi-carousel-viewport:focus-visible {
    outline: var(--focus-ring-width) solid var(--kpi-accent);
    outline-offset: 2px;
  }

  #sc-dashboard .kpi-grid {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 10px;
    width: max-content;
    min-width: 100%;
    padding: 0 var(--space-3);
  }

  #sc-dashboard .kpi {
    flex: 0 0 calc(100vw - var(--space-3) * 2 - 28px);
    max-width: calc(100vw - var(--space-3) * 2 - 28px);
    scroll-snap-align: center;
    scroll-snap-stop: always;
    min-height: 5.25rem;
    height: auto;
    padding: 12px 14px;
    gap: 0;
    transform: scale(0.97);
    opacity: 0.88;
  }

  #sc-dashboard .kpi.is-active {
    transform: scale(1);
    opacity: 1;
    box-shadow: 0 3px 14px rgba(18, 28, 45, 0.12);
  }

  @media (prefers-reduced-motion: reduce) {
    #sc-dashboard .kpi,
    #sc-dashboard .kpi-carousel-viewport {
      transition: none;
      scroll-behavior: auto;
    }

    #sc-dashboard .kpi {
      transform: none;
      opacity: 1;
    }
  }

  #sc-dashboard .kpi .kv {
    font-size: 1.5rem;
    font-weight: 600;
    line-height: 1.05;
    letter-spacing: -0.03em;
  }

  #sc-dashboard .kpi.hero .kv {
    font-size: 1.625rem;
  }

  #sc-dashboard .kpi .kl {
    font-size: 0.6875rem;
    margin-top: 4px;
    line-height: 1.25;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  #sc-dashboard .kpi .ksub {
    font-size: 0.6875rem;
    margin-top: 2px;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  #sc-dashboard .kpi-carousel-nav {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    padding: 0 var(--space-3);
  }

  #sc-dashboard .kpi-carousel-dot {
    width: 6px;
    height: 6px;
    padding: 0;
    border: none;
    border-radius: 999px;
    background: var(--border-default);
    cursor: pointer;
    transition:
      width 0.3s cubic-bezier(0.4, 0, 0.2, 1),
      background 0.25s ease,
      opacity 0.25s ease;
    opacity: 0.55;
  }

  #sc-dashboard .kpi-carousel-dot[aria-selected="true"] {
    width: 18px;
    background: var(--kpi-accent);
    opacity: 1;
  }

  #sc-dashboard .kpi-carousel-dot:focus-visible {
    outline: var(--focus-ring-width) solid var(--kpi-accent);
    outline-offset: 2px;
    opacity: 1;
  }

  #sc-dashboard .dashboard-analytics {
    gap: var(--space-2);
    margin-bottom: var(--space-1);
  }

  #sc-dashboard .section-title {
    margin: var(--space-2) 0 var(--space-1);
    padding-bottom: 4px;
    font-size: var(--text-sm);
  }

  #sc-dashboard .dashboard-panel--activity .dashboard-legend {
    margin-bottom: var(--space-1);
    gap: var(--space-2);
    font-size: var(--text-2xs);
  }

  #sc-dashboard .sem-row {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: var(--space-1);
    margin-bottom: 3px;
    font-size: 0.625rem;
  }

  #sc-dashboard .sem-label {
    width: 3.75rem;
    flex-shrink: 0;
  }

  #sc-dashboard .sem-dots {
    flex: 0 1 auto;
    min-width: 0;
    gap: 3px;
    overflow: hidden;
  }

  #sc-dashboard .sem-row .dot {
    width: 7px;
    height: 7px;
    flex-shrink: 0;
  }

  #sc-dashboard .sem-dots-more {
    display: none;
  }

  #sc-dashboard .sem-row > div:last-child {
    flex: 1 1 auto;
    min-width: 0;
    margin-left: 0 !important;
    font-size: 0.625rem !important;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: right;
  }

  #sc-dashboard .bar-row {
    margin-bottom: 4px;
    gap: var(--space-1);
  }

  #sc-dashboard .bar-label {
    flex: 0 1 5.5rem;
    min-width: 3.5rem;
    max-width: 42%;
    font-size: 0.625rem;
  }

  #sc-dashboard .bar-val {
    width: 2rem;
    font-size: 0.625rem;
  }
}
