/* ═══════════════════════════════════════════════════════════
   RUN Art Foundry — Client Dashboard Styles
   Adapted from Thor Metal Art TICKET-DASH-001
   Brand: Bronze foundry — warm copper/bronze palette
   ═══════════════════════════════════════════════════════════ */

/* ── CSS Custom Properties ── */
:root {
  --font-sans: 'DM Sans', 'Inter', system-ui, sans-serif;
  --color-brand: #8B5E3C;
  --color-brand-light: #C49A6C;
  --color-brand-dark: #5C3D2E;
  --color-text-primary: #1A1A1A;
  --color-text-secondary: #666;
  --color-text-tertiary: #999;
  --color-text-success: #137333;
  --color-text-danger: #d32f2f;
  --color-text-info: #1a73e8;
  --color-text-warning: #f57f17;
  --color-background-primary: #fff;
  --color-background-secondary: #F7F4F0;
  --color-background-info: #e8f0fe;
  --color-background-warning: #fff8e1;
  --color-background-success: #e6f4ea;
  --color-background-danger: #fce8e6;
  --color-border-secondary: #ccc;
  --color-border-tertiary: #e0ddd8;
  --border-radius-lg: 12px;
  --border-radius-md: 8px;
}

/* ── Reset ── */
* { box-sizing: border-box; margin: 0; padding: 0 }
body { font-family: var(--font-sans); color: var(--color-text-primary); background: #EDEAE5 }

/* ── Layout ── */
.dash { max-width: 1200px; margin: 0 auto; padding: 0 0 2rem }

.topbar {
  background: #2C1810;
  padding: 14px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
}

.logo { font-size: 16px; font-weight: 600; color: var(--color-brand-light); letter-spacing: .04em }
.logo span { color: #888; font-size: 12px; font-weight: 400; margin-left: 10px }

.status-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #4caf50; display: inline-block; margin-right: 6px;
  animation: pulse 2s infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1 }
  50% { opacity: .4 }
}

.live { font-size: 12px; color: #888 }

/* ── Tabs ── */
.tabs {
  display: flex; gap: 2px; padding: 0 24px;
  background: var(--color-background-secondary);
  border-bottom: 0.5px solid var(--color-border-tertiary);
  overflow-x: auto;
}

.tab {
  padding: 10px 16px; font-size: 13px; color: var(--color-text-secondary);
  cursor: pointer; border-bottom: 2px solid transparent; transition: .15s;
  white-space: nowrap;
}

.tab:hover { color: var(--color-text-primary) }
.tab.active { color: var(--color-text-primary); border-bottom-color: var(--color-brand); font-weight: 500 }

/* ── Sections ── */
.body { padding: 16px 24px; background: var(--color-background-primary); border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg) }
.section { display: none }
.section.active { display: block }

/* ── KPI Grid ── */
.kpi-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 10px; margin-bottom: 16px }

.kpi {
  background: var(--color-background-secondary);
  border-radius: var(--border-radius-md);
  padding: 14px 16px;
}

.kpi-label { font-size: 11px; color: var(--color-text-secondary); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px }
.kpi-value { font-size: 24px; font-weight: 600; line-height: 1 }
.kpi-delta { font-size: 11px; margin-top: 5px }
.up { color: var(--color-text-success) }
.down { color: var(--color-text-danger) }
.neu { color: var(--color-text-secondary) }
.kpi-accent { border-left: 3px solid var(--color-brand) }

/* ── Grid Layouts ── */
.row2 { display: grid; grid-template-columns: 1.5fr 1fr; gap: 12px; margin-bottom: 16px }
.row3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 12px; margin-bottom: 16px }

/* ── Cards ── */
.card {
  background: var(--color-background-primary);
  border: 0.5px solid var(--color-border-tertiary);
  border-radius: var(--border-radius-lg);
  padding: 16px 18px;
}

.card-title {
  font-size: 12px; font-weight: 500; color: var(--color-text-secondary);
  text-transform: uppercase; letter-spacing: .05em; margin-bottom: 12px;
  display: flex; align-items: center; justify-content: space-between;
}

/* ── Charts ── */
.chart-wrap { position: relative; width: 100% }

/* ── Source Badges ── */
.source-bar { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px }

