/* ==========================================================================
   RevealCheaters Scanner Simulator Stylesheet
   Curated with rich modern aesthetics, micro-animations & glassmorphic layouts.
   ========================================================================== */

/* Scoped variables under the main container to avoid polluting theme styles */
.rc-scanner-container {
  --rc-primary: hsl(292, 79%, 19%);          /* Deep Violet #4A0A55 */
  --rc-primary-light: hsl(298, 45%, 52%);    /* Bright Pink #B350BB */
  --rc-accent: hsl(0, 100%, 61%);            /* Accent Red #FF3A3A */
  --rc-success: hsl(150, 84%, 37%);           /* Emerald #10b981 */
  
  /* Gradients */
  --rc-grad-primary: linear-gradient(135deg, var(--rc-primary), var(--rc-primary-light));
  --rc-grad-subtle: linear-gradient(180deg, hsl(240, 5%, 96%) 0%, hsl(0, 0%, 100%) 100%);
  --rc-grad-skeleton: linear-gradient(90deg, #e4e4e7 25%, #f4f4f5 50%, #e4e4e7 75%);

  /* Neutrals */
  --rc-zinc-50: hsl(240, 5%, 98%);
  --rc-zinc-100: hsl(240, 5%, 96%);
  --rc-zinc-200: hsl(240, 6%, 90%);
  --rc-zinc-300: hsl(240, 5%, 84%);
  --rc-zinc-400: hsl(240, 5%, 65%);
  --rc-zinc-500: hsl(240, 4%, 46%);
  --rc-zinc-800: hsl(240, 4%, 16%);
  --rc-zinc-900: hsl(240, 10%, 4%);
  
  /* Layout Settings */
  font-family: 'Outfit', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  line-height: 1.5;
  background-color: transparent;
  width: 100%;
  max-width: 800px;
  margin: 0 auto;
  padding: 1.5rem 1rem;
  box-sizing: border-box;
}

.rc-scanner-container *, 
.rc-scanner-container *::before, 
.rc-scanner-container *::after {
  box-sizing: border-box;
}

/* --- Layout Transitions --- */
.rc-fade-in {
  animation: rcFadeIn 0.5s cubic-bezier(0.16, 1, 0.3, 1) forwards;
}

@keyframes rcFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

/* --- Main Header Card --- */
.rc-header {
  text-align: center;
  margin-bottom: 2rem;
}

.rc-avatar-container {
  margin: 0 auto 1.25rem;
  display: flex;
  justify-content: center;
}

.rc-avatar {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  border: 4px solid #ffffff;
  box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1);
  object-cover: cover;
}

.rc-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--rc-zinc-900);
  margin: 0;
  letter-spacing: -0.025em;
}

.rc-subtitle {
  font-size: 1rem;
  color: var(--rc-zinc-500);
  margin-top: 0.5rem;
  max-width: 500px;
  margin-left: auto;
  margin-right: auto;
}

.rc-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  background-color: #ffffff;
  border: 1px solid var(--rc-zinc-200);
  border-radius: 9999px;
  padding: 0.5rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--rc-zinc-500);
  margin-top: 1rem;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.05);
}

.rc-badge svg {
  color: var(--rc-success);
}

/* --- Progress Bar --- */
.rc-progress-wrapper {
  margin-bottom: 2rem;
}

.rc-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--rc-zinc-400);
  margin-bottom: 0.5rem;
}

.rc-progress-bar {
  height: 6px;
  background-color: var(--rc-zinc-100);
  border-radius: 9999px;
  overflow: hidden;
}

.rc-progress-fill {
  height: 100%;
  background: var(--rc-grad-primary);
  border-radius: 9999px;
  width: 12.5%;
  transition: width 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

/* --- Conversational Form Box --- */
.rc-form-box {
  background-color: #ffffff;
  border: 1px solid var(--rc-zinc-200);
  border-radius: 24px;
  padding: 2rem;
  box-shadow: 0 15px 35px -10px rgba(74, 10, 85, 0.08), 0 5px 15px -5px rgba(0, 0, 0, 0.03);
}

.rc-step-content {
  min-height: 200px;
}

.rc-question-header {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
  margin-bottom: 2rem;
}

.rc-question-icon {
  width: 56px;
  height: 56px;
  border-radius: 16px;
  background-color: hsla(292, 79%, 19%, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--rc-primary);
  flex-shrink: 0;
}

.rc-question-body {
  flex: 1;
}

.rc-question-eyebrow {
  font-size: 0.875rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--rc-primary-light);
  margin: 0;
}

