/* R5 Academy — Responsive Fine-Tuning
   Mobile-first refinements for critical interactions.
   Loaded LAST to win specificity battles. */

/* ============================================================
   PROMO BAR — keep compact on mobile
   ============================================================ */
@media (max-width: 720px) {
  .r5-promo {
    font-size: 10px;
    padding: 7px var(--sp-3);
    letter-spacing: 0.08em;
    line-height: 1.35;
  }
}
@media (max-width: 480px) {
  .r5-promo {
    font-size: 9px;
    padding: 6px var(--sp-3);
  }
  .r5-promo .blink { width: 5px; height: 5px; margin-right: 5px; }
}

/* ============================================================
   NAVBAR — tighter on small screens
   ============================================================ */
@media (max-width: 480px) {
  :root { --nav-h: 64px; }
  .r5-nav__brand img { height: 32px; }
  .r5-nav__brand-tag { display: none; }
  .r5-nav__burger { width: 40px; height: 40px; }
}

/* ============================================================
   HERO (home) — mobile polish
   ============================================================ */
@media (max-width: 700px) {
  .hero { padding: var(--sp-6) 0 var(--sp-7); }
  .hero__megafive {
    font-size: 18rem;
    right: -20%;
    opacity: 0.5;
  }
  .hero__speedlines { display: none; }
  .hero__title { font-size: clamp(2.25rem, 9vw, 3rem); }
  .hero__lead { font-size: var(--fs-base); }
  .hero__ctas .btn { flex: 1; min-width: 0; justify-content: center; }
  .hero__meta { gap: var(--sp-3); }
  .hero__stat .val { font-size: var(--fs-xl); }
}

/* ============================================================
   PRODUCT HERO — mobile polish
   ============================================================ */
@media (max-width: 700px) {
  .p-hero { padding: var(--sp-6) 0 var(--sp-7); }
  .p-hero__bg-num { font-size: 14rem; right: -20%; opacity: 0.5; }
  .p-hero__bg-num--ai { font-size: 11rem !important; right: -8% !important; }
  .p-hero__bg-flutter { width: 16rem; right: -20%; opacity: 0.08; }
  .p-hero__title { font-size: clamp(2rem, 8vw, 2.75rem); }
  .p-hero__lead { font-size: var(--fs-base); }
  .p-hero__price { padding-left: var(--sp-3); }
  .p-hero__price .val { font-size: var(--fs-2xl); }
}

/* ============================================================
   COMPLETO HERO — mobile polish
   ============================================================ */
@media (max-width: 700px) {
  .completo-hero { padding: var(--sp-6) 0 var(--sp-7); }
  .completo-hero__title { font-size: clamp(2rem, 8vw, 2.75rem); }
  .completo-hero__lead { font-size: var(--fs-base); }
  .completo-stack__total {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-3);
  }
  .completo-stack__total .vals { width: 100%; justify-content: space-between; }
}

/* ============================================================
   PRICING — never feel cramped
   ============================================================ */
@media (max-width: 700px) {
  .pricing .plan { padding: var(--sp-5); }
  .plan.is-featured { transform: none; }
  .plan.is-featured:hover { transform: translateY(-2px); }
  .plan__price-main .amount { font-size: var(--fs-3xl); }
  .plan__ribbon { top: 10px; right: -6px; padding: 5px 12px; font-size: 9px; }
}

/* ============================================================
   BUTTONS — touch-friendly sizing
   ============================================================ */
@media (max-width: 600px) {
  .btn {
    padding: 16px 28px;
    font-size: 13px;
    gap: var(--sp-3);
  }
  .btn-lg {
    padding: 20px 32px;
    font-size: 14px;
    gap: var(--sp-3);
  }
  .btn-xl {
    padding: 22px 36px;
    font-size: 15px;
    gap: var(--sp-3);
  }
  .btn .arrow { margin-left: 4px; }

  /* Full-width primary CTAs on tight screens */
  .hero__ctas, .p-hero__ctas, .final-cta__inner > div[style*="display:flex"] {
    width: 100%;
  }
  .hero__ctas .btn, .p-hero__ctas .btn {
    width: 100%;
    min-width: 0;
    justify-content: center;
    padding-left: var(--sp-5);
    padding-right: var(--sp-5);
  }
}

@media (max-width: 400px) {
  /* On very tight screens, ensure no button feels cramped */
  .btn { padding: 14px 20px; font-size: 12px; }
  .btn-lg { padding: 18px 24px; font-size: 13px; }
  .btn-xl { padding: 20px 28px; font-size: 14px; }
}

/* ============================================================
   SECTION HEADERS — controlled wrap
   ============================================================ */
@media (max-width: 700px) {
  .section { padding: clamp(2.5rem, 8vw, 4rem) 0; }
  .section-head h2 { font-size: clamp(1.5rem, 6vw, 2rem); }
  .section-head p { font-size: var(--fs-base); }

  /* Heads with action button — stack */
  .section-head[style*="display:flex"] {
    flex-direction: column;
    align-items: flex-start !important;
  }
}

/* ============================================================
   PILLARS — readable on tiny screens
   ============================================================ */
@media (max-width: 540px) {
  .pillar { min-height: 220px; padding: var(--sp-5); }
  .pillar__num { font-size: var(--fs-xl); }
}

/* ============================================================
   ARCHITECTURE DIAGRAM
   ============================================================ */
@media (max-width: 640px) {
  .arch__hub { padding: var(--sp-4) var(--sp-5); }
  .arch__hub img { height: 28px; }
  .arch__hub-text { font-size: var(--fs-sm); }
  .arch__connector { height: 32px; }
  .arch__div { padding: var(--sp-5); }
}

