/**
 * CoRaise Design System - CSS Variables
 * Generated by CoRaise Theme Forge
 */

/* ============================================
   BASE SCALE TOKENS (mode-independent)
   ============================================ */

:root {
  /* Primary Color Scale */
  --cr-primary-50: #F0F6F8;
  --cr-primary-100: #DCE9ED;
  --cr-primary-200: #B9D3DC;
  --cr-primary-300: #8FBAC8;
  --cr-primary-400: #6BA0B0;
  --cr-primary-500: #5A8A9D;
  --cr-primary-600: #4A7485;
  --cr-primary-700: #3D5F6D;
  --cr-primary-800: #324D59;
  --cr-primary-900: #283D47;
  --cr-primary-950: #1C2B32;

  /* Secondary Color Scale */
  --cr-secondary-50: #EEFBFC;
  --cr-secondary-100: #D4F4F6;
  --cr-secondary-200: #ADE9ED;
  --cr-secondary-300: #7BD9E0;
  --cr-secondary-400: #5EC9CF;
  --cr-secondary-500: #49ACB2;
  --cr-secondary-600: #3A9299;
  --cr-secondary-700: #317880;
  --cr-secondary-800: #2A6066;
  --cr-secondary-900: #244E53;
  --cr-secondary-950: #183538;

  /* Neutral Color Scale */
  --cr-neutral-50: #F8FAFB;
  --cr-neutral-100: #F1F4F6;
  --cr-neutral-200: #E2E7EA;
  --cr-neutral-300: #CED5DA;
  --cr-neutral-400: #A8B4BC;
  --cr-neutral-500: #7B8C96;
  --cr-neutral-600: #5A6B75;
  --cr-neutral-700: #465560;
  --cr-neutral-800: #384C57;
  --cr-neutral-900: #242F36;
  --cr-neutral-950: #141D22;

  /* Spacing Scale */
  --cr-space-0: 0;
  --cr-space-1: 4px;
  --cr-space-2: 8px;
  --cr-space-3: 12px;
  --cr-space-4: 16px;
  --cr-space-5: 20px;
  --cr-space-6: 24px;
  --cr-space-8: 32px;
  --cr-space-10: 40px;
  --cr-space-12: 48px;
  --cr-space-16: 64px;
  --cr-space-20: 80px;
  --cr-space-24: 96px;

  /* Border Radius Scale */
  --cr-radius-xs: 6px;
  --cr-radius-sm: 10px;
  --cr-radius-md: 14px;
  --cr-radius-lg: 18px;
  --cr-radius-xl: 24px;
  --cr-radius-2xl: 32px;
  --cr-radius-pill: 999px;

  /* Font Families */
  --cr-font-heading: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --cr-font-body: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --cr-font-mono: ui-monospace, SFMono-Regular, 'SF Mono', Menlo, Consolas, monospace;

  /* Font Sizes */
  --cr-text-xs: 12px;
  --cr-text-sm: 14px;
  --cr-text-base: 16px;
  --cr-text-lg: 18px;
  --cr-text-xl: 20px;
  --cr-text-2xl: 24px;
  --cr-text-3xl: 30px;
  --cr-text-4xl: 36px;
  --cr-text-5xl: 48px;
  --cr-text-6xl: 60px;

  /* Font Weights */
  --cr-font-regular: 400;
  --cr-font-medium: 500;
  --cr-font-semibold: 600;
  --cr-font-bold: 700;

  /* Line Heights */
  --cr-leading-tight: 1.12;
  --cr-leading-snug: 1.28;
  --cr-leading-normal: 1.5;
  --cr-leading-relaxed: 1.65;

  /* Letter Spacing */
  --cr-tracking-tight: -0.02em;
  --cr-tracking-normal: 0;
  --cr-tracking-wide: 0.02em;

  /* Shadows */
  --cr-shadow-sm: 0 1px 2px 0 rgba(20, 29, 34, 0.05);
  --cr-shadow-md: 0 4px 6px -1px rgba(20, 29, 34, 0.08), 0 2px 4px -2px rgba(20, 29, 34, 0.04);
  --cr-shadow-lg: 0 10px 15px -3px rgba(20, 29, 34, 0.08), 0 4px 6px -4px rgba(20, 29, 34, 0.04);
  --cr-shadow-xl: 0 20px 25px -5px rgba(20, 29, 34, 0.1), 0 8px 10px -6px rgba(20, 29, 34, 0.05);

  /* Motion */
  --cr-duration-fast: 120ms;
  --cr-duration-base: 180ms;
  --cr-duration-slow: 260ms;
  --cr-easing-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --cr-easing-emphasized: cubic-bezier(0.2, 0, 0, 1);

  /* Component Dimensions */
  --cr-btn-height-sm: 36px;
  --cr-btn-height-md: 44px;
  --cr-btn-height-lg: 52px;
  --cr-btn-radius: var(--cr-radius-lg);
  --cr-btn-px-sm: 16px;
  --cr-btn-px-md: 20px;
  --cr-btn-px-lg: 24px;

  --cr-input-height-sm: 40px;
  --cr-input-height-md: 48px;
  --cr-input-radius: var(--cr-radius-lg);
  --cr-input-px: 16px;

  --cr-card-radius: var(--cr-radius-xl);
  --cr-card-padding: 24px;

  --cr-badge-radius: var(--cr-radius-pill);
  --cr-badge-px: 10px;
  --cr-badge-py: 4px;

  --cr-chip-radius: var(--cr-radius-pill);
  --cr-chip-px: 12px;
  --cr-chip-py: 6px;

  --cr-modal-radius: var(--cr-radius-2xl);
  --cr-modal-padding: 24px;

  --cr-toast-radius: var(--cr-radius-lg);
  --cr-toast-padding: 16px;
}

