@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Mulish:wght@300;400;500;600;700&display=swap');

:root{
/* core brand */
--bmw-c-primary:#588090; --bmw-c-primary-dark:#002848; --bmw-c-accent:#A9C2CC;
--bmw-font-head:"Cormorant Garamond",Georgia,serif;
--bmw-font-body:"Mulish",-apple-system,BlinkMacSystemFont,sans-serif;

/* neutrals + surfaces */
--bmw-c-ink:#001830; --bmw-c-ink-2:#2C475A; --bmw-c-muted:#647E8B;
--bmw-c-paper:#FBFCFD; --bmw-c-ivory:#F1F5F7; --bmw-c-ivory-deep:#E7EFF1;
--bmw-c-sand:#DCE7EA; --bmw-c-sand-deep:#C9D9DE; --bmw-c-cream:#FBFCFD;
--bmw-c-line:#CCDADF; --bmw-c-sage-soft:#7B9AA7; --bmw-c-sage-mist:#A9C2CC;
--bmw-c-terra:#C2603F;

/* buttons */
--bmw-btn-bg:var(--bmw-c-primary-dark); --bmw-btn-text:var(--bmw-c-cream);
--bmw-btn-bg-hover:#001830;

/* rhythm */
--bmw-space-section:104px; --bmw-gap:30px;
--bmw-r-sm:10px; --bmw-r-md:18px; --bmw-r-lg:26px; --bmw-r-pill:999px;
--bmw-shadow-soft:0 24px 60px -28px rgba(0,24,48,.34);
--bmw-shadow-card:0 18px 40px -26px rgba(0,24,48,.30);

/* type scale */
--bmw-fs-h2:clamp(31px,3.6vw,40px);
--bmw-fs-h3:clamp(20px,2.4vw,26px);
--bmw-fs-body:18px;
}
@media all and (max-width:640.5px){
:root{ --bmw-space-section:72px; --bmw-gap:18px; }
}

/* === HEADER LUXE — Be Mindfully Well === */
/* Targets the existing new-header-6 markup. No HTML changes required. */

/* --- Outer header shell --- */
header#header.new-header-6 {
    background: var(--bmw-c-ivory);
    border-bottom: 1px solid rgba(0, 24, 48, 0.08);
    position: relative;
    z-index: 99;
    transition: box-shadow 0.4s cubic-bezier(0.16, 1, 0.3, 1),
                background 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

header#header.new-header-6.is-stuck {
    background: var(--bmw-c-ivory);
    box-shadow: 0 6px 28px rgba(0, 24, 48, 0.08);
    border-bottom: 1px solid rgba(0, 24, 48, 0.08);
}

/* Hairline accent at top edge — soft sage-mist → primary band */
header#header.new-header-6::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: linear-gradient(90deg,
        var(--bmw-c-accent) 0%,
        var(--bmw-c-primary) 50%,
        var(--bmw-c-accent) 100%);
    opacity: 0.85;
    z-index: 2;
}

/* --- Logo / Text logo --- */
header#header.new-header-6 .logo-container {
    padding: 4px 0;
}

header#header.new-header-6 .logo-container a {
    display: inline-block;
}



header#header.new-header-6 .text-logo {
    font-family: var(--bmw-font-head);
    font-style: italic;
    font-weight: 500;
    letter-spacing: -0.01em;
    color: var(--bmw-c-primary-dark);
    line-height: 1;
    background: linear-gradient(135deg,
        #FFFFFF 0%,
        var(--bmw-c-primary) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    transition: letter-spacing 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

header#header.new-header-6 .logo-container a:hover .text-logo {
    letter-spacing: 0.005em;
}

header#header.new-header-6 .logo-container img {
    max-height: 100px;
    width: auto;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

/*header#header.new-header-6 .logo-container a:hover img {
    transform: scale(1.03);
}*/

/* === DESKTOP (1024px and up) === */
@media screen and (min-width: 64em) {

    /* --- Contact section (Email + Phone + Button) --- */
    header#header.new-header-6 .contact-section.menu {
        display: flex;
        align-items: center;
        gap: 8px;
        list-style: none;
        margin: 0;
        padding: 0;
        justify-content: flex-end;
    }

    header#header.new-header-6 .contact-section.menu > li {
        margin: 0;
    }

    /* Email and phone contact blocks */
    header#header.new-header-6 .menu a.head-contact-links {
        display: flex !important;
        align-items: center;
        gap: 12px;
        padding: 10px 18px !important;
        border-radius: 10px;
        background: transparent;
        transition: background 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        position: relative;
    }

    header#header.new-header-6 .menu a.head-contact-links:hover {
        background: rgba(88, 128, 144, 0.06);
        transform: translateY(-1px);
    }

    /* Icon circle */
    header#header.new-header-6 .menu a.head-contact-links .icon-part {
        width: 40px;
        height: 40px;
        min-width: 40px;
        border-radius: 50%;
        background: var(--bmw-c-sand);
        color: var(--bmw-c-primary);
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 16px;
        padding: 0;
        transition: background 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    }

    header#header.new-header-6 .menu a.head-contact-links:hover .icon-part {
        background: var(--bmw-c-primary);
        color: var(--bmw-c-cream);
        transform: rotate(-8deg) scale(1.08);
    }

    header#header.new-header-6 .menu a.head-contact-links .icon-part i {
        color: inherit;
        font-size: 16px;
    }

    /* Text part */
    header#header.new-header-6 .menu a.head-contact-links .text-part {
        text-align: left;
        line-height: 1.2;
    }

    header#header.new-header-6 .menu a.head-contact-links .text-part .heading {
        font-family: var(--bmw-font-head);
        font-style: italic;
        font-size: 12px;
        color: var(--bmw-c-primary);
        padding-bottom: 3px !important;
        font-weight: 500;
        letter-spacing: 0.02em;
        line-height: 1;
    }

    header#header.new-header-6 .menu a.head-contact-links .text-part .below-text {
        font-family: var(--bmw-font-body);
        font-size: 14px;
        font-weight: 500;
        color: var(--bmw-c-ink);
        line-height: 1.2;
        letter-spacing: 0.01em;
    }

    /* Divider between contact blocks */
    header#header.new-header-6 .contact-section.menu > li:nth-child(2) {
        position: relative;
    }

    header#header.new-header-6 .contact-section.menu > li:nth-child(2)::before {
        content: "";
        position: absolute;
        left: -4px;
        top: 50%;
        transform: translateY(-50%);
        width: 1px;
        height: 32px;
        background: rgba(0, 24, 48, 0.12);
    }

    /* --- Primary CTA button --- */
    header#header.new-header-6 .contact-section.menu > li.padding-left-1 {
        padding-left: 16px !important;
    }

    header#header.new-header-6 .contact-section.menu .button {
        display: inline-flex !important;
        align-items: center;
        gap: 10px;
        background: var(--bmw-btn-bg) !important;
        color: var(--bmw-btn-text) !important;
        font-family: var(--bmw-font-body) !important;
        font-size: 12px !important;
        font-weight: 500 !important;
        letter-spacing: 0.16em;
        text-transform: uppercase;
        padding: 14px 26px !important;
        border-radius: 40px !important;
        border: none !important;
        box-shadow: 0 4px 16px rgba(0, 40, 72, 0.22);
        transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1) !important;
        position: relative;
        overflow: hidden;
        margin-bottom: 0;
    }

    /*header#header.new-header-6 .contact-section.menu .button::after {
        content: "→";
        font-size: 14px;
        line-height: 1;
        transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
    }*/

    header#header.new-header-6 .contact-section.menu .button:hover {
        transform: translateY(-2px);
        box-shadow: 0 8px 24px rgba(0, 40, 72, 0.34) !important;
    }

    header#header.new-header-6 .contact-section.menu .button:hover::after {
        transform: translateX(5px);
    }

    /* --- Menu container (nav bar) --- */
    header#header.new-header-6 .menu-container {
        border-top: 1px solid rgba(0, 24, 48, 0.08) !important;
     
        padding-top: 6px !important;
    }

    /* --- Main navigation --- */
    header#header.new-header-6 .dropdown.menu.level-1 {
        gap: 1px;
    }

    header#header.new-header-6 .dropdown.menu.level-1 > li {
        position: relative;
    }

    header#header.new-header-6 .dropdown.menu.level-1 > li > a:not(.button) {
        font-family: var(--bmw-font-body);
        font-size: 12px;
        font-weight: 500;
        letter-spacing: 0.12em;
        text-transform: uppercase;
        color: var(--bmw-c-ink);
        padding: 16px 8.5px !important;
        position: relative;
        transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    /* Animated underline indicator — uses ::before so it doesn't conflict
       with the chevron arrow ::after used on parent items (Services). */
    header#header.new-header-6 .dropdown.menu.level-1 > li > a:not(.button)::before {
        content: "";
        position: absolute;
        left: 18px;
        right: 18px;
        bottom: 8px;
        height: 1.5px;
        background: var(--bmw-c-primary);
        transform: scaleX(0);
        transform-origin: left center;
        transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
        pointer-events: none;
    }

    header#header.new-header-6 .dropdown.menu.level-1 > li:hover > a:not(.button)::before,
    header#header.new-header-6 .dropdown.menu.level-1 > li.active > a:not(.button)::before,
    header#header.new-header-6 .dropdown.menu.level-1 > li.is-active > a:not(.button)::before {
        transform: scaleX(1);
    }

    /* Active / hover link color — override the existing .new-header rule
       that sets cream on active span, which is invisible on a light
       header. Use primary teal for clear visibility. */
    header#header.new-header-6 .dropdown.menu.level-1 > li:hover > a:not(.button),
    header#header.new-header-6 .dropdown.menu.level-1 > li.active > a:not(.button),
    header#header.new-header-6 .dropdown.menu.level-1 > li.is-active > a:not(.button) {
        color: var(--bmw-c-primary);
        background: transparent !important;
    }

    header#header.new-header-6 .dropdown.menu.level-1 > li:hover > a:not(.button) span,
    header#header.new-header-6 .dropdown.menu.level-1 > li.active > a:not(.button) span,
    header#header.new-header-6 .dropdown.menu.level-1 > li.is-active > a:not(.button) span {
        color: var(--bmw-c-primary);
    }

    /* Submenu chevron — uses ::after (separate from underline ::before).
       Vertical centering via margin-top (not transform) so rotate doesn't
       conflict with translate. Every property forced with !important to
       win against Foundation base + theme rules. */
    header#header.new-header-6 .dropdown.menu > li.is-dropdown-submenu-parent > a::after {
        content: "" !important;
        display: block !important;
        position: absolute !important;
        left: auto !important;
        right: 8px !important;
        top: 50% !important;
        bottom: auto !important;
        width: 10px !important;
        height: 6px !important;
        margin: -3px 0 0 !important;
        padding: 0 !important;
        transform: rotate(0deg);
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1L5 5L9 1' stroke='%23001830' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
        background-repeat: no-repeat !important;
        background-size: contain !important;
        background-position: center !important;
        background-color: transparent !important;
        border: none !important;
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    background-image 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        pointer-events: none;
        z-index: 1;
    }

    /* Give parent items extra right padding so chevron doesn't crowd the text */
    header#header.new-header-6 .dropdown.menu.level-1 > li.is-dropdown-submenu-parent > a:not(.button) {
        padding-right: 20px !important;
    }

    /* Chevron rotates up + shifts to primary teal on hover/active */
    header#header.new-header-6 .dropdown.menu > li.is-dropdown-submenu-parent:hover > a::after,
    header#header.new-header-6 .dropdown.menu > li.is-dropdown-submenu-parent.is-active > a::after,
    header#header.new-header-6 .dropdown.menu > li.is-dropdown-submenu-parent.active > a::after {
        transform: rotate(180deg) !important;
        background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6' fill='none'><path d='M1 1L5 5L9 1' stroke='%23588090' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
    }

    /* Submenu dropdown */
    header#header.new-header-6 .dropdown.menu li ul.submenu {
        background: var(--bmw-c-primary-dark) !important;
        min-width: 220px;
        padding: 10px 0 !important;
        border-radius: 6px !important;
        box-shadow: 0 16px 40px rgba(0, 24, 48, 0.18),
                    0 4px 12px rgba(0, 24, 48, 0.08);
        border: none !important;
        margin-top: 6px;
        opacity: 0;
        transform: translateY(-6px);
        transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        pointer-events: none;
    }

    header#header.new-header-6 .dropdown.menu li.is-active > ul.submenu,
    header#header.new-header-6 .dropdown.menu li:hover > ul.submenu {
        opacity: 1;
        transform: translateY(0);
        pointer-events: auto;
    }

    header#header.new-header-6 .dropdown.menu li ul.submenu li a:not(.button) {
        font-family: var(--bmw-font-body);
        font-size: 13px;
        font-weight: 400;
        letter-spacing: 0.04em;
        text-transform: none;
        color: var(--bmw-c-cream);
        padding: 10px 22px !important;
        position: relative;
        transition: all 0.25s ease;
        line-height:1.5;
    }

    header#header.new-header-6 .dropdown.menu li ul.submenu li a:not(.button):hover {
        color: var(--bmw-c-accent) !important;
        background: rgba(251, 252, 253, 0.06) !important;
        padding-left: 28px !important;
    }

    /* Active submenu item — current page indicator inside the dropdown */
    header#header.new-header-6 .dropdown.menu li ul.submenu li.active > a:not(.button),
    header#header.new-header-6 .dropdown.menu li ul.submenu li.is-active > a:not(.button) {
        color: var(--bmw-c-accent) !important;
        background: rgba(169, 194, 204, 0.10) !important;
        padding-left: 32px !important;
        font-weight: 500;
    }

    header#header.new-header-6 .dropdown.menu li ul.submenu li.active > a:not(.button) span,
    header#header.new-header-6 .dropdown.menu li ul.submenu li.is-active > a:not(.button) span {
        color: var(--bmw-c-accent) !important;
    }

    /* Small dot indicator on the left of active submenu item */
    header#header.new-header-6 .dropdown.menu li ul.submenu li.active > a:not(.button)::before,
    header#header.new-header-6 .dropdown.menu li ul.submenu li.is-active > a:not(.button)::before {
        content: "";
        position: absolute;
        left: 14px;
        top: 50%;
        transform: translateY(-50%);
        width: 5px;
        height: 5px;
        border-radius: 50%;
        background: var(--bmw-c-accent);
        pointer-events: none;
    }
}

