/* Mobile Design - Phone Screen Sizes Only (max-width: 932px) */

/* Base Mobile Optimizations */
* {
  -webkit-tap-highlight-color: rgba(106, 183, 255, 0.2);
  -webkit-touch-callout: none;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
}

/* Phone Screen Sizes Only */
@media (max-width: 932px) {
  /* Reset all desktop layouts */
  body {
    display: block !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
  }
  
  /* Mobile Sidebar - Slide in from left */
  .sidebar {
    position: fixed !important;
    top: 0 !important;
    left: -100% !important;
    width: 280px !important;
    max-width: 85vw !important;
    height: 100vh !important;
    z-index: 12000 !important;
    background: rgba(17, 26, 34, 0.98) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-right: 1px solid rgba(255, 255, 255, 0.1) !important;
    transition: left 0.3s ease !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    display: block !important;
    box-shadow: 2px 0 8px rgba(0, 0, 0, 0.3) !important;
  }

  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
  }

  body.mobile-lock {
    position: fixed !important;
    width: 100% !important;
    left: 0 !important;
    right: 0 !important;
    overflow: hidden !important;
    touch-action: none !important;
  }

  body.sidebar-open .main-content,
  body.filters-open .main-content {
    overflow: hidden !important;
  }

  img,
  video,
  canvas,
  svg {
    max-width: 100% !important;
    height: auto !important;
  }
  
  .sidebar.open {
    left: 0 !important;
  }
  
  /* Sidebar Content Styling */
  .sidebar-content {
    padding: 20px !important;
    height: 100% !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .sidebar-nav .nav-item {
    padding: 16px !important;
    margin-bottom: 8px !important;
    font-size: 16px !important;
    min-height: 48px !important;
    display: flex !important;
    align-items: center !important;
  }

  .sidebar-user,
  .sidebar-footer {
    padding: 16px 20px !important;
  }
  
  .user-action {
    min-height: 48px !important;
    padding: 12px 16px !important;
    font-size: 16px !important;
  }

  /* Mobile Header - Always visible */
  .mobile-header {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    z-index: 10000 !important;
    background: rgba(17, 26, 34, 0.98) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.1) !important;
    padding: 12px 16px !important;
    min-height: 56px !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2) !important;
  }
  
  /* Menu Button - Unique styling for hamburger menu */
  .mobile-header .menu-btn,
  .mobile-header button.menu-btn,
  .mobile-header #mobileMenuBtn {
    font-size: 24px !important;
    line-height: 1 !important;
    padding: 8px 12px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    border: 1px solid rgba(255, 255, 255, 0.15) !important;
    color: #ffffff !important;
    border-radius: 8px !important;
    cursor: pointer !important;
    min-width: 44px !important;
    min-height: 44px !important;
    max-width: 44px !important;
    max-height: 44px !important;
    width: 44px !important;
    height: 44px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    touch-action: manipulation !important;
    flex-shrink: 0 !important;
    /* Override general button styles */
    width: 44px !important;
    min-width: 44px !important;
    max-width: 44px !important;
  }
  
  /* Filters Button - Unique styling for filters button */
  .mobile-header .filters-btn,
  .mobile-header button.filters-btn,
  .mobile-header #mobileFiltersBtn {
    padding: 8px 14px !important;
    background: rgba(106, 183, 255, 0.15) !important;
    border: 1px solid rgba(106, 183, 255, 0.3) !important;
    color: #b3d9ff !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    min-height: 44px !important;
    min-width: auto !important;
    max-width: none !important;
    width: auto !important;
    height: auto !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    white-space: nowrap !important;
    touch-action: manipulation !important;
    flex-shrink: 0 !important;
    margin-left: 8px !important;
    /* Override general button styles */
    width: auto !important;
    min-width: 70px !important;
  }
  
  /* Brand Link - Unique styling, not a button */
  .mobile-header .brand,
  .mobile-header a.brand {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    color: #ffffff !important;
    font-weight: 700 !important;
    text-decoration: none !important;
    flex: 1 !important;
    overflow: hidden !important;
    min-width: 0 !important;
    /* Override any button styles */
    min-height: auto !important;
    padding: 0 !important;
    width: auto !important;
    max-width: none !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    margin-left: 12px !important;
  }

  .mobile-header .brand img {
    height: 32px !important;
    width: auto !important;
    flex-shrink: 0 !important;
  }

  .mobile-header .brand span {
    font-size: 18px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    flex: 1 !important;
    min-width: 0 !important;
  }
  
  /* Main Content - Full Width */
  .main-content {
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding: 0 !important;
    padding-top: 56px !important;
    width: 100vw !important;
    max-width: 100vw !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
    height: auto !important;
    min-height: calc(100vh - 56px) !important;
  }
  
  /* Content Panels */
  .content-panel,
  .wrap,
  .container {
    padding: 16px !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Typography */
  h1 {
    font-size: 28px !important;
    font-weight: 800 !important;
    margin: 0 0 16px 0 !important;
    line-height: 1.2 !important;
  }
  
  h2 {
    font-size: 24px !important;
    font-weight: 700 !important;
    margin: 0 0 12px 0 !important;
  }

  h3 {
    font-size: 20px !important;
    font-weight: 600 !important;
    margin: 0 0 10px 0 !important;
  }
  
  p, li, span, div {
    font-size: 16px !important;
    line-height: 1.5 !important;
  }
  
  /* Cards - Full Width, Stack Vertically (exclude participants-grid which should stay as grid) */
  .grid:not(.participants-grid),
  .campaigns-grid,
  .investigator-grid,
  .expansion-grid,
  .deck-grid,
  .cards-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    padding: 16px !important;
    margin: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
    overflow-y: visible !important;
  }
  
  .card,
  .campaign-card,
  .investigator-card,
  .expansion-card,
  .deck-card {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    margin: 0 !important;
  }
  
  /* Buttons - Touch Friendly Minimum Sizes Only (exclude mobile header buttons and small buttons) */
  button:not(.mobile-header button):not(.menu-btn):not(.filters-btn):not(.btn-small):not(.btn-icon):not(.favorite-btn),
  .btn:not(.mobile-header .btn):not(.menu-btn):not(.filters-btn):not(.btn-small):not(.btn-icon):not(.favorite-btn),
  a.btn:not(.mobile-header a.btn):not(.btn-small):not(.btn-icon),
  input[type="button"]:not(.mobile-header input):not(.btn-small),
  input[type="submit"]:not(.mobile-header input):not(.btn-small) {
    min-height: 44px !important;
    min-width: 44px !important;
    touch-action: manipulation !important;
    /* Don't force width or padding - let buttons keep their natural sizes */
    box-sizing: border-box !important;
  }
  
  /* Small buttons keep their size */
  .btn-small,
  button.btn-small,
  a.btn-small {
    min-height: 32px !important;
    min-width: 32px !important;
    touch-action: manipulation !important;
    width: auto !important;
    padding: 3px 8px !important;
    font-size: 11px !important;
  }
  
  /* Icon buttons keep their size */
  .btn-icon,
  button.btn-icon {
    min-height: 32px !important;
    min-width: 32px !important;
    touch-action: manipulation !important;
    width: auto !important;
    padding: 4px !important;
  }

  /* Campaigns Page - Mobile Layout */
  .campaigns-container {
    width: 100% !important;
    max-width: 100% !important;
    padding: 16px !important;
    box-sizing: border-box !important;
  }
  
  /* Campaign card - full width on mobile */
  .campaign-card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: 16px !important;
    margin-bottom: 16px !important;
  }
  
  /* Override inline grid styles for create/join section - stack vertically */
  .campaigns-container .campaign-card > div[style*="grid-template-columns: auto 1fr"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }
  
  .campaigns-container .campaign-card > div > div[style*="grid-template-columns: 1fr 1fr"] {
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    min-width: 0 !important;
    width: 100% !important;
  }
  
  .campaigns-container .campaign-card > div > div[style*="grid-template-columns: repeat(3"] {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 12px !important;
    width: 100% !important;
  }
  
  /* Remove min-width constraints on mobile */
  .campaigns-container .campaign-card > div > div[style*="min-width: 500px"] {
    min-width: 0 !important;
    width: 100% !important;
  }
  
  /* Campaign form inputs and buttons - full width on mobile */
  .campaign-card form {
    width: 100% !important;
  }
  
  .campaign-card select,
  .campaign-card input[type="text"] {
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .campaign-card .btn:not(.btn-small):not(.btn-icon) {
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Help section grids - stack on mobile (only for campaigns page, not campaign-log) */
  .campaigns-container .campaign-card > div[style*="grid-template-columns: repeat(auto-fit"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  
  /* Campaign log page - stack grid items on mobile only */
  .campaign-log-container .campaign-card > div[style*="grid-template-columns: repeat(auto-fit"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }
  
  /* Ensure campaign log sections maintain their original grid on desktop (outside media query) */
  
  /* Form Elements */
  input[type="text"],
  input[type="email"],
  input[type="search"],
  textarea,
  select {
    width: 100% !important;
    min-height: 44px !important;
    padding: 12px 16px !important;
    font-size: 16px !important;
    border-radius: 12px !important;
    box-sizing: border-box !important;
  }
  
  textarea {
    min-height: 120px !important;
    resize: vertical !important;
  }
  
  /* Forms */
  .form-group {
    margin-bottom: 20px !important;
  }

  label {
    display: block !important;
    margin-bottom: 8px !important;
    font-weight: 600 !important;
    font-size: 14px !important;
  }
  
  /* Panels and Containers */
  .panel,
  .glass-panel,
  .content-panel {
    padding: 20px !important;
    margin-bottom: 16px !important;
    border-radius: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Navigation - Bottom Sheet Style */
  .mobile-nav-sheet {
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(17, 26, 34, 0.98) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    z-index: 9999 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 20px !important;
    transform: translateX(-100%) !important;
    transition: transform 0.3s ease !important;
  }

  .mobile-nav-sheet.open {
    transform: translateX(0) !important;
  }

  .mobile-nav-sheet .nav-item {
    display: block !important;
    padding: 16px !important;
    margin-bottom: 8px !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.05) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    color: #ffffff !important;
    text-decoration: none !important;
    font-size: 16px !important;
    font-weight: 500 !important;
    min-height: 48px !important;
  }

  .mobile-nav-sheet .nav-item:active {
    background: rgba(255, 255, 255, 0.1) !important;
  }

  /* Backdrop for sidebar */
  .sidebar-backdrop {
    display: none !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    z-index: 11000 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  
  /* Show backdrop when sidebar is open */
  .sidebar.open ~ .sidebar-backdrop {
    display: block !important;
  }
  
  /* Also support backdrop with active class (for pages where backdrop comes before sidebar) */
  .sidebar-backdrop.active {
    display: block !important;
  }
  
  /* Fallback: show backdrop when sidebar has open class (using :has selector if supported) */
  @supports selector(:has(*)) {
    body:has(.sidebar.open) .sidebar-backdrop {
      display: block !important;
  }
  }
  
  /* Tables - Scrollable */
  table {
    display: block !important;
    width: 100% !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* Modals - Full Screen */
  .modal,
  #upgradeModal,
  #addCardModal {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    margin: 0 !important;
    padding: 0 !important;
    border-radius: 0 !important;
    z-index: 20000 !important;
    background: rgba(0, 0, 0, 0.95) !important;
  }
  
  .modal-content {
    padding: 20px !important;
    max-height: 100vh !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }
  
  /* Remove all hover effects on mobile */
  *:hover {
    transform: none !important;
    scale: 1 !important;
  }
  
  /* Disable animations for performance (but allow snow, rain, storm and essential animations) */
  *:not(.wallpaper-background):not(.wallpaper-background *):not(.loading-circle):not(.spin):not(.rain-canvas):not(.storm-effect):not(.rain-canvas *):not(.storm-effect *)::before,
  *:not(.wallpaper-background):not(.wallpaper-background *):not(.loading-circle):not(.spin):not(.rain-canvas):not(.storm-effect):not(.rain-canvas *):not(.storm-effect *)::after {
    transition: none !important;
    animation: none !important;
  }
  
  /* Also disable on elements themselves (except snow, rain, storm and spinners) */
  *:not(.wallpaper-background):not(.wallpaper-background *):not(.loading-circle):not(.spin):not(.rain-canvas):not(.storm-effect):not(.rain-canvas *):not(.storm-effect *) {
    transition: none !important;
    animation: none !important;
  }
  
  /* Allow snow effect animation */
  .wallpaper-background.snow-effect::before {
    animation: snowing 20s linear infinite !important;
    -webkit-animation: snowing 20s linear infinite !important;
    -moz-animation: snowing 20s linear infinite !important;
    -ms-animation: snowing 20s linear infinite !important;
    -o-animation: snowing 20s linear infinite !important;
  }
  
  /* Allow rain canvas to be visible and functional on mobile */
  .rain-canvas {
    position: fixed !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    height: 100% !important;
    pointer-events: none !important;
    z-index: -1 !important;
    /* Don't force display - let JavaScript control visibility via .active class */
  }
  
  .rain-canvas.active {
    display: block !important;
  }
  
  /* Allow storm effect on mobile */
  .storm-effect {
    position: fixed !important;
    left: 0 !important;
    top: 0 !important;
    width: 100% !important;
    height: 100% !important;
    pointer-events: none !important;
    z-index: -1 !important;
  }
  
  /* Allow only essential transitions */
  .mobile-nav-sheet,
  .mobile-backdrop,
  .sidebar,
  .sidebar-backdrop,
  #mobileFiltersPanel,
  .filters-backdrop {
    transition: transform 0.3s ease, opacity 0.3s ease !important;
  }
  
  /* Allow loading spinner animations */
  .loading-circle,
  .spin {
    animation: spin 0.8s linear infinite !important;
  }
  
  /* Campaign Log Specific Styles */
  .campaign-log-container {
    padding: 16px !important;
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .log-entry {
    padding: 16px !important;
    margin-bottom: 12px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .log-section {
    padding: 16px !important;
    margin-bottom: 16px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Form grid - stack on mobile */
  .campaign-log-container .form-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
  }
  
  .logs-list {
    column-count: 1 !important;
    column-gap: 0 !important;
  }
  
  /* Edit/Delete buttons - smaller for log entries */
  .log-entry button.edit-log-btn,
  .log-entry button.delete-log-btn,
  button.edit-log-btn,
  button.delete-log-btn,
  .log-entry .edit-log-btn,
  .log-entry .delete-log-btn,
  .log-actions button.edit-log-btn,
  .log-actions button.delete-log-btn,
  .log-actions .edit-log-btn,
  .log-actions .delete-log-btn,
  button[class*="edit-log"],
  button[class*="delete-log"] {
    min-height: 32px !important;
    max-height: 32px !important;
    height: 32px !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    width: auto !important;
    min-width: 60px !important;
    max-width: 80px !important;
    box-sizing: border-box !important;
  }
  
  /* World Map */
  .world-map-container {
    padding: 12px !important;
    height: 300px !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  
  .world-map {
    height: 100% !important;
    width: 100% !important;
  }
  
  .world-map .city-label {
    font-size: 10px !important;
  }
  
  .world-map .city-code {
    font-size: 9px !important;
  }
  
  .city-notes-modal-content {
    width: 100% !important;
    max-height: 90vh !important;
    margin: 0 !important;
    border-radius: 0 !important;
  }
  
  /* Participants row - keep a single-line layout with scroll on mobile */
  .participants-grid {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding-bottom: 8px !important;
  }
  
  .participants-grid::-webkit-scrollbar {
    height: 6px !important;
  }
  
  .participants-grid::-webkit-scrollbar-thumb {
    background: rgba(255, 255, 255, 0.2) !important;
    border-radius: 999px !important;
  }
  
  .participant-card {
    padding: 12px !important;
    min-width: 150px !important;
    flex: 0 0 150px !important;
    box-sizing: border-box !important;
  }
  
  /* Filters Backdrop */
  .filters-backdrop {
    display: none !important;
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(0, 0, 0, 0.5) !important;
    z-index: 10999 !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
  }
  
  .filters-backdrop.active,
  body.filters-open .filters-backdrop {
    display: block !important;
  }
  
  /* Mobile Filters Panel - Full Screen Sheet */
  #mobileFiltersPanel {
    position: fixed !important;
    top: 56px !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: rgba(17, 26, 34, 0.98) !important;
    backdrop-filter: blur(20px) saturate(180%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(180%) !important;
    z-index: 11000 !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 20px !important;
    transform: translateX(100%) !important;
    transition: transform 0.3s ease !important;
    display: block !important;
    box-sizing: border-box !important;
  }
  
  #mobileFiltersPanel.open,
  body.filters-open #mobileFiltersPanel {
    transform: translateX(0) !important;
  }
  
  #mobileFiltersPanel .mFiltersBar {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Hide desktop filters on mobile - show only in mobile panel */
  .filtersBar,
  #classBar {
    display: none !important;
    visibility: hidden !important;
  }
  
  /* Show filters in mobile panel with proper styling */
  #mobileFiltersPanel .filtersBar,
  #mobileFiltersPanel #classBar {
    display: block !important;
    visibility: visible !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 20px !important;
    box-sizing: border-box !important;
    padding: 0 !important;
    position: static !important;
    top: auto !important;
  }
  
  /* Style filter groups inside mobile panel */
  #mobileFiltersPanel .filterGroup {
    width: 100% !important;
    max-width: 100% !important;
    margin-bottom: 20px !important;
    box-sizing: border-box !important;
    padding: 0 !important;
  }
  
  #mobileFiltersPanel .filterInputs,
  #mobileFiltersPanel .inputGroup {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  #mobileFiltersPanel input[type="text"],
  #mobileFiltersPanel input[type="search"] {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
  }
  
  /* Class bar chips in mobile panel - smaller and left-aligned */
  #mobileFiltersPanel .classBar {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    margin-bottom: 16px !important;
    padding: 0 !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
  }
  
  #mobileFiltersPanel .classBar .chip {
    flex: 0 0 auto !important;
    min-width: auto !important;
    max-width: none !important;
    width: auto !important;
    min-height: 36px !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    margin: 0 !important;
  }
  
  /* Filter chips and buttons in mobile panel - smaller */
  #mobileFiltersPanel .chip {
    min-height: 36px !important;
    padding: 6px 12px !important;
    font-size: 12px !important;
    touch-action: manipulation !important;
    margin: 0 6px 6px 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: left !important;
  }
  
  /* Filter groups - left aligned */
  #mobileFiltersPanel .filterGroup {
    text-align: left !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  
  /* Filter rows - left aligned and wrap */
  #mobileFiltersPanel .filterGroup > div {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px !important;
    justify-content: flex-start !important;
    align-items: flex-start !important;
    width: 100% !important;
    margin-bottom: 12px !important;
  }
  
  /* Buttons in mobile panel - smaller */
  #mobileFiltersPanel button:not(.mobile-header button) {
    min-height: 36px !important;
    padding: 8px 14px !important;
    font-size: 13px !important;
    touch-action: manipulation !important;
    width: auto !important;
    min-width: auto !important;
    max-width: none !important;
  }
  
  /* Reset button styling in mobile panel */
  #mobileFiltersPanel .reset-btn {
    width: 100% !important;
    margin: 0 0 16px 0 !important;
    min-height: 40px !important;
    font-size: 14px !important;
  }
  
  /* Input groups - left aligned */
  #mobileFiltersPanel .inputGroup {
    width: 100% !important;
    text-align: left !important;
    margin-bottom: 16px !important;
  }
  
  /* Search input - full width, left aligned */
  #mobileFiltersPanel input[type="text"],
  #mobileFiltersPanel input[type="search"] {
    text-align: left !important;
    padding-left: 12px !important;
  }
  
  /* Filters button visibility - show on pages with filters */
  .mobile-header .filters-btn {
    display: flex !important;
    visibility: visible !important;
  }
  
  body:not(:has(.filtersBar)):not(:has(#classBar)) .mobile-header .filters-btn,
  body:not(:has(.filtersBar)):not(:has(#classBar)) #mobileFiltersBtn {
    display: none !important;
    visibility: hidden !important;
  }
  
  /* Hide filters button on campaign log page */
  .campaign-log-container ~ * #mobileFiltersBtn,
  body:has(.campaign-log-container) #mobileFiltersBtn {
    display: none !important;
    visibility: hidden !important;
  }
  
  /* Favorite Button - Fix positioning to not overlap content */
  .card {
    position: relative !important;
    padding-bottom: 48px !important; /* Add space for favorite button */
  }
  
  .favorite-btn {
    position: absolute !important;
    bottom: 12px !important;
    right: 12px !important;
    background: rgba(28, 28, 30, 0.8) !important;
    backdrop-filter: blur(10px) saturate(120%) !important;
    -webkit-backdrop-filter: blur(10px) saturate(120%) !important;
    border: 1px solid rgba(255, 255, 255, 0.2) !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    min-height: 40px !important;
    max-width: 40px !important;
    max-height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    font-size: 20px !important;
    z-index: 10 !important;
    opacity: 1 !important;
    pointer-events: auto !important;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3) !important;
    /* Override general button styles */
    padding: 0 !important;
    width: 40px !important;
    height: 40px !important;
  }
  
  .favorite-btn.favorited {
    background: rgba(220, 20, 60, 0.8) !important;
    border-color: rgba(220, 20, 60, 0.6) !important;
  }
  
  .favorite-btn:active {
    transform: scale(0.95) !important;
  }
  
  /* Ensure card meta doesn't overlap favorite button */
  .card .meta {
    padding-bottom: 8px !important;
  }
  
  /* Safe area insets for notched devices */
  @supports (padding: env(safe-area-inset-top)) {
  .mobile-header {
      padding-top: max(12px, env(safe-area-inset-top)) !important;
      padding-left: max(16px, env(safe-area-inset-left)) !important;
      padding-right: max(16px, env(safe-area-inset-right)) !important;
  }
  
    .main-content {
      padding-left: max(0px, env(safe-area-inset-left)) !important;
      padding-right: max(0px, env(safe-area-inset-right)) !important;
      padding-bottom: max(20px, env(safe-area-inset-bottom)) !important;
    }
  }
}

