/* ===========================================
   MOBILE-SPECIFIC STYLES
   Fully independent from desktop UI
   Only applies at viewport <= 768px
   =========================================== */

@media (max-width: 768px) {
  /* Mobile dropdown container - must be relative for dropdown positioning */
  /* Override contain property that prevents dropdown from showing outside bounds */
  .js-dropdown-container {
    position: relative !important;
    overflow: visible !important;
    contain: none !important;
    content-visibility: visible !important;
    z-index: 1 !important; /* Default low z-index */
  }

  /* Elevate the container when dropdown is active so it sits on top of siblings */
  .js-dropdown-container.active-dropdown-container {
    z-index: 9999999 !important;
  }

  /* Standardize ALL mobile buttons inside dropdown containers */
  /* This ensures Athena, Timothy Groth, and all other clinic buttons match Generate Note size */
  .js-dropdown-container > button,
  .btn-general.generateBtnMobile {
    width: 369px !important;
    min-width: 369px !important;
    max-width: 369px !important;
    height: 54px !important;
    min-height: 54px !important;
    max-height: 54px !important;
    font-size: 18px !important;
    border-radius: 8px !important;
    margin: 5px auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    padding: 0 16px !important;
    gap: 8px !important;
    /* Ensure icons inside are sized correctly */
  }

  .js-dropdown-container > button i,
  .btn-general.generateBtnMobile i {
    font-size: 18px !important;
  }

  .js-dropdown-container > button span,
  .btn-general.generateBtnMobile span {
    font-size: 18px !important;
    font-weight: 500 !important;
  }

  /* Mobile dropdown menu - higher specificity to override .dropdown-menu display:none */
  .dropdown-menu.mobile-dropdown-active,
  .mobile-dropdown-active {
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    min-width: 100% !important;
    margin-top: 4px !important;
    background-color: white !important;
    border-radius: 8px !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.25) !important;
    z-index: 999999 !important;
    max-height: 60vh !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    transform: none !important;
  }

  /* Mobile dropdown items - high specificity */
  .dropdown-menu.mobile-dropdown-active .dropdown-item,
  .mobile-dropdown-active .dropdown-item {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    align-items: center !important;
    gap: 12px !important;
    width: 100% !important;
    padding: 14px 16px !important;
    min-height: 48px !important;
    text-align: left !important;
    font-size: 15px !important;
    font-weight: 500 !important;
    color: #333 !important;
    background-color: white !important;
    border: none !important;
    border-bottom: 1px solid #eee !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
  }

  .dropdown-menu.mobile-dropdown-active .dropdown-item:last-child,
  .mobile-dropdown-active .dropdown-item:last-child {
    border-bottom: none !important;
  }

  .dropdown-menu.mobile-dropdown-active .dropdown-item:hover,
  .dropdown-menu.mobile-dropdown-active .dropdown-item:active,
  .mobile-dropdown-active .dropdown-item:hover,
  .mobile-dropdown-active .dropdown-item:active {
    background-color: #f5f5f5 !important;
  }

  .dropdown-menu.mobile-dropdown-active .dropdown-item i,
  .mobile-dropdown-active .dropdown-item i {
    font-size: 16px !important;
    width: 20px !important;
    text-align: center !important;
    color: var(--blue, #335df3) !important;
  }

  /* Ensure parent containers don't clip the dropdown */
  .mobile-button-container,
  .mobile-button-container-2 {
    overflow: visible !important;
    contain: none !important;
    content-visibility: visible !important;
  }

  /* Override any containment on the main content area */
  .main-content,
  .content-wrapper {
    overflow: visible !important;
  }
}
