/*
 * LT-VMI Responsive — mobile overrides for all bank pages.
 * Loaded after lt-vmi-base.css and bank-specific styles.
 */
html { -webkit-text-size-adjust: 100%; }
img, video, svg { max-width: 100%; height: auto; }
table { display: block; overflow-x: auto; }

/* ============================================================ Mobile < 480px */
@media (max-width: 480px) {
  /* --- Generic: kill horizontal scroll --- */
  html, body { overflow-x: hidden; width: 100%; }
  input, select, textarea, button { max-width: 100%; }
  * { word-break: break-word; }

  /* --- VMI Index --- */
  .vmi-header-inner { flex-wrap: wrap; padding: 0 14px; gap: 10px; }
  .vmi-logo-mark { width: 32px; height: 32px; font-size: 14px; }
  .vmi-logo-text .l1 { font-size: 12px; }
  .vmi-logo-text .l2 { font-size: 11px; }
  .vmi-page-title { font-size: 19px; }
  .vmi-page-lead { font-size: 13px; margin-bottom: 20px; }
  .vmi-stepper { padding: 14px; gap: 12px; }
  .vmi-bank { padding: 14px; min-height: 100px; gap: 8px; }
  .vmi-bank-logo { height: 28px; }
  .vmi-bank-logo img, .vmi-bank-logo svg { max-height: 22px; }
  .vmi-bank-logo .text-logo { font-size: 16px; }
  .vmi-bank-name { font-size: 13px; }
  .vmi-bank-tag { font-size: 11px; }
  .vmi-bank-arrow { top: 14px; right: 14px; width: 16px; height: 16px; font-size: 9px; }
  .vmi-trust { flex-direction: column; gap: 10px; padding: 14px; }
  .vmi-trust-item { font-size: 12px; }
  .vmi-step { gap: 10px; }
  .vmi-step-num { flex: 0 0 26px; width: 26px; height: 26px; font-size: 12px; }
  .vmi-step-body h3 { font-size: 13px; }
  .vmi-step-body p { font-size: 12px; }
  .vmi-footer-grid { gap: 12px; }
  .vmi-lang button { padding: 4px 8px; font-size: 12px; }
  .vmi-cookie { left: 12px; right: 12px; bottom: 12px; padding: 14px; font-size: 12px; max-width: none; }

  /* --- Swedbank --- */
  .sw-header { padding: 8px 14px !important; flex-wrap: wrap !important; gap: 8px !important; }
  .sw-logo { font-size: 18px !important; }
  .sw-logo::after { width: 20px !important; height: 20px !important; }
  .sw-nav { margin-left: 0 !important; gap: 6px !important; order: 3; width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .sw-nav__item { font-size: 12px !important; white-space: nowrap; padding: 6px 2px !important; }
  .sw-header__right { gap: 8px !important; }
  .sw-header__right a { font-size: 12px !important; }
  .sw-lang-btn { font-size: 12px !important; }
  .sw-content { padding: 16px !important; }
  .sw-form { padding: 16px !important; }
  #sw-login-form { padding: 12px !important; }
  #userId, #secondary { font-size: 14px !important; padding: 10px 12px !important; }
  .sw-btn { width: 100% !important; padding: 12px !important; font-size: 14px !important; }
  .sw-warn { padding: 10px !important; font-size: 12px !important; }
  .sw-tab { font-size: 13px !important; padding: 8px 6px !important; }
  .sw-footer { padding: 16px !important; flex-direction: column !important; text-align: center !important; }

  /* --- SEB --- */
  [class*="login-wrapper"], [class*="login-container"] { padding: 0 12px !important; }
  [class*="login-box"], [class*="login-card"] { padding: 16px !important; border-radius: 8px !important; }
  [class*="loading"] { padding: 16px !important; }

  /* --- Luminor --- */
  [class*="login-page"], [class*="login-content"] { padding: 0 12px !important; }
  [class*="login-form"] { padding: 16px !important; }

  /* --- Citadele --- */
  [class*="login-section"], [class*="form-section"] { padding: 0 10px !important; }
  [class*="login-panel"], [class*="login-frame"] { padding: 12px !important; }

  /* --- Flow pages (MPIN, OTP, card, personal, etc.) --- */
  .verification-container { padding: 20px 14px !important; }
  .verification-code { font-size: 28px !important; padding: 16px !important; max-width: 140px !important; letter-spacing: 6px !important; }
  .instructions { font-size: 13px !important; margin: 14px 0 !important; }
  .sub-instructions { font-size: 12px !important; }
  .loader { width: 24px !important; height: 24px !important; margin: 14px auto !important; }

  /* --- OTP --- */
  .lt-otp-group { gap: 4px; }
  .lt-otp-input { width: 40px; height: 48px; font-size: 20px; }

  /* --- Modals --- */
  .lt-error-card { width: calc(100% - 20px); padding: 16px; margin: 10px; }
  .lt-transition-card { min-width: auto; width: calc(100% - 32px); padding: 16px; }
}

/* ============================================================ Tablet 481-900px */
@media (min-width: 481px) and (max-width: 900px) {
  /* --- Swedbank --- */
  .sw-header { padding: 10px 24px !important; }
  .sw-nav { margin-left: 20px !important; gap: 14px !important; }
  .sw-nav__item { font-size: 13px !important; }

  /* --- Flow pages --- */
  .verification-container { padding: 30px 16px !important; }
  .verification-code { font-size: 36px !important; padding: 24px !important; }
}

/* ============================================================ Very small screens */
@media (max-width: 360px) {
  .vmi-bank-grid { gap: 8px; }
  .vmi-bank { padding: 10px; min-height: 80px; }
  .vmi-bank-logo { height: 24px; }
  .vmi-bank-logo img, .vmi-bank-logo svg { max-height: 18px; }
  .vmi-bank-logo .text-logo { font-size: 14px; }
  .vmi-bank-arrow { display: none; }
  .sw-logo { font-size: 16px !important; }
  .lt-otp-input { width: 34px; height: 42px; font-size: 18px; }
}