.src { font-size: 10px; padding: 3px 8px; border-radius: 20px; font-weight: 500 }
.src-ga { background: #e8f0fe; color: #1a73e8 }
.src-gsc { background: #fce4ec; color: #c2185b }
.src-gbp { background: #e6f4ea; color: #137333 }
.src-audit { background: #fff3e0; color: #e65100 }

/* ── Progress Bars ── */
.prog-row { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; font-size: 12px }
.prog-label { min-width: 90px; color: var(--color-text-secondary) }
.prog-track { flex: 1; height: 6px; background: var(--color-background-secondary); border-radius: 3px; overflow: hidden }
.prog-fill { height: 100%; border-radius: 3px; transition: width .6s ease }
.prog-val { min-width: 36px; text-align: right; font-weight: 500; font-size: 12px }

/* ── Reviews ── */
.review-row { display: flex; gap: 3px; margin-bottom: 3px }
.star { color: var(--color-brand); font-size: 14px }
.review-text { font-size: 12px; color: var(--color-text-secondary); margin-top: 4px; line-height: 1.5 }
.review-author { font-size: 11px; color: var(--color-text-tertiary); margin-top: 4px }

/* ── Sparkline ── */
.sparkline { display: flex; align-items: flex-end; gap: 3px; height: 36px }

.bar {
  background: var(--color-brand);
  border-radius: 2px 2px 0 0;
  opacity: .85; transition: .2s; min-width: 6px;
}

.bar:hover { opacity: 1 }

/* ── Lead/Query Table ── */
.query-row {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; border-bottom: 0.5px solid var(--color-border-tertiary); font-size: 13px;
}

.query-row:last-child { border: none }
.query-text { flex: 1; font-weight: 400 }
.query-metric { min-width: 60px; text-align: right; font-size: 12px }
.query-metric.accent { font-weight: 600; color: var(--color-brand-dark) }

/* ── Mini KPIs ── */
.mini-kpi-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 14px }

.mini-k {
  background: var(--color-background-secondary);
  border-radius: var(--border-radius-md);
  padding: 10px 12px; text-align: center;
}

.mini-k-v { font-size: 18px; font-weight: 600 }
.mini-k-l { font-size: 10px; color: var(--color-text-secondary); margin-top: 2px }

/* ── Badges ── */
.badge { font-size: 10px; padding: 2px 8px; border-radius: 20px; font-weight: 500; white-space: nowrap }
.b-ok { background: var(--color-background-success); color: var(--color-text-success) }
.b-warn { background: var(--color-background-warning); color: var(--color-text-warning) }
.b-crit { background: var(--color-background-danger); color: var(--color-text-danger) }
.b-info { background: var(--color-background-info); color: var(--color-text-info) }

/* ── Alerts ── */
.alert-row {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 12px; border-radius: var(--border-radius-md);
  margin-bottom: 8px; font-size: 12px;
}

.alert-icon {
  width: 18px; height: 18px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 10px; flex-shrink: 0; margin-top: 1px; font-weight: 700;
}

.a-crit { background: var(--color-background-danger) }
.a-crit .alert-icon { background: var(--color-text-danger); color: #fff }
.a-warn { background: var(--color-background-warning) }
.a-warn .alert-icon { background: var(--color-text-warning); color: #fff }
.a-ok { background: var(--color-background-success) }
.a-ok .alert-icon { background: var(--color-text-success); color: #fff }
.a-info { background: var(--color-background-info) }
.a-info .alert-icon { background: var(--color-text-info); color: #fff }
.alert-body { flex: 1 }
.alert-title { font-weight: 500; color: var(--color-text-primary); margin-bottom: 2px }
.alert-sub { color: var(--color-text-secondary); line-height: 1.4 }

/* ── Phase Pill ── */
.phase-pill {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; padding: 3px 10px; border-radius: 20px;
  background: var(--color-background-warning); color: var(--color-text-warning);
  font-weight: 500; margin-bottom: 14px;
}

.phase-dot { width: 6px; height: 6px; border-radius: 50%; background: currentColor }

/* ── Audit Filters ── */
.audit-filter {
  font-size: 11px; padding: 4px 12px; border-radius: 16px;
  background: var(--color-background-secondary); color: var(--color-text-secondary);
  border: 1px solid var(--color-border-tertiary); cursor: pointer;
  font-family: inherit; font-weight: 500; transition: all .2s;
}
.audit-filter:hover { border-color: var(--color-brand); color: var(--color-brand) }
.audit-filter.active { background: var(--color-brand); color: #fff; border-color: var(--color-brand) }

/* ── Phase Progress Rows ── */
.phase-progress-row {
  display: flex; align-items: center; gap: 10px; margin-bottom: 10px;
  padding: 8px 12px; background: var(--color-background-secondary);
  border-radius: var(--border-radius-md); font-size: 12px;
}
.phase-progress-row .phase-name { min-width: 200px; font-weight: 500; color: var(--color-text-primary) }
.phase-progress-row .prog-track { flex: 1; height: 8px }
.phase-progress-row .prog-val { min-width: 50px; text-align: right; font-weight: 600 }
.phase-complete { opacity: .85 }
.phase-complete .phase-name::after { content: ' ✓'; color: var(--color-text-success) }

/* ── Divider ── */
.divider { height: 0.5px; background: var(--color-border-tertiary); margin: 14px 0 }

/* ── Timestamp ── */
.timestamp { font-size: 10px; color: var(--color-text-tertiary); text-align: right; margin-top: 16px }

/* ── Position indicator ── */
.pos-indicator {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 500;
}

.pos-indicator.good { color: var(--color-text-success) }
.pos-indicator.mid { color: var(--color-text-warning) }
.pos-indicator.poor { color: var(--color-text-danger) }

/* ── Responsive ── */
@media (max-width: 768px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr) }
  .row2 { grid-template-columns: 1fr }
  .row3 { grid-template-columns: 1fr }
  .mini-kpi-row { grid-template-columns: repeat(2, 1fr) }
  .body { padding: 12px 16px }
}

@media (max-width: 480px) {
  .kpi-grid { grid-template-columns: 1fr }
  .tabs { flex-wrap: nowrap }
  .tab { padding: 10px 12px; font-size: 12px }
}

/* ── Loading Placeholder ── */
.loading-placeholder {
  font-size: 12px;
  color: var(--color-text-tertiary);
  padding: 16px 0;
  text-align: center;
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0%, 100% { opacity: 1 }
  50% { opacity: .4 }
}

/* ── GBP Post Alerts ── */
.post-alert {
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  line-height: 1.4;
}
.alert-overdue {
  background: #fff5f5;
  border-left: 3px solid #e53e3e;
  color: #c53030;
}
.alert-today {
  background: #fffbeb;
  border-left: 3px solid #dd6b20;
  color: #c05621;
}
.alert-soon {
  background: #fffff0;
  border-left: 3px solid #d69e2e;
  color: #975a16;
}


