/* === Variables — update with client brand colors === */
:root {
    --color-primary:   #064164;
    --color-accent:    #068D4D;
    --color-bg:        #ffffff;
    --color-text:      #333333;
    --color-muted:     #666666;
    --color-border:    #e0e0e0;
    --color-header-bg: #064164;
    --font-base:       'Georgia', serif;
    --font-heading:    'IBM Plex Sans', sans-serif;
    --container-width: 1100px;
    --spacing-unit:    1rem;
    --noise: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");
}

/* === Reset === */
*, *::before, *::after { box-sizing: border-box; }
body   { margin: 0; font-family: var(--font-base); color: var(--color-text); background: var(--color-bg); line-height: 1.6; }
img    { max-width: 100%; height: auto; display: block; }
a      { color: var(--color-primary); }
a:hover { text-decoration: underline; }

/* === Layout === */
.container {
    max-width: var(--container-width);
    margin-inline: auto;
    padding-inline: 1.25rem;
}

/* === Header === */
.site-header {
    background: var(--color-header-bg);
    background-image: var(--noise), linear-gradient(135deg, rgba(255,255,255,.05) 0%, transparent 60%);
    background-blend-mode: overlay, normal;
    border-bottom: 1px solid rgba(255,255,255,.07);
    box-shadow: 0 1px 0 rgba(255,255,255,.05) inset, 0 2px 10px rgba(0,0,0,.25);
    position: sticky;
    top: 0;
    z-index: 600;
}

.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 1rem;
}

.site-logo-link { display: inline-flex; align-items: center; text-decoration: none; }

.site-logo {
    height: 70px;
    width: auto;
    display: block;
    filter: brightness(0) invert(1);
}

.site-title {
    font-family: 'IBM Plex Sans', sans-serif;
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    text-decoration: none;
}

.site-header .custom-logo { max-height: 50px; width: auto; filter: brightness(0) invert(1); }

/* === Navigation === */
.nav-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0.5rem;
    flex-direction: column;
    gap: 5px;
}

.nav-toggle__bar {
    display: block;
    width: 24px;
    height: 2px;
    background: #fff;
    border-radius: 2px;
    transition: transform 0.28s ease, opacity 0.18s ease;
    transform-origin: center;
}

/* sr-only is :nth-child(1), bars are 2/3/4 */
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(2) {
    transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(3) {
    opacity: 0;
    transform: scaleX(0);
}
.nav-toggle[aria-expanded="true"] .nav-toggle__bar:nth-child(4) {
    transform: translateY(-7px) rotate(-45deg);
}

.nav-menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 0;
}

.nav-menu > li > a {
    display: block;
    padding: 1rem 0.875rem;
    font-family: var(--font-heading);
    font-size: 13px;
    font-weight: 500;
    color: rgba(255,255,255,.7);
    text-decoration: none;
    letter-spacing: 0.04em;
    white-space: nowrap;
}

.nav-menu > li > a:hover,
.nav-menu > li.current-menu-item > a,
.nav-menu > li.current-menu-ancestor > a {
    color: #fff;
    text-decoration: none;
}

/* Dropdowns */
.nav-menu .menu-item-has-children { position: relative; }

.nav-menu .sub-menu {
    list-style: none;
    margin: 0;
    padding: 0.5rem 0;
    position: absolute;
    top: 100%;
    left: 0;
    background: #032d47;
    border: 1px solid rgba(255,255,255,.1);
    border-top: 2px solid rgba(90,219,160,.4);
    min-width: 200px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
    display: none;
    z-index: 200;
}

.nav-menu .menu-item-has-children:hover .sub-menu { display: block; }

.nav-menu .sub-menu a {
    display: block;
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: rgba(255,255,255,.75);
    text-decoration: none;
}

.nav-menu .sub-menu a:hover { background: rgba(255,255,255,.07); color: #fff; }

/* === Beebox Banner === */
.beebox-banner {
    background: var(--color-accent);
    color: #fff;
    text-align: center;
    padding: 0.75rem 1rem;
}

.beebox-banner p { margin: 0 0 0.5rem; font-weight: 600; }

.btn {
    display: inline-block;
    padding: 0.5rem 1.25rem;
    border-radius: 4px;
    font-weight: 700;
    text-decoration: none;
    font-size: 0.9rem;
    cursor: pointer;
    border: 2px solid transparent;
}

.btn-primary {
    background: var(--color-primary);
    color: #fff;
    border-color: var(--color-primary);
}

.btn-primary:hover { opacity: 0.9; text-decoration: none; }

/* === Page content === */
.page-title {
    font-family: var(--font-heading);
    color: var(--color-primary);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    margin-block: 1.5rem 1rem;
    border-bottom: 2px solid var(--color-accent);
    padding-bottom: 0.5rem;
}

.page-content { max-width: 72ch; }

main.container { padding-block: 2rem; min-height: 60vh; }

/* === Sponsor Banner === */
.sponsor-banner {
    overflow: hidden;
    background: #f5f7fa;
    border-top: 2px solid var(--color-border);
    padding: 2.5rem 0 3rem;
}

.sponsor-banner__heading {
    text-align: center;
    font-size: 1.25rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-primary);
    margin: 0 0 2rem;
    padding: 0 1rem;
}

