/* ================================================================
   CIFRATURN — MOBILE FIXES
   Covers: shared, index.html, cifra.html
   Breakpoints: 960px / 768px / 480px / 360px
   ================================================================ */

/* ── 0. BASE RESET ─────────────────────────────────────────────── */
*,
*::before,
*::after {
    box-sizing: border-box;
}

html,
body {
    overflow-x: hidden;
    max-width: 100%;
    -webkit-text-size-adjust: 100%;
}

/* ================================================================
   1. HEADER — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .top-header {
        position: sticky;
        top: 0;
        z-index: 9000;
    }

    .header-container {
        display: grid;
        grid-template-columns: 1fr auto;
        grid-template-rows: auto auto;
        gap: 8px;
        padding: 10px 14px !important;
        align-items: center;
    }

    .logo-area {
        grid-column: 1;
        grid-row: 1;
    }

    .logo h1 {
        font-size: 20px !important;
    }

    .logo-slogan {
        display: none;
    }

    .user-area {
        grid-column: 2;
        grid-row: 1;
        display: flex;
        gap: 6px;
        align-items: center;
    }

    .btn-login,
    .btn-signup {
        padding: 7px 12px !important;
        font-size: 12px !important;
        min-height: 36px !important;
        border-radius: 8px !important;
    }

    .btn-signup {
        display: none;
    }

    /* Esconde "Cadastre-se" em mobile pequeno */

    .search-area {
        grid-column: 1 / -1;
        grid-row: 2;
    }

    .search-box input {
        font-size: 14px !important;
        padding: 10px 40px 10px 14px !important;
        border-radius: 10px !important;
    }
}

@media (max-width: 480px) {
    .header-container {
        padding: 8px 12px !important;
    }
}

/* ================================================================
   2. AUTH MODAL — FIX PRINCIPAL (scrollbar, overlay, layout)
   ================================================================ */

/* ================================================================
   2. AUTH MODAL — MOBILE LAYOUT (sem tocar no display)
   ================================================================ */
