@charset "UTF-8";

/* apps/bible/src/styles.scss */
*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  -webkit-text-size-adjust: 100%;
  -moz-tab-size: 4;
  tab-size: 4;
}
body {
  margin: 0;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}
ul[role=list],
ol[role=list] {
  list-style: none;
}
body {
  min-height: 100vh;
  text-rendering: optimizeSpeed;
}
a {
  text-decoration-skip-ink: auto;
}
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}
input,
button,
textarea,
select {
  font: inherit;
  color: inherit;
}
p,
h1,
h2,
h3,
h4,
h5,
h6 {
  overflow-wrap: break-word;
}
:focus-visible {
  outline: 2px solid var(--cl-primary);
  outline-offset: 2px;
}
:focus:not(:focus-visible) {
  outline: none;
}
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
button {
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
}
[hidden] {
  display: none !important;
}
fieldset {
  border: 0;
  padding: 0;
  margin: 0;
  min-width: 0;
}
legend {
  padding: 0;
}
summary {
  display: list-item;
}
textarea {
  resize: vertical;
}
:root {
  --color-blue-50: #e8f0fe;
  --color-blue-100: #d0e1fd;
  --color-blue-200: #a1c3fb;
  --color-blue-300: #7aa3e6;
  --color-blue-400: #4a6eaf;
  --color-blue-500: #4369a0;
  --color-blue-600: #3b5998;
  --color-blue-700: #2a4d7a;
  --color-blue-800: #1e3a5f;
  --color-blue-900: #132844;
  --color-blue-950: #0a1929;
  --color-indigo-50: #eef2ff;
  --color-indigo-100: #e0e7ff;
  --color-indigo-200: #c7d2fe;
  --color-indigo-300: #a5b4fc;
  --color-indigo-400: #818cf8;
  --color-indigo-500: #667eea;
  --color-indigo-600: #5b5bd6;
  --color-indigo-700: #4f46e5;
  --color-indigo-800: #3730a3;
  --color-indigo-900: #312e81;
  --color-indigo-950: #1e1b4b;
  --color-gray-0: #ffffff;
  --color-gray-50: #f8f9fa;
  --color-gray-100: #f1f3f5;
  --color-gray-150: #e9ecef;
  --color-gray-200: #dee2e6;
  --color-gray-300: #ced4da;
  --color-gray-400: #adb5bd;
  --color-gray-500: #6c757d;
  --color-gray-600: #495057;
  --color-gray-700: #343a40;
  --color-gray-800: #212529;
  --color-gray-900: #1e1e1e;
  --color-gray-950: #121212;
  --color-gray-1000: #000000;
  --color-green-50: #f0fdf4;
  --color-green-100: #dcfce7;
  --color-green-200: #bbf7d0;
  --color-green-300: #86efac;
  --color-green-400: #4ade80;
  --color-green-500: #28a745;
  --color-green-600: #16a34a;
  --color-green-700: #15803d;
  --color-green-800: #166534;
  --color-green-900: #14532d;
  --color-green-950: #052e16;
  --color-red-50: #fef2f2;
  --color-red-100: #fee2e2;
  --color-red-200: #fecaca;
  --color-red-300: #fca5a5;
  --color-red-400: #f87171;
  --color-red-500: #dc3545;
  --color-red-600: #dc2626;
  --color-red-700: #b91c1c;
  --color-red-800: #991b1b;
  --color-red-900: #7f1d1d;
  --color-red-950: #450a0a;
  --color-yellow-50: #fefce8;
  --color-yellow-100: #fef9c3;
  --color-yellow-200: #fef08a;
  --color-yellow-300: #fde047;
  --color-yellow-400: #facc15;
  --color-yellow-500: #ffc107;
  --color-yellow-600: #ca8a04;
  --color-yellow-700: #a16207;
  --color-yellow-800: #854d0e;
  --color-yellow-900: #713f12;
  --color-yellow-950: #422006;
  --color-orange-50: #fff7ed;
  --color-orange-100: #ffedd5;
  --color-orange-200: #fed7aa;
  --color-orange-300: #fdba74;
  --color-orange-400: #fb923c;
  --color-orange-500: #f97316;
  --color-orange-600: #ea580c;
  --color-orange-700: #c2410c;
  --color-orange-800: #9a3412;
  --color-orange-900: #7c2d12;
  --color-orange-950: #431407;
  --color-teal-50: #f0fdfa;
  --color-teal-100: #ccfbf1;
  --color-teal-200: #99f6e4;
  --color-teal-300: #5eead4;
  --color-teal-400: #2dd4bf;
  --color-teal-500: #17a2b8;
  --color-teal-600: #0d9488;
  --color-teal-700: #0f766e;
  --color-teal-800: #115e59;
  --color-teal-900: #134e4a;
  --color-teal-950: #042f2e;
  --color-lime-50: #f7fee7;
  --color-lime-100: #ecfccb;
  --color-lime-200: #d9f99d;
  --color-lime-300: #bef264;
  --color-lime-400: #a3e635;
  --color-lime-500: #84cc16;
  --color-lime-600: #65a30d;
  --color-lime-700: #4d7c0f;
  --color-lime-800: #3f6212;
  --color-lime-900: #365314;
  --color-lime-950: #1a2e05;
  --color-purple-50: #faf5ff;
  --color-purple-100: #f3e8ff;
  --color-purple-200: #e9d5ff;
  --color-purple-300: #d8b4fe;
  --color-purple-400: #c084fc;
  --color-purple-500: #a855f7;
  --color-purple-600: #9333ea;
  --color-purple-700: #764ba2;
  --color-purple-800: #6b21a8;
  --color-purple-900: #581c87;
  --color-purple-950: #3b0764;
  --color-google: #db4437;
  --color-facebook: #4267b2;
  --color-apple: #000000;
}
:root {
  --cl-primary: var(--color-blue-500);
  --cl-primary-hover: var(--color-blue-700);
  --cl-primary-light: var(--color-blue-50);
  --cl-primary-lighter: var(--color-blue-100);
  --cl-primary-accent: var(--color-blue-300);
  --cl-primary-muted: var(--color-blue-400);
  --cl-secondary: var(--color-blue-700);
  --cl-secondary-hover: var(--color-blue-800);
  --cl-accent: var(--color-teal-500);
  --cl-bg: #f5f7fa;
  --cl-bg-card: var(--color-gray-0);
  --cl-bg-elevated: var(--color-gray-0);
  --cl-bg-muted: var(--color-gray-50);
  --cl-bg-subtle: var(--color-gray-100);
  --cl-bg-input: var(--color-gray-0);
  --cl-text: var(--color-gray-800);
  --cl-text-secondary: var(--color-gray-600);
  --cl-text-muted: var(--color-gray-500);
  --cl-text-placeholder: var(--color-gray-400);
  --cl-text-inverse: var(--color-gray-0);
  --cl-text-on-primary: var(--color-gray-0);
  --cl-border: var(--color-gray-200);
  --cl-border-light: var(--color-gray-150);
  --cl-border-input: var(--color-gray-200);
  --cl-border-focus: var(--cl-primary);
  --cl-success: var(--color-green-500);
  --cl-success-light: var(--color-green-50);
  --cl-info: var(--color-teal-500);
  --cl-info-light: var(--color-teal-50);
  --cl-warning: var(--color-yellow-500);
  --cl-warning-light: var(--color-yellow-50);
  --cl-danger: var(--color-red-500);
  --cl-danger-light: var(--color-red-50);
  --cl-link: var(--cl-primary);
  --cl-link-hover: var(--cl-primary-hover);
  --cl-focus-ring: rgba(67, 105, 160, 0.25);
  --cl-hover-overlay: rgba(0, 0, 0, 0.03);
  --cl-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.05);
  --cl-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.06);
  --cl-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  --cl-shadow-md: 0 6px 18px rgba(0, 0, 0, 0.12);
  --cl-shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.1);
  --cl-shadow-header: 0 4px 12px rgba(0, 0, 0, 0.1);
  --cl-shadow-modal:
    0 20px 60px rgba(0, 0, 0, 0.15),
    0 8px 24px rgba(0, 0, 0, 0.1),
    0 0 0 1px rgba(0, 0, 0, 0.04);
  --cl-shadow-modal-sheet: 0 -4px 32px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.04);
  --cl-shadow-float-xs: 0 2px 8px rgba(0, 0, 0, 0.06);
  --cl-shadow-float-sm: 0 2px 8px rgba(0, 0, 0, 0.15);
  --cl-shadow-float-md: 0 8px 24px rgba(0, 0, 0, 0.12), 0 2px 8px rgba(0, 0, 0, 0.06);
  --cl-shadow-float-lg: 0 12px 40px rgba(0, 0, 0, 0.12), 0 4px 12px rgba(0, 0, 0, 0.06);
  --cl-highlight-yellow: rgba(255, 255, 0, 0.3);
  --cl-highlight-blue: rgba(0, 0, 255, 0.3);
  --cl-highlight-green: rgba(0, 255, 0, 0.3);
  --cl-highlight-pink: rgba(255, 0, 255, 0.3);
  --cl-highlight-purple: color-mix( in srgb, var(--color-purple-400) 30%, transparent );
  --cl-highlight-red: color-mix(in srgb, var(--color-red-300) 30%, transparent);
  --cl-words-of-christ: #d32f2f;
  --cl-gradient-primary:
    linear-gradient(
      
      135deg,
      var(--color-indigo-500),
      var(--color-purple-700) );
  --cl-gradient-summary:
    linear-gradient(
      
      145deg,
      var(--color-gray-0),
      var(--color-blue-50) );
  --cl-slider-track: var(--color-gray-200);
  --cl-slider-thumb: var(--color-blue-400);
  --cl-slider-thumb-hover: var(--color-blue-300);
  --cl-slider-progress: var(--color-blue-200);
  --cl-divider: rgba(0, 0, 0, 0.1);
  --cl-overlay: rgba(0, 0, 0, 0.5);
  --cl-scrollbar-thumb: color-mix( in srgb, var(--cl-primary), var(--cl-bg-card) 72% );
  --cl-scrollbar-track: color-mix( in srgb, var(--cl-bg-muted), var(--cl-bg-card) 68% );
  --cl-note-indicator: var(--color-yellow-500);
  --cl-note-indicator-hover: var(--color-orange-500);
  --cl-badge-bg: var(--color-blue-400);
  --cl-app-chrome-surface-start: var(--cl-primary);
  --cl-app-chrome-surface-mid: color-mix( in srgb, var(--cl-primary), var(--cl-secondary) 35% );
  --cl-app-chrome-surface-end: var(--cl-secondary);
  --cl-app-chrome-brand-bg: color-mix( in srgb, var(--cl-primary), var(--cl-secondary) 28% );
  --cl-app-chrome-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 84% );
  --cl-app-chrome-border-soft: color-mix( in srgb, var(--cl-text-on-primary), transparent 88% );
  --cl-app-chrome-shadow: 2px 0 18px rgba(23, 44, 82, 0.3);
  --cl-app-chrome-sheen:
    linear-gradient(
      
      90deg,
      color-mix(in srgb, var(--cl-text-on-primary), transparent 92%),
      transparent,
      color-mix(in srgb, var(--cl-text-on-primary), transparent 95%) );
  --cl-app-search-bg: color-mix( in srgb, var(--cl-primary), var(--cl-bg-card) 20% );
  --cl-app-search-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 78% );
  --cl-app-search-inset: color-mix( in srgb, var(--cl-text-on-primary), transparent 92% );
  --cl-app-search-focus-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 58% );
  --cl-app-search-focus-ring: color-mix( in srgb, var(--cl-text-on-primary), transparent 86% );
  --cl-app-nav-active-bg: color-mix( in srgb, var(--cl-secondary), transparent 18% );
  --cl-app-nav-active-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 82% );
  --cl-app-footer-bg: color-mix( in srgb, var(--cl-secondary), var(--cl-primary) 42% );
  --cl-notification-badge-ring: var(--cl-primary);
  --cl-dashboard-card-shadow: 0 8px 24px rgba(27, 45, 79, 0.06);
  --cl-dashboard-hover-shadow: 0 10px 18px rgba(39, 50, 72, 0.08);
  --cl-dashboard-hero-bg:
    linear-gradient(
      
      115deg,
      rgba(248, 244, 237, 0.9) 0%,
      rgba(242, 234, 223, 0.78) 55%,
      rgba(239, 221, 194, 0.68) 100% );
  --cl-dashboard-hero-before-bg:
    radial-gradient(
      
      circle at 30% 30%,
      rgba(255, 255, 255, 0.82),
      transparent 45% ),
    linear-gradient(
      145deg,
      rgba(183, 141, 90, 0.28),
      rgba(141, 112, 74, 0.18));
  --cl-dashboard-hero-after-bg:
    radial-gradient(
      
      circle,
      rgba(237, 206, 157, 0.24),
      transparent 68% );
  --cl-dashboard-continue-bg: color-mix( in srgb, var(--cl-bg-card), transparent 14% );
  --cl-dashboard-continue-shadow: 0 12px 28px rgba(45, 58, 83, 0.08);
  --cl-dashboard-explore-panel-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), transparent 8%),
      color-mix(in srgb, var(--cl-bg-muted), transparent 8%) );
  --cl-dashboard-explore-panel-glow:
    radial-gradient(
      
      circle at 12% 10%,
      color-mix(in srgb, var(--cl-primary), transparent 78%),
      transparent 40% );
  --cl-dashboard-chart-line: var(--color-blue-400);
  --cl-dashboard-chart-point: var(--color-orange-500);
  --cl-dashboard-chart-area: color-mix( in srgb, var(--color-blue-400), transparent 82% );
  --cl-dashboard-chart-point-border: var(--cl-bg-card);
  --cl-audio-panel-border: color-mix( in srgb, var(--cl-border), transparent 18% );
  --cl-audio-panel-border-strong: color-mix( in srgb, var(--cl-border), transparent 8% );
  --cl-audio-divider: color-mix(in srgb, var(--cl-border), transparent 16%);
  --cl-audio-surface-glow: color-mix( in srgb, var(--cl-primary), transparent 92% );
  --cl-audio-surface-accent: color-mix( in srgb, var(--cl-note-indicator), transparent 90% );
  --cl-audio-pill-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 68% );
  --cl-audio-pill-border: color-mix( in srgb, var(--cl-border-light), transparent 10% );
  --cl-audio-pill-active-bg:
    linear-gradient(
      
      180deg,
      var(--cl-primary-accent),
      var(--cl-primary) );
  --cl-audio-pill-active-text: var(--cl-text-on-primary);
  --cl-audio-slider-card-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 58% );
  --cl-audio-slider-card-border: color-mix( in srgb, var(--cl-border), transparent 20% );
  --cl-audio-switch-bg: color-mix(in srgb, var(--cl-border), transparent 30%);
  --cl-audio-switch-active-bg:
    linear-gradient(
      
      180deg,
      var(--cl-primary-accent),
      var(--cl-primary) );
  --cl-audio-switch-thumb: var(--cl-bg-card);
  --cl-audio-avatar-bg:
    linear-gradient(
      
      180deg,
      var(--cl-primary-accent),
      var(--cl-primary) );
  --cl-audio-avatar-text: var(--cl-text-on-primary);
  --cl-audio-accent-surface: color-mix( in srgb, var(--cl-warning-light), var(--cl-bg-card) 28% );
  --cl-audio-accent-border: color-mix( in srgb, var(--cl-note-indicator), transparent 74% );
  --cl-audio-accent-text: color-mix( in srgb, var(--cl-note-indicator-hover), var(--cl-text) 38% );
  --cl-audio-verse-hover-bg: color-mix( in srgb, var(--cl-primary), transparent 94% );
  --cl-audio-verse-active-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-warning), transparent 80%),
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 26%) );
  --cl-audio-verse-active-border: color-mix( in srgb, var(--cl-note-indicator), transparent 76% );
  --cl-audio-spotlight-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-warning), transparent 82%),
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 22%) );
  --cl-audio-spotlight-shadow: var(--cl-shadow-sm);
  --cl-audio-indicator-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      var(--cl-note-indicator-hover) );
  --cl-audio-player-cta-bg:
    linear-gradient(
      
      180deg,
      var(--cl-primary-accent),
      var(--cl-secondary) );
  --cl-audio-player-cta-bg-hover:
    linear-gradient(
      
      180deg,
      var(--cl-primary),
      var(--cl-secondary-hover) );
  --cl-audio-player-cta-text: var(--cl-text-on-primary);
  --cl-audio-player-cta-shadow: var(--cl-shadow-md);
  --cl-audio-settings-shell-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 18%),
      color-mix(in srgb, var(--cl-bg-card), var(--cl-bg-muted) 30%) );
  --cl-audio-settings-shell-border: color-mix( in srgb, var(--cl-note-indicator-hover), transparent 84% );
  --cl-audio-settings-shell-shadow: 0 18px 36px color-mix(in srgb, var(--cl-note-indicator-hover), transparent 88%);
  --cl-audio-settings-title: var(--cl-text);
  --cl-audio-settings-card-bg: color-mix( in srgb, var(--cl-bg-card), transparent 10% );
  --cl-audio-settings-card-border: color-mix( in srgb, var(--cl-note-indicator-hover), transparent 88% );
  --cl-audio-settings-accent-text: color-mix( in srgb, var(--cl-note-indicator-hover), var(--cl-text) 32% );
  --cl-audio-settings-pill-text: color-mix( in srgb, var(--cl-note-indicator-hover), var(--cl-text) 44% );
  --cl-audio-settings-pill-border-hover: color-mix( in srgb, var(--cl-note-indicator-hover), transparent 76% );
  --cl-audio-settings-pill-shadow: 0 10px 22px color-mix(in srgb, var(--cl-note-indicator-hover), transparent 88%);
  --cl-audio-settings-pill-active-shadow: 0 16px 28px color-mix(in srgb, var(--cl-note-indicator-hover), transparent 80%);
  --cl-audio-settings-slider-meta: color-mix( in srgb, var(--cl-text-secondary), transparent 18% );
  --cl-audio-settings-toggle-bg: color-mix( in srgb, var(--cl-bg-card), transparent 18% );
  --cl-audio-settings-toggle-border: color-mix( in srgb, var(--cl-note-indicator-hover), transparent 88% );
  --cl-audio-settings-toggle-text: color-mix( in srgb, var(--cl-note-indicator-hover), var(--cl-text) 52% );
  --cl-audio-settings-toggle-border-hover: color-mix( in srgb, var(--cl-note-indicator-hover), transparent 80% );
  --cl-audio-settings-toggle-shadow: 0 12px 22px color-mix(in srgb, var(--cl-note-indicator-hover), transparent 90%);
  --cl-audio-settings-toggle-action-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-note-indicator-hover), transparent 90%),
      color-mix(in srgb, var(--cl-note-indicator-hover), transparent 84%) );
  --cl-audio-up-next-bg:
    linear-gradient(
      
      145deg,
      color-mix(in srgb, var(--cl-primary), var(--cl-bg-card) 90%),
      color-mix(in srgb, var(--cl-secondary), var(--cl-bg-card) 92%) 52%,
      color-mix(in srgb, var(--cl-note-indicator-hover), var(--cl-bg-card) 94%) 100% );
  --cl-audio-up-next-text: var(--cl-text);
  --cl-audio-up-next-text-muted: var(--cl-text-secondary);
  --cl-audio-up-next-ghost-bg: color-mix( in srgb, var(--cl-primary), transparent 92% );
  --cl-audio-up-next-ghost-border: color-mix( in srgb, var(--cl-primary), var(--cl-border) 58% );
  --cl-audio-waveform-neutral:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-border-light), var(--cl-bg-card) 18%),
      color-mix(in srgb, var(--cl-border), transparent 36%) );
  --cl-audio-waveform-gold:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-warning), var(--cl-bg-card) 14%),
      var(--cl-note-indicator-hover) );
  --cl-audio-waveform-blue:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 10%),
      var(--cl-primary) );
  --cl-audio-waveform-shadow: 0 0 0.35rem color-mix(in srgb, var(--cl-primary), transparent 72%);
  --cl-coming-soon-shadow: 0 14px 40px rgba(15, 23, 42, 0.08);
  --cl-coming-soon-badge-bg: var(--cl-text);
  --cl-coming-soon-badge-text: var(--cl-text-on-primary);
  --cl-coming-soon-btn-border: var(--cl-text);
  --cl-coming-soon-btn-bg: transparent;
  --cl-coming-soon-btn-text: var(--cl-text);
  --cl-coming-soon-btn-primary-bg: var(--cl-text);
  --cl-coming-soon-btn-primary-text: var(--cl-text-on-primary);
  --cl-coming-soon-btn-hover-shadow: 0 8px 22px rgba(15, 23, 42, 0.15);
  --cl-settings-page-backdrop:
    radial-gradient(
      
      circle at top right,
      color-mix(in srgb, var(--cl-warning), transparent 84%),
      transparent 34% ),
    radial-gradient(
      
      circle at 14% 18%,
      color-mix(in srgb, var(--cl-primary), transparent 90%),
      transparent 30% ),
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), transparent 20%),
      transparent );
  --cl-settings-shell-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), var(--cl-bg) 10%),
      color-mix(in srgb, var(--cl-bg-muted), var(--cl-bg-card) 36%) );
  --cl-settings-elevated-surface: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 22% );
  --cl-settings-panel-border: color-mix( in srgb, var(--cl-border), transparent 18% );
  --cl-settings-panel-shadow: var(--cl-shadow-lg);
  --cl-settings-divider: color-mix(in srgb, var(--cl-border), transparent 24%);
  --cl-settings-title: var(--cl-text);
  --cl-settings-copy-muted: var(--cl-text-secondary);
  --cl-settings-section-label: color-mix( in srgb, var(--cl-primary), var(--cl-warning) 32% );
  --cl-settings-chip-bg: color-mix(in srgb, var(--cl-bg-card), transparent 10%);
  --cl-settings-chip-text: var(--cl-text);
  --cl-settings-tab-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 18% );
  --cl-settings-tab-bg-active:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-light), var(--cl-bg-card) 36%),
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 18%) );
  --cl-settings-tab-border: color-mix( in srgb, var(--cl-border), transparent 20% );
  --cl-settings-tab-border-active: color-mix( in srgb, var(--cl-primary), transparent 58% );
  --cl-settings-tab-badge-bg: color-mix( in srgb, var(--cl-primary), transparent 84% );
  --cl-settings-tab-badge-text: var(--cl-text);
  --cl-settings-inner-border: color-mix( in srgb, var(--cl-border), transparent 26% );
  --cl-settings-hero-bg:
    linear-gradient(
      
      150deg,
      color-mix(in srgb, var(--cl-primary), var(--cl-bg-card) 10%),
      color-mix(in srgb, var(--cl-secondary), var(--cl-warning) 16%) );
  --cl-settings-avatar-ring: color-mix( in srgb, var(--cl-text-on-primary), transparent 78% );
  --cl-settings-avatar-frame-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-text-on-primary), transparent 90%),
      color-mix(in srgb, var(--cl-text-on-primary), transparent 96%) );
  --cl-settings-badge-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      color-mix(in srgb, var(--cl-warning), var(--cl-primary) 22%) );
  --cl-settings-badge-text: var(--cl-text-inverse);
  --cl-settings-input-bg: color-mix( in srgb, var(--cl-bg-input), var(--cl-bg-card) 22% );
  --cl-settings-input-border: color-mix( in srgb, var(--cl-border-input), transparent 14% );
  --cl-settings-input-border-focus: var(--cl-border-focus);
  --cl-settings-input-highlight: color-mix( in srgb, var(--cl-bg-card), transparent 10% );
  --cl-settings-focus-ring: color-mix( in srgb, var(--cl-focus-ring), transparent 8% );
  --cl-settings-primary-action-bg:
    linear-gradient(
      
      180deg,
      var(--cl-primary-accent),
      var(--cl-primary) );
  --cl-settings-primary-action-text: var(--cl-text-on-primary);
  --cl-settings-secondary-action-bg: color-mix( in srgb, var(--cl-text-on-primary), transparent 88% );
  --cl-settings-secondary-action-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 80% );
  --cl-settings-secondary-action-text: var(--cl-text-on-primary);
  --cl-settings-ghost-action-bg: color-mix( in srgb, var(--cl-bg-card), transparent 8% );
  --cl-settings-ghost-action-border: color-mix( in srgb, var(--cl-border), transparent 18% );
  --cl-settings-ghost-action-text: var(--cl-text);
  --cl-settings-status-pulse-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      color-mix(in srgb, var(--cl-warning), var(--cl-primary) 24%) );
}
body.dark-mode,
.dark {
  --cl-primary: var(--color-blue-300);
  --cl-primary-hover: var(--color-blue-200);
  --cl-primary-light: rgba(122, 163, 230, 0.1);
  --cl-primary-lighter: rgba(122, 163, 230, 0.15);
  --cl-primary-accent: var(--color-blue-400);
  --cl-primary-muted: var(--color-blue-300);
  --cl-secondary: var(--color-blue-300);
  --cl-secondary-hover: var(--color-blue-200);
  --cl-accent: var(--color-teal-300);
  --cl-bg: var(--color-gray-950);
  --cl-bg-card: var(--color-gray-900);
  --cl-bg-elevated: var(--color-gray-700);
  --cl-bg-muted: rgba(255, 255, 255, 0.05);
  --cl-bg-subtle: rgba(255, 255, 255, 0.08);
  --cl-bg-input: var(--color-gray-700);
  --cl-text: #f0f0f0;
  --cl-text-secondary: #cccccc;
  --cl-text-muted: #aaaaaa;
  --cl-text-placeholder: #888888;
  --cl-text-inverse: var(--color-gray-900);
  --cl-text-on-primary: var(--color-gray-0);
  --cl-border: #333333;
  --cl-border-light: #2a2a2a;
  --cl-border-input: #444444;
  --cl-border-focus: var(--cl-primary);
  --cl-success: var(--color-green-400);
  --cl-success-light: rgba(40, 167, 69, 0.15);
  --cl-info: var(--color-teal-300);
  --cl-info-light: rgba(23, 162, 184, 0.15);
  --cl-warning: var(--color-yellow-400);
  --cl-warning-light: rgba(255, 193, 7, 0.15);
  --cl-danger: var(--color-red-400);
  --cl-danger-light: rgba(220, 53, 69, 0.15);
  --cl-link: var(--cl-primary);
  --cl-link-hover: var(--cl-primary-hover);
  --cl-focus-ring: rgba(122, 163, 230, 0.3);
  --cl-hover-overlay: rgba(255, 255, 255, 0.05);
  --cl-shadow-xs: 0 1px 2px rgba(0, 0, 0, 0.2);
  --cl-shadow-sm: 0 2px 4px rgba(0, 0, 0, 0.25);
  --cl-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  --cl-shadow-md: 0 6px 18px rgba(0, 0, 0, 0.35);
  --cl-shadow-lg: 0 10px 30px rgba(0, 0, 0, 0.4);
  --cl-shadow-header: 0 4px 12px rgba(0, 0, 0, 0.3);
  --cl-shadow-modal:
    0 20px 60px rgba(0, 0, 0, 0.5),
    0 8px 24px rgba(0, 0, 0, 0.42),
    0 0 0 1px rgba(255, 255, 255, 0.04);
  --cl-shadow-modal-sheet: 0 -4px 32px rgba(0, 0, 0, 0.42), 0 0 0 1px rgba(255, 255, 255, 0.04);
  --cl-shadow-float-xs: 0 2px 8px rgba(0, 0, 0, 0.24);
  --cl-shadow-float-sm: 0 2px 8px rgba(0, 0, 0, 0.36);
  --cl-shadow-float-md: 0 8px 24px rgba(0, 0, 0, 0.4), 0 2px 8px rgba(0, 0, 0, 0.3);
  --cl-shadow-float-lg: 0 12px 40px rgba(0, 0, 0, 0.42), 0 4px 12px rgba(0, 0, 0, 0.34);
  --cl-highlight-yellow: rgba(255, 255, 0, 0.2);
  --cl-highlight-blue: rgba(80, 130, 255, 0.25);
  --cl-highlight-green: rgba(80, 220, 80, 0.25);
  --cl-highlight-pink: rgba(255, 80, 255, 0.25);
  --cl-words-of-christ: #ff6b6b;
  --cl-gradient-summary:
    linear-gradient(
      
      145deg,
      var(--color-gray-900),
      var(--color-gray-800) );
  --cl-slider-track: #3a3a3a;
  --cl-slider-thumb: var(--color-blue-300);
  --cl-slider-thumb-hover: var(--color-blue-200);
  --cl-slider-progress: var(--color-blue-400);
  --cl-divider: rgba(255, 255, 255, 0.1);
  --cl-overlay: rgba(0, 0, 0, 0.7);
  --cl-note-indicator: var(--color-yellow-400);
  --cl-note-indicator-hover: var(--color-orange-400);
  --cl-badge-bg: var(--color-blue-300);
  --cl-app-chrome-surface-start: var(--color-gray-900);
  --cl-app-chrome-surface-mid: color-mix( in srgb, var(--color-gray-900), var(--color-gray-800) 42% );
  --cl-app-chrome-surface-end: var(--color-gray-950);
  --cl-app-chrome-brand-bg: color-mix( in srgb, var(--color-gray-900), var(--color-gray-950) 30% );
  --cl-app-chrome-border: color-mix( in srgb, var(--color-gray-0), transparent 90% );
  --cl-app-chrome-border-soft: color-mix( in srgb, var(--color-gray-0), transparent 92% );
  --cl-app-chrome-shadow: 2px 0 22px rgba(0, 0, 0, 0.55);
  --cl-app-chrome-sheen:
    linear-gradient(
      
      90deg,
      color-mix(in srgb, var(--color-gray-0), transparent 97%),
      transparent,
      color-mix(in srgb, var(--color-gray-0), transparent 98%) );
  --cl-app-search-bg: color-mix( in srgb, var(--color-gray-900), var(--color-gray-800) 34% );
  --cl-app-search-border: color-mix( in srgb, var(--color-gray-0), transparent 88% );
  --cl-app-search-inset: color-mix( in srgb, var(--color-gray-0), transparent 97% );
  --cl-app-search-focus-border: color-mix( in srgb, var(--color-gray-0), transparent 78% );
  --cl-app-search-focus-ring: color-mix( in srgb, var(--color-gray-0), transparent 92% );
  --cl-app-nav-active-bg: color-mix( in srgb, var(--cl-primary), transparent 78% );
  --cl-app-nav-active-border: color-mix( in srgb, var(--color-gray-0), transparent 90% );
  --cl-app-footer-bg: color-mix( in srgb, var(--color-gray-900), var(--color-gray-800) 44% );
  --cl-notification-badge-ring: var(--color-gray-900);
  --cl-dashboard-card-shadow: 0 10px 30px rgba(0, 0, 0, 0.35);
  --cl-dashboard-hover-shadow: 0 12px 28px rgba(0, 0, 0, 0.4);
  --cl-dashboard-hero-bg:
    linear-gradient(
      
      115deg,
      color-mix(in srgb, var(--color-gray-900), var(--color-orange-900) 8%) 0%,
      color-mix(in srgb, var(--color-gray-900), var(--color-orange-900) 13%) 55%,
      color-mix(in srgb, var(--color-gray-900), var(--color-orange-950) 18%) 100% );
  --cl-dashboard-hero-before-bg:
    radial-gradient(
      
      circle at 30% 30%,
      color-mix(in srgb, var(--color-gray-0), transparent 90%),
      transparent 45% ),
    linear-gradient(
      
      145deg,
      color-mix(in srgb, var(--color-orange-500), transparent 86%),
      color-mix(in srgb, var(--color-orange-700), transparent 92%) );
  --cl-dashboard-hero-after-bg:
    radial-gradient(
      
      circle,
      color-mix(in srgb, var(--color-orange-300), transparent 90%),
      transparent 70% );
  --cl-dashboard-continue-bg: color-mix( in srgb, var(--cl-bg-card), transparent 4% );
  --cl-dashboard-continue-shadow: 0 12px 28px rgba(0, 0, 0, 0.35);
  --cl-dashboard-explore-panel-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--color-gray-900), var(--color-gray-800) 24%),
      color-mix(in srgb, var(--color-gray-900), var(--color-gray-800) 42%) );
  --cl-dashboard-explore-panel-glow:
    radial-gradient(
      
      circle at 12% 10%,
      color-mix(in srgb, var(--cl-primary), transparent 86%),
      transparent 44% );
  --cl-dashboard-chart-line: var(--color-blue-300);
  --cl-dashboard-chart-point: var(--color-orange-400);
  --cl-dashboard-chart-area: color-mix( in srgb, var(--color-blue-300), transparent 84% );
  --cl-dashboard-chart-point-border: var(--color-gray-900);
  --cl-scrollbar-thumb: color-mix( in srgb, var(--cl-primary), var(--cl-bg-card) 84% );
  --cl-scrollbar-track: color-mix( in srgb, var(--cl-bg-muted), var(--cl-bg-card) 84% );
  --cl-audio-panel-border: color-mix( in srgb, var(--cl-border), transparent 10% );
  --cl-audio-panel-border-strong: color-mix( in srgb, var(--cl-border), transparent 2% );
  --cl-audio-divider: color-mix(in srgb, var(--cl-border), transparent 12%);
  --cl-audio-surface-glow: color-mix( in srgb, var(--cl-primary), transparent 94% );
  --cl-audio-surface-accent: color-mix( in srgb, var(--cl-note-indicator), transparent 92% );
  --cl-audio-pill-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 46% );
  --cl-audio-pill-border: color-mix(in srgb, var(--cl-border), transparent 6%);
  --cl-audio-pill-active-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 10%),
      var(--cl-primary) );
  --cl-audio-pill-active-text: var(--cl-text-on-primary);
  --cl-audio-slider-card-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 32% );
  --cl-audio-slider-card-border: color-mix( in srgb, var(--cl-border), transparent 8% );
  --cl-audio-switch-bg: color-mix(in srgb, var(--cl-border), transparent 18%);
  --cl-audio-switch-active-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 8%),
      var(--cl-primary) );
  --cl-audio-switch-thumb: var(--cl-bg-card);
  --cl-audio-avatar-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 8%),
      var(--cl-primary) );
  --cl-audio-avatar-text: var(--cl-text-on-primary);
  --cl-audio-accent-surface: color-mix( in srgb, var(--cl-warning-light), var(--cl-bg-card) 40% );
  --cl-audio-accent-border: color-mix( in srgb, var(--cl-note-indicator), transparent 70% );
  --cl-audio-accent-text: color-mix( in srgb, var(--cl-note-indicator), var(--cl-text) 28% );
  --cl-audio-verse-hover-bg: color-mix( in srgb, var(--cl-primary), transparent 92% );
  --cl-audio-verse-active-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-warning), transparent 86%),
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 42%) );
  --cl-audio-verse-active-border: color-mix( in srgb, var(--cl-note-indicator), transparent 70% );
  --cl-audio-spotlight-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-warning), transparent 88%),
      color-mix(in srgb, var(--cl-warning-light), var(--cl-bg-card) 44%) );
  --cl-audio-spotlight-shadow: var(--cl-shadow-sm);
  --cl-audio-indicator-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      var(--cl-note-indicator-hover) );
  --cl-audio-player-cta-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 10%),
      var(--cl-secondary) );
  --cl-audio-player-cta-bg-hover:
    linear-gradient(
      
      180deg,
      var(--cl-primary),
      var(--cl-secondary-hover) );
  --cl-audio-player-cta-text: var(--cl-text-on-primary);
  --cl-audio-player-cta-shadow: var(--cl-shadow-lg);
  --cl-audio-settings-shell-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), var(--cl-bg-muted) 22%),
      color-mix(in srgb, var(--cl-bg-muted), var(--cl-bg-card) 22%) );
  --cl-audio-settings-shell-border: color-mix( in srgb, var(--cl-border), transparent 12% );
  --cl-audio-settings-shell-shadow: 0 18px 36px rgba(0, 0, 0, 0.28);
  --cl-audio-settings-title: var(--cl-text);
  --cl-audio-settings-card-bg: color-mix( in srgb, var(--cl-bg-card), transparent 8% );
  --cl-audio-settings-card-border: color-mix( in srgb, var(--cl-border), transparent 10% );
  --cl-audio-settings-accent-text: color-mix( in srgb, var(--cl-note-indicator), var(--cl-text) 36% );
  --cl-audio-settings-pill-text: color-mix( in srgb, var(--cl-note-indicator), var(--cl-text) 48% );
  --cl-audio-settings-pill-border-hover: color-mix( in srgb, var(--cl-note-indicator), transparent 72% );
  --cl-audio-settings-pill-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
  --cl-audio-settings-pill-active-shadow: 0 16px 28px rgba(0, 0, 0, 0.3);
  --cl-audio-settings-slider-meta: color-mix( in srgb, var(--cl-text-secondary), transparent 10% );
  --cl-audio-settings-toggle-bg: color-mix( in srgb, var(--cl-bg-card), transparent 14% );
  --cl-audio-settings-toggle-border: color-mix( in srgb, var(--cl-border), transparent 12% );
  --cl-audio-settings-toggle-text: color-mix( in srgb, var(--cl-note-indicator), var(--cl-text) 58% );
  --cl-audio-settings-toggle-border-hover: color-mix( in srgb, var(--cl-note-indicator), transparent 76% );
  --cl-audio-settings-toggle-shadow: 0 12px 22px rgba(0, 0, 0, 0.24);
  --cl-audio-settings-toggle-action-bg:
    linear-gradient(
      
      135deg,
      color-mix(in srgb, var(--cl-note-indicator-hover), transparent 92%),
      color-mix(in srgb, var(--cl-note-indicator-hover), transparent 86%) );
  --cl-audio-up-next-bg:
    linear-gradient(
      
      145deg,
      color-mix(in srgb, var(--cl-primary), var(--cl-bg-card) 72%),
      color-mix(in srgb, var(--cl-secondary), var(--cl-bg-card) 76%) 52%,
      color-mix(in srgb, var(--cl-secondary-hover), var(--cl-bg-card) 80%) 100% );
  --cl-audio-up-next-text: var(--cl-text);
  --cl-audio-up-next-text-muted: var(--cl-text-secondary);
  --cl-audio-up-next-ghost-bg: color-mix( in srgb, var(--cl-primary), transparent 88% );
  --cl-audio-up-next-ghost-border: color-mix( in srgb, var(--cl-primary), var(--cl-border) 52% );
  --cl-audio-waveform-neutral:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-border-light), var(--cl-bg-card) 12%),
      color-mix(in srgb, var(--cl-border), transparent 28%) );
  --cl-audio-waveform-gold:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-warning), var(--cl-bg-card) 16%),
      var(--cl-note-indicator-hover) );
  --cl-audio-waveform-blue:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 12%),
      var(--cl-primary) );
  --cl-audio-waveform-shadow: 0 0 0.35rem color-mix(in srgb, var(--cl-primary), transparent 68%);
  --cl-coming-soon-shadow: 0 18px 42px rgba(0, 0, 0, 0.45);
  --cl-coming-soon-badge-bg: color-mix( in srgb, var(--cl-primary), var(--color-gray-700) 72% );
  --cl-coming-soon-badge-text: var(--cl-text);
  --cl-coming-soon-btn-border: var(--cl-border);
  --cl-coming-soon-btn-bg: var(--cl-bg-card);
  --cl-coming-soon-btn-text: var(--cl-text);
  --cl-coming-soon-btn-primary-bg: var(--cl-primary);
  --cl-coming-soon-btn-primary-text: var(--cl-text-on-primary);
  --cl-coming-soon-btn-hover-shadow: 0 10px 24px rgba(0, 0, 0, 0.45);
  --cl-settings-page-backdrop:
    radial-gradient(
      
      circle at top right,
      color-mix(in srgb, var(--cl-warning), transparent 90%),
      transparent 36% ),
    radial-gradient(
      
      circle at 14% 18%,
      color-mix(in srgb, var(--cl-primary), transparent 92%),
      transparent 32% ),
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), transparent 6%),
      transparent );
  --cl-settings-shell-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-bg-card), var(--cl-bg-muted) 12%),
      color-mix(in srgb, var(--cl-bg-card), var(--cl-bg-muted) 36%) );
  --cl-settings-elevated-surface: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 18% );
  --cl-settings-panel-border: color-mix( in srgb, var(--cl-border), transparent 8% );
  --cl-settings-panel-shadow: var(--cl-shadow-lg);
  --cl-settings-divider: color-mix(in srgb, var(--cl-border), transparent 12%);
  --cl-settings-title: var(--cl-text);
  --cl-settings-copy-muted: var(--cl-text-secondary);
  --cl-settings-section-label: color-mix( in srgb, var(--cl-primary), var(--cl-warning) 18% );
  --cl-settings-chip-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 24% );
  --cl-settings-chip-text: var(--cl-text);
  --cl-settings-tab-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 16% );
  --cl-settings-tab-bg-active:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary), transparent 88%),
      color-mix(in srgb, var(--cl-warning), transparent 92%) );
  --cl-settings-tab-border: color-mix( in srgb, var(--cl-border), transparent 6% );
  --cl-settings-tab-border-active: color-mix( in srgb, var(--cl-primary), transparent 68% );
  --cl-settings-tab-badge-bg: color-mix( in srgb, var(--cl-primary), transparent 82% );
  --cl-settings-tab-badge-text: var(--cl-text);
  --cl-settings-inner-border: color-mix( in srgb, var(--cl-border), transparent 10% );
  --cl-settings-hero-bg:
    linear-gradient(
      
      150deg,
      color-mix(in srgb, var(--cl-primary), var(--color-gray-900) 28%),
      color-mix(in srgb, var(--cl-secondary), var(--color-orange-900) 16%) );
  --cl-settings-avatar-ring: color-mix( in srgb, var(--cl-text-on-primary), transparent 82% );
  --cl-settings-avatar-frame-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-text-on-primary), transparent 94%),
      color-mix(in srgb, var(--cl-text-on-primary), transparent 97%) );
  --cl-settings-badge-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      color-mix(in srgb, var(--cl-warning), var(--cl-primary) 18%) );
  --cl-settings-badge-text: var(--cl-text-inverse);
  --cl-settings-input-bg: color-mix( in srgb, var(--cl-bg-input), var(--cl-bg-card) 10% );
  --cl-settings-input-border: color-mix( in srgb, var(--cl-border-input), transparent 4% );
  --cl-settings-input-border-focus: var(--cl-border-focus);
  --cl-settings-input-highlight: color-mix( in srgb, var(--cl-text-on-primary), transparent 98% );
  --cl-settings-focus-ring: color-mix( in srgb, var(--cl-focus-ring), transparent 12% );
  --cl-settings-primary-action-bg:
    linear-gradient(
      
      180deg,
      color-mix(in srgb, var(--cl-primary-accent), var(--cl-bg-card) 14%),
      var(--cl-primary) );
  --cl-settings-primary-action-text: var(--cl-text-on-primary);
  --cl-settings-secondary-action-bg: color-mix( in srgb, var(--cl-text-on-primary), transparent 92% );
  --cl-settings-secondary-action-border: color-mix( in srgb, var(--cl-text-on-primary), transparent 88% );
  --cl-settings-secondary-action-text: var(--cl-text-on-primary);
  --cl-settings-ghost-action-bg: color-mix( in srgb, var(--cl-bg-card), var(--cl-bg-muted) 18% );
  --cl-settings-ghost-action-border: color-mix( in srgb, var(--cl-border), transparent 4% );
  --cl-settings-ghost-action-text: var(--cl-text);
  --cl-settings-status-pulse-bg:
    linear-gradient(
      
      180deg,
      var(--cl-warning),
      color-mix(in srgb, var(--cl-warning), var(--cl-primary) 20%) );
}
:root {
  --font-body:
    "Open Sans",
    system-ui,
    -apple-system,
    "Segoe UI",
    sans-serif;
  --font-heading:
    "Open Sans",
    system-ui,
    -apple-system,
    "Segoe UI",
    sans-serif;
  --font-mono:
    "Courier New",
    Consolas,
    "Liberation Mono",
    monospace;
  --font-dyslexia: "Open Dyslexic", sans-serif;
  --font-readable: "Atkinson Hyperlegible", sans-serif;
  --fw-light: 300;
  --fw-regular: 400;
  --fw-medium: 500;
  --fw-semibold: 600;
  --fw-bold: 700;
  --fs-xs: 0.75rem;
  --fs-sm: 0.8125rem;
  --fs-base: 0.875rem;
  --fs-md: 1rem;
  --fs-lg: 1.125rem;
  --fs-xl: 1.25rem;
  --fs-2xl: 1.5rem;
  --fs-3xl: 1.875rem;
  --fs-4xl: 2.25rem;
  --fs-5xl: 3rem;
  --bible-font-size: 1.125rem;
  --lh-tight: 1.25;
  --lh-snug: 1.375;
  --lh-normal: 1.5;
  --lh-relaxed: 1.625;
  --lh-loose: 1.8;
  --ls-tight: -0.025em;
  --ls-normal: 0;
  --ls-wide: 0.025em;
  --ls-wider: 0.05em;
}
body {
  font-family: var(--font-body);
  font-size: var(--fs-md);
  font-weight: var(--fw-regular);
  line-height: var(--lh-relaxed);
  color: var(--cl-text);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: var(--font-heading);
  font-weight: var(--fw-semibold);
  line-height: var(--lh-tight);
  letter-spacing: var(--ls-tight);
  color: var(--cl-text);
  margin-bottom: 0.5em;
}
h1 {
  font-size: var(--fs-4xl);
}
h2 {
  font-size: var(--fs-3xl);
}
h3 {
  font-size: var(--fs-2xl);
}
h4 {
  font-size: var(--fs-xl);
}
h5 {
  font-size: var(--fs-lg);
}
h6 {
  font-size: var(--fs-md);
}
p {
  margin-bottom: 1rem;
  line-height: var(--lh-relaxed);
}
small,
.text-sm {
  font-size: var(--fs-sm);
}
.text-xs {
  font-size: var(--fs-xs);
}
.text-base {
  font-size: var(--fs-base);
}
.text-md {
  font-size: var(--fs-md);
}
.text-lg {
  font-size: var(--fs-lg);
}
.text-xl {
  font-size: var(--fs-xl);
}
.text-2xl {
  font-size: var(--fs-2xl);
}
.text-3xl {
  font-size: var(--fs-3xl);
}
body.font-readable,
.font-readable {
  font-family: var(--font-readable);
}
body.font-dyslexia,
.font-dyslexia {
  font-family: var(--font-dyslexia);
}
:root {
  --space-0: 0;
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.25rem;
  --space-6: 1.5rem;
  --space-8: 2rem;
  --space-10: 2.5rem;
  --space-12: 3rem;
  --radius-sm: 4px;
  --radius: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-pill: 50px;
  --radius-full: 50%;
  --ease-default: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in: cubic-bezier(0.4, 0, 1, 1);
  --ease-out: cubic-bezier(0, 0, 0.2, 1);
  --duration-fast: 150ms;
  --duration: 250ms;
  --duration-slow: 400ms;
  --transition: all var(--duration) var(--ease-default);
  --sidebar-width: 232px;
  --sidebar-collapsed-width: 80px;
  --header-height: 60px;
  --max-width-content: 1200px;
  --max-width-narrow: 800px;
  --max-width-auth: 750px;
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-sidebar: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
  --z-overlay: 1999;
  --z-toast: 3000;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-family: inherit;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  line-height: 1.5;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  user-select: none;
  border: 1px solid transparent;
  border-radius: var(--radius);
  transition: var(--transition);
  background-color: transparent;
  color: var(--cl-text);
}
.btn:hover:not(:disabled) {
  transform: translateY(-1px);
}
.btn:active:not(:disabled) {
  transform: translateY(0);
}
.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
  pointer-events: none;
}
.btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--cl-focus-ring);
}
.btn-primary {
  background-color: var(--cl-primary);
  border-color: var(--cl-primary);
  color: var(--cl-text-on-primary);
}
.btn-primary:hover:not(:disabled),
.btn-primary:focus:not(:disabled) {
  background-color: var(--cl-primary-hover);
  border-color: var(--cl-primary-hover);
  color: var(--cl-text-on-primary);
  box-shadow: var(--cl-shadow-sm);
}
.btn-secondary {
  background-color: var(--cl-secondary);
  border-color: var(--cl-secondary);
  color: var(--cl-text-on-primary);
}
.btn-secondary:hover:not(:disabled),
.btn-secondary:focus:not(:disabled) {
  background-color: var(--cl-secondary-hover);
  border-color: var(--cl-secondary-hover);
}
.btn-success {
  background-color: var(--cl-success);
  border-color: var(--cl-success);
  color: var(--cl-text-on-primary);
}
.btn-success:hover:not(:disabled) {
  filter: brightness(1.1);
}
.btn-danger {
  background-color: var(--cl-danger);
  border-color: var(--cl-danger);
  color: var(--cl-text-on-primary);
}
.btn-danger:hover:not(:disabled) {
  filter: brightness(1.1);
}
.btn-warning {
  background-color: var(--cl-warning);
  border-color: var(--cl-warning);
  color: var(--color-gray-800);
}
.btn-warning:hover:not(:disabled) {
  filter: brightness(1.05);
}
.btn-info {
  background-color: var(--cl-info);
  border-color: var(--cl-info);
  color: var(--cl-text-on-primary);
}
.btn-info:hover:not(:disabled) {
  filter: brightness(1.1);
}
.btn-light {
  background-color: var(--cl-bg-muted);
  border-color: var(--cl-border-light);
  color: var(--cl-text);
}
.btn-light:hover:not(:disabled) {
  background-color: var(--cl-bg-subtle);
}
.btn-outline-primary {
  color: var(--cl-primary);
  border-color: var(--cl-primary);
  background-color: transparent;
}
.btn-outline-primary:hover:not(:disabled),
.btn-outline-primary:focus:not(:disabled) {
  background-color: var(--cl-primary);
  color: var(--cl-text-on-primary);
  box-shadow: var(--cl-shadow-sm);
}
.btn-outline-secondary {
  color: var(--cl-text-secondary);
  border-color: var(--cl-border);
  background-color: transparent;
}
.btn-outline-secondary:hover:not(:disabled),
.btn-outline-secondary:focus:not(:disabled) {
  background-color: var(--cl-bg-subtle);
  border-color: var(--cl-text-secondary);
  color: var(--cl-text);
}
.btn-outline-danger {
  color: var(--cl-danger);
  border-color: var(--cl-danger);
  background-color: transparent;
}
.btn-outline-danger:hover:not(:disabled),
.btn-outline-danger:focus:not(:disabled) {
  background-color: var(--cl-danger);
  color: var(--cl-text-on-primary);
}
.btn-lg {
  padding: 0.75rem 1.5rem;
  font-size: var(--fs-md);
  border-radius: var(--radius-md);
}
.btn-sm {
  padding: 0.25rem 0.625rem;
  font-size: var(--fs-sm);
  border-radius: var(--radius-sm);
}
.btn-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  padding: 0;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  opacity: 0.65;
  transition: var(--transition);
}
.btn-close::before {
  content: "\d7";
  font-size: 1.5rem;
  line-height: 1;
  color: currentColor;
}
.btn-close:hover {
  opacity: 1;
}
.btn-close:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px var(--cl-focus-ring);
}
.btn-close-white {
  color: var(--cl-text-on-primary);
}
.btn-close-white::before {
  color: var(--cl-text-on-primary);
}
.form-control {
  display: block;
  width: 100%;
  padding: 0.5rem 0.875rem;
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--cl-text);
  background-color: var(--cl-bg-input);
  border: 1px solid var(--cl-border-input);
  border-radius: var(--radius);
  transition: var(--transition);
  appearance: none;
}
.form-control::placeholder {
  color: var(--cl-text-placeholder);
  opacity: 1;
}
.form-control:focus {
  border-color: var(--cl-border-focus);
  outline: 0;
  box-shadow: 0 0 0 3px var(--cl-focus-ring);
  background-color: var(--cl-bg-input);
  color: var(--cl-text);
}
.form-control:disabled,
.form-control[readonly] {
  background-color: var(--cl-bg-muted);
  opacity: 0.7;
  cursor: not-allowed;
}
textarea.form-control {
  min-height: calc(1.5em + 1rem + 2px);
}
.form-select {
  display: block;
  width: 100%;
  padding: 0.5rem 2.25rem 0.5rem 0.875rem;
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--cl-text);
  background-color: var(--cl-bg-input);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%236c757d' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 12px;
  border: 1px solid var(--cl-border-input);
  border-radius: var(--radius);
  appearance: none;
  transition: var(--transition);
}
.form-select:focus {
  border-color: var(--cl-border-focus);
  outline: 0;
  box-shadow: 0 0 0 3px var(--cl-focus-ring);
}
.form-label {
  display: inline-block;
  margin-bottom: 0.375rem;
  font-size: var(--fs-sm);
  font-weight: var(--fw-medium);
  color: var(--cl-text);
}
.form-text {
  display: block;
  margin-top: 0.25rem;
  font-size: var(--fs-xs);
  color: var(--cl-text-muted);
}
.form-floating {
  position: relative;
}
.form-floating > .form-control {
  height: calc(3.5rem + 2px);
  padding: 1rem 0.875rem;
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label {
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
  color: var(--cl-primary);
}
.form-floating > .form-control::placeholder {
  color: transparent;
}
.form-floating > label {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  padding: 1rem 0.875rem;
  overflow: hidden;
  text-align: start;
  text-overflow: ellipsis;
  white-space: nowrap;
  pointer-events: none;
  border: 1px solid transparent;
  transform-origin: 0 0;
  transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out;
  color: var(--cl-text-muted);
  font-size: var(--fs-base);
}
.form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  min-height: 1.5rem;
  margin-bottom: 0.125rem;
}
.form-check .form-check-input {
  flex-shrink: 0;
  width: 1.125rem;
  height: 1.125rem;
  margin-top: 0.1875rem;
  cursor: pointer;
  accent-color: var(--cl-primary);
}
.form-check .form-check-label {
  cursor: pointer;
  font-size: var(--fs-base);
  color: var(--cl-text);
}
.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}
.input-group > .form-control,
.input-group > .form-select {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}
.input-group > .form-control:not(:first-child),
.input-group > .form-select:not(:first-child) {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.input-group > .form-control:not(:last-child),
.input-group > .form-select:not(:last-child) {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}
.input-group > .form-control:focus {
  z-index: 3;
}
.input-group:focus-within .input-group-text {
  border-color: var(--cl-primary);
}
.input-group-text {
  display: flex;
  align-items: center;
  padding: 0.5rem 0.875rem;
  font-size: var(--fs-base);
  font-weight: var(--fw-regular);
  line-height: 1.5;
  color: var(--cl-text);
  text-align: center;
  white-space: nowrap;
  background-color: var(--cl-bg-muted);
  border: 1px solid var(--cl-border-input);
  border-radius: var(--radius);
  transition: var(--transition);
}
.input-group-text:last-child {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  border-left: none;
}
.input-group-text:first-child {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}
.invalid-feedback {
  display: none;
  width: 100%;
  margin-top: 0.25rem;
  font-size: var(--fs-xs);
  color: var(--cl-danger);
}
.invalid-feedback.d-block {
  display: block;
}
.is-invalid {
  border-color: var(--cl-danger) !important;
}
.is-invalid:focus {
  box-shadow: 0 0 0 3px rgba(220, 53, 69, 0.25) !important;
}
.card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  word-wrap: break-word;
  background-color: var(--cl-bg-card);
  border: 1px solid var(--cl-border);
  border-radius: var(--radius);
  box-shadow: var(--cl-shadow);
  color: var(--cl-text);
}
.card-header {
  padding: 0.75rem 1rem;
  background-color: var(--cl-bg-muted);
  border-bottom: 1px solid var(--cl-border);
}
.card-header:first-child {
  border-radius: calc(var(--radius) - 1px) calc(var(--radius) - 1px) 0 0;
}
.card-body {
  flex: 1 1 auto;
  padding: 1rem;
}
.card-footer {
  padding: 0.75rem 1rem;
  background-color: var(--cl-bg-muted);
  border-top: 1px solid var(--cl-border);
}
.card-footer:last-child {
  border-radius: 0 0 calc(var(--radius) - 1px) calc(var(--radius) - 1px);
}
.card-title {
  margin-bottom: 0.5rem;
  font-weight: var(--fw-semibold);
}
.card-text:last-child {
  margin-bottom: 0;
}
.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--z-modal);
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--cl-overlay);
  animation: fadeIn var(--duration-fast) ease;
}
.modal-dialog {
  position: relative;
  width: auto;
  margin: 1.75rem auto;
  max-width: 500px;
  pointer-events: none;
  animation: slideUp var(--duration) var(--ease-out);
}
.modal-dialog.modal-lg {
  max-width: 800px;
}
.modal-dialog.modal-xl {
  max-width: 1140px;
}
.modal-dialog.modal-sm {
  max-width: 300px;
}
.modal-dialog.modal-fullscreen {
  width: 100vw;
  max-width: none;
  height: 100%;
  margin: 0;
}
.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  pointer-events: auto;
  background-color: var(--cl-bg-card);
  border: 1px solid var(--cl-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--cl-shadow-lg);
  outline: 0;
  color: var(--cl-text);
}
.modal-header {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: space-between;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--cl-border);
  border-top-left-radius: var(--radius-lg);
  border-top-right-radius: var(--radius-lg);
}
.modal-title {
  margin-bottom: 0;
  line-height: 1.5;
  font-weight: var(--fw-semibold);
}
.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: 1.25rem;
}
.modal-footer {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  padding: 0.75rem 1.25rem;
  border-top: 1px solid var(--cl-border);
  border-bottom-right-radius: var(--radius-lg);
  border-bottom-left-radius: var(--radius-lg);
}
.modal-backdrop {
  background-color: var(--cl-overlay);
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.alert {
  position: relative;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font-size: var(--fs-sm);
  line-height: 1.5;
}
.alert-success {
  background-color: var(--cl-success-light);
  color: var(--cl-success);
  border-color: var(--cl-success);
}
.alert-danger {
  background-color: var(--cl-danger-light);
  color: var(--cl-danger);
  border-color: var(--cl-danger);
}
.alert-warning {
  background-color: var(--cl-warning-light);
  color: var(--cl-warning);
  border-color: var(--cl-warning);
}
.alert-info {
  background-color: var(--cl-info-light);
  color: var(--cl-info);
  border-color: var(--cl-info);
}
.badge {
  display: inline-flex;
  align-items: center;
  padding: 0.25em 0.625em;
  font-size: var(--fs-xs);
  font-weight: var(--fw-semibold);
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: var(--radius-pill);
}
.badge.bg-primary {
  background-color: var(--cl-primary) !important;
  color: var(--cl-text-on-primary);
}
.badge.bg-success {
  background-color: var(--cl-success) !important;
  color: var(--cl-text-on-primary);
}
.badge.bg-danger {
  background-color: var(--cl-danger) !important;
  color: var(--cl-text-on-primary);
}
.badge.bg-warning {
  background-color: var(--cl-warning) !important;
  color: var(--color-gray-800);
}
.badge.bg-info {
  background-color: var(--cl-info) !important;
  color: var(--cl-text-on-primary);
}
.spinner-border {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  vertical-align: -0.125em;
  border: 0.25em solid currentColor;
  border-right-color: transparent;
  border-radius: 50%;
  animation: spinner-border 0.75s linear infinite;
}
.spinner-border-sm {
  width: 1rem;
  height: 1rem;
  border-width: 0.2em;
}
@keyframes spinner-border {
  to {
    transform: rotate(360deg);
  }
}
.dropdown {
  position: relative;
}
.dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
}
.dropdown-menu {
  position: absolute;
  z-index: var(--z-dropdown);
  display: none;
  min-width: 10rem;
  padding: 0.5rem 0;
  margin: 0;
  font-size: var(--fs-base);
  color: var(--cl-text);
  text-align: left;
  list-style: none;
  background-color: var(--cl-bg-card);
  border: 1px solid var(--cl-border);
  border-radius: var(--radius);
  box-shadow: var(--cl-shadow);
}
.dropdown-menu.show {
  display: block;
}
.dropdown-menu-end {
  right: 0;
  left: auto;
}
.dropdown-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding: 0.5rem 1rem;
  clear: both;
  font-weight: var(--fw-regular);
  color: var(--cl-text);
  text-align: inherit;
  text-decoration: none;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
  cursor: pointer;
  transition: var(--transition);
}
.dropdown-item:hover,
.dropdown-item:focus {
  color: var(--cl-primary);
  background-color: var(--cl-hover-overlay);
}
.dropdown-item.active,
.dropdown-item:active {
  color: var(--cl-primary);
  background-color: var(--cl-primary-light);
}
.dropdown-divider {
  height: 0;
  margin: 0.5rem 0;
  overflow: hidden;
  border-top: 1px solid var(--cl-border);
}
.nav {
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.nav-tabs {
  border-bottom: 1px solid var(--cl-border);
}
.nav-tabs .nav-link {
  margin-bottom: -1px;
  border: 1px solid transparent;
  border-top-left-radius: var(--radius);
  border-top-right-radius: var(--radius);
}
.nav-tabs .nav-link:hover {
  color: var(--cl-primary);
  border-color: transparent;
  background-color: var(--cl-primary-light);
}
.nav-tabs .nav-link.active {
  color: var(--cl-primary);
  background-color: var(--cl-bg-card);
  border-color: transparent;
  border-bottom: 3px solid var(--cl-primary);
  font-weight: var(--fw-semibold);
}
.nav-item {
  display: flex;
}
.nav-link {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 1rem;
  font-size: var(--fs-base);
  font-weight: var(--fw-medium);
  color: var(--cl-text-secondary);
  text-decoration: none;
  background: none;
  border: 0;
  cursor: pointer;
  transition: var(--transition);
}
.nav-link:hover,
.nav-link:focus {
  color: var(--cl-primary);
}
.nav-link.disabled {
  color: var(--cl-text-muted);
  pointer-events: none;
  cursor: default;
}
.progress {
  display: flex;
  height: 1rem;
  overflow: hidden;
  font-size: var(--fs-xs);
  background-color: var(--cl-primary-light);
  border-radius: var(--radius-sm);
}
.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  color: var(--cl-text-on-primary);
  text-align: center;
  white-space: nowrap;
  background-color: var(--cl-primary);
  transition: width var(--duration-slow) var(--ease-default);
}
.toast-container {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.toast {
  position: relative;
  display: flex;
  align-items: center;
  width: 350px;
  max-width: 100%;
  padding: 0.75rem 1rem;
  font-size: var(--fs-sm);
  background-color: var(--cl-bg-card);
  border-radius: var(--radius);
  box-shadow: var(--cl-shadow);
  color: var(--cl-text);
  pointer-events: auto;
  overflow: hidden;
}
.toast.show {
  display: flex;
}
.toast.bg-success {
  background-color: var(--cl-success);
  color: var(--cl-text-on-primary);
}
.toast.bg-danger {
  background-color: var(--cl-danger);
  color: var(--cl-text-on-primary);
}
.toast.bg-info {
  background-color: var(--cl-info);
  color: var(--cl-text-on-primary);
}
.toast.bg-warning {
  background-color: var(--cl-warning);
  color: var(--color-gray-800);
}
.toast-body {
  padding: 0.25rem 0;
  flex: 1;
}
.table {
  width: 100%;
  margin-bottom: 1rem;
  color: var(--cl-text);
  vertical-align: top;
  border-color: var(--cl-border-light);
}
.table > :not(caption) > * > * {
  padding: 0.5rem;
  border-bottom-width: 1px;
  border-bottom-color: var(--cl-border-light);
}
.table > thead > * > * {
  font-weight: var(--fw-semibold);
  border-bottom-color: var(--cl-border);
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: var(--cl-hover-overlay);
}
.table-hover > tbody > tr:hover > * {
  background-color: var(--cl-hover-overlay);
}
::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}
::-webkit-scrollbar-track {
  background: var(--cl-scrollbar-track);
  border-radius: var(--radius-md);
}
::-webkit-scrollbar-thumb {
  background-color: var(--cl-scrollbar-thumb);
  border-radius: var(--radius-md);
}
.settings-page {
  display: grid;
  gap: 0.875rem;
  padding: 0.875rem;
  background: var(--cl-settings-page-backdrop);
  border-radius: 1.75rem;
}
app-settings-security-panel,
app-settings-security-panel-overview {
  display: block;
  width: 100%;
}
.settings-toolbar,
.settings-card,
.settings-state {
  border: 1px solid var(--cl-settings-panel-border);
  border-radius: 1.5rem;
  background: var(--cl-settings-shell-bg);
  box-shadow: var(--cl-settings-panel-shadow);
  -webkit-backdrop-filter: blur(1rem);
  backdrop-filter: blur(1rem);
}
.settings-toolbar {
  display: grid;
  gap: 0.875rem;
  padding: 0.95rem;
}
.settings-toolbar__identity {
  display: flex;
  align-items: center;
  gap: 0.9rem;
  min-width: 0;
}
.settings-toolbar__avatar {
  display: block;
  width: 3.25rem;
  height: 3.25rem;
  flex: 0 0 auto;
  border-radius: 1rem;
  border: 0.125rem solid var(--cl-settings-avatar-ring);
  box-shadow: var(--cl-shadow-sm);
}
.settings-toolbar__copy {
  min-width: 0;
}
.settings-toolbar__copy h1 {
  margin: 0;
  color: var(--cl-settings-title);
  font-size: clamp(1.8rem, 5vw, 2.4rem);
  line-height: 1.1;
}
.settings-toolbar__copy p {
  margin: 0.35rem 0 0;
  color: var(--cl-settings-copy-muted);
  white-space: normal;
}
.settings-toolbar__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
.settings-toolbar__separator {
  color: var(--cl-settings-copy-muted);
}
.settings-status-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem 0.9rem;
  border-radius: 999rem;
  background: var(--cl-settings-chip-bg);
  color: var(--cl-settings-chip-text);
  font-size: 0.84rem;
  box-shadow: var(--cl-shadow-xs);
}
.settings-status-chip--subtle {
  background: var(--cl-settings-tab-badge-bg);
}
.settings-tabs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(6.5rem, 100%), 1fr));
  gap: 0.6rem;
}
.settings-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 2.8rem;
  padding: 0.7rem 0.85rem;
  border: 1px solid var(--cl-settings-tab-border);
  border-radius: 999rem;
  background: var(--cl-settings-tab-bg);
  box-shadow: var(--cl-shadow-xs);
  color: var(--cl-settings-title);
  text-align: center;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}
