/* =========================================
   EDDERTON SCOTT HEADER STYLES
   ========================================= */

#es-header-root, #es-drawer {
    --es-bg:        #F8F8F8;
    --es-panel:     #f4f4f2;
    --es-border:    #e0e0e0;
    --es-text:      #1a1a1a;
    --es-grey-text: #5a5a5a;
    --es-grey-label:#999999;
    --es-font-body: 'Urbanist', sans-serif;
    --es-font-head: 'Syne', sans-serif;
    --es-width:     1280px;
    --logo-height:  18px;
    --es-t-fast:    0.15s;
    --es-t-base:    0.25s;
    --es-t-ease:    cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

#es-header-root *, #es-header-root *::before, #es-header-root *::after,
#es-drawer *, #es-drawer *::before, #es-drawer *::after {
    box-sizing: border-box !important;
}

/* ---- HEADER CONTAINER ---- */
#es-header-root {
    width: 100%;
    background: rgba(250, 250, 248, 0.85);
    backdrop-filter: blur(12px) saturate(1.4);
    -webkit-backdrop-filter: blur(12px) saturate(1.4);
    font-family: var(--es-font-body);
    line-height: 1.5;
    border-bottom: 1px solid var(--es-border);
    position: sticky;
    top: 0;
    z-index: 99999;
    transition: background var(--es-t-base), box-shadow var(--es-t-base);
}

#es-header-root.scrolled {
    background: rgba(250, 250, 248, 0.96);
    box-shadow: 0 1px 24px rgba(0,0,0,0.06);
}

#es-header-root ul, #es-header-root li {
    margin: 0 !important; padding: 0 !important; list-style: none !important;
}

#es-header-root a {
    text-decoration: none !important;
    color: inherit !important;
    transition: opacity var(--es-t-fast);
}

#es-header-root button {
    background: none !important; border: none !important; padding: 0 !important; cursor: pointer;
}

/* ---- INNER CONTAINER ---- */
.es-header-inner {
    max-width: var(--es-width);
    margin: 0 auto;
    padding: 0 24px;
    height: 72px;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    position: relative !important;
}

/* ---- LOGO ---- */
.es-logo img {
    height: var(--logo-height) !important;
    width: auto !important;
    display: block !important;
    transition: opacity var(--es-t-fast);
}
.es-logo:hover img { opacity: 0.7 !important; }

/* ---- DESKTOP NAV ---- */
.es-nav {
    display: flex !important;
    height: 100%;
    align-items: center;
    gap: 0;
}

.es-item {
    height: 100%;
    display: flex;
    align-items: center;
    padding: 0 18px;
    position: static !important;
    cursor: default !important;
}

.es-item .es-link { cursor: pointer !important; }

.es-link {
    font-size: 14px;
    font-weight: 600;
    color: var(--es-text) !important;
    letter-spacing: 0.02em;
    position: relative;
    opacity: 0.75;
    display: flex;
    align-items: center;
    transition: opacity var(--es-t-fast) !important;
}

.es-item:hover .es-link { opacity: 1; }

/* HOME ICON */
.es-home-icon {
    font-size: 18px;
    display: block;
}

/* ---- CTA BUTTONS ---- */
.es-nav-cta {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    margin-left: 16px !important;
}

/* Override blanket anchor colour rule for secondary button */
#es-header-root a.es-btn-secondary,
#es-drawer a.es-btn-secondary,
a.es-btn-secondary {
    color: var(--es-bg) !important;
}

.es-btn-secondary {
    background: var(--es-text) !important;
    color: var(--es-bg) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    padding: 10px 20px !important;
    border-radius: 0 !important;
    display: inline-block !important;
    transition: background var(--es-t-fast), color var(--es-t-fast), border-color var(--es-t-fast), transform var(--es-t-base) var(--es-t-ease), box-shadow var(--es-t-base) var(--es-t-ease) !important;
    border: 1px solid var(--es-text) !important;
    cursor: pointer !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

.es-btn-secondary:hover,
#es-header-root a.es-btn-secondary:hover,
#es-drawer a.es-btn-secondary:hover,
a.es-btn-secondary:hover {
    background: transparent !important;
    border-color: var(--es-text) !important;
    color: var(--es-text) !important;
    opacity: 1 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.08) !important;
}