.auth-modal {
    position: relative !important;
    width: 100% !important;
    max-width: 440px !important;
    max-height: calc(100dvh - 24px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    border-radius: 20px !important;
    scrollbar-width: none !important;
    box-shadow: 0 32px 80px rgba(0, 0, 0, .55) !important;
}

.auth-modal::-webkit-scrollbar {
    display: none;
}

/* ================================================================
   3. MODAL GENÉRICO (metrônomo / afinador) — MOBILE
   ================================================================ */
@media (max-width: 768px) {

    #modal-overlay,
    .modal-overlay {
        padding: 12px !important;
        align-items: center !important;
        justify-content: center !important;
    }

    #modal-content,
    .modal-content {
        max-width: 100% !important;
        max-height: calc(100dvh - 24px) !important;
        border-radius: 18px !important;
    }

    #modal-body,
    .modal-body {
        padding: 16px !important;
    }

    .modal-header {
        padding: 16px 18px !important;
    }

    .modal-header h2 {
        font-size: 15px !important;
    }

    .modal-footer {
        padding: 12px 16px !important;
        gap: 8px !important;
    }

    .btn-modal {
        padding: 10px 16px !important;
        font-size: 13px !important;
    }
}

/* ================================================================
   4. MODAL ACORDES — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .modal-acordes-overlay {
        padding: 12px !important;
        align-items: center !important;
    }

    .modal-acordes-box {
        max-height: calc(100dvh - 24px) !important;
        border-radius: 18px !important;
    }

    .acordes-grid {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 10px !important;
        padding: 14px !important;
    }
}

/* ================================================================
   5. FOOTER — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .footer {
        padding: 32px 0 24px !important;
    }

    .footer-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 24px 16px !important;
        padding: 0 16px !important;
    }

    .footer h4 {
        font-size: 13px !important;
        margin-bottom: 10px !important;
    }

    .footer ul li a {
        font-size: 12px !important;
    }

    .footer-bottom {
        flex-direction: column !important;
        text-align: center !important;
        gap: 12px !important;
        padding: 0 16px !important;
    }

    .footer-copy p {
        font-size: 11px !important;
    }
}

@media (max-width: 480px) {
    .footer-grid {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
}

/* ================================================================
   6. PAINEL DO UTILIZADOR — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    #painel-usuario-overlay {
        padding: 0 !important;
        align-items: flex-end !important;
    }

    #painel-usuario {
        width: 100% !important;
        max-width: 100% !important;
        max-height: 85dvh !important;
        border-radius: 24px 24px 0 0 !important;
        box-shadow: 0 -16px 48px rgba(0, 0, 0, .5) !important;
    }
}


/* ╔══════════════════════════════════════════════════════════════╗
   ║                     INDEX.HTML MOBILE                       ║
   ╚══════════════════════════════════════════════════════════════╝ */

/* ================================================================
   7. HERO CAROUSEL — INDEX
   ================================================================ */
@media (max-width: 768px) {
    .carousel-slide img {
        height: 360px !important;
        object-position: center 30% !important;
    }

    .slide-overlay {
        padding: 20px 20px 60px !important;
        align-items: flex-start !important;
        background: linear-gradient(to top, rgba(0, 0, 0, .8) 0%, rgba(0, 0, 0, .35) 60%, transparent 100%) !important;
        justify-content: flex-end !important;
    }

    .slide-title {
        font-size: 20px !important;
        margin-bottom: 8px !important;
    }

    .slide-subtitle {
        font-size: 13px !important;
        margin-bottom: 16px !important;
    }

    .btn-carousel {
        padding: 10px 20px !important;
        font-size: 13px !important;
        min-height: 42px !important;
    }

    .carousel-nav {
        width: 36px !important;
        height: 36px !important;
        font-size: 13px !important;
    }

    .carousel-prev {
        left: 10px !important;
    }

    .carousel-next {
        right: 10px !important;
    }
}

@media (max-width: 480px) {
    .carousel-slide img {
        height: 300px !important;
    }

    .slide-title {
        font-size: 17px !important;
    }

    .slide-subtitle {
        font-size: 12px !important;
        margin-bottom: 12px !important;
    }
}

/* ================================================================
   8. RANKING — INDEX (principal fix)
   ================================================================ */
@media (max-width: 960px) {
    #ranking {
        padding: 28px 16px !important;
    }

    #ranking .section-header {
        margin-bottom: 16px !important;
    }

    #ranking .section-header h2 {
        font-size: 18px !important;
        display: flex !important;
        align-items: center !important;
        gap: 8px !important;
    }

    .ranking-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
    }

    .ranking-card {
        border-radius: 14px !important;
        overflow: hidden !important;
        border: 1px solid rgba(255, 255, 255, .07) !important;
        box-shadow: 0 4px 20px rgba(0, 0, 0, .12) !important;
    }

    .ranking-header {
        padding: 14px 16px !important;
        border-bottom: 1px solid rgba(255, 255, 255, .06) !important;
    }

    .ranking-header h3 {
        font-size: 14px !important;
        font-weight: 700 !important;
        margin: 0 !important;
    }

    .ranking-list {
        padding: 8px 0 !important;
    }

    /* Itens do ranking */
    .ranking-item,
    .playlist-item {
        display: flex !important;
        align-items: center !important;
        gap: 10px !important;
        padding: 10px 16px !important;
        min-height: 52px !important;
        cursor: pointer !important;
        transition: background .15s !important;
        border-bottom: 1px solid rgba(255, 255, 255, .04) !important;
    }

    .ranking-item:hover,
    .playlist-item:hover {
        background: rgba(255, 107, 53, .07) !important;
    }

    .ranking-item:last-child,
    .playlist-item:last-child {
        border-bottom: none !important;
    }

    /* Número do ranking */
    .playlist-number,
    .ranking-number {
        width: 28px !important;
        height: 28px !important;
        border-radius: 8px !important;
        font-size: 12px !important;
        font-weight: 800 !important;
        flex-shrink: 0 !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
    }

    /* Info do item */
    .ranking-info,
    .playlist-info {
        flex: 1 !important;
        min-width: 0 !important;
    }

    .ranking-info h4,
    .playlist-info h4,
    .ranking-titulo,
    .playlist-titulo {
        font-size: 13px !important;
        font-weight: 700 !important;
        margin: 0 0 2px !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .ranking-artista,
    .playlist-artista,
    .ranking-info p,
    .playlist-info p {
        font-size: 11px !important;
        margin: 0 !important;
    }
}

