/* Mobile Styles - Consolidated
 *
 * ARCHITECTURE NOTE:
 * App.vue uses dedicated mobile components with v-show for tab switching:
 * - .mobile-browse-content (v-show="mobileActiveTab === 'browse'") - Lists (QuickUISidebar)
 * - .mobile-prechecklist-content (v-show="mobileActiveTab === 'prechecklist'") - Precheck (main checklist)
 * - .mobile-checkout-content (v-show="mobileActiveTab === 'checkout'") - Checklist (selected items)
 *
 * NO hamburger menu - content fills entire space above bottom nav.
 * DO NOT add display:block !important rules here - they break v-show.
 */

@media (max-width: 767px) {
  /* ===== BODY SETUP ===== */
  body[data-mobile-ui="true"] {
    position: fixed;
    overflow: hidden;
    width: 100%;
    height: 100%;
    font-size: 16px !important;
    line-height: 1.5 !important;
    -webkit-font-smoothing: antialiased !important;
    background: #0c0d12 !important; /* Ensure consistent dark background */
  }

  /* Ensure html element also has correct background for safe area */
  html {
    background: #0c0d12 !important;
  }

  /* ===== HIDE DESKTOP COMPONENTS ===== */
  /* Note: Circular buttons (quick-add, notes, budget, costs, save) are kept visible on mobile */
  body[data-mobile-ui="true"] .app-header,
  body[data-mobile-ui="true"] .app-layout:not(.mobile-layout),
  body[data-mobile-ui="true"] .app-content,
  body[data-mobile-ui="true"] .density-toggle,
  body[data-mobile-ui="true"] .theme-toggle:not(.mobile-theme-toggle),
  body[data-mobile-ui="true"] .view-toggle,
  body[data-mobile-ui="true"] .resize-handle,
  body[data-mobile-ui="true"] .drag-handle {
    display: none !important;
  }

  /* ===== HIDE INSPECTOR BUTTON ON MOBILE ===== */
  /* The Inspector button should not appear in the Precheck (main checklist) tab */
  body[data-mobile-ui="true"] .inspector-toggle,
  body[data-mobile-ui="true"] .circular-inspector,
  body[data-mobile-ui="true"] .toggle-inspector-btn {
    display: none !important;
  }

  /* ===== MOBILE APP CONTAINER ===== */
  body[data-mobile-ui="true"] .mobile-app-container {
    display: flex !important;
    flex-direction: column !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    background: var(--bg-primary, #0c0d12) !important;
    z-index: 100 !important;
  }

  /* ===== MOBILE TAB CONTENT ===== */
  body[data-mobile-ui="true"] .mobile-tab-content {
    flex: 1;
    overflow: hidden;
    position: relative;
  }

  body[data-mobile-ui="true"] .mobile-page {
    height: 100%;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    background: var(--bg-primary, #0c0d12);
  }

  /* ===== MOBILE BOTTOM NAV ===== */
  body[data-mobile-ui="true"] .mobile-bottom-nav {
    position: relative;
    height: 60px;
    display: flex !important;
    background: var(--bg-primary, #0c0d12); /* Match content area - near black */
    border-top: 1px solid var(--border-color, #333);
    z-index: 1500 !important;
    padding-bottom: env(safe-area-inset-bottom);
    flex-shrink: 0;
  }

  body[data-mobile-ui="true"] .mobile-bottom-nav .nav-tab {
    flex: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: transparent !important;
    border: none !important;
    min-height: 60px !important;
    font-size: 11px !important;
    color: var(--text-secondary, #888);
    transition: color 0.2s;
  }

  body[data-mobile-ui="true"] .mobile-bottom-nav .nav-tab.active {
    color: var(--accent-color, #4facfe);
  }

  body[data-mobile-ui="true"] .mobile-bottom-nav .nav-tab i {
    font-size: 20px !important;
    margin-bottom: 4px !important;
  }

  /* ===== TOUCH-FRIENDLY SIZING ===== */
  body[data-mobile-ui="true"] button,
  body[data-mobile-ui="true"] .clickable,
  body[data-mobile-ui="true"] .checkbox,
  body[data-mobile-ui="true"] input[type="checkbox"] {
    min-width: 44px;
    min-height: 44px;
  }

  /* ===== iOS ZOOM PREVENTION ===== */
  body[data-mobile-ui="true"] input[type="text"],
  body[data-mobile-ui="true"] input[type="email"],
  body[data-mobile-ui="true"] input[type="number"],
  body[data-mobile-ui="true"] input[type="tel"],
  body[data-mobile-ui="true"] input[type="date"],
  body[data-mobile-ui="true"] input[type="password"],
  body[data-mobile-ui="true"] input[type="search"],
  body[data-mobile-ui="true"] input[type="url"],
  body[data-mobile-ui="true"] textarea,
  body[data-mobile-ui="true"] select {
    font-size: 16px !important;
  }

  /* ===== TEXT SELECTION ===== */
  body[data-mobile-ui="true"] * {
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -webkit-tap-highlight-color: transparent;
  }

  body[data-mobile-ui="true"] input,
  body[data-mobile-ui="true"] textarea {
    -webkit-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
    user-select: text;
  }

  /* ===== QUICK ADD TOUCH TARGETS ===== */
  /* Ensure quick-add areas are touchable on mobile */
  body[data-mobile-ui="true"] .quick-add-container,
  body[data-mobile-ui="true"] .quick-add-form,
  body[data-mobile-ui="true"] .quick-add-row,
  body[data-mobile-ui="true"] .quick-add-input,
  body[data-mobile-ui="true"] .quick-add-inline-selector,
  body[data-mobile-ui="true"] .quick-add-inline-tab,
  body[data-mobile-ui="true"] .category-quick-add {
    pointer-events: auto !important;
    touch-action: manipulation !important;
    -webkit-user-select: text !important;
    user-select: text !important;
  }

  body[data-mobile-ui="true"] .quick-add-input {
    min-height: 44px !important;
    font-size: 16px !important;
    padding: 12px !important;
  }

  body[data-mobile-ui="true"] .quick-add-inline-tab {
    min-width: 44px !important;
    min-height: 44px !important;
  }

  /* ===== SCROLLING IMPROVEMENTS ===== */
  body[data-mobile-ui="true"] .mobile-checklist-view,
  body[data-mobile-ui="true"] .mobile-selected-list,
  body[data-mobile-ui="true"] .mobile-categories,
  body[data-mobile-ui="true"] .quick-ui-sidebar,
  body[data-mobile-ui="true"] .checklist-sidebar {
    -webkit-overflow-scrolling: touch !important;
    scroll-behavior: smooth !important;
  }

  /* ===== ITEM TOUCH TARGETS ===== */
  body[data-mobile-ui="true"] .category-header {
    padding: 12px !important;
    font-size: 16px !important;
    min-height: 44px !important;
  }

  body[data-mobile-ui="true"] .item-row {
    padding: 12px !important;
    font-size: 15px !important;
    min-height: 44px !important;
  }

  /* ===== FIX OVAL CHECKBOXES - MAKE CIRCLES ===== */
  body[data-mobile-ui="true"] .item-checkbox,
  body[data-mobile-ui="true"] .category-checkbox,
  body[data-mobile-ui="true"] .subcategory-checkbox {
    width: 28px !important;
    height: 28px !important;
    min-width: 28px !important;
    min-height: 28px !important;
    max-width: 28px !important;
    max-height: 28px !important;
    aspect-ratio: 1 !important;
    border-radius: 50% !important;
    flex-shrink: 0 !important;
  }

  /* ===== ROUND CORNERS ON CATEGORIES/SUBCATEGORIES (4px) ===== */
  body[data-mobile-ui="true"] .category-header,
  body[data-mobile-ui="true"] .subcategory-header {
    border-radius: 4px !important;
  }

  /* ===== HIDE INLINE ACTION BUTTONS ON MOBILE ===== */
  /* Use MobileActionBar instead */
  body[data-mobile-ui="true"] .item-actions,
  body[data-mobile-ui="true"] .category-actions {
    display: none !important;
  }

  /* ===== MOBILE ACTION BAR ===== */
  body[data-mobile-ui="true"] .mobile-action-bar {
    position: fixed;
    bottom: calc(60px + env(safe-area-inset-bottom));
    left: 0;
    right: 0;
    height: 50px;
    background: var(--bg-secondary, #232836);
    border-top: 1px solid var(--border-color, #333);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 0 16px;
    z-index: 1400;
  }

  body[data-mobile-ui="true"] .mobile-action-bar .action-btn {
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    border-radius: 50%;
    background: rgba(255, 255, 255, 0.05);
    border: 1px solid rgba(255, 255, 255, 0.1);
    color: rgba(255, 255, 255, 0.7);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    cursor: pointer;
    transition: all 0.15s ease;
  }

  body[data-mobile-ui="true"] .mobile-action-bar .action-btn:active {
    transform: scale(0.95);
    background: rgba(255, 255, 255, 0.1);
  }

  body[data-mobile-ui="true"] .mobile-action-bar .action-btn.delete {
    color: rgba(245, 101, 101, 0.8);
  }

  body[data-mobile-ui="true"] .mobile-action-bar .divider {
    width: 1px;
    height: 24px;
    background: rgba(255, 255, 255, 0.1);
  }

  /* ===== MOBILE EDIT SLIDE-IN FROM LEFT ===== */
  body[data-mobile-ui="true"] .item-edit-modal,
  body[data-mobile-ui="true"] .edit-modal-container {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: calc(60px + env(safe-area-inset-bottom)) !important;
    transform: translateX(-100%);
    transition: transform 0.3s ease;
    z-index: 2000 !important;
    background: var(--bg-primary, #0c0d12) !important;
  }

  body[data-mobile-ui="true"] .item-edit-modal.open,
  body[data-mobile-ui="true"] .edit-modal-container.visible {
    transform: translateX(0);
  }

  /* Adjust content padding when action bar is visible */
  body[data-mobile-ui="true"][data-has-selection="true"] .mobile-page {
    padding-bottom: 0 !important; /* Footer handles spacing with fixed positioning */
  }

  /* ===== EXPORT BUTTONS ===== */
  body[data-mobile-ui="true"] .sidebar-export-menu {
    margin: 10px 0 !important;
  }

  body[data-mobile-ui="true"] .export-btn {
    width: 100% !important;
    padding: 12px !important;
    font-size: 14px !important;
  }

  /* ===== CHECKLIST SIDEBAR - ICON ONLY BUTTONS ON MOBILE ===== */
  /* Hide text labels in tab buttons (Dates, Checklist Mode, Notes, Show Tables) */
  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-tabs .tab-btn span,
  body[data-mobile-ui="true"] .checklist-sidebar .vertical-tabs .vertical-tab-btn span {
    display: none !important;
  }

  /* Hide footer buttons entirely - now using MobileFooterBar instead */
  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-footer,
  body[data-mobile-ui="true"] .checklist-sidebar .footer-buttons,
  body[data-mobile-ui="true"] .checklist-sidebar .export-dropdown,
  body[data-mobile-ui="true"] .checklist-sidebar .export-dropdown-menu,
  body[data-mobile-ui="true"] .checklist-sidebar .vertical-export-dropdown,
  body[data-mobile-ui="true"] .checklist-sidebar .vertical-export-menu {
    display: none !important;
  }

  /* Hide inline action buttons on selected items - use MobileActionBar instead */
  body[data-mobile-ui="true"] .selected-item .item-actions,
  body[data-mobile-ui="true"] .selected-item.keyboard-selected .item-actions,
  body[data-mobile-ui="true"] .selected-item.attachment-menu-open .item-actions {
    display: none !important;
    max-height: 0 !important;
    padding: 0 !important;
    opacity: 0 !important;
  }

  /* Remove extra padding from selected items when selected (no action row expansion on mobile) */
  body[data-mobile-ui="true"] .selected-item.keyboard-selected {
    padding-bottom: 0 !important;
  }

  /* Fix checklist sidebar to fill available space on mobile */
  body[data-mobile-ui="true"] .mobile-checklist-sidebar {
    height: 100% !important;
    display: flex !important;
    flex-direction: column !important;
  }

  body[data-mobile-ui="true"] .checklist-sidebar {
    height: 100% !important;
    padding-bottom: 0 !important;
  }

  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-content {
    flex: 1 !important;
    overflow-y: auto !important;
    padding-bottom: calc(60px + env(safe-area-inset-bottom)) !important;
  }

  /* Adjust button styling for icon-only mode */
  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-tabs .tab-btn {
    min-width: 44px !important;
    padding: 8px !important;
    justify-content: center !important;
  }

  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-tabs .tab-btn i {
    margin-right: 0 !important;
    font-size: 18px !important;
  }

  /* Compact layout for tab button containers */
  body[data-mobile-ui="true"] .checklist-sidebar .sidebar-tabs {
    gap: 4px !important;
    flex-wrap: wrap !important;
  }

  /* Add padding at bottom for footer bar on checkout tab */
  body[data-mobile-ui="true"][data-mobile-tab="checkout"] .mobile-page {
    padding-bottom: 0 !important; /* Footer handles spacing with fixed positioning */
  }

  /* ===== MOBILE BROWSE VIEW ===== */
  /* Ensure browse content fills available space */
  body[data-mobile-ui="true"] .mobile-browse-content {
    display: flex;
    flex-direction: column;
  }

  body[data-mobile-ui="true"] .mobile-browse-content .mobile-browse-view {
    flex: 1;
    display: flex;
    flex-direction: column;
  }

  /* ===== MOBILE TEXT INPUT FIXES ===== */
  /* Make text inputs visible with dark background */
  body[data-mobile-ui="true"] input[type="text"],
  body[data-mobile-ui="true"] input[type="number"],
  body[data-mobile-ui="true"] input[type="search"],
  body[data-mobile-ui="true"] textarea,
  body[data-mobile-ui="true"] .item-name-edit,
  body[data-mobile-ui="true"] .category-name-edit,
  body[data-mobile-ui="true"] .subcategory-name-edit,
  body[data-mobile-ui="true"] .quick-add-input {
    background: #0c0d12 !important;
    color: #ffffff !important;
    border: 1px solid rgba(79, 172, 254, 0.5) !important;
    border-radius: 8px !important;
    padding: 12px !important;
    font-size: 16px !important; /* Prevent iOS zoom */
    caret-color: #4facfe !important;
  }

  body[data-mobile-ui="true"] input::placeholder,
  body[data-mobile-ui="true"] textarea::placeholder {
    color: rgba(255, 255, 255, 0.4) !important;
  }

  /* Focus state for text inputs */
  body[data-mobile-ui="true"] input:focus,
  body[data-mobile-ui="true"] textarea:focus {
    outline: none !important;
    border-color: #4facfe !important;
    box-shadow: 0 0 0 2px rgba(79, 172, 254, 0.2) !important;
  }

  /* ===== MOBILE KEYBOARD DONE BAR ===== */
  /* Floating done button that appears above keyboard when input is focused */
  body[data-mobile-ui="true"] .mobile-keyboard-done-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 44px;
    background: #1a1f2e;
    border-top: 1px solid rgba(79, 172, 254, 0.3);
    display: none;
    align-items: center;
    justify-content: flex-end;
    padding: 0 16px;
    z-index: 9999;
  }

  body[data-mobile-ui="true"].keyboard-open .mobile-keyboard-done-bar {
    display: flex;
  }

  body[data-mobile-ui="true"] .mobile-keyboard-done-bar .done-btn {
    background: rgba(79, 172, 254, 0.2);
    color: #4facfe;
    border: 1px solid rgba(79, 172, 254, 0.4);
    border-radius: 6px;
    padding: 8px 20px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    min-width: 44px;
    min-height: 36px;
  }

  body[data-mobile-ui="true"] .mobile-keyboard-done-bar .done-btn:active {
    background: rgba(79, 172, 254, 0.3);
  }

  /* ===== MOBILE CIRCULAR BUTTONS ===== */
  body[data-mobile-ui="true"] .mobile-circular-buttons {
    display: flex;
    gap: 12px;
    padding: 8px 16px;
    background: var(--bg-primary, #0c0d12);
    border-bottom: 1px solid rgba(255, 255, 255, 0.05);
  }

  body[data-mobile-ui="true"] .mobile-circular-btn {
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    border-radius: 50%;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.15);
    color: rgba(255, 255, 255, 0.6);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn:active {
    transform: scale(0.95);
  }

  /* Quick Add Button */
  body[data-mobile-ui="true"] .mobile-circular-btn.quick-add-btn.active {
    border-color: #fbbf24;
    color: #fbbf24;
    border-width: 2px;
  }

  /* Quick Add Button - AI Mode (purple) */
  body[data-mobile-ui="true"] .mobile-circular-btn.quick-add-btn.ai-mode {
    border-color: #a855f7;
    color: #a855f7;
    border-width: 2px;
  }

  /* Notes Button */
  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn .fa-sticky-note {
    font-size: 12px;
    margin-top: -2px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn .notes-indicators {
    display: flex;
    gap: 2px;
    position: absolute;
    bottom: 6px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn .indicator {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: #374151;
    transition: all 0.2s ease;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn .indicator.active {
    background: #60a5fa;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-prechecklist {
    border-color: #fbbf24;
    color: #fbbf24;
    border-width: 2px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-prechecklist .indicator:first-child {
    background: #fbbf24;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-checklist {
    border-color: #60a5fa;
    color: #60a5fa;
    border-width: 2px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-checklist .indicator:nth-child(2) {
    background: #60a5fa;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-all {
    border-color: #e879f9;
    color: #e879f9;
    border-width: 2px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.notes-btn.mode-all .indicator {
    background: #e879f9;
  }

  /* Costs Button */
  body[data-mobile-ui="true"] .mobile-circular-btn.costs-btn .currency-symbol {
    font-size: 14px;
    font-weight: 600;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.costs-btn.active {
    border-color: #10b981;
    color: #10b981;
    border-width: 2px;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.costs-btn.disabled {
    opacity: 0.4;
    cursor: not-allowed;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.costs-btn .lock-icon {
    position: absolute;
    bottom: 4px;
    right: 4px;
    font-size: 8px;
    opacity: 0.6;
  }

  /* Save Button */
  body[data-mobile-ui="true"] .mobile-circular-btn.save-btn {
    color: rgba(255, 255, 255, 0.6);
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.save-btn:not(.disabled):active {
    border-color: #3b82f6;
    color: #3b82f6;
  }

  body[data-mobile-ui="true"] .mobile-circular-btn.save-btn.disabled {
    opacity: 0.3;
    cursor: not-allowed;
  }
}

/* ===== LIGHT MODE SUPPORT ===== */
@media (max-width: 767px) {
  body.light-mode[data-mobile-ui="true"] .mobile-app-container {
    background: #ffffff !important;
  }

  /* Light mode text inputs */
  body.light-mode[data-mobile-ui="true"] input[type="text"],
  body.light-mode[data-mobile-ui="true"] input[type="number"],
  body.light-mode[data-mobile-ui="true"] input[type="search"],
  body.light-mode[data-mobile-ui="true"] textarea,
  body.light-mode[data-mobile-ui="true"] .item-name-edit,
  body.light-mode[data-mobile-ui="true"] .category-name-edit,
  body.light-mode[data-mobile-ui="true"] .subcategory-name-edit,
  body.light-mode[data-mobile-ui="true"] .quick-add-input {
    background: #ffffff !important;
    color: #1a1a1a !important;
    border: 1px solid rgba(59, 130, 246, 0.5) !important;
    caret-color: #3b82f6 !important;
  }

  body.light-mode[data-mobile-ui="true"] input::placeholder,
  body.light-mode[data-mobile-ui="true"] textarea::placeholder {
    color: rgba(0, 0, 0, 0.4) !important;
  }

  body.light-mode[data-mobile-ui="true"] input:focus,
  body.light-mode[data-mobile-ui="true"] textarea:focus {
    border-color: #3b82f6 !important;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.2) !important;
  }

  body.light-mode[data-mobile-ui="true"] .mobile-page {
    background: #f5f5f7 !important;
  }

  body.light-mode[data-mobile-ui="true"] .mobile-bottom-nav {
    background: #ffffff !important;
    border-top-color: #e5e5e5 !important;
  }

  body.light-mode[data-mobile-ui="true"] .mobile-bottom-nav .nav-tab {
    color: #666 !important;
  }

  body.light-mode[data-mobile-ui="true"] .mobile-bottom-nav .nav-tab.active {
    color: #3b82f6 !important;
  }

  /* Light mode keyboard done bar */
  body.light-mode[data-mobile-ui="true"] .mobile-keyboard-done-bar {
    background: #ffffff;
    border-top-color: rgba(59, 130, 246, 0.3);
  }

  body.light-mode[data-mobile-ui="true"] .mobile-keyboard-done-bar .done-btn {
    background: rgba(59, 130, 246, 0.1);
    color: #3b82f6;
    border-color: rgba(59, 130, 246, 0.4);
  }

  body.light-mode[data-mobile-ui="true"] .mobile-keyboard-done-bar .done-btn:active {
    background: rgba(59, 130, 246, 0.2);
  }

  /* Light mode mobile circular buttons */
  body.light-mode[data-mobile-ui="true"] .mobile-circular-buttons {
    background: #ffffff;
    border-bottom-color: rgba(0, 0, 0, 0.08);
  }

  body.light-mode[data-mobile-ui="true"] .mobile-circular-btn {
    border-color: rgba(0, 0, 0, 0.15);
    color: rgba(0, 0, 0, 0.5);
  }

  body.light-mode[data-mobile-ui="true"] .mobile-circular-btn.notes-btn .indicator {
    background: #d1d5db;
  }
}