.settings-tab:hover,
.settings-tab:focus-visible,
.settings-tab--active {
  border-color: var(--cl-settings-tab-border-active);
  box-shadow: var(--cl-shadow-sm);
  transform: translateY(-0.0625rem);
}
.settings-tab--active {
  background: var(--cl-settings-tab-bg-active);
}
.settings-tab__label {
  font-weight: 700;
}
.settings-tab__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.28rem 0.65rem;
  border-radius: 999rem;
  background: var(--cl-settings-tab-badge-bg);
  color: var(--cl-settings-tab-badge-text);
  font-size: 0.72rem;
  font-weight: 700;
}
.settings-shell,
.settings-panel {
  display: grid;
  min-width: 0;
}
.settings-state {
  display: grid;
  gap: 0.85rem;
  padding: 1.25rem;
}
.settings-state__pulse {
  width: 1rem;
  height: 1rem;
  border-radius: 999rem;
  background: var(--cl-settings-status-pulse-bg);
  animation: settings-pulse 1.4s ease-in-out infinite;
}
.settings-card {
  display: grid;
  gap: 1rem;
  padding: 1rem;
}
.settings-card h2 {
  margin: 0;
  color: var(--cl-settings-title);
}
.settings-card p {
  margin: 0;
  color: var(--cl-settings-copy-muted);
}
.settings-card__header {
  display: grid;
  gap: 0.85rem;
}
.settings-card__header .settings-btn {
  width: 100%;
}
.profile-layout {
  display: grid;
  gap: 0.9rem;
}
.profile-avatar-card {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 0.95rem;
  border-radius: 1.35rem;
  background: var(--cl-settings-hero-bg);
  color: var(--cl-text-on-primary);
}
.profile-avatar-card__frame {
  width: min(100%, 13rem);
  aspect-ratio: 1;
  margin: 0 auto;
  padding: 0.45rem;
  border-radius: 1.2rem;
  background: var(--cl-settings-avatar-frame-bg);
}
.profile-avatar-card__image {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 1rem;
}
.profile-avatar-card__copy,
.profile-avatar-card__summary {
  display: grid;
  gap: 0.35rem;
}
.profile-avatar-card__copy strong,
.profile-avatar-card__summary strong {
  color: var(--cl-text-on-primary);
}
.profile-avatar-card__copy p,
.profile-avatar-card__summary span {
  color: color-mix(in srgb, var(--cl-text-on-primary), transparent 26%);
}
.profile-avatar-card__upload {
  justify-content: center;
}
.profile-avatar-card__upload input {
  display: none;
}
.profile-form {
  display: grid;
  gap: 0.9rem;
}
.profile-form__grid {
  display: grid;
  gap: 0.9rem;
}
.profile-field {
  display: grid;
  gap: 0.45rem;
}
.profile-field--full {
  grid-column: 1/-1;
}
.profile-field__label {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  color: var(--cl-settings-title);
  font-weight: 700;
}
.profile-field__required {
  color: var(--cl-settings-section-label);
}
.profile-field__hint,
.profile-field__meta {
  color: var(--cl-settings-copy-muted);
}
.profile-field__meta {
  display: flex;
  justify-content: space-between;
  gap: 0.75rem;
  font-size: 0.82rem;
}
.profile-field__input {
  width: 100%;
  min-width: 0;
  padding: 0.9rem 1rem;
  border: 1px solid var(--cl-settings-input-border);
  border-radius: 1rem;
  background: var(--cl-settings-input-bg);
  color: var(--cl-settings-title);
  box-shadow: inset 0 0.0625rem 0 var(--cl-settings-input-highlight);
}
.profile-field__input::placeholder {
  color: var(--cl-text-placeholder);
}
.profile-field__input:focus {
  outline: 0.18rem solid var(--cl-settings-focus-ring);
  border-color: var(--cl-settings-input-border-focus);
}
.profile-field__input--textarea {
  min-height: 7.5rem;
  resize: vertical;
}
.profile-field__error {
  color: var(--cl-danger);
  font-size: 0.82rem;
  font-weight: 600;
}
.settings-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.8rem 1.05rem;
  border: 1px solid transparent;
  border-radius: 999rem;
  font: inherit;
  font-weight: 700;
  transition:
    box-shadow 160ms ease,
    opacity 160ms ease,
    transform 160ms ease;
}
.settings-btn:hover:not(:disabled),
.settings-btn:focus-visible:not(:disabled) {
  box-shadow: var(--cl-shadow-sm);
  transform: translateY(-0.0625rem);
}
.settings-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
.settings-btn--primary {
  background: var(--cl-settings-primary-action-bg);
  color: var(--cl-settings-primary-action-text);
}
.settings-btn--secondary {
  background: var(--cl-settings-secondary-action-bg);
  border-color: var(--cl-settings-secondary-action-border);
  color: var(--cl-settings-secondary-action-text);
}
.settings-btn--ghost {
  background: var(--cl-settings-ghost-action-bg);
  border-color: var(--cl-settings-ghost-action-border);
  color: var(--cl-settings-ghost-action-text);
}
.settings-card--placeholder {
  min-height: 12rem;
  align-content: center;
}
.settings-card__header--stacked {
  grid-template-columns: minmax(0, 1fr);
}
.settings-security {
  display: grid;
  gap: 1.35rem;
}
.settings-security__heading h2 {
  margin: 0;
  color: var(--cl-settings-title);
  font-size: clamp(1.7rem, 3vw, 2.15rem);
  line-height: 1.08;
}
.security-overview {
  display: grid;
  gap: 1.2rem;
}
.security-account-card {
  position: relative;
  display: grid;
  gap: 1rem;
  padding: clamp(1.1rem, 2vw, 1.45rem);
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 20%);
  border-radius: 1.6rem;
  background:
    radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--cl-info), transparent 92%) 0,
      transparent 38%),
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 18%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 6%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 18%), 0 18px 34px color-mix(in srgb, black, transparent 90%);
}
.security-account-card--attention {
  background:
    radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--cl-warning), transparent 88%) 0,
      transparent 34%),
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--cl-warning-light), white 18%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 8%));
}
.security-account-card__header {
  display: grid;
  gap: 0.9rem;
  align-items: start;
}
.security-account-card__icon-shell {
  display: grid;
  place-items: center;
  width: 3.5rem;
  height: 3.5rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-bg-card), transparent 6%);
  color: var(--cl-info);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 18%), 0 14px 26px color-mix(in srgb, var(--cl-info), transparent 90%);
}
.security-account-card--attention .security-account-card__icon-shell {
  color: color-mix(in srgb, var(--cl-warning), black 18%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 18%), 0 14px 26px color-mix(in srgb, var(--cl-warning), transparent 88%);
}
.security-account-card__icon-shell .security-icon-mask {
  width: 1.5rem;
  height: 1.5rem;
}
.security-account-card__copy {
  display: grid;
  gap: 0.35rem;
}
.security-account-card__eyebrow {
  color: var(--cl-settings-copy-muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.security-account-card__copy h3 {
  margin: 0;
  color: var(--cl-settings-title);
  font-size: clamp(1.25rem, 2.4vw, 1.65rem);
  line-height: 1.14;
}
.security-account-card__copy p,
.security-account-card__hint {
  margin: 0;
  color: var(--cl-settings-copy-muted);
  line-height: 1.55;
}
.security-account-card__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 2rem;
  padding: 0.35rem 0.8rem;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 700;
}
.security-account-card__badge--verified {
  background: color-mix(in srgb, var(--cl-success), white 76%);
  color: color-mix(in srgb, var(--cl-success), black 14%);
}
.security-account-card__badge--attention {
  background: color-mix(in srgb, var(--cl-warning), white 74%);
  color: color-mix(in srgb, var(--cl-warning), black 20%);
}
.security-account-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem 0.9rem;
  align-items: center;
  padding: 0.85rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 24%);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-bg-card), transparent 4%);
  color: var(--cl-settings-copy-muted);
}
.security-account-card__meta strong {
  color: var(--cl-settings-title);
  font-weight: 700;
}
.security-account-card__actions {
  display: grid;
  gap: 0.75rem;
}
.security-account-card__button {
  width: 100%;
}
.security-icon-mask {
  display: block;
  width: 100%;
  height: 100%;
  background-color: currentColor;
  mask-position: center;
  mask-repeat: no-repeat;
  mask-size: contain;
  -webkit-mask-position: center;
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: contain;
}
.security-icon-mask--shield-check {
  mask-image: url(/assets/settings/security/shield-check.svg);
  -webkit-mask-image: url(/assets/settings/security/shield-check.svg);
}
.security-icon-mask--check-circle {
  mask-image: url(/assets/settings/security/check-circle.svg);
  -webkit-mask-image: url(/assets/settings/security/check-circle.svg);
}
.security-icon-mask--lock {
  mask-image: url(/assets/settings/security/lock.svg);
  -webkit-mask-image: url(/assets/settings/security/lock.svg);
}
.security-icon-mask--clock {
  mask-image: url(/assets/settings/security/clock.svg);
  -webkit-mask-image: url(/assets/settings/security/clock.svg);
}
.security-icon-mask--warning-triangle {
  mask-image: url(/assets/settings/security/warning-triangle.svg);
  -webkit-mask-image: url(/assets/settings/security/warning-triangle.svg);
}
.security-icon-mask--copy {
  mask-image: url(/assets/settings/security/copy.svg);
  -webkit-mask-image: url(/assets/settings/security/copy.svg);
}
.security-icon-mask--chevron-right {
  mask-image: url(/assets/settings/security/chevron-right.svg);
  -webkit-mask-image: url(/assets/settings/security/chevron-right.svg);
}
.security-icon-mask--alert-circle {
  mask-image: url(/assets/settings/security/alert-circle.svg);
  -webkit-mask-image: url(/assets/settings/security/alert-circle.svg);
}
.security-hero-card {
  position: relative;
  display: grid;
  gap: 1.35rem;
  align-items: center;
  overflow: hidden;
  padding: clamp(1.25rem, 2vw, 1.85rem);
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 18%);
  border-radius: 1.75rem;
  background:
    radial-gradient(
      circle at 12% 18%,
      color-mix(in srgb, var(--cl-primary), transparent 84%) 0,
      transparent 24%),
    radial-gradient(
      circle at 100% 100%,
      color-mix(in srgb, var(--cl-success), transparent 92%) 0,
      transparent 28%),
    linear-gradient(
      145deg,
      color-mix(in srgb, var(--cl-settings-elevated-surface), white 6%),
      color-mix(in srgb, var(--cl-settings-elevated-surface), black 14%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 14%), 0 22px 48px color-mix(in srgb, black, transparent 88%);
}
.security-hero-card > * {
  position: relative;
  z-index: 1;
}
.security-hero-card__icon-shell {
  position: relative;
  display: grid;
  place-items: center;
  width: 6.5rem;
  min-height: 6.5rem;
}
.security-hero-card__icon-bubble {
  display: grid;
  place-items: center;
  width: 6.25rem;
  height: 6.25rem;
  border: 1px solid color-mix(in srgb, var(--cl-primary), transparent 72%);
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 30% 20%,
      color-mix(in srgb, white, transparent 16%) 0,
      transparent 36%),
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--cl-primary), white 74%),
      color-mix(in srgb, var(--cl-settings-elevated-surface), white 8%));
  color: color-mix(in srgb, var(--cl-primary), white 12%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 12%), 0 20px 40px color-mix(in srgb, var(--cl-primary), transparent 82%);
}
.security-hero-card__icon {
  width: 3rem;
  height: 3rem;
}
.security-hero-card__spark {
  position: absolute;
  color: color-mix(in srgb, var(--cl-primary-accent), white 12%);
  font-size: 1.1rem;
  font-weight: 800;
  line-height: 1;
  text-shadow: 0 0 18px color-mix(in srgb, var(--cl-primary), transparent 78%);
}
.security-hero-card__spark--top {
  top: 0.45rem;
  left: 0.3rem;
}
.security-hero-card__spark--bottom {
  right: 0.2rem;
  bottom: 0.65rem;
}
.security-hero-card__copy {
  display: grid;
  gap: 0.85rem;
}
.security-hero-card__copy h3,
.security-benefits h3,
.security-modal__intro-copy h3,
.security-modal__card-copy strong,
.security-modal__loading-card strong,
.security-modal__summary-card strong,
.security-modal__support-card strong,
.security-benefit-card strong {
  margin: 0;
  color: var(--cl-settings-title);
}
.security-hero-card__copy h3 {
  font-size: clamp(1.55rem, 3vw, 2.1rem);
  line-height: 1.08;
}
.security-hero-card__copy p,
.security-benefit-card p,
.security-modal__intro-copy p,
.security-modal__card-copy p,
.security-modal__loading-card p,
.security-inline-state,
.security-modal__support-card p {
  margin: 0;
  color: var(--cl-settings-copy-muted);
}
.security-hero-card__copy p {
  max-width: 42rem;
}
.security-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}
.security-chip {
  --security-chip-accent: var(--cl-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 2.25rem;
  padding: 0.48rem 0.88rem;
  border: 1px solid color-mix(in srgb, var(--security-chip-accent), transparent 82%);
  border-radius: 999rem;
  background: color-mix(in srgb, var(--cl-settings-elevated-surface), transparent 6%);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 14%);
  color: var(--cl-settings-title);
  font-size: 0.85rem;
  font-weight: 600;
}
.security-chip--protect {
  --security-chip-accent: var(--cl-primary);
}
.security-chip--verify {
  --security-chip-accent: var(--cl-info);
}
.security-chip--quick {
  --security-chip-accent: var(--cl-success);
}
.security-chip__icon {
  display: inline-flex;
  width: 1.05rem;
  height: 1.05rem;
  color: var(--security-chip-accent);
}
.security-toggle-card {
  position: relative;
  display: grid;
  min-height: 100%;
  align-content: center;
  overflow: hidden;
  padding: 1.05rem 1.2rem;
  border: 1px solid color-mix(in srgb, var(--cl-primary), transparent 84%);
  border-radius: 1.35rem;
  background:
    radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--cl-primary), transparent 88%) 0,
      transparent 38%),
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--cl-settings-elevated-surface), white 10%),
      color-mix(in srgb, var(--cl-settings-elevated-surface), black 8%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 18%), 0 18px 30px color-mix(in srgb, black, transparent 90%);
}
.security-toggle-card__row {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.95rem;
  min-height: 100%;
  width: 100%;
}
.security-toggle-card__label {
  color: var(--cl-settings-title);
  font-size: clamp(1rem, 1.3vw, 1.3rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  white-space: nowrap;
}
.security-toggle-card vl-switch {
  display: inline-flex;
  flex: 0 0 auto;
  transform: scale(1.14);
  transform-origin: center;
}
.security-inline-state {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.95rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 22%);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-settings-shell-bg), white 16%);
}
.security-inline-state--error {
  border-color: color-mix(in srgb, var(--cl-danger), transparent 78%);
  background: color-mix(in srgb, var(--cl-danger-light), white 22%);
  color: color-mix(in srgb, var(--cl-danger), black 10%);
}
.security-inline-state--loading {
  color: var(--cl-settings-copy-muted);
}
.security-inline-state--success {
  border-color: color-mix(in srgb, var(--cl-success), transparent 80%);
  background: color-mix(in srgb, var(--cl-success), white 82%);
  color: color-mix(in srgb, var(--cl-success), black 12%);
}
.security-benefits {
  display: grid;
  gap: 1rem;
}
.security-benefits h3 {
  font-size: clamp(1.2rem, 2vw, 1.55rem);
}
.security-benefits__grid {
  display: grid;
  gap: 1rem;
}
.security-benefit-card {
  --security-benefit-accent: var(--cl-primary);
  position: relative;
  display: grid;
  overflow: hidden;
  justify-items: center;
  gap: 0.95rem;
  padding: 1.5rem 1.2rem;
  border: 1px solid color-mix(in srgb, var(--security-benefit-accent), transparent 88%);
  border-radius: 1.5rem;
  background:
    radial-gradient(
      circle at top center,
      color-mix(in srgb, var(--security-benefit-accent), transparent 92%) 0,
      transparent 34%),
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--cl-settings-elevated-surface), white 2%),
      color-mix(in srgb, var(--cl-settings-elevated-surface), black 10%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 14%), 0 18px 36px color-mix(in srgb, black, transparent 90%);
  text-align: center;
}
.security-benefit-card--protect {
  --security-benefit-accent: var(--cl-primary);
}
.security-benefit-card--verify {
  --security-benefit-accent: var(--cl-info);
}
.security-benefit-card--quick {
  --security-benefit-accent: var(--cl-success);
}
.security-benefit-card__icon {
  display: grid;
  place-items: center;
  width: 4.6rem;
  height: 4.6rem;
  border: 1px solid color-mix(in srgb, var(--security-benefit-accent), transparent 78%);
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 30% 24%,
      color-mix(in srgb, white, transparent 16%) 0,
      transparent 38%),
    linear-gradient(
      160deg,
      color-mix(in srgb, var(--security-benefit-accent), transparent 86%),
      color-mix(in srgb, var(--cl-settings-elevated-surface), white 4%));
  color: var(--security-benefit-accent);
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 14%), 0 18px 32px color-mix(in srgb, var(--security-benefit-accent), transparent 90%);
}
.security-benefit-card__icon--success {
  --security-benefit-accent: var(--cl-success);
}
.security-benefit-card__icon-graphic {
  width: 2rem;
  height: 2rem;
}
.security-benefit-card strong {
  font-size: 1.08rem;
}
.security-benefit-card p {
  max-width: 16rem;
  line-height: 1.6;
}
.security-modal {
  display: grid;
  gap: 1rem;
}
.security-modal__stage,
.security-modal__stack,
.security-modal__setup-grid,
.security-modal__summary-grid,
.security-modal__meta-grid {
  display: grid;
  gap: 1rem;
}
.security-modal__intro,
.security-modal__scan-card,
.security-modal__step-card,
.security-modal__form-card,
.security-modal__loading-card,
.security-modal__summary-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.15rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 22%);
  border-radius: 1.45rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 24%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 10%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 16%), 0 16px 34px color-mix(in srgb, var(--cl-primary), transparent 92%);
}
.security-modal__intro {
  align-items: start;
}
.security-modal__intro--setup {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--cl-primary), white 84%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 20%));
}
.security-modal__intro--neutral {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--cl-primary), white 88%),
      color-mix(in srgb, var(--cl-info-light), white 20%));
}
.security-modal__intro--warning {
  background:
    linear-gradient(
      135deg,
      color-mix(in srgb, var(--cl-warning), white 88%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 18%));
}
.security-modal__intro-icon {
  display: grid;
  place-items: center;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 1rem;
  background: color-mix(in srgb, white, transparent 16%);
  color: var(--cl-primary);
}
.security-modal__intro--warning .security-modal__intro-icon {
  color: color-mix(in srgb, var(--cl-warning), black 24%);
}
.security-modal__intro-icon-graphic {
  width: 1.6rem;
  height: 1.6rem;
}
.security-modal__intro-copy {
  display: grid;
  gap: 0.4rem;
}
.security-modal__intro-copy h3 {
  font-size: clamp(1.18rem, 2vw, 1.45rem);
  line-height: 1.14;
}
.security-modal__eyebrow,
.security-modal__step-badge {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  justify-content: center;
  min-height: 1.8rem;
  padding: 0.3rem 0.7rem;
  border-radius: 999rem;
  background: color-mix(in srgb, white, transparent 16%);
  color: var(--cl-settings-title);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.security-modal__card-copy {
  display: grid;
  gap: 0.35rem;
}
.security-modal__card-copy strong,
.security-modal__loading-card strong,
.security-modal__summary-card strong,
.security-modal__support-card strong {
  font-size: 1.04rem;
  line-height: 1.2;
}
.security-modal__loading-card {
  min-height: 16rem;
  justify-items: center;
  align-content: center;
  text-align: center;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 28%),
      color-mix(in srgb, var(--cl-settings-secondary-action-bg), white 56%));
}
.security-modal__scan-card {
  align-content: start;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 28%),
      color-mix(in srgb, var(--cl-settings-secondary-action-bg), white 52%));
}
.security-modal__qr-frame {
  display: grid;
  place-items: center;
  min-height: 18rem;
  padding: 1rem;
  border-radius: 1.15rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 36%),
      color-mix(in srgb, var(--cl-settings-secondary-action-bg), white 64%));
}
.security-modal__qr-image {
  width: min(100%, 18rem);
  border-radius: 1rem;
}
.security-modal__qr-placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 14rem;
}
.security-modal__meta-grid {
  gap: 0.8rem;
}
.security-modal__meta-card {
  display: grid;
  gap: 0.18rem;
  padding: 0.9rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 22%);
  border-radius: 1rem;
  background: color-mix(in srgb, white, transparent 14%);
}
.security-modal__meta-card dt,
.security-modal__summary-label {
  color: var(--cl-settings-copy-muted);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.security-modal__meta-card dd {
  margin: 0;
  color: var(--cl-settings-title);
  font-weight: 700;
}
.security-modal__step-card--soft,
.security-modal__form-card {
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 22%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 8%));
}
.security-modal__secret-block {
  padding: 1rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-settings-title), black 28%);
  color: color-mix(in srgb, var(--cl-settings-shell-bg), white 28%);
  font-family: var(--font-mono);
  font-size: 1rem;
  letter-spacing: 0.16em;
  word-break: break-word;
}
.security-modal__code-form {
  display: grid;
}
.security-modal__code-input {
  font-family: var(--font-mono);
  font-size: 1.25rem;
  letter-spacing: 0.28em;
  text-align: center;
}
.security-modal__support-card {
  display: grid;
  gap: 0.35rem;
  padding: 0.95rem 1rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-settings-shell-bg), white 24%);
}
.security-modal__summary-card--identity strong,
.security-modal__support-card strong {
  word-break: break-word;
}
.security-modal__warning {
  padding: 0.95rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cl-danger), transparent 82%);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-danger-light), white 18%);
  color: color-mix(in srgb, var(--cl-danger), black 8%);
  font-weight: 600;
}
.security-modal__footer {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  width: 100%;
}
.security-modal__footer .settings-btn {
  min-width: 8.5rem;
}
.security-modal__stage--setup-refined {
  gap: 1.5rem;
}
.security-modal__setup-subtitle {
  margin: 0;
  color: var(--cl-settings-copy-muted);
  font-size: 1.02rem;
  line-height: 1.6;
  text-align: center;
}
.security-modal__qr-layout {
  display: grid;
  gap: 1.5rem;
  align-items: start;
}
.security-qr-card {
  position: relative;
  display: grid;
  gap: 1rem;
  padding: 1.1rem;
  border: 1px solid color-mix(in srgb, var(--cl-primary), transparent 72%);
  border-radius: 1.65rem;
  background:
    radial-gradient(
      circle at top left,
      color-mix(in srgb, var(--cl-primary), white 82%) 0,
      transparent 42%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 32%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 12%));
  box-shadow:
    inset 0 1px 0 color-mix(in srgb, white, transparent 10%),
    0 0 0 3px color-mix(in srgb, var(--cl-primary), transparent 92%),
    0 24px 48px color-mix(in srgb, var(--cl-primary), transparent 86%);
}
.security-qr-card__badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.7rem;
  padding: 0.2rem 0.75rem;
  border-radius: 999rem;
  background: color-mix(in srgb, var(--cl-success), white 20%);
  color: var(--cl-text-on-primary);
  font-size: 0.76rem;
  font-weight: 700;
}
.security-qr-card__frame {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 18rem;
  padding: 1.25rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 30%);
  border-radius: 1.35rem;
  background:
    radial-gradient(
      circle at 20% 30%,
      color-mix(in srgb, white, transparent 6%) 0,
      transparent 22%),
    radial-gradient(
      circle at 78% 70%,
      color-mix(in srgb, white, transparent 8%) 0,
      transparent 18%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-settings-shell-bg), white 44%),
      color-mix(in srgb, var(--cl-settings-secondary-action-bg), white 76%));
}
.security-qr-card__image {
  width: min(100%, 13rem);
  padding: 0.55rem;
  border-radius: 1rem;
  background: white;
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--cl-settings-panel-border), white 20%), 0 14px 30px color-mix(in srgb, var(--cl-primary), transparent 88%);
}
.security-qr-card__placeholder {
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 12rem;
}
.security-qr-card__meta {
  display: grid;
  gap: 0.65rem;
}
.security-qr-card__key-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}
.security-qr-card__key-header strong {
  color: var(--cl-settings-title);
  font-size: 1.1rem;
}
.security-qr-card__copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2rem;
  height: 2rem;
  border: 0;
  border-radius: 0.75rem;
  background: color-mix(in srgb, var(--cl-settings-shell-bg), white 24%);
  color: var(--cl-settings-copy-muted);
}
.security-qr-card__copy-icon {
  width: 1.1rem;
  height: 1.1rem;
}
.security-qr-card__key-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  width: 100%;
  padding: 0.85rem 1rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 28%);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-settings-shell-bg), white 30%);
  color: var(--cl-settings-title);
  font-family: var(--font-mono);
  font-size: 0.98rem;
  letter-spacing: 0.12em;
  text-align: left;
}
.security-qr-card__key-pill-icon {
  width: 1rem;
  height: 1rem;
  flex: 0 0 auto;
  color: var(--cl-settings-copy-muted);
}
.security-setup-panel {
  display: grid;
  gap: 1.5rem;
  align-content: start;
  padding-top: 0.45rem;
}
.security-setup-panel__steps {
  display: grid;
  gap: 1rem;
  padding: 0;
  margin: 0;
  list-style: none;
}
.security-setup-panel__step {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.85rem;
  align-items: start;
}
.security-setup-panel__step-index {
  display: inline-grid;
  place-items: center;
  width: 1.75rem;
  height: 1.75rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--cl-primary), white 12%);
  color: var(--cl-text-on-primary);
  font-size: 0.92rem;
  font-weight: 800;
}
.security-setup-panel__step-copy {
  color: var(--cl-settings-title);
  font-size: 1.06rem;
  line-height: 1.5;
}
.security-code-entry {
  display: grid;
  gap: 0.55rem;
  justify-items: start;
}
.security-code-entry__form {
  width: 100%;
}
.security-code-entry__label {
  position: relative;
  display: grid;
  width: 100%;
}
.security-code-entry__input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: text;
}
.security-code-entry__slots {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 3rem));
  gap: 0.45rem;
}
.security-code-entry__slot {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 26%);
  border-radius: 0.6rem;
  background: color-mix(in srgb, var(--cl-settings-shell-bg), white 30%);
  color: transparent;
  font-family: var(--font-mono);
  font-size: 1.25rem;
  font-weight: 700;
  text-transform: uppercase;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    background 160ms ease;
}
.security-code-entry__input:focus + .security-code-entry__slots .security-code-entry__slot {
  border-color: color-mix(in srgb, var(--cl-primary), transparent 58%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cl-primary), transparent 90%);
}
.security-code-entry__slot--filled {
  color: var(--cl-settings-title);
  background: color-mix(in srgb, white, transparent 10%);
}
.security-code-entry__error {
  text-align: left;
}
.security-code-entry__help {
  padding: 0;
  border: 0;
  background: transparent;
  color: color-mix(in srgb, var(--cl-primary), black 8%);
  font-size: 0.98rem;
  text-decoration: underline;
}
.security-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;
}
.security-modal__error-card {
  display: grid;
  gap: 1rem;
  justify-items: center;
  padding: 2rem 1.5rem;
  border: 1px solid color-mix(in srgb, var(--cl-danger), transparent 84%);
  border-radius: 1.5rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-danger-light), white 12%),
      color-mix(in srgb, var(--cl-settings-shell-bg), white 10%));
  text-align: center;
}
.security-modal__error-icon {
  display: grid;
  place-items: center;
  width: 3.4rem;
  height: 3.4rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--cl-danger-light), white 8%);
  color: var(--cl-danger);
}
.security-modal__error-icon-graphic {
  width: 1.8rem;
  height: 1.8rem;
}
.security-modal__error-hint {
  color: var(--cl-settings-copy-muted);
  line-height: 1.6;
}
.security-awareness-screen {
  gap: 1.5rem;
  justify-items: center;
  padding: clamp(0.25rem, 1vw, 0.75rem) clamp(0.25rem, 1vw, 0.5rem);
  text-align: center;
}
.security-awareness-screen__copy {
  display: grid;
  gap: 0.55rem;
  justify-items: center;
  max-width: 34rem;
}
.security-awareness-screen__copy h3 {
  margin: 0;
  color: var(--cl-settings-title);
  font-size: clamp(1.9rem, 3.2vw, 2.45rem);
  line-height: 1.08;
}
.security-awareness-screen__copy p {
  margin: 0;
  color: color-mix(in srgb, var(--cl-settings-copy-muted), var(--cl-settings-title) 12%);
  font-size: 1.02rem;
  line-height: 1.5;
}
.security-awareness-screen__copy--center {
  justify-items: center;
}
.security-awareness-screen__headline {
  display: inline-flex;
  align-items: center;
  gap: 0.75rem;
}
.security-awareness-screen__headline-icon {
  display: inline-grid;
  place-items: center;
  width: 2.15rem;
  height: 2.15rem;
  border-radius: 0.85rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-warning), white 26%),
      color-mix(in srgb, var(--cl-warning), white 10%));
  color: var(--cl-text-on-primary);
  box-shadow: 0 12px 24px color-mix(in srgb, var(--cl-warning), transparent 70%);
}
.security-awareness-screen__headline-icon-graphic {
  width: 1rem;
  height: 1rem;
}
.security-awareness-hero {
  position: relative;
  display: grid;
  place-items: center;
  width: min(100%, 24rem);
  min-height: 14rem;
}
.security-awareness-hero__glow {
  position: absolute;
  inset: 12% 10% 2%;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at center,
      color-mix(in srgb, var(--cl-primary), white 86%) 0,
      color-mix(in srgb, var(--cl-primary), white 94%) 38%,
      transparent 72%),
    radial-gradient(
      circle at 78% 28%,
      color-mix(in srgb, var(--cl-warning), white 30%) 0,
      transparent 16%),
    radial-gradient(
      circle at 20% 72%,
      color-mix(in srgb, var(--cl-primary), white 60%) 0,
      transparent 20%);
}
.security-awareness-hero__spark {
  position: absolute;
  display: block;
  border-radius: 999rem;
}
.security-awareness-hero__spark--gold {
  bottom: 2.6rem;
  left: 3.15rem;
  width: 0.9rem;
  height: 0.9rem;
  background: color-mix(in srgb, var(--cl-warning), white 10%);
  box-shadow: 0 0 0 0.4rem color-mix(in srgb, var(--cl-warning), transparent 82%);
}
.security-awareness-hero__spark--blue {
  top: 2.3rem;
  right: 4.6rem;
  width: 0.7rem;
  height: 0.7rem;
  background: color-mix(in srgb, var(--cl-primary), white 14%);
  box-shadow: 0 0 0 0.32rem color-mix(in srgb, var(--cl-primary), transparent 84%);
}
.security-awareness-hero__spark--plus {
  top: 4.1rem;
  left: 4.35rem;
  width: 1rem;
  height: 1rem;
  background: transparent;
}
.security-awareness-hero__spark--plus::before,
.security-awareness-hero__spark--plus::after {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  border-radius: 999rem;
  background: color-mix(in srgb, var(--cl-primary), white 32%);
}
.security-awareness-hero__spark--plus::before {
  width: 1rem;
  height: 0.14rem;
}
.security-awareness-hero__spark--plus::after {
  width: 0.14rem;
  height: 1rem;
}
.security-awareness-hero__device {
  position: relative;
  z-index: 1;
  width: 8rem;
  height: 11.25rem;
  border-radius: 1.75rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary), white 24%),
      color-mix(in srgb, var(--cl-primary), black 8%));
  box-shadow: 0 22px 42px color-mix(in srgb, var(--cl-primary), transparent 76%);
}
.security-awareness-hero__device::before {
  content: "";
  position: absolute;
  inset: 0.5rem;
  border-radius: 1.35rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 6%),
      color-mix(in srgb, var(--cl-primary-light), white 26%));
}
.security-awareness-hero__device-notch {
  position: absolute;
  top: 0.72rem;
  left: 50%;
  z-index: 1;
  width: 2.35rem;
  height: 0.42rem;
  border-radius: 999rem;
  transform: translateX(-50%);
  background: color-mix(in srgb, var(--cl-primary), black 22%);
}
.security-awareness-hero__device-screen {
  position: absolute;
  inset: 1.3rem 1rem 1rem;
  border-radius: 1.05rem;
  background:
    radial-gradient(
      circle at 20% 22%,
      color-mix(in srgb, white, transparent 16%) 0,
      transparent 22%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 10%),
      color-mix(in srgb, var(--cl-primary-light), white 30%));
}
.security-awareness-hero__shield {
  position: absolute;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 6rem;
  height: 6.6rem;
  bottom: 1.2rem;
  left: 50%;
  transform: translateX(-50%);
}
.security-awareness-hero__shield-plate {
  position: absolute;
  inset: 0;
  clip-path: polygon(50% 0%, 86% 14%, 86% 53%, 50% 100%, 14% 53%, 14% 14%);
  border-radius: 1.2rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary), white 22%),
      color-mix(in srgb, var(--cl-primary), black 8%));
  box-shadow: inset 0 1px 0 color-mix(in srgb, white, transparent 10%), 0 18px 30px color-mix(in srgb, var(--cl-primary), transparent 72%);
}
.security-awareness-hero__shield::before {
  content: "";
  position: absolute;
  inset: 0.55rem;
  clip-path: polygon(50% 0%, 86% 14%, 86% 53%, 50% 100%, 14% 53%, 14% 14%);
  border-radius: 1rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary-light), white 6%),
      color-mix(in srgb, var(--cl-primary), white 36%));
}
.security-awareness-hero__shield-icon {
  position: relative;
  z-index: 1;
  width: 1.65rem;
  height: 1.65rem;
  color: color-mix(in srgb, var(--cl-warning), white 8%);
}
.security-awareness-benefits {
  display: grid;
  gap: 0.9rem;
  width: min(100%, 28rem);
  padding: 0;
  margin: 0;
  list-style: none;
}
.security-awareness-benefits__item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  color: var(--cl-settings-title);
  font-size: 1rem;
  font-weight: 500;
  text-align: left;
}
.security-awareness-benefits__icon {
  display: inline-grid;
  place-items: center;
  width: 1.6rem;
  height: 1.6rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--cl-primary), white 8%);
  color: var(--cl-text-on-primary);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--cl-primary), transparent 78%);
  flex: 0 0 auto;
}
.security-awareness-benefits__icon-graphic {
  width: 0.85rem;
  height: 0.85rem;
}
.security-awareness-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.85rem;
  width: 100%;
}
.security-awareness-actions--center {
  justify-content: center;
}
.security-awareness-actions__button {
  min-width: 12rem;
  min-height: 3rem;
  padding-inline: 1.5rem;
  box-shadow: 0 18px 30px color-mix(in srgb, var(--cl-primary), transparent 88%);
}
.security-awareness-actions__button--primary,
.security-awareness-actions__button--continue {
  min-width: 13rem;
}
.security-awareness-actions__button--secondary {
  box-shadow: none;
}
.security-awareness-methods {
  display: grid;
  gap: 1rem;
  width: 100%;
}
.security-awareness-method-card {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 1rem;
  padding: 1rem 1rem 1.15rem;
  border: 1px solid color-mix(in srgb, var(--cl-settings-panel-border), white 24%);
  border-radius: 1.35rem;
  background:
    radial-gradient(
      circle at top center,
      color-mix(in srgb, var(--cl-primary), transparent 94%) 0,
      transparent 40%),
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 10%),
      color-mix(in srgb, var(--cl-primary-light), white 44%));
  color: inherit;
  text-align: center;
  transition:
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}
.security-awareness-method-card--selected {
  border-color: color-mix(in srgb, var(--cl-primary), transparent 34%);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cl-primary), transparent 88%), 0 18px 34px color-mix(in srgb, var(--cl-primary), transparent 86%);
}
.security-awareness-method-card--disabled {
  opacity: 0.62;
  box-shadow: none;
  cursor: not-allowed;
}
.security-awareness-method-card__badge {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.6rem;
  padding: 0.2rem 0.7rem;
  border-radius: 999rem;
  background: color-mix(in srgb, var(--cl-success), white 18%);
  color: var(--cl-text-on-primary);
  font-size: 0.74rem;
  font-weight: 700;
}
.security-awareness-method-card__copy {
  display: grid;
  gap: 0.3rem;
}
.security-awareness-method-card__copy strong {
  color: var(--cl-settings-title);
  font-size: 1.05rem;
}
.security-awareness-method-card__copy p {
  margin: 0;
  color: var(--cl-settings-copy-muted);
  font-size: 0.98rem;
  line-height: 1.45;
}
.security-awareness-method-figure {
  position: relative;
  display: grid;
  place-items: center;
  width: 100%;
  min-height: 9rem;
}
.security-awareness-method-figure__halo {
  position: absolute;
  inset: 0.65rem 0.3rem 0.35rem;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at center,
      color-mix(in srgb, var(--cl-primary), white 86%) 0,
      color-mix(in srgb, var(--cl-primary), white 96%) 44%,
      transparent 72%);
}
.security-awareness-method-figure__device {
  position: relative;
  z-index: 1;
  width: 4.4rem;
  height: 6.25rem;
  border-radius: 1rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary), white 18%),
      color-mix(in srgb, var(--cl-primary), black 8%));
}
.security-awareness-method-figure__device::before {
  content: "";
  position: absolute;
  inset: 0.35rem;
  border-radius: 0.78rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 8%),
      color-mix(in srgb, var(--cl-primary-light), white 24%));
}
.security-awareness-method-figure__device--compact {
  width: 3.65rem;
  height: 5.6rem;
}
.security-awareness-method-figure__device-notch {
  position: absolute;
  top: 0.45rem;
  left: 50%;
  z-index: 1;
  width: 1.2rem;
  height: 0.22rem;
  border-radius: 999rem;
  transform: translateX(-50%);
  background: color-mix(in srgb, var(--cl-primary), black 22%);
}
.security-awareness-method-figure__shield,
.security-awareness-method-figure__mini-shield {
  position: absolute;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 3.45rem;
  height: 3.8rem;
  clip-path: polygon(50% 0%, 86% 14%, 86% 53%, 50% 100%, 14% 53%, 14% 14%);
  border-radius: 0.9rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary), white 22%),
      color-mix(in srgb, var(--cl-primary), black 12%));
  box-shadow: 0 16px 26px color-mix(in srgb, var(--cl-primary), transparent 78%);
}
.security-awareness-method-figure__shield {
  bottom: 1.1rem;
}
.security-awareness-method-figure__mini-shield {
  width: 2.15rem;
  height: 2.4rem;
  right: 2.15rem;
  bottom: 1.3rem;
}
.security-awareness-method-figure__shield-icon {
  width: 1rem;
  height: 1rem;
  color: color-mix(in srgb, var(--cl-warning), white 8%);
}
.security-awareness-method-figure__envelope {
  position: relative;
  z-index: 1;
  width: 5.2rem;
  height: 3.8rem;
  border-radius: 0.95rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-primary), white 16%),
      color-mix(in srgb, var(--cl-primary), black 2%));
  overflow: hidden;
  box-shadow: 0 16px 28px color-mix(in srgb, var(--cl-primary), transparent 82%);
}
.security-awareness-method-figure__envelope::before,
.security-awareness-method-figure__envelope::after,
.security-awareness-method-figure__envelope-flap {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, white, transparent 10%),
      color-mix(in srgb, var(--cl-primary-light), white 8%));
}
.security-awareness-method-figure__envelope::before {
  clip-path: polygon(0 0, 50% 58%, 100% 0, 100% 100%, 0 100%);
}
.security-awareness-method-figure__envelope::after {
  clip-path: polygon(0 100%, 50% 42%, 100% 100%);
}
.security-awareness-method-figure__envelope-flap {
  clip-path: polygon(0 0, 50% 58%, 100% 0);
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 4%),
      color-mix(in srgb, var(--cl-primary-light), white 24%));
}
.security-awareness-method-figure__bubble {
  position: absolute;
  top: 1.2rem;
  right: 1.6rem;
  z-index: 2;
  padding: 0.38rem 0.7rem;
  border: 1px solid color-mix(in srgb, var(--cl-warning), transparent 54%);
  border-radius: 0.85rem;
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--cl-bg-card), white 2%),
      color-mix(in srgb, var(--cl-warning-light), white 12%));
  color: color-mix(in srgb, var(--cl-primary), black 12%);
  font-size: 0.96rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 14px 24px color-mix(in srgb, var(--cl-primary), transparent 88%);
}
@keyframes settings-pulse {
  0%, 100% {
    opacity: 0.5;
    transform: scale(0.9);
  }
  50% {
    opacity: 1;
    transform: scale(1);
  }
}
@media (min-width: 767.98px) {
  .settings-page {
    padding: 1.5rem;
  }
  .settings-toolbar {
    padding: 1.15rem 1.25rem;
  }
  .settings-tabs {
    grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
  }
  .settings-card__header,
  .profile-form__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .settings-card__header .settings-btn {
    width: auto;
    min-width: 10rem;
    justify-self: end;
  }
  .profile-layout {
    grid-template-columns: minmax(15rem, 18rem) minmax(0, 1fr);
    align-items: start;
  }
}
@media (min-width: 991.98px) {
  .settings-toolbar {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
  }
  .settings-toolbar__meta {
    justify-content: flex-end;
  }
  app-settings-navigation {
    grid-column: 1/-1;
  }
}
@media (min-width: 767.98px) {
  .security-account-card__header {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
  .security-account-card__actions {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
  }
  .security-account-card__button {
    width: auto;
    min-width: 14rem;
  }
  .security-hero-card {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .security-toggle-card {
    grid-column: 1/-1;
  }
  .security-benefits__grid,
  .security-modal__summary-grid,
  .security-modal__meta-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .security-modal__intro {
    grid-template-columns: auto minmax(0, 1fr);
  }
  .security-modal__stage--two-up,
  .security-modal__setup-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }
  .security-modal__qr-layout {
    grid-template-columns: minmax(18rem, 19.5rem) minmax(0, 1fr);
  }
  .security-awareness-methods {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (min-width: 991.98px) {
  .security-hero-card {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
  .security-toggle-card {
    grid-column: auto;
    min-width: 15rem;
    align-self: stretch;
  }
  .security-benefits__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 767.98px) {
  .security-awareness-screen__headline {
    flex-direction: column;
  }
  .security-awareness-actions__button {
    width: 100%;
  }
  .security-code-entry__slots {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
  .security-code-entry__slot {
    width: 100%;
    height: 2.8rem;
  }
}
.color-blue-50 {
  color: var(--color-blue-50) !important;
}
.bg-blue-50 {
  background-color: var(--color-blue-50) !important;
}
.color-blue-100 {
  color: var(--color-blue-100) !important;
}
.bg-blue-100 {
  background-color: var(--color-blue-100) !important;
}
.color-blue-200 {
  color: var(--color-blue-200) !important;
}
.bg-blue-200 {
  background-color: var(--color-blue-200) !important;
}
.color-blue-300 {
  color: var(--color-blue-300) !important;
}
.bg-blue-300 {
  background-color: var(--color-blue-300) !important;
}
.color-blue-400 {
  color: var(--color-blue-400) !important;
}
.bg-blue-400 {
  background-color: var(--color-blue-400) !important;
}
.color-blue-500 {
  color: var(--color-blue-500) !important;
}
.bg-blue-500 {
  background-color: var(--color-blue-500) !important;
}
.color-blue-600 {
  color: var(--color-blue-600) !important;
}
.bg-blue-600 {
  background-color: var(--color-blue-600) !important;
}
.color-blue-700 {
  color: var(--color-blue-700) !important;
}
.bg-blue-700 {
  background-color: var(--color-blue-700) !important;
}
.color-blue-800 {
  color: var(--color-blue-800) !important;
}
.bg-blue-800 {
  background-color: var(--color-blue-800) !important;
}
.color-blue-900 {
  color: var(--color-blue-900) !important;
}
.bg-blue-900 {
  background-color: var(--color-blue-900) !important;
}
.color-blue-950 {
  color: var(--color-blue-950) !important;
}
.bg-blue-950 {
  background-color: var(--color-blue-950) !important;
}
.color-indigo-50 {
  color: var(--color-indigo-50) !important;
}
.bg-indigo-50 {
  background-color: var(--color-indigo-50) !important;
}
.color-indigo-100 {
  color: var(--color-indigo-100) !important;
}
.bg-indigo-100 {
  background-color: var(--color-indigo-100) !important;
}
.color-indigo-200 {
  color: var(--color-indigo-200) !important;
}
.bg-indigo-200 {
  background-color: var(--color-indigo-200) !important;
}
.color-indigo-300 {
  color: var(--color-indigo-300) !important;
}
.bg-indigo-300 {
  background-color: var(--color-indigo-300) !important;
}
.color-indigo-400 {
  color: var(--color-indigo-400) !important;
}
.bg-indigo-400 {
  background-color: var(--color-indigo-400) !important;
}
.color-indigo-500 {
  color: var(--color-indigo-500) !important;
}
.bg-indigo-500 {
  background-color: var(--color-indigo-500) !important;
}
.color-indigo-600 {
  color: var(--color-indigo-600) !important;
}
.bg-indigo-600 {
  background-color: var(--color-indigo-600) !important;
}
.color-indigo-700 {
  color: var(--color-indigo-700) !important;
}
.bg-indigo-700 {
  background-color: var(--color-indigo-700) !important;
}
.color-indigo-800 {
  color: var(--color-indigo-800) !important;
}
.bg-indigo-800 {
  background-color: var(--color-indigo-800) !important;
}
.color-indigo-900 {
  color: var(--color-indigo-900) !important;
}
.bg-indigo-900 {
  background-color: var(--color-indigo-900) !important;
}
.color-indigo-950 {
  color: var(--color-indigo-950) !important;
}
.bg-indigo-950 {
  background-color: var(--color-indigo-950) !important;
}
.color-gray-50 {
  color: var(--color-gray-50) !important;
}
.bg-gray-50 {
  background-color: var(--color-gray-50) !important;
}
.color-gray-100 {
  color: var(--color-gray-100) !important;
}
.bg-gray-100 {
  background-color: var(--color-gray-100) !important;
}
.color-gray-200 {
  color: var(--color-gray-200) !important;
}
.bg-gray-200 {
  background-color: var(--color-gray-200) !important;
}
.color-gray-300 {
  color: var(--color-gray-300) !important;
}
.bg-gray-300 {
  background-color: var(--color-gray-300) !important;
}
.color-gray-400 {
  color: var(--color-gray-400) !important;
}
.bg-gray-400 {
  background-color: var(--color-gray-400) !important;
}
.color-gray-500 {
  color: var(--color-gray-500) !important;
}
.bg-gray-500 {
  background-color: var(--color-gray-500) !important;
}
.color-gray-600 {
  color: var(--color-gray-600) !important;
}
.bg-gray-600 {
  background-color: var(--color-gray-600) !important;
}
.color-gray-700 {
  color: var(--color-gray-700) !important;
}
.bg-gray-700 {
  background-color: var(--color-gray-700) !important;
}
.color-gray-800 {
  color: var(--color-gray-800) !important;
}
.bg-gray-800 {
  background-color: var(--color-gray-800) !important;
}
.color-gray-900 {
  color: var(--color-gray-900) !important;
}
.bg-gray-900 {
  background-color: var(--color-gray-900) !important;
}
.color-gray-950 {
  color: var(--color-gray-950) !important;
}
.bg-gray-950 {
  background-color: var(--color-gray-950) !important;
}
.color-green-50 {
  color: var(--color-green-50) !important;
}
.bg-green-50 {
  background-color: var(--color-green-50) !important;
}
.color-green-100 {
  color: var(--color-green-100) !important;
}
.bg-green-100 {
  background-color: var(--color-green-100) !important;
}
.color-green-200 {
  color: var(--color-green-200) !important;
}
.bg-green-200 {
  background-color: var(--color-green-200) !important;
}
.color-green-300 {
  color: var(--color-green-300) !important;
}
.bg-green-300 {
  background-color: var(--color-green-300) !important;
}
.color-green-400 {
  color: var(--color-green-400) !important;
}
.bg-green-400 {
  background-color: var(--color-green-400) !important;
}
.color-green-500 {
  color: var(--color-green-500) !important;
}
.bg-green-500 {
  background-color: var(--color-green-500) !important;
}
.color-green-600 {
  color: var(--color-green-600) !important;
}
.bg-green-600 {
  background-color: var(--color-green-600) !important;
}
.color-green-700 {
  color: var(--color-green-700) !important;
}
.bg-green-700 {
  background-color: var(--color-green-700) !important;
}
.color-green-800 {
  color: var(--color-green-800) !important;
}
.bg-green-800 {
  background-color: var(--color-green-800) !important;
}
.color-green-900 {
  color: var(--color-green-900) !important;
}
.bg-green-900 {
  background-color: var(--color-green-900) !important;
}
.color-green-950 {
  color: var(--color-green-950) !important;
}
.bg-green-950 {
  background-color: var(--color-green-950) !important;
}
.color-red-50 {
  color: var(--color-red-50) !important;
}
.bg-red-50 {
  background-color: var(--color-red-50) !important;
}
.color-red-100 {
  color: var(--color-red-100) !important;
}
.bg-red-100 {
  background-color: var(--color-red-100) !important;
}
.color-red-200 {
  color: var(--color-red-200) !important;
}
.bg-red-200 {
  background-color: var(--color-red-200) !important;
}
.color-red-300 {
  color: var(--color-red-300) !important;
}
.bg-red-300 {
  background-color: var(--color-red-300) !important;
}
.color-red-400 {
  color: var(--color-red-400) !important;
}
.bg-red-400 {
  background-color: var(--color-red-400) !important;
}
.color-red-500 {
  color: var(--color-red-500) !important;
}
.bg-red-500 {
  background-color: var(--color-red-500) !important;
}
.color-red-600 {
  color: var(--color-red-600) !important;
}
.bg-red-600 {
  background-color: var(--color-red-600) !important;
}
.color-red-700 {
  color: var(--color-red-700) !important;
}
.bg-red-700 {
  background-color: var(--color-red-700) !important;
}
.color-red-800 {
  color: var(--color-red-800) !important;
}
.bg-red-800 {
  background-color: var(--color-red-800) !important;
}
.color-red-900 {
  color: var(--color-red-900) !important;
}
.bg-red-900 {
  background-color: var(--color-red-900) !important;
}
.color-red-950 {
  color: var(--color-red-950) !important;
}
.bg-red-950 {
  background-color: var(--color-red-950) !important;
}
.color-yellow-50 {
  color: var(--color-yellow-50) !important;
}
.bg-yellow-50 {
  background-color: var(--color-yellow-50) !important;
}
.color-yellow-100 {
  color: var(--color-yellow-100) !important;
}
.bg-yellow-100 {
  background-color: var(--color-yellow-100) !important;
}
.color-yellow-200 {
  color: var(--color-yellow-200) !important;
}
.bg-yellow-200 {
  background-color: var(--color-yellow-200) !important;
}
.color-yellow-300 {
  color: var(--color-yellow-300) !important;
}
.bg-yellow-300 {
  background-color: var(--color-yellow-300) !important;
}
.color-yellow-400 {
  color: var(--color-yellow-400) !important;
}
.bg-yellow-400 {
  background-color: var(--color-yellow-400) !important;
}
.color-yellow-500 {
  color: var(--color-yellow-500) !important;
}
.bg-yellow-500 {
  background-color: var(--color-yellow-500) !important;
}
.color-yellow-600 {
  color: var(--color-yellow-600) !important;
}
.bg-yellow-600 {
  background-color: var(--color-yellow-600) !important;
}
.color-yellow-700 {
  color: var(--color-yellow-700) !important;
}
.bg-yellow-700 {
  background-color: var(--color-yellow-700) !important;
}
.color-yellow-800 {
  color: var(--color-yellow-800) !important;
}
.bg-yellow-800 {
  background-color: var(--color-yellow-800) !important;
}
.color-yellow-900 {
  color: var(--color-yellow-900) !important;
}
.bg-yellow-900 {
  background-color: var(--color-yellow-900) !important;
}
.color-yellow-950 {
  color: var(--color-yellow-950) !important;
}
.bg-yellow-950 {
  background-color: var(--color-yellow-950) !important;
}
.color-orange-50 {
  color: var(--color-orange-50) !important;
}
.bg-orange-50 {
  background-color: var(--color-orange-50) !important;
}
.color-orange-100 {
  color: var(--color-orange-100) !important;
}
.bg-orange-100 {
  background-color: var(--color-orange-100) !important;
}
.color-orange-200 {
  color: var(--color-orange-200) !important;
}
.bg-orange-200 {
  background-color: var(--color-orange-200) !important;
}
.color-orange-300 {
  color: var(--color-orange-300) !important;
}
.bg-orange-300 {
  background-color: var(--color-orange-300) !important;
}
.color-orange-400 {
  color: var(--color-orange-400) !important;
}
.bg-orange-400 {
  background-color: var(--color-orange-400) !important;
}
.color-orange-500 {
  color: var(--color-orange-500) !important;
}
.bg-orange-500 {
  background-color: var(--color-orange-500) !important;
}
.color-orange-600 {
  color: var(--color-orange-600) !important;
}
.bg-orange-600 {
  background-color: var(--color-orange-600) !important;
}
.color-orange-700 {
  color: var(--color-orange-700) !important;
}
.bg-orange-700 {
  background-color: var(--color-orange-700) !important;
}
.color-orange-800 {
  color: var(--color-orange-800) !important;
}
.bg-orange-800 {
  background-color: var(--color-orange-800) !important;
}
.color-orange-900 {
  color: var(--color-orange-900) !important;
}
.bg-orange-900 {
  background-color: var(--color-orange-900) !important;
}
.color-orange-950 {
  color: var(--color-orange-950) !important;
}
.bg-orange-950 {
  background-color: var(--color-orange-950) !important;
}
.color-teal-50 {
  color: var(--color-teal-50) !important;
}
.bg-teal-50 {
  background-color: var(--color-teal-50) !important;
}
.color-teal-100 {
  color: var(--color-teal-100) !important;
}
.bg-teal-100 {
  background-color: var(--color-teal-100) !important;
}
.color-teal-200 {
  color: var(--color-teal-200) !important;
}
.bg-teal-200 {
  background-color: var(--color-teal-200) !important;
}
.color-teal-300 {
  color: var(--color-teal-300) !important;
}
.bg-teal-300 {
  background-color: var(--color-teal-300) !important;
}
.color-teal-400 {
  color: var(--color-teal-400) !important;
}
.bg-teal-400 {
  background-color: var(--color-teal-400) !important;
}
.color-teal-500 {
  color: var(--color-teal-500) !important;
}
.bg-teal-500 {
  background-color: var(--color-teal-500) !important;
}
.color-teal-600 {
  color: var(--color-teal-600) !important;
}
.bg-teal-600 {
  background-color: var(--color-teal-600) !important;
}
.color-teal-700 {
  color: var(--color-teal-700) !important;
}
.bg-teal-700 {
  background-color: var(--color-teal-700) !important;
}
.color-teal-800 {
  color: var(--color-teal-800) !important;
}
.bg-teal-800 {
  background-color: var(--color-teal-800) !important;
}
.color-teal-900 {
  color: var(--color-teal-900) !important;
}
.bg-teal-900 {
  background-color: var(--color-teal-900) !important;
}
.color-teal-950 {
  color: var(--color-teal-950) !important;
}
.bg-teal-950 {
  background-color: var(--color-teal-950) !important;
}
.color-lime-50 {
  color: var(--color-lime-50) !important;
}
.bg-lime-50 {
  background-color: var(--color-lime-50) !important;
}
.color-lime-100 {
  color: var(--color-lime-100) !important;
}
.bg-lime-100 {
  background-color: var(--color-lime-100) !important;
}
.color-lime-200 {
  color: var(--color-lime-200) !important;
}
.bg-lime-200 {
  background-color: var(--color-lime-200) !important;
}
.color-lime-300 {
  color: var(--color-lime-300) !important;
}
.bg-lime-300 {
  background-color: var(--color-lime-300) !important;
}
.color-lime-400 {
  color: var(--color-lime-400) !important;
}
.bg-lime-400 {
  background-color: var(--color-lime-400) !important;
}
.color-lime-500 {
  color: var(--color-lime-500) !important;
}
.bg-lime-500 {
  background-color: var(--color-lime-500) !important;
}
.color-lime-600 {
  color: var(--color-lime-600) !important;
}
.bg-lime-600 {
  background-color: var(--color-lime-600) !important;
}
.color-lime-700 {
  color: var(--color-lime-700) !important;
}
.bg-lime-700 {
  background-color: var(--color-lime-700) !important;
}
.color-lime-800 {
  color: var(--color-lime-800) !important;
}
.bg-lime-800 {
  background-color: var(--color-lime-800) !important;
}
.color-lime-900 {
  color: var(--color-lime-900) !important;
}
.bg-lime-900 {
  background-color: var(--color-lime-900) !important;
}
.color-lime-950 {
  color: var(--color-lime-950) !important;
}
.bg-lime-950 {
  background-color: var(--color-lime-950) !important;
}
.color-purple-50 {
  color: var(--color-purple-50) !important;
}
.bg-purple-50 {
  background-color: var(--color-purple-50) !important;
}
.color-purple-100 {
  color: var(--color-purple-100) !important;
}
.bg-purple-100 {
  background-color: var(--color-purple-100) !important;
}
.color-purple-200 {
  color: var(--color-purple-200) !important;
}
.bg-purple-200 {
  background-color: var(--color-purple-200) !important;
}
.color-purple-300 {
  color: var(--color-purple-300) !important;
}
.bg-purple-300 {
  background-color: var(--color-purple-300) !important;
}
.color-purple-400 {
  color: var(--color-purple-400) !important;
}
.bg-purple-400 {
  background-color: var(--color-purple-400) !important;
}
.color-purple-500 {
  color: var(--color-purple-500) !important;
}
.bg-purple-500 {
  background-color: var(--color-purple-500) !important;
}
.color-purple-600 {
  color: var(--color-purple-600) !important;
}
.bg-purple-600 {
  background-color: var(--color-purple-600) !important;
}
.color-purple-700 {
  color: var(--color-purple-700) !important;
}
.bg-purple-700 {
  background-color: var(--color-purple-700) !important;
}
.color-purple-800 {
  color: var(--color-purple-800) !important;
}
.bg-purple-800 {
  background-color: var(--color-purple-800) !important;
}
.color-purple-900 {
  color: var(--color-purple-900) !important;
}
.bg-purple-900 {
  background-color: var(--color-purple-900) !important;
}
.color-purple-950 {
  color: var(--color-purple-950) !important;
}
.bg-purple-950 {
  background-color: var(--color-purple-950) !important;
}
.text-primary {
  color: var(--cl-primary) !important;
}
.text-secondary {
  color: var(--cl-text-secondary) !important;
}
.text-muted {
  color: var(--cl-text-muted) !important;
}
.text-success {
  color: var(--cl-success) !important;
}
.text-danger {
  color: var(--cl-danger) !important;
}
.text-warning {
  color: var(--cl-warning) !important;
}
.text-info {
  color: var(--cl-info) !important;
}
.text-body {
  color: var(--cl-text) !important;
}
.text-inverse {
  color: var(--cl-text-inverse) !important;
}
.text-white {
  color: #fff !important;
}
.bg-primary {
  background-color: var(--cl-primary) !important;
}
.bg-primary-light {
  background-color: var(--cl-primary-light) !important;
}
.bg-body {
  background-color: var(--cl-bg) !important;
}
.bg-card {
  background-color: var(--cl-bg-card) !important;
}
.bg-muted {
  background-color: var(--cl-bg-muted) !important;
}
.bg-subtle {
  background-color: var(--cl-bg-subtle) !important;
}
.bg-success {
  background-color: var(--cl-success) !important;
}
.bg-danger {
  background-color: var(--cl-danger) !important;
}
.bg-warning {
  background-color: var(--cl-warning) !important;
}
.bg-info {
  background-color: var(--cl-info) !important;
}
.bg-success-light {
  background-color: var(--cl-success-light) !important;
}
.bg-danger-light {
  background-color: var(--cl-danger-light) !important;
}
.bg-warning-light {
  background-color: var(--cl-warning-light) !important;
}
.bg-info-light {
  background-color: var(--cl-info-light) !important;
}
.bg-transparent {
  background-color: transparent !important;
}
.border-theme {
  border-color: var(--cl-border) !important;
}
.border-theme-light {
  border-color: var(--cl-border-light) !important;
}
.border-primary {
  border-color: var(--cl-primary) !important;
}
.border-0 {
  border: 0 !important;
}
.border {
  border: 1px solid var(--cl-border) !important;
}
.border-top {
  border-top: 1px solid var(--cl-border) !important;
}
.border-bottom {
  border-bottom: 1px solid var(--cl-border) !important;
}
.shadow-xs {
  box-shadow: var(--cl-shadow-xs) !important;
}
.shadow-sm {
  box-shadow: var(--cl-shadow-sm) !important;
}
.shadow {
  box-shadow: var(--cl-shadow) !important;
}
.shadow-md {
  box-shadow: var(--cl-shadow-md) !important;
}
.shadow-lg {
  box-shadow: var(--cl-shadow-lg) !important;
}
.shadow-none {
  box-shadow: none !important;
}
.rounded {
  border-radius: var(--radius) !important;
}
.rounded-sm {
  border-radius: var(--radius-sm) !important;
}
.rounded-md {
  border-radius: var(--radius-md) !important;
}
.rounded-lg {
  border-radius: var(--radius-lg) !important;
}
.rounded-pill {
  border-radius: var(--radius-pill) !important;
}
.rounded-circle {
  border-radius: 50% !important;
}
.fw-light {
  font-weight: var(--fw-light) !important;
}
.fw-regular {
  font-weight: var(--fw-regular) !important;
}
.fw-medium {
  font-weight: var(--fw-medium) !important;
}
.fw-semibold {
  font-weight: var(--fw-semibold) !important;
}
.fw-bold {
  font-weight: var(--fw-bold) !important;
}
.d-none {
  display: none !important;
}
.d-block {
  display: block !important;
}
.d-inline {
  display: inline !important;
}
.d-inline-block {
  display: inline-block !important;
}
.d-flex {
  display: flex !important;
}
.d-inline-flex {
  display: inline-flex !important;
}
.d-grid {
  display: grid !important;
}
@media (min-width: 768px) {
  .d-md-none {
    display: none !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-flex {
    display: flex !important;
  }
}
@media (min-width: 992px) {
  .d-lg-none {
    display: none !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
}
.flex-row {
  flex-direction: row !important;
}
.flex-column {
  flex-direction: column !important;
}
.flex-wrap {
  flex-wrap: wrap !important;
}
.flex-nowrap {
  flex-wrap: nowrap !important;
}
.flex-grow-1 {
  flex-grow: 1 !important;
}
.flex-shrink-0 {
  flex-shrink: 0 !important;
}
.flex-fill {
  flex: 1 1 auto !important;
}
.justify-content-start {
  justify-content: flex-start !important;
}
.justify-content-end {
  justify-content: flex-end !important;
}
.justify-content-center {
  justify-content: center !important;
}
.justify-content-between {
  justify-content: space-between !important;
}
.justify-content-around {
  justify-content: space-around !important;
}
.align-items-start {
  align-items: flex-start !important;
}
.align-items-end {
  align-items: flex-end !important;
}
.align-items-center {
  align-items: center !important;
}
.align-items-stretch {
  align-items: stretch !important;
}
.align-self-start {
  align-self: flex-start !important;
}
.align-self-center {
  align-self: center !important;
}
.gap-0 {
  gap: 0 !important;
}
.gap-1 {
  gap: var(--space-1) !important;
}
.gap-2 {
  gap: var(--space-2) !important;
}
.gap-3 {
  gap: var(--space-3) !important;
}
.gap-4 {
  gap: var(--space-4) !important;
}
.gap-5 {
  gap: var(--space-5) !important;
}
.gap-6 {
  gap: var(--space-6) !important;
}
.m-0 {
  margin: 0 !important;
}
.mt-0 {
  margin-top: 0 !important;
}
.mb-0 {
  margin-bottom: 0 !important;
}
.ms-0 {
  margin-inline-start: 0 !important;
}
.me-0 {
  margin-inline-end: 0 !important;
}
.mx-0 {
  margin-inline: 0 !important;
}
.my-0 {
  margin-block: 0 !important;
}
.m-1 {
  margin: var(--space-1) !important;
}
.mt-1 {
  margin-top: var(--space-1) !important;
}
.mb-1 {
  margin-bottom: var(--space-1) !important;
}
.ms-1 {
  margin-inline-start: var(--space-1) !important;
}
.me-1 {
  margin-inline-end: var(--space-1) !important;
}
.mx-1 {
  margin-inline: var(--space-1) !important;
}
.my-1 {
  margin-block: var(--space-1) !important;
}
.m-2 {
  margin: var(--space-2) !important;
}
.mt-2 {
  margin-top: var(--space-2) !important;
}
.mb-2 {
  margin-bottom: var(--space-2) !important;
}
.ms-2 {
  margin-inline-start: var(--space-2) !important;
}
.me-2 {
  margin-inline-end: var(--space-2) !important;
}
.mx-2 {
  margin-inline: var(--space-2) !important;
}
.my-2 {
  margin-block: var(--space-2) !important;
}
.m-3 {
  margin: var(--space-3) !important;
}
.mt-3 {
  margin-top: var(--space-3) !important;
}
.mb-3 {
  margin-bottom: var(--space-3) !important;
}
.ms-3 {
  margin-inline-start: var(--space-3) !important;
}
.me-3 {
  margin-inline-end: var(--space-3) !important;
}
.mx-3 {
  margin-inline: var(--space-3) !important;
}
.my-3 {
  margin-block: var(--space-3) !important;
}
.m-4 {
  margin: var(--space-4) !important;
}
.mt-4 {
  margin-top: var(--space-4) !important;
}
.mb-4 {
  margin-bottom: var(--space-4) !important;
}
.ms-4 {
  margin-inline-start: var(--space-4) !important;
}
.me-4 {
  margin-inline-end: var(--space-4) !important;
}
.mx-4 {
  margin-inline: var(--space-4) !important;
}
.my-4 {
  margin-block: var(--space-4) !important;
}
.m-5 {
  margin: var(--space-5) !important;
}
.mt-5 {
  margin-top: var(--space-5) !important;
}
.mb-5 {
  margin-bottom: var(--space-5) !important;
}
.ms-5 {
  margin-inline-start: var(--space-5) !important;
}
.me-5 {
  margin-inline-end: var(--space-5) !important;
}
.mx-5 {
  margin-inline: var(--space-5) !important;
}
.my-5 {
  margin-block: var(--space-5) !important;
}
.ms-auto {
  margin-inline-start: auto !important;
}
.me-auto {
  margin-inline-end: auto !important;
}
.mx-auto {
  margin-inline: auto !important;
}
.p-0 {
  padding: 0 !important;
}
.pt-0 {
  padding-top: 0 !important;
}
.pb-0 {
  padding-bottom: 0 !important;
}
.ps-0 {
  padding-inline-start: 0 !important;
}
.pe-0 {
  padding-inline-end: 0 !important;
}
.px-0 {
  padding-inline: 0 !important;
}
.py-0 {
  padding-block: 0 !important;
}
.p-1 {
  padding: var(--space-1) !important;
}
.pt-1 {
  padding-top: var(--space-1) !important;
}
.pb-1 {
  padding-bottom: var(--space-1) !important;
}
.ps-1 {
  padding-inline-start: var(--space-1) !important;
}
.pe-1 {
  padding-inline-end: var(--space-1) !important;
}
.px-1 {
  padding-inline: var(--space-1) !important;
}
.py-1 {
  padding-block: var(--space-1) !important;
}
.p-2 {
  padding: var(--space-2) !important;
}
.pt-2 {
  padding-top: var(--space-2) !important;
}
.pb-2 {
  padding-bottom: var(--space-2) !important;
}
.ps-2 {
  padding-inline-start: var(--space-2) !important;
}
.pe-2 {
  padding-inline-end: var(--space-2) !important;
}
.px-2 {
  padding-inline: var(--space-2) !important;
}
.py-2 {
  padding-block: var(--space-2) !important;
}
.p-3 {
  padding: var(--space-3) !important;
}
.pt-3 {
  padding-top: var(--space-3) !important;
}
.pb-3 {
  padding-bottom: var(--space-3) !important;
}
.ps-3 {
  padding-inline-start: var(--space-3) !important;
}
.pe-3 {
  padding-inline-end: var(--space-3) !important;
}
.px-3 {
  padding-inline: var(--space-3) !important;
}
.py-3 {
  padding-block: var(--space-3) !important;
}
.p-4 {
  padding: var(--space-4) !important;
}
.pt-4 {
  padding-top: var(--space-4) !important;
}
.pb-4 {
  padding-bottom: var(--space-4) !important;
}
.ps-4 {
  padding-inline-start: var(--space-4) !important;
}
.pe-4 {
  padding-inline-end: var(--space-4) !important;
}
.px-4 {
  padding-inline: var(--space-4) !important;
}
.py-4 {
  padding-block: var(--space-4) !important;
}
.p-5 {
  padding: var(--space-5) !important;
}
.pt-5 {
  padding-top: var(--space-5) !important;
}
.pb-5 {
  padding-bottom: var(--space-5) !important;
}
.ps-5 {
  padding-inline-start: var(--space-5) !important;
}
.pe-5 {
  padding-inline-end: var(--space-5) !important;
}
.px-5 {
  padding-inline: var(--space-5) !important;
}
.py-5 {
  padding-block: var(--space-5) !important;
}
.text-center {
  text-align: center !important;
}
.text-start {
  text-align: left !important;
}
.text-end {
  text-align: right !important;
}
.text-nowrap {
  white-space: nowrap !important;
}
.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.text-break {
  word-wrap: break-word !important;
  word-break: break-word !important;
}
.text-uppercase {
  text-transform: uppercase !important;
}
.text-lowercase {
  text-transform: lowercase !important;
}
.text-capitalize {
  text-transform: capitalize !important;
}
.text-decoration-none {
  text-decoration: none !important;
}
.w-25 {
  width: 25% !important;
}
.w-50 {
  width: 50% !important;
}
.w-75 {
  width: 75% !important;
}
.w-100 {
  width: 100% !important;
}
.w-auto {
  width: auto !important;
}
.h-100 {
  height: 100% !important;
}
.h-auto {
  height: auto !important;
}
.mw-100 {
  max-width: 100% !important;
}
.mh-100 {
  max-height: 100% !important;
}
.min-vw-100 {
  min-width: 100vw !important;
}
.min-vh-100 {
  min-height: 100vh !important;
}
.position-static {
  position: static !important;
}
.position-relative {
  position: relative !important;
}
.position-absolute {
  position: absolute !important;
}
.position-fixed {
  position: fixed !important;
}
.position-sticky {
  position: sticky !important;
}
.top-0 {
  top: 0 !important;
}
.end-0 {
  right: 0 !important;
}
.bottom-0 {
  bottom: 0 !important;
}
.start-0 {
  left: 0 !important;
}
.overflow-auto {
  overflow: auto !important;
}
.overflow-hidden {
  overflow: hidden !important;
}
.overflow-visible {
  overflow: visible !important;
}
.overflow-x-auto {
  overflow-x: auto !important;
}
.overflow-y-auto {
  overflow-y: auto !important;
}
.visually-hidden,
.sr-only {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.highlight-yellow {
  background-color: var(--cl-highlight-yellow);
  padding: 0.1rem 0.2rem;
  border-radius: 0.2rem;
}
.highlight-blue {
  background-color: var(--cl-highlight-blue);
  padding: 0.1rem 0.2rem;
  border-radius: 0.2rem;
}
.highlight-green {
  background-color: var(--cl-highlight-green);
  padding: 0.1rem 0.2rem;
  border-radius: 0.2rem;
}
.highlight-pink {
  background-color: var(--cl-highlight-pink);
  padding: 0.1rem 0.2rem;
  border-radius: 0.2rem;
}
@media print {
  .no-print {
    display: none !important;
  }
}
@media (min-width: 768px) {
  .desktop-hidden {
    display: none !important;
  }
}
@media (max-width: 767.98px) {
  .mobile-hidden {
    display: none !important;
  }
}
.cursor-pointer {
  cursor: pointer !important;
}
.user-select-none {
  -webkit-user-select: none !important;
  user-select: none !important;
}
.opacity-0 {
  opacity: 0 !important;
}
.opacity-50 {
  opacity: 0.5 !important;
}
.opacity-75 {
  opacity: 0.75 !important;
}
.opacity-100 {
  opacity: 1 !important;
}
.container {
  width: 100%;
  max-width: var(--max-width-content);
  margin-inline: auto;
  padding-inline: var(--space-4);
}
.container-fluid {
  width: 100%;
  padding-inline: var(--space-4);
}
.container-narrow {
  width: 100%;
  max-width: var(--max-width-narrow);
  margin-inline: auto;
  padding-inline: var(--space-4);
}
body {
  background-color: var(--cl-bg);
  color: var(--cl-text);
  transition: var(--transition);
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
}
a {
  color: var(--cl-link);
  text-decoration: none;
  transition: var(--transition);
}
a:hover {
  color: var(--cl-link-hover);
}
.login-container,
.register-container,
.reset-container {
  width: 100%;
  background: var(--cl-bg-card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--cl-border-light);
  box-shadow: var(--cl-shadow-lg);
  overflow: hidden;
  animation: authFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}
.login-header,
.register-header,
.reset-header {
  background: var(--cl-primary);
  color: var(--cl-text-on-primary);
  padding: 1.5rem 2rem;
  text-align: center;
  position: relative;
}
.login-header h2,
.login-header h3,
.register-header h2,
.register-header h3,
.reset-header h2,
.reset-header h3 {
  margin: 0;
  font-weight: var(--fw-bold);
  color: var(--cl-text-on-primary);
  letter-spacing: -0.01em;
}
.login-header h3,
.reset-header h3 {
  font-size: var(--fs-xl);
}
.register-header h3 {
  font-size: var(--fs-2xl);
}
.reset-header .back-to-login,
.register-header .login-link {
  position: absolute;
  left: 1.25rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--cl-text-on-primary);
  font-size: var(--fs-base);
  text-decoration: none;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--cl-text-on-primary), transparent 85%);
  transition: all 0.2s ease;
}
.reset-header .back-to-login:hover,
.register-header .login-link:hover {
  background: color-mix(in srgb, var(--cl-text-on-primary), transparent 75%);
}
.login-body,
.register-body,
.reset-body {
  padding: 2rem 2rem 1.5rem;
}
.register-icon,
.step-icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-lg);
  background: var(--cl-primary-light);
  color: var(--cl-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.25rem;
  font-size: 1.25rem;
}
.register-instructions,
.step-instructions {
  text-align: center;
  margin-bottom: 1.5rem;
  color: var(--cl-text-secondary);
  font-size: var(--fs-sm);
  line-height: 1.6;
}
.input-group-text {
  background: var(--cl-bg-card);
  border: 1px solid var(--cl-border-input);
  border-left: none;
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
  transition: border-color 0.2s ease;
}
.input-group > .form-control {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
  border-right: none;
}
.input-group > .form-control:focus {
  z-index: 3;
}
.input-group:focus-within .input-group-text {
  border-color: var(--cl-primary);
}
.password-toggle {
  cursor: pointer;
  background: var(--cl-bg-card);
  border-left: none;
  color: var(--cl-text-muted);
  display: flex;
  align-items: center;
  transition: color 0.2s ease;
}
.password-toggle:hover {
  color: var(--cl-primary);
}
.otp-input {
  text-align: center;
  font-size: var(--fs-2xl);
  font-weight: var(--fw-bold);
  letter-spacing: 0.6em;
  border: 2px solid var(--cl-border-input);
  border-radius: var(--radius);
  transition: all 0.2s ease;
  background: var(--cl-bg-input);
  color: var(--cl-text);
  padding: 0.875rem 1rem;
}
.otp-input:focus {
  border-color: var(--cl-primary);
  outline: none;
  box-shadow: 0 0 0 3px var(--cl-focus-ring);
}
.otp-timer {
  text-align: center;
  font-size: var(--fs-sm);
  color: var(--cl-text-muted);
  margin-bottom: 1rem;
  padding: 0.5rem 1rem;
  background: var(--cl-bg-muted);
  border-radius: var(--radius);
}
.otp-timer strong {
  color: var(--cl-primary);
  font-variant-numeric: tabular-nums;
}
.otp-timer.expired {
  color: var(--cl-danger);
  background: var(--cl-danger-light);
}
.otp-timer.expired strong {
  color: var(--cl-danger);
}
.btn-login,
.btn-register,
.btn-reset {
  background: var(--cl-primary);
  color: var(--cl-text-on-primary);
  border: none;
  padding: 0.875rem 1.5rem;
  font-weight: var(--fw-semibold);
  font-size: var(--fs-base);
  border-radius: var(--radius);
  transition: all 0.2s ease;
  width: 100%;
  cursor: pointer;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.btn-login:hover:not(:disabled),
.btn-register:hover:not(:disabled),
.btn-reset:hover:not(:disabled) {
  background: var(--cl-primary-hover);
  transform: translateY(-1px);
  box-shadow: var(--cl-shadow-sm);
  color: var(--cl-text-on-primary);
}
.btn-login:active:not(:disabled),
.btn-register:active:not(:disabled),
.btn-reset:active:not(:disabled) {
  transform: translateY(0);
  box-shadow: none;
}
.btn-login:disabled,
.btn-register:disabled,
.btn-reset:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}
.password-strength {
  height: 4px;
  background: var(--cl-bg-subtle);
  border-radius: 2px;
  margin-top: 0.5rem;
  overflow: hidden;
}
.password-strength-bar {
  height: 100%;
  width: 0;
  border-radius: 2px;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}
.password-strength-bar.weak {
  width: 40%;
  background:
    linear-gradient(
      90deg,
      var(--cl-danger),
      var(--color-orange-500));
}
.password-strength-bar.strong {
  width: 100%;
  background:
    linear-gradient(
      90deg,
      var(--cl-success),
      var(--color-teal-400));
}
.password-requirements {
  font-size: var(--fs-xs);
  color: var(--cl-text-muted);
  margin-top: 0.5rem;
}
.password-requirements ul {
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.25rem 0.75rem;
}
.password-requirements li {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  transition: color 0.2s ease;
}
.password-requirements li i {
  font-size: 0.6rem;
  width: 14px;
  text-align: center;
  color: var(--cl-text-muted);
  transition: color 0.2s ease;
}
.password-requirements li.met {
  color: var(--cl-success);
}
.password-requirements li.met i {
  color: var(--cl-success);
}
.terms-check {
  margin: 1.25rem 0;
}
.terms-check label {
  font-size: var(--fs-sm);
  color: var(--cl-text-secondary);
  margin-bottom: 0;
}
.terms-check a {
  color: var(--cl-primary);
  font-weight: var(--fw-semibold);
}
.terms-check a:hover {
  text-decoration: underline;
}
.social-login,
.social-register {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}
.social-btn {
  width: 44px;
  height: 44px;
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--cl-text-on-primary);
  font-size: var(--fs-base);
  transition: all 0.2s ease;
  text-decoration: none;
  border: none;
}
.social-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--cl-shadow-sm);
}
.social-btn.google {
  background: var(--color-google);
}
.social-btn.facebook {
  background: var(--color-facebook);
}
.social-btn.apple {
  background: var(--color-apple);
}
.divider {
  display: flex;
  align-items: center;
  margin: 1.25rem 0;
}
.divider::before,
.divider::after {
  content: "";
  flex: 1;
  border-bottom: 1px solid var(--cl-border-light);
}
.divider-text {
  padding: 0 0.75rem;
  color: var(--cl-text-muted);
  font-size: var(--fs-sm);
}
.login-footer {
  text-align: center;
  padding: 1rem 1.5rem;
  background: var(--cl-bg-muted);
  border-top: 1px solid var(--cl-border-light);
  font-size: var(--fs-sm);
}
.login-footer a {
  color: var(--cl-text-muted);
  font-weight: var(--fw-medium);
}
.login-footer a:hover {
  color: var(--cl-primary);
}
.countdown-timer {
  text-align: center;
  margin: 1rem 0;
  font-size: var(--fs-sm);
  color: var(--cl-text-muted);
}
.resend-link {
  text-align: center;
  margin-top: 0.75rem;
}
.resend-link a {
  color: var(--cl-primary);
  font-weight: var(--fw-semibold);
  cursor: pointer;
  font-size: var(--fs-sm);
}
.resend-link a:hover {
  text-decoration: underline;
}
.resend-link a.disabled {
  color: var(--cl-text-muted);
  pointer-events: none;
  cursor: default;
}
.step-content {
  animation: authFadeIn 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}
@keyframes authFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (max-width: 575.98px) {
  .login-body,
  .register-body,
  .reset-body {
    padding: 1.5rem 1.25rem 1.25rem;
  }
  .login-header,
  .register-header,
  .reset-header {
    padding: 1.25rem 1rem;
  }
  .register-header,
  .reset-header {
    padding-left: 3.5rem;
  }
  .password-requirements ul {
    grid-template-columns: 1fr;
  }
}

/* angular:styles/global:styles */
/*# sourceMappingURL=styles.css.map */