/* ============================================
   LIGHT MODE SEMANTIC TOKENS (default)
   ============================================ */

:root {
  /* Core Semantics */
  --cr-bg: #F8FAFB;
  --cr-fg: #141D22;
  --cr-surface: #FFFFFF;
  --cr-surface2: #F1F4F6;
  --cr-border: #E2E7EA;
  --cr-muted: #7B8C96;
  --cr-accent: #49ACB2;
  --cr-accent-fg: #FFFFFF;

  /* Status Colors */
  --cr-info: #3B82F6;
  --cr-info-fg: #FFFFFF;
  --cr-success: #10B981;
  --cr-success-fg: #FFFFFF;
  --cr-warning: #F59E0B;
  --cr-warning-fg: #141D22;
  --cr-destructive: #EF4444;
  --cr-destructive-fg: #FFFFFF;

  /* Focus */
  --cr-focus-ring: rgba(73, 172, 178, 0.5);

  /* Gradients */
  --cr-hero-gradient: linear-gradient(135deg, #F0F6F8 0%, #EEFBFC 50%, #F8FAFB 100%);
  --cr-surface-gradient: linear-gradient(180deg, #FFFFFF 0%, #F8FAFB 100%);

  /* Button: Primary */
  --cr-btn-primary-bg: #5A8A9D;
  --cr-btn-primary-bg-hover: #4A7485;
  --cr-btn-primary-bg-active: #3D5F6D;
  --cr-btn-primary-fg: #FFFFFF;

  /* Button: Secondary */
  --cr-btn-secondary-bg: #F1F4F6;
  --cr-btn-secondary-bg-hover: #E2E7EA;
  --cr-btn-secondary-bg-active: #CED5DA;
  --cr-btn-secondary-fg: #141D22;

  /* Button: Ghost */
  --cr-btn-ghost-bg: transparent;
  --cr-btn-ghost-bg-hover: rgba(90, 138, 157, 0.08);
  --cr-btn-ghost-bg-active: rgba(90, 138, 157, 0.12);
  --cr-btn-ghost-fg: #5A8A9D;

  /* Button: Destructive */
  --cr-btn-destructive-bg: #EF4444;
  --cr-btn-destructive-bg-hover: #DC2626;
  --cr-btn-destructive-bg-active: #B91C1C;
  --cr-btn-destructive-fg: #FFFFFF;

  /* Input */
  --cr-input-bg: #FFFFFF;
  --cr-input-border: #E2E7EA;
  --cr-input-border-focus: #5A8A9D;
  --cr-input-border-error: #EF4444;
  --cr-input-placeholder: #A8B4BC;

  /* Status Badges */
  --cr-status-pending-bg: #FEF3C7;
  --cr-status-pending-fg: #92400E;
  --cr-status-pending-border: #FCD34D;

  --cr-status-ready-bg: #D1FAE5;
  --cr-status-ready-fg: #065F46;
  --cr-status-ready-border: #6EE7B7;

  --cr-status-failed-bg: #FEE2E2;
  --cr-status-failed-fg: #991B1B;
  --cr-status-failed-border: #FCA5A5;

  /* Preset: Calm Communication */
  --cr-message-mine-bg: #5A8A9D;
  --cr-message-mine-fg: #FFFFFF;
  --cr-message-theirs-bg: #F1F4F6;
  --cr-message-theirs-fg: #141D22;
  --cr-timeline-dot: #49ACB2;
  --cr-timeline-line: #E2E7EA;

  /* Preset: Evidence Mode */
  --cr-evidence-bg: #FAFBFC;
  --cr-evidence-border: #CED5DA;
  --cr-immutable-mark: #5A8A9D;
  --cr-verified: #10B981;
  --cr-verified-bg: #ECFDF5;
  --cr-unverified: #F59E0B;
  --cr-unverified-bg: #FFFBEB;
  --cr-timestamp: #7B8C96;
  --cr-audit-row-bg: #FFFFFF;
  --cr-audit-row-bg-alt: #F8FAFB;
  --cr-audit-row-border: #E2E7EA;
}

/* ============================================
   DARK MODE SEMANTIC TOKENS
   ============================================ */

[data-theme="dark"] {
  /* Core Semantics */
  --cr-bg: #141D22;
  --cr-fg: #F1F4F6;
  --cr-surface: #1C2A30;
  --cr-surface2: #243138;
  --cr-border: #384C57;
  --cr-muted: #7B8C96;
  --cr-accent: #5EC9CF;
  --cr-accent-fg: #141D22;

  /* Status Colors */
  --cr-info: #60A5FA;
  --cr-info-fg: #141D22;
  --cr-success: #34D399;
  --cr-success-fg: #141D22;
  --cr-warning: #FBBF24;
  --cr-warning-fg: #141D22;
  --cr-destructive: #F87171;
  --cr-destructive-fg: #141D22;

  /* Focus */
  --cr-focus-ring: rgba(94, 201, 207, 0.5);

  /* Gradients */
  --cr-hero-gradient: linear-gradient(135deg, #1C2B32 0%, #183538 50%, #141D22 100%);
  --cr-surface-gradient: linear-gradient(180deg, #1C2A30 0%, #141D22 100%);

  /* Shadows (more pronounced for dark mode) */
  --cr-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.2);
  --cr-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.3), 0 2px 4px -2px rgba(0, 0, 0, 0.2);
  --cr-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.35), 0 4px 6px -4px rgba(0, 0, 0, 0.2);
  --cr-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.4), 0 8px 10px -6px rgba(0, 0, 0, 0.25);

  /* Button: Primary */
  --cr-btn-primary-bg: #5EC9CF;
  --cr-btn-primary-bg-hover: #7BD9E0;
  --cr-btn-primary-bg-active: #49ACB2;
  --cr-btn-primary-fg: #141D22;

  /* Button: Secondary */
  --cr-btn-secondary-bg: #243138;
  --cr-btn-secondary-bg-hover: #2E3E46;
  --cr-btn-secondary-bg-active: #384C57;
  --cr-btn-secondary-fg: #F1F4F6;

  /* Button: Ghost */
  --cr-btn-ghost-bg: transparent;
  --cr-btn-ghost-bg-hover: rgba(94, 201, 207, 0.12);
  --cr-btn-ghost-bg-active: rgba(94, 201, 207, 0.18);
  --cr-btn-ghost-fg: #5EC9CF;

  /* Button: Destructive */
  --cr-btn-destructive-bg: #F87171;
  --cr-btn-destructive-bg-hover: #FCA5A5;
  --cr-btn-destructive-bg-active: #EF4444;
  --cr-btn-destructive-fg: #141D22;

  /* Input */
  --cr-input-bg: #1C2A30;
  --cr-input-border: #384C57;
  --cr-input-border-focus: #5EC9CF;
  --cr-input-border-error: #F87171;
  --cr-input-placeholder: #5A6B75;

  /* Status Badges */
  --cr-status-pending-bg: #3D2E08;
  --cr-status-pending-fg: #FCD34D;
  --cr-status-pending-border: #92400E;

  --cr-status-ready-bg: #052E24;
  --cr-status-ready-fg: #6EE7B7;
  --cr-status-ready-border: #065F46;

  --cr-status-failed-bg: #3B1111;
  --cr-status-failed-fg: #FCA5A5;
  --cr-status-failed-border: #991B1B;

  /* Preset: Calm Communication */
  --cr-message-mine-bg: #5EC9CF;
  --cr-message-mine-fg: #141D22;
  --cr-message-theirs-bg: #243138;
  --cr-message-theirs-fg: #F1F4F6;
  --cr-timeline-dot: #5EC9CF;
  --cr-timeline-line: #384C57;

  /* Preset: Evidence Mode */
  --cr-evidence-bg: #1C2A30;
  --cr-evidence-border: #465560;
  --cr-immutable-mark: #5EC9CF;
  --cr-verified: #34D399;
  --cr-verified-bg: #052E24;
  --cr-unverified: #FBBF24;
  --cr-unverified-bg: #3D2E08;
  --cr-timestamp: #7B8C96;
  --cr-audit-row-bg: #1C2A30;
  --cr-audit-row-bg-alt: #243138;
  --cr-audit-row-border: #384C57;
}

