/* ─── Large desktops 1280px+ ─────────────────────────────────────────────── */
@media (min-width: 1280px) {
    .container { max-width: 128rem; }
}
@media (min-width: 992px) {
    .container { max-width: 128rem; }
    .container_lg { max-width: 142rem; }
    .container_sm { max-width: 108rem; }
    .advanced_technologica_area .col-lg-8 { width: 64%; }
    .advanced_technologica_area .col-lg-4 { width: 34%; }
    .faq_area > .container { max-width: 87rem; }
}

/* ─── Tablets 991px and below ────────────────────────────────────────────── */
@media (max-width: 991px) {

    html { font-size: 62.5%; }

    /* ── USP BAR ── */
    .usp_bar { padding: 0 1.6rem; height: 3.6rem; }
    .usp_bar__content { gap: 0 1.2rem; overflow: hidden; }
    .usp_bar__text { font-size: 1.25rem; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; min-width: 0; }
    .usp_bar__btn { padding: 0.4rem 1.2rem; font-size: 1.15rem; white-space: nowrap; flex-shrink: 0; }

    /* ── HEADER / NAV ── */
    .site_header { position: sticky; top: 0; z-index: 1000; }
    .site_nav {
        height: 7rem;
        padding: 0;
        background-color: rgba(255,255,255,0.60) !important;
        backdrop-filter: blur(40px) saturate(200%) !important;
        -webkit-backdrop-filter: blur(40px) saturate(200%) !important;
        border-bottom: 1px solid rgba(255,255,255,0.5) !important;
        box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset, 0 2px 20px rgba(20,25,33,0.08) !important;
    }
    .site_nav__inner { height: 7rem; align-items: center; }

    /* Mobile menu close button — iOS SF Symbol style */
    .mobile-menu-close-wrap {
        list-style: none;
        padding: 0;
        margin: 0;
        border: none !important;
    }
    .mobile-menu-close {
        width: 3.6rem;
        height: 3.6rem;
        display: flex;
        align-items: center;
        justify-content: center;
        /* iOS circular close button: glass fill */
        background: rgba(39,35,32,0.09);
        border: 1px solid rgba(39,35,32,0.09);
        box-shadow: 0 1px 0 rgba(255,255,255,0.7) inset;
        border-radius: 50%;
        cursor: pointer;
        color: rgba(39,35,32,0.7);
        transition: background 140ms, color 140ms;
        -webkit-tap-highlight-color: transparent;
    }
    .mobile-menu-close:hover,
    .mobile-menu-close:active {
        background: rgba(39,35,32,0.15);
        color: var(--c-eclipse-noir);
    }

    /* ── iOS 26 Liquid Glass mobile menu ───────────────────────────── */
    .menu.site_nav__links {
        position: fixed;
        top: 0; left: 0;
        width: min(34rem, 86vw);
        height: 100dvh;

        /* Liquid glass material — warm frosted, high opacity */
        background: rgba(250, 248, 246, 0.92);
        backdrop-filter: blur(56px) saturate(200%) brightness(1.04);
        -webkit-backdrop-filter: blur(56px) saturate(200%) brightness(1.04);

        /* Layered box-shadows: outer depth + inner specular rim */
        box-shadow:
            /* top specular edge */
            0 1px 0 rgba(255,255,255,0.95) inset,
            /* left inner rim */
            1px 0 0 rgba(255,255,255,0.55) inset,
            /* bottom depth */
            0 -1px 0 rgba(0,0,0,0.04) inset,
            /* outer depth shadow */
            6px 0 48px rgba(20,25,33,0.22),
            /* tight outer shadow */
            1px 0 4px rgba(20,25,33,0.08);

        /* Right edge glass refraction border */
        border-right: 1px solid rgba(255,255,255,0.45);
        border-top: none;
        border-left: none;
        border-bottom: none;

        flex-direction: column;
        align-items: flex-start;
        justify-content: flex-start;
        padding: 7.2rem 0 3rem;
        gap: 0;
        overflow-y: auto;
        overflow-x: hidden;

        /* Spring physics: ease-out with subtle deceleration */
        transform: translateX(-105%);
        transition: transform 520ms cubic-bezier(0.22, 1, 0.36, 1);
        z-index: 500;
    }

    /* Right-edge refraction stripe (simulates glass rim catching light) */
    .menu.site_nav__links::after {
        content: '';
        position: absolute;
        top: 0; right: -1px;
        width: 1px; height: 100%;
        background: linear-gradient(
            to bottom,
            transparent 0%,
            rgba(255,255,255,0.9) 15%,
            rgba(255,255,255,1)   45%,
            rgba(255,255,255,0.9) 75%,
            transparent 100%
        );
        pointer-events: none;
        z-index: 1;
    }

    .menu.site_nav__links.current {
        transform: translateX(0);
    }

    /* Hide hamburger when menu open — close button inside panel takes over */
    body.overflow-hidden .hamburger-menu {
        opacity: 0;
        pointer-events: none;
        transition: opacity 180ms;
    }

    /* ── Backdrop overlay with blur ── */
    body.overflow-hidden::before {
        content: '';
        position: fixed;
        inset: 0;
        background: rgba(20,25,33,0.28);
        backdrop-filter: blur(4px) saturate(80%);
        -webkit-backdrop-filter: blur(4px) saturate(80%);
        z-index: 499;
        animation: overlayFadeIn 420ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
    }
    @keyframes overlayFadeIn {
        from { opacity: 0; }
        to   { opacity: 1; }
    }

    /* ── Close button: absolute top-right corner (iOS style) ── */
    .mobile-menu-close-wrap {
        position: absolute !important;
        top: 1.6rem;
        right: 1.6rem;
        padding: 0 !important;
        margin: 0 !important;
        border: none !important;
        background: none !important;
        z-index: 20;
    }

    /* Nav items */
    .nav__item {
        width: 100%;
        padding: 0 1.2rem;
    }
    .nav__item:first-of-type { margin-top: 1.2rem; }

    .nav__link {
        display: flex;
        justify-content: space-between;
        align-items: center;
        width: 100%;
        font-size: 1.7rem;
        font-weight: 600;
        letter-spacing: -0.01em;
        color: var(--c-eclipse-noir);
        /* iOS-style touch target */
        padding: 1.3rem 1.6rem;
        border-radius: 1.4rem;
        border-bottom: none;
        text-transform: none;
        margin-bottom: 0.3rem;
        /* Glass pill hover */
        background: transparent;
        transition: background 140ms, box-shadow 140ms;
        -webkit-tap-highlight-color: transparent;
    }

    /* iOS pressed state: glass pill */
    .nav__link:hover,
    .nav__link:active {
        background: rgba(39,35,32,0.06);
        box-shadow:
            0 1px 0 rgba(255,255,255,0.8) inset,
            0 -1px 0 rgba(0,0,0,0.03) inset;
        backdrop-filter: none;
    }

    /* Active page: dark glass pill */
    .nav__link.is-active {
        background: rgba(39,35,32,0.10);
        box-shadow:
            0 1px 0 rgba(255,255,255,0.6) inset,
            0 -1px 0 rgba(0,0,0,0.04) inset;
        color: var(--c-eclipse-noir);
    }
    .nav__link.is-active:hover {
        background: rgba(39,35,32,0.13);
    }

    /* Mobile CTA button — sticky bottom, clean styling */
    .nav__item.d-block.d-lg-none {
        padding: 2rem 1.6rem 2.4rem;
        margin-top: auto;
        width: 100%;
        border-top: 1px solid rgba(39,35,32,0.10);
    }
    .nav__item.d-block.d-lg-none .btn {
        /* Override glass/inherited backdrop effects — use standard btn--dark */
        backdrop-filter: none !important;
        -webkit-backdrop-filter: none !important;
        box-shadow: 0 2px 12px rgba(39,35,32,0.18) !important;
    }

    /* Dropdowns: inline on mobile */
    .dropdown .dropdwon_menu,
    .nav__dropdown {
        display: none;
        position: static;
        box-shadow: none;
        border: none;
        border-radius: 0;
        background: transparent;
        padding: 0 0 0 2rem;
        opacity: 1;
        transform: none;
    }
    .dropdown_toggler.active + .dropdwon_menu,
    .dropdown_toggler.active + .nav__dropdown { display: block; }
    .dropdown .dropdwon_menu li a,
    .nav__dropdown li a { padding: 1rem 0; font-size: 1.7rem; border-radius: 0; }
    .dropdown .dropdwon_menu li a:hover,
    .nav__dropdown li a:hover { background: none; color: var(--c-orange); }

    .nav__item:hover .dropdwon_menu { display: none; }
    .dropdown_toggler.active + .dropdwon_menu { display: block !important; }
    .dropdown_toggler.active .nav__chevron { transform: rotate(-180deg); }
    .nav__item:hover .nav__chevron { transform: none; }

    /* Hide desktop CTA */
    .site_nav__cta { display: none !important; }

    /* Show hamburger */
    .hamburger-menu { display: flex; }

    /* fix #2 — about-us testimonials header wrap */
    .testimonials__header { flex-wrap: wrap; gap: 1.6rem; }
    .testimonials__heading { font-size: 3.2rem !important; }

    /* fix #3 — about-us popular products grid */
    .about-products-grid { grid-template-columns: repeat(2,1fr) !important; gap: 1.6rem !important; }
    /* new product-grid responsive */
    .products-grid--3col,
    .products-grid--4col { grid-template-columns: repeat(2, 1fr); gap: 1.6rem; }
    .products-grid--2col { grid-template-columns: 1fr; }

    /* fix #8 — feature section text padding on mobile (too close to image) */
    .feature-section__text { padding: 4rem 0 !important; }
    .feature-section--colored .feature-section__text { padding: 5rem 0 4rem !important; }

    /* fix #9 — betaalplan section image/CTA gap */
    .feature-section__media { margin-top: 2rem; }

    /* ── HERO ── */
    .hero__title { font-size: 5rem; }
    .hero__slide {
        flex-direction: column !important;
        align-items: stretch !important;
        min-height: auto !important;
    }
    /* Split hero: stack on mobile */
    .hero__slide--split { min-height: auto !important; }
    .hero__split-container { grid-template-columns: 1fr !important; min-height: auto !important; }
    .hero__split-container .hero__content { padding: 5rem 0 3rem !important; }
    .hero__image-panel { padding-top: 0; height: auto; justify-content: center; }
    .hero__product-img { max-height: 28rem; }
    .hero__slide > img {
        display: block !important;
        position: static !important;
        order: -1;
        width: 100% !important;
        height: 28rem !important;
        object-fit: contain !important;
        object-position: center bottom !important;
        padding: 3rem 4rem 0 !important;
        right: auto !important;
        bottom: auto !important;
    }
    .hero__content { padding: 3rem 0 6rem; max-width: 100%; }

    /* ── FEATURE SECTIONS ── */
    .feature-section__inner,
    .feature-section--colored .feature-section__inner {
        grid-template-columns: 1fr !important;
        direction: ltr !important;
    }
    .feature-section__inner--reversed { direction: ltr !important; }
    .feature-section--colored .feature-section__text { padding: 6rem 0 4rem !important; }
    .feature-section--colored .feature-section__title { font-size: 4.8rem !important; }
    .feature-section--colored .feature-section__media { max-height: 40rem; }
    .feature-section--colored .feature-section__media img { border-radius: 2rem !important; object-fit: cover; max-height: 36rem; }
    .feature-section { padding: 7rem 0 !important; }
    .feature-section__title { font-size: 4.2rem !important; }

    /* Mission section */
    .mission-section-grid { grid-template-columns: 1fr !important; }

    /* ── TESTIMONIALS ── */
    .tesimonial_slider { overflow: hidden; }
    .tesimonial_slider .owl-stage-outer { overflow: hidden; }
    .tesimonial_card { width: 34rem; }
    .tesimonial_slider .item { padding: 0 1.5rem; }

    /* ── USP CARDS ── */
    .usp-grid { grid-template-columns: 1fr; gap: 2rem; padding: 6rem 0; }
    .usp-cards-grid { grid-template-columns: 1fr !important; gap: 2rem !important; }
    .usp-card__img { height: 40rem; }

    /* ── CONTACT ── */
    .contact_wrap { padding: 6rem 4rem; }
    .contact_area .img { display: none; }
    .contact_wrap .sh { display: none; }

    /* ── PRODUCT ABOUT ── */
    .product_about_wrap { display: none; }
    .product_about_area { padding: 8rem 0; }
    .product_about_area .text_block { background: var(--c-white); border: 1.5px solid var(--c-border); padding: 3.5rem 3rem 0; border-radius: 2rem; overflow: hidden; height: 338px; }
    .product_about_area .text_block .img { display: block; margin-left: auto; margin-right: 3.5rem; width: 19rem; }

    /* ── FOOTER ── */
    .footer__newsletter-inner { flex-direction: column; align-items: flex-start; gap: 4rem; }
    .footer__newsletter-form-wrap { min-width: 100%; width: 100%; }
    .footer__newsletter-text h2 { font-size: 4rem; }
    .footer__main > .container { padding-top: 5rem; padding-bottom: 3rem; }
    .footer__col { padding: 2rem 0; border-top: 1px solid rgba(255,255,255,0.1); }
    .footer__col-title { cursor: pointer; }
    .footer__copyright .container { flex-direction: column; gap: 1.6rem; text-align: center; }
    /* fix #10 — instagram icon spacing from border */
    .footer__about { padding-bottom: 3.2rem; }
    .footer__social { margin-top: 2rem; }

    /* ── MORI ABOUT ── */
    .mori_about_area .block_img { width: 100%; margin-bottom: 4rem; }
    .mori_about_area .title1, .mori_about_area .title2 { max-width: 100%; margin: 6rem auto; }
    .mori_about_area .block1 { padding: 5rem 0; }
    .mori_about_area .block3 { margin-top: 6rem; }

    /* ── HERO HEADINGS — schaal grote inline font-sizes terug op mobiel ── */
    .about-hero-text h1,
    .contact-hero-grid h1,
    .about-hero-grid h1 { font-size: 5rem !important; }

    /* Sectie-headings (h2 met grote inline sizes) */
    .about-hero-grid h2,
    .contact-hero-grid h2,
    section h2[style*="font-size:6"],
    section h2[style*="font-size:5"] { font-size: 4rem !important; }

    /* Academy cursussen & aanmeld heading */
    .academy-courses-grid { grid-template-columns: 1fr; gap: 2rem; }

    /* ── CONTACT ── */
    .contact-hero-grid { grid-template-columns: 1fr; gap: 5rem 0; padding-top: 8rem; padding-bottom: 8rem; }
    .contact-hero-form { padding-top: 0; }
    .contact-form-card { padding: 3rem 2.4rem; }

    /* ── ABOUT US & ACADEMY hero ── */
    .about-hero-grid { grid-template-columns: 1fr; gap: 4rem 0; }
    .about-hero-media { height: 36rem; min-height: 0; }
    .about-stats-row { flex-wrap: wrap; gap: 3rem; }
    .about-stat { flex: calc(50% - 2rem); }
    .about-stat__divider { display: none; }
    .about-stat__num { font-size: 4rem; }
    .about-mission-text { font-size: 2.8rem; }
    .about-story-grid { grid-template-columns: 1fr; gap: 4rem 0; direction: ltr !important; }
    .about-story-media { min-height: 36rem; }
    .about-pillars-grid { grid-template-columns: 1fr; gap: 2rem; }

    /* ── 404 PAGE ── */
    .error-404__code { font-size: 18rem !important; }
    .error-404__heading { font-size: 2.8rem !important; }

    /* ── GENERAL ── */
    .title_xl { font-size: 3.8rem; }
    .title_lg  { font-size: 2.8rem; }
    .advanced_technologica_area .left { padding: 0; border-right: none; }
    .advanced_technologica_area .right { padding-left: 0; padding-top: 4rem; }
    .advanced_technologica_area .left a { justify-content: space-between; width: 100%; }
    .img_card .top_img img { height: 40rem; }
    .img_card:hover .top_img img { height: 40rem; }
    .img_card .text { position: static; padding: 2rem 0 0; }
    .product_about_slider .owl-stage-outer { overflow: visible; }

    /* Product images */
    .product_img_slider img { height: 36rem; object-fit: cover; }
    .product_img_slider .owl-stage-outer { overflow: visible; }
    .threeD_img_wrap p { position: static; text-align: center; padding-bottom: 4rem; }
    .threeD_img_wrap img { width: 28rem; }
    .instruction_card .card_body { padding-right: 0; }
    .product_lg_slider .owl-dots { position: static; }
    .vision_featured_area { padding: 8rem 0 0; }
    .imgs_area .d-grid { padding-bottom: 10rem; }
    .imgs_area.pb_100 { padding-bottom: 0; }

    /* PDP mobile ≤991px */
    .pdp-layout { grid-template-columns: 1fr; gap: 4rem 0; }
    /* Gallery stacks vertically: main photo top, thumbs below */
    .pdp-gallery { grid-template-columns: 1fr; grid-template-rows: auto auto; gap: 1.2rem 0; }
    .pdp-thumbs {
        display: flex !important;
        flex-direction: row !important;
        height: auto !important;
        width: 100% !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        gap: 1rem;
        padding-bottom: 0.4rem;
        order: 2;
    }
    .pdp-thumbs .swiper-wrapper { flex-direction: row !important; height: auto !important; width: auto !important; }
    .pdp-thumbs .swiper-slide { width: 7rem !important; height: 7rem !important; flex-shrink: 0; }
    .pdp-thumb-slide { width: 7rem !important; height: 7rem !important; }
    .pdp-main-wrap { order: 1; }
    .pdp-main { height: 36rem; }
    .pdp-main .swiper-wrapper { height: 36rem; }
    .pdp-main .swiper-slide { height: 36rem; }
    .pdp-info__inner { position: static; }
    .pdp-title { font-size: 2.8rem; }
    .pdp-details-layout { grid-template-columns: 1fr; gap: 5rem 0; }
    .pdp-review-card { padding: 3.2rem; }
    .pdp-review-text { font-size: 1.7rem; }
}