/* === MOBILE / TABLET (1023.5px and below) === */
@media screen and (max-width: 1023.5px) {

    header#header.new-header-6 {
        background: var(--bmw-c-ivory);
    }

    header#header.new-header-6 .custom-grid-container {
        padding-top: 14px !important;
        padding-bottom: 14px !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* Mobile header row — relative parent so hamburger can absolute-position */
    header#header.new-header-6 .custom-grid-container {
        position: relative;
    }

    /* Logo — centered on mobile, takes full width so true page-center */
    header#header.new-header-6 .logo-container {
        text-align: center !important;
        width: 100%;
        flex: 1 1 100%;
        margin: 0 auto;
        padding-left: 56px !important;
        padding-right: 56px !important;
    }

    header#header.new-header-6 .logo-container a {
        display: inline-block;
    }

    header#header.new-header-6 .text-logo {
        font-size: 28px !important;
    }

    header#header.new-header-6 .logo-container img {
        max-height: 100px;
        display: inline-block;
    }

    /* Hamburger button — absolute on right, vertically centered */
    header#header.new-header-6 .sidenav-container {
        background-color: transparent;
        color: var(--bmw-c-ink);
        height: 44px;
        width: 44px;
        text-align: center;
        border-radius: 50%;
        padding-top: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        border: 1px solid rgba(0, 24, 48, 0.12);
        transition: all 0.3s cubic-bezier(0.16, 1, 0.3, 1);
        position: absolute;
        right: 14px;
        top: 50%;
        transform: translateY(-50%);
        z-index: 3;
    }

    header#header.new-header-6 .sidenav-container:hover,
    header#header.new-header-6 .sidenav-container:active {
        background-color: var(--bmw-c-primary);
        border-color: var(--bmw-c-primary);
    }

    header#header.new-header-6 .sidenav-container:hover .openMenu i,
    header#header.new-header-6 .sidenav-container:active .openMenu i {
        color: var(--bmw-c-cream);
    }

    header#header.new-header-6 .sidenav-container .openMenu {
        background: transparent;
        padding: 0;
        margin: 0;
        box-shadow: none;
    }

    header#header.new-header-6 .sidenav-container .openMenu:hover,
    header#header.new-header-6 .sidenav-container .openMenu:focus,
    header#header.new-header-6 .sidenav-container .openMenu:active {
        box-shadow: none;
        background: transparent;
    }

    header#header.new-header-6 .sidenav-container .openMenu i {
        color: var(--bmw-c-ink);
        font-size: 20px;
        line-height: 1;
        transition: color 0.3s ease;
    }

    header#header.new-header-6 .sidenav-container i.fa-bars.icon {
        color: inherit;
    }

    /* Mobile bottom CTA strip — contains TWO .mobile-contact-button-section
       siblings: first holds the phone link (.head-contact-links), second
       holds the "Book a session" .button. Each gets distinct treatment. */
    header#header.new-header-6 .mobile-contact-button-section {
        padding: 0;
        margin: 0;
        line-height: normal;
        text-align: center;
        display: flex;
        justify-content: center;
        align-items: stretch;
        min-height: 0;
        background: transparent;
        border-top: 1px solid rgba(0, 24, 48, 0.08);
                gap: 7px;
    }

    /* === Phone CTA row (first .mobile-contact-button-section) === */
    /* Detected by presence of .head-contact-links inside */
    header#header.new-header-6 .mobile-contact-button-section .head-contact-links {
        display: flex !important;
        align-items: center;
        justify-content: center;
        gap: 12px;
        padding: 14px 20px !important;
        width: 100%;
        color: var(--bmw-c-ink);
        text-align: left;
        transition: background 0.3s ease;
                border-radius: 40px !important;
                        border-radius: 40px !important;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links:hover,
    header#header.new-header-6 .mobile-contact-button-section .head-contact-links:active {
        background: rgba(88, 128, 144, 0.06);
    }

    /* Icon circle on phone row */
    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .icon-part {
        width: 38px;
        height: 38px;
        min-width: 38px;
        border-radius: 50%;
        background: var(--bmw-c-sand);
        color: var(--bmw-c-primary);
        display: flex;
        align-items: center;
        justify-content: center;
        padding: 0;
        font-size: 14px;
        flex-shrink: 0;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .icon-part i {
        color: inherit;
        font-size: 14px;
    }

    /* Text block on phone row */
    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .text-part {
        text-align: left;
        line-height: 1.2;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .text-part .heading {
        font-family: var(--bmw-font-head);
        font-style: italic;
        font-size: 11px;
        color: var(--bmw-c-primary);
        padding-bottom: 2px !important;
        font-weight: 500;
        letter-spacing: 0.02em;
        line-height: 1;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .text-part .below-text {
        font-family: var(--bmw-font-body);
        font-size: 14px;
        font-weight: 500;
        color: var(--bmw-c-ink);
        line-height: 1.2;
        letter-spacing: 0.01em;
    }

    /* === Book a session row (second .mobile-contact-button-section) === */
    /* Detected by presence of .button inside.
       Arrow uses ::after (not background-image) so it sits adjacent to
       the text via flex gap — keeps text+arrow visually paired. */
    header#header.new-header-6 .mobile-contact-button-section .button {
        background-color: var(--bmw-btn-bg) !important;
        background-image: none !important;
        color: var(--bmw-btn-text) !important;
        font-family: var(--bmw-font-body) !important;
        font-size: 12px !important;
        font-weight: 500 !important;
        letter-spacing: 0.18em;
        text-transform: uppercase;
        padding: 18px 24px !important;
        border-radius: 0 !important;
        border: none !important;
        box-shadow: none !important;       
        display: inline-flex !important;
        align-items: center;
        justify-content: center;
        gap: 12px;
                border-radius: 40px !important;
        transition: background-color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                    gap 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }

    /* Arrow next to text */
    /*header#header.new-header-6 .mobile-contact-button-section .button::after {
        content: "→";
        font-size: 16px;
        font-weight: 400;
        line-height: 1;
        display: inline-block;
        transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
    }*/

    header#header.new-header-6 .mobile-contact-button-section .button:hover,
    header#header.new-header-6 .mobile-contact-button-section .button:focus {
        background-color: var(--bmw-btn-bg-hover) !important;
        box-shadow: none !important;
        gap: 16px;
    }

    header#header.new-header-6 .mobile-contact-button-section .button:hover::after,
    header#header.new-header-6 .mobile-contact-button-section .button:focus::after {
        transform: translateX(2px);
    }
}

/* === SMALL MOBILE (640px and below) — refinements === */
@media screen and (max-width: 39.9375em) {

    header#header.new-header-6 .custom-grid-container {
        padding-top: 12px !important;
        padding-bottom: 12px !important;
    }

    header#header.new-header-6 .text-logo {
        font-size: 24px !important;
    }

    header#header.new-header-6 .logo-container {
        padding-left: 50px !important;
        padding-right: 50px !important;
    }

    header#header.new-header-6 .logo-container img {
        max-height: 150px;
    }

    header#header.new-header-6 .sidenav-container {
        height: 40px;
        width: 40px;
        right: 12px;
    }

    header#header.new-header-6 .sidenav-container .openMenu i {
        font-size: 18px;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links {
        padding: 12px 18px !important;
        gap: 10px;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .icon-part {
        width: 34px;
        height: 34px;
        min-width: 34px;
        font-size: 12px;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .text-part .heading {
        font-size: 10px;
    }

    header#header.new-header-6 .mobile-contact-button-section .head-contact-links .text-part .below-text {
        font-size: 13px;
    }

    header#header.new-header-6 .mobile-contact-button-section .button {
        padding: 16px 20px !important;
        font-size: 11px !important;
        letter-spacing: 0.16em;
    }
}

/* === Reduced motion === */
@media (prefers-reduced-motion: reduce) {
    header#header.new-header-6,
    header#header.new-header-6 *,
    header#header.new-header-6 *::before,
    header#header.new-header-6 *::after {
        transition: none !important;
        animation: none !important;
    }
}

/* === SIDENAV LUXE — Mobile off-canvas drawer === */
/* Matches the desktop navigation aesthetic: uppercase tracked Mulish,
   ink default, primary-teal hover/active, animated left-edge accent
   bar, accordion chevron on parent items. */

aside.sidenav {
    background: var(--bmw-c-ivory) !important;
    box-shadow: -8px 0 32px rgba(0, 24, 48, 0.14);
    padding: 0 !important;
}

/* Subtle top accent strip — premium drawer feel */
aside.sidenav::before {
    content: "";
    display: block;
    height: 3px;
    background: linear-gradient(90deg,
        transparent 0%,
        var(--bmw-c-primary) 30%,
        var(--bmw-c-accent) 50%,
        var(--bmw-c-primary) 70%,
        transparent 100%);
}

/* Top eyebrow — small brand cue inside the drawer */
aside.sidenav .menu.accordion-menu {
    background: transparent !important;
    margin: 0 !important;
    padding: 0 0 !important;
    border: none !important;
}

/* Top-level list items — clean separators between items */
aside.sidenav .menu.accordion-menu > li {
    background: transparent !important;
    border-bottom: 1px solid rgba(0, 24, 48, 0.06) !important;
    margin: 0 !important;
}

aside.sidenav .menu.accordion-menu > li:last-child {
    border-bottom: 0 !important;
}

/* Top-level link styling — matches desktop nav */
aside.sidenav .menu.accordion-menu > li > a:not(.button) {
    font-family: var(--bmw-font-body) !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase;
    color: var(--bmw-c-ink) !important;
    background: transparent !important;
    padding: 20px 28px 20px 32px !important;
    position: relative;
    display: block;
    line-height: 1;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                padding-left 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                background 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Top-level link text (span inside) — inherit color */
aside.sidenav .menu.accordion-menu > li > a:not(.button) span {
    color: inherit !important;
    background: transparent !important;
    padding-left: 0 !important;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Animated left-edge accent bar (only on top-level items) */
aside.sidenav .menu.accordion-menu > li > a:not(.button)::before {
    content: "";
    position: absolute;
    left: 0;
    top: 50%;
    width: 3px;
    height: 20px;
    background: var(--bmw-c-primary);
    transform: translateY(-50%) scaleY(0);
    transform-origin: center center;
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    border-radius: 0 2px 2px 0;
    pointer-events: none;
}

/* Hover / active / current-page states */
aside.sidenav .menu.accordion-menu > li:hover > a:not(.button),
aside.sidenav .menu.accordion-menu > li.active > a:not(.button),
aside.sidenav .menu.accordion-menu > li.is-active > a:not(.button) {
    color: var(--bmw-c-primary) !important;
    background: rgba(88, 128, 144, 0.05) !important;
    padding-left: 40px !important;
}

aside.sidenav .menu.accordion-menu > li:hover > a:not(.button) span,
aside.sidenav .menu.accordion-menu > li.active > a:not(.button) span,
aside.sidenav .menu.accordion-menu > li.is-active > a:not(.button) span {
    color: var(--bmw-c-primary) !important;
}

aside.sidenav .menu.accordion-menu > li:hover > a:not(.button)::before,
aside.sidenav .menu.accordion-menu > li.active > a:not(.button)::before,
aside.sidenav .menu.accordion-menu > li.is-active > a:not(.button)::before {
    transform: translateY(-50%) scaleY(1);
}

/* Accordion chevron for parent items (Services) */
aside.sidenav .menu.accordion-menu li.is-accordion-submenu-parent > a::after,
aside.sidenav .menu.accordion-menu li.has-submenu > a::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    right: 24px !important;
    top: 50% !important;
    bottom: auto !important;
    left: auto !important;
    width: 12px !important;
    height: 8px !important;
    margin: -4px 0 0 !important;
    padding: 0 !important;
    transform: rotate(0deg);
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1L6 7L11 1' stroke='%23001830' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
    background-repeat: no-repeat !important;
    background-size: contain !important;
    background-position: center !important;
    background-color: transparent !important;
    border: none !important;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                background-image 0.3s ease;
    pointer-events: none;
    z-index: 1;
}

/* Chevron rotates + turns primary teal on hover / when expanded */
aside.sidenav .menu.accordion-menu li.is-accordion-submenu-parent:hover > a::after,
aside.sidenav .menu.accordion-menu li.is-accordion-submenu-parent.is-active > a::after,
aside.sidenav .menu.accordion-menu li.has-submenu.is-active > a::after,
aside.sidenav .menu.accordion-menu li.has-submenu[aria-expanded="true"] > a::after {
    transform: rotate(180deg) !important;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'><path d='M1 1L6 7L11 1' stroke='%23588090' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/></svg>") !important;
}

/* === Submenu (nested) styling === */
aside.sidenav .menu.accordion-menu .is-accordion-submenu,
aside.sidenav .menu.accordion-menu ul.submenu {
    background: rgba(0, 24, 48, 0.03) !important;
    padding: 6px 0 0 !important;
    margin: 0 !important;
    border-top: 1px solid rgba(0, 24, 48, 0.06);
    list-style: none;
}

aside.sidenav .menu.accordion-menu .is-accordion-submenu li,
aside.sidenav .menu.accordion-menu ul.submenu li {
    border-bottom: 1px solid #ccc !important;
    background: transparent !important;
}

/* Submenu links — refined, less prominent than top-level */
aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item > a,
aside.sidenav .menu.accordion-menu ul.submenu li > a {
    font-family: var(--bmw-font-body) !important;
    font-size: 12px !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em !important;
    text-transform: none !important;
    color: rgba(0, 24, 48, 0.72) !important;
    background: transparent !important;
    padding: 11px 28px 11px 48px !important;
    line-height: 1.4;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                padding-left 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Reset the padding-left-1 utility on submenu spans */
aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item > a span.padding-left-1,
aside.sidenav .menu.accordion-menu ul.submenu li > a span {
    color: inherit !important;
    padding-left: 0 !important;
    margin-left: 0 !important;
}

aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item > a:hover,
aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item.active > a,
aside.sidenav .menu.accordion-menu ul.submenu li > a:hover,
aside.sidenav .menu.accordion-menu ul.submenu li.active > a {
    color: var(--bmw-c-primary) !important;
    background: transparent !important;
    padding-left: 54px !important;
}

aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item > a:hover span,
aside.sidenav .menu.accordion-menu .is-accordion-submenu .is-submenu-item.active > a span,
aside.sidenav .menu.accordion-menu ul.submenu li > a:hover span,
aside.sidenav .menu.accordion-menu ul.submenu li.active > a span {
    color: var(--bmw-c-primary) !important;
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    aside.sidenav,
    aside.sidenav *,
    aside.sidenav *::before,
    aside.sidenav *::after {
        transition: none !important;
        animation: none !important;
    }
}

/* ===========================================================
   FOOTER LUXE — Be Mindfully Well
   Deep-navy background, italic Cormorant column headings in sage-mist,
   primary-teal underline accents, cream body text, hover micro-interactions,
   circular social icons, premium contact section.
   =========================================================== */

#footer {
    background: var(--bmw-c-primary-dark) !important;
    color: rgba(251, 252, 253, 0.82);
    position: relative;
    padding: 0 !important;
    overflow: hidden;
}

/* Top gradient hairline accent — premium divider from page content */
#footer::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: linear-gradient(90deg,
        transparent 0%,
        rgba(88, 128, 144, 0.4) 20%,
        var(--bmw-c-accent) 50%,
        rgba(88, 128, 144, 0.4) 80%,
        transparent 100%);
    z-index: 2;
    pointer-events: none;
}

