/* Sure As Ship – Dark Theme Overrides */

.theme-dark{
  /* ============================================
     BRAND COLORS - Dark Theme (Lighter for dark backgrounds)
     Change these to rebrand dark mode!
     ============================================ */
  --sas-brand-primary:#5ea3ff;        /* Main brand color (lighter blue for dark bg) */
  --sas-brand-primary-light:#7db8ff;  /* Light variant */
  --sas-brand-primary-dark:#3b82f6;   /* Dark variant (still visible on dark) */
  --sas-brand-primary-hover:#9fcdff;  /* Hover state (even lighter) */
  --sas-brand-secondary:#60a5fa;      /* Secondary actions */
  --sas-brand-secondary-light:#7db8ff; /* Secondary hover */

  /* Core Colors */
  --sas-bg:#0b0c10;
  --sas-surface:#101218;
  --sas-card:#121521;
  --sas-text:#e8eaf1;
  --sas-muted:#a7afc0;
  --sas-accent:var(--sas-brand-primary);
  --sas-accent-2:#00b894;
  --sas-attn:#fbbf24;
  --sas-danger:#f87171;
  --sas-border:#5a6a8f;
  --sas-stamp:var(--sas-brand-primary);

  /* Forms */
  --sas-input-bg:#101218;
  --sas-input-text:#e8eaf1;
  --sas-input-border:#273047;
  --sas-label-text:#e8eaf1;
  --sas-helper-text:#a7afc0;

  /* Links */
  --sas-link:var(--sas-brand-primary);
  --sas-link-hover:var(--sas-brand-primary-light);

  /* Header/Footer */
  --sas-header-bg-start:#101218;
  --sas-header-bg-end:#0b0c10;
  --sas-footer-bg-start:#0b0c10;
  --sas-footer-bg-end:#101218;
  --sas-footer-text:#a7afc0;

  /* Tables */
  --sas-table-head-bg:rgba(255,255,255,.06);
  --sas-table-head-text:#c9d2e3;
  --sas-table-stripe:rgba(255,255,255,.02);
  --sas-table-like-bg:#101218;

  /* Buttons - Default */
  --sas-btn-bg-start:#1a1d2e;
  --sas-btn-bg-end:#141722;
  --sas-btn-text:#e8eaf1;
  --sas-btn-border:#273047;

  /* Buttons - Primary (Blue - Brand Color) */
  --sas-btn-primary-bg-start:var(--sas-brand-primary-light);
  --sas-btn-primary-bg-end:var(--sas-brand-primary);
  --sas-btn-primary-text:#0b0c10;
  --sas-btn-primary-border:var(--sas-brand-primary);
  --sas-btn-primary-hover-start:var(--sas-brand-primary-hover);
  --sas-btn-primary-hover-end:var(--sas-brand-primary-light);

  /* Buttons - Warn */
  --sas-btn-warn-bg-start:#fbbf24;
  --sas-btn-warn-bg-end:#f59e0b;
  --sas-btn-warn-text:#0b0c10;
  --sas-btn-warn-hover-start:#fcd34d;
  --sas-btn-warn-hover-end:#fbbf24;

  /* Buttons - Danger */
  --sas-btn-danger-bg-start:#f87171;
  --sas-btn-danger-bg-end:#ef4444;
  --sas-btn-danger-text:#0b0c10;
  --sas-btn-danger-hover-start:#fca5a5;
  --sas-btn-danger-hover-end:#f87171;

  /* Buttons - Ghost */
  --sas-btn-ghost-bg:transparent;
  --sas-btn-ghost-hover-bg:rgba(94,163,255,0.1);

  /* Badges - Default */
  --sas-badge-bg:rgba(59,130,246,.15);
  --sas-badge-text:#cfe3ff;
  --sas-badge-border:#3b82f6;

  /* Badges - OK/Success */
  --sas-badge-ok-bg:rgba(94,224,161,.15);
  --sas-badge-ok-text:#69e6c2;
  --sas-badge-ok-border:#5ee0a1;

  /* Badges - Warning */
  --sas-badge-warn-bg:rgba(251,191,36,.15);
  --sas-badge-warn-text:#fcd34d;
  --sas-badge-warn-border:#fbbf24;

  /* Badges - Danger/Error */
  --sas-badge-danger-bg:rgba(248,113,113,.15);
  --sas-badge-danger-text:#fca5a5;
  --sas-badge-danger-border:#f87171;

  /* Notices */
  --sas-notice-bg:rgba(255,255,255,.03);
  --sas-notice-border:#3b82f6;
  --sas-notice-text:#d6e1ff;
  --sas-notice-hover-border:#5ea3ff;
  --sas-notice-hover-bg:rgba(94,163,255,.08);

  /* KV (Key-Value) */
  --sas-kv-key-text:#c9d2e3;
  --sas-kv-val-text:#e8eaf1;

  /* Stamp */
  --sas-stamp-bg:rgba(105,230,194,.15);
  --sas-stamp-text:#69e6c2;
  --sas-stamp-box-shadow:#273047;

  /* Brand Badge */
  --sas-brand-badge-text:#0b0c10;

  /* Utility Colors */
  --sas-blue:#60a5fa;
  --sas-blue-light:#93c5fd;
  --sas-gray:#9ca3af;
  --sas-gray-dark:#6b7280;
  --sas-purple:#a78bfa;
  --sas-teal:#5eead4;

  /* Shadows & Effects (darker for dark mode) */
  --sas-ring:rgba(94,163,255,.4);
  --sas-shadow:0 8px 24px rgba(0,0,0,.35);
  --sas-shadow-soft:0 3px 10px rgba(0,0,0,.25);
  --sas-shadow-hover:0 12px 32px rgba(0,0,0,.45);
  --sas-shadow-focus:0 0 0 4px rgba(94,163,255,.25);

  /* Background gradient override */
  background:linear-gradient(180deg, #0a0b12 0%, #0b0c10 100%);
}

/* Specific element overrides for dark theme */
.theme-dark a{color:var(--sas-accent)}

.theme-dark table thead th{
  background:rgba(255,255,255,.06);
  color:#c9d2e3;
}

.theme-dark .table{
  background:var(--sas-surface);
  box-shadow:0 8px 24px rgba(0,0,0,.35);
}

.theme-dark .badge{
  border-color:#3b82f6;
  color:#cfe3ff;
  background:rgba(59,130,246,.15);
}

.theme-dark .notice{
  background:rgba(255,255,255,.03);
  border-color:#3b82f6;
  color:#d6e1ff;
}

/* Slightly dim banner in dark mode */
.theme-dark .brand-banner{filter:brightness(.9)}

/* ============================================
   USER PAGES PREMIUM STYLING - DARK MODE
   ============================================ */

/* Page Guidance Cards - Dark Mode */
.theme-dark .page-guidance,
.theme-dark .page-intro,
.theme-dark .page-help-text {
  background: linear-gradient(135deg, var(--sas-brand-primary) 0%, var(--sas-brand-primary-dark) 100%) !important;
  color: var(--sas-bg) !important;
  border-color: var(--sas-brand-primary);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.theme-dark .page-guidance p,
.theme-dark .page-intro p,
.theme-dark .page-help-text p {
  color: var(--sas-bg) !important;
}

.theme-dark .page-guidance strong,
.theme-dark .page-intro strong,
.theme-dark .page-help-text strong {
  color: var(--sas-bg) !important;
}

.theme-dark .page-guidance em,
.theme-dark .page-intro em,
.theme-dark .page-help-text em {
  color: rgba(11, 12, 16, 0.9);
}

/* Premium Tables - Dark Mode */
.theme-dark .list-table,
.theme-dark .data-table {
  background: var(--sas-surface);
  border-color: var(--sas-border);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.theme-dark .list-table thead,
.theme-dark .data-table thead {
  background: rgba(94, 163, 255, 0.12);
}

.theme-dark .list-table thead th,
.theme-dark .data-table thead th {
  color: var(--sas-brand-primary-light);
  border-color: var(--sas-border);
}

.theme-dark .list-table tbody tr:hover,
.theme-dark .data-table tbody tr:hover {
  background: rgba(94, 163, 255, 0.08);
}

.theme-dark .list-table tbody td,
.theme-dark .data-table tbody td {
  border-color: rgba(90, 106, 143, 0.3);
  color: var(--sas-text);
}

/* Status Badges - Dark Mode */
.theme-dark .status-badge {
  border-width: 1px;
}

.theme-dark .status-badge.booked {
  background: rgba(96, 165, 250, 0.15);
  color: #93c5fd;
  border-color: #60a5fa;
}

.theme-dark .status-badge.paid {
  background: rgba(94, 224, 161, 0.15);
  color: #69e6c2;
  border-color: #5ee0a1;
}

.theme-dark .status-badge.sent {
  background: rgba(168, 139, 250, 0.15);
  color: #c4b5fd;
  border-color: #a78bfa;
}

.theme-dark .status-badge.cancelled {
  background: rgba(156, 163, 175, 0.15);
  color: #d1d5db;
  border-color: #9ca3af;
}

.theme-dark .status-badge.failed {
  background: rgba(248, 113, 113, 0.15);
  color: #fca5a5;
  border-color: #f87171;
}

.theme-dark .status-badge.draft {
  background: rgba(251, 191, 36, 0.15);
  color: #fcd34d;
  border-color: #fbbf24;
}

/* Company-wide and Residential Badges - Dark Mode */
.theme-dark .badge-company-wide {
  background: rgba(168, 139, 250, 0.15);
  color: #c4b5fd;
  border-color: #a78bfa;
}

.theme-dark .badge-residential {
  background: rgba(94, 224, 161, 0.15);
  color: #69e6c2;
  border-color: #5ee0a1;
}

/* Filter Section - Dark Mode */
.theme-dark .filter-section {
  background: var(--sas-surface);
  border-color: var(--sas-border);
}

/* Empty States - Dark Mode */
.theme-dark .empty-state {
  color: var(--sas-muted);
  background: rgba(255, 255, 255, 0.02);
}

.theme-dark .empty-state-mascot {
  opacity: 0.85;
}

.theme-dark .empty-state-title {
  color: var(--sas-text);
}

.theme-dark .empty-state-message {
  color: var(--sas-muted);
}

/* Info Cards - Dark Mode */
.theme-dark .info-card {
  background: rgba(96, 165, 250, 0.08);
  border-left-color: var(--sas-brand-primary);
  color: var(--sas-text);
}

.theme-dark .warning-card {
  background: rgba(251, 191, 36, 0.08);
  border-left-color: #fbbf24;
  color: var(--sas-text);
}

.theme-dark .success-card {
  background: rgba(94, 224, 161, 0.08);
  border-left-color: #5ee0a1;
  color: var(--sas-text);
}

/* Balance Summary - Dark Mode */
.theme-dark .balance-summary {
  background: var(--sas-surface);
  border-color: var(--sas-border);
}

/* Pagination - Dark Mode */
.theme-dark .pagination-wrapper {
  color: var(--sas-text);
}

.theme-dark .pagination-info {
  color: var(--sas-muted);
}

/* Card Enhanced - Dark Mode */
.theme-dark .card-enhanced {
  background: var(--sas-card);
  border-color: var(--sas-border);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.theme-dark .card-enhanced:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,.45);
  border-color: var(--sas-brand-primary);
}

/* Stat Cards - Dark Mode */
.theme-dark .stat-card {
  background: var(--sas-surface);
  border-color: var(--sas-border);
}

.theme-dark .stat-card .stat-label {
  color: var(--sas-muted);
}

.theme-dark .stat-card .stat-value {
  color: var(--sas-brand-primary-light);
}

/* ============================================
   PUBLIC PAGES ENHANCEMENTS - DARK MODE
   ============================================ */

/* FAQ Page - Dark Mode */
.theme-dark .faq-section details {
  background: var(--sas-surface);
  border-color: var(--sas-brand-primary);
  box-shadow: 0 4px 12px rgba(0,0,0,.35);
}

.theme-dark .faq-section details:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,.55);
  border-color: var(--sas-brand-primary-light);
  transform: translateY(-4px);
}