/* ============================================
   PRESET OVERRIDES
   ============================================ */

[data-preset="calm-communication"] {
  /* Calm communication preset is default, no overrides needed */
}

[data-preset="evidence-mode"] {
  /* Evidence mode emphasizes document/audit styling */
  --cr-surface: var(--cr-evidence-bg);
  --cr-border: var(--cr-evidence-border);
}

/* ============================================
   UTILITY CLASSES
   ============================================ */

.cr-surface {
  background-color: var(--cr-surface);
  color: var(--cr-fg);
}

.cr-surface2 {
  background-color: var(--cr-surface2);
  color: var(--cr-fg);
}

.cr-card {
  background-color: var(--cr-surface);
  border-radius: var(--cr-card-radius);
  padding: var(--cr-card-padding);
  box-shadow: var(--cr-shadow-md);
}

.cr-border {
  border: 1px solid var(--cr-border);
}

.cr-focus-ring:focus,
.cr-focus-ring:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--cr-focus-ring);
}

.cr-hero-bg {
  background: var(--cr-hero-gradient);
}

/* ============================================
   BADGE & CHIP STYLES
   ============================================ */

.cr-badge {
  display: inline-flex;
  align-items: center;
  padding: var(--cr-badge-py) var(--cr-badge-px);
  border-radius: var(--cr-badge-radius);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-font-medium);
  line-height: 1;
}

