/**
 * Accessibility contrast, focus, tap targets & reduced motion
 */

/* ── Skip link ── */
.skip-link {
  position: absolute;
  top: -100%;
  left: max(12px, env(safe-area-inset-left));
  z-index: 1000001;
  padding: 12px 18px;
  border-radius: 0 0 10px 10px;
  background: var(--brand-navy, #071a42);
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.2);
}

.skip-link:focus,
.skip-link:focus-visible {
  top: 0;
  outline: 2px solid var(--brand-accent, #ffb302);
  outline-offset: 2px;
}

#main-content:focus {
  outline: none;
}

/* ── Contrast tweaks ── */
.site-footer__about {
  color: rgba(255, 255, 255, 0.82);
}

.site-footer__links a {
  color: rgba(255, 255, 255, 0.78);
}

.site-footer__links a:hover {
  color: #ffb302;
}

.site-footer__contact-row:focus-visible,
.site-footer__contact-icon:focus-visible {
  outline: 2px solid #ffb302;
  outline-offset: 2px;
  border-radius: 4px;
}

.site-footer__payment-badge {
  color: rgba(255, 255, 255, 0.88);
}

.page-home,
.page-content {
  --iptv-muted: #4b5563;
}

/* ── Focus visible (keyboard users) ── */
.header-cta-trial:focus-visible,
.home-btn:focus-visible,
.pg-btn:focus-visible,
.back-to-top-btn:focus-visible,
.float-stack__btn:focus-visible,
.site-nav ul li a:focus-visible,
.mobile-drawer-nav__link:focus-visible,
.mobile-drawer-cta:focus-visible,
.iptv-faq__btn:focus-visible,
.home-conn-selector__btn:focus-visible,
.home-pricing-card__btn:focus-visible,
.home-reviews__dot:focus-visible,
.site-announcement__close:focus-visible,
.tpoffcanvas .tpoffcanvas__close-btn button:focus-visible,
a:focus-visible,
button:focus-visible {
  outline: 2px solid #ffb302;
  outline-offset: 2px;
}

.floating-contact a:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
}

/* WCAG AA contrast for WhatsApp CTAs (white on #075E54 ≈ 7:1) */
.home-btn--whatsapp,
.trial-btn--whatsapp,
.floating-contact .btn-whatsapp,
.mobile-sticky-cta__whatsapp,
[class*="btn--whatsapp"],
[class*="__whatsapp"] {
  background: #075E54 !important;
  color: #fff !important;
}

.home-btn--whatsapp:hover,
.trial-btn--whatsapp:hover,
.floating-contact .btn-whatsapp:hover {
  background: #064e45 !important;
  color: #fff !important;
}

/* ── Tap targets ≥ 48px (mobile) ── */
@media (max-width: 767.98px) {
  .mobile-sticky-cta a {
    min-height: 48px;
  }

  .home-conn-selector__btn {
    min-height: 48px;
  }

  .home-reviews__dot {
    width: 12px;
    height: 12px;
    padding: 18px;
    box-sizing: content-box;
  }

  .tpoffcanvas .tpoffcanvas__close-btn button {
    width: 48px;
    height: 48px;
    min-width: 48px;
    min-height: 48px;
  }

  .mobile-drawer-nav__link {
    min-height: 48px;
  }
}

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto !important;
  }

  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .skip-link {
    transition: none;
  }

  .float-stack,
  .float-stack__btn,
  .float-stack__btn--top,
  .float-stack__btn--wa,
  .back-to-top-wrapper,
  .floating-contact,
  .floating-contact a,
  .site-announcement__close,
  .site-header__bar,
  .site-header .tp-menu-bar,
  .home-hero__aurora,
  .home-stats__card,
  .home-pricing-card,
  .home-pricing-card__price,
  .home-trial-step,
  .home-feature-card,
  .home-review-card,
  .home-device-item,
  .home-device-item__icon,
  .home-reviews__dot,
  .iptv-faq__icon,
  .iptv-faq__icon-v,
  .iptv-faq__item,
  .iptv-faq__btn {
    transition: none !important;
    animation: none !important;
  }

  .home-reviews__carousel {
    scroll-behavior: auto;
  }

  .home-hero__pills li:hover,
  .home-hero__pill:hover,
  .home-trial-step:hover,
  .home-feature-card:hover,
  .home-review-card:hover,
  .home-device-item:hover,
  .home-pricing-card--featured,
  .home-pricing-card--value,
  .home-pricing-card--featured:hover,
  .home-pricing-card--value:hover {
    transform: none !important;
  }

  .float-stack__btn--wa {
    animation: none !important;
  }
}
