/**
 * Account, Auth & Pricing Pages - Mobile Optimization
 * Bloomberg-grade finance UX for mobile devices
 * 
 * @package ZL\Theme
 */

/* ============================================
   MOBILE BREAKPOINT (<768px)
   ============================================ */
@media (max-width: 767px) {

  /* ============================================
     ACCOUNT PAGE - Ultra-compact mobile
     ============================================ */
  .zl-profile-page {
    padding: 8px !important;
    padding-bottom: 80px !important;
  }
  
  .zl-profile-page .account-wrapper {
    max-width: 100% !important;
  }
  
  /* Header - Stack vertically */
  .account-header {
    flex-direction: column !important;
    gap: 8px !important;
    margin-bottom: 12px !important;
  }
  
  .account-title {
    font-size: 1.25rem !important;
  }
  
  .account-subtitle {
    font-size: 0.75rem !important;
    margin-top: 2px !important;
  }
  
  .account-header-meta {
    gap: 6px !important;
  }
  
  .account-member-since {
    font-size: 0.6875rem !important;
  }
  
  .account-badge {
    padding: 3px 6px !important;
    font-size: 0.5625rem !important;
    border-radius: 4px !important;
  }
  
  .account-badge svg {
    width: 12px !important;
    height: 12px !important;
  }
  
  /* Tabs - Horizontal scroll */
  .account-tabs {
    display: flex !important;
    overflow-x: auto !important;
    gap: 4px !important;
    padding: 4px !important;
    margin: 0 -8px !important;
    width: calc(100% + 16px) !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    background: var(--bg-tertiary) !important;
    border-radius: 0 !important;
  }
  
  .account-tabs::-webkit-scrollbar {
    display: none !important;
  }
  
  .account-tab {
    flex: 0 0 auto !important;
    padding: 8px 12px !important;
    font-size: 0.6875rem !important;
    gap: 4px !important;
    white-space: nowrap !important;
    border-radius: 6px !important;
    min-height: 40px !important;
  }
  
  .account-tab svg {
    width: 16px !important;
    height: 16px !important;
  }
  
  .account-tab span {
    display: inline !important;
  }
  
  /* Panels */
  .account-panels {
    margin-top: 8px !important;
  }
  
  .account-panel {
    padding: 0 !important;
  }
  
  /* Sections - Full width */
  .account-section {
    margin-bottom: 8px !important;
    padding: 12px !important;
    border-radius: 8px !important;
  }
  
  .account-section-header {
    margin-bottom: 12px !important;
  }
  
  .account-section-title {
    font-size: 0.9375rem !important;
  }
  
  .account-section-subtitle {
    font-size: 0.6875rem !important;
    margin-top: 2px !important;
  }
  
  /* Form fields */
  .account-form {
    gap: 12px !important;
  }
  
  .account-field {
    margin-bottom: 12px !important;
  }
  
  .account-label {
    font-size: 0.6875rem !important;
    margin-bottom: 4px !important;
  }
  
  .account-input {
    padding: 10px 12px !important;
    font-size: 0.875rem !important;
    border-radius: 6px !important;
    min-height: 44px !important;
  }
  
  .account-hint {
    font-size: 0.5625rem !important;
    margin-top: 4px !important;
  }
  
  /* Buttons */
  .account-btn {
    padding: 10px 16px !important;
    font-size: 0.8125rem !important;
    border-radius: 6px !important;
    min-height: 44px !important;
  }
  
  .account-btn-primary {
    width: 100% !important;
  }
  
  /* Password strength */
  .password-strength-bar {
    height: 3px !important;
    margin-top: 6px !important;
  }
  
  /* Subscription section */
  .subscription-card {
    padding: 12px !important;
    border-radius: 8px !important;
  }
  
  .subscription-header {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: flex-start !important;
  }
  
  .subscription-plan-name {
    font-size: 1rem !important;
  }
  
  .subscription-status {
    padding: 3px 8px !important;
    font-size: 0.5625rem !important;
  }
  
  .subscription-details {
    gap: 8px !important;
    margin-top: 12px !important;
  }
  
  .subscription-detail {
    font-size: 0.75rem !important;
  }
  
  /* ============================================
     AUTH PAGES - Mobile optimized
     ============================================ */
  .auth-page {
    padding: 8px !important;
    padding-bottom: 24px !important;
    align-items: flex-start !important;
    padding-top: 16px !important;
  }
  
  .auth-container {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    border-radius: 12px !important;
    max-width: 100% !important;
  }
  
  /* Hide sidebar on mobile */
  .auth-sidebar {
    display: none !important;
  }
  
  /* Form section */
  .auth-form-section {
    padding: 20px 16px !important;
  }
  
  .auth-form-section::before {
    height: 2px !important;
  }
  
  .auth-header {
    margin-bottom: 16px !important;
    text-align: center !important;
  }
  
  .auth-title {
    font-size: 1.25rem !important;
  }
  
  .auth-subtitle {
    font-size: 0.75rem !important;
  }
  
  /* Form */
  .auth-form {
    gap: 12px !important;
  }
  
  .auth-field {
    margin-bottom: 0 !important;
  }
  
  .auth-label {
    font-size: 0.6875rem !important;
    margin-bottom: 4px !important;
  }
  
  .auth-input-wrapper {
    position: relative !important;
  }
  
  .auth-input {
    padding: 10px 12px !important;
    font-size: 0.875rem !important;
    border-radius: 6px !important;
    min-height: 44px !important;
  }
  
  .auth-input-icon {
    left: 10px !important;
  }
  
  .auth-input-icon svg {
    width: 16px !important;
    height: 16px !important;
  }
  
  .auth-input.has-icon {
    padding-left: 36px !important;
  }
  
  .auth-password-toggle {
    right: 10px !important;
  }
  
  .auth-password-toggle svg {
    width: 16px !important;
    height: 16px !important;
  }
  
  .auth-error {
    font-size: 0.625rem !important;
    margin-top: 4px !important;
  }
  
  /* Remember me / Forgot password row */
  .auth-options {
    flex-direction: column !important;
    gap: 8px !important;
    align-items: center !important;
  }
  
  .auth-remember label {
    font-size: 0.75rem !important;
  }
  
  .auth-forgot {
    font-size: 0.75rem !important;
  }
  
  /* Submit button */
  .auth-submit {
    padding: 12px 16px !important;
    font-size: 0.875rem !important;
    border-radius: 8px !important;
    min-height: 48px !important;
    margin-top: 8px !important;
  }
  
  /* Social login */
  .auth-divider {
    margin: 16px 0 !important;
    font-size: 0.6875rem !important;
  }
  
  .auth-social-buttons {
    gap: 8px !important;
  }
  
  .auth-social-btn {
    padding: 10px 12px !important;
    font-size: 0.75rem !important;
    min-height: 44px !important;
  }
  
  .auth-social-btn svg {
    width: 18px !important;
    height: 18px !important;
  }
  
  /* Footer links */
  .auth-footer {
    margin-top: 16px !important;
    text-align: center !important;
  }
  
  .auth-footer-text {
    font-size: 0.75rem !important;
  }
  
  .auth-footer-link {
    font-size: 0.75rem !important;
  }
  
  /* Terms */
  .auth-terms {
    font-size: 0.5625rem !important;
    margin-top: 12px !important;
    text-align: center !important;
  }
  
  /* ============================================
     PRICING PAGE - Mobile optimized
     ============================================ */
  .pricing-page {
    padding-bottom: 80px !important;
  }
  
  .pricing-container {
    padding: 0 8px !important;
  }
  
  /* Hero */
  .pricing-hero {
    padding: 16px 8px 12px !important;
  }
  
  .pricing-hero-badge {
    padding: 4px 8px !important;
    font-size: 0.6875rem !important;
    margin-bottom: 10px !important;
  }
  
  .pricing-hero-title {
    font-size: 1.5rem !important;
    line-height: 1.2 !important;
    margin-bottom: 8px !important;
  }
  
  .pricing-hero-subtitle {
    font-size: 0.8125rem !important;
    line-height: 1.4 !important;
  }
  
  /* Toggle */
  .pricing-toggle-wrapper {
    margin-top: 16px !important;
  }
  
  .pricing-toggle {
    padding: 3px !important;
    border-radius: 8px !important;
  }
  
  .pricing-toggle-btn {
    padding: 8px 16px !important;
    font-size: 0.75rem !important;
    border-radius: 6px !important;
    min-height: 36px !important;
  }
  
  .pricing-save-badge {
    padding: 2px 6px !important;
    font-size: 0.5rem !important;
    top: -8px !important;
    right: -8px !important;
  }
  
  /* Cards grid */
  .pricing-grid {
    display: flex !important;
    flex-direction: column !important;
    gap: 12px !important;
    padding: 12px 8px !important;
  }
  
  /* Card */
  .pricing-card {
    padding: 16px !important;
    border-radius: 12px !important;
  }
  
  .pricing-card-featured {
    padding: 16px !important;
    margin: 0 !important;
    transform: none !important;
  }
  
  .pricing-featured-badge {
    top: -8px !important;
    padding: 4px 10px !important;
    font-size: 0.5625rem !important;
    border-radius: 4px !important;
  }
  
  .pricing-card-header {
    padding-bottom: 12px !important;
    margin-bottom: 12px !important;
  }
  
  .pricing-plan-name {
    font-size: 1rem !important;
  }
  
  .pricing-plan-description {
    font-size: 0.6875rem !important;
    margin-top: 4px !important;
  }
  
  .pricing-price {
    margin: 8px 0 !important;
  }
  
  .pricing-currency {
    font-size: 1rem !important;
  }
  
  .pricing-amount {
    font-size: 2rem !important;
  }
  
  .pricing-period {
    font-size: 0.75rem !important;
  }
  
  .pricing-original-price {
    font-size: 0.75rem !important;
  }
  
  /* Features */
  .pricing-features {
    gap: 6px !important;
    padding: 12px 0 !important;
  }
  
  .pricing-feature {
    font-size: 0.75rem !important;
    gap: 6px !important;
    padding: 4px 0 !important;
  }
  
  .pricing-feature svg {
    width: 14px !important;
    height: 14px !important;
    flex-shrink: 0 !important;
  }
  
  /* CTA button */
  .pricing-cta {
    padding: 12px 16px !important;
    font-size: 0.875rem !important;
    border-radius: 8px !important;
    min-height: 48px !important;
    margin-top: 12px !important;
  }
  
  /* FAQ */
  .pricing-faq {
    padding: 16px 8px !important;
  }
  
  .pricing-faq-title {
    font-size: 1.25rem !important;
    margin-bottom: 16px !important;
  }
  
  .pricing-faq-grid {
    gap: 8px !important;
  }
  
  .pricing-faq-item {
    padding: 12px !important;
    border-radius: 8px !important;
  }
  
  .pricing-faq-question {
    font-size: 0.8125rem !important;
  }
  
  .pricing-faq-answer {
    font-size: 0.75rem !important;
    margin-top: 8px !important;
    line-height: 1.5 !important;
  }
  
  /* Categories */
  .pricing-categories {
    padding: 12px 8px !important;
    gap: 12px !important;
  }
  
  .pricing-category-title {
    font-size: 1rem !important;
  }
  
  .pricing-category-grid {
    gap: 6px !important;
  }
  
  .pricing-category-item {
    padding: 8px 10px !important;
    font-size: 0.75rem !important;
    border-radius: 6px !important;
  }

}

