/**
 * Admin Dashboard Styles
 * Extracted from inline style blocks in admin templates
 * Part of smsai Design System Phase 6
 *
 * All styles use design tokens from tokens.css
 * Mobile-first responsive design
 * Zero inline styles - all CSS consolidated here
 */

/* ========================================
   Health Dashboard Styles (admin/health.html)
   ======================================== */

/* Health toolbar */
.health-toolbar {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.health-toolbar__left {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  flex-wrap: wrap;
}

.health-info-chip {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.35);
  color: #fff;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-base);
  font-size: var(--text-sm);
}

.health-select {
  border: 1px solid rgba(255, 255, 255, 0.35);
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  border-radius: var(--radius-base);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-sm);
}

.health-select:focus {
  outline: 2px solid var(--color-primary-400);
  outline-offset: 2px;
}

/* Key-value grid */
.kv-grid {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: var(--space-2);
  border-top: 1px solid var(--color-border-secondary);
  padding-top: var(--space-3);
}

.kv-grid__key {
  color: var(--color-text-secondary);
  font-weight: var(--font-medium);
}

.kv-grid__value {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  color: var(--color-text-primary);
}

/* Health checks grid */
.checks-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  gap: var(--space-3);
}

.check-item {
  border: 1px solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.check-item__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}

.check-item__title {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}

.check-item__message {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

/* Status dots */
.status-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  display: inline-block;
}

.status-dot--healthy {
  background: var(--color-success-600);
}

.status-dot--degraded,
.status-dot--warning {
  background: var(--color-warning-600);
}

.status-dot--unhealthy {
  background: var(--color-danger-600);
}

.status-dot--unknown,
.status-dot--info {
  background: var(--color-info-600);
}

/* Raw JSON viewer */
.raw-json {
  background: #0b1020;
  color: #d1e4ff;
  border-radius: var(--radius-md);
  padding: var(--space-3);
  overflow: auto;
  max-height: 320px;
}

.raw-json pre {
  margin: 0;
  white-space: pre-wrap;
  word-break: break-word;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: var(--text-sm);
}

.footer-note {
  color: rgba(255, 255, 255, 0.85);
  font-size: var(--text-sm);
  margin-top: var(--space-3);
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

/* ========================================
   Login Styles (admin/login.html)
   ======================================== */

/* Login container */
.login-container {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--space-6);
  background: linear-gradient(135deg, var(--color-primary-600) 0%, #764ba2 100%);
}

.login-card {
  width: 100%;
  max-width: 480px;
}

.login-header {
  margin-bottom: var(--space-6);
}

.login-title {
  margin: 0 0 var(--space-2);
  color: var(--color-text-primary);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  line-height: var(--leading-tight);
}

.login-subtitle {
  margin: 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}

.form-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--space-2);
  align-items: end;
}

.login-footer {
  margin-top: var(--space-4);
  padding-top: var(--space-4);
  border-top: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-3);
}

.login-footer-text {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.login-link {
  color: var(--color-primary-600);
  text-decoration: none;
  font-weight: var(--font-semibold);
  font-size: var(--text-sm);
  transition: color var(--transition-base) var(--ease-in-out);
}

.login-link:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
}

/* Alert visibility toggle */
.alert-hidden {
  display: none;
}

/* ========================================
   Expert Management Styles (admin/experts.html)
   ======================================== */

/* Modal backdrop */
.modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.45);
  display: none;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  z-index: 1000;
}

/* Modal container */
.modal {
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  max-width: 720px;
  width: 100%;
  max-height: 90vh;
  overflow-y: auto;
}

.modal__header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border-secondary);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.modal__content {
  padding: var(--space-5);
}

.modal__footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-border-secondary);
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
}

.modal__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

/* Toast notification */
.toast {
  position: fixed;
  right: var(--space-4);
  bottom: var(--space-4);
  background: var(--color-bg-inverse);
  color: var(--color-text-inverse);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-base);
  box-shadow: var(--shadow-lg);
  display: none;
  z-index: 1001;
}

.toast--error {
  background: var(--color-danger-600);
}

