/* 
 * Mobile Responsiveness Fixes for Body Joga Studio
 * Comprehensive mobile optimizations focusing on calendar and overall UX
 */

/* ===========================================
 * Global Mobile Optimizations
 * =========================================== */

/* Better viewport handling */
@media (max-width: 480px) {
  html {
    font-size: 14px; /* Smaller base font for very small screens */
  }
  
  body {
    font-size: 14px;
    line-height: 1.4;
  }
}

/* Touch-friendly interactions */
@media (max-width: 768px) {
  * {
    -webkit-tap-highlight-color: rgba(139, 111, 71, 0.3);
  }
  
  /* Larger touch targets */
  button, .btn, a, input, select, textarea {
    min-height: 44px !important;
    min-width: 44px !important;
  }
  
  /* Better text sizing */
  p, span, div {
    font-size: 16px !important; /* Prevent zoom on iOS */
  }
  
  input, select, textarea {
    font-size: 16px !important;
  }
}

/* ===========================================
 * Navigation Mobile Fixes
 * =========================================== */

@media (max-width: 768px) {
  .navbar[data-v-57792a44] {
    padding: 8px 16px !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1000 !important;
  }
  
  /* Hide user info in desktop nav on mobile */
  .desktop-nav[data-v-57792a44] {
    display: none !important;
  }
  
  /* Hide user info elements in header on mobile */
  .auth-buttons[data-v-57792a44],
  .user-info[data-v-57792a44] {
    display: none !important;
  }
  
  .mobile-nav[data-v-57792a44] {
    position: fixed !important;
    top: 70px !important;
    left: 0 !important;
    right: 0 !important;
    background: rgba(255, 255, 255, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    z-index: 999 !important;
    max-height: calc(100vh - 70px) !important;
    overflow-y: auto !important;
  }
  
  .mobile-nav-item[data-v-57792a44] {
    padding: 16px 20px !important;
    border-bottom: 1px solid rgba(139, 111, 71, 0.1) !important;
    font-size: 18px !important;
  }
  
  /* Show user info only in mobile menu */
  .mobile-user-info[data-v-57792a44] {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 16px 20px !important;
    background: rgba(139, 111, 71, 0.1) !important;
    border-bottom: 2px solid rgba(139, 111, 71, 0.2) !important;
    margin-bottom: 8px !important;
  }
  
  .mobile-auth-buttons[data-v-57792a44] {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 16px 20px !important;
    border-top: 1px solid rgba(139, 111, 71, 0.1) !important;
    margin-top: 8px !important;
  }
  
  .mobile-auth-buttons .btn {
    width: 100% !important;
    justify-content: center !important;
    padding: 12px !important;
    font-size: 16px !important;
  }
}

@media (max-width: 480px) {
  .navbar[data-v-57792a44] {
    padding: 6px 12px !important;
  }
  
  .logo-text[data-v-57792a44] {
    font-size: 1.1rem !important;
  }
  
  .flower-of-life[data-v-57792a44] {
    width: 24px !important;
    height: 24px !important;
  }
}

/* ===========================================
 * Calendar (Schedule) Mobile Optimizations
 * =========================================== */

/* Mobile Calendar Grid - Complete Redesign */
@media (max-width: 768px) {
  .schedule-grid[data-v-760ee808] {
    display: block !important;
    grid-template-columns: none !important;
    grid-template-rows: none !important;
    overflow-x: visible !important;
    overflow-y: auto !important;
    border: none !important;
    background: transparent !important;
    backdrop-filter: none !important;
  }
  
  /* Day-based layout for mobile */
  .schedule-mobile-day {
    background: rgba(255, 255, 255, 0.6) !important;
    backdrop-filter: blur(10px) !important;
    border-radius: 12px !important;
    margin-bottom: 20px !important;
    border: 1px solid rgba(139, 111, 71, 0.2) !important;
    overflow: hidden !important;
  }
  
  .schedule-mobile-day-header {
    background: linear-gradient(135deg, #8b6f47, #a68b5b) !important;
    color: white !important;
    padding: 16px 20px !important;
    text-align: center !important;
    font-weight: bold !important;
    font-size: 18px !important;
  }
  
  .schedule-mobile-day-date {
    font-size: 14px !important;
    opacity: 0.9 !important;
    margin-top: 4px !important;
  }
  
  .schedule-mobile-times {
    padding: 12px !important;
  }
  
  .schedule-mobile-time-slot {
    display: flex !important;
    align-items: center !important;
    padding: 12px 16px !important;
    border-bottom: 1px solid rgba(139, 111, 71, 0.1) !important;
    min-height: 60px !important;
  }
  
  .schedule-mobile-time-slot:last-child {
    border-bottom: none !important;
  }
  
  .schedule-mobile-time {
    font-weight: bold !important;
    color: #8b6f47 !important;
    min-width: 80px !important;
    font-size: 14px !important;
  }
  
  .schedule-mobile-class {
    flex: 1 !important;
    margin-left: 16px !important;
    padding: 12px 16px !important;
    border-radius: 8px !important;
    background: linear-gradient(135deg, #8b6f47, #a68b5b) !important;
    color: white !important;
    cursor: pointer !important;
    transition: all 0.3s ease !important;
  }
  
  .schedule-mobile-class:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 4px 12px rgba(139, 111, 71, 0.3) !important;
  }
  
  .schedule-mobile-class-title {
    font-weight: bold !important;
    font-size: 16px !important;
    margin-bottom: 4px !important;
  }
  
  .schedule-mobile-class-instructor {
    font-size: 14px !important;
    opacity: 0.9 !important;
    margin-bottom: 4px !important;
  }
  
  .schedule-mobile-class-info {
    font-size: 12px !important;
    opacity: 0.8 !important;
  }
  
  .schedule-mobile-empty {
    flex: 1 !important;
    margin-left: 16px !important;
    padding: 12px 16px !important;
    border: 2px dashed #8b6f47 !important;
    border-radius: 8px !important;
    text-align: center !important;
    color: #8b6f47 !important;
    font-size: 14px !important;
    opacity: 0.6 !important;
  }
  
  /* Hide original grid headers and cells on mobile */
  .day-header[data-v-760ee808],
  .time-header[data-v-760ee808],
  .time-cell[data-v-760ee808],
  .schedule-cell[data-v-760ee808] {
    display: none !important;
  }
}

@media (max-width: 480px) {
  .schedule-container[data-v-760ee808] {
    padding: 12px !important;
  }
  
  .schedule-mobile-day-header {
    padding: 12px 16px !important;
    font-size: 16px !important;
  }
  
  .schedule-mobile-day-date {
    font-size: 12px !important;
  }
  
  .schedule-mobile-time-slot {
    flex-direction: column !important;
    align-items: stretch !important;
    padding: 12px !important;
  }
  
  .schedule-mobile-time {
    margin-bottom: 8px !important;
    text-align: center !important;
    background: rgba(139, 111, 71, 0.1) !important;
    padding: 8px !important;
    border-radius: 6px !important;
    min-width: auto !important;
  }
  
  .schedule-mobile-class,
  .schedule-mobile-empty {
    margin-left: 0 !important;
    margin-top: 8px !important;
  }
  
  .schedule-mobile-class-title {
    font-size: 14px !important;
  }
  
  .schedule-mobile-class-instructor,
  .schedule-mobile-class-info {
    font-size: 12px !important;
  }
}

/* ===========================================
 * Week Navigation Mobile
 * =========================================== */

@media (max-width: 768px) {
  .week-navigation[data-v-760ee808] {
    flex-direction: column !important;
    gap: 16px !important;
    padding: 16px !important;
  }
  
  .week-navigation h2[data-v-760ee808] {
    font-size: 20px !important;
    padding: 12px 16px !important;
    margin: 0 !important;
  }
  
  .week-nav-buttons {
    display: flex !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }
  
  .week-nav-buttons .btn[data-v-760ee808] {
    flex: 1 !important;
    padding: 12px 8px !important;
    font-size: 14px !important;
  }
}

@media (max-width: 480px) {
  .week-navigation h2[data-v-760ee808] {
    font-size: 18px !important;
    padding: 10px 12px !important;
  }
  
  .week-nav-buttons .btn[data-v-760ee808] {
    padding: 10px 6px !important;
    font-size: 12px !important;
  }
}

/* ===========================================
 * Modal Mobile Optimizations
 * =========================================== */

@media (max-width: 768px) {
  .modal-overlay[data-v-760ee808] {
    padding: 20px 10px !important;
  }
  
  .modal-content[data-v-760ee808],
  .beautiful-modal-content[data-v-760ee808] {
    width: 95vw !important;
    max-width: 95vw !important;
    max-height: 85vh !important;
    margin: 0 !important;
  }
  
  .modal-header[data-v-760ee808],
  .modal-header-beautiful[data-v-760ee808] {
    padding: 16px !important;
  }
  
  .modal-body[data-v-760ee808],
  .beautiful-form[data-v-760ee808] {
    padding: 16px !important;
  }
  
  .form-row[data-v-760ee808],
  .form-row-beautiful[data-v-760ee808] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  
  .modal-actions[data-v-760ee808],
  .form-actions-beautiful[data-v-760ee808] {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .modal-actions button,
  .form-actions-beautiful button {
    width: 100% !important;
    justify-content: center !important;
  }
}

@media (max-width: 480px) {
  .modal-overlay[data-v-760ee808] {
    padding: 10px 5px !important;
  }
  
  .modal-content[data-v-760ee808],
  .beautiful-modal-content[data-v-760ee808] {
    width: 98vw !important;
    max-width: 98vw !important;
    max-height: 90vh !important;
    border-radius: 8px !important;
  }
  
  .modal-header[data-v-760ee808],
  .modal-header-beautiful[data-v-760ee808] {
    padding: 12px !important;
  }
  
  .modal-body[data-v-760ee808],
  .beautiful-form[data-v-760ee808] {
    padding: 12px !important;
  }
  
  .modal-header h3,
  .modal-header-beautiful h3 {
    font-size: 18px !important;
  }
}

/* ===========================================
 * Forms Mobile Optimizations
 * =========================================== */

@media (max-width: 768px) {
  .form-group[data-v-760ee808],
  .form-group-beautiful[data-v-760ee808] {
    margin-bottom: 16px !important;
  }
  
  .form-group input[data-v-760ee808],
  .form-group select[data-v-760ee808],
  .form-group textarea[data-v-760ee808],
  .form-group-beautiful input[data-v-760ee808],
  .form-group-beautiful select[data-v-760ee808],
  .form-group-beautiful textarea[data-v-760ee808] {
    padding: 12px 16px !important;
    font-size: 16px !important;
    border-radius: 8px !important;
  }
  
  .form-group label[data-v-760ee808],
  .form-group-beautiful label[data-v-760ee808] {
    font-size: 14px !important;
    margin-bottom: 8px !important;
  }
}

/* ===========================================
 * Hero Section Mobile Fixes
 * =========================================== */

@media (max-width: 768px) {
  .hero[data-v-c5e0ba04],
  .hero[data-v-2b0d8be0] {
    min-height: 50vh !important;
    padding: 24px 16px !important;
    margin: 12px !important;
    text-align: center !important;
  }
  
  .hero-content[data-v-c5e0ba04] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }
  
  .hero-title[data-v-c5e0ba04],
  .hero-title[data-v-2b0d8be0] {
    font-size: 2rem !important;
    line-height: 1.2 !important;
  }
  
  .hero-subtitle[data-v-c5e0ba04],
  .hero-subtitle[data-v-2b0d8be0] {
    font-size: 1.1rem !important;
    line-height: 1.5 !important;
  }
  
  .hero-features[data-v-c5e0ba04] {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .hero-buttons[data-v-c5e0ba04] {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .hero-buttons .btn {
    width: 100% !important;
    max-width: 300px !important;
    margin: 0 auto !important;
  }
}

@media (max-width: 480px) {
  .hero[data-v-c5e0ba04],
  .hero[data-v-2b0d8be0] {
    min-height: 40vh !important;
    padding: 20px 12px !important;
    margin: 8px !important;
  }
  
  .hero-title[data-v-c5e0ba04],
  .hero-title[data-v-2b0d8be0] {
    font-size: 1.75rem !important;
  }
  
  .hero-subtitle[data-v-c5e0ba04],
  .hero-subtitle[data-v-2b0d8be0] {
    font-size: 1rem !important;
  }
}

/* ===========================================
 * Section and Grid Mobile Fixes
 * =========================================== */

@media (max-width: 768px) {
  .section[data-v-c5e0ba04],
  .section[data-v-2b0d8be0] {
    margin: 12px !important;
    padding: 20px 16px !important;
  }
  
  .services-grid[data-v-c5e0ba04],
  .pricing-grid[data-v-c5e0ba04],
  .instructors-grid[data-v-6f18a782] {
    grid-template-columns: 1fr !important;
    gap: 20px !important;
  }
  
  .welcome-content[data-v-c5e0ba04],
  .studio-content[data-v-2b0d8be0],
  .opening-content[data-v-2b0d8be0] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    text-align: center !important;
  }
}

@media (max-width: 480px) {
  .section[data-v-c5e0ba04],
  .section[data-v-2b0d8be0] {
    margin: 8px !important;
    padding: 16px 12px !important;
  }
  
  .service-card[data-v-c5e0ba04],
  .pricing-card[data-v-c5e0ba04] {
    margin: 0 !important;
  }
}

/* ===========================================
 * Instructor Pages Mobile
 * =========================================== */

@media (max-width: 768px) {
  .instructor-header[data-v-6f18a782] {
    flex-direction: column !important;
    text-align: center !important;
    gap: 20px !important;
  }
  
  .instructor-avatar img[data-v-6f18a782] {
    width: 100px !important;
    height: 100px !important;
  }
  
  .instructor-profile .instructor-name[data-v-6f18a782] {
    font-size: 1.5rem !important;
  }
  
  .instructor-badges[data-v-6f18a782] {
    justify-content: center !important;
  }
  
  .schedule-time[data-v-6f18a782] {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: center !important;
  }
  
  .instructor-description[data-v-6f18a782] {
    font-size: 1rem !important;
  }
}

@media (max-width: 480px) {
  .instructor-profile .instructor-card[data-v-6f18a782] {
    padding: 16px !important;
  }
  
  .instructor-avatar img[data-v-6f18a782] {
    width: 80px !important;
    height: 80px !important;
  }
  
  .instructor-profile .instructor-name[data-v-6f18a782] {
    font-size: 1.3rem !important;
  }
  
  .schedule-content h5[data-v-6f18a782] {
    font-size: 1.1rem !important;
  }
}

/* ===========================================
 * Footer Mobile
 * =========================================== */

@media (max-width: 768px) {
  .footer[data-v-d343f254] {
    padding: 32px 0 16px !important;
  }
  
  .footer-content[data-v-d343f254] {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
    text-align: center !important;
  }
  
  .footer-bottom-content[data-v-d343f254] {
    flex-direction: column !important;
    gap: 16px !important;
    text-align: center !important;
  }
  
  .footer-bottom .footer-links[data-v-d343f254] {
    justify-content: center !important;
  }
}

@media (max-width: 480px) {
  .footer-bottom .footer-links[data-v-d343f254] {
    flex-direction: column !important;
    gap: 12px !important;
  }
}

/* ===========================================
 * Button Mobile Optimizations
 * =========================================== */

@media (max-width: 768px) {
  .btn[data-v-760ee808],
  .btn {
    padding: 12px 20px !important;
    font-size: 16px !important;
    border-radius: 8px !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
  }
  
  .btn-secondary[data-v-760ee808] {
    background: linear-gradient(135deg, #8b6f47, #a68b5b) !important;
  }
  
  .cta-buttons[data-v-c5e0ba04],
  .cta-buttons[data-v-2b0d8be0] {
    flex-direction: column !important;
    align-items: center !important;
    gap: 12px !important;
  }
  
  .cta-buttons .btn {
    width: 100% !important;
    max-width: 280px !important;
  }
}

/* ===========================================
 * Legend Mobile
 * =========================================== */

@media (max-width: 768px) {
  .legend[data-v-760ee808] {
    padding: 20px 16px !important;
    margin-top: 20px !important;
  }
  
  .legend-items[data-v-760ee808] {
    flex-direction: column !important;
    gap: 12px !important;
  }
  
  .legend-item[data-v-760ee808] {
    justify-content: center !important;
    padding: 12px 16px !important;
  }
  
  .legend h3[data-v-760ee808] {
    font-size: 18px !important;
    margin-bottom: 16px !important;
  }
}

/* ===========================================
 * Booking Status Mobile
 * =========================================== */

@media (max-width: 768px) {
  .booking-actions[data-v-760ee808] {
    flex-direction: column !important;
    gap: 8px !important;
  }
  
  .btn-book[data-v-760ee808],
  .btn-cancel-booking[data-v-760ee808] {
    width: 100% !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
  }
  
  .booking-status-success[data-v-760ee808],
  .booking-status.completed[data-v-760ee808] {
    flex-direction: column !important;
    text-align: center !important;
    gap: 8px !important;
  }
  
  .cancel-info[data-v-760ee808] {
    max-width: none !important;
    text-align: center !important;
  }
}

/* ===========================================
 * Rental Page Mobile (if exists)
 * =========================================== */

@media (max-width: 768px) {
  .rental-page[data-v-0ef38d9e] {
    padding: 16px 12px !important;
  }
  
  .rental-form,
  .rental-info {
    margin: 12px 0 !important;
    padding: 16px !important;
  }
}

/* ===========================================
 * Utility Classes for Mobile
 * =========================================== */

@media (max-width: 768px) {
  .mobile-hidden {
    display: none !important;
  }
  
  .mobile-full-width {
    width: 100% !important;
  }
  
  .mobile-center {
    text-align: center !important;
  }
  
  .mobile-stack {
    flex-direction: column !important;
  }
  
  .mobile-gap-small {
    gap: 12px !important;
  }
  
  .mobile-padding {
    padding: 16px !important;
  }
  
  .mobile-margin {
    margin: 12px !important;
  }
}

/* ===========================================
 * Accessibility & Performance
 * =========================================== */

@media (max-width: 768px) {
  /* Reduce animations for better performance */
  .reduce-motion {
    animation: none !important;
    transition: none !important;
  }
  
  /* Better focus states for touch */
  button:focus,
  input:focus,
  select:focus,
  textarea:focus,
  .btn:focus {
    outline: 3px solid rgba(139, 111, 71, 0.5) !important;
    outline-offset: 2px !important;
  }
  
  /* Larger clickable areas */
  .schedule-mobile-class {
    position: relative !important;
  }
  
  .schedule-mobile-class::after {
    content: '' !important;
    position: absolute !important;
    top: -10px !important;
    left: -10px !important;
    right: -10px !important;
    bottom: -10px !important;
  }
}

/* ===========================================
 * Landscape orientation fixes
 * =========================================== */

@media (max-width: 768px) and (orientation: landscape) {
  .hero[data-v-c5e0ba04],
  .hero[data-v-2b0d8be0] {
    min-height: 70vh !important;
  }
  
  .modal-content[data-v-760ee808],
  .beautiful-modal-content[data-v-760ee808] {
    max-height: 75vh !important;
  }
}
