/* ============================================================
   WinLogicPro — mobile-fixes.css
   ADD these rules to the BOTTOM of assets/style.css
   Fixes mobile responsiveness across ALL pages
   ============================================================ */

/* ---- GLOBAL MOBILE BASE ---- */
@media (max-width: 768px) {

  /* Nav */
  .nav { padding: 0 16px; height: 58px; }
  .nav-links, .nav-actions { display: none !important; }
  .nav-hamburger { display: flex !important; }
  .nav-logo-icon { height: 36px !important; }
  .nav-logo-name { font-size: 18px !important; }
  .nav-logo-tagline { display: none; }

  /* Mobile menu full-width */
  .mobile-menu { padding: 12px 16px 16px; }
  .mobile-menu a { font-size: 15px; padding: 12px 0; }

  /* Hero */
  .hero { padding: 48px 16px 52px; }
  .hero h1 { font-size: clamp(42px, 12vw, 72px); }
  .hero-sub { font-size: 15px; margin-bottom: 28px; }
  .hero-ctas { flex-direction: column; align-items: center; gap: 10px; }
  .btn-hero-primary, .btn-hero-secondary { width: 100%; max-width: 320px; text-align: center; }
  .hero-stats { gap: 20px; flex-wrap: wrap; justify-content: center; padding-top: 28px; margin-top: 36px; }
  .hero-stat-num { font-size: 30px; }
  .hero-stat-label { font-size: 11px; }

  /* Ticker */
  .tick-item { padding: 0 18px; }

  /* Sections */
  .section { padding: 48px 16px; }
  .section-title { font-size: clamp(28px, 8vw, 42px); }
  .section-sub { font-size: 14px; }

  /* Features grid: 1 column on mobile */
  .features-grid { grid-template-columns: 1fr !important; gap: 12px; }
  .feat-card { padding: 20px 18px; }

  /* How it works: 1 column */
  .steps-grid { grid-template-columns: 1fr !important; }
  .step { border-right: none !important; border-bottom: 1px solid var(--border); padding: 24px 16px; }
  .step:last-child { border-bottom: none; }
  .step-num { font-size: 40px; }

  /* Pricing: 1 column stack */
  .pricing-grid { grid-template-columns: 1fr !important; max-width: 100% !important; gap: 14px; }
  .price-card.featured { transform: none !important; }
  .price-card { padding: 28px 20px; }
  .plan-amount { font-size: 48px; }

  /* News grid: 1 column */
  .news-grid { grid-template-columns: 1fr !important; }
  .news-main-thumb { height: 160px; }
  .news-headline { font-size: 20px; }

  /* CTA Banner */
  .cta-banner { padding: 48px 16px; }
  .cta-banner h2 { font-size: clamp(28px, 8vw, 44px); }
  .cta-banner .btn-hero-primary { width: 100%; max-width: 300px; }

  /* Footer */
  footer { padding: 36px 16px 24px; }
  .footer-top { grid-template-columns: 1fr !important; gap: 24px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px; }
  .footer-legal { text-align: left !important; font-size: 11px; }
  .footer-logo-icon { height: 44px !important; }

  /* Auth pages (login/register) */
  .auth-wrap { padding: 24px 16px; align-items: flex-start; padding-top: 32px; }
  .auth-card { padding: 28px 20px; border-radius: 14px; }

  /* Dashboard */
  .dash-wrap { padding: 20px 14px; }
  .dash-header { flex-direction: column; align-items: flex-start; gap: 12px; }
  .dash-greeting { font-size: 28px; }
  .metrics { grid-template-columns: 1fr 1fr !important; gap: 10px; }
  .metric-val { font-size: 28px; }
  .dash-grid { grid-template-columns: 1fr !important; }
  .quick-links { grid-template-columns: 1fr 1fr; gap: 8px; }

  /* Pricing page */
  .pricing-page { padding: 36px 16px; }
  .billing-toggle-wrap { gap: 10px; font-size: 13px; }

  /* Prediction card */
  .match-tab { font-size: 11px; padding: 5px 10px; }

  /* Trust strip */
  .trust-strip { flex-direction: column; align-items: center; gap: 10px; text-align: center; }
}

/* ---- SMALL PHONES (under 400px) ---- */
@media (max-width: 400px) {
  .hero h1 { font-size: 38px; letter-spacing: 1px; }
  .hero-badge { font-size: 10px; padding: 5px 12px; }
  .hero-stats { gap: 16px; }
  .hero-stat-num { font-size: 26px; }
  .metrics { grid-template-columns: 1fr !important; }
  .quick-links { grid-template-columns: 1fr !important; }
  .auth-card { padding: 22px 16px; }
  .plan-amount { font-size: 42px; }
  .match-tab { font-size: 10px; padding: 4px 8px; }
}

/* ---- TABLET (769px - 960px) ---- */
@media (min-width: 769px) and (max-width: 960px) {
  .nav { padding: 0 24px; }
  .nav-links { gap: 18px; }
  .nav-links a { font-size: 12px; }

  .section { padding: 60px 24px; }
  .hero { padding: 60px 24px 64px; }

  .features-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .steps-grid    { grid-template-columns: repeat(2, 1fr) !important; }
  .pricing-grid  { grid-template-columns: 1fr !important; max-width: 480px; margin: 0 auto; }
  .price-card.featured { transform: none !important; }
  .news-grid     { grid-template-columns: 1fr !important; }
  .footer-top    { grid-template-columns: 1fr 1fr !important; }
  .dash-grid     { grid-template-columns: 1fr !important; }
  .metrics       { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ---- ENSURE NAV HAMBURGER HIDDEN ON DESKTOP ---- */
@media (min-width: 769px) {
  .nav-hamburger { display: none !important; }
  .mobile-menu   { display: none !important; }
  .nav-links     { display: flex !important; }
  .nav-actions   { display: flex !important; }
}

/* ---- TOUCH IMPROVEMENTS ---- */
@media (hover: none) {
  .feat-card:hover    { transform: none; border-color: var(--border); }
  .news-mini:hover    { transform: none; border-color: var(--border); }
  .btn-primary:hover  { transform: none; opacity: 1; }
  .plan-btn:hover     { border-color: var(--border2); color: var(--text); }
}

/* ---- PREVENT HORIZONTAL SCROLL ---- */
html, body {
  overflow-x: hidden;
  max-width: 100%;
}

/* ---- TICKER on mobile: slightly smaller ---- */
@media (max-width: 480px) {
  .tick-item { font-size: 12px; padding: 0 14px; gap: 7px; }
  .tick-score { font-size: 13px; }
  .tick-live  { font-size: 9px; padding: 2px 5px; }
}

/* ---- PREDICTION CARD on mobile ---- */
@media (max-width: 680px) {
  .pred-lock-overlay button { font-size: 12px; padding: 10px 18px; }
}

/* ---- DASHBOARD NAV on mobile ---- */
@media (max-width: 768px) {
  .nav .nav-links[style] { display: none !important; }
}

/* ---- FORMS on mobile ---- */
@media (max-width: 480px) {
  .form-input { font-size: 16px; } /* prevents iOS zoom on input focus */
  .btn-submit { font-size: 15px; padding: 14px; }
  .checkbox-group { font-size: 13px; }
}

/* ---- PAYMENT SUCCESS on mobile ---- */
@media (max-width: 480px) {
  .success-card { padding: 36px 20px; }
  .success-title { font-size: 34px; }
  .success-icon { font-size: 52px; }
}