.es-btn-primary {
    background: transparent !important;
    color: var(--es-text) !important;
    font-weight: 700 !important;
    font-size: 13px !important;
    padding: 10px 20px !important;
    border-radius: 0 !important;
    display: inline-block !important;
    transition: background var(--es-t-fast), color var(--es-t-fast), transform var(--es-t-base) var(--es-t-ease), box-shadow var(--es-t-base) var(--es-t-ease) !important;
    border: 1px solid var(--es-text) !important;
    cursor: pointer !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    letter-spacing: 0.06em !important;
    text-transform: uppercase !important;
}

#es-header-root .es-btn-primary:hover {
    background: var(--es-text) !important;
    color: var(--es-bg) !important;
    opacity: 1 !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 14px rgba(0,0,0,0.08) !important;
    text-decoration: none !important;
}

/* ---- MEGA MENU ---- */
.es-mega {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--es-bg);
    border: 1px solid var(--es-border);
    border-top: none;
    display: grid;
    grid-template-columns: 280px repeat(3, 1fr);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(6px);
    transition: opacity var(--es-t-base) var(--es-t-ease),
                transform var(--es-t-base) var(--es-t-ease),
                visibility var(--es-t-base);
    box-shadow: 0 24px 60px rgba(0,0,0,0.08);
    z-index: 1000;
    cursor: default !important;
}

.es-item:nth-child(5) .es-mega { grid-template-columns: 280px 1fr 1fr; }

.es-item:hover .es-mega {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}

/* Stagger column reveal */
.es-item:hover .es-mega > *:nth-child(1) { transition-delay: 0ms; }
.es-item:hover .es-mega > *:nth-child(2) { transition-delay: 30ms; }
.es-item:hover .es-mega > *:nth-child(3) { transition-delay: 60ms; }
.es-item:hover .es-mega > *:nth-child(4) { transition-delay: 90ms; }

.es-mega-panel {
    background: var(--es-panel);
    padding: 36px 28px;
    border-right: 1px solid var(--es-border);
    display: flex;
    flex-direction: column;
    cursor: default !important;
}

.es-panel-head {
    font-family: var(--es-font-head);
    font-size: 18px;
    color: var(--es-text);
    margin-bottom: 10px !important;
    font-weight: 700;
    letter-spacing: -0.01em;
}

.es-panel-desc {
    font-size: 14px;
    color: var(--es-grey-text) !important;
    line-height: 1.65;
    margin-bottom: 20px !important;
}

.es-panel-link {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    border-bottom: 1px solid var(--es-text);
    padding-bottom: 2px;
    align-self: flex-start;
    color: var(--es-text) !important;
    cursor: pointer !important;
    transition: opacity var(--es-t-fast) !important;
}
.es-panel-link:hover { opacity: 0.6 !important; }

.es-mega-col {
    padding: 36px 28px;
    border-left: 1px solid var(--es-border);
    cursor: default !important;
}

.es-col-title {
    display: block;
    font-family: var(--es-font-head);
    font-size: 11px;
    color: var(--es-grey-label) !important;
    margin-bottom: 18px !important;
    text-transform: uppercase;
    font-weight: 700;
    letter-spacing: 0.1em;
    cursor: default !important;
}

.es-mega-col ul li { margin-bottom: 10px !important; }

.es-mega-col a {
    font-size: 15px;
    font-weight: 500;
    color: var(--es-text) !important;
    display: block;
    cursor: pointer !important;
    transition: opacity var(--es-t-fast), transform var(--es-t-base) var(--es-t-ease) !important;
}

.es-mega-col a:hover {
    opacity: 0.6 !important;
    transform: translateX(3px);
}

/* ---- BURGER ---- */
.es-burger {
    display: none;
    color: var(--es-text);
    font-size: 22px;
    padding: 10px;
    cursor: pointer !important;
}

/* ---- MOBILE DRAWER ---- */
#es-drawer {
    position: fixed;
    top: 0;
    right: -100%;
    width: 100%;
    max-width: 420px;
    height: 100vh;
    background: var(--es-bg);
    z-index: 9999999;
    transition: right 0.38s cubic-bezier(0.22, 1, 0.36, 1);
    padding: 0;
    display: flex;
    flex-direction: column;
    box-shadow: -20px 0 60px rgba(0,0,0,0.08);
}

body.admin-bar #es-drawer { top: 32px; height: calc(100vh - 32px); }
@media screen and (max-width: 782px) {
    body.admin-bar #es-drawer { top: 46px; height: calc(100vh - 46px); }
}