/* Subtle background texture — radial gradient for depth */
#footer::after {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 800px;
    height: 100%;
    background: radial-gradient(ellipse at top,
        rgba(88, 128, 144, 0.06) 0%,
        transparent 60%);
    pointer-events: none;
    z-index: 0;
}

/* Internal hairlines — make them cream-tinted thin lines */
#footer hr {
    border: none !important;
    border-top: 1px solid rgba(251, 252, 253, 0.08) !important;
    margin: 0 !important;
    background: transparent !important;
    height: 1px;
}

/* Main footer content grid */
#footer .footer2 {
    padding: 64px 0 36px !important;
    position: relative;
    z-index: 1;
}

#footer .grid-x.footer2 > .cell {
    margin-bottom: 32px;
}

/* Reset Foundation's border-bottom-small (we control borders) */
#footer .border-bottom-small {
    border-bottom: none !important;
}

/* === Column containers === */
#footer .column-container {
    text-align: left;
    padding: 0 12px;
}

/* === Column headings (h4) — italic Cormorant, sage-mist === */
#footer h4 {
    font-family: var(--bmw-font-head);
    font-style: italic;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.01em;
    text-transform: none;
    color: var(--bmw-c-accent);
    margin: 0 0 22px 0 !important;
    padding-bottom: 14px;
    position: relative;
    line-height: 1.2;
}

/* Teal hairline under each heading */
#footer h4::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 32px;
    height: 1.5px;
    background: var(--bmw-c-primary);
    border-radius: 1px;
}

/* === Generic lists === */
#footer .column-container ul.no-bullet,
#footer .footer2 ul.no-bullet {
    list-style: none;
    margin: 0;
    padding: 0;
}

#footer .footer2 ul li {
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
    list-style: none;
}

/* === Links section — navigation list === */
#footer .links-section ul li a {
    color: rgba(251, 252, 253, 0.72);
    font-family: var(--bmw-font-body);
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 0.02em;
    line-height: 1.5;
    padding: 7px 0 7px 0;
    display: inline-block;
    text-decoration: none;
    position: relative;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                padding-left 0.35s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Arrow indicator that fades in on hover (sits before text) */
#footer .links-section ul li a::before {
    content: "→";
    position: absolute;
    left: -2px;
    top: 50%;
    transform: translateY(-50%);
    opacity: 0;
    color: var(--bmw-c-primary);
    font-size: 13px;
    transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                left 0.35s cubic-bezier(0.16, 1, 0.3, 1);
    pointer-events: none;
}

#footer .links-section ul li a:hover,
#footer .links-section ul li.active > a {
    color: var(--bmw-c-accent);
    padding-left: 18px;
}

#footer .links-section ul li a:hover::before,
#footer .links-section ul li.active > a::before {
    opacity: 1;
    left: 0;
}

/* === Social media icons — clean natural display, no badge interference === */
/* Aggressive resets — icons render in their native form without any
   wrapping badge or filter manipulation that could conflict with the
   source PNG (which may have built-in backgrounds). */
#footer .media-section ul.social-media-icons {
    display: flex !important;
    flex-wrap: wrap;
    gap: 14px;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none;
    align-items: center;
}

#footer .media-section ul.social-media-icons li,
#footer .media-section ul.social-media-icons li.menu-text {
    margin: 0 !important;
    padding: 0 !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    box-shadow: none !important;
    list-style: none !important;
    display: inline-flex;
    line-height: 1;
}

#footer .media-section ul.social-media-icons li::before,
#footer .media-section ul.social-media-icons li::after {
    display: none !important;
    content: none !important;
}

#footer .media-section ul.social-media-icons li a {
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    width: auto !important;
    height: auto !important;
    background: none !important;
    background-color: transparent !important;
    background-image: none !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 4px !important;
    margin: 0 !important;
    box-shadow: none !important;
    color: inherit !important;
    text-decoration: none;
    line-height: 0;
    overflow: visible !important;
    transition: transform 0.35s cubic-bezier(0.16, 1, 0.3, 1),
                opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .media-section ul.social-media-icons li a::before,
#footer .media-section ul.social-media-icons li a::after {
    display: none !important;
    content: none !important;
}

#footer .media-section ul.social-media-icons li a:hover,
#footer .media-section ul.social-media-icons li a:focus {
    transform: translateY(-3px);
    background: none !important;
    box-shadow: none !important;
}

/* Icon image — natural form, no filter, sized appropriately */
#footer .media-section ul.social-media-icons li a img {
    width: 32px !important;
    height: 32px !important;
    max-width: 32px !important;
    max-height: 32px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    object-fit: contain;
    background: none !important;
    background-color: transparent !important;
    border: none !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    margin: 0 !important;
    padding: 0 !important;
    display: block !important;
    /* NO filter — let the icon show in its natural form. If the source
       PNG has its own colors or background, that's how it'll appear. */
    filter: none !important;
    opacity: 0.88;
    transition: opacity 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .media-section ul.social-media-icons li a:hover img,
#footer .media-section ul.social-media-icons li a:focus img {
    opacity: 1;
    transform: scale(1.08);
}

/* Font-based icons (FontAwesome etc.) — keep clean styling */
#footer .media-section ul.social-media-icons li a i,
#footer .media-section ul.social-media-icons li a svg {
    font-size: 22px;
    color: rgba(251, 252, 253, 0.78);
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .media-section ul.social-media-icons li a:hover i,
#footer .media-section ul.social-media-icons li a:focus i,
#footer .media-section ul.social-media-icons li a:hover svg,
#footer .media-section ul.social-media-icons li a:focus svg {
    color: var(--bmw-c-accent);
}

/* === Newsletter Subscribe button — ghost style on dark === */
#footer .newsletter-section .column-container span {
    display: block;
    margin-top: 6px;
}

#footer .newsletter-section .button,
#footer .newsletter-section a.button {
    background-color: transparent !important;
    background-image: none !important;
    color: var(--bmw-c-cream) !important;
    border: 1px solid rgba(251, 252, 253, 0.28) !important;
    font-family: var(--bmw-font-body) !important;
    font-size: 11px !important;
    font-weight: 500 !important;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    padding: 17px  !important;
    border-radius: 40px !important;
    box-shadow: none !important;
    margin: 0 !important;
    display: inline-flex !important;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    transition: background-color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                border-color 0.3s cubic-bezier(0.16, 1, 0.3, 1),
                gap 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/*#footer .newsletter-section .button::after {
    content: "→";
    font-size: 14px;
    line-height: 1;
    display: inline-block;
    transition: transform 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}*/

#footer .newsletter-section .button:hover,
#footer .newsletter-section .button:focus {
    background-color: var(--bmw-c-primary) !important;
    border-color: var(--bmw-c-primary) !important;
    color: var(--bmw-c-cream) !important;
    gap: 16px;
    box-shadow: none !important;
}

#footer .newsletter-section .button:hover::after,
#footer .newsletter-section .button:focus::after {
    transform: translateX(2px);
}

/* === Contact section === */
#footer .contact-section a {
    text-decoration: none;
    color: inherit;
}

/* === Contact items — each with a brand-colored icon on the left.
   Using display:flex (block-level) so each item is on its own line
   automatically, AND ::before pseudo-element behaves as a flex item
   (width/height honored). justify-content controls left vs center
   alignment for desktop vs mobile. NO icon on the Contact Us heading. */

#footer .contact-section .actual-address,
#footer .contact-section .address-container {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    font-family: var(--bmw-font-body);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.7;
    color: rgba(251, 252, 253, 0.82);
    margin: 0 0 16px 0;
    text-align: left;
    max-width: 100%;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Location pin icon on address */
#footer .contact-section .actual-address::before,
#footer .contact-section .address-container::before {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 16px;
    height: 18px;
    margin-top: 4px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A9C2CC' stroke-width='1.7' stroke-linecap='round' stroke-linejoin='round'><path d='M21 10c0 7-9 13-9 13s-9-6-9-13a9 9 0 0 1 18 0z'/><circle cx='12' cy='10' r='3'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .contact-section a:hover .actual-address,
#footer .contact-section a:hover .address-container {
    color: var(--bmw-c-accent);
}

#footer .contact-section a:hover .actual-address::before,
#footer .contact-section a:hover .address-container::before {
    transform: translateY(-3px);
}

/* Phone & email wrappers — block-level flex */
#footer .contact-section .contact-number,
#footer .contact-section .contact-email {
    display: flex;
    align-items: center;
    gap: 12px;
    margin: 8px 0;
    line-height: 1;
}

/* Phone icon */
#footer .contact-section .contact-number::before {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 16px;
    height: 16px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A9C2CC' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M22 16.92v3a2 2 0 0 1-2.18 2 19.79 19.79 0 0 1-8.63-3.07 19.5 19.5 0 0 1-6-6 19.79 19.79 0 0 1-3.07-8.67A2 2 0 0 1 4.11 2h3a2 2 0 0 1 2 1.72 12.84 12.84 0 0 0 .7 2.81 2 2 0 0 1-.45 2.11L8.09 9.91a16 16 0 0 0 6 6l1.27-1.27a2 2 0 0 1 2.11-.45 12.84 12.84 0 0 0 2.81.7A2 2 0 0 1 22 16.92z'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .contact-section .contact-number:hover::before {
    transform: rotate(-12deg) scale(1.1);
}

/* Email icon */
#footer .contact-section .contact-email::before {
    content: "";
    display: block;
    flex-shrink: 0;
    width: 16px;
    height: 13px;
    background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23A9C2CC' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M4 4h16c1.1 0 2 .9 2 2v12c0 1.1-.9 2-2 2H4c-1.1 0-2-.9-2-2V6c0-1.1.9-2 2-2z'/><polyline points='22,6 12,13 2,6'/></svg>");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .contact-section .contact-email:hover::before {
    transform: translateY(-2px) scale(1.05);
}

#footer .contact-section a.footer-phone,
#footer .contact-section a.footer-email {
    font-family: var(--bmw-font-body);
    font-size: 14px;
    font-weight: 500;
    color: var(--bmw-c-cream) !important;
    text-decoration: none;
    display: inline-block;
    padding: 4px 0;
    position: relative;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Animated underline on contact links */
#footer .contact-section a.footer-phone::after,
#footer .contact-section a.footer-email::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 1px;
    background: var(--bmw-c-primary);
    transform: scaleX(0);
    transform-origin: left center;
    transition: transform 0.4s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .contact-section a.footer-phone:hover,
#footer .contact-section a.footer-email:hover {
    color: var(--bmw-c-accent) !important;
}

#footer .contact-section a.footer-phone:hover::after,
#footer .contact-section a.footer-email:hover::after {
    transform: scaleX(1);
}

/* Spacer utility used between sections */
#footer .spacer.height-20 {
    height: 20px;
    width: 100%;
}

/* === Copyright section (bottom) === */
#footer .copyright {
    font-family: var(--bmw-font-body);
    font-size: 12px;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: rgba(251, 252, 253, 0.55);
    margin: 0 !important;
    line-height: 1.6;
}

/* Bottom copyright row — symmetric top/bottom padding (was 64px 0 36px
   from the .footer2 base rule which applies to both the main 4-column
   row and this one — we balance just this row). */
#footer .grid-x.footer2:has(.copyright) {
    padding: 14px 0 !important;
}

/* Zero out Foundation's padding-top-1 utility on the cell — we control
   spacing via the row's padding only, so top/bottom stay symmetric. */
#footer .grid-x.footer2:has(.copyright) > .cell.padding-top-1 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

/* Zero out the 32px cell margin-bottom (which is set globally on
   .footer2 > .cell for the main 4-column row's column spacing) — that
   extra margin was making the bottom much taller than the top here. */
#footer .grid-x.footer2:has(.copyright) > .cell {
    margin-bottom: 16px !important;
    margin-top: 16px !important;
}

#footer .copyright a {
    color: rgba(251, 252, 253, 0.78);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.3s cubic-bezier(0.16, 1, 0.3, 1);
}

#footer .copyright a:hover {
    color: var(--bmw-c-accent);
}

#footer .copyright span#ps-copyrightyear-js {
    color: rgba(251, 252, 253, 0.78);
}