/* Hint text */
.hint {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* Badge variants for experts */
.badge-fam {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
  color: #4338ca;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  display: inline-flex;
  align-items: center;
}

.badge-id {
  background: #ecfeff;
  border: 1px solid #a5f3fc;
  color: #0369a1;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  display: inline-flex;
  align-items: center;
}

.badge-store {
  background: #fef9c3;
  border: 1px solid #fde68a;
  color: #a16207;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  display: inline-flex;
  align-items: center;
}

.badge-count {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
  color: #065f46;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  display: inline-flex;
  align-items: center;
}

.note {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

/* ========================================
   Customer Management Styles (admin/customers.html)
   ======================================== */

/* Modal overlay for customers */
.modal.show {
  display: flex;
}

.modal__overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(4px);
}

.modal__content {
  position: relative;
  z-index: 1001;
  width: 92%;
  max-width: 520px;
  max-height: 90vh;
  overflow-y: auto;
  animation: modal-slide-up 0.2s ease-out;
}

@keyframes modal-slide-up {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* Actions bar responsive adjustments */
.customers-actions-bar .form-field {
  margin-bottom: 0;
}

.search-field {
  flex: 1;
  min-width: 240px;
}

/* ========================================
   Vector Store Styles (admin/vector-stores.html)
   ======================================== */

/* Toolbar */
.toolbar {
  display: flex;
  gap: var(--space-3);
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-4);
  flex-wrap: wrap;
}

.toolbar__left,
.toolbar__right {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  flex-wrap: wrap;
}

.toolbar__select {
  padding: var(--space-2) var(--space-3);
  border: var(--border-1) solid var(--color-border-primary);
  border-radius: var(--radius-base);
  background: var(--color-bg-primary);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  min-width: 180px;
}

.toolbar__select:focus {
  outline: 2px solid var(--color-primary-600);
  outline-offset: 2px;
}

.toolbar__input {
  padding: var(--space-2) var(--space-3);
  border: var(--border-1) solid var(--color-border-primary);
  border-radius: var(--radius-base);
  background: var(--color-bg-primary);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  min-width: 220px;
}

.toolbar__input:focus {
  outline: 2px solid var(--color-primary-600);
  outline-offset: 2px;
}

.table-actions {
  display: flex;
  gap: var(--space-2);
  white-space: nowrap;
}

.table__checkbox {
  width: 18px;
  height: 18px;
  cursor: pointer;
}

.table__note {
  font-size: var(--text-sm);
  color: var(--color-text-tertiary);
}

.toolbar__search {
  margin: 0;
  min-width: 200px;
}

/* ========================================
   Overview Dashboard Styles (admin/overview.html)
   ======================================== */

/* Admin layout */
.admin-layout {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--color-primary-600) 0%, var(--color-primary-800) 100%);
  padding: var(--space-5);
}

.admin-container {
  max-width: var(--container-xl);
  margin: 0 auto;
}

.admin-header {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-6) var(--space-8);
  margin-bottom: var(--space-5);
  box-shadow: var(--shadow-base);
}

.admin-header__title {
  color: var(--color-text-primary);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-1);
  line-height: var(--leading-tight);
}

.admin-header__subtitle {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.admin-nav {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-top: var(--space-4);
}

.admin-nav__link {
  color: var(--color-primary-600);
  text-decoration: none;
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-base);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  transition: background var(--transition-base) var(--ease-in-out);
  background: var(--color-bg-secondary);
}

.admin-nav__link:hover {
  background: var(--color-bg-tertiary);
}

.admin-nav__link--active {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
}

.admin-info {
  background: rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(10px);
  border: var(--border-1) solid rgba(255, 255, 255, 0.3);
  color: var(--color-surface);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-base);
  font-size: var(--text-sm);
  text-align: right;
  margin-bottom: var(--space-5);
}

.search-section {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-5);
  box-shadow: var(--shadow-base);
  display: flex;
  gap: var(--space-3);
  align-items: flex-end;
}

.search-section__field {
  flex: 1;
  margin-bottom: 0;
}

.activity-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.activity-item {
  padding: var(--space-4);
  border-bottom: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
}

.activity-item:last-child {
  border-bottom: none;
}

