/* ==========================
  MOBILE GANTT CHART OPTIMIZATION
  Enhanced horizontal overflow and mobile optimization for FestivalBuildGanttChart
========================== */

@media (max-width: 480px) {
  /* Ultra-small mobile devices - Gantt Chart */
  .gantt-chart-container, 
  .festival-build-gantt,
  [data-component="FestivalBuildGanttChart"],
  .gantt-chart-wrapper {
    width: 100% !important;
    min-width: 1200px !important; /* Ensure wide enough for chart readability */
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 4px !important;
    margin: 0 !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
    scrollbar-color: #ff8800 transparent !important;
  }
  
  /* Gantt chart SVG ultra-mobile optimization */
  .gantt-chart-container svg,
  .festival-build-gantt svg,
  [data-component="FestivalBuildGanttChart"] svg {
    min-width: 1200px !important;
    width: 1200px !important;
    height: auto !important;
    max-height: 60vh !important;
  }
  
  /* Gantt chart controls ultra-mobile */
  .gantt-controls,
  .chart-controls {
    flex-direction: column !important;
    gap: 8px !important;
    padding: 8px !important;
    margin: 8px 0 !important;
  }
  
  /* Gantt chart headers */
  .gantt-header,
  .chart-header {
    padding: 8px !important;
    font-size: 14px !important;
    text-align: center !important;
  }
}

@media (max-width: 768px) {
  /* Standard mobile devices - Gantt Chart */
  .gantt-chart-container, 
  .festival-build-gantt,
  [data-component="FestivalBuildGanttChart"],
  .gantt-chart-wrapper {
    width: 100% !important;
    min-width: 1000px !important; /* Ensure minimum width for chart readability */
    overflow-x: auto !important;
    overflow-y: hidden !important;
    padding: 8px !important;
    margin: 0 !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: thin !important;
    scrollbar-color: #ff8800 transparent !important;
  }
  
  /* Gantt chart SVG mobile optimization */
  .gantt-chart-container svg,
  .festival-build-gantt svg,
  [data-component="FestivalBuildGanttChart"] svg {
    min-width: 1000px !important;
    width: 1000px !important;
    height: auto !important;
    max-height: 70vh !important;
  }
  
  /* Gantt chart controls mobile optimization */
  .gantt-controls,
  .chart-controls {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 12px !important;
    justify-content: center !important;
  }
  
  /* Gantt chart control buttons */
  .gantt-controls button,
  .chart-controls button {
    padding: 8px 12px !important;
    font-size: 12px !important;
    min-width: 80px !important;
  }
  
  /* Gantt chart headers mobile */
  .gantt-header,
  .chart-header {
    padding: 12px !important;
    font-size: 16px !important;
  }
}

/* ==========================
  MOBILE HEADERS AND CONTAINERS
  Enhanced padding and spacing for mobile headers and containers
========================== */

@media (max-width: 480px) {
  /* Ultra-small mobile devices */
  .platform-container {
    padding: 8px !important;
    margin: 0 !important;
  }
  
  .dashboard-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  
  .dashboard-card {
    min-height: 120px !important;
    padding: 12px !important;
  }
  
  .card-title {
    font-size: 14px !important;
  }
  
  .card-value {
    font-size: 18px !important;
  }
  
  /* Headers and titles */
  .platform-header,
  .section-header,
  .page-header {
    padding: 12px 16px !important;
    font-size: 18px !important;
    margin-bottom: 12px !important;
  }
  
  .sub-header {
    padding: 8px 16px !important;
    font-size: 14px !important;
    margin-bottom: 8px !important;
  }
  
  /* Content containers */
  .content-container,
  .main-content,
  .dashboard-content {
    padding: 12px 16px !important;
    margin: 8px 0 !important;
  }
  
  .section-container {
    padding: 12px !important;
    margin: 8px 0 !important;
    border-radius: 8px !important;
  }
  
  /* Card containers */
  .card-container {
    padding: 12px !important;
    margin: 8px 0 !important;
  }
  
  .card-header {
    padding: 8px 12px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
  }
  
  .card-body {
    padding: 12px !important;
  }
  
  .card-footer {
    padding: 8px 12px !important;
  }
}