#footer .copyright span.show-for-large {
    color: rgba(251, 252, 253, 0.32);
    margin: 0 4px;
}

/* === Mobile / Tablet (≤1023.5px) === */
@media screen and (max-width: 1023.5px) {

    #footer .footer2 {
        padding: 48px 0 24px !important;
    }

    #footer .grid-x.footer2 > .cell {
        margin-bottom: 36px;
        text-align: center;
    }

    /* Copyright row — keep symmetric on mobile too, overriding both
       the .footer2 mobile padding and the cell margin-bottom above */
    #footer .grid-x.footer2:has(.copyright) {
        padding: 12px 0 !important;
    }

    #footer .grid-x.footer2:has(.copyright) > .cell {
        margin-bottom: 0 !important;
        margin-top: 0 !important;
    }

    #footer .column-container {
        text-align: center;
        padding: 0 16px;
    }

    #footer h4 {
        font-size: 20px;
        margin-bottom: 18px !important;
    }

    #footer h4::after {
        left: 50%;
        transform: translateX(-50%);
    }

    #footer .media-section ul.social-media-icons {
        justify-content: center;
    }

    /* Reset link hover padding shift on mobile (touch-only, no hover) */
    #footer .links-section ul li a:hover,
    #footer .links-section ul li.active > a {
        padding-left: 0;
    }

    #footer .links-section ul li a::before {
        display: none;
    }

    /* Center contact items (icon + text together) on mobile */
    #footer .contact-section .actual-address,
    #footer .contact-section .address-container,
    #footer .contact-section .contact-number,
    #footer .contact-section .contact-email {
        justify-content: center;
    }

    #footer .contact-section a.footer-phone::after,
    #footer .contact-section a.footer-email::after {
        left: 50%;
        transform: translateX(-50%) scaleX(0);
    }

    #footer .contact-section a.footer-phone:hover::after,
    #footer .contact-section a.footer-email:hover::after {
        transform: translateX(-50%) scaleX(1);
    }
}

/* Small mobile refinements */
@media screen and (max-width: 39.9375em) {

    #footer .footer2 {
        padding: 36px 0 20px !important;
    }

    #footer .grid-x.footer2 > .cell {
        margin-bottom: 30px;
    }

    #footer h4 {
        font-size: 18px;
    }

    #footer .copyright {
        font-size: 11px;
        padding: 0 16px;
    }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
    #footer *,
    #footer *::before,
    #footer *::after {
        transition: none !important;
        animation: none !important;
    }
}



/* ============================================================
   BRAND TOKENS — BE MINDFULLY WELL — change colors/fonts here = whole site updates
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Mulish:wght@300;400;500;600;700&display=swap');

:root{
  /* core brand */
  --bmw-c-primary:#588090; --bmw-c-primary-dark:#002848; --bmw-c-accent:#A9C2CC;
  --bmw-font-head:"Cormorant Garamond",Georgia,serif;
  --bmw-font-body:"Mulish",-apple-system,BlinkMacSystemFont,sans-serif;

  /* neutrals + surfaces */
  --bmw-c-ink:#001830; --bmw-c-ink-2:#2C475A; --bmw-c-muted:#647E8B;
  --bmw-c-paper:#FBFCFD; --bmw-c-ivory:#F1F5F7; --bmw-c-ivory-deep:#E7EFF1;
  --bmw-c-sand:#DCE7EA; --bmw-c-sand-deep:#C9D9DE; --bmw-c-cream:#FBFCFD;
  --bmw-c-line:#CCDADF; --bmw-c-sage-soft:#7B9AA7; --bmw-c-sage-mist:#A9C2CC;
  --bmw-c-terra:#C2603F;

  /* buttons */
  --bmw-btn-bg:var(--bmw-c-primary-dark); --bmw-btn-text:var(--bmw-c-cream);
  --bmw-btn-bg-hover:#001830;

  /* rhythm */
  --bmw-space-section:104px; --bmw-gap:30px;
  --bmw-r-sm:10px; --bmw-r-md:18px; --bmw-r-lg:26px; --bmw-r-pill:999px;
  --bmw-shadow-soft:0 24px 60px -28px rgba(0,24,48,.34);
  --bmw-shadow-card:0 18px 40px -26px rgba(0,24,48,.30);

  /* type scale */
  --bmw-fs-h2:clamp(31px,3.6vw,40px);
  --bmw-fs-h3:clamp(20px,2.4vw,26px);
  --bmw-fs-body:18px;
}
@media all and (max-width:640px){
  :root{ --bmw-space-section:72px; --bmw-gap:18px; }
}

/* ============================================================
   BASE TYPOGRAPHY (scoped to wrapper, never touches wrappers)
   ============================================================ */
.is-wrapper h1.bmw-h,.is-wrapper h2.bmw-h,.is-wrapper h3.bmw-h{
  font-family:var(--bmw-font-head); font-weight:500; line-height:1.12;
  letter-spacing:-.01em; color:var(--bmw-c-ink); text-wrap:balance;
}
.is-wrapper p.bmw-p,.is-wrapper li.bmw-li{
  font-family:var(--bmw-font-body); color:var(--bmw-c-ink-2);
  line-height:1.65; text-wrap:pretty;
}

/* ---------- Eyebrow ---------- */
.bmw-eyebrow{
  font-family:var(--bmw-font-body); font-size:12.5px; font-weight:600;
  letter-spacing:.22em; text-transform:uppercase; color:var(--bmw-c-primary);
  display:inline-flex; align-items:center; gap:10px;
}
.bmw-eyebrow::before{
  content:""; width:26px; height:1px; background:var(--bmw-c-sage-soft); display:inline-block;
}
.bmw-eyebrow.bmw-center::before{ display:none; }

/* ============================================================
   BUTTONS — single global interaction system (all button types)
   ============================================================ */
.is-wrapper a.bmw-btn,
.is-wrapper button.bmw-btn{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--bmw-font-body); font-size:15px; font-weight:600;
  letter-spacing:.01em; padding:15px 28px; border-radius:var(--bmw-r-pill);
  cursor:pointer; border:1px solid transparent; white-space:nowrap;
  transition:transform .25s ease, background .25s ease, color .25s ease,
             box-shadow .25s ease, border-color .25s ease;
}
.is-wrapper a.bmw-btn svg,
.is-wrapper button.bmw-btn svg{ width:16px; height:16px; transition:transform .25s ease; }

/* primary */
.is-wrapper a.bmw-primary-btn,
.is-wrapper button.bmw-primary-btn{
  background:var(--bmw-btn-bg); color:var(--bmw-btn-text);
  box-shadow:0 12px 26px -14px rgba(0,40,72,.55);
}
.is-wrapper a.bmw-primary-btn:hover,
.is-wrapper button.bmw-primary-btn:hover{
  background:var(--bmw-btn-bg-hover); transform:translateY(-2px);
}
.is-wrapper a.bmw-primary-btn:hover svg{ transform:translateX(4px); }

/* secondary (ghost) */
.is-wrapper a.bmw-secondary-btn,
.is-wrapper button.bmw-secondary-btn{
  background:transparent; color:var(--bmw-c-ink); border-color:var(--bmw-c-line);
}
.is-wrapper a.bmw-secondary-btn:hover,
.is-wrapper button.bmw-secondary-btn:hover{
  border-color:var(--bmw-c-primary); color:var(--bmw-c-primary-dark); transform:translateY(-2px);
}

/* text-only button */
.is-wrapper a.bmw-text-btn,
.is-wrapper button.bmw-text-btn{
  background:transparent; color:var(--bmw-c-primary-dark);
  border:0; border-bottom:1px solid transparent; border-radius:0;
  padding:6px 0 4px; gap:8px;
}
.is-wrapper a.bmw-text-btn:hover,
.is-wrapper button.bmw-text-btn:hover{
  gap:12px; border-bottom-color:var(--bmw-c-primary); transform:none;
}

/* ghost-on-dark (hero / dark sections) */
.is-wrapper a.bmw-ghost-light-btn,
.is-wrapper button.bmw-ghost-light-btn{
  background:transparent; color:var(--bmw-c-cream); border-color:rgba(255,255,255,.55);
}
.is-wrapper a.bmw-ghost-light-btn:hover,
.is-wrapper button.bmw-ghost-light-btn:hover{
  background:rgba(255,255,255,.12); border-color:#fff; transform:translateY(-2px);
}

/* CTA link */
.is-wrapper a.bmw-cta-link{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--bmw-font-body); font-weight:600; font-size:15px;
  color:var(--bmw-c-primary-dark); border-bottom:1px solid transparent; padding-bottom:2px;
  transition:gap .25s ease, border-color .25s ease;
}
.is-wrapper a.bmw-cta-link:hover{ gap:12px; border-bottom-color:var(--bmw-c-primary); }

/* ============================================================
   HERO  (styles only the bmw-* helpers inside the locked hero chain)
   ============================================================ */
.is-wrapper > .bmw-hero-sec .bmw-hero-img img,
.is-wrapper .bmw-hero-sec .bmw-hero-img img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.is-wrapper .bmw-hero-sec .bn-overlay{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(135deg,rgba(0,24,48,.78),rgba(0,24,48,.55) 52%,rgba(0,15,30,.30));
}
.is-wrapper .bmw-hero-sec .bn-content{ position:relative; z-index:2; }
.bmw-hero-card{
  position:relative; max-width:700px; padding:30px 30px 30px;
  background:rgba(0,24,48,.72); backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.10); border-radius:16px;
  box-shadow:0 44px 90px -42px rgba(0,15,30,.75);
}
.bmw-hero-card::before{
  content:""; position:absolute; left:-1px; top:44px; bottom:44px; width:3px;
  background:var(--bmw-c-primary); border-radius:3px;
}
.bmw-hero-card .bmw-eyebrow{ color:var(--bmw-c-sage-mist); margin-bottom:24px; }
.bmw-hero-card .bmw-eyebrow::before{ background:var(--bmw-c-sage-soft); }
.bmw-hero-card .banner-main-heading{
  font-family:var(--bmw-font-head); font-style:italic; font-weight:500;
  font-size:42px; line-height:1.12; color:var(--bmw-c-cream); margin:0 0 22px;
  text-wrap:balance;
}
.bmw-hero-card .banner-main-heading .bmw-accent{ color:var(--bmw-c-sage-mist); font-style:italic; }
.bmw-hero-card .bmw-lede{
  font-family:var(--bmw-font-body); font-size:18px; color:#C9D6DC;
  max-width:470px; margin:0 0 34px; line-height:1.6;
}
.bmw-hero-cta{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }

/* ============================================================
   SECTION SCAFFOLDING (wrapper-scoped backgrounds)
   ============================================================ */
.is-wrapper > .bmw-bg-sand,   .is-wrapper .bmw-bg-sand{ background:var(--bmw-c-sand); padding:20px 0; }
.is-wrapper > .bmw-bg-ivory,  .is-wrapper .bmw-bg-ivory{ background:var(--bmw-c-ivory-deep); padding:20px 0; }
.is-wrapper > .bmw-bg-paper,  .is-wrapper .bmw-bg-paper{ background:var(--bmw-c-paper); padding:20px 0; }
.is-wrapper > .bmw-bg-sage,   .is-wrapper .bmw-bg-sage{ background:var(--bmw-c-primary-dark); padding:20px 0; }

.bmw-section-head{ max-width:720px; }
.bmw-section-head.bmw-center{ margin:0 auto; text-align:center; }
.bmw-section-head .bmw-eyebrow{ margin-bottom:20px; }
.bmw-section-head .bmw-h{ font-size:var(--bmw-fs-h2); color:var(--bmw-c-ink); margin:0 0 20px; }

/* shared two-column copy block */
.bmw-col-eyebrow{ margin-bottom:20px; }
.bmw-col-title{ font-size:var(--bmw-fs-h2); margin:0 0 24px; }
.bmw-col-text{ font-size:var(--bmw-fs-body); margin:0 0 34px; }
.bmw-col-text:last-child{ margin-bottom:0; }

/* generic media tiles (style the INNER div, never the cell) */
.bmw-media{ width:100%; box-shadow:var(--bmw-shadow-soft); border-radius:var(--bmw-r-md); overflow:hidden; }
.bmw-media img{ display:block; width:100%; height:100%; object-fit:cover; }
/*.bmw-media-480{ height:480px; }
.bmw-media-560{ height:560px; }
.bmw-media-420{ height:420px; }*/

/* ============================================================
   READY  (image + copy)
   ============================================================ */
.bmw-ready-media{ position:relative; }

/* ============================================================
   ABOUT BRIAN
   ============================================================ */
.bmw-about-media{ position:relative; }
.bmw-about-media .bmw-media{ border-radius:200px 200px var(--bmw-r-md) var(--bmw-r-md); }
.bmw-sig{
  position:absolute; left:-18px; bottom:36px; background:var(--bmw-c-cream);
  border:1px solid var(--bmw-c-line); border-radius:14px; padding:16px 22px; box-shadow:var(--bmw-shadow-card);
}
.bmw-sig .bmw-sig-nm{ font-family:var(--bmw-font-head); font-style:italic; font-size:26px; color:var(--bmw-c-primary-dark); }
.bmw-sig .bmw-sig-rl{ font-family:var(--bmw-font-body); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--bmw-c-muted); }

/* ============================================================
   ENNEAGRAM
   ============================================================ */
.bmw-enn-visual{ display:grid; place-items:center; }
.bmw-enn-ring{ position:relative; width:340px; height:340px; max-width:100%; }
.bmw-enn-ring svg{ width:100%; height:100%; }
.bmw-enn-core{ position:absolute; inset:0; display:grid; place-items:center; text-align:center; }
.bmw-enn-core .bmw-enn-num{ font-family:var(--bmw-font-head); font-size:56px; color:var(--bmw-c-primary-dark); line-height:1; }
.bmw-enn-core .bmw-enn-lbl{ font-family:var(--bmw-font-body); font-size:11.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--bmw-c-muted); margin-top:6px; }

/* ============================================================
   PILLARS — interactive accordion/tabs
   ============================================================ */
