/**
 * Global mobile-friendly tweaks — load after page-specific CSS.
 */

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

body {
  overflow-x: clip;
}

/* Notched devices */
.header {
  padding-top: env(safe-area-inset-top, 0);
}

@media (max-width: 768px) {
  .header-container {
    padding-left: max(0.75rem, env(safe-area-inset-left, 0px));
    padding-right: max(0.75rem, env(safe-area-inset-right, 0px));
    align-items: center;
  }
}

.site-footer {
  padding-bottom: max(2.5rem, calc(2rem + env(safe-area-inset-bottom, 0px)));
}

/* Touch-friendly menu button */
.mobile-menu-btn {
  min-width: 44px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mobile-menu-close {
  min-width: 44px;
  min-height: 44px;
}

/* Full-width drawer on small phones */
@media (max-width: 480px) {
  .mobile-menu-content {
    width: 100% !important;
    max-width: min(100vw, 100%) !important;
  }
}

/* Backtest home */
@media (max-width: 768px) {
  .backtest-page {
    padding: 1rem max(0.75rem, env(safe-area-inset-right)) 1.5rem
      max(0.75rem, env(safe-area-inset-left)) !important;
  }

  .backtest-page__card {
    padding: 1.15rem !important;
  }

  .backtest-page__hero {
    margin-bottom: 1.5rem;
  }

  .form-section {
    padding: 1rem 0 !important;
  }

  .backtest-page__card .form-grid {
    grid-template-columns: 1fr;
    gap: 1rem;
  }

  .backtest-page__progress-wrap:has(.progress-indicator.active),
  .backtest-page__progress-wrap:has(.progress-indicator.hiding) {
    padding: 1rem !important;
  }
}

/* Progress phases: stack on narrow screens */
@media (max-width: 640px) {
  .backtest-page__progress-wrap .progress-indicator__header {
    flex-direction: column;
    align-items: flex-start;
  }

  .backtest-page__progress-wrap .progress-indicator__status {
    padding: 0.35rem 0.65rem;
  }

  .progress-phases {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    margin-bottom: 0;
  }

  .progress-line {
    display: none;
  }

  .progress-phase {
    flex-direction: row;
    justify-content: flex-start;
    align-items: center;
    gap: 0.85rem;
    flex: none;
  }

  .progress-dot {
    width: 36px;
    height: 36px;
    font-size: 1rem;
    flex-shrink: 0;
  }

  .progress-label {
    text-align: left;
    font-size: 0.8125rem;
  }
}

/* Screener */
@media (max-width: 768px) {
  .screener-page {
    padding: 1rem 0.75rem !important;
  }

  .screener-hero-title {
    font-size: 1.4rem !important;
  }

  .screener-hero-desc {
    font-size: 0.875rem !important;
  }

  .screener-card {
    padding: 1.15rem !important;
  }

  .screener-controls {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1rem !important;
  }

  .screener-controls label {
    width: 100%;
  }

  .screener-controls input,
  .screener-controls select {
    width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box;
  }

  .screener-controls input[type='number'] {
    width: 100% !important;
    max-width: 100%;
  }

  .screener-controls .btn-primary-action {
    margin-left: 0 !important;
    width: 100%;
    justify-content: center;
    min-height: 44px;
    box-sizing: border-box;
  }

  .screener-table-wrap {
    -webkit-overflow-scrolling: touch;
    margin: 0 -0.25rem;
  }

  .screener-table {
    font-size: 0.78rem;
  }

  .screener-table th,
  .screener-table td {
    padding: 0.5rem 0.55rem;
  }

  .screener-idle,
  .screener-loading {
    padding: 1.25rem !important;
    font-size: 0.875rem;
  }
}

/* Rank */
@media (max-width: 768px) {
  .rank-page {
    padding: 1rem 0.75rem !important;
  }

  .rank-hero-title {
    font-size: 1.4rem !important;
  }

  .rank-card {
    padding: 1.15rem !important;
  }

  .rank-controls {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 1rem !important;
  }

  .rank-controls-fields {
    flex-direction: column !important;
    width: 100%;
    gap: 1rem !important;
  }

  .rank-controls label {
    width: 100%;
  }

  .rank-controls input,
  .rank-controls .metric-dropdown {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
  }

  .rank-controls > .btn-primary-action {
    width: 100%;
    min-height: 44px;
    justify-content: center;
    margin-top: 0.25rem;
  }

  .rank-table {
    font-size: 0.72rem;
  }

  .rank-table th,
  .rank-table td {
    padding: 0.4rem 0.35rem;
  }

  .rank-loading,
  .rank-error {
    padding: 1.25rem !important;
  }
}

/* Analyze */
@media (max-width: 768px) {
  .analyze-page {
    padding: 1rem 0.75rem !important;
  }

  .analyze-page-hero-title {
    font-size: 1.4rem !important;
  }

  .analyze-page-hero-desc {
    font-size: 0.875rem !important;
  }

  .analyze-config-card {
    padding: 1.15rem !important;
  }

  .analyze-controls-secondary {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .analyze-controls-secondary .control-group {
    width: 100%;
  }

  .analyze-table-wrap,
  .stats-table-wrap {
    -webkit-overflow-scrolling: touch;
    margin-left: -0.25rem;
    margin-right: -0.25rem;
  }

  .metric-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 0.65rem !important;
  }
}

@media (max-width: 480px) {
  .metric-cards {
    grid-template-columns: 1fr !important;
  }
}

/* Flatpickr: avoid overflow on narrow screens */
@media (max-width: 400px) {
  .flatpickr-calendar {
    max-width: calc(100vw - 1rem) !important;
  }
}

/* Results report horizontal safety */
@media (max-width: 768px) {
  .report__compare-row {
    flex-direction: column;
  }

  .results-content {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

/* Legal pages */
@media (max-width: 768px) {
  .legal-page {
    padding-left: max(1rem, env(safe-area-inset-left)) !important;
    padding-right: max(1rem, env(safe-area-inset-right)) !important;
  }

  .legal-page__header-inner {
    flex-wrap: wrap;
    gap: 0.75rem;
  }
}

/* Logo: prevent header overflow */
@media (max-width: 380px) {
  .brand-subtitle {
    display: none;
  }
}
