/* =========================================================
   Maple & May — redesigned header & footer
   Ported from the prototype (prototypes/new-homes). Scoped to
   .site-header / .site-footer so it cannot disturb app.css or
   the Foundation grid. Uses .mm-container (not .container) for
   the same reason.
   ========================================================= */

:root {
    --mm-dark:        #455560;  /* Dark Grey */
    --mm-dark-2:      #283035;  /* secondary/Black */
    --mm-cream:       #E6DFD5;  /* Linen */
    --mm-tan:         #AA9678;  /* Wheat */
    --mm-soft-wheat:  #C1B199;  /* Soft Wheat */
    --mm-white:       #ffffff;

    --mm-font-head: 'Montserrat', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --mm-font-body: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

    --mm-label:   600 16px/24px var(--mm-font-head);  /* Montserrat SemiBold */
    --mm-h-sm:    700 20px/28px var(--mm-font-head);  /* Desktop/Small — matches --type-desktop-sm */
    --mm-body:    400 16px/24px var(--mm-font-body);  /* Open Sans */
    --mm-small:   400 12px/20px var(--mm-font-body);  /* Open Sans small */
}

/* Self-contained resets (so app.css cannot bleed in) */
.site-header, .site-header *,
.site-footer, .site-footer * { box-sizing: border-box; }
.site-header ul, .site-footer ul { list-style: none; margin: 0; padding: 0; }
.site-header li, .site-footer li { margin: 0; }
.site-header a, .site-footer a { text-decoration: none; }
.site-header img, .site-footer img { max-width: 100%; display: block; }

.mm-container {
    box-sizing: border-box;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* ---------- Header ---------- */
.site-header { background: var(--mm-dark); color: var(--mm-white); position: sticky; top: 0; z-index: 100; margin: 0; padding: 0; border: 0; box-shadow: none; overflow: visible; }
.site-header__inner { display: flex; align-items: center; justify-content: space-between; height: 120px; gap: 1rem; }
.site-header__logo { display: inline-flex; align-items: center; }
.site-header__logo img { height: 62px; width: auto; }
.site-header__toggle { display: flex; flex-direction: column; justify-content: space-between; width: 48px; height: 48px; padding: 12px 8px; background: transparent; border: none; cursor: pointer; }
.site-header__toggle span { display: block; height: 3px; background: var(--mm-tan); border-radius: 2px; }
.site-header__nav { display: none; margin: 0 auto; }
.site-header__nav ul { display: flex; align-items: stretch; gap: 10px; }
.site-header__nav a { display: inline-flex; align-items: center; height: 120px; padding: 9px 17px; font: var(--mm-label); color: var(--mm-white); border-bottom: 3px solid transparent; transition: background 0.15s ease; }
.site-header__nav a:hover { background: rgba(255,255,255,0.06); border-bottom-color: var(--mm-tan); text-decoration: none; }
.site-header__nav a.is-active { background: rgba(255,255,255,0.06); border-bottom-color: var(--mm-tan); }
.site-header__nav-toggle { display: inline-flex; align-items: center; height: 120px; padding: 9px 17px; font: var(--mm-label); color: var(--mm-white); background: transparent; border: none; border-bottom: 3px solid transparent; cursor: pointer; transition: background 0.15s ease; }
.site-header__nav-toggle:hover { background: rgba(255,255,255,0.06); border-bottom-color: var(--mm-tan); }
.site-header__nav.is-open { display: block; position: absolute; top: 100%; left: 0; right: 0; background: var(--mm-dark-2); }
.site-header__nav.is-open ul { flex-direction: column; gap: 0; }
.site-header__nav.is-open a { height: auto; padding: 1rem 20px; border-top: 1px solid rgba(255,255,255,0.08); border-bottom: none; }

/* Safety overrides — beat any id-scoped app.css nav rules (header is inside #container) */
#container .site-header { overflow: visible; }
#container .site-header__toggle { display: flex; }
#container .site-header__nav { display: none; position: static; background: none; }
#container .site-header__nav ul { display: flex; flex-direction: column; gap: 0; }
#container .site-header__nav.is-open { display: block; position: absolute; top: 100%; left: 0; right: 0; background: var(--mm-dark-2); z-index: 100; }
#container .site-header__nav a { display: flex; align-items: flex-end; height: auto; padding: 1rem 20px; font: var(--mm-label); border-bottom: 3px solid transparent; border-top: 1px solid rgba(255,255,255,0.08); text-decoration: none; }
#container .site-header__nav a:hover { border-bottom-color: var(--mm-tan); background: var(--mm-dark-2); }
#container .site-header__nav a.is-active { background: var(--mm-dark-2); border-bottom-color: var(--mm-tan); font-weight: 700; }
#container .site-header__nav-toggle { display: flex; align-items: flex-end; width: 100%; height: auto; padding: 1rem 20px; font: var(--mm-label); color: var(--mm-white); background: transparent; border: none; border-bottom: 3px solid transparent; border-top: 1px solid rgba(255,255,255,0.08); cursor: pointer; text-align: left; }
#container .site-header__nav-toggle:hover { border-bottom-color: var(--mm-tan); background: var(--mm-dark-2); }

@media (min-width: 768px) {
    #container .site-header__toggle { display: none; }
    #container .site-header__nav { display: block; position: static; background: none; }
    #container .site-header__nav ul { flex-direction: row; gap: 10px; }
    #container .site-header__nav a { height: 120px; padding: 9px 10px 30px 10px; border-top: 0; }
    #container .site-header__nav-toggle { height: 120px; padding: 9px 10px 30px 10px; border-top: 0; }

    /* Desktop submenu behavior: reveal nested menus on hover/focus */
    #container .site-header__nav > ul > li { position: relative; }
    #container .site-header__nav > ul > li > ul {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        min-width: 240px;
        width: max-content;
        background: transparent;
        z-index: 200;
        padding: 0;
        box-shadow: none;
    }
    #container .site-header__nav > ul > li:hover > ul,
    #container .site-header__nav > ul > li:focus-within > ul {
        display: flex;
        flex-direction: column;
        gap: 2px;
    }
    #container .site-header__nav > ul > li > ul > li > a {
        height: 60px;
        align-items: center;
        padding: 0 10px;
        background: rgb(69 85 96 / 0.98);   /* #455560 @ 98% — brand Dark Grey */
        font: var(--mm-body);
        border-top: 0;
        border-bottom: 3px solid transparent;
        white-space: nowrap;
    }
    #container .site-header__submenu a:hover { background: var(--mm-dark-2); border-bottom-color: var(--mm-tan); }
    #container .site-header__submenu .icon--chevron-right { color: var(--mm-tan); }

    /* When a submenu item is hovered, apply the same hover style to the parent toggle */
    #container .site-header__nav > ul > li:has(.site-header__submenu a:hover) > .site-header__nav-toggle {
        border-bottom-color: var(--mm-tan);
        background: var(--mm-dark-2);
    }
}