.bmw-approach{ display:grid; grid-template-columns:0.82fr 1.18fr; gap:60px; margin-top:64px; align-items:stretch; }
.bmw-approach-nav{ display:flex; flex-direction:column; align-self:center; width:100%; }
.bmw-approach-tab{
  position:relative; display:grid; grid-template-columns:auto 1fr auto; gap:22px; align-items:center;
  width:100%; text-align:left; cursor:pointer; padding:28px 6px 28px 24px;
  background:none; border:none; border-top:1px solid var(--bmw-c-line);
  font-family:var(--bmw-font-head); transition:padding .35s ease;
}
.bmw-approach-nav .bmw-approach-tab:last-child{ border-bottom:1px solid var(--bmw-c-line); }
.bmw-approach-tab::before{
  content:""; position:absolute; left:0; top:50%; transform:translateY(-50%) scaleY(0);
  width:3px; height:58%; background:var(--bmw-c-primary-dark); transition:transform .4s cubic-bezier(.2,.7,.2,1);
}
.bmw-approach-tab.bmw-active::before{ transform:translateY(-50%) scaleY(1); }
.bmw-approach-tab .bmw-tnum{ font-style:italic; font-size:30px; font-weight:500; color:var(--bmw-c-sage-mist); transition:color .35s ease; }
.bmw-approach-tab .bmw-ttitle{ font-size:21px; line-height:1.2; color:var(--bmw-c-muted); transition:color .35s ease; }
.bmw-approach-tab .bmw-tdot{ width:7px; height:7px; border-radius:50%; background:var(--bmw-c-sage-mist); opacity:0; transition:opacity .35s ease; }
.bmw-approach-tab:hover .bmw-ttitle{ color:var(--bmw-c-ink-2); }
.bmw-approach-tab.bmw-active{ padding-left:30px; }
.bmw-approach-tab.bmw-active .bmw-tnum{ color:var(--bmw-c-primary-dark); }
.bmw-approach-tab.bmw-active .bmw-ttitle{ color:var(--bmw-c-ink); }
.bmw-approach-tab.bmw-active .bmw-tdot{ opacity:1; background:var(--bmw-c-primary-dark); }

.bmw-approach-panel{
  position:relative; overflow:hidden; background:var(--bmw-c-primary-dark); color:var(--bmw-c-cream);
  border-radius:var(--bmw-r-lg); padding:54px 54px 50px; min-height:440px; display:flex; align-items:center;
  box-shadow:var(--bmw-shadow-soft);
}
.bmw-approach-panel::after{
  content:""; position:absolute; right:-120px; bottom:-120px; width:320px; height:320px;
  border-radius:50%; background:radial-gradient(circle,rgba(169,194,204,.16),transparent 70%); pointer-events:none;
}
.bmw-approach-panel .bmw-pnum{
  position:absolute; top:8px; right:34px; font-family:var(--bmw-font-head); font-style:italic;
  font-size:150px; line-height:1; color:rgba(255,255,255,.08); pointer-events:none; user-select:none;
}
.bmw-panel-content{ display:none; position:relative; z-index:1; max-width:92%; }
.bmw-panel-content.bmw-active{ display:block; animation:bmwPanelIn .55s cubic-bezier(.2,.7,.2,1); }
@keyframes bmwPanelIn{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
.bmw-panel-content .bmw-picon{
  display:inline-grid; place-items:center; width:58px; height:58px; border-radius:50%;
  border:1px solid rgba(255,255,255,.28); margin-bottom:28px;
}
.bmw-panel-content .bmw-picon svg{ width:26px; height:26px; color:var(--bmw-c-sage-mist); }
.bmw-panel-content h3{ font-family:var(--bmw-font-head); font-weight:500; font-size:30px; color:var(--bmw-c-cream); margin:0 0 18px; line-height:1.14; }
.bmw-panel-content p{ font-family:var(--bmw-font-body); color:#D5E0E2; font-size:17px; line-height:1.72; margin:0; }

/* ============================================================
   SERVICE AREA  (dark)
   ============================================================ */

/* light text scoped to the dark band itself (bulletproof, used only here) */
.is-wrapper .bmw-bg-sage .bmw-col-title,
.is-wrapper .bmw-bg-sage .bmw-h{ color:var(--bmw-c-cream); }
.is-wrapper .bmw-bg-sage .bmw-col-text,
.is-wrapper .bmw-bg-sage .bmw-p{ color:#C9DBE1; }
.is-wrapper .bmw-bg-sage .bmw-eyebrow{ color:var(--bmw-c-sage-mist); }
.is-wrapper .bmw-bg-sage .bmw-eyebrow::before{ background:var(--bmw-c-sage-soft); }

/* layered depth on the dark band (overrides flat navy; padding kept from scaffolding) */
.is-wrapper > .bmw-bg-sage, .is-wrapper .bmw-bg-sage{
  background:
    radial-gradient(118% 82% at 86% -12%, rgba(169,194,204,.16), transparent 55%),
    radial-gradient(92% 78% at -6% 112%, rgba(0,46,82,.60), transparent 60%),
    var(--bmw-c-primary-dark);
}

/* copy column */
.bmw-bg-sage .bmw-two-col{ align-items:center; }
.bmw-bg-sage .bmw-col-title{ letter-spacing:.2px; text-wrap:balance; }

/* region pills — premium glass */
.bmw-regions{ display:flex; flex-wrap:wrap; gap:12px; margin-top:38px; }
.is-wrapper a.bmw-region{
  position:relative; display:inline-flex; align-items:center; gap:9px;
  border:1px solid rgba(255,255,255,.20); border-radius:var(--bmw-r-pill);
  padding:10px 20px; font-family:var(--bmw-font-body); font-size:14px; font-weight:600; letter-spacing:.2px;
  color:var(--bmw-c-cream); text-decoration:none;
  background:linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.04));
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  box-shadow:0 1px 0 rgba(255,255,255,.07) inset, 0 8px 18px -12px rgba(0,0,0,.6);
  transition:transform .28s cubic-bezier(.2,.7,.2,1), border-color .28s ease, background .28s ease, box-shadow .28s ease, color .28s ease;
}
.is-wrapper a.bmw-region svg{ width:14px; height:14px; color:var(--bmw-c-sage-mist); flex:none; transition:color .28s ease; }
.is-wrapper a.bmw-region:hover{
  transform:translateY(-3px); border-color:var(--bmw-c-sage-mist);
  background:linear-gradient(180deg, rgba(169,194,204,.26), rgba(169,194,204,.13));
  box-shadow:0 14px 26px -14px rgba(0,0,0,.7);
}
.is-wrapper a.bmw-region:hover svg{ color:var(--bmw-c-cream); }
.is-wrapper a.bmw-region:focus-visible{ outline:2px solid var(--bmw-c-sage-mist); outline-offset:3px; }

/* stat / map card — elevated glass with ambient glow */
.bmw-service-visual{ display:grid; place-items:center; }
.bmw-map-card{
  position:relative; overflow:hidden; width:100%; max-width:520px;
  background:linear-gradient(165deg, rgba(255,255,255,.12), rgba(255,255,255,.045));
  border:1px solid rgba(255,255,255,.18); border-radius:24px; padding:50px 46px;
  text-align:center; -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  box-shadow:0 44px 88px -42px rgba(0,10,24,.85), 0 1px 0 rgba(255,255,255,.08) inset;
}
.bmw-map-card::before{ /* ambient corner glow */
  content:""; position:absolute; z-index:0; top:-42%; right:-30%; width:72%; height:84%;
  background:radial-gradient(circle, rgba(169,194,204,.32), transparent 70%); pointer-events:none;
}
.bmw-map-card::after{ /* hairline top accent */
  content:""; position:absolute; z-index:2; left:50%; top:0; transform:translateX(-50%);
  width:64px; height:3px; border-radius:0 0 3px 3px; background:var(--bmw-c-sage-mist);
}
.bmw-map-card > *{ position:relative; z-index:1; }
.bmw-map-card .bmw-big{
  font-family:var(--bmw-font-head); font-weight:500; font-size:clamp(54px,7vw,76px);
  color:var(--bmw-c-cream); line-height:1; letter-spacing:.5px;
  text-shadow:0 8px 40px rgba(169,194,204,.18);
}
.bmw-map-card .bmw-big span{ color:var(--bmw-c-sage-mist); font-style:italic; }
.bmw-map-card .bmw-cap{
  font-family:var(--bmw-font-body); font-size:12.5px; letter-spacing:.18em;
  text-transform:uppercase; color:var(--bmw-c-sage-mist); margin-top:16px;
}
.bmw-map-modes{
  display:flex; justify-content:center; gap:0; margin-top:32px; padding-top:28px;
  border-top:1px solid rgba(255,255,255,.16);
}
.bmw-map-modes .bmw-mode{ display:flex; flex-direction:column; align-items:center; padding:0 30px; }
.bmw-map-modes .bmw-mode + .bmw-mode{ border-left:1px solid rgba(255,255,255,.16); }
.bmw-map-modes .bmw-mode .bmw-mode-v{ font-family:var(--bmw-font-head); font-weight:500; font-size:30px; color:var(--bmw-c-cream); line-height:1.1; }
.bmw-map-modes .bmw-mode .bmw-mode-k{ font-family:var(--bmw-font-body); font-size:12px; letter-spacing:.04em; color:#BFD2D9; margin-top:5px; }

@media all and (max-width:640px){
  .bmw-map-card{ padding:36px 26px; }
  .bmw-map-modes .bmw-mode{ padding:0 20px; }
  .bmw-regions{ gap:10px; }
}

/* ============================================================
   BLOG
   ============================================================ */
.bmw-blog-topics{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:36px; }
.is-wrapper a.bmw-topic{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--bmw-font-body); font-size:13px; font-weight:600; letter-spacing:.01em;
  color:var(--bmw-c-primary-dark); text-decoration:none;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-pill); padding:8px 16px;
  transition:background .25s ease, color .25s ease, border-color .25s ease, transform .25s ease, box-shadow .25s ease;
}
.is-wrapper a.bmw-topic::before{
  content:""; width:7px; height:7px; border-radius:50%; flex:none;
  background:var(--bmw-c-primary); transition:background .25s ease, transform .25s ease;
}
.is-wrapper a.bmw-topic:hover{
  background:var(--bmw-c-primary); color:var(--bmw-c-cream); border-color:var(--bmw-c-primary);
  transform:translateY(-2px); box-shadow:0 12px 24px -14px rgba(0,40,72,.45);
}
.is-wrapper a.bmw-topic:hover::before{ background:var(--bmw-c-sage-mist); transform:scale(1.1); }

/* ============================================================
   NEWSLETTER  — premium dark editorial CTA card on an ivory band
   ============================================================ */
.is-wrapper > .bmw-news-wrap,
.is-wrapper .bmw-news-wrap{ background:var(--bmw-c-ivory-deep); padding:50px 0; }

.bmw-news-card{
  position:relative; overflow:hidden; text-align:center;
  background:linear-gradient(150deg,#02314f 0%,var(--bmw-c-primary-dark) 48%,#001324 100%);
  border:1px solid rgba(169,194,204,.18); border-radius:var(--bmw-r-lg);
  padding:80px 64px 76px; box-shadow:var(--bmw-shadow-soft);
}
/* hairline inner glow */
.bmw-news-card::before{
  content:""; position:absolute; inset:1px; border-radius:calc(var(--bmw-r-lg) - 1px);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08); pointer-events:none;
}
/* ambient orbs */
.bmw-news-orb{ position:absolute; border-radius:50%; pointer-events:none; filter:blur(2px); }
.bmw-news-orb-a{ width:420px; height:420px; top:-180px; left:-120px;
  background:radial-gradient(circle,rgba(88,128,144,.30),transparent 68%); }
.bmw-news-orb-b{ width:360px; height:360px; bottom:-160px; right:-100px;
  background:radial-gradient(circle,rgba(169,194,204,.18),transparent 70%); }

.bmw-news-leaf{ position:absolute; top:-26px; right:18px; opacity:.10; pointer-events:none; }
.bmw-news-leaf svg{ width:190px; height:190px; color:var(--bmw-c-sage-mist); }

.bmw-news-inner{ position:relative; z-index:1; max-width:100%; margin:0 auto; }
.bmw-news-inner .bmw-eyebrow{ color:var(--bmw-c-sage-mist); margin-bottom:18px; }
.bmw-news-inner .bmw-eyebrow::before{ background:var(--bmw-c-sage-soft); }
.is-wrapper .bmw-news-inner .bmw-h{ font-size:clamp(28px,3vw,42px); color:var(--bmw-c-cream); margin:0 0 18px; }
.is-wrapper .bmw-news-inner .bmw-news-text{
  font-family:var(--bmw-font-body); color:#C9D6DC; font-size:17px;
  max-width:100%; margin:0 auto 34px; line-height:1.7;
}

/* value points */
.bmw-news-points{
  list-style:none; margin:0 auto 38px; padding:0; max-width:660px;
  display:flex; flex-wrap:wrap; justify-content:center; gap:14px 28px;
}
.is-wrapper .bmw-news-points .bmw-li{
  display:inline-flex; align-items:center; gap:10px; margin:0;
  font-family:var(--bmw-font-body); font-size:14px; font-weight:500; color:#CFDDE3; line-height:1.4;
}
.bmw-news-points .bmw-li svg{ width:18px; height:18px; color:var(--bmw-c-sage-mist); flex:none; }