.rc-question-title {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--rc-zinc-900);
  margin: 0.25rem 0 0.5rem;
  line-height: 1.25;
}

.rc-question-desc {
  font-size: 1rem;
  color: var(--rc-zinc-500);
  margin: 0;
}

.rc-tip-box {
  display: flex;
  gap: 0.75rem;
  background-color: hsla(292, 79%, 19%, 0.03);
  border: 1px solid hsla(292, 79%, 19%, 0.1);
  padding: 0.75rem 1rem;
  border-radius: 12px;
  font-size: 0.875rem;
  color: var(--rc-zinc-500);
  margin-top: 1rem;
}

.rc-tip-box svg {
  color: var(--rc-primary-light);
  flex-shrink: 0;
}

/* --- Form Fields & Inputs --- */
.rc-input-wrapper {
  margin-top: 1.5rem;
}

.rc-text-input {
  width: 100%;
  border-radius: 14px;
  border: 1.5px solid var(--rc-zinc-200);
  background-color: #ffffff;
  padding: 0.875rem 1.25rem;
  font-size: 1.05rem;
  color: var(--rc-zinc-900);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  outline: none;
}

.rc-text-input:focus {
  border-color: var(--rc-primary-light);
  box-shadow: 0 0 0 4px hsla(296, 45%, 52%, 0.15);
}

.rc-text-input::placeholder {
  color: var(--rc-zinc-400);
}

.rc-error-text {
  color: var(--rc-accent);
  font-size: 0.875rem;
  margin-top: 0.5rem;
  display: none;
}

/* --- Presentation Selector (Custom Cards) --- */
.rc-cards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: 1.5rem;
}

.rc-select-card {
  border: 2px solid var(--rc-zinc-200);
  border-radius: 20px;
  padding: 1.5rem;
  text-align: center;
  cursor: pointer;
  background-color: #ffffff;
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
}

.rc-select-card:hover {
  border-color: var(--rc-primary-light);
  background-color: var(--rc-zinc-50);
  transform: translateY(-2px);
}

.rc-select-card.active {
  border-color: var(--rc-primary);
  background-color: hsla(292, 79%, 19%, 0.02);
  box-shadow: 0 8px 20px -4px hsla(292, 79%, 19%, 0.1);
}

.rc-card-icon {
  font-size: 1.5rem;
  color: var(--rc-zinc-400);
  transition: color 0.3s ease;
}

.rc-select-card.active .rc-card-icon {
  color: var(--rc-primary);
}

.rc-card-label {
  font-weight: 600;
  font-size: 1rem;
  color: var(--rc-zinc-800);
}

/* --- Age Slider --- */
.rc-slider-wrapper {
  margin-top: 2rem;
  text-align: center;
}

.rc-slider-value {
  font-size: 3rem;
  font-weight: 800;
  color: var(--rc-primary);
  line-height: 1;
  margin-bottom: 0.5rem;
}

.rc-slider-value span {
  font-size: 1.125rem;
  font-weight: 500;
  color: var(--rc-zinc-400);
}

.rc-slider {
  -webkit-appearance: none;
  width: 100%;
  height: 8px;
  border-radius: 9999px;
  background: var(--rc-zinc-100);
  outline: none;
  margin: 1.5rem 0;
  cursor: pointer;
}

.rc-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  appearance: none;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--rc-primary);
  border: 4px solid #ffffff;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.2);
  transition: transform 0.1s ease;
}

.rc-slider::-webkit-slider-thumb:hover {
  transform: scale(1.15);
}

.rc-slider-labels {
  display: flex;
  justify-content: space-between;
  color: var(--rc-zinc-400);
  font-size: 0.875rem;
  font-weight: 500;
}

/* --- Photo Uploader --- */
.rc-uploader-area {
  border: 2px dashed var(--rc-zinc-300);
  border-radius: 20px;
  padding: 2.5rem 1.5rem;
  text-align: center;
  cursor: pointer;
  background-color: var(--rc-zinc-50);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.75rem;
}

.rc-uploader-area:hover, 
.rc-uploader-area.drag-over {
  border-color: var(--rc-primary-light);
  background-color: #ffffff;
  box-shadow: 0 10px 20px -5px rgba(0, 0, 0, 0.02);
}