.cr-badge--info {
  background-color: var(--cr-info);
  color: var(--cr-info-fg);
}

.cr-badge--success {
  background-color: var(--cr-success);
  color: var(--cr-success-fg);
}

.cr-badge--warning {
  background-color: var(--cr-warning);
  color: var(--cr-warning-fg);
}

.cr-badge--destructive {
  background-color: var(--cr-destructive);
  color: var(--cr-destructive-fg);
}

.cr-chip {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-2);
  padding: var(--cr-chip-py) var(--cr-chip-px);
  border-radius: var(--cr-chip-radius);
  font-size: var(--cr-text-sm);
  font-weight: var(--cr-font-medium);
  background-color: var(--cr-surface2);
  color: var(--cr-fg);
  border: 1px solid var(--cr-border);
  transition: all var(--cr-duration-fast) var(--cr-easing-standard);
}

.cr-chip:hover {
  background-color: var(--cr-border);
}

/* ============================================
   STATUS BADGES
   ============================================ */

.cr-status {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-1);
  padding: var(--cr-badge-py) var(--cr-badge-px);
  border-radius: var(--cr-badge-radius);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-font-semibold);
  text-transform: uppercase;
  letter-spacing: var(--cr-tracking-wide);
}

.cr-status--pending {
  background-color: var(--cr-status-pending-bg);
  color: var(--cr-status-pending-fg);
  border: 1px solid var(--cr-status-pending-border);
}

.cr-status--ready {
  background-color: var(--cr-status-ready-bg);
  color: var(--cr-status-ready-fg);
  border: 1px solid var(--cr-status-ready-border);
}

.cr-status--failed {
  background-color: var(--cr-status-failed-bg);
  color: var(--cr-status-failed-fg);
  border: 1px solid var(--cr-status-failed-border);
}

/* ============================================
   BUTTON STYLES
   ============================================ */

.cr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--cr-space-2);
  font-family: var(--cr-font-body);
  font-weight: var(--cr-font-semibold);
  border: none;
  cursor: pointer;
  transition: all var(--cr-duration-fast) var(--cr-easing-standard);
}

.cr-btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--cr-focus-ring);
}