/* Desktop styles for campaign log - ensure grid layouts work correctly */
@media (min-width: 769px) {
  /* Restore original grid layouts for campaign log on desktop */
  .campaign-log-container .campaign-card > div[style*="grid-template-columns: repeat(auto-fit"] {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
    gap: 20px !important;
  }
  
  /* Ensure participants row stays single-line on desktop */
  .campaign-log-container .participants-grid {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    overflow-x: hidden !important;
    padding-bottom: 4px !important;
  }
  
  /* Restore form-grid layout for Investigator Report on desktop */
  .campaign-log-container .form-grid {
    display: grid !important;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)) !important;
    gap: 15px !important;
    margin-bottom: 20px !important;
  }
  
  /* Restore participant image sizes on desktop */
  .campaign-log-container .participant-card .circle-crop {
    --size: 72px !important;
    width: 72px !important;
    height: 72px !important;
    min-width: 72px !important;
    min-height: 72px !important;
    max-width: 72px !important;
    max-height: 72px !important;
    margin-right: 8px !important;
  }
  
  .campaign-log-container .participant-card .circle-crop > img {
    min-width: 72px !important;
    min-height: 72px !important;
    max-width: 72px !important;
    max-height: 72px !important;
  }
  
  /* Restore column layout for logs list on desktop */
  .logs-list {
    column-count: 3 !important;
    column-gap: 12px !important;
    max-height: none !important;
    overflow: visible !important;
  }
}

@media (min-width: 1200px) {
  .logs-list {
    column-count: 4 !important;
    column-gap: 12px !important;
    max-height: none !important;
    overflow: visible !important;
  }
}
