/* =====================================================
   GLOBAL POLISH
   Scroll reveal · Page loader · Navbar shadow
   Hover micro-interactions · Button/input consistency
   ===================================================== */

/* ---------- Smooth scroll ---------- */
html {
  scroll-behavior: smooth;
}

/* =====================================================
   PAGE LOADER
   ===================================================== */
.page-loader {
  position: fixed;
  inset: 0;
  background: #ffffff;
  z-index: 99999;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 20px;
  pointer-events: none;
  transition: opacity 0.45s ease 0.1s, visibility 0.45s ease 0.1s;
}

.page-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
}

.page-loader__bar {
  position: absolute;
  top: 0;
  left: 0;
  height: 3px;
  width: 0;
  background: linear-gradient(90deg, #2e7d32 0%, #66bb6a 60%, #a5d6a7 100%);
  border-radius: 0 2px 2px 0;
  animation: loaderBar 0.65s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes loaderBar {
  0%   { width: 0; }
  60%  { width: 75%; }
  100% { width: 100%; }
}

.page-loader__logo {
  font-size: 1.2rem;
  font-weight: 800;
  color: #2e7d32;
  letter-spacing: 0.06em;
  animation: loaderFade 0.4s ease 0.1s both;
}

.page-loader__dots {
  display: flex;
  gap: 6px;
  animation: loaderFade 0.4s ease 0.2s both;
}

.page-loader__dots span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #2e7d32;
  animation: loaderDot 1s ease infinite;
}

.page-loader__dots span:nth-child(2) { animation-delay: 0.18s; }
.page-loader__dots span:nth-child(3) { animation-delay: 0.36s; }

@keyframes loaderDot {
  0%, 80%, 100% { transform: scale(0.5); opacity: 0.4; }
  40%           { transform: scale(1);   opacity: 1; }
}

@keyframes loaderFade {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* =====================================================
   SCROLL REVEAL
   ===================================================== */
.scroll-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition:
    opacity  0.65s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.65s cubic-bezier(0.4, 0, 0.2, 1);
}

.scroll-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Transition delay helpers */
.scroll-reveal[data-delay="100"] { transition-delay: 0.1s; }
.scroll-reveal[data-delay="150"] { transition-delay: 0.15s; }
.scroll-reveal[data-delay="200"] { transition-delay: 0.2s; }
.scroll-reveal[data-delay="250"] { transition-delay: 0.25s; }
.scroll-reveal[data-delay="300"] { transition-delay: 0.3s; }
.scroll-reveal[data-delay="400"] { transition-delay: 0.4s; }

/* =====================================================
   NAVBAR — scroll-aware shadow boost
   ===================================================== */
.header.is-scrolled .navbar {
  box-shadow:
    0 2px 8px rgba(0, 0, 0, 0.06),
    0 8px 32px rgba(0, 0, 0, 0.1);
}

@supports (backdrop-filter: blur(1px)) {
  .header.is-scrolled .navbar {
    background: rgba(255, 255, 255, 0.88);
  }
}

/* =====================================================
   BUTTON CONSISTENCY — pill style everywhere
   ===================================================== */

/* CTA section buttons */
.cta__btn {
  border-radius: 50px;
}

/* Claim section buttons */
.claim__btn {
  border-radius: 50px;
}

/* Calculator CTA */
.calculator__result-cta {
  border-radius: 50px;
}

/* Modal submit */
.modal__submit {
  border-radius: 50px;
}

/* =====================================================
   HOVER MICRO-INTERACTIONS
   ===================================================== */

/* Generic card lift — applied to any card that lacks its own lift */
.why__card,
.insurance__card,
.claim__card {
  will-change: transform;
}

/* FAQ item hover – softer lift  */
.faq__item {
  transition:
    transform 0.26s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.26s ease,
    border-color 0.26s ease;
}

.faq__item:hover {
  transform: translateY(-3px);
}

/* Partner badges — lift */
.companies__badge {
  transition:
    transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1),
    border-color 0.22s ease,
    box-shadow 0.22s ease,
    color 0.22s ease;
}

.companies__badge:hover {
  transform: translateY(-3px) scale(1.04);
}

/* All anchor/button hover scale baseline (links that are CTAs) */
.whatsapp__btn,
.hero__btn,
.calculator__result-cta,
.cta__btn,
.claim__btn {
  transition:
    transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.22s ease,
    background 0.2s ease,
    color 0.2s ease;
}

.whatsapp__btn:hover,
.calculator__result-cta:hover {
  transform: scale(1.04);
}

/* =====================================================
   INPUT FOCUS GLOW — global consistency
   ===================================================== */