/* CTA row */
.bmw-news-cta{ display:flex; align-items:center; justify-content:center; gap:26px; flex-wrap:wrap; }
.is-wrapper a.bmw-news-btn{
  background:var(--bmw-c-cream); color:var(--bmw-c-primary-dark);
  text-transform:none; letter-spacing:.01em; padding:16px 32px;
  box-shadow:0 16px 34px -16px rgba(0,0,0,.55);
}
.is-wrapper a.bmw-news-btn:hover{ background:#fff; transform:translateY(-2px); box-shadow:0 20px 40px -16px rgba(0,0,0,.6); }
.is-wrapper a.bmw-news-btn svg{ width:16px; height:16px; }
.is-wrapper a.bmw-news-btn:hover svg{ transform:translateX(4px); }
.is-wrapper a.bmw-news-link{ color:var(--bmw-c-sage-mist); }
.is-wrapper a.bmw-news-link:hover{ color:var(--bmw-c-cream); border-bottom-color:var(--bmw-c-sage-mist); }

@media all and (max-width:640px){
  .bmw-news-card{ padding:52px 26px 50px; }
  .bmw-news-points{ flex-direction:column; align-items:center; gap:14px; }
  .bmw-news-cta{ flex-direction:column; gap:18px; }
  .bmw-news-cta .bmw-btn{ justify-content:center; width:100%; }
}
.bmw-news-cta{ display:flex; justify-content:center; }

/* ============================================================
   GRID HELPERS — two-column on desktop, stack on mobile
   ============================================================ */
.bmw-two-col{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.bmw-two-col.bmw-ready{ grid-template-columns:0.85fr 1.15fr; gap:70px; }
.bmw-two-col.bmw-about{ grid-template-columns:1.1fr 0.9fr; gap:72px; }
.bmw-two-col.bmw-enn{ grid-template-columns:1.1fr 0.9fr; gap:72px; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media all and (max-width:1023px){
  .bmw-two-col,
  .bmw-two-col.bmw-ready,
  .bmw-two-col.bmw-about,
  .bmw-two-col.bmw-enn{ grid-template-columns:1fr; gap:44px; }
 /* .bmw-media-480,.bmw-media-560,.bmw-media-420{ height:420px; }
  .bmw-hero-sec .bmw-hero-img img{ min-height:600px; }*/
  .bmw-hero-card{ max-width:none; padding:44px 32px; }
  .bmw-hero-sec .bn-overlay{ background:linear-gradient(180deg,rgba(0,24,48,.62),rgba(0,15,30,.52)); }
  .bmw-approach{ grid-template-columns:1fr; gap:34px; }
  .bmw-approach-panel{ min-height:0; padding:40px 30px; }
  .bmw-approach-panel .bmw-pnum{ font-size:110px; top:0; right:22px; }
  .bmw-panel-content{ max-width:100%; }
  .bmw-enn-visual{ order:-1; }
}
@media all and (max-width:560px){
  .bmw-hero-cta{ gap:16px; }
  .bmw-news-cta .bmw-btn{ justify-content:center; }
}

/* ============================================================
   ABOUT PAGE — components (reuse tokens; scoped; never touch wrappers)
   ============================================================ */

/* two-col variant: teaching (image left, copy right) */
.bmw-two-col.bmw-teach{ grid-template-columns:0.95fr 1.05fr; gap:70px; }

/* centered statement (My Mission / Curiosity) */
.bmw-statement{ max-width:880px; margin:0 auto; text-align:center; }
.bmw-statement .bmw-statement-leaf{ display:flex; justify-content:center; margin-bottom:22px; color:var(--bmw-c-sage-soft); }
.bmw-statement .bmw-statement-leaf svg{ width:44px; height:44px; }
.is-wrapper .bmw-statement .bmw-h{ font-size:var(--bmw-fs-h2); margin:0 0 24px; }
.bmw-statement .bmw-statement-text{
  font-family:var(--bmw-font-body); font-size:20px; line-height:1.72;
  color:var(--bmw-c-ink-2); margin:0;
}

/* credentials list (What Shapes My Approach) */
.bmw-creds{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:16px; }
.is-wrapper .bmw-creds .bmw-cred{
  display:grid; grid-template-columns:auto 1fr; gap:16px; align-items:center; margin:0;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line); border-radius:var(--bmw-r-md);
  padding:18px 20px;
  font-family:var(--bmw-font-body); font-size:16px; line-height:1.5; color:var(--bmw-c-ink-2);
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.is-wrapper .bmw-creds .bmw-cred:hover{
  transform:translateY(-2px); box-shadow:var(--bmw-shadow-card); border-color:var(--bmw-c-sage-mist);
}
.bmw-creds .bmw-cred-ic{
  display:inline-grid; place-items:center; width:40px; height:40px; border-radius:50%;
  background:var(--bmw-c-ivory-deep); flex:none;
}
.bmw-creds .bmw-cred-ic svg{ width:19px; height:19px; color:var(--bmw-c-primary); }

/* narrative rows (Foundation / Listening) */
.bmw-narrative{ display:flex; flex-direction:column; }
.bmw-narr-row{
  display:grid; grid-template-columns:0.8fr 1.2fr; gap:54px; align-items:start;
  padding:46px 0; border-top:1px solid var(--bmw-c-line);
}
.bmw-narr-row:first-child{ border-top:0; padding-top:0; }
.bmw-narr-row:last-child{ padding-bottom:0; }
.bmw-narr-head{ display:flex; flex-direction:column; gap:14px; }
.bmw-narr-index{ font-family:var(--bmw-font-head); font-style:italic; font-size:36px; color:var(--bmw-c-sage-mist); line-height:1; }
.is-wrapper .bmw-narr-head .bmw-h{ font-size:clamp(23px,2.5vw,29px); margin:0; }
.is-wrapper .bmw-narr-body .bmw-p{ font-size:var(--bmw-fs-body); margin:0; }

/* CTA band (Begin the Conversation) */
.bmw-cta-band{ max-width:760px; margin:0 auto; text-align:center; }
.bmw-cta-band .bmw-eyebrow{ margin-bottom:18px; }
.is-wrapper .bmw-cta-band .bmw-h{ font-size:var(--bmw-fs-h2); margin:0 0 18px; }
.is-wrapper .bmw-cta-band .bmw-p{ font-size:var(--bmw-fs-body); margin:0 auto 30px; max-width:640px; }

/* ---- About page responsive ---- */
@media all and (max-width:1023px){
  .bmw-two-col.bmw-teach{ grid-template-columns:1fr; gap:44px; }
  .bmw-teach-media{ order:-1; }
  .bmw-narr-row{ grid-template-columns:1fr; gap:16px; padding:34px 0; }
}
@media all and (max-width:640px){
  .bmw-statement .bmw-statement-text{ font-size:18px; }
  .is-wrapper .bmw-creds .bmw-cred{ font-size:15px; padding:16px 16px; }
}

/* ============================================================
   SERVICES PAGE — intro head lead + 6-card grid
   ============================================================ */
.is-wrapper .bmw-section-head .bmw-p{ font-size:var(--bmw-fs-body); color:var(--bmw-c-ink-2); max-width:720px; margin:0 auto; }
.bmw-section-head.bmw-center .bmw-p{ margin-left:auto; margin-right:auto; }

.bmw-svc-head{ margin-bottom:32px; }
.bmw-svc-cell{ display:flex; }
.bmw-service-card{
  width:100%; height:100%; display:flex; flex-direction:column; background:var(--bmw-c-paper);
  border:1px solid var(--bmw-c-line); border-radius:var(--bmw-r-md); overflow:hidden;
  text-decoration:none; color:inherit;
  transition:transform .3s ease, box-shadow .3s ease, border-color .3s ease;
}
.bmw-service-card:hover,
.bmw-service-card:focus,
.bmw-service-card:visited{ text-decoration:none; color:inherit; }
.bmw-service-card:focus-visible{ outline:3px solid var(--bmw-c-accent); outline-offset:3px; }
.bmw-service-card:hover{
  transform:translateY(-6px); box-shadow:var(--bmw-shadow-soft); border-color:var(--bmw-c-sage-mist);
}
.bmw-svc-media{ position:relative; height:210px; overflow:hidden; background:var(--bmw-c-ivory-deep); }
.bmw-svc-media img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .55s ease; }
.bmw-service-card:hover .bmw-svc-media img{ transform:scale(1.05); }
.bmw-svc-body{ display:flex; flex-direction:column; flex:1; padding:30px 30px 34px; }
.is-wrapper .bmw-svc-title{
  font-family:var(--bmw-font-head); font-weight:500; font-size:23px; line-height:1.2;
  color:var(--bmw-c-ink); margin:0 0 12px; text-wrap:balance;
}
.bmw-svc-text{
  font-family:var(--bmw-font-body); font-size:15.5px; line-height:1.62;
  color:var(--bmw-c-ink-2); margin:0;
}
.bmw-svc-more{
  display:inline-flex; align-items:center; gap:8px; margin-top:auto; padding-top:20px;
  font-family:var(--bmw-font-body); font-size:14.5px; font-weight:700; line-height:1.3;
  color:var(--bmw-c-primary);
}
.bmw-svc-more svg{ width:17px; height:17px; transition:transform .3s ease; }
.bmw-service-card:hover .bmw-svc-more{ color:var(--bmw-c-primary-dark); }
.bmw-service-card:hover .bmw-svc-more svg{ transform:translateX(4px); }

@media all and (max-width:600px){
  .bmw-svc-body{ padding:26px 24px 30px; }
}

/* ============================================================
   LIFE COACHING PAGE — feature rows, checklist, benefit cards
   (appended; tokens only)
   ============================================================ */

/* benefit cards (intro grid) */
.bmw-value-cell{ display:flex; }
.bmw-value-card{
  width:100%;
  background:var(--bmw-c-ivory);
  border:1px solid var(--bmw-c-line);
  border-left:4px solid var(--bmw-c-primary);
  border-radius:var(--bmw-r-md);
  padding:28px 26px 30px;
  box-shadow:var(--bmw-shadow-card);
}
.is-wrapper .bmw-value-title{
  font-family:var(--bmw-font-head); font-weight:600;
  font-size:22px; line-height:1.2; color:var(--bmw-c-ink);
  margin:0 0 9px; text-wrap:balance;
}
.bmw-value-card p{
  font-family:var(--bmw-font-body); color:var(--bmw-c-ink-2);
  font-size:15.5px; line-height:1.6; margin:0;
}

/* feature rows (image + copy + checklist) */
.bmw-feature{ display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; }
.bmw-feature-rev .bmw-feature-media{ order:2; }
.is-wrapper .bmw-feature-title{
  font-family:var(--bmw-font-head); font-weight:600;
  font-size:var(--bmw-fs-h2); line-height:1.12; color:var(--bmw-c-ink);
  margin:0 0 16px; text-wrap:balance;
}
.bmw-feature-body p{
  font-family:var(--bmw-font-body); color:var(--bmw-c-ink-2);
  font-size:var(--bmw-fs-body); line-height:1.7; margin:0;
}

/* checklist */
.bmw-checklist{ list-style:none; margin:24px 0 0; padding:0; display:grid; gap:13px; }
.bmw-checklist li{
  display:flex; align-items:flex-start; gap:13px;
  font-family:var(--bmw-font-body); color:var(--bmw-c-ink-2);
  font-size:16px; line-height:1.5;
}
.bmw-chk{ flex:0 0 auto; width:23px; height:23px; color:var(--bmw-c-primary); margin-top:1px; }

@media all and (max-width:1023.5px){
  .bmw-feature{ grid-template-columns:1fr; gap:32px; }
  .bmw-feature-rev .bmw-feature-media{ order:0; }
}
@media all and (max-width:600px){
  .bmw-value-card{ padding:24px 22px 26px; }
}

/* ============================================================
   SERVICE AREAS PAGE — interactive service-card grid (bmw-sa-*)
   Distinct from Services-hub cards: index-on-image, animated
   title underline, circular arrow button that fills on hover.
   ============================================================ */
.bmw-sa-cell{ display:flex; }
.bmw-sa-card{
  position:relative; display:flex; flex-direction:column; width:100%;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); overflow:hidden;
  box-shadow:var(--bmw-shadow-card); text-decoration:none;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s ease, border-color .4s ease;
}
.bmw-sa-card:hover,.bmw-sa-card:focus-visible{
  transform:translateY(-10px); box-shadow:var(--bmw-shadow-soft);
  border-color:var(--bmw-c-sage-mist); outline:none;
}
.bmw-sa-media{ position:relative; display:block; aspect-ratio:16/11; overflow:hidden; }
.bmw-sa-media img{ width:100%; height:100%; object-fit:cover; transition:transform .9s cubic-bezier(.2,.8,.2,1); }
.bmw-sa-card:hover .bmw-sa-media img{ transform:scale(1.07); }
.bmw-sa-media::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,24,48,.46), rgba(0,24,48,0) 58%);
  opacity:.9; transition:opacity .5s ease;
}
.bmw-sa-card:hover .bmw-sa-media::after{ opacity:1; }
.bmw-sa-index{
  position:absolute; left:20px; bottom:14px; z-index:1;
  font-family:var(--bmw-font-head); font-weight:600; font-size:30px;
  color:var(--bmw-c-cream); letter-spacing:.05em; line-height:1;
  transition:transform .5s ease;
}
.bmw-sa-card:hover .bmw-sa-index{ transform:translateY(-3px); }
.bmw-sa-body{ display:flex; flex-direction:column; flex:1 1 auto; padding:26px 26px 24px; }
.is-wrapper .bmw-sa-title{
  font-family:var(--bmw-font-head); font-weight:600; color:var(--bmw-c-ink);
  font-size:23px; line-height:1.18; margin:0 0 11px;
  position:relative; display:inline-block; align-self:flex-start;
}
.bmw-sa-title::after{
  content:""; position:absolute; left:0; bottom:-5px; height:2px; width:100%;
  background:var(--bmw-c-primary); transform:scaleX(0); transform-origin:left;
  transition:transform .5s cubic-bezier(.2,.8,.2,1);
}
.bmw-sa-card:hover .bmw-sa-title::after{ transform:scaleX(1); }
.bmw-sa-text{
  font-family:var(--bmw-font-body); color:var(--bmw-c-ink-2);
  font-size:15.5px; line-height:1.66; margin:0 0 20px; flex:1 1 auto;
}
.bmw-sa-cta{
  width:42px; height:42px; border-radius:50%; margin-top:auto;
  border:1.5px solid var(--bmw-c-line); color:var(--bmw-c-primary-dark);
  display:inline-flex; align-items:center; justify-content:center;
  transition:background .45s ease, border-color .45s ease, color .45s ease, transform .45s ease;
}
.bmw-sa-card:hover .bmw-sa-cta{
  background:var(--bmw-c-primary-dark); border-color:var(--bmw-c-primary-dark);
  color:var(--bmw-c-cream); transform:translateY(-2px);
}
.bmw-sa-cta svg{ width:18px; height:18px; transition:transform .45s ease; }
.bmw-sa-card:hover .bmw-sa-cta svg{ transform:translateX(3px); }
@media all and (max-width:600px){
  .bmw-sa-body{ padding:22px 22px 22px; }
  .is-wrapper .bmw-sa-title{ font-size:21px; }
}

