/* Final mobile overrides. Loaded after theme.css so these rules always win. */
html,
body {
    width: 100%;
    max-width: 100%;
    overflow-x: hidden !important;
}

@media (max-width: 760px) {
    .hero {
        min-height: 540px !important;
    }

    .hero__slide {
        overflow: hidden !important;
    }

    .hero__slide .hero__media {
        background:
            linear-gradient(180deg, rgba(0, 0, 0, .08) 0%, rgba(0, 0, 0, .16) 32%, rgba(0, 0, 0, .56) 68%, rgba(0, 0, 0, .78) 100%),
            var(--hero-image) center/cover !important;
    }

    .hero__content {
        width: 100% !important;
        max-width: 100% !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        padding: 56px 20px 84px !important;
    }

    .hero__content-inner {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 12px !important;
        width: min(100%, 300px) !important;
        max-width: 300px !important;
        text-align: center !important;
    }

    .hero__slide--right .hero__content {
        align-items: center !important;
    }

    .hero__slide--right .hero__content-inner {
        text-align: center !important;
    }

    .hero__content h1 {
        display: grid !important;
        gap: 2px !important;
        width: 100% !important;
        max-width: 300px !important;
        margin: 0 !important;
        font-size: clamp(2rem, 9.3vw, 2.75rem) !important;
        line-height: 0.9 !important;
        letter-spacing: -0.04em !important;
        text-align: center !important;
        text-wrap: balance !important;
    }

    .hero__title-line {
        display: block !important;
        width: 100% !important;
    }

    .hero__copy {
        display: grid !important;
        gap: 4px !important;
        width: 100% !important;
        max-width: 272px !important;
    }

    .hero__copy p,
    .hero__content p:not(.eyebrow) {
        margin: 0 !important;
        max-width: 272px !important;
        font-size: 0.99rem !important;
        line-height: 1.12 !important;
        text-align: center !important;
        text-wrap: pretty;
    }

    .hero__fineprint {
        margin: 0 !important;
        max-width: 250px !important;
        font-size: 0.72rem !important;
        font-weight: 800 !important;
        line-height: 1.14 !important;
        text-align: center !important;
    }

    .hero__fineprint-group {
        display: grid !important;
        gap: 6px !important;
        margin-top: 2px !important;
    }

    .hero__actions {
        width: 100% !important;
        justify-content: center !important;
    }

    .hero__actions .button {
        width: min(100%, 280px) !important;
        min-width: 0 !important;
        min-height: 52px !important;
        margin-top: 2px !important;
    }

    .hero__arrow {
        display: none !important;
    }

    .promo-strip,
    .promo-strip__inner,
    .promo-slides,
    .promo-slide {
        min-height: 72px !important;
        height: 72px !important;
    }

    .promo-strip__inner {
        align-items: center !important;
    }

    .promo-arrow {
        align-self: stretch !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        height: 72px !important;
    }

    .promo-slide {
        align-items: center !important;
        justify-content: center !important;
    }

    .promo-slide p {
        min-height: 72px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        align-content: center !important;
        max-width: 260px !important;
        line-height: 1.16 !important;
    }

    .shop-subcats {
        overflow: visible !important;
    }

    .shop-subcats__track {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .shop-subcats__track::-webkit-scrollbar {
        display: none;
    }
}

.site-header,
.site-main,
.site-footer {
    max-width: 100vw;
    overflow-x: hidden !important;
}

@media (min-width: 1101px) {
    .site-header {
        position: relative;
        z-index: 10000;
        overflow: visible !important;
    }

    .main-header,
    .main-header__inner {
        overflow: visible !important;
    }

    .mega-nav,
    .mega-nav__inner,
    .mega-nav__item {
        position: static !important;
        overflow: visible !important;
    }

    .mega-panel {
        left: 50% !important;
        right: auto !important;
        width: 100vw !important;
        max-height: calc(100vh - 118px);
        margin: 0 0 0 -50vw !important;
        overflow-x: hidden !important;
        overflow-y: auto !important;
        box-sizing: border-box;
        padding-inline: max(28px, calc((100vw - 1560px) / 2 + 28px)) !important;
    }
}

.footer-trust-badges img {
    filter: none !important;
    opacity: 1 !important;
}

@media (max-width: 1100px) {
    body.tpz-menu-open {
        overflow: hidden !important;
    }

    .mega-nav {
        display: none !important;
        grid-column: 1 / -1;
        order: 5;
        width: 100% !important;
        margin-top: 8px;
        background: #fff;
        border-top: 1px solid #d8d8d8;
        overflow: visible !important;
    }

    .mega-nav.is-open {
        display: block !important;
        max-height: calc(100vh - 160px);
        overflow-y: auto !important;
    }

    .mega-nav__inner {
        display: block !important;
        width: 100%;
        padding: 8px 0 16px !important;
    }

    .mega-nav__item {
        border-bottom: 1px solid #ededed;
    }

    .mega-nav__link {
        display: flex !important;
        align-items: center;
        justify-content: space-between;
        min-height: 58px;
        padding: 16px 2px !important;
        font-size: clamp(1.18rem, 5vw, 1.45rem) !important;
        line-height: 1;
    }

    .mega-nav__item:has(.mega-panel) > .mega-nav__link::after {
        content: ">";
        font-family: Arial, sans-serif;
        font-size: 1.25rem;
        line-height: 1;
    }

    .mega-panel,
    .mega-nav__item:hover .mega-panel,
    .mega-nav__item:focus-within .mega-panel {
        position: static !important;
        display: none !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 0 12px !important;
        border: 0 !important;
        background: #fff !important;
        box-shadow: none !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        transform: none !important;
    }

    .mega-nav__item.is-expanded .mega-panel {
        display: block !important;
    }

    .mega-panel__promo {
        display: none !important;
    }

    .mega-panel__columns {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 0 !important;
    }
}

@media (max-width: 760px) {
    body,
    .site-main,
    .shop-main,
    .tpz-page,
    .tpz-page-hero,
    .tpz-page-body,
    .tpz-page-sections,
    .tpz-page-support {
        width: 100vw !important;
        max-width: 100vw !important;
        overflow-x: hidden !important;
    }

    .site-header *,
    .site-main *,
    .site-footer * {
        min-width: 0;
        box-sizing: border-box;
    }

    .container,
    .shop-main > .container,
    .tpz-page .container,
    .tpz-rail .container,
    .tpz-faq .container,
    .tpz-product-reviews .container {
        width: calc(100vw - 28px) !important;
        max-width: calc(100vw - 28px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .utility-bar__inner {
        display: grid !important;
        grid-template-columns: 38px minmax(0, 1fr) 38px !important;
        min-height: 42px !important;
        padding: 0 !important;
    }

    .utility-bar__slides {
        position: relative !important;
        height: 42px !important;
        overflow: hidden !important;
    }

    .utility-slide,
    .utility-bar a,
    .utility-bar__inner a {
        position: absolute !important;
        inset: 0;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        gap: 8px !important;
        min-height: 42px !important;
        padding: 0 !important;
        border: 0 !important;
        font-size: 0.82rem !important;
        line-height: 1 !important;
        opacity: 0 !important;
        visibility: hidden !important;
        white-space: nowrap !important;
    }

    .utility-slide.is-active {
        opacity: 1 !important;
        visibility: visible !important;
    }

    .utility-carousel-arrow {
        display: grid !important;
        width: 38px !important;
        height: 42px !important;
        font-size: 1.55rem !important;
    }

    .main-header__inner {
        grid-template-columns: 72px minmax(0, 1fr) 48px !important;
        gap: 8px !important;
        padding: 14px 0 16px !important;
        overflow: visible !important;
    }

    .nav-toggle {
        display: inline-grid !important;
        place-items: center;
        width: 72px;
        height: 46px;
        padding: 0 !important;
        font-size: 0.82rem !important;
    }

    .tpz-badge-logo {
        min-width: 116px !important;
        max-width: 128px !important;
        min-height: 54px !important;
    }

    .site-logo {
        justify-self: center !important;
    }

    .account-nav {
        display: flex !important;
        width: 48px;
        justify-content: flex-end !important;
        gap: 0 !important;
    }

    .account-link {
        display: none !important;
    }

    .cart-link {
        display: flex !important;
    }

    .cart-link svg {
        width: 25px !important;
        height: 25px !important;
    }

    .header-search {
        grid-column: 1 / -1 !important;
        order: 4 !important;
        width: 100% !important;
        margin: 10px 0 0 !important;
        border-radius: 0 !important;
    }

    .header-search input[type="search"] {
        min-height: 48px !important;
        font-size: 1rem !important;
    }

    .promo-strip {
        height: 58px !important;
        overflow: hidden !important;
    }

    .promo-strip__inner {
        display: grid !important;
        grid-template-columns: 32px minmax(0, 1fr) 32px !important;
        align-items: center !important;
        height: 58px !important;
        min-height: 58px !important;
        padding: 0 !important;
        overflow: hidden !important;
    }

    .promo-arrow {
        position: static !important;
        display: grid !important;
        transform: none !important;
        width: 32px !important;
        height: 58px !important;
        padding: 0 !important;
        font-size: 1.7rem !important;
    }

    .promo-slides {
        position: relative !important;
        height: 58px !important;
        min-height: 58px !important;
        overflow: hidden !important;
    }

    .promo-slide {
        position: absolute !important;
        inset: 0 !important;
        display: none !important;
        align-items: center !important;
        justify-content: center !important;
        opacity: 0 !important;
        visibility: hidden !important;
        pointer-events: none !important;
    }

    .promo-slide.is-active {
        display: flex !important;
        opacity: 1 !important;
        visibility: visible !important;
        pointer-events: auto !important;
    }

    .promo-slide p {
        display: block !important;
        max-width: 272px !important;
        margin: 0 auto !important;
        padding: 0 !important;
        color: #fff !important;
        font-size: 0.78rem !important;
        font-weight: 800 !important;
        line-height: 1.18 !important;
        text-align: center !important;
        white-space: normal !important;
        overflow-wrap: break-word !important;
    }

    .hero {
        min-height: 492px !important;
        max-height: 610px;
    }

    .hero__content {
        width: 100% !important;
        max-width: 100% !important;
        padding: 58px 36px 52px !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
    }

    .hero__content-inner {
        max-width: 300px !important;
        text-align: center !important;
    }

    .hero__content h1 {
        max-width: 300px !important;
        font-size: clamp(1.85rem, 8.4vw, 2.55rem) !important;
        line-height: 0.96 !important;
    }

    .hero__content p:not(.eyebrow) {
        max-width: 300px !important;
        font-size: clamp(0.94rem, 3.8vw, 1.12rem) !important;
        line-height: 1.18 !important;
    }

    .hero__actions .button {
        width: min(100%, 280px) !important;
        min-height: 50px;
        font-size: 0.9rem !important;
    }

    .shop-main {
        padding-top: 0 !important;
    }

    .shop-header {
        padding: 28px 0 18px !important;
        margin-bottom: 18px !important;
    }

    .tpz-breadcrumbs {
        margin-bottom: 20px !important;
        font-size: 0.86rem !important;
    }

    .shop-title {
        max-width: 100% !important;
        font-size: clamp(2.55rem, 13vw, 3.55rem) !important;
        line-height: 0.9 !important;
    }

    .shop-description {
        display: none !important;
    }

    .shop-controls {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 12px !important;
        padding-top: 16px !important;
        overflow: hidden !important;
    }

    .shop-subcats {
        position: relative !important;
        width: 100% !important;
        max-width: calc(100vw - 28px) !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch;
    }

    .shop-subcats__track {
        display: flex !important;
        width: max-content !important;
        max-width: none !important;
        gap: 8px !important;
        padding: 0 4px 4px 0 !important;
    }

    .subcat-pill {
        flex: 0 0 auto !important;
        height: 42px !important;
        padding: 0 13px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        font-size: 0.74rem !important;
        line-height: 1 !important;
        white-space: nowrap !important;
    }

    .subcat-nav {
        display: flex !important;
        justify-content: flex-end !important;
        gap: 8px !important;
        margin-top: 8px !important;
    }

    .subcat-arrow,
    .recommended-arrow {
        display: inline-grid !important;
        place-items: center !important;
        width: 44px !important;
        height: 44px !important;
        border: 1px solid #d6d6d6 !important;
        background: #fff !important;
        color: #111 !important;
        font-size: 1.35rem !important;
        line-height: 1 !important;
        opacity: 1 !important;
        pointer-events: auto !important;
        cursor: pointer !important;
    }

    .subcat-arrow:disabled,
    .recommended-arrow:disabled {
        opacity: 0.35 !important;
        cursor: default !important;
    }

    .shop-utility {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 10px !important;
        width: 100% !important;
    }

    .shop-count {
        font-size: 0.95rem !important;
        font-weight: 900 !important;
    }

    .filter-toggle {
        width: 100% !important;
        min-height: 46px !important;
        justify-content: center !important;
        font-size: 0.9rem !important;
    }

    .woocommerce ul.products {
        display: grid !important;
        grid-template-columns: minmax(0, 1fr) !important;
        gap: 10px !important;
        width: 100% !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    .woocommerce ul.products li.product,
    .woocommerce-page ul.products li.product,
    .woocommerce ul.products[class*="columns-"] li.product,
    .woocommerce-page ul.products[class*="columns-"] li.product,
    .woocommerce ul.products li.product.tpz-product-card {
        width: 100% !important;
        min-width: 0 !important;
        margin: 0 !important;
        float: none !important;
        background: #fff !important;
        border: 1px solid #dedede !important;
    }

    .tpz-card__link {
        display: grid !important;
        grid-template-columns: minmax(118px, 40%) minmax(0, 1fr) !important;
        grid-template-rows: auto auto !important;
        grid-template-areas:
            "media body"
            "media footer" !important;
        height: 100% !important;
        min-height: 156px !important;
    }

    .tpz-card__media {
        grid-area: media !important;
        width: 100% !important;
        height: 156px !important;
        aspect-ratio: auto !important;
        padding: 8px !important;
        overflow: hidden !important;
        background: #fff !important;
    }

    .woocommerce ul.products li.product .tpz-card__media img,
    .woocommerce-page ul.products li.product .tpz-card__media img {
        width: 100% !important;
        height: 100% !important;
        max-height: 100% !important;
        object-fit: contain !important;
        object-position: center !important;
        margin: 0 !important;
    }

    .tpz-card__sale {
        top: 7px !important;
        left: 7px !important;
        padding: 3px 6px !important;
        font-size: 0.62rem !important;
    }

    .tpz-card__body {
        grid-area: body !important;
        padding: 9px 9px 10px !important;
    }

    .tpz-card__eyebrow {
        margin-bottom: 5px !important;
        font-size: 0.56rem !important;
        line-height: 1.1 !important;
    }

    .woocommerce ul.products li.product .tpz-card__title {
        display: -webkit-box !important;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 3;
        min-height: 0 !important;
        max-height: 4.05em !important;
        overflow: hidden !important;
        margin-bottom: 8px !important;
        font-size: 0.78rem !important;
        line-height: 1.25 !important;
        font-weight: 800 !important;
    }

    .woocommerce ul.products li.product .tpz-card__price,
    .woocommerce ul.products li.product .tpz-card__price .price {
        font-size: 0.83rem !important;
        line-height: 1.2 !important;
    }

    .tpz-card__footer {
        grid-area: footer !important;
        display: grid !important;
        align-self: end !important;
        gap: 4px !important;
        padding: 0 9px 10px !important;
        border-top: 0 !important;
    }

    .tpz-card__footer-item {
        gap: 4px !important;
        font-size: 0.55rem !important;
        line-height: 1.1 !important;
        white-space: nowrap !important;
    }

    .tpz-card__footer-item svg {
        width: 12px !important;
        height: 12px !important;
        flex: 0 0 12px !important;
    }

    .tpz-rail__track,
    .recommended-track {
        overflow-x: auto !important;
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch;
    }

    .tpz-rail__arrows,
    .recommended-controls {
        position: relative !important;
        z-index: 3 !important;
    }

    .tpz-page-hero h1 {
        max-width: 100% !important;
        font-size: clamp(2.08rem, 10vw, 2.85rem) !important;
    }

    .tpz-page-hero__inner,
    .tpz-page-body__inner,
    .tpz-page-sections__inner,
    .tpz-page-support__inner,
    .tpz-page-grid,
    .tpz-page-panel,
    .tpz-page-section {
        width: calc(100vw - 28px) !important;
        max-width: calc(100vw - 28px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
        overflow: visible !important;
    }

    .tpz-page-hero p:not(.eyebrow),
    .tpz-page-panel p,
    .tpz-page-section p,
    .tpz-page-support__inner p {
        max-width: 100% !important;
        white-space: normal !important;
        overflow-wrap: anywhere;
        word-break: normal;
    }

    .footer-main {
        display: block !important;
        padding: 34px 0 22px !important;
    }

    .footer-links {
        display: block !important;
        margin-top: 28px;
    }

    .footer-link-group {
        border-top: 1px solid rgba(255, 255, 255, .08);
    }

    .footer-link-group__toggle {
        display: flex !important;
        align-items: center;
        justify-content: space-between;
        min-height: 68px;
        margin: 0 !important;
        font-size: 1.3rem !important;
        cursor: pointer;
    }

    .footer-link-group__icon {
        display: inline-block !important;
        font-family: Arial, sans-serif;
        font-size: 2rem;
        font-weight: 300;
    }

    .footer-link-group__nav {
        display: none;
        padding: 0 0 18px;
    }

    .footer-link-group.is-open .footer-link-group__nav {
        display: block;
    }

    .footer-legal__inner {
        align-items: flex-start !important;
        text-align: left !important;
    }

    .footer-legal__copy {
        display: flex;
        flex-direction: column-reverse;
        gap: 26px;
        width: 100%;
    }

    .footer-legal nav {
        display: flex !important;
        flex-wrap: wrap;
        justify-content: flex-start !important;
    }

    .footer-trust-badges {
        width: 100%;
        justify-content: flex-start !important;
    }

    .footer-trust-badges img {
        height: 32px !important;
    }

    .footer-trust-badges img:last-child {
        height: 38px !important;
    }
}

@media (max-width: 760px) {
    .hero {
        min-height: 560px !important;
    }

    .hero__slide {
        overflow: hidden !important;
    }

    .hero__slide .hero__media {
        background:
            linear-gradient(180deg, rgba(7, 10, 13, .04) 0%, rgba(7, 10, 13, .18) 28%, rgba(7, 10, 13, .58) 68%, rgba(7, 10, 13, .84) 100%),
            var(--hero-image) center/cover !important;
    }

    .hero__content {
        width: 100% !important;
        max-width: 100% !important;
        align-items: center !important;
        justify-content: flex-end !important;
        text-align: center !important;
        padding: 34px 18px 74px !important;
    }

    .hero__content-inner {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 10px !important;
        width: min(100%, 332px) !important;
        max-width: 332px !important;
        margin: 0 auto !important;
        padding: 24px 18px 18px !important;
        border: 1px solid rgba(255, 255, 255, .14) !important;
        border-radius: 24px !important;
        background: linear-gradient(180deg, rgba(16, 20, 24, .18) 0%, rgba(16, 20, 24, .74) 100%) !important;
        box-shadow: 0 18px 44px rgba(0, 0, 0, .28) !important;
        backdrop-filter: blur(7px);
        -webkit-backdrop-filter: blur(7px);
        text-align: center !important;
    }

    .hero__content h1 {
        display: grid !important;
        gap: 4px !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 0 !important;
        font-size: clamp(1.94rem, 8vw, 2.5rem) !important;
        line-height: 0.92 !important;
        letter-spacing: -0.045em !important;
        text-align: center !important;
        text-wrap: balance !important;
    }

    .hero__title-line {
        display: block !important;
        width: 100% !important;
        white-space: nowrap !important;
    }

    .hero__copy {
        display: grid !important;
        gap: 6px !important;
        width: 100% !important;
        max-width: 286px !important;
    }

    .hero__content p:not(.eyebrow) {
        max-width: none !important;
        margin: 0 !important;
        font-size: 0.98rem !important;
        line-height: 1.2 !important;
        text-align: center !important;
        text-wrap: pretty;
    }

    .hero__fineprint {
        max-width: 100% !important;
        margin: 0 !important;
        font-size: 0.72rem !important;
        font-weight: 800 !important;
        line-height: 1.18 !important;
        text-align: center !important;
        opacity: .94;
    }

    .hero__fineprint-group {
        display: grid !important;
        gap: 4px !important;
        width: 100% !important;
        margin-top: 2px !important;
    }

    .hero__actions {
        width: 100% !important;
        justify-content: center !important;
        margin-top: 2px !important;
    }

    .hero__actions .button {
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 100% !important;
        min-width: 0 !important;
        min-height: 52px !important;
        padding: 0 18px !important;
        font-size: 0.92rem !important;
        line-height: 1.1 !important;
    }

    .hero__slide--spring .hero__content-inner {
        max-width: 348px !important;
    }

    .hero__slide--spring .hero__content h1 {
        font-size: clamp(1.8rem, 7.3vw, 2.28rem) !important;
    }

    .hero__slide--spring .hero__copy {
        max-width: 300px !important;
    }

    .hero__slide--forks .hero__content-inner {
        max-width: 340px !important;
    }

    .hero__slide--forks .hero__content h1 {
        font-size: clamp(1.94rem, 7.6vw, 2.36rem) !important;
    }

    .hero__slide--forks .hero__copy {
        max-width: 276px !important;
    }

    .shop-subcats {
        overflow: visible !important;
    }

    .shop-subcats__track {
        width: 100% !important;
        max-width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-behavior: smooth !important;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }

    .shop-subcats__track::-webkit-scrollbar {
        display: none;
    }
}