.hero__form-input:focus,
.hero__form-select:focus,
.modal__input:focus {
  outline: none;
  border-color: #2e7d32;
  box-shadow: 0 0 0 3px rgba(46, 125, 50, 0.14);
  background: #ffffff;
}

/* =====================================================
   MODAL — premium spring animation
   ===================================================== */
.modal {
  transform-origin: center 60%;
}

.modal-overlay:not([hidden]) .modal {
  animation: modalSpring 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

@keyframes modalSpring {
  from {
    opacity: 0;
    transform: translateY(32px) scale(0.92);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

/* =====================================================
   SECTION LABEL CONSISTENCY
   ===================================================== */
.section__label {
  border-radius: 50px;
  padding: 4px 14px;
  background: rgba(46, 125, 50, 0.08);
}

/* =====================================================
   FOOTER LINK HOVER
   ===================================================== */
.footer__link {
  transition: color 0.2s ease, padding-left 0.2s ease;
  display: inline-block;
}

.footer__link:hover {
  color: #2e7d32;
  padding-left: 4px;
}

/* =====================================================
   ENHANCED CARD HOVER LIFTS — all pages
   ===================================================== */
.why__card,
.insurance__card,
.claim__card,
.vi-type-card,
.vi-addon,
.vi-tax-card,
.li-plan-card,
.li-tax-card,
.hi-plan-card,
.hi-tax-card,
.ti-plan-card,
.ti-why-card,
.cl-type-card,
.cl-support-card,
.ai-suggest-card,
.ai-know-card,
.co-card,
.co-support-card {
  transition:
    transform 0.30s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.30s ease;
}

.why__card:hover,
.insurance__card:hover,
.claim__card:hover,
.vi-type-card:hover,
.vi-addon:hover,
.vi-tax-card:hover,
.li-plan-card:hover,
.li-tax-card:hover,
.hi-plan-card:hover,
.hi-tax-card:hover,
.ti-plan-card:hover,
.ti-why-card:hover,
.cl-type-card:hover,
.cl-support-card:hover,
.ai-suggest-card:hover,
.ai-know-card:hover,
.co-card:hover,
.co-support-card:hover {
  transform: translateY(-6px);
  box-shadow:
    0 8px 28px rgba(0, 0, 0, 0.10),
    0 2px 8px rgba(0, 0, 0, 0.06);
}

/* =====================================================
   BUTTON HOVER — scale + soft green glow (all pages)
   ===================================================== */
.navbar__cta,
.vi-btn,
.vi-type-card__cta,
.li-btn,
.li-plan-card__cta,
.hi-btn,
.hi-plan-card__cta,
.ti-btn,
.ti-plan-card__cta,
.cl-btn,
.ai-btn,
.co-btn,
.co-form__submit {
  transition:
    transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.22s ease,
    background 0.2s ease,
    color 0.2s ease;
}

.navbar__cta:hover,
.hero__btn:hover,
.vi-btn:hover,
.vi-type-card__cta:hover,
.li-btn:hover,
.li-plan-card__cta:hover,
.hi-btn:hover,
.hi-plan-card__cta:hover,
.ti-btn:hover,
.ti-plan-card__cta:hover,
.cl-btn:hover,
.ai-btn:hover,
.co-btn:hover,
.co-form__submit:hover,
.cta__btn:hover,
.claim__btn:hover,
.calculator__result-cta:hover,
.modal__submit:hover {
  transform: scale(1.04) translateY(-1px);
  box-shadow: 0 4px 18px rgba(46, 125, 50, 0.22);
}

/* =====================================================
   ICON HOVER — scale via parent card hover
   ===================================================== */
.why__card [class*="__icon"],
.insurance__card [class*="__icon"],
.vi-type-card [class*="__icon"],
.vi-addon [class*="__icon"],
.li-plan-card [class*="__icon"],
.hi-plan-card [class*="__icon"],
.ti-plan-card [class*="__icon"],
.ti-why-card [class*="__icon"],
.cl-type-card [class*="__icon"],
.cl-support-card [class*="__icon"],
.ai-know-card [class*="__icon"],
.co-card [class*="__icon"],
.co-support-card [class*="__icon"] {
  transition: transform 0.30s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: inline-block;
}

.why__card:hover [class*="__icon"],
.insurance__card:hover [class*="__icon"],
.vi-type-card:hover [class*="__icon"],
.vi-addon:hover [class*="__icon"],
.li-plan-card:hover [class*="__icon"],
.hi-plan-card:hover [class*="__icon"],
.ti-plan-card:hover [class*="__icon"],
.ti-why-card:hover [class*="__icon"],
.cl-type-card:hover [class*="__icon"],
.cl-support-card:hover [class*="__icon"],
.ai-know-card:hover [class*="__icon"],
.co-card:hover [class*="__icon"],
.co-support-card:hover [class*="__icon"] {
  transform: scale(1.18) rotate(-4deg);
}

/* =====================================================
   SCROLL TO TOP BUTTON
   ===================================================== */
.scroll-to-top {
  position: fixed;
  bottom: 96px;
  right: 28px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: #2e7d32;
  color: #ffffff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.4rem;
  line-height: 1;
  box-shadow: 0 4px 18px rgba(46, 125, 50, 0.30);
  z-index: 9998;
  opacity: 0;
  visibility: hidden;
  transform: translateY(14px) scale(0.88);
  transition:
    opacity 0.30s ease,
    visibility 0.30s ease,
    transform 0.30s cubic-bezier(0.34, 1.56, 0.64, 1),
    box-shadow 0.25s ease,
    background 0.2s ease;
}

.scroll-to-top.is-visible {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
}

.scroll-to-top:hover {
  background: #1b5e20;
  box-shadow: 0 6px 22px rgba(46, 125, 50, 0.40);
  transform: translateY(-3px) scale(1.08);
}

.scroll-to-top:active {
  transform: scale(0.94);
}

/* =====================================================
   REDUCED MOTION — respect user preferences
   ===================================================== */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .scroll-reveal {
    opacity: 1;
    transform: none;
  }
}

/* =====================================================
   PROCESS STEPS SECTION (index.html)
   ===================================================== */
.process { padding: 80px 0; background: linear-gradient(150deg, #f0f6ff 0%, #ffffff 60%, #eef7ff 100%); }
.process__header { text-align: center; margin-bottom: 52px; }
.process__steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; position: relative; }
.process__steps::before { content: ''; position: absolute; top: 44px; left: calc(12.5% + 20px); right: calc(12.5% + 20px); height: 2px; background: linear-gradient(90deg, #3b82f6 0%, #6366f1 100%); opacity: 0.25; pointer-events: none; z-index: 0; }
@media (max-width: 768px) { .process__steps { grid-template-columns: repeat(2, 1fr); } .process__steps::before { display: none; } }
@media (max-width: 480px) { .process__steps { grid-template-columns: 1fr; } }
.process__card { background: #fff; border-radius: 18px; padding: 32px 22px 28px; text-align: center; box-shadow: 0 2px 16px rgba(59,130,246,0.08), 0 1px 4px rgba(0,0,0,0.05); border: 1px solid rgba(99,102,241,0.09); position: relative; z-index: 1; transition: transform 0.22s ease, box-shadow 0.22s ease; }
.process__card:hover { transform: translateY(-6px); box-shadow: 0 12px 36px rgba(59,130,246,0.14), 0 2px 8px rgba(0,0,0,0.07); }
.process__step-num { position: absolute; top: -14px; left: 50%; transform: translateX(-50%); background: linear-gradient(135deg, #3b82f6, #6366f1); color: #fff; font-size: 0.68rem; font-weight: 800; letter-spacing: 0.07em; padding: 3px 11px; border-radius: 20px; text-transform: uppercase; }
.process__icon { width: 64px; height: 64px; border-radius: 16px; background: linear-gradient(135deg, rgba(59,130,246,0.1), rgba(99,102,241,0.12)); display: flex; align-items: center; justify-content: center; font-size: 1.9rem; margin: 8px auto 18px; }
.process__card-title { font-size: 1rem; font-weight: 700; color: #1e293b; margin-bottom: 8px; }
.process__card-desc { font-size: 0.82rem; color: #64748b; line-height: 1.55; }

/* =====================================================
   PARTNERS LOGO GRID (index.html)
   ===================================================== */
.partners-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; }
@media (max-width: 900px) { .partners-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .partners-grid { grid-template-columns: repeat(2, 1fr); } }
.partner-logo-card { background: #fff; border: 1px solid rgba(0,0,0,0.06); border-radius: 14px; padding: 20px 14px; display: flex; align-items: center; justify-content: center; text-align: center; box-shadow: 0 1px 6px rgba(0,0,0,0.05); transition: transform 0.2s ease, box-shadow 0.2s ease; cursor: default; min-height: 80px; }
.partner-logo-card:hover { transform: scale(1.05); box-shadow: 0 6px 22px rgba(59,130,246,0.13); border-color: rgba(59,130,246,0.2); }
.partner-logo-card span { font-size: 0.88rem; font-weight: 700; color: #334155; letter-spacing: 0.02em; line-height: 1.3; }
