/* Catering locality page (Views/CateringLocality/BySlug.cshtml) */

/* ── Sticky sidebar ── */

.catering-locality-sidebar-sticky {

    position: sticky;

    top: 90px;

}

/* ── AEO direct answer zone ── */

.locality-aeo-direct {

    background: #f8f9fa;

    border-radius: 0.5rem;

    padding: 1.5rem 1.75rem;

    margin-bottom: 2rem;

}

.locality-aeo-direct .lead {

    font-size: 1.1rem;

    line-height: 1.75;

    color: #333;

}

.locality-aeo-direct .keyFacts-list {

    margin-top: 0.25rem;

}

.locality-aeo-direct .keyFacts-list li {

    padding: 0.25rem 0;

    font-size: 0.97rem;

}

/* ── Diets slider section ── */

.locality-diets-section {

    background: #f8f9fa;

    border-radius: 0.5rem;

}

.locality-diets-section h2 {

    font-size: 1.45rem;

    font-weight: 700;

    color: #222;

}




.catering-locality-postal-codes-section .badge {

    font-size: 0.9rem;

    font-weight: 500;

    padding: 0.35em 0.55em;

}



#catering-locality-map.catering-locality-map {

    height: 380px;

    width: 100%;

    z-index: 1;

}



/* ── Section headings: Avone-style left-accent border (size from semantic h2 + utilities) ── */

.locality-section-heading {

    font-size: inherit;

    font-weight: inherit;

    color: #222;

    padding-left: 0.75rem;

    border-left: 3px solid var(--primary-color, #336699);

    line-height: 1.4;

}



.locality-section-heading i {

    margin-right: 0.4rem;

    font-size: 0.95rem;

}



/* ── Accordion: clean flat Avone-style with +/− toggle ── */

#localityAeoAccordionLeft,

#localityAeoAccordionRight,

#localityFaqAccordion {

    border: 1px solid #e9ecef;

    border-radius: 0.375rem;

    overflow: visible;

}



#localityAeoAccordionLeft .card,

#localityAeoAccordionRight .card,

#localityFaqAccordion .card {

    border: none;

    border-bottom: 1px solid #e9ecef;

    border-radius: 0 !important;

}



#localityAeoAccordionLeft .card:last-child,

#localityAeoAccordionRight .card:last-child,

#localityFaqAccordion .card:last-child {

    border-bottom: none;

    margin-bottom: 0 !important;

}



#localityAeoAccordionLeft .card-header,

#localityAeoAccordionRight .card-header,

#localityFaqAccordion .card-header {

    background: #fff;

    border-bottom: none;

}



#localityAeoAccordionLeft .btn-link,

#localityAeoAccordionRight .btn-link,

#localityFaqAccordion .btn-link {

    justify-content: space-between;

    align-items: flex-start;

    font-weight: 700;

    color: #222;

    text-decoration: none;

    font-size: 1rem;

    text-transform: none;

    letter-spacing: 0;

    white-space: normal;

    overflow-wrap: break-word;

    word-wrap: break-word;

}

/* Flex text column must shrink so long questions wrap on mobile (default min-width:auto prevents wrapping) */

.catering-locality-aeo .card-header .btn-link > span,

.catering-locality-faq .card-header .btn-link > span {

    min-width: 0;

    flex: 1 1 auto;

}



#localityAeoAccordionLeft .btn-link::after,

#localityAeoAccordionRight .btn-link::after,

#localityFaqAccordion .btn-link::after {

    content: '+';

    font-size: 1.3rem;

    font-weight: 300;

    line-height: 1;

    color: var(--primary-color, #336699);

    flex-shrink: 0;

    margin-left: 0.75rem;

    transition: transform 0.2s ease;

}



#localityAeoAccordionLeft .btn-link:not(.collapsed)::after,

#localityAeoAccordionRight .btn-link:not(.collapsed)::after,

#localityFaqAccordion .btn-link:not(.collapsed)::after {

    content: '−';

}



.catering-locality-faq .card-body p,

.catering-locality-aeo .card-body p {

    margin-bottom: 0.5rem;

    line-height: 1.7;

}



