/**
 * Reseller archive layout (map + filters column).
 *
 * @package wd99-resellers-finder
 */

.wd99-reseller-archive {
    --baseline: 8px;
    --header-height: calc(var(--baseline) * 22);
    --font-size-16: clamp(1.4rem, 0.925930vw, calc(var(--baseline) * 2));
    --font-size-15: clamp(1.3rem, 0.868050vw, calc(var(--baseline) * 1.875));
    --carbon-black-600: #313633ff;

    .main {
        padding-top: var(--header-height, 100px);
    }

    .inner-wrapper {
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        justify-content: space-between;
        gap: 1.5rem 0;

        max-width: unset !important;
    }
}

.wd99-reseller-archive__header {
    --block-padding: calc(var(--baseline) * 0);
    --header-pad-top: calc(var(--baseline) * 4);
    --header-pad-bottom: calc(var(--baseline) * 4);

    @media screen and (min-width: 768px) {
        --block-padding: calc(var(--baseline) * 0) calc(var(--baseline) * 4.5);
        --header-pad-top: calc(var(--baseline) * 6);
        --header-pad-bottom: calc(var(--baseline) * 6);
    }

    padding: var(--block-padding);

    .inner-wrapper {
        max-width: unset;
        padding-top: var(--header-pad-top);
        padding-bottom: var(--header-pad-bottom);
    }
}


.wd99-reseller-archive__title-wrap .page-title {
    margin: 0;
}

.wd99-reseller-archive__toolbar {
    max-width: 100%;
}

.wd99-reseller-archive__search-row {
    display: flex;
    align-items: stretch;
}

/* Autocomplete wrapper */
.wd99-reseller-archive__search-wrap {
    flex: 1 1 auto;
    min-width: 0;
    position: relative;
}

