/* FreePDFWorld homepage (index.jsp)
   Goals:
   - Compact enterprise layout on desktop + mobile
   - Minimal CLS (stable spacing, reserved heights)
   - Cacheable CSS: keep large blocks out of index.jsp
*/

/* ---------- Theme tokens (homepage-scoped; header has its own) ---------- */
:root {
  --primary-blue: #1e40af;
  --primary-dark: #1e3a8a;
  --accent-teal: #0d9488;
  --accent-orange: #ea580c;

  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-600: #374151;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;

  --success: #059669;
  --warning: #d97706;
  --danger: #dc2626;

  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1);
}

/* ---------- Base ---------- */
.home-page {
  background: var(--gray-50);
  color: var(--gray-900);
  font-family: 'Poppins', sans-serif;
}

.home-page a:focus-visible,
.home-page button:focus-visible {
  outline: 3px solid var(--primary-blue);
  outline-offset: 2px;
  border-radius: 6px;
}

/* Skip link */
.home-page .skip-to-content {
  position: absolute;
  top: -200px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
  color: #fff;
  padding: .875rem 2rem;
  text-decoration: none;
  font-weight: 700;
  font-size: .9375rem;
  letter-spacing: .025em;
  z-index: 100000;
  border-radius: 0 0 12px 12px;
  box-shadow: 0 10px 40px rgba(37, 99, 235, 0.4);
  transition: all .25s ease;
  border: 2px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(10px);
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  white-space: nowrap;
}

.home-page .skip-to-content:focus {
  top: 0;
  outline: none;
  background: linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);
  box-shadow: 0 15px 50px rgba(37, 99, 235, 0.6), 0 0 0 4px rgba(251, 191, 36, 0.35);
  transform: translateX(-50%) scale(1.02);
}

/* ---------- HERO ---------- */
.home-page .hero-section {
  background: linear-gradient(135deg, #f8fbff 0%, #eef4ff 50%, #e0ecff 100%);
  padding: 5rem 0 3rem;
  position: relative;
  overflow: hidden;
  /* IMPORTANT (iPad Safari): avoid creating new stacking contexts that can
     cause sticky header dropdowns to paint behind page sections. */
  z-index: auto;
  transform: none;
}

.home-page .hero-section::before {
  content: '';
  position: absolute;
  width: 500px;
  height: 500px;
  background: radial-gradient(circle, rgba(37, 99, 235, 0.15) 0%, transparent 70%);
  top: -250px;
  right: -250px;
  border-radius: 50%;
}

.home-page .hero-content {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  height: 100%;
  padding-top: 0.5rem;
}

/* Hero Row Alignment */
.home-page .hero-section .row {
  align-items: flex-start;
}

.home-page .hero-section .col-lg-6 {
  display: flex;
  flex-direction: column;
}

.home-page .hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  background: white;
  border-radius: 50px;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--primary-blue);
  margin-bottom: 1rem;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
  width: fit-content;
  max-width: fit-content;
}
.fa-star {
 color: var(--warning);
}
.home-page .hero-title {
  font-size: 3rem;
  font-weight: 800;
  color: var(--gray-900);
  margin-bottom: 1rem;
}

.home-page .hero-title .highlight { color: var(--primary-blue); display: inline-block; }

.home-page .hero-description {
  font-size: 1.25rem;
  color: var(--gray-600);
  max-width: 700px;
  margin-bottom: 2rem;
  line-height: 1.6;
}

.home-page .hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .9rem;
  margin-bottom: 1.75rem;
}

