/* Polymarket Navigation - Mobile Responsive Fixes */
/* Ensures tabs, menu bar, and all content display correctly on mobile */
/* Uses responsive units (rem, %, vw, vh) for proportional scaling */

/* ========================================
   CSS CUSTOM PROPERTIES FOR RESPONSIVE SCALING
   ======================================== */

:root {
  /* Touch-friendly minimum sizes */
  --touch-target-min: 2.75rem; /* 44px at default 16px base */
  
  /* Responsive spacing scale */
  --spacing-xs: clamp(0.25rem, 1vw, 0.5rem);
  --spacing-sm: clamp(0.5rem, 2vw, 0.75rem);
  --spacing-md: clamp(0.75rem, 3vw, 1.25rem);
  --spacing-lg: clamp(1rem, 4vw, 2rem);
  --spacing-xl: clamp(1.5rem, 5vw, 3rem);
  
  /* Responsive font sizes */
  --font-size-xs: clamp(0.75rem, 2vw, 0.8125rem);
  --font-size-sm: clamp(0.8125rem, 2.25vw, 0.875rem);
  --font-size-base: clamp(0.875rem, 2.5vw, 1rem);
  --font-size-md: clamp(0.9375rem, 2.75vw, 1.0625rem);
  --font-size-lg: clamp(1rem, 3vw, 1.25rem);
  --font-size-xl: clamp(1.125rem, 3.5vw, 1.5rem);
  --font-size-2xl: clamp(1.25rem, 4vw, 1.75rem);
  
  /* Top bar heights */
  --top-bar-height-mobile: 3.5rem;
  --top-bar-height-tablet: 3.75rem;
  --top-bar-height-desktop: 4rem;
  
  /* Left dock widths */
  --dock-width-collapsed: 5rem;
  --dock-width-expanded: 15rem;
  --dock-width-mobile: clamp(17.5rem, 85vw, 20rem);
}

/* ========================================
   MOBILE-FIRST RESPONSIVE BREAKPOINTS
   ======================================== */