.rc-upload-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background-color: #ffffff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--rc-zinc-500);
}

.rc-uploader-area:hover .rc-upload-icon {
  color: var(--rc-primary-light);
}

.rc-upload-label {
  font-weight: 600;
  color: var(--rc-zinc-800);
  margin: 0;
}

.rc-upload-subtext {
  font-size: 0.875rem;
  color: var(--rc-zinc-400);
  margin: 0;
}

.rc-preview-container {
  margin-top: 1.5rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  background-color: #ffffff;
  border: 1px solid var(--rc-zinc-200);
  border-radius: 16px;
  padding: 0.75rem 1rem;
}

.rc-preview-thumb {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  object-fit: cover;
}

.rc-preview-info {
  flex: 1;
  text-align: left;
}

.rc-preview-name {
  font-weight: 600;
  font-size: 0.875rem;
  color: var(--rc-zinc-800);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 200px;
}

.rc-preview-size {
  font-size: 0.75rem;
  color: var(--rc-zinc-400);
}

.rc-remove-file {
  background: none;
  border: none;
  color: var(--rc-zinc-400);
  cursor: pointer;
  padding: 0.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.rc-remove-file:hover {
  color: var(--rc-accent);
}

/* --- Review Summary Card --- */
.rc-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
  margin-top: 1.5rem;
}

.rc-summary-item {
  background-color: var(--rc-zinc-50);
  border: 1px solid var(--rc-zinc-200);
  border-radius: 16px;
  padding: 1rem 1.25rem;
}

.rc-summary-label {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  color: var(--rc-zinc-400);
  letter-spacing: 0.05em;
}

.rc-summary-value {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--rc-zinc-800);
  margin-top: 0.25rem;
}

/* --- Navigation Buttons --- */
.rc-footer-nav {
  margin-top: 2.5rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid var(--rc-zinc-100);
  padding-top: 1.5rem;
}

.rc-btn-back {
  background: none;
  border: none;
  font-weight: 600;
  color: var(--rc-zinc-500);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
}

.rc-btn-back:hover {
  color: var(--rc-primary);
}

.rc-btn-continue {
  background: var(--rc-grad-primary);
  color: #ffffff;
  border: none;
  font-weight: 600;
  font-size: 1rem;
  border-radius: 9999px;
  padding: 0.875rem 2.5rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 8px 16px -4px hsla(292, 79%, 19%, 0.3);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.rc-btn-continue:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 20px -4px hsla(292, 79%, 19%, 0.45);
}

.rc-btn-run {
  background: var(--rc-grad-primary);
  color: #ffffff;
  border: none;
  font-weight: 600;
  font-size: 1.125rem;
  border-radius: 16px;
  padding: 1rem 3rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: 0 10px 20px -3px hsla(292, 79%, 19%, 0.3);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

.rc-btn-run:hover {
  transform: translateY(-2px) scale(1.02);
  box-shadow: 0 12px 25px -3px hsla(292, 79%, 19%, 0.4);
}

/* ==========================================================================
   2. Scanning Simulator Screen
   ========================================================================== */
.rc-scanning-box {
  background-color: #ffffff;
  border: 1px solid var(--rc-zinc-200);
  border-radius: 28px;
  padding: 3rem 2rem;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.05);
  text-align: center;
}

.rc-scanner-alert {
  background-color: hsl(48, 100%, 96%);
  border-bottom: 1px solid hsl(48, 100%, 88%);
  padding: 0.75rem 1rem;
  border-radius: 12px;
  font-size: 0.875rem;
  font-weight: 500;
  color: hsl(48, 100%, 25%);
  margin-bottom: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.rc-scanner-alert svg {
  color: hsl(48, 100%, 40%);
}

.rc-scan-circle {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  border: 4px solid var(--rc-zinc-100);
  border-top-color: var(--rc-primary-light);
  margin: 0 auto 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  animation: rcSpin 2s linear infinite;
}

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

.rc-scan-circle-inner {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background-color: var(--rc-zinc-50);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  animation: rcSpinCounter 2s linear infinite;
}

@keyframes rcSpinCounter {
  from { transform: rotate(360deg); }
  to { transform: rotate(0deg); }
}

.rc-scan-percent {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--rc-primary);
  line-height: 1;
}