/* ─── Support page ────────────────────────────────────────────────────────── */
@media (max-width: 991px) {
    .support-contact-panel { gap: 1.2rem; }
    .support-faq__question { font-size: 1.55rem; }
}

/* ─── Mobile 767px and below ─────────────────────────────────────────────── */
@media (max-width: 767px) {

    .usp_bar { height: 3.4rem; padding: 0 1.4rem; }
    .usp_bar__text { font-size: 1.2rem; }

    .site_nav { height: 6.4rem !important; }
    .site_nav__inner { height: 6.4rem; align-items: center; }
    .site_logo img { width: 14rem; height: auto; }

    /* Hero headings ≤767px */
    .about-hero-text h1,
    .contact-hero-grid h1,
    .about-hero-grid h1 { font-size: 4rem !important; }
    section h2[style*="font-size:6"],
    section h2[style*="font-size:5"] { font-size: 3.2rem !important; }

    .hero__title { font-size: 3.8rem; }
    .hero__body  { font-size: 1.5rem; }
    .hero__slide > img { height: 24rem !important; padding: 2rem 3rem 0 !important; }

    .feature-section__title { font-size: 3.2rem !important; }
    .feature-section--colored .feature-section__title { font-size: 3.8rem !important; }

    .tesimonial_card { width: calc(100vw - 6rem); max-width: 36rem; }
    .tesimonial_card__body { padding: 2.4rem; }
    .tesimonial_slider .item { padding: 0 1rem; }

    .contact_wrap { padding: 4rem 2.4rem; }

    .footer__newsletter-text h2 { font-size: 3.2rem; }
    .footer__newsletter-input-row { border-radius: 1.2rem; flex-direction: column; padding: 1.2rem; gap: 1.2rem; }
    /* fix #5 — newsletter input full-width left-aligned */
    .footer__newsletter-input { padding: 0.8rem 0.4rem; font-size: 1.4rem; width: 100%; text-align: left; }
    .footer__newsletter-btn { width: 100%; padding: 1.4rem; }

    .title_xl { font-size: 2.8rem; }
    .title_lg  { font-size: 2.4rem; }

    .usp-card__img { height: 36rem; }

    .product_card .img { height: 26rem !important; }
    .contact_area form .button, .contact_area form .btn { width: 100%; justify-content: center; }

    .accordion-item { padding: 2rem; }
    .accordion-item p { padding-right: 0; }

    .form_area form { padding: 3rem; padding-top: 0.1rem; max-width: 100%; }
    .form_area form .btn { width: 100%; justify-content: center; }
    .form_area .register_btn { padding: 3rem 3rem 0; margin: 0 -3rem; }
    .form_area form.register_form { padding: 3rem; max-width: 100%; }

    #cookieConsentPopup { width: calc(100vw - 3.2rem); right: 1.6rem; bottom: 1.6rem; padding: 2rem; }

    .products-grid--3col,
    .products-grid--4col { grid-template-columns: 1fr; }
    /* PDP mobile ≤767px */
    .pdp-title { font-size: 2.4rem; }
    .pdp-price { font-size: 2.6rem; }
    .pdp-review-card { padding: 2.4rem; }
    .pdp-review-quote { font-size: 8rem; }
}