/* ============================================================
   TRUST STRIP
   ============================================================ */
@media (max-width: 500px) {
  .trust-strip { padding: var(--sp-4) 0; }
  .trust-strip__inner { gap: var(--sp-3); }
  .trust-item { padding: 0 var(--sp-2); }
  .trust-item .val { font-size: var(--fs-xl); }
  .trust-item .label { font-size: 10px; letter-spacing: 0.10em; }
}

/* ============================================================
   TESTIMONIALS — comfortable padding
   ============================================================ */
@media (max-width: 600px) {
  .testimonial { padding: var(--sp-4); }
  .testimonial__text { font-size: var(--fs-sm); }
}

/* ============================================================
   FAQ — better spacing on mobile
   ============================================================ */
@media (max-width: 600px) {
  .faq__q { padding: var(--sp-4); font-size: var(--fs-base); }
  .faq__a { padding: 0 var(--sp-4) var(--sp-4); font-size: var(--fs-sm); }
}

/* ============================================================
   FINAL CTA
   ============================================================ */
@media (max-width: 700px) {
  .final-cta { padding: var(--sp-7) 0; }
  .final-cta h2 { font-size: clamp(1.75rem, 7vw, 2.5rem); }
  .final-cta__megafive { font-size: 16rem; }
}

/* ============================================================
   GUARANTEE BLOCK
   ============================================================ */
@media (max-width: 600px) {
  .guarantee { padding: var(--sp-5); }
  .guarantee__seal { width: 80px; height: 80px; font-size: var(--fs-xl); }
}

/* ============================================================
   ORCHESTRA (AI page) — borders ajustes
   ============================================================ */
@media (max-width: 800px) {
  .orchestra__step { border-right: none; border-bottom: 1px solid var(--titanium-border); }
  .orchestra__step:nth-last-child(-n+2) { border-bottom: none; }
}
@media (max-width: 480px) {
  .orchestra__step:nth-last-child(-n+2) { border-bottom: 1px solid var(--titanium-border); }
  .orchestra__step:last-child { border-bottom: none; }
}

/* ============================================================
   MODULE LIST (ementa preview)
   ============================================================ */
@media (max-width: 600px) {
  .module-row {
    grid-template-columns: 1fr;
    gap: var(--sp-1);
    padding: var(--sp-4);
  }
  .module-row__meta { font-size: 10px; letter-spacing: 0.10em; }
}

/* ============================================================
   EMENTA LAYOUT — sidebar becomes top bar
   ============================================================ */
@media (max-width: 900px) {
  .ementa-toc {
    display: flex;
    flex-wrap: wrap;
    gap: var(--sp-2);
    padding: var(--sp-4);
    background: var(--carbon-2);
    border: 1px solid var(--titanium-border);
    margin-bottom: var(--sp-5);
  }
  .ementa-toc h5 { width: 100%; margin-bottom: var(--sp-2); }
  .ementa-toc a { border-left: none; padding: var(--sp-2) var(--sp-3); background: var(--carbon-3); border: 1px solid var(--titanium-border); }
}

/* ============================================================
   FOOTER — comfortable on tiny screens
   ============================================================ */
@media (max-width: 480px) {
  .r5-footer { padding: var(--sp-6) 0 var(--sp-4); }
  .r5-footer__grid { gap: var(--sp-5); padding-bottom: var(--sp-5); }
  .r5-footer__bottom { font-size: 10px; flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
  .r5-footer__bottom .sep { display: none; }
}

/* ============================================================
   IMAGE HANDLING — never overflow
   ============================================================ */
img { max-width: 100%; height: auto; }

/* ============================================================
   PREVENT HORIZONTAL OVERFLOW (catch-all)
   ============================================================ */
html, body { overflow-x: hidden; max-width: 100vw; }

/* ============================================================
   COMPARE GRID (AI page)
   ============================================================ */
@media (max-width: 720px) {
  .compare-card { padding: var(--sp-4); }
  .compare-card h4 { font-size: var(--fs-md); }
}

/* ============================================================
   PRODUCTS GRID — better mobile alignment
   ============================================================ */
@media (max-width: 1100px) {
  .products__grid { grid-template-columns: 1fr 1fr !important; }
}
@media (max-width: 600px) {
  .products__grid { grid-template-columns: 1fr !important; }
  .product-card.featured { grid-column: 1; }
  .product-card { padding: var(--sp-5); }
  .product-card__title { font-size: var(--fs-lg); }
  .product-card.featured .product-card__title { font-size: var(--fs-xl); }
}

/* ============================================================
   CROSS-SELL — stack on mobile
   ============================================================ */
@media (max-width: 800px) {
  .cross-sell__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   INSTRUCTOR GRID
   ============================================================ */
@media (max-width: 800px) {
  .instructor__grid { grid-template-columns: 1fr; gap: var(--sp-5); }
  .instructor__photo { max-width: 320px; margin: 0 auto; }
}

/* ============================================================
   TESTIMONIAL GRID — explicit override
   ============================================================ */
@media (max-width: 900px) {
  .testimonials__grid, .section .container > .reveal[style*="grid"][style*="3, 1fr"] {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media (max-width: 600px) {
  .testimonials__grid, .section .container > .reveal[style*="grid"][style*="3, 1fr"] {
    grid-template-columns: 1fr !important;
  }
}

/* ============================================================
   CONTAINER PADDING — tighter on phones
   ============================================================ */
@media (max-width: 480px) {
  .container, .container-narrow { padding: 0 var(--sp-4); }
}

/* ============================================================
   PRICING — better mobile layout
   ============================================================ */
@media (max-width: 900px) {
  .pricing { grid-template-columns: 1fr !important; gap: var(--sp-4); }
}