.activity-item__content {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.activity-item__phone {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

.activity-item__timestamp {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  white-space: nowrap;
}

.empty-state {
  text-align: center;
  padding: var(--space-12);
  color: var(--color-text-muted);
}

/* ========================================
   Admin Users Styles (admin/users.html)
   ======================================== */

/* Action Bar Layout */
.action-bar {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.search-box {
  display: flex;
  gap: var(--space-3);
  align-items: flex-end;
  flex: 1;
  max-width: 500px;
}

.action-buttons {
  display: flex;
  gap: var(--space-3);
}

/* Action Bar Card Spacing */
.action-bar-card {
  margin-bottom: var(--space-5);
}

/* Table Actions Column */
.actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* Modal Dialog */
.modal-backdrop {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
}

.modal-dialog {
  position: relative;
  z-index: 1001;
  max-width: 500px;
  width: 90%;
  max-height: 90vh;
  overflow-y: auto;
}

.modal-card {
  box-shadow: var(--shadow-2xl);
}

/* Form Actions */
.form-actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
  margin-top: var(--space-6);
}

/* ========================================
   Messages Styles (admin/messages.html)
   ======================================== */

/* Message bubble custom styles */
.message-bubble {
  max-width: 760px;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  line-height: 1.4;
  margin: var(--space-3) 0;
}

.message-bubble--user {
  background: #eef2ff;
  border: 1px solid #c7d2fe;
}

.message-bubble--assistant {
  background: #ecfdf5;
  border: 1px solid #a7f3d0;
}

.message-meta {
  color: var(--color-text-tertiary);
  font-size: var(--text-xs);
  margin-top: var(--space-2);
}

.filter-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-4);
}

.resolver-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
  margin-bottom: var(--space-3);
}

.status-message {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  margin-top: var(--space-2);
}

/* ========================================
   Campaigns Styles (admin/campaigns.html)
   ======================================== */

.metric-tile__value {
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
}

/* ========================================
   Customer 360 Styles (admin/customer_360.html)
   ======================================== */

/* Search Bar */
.search-bar {
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  margin-bottom: var(--space-5);
  box-shadow: var(--shadow-base);
  display: flex;
  gap: var(--space-3);
  align-items: center;
}

.search-input {
  flex: 1;
  padding: var(--space-3) var(--space-4);
  border: var(--border-1) solid var(--color-border-primary);
  border-radius: var(--radius-base);
  font-size: var(--text-sm);
  transition: var(--transition-base);
}

.search-input:focus {
  outline: none;
  border-color: var(--color-primary-600);
  box-shadow: var(--ring-primary);
}

/* Customer Header Customizations */
.customer-meta {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  margin-top: var(--space-4);
}

.customer-meta-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.customer-meta-item strong {
  color: var(--color-text-primary);
}

.customer-tags {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-3);
}

/* Grid Layout */
.customer-360-grid {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-5);
  margin-bottom: var(--space-5);
}

/* Profile Attributes */
.attribute-list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.attribute-list li {
  padding: var(--space-3) 0;
  border-bottom: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.attribute-list li:last-child {
  border-bottom: none;
}

.attribute-label {
  font-weight: var(--font-semibold);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.attribute-value {
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  text-align: right;
}

/* Timeline */
.timeline {
  position: relative;
  padding-left: 0;
}

.timeline-item {
  position: relative;
  padding-left: 40px;
  padding-bottom: var(--space-6);
}

.timeline-item:last-child {
  padding-bottom: 0;
}

.timeline-item::before {
  content: '';
  position: absolute;
  left: 12px;
  top: 8px;
  bottom: -8px;
  width: 2px;
  background: var(--color-border-primary);
}

.timeline-item:last-child::before {
  display: none;
}

.timeline-icon {
  position: absolute;
  left: 0;
  top: 0;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: var(--font-bold);
  background: var(--color-primary-600);
  color: white;
}

.timeline-icon.inbound {
  background: var(--color-info-600);
}

.timeline-icon.outbound {
  background: var(--color-success-600);
}

.timeline-icon.voice {
  background: #8b5cf6;
}

.timeline-icon.voice.inbound {
  background: #7c3aed;
}

.timeline-icon.voice.outbound {
  background: #a855f7;
}

.timeline-content {
  background: var(--color-bg-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  border-left: 3px solid var(--color-primary-600);
}

.timeline-content.inbound {
  border-left-color: var(--color-info-600);
}

.timeline-content.outbound {
  border-left-color: var(--color-success-600);
}

.timeline-content.voice {
  border-left-color: #8b5cf6;
  background: #f3f0ff;
}

.timeline-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}

.timeline-title {
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
}

.timeline-time {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}

.timeline-body {
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.timeline-meta {
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  gap: var(--space-3);
  flex-wrap: wrap;
}

.timeline-meta-item {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}

.timeline-meta-item strong {
  color: var(--color-text-primary);
}

.timeline-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: var(--space-2);
}

/* Voice-specific styles */
.voice-meta-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: #4c1d95;
  margin-bottom: var(--space-2);
}

.voice-meta-row span {
  display: inline-flex;
  gap: var(--space-1);
  align-items: center;
  background: rgba(139, 92, 246, 0.12);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-2);
  transition: var(--transition-base);
}

