/* Mophyz Responsive System — global mobile-first polish */

html {
    overflow-x: hidden;
    -webkit-text-size-adjust: 100%;
}

body {
    overflow-x: hidden;
    max-width: 100vw;
}

body.mophyz-nav-open {
    overflow: hidden;
    touch-action: none;
}

img,
video,
svg {
    max-width: 100%;
    height: auto;
}

/* Prevent horizontal scroll from wide children */
.container {
    max-width: 100%;
}

/* Touch-friendly tap targets on mobile */
@media (max-width: 767px) {
    .inf-btn,
    .glass-button,
    .inf-btn-primary,
    .moc-page-summary__cta,
    button[type="submit"]:not(.inf-nav__toggle) {
        min-height: 2.75rem;
    }

    .hamburger {
        min-width: 2.75rem;
        min-height: 2.75rem;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 5px;
        padding: 0;
        background: rgba(255, 255, 255, 0.06);
        border: 1px solid rgba(255, 255, 255, 0.12);
        border-radius: 0.65rem;
        cursor: pointer;
        -webkit-tap-highlight-color: transparent;
    }

    .hamburger span {
        display: block;
        width: 1.15rem;
        height: 2px;
        background: #fff;
        border-radius: 2px;
        transition: transform 0.3s ease, opacity 0.3s ease;
    }

    .hamburger.active span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .hamburger.active span:nth-child(2) {
        opacity: 0;
    }

    .hamburger.active span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    /* Compact mobile header */
    header .top-header {
        padding-top: 0.35rem !important;
        padding-bottom: 0.35rem !important;
    }

    header .main-header {
        padding-top: 0.5rem !important;
        padding-bottom: 0.5rem !important;
    }

    header .main-header img[alt*="Logo"],
    header .main-header img[alt*="logo"],
    header .main-header .h-16 {
        height: 2.5rem !important;
        margin-right: 0 !important;
    }

    /* Footer QR: keep visible, just scale down on small screens */
    .mhz-footer-qr {
        display: flex;
        justify-content: center;
    }

    .mhz-footer-qr .qr-scan--footer .qr-scan__frame {
        width: 88px;
    }
}

/* Tables scroll safely on small screens */
.mophyz-table-wrap,
.mecc-card.overflow-x-auto,
.overflow-x-auto table,
.inf-apply-form + table,
.glass-card table {
    display: block;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
}

/* Form stacks on mobile */
@media (max-width: 767px) {
    .grid.grid-cols-2:not(.grid-cols-2.keep-cols) {
        grid-template-columns: 1fr;
    }

    .moc-checkout-grid {
        grid-template-columns: 1fr !important;
    }

    .inf-hero-split {
        grid-template-columns: 1fr !important;
        text-align: center;
    }

    .inf-hero-split__copy {
        text-align: center;
    }

    .inf-hero-split__qr {
        order: -1;
    }

    .inf-hero-qr {
        max-width: 18rem;
        margin: 0 auto;
    }

    .inf-page-section--apply .inf-step-indicator {
        justify-content: flex-start;
        overflow-x: auto;
        flex-wrap: nowrap;
        padding-bottom: 0.25rem;
        -webkit-overflow-scrolling: touch;
    }

    .inf-portal-layout {
        flex-direction: column;
    }

    .inf-portal-sidebar {
        width: 100%;
        min-height: auto;
        border-right: none;
    }

    .inf-portal-content {
        padding: 1rem;
    }

    /* Full-width CTAs on small screens */
    .inf-hero-split .inf-btn--primary,
    .glass-mesh-hero .inf-btn--primary {
        width: 100%;
        max-width: 20rem;
    }
}

/* Tablet: 2-column stats */
@media (min-width: 640px) and (max-width: 1023px) {
    .inf-landing-hero + section .grid-cols-2 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

/* Disable hover scale on touch devices */
@media (hover: none) {
    .glass-card:hover,
    .inf-hover-lift:hover,
    .inf-card:hover {
        transform: none;
    }
}

/* Mobile menu overlay + drawer layering */
.mobile-menu-overlay {
    position: fixed;
    inset: 0;
    z-index: 10040;
    background: rgba(0, 0, 0, 0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.3s ease;
}

.mobile-menu-overlay.is-active {
    opacity: 1;
    pointer-events: auto;
}

.mobile-menu {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    width: min(100%, 22rem) !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    z-index: 10050 !important;
    display: flex !important;
    flex-direction: column;
    background: rgba(12, 12, 14, 0.98) !important;
    color: #fff !important;
    transform: translateX(100%) !important;
    transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1) !important;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    pointer-events: none;
    visibility: hidden;
}

.mobile-menu.active {
    transform: translateX(0) !important;
    pointer-events: auto;
    visibility: visible;
}

.mobile-menu .container {
    flex: 1;
    width: 100%;
}

.mobile-menu nav a,
.mobile-menu nav button.mobile-menu-dropdown {
    color: #fff !important;
}

.mobile-menu .mobile-close {
    color: #fff !important;
}

.hamburger {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 5px;
    cursor: pointer;
    border: none;
    background: transparent;
    padding: 0;
    color: #fff;
}

.hamburger span {
    display: block;
    width: 1.25rem;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: transform 0.3s ease, opacity 0.3s ease;
}

.mobile-submenu {
    height: 0;
    overflow: hidden;
    transition: height 0.35s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.3s ease;
    opacity: 1;
}

.mobile-submenu.is-open {
    opacity: 1;
}

.mobile-menu-dropdown.is-open,
.mobile-menu-dropdown[aria-expanded="true"] {
    color: var(--qr-gold, #f59e0b);
}

/* Line clamp utilities */
.line-clamp-2 {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.line-clamp-3 {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Modal scroll lock helper */
body.mophyz-modal-open {
    overflow: hidden;
}

@media (max-width: 767px) {
    .mecc-modal,
    [role="dialog"] {
        max-width: 100vw !important;
        max-height: 100dvh;
        margin: 0;
        border-radius: 0;
    }
}

/* Consistent horizontal padding */
@media (max-width: 639px) {
    .px-page {
        padding-left: 1rem;
        padding-right: 1rem;
    }
}

@media (min-width: 640px) and (max-width: 1023px) {
    .px-page {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
    }
}

@media (min-width: 1024px) {
    .px-page {
        padding-left: 2.5rem;
        padding-right: 2.5rem;
    }
}
