/* THE PIVOTAL PROTOCOL Academy mobile rescue layer.
   Universal mobile responsiveness baseline applied to every academy page.
   Brand-locked palette: --bg #020203, --gold #C9A84C, --text #F2EDE0. */

/* iOS form-zoom prevention */
@media (max-width: 768px) {
  input, select, textarea {
    font-size: 16px !important;
  }
}

/* Touch target minimum */
@media (max-width: 768px) {
  button, a.btn, .button, .cta, [role="button"] {
    min-height: 44px;
    min-width: 44px;
    padding: 12px 18px;
  }
  a, button { touch-action: manipulation; }
}

/* Tablet breakpoint */
@media (max-width: 768px) {
  body { font-size: 16px; line-height: 1.55; }
  h1 { font-size: clamp(32px, 7vw, 48px) !important; line-height: 1.15 !important; }
  h2 { font-size: clamp(26px, 5.5vw, 36px) !important; line-height: 1.2 !important; }
  h3 { font-size: clamp(20px, 4.5vw, 28px) !important; line-height: 1.25 !important; }
  .hero, .hero-section, section.hero { padding: 48px 20px !important; }
  section, .section { padding-left: 20px !important; padding-right: 20px !important; }
  .container, .wrap, .wrapper { padding-left: 20px !important; padding-right: 20px !important; max-width: 100% !important; }
  .grid, .two-col, .three-col, .four-col, [class*="grid-cols"] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  .row, .flex-row { flex-direction: column !important; gap: 16px !important; }
  .nav, nav, header nav { flex-wrap: wrap !important; gap: 12px !important; padding: 12px 16px !important; }
  .nav-links, .nav-menu { gap: 8px !important; flex-wrap: wrap !important; }
  table { display: block; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  img, video, iframe, svg { max-width: 100% !important; height: auto !important; }
  pre, code { white-space: pre-wrap !important; word-break: break-word !important; }
}

/* Phone breakpoint */
@media (max-width: 480px) {
  body { font-size: 15px; }
  h1 { font-size: clamp(28px, 8vw, 36px) !important; }
  h2 { font-size: clamp(22px, 6vw, 28px) !important; }
  .hero, .hero-section, section.hero { padding: 32px 16px !important; }
  section, .section { padding-top: 32px !important; padding-bottom: 32px !important; padding-left: 16px !important; padding-right: 16px !important; }
  .container, .wrap, .wrapper { padding-left: 16px !important; padding-right: 16px !important; }
  .nav-links a, .nav-menu a { padding: 10px 12px !important; }
  /* Hide secondary nav on phone, keep brand + primary CTA */
  .nav-secondary, .nav-extra, .nav-utility { display: none !important; }
  /* Stack form fields */
  form .form-row, form .field-row { flex-direction: column !important; gap: 12px !important; }
  input, textarea, select { width: 100% !important; box-sizing: border-box !important; padding: 12px 14px !important; }
  /* Sticky CTA bar safe area */
  .sticky-cta, .sticky-bar, .floating-cta {
    padding-bottom: calc(12px + env(safe-area-inset-bottom)) !important;
  }
  /* Modal mobile-aware */
  .modal, .popup, .overlay-modal {
    width: 100vw !important;
    max-width: 100vw !important;
    border-radius: 0 !important;
    padding: 24px 16px !important;
  }
}

/* Disable exit-intent modals on touch devices */
@media (hover: none) and (pointer: coarse) {
  .exit-intent, #exit-modal, [data-exit-intent] {
    display: none !important;
  }
}

/* Focus-visible accessibility */
:focus-visible {
  outline: 2px solid #C9A84C !important;
  outline-offset: 2px;
}

/* Prefers reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Skip-link visible on focus */
.skip-link:focus {
  left: 0 !important;
  outline: 3px solid #C9A84C !important;
}