.rc-scan-percent-lbl {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--rc-zinc-400);
  text-transform: uppercase;
}

/* --- Terminal Progress Cards --- */
.rc-terminal-box {
  background-color: var(--rc-zinc-50);
  border: 1px solid var(--rc-zinc-200);
  border-radius: 20px;
  padding: 1.5rem;
  text-align: left;
  margin-bottom: 2rem;
}

.rc-terminal-status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
}

.rc-terminal-label {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--rc-zinc-800);
}

.rc-terminal-step {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 1rem;
  font-weight: 500;
  color: var(--rc-zinc-800);
}

.rc-dot-pulse {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background-color: var(--rc-primary-light);
  animation: rcDotPulse 1.2s infinite ease-in-out;
}

@keyframes rcDotPulse {
  0%, 100% { transform: scale(0.6); opacity: 0.4; }
  50% { transform: scale(1.2); opacity: 1; }
}

/* --- App Platform Grids --- */
.rc-platform-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  margin-top: 2rem;
}

.rc-platform-icon {
  border: 1px solid var(--rc-zinc-200);
  background-color: #ffffff;
  border-radius: 16px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  opacity: 0.4;
  transition: all 0.5s ease;
}

.rc-platform-icon.active {
  opacity: 1;
  border-color: var(--rc-primary-light);
  box-shadow: 0 4px 12px hsla(296, 45%, 52%, 0.15);
  transform: scale(1.05);
}

.rc-platform-icon svg {
  width: 32px;
  height: 32px;
}

.rc-platform-name {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--rc-zinc-800);
}

/* ==========================================================================
   3. Locked Results Screen
   ========================================================================== */
.rc-results-wrapper {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid var(--rc-zinc-200);
  background-color: #ffffff;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.05);
}

/* --- Encrypted Status Bar --- */
.rc-encrypted-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background-color: var(--rc-zinc-900);
  color: #ffffff;
  padding: 0.75rem 1.5rem;
  border-top-left-radius: 27px;
  border-top-right-radius: 27px;
}

.rc-status-done {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
}

.rc-check-icon-badge {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: hsla(150, 84%, 37%, 0.2);
  color: var(--rc-success);
  display: flex;
  align-items: center;
  justify-content: center;
}

.rc-report-id {
  font-size: 0.75rem;
  color: var(--rc-zinc-400);
}

.rc-encrypted-text {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.75rem;
  color: var(--rc-zinc-400);
}

/* --- Header Complete Title --- */
.rc-results-header {
  text-align: center;
  padding: 3rem 2rem 1.5rem;
}

.rc-eyebrow-violet {
  font-size: 0.875rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--rc-primary-light);
  letter-spacing: 0.1em;
}

.rc-results-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 2.25rem;
  font-weight: 700;
  color: var(--rc-zinc-900);
  margin: 0.5rem 0 0.75rem;
}

.rc-results-desc {
  font-size: 1.05rem;
  color: var(--rc-zinc-500);
  max-width: 500px;
  margin: 0 auto;
}

/* --- Blurry Card Content --- */
.rc-blurry-preview {
  position: relative;
  padding: 0 2rem 2.5rem;
  overflow: hidden;
}

.rc-blur-layer {
  filter: blur(5px);
  pointer-events: none;
  user-select: none;
  -webkit-user-select: none;
  opacity: 0.55;
  transition: filter 0.5s ease;
}

/* --- Skeleton Report Elements --- */
.rc-skele-card {
  border: 1px solid var(--rc-zinc-200);
  border-radius: 20px;
  background-color: #ffffff;
  padding: 1.5rem;
  margin-bottom: 1rem;
}

.rc-skele-avatar {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--rc-grad-skeleton);
  background-size: 200% 100%;
  animation: rcShimmer 1.5s infinite;
}

.rc-skele-text {
  height: 12px;
  border-radius: 4px;
  background: var(--rc-grad-skeleton);
  background-size: 200% 100%;
  animation: rcShimmer 1.5s infinite;
  margin-bottom: 0.75rem;
}

.rc-skele-title {
  height: 18px;
  margin-bottom: 1.25rem;
}

.rc-skele-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 1rem;
}

@keyframes rcShimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* --- Floating Locked Overlay Dialog --- */
.rc-lock-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 30;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  background-color: rgba(255, 255, 255, 0.4);
}