/* ============================================
   TABLET BREAKPOINT (768px - 1023px)
   ============================================ */
@media (min-width: 768px) and (max-width: 1023px) {
  
  /* Auth - Single column but larger */
  .auth-container {
    grid-template-columns: 1fr !important;
    max-width: 480px !important;
  }
  
  .auth-sidebar {
    display: none !important;
  }
  
  /* Pricing - 2 columns */
  .pricing-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 16px !important;
  }
  
  .pricing-card-featured {
    transform: none !important;
    margin: 0 !important;
  }
  
}

/* ============================================
   LIGHT MODE FIXES
   ============================================ */
:root:not(.dark) {
  
  @media (max-width: 767px) {
    
    /* Account tabs */
    .account-tabs {
      background: rgba(0, 0, 0, 0.03) !important;
    }
    
    /* Auth page */
    .auth-page {
      background: #f8fafc !important;
    }
    
    .auth-container {
      background: #ffffff !important;
      border-color: rgba(0, 0, 0, 0.1) !important;
      box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08) !important;
    }
    
    .auth-form-section::before {
      opacity: 1 !important;
    }
    
    /* Pricing */
    .pricing-page {
      background: #f8fafc !important;
    }
    
    .pricing-card {
      background: #ffffff !important;
      border-color: rgba(0, 0, 0, 0.08) !important;
    }
    
    .pricing-card-featured {
      background: linear-gradient(135deg, #ffffff 0%, #f8fafc 100%) !important;
    }
    
  }
  
}

/* ============================================
   SAFE AREA INSETS
   ============================================ */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
  @media (max-width: 767px) {
    .zl-profile-page,
    .pricing-page {
      padding-bottom: calc(80px + env(safe-area-inset-bottom)) !important;
    }
  }
}