/* Desktop: scrolling ticker */
.sponsor-banner__track {
    display: flex;
    align-items: stretch;
    gap: 1.25rem;
    animation: sponsor-scroll 55s linear infinite;
    width: max-content;
}

.sponsor-banner:hover .sponsor-banner__track { animation-play-state: paused; }

.sponsor-banner__item {
    flex-shrink: 0;
    background: #fff;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.07);
    padding: 1.5rem 2.5rem;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 180px;
    height: 140px;
}

.sponsor-banner__item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.sponsor-banner__item img {
    height: 96px;
    width: auto;
    max-width: 220px;
    object-fit: contain;
    display: block;
}

.sponsor-banner__name {
    font-size: 0.85rem;
    font-weight: 600;
    color: var(--color-muted);
    text-align: center;
}

@keyframes sponsor-scroll {
    0%   { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}

/* Mobile: static grid, no scroll */
@media (max-width: 640px) {
    .sponsor-banner {
        overflow: visible;
        padding: 2rem 1rem 2.5rem;
    }

    .sponsor-banner__heading {
        font-size: 1rem;
        margin-bottom: 1.5rem;
    }

    .sponsor-banner__track {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 0.75rem;
        width: 100%;
        animation: none;
    }

    .sponsor-banner__item[aria-hidden="true"] {
        display: none;
    }

    .sponsor-banner__item {
        min-width: 0;
        height: 100px;
        padding: 1rem;
    }

    .sponsor-banner__item img {
        height: 64px;
        max-width: 100%;
    }

    .sponsor-banner__name {
        font-size: 0.8rem;
        white-space: normal;
    }
}

/* === Footer === */
.site-footer {
    background: var(--color-primary);
    color: rgba(255,255,255,0.85);
    text-align: center;
    padding: 1.5rem 1rem;
    font-size: 0.85rem;
}

.site-footer a { color: rgba(255,255,255,0.85); }

/* === Utility === */
.sr-only {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

/* === Responsive === */
@media (max-width: 767px) {
    .nav-toggle { display: flex; }

    /* Full-screen overlay — sits below header (z-index 600) */
    .nav-menu {
        display: none;
        position: fixed;
        inset: 0;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 0;
        background: #032d47;
        z-index: 500;
        padding: 2rem 1.5rem;
        overflow-y: auto;
    }

    .nav-menu.is-open { display: flex; }

    .nav-menu > li {
        width: 100%;
        max-width: 380px;
        text-align: center;
    }

    .nav-menu > li > a {
        display: block;
        font-size: 2.2rem;
        font-weight: 700;
        letter-spacing: 0.02em;
        text-align: center;
        padding: 1.1rem 0;
        color: rgba(255,255,255,.82);
        border-bottom: 1px solid rgba(255,255,255,.1);
        white-space: normal;
    }

    .nav-menu > li:first-child > a { border-top: 1px solid rgba(255,255,255,.1); }

    .nav-menu > li > a:hover,
    .nav-menu > li.current-menu-item > a,
    .nav-menu > li.current-menu-ancestor > a {
        color: #fff;
    }

    .nav-menu .sub-menu {
        position: static;
        border: none;
        box-shadow: none;
        background: rgba(0,0,0,.18);
        display: none;
        padding: 0;
    }

    .nav-menu .menu-item-has-children.submenu-open .sub-menu { display: block; }
    .nav-menu .menu-item-has-children:hover .sub-menu { display: none; }

    .nav-menu .sub-menu li { text-align: center; }
    .nav-menu .sub-menu a {
        padding: 0.75rem 0;
        font-size: 1.1rem;
        text-align: center;
    }
}

/* === WPForms: purchase-item row polish === */

/* Inputs fill their column — default 60% max-width is too narrow at ¼-width */
div.wpforms-container-full .wpforms-form .wpforms-field.wpforms-one-fourth input,
div.wpforms-container-full .wpforms-form .wpforms-field.wpforms-one-fourth select,
div.wpforms-container-full .wpforms-form .wpforms-field.wpforms-one-fourth .wpforms-datepicker-wrap input {
    max-width: 100% !important;
    width: 100%;
    box-sizing: border-box;
}

/* Row-group separators between purchase items #2-5.
   The ~ combinator targets .wpforms-first only when a .wpforms-one-fourth
   sibling precedes it, leaving purchase item #1 (field_38) untouched. */
div.wpforms-container-full .wpforms-form
.wpforms-field.wpforms-one-fourth ~ .wpforms-field.wpforms-one-fourth.wpforms-first {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(6, 65, 100, 0.15);
}