.rc-lock-card {
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 28px;
  padding: 3rem 2.5rem;
  max-width: 440px;
  width: 100%;
  text-align: center;
  box-shadow: 0 30px 60px -15px rgba(74, 10, 85, 0.15), 0 15px 30px -10px rgba(0, 0, 0, 0.05);
}

.rc-overlay-lock-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background-color: var(--rc-zinc-900);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  box-shadow: 0 10px 20px rgba(0, 0, 0, 0.15);
}

.rc-lock-title {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--rc-zinc-900);
  margin: 0 0 0.5rem;
}

.rc-lock-subtitle {
  font-size: 0.95rem;
  color: var(--rc-zinc-500);
  margin: 0 0 1.75rem;
  line-height: 1.4;
}

.rc-btn-primary {
  width: 100%;
  background-color: var(--rc-zinc-900);
  color: #ffffff;
  border: none;
  font-weight: 600;
  font-size: 1rem;
  border-radius: 9999px;
  padding: 0.875rem 2rem;
  cursor: pointer;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
  text-align: center;
  display: block;
}

.rc-btn-primary:hover {
  background-color: var(--rc-primary);
  box-shadow: 0 10px 20px -3px hsla(292, 79%, 19%, 0.2);
  transform: translateY(-1px);
}

.rc-lock-footer {
  margin-top: 1.25rem;
  font-size: 0.875rem;
  color: var(--rc-zinc-500);
}

.rc-btn-link {
  background: none;
  border: none;
  font-weight: 600;
  color: var(--rc-primary-light);
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.rc-btn-link:hover {
  color: var(--rc-primary);
}

/* ==========================================================================
   4. Clerk-like Auth Modal
   ========================================================================== */
.rc-modal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(9, 9, 11, 0.4);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
}

.rc-modal-card {
  background-color: #ffffff;
  border: 1px solid var(--rc-zinc-200);
  border-radius: 24px;
  max-width: 400px;
  width: 100%;
  padding: 2.5rem 2rem;
  position: relative;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
}

.rc-modal-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  background: none;
  border: none;
  color: var(--rc-zinc-400);
  cursor: pointer;
  padding: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  transition: all 0.2s ease;
}

.rc-modal-close:hover {
  background-color: var(--rc-zinc-50);
  color: var(--rc-zinc-800);
}

.rc-modal-header {
  text-align: center;
  margin-bottom: 2rem;
}

.rc-modal-logo {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--rc-primary);
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.5rem;
}

.rc-modal-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--rc-zinc-900);
  margin: 0;
}

.rc-modal-subtitle {
  font-size: 0.875rem;
  color: var(--rc-zinc-500);
  margin-top: 0.25rem;
}

.rc-form-group {
  margin-bottom: 1.25rem;
}

.rc-form-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--rc-zinc-700);
  margin-bottom: 0.5rem;
}

.rc-modal-input {
  width: 100%;
  border-radius: 12px;
  border: 1px solid var(--rc-zinc-300);
  padding: 0.75rem 1rem;
  font-size: 0.95rem;
  outline: none;
  transition: all 0.2s ease;
}

.rc-modal-input:focus {
  border-color: var(--rc-primary-light);
  box-shadow: 0 0 0 3px hsla(296, 45%, 52%, 0.1);
}

/* Spinner Loader */
.rc-spinner {
  width: 20px;
  height: 20px;
  border: 3px solid rgba(255, 255, 255, 0.3);
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: rcSpin 0.8s linear infinite;
  display: inline-block;
}

