/* iOS PWA Safe Area Support */
/* This file provides comprehensive safe area inset support for iOS PWA */

/* CSS Custom Properties for safe area insets with fallbacks */
:root {
  --safe-area-inset-top: 0px;
  --safe-area-inset-left: 0px;
  --safe-area-inset-right: 0px;
  --safe-area-inset-bottom: 0px;
}

/* Use env() with fallbacks for browsers that support it */
@supports (padding-top: env(safe-area-inset-top)) {
  :root {
    --safe-area-inset-top: env(safe-area-inset-top);
    --safe-area-inset-left: env(safe-area-inset-left);
    --safe-area-inset-right: env(safe-area-inset-right);
    --safe-area-inset-bottom: env(safe-area-inset-bottom);
  }
}

/* Global body and html safe area support */
body {
  /* Ensure body respects safe areas */
  padding-top: var(--safe-area-inset-top);
  padding-left: var(--safe-area-inset-left);
  padding-right: var(--safe-area-inset-right);
  padding-bottom: var(--safe-area-inset-bottom);
}

/* Fixed header support */
@supports (-webkit-touch-callout: none) {
  header,
  .main-header,
  .navbar,
  .top-header {
    /* Add safe area padding to fixed headers - reduced padding */
    padding-top: calc(5px + var(--safe-area-inset-top));
    padding-left: calc(5px + var(--safe-area-inset-left));
    padding-right: calc(5px + var(--safe-area-inset-right));
  }
  
  /* Specific header fixes for different pages */
  /* Games page header fix */
  .games-index-page .header {
    padding-top: calc(2px + var(--safe-area-inset-top));
  }
  
  /* Events page header fix */
  .events-page .main-header,
  .events-page .header,
  .my-events-page .main-header,
  .my-events-page .header {
    padding-top: calc(2px + var(--safe-area-inset-top));
  }
  
  /* Live page header fix */
  .live-stream-page .main-header,
  .live-page .main-header {
    padding-top: calc(2px + var(--safe-area-inset-top));
  }
}

/* Fixed bottom elements support */
.bottom-menu,
.bottom-nav,
.fixed-bottom {
  /* Add safe area padding to fixed bottom elements */
  padding-bottom: calc(8px + var(--safe-area-inset-bottom));
  padding-left: var(--safe-area-inset-left);
  padding-right: var(--safe-area-inset-right);
}

/* Main content containers */
@supports (-webkit-touch-callout: none) {
  .main-container,
  .content-container,
  .page-container {
    /* Ensure main content doesn't overlap with safe areas */
    padding-top: calc(60px + var(--safe-area-inset-top));
    padding-left: var(--safe-area-inset-left);
    padding-right: var(--safe-area-inset-right);
    padding-bottom: var(--safe-area-inset-bottom);
  }
  
  /* Fix for post-content field */
  .post-creation-card {
    margin-top: 10px;
  }
  
  /* Fix for social container */
  .social-container {
    padding-top: calc(60px + var(--safe-area-inset-top)) !important;
    margin-top: 0 !important;
  }
}

/* Sticky elements */
.sticky-top,
.sticky-header {
  top: calc(0px + var(--safe-area-inset-top));
}

/* Modal and overlay support */
.modal,
.overlay,
.popup {
  /* Ensure modals respect safe areas */
  padding-top: var(--safe-area-inset-top);
  padding-left: var(--safe-area-inset-left);
  padding-right: var(--safe-area-inset-right);
  padding-bottom: var(--safe-area-inset-bottom);
}

/* Form elements and inputs - iOS only */
@supports (-webkit-touch-callout: none) {
  /* Only apply to form inputs, not buttons */
  input:not([type="button"]):not([type="submit"]):not([type="reset"]),
  textarea,
  select {
    /* Ensure form elements don't get cut off */
    min-height: 44px; /* iOS minimum touch target size */
  }
}

/* iOS-specific optimizations */
@supports (-webkit-touch-callout: none) {
  /* iOS-only media query */
  @media screen and (max-width: 768px) {
    /* Ensure proper spacing on mobile */
    body {
      /* Prevent horizontal scrolling on iOS */
      overflow-x: hidden;
      width: 100vw;
    }
    
    /* Improve touch targets on iOS - EXCEPT media buttons */
    button:not(.media-button),
    .button:not(.media-button),
    [role="button"]:not(.media-button) {
      min-height: 44px;
      min-width: 20px; /* Reduced minimum width as requested */
    }
    
    /* Special handling for media buttons on iOS */
    .media-button {
      min-height: 36px;
      min-width: 20px;
    }
    
    /* Special handling for AI buttons on iOS */
    .ai-button-fixed {
      min-height: 26px !important;
      min-width: 26px !important;
      height: 26px !important;
      width: 26px !important;
      padding: 0 !important;
    }
    
    /* Ensure proper text size for iOS */
    input,
    textarea,
    select {
      font-size: 16px; /* Prevents zoom on iOS */
    }
  }
}

/* Dark mode support for iOS */
@media (prefers-color-scheme: dark) {
  :root {
    /* Ensure safe areas work in dark mode */
    color-scheme: dark;
  }
}

/* Landscape orientation support */
@media screen and (orientation: landscape) {
  /* Adjust safe areas for landscape mode */
  body {
    padding-top: calc(var(--safe-area-inset-top) / 2);
    padding-bottom: calc(var(--safe-area-inset-bottom) / 2);
  }
}

/* iPhone X and newer support */
@supports (padding: max(0px)) {
  /* Use max() for better fallback support */
  body {
    padding-top: max(0px, var(--safe-area-inset-top));
    padding-left: max(0px, var(--safe-area-inset-left));
    padding-right: max(0px, var(--safe-area-inset-right));
    padding-bottom: max(0px, var(--safe-area-inset-bottom));
  }
} 