/* Mobile Small: ≤480px */
@media (max-width: 480px) {
  
  /* Top Bar - Make fully visible and functional on mobile */
  .poly-top-bar {
    left: 0;
    right: 0;
    width: 100%;
    padding: 0 var(--spacing-sm);
    height: var(--top-bar-height-mobile);
  }
  
  /* Search Bar - Responsive sizing */
  .poly-search {
    flex: 1;
    max-width: none;
    min-width: 0;
  }
  
  .poly-search-input {
    font-size: var(--font-size-sm);
    padding: var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 2rem;
    height: auto;
    min-height: var(--touch-target-min);
  }
  
  .poly-search-icon {
    left: var(--spacing-sm);
    font-size: var(--font-size-base);
  }
  
  /* Top Bar Right - Hide unnecessary items on small mobile */
  .poly-onboarding {
    display: none;
  }
  
  .poly-wallet {
    display: none;
  }
  
  .poly-top-bar-right {
    gap: var(--spacing-sm);
  }
  
  /* Top icons and profile - touch-friendly responsive sizing */
  .poly-top-icon {
    width: var(--touch-target-min);
    height: var(--touch-target-min);
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
  }
  
  .poly-profile-avatar {
    width: 2rem;
    height: 2rem;
    font-size: var(--font-size-sm);
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    padding: 0.5rem;
  }
  
  /* Left Dock - Full width when shown on mobile */
  .poly-left-dock {
    width: var(--dock-width-mobile) !important;
    transform: translateX(-100%) !important;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }
  
  /* Logo - Very Discreet & Modern on Mobile */
  .poly-left-dock .poly-dock-logo {
    padding: 0.5rem !important;
  }
  
  .poly-left-dock .poly-dock-logo img {
    height: 24px !important;
    width: auto !important;
    max-width: 100px !important;
    object-fit: contain !important;
    object-position: center !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }
  
  .poly-left-dock.show {
    transform: translateX(0) !important;
    z-index: 1041 !important;
  }
  
  .poly-left-dock.show .poly-nav-link span,
  .poly-left-dock.show .poly-nav-section-title,
  .poly-left-dock.show .poly-dock-footer,
  .poly-left-dock.show .poly-badge {
    opacity: 1;
  }
  
  /* Main Content - Adjust for mobile top bar */
  .poly-main-content {
    margin-left: 0;
    margin-top: var(--top-bar-height-mobile);
    padding: var(--spacing-sm);
    min-height: calc(100vh - var(--top-bar-height-mobile));
  }
  
  /* Mobile Toggle Button - Ensure it's visible */
  .poly-nav-toggle {
    display: flex;
    width: var(--touch-target-min);
    height: var(--touch-target-min);
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    top: 0.5rem;
    left: 0.5rem;
    z-index: 1046;
  }
  
  /* Dashboard Specific - Welcome Section */
  .welcome-section {
    padding: var(--spacing-sm);
  }
  
  .welcome-section h2 {
    font-size: var(--font-size-base);
    margin-bottom: var(--spacing-xs);
  }
  
  .welcome-section .col-md-8 {
    padding-left: var(--spacing-sm);
    padding-right: var(--spacing-sm);
  }
  
  /* Onboarding & User Level - Stack vertically on small mobile */
  .welcome-section .d-flex.gap-4 {
    flex-direction: column;
    gap: var(--spacing-md);
    align-items: flex-start;
  }
  
  .onboarding-compact,
  .user-level-compact {
    width: 100%;
  }
  
  .onboarding-compact .progress,
  .user-level-compact .progress {
    width: 100%;
    max-width: 12.5rem;
  }
  
  /* Search Bar Container */
  .search-bar-container {
    padding: var(--spacing-sm);
  }
  
  .search-bar-container .form-control {
    height: auto;
    min-height: var(--touch-target-min);
    font-size: var(--font-size-sm);
  }
  
  /* Cards - Full width and responsive padding */
  .modern-card {
    margin-bottom: var(--spacing-sm);
    border-radius: 0.375rem;
  }
  
  .modern-card-header {
    padding: var(--spacing-sm) var(--spacing-sm);
    font-size: var(--font-size-xs);
  }
  
  .modern-card-body {
    padding: var(--spacing-md);
  }
  
  /* Buttons - Touch-friendly sizes */
  .btn,
  button {
    min-height: var(--touch-target-min);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
  }
  
  .btn-modern-primary,
  .btn-modern-secondary,
  .btn-modern-danger {
    font-size: var(--font-size-xs);
    padding: var(--spacing-sm) var(--spacing-md);
  }
  
  /* Text Responsive Sizing */
  h1 { font-size: var(--font-size-2xl); }
  h2 { font-size: var(--font-size-xl); }
  h3 { font-size: var(--font-size-lg); }
  h4 { font-size: var(--font-size-base); }
  h5 { font-size: var(--font-size-md); }
  h6 { font-size: var(--font-size-sm); }
  
  p, .text-muted, .small {
    font-size: var(--font-size-sm);
  }
  
  /* Ensure no horizontal overflow */
  body, html {
    overflow-x: hidden;
    max-width: 100vw;
  }
  
  .row {
    margin-left: 0;
    margin-right: 0;
  }
  
  .container-fluid {
    padding-left: var(--spacing-sm);
    padding-right: var(--spacing-sm);
  }
}