@media (max-width: 768px) {
  /* Standard mobile devices */
  .platform-container {
    padding: 12px !important;
    overflow-x: hidden !important;
  }
  
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)) !important;
    gap: 12px !important;
  }
  
  .dashboard-card {
    min-height: 140px !important;
    padding: 16px !important;
  }
  
  .financial-overview {
    flex-direction: column !important;
  }
  
  .spend-analysis-panel {
    margin-top: 16px !important;
  }
  
  .project-status-grid {
    grid-template-columns: 1fr !important;
  }
  
  .activity-feed {
    max-height: 300px !important;
    overflow-y: auto !important;
  }
  
  /* Headers and titles mobile */
  .platform-header,
  .section-header,
  .page-header {
    padding: 16px 20px !important;
    font-size: 20px !important;
    margin-bottom: 16px !important;
  }
  
  .sub-header {
    padding: 12px 20px !important;
    font-size: 16px !important;
    margin-bottom: 12px !important;
  }
  
  /* Content containers mobile */
  .content-container,
  .main-content,
  .dashboard-content {
    padding: 16px 20px !important;
    margin: 12px 0 !important;
  }
  
  .section-container {
    padding: 16px !important;
    margin: 12px 0 !important;
    border-radius: 12px !important;
  }
  
  /* Card containers mobile */
  .card-container {
    padding: 16px !important;
    margin: 12px 0 !important;
  }
  
  .card-header {
    padding: 12px 16px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
  }
  
  .card-body {
    padding: 16px !important;
  }
  
  .card-footer {
    padding: 12px 16px !important;
  }
}

/* ==========================
  NAVBAR RESPONSIVE DESIGN
  Enhanced mobile responsiveness for Schedule Follow-up and navbar features
========================== */

/* Mobile navbar optimizations */
@media (max-width: 480px) {
  .navbar-icons {
    gap: 4px !important;
  }
  
  .navbar-icon {
    font-size: 18px !important;
    padding: 2px !important;
  }
  
  .notification-badge {
    top: 3px !important;
    right: 3px !important;
    min-width: 14px !important;
    height: 14px !important;
    font-size: 10px !important;
  }
}

/* ==========================
  SCHEDULE FOLLOW-UP MODAL MOBILE OPTIMIZATION
  Enhanced mobile responsiveness for Schedule Follow-up modal and AI Auto Rescheduler
========================== */