.cr-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Button Sizes */
.cr-btn--sm {
  height: var(--cr-btn-height-sm);
  padding: 0 var(--cr-btn-px-sm);
  font-size: var(--cr-text-sm);
  border-radius: var(--cr-btn-radius);
}

.cr-btn--md {
  height: var(--cr-btn-height-md);
  padding: 0 var(--cr-btn-px-md);
  font-size: var(--cr-text-base);
  border-radius: var(--cr-btn-radius);
}

.cr-btn--lg {
  height: var(--cr-btn-height-lg);
  padding: 0 var(--cr-btn-px-lg);
  font-size: var(--cr-text-lg);
  border-radius: var(--cr-btn-radius);
}

/* Button Variants */
.cr-btn--primary {
  background-color: var(--cr-btn-primary-bg);
  color: var(--cr-btn-primary-fg);
}

.cr-btn--primary:hover:not(:disabled) {
  background-color: var(--cr-btn-primary-bg-hover);
}

.cr-btn--primary:active:not(:disabled) {
  background-color: var(--cr-btn-primary-bg-active);
}

.cr-btn--secondary {
  background-color: var(--cr-btn-secondary-bg);
  color: var(--cr-btn-secondary-fg);
}

.cr-btn--secondary:hover:not(:disabled) {
  background-color: var(--cr-btn-secondary-bg-hover);
}

.cr-btn--secondary:active:not(:disabled) {
  background-color: var(--cr-btn-secondary-bg-active);
}

.cr-btn--ghost {
  background-color: var(--cr-btn-ghost-bg);
  color: var(--cr-btn-ghost-fg);
}

.cr-btn--ghost:hover:not(:disabled) {
  background-color: var(--cr-btn-ghost-bg-hover);
}

.cr-btn--ghost:active:not(:disabled) {
  background-color: var(--cr-btn-ghost-bg-active);
}

.cr-btn--destructive {
  background-color: var(--cr-btn-destructive-bg);
  color: var(--cr-btn-destructive-fg);
}

.cr-btn--destructive:hover:not(:disabled) {
  background-color: var(--cr-btn-destructive-bg-hover);
}

.cr-btn--destructive:active:not(:disabled) {
  background-color: var(--cr-btn-destructive-bg-active);
}

/* Loading State */
.cr-btn--loading {
  position: relative;
  color: transparent;
}

.cr-btn--loading::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: cr-spin 0.6s linear infinite;
}

.cr-btn--primary.cr-btn--loading::after {
  border-color: var(--cr-btn-primary-fg);
  border-right-color: transparent;
}

@keyframes cr-spin {
  to {
    transform: rotate(360deg);
  }
}

/* ============================================
   INPUT STYLES
   ============================================ */

.cr-input {
  width: 100%;
  font-family: var(--cr-font-body);
  font-size: var(--cr-text-base);
  background-color: var(--cr-input-bg);
  color: var(--cr-fg);
  border: 2px solid var(--cr-input-border);
  border-radius: var(--cr-input-radius);
  padding: 0 var(--cr-input-px);
  transition: all var(--cr-duration-fast) var(--cr-easing-standard);
}

.cr-input::placeholder {
  color: var(--cr-input-placeholder);
}

.cr-input--sm {
  height: var(--cr-input-height-sm);
}

.cr-input--md {
  height: var(--cr-input-height-md);
}

.cr-input:focus {
  outline: none;
  border-color: var(--cr-input-border-focus);
  box-shadow: 0 0 0 3px var(--cr-focus-ring);
}

.cr-input--error {
  border-color: var(--cr-input-border-error);
}

.cr-input--error:focus {
  border-color: var(--cr-input-border-error);
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.2);
}

.cr-input:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background-color: var(--cr-surface2);
}

/* ============================================
   MESSAGE BUBBLE STYLES
   ============================================ */

.cr-message {
  max-width: 320px;
  padding: var(--cr-space-4);
  border-radius: var(--cr-radius-xl);
  font-size: var(--cr-text-base);
  line-height: var(--cr-leading-normal);
}

.cr-message--mine {
  background-color: var(--cr-message-mine-bg);
  color: var(--cr-message-mine-fg);
  border-bottom-right-radius: var(--cr-radius-xs);
  margin-left: auto;
}

.cr-message--theirs {
  background-color: var(--cr-message-theirs-bg);
  color: var(--cr-message-theirs-fg);
  border-bottom-left-radius: var(--cr-radius-xs);
}

/* ============================================
   TIMELINE STYLES
   ============================================ */