.home-page .btn-hero-primary {
  padding: .9rem 1.4rem;
  background: var(--primary-blue);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-weight: 700;
  font-size: 1rem;
  box-shadow: 0 4px 10px rgba(30, 64, 175, 0.22);
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.home-page .btn-hero-primary:hover {
  background: var(--primary-dark);
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(30, 64, 175, 0.25);
  color: #fff;
}

.home-page .btn-hero-secondary {
  padding: .9rem 1.4rem;
  background: #fff;
  color: var(--gray-800);
  border: 2px solid var(--gray-300);
  border-radius: 12px;
  font-weight: 700;
  font-size: 1rem;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .5rem;
}

.home-page .btn-hero-secondary:hover {
  border-color: var(--primary-blue);
  color: var(--primary-blue);
  background: #eff6ff;
}

.home-page .hero-stats {
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.home-page .stat-item {
  padding: 1rem 1.25rem;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  min-width: 100px;
  text-align: center;
}

.home-page .stat-item:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(37, 99, 235, 0.15);
  border-color: rgba(37, 99, 235, 0.2);
}

.home-page .stat-number {
  font-size: 1.75rem;
  font-weight: 800;
  color: var(--primary-blue);
  line-height: 1;
  margin-bottom: .35rem;
  background: var(--primary-blue);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.home-page .stat-label {
  font-size: .85rem;
  color: var(--gray-600);
  font-weight: 600;
}

.home-page .hero-image {
  position: relative;
  z-index: 1;
  height: 460px;
  aspect-ratio: 1 / 1;
}

.home-page .hero-cards-container { position: relative; width: 100%; height: 100%; }

.home-page .hero-card-float {
  position: absolute;
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  border-radius: 24px;
  padding: 1.5rem;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(255, 255, 255, 0.5);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
  cursor: default;
  border: 1px solid rgba(37, 99, 235, 0.12);
  will-change: transform;
  /* Don't force GPU layers here; on iOS it can interfere with sticky stacking. */
  transform: none;
}

.home-page .hero-card-float:hover {
  transform: translate3d(0, -8px, 0) scale(1.03);
  box-shadow: 0 30px 80px rgba(37, 99, 235, 0.22);
  border-color: rgba(37, 99, 235, 0.25);
}

.home-page .hero-card-1 { top: 0; left: 0; width: 200px; animation: fpw-float-1 6s ease-in-out infinite; }
.home-page .hero-card-2 { top: 0; right: 0; width: 180px; animation: fpw-float-2 7s ease-in-out infinite; }
.home-page .hero-card-3 { bottom: 0; left: 50px; width: 220px; animation: fpw-float-3 8s ease-in-out infinite; }
.home-page .hero-card-4 { bottom: 20px; right: 50px; width: 190px; animation: fpw-float-4 9s ease-in-out infinite; }
.home-page .hero-card-main {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 280px;
  z-index: 10;
  animation: fpw-float-main 5s ease-in-out infinite;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(239, 246, 255, 0.98) 100%);
}

@keyframes fpw-float-1 { 0%,100%{transform:translate3d(0,0,0) rotate(0)} 50%{transform:translate3d(0,-18px,0) rotate(-3deg)} }
@keyframes fpw-float-2 { 0%,100%{transform:translate3d(0,0,0) rotate(0)} 50%{transform:translate3d(0,-22px,0) rotate(3deg)} }
@keyframes fpw-float-3 { 0%,100%{transform:translate3d(0,0,0) rotate(0)} 50%{transform:translate3d(0,-14px,0) rotate(-2deg)} }
@keyframes fpw-float-4 { 0%,100%{transform:translate3d(0,0,0) rotate(0)} 50%{transform:translate3d(0,-26px,0) rotate(2deg)} }
@keyframes fpw-float-main { 0%,100%{transform:translate3d(-50%,-50%,0) scale(1)} 50%{transform:translate3d(-50%,-54%,0) scale(1.02)} }

.home-page .hero-card-icon {
  width: 50px;
  height: 50px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  font-size: 1.5rem;
  color: #fff;
  position: relative;
  overflow: hidden;
}

.home-page .hero-card-icon::before {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: linear-gradient(45deg, transparent, rgba(255, 255, 255, 0.28), transparent);
  transform: rotate(45deg);
  animation: fpw-shine 3s infinite;
}

@keyframes fpw-shine { 0%{transform:translateX(-100%) translateY(-100%) rotate(45deg)} 100%{transform:translateX(100%) translateY(100%) rotate(45deg)} }

.home-page .icon-gradient-blue { background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%); }
.home-page .icon-gradient-teal { background: linear-gradient(135deg, #14b8a6 0%, #0d9488 100%); }
.home-page .icon-gradient-orange { background: linear-gradient(135deg, #f97316 0%, #ea580c 100%); }
.home-page .icon-gradient-green { background: linear-gradient(135deg, #10b981 0%, #059669 100%); }
.home-page .icon-gradient-purple { background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%); }

.home-page .hero-card-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--gray-900);
  margin-bottom: .5rem;
  text-align: center;
}

.home-page .hero-card-main .hero-card-title { font-size: 1.35rem; margin-bottom: .75rem; }

.home-page .hero-card-desc {
  font-size: .75rem;
  color: var(--gray-600);
  text-align: center;
  line-height: 1.4;
  margin: 0;
}

.home-page .hero-card-main .hero-card-desc { font-size: .95rem; }

.home-page .hero-card-badge {
  display: inline-block;
  padding: .25rem .75rem;
  background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
  color: #fff;
  border-radius: 999px;
  font-size: .625rem;
  font-weight: 700;
  margin-top: .75rem;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.home-page .hero-card-main::before {
  content: '';
  position: absolute;
  top: -2px;
  left: -2px;
  right: -2px;
  bottom: -2px;
  background: linear-gradient(135deg, #2563eb, #14b8a6, #f97316);
  border-radius: 24px;
  z-index: -1;
  opacity: 0;
  animation: fpw-pulse-border 3s ease-in-out infinite;
}

@keyframes fpw-pulse-border { 0%,100%{opacity:0;transform:scale(1)} 50%{opacity:.5;transform:scale(1.02)} }

/* ---------- SECTIONS ---------- */
.home-page .tools-section {
  padding: 3.25rem 0;
  background: #fff;
  /* Performance enhancement, but safe: do not create a stacking context. */
  content-visibility: auto;
  contain-intrinsic-size: 0 1400px;
  contain: none;
}

.home-page .how-it-works-section {
  padding: 3rem 0;
  background: var(--gray-50);
  content-visibility: auto;
  contain-intrinsic-size: 0 800px;
  contain: none;
}

.home-page .section-header {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 2.5rem;
}

.home-page .section-badge {
  display: inline-block;
  padding: .45rem 1.1rem;
  background: #eff6ff;
  border-radius: 999px;
  font-size: .875rem;
  font-weight: 700;
  color: var(--primary-blue);
  margin-bottom: 1rem;
}

.home-page .section-title {
  font-size: 2rem;
  font-weight: 700;
  color: var(--gray-900);
  margin-bottom: 1.5rem;
  text-align: center;
  position: relative;
  padding-bottom: 0.75rem;
}

.home-page .section-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 60px;
  height: 4px;
  background: linear-gradient(90deg, var(--primary-blue), var(--accent-teal));
  border-radius: 2px;
}

.home-page .section-description {
  font-size: 1.05rem;
  color: var(--gray-800);
}

/* ---------- TOOL CARDS ---------- */
.home-page .tool-card {
  background: #fff;
  border: 2px solid var(--gray-200);
  border-radius: 16px;
  padding: 1.5rem;
  height: 100%;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  text-decoration: none;
  display: block;
  position: relative;
  overflow: hidden;
  /* Containment can create a new stacking context on some browsers.
     Keep the layout stable without contain to prevent header dropdown overlap on tablets. */
  contain: none;
}

.home-page .tool-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--primary-blue);
  transform: scaleX(0);
  transition: transform .25s ease;
}

.home-page .tool-card:hover {
  border-color: var(--primary-blue);
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}

.home-page .tool-card:hover::before { transform: scaleX(1); }

.home-page .tool-icon-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  margin-bottom: 1.25rem;
}

.home-page .tool-icon {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.55rem;
  color: #fff;
  transition: transform .2s ease;
}

.home-page .tool-card:hover .tool-icon { transform: scale(1.08); }

.home-page .icon-blue { background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%); }
.home-page .icon-teal { background: linear-gradient(135deg, #14b8a6 0%, #0d9488 100%); }
.home-page .icon-orange { background: linear-gradient(135deg, #f97316 0%, #ea580c 100%); }
.home-page .icon-green { background: linear-gradient(135deg, #10b981 0%, #059669 100%); }
.home-page .icon-red { background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%); }
.home-page .icon-pink { background: linear-gradient(135deg, #ec4899 0%, #db2777 100%); }
.home-page .icon-purple { background: linear-gradient(135deg, #8b5cf6 0%, #7c3aed 100%); }

.home-page .tool-arrow { font-size: 1.25rem; color: var(--gray-400); }

.home-page .tool-title {
  font-size: 1.25rem;
  font-weight: 800;
  margin-bottom: .65rem;
  color: var(--gray-900);
}

.home-page .tool-description {
  color: var(--gray-800);
  line-height: 1.6;
  margin-bottom: 1.1rem;
  font-size: .9375rem;
}

.home-page .tool-features {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.1rem;
}

.home-page .feature-tag {
  padding: .32rem .75rem;
  background: var(--gray-100);
  border-radius: 999px;
  font-size: .8125rem;
  font-weight: 700;
  color: var(--gray-800);
}

.home-page .tool-cta {
  color: var(--primary-blue);
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  gap: .4rem;
  font-size: .9375rem;
}

.home-page .coming-soon-card { opacity: .7; cursor: not-allowed; }

.home-page .coming-soon-badge {
  display: inline-block;
  padding: .5rem 1.1rem;
  background: linear-gradient(135deg, #f97316 0%, #ea580c 100%);
  color: #fff;
  border-radius: 999px;
  font-weight: 700;
  font-size: .875rem;
}

/* ---------- HOW IT WORKS ---------- */
.home-page .step-card {
  background: #fff;
  border-radius: 16px;
  padding: 2rem;
  text-align: center;
  height: 100%;
  box-shadow: var(--shadow-sm);
  border: 2px solid var(--gray-200);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
  position: relative;
}

.home-page .step-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: var(--primary-blue);
}

.home-page .step-number {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, #2563eb 0%, #1e40af 100%);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 800;
  box-shadow: 0 4px 10px rgba(37, 99, 235, 0.25);
}

.home-page .step-icon {
  font-size: 2.2rem;
  color: var(--primary-blue);
  margin: 1.75rem 0 1.25rem;
}

.home-page .how-it-works-section h3 {
  font-size: 1.15rem;
  font-weight: 800;
  margin-bottom: .65rem;
  color: var(--gray-900);
}

.home-page .step-card p { color: var(--gray-700); line-height: 1.6; margin: 0; }

/* ---------- Responsive ---------- */

/* Desktop (≥992px): Hide mobile benefits section */
.home-page .hero-benefits-mobile {
  display: none !important;
}

@media (max-width: 991px) {
  .home-page .hero-image { margin-top: 2rem; height: 420px; }
  .home-page .section-header { margin-bottom: 2rem; }
}

@media (max-width: 767px) {
  .home-page .hero-section { padding: 2rem 0 1.5rem; }
  .home-page .hero-section::before { width: 300px; height: 300px; top: -150px; right: -150px; opacity: .3; }
  .home-page .hero-buttons { flex-direction: column; }
  .home-page .btn-hero-primary, .home-page .btn-hero-secondary { width: 100%; justify-content: center; }

  /* Enhanced Mobile Stats */
  .home-page .hero-stats {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
    padding: 1.5rem;
    background: linear-gradient(135deg, #eff6ff 0%, #dbeafe 100%);
    border-radius: 16px;
    margin-top: 1.5rem;
    border: 2px solid rgba(37, 99, 235, 0.1);
  }

  .home-page .stat-item {
    text-align: center;
    padding: 0.75rem;
    background: rgba(255, 255, 255, 0.6);
    border-radius: 12px;
    backdrop-filter: blur(10px);
    border: 1px solid rgba(255, 255, 255, 0.5);
  }

  .home-page .stat-number {
    font-size: 1.35rem;
    margin-bottom: 0.25rem;
  }

  .home-page .stat-label {
    font-size: 0.7rem;
    font-weight: 600;
  }

  /* Mobile Benefits Section (replaces hero-image) */
  .home-page .hero-benefits-mobile {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    margin-top: 1.5rem;
  }

  .home-page .hero-benefit-item {
    padding: 1.25rem 1rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    text-align: center;
    border: 1px solid #e5e7eb;
    transition: all 0.3s ease;
  }

  .home-page .hero-benefit-item:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(37, 99, 235, 0.15);
    border-color: rgba(37, 99, 235, 0.2);
  }

  .home-page .hero-benefit-icon {
    font-size: 2rem;
    margin-bottom: 0.5rem;
    display: inline-block;
  }

  .home-page .hero-benefit-title {
    font-size: 0.9rem;
    font-weight: 700;
    color: var(--gray-900);
    margin: 0;
    line-height: 1.3;
  }

  /* Show benefits only on mobile */
  @media (min-width: 992px) {
    .home-page .hero-benefits-mobile {
      display: none !important;
    }
  }

  .home-page .hero-image { display: none !important; }

  .home-page .tools-section { padding: 2.25rem 0; }
  .home-page .how-it-works-section { padding: 2.25rem 0; }

  .home-page .tool-card { padding: 1.25rem; border-radius: 12px; box-shadow: 0 2px 6px rgba(0,0,0,.06); }
  .home-page .tool-card:hover { transform: none; box-shadow: 0 2px 6px rgba(0,0,0,.06); border-color: var(--gray-200); }
  .home-page .tool-card::before { display: none; }

  .home-page .tool-icon-wrapper { justify-content: flex-start; }
  .home-page .tool-icon { width: 44px; height: 44px; font-size: 1.25rem; border-radius: 10px; }
  .home-page .tool-arrow { display: none; }

  .home-page .tool-title { font-size: 1rem; }
  .home-page .tool-description { font-size: .8125rem; margin-bottom: .75rem; }
  .home-page .feature-tag { padding: .2rem .625rem; font-size: .6875rem; }
  .home-page .tool-cta { font-size: .8125rem; }

  .home-page .step-card { padding: 1.5rem 1.25rem; border-radius: 12px; box-shadow: 0 2px 6px rgba(0,0,0,.06); }
  .home-page .step-card:hover { transform: none; box-shadow: 0 2px 6px rgba(0,0,0,.06); border-color: var(--gray-200); }
  .home-page .step-number { width: 36px; height: 36px; font-size: 1.125rem; top: -16px; }
  .home-page .step-icon { font-size: 1.75rem; margin: 1.25rem 0 .875rem; }
  .home-page .how-it-works-section h3 { font-size: 1rem; }
  .home-page .step-card p { font-size: .8125rem; }

  /* Performance: disable hero float animations on mobile */
  .home-page .hero-card-float,
  .home-page .hero-card-icon::before,
  .home-page .hero-card-main::before {
    animation: none !important;
  }
}

/* Tablet/iPad Safari hardening:
   Coarse pointers (touch) are where the dropdown-getting-hidden bug reproduces.
   We keep the same visuals, but remove 3D transforms and backdrop-filter
   so the sticky header dropdown can reliably paint above the hero section.
*/
@media (pointer: coarse) {
  .home-page .hero-card-float,
  .home-page .hero-card-float:hover {
    transform: none !important;
    transition: none !important;
  }

  .home-page .hero-card-float {
    animation: none !important;
    will-change: auto;
    /* iOS blending/filtering can create a new compositing layer that sits above sticky headers */
    backdrop-filter: none;
  }

  .home-page .hero-card-main::before,
  .home-page .hero-card-icon::before {
    animation: none !important;
  }
}

@media (max-width: 575px) {
  .home-page .hero-title { font-size: 1.35rem; }
  .home-page .hero-description { font-size: .875rem; }
  .home-page .hero-stats { gap: .5rem; }
  .home-page .stat-number { font-size: 1.125rem; }
  .home-page .stat-label { font-size: .625rem; }
  .home-page .section-title { font-size: 1.25rem; }
}

@media (prefers-reduced-motion: reduce) {
  .home-page .hero-card-float,
  .home-page .hero-card-float::before,
  .home-page .hero-card-icon::before {
    animation: none !important;
    transition: none !important;
  }
}

/* Ensure the home page root doesn't create a stacking context that can compete with the sticky header */
.home-page,
.home-page main,
.home-page #main-content {
  position: relative;
  z-index: 0;
  transform: none;
}
/* =============================================================================
   HOME PAGE — DARK THEME OVERRIDES
   Added here (end of file) so [data-theme="dark"] rules beat the light-mode
   class selectors above without needing !important on every property.
   ============================================================================= */
/* Base page background */
[data-theme="dark"] .home-page {
  background: #0f172a;
  color: #e2e8f0;
}
/* ---- 1. HERO SECTION ---- */
[data-theme="dark"] .home-page .hero-section {
  background: linear-gradient(135deg, #0f172a 0%, #1e293b 50%, #0f2040 100%) !important;
}
[data-theme="dark"] .home-page .hero-section::before {
  background: radial-gradient(circle, rgba(96,165,250,0.08) 0%, transparent 70%) !important;
}
/* Badge pill — hardcoded background:white above */
[data-theme="dark"] .home-page .hero-badge {
  background: #1e293b !important;
  color: #60a5fa !important;
  box-shadow: 0 4px 6px -1px rgba(0,0,0,0.4) !important;
}
[data-theme="dark"] .home-page .hero-title       { color: #f1f5f9 !important; }
[data-theme="dark"] .home-page .hero-title .highlight { color: #60a5fa !important; }
[data-theme="dark"] .home-page .hero-description { color: #cbd5e1 !important; }
/* Buttons */
[data-theme="dark"] .home-page .btn-hero-primary {
  background: #3b82f6 !important;
  color: #ffffff !important;
  border: none !important;
  box-shadow: 0 4px 10px rgba(59,130,246,0.35) !important;
}
[data-theme="dark"] .home-page .btn-hero-primary:hover {
  background: #2563eb !important;
  color: #ffffff !important;
  box-shadow: 0 10px 20px rgba(59,130,246,0.45) !important;
}
[data-theme="dark"] .home-page .btn-hero-primary span,
[data-theme="dark"] .home-page .btn-hero-primary i {
  color: #ffffff !important;
}
[data-theme="dark"] .home-page .btn-hero-secondary {
  background: #1e293b !important;
  color: #e2e8f0 !important;
  border-color: #475569 !important;
}
[data-theme="dark"] .home-page .btn-hero-secondary:hover {
  background: #334155 !important;
  border-color: #60a5fa !important;
  color: #60a5fa !important;
}
[data-theme="dark"] .home-page .btn-hero-secondary span,
[data-theme="dark"] .home-page .btn-hero-secondary i {
  color: inherit !important;
}
/* Stats */
[data-theme="dark"] .home-page .stat-number {
  background: linear-gradient(135deg, #60a5fa, #a78bfa) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}
[data-theme="dark"] .home-page .stat-label  { color: #94a3b8 !important; }
/* Mobile hero-stats strip — hardcoded light gradient above */
[data-theme="dark"] .home-page .hero-stats {
  background: transparent !important;
}
[data-theme="dark"] .home-page .stat-item {
  background: rgba(30,41,59,0.9) !important;
  border-color: rgba(96,165,250,0.2) !important;
  backdrop-filter: blur(10px) !important;
}
[data-theme="dark"] .home-page .stat-item:hover {
  border-color: rgba(96,165,250,0.4) !important;
  box-shadow: 0 12px 30px rgba(96,165,250,0.15) !important;
}
/* Floating hero cards — hardcoded rgba(255,255,255,0.95) above */
[data-theme="dark"] .home-page .hero-card-float {
  background: rgba(30,41,59,0.95) !important;
  border-color: rgba(96,165,250,0.2) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 0 1px rgba(96,165,250,0.1) !important;
}
/* Main hero card — hardcoded gradient(rgba white) above */
[data-theme="dark"] .home-page .hero-card-main {
  background: linear-gradient(135deg, rgba(30,41,59,0.98) 0%, rgba(15,23,42,0.98) 100%) !important;
}
[data-theme="dark"] .home-page .hero-card-title { color: #f1f5f9 !important; }
[data-theme="dark"] .home-page .hero-card-desc  { color: #94a3b8 !important; }
/* Mobile benefit items — hardcoded background:#fff above */
[data-theme="dark"] .home-page .hero-benefit-item {
  background: #1e293b !important;
  border-color: #334155 !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.3) !important;
}
[data-theme="dark"] .home-page .hero-benefit-title { color: #f1f5f9 !important; }
/* ---- 2. TOOLS SECTION ---- */
/* hardcoded background:#fff above */
[data-theme="dark"] .home-page .tools-section { background: #1e293b !important; }
/* section badge — hardcoded background:#eff6ff above */
[data-theme="dark"] .home-page .section-badge {
  background: rgba(96,165,250,0.15) !important;
  color: #93c5fd !important;
}
[data-theme="dark"] .home-page .section-title       { color: #f1f5f9 !important; }
[data-theme="dark"] .home-page .section-description { color: #cbd5e1 !important; }
/* Tool cards — hardcoded background:#fff, border:var(--gray-200) above */
[data-theme="dark"] .home-page .tool-card {
  background: #1e293b !important;
  border-color: #334155 !important;
}
[data-theme="dark"] .home-page .tool-card:hover {
  border-color: #60a5fa !important;
  box-shadow: 0 10px 15px -3px rgba(0,0,0,0.4) !important;
}
[data-theme="dark"] .home-page .tool-title       { color: #f1f5f9 !important; }
[data-theme="dark"] .home-page .tool-description { color: #cbd5e1 !important; }
[data-theme="dark"] .home-page .tool-cta         { color: #60a5fa !important; }
/* Feature tags — hardcoded background:var(--gray-100) above */
[data-theme="dark"] .home-page .feature-tag {
  background: #334155 !important;
  color: #cbd5e1 !important;
}
/* ---- 3. HOW IT WORKS SECTION ---- */
/* hardcoded background:var(--gray-50) above — resolved to #f9fafb light */
[data-theme="dark"] .home-page .how-it-works-section { background: #0f172a !important; }
[data-theme="dark"] .home-page .how-it-works-section h3 { color: #f1f5f9 !important; }
/* Step cards — hardcoded background:#fff above */
[data-theme="dark"] .home-page .step-card {
  background: #1e293b !important;
  border-color: #334155 !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.3) !important;
}
[data-theme="dark"] .home-page .step-card:hover {
  border-color: #60a5fa !important;
  background: #1e293b !important;
}
[data-theme="dark"] .home-page .step-card h3,
[data-theme="dark"] .home-page .step-card:hover h3,
[data-theme="dark"] .home-page .step-card.fpw-reveal:hover h3,
[data-theme="dark"] .home-page .step-card.fpw-reveal--in:hover h3 {
  color: #f1f5f9 !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: #f1f5f9 !important;
}
[data-theme="dark"] .home-page .step-card p,
[data-theme="dark"] .home-page .step-card:hover p,
[data-theme="dark"] .home-page .step-card.fpw-reveal:hover p,
[data-theme="dark"] .home-page .step-card.fpw-reveal--in:hover p {
  color: #cbd5e1 !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: #cbd5e1 !important;
}
[data-theme="dark"] .home-page .step-card .step-icon,
[data-theme="dark"] .home-page .step-card:hover .step-icon {
  color: #60a5fa !important;
  -webkit-text-fill-color: #60a5fa !important;
}
