/*
 * AvaSite 3.2.0 — Mobile-first interaction and layout layer.
 * This file is intentionally loaded last to normalize both native Ava widgets
 * and all Elementor layouts built with the dedicated Ava widgets.
 */

:root {
    --ava-mobile-safe-inline: max(16px, env(safe-area-inset-left));
    --ava-mobile-card-width: min(84vw, 340px);
}

html {
    max-width: 100%;
    overflow-x: clip;
    scroll-padding-top: calc(var(--ava-header-height, 78px) + 20px);
    -webkit-text-size-adjust: 100%;
}
body {
    min-width: 320px;
    max-width: 100%;
}
html.ava-menu-open,
body.ava-menu-open {
    overflow: hidden !important;
    overscroll-behavior: none;
}

/* Reliable mobile header and accessible off-canvas navigation. */
.ava-mobile-panel {
    visibility: hidden;
    opacity: 0;
    transition: visibility 0s linear .26s, opacity .22s ease;
}
.ava-mobile-panel[data-state="open"] {
    visibility: visible;
    opacity: 1;
    transition-delay: 0s;
}
.ava-mobile-panel__backdrop {
    opacity: 0;
    transition: opacity .22s ease;
}
.ava-mobile-panel[data-state="open"] .ava-mobile-panel__backdrop {
    opacity: 1;
}
.ava-mobile-panel__inner {
    display: flex;
    flex-direction: column;
    width: min(91vw, 400px);
    max-width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    padding: max(18px, env(safe-area-inset-top)) 18px max(20px, env(safe-area-inset-bottom));
    overscroll-behavior: contain;
    transform: translateX(105%);
    transition: transform .26s cubic-bezier(.2,.75,.3,1);
}
.ava-mobile-panel--left .ava-mobile-panel__inner {
    transform: translateX(-105%);
}
.ava-mobile-panel[data-state="open"] .ava-mobile-panel__inner {
    transform: translateX(0);
}
.ava-mobile-panel__head {
    position: sticky;
    top: 0;
    z-index: 2;
    flex: 0 0 auto;
    min-height: 62px;
    padding: 0 0 14px;
    background: var(--ava-surface);
}
.ava-mobile-panel__head .ava-brand img {
    width: auto !important;
    max-width: 150px;
    max-height: 44px;
}
.ava-mobile-panel nav {
    min-height: 0;
    flex: 1 1 auto;
}
.ava-mobile-menu {
    display: grid;
    gap: 7px;
    margin: 14px 0 20px;
}
.ava-mobile-menu > li {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: center;
    overflow: hidden;
    border: 1px solid color-mix(in srgb, var(--ava-border-color) 88%, transparent);
    border-radius: 14px;
    background: color-mix(in srgb, var(--ava-surface) 96%, var(--ava-bg));
}
.ava-mobile-menu > li.menu-item-has-children {
    grid-template-columns: minmax(0, 1fr) 46px;
}
.ava-mobile-menu li {
    border-bottom: 0;
}
.ava-mobile-menu > li > a {
    min-width: 0;
    min-height: 52px;
    padding: 11px 14px;
    font-size: 14px;
    line-height: 1.65;
}
.ava-mobile-menu > li.current-menu-item,
.ava-mobile-menu > li.current-menu-ancestor {
    border-color: color-mix(in srgb, var(--ava-primary) 30%, var(--ava-border-color));
    background: color-mix(in srgb, var(--ava-primary) 6%, var(--ava-surface));
}
.ava-mobile-menu .ava-submenu-toggle {
    width: 42px;
    height: 42px;
    margin: 0;
    border-radius: 11px;
}
.ava-mobile-menu .ava-submenu-toggle svg {
    width: 20px;
    height: 20px;
    transition: transform .2s ease;
}
.ava-mobile-menu .ava-submenu-toggle[aria-expanded="true"] svg {
    transform: rotate(180deg);
}
.ava-mobile-menu .sub-menu {
    grid-column: 1 / -1;
    display: grid !important;
    gap: 4px;
    margin: 0 10px 10px;
    padding: 8px;
    border: 0;
    border-radius: 12px;
    background: color-mix(in srgb, var(--ava-primary) 4%, var(--ava-bg));
}
.ava-mobile-menu .sub-menu[hidden] {
    display: none !important;
}
.ava-mobile-menu .sub-menu li {
    border: 0;
}
.ava-mobile-menu .sub-menu a {
    min-height: 44px;
    padding: 8px 10px;
    border-radius: 9px;
    color: var(--ava-text);
    font-size: 12.5px;
    font-weight: 700;
}
.ava-mobile-panel__contact {
    flex: 0 0 auto;
    margin-top: auto;
}