.cr-timeline {
  position: relative;
  padding-left: var(--cr-space-8);
}

.cr-timeline::before {
  content: '';
  position: absolute;
  left: 5px;
  top: 0;
  bottom: 0;
  width: 2px;
  background-color: var(--cr-timeline-line);
}

.cr-timeline-item {
  position: relative;
  padding-bottom: var(--cr-space-6);
}

.cr-timeline-item::before {
  content: '';
  position: absolute;
  left: calc(-1 * var(--cr-space-8) + 1px);
  top: 4px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: var(--cr-timeline-dot);
  border: 2px solid var(--cr-surface);
}

/* ============================================
   EVIDENCE CARD STYLES
   ============================================ */

.cr-evidence-card {
  background-color: var(--cr-evidence-bg);
  border: 2px solid var(--cr-evidence-border);
  border-radius: var(--cr-radius-lg);
  padding: var(--cr-space-5);
  position: relative;
}

.cr-evidence-card--immutable {
  border-color: var(--cr-immutable-mark);
}

.cr-evidence-card--immutable::before {
  content: '';
  position: absolute;
  top: var(--cr-space-3);
  right: var(--cr-space-3);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--cr-immutable-mark);
}

.cr-evidence-verified {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-1);
  padding: var(--cr-space-1) var(--cr-space-2);
  background-color: var(--cr-verified-bg);
  color: var(--cr-verified);
  border-radius: var(--cr-radius-sm);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-font-semibold);
}

.cr-evidence-unverified {
  display: inline-flex;
  align-items: center;
  gap: var(--cr-space-1);
  padding: var(--cr-space-1) var(--cr-space-2);
  background-color: var(--cr-unverified-bg);
  color: var(--cr-unverified);
  border-radius: var(--cr-radius-sm);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-font-semibold);
}

.cr-timestamp {
  color: var(--cr-timestamp);
  font-size: var(--cr-text-xs);
  font-family: var(--cr-font-mono);
}

/* ============================================
   AUDIT LOG ROW STYLES
   ============================================ */

.cr-audit-row {
  display: flex;
  align-items: center;
  gap: var(--cr-space-4);
  height: 56px;
  padding: 0 var(--cr-space-4);
  background-color: var(--cr-audit-row-bg);
  border-bottom: 1px solid var(--cr-audit-row-border);
}

.cr-audit-row:nth-child(even) {
  background-color: var(--cr-audit-row-bg-alt);
}

.cr-audit-row:last-child {
  border-bottom: none;
}

/* ============================================
   TABS STYLES
   ============================================ */

.cr-tabs {
  display: flex;
  gap: var(--cr-space-1);
  background-color: var(--cr-surface2);
  padding: var(--cr-space-1);
  border-radius: var(--cr-radius-lg);
}

.cr-tab {
  flex: 1;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: var(--cr-text-sm);
  font-weight: var(--cr-font-medium);
  color: var(--cr-muted);
  background: transparent;
  border: none;
  border-radius: var(--cr-radius-md);
  cursor: pointer;
  transition: all var(--cr-duration-fast) var(--cr-easing-standard);
}

.cr-tab:hover {
  color: var(--cr-fg);
}

.cr-tab--active {
  background-color: var(--cr-surface);
  color: var(--cr-fg);
  box-shadow: var(--cr-shadow-sm);
}

/* ============================================
   MODAL STYLES
   ============================================ */

.cr-modal-overlay {
  position: fixed;
  inset: 0;
  background-color: rgba(20, 29, 34, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--cr-space-6);
}

.cr-modal {
  background-color: var(--cr-surface);
  border-radius: var(--cr-modal-radius);
  padding: var(--cr-modal-padding);
  box-shadow: var(--cr-shadow-xl);
  max-width: 480px;
  width: 100%;
}

/* ============================================
   TOAST STYLES
   ============================================ */

.cr-toast {
  display: flex;
  align-items: flex-start;
  gap: var(--cr-space-3);
  padding: var(--cr-toast-padding);
  background-color: var(--cr-surface);
  border-radius: var(--cr-toast-radius);
  box-shadow: var(--cr-shadow-lg);
  border-left: 4px solid var(--cr-accent);
}

.cr-toast--success {
  border-left-color: var(--cr-success);
}

.cr-toast--warning {
  border-left-color: var(--cr-warning);
}

.cr-toast--error {
  border-left-color: var(--cr-destructive);
}

/* ============================================
   TYPOGRAPHY UTILITIES
   ============================================ */