/* ---------- Footer ---------- */
.site-footer { background: var(--mm-dark); color: var(--mm-white); padding: 72px 0 0; font: var(--mm-body); }
.site-footer h4 { font: var(--mm-h-sm); color: var(--mm-white); margin: 0 0 16px; }
.site-footer a { color: var(--mm-white); }
.site-footer a:hover { text-decoration: underline; }
.site-footer__grid { display: grid; grid-template-columns: 1fr; gap: 32px; padding-bottom: 32px; }
.site-footer__brand { display: flex; flex-direction: column; gap: 24px; }
.site-footer__brand-lockup { display: flex; align-items: center; gap: 16px; }
.site-footer__brand-lockup img { height: 68px; width: auto; }
.site-footer__strapline { display: flex; flex-direction: column; font: 400 26px/1.15 var(--mm-font-head); color: var(--mm-white); border-left: 1px solid rgba(255,255,255,0.35); padding-left: 16px; }
.site-footer__address { margin: 30px 0 0 28px; }
.site-footer__address p { font: var(--mm-body); color: var(--mm-white); margin: 0; }
.site-footer__links ul { display: flex; flex-direction: column; gap: 16px; }
.site-footer__links a { font: var(--mm-small); }
.site-footer__social { display: flex; gap: 8px; margin: 0 0 16px; }
.site-footer__social a { display: inline-flex; align-items: center; justify-content: center; width: 42px; height: 42px; background: var(--mm-white); color: var(--mm-dark); border-radius: 50%; }
.site-footer__social svg { width: 28px; height: 28px; }
.site-footer__contact { display: flex; flex-direction: column; gap: 16px; }
.site-footer__contact p { margin: 0; font: var(--mm-label); color: var(--mm-white); }
.site-footer__contact p a { font: var(--mm-label); }
.site-footer__copy { padding: 0 0 40px; text-align: center; font: var(--mm-small); color: var(--mm-white); }
.site-footer__copy p { margin: 0; }

/* --------------------------------------------------------
   Suppress pink text colour on M&M button hover.
   app.css sets  a:hover, a:focus { color: #cb0078 }  which
   has specificity (0,1,1) and beats any plain class rule
   (0,1,0).  Prefixing with #container raises these rules
   to (1,2,1) so they always win.
   Covers every anchor-based button pattern used in M&M
   templates: .btn (and --rect / --block variants),
   .register__btn, .btn-eligibility, .brochure-card.
   -------------------------------------------------------- */
#container a.btn:hover,
#container a.btn:focus,
#container a.register__btn:hover,
#container a.register__btn:focus,
#container a.btn-eligibility:hover,
#container a.btn-eligibility:focus,
#container a.brochure-card:hover,
#container a.brochure-card:focus { color: var(--mm-white); }

/* ---------- Tablet / Desktop ---------- */
@media (min-width: 768px) {
    .site-header__toggle { display: none; }
    .site-header__nav { display: block; }
    .site-header__nav ul { flex-direction: row; }

    .site-footer__grid { grid-template-columns: 1.4fr 1fr 1fr; gap: 37px; }
    .site-footer__links, .site-footer__contact { position: relative; padding-left: 37px; }
    .site-footer__links::before, .site-footer__contact::before {
        content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 2px; background: var(--mm-cream);
    }
}
