/* Accordion treatment for gridded_list module on /services/ and /markets/.
   Flexbox cards inside the existing parent grid placement (don't disturb the
   12-col positioning the theme uses for the section). 2026-05-14. */

/* Keep .gridded_list-blocks positioned in the parent grid; only flip its
   INTERNAL display from grid to flex so cards lay out independently. */
.gridded_list.is_accordion .gridded_list-blocks {
    display: flex !important;
    flex-wrap: wrap;
    flex-direction: row;
    align-items: flex-start;
    align-content: flex-start;
    column-gap: 40px;
    row-gap: 0;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none;
    grid-template-columns: none !important;
    -ms-grid-columns: none !important;
}

/* Hide the CTA card in accordion mode (Aaron: "that get in touch doesn't need to be there"). */
.gridded_list.is_accordion .gridded_list-cta {
    display: none !important;
}

/* Cards: 50/50 with the column gap split between them. */
.gridded_list.is_accordion .gridded_list-block {
    flex: 0 0 calc(50% - 20px);
    max-width: calc(50% - 20px);
    min-width: 0;
    border-bottom: 1px solid currentColor;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

@media (max-width: 767px) {
    .gridded_list.is_accordion .gridded_list-block {
        flex: 0 0 100%;
        max-width: 100%;
    }
}

/* Belt-and-suspenders: explicitly hide closed-card descriptions. */
.gridded_list.is_accordion .gridded_list-details:not([open]) .gridded_list-block_desc {
    display: none;
}

/* <details> wrapper. */
.gridded_list.is_accordion .gridded_list-details {
    width: 100%;
    display: block;
}

/* Summary row: title left, +/- right. */
.gridded_list.is_accordion .gridded_list-summary {
    list-style: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 24px 0;
    outline: none;
}
.gridded_list.is_accordion .gridded_list-summary::-webkit-details-marker { display: none; }
.gridded_list.is_accordion .gridded_list-summary::marker { content: ''; }

/* Title: kill the inherited min-height that stretches closed cards. */
.gridded_list.is_accordion .gridded_list-block_title {
    min-height: 0;
    padding-right: 0;
    margin: 0;
    flex: 1 1 auto;
    line-height: 1.2;
}

/* Plus/minus toggle. */
.gridded_list.is_accordion .gridded_list-toggle {
    position: relative;
    width: 18px;
    height: 18px;
    flex: 0 0 18px;
    display: inline-block;
}
.gridded_list.is_accordion .gridded_list-toggle::before,
.gridded_list.is_accordion .gridded_list-toggle::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    background: currentColor;
    transition: transform 200ms ease;
}
.gridded_list.is_accordion .gridded_list-toggle::before {
    width: 18px; height: 2px; margin: -1px 0 0 -9px;
}
.gridded_list.is_accordion .gridded_list-toggle::after {
    width: 2px; height: 18px; margin: -9px 0 0 -1px;
}
.gridded_list.is_accordion .gridded_list-details[open] .gridded_list-toggle::after {
    transform: rotate(90deg);
}

/* Description spacing when open. */
.gridded_list.is_accordion .gridded_list-block_desc {
    margin: 0 0 24px;
    font-size: 16px;
    line-height: 1.55;
}
.gridded_list.is_accordion .gridded_list-details[open] .gridded_list-block_desc {
    animation: gridded_list_fade_in 200ms ease;
}
@keyframes gridded_list_fade_in {
    from { opacity: 0; transform: translateY(-4px); }
    to   { opacity: 1; transform: translateY(0); }
}