.cr-heading-1 {
  font-family: var(--cr-font-heading);
  font-size: var(--cr-text-4xl);
  font-weight: var(--cr-font-bold);
  line-height: var(--cr-leading-tight);
  letter-spacing: var(--cr-tracking-tight);
  color: var(--cr-fg);
}

.cr-heading-2 {
  font-family: var(--cr-font-heading);
  font-size: var(--cr-text-3xl);
  font-weight: var(--cr-font-semibold);
  line-height: var(--cr-leading-snug);
  letter-spacing: var(--cr-tracking-tight);
  color: var(--cr-fg);
}

.cr-heading-3 {
  font-family: var(--cr-font-heading);
  font-size: var(--cr-text-2xl);
  font-weight: var(--cr-font-semibold);
  line-height: var(--cr-leading-snug);
  color: var(--cr-fg);
}

.cr-heading-4 {
  font-family: var(--cr-font-heading);
  font-size: var(--cr-text-xl);
  font-weight: var(--cr-font-semibold);
  line-height: var(--cr-leading-snug);
  color: var(--cr-fg);
}

.cr-body {
  font-family: var(--cr-font-body);
  font-size: var(--cr-text-base);
  font-weight: var(--cr-font-regular);
  line-height: var(--cr-leading-normal);
  color: var(--cr-fg);
}

.cr-body-sm {
  font-family: var(--cr-font-body);
  font-size: var(--cr-text-sm);
  font-weight: var(--cr-font-regular);
  line-height: var(--cr-leading-normal);
  color: var(--cr-fg);
}

.cr-muted-text {
  color: var(--cr-muted);
}

.cr-mono {
  font-family: var(--cr-font-mono);
}

/* ============================================
   PAGE LAYOUT
   ============================================ */

*,
*::before,
*::after {
  box-sizing: border-box;
}

body {
  margin: 0;
  background-color: var(--cr-bg);
  background-image: radial-gradient(
      circle at top right,
      rgba(73, 172, 178, 0.12),
      transparent 50%
    ),
    radial-gradient(circle at 10% 20%, rgba(90, 138, 157, 0.1), transparent 55%);
  color: var(--cr-fg);
  font-family: var(--cr-font-body);
}

img {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

.container {
  width: min(1100px, 92vw);
  margin: 0 auto;
}

.section {
  padding: var(--cr-space-20) 0;
}

.section--tight {
  padding: var(--cr-space-12) 0;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: var(--cr-tracking-wide);
  font-size: var(--cr-text-xs);
  font-weight: var(--cr-font-semibold);
  color: var(--cr-accent);
}

.stack {
  display: flex;
  flex-direction: column;
  gap: var(--cr-space-4);
}

.grid-2 {
  display: grid;
  gap: var(--cr-space-8);
}

.grid-3 {
  display: grid;
  gap: var(--cr-space-6);
}

.grid-4 {
  display: grid;
  gap: var(--cr-space-5);
}

@media (min-width: 768px) {
  .grid-2 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: center;
  }

  .grid-3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .grid-4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

/* ============================================
   HEADER & NAV
   ============================================ */

.site-header {
  position: sticky;
  top: 0;
  z-index: 10;
  background: rgba(248, 250, 251, 0.8);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--cr-border);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--cr-space-4) 0;
}

.nav-brand {
  display: flex;
  align-items: center;
  gap: var(--cr-space-3);
  font-weight: var(--cr-font-semibold);
  font-size: var(--cr-text-lg);
}

.nav-logo {
  width: 120px;
  height: 88px;
  border-radius: 16px;
  box-shadow: var(--cr-shadow-sm);
}

.nav-links {
  display: none;
  gap: var(--cr-space-6);
  font-size: var(--cr-text-sm);
  font-weight: var(--cr-font-medium);
  color: var(--cr-muted);
}

.nav-links a:hover {
  color: var(--cr-fg);
}

.nav-actions {
  display: flex;
  gap: var(--cr-space-3);
}

@media (min-width: 900px) {
  .nav-links {
    display: flex;
  }
}

/* ============================================
   HERO
   ============================================ */

.hero {
  position: relative;
  overflow: hidden;
  background: var(--cr-hero-gradient);
  border-bottom: 1px solid var(--cr-border);
}

.hero::before,
.hero::after {
  content: '';
  position: absolute;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  opacity: 0.6;
  background: radial-gradient(
    circle,
    rgba(73, 172, 178, 0.5),
    transparent 65%
  );
  animation: floatGlow 14s ease-in-out infinite;
  pointer-events: none;
}