/* ================================================================
   9. VIDEOAULAS — INDEX
   ================================================================ */
@media (max-width: 960px) {
    .video-section {
        padding: 28px 16px !important;
    }

    .video-header h2 {
        font-size: 18px !important;
        margin-bottom: 16px !important;
    }

    .video-container {
        display: flex !important;
        flex-direction: column !important;
        gap: 0 !important;
    }

    .video-player {
        width: 100% !important;
        border-radius: 14px 14px 0 0 !important;
        overflow: hidden !important;
    }

    .video-thumb-wrap {
        width: 100% !important;
        aspect-ratio: 16/9 !important;
        position: relative !important;
    }

    .video-thumb-img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }

    .playlist {
        width: 100% !important;
        border-radius: 0 0 14px 14px !important;
        border-top: none !important;
        max-height: 280px !important;
        overflow-y: auto !important;
    }

    .playlist-header {
        padding: 12px 14px !important;
        font-size: 12px !important;
        font-weight: 700 !important;
        position: sticky !important;
        top: 0 !important;
        z-index: 2 !important;
    }

    .video-title-overlay {
        padding: 12px 14px !important;
    }

    .video-thumb-title {
        font-size: 14px !important;
        line-height: 1.3 !important;
    }

    .video-thumb-meta {
        font-size: 11px !important;
        gap: 8px !important;
    }
}

/* ================================================================
   10. FERRAMENTAS — INDEX
   ================================================================ */
@media (max-width: 960px) {
    #funcionalidades {
        padding: 28px 16px !important;
    }

    #funcionalidades .section-header {
        flex-wrap: wrap !important;
        gap: 8px !important;
        margin-bottom: 16px !important;
    }

    #funcionalidades .section-header h2 {
        font-size: 18px !important;
    }

    .features-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
    }

    .feature-card {
        padding: 18px 14px !important;
        border-radius: 14px !important;
    }

    .feature-icon {
        font-size: 26px !important;
        margin-bottom: 8px !important;
    }

    .feature-card h3 {
        font-size: 14px !important;
        margin-bottom: 4px !important;
    }

    .feature-card p {
        font-size: 12px !important;
        margin-bottom: 12px !important;
        line-height: 1.5 !important;
    }

    .feature-btn {
        width: 100% !important;
        padding: 10px 12px !important;
        font-size: 12px !important;
        min-height: 40px !important;
        border-radius: 10px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 6px !important;
    }
}

@media (max-width: 480px) {
    .features-grid {
        grid-template-columns: 1fr !important;
    }

    .feature-card {
        padding: 16px !important;
    }
}

/* ================================================================
   11. JOGOS — INDEX
   ================================================================ */
