/* ============================================
   RESPONSIVE.CSS - Mobile-First Responsive Design
   Raidho Coaching Website
   ============================================ */

/* Comparison table: default to desktop version */
.compare-table-mobile {
  display: none;
}

.compare-table-desktop {
  display: block;
}

/* Tablet: 768px and up */
@media (min-width: 768px) {
  .hero-dual .hero-container {
    gap: 40px;
    padding: 4vh 20px;
  }

  .section {
    padding: var(--space-2xl) var(--space-xl);
  }

  .section-title {
    font-size: var(--font-size-4xl);
  }

  .grid-2 {
    grid-template-columns: repeat(2, 1fr);
  }

  .grid-3 {
    grid-template-columns: repeat(3, 1fr);
  }

  .grid-4 {
    grid-template-columns: repeat(3, 1fr);
  }

  .two-column {
    gap: var(--space-xl);
  }

  .hero {
    min-height: 100vh;
  }

  .hero-dual {
    justify-content: space-between;
    padding: 0 var(--space-xl);
  }

  .hero-dual-portrait {
    max-width: 400px;
  }

  .hero h1 {
    font-size: var(--font-size-4xl);
  }

  .hero p {
    font-size: var(--font-size-2xl);
  }

  /* Navigation */
  .nav-mobile {
    display: none;
  }

  .nav-desktop {
    display: flex;
  }

  .header {
    padding: var(--space-md) var(--space-lg);
  }
}

/* Desktop: 1024px and up */
@media (min-width: 1024px) {
  .section {
    padding: var(--space-2xl) 0;
  }

  .grid-4 {
    grid-template-columns: repeat(4, 1fr);
  }

  .two-column {
    gap: var(--space-2xl);
  }

  .hero-dual {
    min-height: 100vh;
    gap: var(--space-2xl);
  }

  .hero-dual-portrait {
    max-width: 500px;
  }

  /* Cards in grid get equal height */
  .grid-3 .card,
  .grid-4 .card {
    display: flex;
    flex-direction: column;
  }

  .grid-3 .card-body,
  .grid-4 .card-body {
    flex-grow: 1;
  }
}

/* Large Desktop: 1280px and up */
@media (min-width: 1280px) {
  .container {
    padding: 0;
  }

  .hero h1 {
    font-size: 56px;
  }

  .section-title {
    font-size: 48px;
  }
}