.voice-meta-row span:hover {
  background: rgba(139, 92, 246, 0.24);
  color: #312e81;
}

.voice-summary {
  margin-top: var(--space-2);
  background: rgba(139, 92, 246, 0.1);
  border: var(--border-1) solid rgba(139, 92, 246, 0.2);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  color: #4c1d95;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  max-height: 180px;
  overflow-y: auto;
}

.voice-section {
  margin-top: var(--space-3);
}

.voice-section strong {
  color: #4c1d95;
}

.voice-section ul {
  margin: var(--space-2) 0 0 var(--space-5);
  color: #312e81;
  font-size: var(--text-sm);
}

.voice-audio {
  margin-top: var(--space-3);
  padding: var(--space-3);
  background: rgba(15, 23, 42, 0.05);
  border-radius: var(--radius-md);
  border: var(--border-1) solid rgba(15, 23, 42, 0.1);
}

.voice-audio audio {
  width: 100%;
  outline: none;
}

/* Email-specific styles */
.email-subject {
  font-weight: var(--font-semibold);
  margin-bottom: var(--space-2);
}

.email-body {
  background: rgba(243, 244, 246, 0.5);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}

.email-attachments {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.email-attachment {
  border: var(--border-1) solid var(--color-border-primary);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  font-size: var(--text-xs);
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
}

/* Read Status */
.read-status {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.read-status.read {
  color: var(--color-success-700);
}

/* Presence Indicators */
.presence-banner {
  background: rgba(99, 102, 241, 0.08);
  border: var(--border-1) solid rgba(99, 102, 241, 0.3);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  margin-bottom: var(--space-4);
  display: none;
  gap: var(--space-2);
  flex-wrap: wrap;
  align-items: center;
}

.presence-pill {
  background: rgba(99, 102, 241, 0.16);
  color: var(--color-primary-600);
  border-radius: var(--radius-full);
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
}

/* Typing Indicator */
.typing-indicator {
  display: none;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-3);
}

.typing-indicator .dot {
  width: 6px;
  height: 6px;
  border-radius: var(--radius-full);
  background: var(--color-text-secondary);
  animation: blink 1.4s infinite both;
}

.typing-indicator .dot:nth-child(2) {
  animation-delay: 0.2s;
}

.typing-indicator .dot:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes blink {
  0%, 80%, 100% {
    opacity: 0;
  }
  40% {
    opacity: 1;
  }
}

/* ========================================
   Accessibility: Prefers Reduced Motion
   Phase 7: Motion-sensitive user support
   ======================================== */

@media (prefers-reduced-motion: reduce) {
  /* Disable all animations and transitions */
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  /* Neutralize specific animations */
  @keyframes campaigns-pulse {
    0%, 100% {
      opacity: 1;
    }
    50% {
      opacity: 1;
    }
  }

  @keyframes modal-slide-up {
    from {
      opacity: 1;
      transform: translateY(0);
    }
    to {
      opacity: 1;
      transform: translateY(0);
    }
  }

  @keyframes blink {
    0%, 80%, 100% {
      opacity: 1;
    }
    40% {
      opacity: 1;
    }
  }

  @keyframes spin {
    to {
      transform: rotate(0deg);
    }
  }

  /* Remove hover transforms */
  .campaigns-metric-card:hover,
  .campaigns-list-item:hover,
  .campaigns-activity-item:hover,
  .funnel-step:hover,
  .voice-meta-row span:hover {
    transform: none !important;
  }

  /* Disable pulsing live indicator */
  .campaigns-live-indicator__dot {
    animation: none;
    opacity: 1;
  }

  /* Disable typing indicator animation */
  .typing-indicator .dot {
    animation: none;
    opacity: 1;
  }

  /* Disable spinner animation */
  .spinner {
    animation: none;
    border-top-color: var(--color-border-primary);
  }
}

/* Loading & Empty States */
.loading,
.empty {
  text-align: center;
  padding: var(--space-10);
  color: var(--color-text-secondary);
}

.spinner {
  display: inline-block;
  width: 40px;
  height: 40px;
  border: 4px solid var(--color-border-primary);
  border-top-color: var(--color-primary-600);
  border-radius: var(--radius-full);
  animation: spin 1s linear infinite;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

/* Error Message */
.error-message {
  background: var(--color-danger-50);
  border: var(--border-1) solid var(--color-danger-200);
  color: var(--color-danger-700);
  padding: var(--space-4);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-5);
}

/* ========================================
   Campaign Detail Styles (campaigns/detail.html)
   ======================================== */

/* Page Header for Campaign Detail */
.page-header {
  margin-bottom: var(--space-5);
}

.page-header__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  flex-wrap: wrap;
  margin-bottom: var(--space-3);
}