@media (max-width: 480px) {
  /* Ultra-small mobile - Schedule Follow-up Modal */
  .follow-up-modal-overlay {
    padding: 8px !important;
    align-items: flex-start !important;
    padding-top: 20px !important;
  }
  
  .follow-up-modal,
  [data-component="FollowUpModal"] {
    width: calc(100vw - 16px) !important;
    height: calc(100vh - 40px) !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 16px !important;
    border-radius: 12px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* Modal header mobile */
  .follow-up-modal-header {
    padding: 12px 16px !important;
    font-size: 16px !important;
    position: sticky !important;
    top: 0 !important;
    background: rgba(15, 15, 18, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    z-index: 100 !important;
  }
  
  /* Modal content mobile */
  .follow-up-modal-content {
    padding: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }
  
  /* Form sections mobile */
  .follow-up-form-section {
    margin-bottom: 16px !important;
  }
  
  .follow-up-form-group {
    margin-bottom: 12px !important;
  }
  
  .follow-up-form-label {
    font-size: 14px !important;
    margin-bottom: 8px !important;
    display: block !important;
  }
  
  .follow-up-form-input,
  .follow-up-form-select,
  .follow-up-form-textarea {
    font-size: 16px !important; /* Prevents zoom on iOS */
    padding: 12px !important;
    width: 100% !important;
    border-radius: 8px !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    background: rgba(30, 30, 35, 0.8) !important;
    color: #ffffff !important;
  }
  
  /* Time picker mobile */
  .follow-up-time-picker {
    flex-direction: column !important;
    gap: 8px !important;
  }
  
  .follow-up-time-select {
    width: 100% !important;
  }
  
  /* Attendees section mobile */
  .follow-up-attendees-section {
    max-height: 200px !important;
    overflow-y: auto !important;
  }
  
  .follow-up-attendees-list {
    max-height: 150px !important;
    overflow-y: auto !important;
  }
  
  /* Action buttons mobile */
  .follow-up-action-buttons {
    flex-direction: column !important;
    gap: 8px !important;
    padding-top: 16px !important;
    position: sticky !important;
    bottom: 0 !important;
    background: rgba(15, 15, 18, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    margin: 0 -16px -16px -16px !important;
    padding: 16px !important;
  }
  
  .follow-up-action-button {
    width: 100% !important;
    padding: 14px !important;
    font-size: 16px !important;
    border-radius: 8px !important;
    min-height: 44px !important;
  }
  
  /* AI Auto Rescheduler Panel Mobile */
  .ai-rescheduler-panel {
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    background: rgba(15, 15, 18, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    border-radius: 12px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* AI panel content mobile */
  .ai-rescheduler-content {
    padding: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
  }
  
  /* AI sliders mobile */
  .ai-priority-slider {
    margin-bottom: 16px !important;
  }
  
  .ai-slider-label {
    font-size: 14px !important;
    margin-bottom: 8px !important;
  }
  
  .ai-slider-input {
    width: 100% !important;
    height: 6px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border-radius: 3px !important;
    outline: none !important;
    appearance: none !important;
    cursor: pointer !important;
  }
}

@media (max-width: 768px) {
  /* Standard mobile - Schedule Follow-up Modal */
  .follow-up-modal-overlay {
    padding: 16px !important;
    align-items: flex-start !important;
    padding-top: 40px !important;
  }
  
  .follow-up-modal,
  [data-component="FollowUpModal"] {
    width: calc(100vw - 32px) !important;
    height: calc(100vh - 80px) !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 20px !important;
    border-radius: 16px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* Modal content standard mobile */
  .follow-up-modal-content {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }
  
  /* Form elements standard mobile */
  .follow-up-form-input,
  .follow-up-form-select,
  .follow-up-form-textarea {
    font-size: 16px !important;
    padding: 14px !important;
    border-radius: 8px !important;
  }
  
  /* Time picker standard mobile */
  .follow-up-time-picker {
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
  
  /* Attendees section standard mobile */
  .follow-up-attendees-section {
    max-height: 250px !important;
    overflow-y: auto !important;
  }
  
  /* Action buttons standard mobile */
  .follow-up-action-buttons {
    flex-direction: column !important;
    gap: 12px !important;
    padding-top: 20px !important;
  }
  
  .follow-up-action-button {
    width: 100% !important;
    padding: 16px !important;
    font-size: 16px !important;
    min-height: 44px !important;
  }
  
  /* AI Auto Rescheduler Panel Standard Mobile */
  .ai-rescheduler-panel {
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    top: 0 !important;
    right: 0 !important;
    background: rgba(15, 15, 18, 0.95) !important;
    backdrop-filter: blur(10px) !important;
    border-radius: 16px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* AI panel content standard mobile */
  .ai-rescheduler-content {
    padding: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }
}

@media (max-width: 768px) {
  .navbar-container {
    padding: 8px 16px !important;
  }
  
  .navbar-icons {
    gap: 6px !important;
  }
  
  .navbar-icon {
    font-size: 20px !important;
    padding: 3px !important;
  }
  
  .notification-popup {
    width: 100vw !important;
    max-width: none !important;
    left: 0 !important;
    right: 0 !important;
    top: 60px !important;
    border-radius: 0 !important;
    max-height: calc(100vh - 60px) !important;
  }
  
  .notification-header {
    padding: 16px !important;
    font-size: 18px !important;
  }
  
  .notification-categories {
    flex-wrap: wrap !important;
    padding: 8px 16px !important;
  }
  
  .notification-category-button {
    font-size: 12px !important;
    padding: 6px 12px !important;
    margin: 2px !important;
  }
  
  .notification-list {
    padding: 0 16px !important;
  }
  
  .notification-card {
    margin-bottom: 12px !important;
    padding: 12px !important;
  }
  
  /* Schedule Follow-up modal tablet optimization */
  .follow-up-modal {
    width: 90vw !important;
    max-width: 500px !important;
    margin: 10vh auto !important;
  }
  
  .follow-up-modal-content {
    padding: 20px !important;
  }
  
  .follow-up-time-picker {
    flex-wrap: wrap !important;
    gap: 12px !important;
  }
  
  .follow-up-attendees-section {
    max-height: 200px !important;
    overflow-y: auto !important;
  }
}

/* ==========================
  PLATFORM GRID RESPONSIVE DESIGN
  Enhanced responsiveness for dashboard grid layouts
========================== */

/* Ultra-wide screens */
@media (min-width: 1920px) {
  .platform-container {
    max-width: 1800px !important;
    margin: 0 auto !important;
  }
  
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
    gap: 24px !important;
  }
}

/* Large screens */
@media (min-width: 1200px) and (max-width: 1919px) {
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)) !important;
    gap: 20px !important;
  }
}

/* Medium screens */
@media (min-width: 769px) and (max-width: 1199px) {
  .dashboard-grid {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)) !important;
    gap: 16px !important;
  }
  
  .financial-overview {
    flex-direction: column !important;
  }
  
  .spend-analysis-panel {
    margin-top: 16px !important;
  }
}

/* ==========================
  SEARCH BAR RESPONSIVE ENHANCEMENTS
  Additional improvements for search functionality
========================== */

@media (max-width: 480px) {
  .search-bar-container {
    width: 100% !important;
    max-width: none !important;
  }
  
  .search-input {
    width: 100% !important;
    padding: 8px 12px !important;
  }
  
  .search-results {
    position: fixed !important;
    top: 60px !important;
    left: 0 !important;
    right: 0 !important;
    max-height: calc(100vh - 60px) !important;
    border-radius: 0 !important;
    z-index: 9999 !important;
  }
}

/* ==========================
  TOUCH OPTIMIZATION
  Enhanced touch targets and gestures for mobile
========================== */

@media (max-width: 768px) {
  /* Ensure all interactive elements have minimum 44px touch targets */
  .navbar-icon,
  .follow-up-action-button,
  .notification-action-button,
  .dashboard-card button {
    min-width: 44px !important;
    min-height: 44px !important;
  }
  
  /* Improve scrolling performance */
  .notification-popup,
  .follow-up-modal,
  .activity-feed,
  .platform-container {
    -webkit-overflow-scrolling: touch !important;
    scroll-behavior: smooth !important;
  }
  
  /* Prevent zooming on form inputs */
  .follow-up-form-input,
  .follow-up-form-select,
  .follow-up-form-textarea,
  .search-input {
    font-size: 16px !important;
  }
}

/* ==========================
  ACCESSIBILITY IMPROVEMENTS
  Enhanced accessibility for mobile devices
========================== */

@media (max-width: 768px) {
  /* High contrast mode support */
  @media (prefers-contrast: high) {
    .dashboard-card {
      border: 2px solid currentColor !important;
    }
    
    .notification-card {
      border: 1px solid currentColor !important;
    }
  }
  
  /* Reduced motion support */
  @media (prefers-reduced-motion: reduce) {
    .follow-up-modal,
    .notification-popup,
    .dashboard-card {
      animation: none !important;
      transition: none !important;
    }
  }
  
  /* Focus indicators */
  .navbar-icon:focus,
  .follow-up-action-button:focus,
  .notification-action-button:focus {
    outline: 2px solid #4285f4 !important;
    outline-offset: 2px !important;
  }
}

/* ==========================
  PERFORMANCE OPTIMIZATIONS
  Optimized rendering for mobile devices
========================== */

@media (max-width: 768px) {
  /* Use transform instead of changing layout properties */
  .follow-up-modal {
    transform: translateZ(0) !important;
    will-change: transform !important;
  }
  
  .notification-popup {
    transform: translateZ(0) !important;
    will-change: transform !important;
  }
  
  /* Optimize repaints */
  .dashboard-card {
    contain: layout style paint !important;
  }
  
  /* Reduce shadow complexity on mobile */
  .follow-up-modal,
  .notification-popup {
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15) !important;
  }
}

/* ==========================
  DARK MODE MOBILE OPTIMIZATIONS
  Enhanced dark mode experience for mobile
========================== */

@media (max-width: 768px) {
  [data-theme="dark"] .platform-container {
    background-color: #1a1a1a !important;
  }
  
  [data-theme="dark"] .dashboard-card {
    background-color: #2d2d2d !important;
    border-color: #404040 !important;
  }
  
  [data-theme="dark"] .follow-up-modal {
    background-color: #2d2d2d !important;
    border-color: #404040 !important;
  }
  
  [data-theme="dark"] .notification-popup {
    background-color: #2d2d2d !important;
    border-color: #404040 !important;
  }
  
  [data-theme="dark"] .follow-up-form-input,
  [data-theme="dark"] .follow-up-form-select,
  [data-theme="dark"] .follow-up-form-textarea {
    background-color: #1a1a1a !important;
    border-color: #404040 !important;
    color: #ffffff !important;
  }
}