.theme-dark .faq-section details[open] {
  box-shadow: 0 12px 32px rgba(0,0,0,.55);
  border-color: var(--sas-brand-primary-light);
  transform: translateY(-2px);
}

.theme-dark .faq-section summary {
  color: var(--sas-text);
  background: rgba(94, 163, 255, 0.08);
}

.theme-dark .faq-section summary:hover {
  background: rgba(94, 163, 255, 0.12);
  color: var(--sas-brand-primary-light);
}

.theme-dark .faq-answer {
  background: var(--sas-surface);
  color: var(--sas-text);
}

/* About Page - Dark Mode */
.theme-dark .page-about .content-box {
  background: var(--sas-surface);
  border-color: var(--sas-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .page-about .content-box:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
}

.theme-dark .toolbox-section {
  background: var(--sas-surface);
  border-color: var(--sas-border);
}

.theme-dark .cards-section .card {
  background: var(--sas-card);
  border-color: var(--sas-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .cards-section .card:hover {
  box-shadow: 0 10px 28px rgba(0,0,0,.45);
  border-color: var(--sas-brand-primary);
}

/* Auth Forms - Dark Mode */
.theme-dark .auth-form {
  background: var(--sas-surface);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .auth-form:focus-within {
  box-shadow: 0 8px 24px rgba(0,0,0,.45), 0 0 0 4px rgba(94, 163, 255, 0.25);
}

.theme-dark .auth-form label {
  color: var(--sas-text);
}

.theme-dark .auth-form .form-group label {
  color: var(--sas-text);
}

.theme-dark .auth-form .checkbox-label {
  color: var(--sas-text);
}

.theme-dark .auth-form .form-text {
  color: var(--sas-muted);
}

.theme-dark .auth-form .help-text {
  color: var(--sas-muted);
}

/* Validation States - Dark Mode */
.theme-dark .form-field input.is-invalid,
.theme-dark .form-field select.is-invalid,
.theme-dark .form-field textarea.is-invalid,
.theme-dark .form-field input.invalid,
.theme-dark .form-field select.invalid,
.theme-dark .form-field textarea.invalid {
  border-color: var(--sas-danger);
  background: rgba(248, 113, 113, 0.15);
  color: var(--sas-text);
}

.theme-dark .form-field input.is-valid,
.theme-dark .form-field select.is-valid,
.theme-dark .form-field textarea.is-valid,
.theme-dark .form-field input.valid,
.theme-dark .form-field select.valid,
.theme-dark .form-field textarea.valid {
  border-color: var(--sas-accent-2);
}

/* Validation Messages - Dark Mode */
.theme-dark .validation-message.error {
  color: #fca5a5;
}

.theme-dark .validation-message.success {
  color: #69e6c2;
}

/* Validation Summary - Dark Mode */
.theme-dark .validation-summary {
  background: rgba(248, 113, 113, 0.15);
  border-color: #f87171;
}

.theme-dark .validation-summary-title {
  color: #fca5a5;
}

.theme-dark .validation-summary-list {
  color: #fca5a5;
}

/* MFA Challenge Page - Dark Mode */
.theme-dark .page-mfa-challenge .mfa-intro {
  background: rgba(94, 163, 255, 0.08);
  border-color: rgba(94, 163, 255, 0.2);
}

.theme-dark .page-mfa-challenge .mfa-intro p {
  color: var(--sas-text);
}

.theme-dark .page-mfa-challenge .form-field label {
  color: var(--sas-text);
}

.theme-dark .page-mfa-challenge .form-field small {
  color: var(--sas-muted);
}

.theme-dark .page-mfa-challenge .form-field input {
  background: var(--sas-input-bg);
  color: var(--sas-input-text);
  border-color: var(--sas-input-border);
}

.theme-dark .page-mfa-challenge .form-field input:focus {
  border-color: var(--sas-brand-primary);
  box-shadow: 0 0 0 3px rgba(94, 163, 255, 0.25);
}

.theme-dark .page-mfa-challenge .divider {
  border-top-color: var(--sas-border);
}

.theme-dark .page-mfa-challenge .recovery-section {
  background: rgba(94, 163, 255, 0.05);
  border-color: rgba(94, 163, 255, 0.15);
}

.theme-dark .page-mfa-challenge .recovery-section:hover {
  background: rgba(94, 163, 255, 0.08);
  border-color: rgba(94, 163, 255, 0.25);
}

.theme-dark .page-mfa-challenge .recovery-section summary {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-mfa-challenge .recovery-section summary:hover {
  color: var(--sas-brand-primary-hover);
}

/* Enhanced input focus pulse in dark mode */
.theme-dark .page-mfa-challenge .form-field input[name="code"]:focus {
  animation: inputPulseDark 2s ease-in-out infinite;
}

@keyframes inputPulseDark {
  0%, 100% {
    box-shadow: 0 0 0 3px rgba(94, 163, 255, 0.25);
  }
  50% {
    box-shadow: 0 0 0 3px rgba(94, 163, 255, 0.35), 0 0 0 6px rgba(94, 163, 255, 0.15);
  }
}

.theme-dark .page-mfa-challenge .auth-back-link a {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-mfa-challenge .auth-back-link a:hover {
  color: var(--sas-brand-primary-hover);
}

/* Login Page - Dark Mode */
.theme-dark .page-login .login-card {
  background: var(--sas-surface);
  border-color: var(--sas-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .page-login .login-card:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
}

.theme-dark .page-login label {
  color: var(--sas-text);
}

.theme-dark .page-login .brand span:last-child {
  color: var(--sas-muted);
}

.theme-dark .page-login .help-row .pill {
  color: var(--sas-muted);
}

.theme-dark .page-login .help-row a {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-login .divider {
  border-top-color: var(--sas-border);
}

.theme-dark .page-login .resend-section p {
  color: var(--sas-muted);
}

.theme-dark .page-login .btn-resend {
  background: var(--sas-brand-primary);
  border-color: var(--sas-border);
  color: white;
}

.theme-dark .page-login .btn-resend:hover:not(:disabled) {
  background: var(--sas-brand-primary-darker);
  border-color: var(--sas-brand-primary-light);
}

.theme-dark .page-login .btn-resend:disabled {
  background: var(--sas-card);
  border-color: var(--sas-border);
  color: var(--sas-muted);
}

/* Register/Waitlist Page - Dark Mode */
.theme-dark .page-register label,
.theme-dark .page-waitlist label {
  color: var(--sas-text);
}

.theme-dark .page-register .form-text,
.theme-dark .page-waitlist .form-text {
  color: var(--sas-muted);
}

.theme-dark .page-register .checkbox-row label,
.theme-dark .page-waitlist .checkbox-row label {
  color: var(--sas-text);
}

.theme-dark .page-register .checkbox-row a,
.theme-dark .page-waitlist .checkbox-row a {
  color: var(--sas-brand-primary-light);
}

/* Calculator Page - Dark Mode */
.theme-dark .page-calculator {
  background: transparent;
}

.theme-dark .calculator-card {
  background: var(--sas-surface);
  border-color: var(--sas-border);
  box-shadow: 0 8px 24px rgba(0,0,0,.35);
}

.theme-dark .calculator-card:hover {
  box-shadow: 0 12px 32px rgba(0,0,0,.45);
}

.theme-dark .page-calculator .hero h1 {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-calculator .hero p {
  color: var(--sas-text);
}

.theme-dark .form-section h3 {
  color: var(--sas-text);
}

.theme-dark .form-group label {
  color: var(--sas-text);
}

.theme-dark .form-control {
  background: var(--sas-input-bg);
  color: var(--sas-input-text);
  border-color: var(--sas-input-border);
}

.theme-dark .form-control:focus {
  border-color: var(--sas-brand-primary);
  box-shadow: 0 0 0 3px rgba(94, 163, 255, 0.25);
}

.theme-dark .calculate-btn {
  background: linear-gradient(135deg, var(--sas-brand-primary-light), var(--sas-brand-primary));
  color: var(--sas-bg);
  border-color: var(--sas-brand-primary);
}

.theme-dark .calculate-btn:hover:not(:disabled) {
  background: white;
  color: var(--sas-brand-primary);
}

.theme-dark .savings-banner {
  background: linear-gradient(135deg, var(--sas-brand-primary) 0%, var(--sas-brand-primary-dark) 100%);
}

.theme-dark .rate-card {
  background: var(--sas-card);
  border-color: var(--sas-border);
}

.theme-dark .rate-card.cheapest {
  border-color: var(--sas-brand-primary);
  background: rgba(94, 163, 255, 0.08);
}

.theme-dark .courier-name {
  color: var(--sas-brand-primary-light);
}

.theme-dark .delivery-info {
  color: var(--sas-muted);
}

.theme-dark .retail-price {
  color: var(--sas-gray);
}

.theme-dark .platform-price {
  color: var(--sas-brand-primary-light);
}

.theme-dark .cta-section {
  background: linear-gradient(135deg, var(--sas-brand-primary) 0%, var(--sas-brand-primary-dark) 100%);
}

.theme-dark .cta-section h2,
.theme-dark .cta-section h3,
.theme-dark .cta-section p {
  color: var(--sas-bg);
}

.theme-dark .discount-footnote {
  color: var(--sas-muted);
}

.theme-dark .feature-title {
  color: var(--sas-brand-primary-light);
}

.theme-dark .feature-description {
  color: var(--sas-muted);
}

.theme-dark .error-message {
  background: rgba(248, 113, 113, 0.15);
  color: #fca5a5;
  border: 1px solid #f87171;
}

/* Toast Notifications - Dark Mode */
.theme-dark .toast {
  background: var(--sas-card);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.4);
}

.theme-dark .toast-message {
  color: var(--sas-text);
}

.theme-dark .toast-close {
  color: var(--sas-muted);
}

.theme-dark .toast-close:hover {
  color: var(--sas-text);
}

/* Flash Banners - Dark Mode */
.theme-dark .banner.success {
  background: rgba(16, 185, 129, 0.15);
  border-color: var(--color-success);
  color: #6ee7b7;
}

.theme-dark .banner.error {
  background: rgba(239, 68, 68, 0.15);
  border-color: var(--color-danger);
  /* #fca5a5 (red-300) on this dark background gave ~3.7:1 (fail AA).
     #fee2e2 (red-100) lifts to ~7.2:1, AAA-clean. */
  color: #fee2e2;
}

.theme-dark .banner.info {
  background: rgba(59, 130, 246, 0.15);
  border-color: var(--color-info);
  color: #93c5fd;
}

.theme-dark .banner.warning {
  background: rgba(245, 158, 11, 0.15);
  border-color: var(--color-warning);
  color: #fcd34d;
}

/* Legal Pages (Terms & Privacy) - Dark Mode */
.theme-dark .page-terms,
.theme-dark .page-privacy {
  background: transparent;
}

.theme-dark .page-terms .legal-header,
.theme-dark .page-privacy .legal-header {
  color: var(--sas-text);
}

.theme-dark .page-terms .legal-header h1,
.theme-dark .page-privacy .legal-header h1 {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-terms .legal-content,
.theme-dark .page-privacy .legal-content {
  color: var(--sas-text);
}

.theme-dark .page-terms .legal-content h2,
.theme-dark .page-privacy .legal-content h2 {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-terms .legal-content h3,
.theme-dark .page-privacy .legal-content h3 {
  color: var(--sas-text);
}

.theme-dark .page-terms .legal-content p,
.theme-dark .page-privacy .legal-content p {
  color: var(--sas-text);
}

/* ===================================
   Legal Acceptance Page - Dark Theme
   =================================== */

.theme-dark .page-legal-accept {
  background: transparent;
}

.theme-dark .page-legal-accept h1 {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-legal-accept .legal-notice {
  background: var(--sas-surface);
  border-color: var(--sas-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .page-legal-accept .notice-content h2 {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-legal-accept .notice-content p {
  color: var(--sas-text);
}

.theme-dark .page-legal-accept .versions {
  background: var(--sas-card);
  border-color: var(--sas-border);
}

.theme-dark .page-legal-accept .version-item strong {
  color: var(--sas-text);
}

.theme-dark .page-legal-accept .version-badge {
  background: var(--sas-brand-primary);
  color: white;
}

.theme-dark .page-legal-accept .review-link {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-legal-accept .review-link:hover {
  color: var(--sas-brand-primary);
}

.theme-dark .page-legal-accept .checkbox-text {
  color: var(--sas-text);
}

.theme-dark .page-legal-accept .checkbox-text a {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-legal-accept .checkbox-text a:hover {
  color: var(--sas-brand-primary);
}

.theme-dark .page-legal-accept .help-text {
  color: var(--sas-text-muted);
}

.theme-dark .page-legal-accept .help-text a {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-legal-accept .help-text a:hover {
  color: var(--sas-brand-primary);
}

.theme-dark .page-terms .legal-content nav,
.theme-dark .page-privacy .legal-content nav {
  background: var(--sas-card);
  border-color: var(--sas-border);
  box-shadow: 0 6px 16px rgba(0,0,0,.35);
}

.theme-dark .page-terms .legal-content nav:hover,
.theme-dark .page-privacy .legal-content nav:hover {
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
}

.theme-dark .page-terms .legal-content nav a,
.theme-dark .page-privacy .legal-content nav a {
  color: var(--sas-brand-primary-light);
}

.theme-dark .page-terms .legal-content ul,
.theme-dark .page-privacy .legal-content ul {
  color: var(--sas-text);
}

.theme-dark .page-terms .legal-content li,
.theme-dark .page-privacy .legal-content li {
  color: var(--sas-text);
}

.theme-dark .page-terms .last-updated,
.theme-dark .page-privacy .last-updated {
  color: var(--sas-muted);
}

.theme-dark .page-terms .legal-content strong,
.theme-dark .page-privacy .legal-content strong {
  color: var(--sas-text);
}

/* ---- Dark-mode contrast fixes from axe sweep (2026-05-10) ---- */
/* gray-600 (#4b5563) is invisible on dark backgrounds; restore the
   semi-muted slate-400 we use elsewhere in dark mode. */
.theme-dark .stepper-pending,
.theme-dark .stepper-pending .stepper-number {
  color: #94a3b8;
}
/* Login tagline & back-link were 3.5–4:1 in dark mode. Boost to slate-200. */
.theme-dark .login-tagline,
.theme-dark .auth-back-link a {
  color: #e2e8f0;
}
.theme-dark .auth-back-link a:hover {
  color: #ffffff;
}
/* The shared `.theme-dark .badge` rule (specificity 0,2,0) was overriding
   the variant-specific badge colors (0,1,0) so EVERY badge picked up the
   low-contrast blue tint. Re-assert each variant at matching specificity
   so the green/red/yellow/grey badges stay distinct AND contrast-clean. */
.theme-dark .badge.badge-tier-preferred {
  background: #065f46;  /* emerald-800 — white text gives ~7:1 in dark mode */
  color: #ffffff;
  border-color: #065f46;
}
.theme-dark .badge.badge-tier-byoc_only,
.theme-dark .badge.tier-byoc_only,
.theme-dark .status-pending {
  background: #78350f;  /* amber-900 — white text gives ~10:1 */
  color: #ffffff;
  border-color: #78350f;
}
.theme-dark .badge.badge-tier-payg,
.theme-dark .badge.tier-payg {
  background: #1f2937;  /* slate-800 */
  color: #f1f5f9;
  border-color: #334155;
}
.theme-dark .status-success {
  background: #064e3b;  /* emerald-900 */
  color: #d1fae5;
  border-color: #064e3b;
}
/* Header nav links: dark-mode top nav (Home, etc.) needed brighter text */
.theme-dark header nav a,
.theme-dark .top-nav a,
.theme-dark .navbar a,
.theme-dark .header a:not(.btn):not(.brand) {
  color: #e2e8f0;
}
.theme-dark header nav a:hover,
.theme-dark .top-nav a:hover {
  color: #ffffff;
}