/* Mobile: Under 768px */
@media (max-width: 767px) {
  .section {
    padding: var(--space-xl) var(--space-md);
  }

  .section-title {
    font-size: var(--font-size-2xl);
  }

  .section-subtitle {
    font-size: var(--font-size-base);
  }

  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
  }

  .two-column {
    grid-template-columns: 1fr;
    gap: var(--space-lg);
  }

  .two-column.reverse {
    direction: ltr;
  }

  .hero {
    min-height: 60vh;
    padding: var(--space-lg);
  }

  .hero h1 {
    font-size: var(--font-size-2xl);
  }

  .hero p {
    font-size: var(--font-size-base);
  }

  .hero-dual {
    height: auto !important;
    min-height: 0 !important;
    flex-direction: column;
    justify-content: flex-start !important;
    margin-top: 0 !important;
    padding: 18px var(--space-md) 22px !important;
  }

  .hero-dual {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  /* Reduce excess whitespace in hero (mobile) */
  .hero-dual > .container {
    padding: 0 16px !important;
    gap: 0 !important;
  }

  .hero-dual > .container > .hero-media {
    margin: 0 !important;
    padding: 0 !important;
  }

  .hero-dual-portrait {
    max-width: 100%;
  }

  /* Mobile Navigation */
  .nav-desktop {
    display: none;
  }

  .nav-mobile {
    display: flex !important;
    flex-direction: row !important;
    position: relative;
    z-index: 110;
  }
  
  .nav-mobile .menu-text {
    transform: none !important;
  }

  .header {
    padding: var(--space-md);
    position: sticky;
    top: 0;
    z-index: 100;
    background-color: var(--bg-primary);
    border-bottom: 1px solid var(--border-color);
  }

  /* Mobile Menu */
  .mobile-menu {
    display: none;
    position: fixed;
    left: 0;
    top: 72px;
    right: 0;
    bottom: 0;
    background-color: var(--bg-primary);
    flex-direction: column;
    padding: var(--space-lg);
    z-index: 109;
    overflow-y: auto;
    width: 100vw;
    max-width: 100vw;
    animation: none !important;
    transform: none !important;
  }

  .mobile-menu.active {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    animation: none !important;
    transform: none !important;
  }

  .mobile-menu a {
    padding: var(--space-md);
    border-bottom: 1px solid var(--border-color);
    color: var(--text-primary);
  }

  /* Touch targets */
  .btn {
    min-height: 48px;
    min-width: 48px;
  }

  .form-input,
  .form-textarea,
  .form-select {
    min-height: 48px;
  }

  /* Stack buttons vertically on mobile */
  .button-group {
    flex-direction: column;
  }

  .button-group .btn {
    width: 100%;
  }

  /* Reduce padding on mobile */
  .card {
    padding: var(--space-md);
  }

  .card-header,
  .card-body,
  .card-footer {
    padding: var(--space-md);
  }

  /* Testimonials */
  .testimonial-card {
    padding: var(--space-md);
  }

  /* Letter block */
  .letter-block {
    padding: var(--space-lg);
  }

  .letter-seal {
    left: 50%;
    transform: translateX(-50%);
  }

  /* ============================================
     Home Hero (Mobile Only)
     - image + badge above text
     ============================================ */
  .hero-dual > .container {
    display: flex !important;
    flex-direction: column !important;
    flex-wrap: nowrap !important;
    align-items: center;
    gap: 0 !important;
    justify-content: flex-start !important;
    padding: 0 16px !important;
  }

  .hero-dual > .container > .hero-media {
    order: -1 !important;
    width: 100%;
    max-width: 100% !important;
    margin-top: 25px !important;
    margin-bottom: 0 !important;
  }

  .hero-dual .hero-media .hero-main-image-wrap {
    border-radius: var(--radius-lg);
    margin-bottom: 0 !important;
    box-shadow: 0 4px 12px rgba(43, 138, 143, 0.1) !important;
  }

  .hero-dual .hero-container {
    gap: 0 !important;
    padding: 0 16px !important;
  }

  .hero-dual .hero-media .hero-main-image {
    width: 100% !important;
    transform: scale(1.12) !important;
    transform-origin: center;
    margin-bottom: 0 !important;
  }

  .hero-dual .hero-media img.hero-badge {
    width: 165px !important;
    height: auto !important;
    top: -29px !important;
    left: -35px !important;
  }

  .hero-dual > .container > .animate-fade-in-up:not(.hero-media) {
    order: 1 !important;
    width: 100%;
    max-width: 560px;
    text-align: center !important;
    margin-top: -220px !important;
    padding-top: 0 !important;
  }

  .hero-dual > .container > .animate-fade-in-up:not(.hero-media) h1 {
    margin-top: 0 !important;
  }

  /* ============================================
     Comparison Table: enforce mobile version
     ============================================ */
  .compare-table-desktop {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .compare-table-mobile {
    display: block !important;
  }

  /* ============================================
     Chakra images: hard-force perfect circle
     (Some global styles can still affect sizing)
     ============================================ */
  img.chakra-img {
    width: min(240px, 78vw) !important;
    height: min(240px, 78vw) !important;
    aspect-ratio: 1 / 1 !important;
    border-radius: 50% !important;
    object-fit: cover !important;
    clip-path: circle(50% at 50% 50%);
    display: block;
  }

  /* ============================================
     Footer: ensure bottom padding is visible
     (components.css sets small bottom padding)
     ============================================ */
  .footer {
    padding-bottom: 40px !important;
  }

  .footer .container {
    padding-bottom: 40px !important;
  }

  /* ============================================
     "50+ Testimonianze Video" Highlight Card
     Fix overflow on small screens
     ============================================ */
  .testimonials-highlight-card {
    padding: 18px !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .testimonials-highlight-card * {
    max-width: 100%;
    box-sizing: border-box;
  }

  .testimonials-video-circle {
    width: min(260px, 80vw) !important;
    height: min(260px, 80vw) !important;
    max-width: 100%;
  }

  .testimonials-video-circle .testimonials-video-icon {
    width: 86% !important;
    height: 86% !important;
    max-width: 100%;
  }

  .testimonials-video-button {
    display: inline-flex;
    max-width: 100%;
    white-space: normal;
    text-align: center;
    box-sizing: border-box;
  }

  .testimonials-video-button > span {
    max-width: 100%;
    flex-wrap: wrap !important;
    white-space: normal !important;
    box-sizing: border-box;
  }

  .testimonials-video-button > span > span {
    white-space: normal !important;
    word-break: break-word;
    overflow-wrap: anywhere;
  }

  /* ============================================
     Comparison Table (Mobile Only)
     - hide desktop table, show mobile stacked layout
     ============================================ */
  .compare-table-desktop {
    display: none !important;
  }

  .compare-table-mobile {
    display: block;
  }

  /* ============================================
     Footer spacing (Mobile Only)
     ============================================ */
  footer.footer {
    padding-bottom: 40px !important;
  }

  footer.footer .container {
    padding-bottom: 40px !important;
  }

  /* ============================================
     Floating CTA + WhatsApp on same line (Mobile Only)
     ============================================ */
  .floating-cta {
    left: 16px !important;
    right: 80px !important;
    bottom: calc(18px + env(safe-area-inset-bottom)) !important;
    transform: none !important;
    display: flex !important;
    justify-content: flex-start;
    z-index: 95;
    pointer-events: none;
    animation: none !important;
  }

  .whatsapp-float {
    bottom: calc(18px + env(safe-area-inset-bottom)) !important;
    right: 16px !important;
    width: 56px !important;
    height: 56px !important;
    z-index: 96;
  }

  .floating-cta .btn {
    pointer-events: auto;
    width: auto !important;
    max-width: calc(100vw - 16px - 16px - 56px - 12px);
    padding: 14px 18px !important;
    font-size: 14px !important;
    white-space: nowrap;
  }

  /* ============================================
     Mobile menu usability
     ============================================ */
  .mobile-menu {
    top: 72px;
    padding: 18px;
    gap: 12px;
    overflow-y: auto;
  }

  .mobile-menu a {
    padding: 14px 12px;
    font-size: 18px;
    font-weight: 600;
    border-bottom: 1px solid var(--border-color);
  }

  .mobile-menu .btn {
    padding: 14px 16px !important;
    font-size: 16px !important;
    min-height: 52px;
  }
}

/* Print Styles */
@media print {
  header, footer, .no-print {
    display: none;
  }

  body {
    font-size: 12pt;
    color: black;
    background: white;
  }

  a {
    text-decoration: underline;
  }

  .btn, .card {
    break-inside: avoid;
  }
}