.page-header__title {
  margin: 0;
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  line-height: var(--leading-tight);
}

.page-header__actions {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.page-header__back {
  display: inline-flex;
  align-items: center;
  color: var(--color-primary-600);
  text-decoration: none;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  transition: color var(--transition-base) var(--ease-in-out);
}

.page-header__back:hover {
  color: var(--color-primary-700);
  text-decoration: underline;
}

/* Help Icon for Tooltips */
.help-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: var(--radius-full);
  background: var(--color-bg-tertiary);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  cursor: help;
  transition: background var(--transition-base) var(--ease-in-out),
              color var(--transition-base) var(--ease-in-out);
}

.help-icon:hover,
.help-icon:focus {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
}

.help-icon:focus {
  outline: var(--border-2) solid var(--color-primary-600);
  outline-offset: 2px;
}

/* Card Header Content with Icon */
.card__header-content {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
}

/* Stats Grid for Metric Tiles */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
  gap: var(--space-4);
}

/* Funnel Step Visualization */
.funnel-step {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4);
  border-bottom: var(--border-1) solid var(--color-border-secondary);
  transition: background var(--transition-base) var(--ease-in-out);
}

.funnel-step:last-child {
  border-bottom: none;
}

.funnel-step:hover {
  background: var(--color-bg-secondary);
}

.funnel-step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  border-radius: var(--radius-full);
  background: var(--color-primary-100);
  color: var(--color-primary-700);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  flex-shrink: 0;
}

.funnel-step__info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.funnel-step__name {
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  font-size: var(--text-base);
}

.funnel-step__stats {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}

.funnel-step__bar {
  flex: 0 0 200px;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  align-items: flex-end;
}

.funnel-step__percentage {
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  font-size: var(--text-sm);
  min-width: 50px;
  text-align: right;
}

/* Progress Bar for Funnel Steps */
.progress-bar {
  width: 100%;
  height: 8px;
  background: var(--color-bg-tertiary);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress-bar__fill {
  height: 100%;
  background: var(--color-primary-600);
  border-radius: var(--radius-full);
  transition: width var(--transition-base) var(--ease-in-out);
}

/* Tab Panel Spacing */
.tabs__panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
}

/* ========================================
   Campaign Analytics Styles (campaigns/analytics.html)
   ======================================== */

/* Campaign Overview Section */
.campaign-analytics-overview {
  display: flex;
  gap: var(--space-6);
  flex-wrap: wrap;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  margin: 0;
}

.campaign-analytics-overview__item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.campaign-analytics-overview__value {
  font-weight: var(--font-bold);
  font-size: var(--text-base);
}

.campaign-analytics-overview__value--primary {
  color: var(--color-primary-600);
}

.campaign-analytics-overview__value--success {
  color: var(--color-success-600);
}

/* Step Header with Tooltip */
.campaign-analytics-step-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.campaign-analytics-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: var(--radius-full);
  background: var(--color-bg-tertiary);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  cursor: help;
  transition: background var(--transition-base) var(--ease-in-out);
}

.campaign-analytics-info-icon:hover {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
}

/* Variant Grid */
.campaign-analytics-variant-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
  gap: var(--space-4);
}

.campaign-analytics-variant-card {
  margin-bottom: 0;
  display: flex;
  flex-direction: column;
}

/* Variant Header */
.campaign-analytics-variant-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: var(--space-4);
  border-bottom: var(--border-1) solid var(--color-border-secondary);
}

.campaign-analytics-variant-label {
  font-weight: var(--font-semibold);
  font-size: var(--text-base);
  color: var(--color-text-primary);
}