.catering-locality-faq .card-body p:last-child,

.catering-locality-aeo .card-body p:last-child {

    margin-bottom: 0;

}



/* ── SEO block cards (Bootstrap card chrome enabled) ── */

.locality-seo-block-card.card {

    background: #fff;
    border: none!important;

}



/* ── Article typography ── */

.catering-locality-article {

    line-height: 1.7;

}



.catering-locality-article p,

.catering-locality-article li {

    line-height: 1.75;

}



.catering-locality-article p {

    margin-bottom: 1rem;

}



/* Normalize heading sizes inside SEO content blocks so template global styles don't bleed in */

.catering-locality-article h2,

.locality-seo-blocks h2 {

    font-size: 1.35rem;

    font-weight: 600;

    margin-top: 1.75rem;

    margin-bottom: 0.65rem;

}



.catering-locality-article h3,

.locality-seo-blocks h3 {

    font-size: 1.1rem;

    font-weight: 600;

    margin-top: 1.25rem;

    margin-bottom: 0.5rem;

}



.catering-locality-article h4,

.locality-seo-blocks h4 {

    font-size: 1rem;

    font-weight: 600;

    margin-top: 1rem;

    margin-bottom: 0.4rem;

}


/* ── Sidebar ── */

.catering-locality-sidebar-card .locality-sidebar-section {

    margin-bottom: 0;

}



.locality-sidebar-section .locality-section-heading {

    border-bottom: 1px solid #e9ecef;

    padding-bottom: 0.6rem;

}



.locality-sidebar-location .list-group-item {

    border-left: none;

    border-right: none;

    font-size: 0.9rem;

    padding: 0.6rem 0.75rem;

}



/* ── Trust signals: light callout block ── */

.locality-trust-box {

    background: #f8f9fa;

    border-radius: 0.5rem;

    padding: 1.25rem;

}



/* ── Bottom CTA block (primary bg: light button for contrast) ── */

.locality-cta-block {

    background: var(--primary-color, #336699);

    border-radius: 0.5rem;

    padding: 2rem 1.5rem;

    text-align: center;

    color: #fff;

}



.locality-cta-block .btn.btn-primary {

    background-color: #fff;

    color: var(--primary-color, #336699);

    border: 0;

}



.locality-cta-block .btn.btn-primary:hover,

.locality-cta-block .btn.btn-primary:focus {

    background-color: #f8f9fa;

    color: var(--primary-color, #336699);

}



/* ── Sidebar CTA button: override any global btn text-transform ── */

.locality-sidebar-section .btn-primary {

    text-transform: none;

    letter-spacing: 0;

}



.locality-sidebar-section .btn-primary.btn-lg {

    font-size: 1rem;

}



/* ── SEO images: text + image rows (Avone-style) ── */

.locality-hero-figure img {

    max-height: 220px;

    width: auto;

    max-width: 100%;

    object-fit: cover;

    border-radius: 0.375rem;

}



.locality-seo-block-row {

    margin-left: -10px;

    margin-right: -10px;

}



.locality-seo-block-row > [class*="col-"] {

    padding-left: 10px;

    padding-right: 10px;

}



.locality-seo-figure {

    margin: 0;

    border-radius: 0.375rem;

    overflow: hidden;

    background: #f8f9fa;

}



.locality-seo-figure img {

    width: 100%;

    height: auto;

    max-height: 420px;

    object-fit: cover;

    display: block;

}



.locality-aeo-media .locality-seo-figure img {

    max-height: 280px;

}



/* Trust row (benefit cards with check icons) */

.catering-locality-trust-home .catering-locality-trust-card {

    background: #fff;

}



.catering-locality-trust-home .catering-locality-trust-icon {

    line-height: 1;

}



.catering-locality-trust-home .catering-locality-trust-icon .fa-check-circle {

    font-size: 2.75rem;

    line-height: 1;

}



.catering-locality-trust-home .icon-box-title {

    font-size: 1.05rem;

    font-weight: 600;

    color: #222;

    line-height: 1.35;

}



.catering-locality-trust-home .text-grey {

    line-height: 1.5;

}