.hero::before {
  top: -180px;
  right: -120px;
}

.hero::after {
  bottom: -200px;
  left: -140px;
  animation-delay: -6s;
}

.hero-card {
  position: relative;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(14px);
  border-radius: var(--cr-radius-2xl);
  padding: var(--cr-space-8);
  box-shadow: var(--cr-shadow-lg);
  border: 1px solid rgba(255, 255, 255, 0.5);
}

.hero-card::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(
    135deg,
    rgba(90, 138, 157, 0.4),
    rgba(73, 172, 178, 0.3),
    transparent 60%
  );
  -webkit-mask: linear-gradient(#fff 0 0) content-box,
    linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}

.hero-visual {
  position: relative;
  z-index: 1;
  animation: floatCard 8s ease-in-out infinite;
}

.hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cr-space-2);
}

.hero-title {
  font-size: clamp(28px, 3.4vw, 46px);
  line-height: 1.1;
  margin: 0;
}

.hero-title-nowrap {
  white-space: nowrap;
}

.hero-subtitle {
  font-size: var(--cr-text-lg);
  color: var(--cr-muted);
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--cr-space-3);
}

.hero-metrics {
  display: grid;
  gap: var(--cr-space-4);
}

@media (min-width: 768px) {
  .hero-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.metric {
  padding: var(--cr-space-4);
  background: var(--cr-surface2);
  border-radius: var(--cr-radius-lg);
  border: 1px solid var(--cr-border);
  transition: transform var(--cr-duration-base) var(--cr-easing-standard),
    box-shadow var(--cr-duration-base) var(--cr-easing-standard);
}

.metric:hover {
  transform: translateY(-4px);
  box-shadow: var(--cr-shadow-md);
}

.metric strong {
  display: block;
  font-size: var(--cr-text-2xl);
}

/* ============================================
   FEATURE SECTIONS
   ============================================ */

.feature-card {
  background: var(--cr-surface);
  border-radius: var(--cr-radius-xl);
  padding: var(--cr-space-6);
  border: 1px solid var(--cr-border);
  box-shadow: var(--cr-shadow-sm);
  height: 100%;
  transition: transform var(--cr-duration-base) var(--cr-easing-standard),
    box-shadow var(--cr-duration-base) var(--cr-easing-standard),
    border-color var(--cr-duration-base) var(--cr-easing-standard);
}

.feature-card h3 {
  margin-top: 0;
}

.feature-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--cr-shadow-md);
  border-color: rgba(73, 172, 178, 0.4);
}

.highlight {
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.95),
    rgba(240, 246, 248, 0.9)
  );
  border: 1px solid rgba(73, 172, 178, 0.25);
  backdrop-filter: blur(10px);
  border-radius: var(--cr-radius-2xl);
  padding: var(--cr-space-8);
}

.timeline {
  display: grid;
  gap: var(--cr-space-4);
}

.timeline-step {
  display: flex;
  gap: var(--cr-space-4);
  align-items: flex-start;
}

.timeline-step span {
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: var(--cr-accent);
  color: var(--cr-accent-fg);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: var(--cr-font-semibold);
}

/* ============================================
   CTA & FOOTER
   ============================================ */

.cta {
  background: linear-gradient(
    120deg,
    rgba(90, 138, 157, 0.1),
    rgba(73, 172, 178, 0.18)
  );
  border: 1px solid var(--cr-border);
  border-radius: var(--cr-radius-2xl);
  padding: var(--cr-space-10);
  text-align: center;
  box-shadow: var(--cr-shadow-md);
}

.footer {
  border-top: 1px solid var(--cr-border);
  padding: var(--cr-space-8) 0;
  color: var(--cr-muted);
  font-size: var(--cr-text-sm);
}

.footer-grid {
  display: grid;
  gap: var(--cr-space-6);
}

.cr-btn--primary {
  box-shadow: 0 12px 24px rgba(90, 138, 157, 0.25);
}

.cr-btn--primary:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 16px 32px rgba(90, 138, 157, 0.3);
}

.cr-btn--secondary {
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid rgba(90, 138, 157, 0.2);
}

@keyframes floatGlow {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(20px, -30px, 0);
  }
}

@keyframes floatCard {
  0%,
  100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -8px, 0);
  }
}

@media (min-width: 768px) {
  .footer-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}