/* Variant Stats Grid */
.campaign-analytics-variant-stats {
  padding: var(--space-4);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  flex: 1;
}

.campaign-analytics-stat {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}

.campaign-analytics-stat__value {
  display: block;
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  line-height: var(--leading-tight);
}

.campaign-analytics-stat__value--success {
  color: var(--color-success-600);
}

.campaign-analytics-stat__value--primary {
  color: var(--color-primary-600);
}

.campaign-analytics-stat__label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

.campaign-analytics-stat-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: var(--radius-full);
  background: var(--color-bg-tertiary);
  color: var(--color-text-secondary);
  font-size: 10px;
  font-weight: var(--font-bold);
  cursor: help;
  font-style: normal;
  transition: background var(--transition-base) var(--ease-in-out);
}

.campaign-analytics-stat-help:hover {
  background: var(--color-primary-100);
  color: var(--color-primary-700);
}

/* Variant Footer with Status Chips */
.campaign-analytics-variant-footer {
  padding: var(--space-3) var(--space-4);
  border-top: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  gap: var(--space-2);
  justify-content: center;
}

/* Funnel Chart Section */
.campaign-analytics-funnel-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
  width: 100%;
}

.campaign-analytics-funnel-dropdown {
  min-width: 180px;
}

.campaign-analytics-chart-placeholder {
  height: 200px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 2px dashed var(--color-border-secondary);
  border-radius: var(--radius-base);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  background: var(--color-bg-secondary);
  transition: border-color var(--transition-base) var(--ease-in-out);
}

.campaign-analytics-chart-placeholder:hover {
  border-color: var(--color-border-primary);
}

/* ========================================
   Responsive Overrides
   ======================================== */

@media (max-width: 968px) {
  .customer-360-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .admin-layout {
    padding: var(--space-3);
  }

  .admin-header {
    padding: var(--space-4) var(--space-5);
  }

  .admin-header__title {
    font-size: var(--text-xl);
  }

  .search-section {
    flex-direction: column;
    align-items: stretch;
  }

  .activity-item {
    flex-direction: column;
    align-items: flex-start;
  }

  .activity-item__timestamp {
    align-self: flex-end;
  }

  .action-bar {
    flex-direction: column;
    align-items: stretch;
  }

  .search-box {
    max-width: none;
  }

  .action-buttons {
    justify-content: stretch;
  }

  .action-buttons .btn {
    flex: 1;
  }

  .message-bubble,
  .filter-row,
  .resolver-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .modal__row,
  .toolbar,
  .toolbar__left,
  .toolbar__right {
    grid-template-columns: 1fr !important;
    flex-direction: column;
    align-items: stretch !important;
  }
}

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

  .health-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .health-toolbar__left {
    flex-direction: column;
    align-items: stretch;
  }

  .form-row {
    grid-template-columns: 1fr !important;
  }

  .modal__content {
    width: 95%;
    max-height: 95vh;
  }

  .metrics-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  }

  /* Campaign Analytics responsive */
  .campaign-analytics-overview {
    flex-direction: column;
    gap: var(--space-3);
  }

  .campaign-analytics-variant-stats {
    grid-template-columns: 1fr;
  }

  .campaign-analytics-funnel-header {
    flex-direction: column;
    align-items: flex-start;
  }

  .campaign-analytics-funnel-dropdown {
    width: 100%;
  }

  /* Campaign Detail responsive */
  .page-header__actions {
    flex-direction: column;
    align-items: flex-start;
    width: 100%;
  }
}

@media (max-width: 768px) {
  /* Campaign Detail medium screen adjustments */
  .page-header__top {
    flex-direction: column;
    align-items: flex-start;
  }

  .page-header__title {
    font-size: var(--text-xl);
  }

  .funnel-step {
    flex-direction: column;
    align-items: stretch;
    gap: var(--space-3);
  }

  .funnel-step__bar {
    flex: 1;
    align-items: stretch;
  }

  .funnel-step__percentage {
    text-align: left;
  }

  .stats-grid {
    grid-template-columns: 1fr;
  }
}

/* ========================================
   Campaigns Overview Styles (campaigns/overview.html)
   Migrated from inline styles - Phase 7 Wave 1
   ======================================== */

/* Dashboard header */
.campaigns-dashboard-header {
  margin-bottom: var(--space-8);
}

.campaigns-dashboard-header h1 {
  margin: 0 0 var(--space-2) 0;
  font-size: var(--text-3xl);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}