/* Autocomplete dropdown */
.wd99-reseller-archive__ac-list {
    position: absolute;
    top: calc(100% + 2px);
    left: 0;
    right: 0;
    z-index: 100;
    margin: 0;
    padding: 0;
    list-style: none;
    background: #fff;
    border: 2px solid var(--carbon-black-500, #555);
    border-top: none;
    border-radius: 0 0 calc(var(--baseline) * .5) calc(var(--baseline) * .5);
    max-height: 280px;
    overflow-y: auto;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
}

.wd99-reseller-ac-item {
    padding: 0.55em 1em;
    font-size: var(--font-size-15);
    cursor: pointer;
    color: var(--carbon-black-600, #313633);
    border-top: 1px solid #eee;

    &:first-child {
        border-top: none;
    }

    &:hover,
    &.is-active {
        background: #f5f5f5;
    }
}

/* Search meta: counter / nearest message */
.wd99-reseller-archive__search-meta {
    margin: 0.35em 0 0;
    font-size: var(--font-size-15);
    color: var(--carbon-black-600, #555);
    min-height: 1.2em;
}

.wd99-reseller-archive__search {
    font-family: var(--font-sans);
    flex: 1 1 auto;
    min-width: 0;
    padding: 0.5em 1em;
    border: 2px solid var(--carbon-black-500);
    border-radius: calc(var(--baseline) * .5);

    &::placeholder {
        color: var(--carbon-white-500);
        font-weight: 700;
    }

    &:focus {
        outline: none;
    }
}

.wd99-reseller-archive__body {
    --block-padding: calc(var(--baseline) * 0);
    --header-pad-top: calc(var(--baseline) * 4);
    --header-pad-bottom: calc(var(--baseline) * 0);

    @media screen and (min-width: 768px) {
        --block-padding: calc(var(--baseline) * 0) calc(var(--baseline) * 4.5);
        --header-pad-top: calc(var(--baseline) * 6);
    }

    padding: var(--block-padding);

    .inner-wrapper {
        max-width: unset;
        padding-top: var(--header-pad-top);
        padding-bottom: var(--header-pad-bottom);
        align-items: flex-start;
    }

    align-items: stretch;
}

.wd99-reseller-archive__facets {
    .facet-item {
        &+.facet-item {
            margin-top: calc(var(--baseline) * 2);
        }
    }

    .inner-wrapper {
        padding-top: 0;
        border-bottom: 1px solid var(--carbon-white-800);

        &[open] {
            .facet-toggle {
                &::before {
                    opacity: 0;
                }
            }
        }
    }

    .facet-heading {
        display: flex;
        justify-content: space-between;
        padding-bottom: calc(var(--baseline) * 2);
        cursor: pointer;

        .facet-toggle {
            display: inline-flex;
            border: 1px solid var(--carbon-white-800);
            width: 1.25em;
            height: 1.25em;
            justify-content: center;

            &::before,
            &::after {
                content: '';
                display: block;
                max-width: .5em;
                width: .5em;
                min-width: .5em;
                height: 2px;
                background-color: var(--carbon-white-800);
                transition: all .4s;
                position: absolute;
                top: 50%;
                left: 50%;
                transform: translate(-50%, -50%);
                transition: all .4s;
            }

            &::before {
                transform: translate(-50%, -50%) rotate(90deg);
            }
        }
    }

    .facet-content {}
}

.wd99-reseller-archive__map-wrap {
    min-width: 0;
}

.wd99-reseller-archive__map-shell {
    position: relative;
    background: #e8e8e8;
    border-radius: 4px;
    min-height: 70vh;
    overflow: hidden;
}

.wd99-reseller-archive__map {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    min-height: 70vh;

    .gm-style .gm-style-iw-c {
        padding: 0 !important;
    }

    .gm-style-iw-d {
        overflow: hidden !important;
        padding: 0 !important;
    }
}

.wd99-reseller-archive__map-fallback {
    position: relative;
    z-index: 1;
    margin: 0;
    padding: 1.25rem;
    font-size: 0.95rem;
    color: #444;
    max-width: 32rem;
}

/* Hide fallback once map JS runs (inline style from JS); keep class for no-API case */
.wd99-reseller-archive__map-shell.is-map-ready .wd99-reseller-archive__map-fallback {
    display: none;
}

/* Google Maps InfoWindow (reseller details) */
.wd99-reseller-infowindow {
    font-size: var(--font-size-15);
    line-height: 1.4286;
    color: var(--carbon-black-600);
    max-width: 320px;
    width: 300px;
    padding: 0 calc(var(--baseline) * 2) calc(var(--baseline) * 3);
    overflow: hidden;


    .wd99-reseller-infowindow__title {
        margin: 0 0 0.5rem;
        font-size: var(--font-size-16);
        line-height: 1.5;
        font-weight: 700;
    }

    .wd99-reseller-infowindow__meta {
        margin: 0;
    }

    .wd99-reseller-infowindow__meta dt {
        font-weight: 500;
        margin: 0.4rem 0 0;
        padding: 0;
    }

    .wd99-reseller-infowindow__meta dd {
        margin: 0.15rem 0 0;
        padding: 0;
    }

    .wd99-reseller-infowindow__meta a {
        word-break: break-word;
    }

    .wd99-reseller-infowindow__abstract {
        margin-top: 0.65rem;
        padding-top: 0.65rem;
        border-top: 1px solid #e0e0e0;
    }

    .wd99-reseller-infowindow__directions-link {
        display: inline-block;
        padding-top: 1em;
    }

    .wd99-reseller-infowindow__abstract-label {
        margin: 0 0 0.35rem;
        font-weight: 600;
        font-size: 0.85rem;
    }

    .wd99-reseller-infowindow__abstract-body {
        margin: 0;
    }

    .wd99-reseller-infowindow__abstract-body > *:first-child {
        margin-top: 0;
    }

    .wd99-reseller-infowindow__abstract-body > *:last-child {
        margin-bottom: 0;
    }
}

/*
 * FacetWP listing: visually hidden post IDs for map sync.
 * Avoid display:none so FacetWP can replace innerHTML on refresh.
 */
.wd99-reseller-archive__fwp-template {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	border: 0;
}