/* ============================================================
   FAQ PAGE — accordion (native <details>/<summary>, no JS)
   ============================================================ */
.bmw-faq{ max-width:880px; margin:0 auto; display:grid; gap:14px; }
.bmw-faq-item{
  background:var(--bmw-c-paper);
  border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md);
  box-shadow:var(--bmw-shadow-card);
  overflow:hidden;
  transition:border-color .35s ease, box-shadow .35s ease, background .35s ease;
}
.bmw-faq-item[open]{
  border-color:var(--bmw-c-sage-mist);
  box-shadow:var(--bmw-shadow-soft);
}
.is-wrapper .bmw-faq-q{
  font-family:var(--bmw-font-head);
  color:var(--bmw-c-ink);
  font-weight:600;
  font-size:clamp(18px,2vw,21px);
  line-height:1.35;
  list-style:none;
  cursor:pointer;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:22px;
  padding:24px 28px;
  margin:0;
  text-wrap:balance;
  transition:color .3s ease;
}
.bmw-faq-q::-webkit-details-marker{ display:none; }
.bmw-faq-q:hover{ color:var(--bmw-c-primary); }
.bmw-faq-item[open] .bmw-faq-q{ color:var(--bmw-c-primary-dark); }
.bmw-faq-icon{
  flex:0 0 auto;
  width:30px; height:30px;
  border-radius:var(--bmw-r-pill);
  border:1.5px solid var(--bmw-c-line);
  display:flex; align-items:center; justify-content:center;
  color:var(--bmw-c-primary);
  margin-top:1px;
  transition:transform .4s cubic-bezier(.4,0,.2,1), background .3s ease, border-color .3s ease, color .3s ease;
}
.bmw-faq-icon svg{ width:15px; height:15px; display:block; }
.bmw-faq-item[open] .bmw-faq-icon{
  transform:rotate(45deg);
  background:var(--bmw-c-primary-dark);
  border-color:var(--bmw-c-primary-dark);
  color:var(--bmw-c-cream);
}
.bmw-faq-a{ padding:0 28px 24px; }
.is-wrapper .bmw-faq-a p{
  font-family:var(--bmw-font-body);
  color:var(--bmw-c-ink-2);
  font-size:var(--bmw-fs-body);
  line-height:1.7;
  margin:0;
  max-width:680px;
}
@media all and (max-width:640px){
  .is-wrapper .bmw-faq-q{ padding:18px 18px; font-size:17px; gap:14px; }
  .bmw-faq-a{ padding:0 18px 18px; }
}


/* ============================================================
   BLOG BANNER — reuses the site hero treatment (scoped: .bmw-blog-hero)
   Title is wrapped in .bmw-hero-card so the glass panel, accent bar,
   italic heading + mobile behaviour are inherited from the hero.
   Only the banner image + overlay are replicated here (those are
   otherwise scoped to .bmw-hero-sec).
   ============================================================ */
.bmw-blog-hero.main-blog-banner{ position:relative; overflow:hidden; }
.bmw-blog-hero figure{ margin:0; line-height:0; }
.bmw-blog-hero picture{ display:block; }
.is-wrapper .bmw-blog-hero figure img,
.bmw-blog-hero figure img{
  width:100%; height:100%; min-height:768px; object-fit:cover; display:block;
}
.bmw-blog-hero::after{
  content:""; position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(135deg,rgba(0,24,48,.78),rgba(0,24,48,.55) 52%,rgba(0,15,30,.30));
}
.is-wrapper .bmw-blog-hero .inner-banner.blog-banner{ z-index:2; }
@media all and (max-width:1023.5px){
  .bmw-blog-hero figure img{ min-height:600px; }
  .bmw-blog-hero::after{ background:linear-gradient(180deg,rgba(0,24,48,.62),rgba(0,15,30,.52)); }
}

/* ============================================================
   BLOG INDEX / LISTING PAGE (main.new-blog-page-type) — premium reskin
   CSS only; works with the platform's existing blog markup.
   Prefixed with main.new-blog-page-type so it wins over base theme.
   ============================================================ */
main.new-blog-page-type .main-blog-widget .grid-container{ max-width:1200px; }
main.new-blog-page-type .blog-articles{ padding-right:6px; }

/* ---- search bar ---- */
main.new-blog-page-type .blog-search-container{ margin-bottom:46px; }
main.new-blog-page-type .blog-search-container .position-relative{ max-width:560px; }
main.new-blog-page-type #search-input-blog{
  height:58px; margin-top:60px; margin-bottom:0;
  padding:8px 18px 8px 50px; border-radius:var(--bmw-r-pill);
  border:1px solid var(--bmw-c-line); background:var(--bmw-c-paper);
  font-family:var(--bmw-font-body); font-size:16px; color:var(--bmw-c-ink);
  box-shadow:var(--bmw-shadow-card); transition:border-color .25s ease, box-shadow .25s ease;
}
main.new-blog-page-type #search-input-blog::placeholder{ color:var(--bmw-c-muted); }
main.new-blog-page-type #search-input-blog:focus{
  outline:none; border-color:var(--bmw-c-sage-mist); box-shadow:0 0 0 4px rgba(169,194,204,.28);
}
main.new-blog-page-type .blog-search-button{
  position:absolute; left:18px; top:50%; transform:translateY(-50%); padding:0;
  background:none; border:none; cursor:pointer; line-height:0;
}
main.new-blog-page-type .blog-search-button svg path{ fill:var(--bmw-c-primary); transition:fill .25s ease; }
main.new-blog-page-type .blog-search-button:hover svg path{ fill:var(--bmw-c-primary-dark); }

/* ---- article cards ---- */
main.new-blog-page-type .blog-ul{ display:grid; grid-template-columns:1fr; gap:30px; margin:0; }
main.new-blog-page-type .blog-li{ margin:0; }
main.new-blog-page-type .blog-li .row{ max-width:none; margin:0; }
main.new-blog-page-type .blog-article{
  position:relative; overflow:hidden; float:none; width:100%;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card); padding:32px 34px;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .4s ease;
}
main.new-blog-page-type .blog-article:hover{
  transform:translateY(-6px); box-shadow:var(--bmw-shadow-soft); border-color:var(--bmw-c-sage-mist);
}
/* full-bleed cover image (only some posts have one) */
main.new-blog-page-type .ps-article-img{ margin:-32px -34px 26px; overflow:hidden; }
main.new-blog-page-type .ps-article-img img{
  display:block; width:100%; height:320px; object-fit:cover; margin:0;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
main.new-blog-page-type .blog-article:hover .ps-article-img img{ transform:scale(1.05); }

/* category meta line */
main.new-blog-page-type .article-category{ margin:0 0 14px; font-family:var(--bmw-font-body); }
main.new-blog-page-type .article-category span{
  font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--bmw-c-muted); font-weight:600;
}
main.new-blog-page-type .article-category a{ color:var(--bmw-c-primary); text-decoration:none; transition:color .25s ease; }
main.new-blog-page-type .article-category a:hover{ color:var(--bmw-c-primary-dark); }

/* title */
main.new-blog-page-type .article-title{ margin:0 0 14px; }
main.new-blog-page-type .article-title a{
  font-family:var(--bmw-font-head); font-weight:600; font-size:clamp(23px,2.4vw,29px);
  line-height:1.18; color:var(--bmw-c-ink); text-decoration:none; text-wrap:balance;
  display:inline-block; transition:color .25s ease;
}
main.new-blog-page-type .article-title a:hover{ color:var(--bmw-c-primary); }

/* excerpt — clamped to 3 lines */
main.new-blog-page-type .article-body{ margin:0 0 20px; }
main.new-blog-page-type .article-body p{
  font-family:var(--bmw-font-body); font-size:16.5px; line-height:1.7; color:var(--bmw-c-ink-2); margin:0;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* read more */
main.new-blog-page-type p.pb-0.mb-0{ margin:0; }
main.new-blog-page-type .blog-read-more{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--bmw-font-body); font-weight:700; font-size:14px; letter-spacing:.04em;
  color:var(--bmw-c-primary-dark); text-decoration:none; transition:gap .25s ease, color .25s ease;
}
main.new-blog-page-type .blog-read-more::after{ content:"\2192"; font-size:16px; transition:transform .25s ease; }
main.new-blog-page-type .blog-read-more:hover{ color:var(--bmw-c-primary); gap:12px; }
main.new-blog-page-type .blog-read-more:hover::after{ transform:translateX(2px); }

/* ---- sidebar + category headings ---- */
main.new-blog-page-type .blog-sidebar .articles-filter-container{
  position:sticky; top:100px;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card); padding:30px 28px;
}
main.new-blog-page-type .articles-filter-container.hide-for-large{ margin-bottom:34px; }
main.new-blog-page-type .filter-h2{
  position:relative; font-family:var(--bmw-font-head); font-weight:600;
  font-size:24px; color:var(--bmw-c-ink); margin:0 0 22px; padding-bottom:14px;
}
main.new-blog-page-type .filter-h2::after{
  content:""; position:absolute; left:0; bottom:0; width:46px; height:3px; border-radius:3px; background:var(--bmw-c-primary);
}

/* ---- category chips ---- */
main.new-blog-page-type .ps-blog-category{ display:flex; flex-wrap:wrap; gap:10px; margin:0; padding:0; list-style:none; max-height:100%; }
main.new-blog-page-type .ps-blog-category li{ display:inline; margin:0; width:100%; }
main.new-blog-page-type .ps-blog-category li a{
  display:block; padding:16px; border-radius:var(--bmw-r-pill);
  border:1px solid var(--bmw-c-line); background:var(--bmw-c-ivory-deep);
  font-family:var(--bmw-font-body); font-size:13.5px !important; font-weight:600; line-height:1.2;
  color:var(--bmw-c-ink-2); text-align:center; text-decoration:none; text-transform:capitalize;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
}
main.new-blog-page-type .ps-blog-category li a:hover{
  transform:translateY(-2px); background:var(--bmw-c-sage-mist); border-color:var(--bmw-c-sage-mist); color:var(--bmw-c-primary-dark);
}
main.new-blog-page-type .ps-blog-category li.active a,
main.new-blog-page-type .ps-blog-category li.active a.all-blogs{
  background:var(--bmw-c-primary-dark); border-color:var(--bmw-c-primary-dark);
  color:var(--bmw-c-cream); border-radius:var(--bmw-r-pill);
}
main.new-blog-page-type .ps-blog-category li.active a:hover{ background:var(--bmw-c-primary); border-color:var(--bmw-c-primary); }

/* ---- pagination (styled for when populated) ---- */
main.new-blog-page-type .ps-pagination-bar{ margin-top:44px; }
main.new-blog-page-type .ps-pagination-bar p{ display:flex; flex-wrap:wrap; gap:8px; justify-content:center; margin:0; }
main.new-blog-page-type .ps-pagination-bar span{
  display:inline-block; border:1px solid var(--bmw-c-line); background:var(--bmw-c-paper);
  border-radius:10px; margin:0; font-family:var(--bmw-font-body); font-size:14px; font-weight:600; color:var(--bmw-c-ink-2);
}
main.new-blog-page-type .ps-pagination-bar span a{ display:block; padding:11px 15px; color:inherit; text-decoration:none; }
main.new-blog-page-type .ps-pagination-bar span.current{ padding:11px 15px; background:var(--bmw-c-primary-dark); border-color:var(--bmw-c-primary-dark); color:var(--bmw-c-cream); }
main.new-blog-page-type .ps-pagination-bar span.next,
main.new-blog-page-type .ps-pagination-bar span.prev{ border-color:var(--bmw-c-primary-dark); background:var(--bmw-c-paper); }

/* ---- responsive ---- */
@media all and (max-width:1023.5px){
  main.new-blog-page-type #search-input-blog{ margin-top:40px; }
  main.new-blog-page-type .blog-articles{ padding-right:0; }
  main.new-blog-page-type .blog-sidebar .articles-filter-container{ position:static; margin-top:34px; }
  main.new-blog-page-type .articles-filter-container{ margin-top:0; }
  main.new-blog-page-type .ps-blog-category li a{
    width:auto; text-align:center; border:1px solid var(--bmw-c-line); border-radius:var(--bmw-r-pill);
    background:var(--bmw-c-ivory-deep); color:var(--bmw-c-ink-2);
  }
  main.new-blog-page-type .ps-blog-category li.active a{ background:var(--bmw-c-primary-dark); color:var(--bmw-c-cream); }
}
@media all and (max-width:640px){
  main.new-blog-page-type .blog-article{ padding:24px 22px; }
  main.new-blog-page-type .ps-article-img{ margin:-24px -22px 20px; }
  main.new-blog-page-type .ps-article-img img{ height:220px; }
}

/* ============================================================
   BLOG ARTICLE / POST PAGE  (main.article-page-type)
   Premium long-form reading layout. CSS only — pairs with the
   blog-listing styles above; appended last so article rules win ties.
   Scoped to main.article-page-type so the listing page is unaffected.
   ============================================================ */

/* container */
main.article-page-type .grid-container{ max-width:1200px; }

/* ---- POST TITLE (override hero banner-main-heading + base .article-title) ---- */
main.article-page-type h1.article-title.banner-main-heading{
  max-width:100%; margin:0 auto 30px; text-align:left;
  font-family:var(--bmw-font-head); font-style:normal; font-weight:600;
  font-size:clamp(32px,4.4vw,42px); line-height:1.15; color:var(--bmw-c-ink); text-wrap:balance;
}