#es-drawer.open { right: 0; }

.es-drawer-header {
    height: 72px;
    padding: 0 24px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid var(--es-border);
    flex-shrink: 0;
}

.es-drawer-close {
    font-size: 28px;
    color: var(--es-text);
    background: none;
    border: none;
    cursor: pointer !important;
    opacity: 0.5;
    transition: opacity var(--es-t-fast);
    line-height: 1;
    padding: 4px !important;
}
.es-drawer-close:hover { opacity: 1; }

.es-drawer-scroll {
    flex: 1;
    overflow-y: auto;
    padding: 12px 24px 40px 24px;
}

.es-mob-item { border-top: 1px solid var(--es-border); }
.es-mob-item:first-child { border-top: none; }

.es-mob-main {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 16px 0;
    width: 100%;
    font-family: var(--es-font-body);
    font-size: 16px;
    color: var(--es-text) !important;
    font-weight: 600;
    background: none;
    border: none;
    cursor: pointer !important;
    min-height: 56px;
}

.es-mob-toggle {
    width: 28px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--es-border);
    border-radius: 50%;
    font-size: 16px;
    color: var(--es-grey-label);
    transition: transform var(--es-t-base) var(--es-t-ease), border-color var(--es-t-fast), color var(--es-t-fast);
    flex-shrink: 0;
}

.es-mob-toggle.open {
    transform: rotate(45deg);
    border-color: var(--es-text);
    color: var(--es-text);
}

.es-mob-submenu {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.35s var(--es-t-ease);
    padding-left: 8px;
}

.es-mob-submenu.open { max-height: 1000px; }

.es-mob-link {
    display: block;
    font-family: var(--es-font-body);
    font-size: 15px;
    color: var(--es-grey-text) !important;
    padding: 10px 12px;
    font-weight: 400;
    transition: color var(--es-t-fast), padding-left var(--es-t-base) var(--es-t-ease) !important;
    cursor: pointer !important;
    min-height: 44px;
    display: flex;
    align-items: center;
}

.es-mob-link:hover {
    color: var(--es-text) !important;
    padding-left: 18px !important;
}

.es-mob-group-label {
    font-family: var(--es-font-body);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--es-grey-label);
    margin: 14px 0 6px 0;
    font-weight: 700;
    display: block;
    padding-left: 12px;
    cursor: default !important;
}

.es-mob-cta-container {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-top: 32px;
    padding-top: 32px;
    border-top: 1px solid var(--es-border);
}

/* Override blanket anchor colour for mobile secondary button */
#es-drawer a.es-mob-cta-secondary,
a.es-mob-cta-secondary {
    color: var(--es-bg) !important;
}

.es-mob-cta-secondary {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: var(--es-text) !important;
    color: var(--es-bg) !important;
    text-align: center;
    padding: 16px !important;
    font-weight: 700;
    font-size: 13px;
    border-radius: 0;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    transition: background var(--es-t-fast), color var(--es-t-fast), border-color var(--es-t-fast) !important;
    border: 1px solid var(--es-text) !important;
    cursor: pointer !important;
    text-decoration: none !important;
    min-height: 52px;
}

.es-mob-cta-secondary:hover,
#es-drawer a.es-mob-cta-secondary:hover,
a.es-mob-cta-secondary:hover {
    background: transparent !important;
    border-color: var(--es-text) !important;
    color: var(--es-text) !important;
}

.es-mob-cta-primary {
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: transparent !important;
    color: var(--es-text) !important;
    text-align: center;
    padding: 16px !important;
    font-weight: 700;
    font-size: 13px;
    border-radius: 0;
    text-transform: uppercase;
    letter-spacing: 0.07em;
    transition: background var(--es-t-fast), color var(--es-t-fast) !important;
    border: 1px solid var(--es-text) !important;
    cursor: pointer !important;
    text-decoration: none !important;
    min-height: 52px;
}

.es-mob-cta-primary:hover {
    background: var(--es-text) !important;
    color: var(--es-bg) !important;
}

/* ---- SCROLL BEHAVIOUR (JS adds .scrolled) ---- */
/* handled above in #es-header-root.scrolled */

/* ---- BREAKPOINT ---- */
@media (max-width: 1100px) {
    .es-nav { display: none !important; }
    .es-burger { display: block !important; }
    .es-header-inner { height: 64px; }
}