@media (max-width: 768px) {
    .features__wrapper {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        margin-top: -40px;
        margin-bottom: 50px;
        min-width: 0;
    }

    .hero__rocket {
        display: none;
    }

    .header__flex {
        flex-direction: column;
        text-align: center;
    }

    .hero__imagery {
        width: 100%;
        margin-top: 40px;
        height: 260px;
        min-height: 0;
        padding: 0;
        position: relative;
    }

    .hero__book {
        width: 38%;
        left: 8%;
        top: 50%;
        transform: translateY(-50%);
    }

    .hero__mob {
        width: 32%;
        right: 8%;
        top: 50%;
        bottom: auto;
        transform: translateY(-50%);
    }

    .btn__flex {
        justify-content: center;
        flex-direction: column;
        align-items: center;
        gap: 20px;
        margin-bottom: 40px;
    }

    .btn__flex .btn {
        width: 100%;
        max-width: 320px;
        text-align: center;
    }

    .btn {
        padding: 21px 30px;
    }

    .awards__flex {
        justify-content: center;
        flex-wrap: wrap;
    }

    .header__content {
        margin: 0 auto;
        width: 100%;
        max-width: 100%;
    }

    .hero__txt {
        max-width: 100%;
        padding-left: 10px;
        padding-right: 10px;
    }

    .hero__title {
        max-width: 100%;
    }

    .phones__pane_section {
        height: auto !important;
        min-height: auto !important;
        margin-bottom: 0px;
    }

    .companions__wrapper {
        flex-direction: column;
        align-items: center;
        margin-top: 60px;
    }

    .companion__card {
        width: 100%;
        max-width: 400px;
    }

    .discover__content {
        padding: 30px;
        text-align: center;
    }

    .discover__flex {
        flex-direction: column;
        margin-right: 0;
    }

    .discover__imagery {
        width: 100%;
        flex: none !important;
        height: 360px !important;
    }

    .draw__horizon-flex {
        text-align: center;
    }

    .btn__diffflex {
        display: flex !important;
        justify-content: center;
        flex-direction: column;
        align-items: center;
        gap: 20px !important;
    }

    /* Fallback for gap visual */
    .btn__diffflex .btn:first-child {
        margin-bottom: 0px !important;
    }

    .btn__diffflex .btn {
        margin: 0 !important;
    }

    .btn_center {
        display: inline-block;
        /* Ensure it respects text-align if parent is centered, or use margin auto if block */
        margin-left: auto;
        margin-right: auto;
    }

    .cards__wrapper {
        flex-direction: column;
        align-items: center;
        gap: 40px;
    }

    .card_image {
        transform: none !important;
        margin: 0;
    }

    .flex_cards {
        grid-template-columns: 1fr;
    }

    .cards__item {
        max-width: 320px;
        margin: 0 auto;
        width: 100%;
    }

    .who__flex {
        flex-direction: column-reverse;
    }

    .who__info,
    .who__book_image {
        max-width: 100%;
        text-align: center;
    }

    .who__book_image {
        margin-bottom: 120px;
        margin-top: 200px;
        transform: scale(2);
    }

    .phones__flex {
        flex-direction: column-reverse;
    }

    .phones__cut {
        max-width: 80%;
        transform: translateY(-50px);
        display: none !important;
    }

    .phones__info {
        margin-top: 0;
        text-align: center;
        padding: 0 20px 60px;
    }

    .phones__title,
    .phones__text {
        margin-left: auto;
        margin-right: auto;
    }

    .decode__wrapper {
        flex-direction: column;
        gap: 40px;
    }

    .decode__item {
        border-bottom: 1px solid #e5e5e5;
        padding-bottom: 40px;
        width: 100%;
    }

    .decode__item:not(:last-child)::after {
        display: none;
    }

    .diff__horizontal {
        flex-direction: column;
    }

    .diff_horizont {
        width: 100%;
        height: 300px;
        border-left: none;
        border-top: 1px solid #e5e5e5;
    }

    .author__wrapper {
        flex-direction: column !important;
        text-align: center;
    }

    .diana,
    .fabrice-photo {
        width: 100%;
        height: auto;
        max-width: 400px;
    }

    .contact-container {
        padding: 30px 20px;
    }

    .form-row {
        flex-direction: column;
        gap: 0;
    }

    .footer__wrapper {
        display: flex;
        flex-direction: column;
        gap: 40px;
        text-align: center;
        align-items: center;
    }

    .socials {
        padding-bottom: 20px;
        justify-content: center;
    }

    .email_flex {
        align-items: center;
        flex-direction: column;
        gap: 15px;
        width: auto;
        height: auto;
        background: transparent;
        box-shadow: none;
        padding-top: 0;
    }

    .email__btn {
        transform: none !important;
        margin: 0 !important;
        position: static !important;
    }

    .privacy_wrapper {
        display: flex;
        flex-direction: column;
        gap: 20px;
        text-align: center;
        align-items: center;
    }

    .privacy__left {
        text-align: center;
    }

    .privacy_right {
        text-align: center !important;
        width: 100%;
    }

    .companions {
        margin-bottom: 40px;
        padding: 50px 0;
    }

    /* Mobile Video and Section Overrides */
    .video-wrap,
    .video-wrap2 {
        width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
        max-width: 100% !important;
        border-radius: 0 !important;
    }

    .video-wrap video,
    .video-wrap2 video {
        width: 100% !important;
        height: auto !important;
        border-radius: 0 !important;
        object-fit: cover;
    }

    .how-it-works {
        display: none !important;
    }

    .logo-image {
        width: 91px;
        height: auto;
    }

    .header .logo-image {
        width: 114px;
    }

    /* Stack cards on mobile */
    .cards__flex-diff {
        grid-template-columns: 1fr !important;
    }

    .first_diff {
        max-width: 100% !important;
        height: auto !important;
    }
}

@media (max-width: 768px) {

    /* Manual scroll for reviews on mobile */
    .reviews-wrapper {
        overflow-x: auto !important;
        -webkit-overflow-scrolling: touch;
        /* smooth scrolling */
        scrollbar-width: none;
        /* hide scrollbar firefox */
        will-change: scroll-position;
    }

    .reviews-wrapper::-webkit-scrollbar {
        display: none;
        /* hide scrollbar chrome/safari */
    }

    .reviews-track {
        animation: none;
        /* Disable CSS scroll on mobile, use JS instead */
    }

}

@media (max-width: 932px) and (orientation: landscape) {
    .phones__pane_section {
        margin-bottom: 0px !important;
    }

    .hero__imagery {
        min-height: 320px;
        height: 85vh;
        /* Use viewport height to ensure fit */
        max-height: 450px;
        /* Don't get too crazy on larger screens */
    }

    .hero__book {
        width: auto;
        height: 70%;
        /* Constrain by height */
        top: 50%;
        left: 20%;
        transform: translateY(-50%);
    }

    .hero__mob {
        width: auto;
        height: 80%;
        /* Constrain by height */
        top: 50%;
        right: 20%;
        bottom: auto;
        transform: translateY(-50%);
    }

    .hero__rocket {
        display: none;
        /* Ensure hidden in landscape to save space */
    }

    /* Fix for Discover Section in Landscape */
    .discover__imagery {
        min-height: 300px;
        height: 85vh !important;
        /* Force height to match viewport */
        max-height: 480px;
        /* prevent it from being too tall on tablets in landscape */
    }

    .double__phones {
        width: auto;
        height: 90%;
        /* Constrain by height */
        max-width: none;
        /* Override generic max-width */
    }
}