/* Mobile-native sliders: services and project process. */
.ava-mobile-slider__nav {
    display: none;
}

@media (max-width: 1024px) {
    .ava-site-header {
        min-height: 68px;
    }
    .ava-site-header .ava-header-shell,
    .ava-site-header .ava-header-shell.ava-container,
    .ava-site-header .ava-header-shell--wide,
    .ava-site-header .ava-header-shell--full {
        width: 100%;
        min-height: 68px;
        padding-inline: max(14px, env(safe-area-inset-left)) max(14px, env(safe-area-inset-right));
        gap: 9px;
    }
    .ava-site-header .ava-primary-navigation,
    .ava-site-header .ava-header-phone,
    .ava-site-header .ava-header-cta {
        display: none !important;
    }
    .ava-site-header .ava-header-brand {
        min-width: 0;
        max-width: calc(100% - 100px);
    }
    .ava-site-header .ava-brand img {
        width: auto !important;
        max-width: min(158px, 44vw) !important;
        max-height: 46px !important;
    }
    .ava-site-header .ava-header-actions {
        margin-inline-start: auto;
        gap: 7px;
    }
    .ava-site-header .ava-mobile-toggle {
        display: grid !important;
        flex: 0 0 44px;
        width: 44px;
        height: 44px;
        padding: 0;
        touch-action: manipulation;
    }
    .ava-site-header .ava-icon-button {
        width: 44px;
        height: 44px;
        padding: 0;
    }
}