.campaigns-dashboard-subtitle {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
}

/* Live indicator with pulsing dot */
.campaigns-live-indicator {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  background: rgba(22, 163, 74, 0.1);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  color: var(--color-success-600);
}

.campaigns-live-indicator__dot {
  width: 8px;
  height: 8px;
  background: var(--color-success-600);
  border-radius: 50%;
  animation: campaigns-pulse 2s infinite;
}

@keyframes campaigns-pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

/* Metrics grid */
.campaigns-metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 250px), 1fr));
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

@media (min-width: 768px) {
  .campaigns-metrics-grid {
    gap: var(--space-6);
  }
}

/* Metric card */
.campaigns-metric-card {
  background: var(--color-surface);
  border: var(--border-1) solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  transition: box-shadow var(--transition-base) var(--ease-in-out);
}

.campaigns-metric-card:hover {
  box-shadow: var(--shadow-md);
}

.campaigns-metric-card__label {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  font-weight: var(--font-medium);
  margin-bottom: var(--space-2);
}

.campaigns-metric-card__value {
  font-size: var(--text-4xl);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
  line-height: var(--leading-tight);
}

/* Campaigns section */
.campaigns-section {
  background: var(--color-surface);
  border: var(--border-1) solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  margin-bottom: var(--space-8);
}

.campaigns-section-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-6);
  flex-wrap: wrap;
  gap: var(--space-4);
}

.campaigns-section-header h2 {
  margin: 0;
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
}

/* Campaign list */
.campaigns-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.campaigns-list-item {
  padding: var(--space-4);
  border-bottom: var(--border-1) solid var(--color-border-secondary);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  transition: background-color var(--transition-base) var(--ease-in-out);
}

.campaigns-list-item:last-child {
  border-bottom: none;
}

.campaigns-list-item:hover {
  background-color: var(--color-bg-tertiary);
}

@media (max-width: 768px) {
  .campaigns-list-item {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Campaign list item info */
.campaigns-list-item__info {
  flex: 1;
  min-width: 0;
}

.campaigns-list-item__info h3 {
  margin: 0 0 var(--space-1) 0;
  font-size: var(--text-base);
  font-weight: var(--font-medium);
}

.campaigns-list-item__info h3 a {
  color: var(--color-text-primary);
  text-decoration: none;
  transition: color var(--transition-base);
}

.campaigns-list-item__info h3 a:hover {
  color: var(--color-primary-600);
}

.campaigns-list-item__info p {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}

/* Campaign list item stats */
.campaigns-list-item__stats {
  display: flex;
  gap: var(--space-6);
  font-size: var(--text-sm);
}

@media (max-width: 768px) {
  .campaigns-list-item__stats {
    width: 100%;
    justify-content: space-between;
    gap: var(--space-4);
  }
}

/* Campaign stat */
.campaigns-stat {
  text-align: center;
}

.campaigns-stat__value {
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  color: var(--color-text-primary);
  display: block;
  line-height: var(--leading-tight);
}

.campaigns-stat__label {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
}

/* Activity feed */
.campaigns-activity-feed {
  background: var(--color-surface);
  border: var(--border-1) solid var(--color-border-secondary);
  border-radius: var(--radius-md);
  padding: var(--space-6);
}

.campaigns-activity-item {
  padding: var(--space-3);
  border-left: var(--border-4) solid var(--color-border-secondary);
  margin-bottom: var(--space-3);
  font-size: var(--text-sm);
  transition: background-color var(--transition-base) var(--ease-in-out);
}

.campaigns-activity-item:last-child {
  margin-bottom: 0;
}

.campaigns-activity-item:hover {
  background-color: var(--color-bg-tertiary);
}

.campaigns-activity-item--success {
  border-left-color: var(--color-success-600);
}

.campaigns-activity-item--failure {
  border-left-color: var(--color-danger-600);
}

.campaigns-activity-item__time {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  margin-bottom: var(--space-1);
  font-weight: var(--font-medium);
}

/* Empty state */
.campaigns-empty-state {
  text-align: center;
  padding: var(--space-12) var(--space-4);
  color: var(--color-text-secondary);
}

.campaigns-empty-state svg {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-4);
  opacity: 0.5;
  color: var(--color-text-muted);
}

.campaigns-empty-state p {
  margin: 0;
  font-size: var(--text-base);
  color: var(--color-text-muted);
}