/* Mobile Medium: 481px-768px (Tablet Portrait) */
@media (min-width: 481px) and (max-width: 768px) {
  
  /* Top Bar - Adjust for tablet */
  .poly-top-bar {
    left: 0;
    padding: 0 var(--spacing-md);
    height: var(--top-bar-height-tablet);
  }
  
  .poly-search {
    max-width: 25rem;
  }
  
  .poly-search-input {
    font-size: var(--font-size-md);
    padding: var(--spacing-sm) var(--spacing-md) var(--spacing-sm) 2.25rem;
    height: auto;
    min-height: var(--touch-target-min);
  }
  
  /* Show onboarding on tablet but simplified */
  .poly-onboarding {
    display: flex;
  }
  
  .poly-onboarding span {
    font-size: var(--font-size-xs);
  }
  
  .poly-progress-bar {
    width: 5rem;
  }
  
  /* Wallet - Hide on tablet portrait */
  .poly-wallet {
    display: none;
  }
  
  .poly-top-icon {
    width: var(--touch-target-min);
    height: var(--touch-target-min);
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
  }
  
  .poly-profile-avatar {
    width: 2.125rem;
    height: 2.125rem;
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    padding: 0.5rem;
  }
  
  /* Left Dock - Still full width on tablet */
  .poly-left-dock {
    width: var(--dock-width-expanded) !important;
    transform: translateX(-100%) !important;
    transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
  }
  
  /* Logo - Very Discreet & Modern on Tablet */
  .poly-left-dock .poly-dock-logo {
    padding: 0.5rem !important;
  }
  
  .poly-left-dock .poly-dock-logo img {
    height: 24px !important;
    width: auto !important;
    max-width: 110px !important;
    object-fit: contain !important;
    object-position: center !important;
    opacity: 1 !important;
    visibility: visible !important;
    display: block !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }
  
  .poly-left-dock.show {
    transform: translateX(0) !important;
  }
  
  /* Main Content */
  .poly-main-content {
    margin-left: 0;
    margin-top: var(--top-bar-height-tablet);
    padding: var(--spacing-md);
  }
  
  /* Mobile Toggle */
  .poly-nav-toggle {
    display: flex;
    width: var(--touch-target-min);
    height: var(--touch-target-min);
  }
  
  /* Welcome Section */
  .welcome-section {
    padding: var(--spacing-md);
  }
  
  .welcome-section h2 {
    font-size: var(--font-size-lg);
  }
  
  /* Onboarding & User Level - Side by side on tablet */
  .welcome-section .d-flex.gap-4 {
    gap: var(--spacing-lg);
  }
  
  /* Cards */
  .modern-card-header {
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--font-size-sm);
  }
  
  .modern-card-body {
    padding: var(--spacing-md);
  }
}

/* Desktop Small: 769px-991px */
@media (min-width: 769px) and (max-width: 991px) {
  
  /* Top Bar - Show left dock space */
  .poly-top-bar {
    left: var(--dock-width-collapsed);
  }
  
  .poly-search {
    max-width: 21.875rem;
  }
  
  /* Show all top bar items */
  .poly-onboarding {
    display: flex;
  }
  
  .poly-wallet {
    display: flex;
  }
  
  /* Left Dock - Collapsed by default */
  .poly-left-dock {
    width: var(--dock-width-collapsed);
  }
  
  .poly-left-dock:hover {
    width: var(--dock-width-expanded);
  }
  
  /* Main Content */
  .poly-main-content {
    margin-left: var(--dock-width-collapsed);
    margin-top: var(--top-bar-height-desktop);
    padding: var(--spacing-lg);
  }
  
  /* Hide mobile toggle */
  .poly-nav-toggle {
    display: none;
  }
}

/* Desktop Medium & Large: ≥992px */
@media (min-width: 992px) {
  
  /* Full desktop experience */
  .poly-top-bar {
    left: var(--dock-width-collapsed);
  }
  
  .poly-left-dock {
    width: var(--dock-width-collapsed);
  }
  
  .poly-left-dock:hover {
    width: var(--dock-width-expanded);
  }
  
  .poly-main-content {
    margin-left: var(--dock-width-collapsed);
    margin-top: var(--top-bar-height-desktop);
    padding: var(--spacing-xl);
  }
  
  .poly-nav-toggle {
    display: none;
  }
  
  .poly-onboarding {
    display: flex;
  }
  
  .poly-wallet {
    display: flex;
  }
}

/* ========================================
   LANDSCAPE ORIENTATION FIXES
   ======================================== */

