/* ========== APP LOGIN (app.html) — MOBILE ========== */

@media (max-width: 1024px) {
    .login-panel {
        flex: 0 0 42%;
        max-width: 42%;
        padding: 0 48px;
    }

    .slider-panel {
        flex: 0 0 58%;
        max-width: 58%;
        padding: 16px 16px 16px 0;
    }

    .slider-inner {
        border-radius: 20px;
    }

    .login-content {
        width: 100%;
        max-width: clamp(325px, calc(42vw - 48px), 502px);
    }
}

@media (max-width: 768px) {
    html,
    body {
        width: 100%;
        max-width: 100%;
        overflow-x: hidden;
    }

    body {
        overflow-y: auto;
        height: auto;
    }

    .app-container {
        flex-direction: column;
        height: auto;
        min-height: 100svh;
    }

    .login-panel {
        flex: none;
        max-width: 100%;
        width: 100%;
        padding: 40px 24px;
        min-height: 100svh;
    }

    .login-content {
        max-width: 100%;
    }

    .login-form,
    .login-desc {
        margin-left: 0;
        width: 100%;
    }

    /* Omitir slider promocional en móvil */
    .slider-panel {
        display: none !important;
    }

    .login-footer {
        margin-top: 48px;
    }

    .hcaptcha-mock {
        width: 100%;
        max-width: 100%;
    }

    .token-panel-box {
        padding: 18px 14px 14px;
    }

    .token-panel-row {
        flex-direction: column;
        align-items: flex-start;
        gap: 14px;
    }

    .token-panel-icon svg {
        width: 56px;
        height: 56px;
    }

    .token-panel-input-row {
        flex-direction: column;
        align-items: stretch;
        width: 100%;
    }

    .token-panel-btn {
        width: 100%;
    }

    .token-panel-warning,
    .token-panel-disclaimer {
        font-size: 12px;
    }

    .login-loading-content {
        padding: 16px;
        max-width: calc(100vw - 32px);
    }

    .login-loading-title {
        font-size: 0.95rem;
    }

    .login-loading-subtitle {
        font-size: 0.8125rem;
    }

    #adminModal.modal-overlay.active {
        padding: 12px;
        align-items: flex-end;
    }

    #adminModal .modal-container {
        width: 100%;
        max-width: none;
        max-height: 92svh;
        overflow-y: auto;
        border-radius: 16px 16px 0 0;
    }

    .tela-token-app-modal .tela-token-input,
    .tela-token-ieb-modal .tela-ieb-input {
        font-size: 16px;
    }
}

@media (max-width: 480px) {
    .login-panel {
        padding: 32px 16px;
    }

    .login-logo img {
        width: 110px;
        height: auto;
    }

    .login-title {
        font-size: 18px;
        line-height: 23px;
    }

    .login-desc {
        font-size: 13px;
        margin-bottom: 32px;
    }

    .btn-login {
        width: 100%;
    }

    .token-sync-error {
        font-size: 12px;
    }
}

@supports (padding: max(0px)) {
    @media (max-width: 768px) {
        .login-panel {
            padding-bottom: max(32px, env(safe-area-inset-bottom));
        }
    }
}