@media (max-width: 960px) {
    .games-section {
        padding: 32px 0 !important;
    }

    .games-inner {
        padding: 0 16px !important;
    }

    .games-header h2 {
        font-size: 22px !important;
    }

    .games-header p {
        font-size: 13px !important;
    }

    .games-tabs {
        display: flex !important;
        overflow-x: auto !important;
        gap: 6px !important;
        padding-bottom: 6px !important;
        margin-bottom: 16px !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .games-tabs::-webkit-scrollbar {
        display: none;
    }

    .games-tab {
        flex: 0 0 auto !important;
        padding: 8px 18px !important;
        font-size: 13px !important;
        min-height: 38px !important;
        border-radius: 20px !important;
        white-space: nowrap !important;
        border: 1.5px solid rgba(255, 255, 255, .15) !important;
        background: transparent !important;
        color: rgba(255, 255, 255, .6) !important;
        font-weight: 600 !important;
        cursor: pointer !important;
        transition: all .2s !important;
    }

    .games-tab.active {
        background: #ff6b35 !important;
        border-color: #ff6b35 !important;
        color: #fff !important;
    }

    .games-grid {
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }

    .game-card {
        border-radius: 16px !important;
        overflow: hidden !important;
    }

    .game-card-header {
        padding: 16px 16px 12px !important;
    }

    .game-card-footer {
        padding: 0 16px 12px !important;
    }

    .game-play-btn {
        width: calc(100% - 32px) !important;
        margin: 0 16px 16px !important;
        min-height: 44px !important;
        font-size: 14px !important;
        border-radius: 10px !important;
    }

    .games-xp-banner {
        padding: 8px 16px !important;
        font-size: 13px !important;
        border-radius: 10px !important;
    }
}

@media (max-width: 480px) {
    .game-card-icon {
        font-size: 28px !important;
    }

    .game-card h3 {
        font-size: 15px !important;
    }

    .game-card-desc {
        font-size: 12px !important;
    }
}


/* ╔══════════════════════════════════════════════════════════════╗
   ║                    CIFRA.HTML MOBILE                        ║
   ╚══════════════════════════════════════════════════════════════╝ */

/* ================================================================
   12. LAYOUT CIFRA — REORGANIZAÇÃO MOBILE
   ================================================================ */
@media (max-width: 960px) {
    .cifra-page-wrapper {
        grid-template-columns: 1fr !important;
        padding: 12px 14px 40px !important;
        gap: 12px !important;
    }

    .cifra-side-col {
        position: static !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        order: 2 !important;
        /* Sidebar ABAIXO da cifra */
    }

    .cifra-main-col {
        order: 1;
    }
}

/* ================================================================
   13. SONG HEADER CARD — CIFRA
   ================================================================ */
@media (max-width: 768px) {
    .song-header-card {
        padding: 16px 14px 0 !important;
        border-radius: 14px !important;
    }

    .song-header-top {
        gap: 12px !important;
        margin-bottom: 12px !important;
    }

    .artist-avatar {
        width: 60px !important;
        height: 60px !important;
        border-width: 2px !important;
    }

    .song-title-block h1 {
        font-size: 19px !important;
        margin-bottom: 2px !important;
    }

    .song-artist-link {
        font-size: 14px !important;
        margin-bottom: 8px !important;
    }

    .song-badges {
        gap: 6px !important;
    }

    .badge-principal {
        font-size: 11px !important;
        padding: 3px 10px !important;
    }

    .btn-favoritar-top {
        font-size: 12px !important;
        padding: 4px 12px !important;
        min-height: 32px !important;
    }

    .song-info-tabs {
        gap: 0 !important;
        padding: 10px 0 !important;
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        scrollbar-width: none !important;
    }

    .song-info-tabs::-webkit-scrollbar {
        display: none;
    }

    .info-tab-item {
        flex-shrink: 0 !important;
        font-size: 12px !important;
        padding-right: 14px !important;
        margin-right: 14px !important;
    }

    .info-tab-label {
        font-size: 10px !important;
    }

    .info-tab-value {
        font-size: 13px !important;
    }
}

/* ================================================================
   14. TOOLBAR CIFRA — MOBILE
   ================================================================ */
@media (max-width: 960px) {
    .cifra-toolbar {
        display: flex !important;
        padding: 10px 12px !important;
        gap: 6px !important;
        border-radius: 12px !important;
        overflow-x: auto !important;
        flex-wrap: nowrap !important;
        scrollbar-width: none !important;
        -webkit-overflow-scrolling: touch !important;
    }

    .cifra-toolbar::-webkit-scrollbar {
        display: none;
    }

    .tool-btn {
        flex: 0 0 auto !important;
        padding: 8px 12px !important;
        font-size: 12px !important;
        min-height: 38px !important;
        border-radius: 8px !important;
        white-space: nowrap !important;
    }

    .tool-btn i {
        font-size: 11px !important;
    }

    .toolbar-sep {
        display: none !important;
    }

    .tom-inline-control {
        flex: 0 0 auto !important;
        padding: 5px 8px !important;
        gap: 5px !important;
    }

    .tom-inline-control .lbl {
        display: none !important;
    }

    .tom-inline-control button {
        width: 26px !important;
        height: 26px !important;
        font-size: 16px !important;
    }

    .tom-inline-control .tom-val {
        font-size: 14px !important;
        min-width: 24px !important;
    }
}

/* ================================================================
   15. CORPO DA CIFRA — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .cifra-body-card {
        padding: 16px 12px !important;
        border-radius: 14px !important;
    }

    .cifra-conteudo {
        font-size: 14px !important;
        line-height: 2 !important;
    }

    .cifra-footer-row {
        gap: 6px !important;
        margin-top: 14px !important;
        padding-top: 12px !important;
        flex-wrap: wrap !important;
    }

    .action-btn {
        padding: 7px 12px !important;
        font-size: 12px !important;
        border-radius: 8px !important;
        min-height: 36px !important;
        flex: 1 1 auto !important;
        justify-content: center !important;
    }
}

@media (max-width: 480px) {
    .cifra-conteudo {
        font-size: 13px !important;
        line-height: 1.9 !important;
    }
}

/* ================================================================
   16. SIDEBAR CIFRA — MOBILE
   ================================================================ */
@media (max-width: 960px) {

    /* Card de vídeo da sidebar — largura total */
    .sidebar-video-card {
        border-radius: 14px !important;
        overflow: hidden !important;
    }

    .sidebar-video-thumb {
        aspect-ratio: 16/9 !important;
    }

    .sidebar-play-btn {
        width: 44px !important;
        height: 44px !important;
        font-size: 16px !important;
    }

    .sidebar-video-title {
        font-size: 13px !important;
        padding: 10px 12px !important;
    }

    /* Ferramentas sidebar — ocultar em mobile */
    .sidebar-tools-card {
        display: none !important;
    }

    /* Acordes usados */
    .sidebar-acordes-card {
        border-radius: 12px !important;
        overflow: hidden !important;
    }

    .sidebar-acordes-title {
        font-size: 10px !important;
        padding: 10px 14px !important;
    }

    .sidebar-acordes-grid {
        padding: 10px !important;
        gap: 6px !important;
    }

    .sidebar-acorde-chip {
        font-size: 12px !important;
        padding: 4px 10px !important;
        border-radius: 6px !important;
        min-height: 32px !important;
        display: inline-flex !important;
        align-items: center !important;
    }
}

/* ================================================================
   17. PAINEL VIDEOAULA — CIFRA MOBILE
   ================================================================ */
@media (max-width: 960px) {
    .painel-videoaula {
        border-radius: 12px !important;
        overflow: hidden !important;
    }

    .videoaula-thumb-wrap {
        border-radius: 0 !important;
    }

    .videoaula-titulo-bar {
        font-size: 13px !important;
        padding: 8px 12px !important;
    }
}

/* ================================================================
   18. CIFRAS RELACIONADAS — MOBILE
   ================================================================ */
@media (max-width: 960px) {
    .cifras-relacionadas-section {
        padding: 0 14px !important;
        margin-bottom: 32px !important;
    }

    .section-heading {
        font-size: 15px !important;
        margin-bottom: 12px !important;
    }

    .relacionadas-grid {
        grid-template-columns: 1fr 1fr !important;
        gap: 10px !important;
    }

    .relacionada-card {
        border-radius: 12px !important;
    }

    .relacionada-header {
        padding: 10px 12px !important;
        gap: 8px !important;
    }

    .relacionada-foto {
        width: 38px !important;
        height: 38px !important;
    }

    .relacionada-info h4 {
        font-size: 12px !important;
    }

    .relacionada-info p {
        font-size: 11px !important;
    }

    .relacionada-info small {
        font-size: 10px !important;
    }
}

@media (max-width: 480px) {
    .relacionadas-grid {
        grid-template-columns: 1fr !important;
    }
}

/* ================================================================
   19. BREADCRUMB — CIFRA MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .cifra-breadcrumb-inner {
        font-size: 11px !important;
        gap: 4px !important;
        padding: 8px 14px !important;
        flex-wrap: nowrap !important;
        overflow: hidden !important;
        white-space: nowrap !important;
    }

    .cifra-breadcrumb-inner a {
        max-width: 80px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }

    .cifra-breadcrumb-inner .current {
        max-width: 140px !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
}

/* ================================================================
   20. MINIPLAYER — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    #youtube-miniplayer-container {
        width: calc(100% - 20px) !important;
        max-width: 320px !important;
        right: 10px !important;
        bottom: 10px !important;
        border-radius: 12px !important;
    }

    .miniplayer-header {
        padding: 7px 12px !important;
        font-size: 11px !important;
    }
}

/* ================================================================
   21. BUSCA — RESULTADOS MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .search-results {
        border-radius: 12px !important;
        max-height: 280px !important;
        top: calc(100% + 6px) !important;
    }
}

/* ================================================================
   22. LOADING / ERROR — MOBILE
   ================================================================ */
@media (max-width: 768px) {
    .loading-container {
        padding: 40px 20px !important;
    }

    .loading-container h3 {
        font-size: 16px !important;
    }

    .loading-container p {
        font-size: 13px !important;
    }

    .error-container {
        padding: 40px 20px !important;
    }

    .error-icon {
        font-size: 42px !important;
    }

    .error-container h3 {
        font-size: 18px !important;
    }
}

/* ================================================================
   23. TOUCH & INTERACTION POLISH
   ================================================================ */
@media (max-width: 960px) {

    /* Garantir áreas de toque mínimas de 44px */
    button,
    .tool-btn,
    .action-btn,
    .ranking-item,
    .game-card,
    .sidebar-acorde-chip,
    .sidebar-tool-item,
    .related-card,
    .carousel-nav,
    .carousel-dot,
    .modal-close,
    .modal-acordes-close {
        -webkit-tap-highlight-color: transparent !important;
        touch-action: manipulation !important;
    }

    /* Scroll suave */
    .cifra-toolbar,
    .acordes-grid,
    .games-tabs,
    .song-info-tabs,
    #modal-body,
    .acordes-grid {
        -webkit-overflow-scrolling: touch !important;
    }

    /* Animações mais rápidas em mobile */
    .carousel-track {
        transition: transform .4s cubic-bezier(.25, .46, .45, .94) !important;
    }
}

/* ================================================================
   24. SMALL SCREENS (≤ 360px)
   ================================================================ */
@media (max-width: 360px) {
    .cifra-page-wrapper {
        padding: 10px 10px 36px !important;
    }

    .song-header-card {
        padding: 12px 10px 0 !important;
    }

    .cifra-body-card {
        padding: 12px 10px !important;
    }

    .cifra-conteudo {
        font-size: 12px !important;
    }

    .artist-avatar {
        width: 50px !important;
        height: 50px !important;
    }

    .song-title-block h1 {
        font-size: 16px !important;
    }

    .btn-favoritar-top {
        font-size: 11px !important;
        padding: 3px 9px !important;
    }

    .badge-principal {
        font-size: 10px !important;
        padding: 2px 8px !important;
    }

    .relacionadas-grid {
        grid-template-columns: 1fr !important;
    }

    .action-btn {
        font-size: 11px !important;
        padding: 6px 10px !important;
    }
}

/* ================================================================
   25. ANALISADOR DE PROGRESSÃO MODAL — MOBILE
   ================================================================ */
@media (max-width: 768px) {

    /* Garante que qualquer modal dinâmico caiba na tela */
    .modal-overlay .modal-content,
    .modal-overlay .modal {
        margin: 0 !important;
        max-height: calc(100dvh - 24px) !important;
        overflow: hidden !important;
        display: flex !important;
        flex-direction: column !important;
    }

    .modal-overlay .modal-body {
        overflow-y: auto !important;
        flex: 1 !important;
        -webkit-overflow-scrolling: touch !important;
    }
}