@media (max-width: 768px) and (orientation: landscape) {
  
  /* Reduce top bar height in landscape while maintaining touch targets */
  .poly-top-bar {
    height: 3rem;
  }
  
  .poly-main-content {
    margin-top: 3rem;
    padding: var(--spacing-xs);
  }
  
  .poly-search-input {
    height: auto;
    min-height: var(--touch-target-min);
    font-size: var(--font-size-xs);
  }
  
  /* Icons maintain touch target size but appear smaller visually */
  .poly-top-icon {
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    font-size: var(--font-size-sm);
    padding: 0.5rem;
  }
  
  .poly-profile-avatar {
    min-width: var(--touch-target-min);
    min-height: var(--touch-target-min);
    width: 1.875rem;
    height: 1.875rem;
    padding: 0.5rem;
  }
  
  /* Reduce spacing */
  .welcome-section {
    padding: var(--spacing-xs);
  }
  
  .welcome-section h2 {
    font-size: var(--font-size-md);
  }
  
  .modern-card {
    margin-bottom: var(--spacing-xs);
  }
}

/* ========================================
   ACCESSIBILITY & TOUCH TARGETS
   ======================================== */

@media (max-width: 768px) {
  
  /* Ensure all interactive elements are touch-friendly */
  button,
  a.poly-nav-link,
  .poly-top-icon,
  input[type="button"],
  input[type="submit"],
  .btn {
    min-height: var(--touch-target-min);
    min-width: var(--touch-target-min);
    touch-action: manipulation;
  }
  
  /* Prevent text selection on navigation */
  .poly-nav-link,
  .poly-top-bar {
    user-select: none;
    -webkit-user-select: none;
  }
  
  /* Smooth scrolling */
  html {
    scroll-behavior: smooth;
  }
  
  /* Improve tap highlighting */
  * {
    -webkit-tap-highlight-color: rgba(0, 178, 255, 0.1);
  }
}

/* ========================================
   PROPORTIONAL SCALING UTILITIES
   ======================================== */

/* Use relative units instead of fixed pixels */
.responsive-text-sm { font-size: var(--font-size-sm); }
.responsive-text-md { font-size: var(--font-size-base); }
.responsive-text-lg { font-size: var(--font-size-lg); }
.responsive-text-xl { font-size: var(--font-size-xl); }

/* Responsive spacing */
.responsive-p-sm { padding: var(--spacing-sm); }
.responsive-p-md { padding: var(--spacing-md); }
.responsive-p-lg { padding: var(--spacing-lg); }

.responsive-m-sm { margin: var(--spacing-sm); }
.responsive-m-md { margin: var(--spacing-md); }
.responsive-m-lg { margin: var(--spacing-lg); }

/* Responsive widths */
.responsive-w-full { width: 100%; max-width: 100%; }
.responsive-w-90 { width: 90vw; max-width: 90vw; }
.responsive-w-80 { width: 80vw; max-width: 80vw; }

/* ========================================
   PREVENT OVERFLOW & CLIPPING
   ======================================== */

@media (max-width: 768px) {
  
  /* Prevent horizontal scrolling */
  body, html, #root, .poly-main-content {
    overflow-x: hidden;
    max-width: 100vw;
  }
  
  /* Ensure containers don't overflow */
  .container,
  .container-fluid,
  .row,
  .col,
  [class*="col-"] {
    max-width: 100%;
    overflow-x: hidden;
  }
  
  /* Handle long text */
  h1, h2, h3, h4, h5, h6, p {
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
  }
  
  /* Images and media */
  img,
  video,
  iframe {
    max-width: 100%;
    height: auto;
  }
  
  /* Tables */
  table {
    width: 100%;
    overflow-x: auto;
    display: block;
  }
}

/* ========================================
   DASHBOARD-SPECIFIC MOBILE FIXES
   ======================================== */

@media (max-width: 768px) {
  
  /* Dashboard grid - Single column on mobile */
  .dashboard-main-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-sm);
  }
  
  /* Map container */
  #map {
    height: 18.75rem;
    min-height: 18.75rem;
  }
  
  /* Stats cards */
  .stat-card {
    padding: var(--spacing-sm);
    margin-bottom: var(--spacing-xs);
  }
  
  .stat-value {
    font-size: var(--font-size-xl);
  }
  
  .stat-label {
    font-size: var(--font-size-xs);
  }
}

/* ========================================
   PRINT STYLES
   ======================================== */

@media print {
  .poly-left-dock,
  .poly-top-bar,
  .poly-nav-toggle,
  .poly-overlay {
    display: none;
  }
  
  .poly-main-content {
    margin: 0;
    padding: 0;
  }
}