/* Responsive adjust */
@media (max-width: 640px) {
  .rc-scanner-container {
    padding: 0.75rem 0.5rem;
  }
  
  .rc-title {
    font-size: 1.75rem;
  }
  
  .rc-subtitle {
    font-size: 0.875rem;
    padding: 0 0.5rem;
  }
  
  .rc-form-box, 
  .rc-scanning-box {
    padding: 1.5rem 1rem;
    border-radius: 20px;
  }
  
  .rc-question-header {
    gap: 0.75rem;
    margin-bottom: 1.25rem;
  }
  
  .rc-question-icon {
    width: 44px;
    height: 44px;
    border-radius: 12px;
  }
  
  .rc-question-icon svg {
    width: 20px;
    height: 20px;
  }
  
  .rc-question-title {
    font-size: 1.35rem;
  }
  
  .rc-question-desc {
    font-size: 0.875rem;
  }
  
  .rc-text-input {
    padding: 0.75rem 1rem;
    font-size: 1rem;
  }
  
  .rc-tip-box {
    padding: 0.5rem 0.75rem;
    font-size: 0.75rem;
    border-radius: 12px;
  }
  
  .rc-cards-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  
  .rc-select-card {
    padding: 1rem;
    flex-direction: row;
    justify-content: flex-start;
    gap: 1rem;
    border-radius: 14px;
  }
  
  .rc-card-icon {
    font-size: 1.25rem;
  }
  
  .rc-slider-value {
    font-size: 2.25rem;
  }
  
  .rc-uploader-area {
    padding: 1.5rem 1rem;
    border-radius: 14px;
  }
  
  .rc-upload-icon {
    width: 44px;
    height: 44px;
  }
  
  .rc-upload-icon svg {
    width: 20px;
    height: 20px;
  }
  
  .rc-preview-container {
    padding: 0.5rem;
    border-radius: 12px;
  }
  
  .rc-preview-thumb {
    width: 44px;
    height: 44px;
  }
  
  .rc-preview-name {
    font-size: 0.75rem;
    max-width: 140px;
  }
  
  .rc-summary-grid {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }
  
  .rc-summary-item {
    padding: 0.75rem 1rem;
    border-radius: 12px;
  }
  
  .rc-footer-nav {
    margin-top: 1.5rem;
    padding-top: 1rem;
  }
  
  .rc-btn-continue {
    padding: 0.75rem 1.75rem;
    font-size: 0.95rem;
    border-radius: 12px;
  }
  
  .rc-btn-run {
    padding: 0.875rem 2rem;
    font-size: 1rem;
    border-radius: 12px;
    width: 100%;
    justify-content: center;
  }
  
  /* --- Scanning view adjustments --- */
  .rc-scan-circle {
    width: 90px;
    height: 90px;
    margin-bottom: 1.25rem;
    border-width: 3px;
  }
  
  .rc-scan-circle-inner {
    width: 70px;
    height: 70px;
  }
  
  .rc-scan-percent {
    font-size: 1.35rem;
  }
  
  .rc-scan-percent-lbl {
    font-size: 0.65rem;
  }
  
  .rc-terminal-box {
    padding: 1rem;
    border-radius: 14px;
    margin-bottom: 1.25rem;
  }
  
  .rc-terminal-step {
    font-size: 0.875rem;
  }
  
  .rc-platform-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 0.75rem;
  }
  
  .rc-platform-icon {
    padding: 0.75rem;
    border-radius: 12px;
  }
  
  .rc-platform-icon svg {
    width: 24px;
    height: 24px;
  }
  
  /* --- Results View adjustments --- */
  .rc-encrypted-bar {
    padding: 0.5rem 1rem;
  }
  
  .rc-results-header {
    padding: 2rem 1rem 1rem;
  }
  
  .rc-results-title {
    font-size: 1.75rem;
  }
  
  .rc-results-desc {
    font-size: 0.875rem;
  }
  
  .rc-blurry-preview {
    padding: 0 1rem 1.5rem;
  }
  
  .rc-skele-card {
    padding: 1rem;
    border-radius: 14px;
  }
  
  .rc-skele-avatar {
    width: 48px;
    height: 48px;
  }
  
  .rc-lock-overlay {
    padding: 1rem;
  }
  
  .rc-lock-card {
    padding: 2rem 1.25rem;
    border-radius: 20px;
  }
  
  .rc-overlay-lock-icon {
    width: 48px;
    height: 48px;
    margin-bottom: 1rem;
  }
  
  .rc-overlay-lock-icon svg {
    width: 20px;
    height: 20px;
  }
  
  .rc-lock-title {
    font-size: 1.25rem;
  }
  
  .rc-lock-subtitle {
    font-size: 0.85rem;
    margin-bottom: 1.25rem;
  }
  
  .rc-btn-primary {
    padding: 0.75rem 1.5rem;
    font-size: 0.95rem;
  }
  
  /* --- Auth Modal adjustments --- */
  .rc-modal-overlay {
    padding: 1rem;
  }
  
  .rc-modal-card {
    padding: 2rem 1.25rem;
    border-radius: 20px;
  }
  
  .rc-modal-header {
    margin-bottom: 1.25rem;
  }
}
