    /* ════════════════════════════
       MOBILE  ≤ 480px
    ════════════════════════════ */
    @media (max-width: 480px) {
      body { padding: 20px 0 76px; }
      .card { max-width: 95vw; margin: 0 auto; }

      .top-header { padding: 16px 16px 10px; }
      .top-title { font-size: 18px; padding-right: 48px; }
      .tagline { font-size: 19px; }
      .wedding-date { font-size: 14px; }

      .bottom-text { padding: 10px 20px 36px; }
      .inv-label { font-size: 17px; }
      .couple-names { font-size: 22px; }

      .music-section { padding: 16px 16px 18px; }
      .player-card { padding: 14px 14px 12px; }
      .song-title { font-size: 14px; }
      .playing-status { font-size: 11px; }
      .player-thumb { width: 72px; height: 54px; }

      .note-section { padding: 72px 16px 16px; }
      .note-card { padding: 32px 14px 24px; }
      .note-photo { height: 220px; }
      .greeting { font-size: 36px; }
      .poem p { font-size: 19px; }

      .quote-section { padding: 28px 20px 24px; }
      .quote-mark { font-size: 64px; }
      .quote-text p { font-size: 18px; }

      .badge { font-size: 13px; padding: 10px 24px; }

      .poem-four { padding: 20px 20px 24px; }
      .poem-four p { font-size: 19px; }

      .gallery-main { height: 220px; width: 85%; }
      .gallery-left-photo { height: 140px; }
      .gallery-text .en { font-size: 16px; }
      .closing-quote .vi { font-size: 20px; }

      .couple-photo-frame { height: 260px; }
      .countdown-num { font-size: 32px; }
      .countdown-item { min-width: 56px; }
      .countdown-grid { gap: 10px; }
      .poem-two { padding: 16px 20px 28px; }
      .poem-two p { font-size: 19px; }

      .final-gallery { padding: 8px 14px 0; }
      .final-wide-photo { height: 200px; width: 80%; }
      .name-grid { gap: 10px; margin-bottom: 10px; }
      .name-grid-photo { height: 130px; margin-bottom: 10px; }
      .name-grid-info .person-name { font-size: 28px; }
      .name-grid-right { margin-top: 28px; }
      .final-bottom-photo { height: 220px; width: 90%; margin-top: 50px; }

      .quote3-section { padding: 28px 20px 24px; }
      .quote3-box .quote-mark { font-size: 64px; }
      .quote3-text p { font-size: 18px; }
      .mountain-decor { padding: 10px 14px 4px; }
      .badge3-section .badge { font-size: 13px; padding: 10px 24px; }
      .poem-three { padding: 20px 20px 28px; }
      .poem-three p { font-size: 19px; }

      .event-section { padding: 28px 16px 20px; }
      .event-card { padding: 82px 14px 22px; }
      .cal-watermark { font-size: 76px; }
      .cal-cell { font-size: 13px; padding: 5px 0; }
      .cal-cell.highlight::before { width: 28px; height: 28px; }
      .map-frame { height: 180px; }
      .address-label { font-size: 17px; }
      .address-text { font-size: 11px; }

      .love-poem-section { padding: 28px 20px 24px; }
      .love-poem-section p { font-size: 19px; }
      .love-gallery { padding: 8px 14px 0; }
      .love-gallery-left { height: 300px; }
      .love-gallery-right { margin-top: 40px; }
      .love-gallery-right-photo { height: 200px; }
      .love-name { font-size: 28px; }
      .names-amp { font-size: 20px; }
      .love-bottom-photo { height: 220px; width: 92%; }

      .dear-section { padding: 20px 16px 32px; }
      .dear-card { padding: 40px 16px 24px; }
      .dear-title { font-size: 18px; padding: 7px 22px; }
      .dear-item-heart { width: 22px; height: 22px; }
      .dear-item-text { font-size: 12px; }
      .dear-buttons { gap: 12px; }
      .dear-btn { font-size: 11px; padding: 10px 12px; }

      /* Closing section mobile */
      .closing-photo { height: 280px; width: 88%; }
      .closing-text p { font-size: 17px; }
      .closing-thankyou { font-size: 40px; }
      .closing-car { width: 160px; }
      .closing-label { font-size: 22px; letter-spacing: 0.04em; }

      /* RSVP modal mobile */
      .rsvp-modal { padding: 28px 20px 24px; max-width: 92vw; }
      .rsvp-title { font-size: 22px; }
      .rsvp-desc  { font-size: 14px; }

      /* Wishes bar mobile */
      .wishes-bar { max-width: 78vw; bottom: 12px; gap: 6px; }
      /* font-size 16px prevents iOS auto-zoom on focus */
      .wishes-input-row input { font-size: 16px; padding: 7px 11px; }
      .wishes-input-row input::placeholder { font-size: 13px; }
      .wishes-bar.is-typing .wishes-send-btn { width: 34px; height: 34px; }
      .wishes-ticker-toggle { width: 32px; height: 32px; }
      .wishes-ticker { width: 260px; left: -22px; max-height: 200px; bottom: 42px; }
      .wishes-suggestions { left: 38px; bottom: 44px; }
      .wishes-chip { font-size: 11px; padding: 4px 10px; }
      .wishes-name-modal { padding: 24px 18px 20px; max-width: 90vw; }
      .wishes-name-modal h3 { font-size: 20px; }
      /* Prevent zoom on modal inputs */
      .rsvp-input, .wishes-name-modal input { font-size: 16px; }
      /* Tagline shift on mobile */
      .tagline.shifted { transform: translateX(-40px); }
      .wedding-date.shifted { transform: translateX(-40px); }
    }