/* ---- HEADER MEDIA (the large-8 hero image; matches only inside .blog-article-content) ---- */
main.article-page-type .blog-article-content .ps-article-img{ margin:0; }
main.article-page-type .blog-article-content .ps-article-img img{
  display:block; width:100%; height:auto; max-height:520px; object-fit:cover;
  border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card); margin:0;
}

/* ---- AUTHOR / META CARD (large-4) ---- */
main.article-page-type .blog-author{
  background:var(--bmw-c-ivory-deep); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); padding:26px 28px;
}
main.article-page-type .blog-author .lab-ul{
  list-style:none; margin:0; padding:0;
  font-family:var(--bmw-font-body); font-size:13px; line-height:1.7; color:var(--bmw-c-muted);
}
main.article-page-type .blog-author .lab-ul li{ margin:0 0 8px; }
main.article-page-type .author_name{
  font-family:var(--bmw-font-head); font-weight:600; font-size:20px; line-height:1.2; color:var(--bmw-c-ink);
}
main.article-page-type .blog-author .pubdate{ font-family:var(--bmw-font-body); font-size:14px; color:var(--bmw-c-ink-2); }
main.article-page-type .blog-author .lab-ul a{ color:var(--bmw-c-primary); text-decoration:none; transition:color .25s ease; }
main.article-page-type .blog-author .lab-ul a:hover{ color:var(--bmw-c-primary-dark); }

/* ---- ARTICLE BODY: comfortable reading measure + premium typography ---- */
main.article-page-type .article-body.rte{
  max-width:100%; margin:64px auto 0;
  font-family:var(--bmw-font-body); font-size:18px; line-height:1.8; color:var(--bmw-c-ink-2);
}
main.article-page-type .article-body.rte > *:first-child{ margin-top:0; }
main.article-page-type .article-body.rte h2{
  font-family:var(--bmw-font-head); font-weight:600; color:var(--bmw-c-ink);
  font-size:clamp(26px,3vw,34px); line-height:1.25; margin:50px 0 16px; text-wrap:balance;
}
main.article-page-type .article-body.rte p{ margin:0 0 22px; }
main.article-page-type .article-body.rte strong{ color:var(--bmw-c-ink); font-weight:700; }
main.article-page-type .article-body.rte a{
  color:var(--bmw-c-primary); text-decoration:underline; text-underline-offset:3px; transition:color .25s ease;
}
main.article-page-type .article-body.rte a:hover{ color:var(--bmw-c-primary-dark); }
/* lists with sage markers */
main.article-page-type .article-body.rte ul{ list-style:none; margin:0 0 26px; padding:0; }
main.article-page-type .article-body.rte ul li{ position:relative; padding-left:30px; margin:0 0 13px; line-height:1.7; }
main.article-page-type .article-body.rte ul li::before{
  content:""; position:absolute; left:5px; top:11px; width:9px; height:9px; border-radius:50%;
  background:var(--bmw-c-primary); box-shadow:0 0 0 4px rgba(88,128,144,.14);
}

/* ---- RECENT POSTS (full-width section below the article) ---- */
main.article-page-type .blog-sidebar{ margin-top:72px; padding-top:8px; border-top:1px solid var(--bmw-c-line); }
main.article-page-type .blog-sidebar-h2,
main.article-page-type .recent-posts-text{
  position:relative; font-family:var(--bmw-font-head); font-weight:600;
  font-size:clamp(26px,3vw,34px); line-height:1.2; color:var(--bmw-c-ink);
  margin:40px 0 30px; padding-bottom:14px; text-align:center;
}
main.article-page-type .blog-sidebar-h2::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%); bottom:0;
  width:54px; height:3px; border-radius:3px; background:var(--bmw-c-primary);
}

/* grid + compact cards (override the larger listing-card sizing) */
main.article-page-type .ps-blog-recent-posts{
  display:grid; grid-template-columns:repeat(3,1fr); gap:26px; list-style:none; margin:0; padding:0;
}
main.article-page-type .ps-blog-recent-posts .blog-li{ margin:0; }
main.article-page-type .ps-blog-recent-posts .blog-li .row{ max-width:none; margin:0; }
main.article-page-type .ps-blog-recent-posts .blog-article{
  position:relative; overflow:hidden; float:none; width:100%;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card); padding:24px 24px;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .4s ease;
}
main.article-page-type .ps-blog-recent-posts .blog-article:hover{
  transform:translateY(-6px); box-shadow:var(--bmw-shadow-soft); border-color:var(--bmw-c-sage-mist);
}
main.article-page-type .ps-blog-recent-posts .ps-article-img{ margin:-24px -24px 20px; overflow:hidden; }
main.article-page-type .ps-blog-recent-posts .ps-article-img img{
  display:block; width:100%; height:190px; object-fit:cover; margin:0;
  transition:transform .6s cubic-bezier(.2,.7,.2,1);
}
main.article-page-type .ps-blog-recent-posts .blog-article:hover .ps-article-img img{ transform:scale(1.05); }
main.article-page-type .ps-blog-recent-posts .article-category{ margin:0 0 10px; }
main.article-page-type .ps-blog-recent-posts .article-category span{
  font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--bmw-c-muted); font-weight:600;
}
main.article-page-type .ps-blog-recent-posts .article-category a{ color:var(--bmw-c-primary); text-decoration:none; }
main.article-page-type .ps-blog-recent-posts .article-title{ margin:0 0 12px; }
main.article-page-type .ps-blog-recent-posts .article-title a{
  font-family:var(--bmw-font-head); font-weight:600; font-size:20px; line-height:1.2;
  color:var(--bmw-c-ink); text-decoration:none; text-wrap:balance; transition:color .25s ease;
}
main.article-page-type .ps-blog-recent-posts .article-title a:hover{ color:var(--bmw-c-primary); }
main.article-page-type .ps-blog-recent-posts .item-body p{
  font-family:var(--bmw-font-body); font-size:15px; line-height:1.65; color:var(--bmw-c-ink-2); margin:0 0 16px;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}

/* ---- responsive ---- */
@media all and (max-width:1023.5px){
  main.article-page-type .article-body.rte{ margin-top:48px; }
  main.article-page-type .blog-author{ margin-top:24px; }
  main.article-page-type .ps-blog-recent-posts{ grid-template-columns:1fr; }
}
@media all and (max-width:640.5px){
  main.article-page-type .ps-blog-recent-posts .ps-article-img{ margin:-24px -24px 18px; }
}

/* ============================================================
   CONTACT PAGE — info cards + intake form + map  (bmw-)
   New classes only; reuses tokens + hero classes. CSS only.
   ============================================================ */
.bmw-contact-grid{ display:grid; grid-template-columns:0.92fr 1.18fr; gap:36px; align-items:start; }

/* ---- contact info cards ---- */
.bmw-info-col{ display:flex; flex-direction:column; gap:16px; }
.is-wrapper .bmw-info-card{
  display:flex; align-items:flex-start; gap:18px;
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card); padding:24px 26px;
  transition:transform .35s cubic-bezier(.2,.7,.2,1), box-shadow .35s ease, border-color .35s ease;
}
.is-wrapper .bmw-info-card:hover{ transform:translateY(-4px); box-shadow:var(--bmw-shadow-soft); border-color:var(--bmw-c-sage-mist); }
.bmw-info-ico{
  flex:0 0 auto; display:grid; place-items:center; width:50px; height:50px; border-radius:50%;
  background:var(--bmw-c-ivory-deep); color:var(--bmw-c-primary); font-size:19px;
  transition:background .35s ease, color .35s ease;
}
.is-wrapper .bmw-info-card:hover .bmw-info-ico{ background:var(--bmw-c-primary); color:#fff; }
.bmw-info-body{ display:flex; flex-direction:column; gap:5px; min-width:0; }
.bmw-info-label{ font-family:var(--bmw-font-body); font-size:12px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--bmw-c-muted); }
.bmw-info-value{ font-family:var(--bmw-font-head); font-weight:600; font-size:18px; line-height:1.35; color:var(--bmw-c-ink); word-break:break-word; text-decoration:none; transition:color .25s ease; }
a.bmw-info-value:hover{ color:var(--bmw-c-primary); }

/* ---- form card ---- */
.bmw-form-card{
  background:var(--bmw-c-paper); border:1px solid var(--bmw-c-line);
  border-radius:var(--bmw-r-lg); box-shadow:var(--bmw-shadow-card); padding:38px 38px 34px;
}
.bmw-form-intro{ margin:0 0 24px; }
.bmw-form-region{ margin:0; }

/* premium styling for the Webware form-template-3 injected inside the card */
.bmw-form-card .form-template-3 form{ border:0; margin:0; padding:0; }
.bmw-form-card .ww-form-container-3 form fieldset{ border:0; margin:0; padding:0; }
.bmw-form-card .form-container,
.bmw-form-card .ww-form-container-3 form > p,
.bmw-form-card .form-template-3 form fieldset > div{ width:100%; max-width:100%; margin:0 0 16px; padding:0; }
.bmw-form-card .ww-form-container-3 input[type="text"],
.bmw-form-card .ww-form-container-3 input[type="password"],
.bmw-form-card .ww-form-container-3 input[type="tel"],
.bmw-form-card .ww-form-container-3 input[type="email"],
.bmw-form-card .ww-form-container-3 select,
.bmw-form-card .ww-form-container-3 textarea{
  width:100%; min-height:52px; margin:0 0 4px; padding:12px 16px;
  background:var(--bmw-c-ivory-deep); border:1px solid var(--bmw-c-line); border-radius:var(--bmw-r-sm);
  font-family:var(--bmw-font-body); font-size:16px; color:var(--bmw-c-ink);
  transition:border-color .25s ease, box-shadow .25s ease, background .25s ease;
}
.bmw-form-card .ww-form-container-3 textarea{ min-height:130px; resize:vertical; }
.bmw-form-card .ww-form-container-3 input:focus,
.bmw-form-card .ww-form-container-3 select:focus,
.bmw-form-card .ww-form-container-3 textarea:focus{
  outline:0; background:var(--bmw-c-paper); border-color:var(--bmw-c-sage-mist);
  box-shadow:0 0 0 4px rgba(169,194,204,.28);
}
.bmw-form-card .ww-form-container-3 label{ font-family:var(--bmw-font-body); font-size:14px; font-weight:600; color:var(--bmw-c-ink-2); }
.bmw-form-card .ww-form-container-3 input[type="submit"],
.bmw-form-card .ww-form-container-3 button,
.bmw-form-card .form-template-3 .button{
  display:inline-block; width:auto; margin-top:6px; padding:14px 40px; cursor:pointer;
  background:var(--bmw-c-primary); color:#fff; border:1px solid var(--bmw-c-primary);
  border-radius:var(--bmw-r-pill); font-family:var(--bmw-font-body); font-size:15px; font-weight:700; letter-spacing:.04em;
  transition:background .3s ease, border-color .3s ease, transform .3s ease, box-shadow .3s ease;
}
.bmw-form-card .ww-form-container-3 input[type="submit"]:hover,
.bmw-form-card .ww-form-container-3 button:hover,
.bmw-form-card .form-template-3 .button:hover{
  background:var(--bmw-c-primary-dark); border-color:var(--bmw-c-primary-dark);
  transform:translateY(-2px); box-shadow:var(--bmw-shadow-soft);
}

/* ---- map ---- */
.bmw-map-embed{
  position:relative; width:100%; height:460px; overflow:hidden;
  border-radius:var(--bmw-r-lg); border:1px solid var(--bmw-c-line); box-shadow:var(--bmw-shadow-soft);
}
.bmw-map-frame{ position:absolute; inset:0; width:100%; height:100%; border:0; display:block; filter:saturate(.92); }
.bmw-map-tag{
  position:absolute; left:24px; bottom:24px; z-index:2; display:inline-flex; align-items:center; gap:12px;
  max-width:calc(100% - 48px); padding:14px 20px; text-decoration:none;
  background:rgba(255,255,255,.92); -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border:1px solid var(--bmw-c-line); border-radius:var(--bmw-r-md); box-shadow:var(--bmw-shadow-card);
  transition:transform .3s ease, box-shadow .3s ease;
}
.bmw-map-tag:hover{ transform:translateY(-3px); box-shadow:var(--bmw-shadow-soft); }
.bmw-map-tag-ico{ flex:0 0 auto; display:grid; place-items:center; width:38px; height:38px; border-radius:50%; background:var(--bmw-c-primary); color:#fff; font-size:15px; }
.bmw-map-tag-txt{ font-family:var(--bmw-font-head); font-weight:600; font-size:16px; line-height:1.3; color:var(--bmw-c-ink); }

/* ---- responsive ---- */
@media all and (max-width:1023.5px){
  .bmw-contact-grid{ grid-template-columns:1fr; gap:26px; }
  .bmw-form-card{ padding:30px 26px; }
  .bmw-map-embed{ height:380px; }
}
@media all and (max-width:640.5px){
  .is-wrapper .bmw-info-card{ padding:20px 20px; gap:14px; }
  .bmw-form-card{ padding:24px 20px; }
  .bmw-map-embed{ height:320px; }
  .bmw-map-tag{ left:14px; bottom:14px; padding:11px 15px; }
  .bmw-map-tag-txt{ font-size:14px; }
}

input#Submit, .new-website-login-form form.settings input.button.ps-login-button, .signup-container input.button.ps-register-button{
        border-radius: var(--bmw-r-pill) !important;
    }
    input#mob_phone_phone_number_tel {
    background: var(--bmw-c-ivory-deep) !important;
    border: 1px solid var(--bmw-c-line) !important;
    border-radius: var(--bmw-r-sm) !important;
}
input#mob_phone_phone_number_tel::placeholder {
    padding-left: 30px !important;
}

@media screen and (max-width:1023.5px){
    .inner-banner.blog-banner{
    position: relative;
    text-align: center;
    justify-content: center;
    padding: 40px;
}
    }