@media (max-width: 767px) {
    :where(.elementor, .elementor-section, .e-con, .elementor-container, .elementor-widget-wrap, .elementor-widget, .elementor-widget-container) {
        min-width: 0;
        max-width: 100%;
    }
    .elementor-section,
    .e-con {
        --container-max-width: 100%;
    }
    .elementor-widget-text-editor :where(img, video, iframe, table),
    .ava-entry-content :where(img, video, iframe, table) {
        max-width: 100%;
    }

    .ava-mobile-slider {
        position: relative;
        width: 100%;
        min-width: 0;
    }
    .ava-mobile-slider__track,
    .aps-home-services__grid.ava-mobile-slider__track,
    .aps-home-process__list.ava-mobile-slider__track,
    .ava-fallback-services.ava-mobile-slider__track {
        display: flex !important;
        grid-template-columns: none !important;
        gap: 13px !important;
        width: calc(100% + 32px);
        max-width: none;
        margin-inline: -16px;
        padding: 2px 16px 14px;
        overflow-x: auto !important;
        overflow-y: visible;
        scroll-snap-type: x mandatory;
        scroll-padding-inline: 16px;
        overscroll-behavior-inline: contain;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: none;
    }
    .ava-mobile-slider__track::-webkit-scrollbar {
        display: none;
    }
    .ava-mobile-slider__slide,
    .aps-home-services__grid > .aps-home-service-card.ava-mobile-slider__slide,
    .aps-home-process__list > .aps-home-process__item.ava-mobile-slider__slide,
    .ava-fallback-services > article.ava-mobile-slider__slide {
        flex: 0 0 var(--ava-mobile-card-width) !important;
        width: var(--ava-mobile-card-width) !important;
        max-width: var(--ava-mobile-card-width) !important;
        min-width: 0 !important;
        height: auto;
        margin: 0 !important;
        scroll-snap-align: center;
        scroll-snap-stop: always;
    }
    .ava-mobile-slider__nav {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 10px;
        margin-top: 4px;
    }
    .ava-mobile-slider__button {
        display: grid;
        place-items: center;
        width: 42px;
        height: 42px;
        padding: 0;
        border: 1px solid var(--ava-border-color);
        border-radius: 13px;
        color: var(--ava-navy);
        background: var(--ava-surface);
        box-shadow: 0 8px 20px rgba(16, 26, 53, .06);
        touch-action: manipulation;
    }
    .ava-mobile-slider__button:disabled {
        opacity: .38;
        box-shadow: none;
    }
    .ava-mobile-slider__button svg {
        width: 20px;
        height: 20px;
        fill: none;
        stroke: currentColor;
        stroke-width: 1.9;
        stroke-linecap: round;
        stroke-linejoin: round;
    }
    .ava-mobile-slider__status {
        min-width: 58px;
        color: var(--ava-muted);
        font-size: 12px;
        font-weight: 850;
        text-align: center;
        font-variant-numeric: tabular-nums;
    }

    .aps-home-service-card {
        min-height: 100%;
        padding: 20px !important;
        border-radius: 20px !important;
    }
    .aps-home-service-card__icon {
        width: 50px;
        height: 50px;
        margin-bottom: 16px;
    }
    .aps-home-service-card h3 {
        font-size: 16px !important;
    }
    .aps-home-service-card p {
        display: -webkit-box;
        overflow: hidden;
        -webkit-box-orient: vertical;
        -webkit-line-clamp: 4;
        font-size: 12.5px !important;
    }

    .aps-home-process__list::before {
        display: none !important;
    }
    .aps-home-process__item {
        position: relative;
        display: grid !important;
        grid-template-columns: 52px minmax(0, 1fr) !important;
        grid-template-areas:
            "icon number"
            "icon title"
            "icon text";
        align-content: start;
        gap: 4px 14px !important;
        min-height: 220px;
        padding: 20px !important;
        overflow: hidden;
        border: 1px solid color-mix(in srgb, var(--aps-home-primary) 16%, var(--aps-home-border));
        border-radius: 22px !important;
        background:
            radial-gradient(circle at 0 0, color-mix(in srgb, var(--aps-home-primary) 10%, transparent), transparent 35%),
            var(--aps-home-surface, #fff);
        box-shadow: 0 16px 38px rgba(23,32,51,.08);
        text-align: right;
    }
    .aps-home-process__number {
        grid-area: number;
        display: inline-flex !important;
        justify-self: start;
        color: var(--aps-home-primary);
        font-size: 11px;
        font-weight: 900;
    }
    .aps-home-process__icon {
        grid-area: icon;
        width: 52px !important;
        height: 52px !important;
        margin: 0 !important;
        border-width: 4px !important;
        box-shadow: 0 10px 24px color-mix(in srgb, var(--aps-home-primary) 18%, transparent);
    }
    .aps-home-process__item h3 {
        grid-area: title;
        margin: 2px 0 0 !important;
        font-size: 16px !important;
        line-height: 1.7 !important;
    }
    .aps-home-process__item p {
        grid-area: text;
        margin: 8px 0 0 !important;
        font-size: 12.5px !important;
        line-height: 1.95 !important;
    }

    /* Image + text widgets used by Ava compositions. */
    .ava-image-text-card {
        position: relative;
        width: 100%;
        min-width: 0;
        max-width: 100%;
    }
    .ava-image-text-card img.main,
    .ava-image-text-card img.inverted-radius,
    .ava-image-text-card .grad > img,
    .ava-image-text-card > img,
    .ava-image-text-card figure > img {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        height: 100% !important;
        min-height: 240px;
        aspect-ratio: 4 / 3;
        object-fit: cover !important;
        object-position: center !important;
    }

    .ava-page-header__media img,
    .aps-article-hero__media img,
    .aps-single-hero-media img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
}

@media (max-width: 430px) {
    :root {
        --ava-mobile-card-width: min(86vw, 320px);
    }
    .ava-site-header .ava-header-shell,
    .ava-site-header .ava-header-shell.ava-container {
        padding-inline: 12px;
    }
    .ava-site-header .ava-brand img {
        max-width: min(145px, 42vw) !important;
    }
    .ava-mobile-panel__inner {
        width: min(94vw, 380px);
        padding-inline: 14px;
    }
}

@media (prefers-reduced-motion: reduce) {
    .ava-mobile-panel,
    .ava-mobile-panel__backdrop,
    .ava-mobile-panel__inner,
    .ava-mobile-menu .ava-submenu-toggle svg {
        transition: none !important;
    }
    .ava-mobile-slider__track {
        scroll-behavior: auto !important;
    }
}