/* ─── Extra small 575px and below ───────────────────────────────────────── */
@media (max-width: 575px) {
    html { font-size: 2.56vw; }
    .menu.site_nav__links { padding: 8rem 2.4rem 2.4rem; }
    .hero__title { font-size: 3.2rem; }

    /* Inline-styled hero headings schalen mee met vw op kleine schermen */
    .about-hero-text h1,
    .contact-hero-grid h1,
    .about-hero-grid h1 { font-size: 10vw !important; }
    section h2[style*="font-size:6"],
    section h2[style*="font-size:5"] { font-size: 8vw !important; }
}

/* ─── ROI Calculator responsive ──────────────────────────────────────────── */
@media (max-width: 991px) {
    .roi-calc__inner { grid-template-columns: 1fr; gap: 5rem 0; }
    .roi-calc__results { grid-template-columns: repeat(2, 1fr); }
    .wa-float { bottom: 1.8rem; right: 1.6rem; }
    .wa-float__btn { width: 5.2rem; height: 5.2rem; }
    .instagram-grid { grid-template-columns: repeat(3, 1fr); }
    .academy-video-grid { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 575px) {
    .roi-calc__results { grid-template-columns: 1fr 1fr; gap: 1.2rem; }
    .roi-calc__stat { padding: 2rem 1.8rem; }
    .roi-calc__stat-num { font-size: 2.4rem; }
    .instagram-grid { grid-template-columns: repeat(3, 1fr); gap: 0.5rem; }
    .wa-float__bubble { max-width: 19rem; }
}
