:root {
    --svf-blue: #4A90E2;
    --svf-navy: #0D2D62;
    --svf-ink: #102033;
    --svf-muted: #5d6b7c;
    --svf-sky: #eef6ff;
    --svf-line: #dbe7f5;
    --svf-gold: #ffc857;
    --svf-mist: #f2f7fb;
    --svf-card: #fbfdff;
    --svf-radius: 8px;
    --svf-shadow: 0 18px 45px rgba(13, 45, 98, 0.12);
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    background: var(--svf-mist);
    color: var(--svf-ink);
    font-family: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    line-height: 1.65;
}

a {
    color: var(--svf-navy);
    text-decoration: none;
}

a:hover {
    color: var(--svf-blue);
}

.skip-link {
    background: var(--svf-navy);
    color: #fff;
    left: 1rem;
    padding: .75rem 1rem;
    position: absolute;
    top: -4rem;
    z-index: 2000;
}

.skip-link:focus {
    top: 1rem;
}

.site-header {
    background: rgba(255, 255, 255, 0.96);
    border-bottom: 1px solid rgba(13, 45, 98, 0.08);
    backdrop-filter: blur(12px);
    transition: background .25s ease, border-color .25s ease, box-shadow .25s ease;
}

.site-header-home {
    background: transparent;
    border-bottom-color: transparent;
    left: 0;
    position: fixed;
    right: 0;
    top: 0;
    z-index: 1030;
}

.site-header-home.is-scrolled {
    background: rgba(255, 255, 255, 0.96);
    border-bottom-color: rgba(13, 45, 98, 0.08);
    box-shadow: 0 10px 30px rgba(13, 45, 98, .08);
}

.site-header-home:not(.is-scrolled) .nav-link {
    color: rgba(255, 255, 255, .92);
}

.site-header-home:not(.is-scrolled) .nav-link.active,
.site-header-home:not(.is-scrolled) .nav-link:hover {
    background: rgba(255, 255, 255, .16);
    color: #fff;
}

.site-header-home:not(.is-scrolled) .navbar-toggler {
    background: rgba(255, 255, 255, .9);
}

.navbar {
    padding: .8rem 0;
}

.navbar-brand img {
    display: block;
    height: 58px;
    width: auto;
}

.nav-link {
    border-radius: 999px;
    color: var(--svf-ink);
    font-size: .92rem;
    font-weight: 700;
    padding: .55rem .9rem !important;
}

.nav-link.active,
.nav-link:hover {
    background: var(--svf-sky);
    color: var(--svf-navy);
}

.nav-link.registry-portal-link {
    color: var(--svf-blue);
    font-weight: 800;
    margin-left: .35rem;
    text-decoration: underline;
    text-decoration-color: currentColor;
    text-decoration-thickness: 2px;
    text-underline-offset: .35rem;
}

.nav-link.registry-portal-link:hover,
.nav-link.registry-portal-link:focus {
    background: transparent;
    color: var(--svf-navy);
}

.site-header-home:not(.is-scrolled) .nav-link.registry-portal-link {
    color: #fff;
    text-decoration-color: rgba(255, 255, 255, .86);
}

.site-header-home:not(.is-scrolled) .nav-link.registry-portal-link:hover,
.site-header-home:not(.is-scrolled) .nav-link.registry-portal-link:focus {
    background: transparent;
    color: #8ec5ff;
    text-decoration-color: currentColor;
}

.btn {
    border-radius: 999px;
    font-weight: 800;
    padding: .72rem 1.2rem;
}

.btn-primary {
    background: var(--svf-blue);
    border-color: var(--svf-blue);
    box-shadow: 0 10px 24px rgba(74, 144, 226, 0.24);
}

.btn-primary:hover,
.btn-primary:focus {
    background: var(--svf-navy);
    border-color: var(--svf-navy);
}

.btn-outline-light {
    border-color: rgba(255, 255, 255, 0.76);
}

.btn-outline-primary {
    border-color: var(--svf-blue);
    color: var(--svf-navy);
}

.btn-outline-primary:hover {
    background: var(--svf-navy);
    border-color: var(--svf-navy);
}

.hero {
    background: #071b3d;
    min-height: clamp(560px, 82vh, 820px);
    position: relative;
    isolation: isolate;
    display: flex;
    align-items: center;
    color: #fff;
    overflow: hidden;
}

.hero::before {
    background: linear-gradient(90deg, rgba(74, 144, 226, .28), rgba(255, 255, 255, 0));
    content: "";
    inset: 0;
    position: absolute;
    z-index: -2;
}

.hero.has-photo::before {
    background:
        linear-gradient(rgba(4, 19, 45, .46), rgba(4, 19, 45, .46)),
        var(--hero-photo) center center / cover no-repeat;
}

.hero::after {
    background: none;
    content: "";
    inset: 0;
    position: absolute;
    z-index: -1;
}

.hero h1 {
    font-size: clamp(1.95rem, 4vw, 3.8rem);
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.02;
    max-width: 760px;
    text-transform: uppercase;
}

.hero p {
    color: rgba(255, 255, 255, .86);
    font-size: clamp(1rem, 1.4vw, 1.22rem);
    max-width: 640px;
}

.hero-btn {
    font-size: .95rem;
    padding: .62rem 1rem;
}

.section {
    padding: clamp(3.2rem, 5vw, 4.25rem) 0;
}

.section:not(.cta-band):not(.president-message-hero):not(.section-newsroom) {
    background:
        radial-gradient(circle at 14% 20%, rgba(74, 144, 226, .12), transparent 26rem),
        radial-gradient(circle at 82% 18%, rgba(255, 200, 87, .1), transparent 22rem),
        linear-gradient(135deg, rgba(13, 45, 98, .045) 25%, transparent 25%) 0 0 / 34px 34px,
        linear-gradient(135deg, transparent 75%, rgba(74, 144, 226, .045) 75%) 0 0 / 34px 34px,
        linear-gradient(180deg, #f6f9fc 0%, #edf4fa 100%);
}

.section-soft {
    background:
        radial-gradient(circle at 80% 16%, rgba(74, 144, 226, .12), transparent 24rem),
        linear-gradient(135deg, rgba(13, 45, 98, .05) 25%, transparent 25%) 0 0 / 36px 36px,
        linear-gradient(135deg, transparent 75%, rgba(74, 144, 226, .04) 75%) 0 0 / 36px 36px,
        linear-gradient(180deg, #f2f7fb 0%, #eaf2f8 100%);
}

.section.section-newsroom {
    background:
        radial-gradient(circle at 14% 8%, rgba(255, 255, 255, .16), transparent 24rem),
        radial-gradient(circle at 86% 18%, rgba(74, 144, 226, .24), transparent 22rem),
        linear-gradient(135deg, rgba(255, 255, 255, .05) 25%, transparent 25%) 0 0 / 36px 36px,
        linear-gradient(180deg, #0a244f 0%, #0d356f 100%);
}

.section-newsroom .section-kicker {
    color: #8ec5ff;
}

.section-newsroom .section-title {
    color: #fff;
}

.section-newsroom .btn-outline-primary {
    border-color: rgba(255, 255, 255, .7);
    color: #fff;
}

.section-newsroom .btn-outline-primary:hover {
    background: #fff;
    border-color: #fff;
    color: var(--svf-navy);
}

.section-newsroom .update-card {
    background: rgba(255, 255, 255, .96);
    border-color: rgba(255, 255, 255, .34);
    box-shadow: 0 18px 42px rgba(3, 15, 35, .2);
}

.home-updates-marquee {
    margin-inline: calc((100vw - 100%) / -2);
    overflow: hidden;
    padding-inline: calc((100vw - 100%) / 2);
}

.home-updates-track {
    animation: homeUpdatesRightToLeft 34s linear infinite;
    display: flex;
    gap: 1.5rem;
    width: max-content;
}

.home-updates-marquee:hover .home-updates-track,
.home-updates-marquee:focus-within .home-updates-track {
    animation-play-state: paused;
}

.home-update-item {
    flex: 0 0 clamp(280px, 31vw, 420px);
}

@keyframes homeUpdatesRightToLeft {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(calc(-50% - .75rem));
    }
}

.section-title {
    color: var(--svf-navy);
    font-size: clamp(2rem, 4vw, 3.35rem);
    font-weight: 800;
    letter-spacing: 0;
    line-height: 1.05;
    margin-bottom: 1rem;
}

.section-kicker {
    color: var(--svf-blue);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .12em;
    margin-bottom: .8rem;
    text-transform: uppercase;
}

.lead-muted {
    color: var(--svf-muted);
    font-size: 1.08rem;
}

.page-hero .container {
    max-width: 900px;
}

.page-intro {
    font-size: 1.05rem;
}

.meta-label {
    color: var(--svf-muted);
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.president-message-hero {
    background:
        linear-gradient(135deg, #eef6ff 0%, #ffffff 54%, #e7f2fb 100%);
    color: var(--svf-ink);
    overflow: hidden;
    padding: clamp(3rem, 5.5vw, 4.5rem) 0;
    position: relative;
}

.president-message-hero::before {
    background:
        linear-gradient(135deg, rgba(74, 144, 226, .08) 25%, transparent 25%) 0 0 / 34px 34px,
        linear-gradient(135deg, transparent 75%, rgba(13, 45, 98, .055) 75%) 0 0 / 34px 34px;
    content: "";
    inset: 0;
    position: absolute;
    z-index: 0;
}

.president-message-hero .container {
    position: relative;
    z-index: 1;
}

.president-portrait-frame {
    display: flex;
    justify-content: center;
}

.president-portrait-shape {
    align-items: flex-end;
    aspect-ratio: 5 / 7;
    background:
        linear-gradient(180deg, rgba(74, 144, 226, .24), rgba(13, 45, 98, .1)),
        #d9e9ff;
    border: 1px solid rgba(74, 144, 226, .28);
    border-radius: 48% 48% 42% 42% / 44% 44% 56% 56%;
    box-shadow: 0 28px 70px rgba(13, 45, 98, .16);
    display: flex;
    max-width: 440px;
    overflow: hidden;
    position: relative;
    width: min(100%, 440px);
}

.president-portrait-shape::after {
    border: 1px solid rgba(255, 255, 255, .7);
    border-radius: inherit;
    content: "";
    inset: 1rem;
    pointer-events: none;
    position: absolute;
}

.president-portrait {
    display: block;
    height: 100%;
    object-fit: cover;
    object-position: center 18%;
    width: 100%;
}

.president-message-content {
    max-width: 830px;
    position: relative;
    width: 100%;
}

.president-message-content .section-kicker {
    color: var(--svf-blue);
}

.president-quote-mark {
    color: var(--svf-blue);
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(5rem, 8vw, 8rem);
    font-weight: 700;
    line-height: .62;
    margin: .55rem 0 .45rem;
}

.president-message-content blockquote {
    border-left: 0;
    color: #061936;
    font-size: clamp(1.35rem, 2.1vw, 2.15rem);
    font-weight: 400;
    line-height: 1.5;
    margin: 0;
    max-width: 840px;
    overflow-wrap: anywhere;
    padding-left: 0;
}

.president-highlight {
    background: var(--svf-blue);
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    color: #fff;
    display: inline-block;
    font-size: clamp(1.35rem, 2.2vw, 2.35rem);
    font-weight: 800;
    line-height: 1.45;
    margin-top: 1.5rem;
    max-width: 100%;
    padding: .12em .3em;
    text-transform: uppercase;
}

.president-signature {
    margin-top: 1.8rem;
    padding-left: 0;
}

.president-signature span {
    color: #061936;
    display: block;
    font-size: clamp(1.7rem, 2.6vw, 2.75rem);
    font-weight: 800;
    line-height: 1.1;
    margin-bottom: .55rem;
    overflow-wrap: anywhere;
}

.president-signature strong {
    color: var(--svf-muted);
    display: block;
    font-size: 1.08rem;
    font-weight: 700;
    letter-spacing: 0;
    text-transform: none;
}

.info-band {
    background: var(--svf-navy);
    color: #fff;
    padding: 1.4rem 0;
}

.info-stat {
    align-items: center;
    border-left: 1px solid rgba(255,255,255,.2);
    display: flex;
    gap: 1rem;
    padding-left: 1.4rem;
}

.info-stat-icon {
    align-items: center;
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 999px;
    color: #8ec5ff;
    display: inline-flex;
    flex: 0 0 52px;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.info-stat-icon svg {
    fill: none;
    height: 27px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 27px;
}

.info-stat-copy {
    display: block;
}

.info-stat strong {
    display: block;
    font-size: 1.65rem;
    line-height: 1;
}

.info-stat-copy span {
    color: rgba(255, 255, 255, .86);
    display: block;
    margin-top: .2rem;
}

.feature-card,
.update-card,
.partner-card,
.contact-card {
    background: rgba(251, 253, 255, .92);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    height: 100%;
    padding: 1.5rem;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.update-card {
    overflow: hidden;
    padding: 0;
}

.update-card .update-category,
.update-card h3,
.update-card p,
.update-card time {
    margin-left: 1.5rem;
    margin-right: 1.5rem;
}

.update-card time {
    display: block;
    margin-bottom: 1.5rem;
}

.update-image {
    aspect-ratio: 16 / 10;
    display: block;
    margin-bottom: 1.2rem;
    object-fit: cover;
    object-position: center;
    width: 100%;
}

.feature-card:hover,
.update-card:hover,
.partner-card:hover {
    border-color: rgba(74, 144, 226, .45);
    box-shadow: var(--svf-shadow);
    transform: translateY(-4px);
}

.feature-card {
    position: relative;
}

.form-panel,
.inquiry-panel,
.hours-panel,
.contact-detail {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, 0.07);
}

.form-panel {
    padding: clamp(1.25rem, 3vw, 2rem);
}

.form-label {
    color: var(--svf-ink);
    font-size: .9rem;
    font-weight: 800;
}

.form-control,
.form-select {
    border-color: #cddbec;
    border-radius: var(--svf-radius);
    min-height: 48px;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--svf-blue);
    box-shadow: 0 0 0 .2rem rgba(74, 144, 226, .18);
}

.check-list {
    display: grid;
    gap: .7rem;
    list-style: none;
    margin: 1.3rem 0 0;
    padding: 0;
}

.check-list li {
    align-items: flex-start;
    display: flex;
    gap: .65rem;
}

.check-list li::before {
    background: var(--svf-blue);
    border-radius: 999px;
    content: "";
    flex: 0 0 1.35rem;
    height: 1.35rem;
    margin-top: .12rem;
    outline: 4px solid var(--svf-sky);
}

.impact-grid {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(7, 1fr);
}

.impact-grid div {
    background: var(--svf-sky);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    color: var(--svf-navy);
    font-weight: 800;
    min-height: 92px;
    padding: 1rem;
}

.contact-stack {
    display: grid;
    gap: 1rem;
}

.contact-detail {
    padding: 1.15rem;
}

.contact-detail span {
    color: var(--svf-blue);
    display: block;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .1em;
    margin-bottom: .45rem;
    text-transform: uppercase;
}

.contact-detail p {
    margin-bottom: 0;
}

.hours-panel,
.inquiry-panel {
    padding: 1.4rem;
}

.hours-panel h3 {
    font-size: 1.2rem;
    font-weight: 800;
    margin-bottom: 1rem;
}

.hours-panel div {
    align-items: center;
    border-top: 1px solid var(--svf-line);
    display: flex;
    justify-content: space-between;
    gap: 1rem;
    padding: .85rem 0;
}

.hours-panel div:last-child {
    padding-bottom: 0;
}

.hours-panel span {
    color: var(--svf-muted);
    text-align: right;
}

.map-frame {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: var(--svf-shadow);
    overflow: hidden;
}

.social-pills {
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    list-style: none;
    margin: 1.5rem 0;
    padding: 0;
}

.social-pills a {
    background: var(--svf-sky);
    border: 1px solid var(--svf-line);
    border-radius: 999px;
    color: var(--svf-navy);
    display: inline-flex;
    font-weight: 800;
    padding: .65rem 1rem;
}

.social-pills a:hover {
    background: var(--svf-navy);
    border-color: var(--svf-navy);
    color: #fff;
}

.feature-icon,
.partner-logo {
    align-items: center;
    background: linear-gradient(135deg, var(--svf-blue), var(--svf-navy));
    border-radius: var(--svf-radius);
    color: #fff;
    display: inline-flex;
    font-weight: 800;
    height: 58px;
    justify-content: center;
    margin-bottom: 1rem;
    min-width: 58px;
    padding: .85rem;
}

.feature-icon svg {
    fill: none;
    height: 30px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 30px;
}

.update-category {
    background: rgba(74, 144, 226, .12);
    border-radius: 999px;
    color: var(--svf-navy);
    display: inline-block;
    font-size: .76rem;
    font-weight: 800;
    margin-bottom: .9rem;
    padding: .28rem .72rem;
}

.partner-card-logo {
    border-bottom: 4px solid var(--svf-blue);
    min-height: 260px;
    overflow: hidden;
    position: relative;
}

.partner-card-logo-image {
    filter: grayscale(100%);
    height: 118px;
    object-fit: contain;
    object-position: right center;
    opacity: .75;
    position: absolute;
    right: 1rem;
    top: 50%;
    transform: scale(1);
    translate: 0 -50%;
    transition: filter .3s ease, opacity .3s ease, transform .3s ease;
    width: min(58%, 230px);
    z-index: 0;
}

.partner-card-logo::after {
    background: linear-gradient(90deg, rgba(251, 253, 255, .98) 0%, rgba(251, 253, 255, .92) 48%, rgba(251, 253, 255, .28) 100%);
    content: "";
    inset: 0;
    position: absolute;
    z-index: 1;
}

.partner-card-logo:hover .partner-card-logo-image,
.partner-card-logo:focus-within .partner-card-logo-image,
.partner-card-logo:active .partner-card-logo-image {
    filter: grayscale(0%);
    opacity: 1;
    transform: translateY(-4px) scale(1.035);
}

.partner-card-logo h3,
.partner-card-logo p,
.partner-card-logo a {
    position: relative;
    z-index: 2;
}

.partner-card-logo h3 {
    color: var(--svf-navy);
    font-size: 1.55rem;
    max-width: 70%;
}

.partner-card-logo p {
    max-width: 72%;
}

.partners-hero {
    background:
        linear-gradient(90deg, rgba(5, 22, 52, .92), rgba(13, 45, 98, .68)),
        url("../images/updates/svf-mens-championship.jpg") center center / cover no-repeat;
    color: #fff;
    overflow: hidden;
    padding: clamp(3.8rem, 6vw, 5.5rem) 0;
    position: relative;
}

.partners-hero::after {
    background: url("../images/svf-icon.png") right 7% center / min(30vw, 300px) no-repeat;
    content: "";
    inset: 0;
    opacity: .08;
    position: absolute;
}

.partners-hero .container {
    position: relative;
    z-index: 1;
}

.partners-hero .section-title,
.partners-hero .lead-muted {
    color: #fff;
}

.partners-hero .lead-muted {
    max-width: 760px;
    opacity: .9;
}

.partners-section {
    background:
        radial-gradient(circle at 16% 14%, rgba(142, 197, 255, .24), transparent 24rem),
        linear-gradient(180deg, #f5f9fd 0%, #eaf2f8 100%);
}

.partners-subsection-heading {
    margin-bottom: 1.5rem;
    max-width: 760px;
}

.partners-subsection-heading h2 {
    color: var(--svf-navy);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.05;
    margin-bottom: .65rem;
}

.partners-subsection-heading p {
    color: var(--svf-muted);
    font-size: 1.05rem;
    margin-bottom: 0;
}

.partners-grid {
    display: grid;
    gap: 1.2rem;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.partner-profile-card {
    align-items: center;
    background: rgba(255, 255, 255, .94);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 14px 34px rgba(13, 45, 98, .08);
    display: grid;
    gap: 1.2rem;
    grid-template-columns: 140px minmax(0, 1fr);
    min-height: 210px;
    overflow: hidden;
    padding: 1.25rem;
    position: relative;
    transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}

.partner-profile-card::after {
    background: linear-gradient(135deg, rgba(74, 144, 226, .12), transparent 55%);
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.partner-profile-card:hover {
    border-color: rgba(74, 144, 226, .45);
    box-shadow: var(--svf-shadow);
    transform: translateY(-3px);
}

.partner-profile-logo {
    align-items: center;
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    display: flex;
    height: 132px;
    justify-content: center;
    padding: 1rem;
    position: relative;
    z-index: 1;
}

.partner-profile-logo img {
    max-height: 92px;
    max-width: 100%;
    object-fit: contain;
}

.partner-profile-logo .partner-logo-placeholder {
    opacity: .72;
    padding: .25rem;
}

.partner-profile-copy {
    position: relative;
    z-index: 1;
}

.partner-profile-copy h2 {
    color: var(--svf-navy);
    font-size: 1.45rem;
    font-weight: 800;
    margin-bottom: .55rem;
}

.partner-profile-copy p {
    color: var(--svf-muted);
    margin-bottom: 1rem;
}

.partner-profile-tag {
    align-items: center;
    background: var(--svf-sky);
    border: 1px solid var(--svf-line);
    border-radius: 999px;
    color: var(--svf-navy);
    display: inline-flex;
    font-size: .84rem;
    font-weight: 800;
    padding: .55rem .85rem;
}

.partners-cooperation {
    background: var(--svf-navy);
    color: #fff;
    padding: clamp(2.4rem, 4vw, 3.3rem) 0;
}

.partners-cooperation h2 {
    font-size: clamp(1.7rem, 3vw, 2.4rem);
    font-weight: 800;
    margin-bottom: .65rem;
}

.partners-cooperation p {
    color: rgba(255, 255, 255, .78);
    margin-bottom: 0;
}

.partner-priority-list {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    justify-content: flex-lg-end;
}

.partner-priority-list span {
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 999px;
    color: #fff;
    font-weight: 800;
    padding: .6rem .9rem;
}

.announcements-hero {
    background:
        linear-gradient(90deg, rgba(5, 22, 52, .9), rgba(13, 45, 98, .68)),
        url("../images/updates/svf-training-court.jpg") center center / cover no-repeat;
    color: #fff;
    padding: clamp(3.6rem, 6vw, 5.2rem) 0;
    position: relative;
}

.announcements-hero::after {
    background: url("../images/svf-icon.png") right 7% center / min(28vw, 290px) no-repeat;
    content: "";
    inset: 0;
    opacity: .08;
    position: absolute;
}

.announcements-hero .container {
    max-width: 980px;
    position: relative;
    z-index: 1;
}

.announcements-hero .section-title,
.announcements-hero .lead-muted {
    color: #fff;
}

.announcements-hero .lead-muted {
    opacity: .9;
}

.announcement-tabs {
    background: var(--svf-navy);
    position: sticky;
    top: 84px;
    z-index: 10;
}

.announcement-tab-list {
    display: flex;
    gap: .65rem;
    overflow-x: auto;
    padding: .85rem 0;
}

.announcement-tab-list a {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 999px;
    color: #fff;
    flex: 0 0 auto;
    font-size: .88rem;
    font-weight: 800;
    padding: .58rem 1rem;
}

.announcement-tab-list a:hover,
.announcement-tab-list a:focus,
.announcement-tab-list a.active {
    background: #fff;
    color: var(--svf-navy);
}

.announcements-section {
    background:
        radial-gradient(circle at 14% 18%, rgba(142, 197, 255, .18), transparent 24rem),
        linear-gradient(180deg, #f7fbff 0%, #eef5fa 100%);
}

.announcements-section-soft {
    background:
        radial-gradient(circle at 80% 16%, rgba(74, 144, 226, .18), transparent 24rem),
        linear-gradient(180deg, #eaf6ff 0%, #f5f9fd 100%);
}

.announcement-section-heading {
    margin-bottom: 1.5rem;
    max-width: 760px;
}

.announcement-section-heading h2 {
    color: var(--svf-navy);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 800;
    line-height: 1.05;
    margin-bottom: .65rem;
}

.announcement-section-heading p {
    color: var(--svf-muted);
    font-size: 1.05rem;
    margin-bottom: 0;
}

.announcement-card {
    box-shadow: 0 14px 34px rgba(13, 45, 98, .08);
}

.announcement-card-link {
    color: inherit;
    display: block;
    height: 100%;
    text-decoration: none;
}

.announcement-detail-card {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 14px 34px rgba(13, 45, 98, .08);
    margin-inline: auto;
    max-width: 1080px;
    overflow: hidden;
}

.announcement-detail-card > img {
    aspect-ratio: 16 / 7.5;
    display: block;
    object-fit: cover;
    width: 100%;
}

.announcement-detail-meta {
    align-items: center;
    border-bottom: 1px solid var(--svf-line);
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
    justify-content: space-between;
    padding: 1rem 1.4rem;
}

.announcement-detail-meta span {
    background: var(--svf-sky);
    border-radius: 999px;
    color: var(--svf-blue);
    font-size: .76rem;
    font-weight: 900;
    letter-spacing: .08em;
    padding: .42rem .72rem;
    text-transform: uppercase;
}

.announcement-detail-meta time {
    color: var(--svf-muted);
    font-weight: 700;
}

.announcement-detail-content {
    color: var(--svf-ink);
    font-size: 1.06rem;
    line-height: 1.75;
    padding: 1.4rem;
}

.announcement-detail-card .btn {
    margin-left: 1.4rem;
    margin-bottom: 1.4rem;
}

@media (prefers-reduced-motion: reduce) {
    .home-updates-marquee {
        margin-inline: 0;
        overflow: visible;
        padding-inline: 0;
    }

    .home-updates-track {
        animation: none;
        display: grid;
        gap: 1.5rem;
        grid-template-columns: repeat(auto-fit, minmax(min(100%, 280px), 1fr));
        width: auto;
    }

    .home-update-item {
        flex-basis: auto;
    }

    .home-update-item[aria-hidden="true"] {
        display: none;
    }
}

.announcement-empty-panel {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .95), rgba(238, 246, 255, .92));
    border: 1px solid var(--svf-line);
    border-left: 5px solid var(--svf-blue);
    border-radius: var(--svf-radius);
    box-shadow: 0 14px 34px rgba(13, 45, 98, .08);
    max-width: 760px;
    padding: 1.4rem;
}

.announcement-empty-panel span {
    color: var(--svf-blue);
    display: block;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .1em;
    margin-bottom: .5rem;
    text-transform: uppercase;
}

.announcement-empty-panel strong {
    color: var(--svf-navy);
    display: block;
    font-size: 1.35rem;
    font-weight: 800;
    margin-bottom: .35rem;
}

.announcement-empty-panel p {
    color: var(--svf-muted);
    margin-bottom: 0;
}

.involved-hero,
.contact-hero {
    background:
        linear-gradient(90deg, rgba(5, 22, 52, .9), rgba(13, 45, 98, .68)),
        url("../images/updates/svf-mens-championship.jpg") center center / cover no-repeat;
    color: #fff;
    padding: clamp(3.6rem, 6vw, 5.2rem) 0;
    position: relative;
}

.involved-hero::after,
.contact-hero::after {
    background: url("../images/svf-icon.png") right 7% center / min(28vw, 290px) no-repeat;
    content: "";
    inset: 0;
    opacity: .08;
    position: absolute;
}

.involved-hero .container,
.contact-hero .container {
    max-width: 980px;
    position: relative;
    z-index: 1;
}

.involved-hero .section-title,
.involved-hero .lead-muted,
.contact-hero .section-title,
.contact-hero .lead-muted {
    color: #fff;
}

.involved-hero .lead-muted,
.contact-hero .lead-muted {
    opacity: .9;
}

.involved-tabs {
    background: var(--svf-navy);
    position: sticky;
    top: 84px;
    z-index: 10;
}

.involved-tab-list {
    display: flex;
    gap: .65rem;
    overflow-x: auto;
    padding: .85rem 0;
}

.involved-tab-list a {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 999px;
    color: #fff;
    flex: 0 0 auto;
    font-size: .88rem;
    font-weight: 800;
    padding: .58rem 1rem;
}

.involved-tab-list a:hover,
.involved-tab-list a:focus,
.involved-tab-list a.active {
    background: #fff;
    color: var(--svf-navy);
}

.involved-section,
.contact-section {
    background:
        radial-gradient(circle at 14% 18%, rgba(142, 197, 255, .18), transparent 24rem),
        linear-gradient(180deg, #f7fbff 0%, #eef5fa 100%);
}

.involved-section-soft {
    background:
        radial-gradient(circle at 80% 16%, rgba(74, 144, 226, .18), transparent 24rem),
        linear-gradient(180deg, #eaf6ff 0%, #f5f9fd 100%);
}

.involved-form-panel h3,
.contact-form-panel h2 {
    color: var(--svf-navy);
    font-weight: 800;
}

.social-panel {
    background:
        radial-gradient(circle at 84% 18%, rgba(255, 255, 255, .18), transparent 8rem),
        linear-gradient(135deg, var(--svf-blue), var(--svf-navy));
    border: 1px solid rgba(255, 255, 255, .22);
    border-radius: var(--svf-radius);
    box-shadow: 0 16px 34px rgba(13, 45, 98, .16);
    color: #fff;
    padding: 1.35rem;
}

.social-panel h3 {
    color: #fff;
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: .06em;
    margin-bottom: 1rem;
    text-transform: uppercase;
}

.contact-info-card {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
    overflow: hidden;
}

.contact-info-row {
    align-items: flex-start;
    display: grid;
    gap: .95rem;
    grid-template-columns: 52px minmax(0, 1fr);
    padding: 1rem;
}

.contact-info-row + .contact-info-row {
    border-top: 1px solid var(--svf-line);
}

.contact-info-icon {
    align-items: center;
    background: var(--svf-sky);
    border: 1px solid rgba(74, 144, 226, .22);
    border-radius: var(--svf-radius);
    color: var(--svf-blue);
    display: inline-flex;
    height: 52px;
    justify-content: center;
    width: 52px;
}

.contact-info-icon svg,
.social-brand-list svg {
    fill: none;
    height: 26px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 26px;
}

.contact-info-row strong {
    color: var(--svf-blue);
    display: block;
    font-size: .78rem;
    font-weight: 800;
    letter-spacing: .1em;
    margin-bottom: .32rem;
    text-transform: uppercase;
}

.contact-info-row p {
    color: var(--svf-ink);
    font-size: .98rem;
    margin-bottom: 0;
}

.social-brand-list {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .8rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

.social-brand-list a {
    align-items: center;
    background: rgba(255, 255, 255, .12);
    border: 1px solid rgba(255, 255, 255, .18);
    border-radius: 10px;
    color: #fff;
    display: inline-flex;
    height: 50px;
    justify-content: center;
    transition: background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
    width: 50px;
}

.social-brand-list a:hover,
.social-brand-list a:focus {
    background: #fff;
    border-color: #fff;
    box-shadow: 0 12px 26px rgba(1, 12, 32, .22);
    color: var(--svf-navy);
    transform: translateY(-2px);
}

.social-brand-list span {
    align-items: center;
    background: transparent;
    color: currentColor;
    display: inline-flex;
    height: 28px;
    justify-content: center;
    width: 28px;
}

.cta-band {
    background:
        linear-gradient(120deg, rgba(13, 45, 98, .96), rgba(74, 144, 226, .9)),
        url("../images/svf-icon.png") right -8rem center / 360px no-repeat;
    color: #fff;
}

.about-hero {
    background:
        linear-gradient(90deg, rgba(5, 22, 52, .86), rgba(13, 45, 98, .52)),
        url("../images/updates/svf-mens-championship.jpg") center center / cover no-repeat;
    color: #fff;
    min-height: clamp(360px, 38vw, 500px);
    overflow: hidden;
    padding: clamp(3.8rem, 6vw, 5.4rem) 0;
    position: relative;
}

.about-hero::after {
    background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(7, 27, 61, .16));
    content: "";
    inset: 0;
    pointer-events: none;
    position: absolute;
}

.about-hero .container {
    position: relative;
    z-index: 1;
}

.about-hero .section-title,
.about-hero .lead-muted {
    color: #fff;
}

.about-hero .lead-muted {
    max-width: 780px;
    opacity: .9;
}

.about-hero-panel {
    align-items: center;
    background: rgba(255, 255, 255, .9);
    border: 1px solid rgba(255, 255, 255, .58);
    border-radius: var(--svf-radius);
    box-shadow: 0 20px 50px rgba(3, 15, 35, .24);
    display: flex;
    gap: 1rem;
    padding: 1.1rem 1.2rem;
}

.timeline-year,
.club-status {
    color: var(--svf-blue);
    display: block;
    font-size: .76rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
}

.about-hero-icon {
    align-items: center;
    background: linear-gradient(135deg, var(--svf-blue), var(--svf-navy));
    border-radius: var(--svf-radius);
    box-shadow: 0 14px 28px rgba(13, 45, 98, .2);
    color: #fff;
    display: inline-flex;
    flex: 0 0 58px;
    height: 58px;
    justify-content: center;
    width: 58px;
}

.about-hero-icon svg {
    fill: none;
    height: 31px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 31px;
}

.about-hero-panel strong {
    color: var(--svf-navy);
    display: block;
    font-size: clamp(1.6rem, 2.6vw, 2.2rem);
    font-weight: 800;
    line-height: 1.05;
    margin: 0;
}

.about-nav-band {
    background: var(--svf-navy);
    box-shadow: 0 12px 28px rgba(3, 15, 35, .16);
    position: sticky;
    top: 84px;
    z-index: 10;
}

.about-nav {
    display: flex;
    gap: .65rem;
    overflow-x: auto;
    padding: .85rem 0;
    scrollbar-width: thin;
}

.about-nav a {
    background: rgba(255, 255, 255, .08);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 999px;
    color: #fff;
    flex: 0 0 auto;
    font-size: .88rem;
    font-weight: 800;
    padding: .58rem 1rem;
}

.about-nav a:hover,
.about-nav a:focus {
    background: #fff;
    color: var(--svf-navy);
}

.history-timeline {
    display: grid;
    gap: .95rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    position: relative;
}

.history-timeline::before {
    background: linear-gradient(90deg, rgba(74, 144, 226, .18), var(--svf-blue), rgba(74, 144, 226, .18));
    content: "";
    height: 2px;
    left: 8%;
    position: absolute;
    right: 8%;
    top: 15px;
}

.timeline-item {
    position: relative;
}

.timeline-marker {
    background: var(--svf-blue);
    border: 4px solid #fff;
    border-radius: 999px;
    box-shadow: 0 0 0 7px rgba(74, 144, 226, .12);
    height: 22px;
    margin: .3rem auto 1.1rem;
    position: relative;
    width: 22px;
    z-index: 1;
}

.timeline-card,
.club-card {
    background: rgba(251, 253, 255, .94);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
}

.timeline-card {
    min-height: 138px;
    padding: 1rem;
    text-align: center;
}

.timeline-card h3,
.mandate-card h3,
.club-card h3 {
    color: var(--svf-navy);
    font-size: 1.2rem;
    font-weight: 800;
    margin-bottom: .55rem;
}

.timeline-card p,
.mandate-card p {
    margin: 0;
}

.timeline-card p {
    color: var(--svf-muted);
}

.mandate-card {
    background:
        radial-gradient(circle at 18% 16%, rgba(255, 255, 255, .38), transparent 4.8rem),
        linear-gradient(135deg, #0f4c93, #0d2d62 72%);
    border-color: rgba(142, 197, 255, .35);
    box-shadow: 0 18px 42px rgba(13, 45, 98, .2);
    min-height: 205px;
}

.mandate-card .feature-icon {
    background:
        radial-gradient(circle at 35% 28%, rgba(255, 255, 255, .94), rgba(238, 246, 255, .88));
    box-shadow:
        0 0 0 8px rgba(142, 197, 255, .14),
        0 14px 30px rgba(3, 15, 35, .2);
    color: var(--svf-blue);
}

.mandate-card h3,
.mandate-card p {
    color: #fff;
}

.mandate-card p {
    opacity: .9;
}

#mandate.section-soft {
    background:
        radial-gradient(circle at 22% 18%, rgba(142, 197, 255, .42), transparent 22rem),
        radial-gradient(circle at 82% 20%, rgba(255, 255, 255, .72), transparent 20rem),
        linear-gradient(180deg, #eaf6ff 0%, #dff0ff 100%);
}

.governance-section {
    background:
        radial-gradient(circle at 12% 18%, rgba(142, 197, 255, .2), transparent 24rem),
        linear-gradient(180deg, #f8fbfe 0%, #edf4fa 100%);
    overflow: hidden;
    position: relative;
}

.governance-section::before,
#clubs::before {
    background: url("../images/svf-icon.png") center / contain no-repeat;
    content: "";
    opacity: .055;
    pointer-events: none;
    position: absolute;
    z-index: 0;
}

.governance-section::before {
    height: min(36vw, 390px);
    right: 4%;
    top: 50%;
    transform: translateY(-50%);
    width: min(36vw, 390px);
}

.governance-section .container,
#clubs .container {
    position: relative;
    z-index: 1;
}

.governance-list {
    display: flex;
    flex-wrap: wrap;
    gap: .65rem;
    margin-top: 1.5rem;
}

.history-section {
    padding-top: clamp(2.6rem, 4vw, 3.5rem);
}

#mandate,
.governance-section,
#clubs {
    padding-top: clamp(2.8rem, 4.6vw, 3.8rem);
    padding-bottom: clamp(2.8rem, 4.6vw, 3.8rem);
}

.governance-list span {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: 999px;
    color: var(--svf-navy);
    font-size: .88rem;
    font-weight: 800;
    padding: .52rem .85rem;
}

.org-chart {
    background:
        linear-gradient(135deg, rgba(255, 255, 255, .96), rgba(238, 246, 255, .94));
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: var(--svf-shadow);
    display: grid;
    gap: 1.05rem 1.2rem;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-template-rows: repeat(5, auto);
    overflow: hidden;
    padding: clamp(1.2rem, 3vw, 2.2rem);
    position: relative;
    text-align: center;
}

.org-chart::before {
    background: url("../images/svf-icon.png") center / contain no-repeat;
    content: "";
    inset: 12%;
    opacity: .045;
    position: absolute;
}

.authority-chart::after {
    background:
        linear-gradient(var(--svf-blue), var(--svf-blue)) center 18% / 2px 12% no-repeat,
        linear-gradient(var(--svf-blue), var(--svf-blue)) center 43% / 2px 13% no-repeat,
        linear-gradient(var(--svf-blue), var(--svf-blue)) 50% 59% / 50% 2px no-repeat,
        linear-gradient(var(--svf-blue), var(--svf-blue)) 31.5% 72% / 2px 16% no-repeat,
        linear-gradient(var(--svf-blue), var(--svf-blue)) 68.5% 54% / 2px 23% no-repeat;
    content: "";
    inset: 0;
    opacity: .46;
    pointer-events: none;
    position: absolute;
}

.org-node {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    color: var(--svf-navy);
    font-weight: 800;
    min-height: 58px;
    margin-inline: auto;
    max-width: 280px;
    padding: .95rem 1rem;
    position: relative;
    width: 100%;
    z-index: 1;
}

.org-node-primary {
    background: var(--svf-navy);
    border-color: var(--svf-navy);
    color: #fff;
}

.org-node-secondary {
    background: var(--svf-blue);
    border-color: var(--svf-blue);
    color: #fff;
}

.org-node-president {
    background: linear-gradient(135deg, #0d2d62, #1258a3);
    border-color: rgba(142, 197, 255, .55);
    box-shadow: 0 16px 34px rgba(13, 45, 98, .24);
    color: #fff;
}

.org-general {
    grid-column: 2 / 4;
    grid-row: 1;
}

.org-executive {
    grid-column: 2 / 4;
    grid-row: 2;
}

.org-president {
    grid-column: 2 / 4;
    grid-row: 3;
}

.org-vps {
    grid-column: 1 / 3;
    grid-row: 4;
}

.org-secretariat {
    grid-column: 1 / 3;
    grid-row: 5;
}

.org-judicial {
    grid-column: 3 / 5;
    grid-row: 4 / 6;
    align-self: center;
    border-color: rgba(74, 144, 226, .35);
}

.club-directory-tools {
    align-items: end;
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
    display: grid;
    gap: 1rem;
    grid-template-columns: minmax(220px, 1fr) auto;
    margin-bottom: 1.5rem;
    padding: 1rem;
}

#clubs {
    background:
        linear-gradient(180deg, #f2f7fb 0%, #eaf2f8 100%);
    overflow: hidden;
    position: relative;
}

#clubs::before {
    height: min(28vw, 300px);
    opacity: .035;
    right: clamp(1rem, 7vw, 7rem);
    top: 5.25rem;
    width: min(28vw, 300px);
}

.club-search label {
    color: var(--svf-ink);
    display: block;
    font-size: .84rem;
    font-weight: 800;
    margin-bottom: .45rem;
}

.club-search input {
    border: 1px solid #cddbec;
    border-radius: var(--svf-radius);
    min-height: 48px;
    padding: .75rem .9rem;
    width: 100%;
}

.club-search input:focus {
    border-color: var(--svf-blue);
    box-shadow: 0 0 0 .2rem rgba(74, 144, 226, .18);
    outline: 0;
}

.club-status-filter {
    align-self: end;
    min-width: 250px;
}

.club-status-filter > span {
    color: var(--svf-ink);
    display: block;
    font-size: .84rem;
    font-weight: 800;
    margin-bottom: .45rem;
}

.club-status-options {
    background: var(--svf-sky);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    display: grid;
    gap: .35rem;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    min-height: 48px;
    padding: .25rem;
}

.club-status-option {
    background: transparent;
    border: 0;
    border-radius: 6px;
    color: var(--svf-navy);
    font-size: .8rem;
    font-weight: 800;
    padding: .55rem .6rem;
    white-space: nowrap;
}

.club-status-option.active,
.club-status-option:hover,
.club-status-option:focus {
    background: var(--svf-navy);
    color: #fff;
    outline: 0;
}

.club-card {
    height: 100%;
    padding: 1.25rem;
}

.club-card-top {
    align-items: center;
    display: flex;
    gap: .8rem;
    justify-content: space-between;
    margin-bottom: 1.1rem;
}

.club-avatar {
    align-items: center;
    background:
        radial-gradient(circle at 35% 28%, rgba(255, 255, 255, .96), rgba(238, 246, 255, .92));
    border: 1px solid rgba(74, 144, 226, .2);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 24px rgba(13, 45, 98, .12);
    display: inline-flex;
    flex: 0 0 58px;
    height: 58px;
    justify-content: center;
    padding: .35rem;
    width: 58px;
}

.club-avatar img {
    display: block;
    height: 100%;
    object-fit: contain;
    width: 100%;
}

.club-status {
    background: rgba(74, 144, 226, .1);
    border-radius: 999px;
    letter-spacing: .06em;
    padding: .35rem .65rem;
    text-align: right;
}

.club-card dl {
    display: grid;
    gap: .7rem;
    margin: 1rem 0 0;
}

.club-card dl div {
    align-items: center;
    border-top: 1px solid var(--svf-line);
    display: flex;
    justify-content: space-between;
    padding-top: .7rem;
}

.club-card dt {
    color: var(--svf-muted);
    font-size: .82rem;
    font-weight: 800;
    text-transform: uppercase;
}

.club-card dd {
    color: var(--svf-navy);
    font-weight: 800;
    margin: 0;
    text-align: right;
}

.club-empty-message {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    color: var(--svf-muted);
    font-weight: 700;
    margin: 1rem 0 0;
    padding: 1rem;
    text-align: center;
}

.site-footer {
    background: #071b3d;
    color: rgba(255, 255, 255, .76);
    padding: 4rem 0 2rem;
}

.footer-logo {
    background: #fff;
    border-radius: var(--svf-radius);
    max-width: 270px;
    padding: .65rem;
    width: 100%;
}

.site-footer h2 {
    color: #fff;
    font-size: .9rem;
    font-weight: 800;
    letter-spacing: .1em;
    text-transform: uppercase;
}

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

.site-footer a:hover {
    color: #fff;
}

.footer-bottom {
    border-top: 1px solid rgba(255, 255, 255, .14);
    font-size: .9rem;
    margin-top: 3rem;
    padding-top: 1.5rem;
}

.footer-credit {
    align-items: center;
    display: inline-flex;
    flex-wrap: wrap;
    gap: .28rem;
}

.footer-credit svg {
    fill: #ff4d8d;
    height: 17px;
    stroke: #ff8ab5;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 1.8;
    width: 17px;
}

.footer-affiliations {
    border-top: 1px solid rgba(255, 255, 255, .12);
    margin-top: 2.5rem;
    padding-top: 1.5rem;
}

.footer-affiliation-logos {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.35rem;
}

.footer-affiliation-logos img {
    background: rgba(255, 255, 255, .9);
    border-radius: 6px;
    filter: grayscale(100%);
    max-height: 42px;
    max-width: 92px;
    object-fit: contain;
    opacity: .6;
    padding: .35rem;
    transition: filter .3s ease, opacity .3s ease, transform .3s ease;
}

.footer-affiliation-logos img:hover {
    filter: grayscale(20%);
    opacity: .88;
    transform: translateY(-2px);
}

.footer-social {
    border-top: 1px solid rgba(255, 255, 255, .12);
    margin-top: 1.5rem;
    padding-top: 1.5rem;
}

.footer-social-links {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .75rem;
}

.footer-social-links a {
    align-items: center;
    background: rgba(255, 255, 255, .1);
    border: 1px solid rgba(255, 255, 255, .16);
    border-radius: 8px;
    color: #fff;
    display: inline-flex;
    height: 42px;
    justify-content: center;
    transition: background .2s ease, color .2s ease, transform .2s ease;
    width: 42px;
}

.footer-social-links a:hover,
.footer-social-links a:focus {
    background: #fff;
    color: var(--svf-navy);
    transform: translateY(-2px);
}

.footer-social-links svg {
    fill: none;
    height: 23px;
    stroke: currentColor;
    stroke-linecap: round;
    stroke-linejoin: round;
    stroke-width: 2;
    width: 23px;
}

.admin-auth-page {
    background:
        linear-gradient(120deg, rgba(5, 22, 52, .9), rgba(13, 45, 98, .72)),
        url("../images/hero-main.jpg") center center / cover no-repeat;
    min-height: 100vh;
}

.admin-auth-card {
    background: rgba(255, 255, 255, .96);
    border: 1px solid rgba(255, 255, 255, .45);
    border-radius: var(--svf-radius);
    box-shadow: 0 24px 60px rgba(1, 12, 32, .24);
    padding: 2rem;
}

.admin-auth-card img {
    height: 72px;
    margin-bottom: 1.25rem;
    object-fit: contain;
    width: auto;
}

.admin-auth-card h1 {
    color: var(--svf-navy);
    font-size: clamp(2rem, 5vw, 2.7rem);
    font-weight: 900;
    letter-spacing: 0;
}

.admin-navbar {
    box-shadow: 0 8px 26px rgba(13, 45, 98, .06);
}

.admin-welcome {
    background:
        radial-gradient(circle at 88% 12%, rgba(74, 144, 226, .18), transparent 12rem),
        #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 14px 34px rgba(13, 45, 98, .07);
    padding: 1.5rem;
}

.admin-page-heading {
    align-items: center;
    display: flex;
    gap: 1rem;
    justify-content: space-between;
}

.admin-filter-bar,
.admin-form-card,
.admin-table-card {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
}

.admin-filter-bar {
    align-items: end;
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    padding: 1rem;
}

.admin-filter-bar label {
    flex: 1 1 210px;
}

.admin-filter-bar span,
.admin-form-card .form-label {
    color: var(--svf-ink);
    font-size: .86rem;
    font-weight: 800;
}

.admin-table-card {
    overflow: hidden;
}

.admin-table-card th {
    color: var(--svf-muted);
    font-size: .78rem;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.admin-table-card td strong,
.admin-table-card td small {
    display: block;
}

.admin-table-card td small {
    color: var(--svf-muted);
    margin-top: .2rem;
}

.admin-status {
    border-radius: 999px;
    display: inline-flex;
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .06em;
    padding: .38rem .72rem;
    text-transform: uppercase;
}

.admin-status-published {
    background: #e5f6ed;
    color: #107541;
}

.admin-status-active {
    background: #e5f6ed;
    color: #107541;
}

.admin-status-inactive {
    background: #edf0f4;
    color: #596579;
}

.admin-status-draft {
    background: #fff3d7;
    color: #9b6200;
}

.admin-status-new {
    background: var(--svf-sky);
    color: var(--svf-blue);
}

.admin-status-read,
.admin-status-reviewed,
.admin-status-in_discussion {
    background: #e9ecff;
    color: #3040a0;
}

.admin-status-archived,
.admin-status-closed {
    background: #edf0f4;
    color: #596579;
}

.admin-status-accepted {
    background: #e5f6ed;
    color: #107541;
}

.admin-status-declined {
    background: #ffe8e8;
    color: #a12f2f;
}

.admin-actions {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .45rem;
    justify-content: flex-end;
}

.admin-actions form {
    margin: 0;
}

.admin-empty-state {
    padding: 2rem;
    text-align: center;
}

.admin-empty-state strong {
    color: var(--svf-navy);
    display: block;
    font-size: 1.25rem;
    font-weight: 900;
    margin-bottom: .35rem;
}

.admin-empty-state p {
    color: var(--svf-muted);
}

.admin-form-card {
    padding: 1.25rem;
}

.admin-side-panel {
    background: linear-gradient(180deg, #f7fbff, #eef6ff);
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    padding: 1rem;
}

.admin-image-preview img {
    aspect-ratio: 16 / 10;
    border-radius: 8px;
    display: block;
    object-fit: cover;
    width: 100%;
}

.admin-partner-cell {
    align-items: center;
    display: flex;
    gap: .85rem;
    min-width: 280px;
}

.admin-partner-cell img {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: 8px;
    height: 52px;
    object-fit: contain;
    padding: .35rem;
    width: 64px;
}

.admin-submission-tabs {
    background: var(--svf-navy);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .08);
    padding: .85rem;
}

.admin-detail-card {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
    overflow: hidden;
}

.admin-detail-row {
    display: grid;
    gap: .75rem;
    grid-template-columns: 180px minmax(0, 1fr);
    padding: 1rem 1.2rem;
}

.admin-detail-row + .admin-detail-row {
    border-top: 1px solid var(--svf-line);
}

.admin-detail-row span {
    color: var(--svf-blue);
    font-size: .78rem;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.admin-detail-row p {
    color: var(--svf-ink);
    margin: 0;
    overflow-wrap: anywhere;
}

.admin-security-note {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: 8px;
    padding: .85rem;
}

.admin-security-note span {
    color: var(--svf-blue);
    display: block;
    font-size: .74rem;
    font-weight: 900;
    letter-spacing: .08em;
    margin-bottom: .25rem;
    text-transform: uppercase;
}

.admin-security-note strong {
    color: var(--svf-navy);
    display: block;
}

.admin-module-card {
    background: #fff;
    border: 1px solid var(--svf-line);
    border-radius: var(--svf-radius);
    box-shadow: 0 12px 30px rgba(13, 45, 98, .07);
    padding: 1.25rem;
}

.admin-module-card span {
    background: var(--svf-sky);
    border-radius: 999px;
    color: var(--svf-blue);
    display: inline-flex;
    font-size: .72rem;
    font-weight: 900;
    letter-spacing: .06em;
    margin-bottom: 1rem;
    padding: .38rem .72rem;
    text-transform: uppercase;
}

.admin-module-card h2 {
    color: var(--svf-navy);
    font-size: 1.25rem;
    font-weight: 900;
}

.admin-module-card p {
    color: var(--svf-muted);
    margin-bottom: 0;
}

@media (max-width: 991.98px) {
    .navbar-brand img {
        height: 46px;
        max-width: 230px;
    }

    .hero {
        min-height: 660px;
    }

    .admin-page-heading {
        align-items: flex-start;
        flex-direction: column;
    }

    .admin-detail-row {
        grid-template-columns: 1fr;
    }

    .hero::before {
        background: linear-gradient(180deg, rgba(74, 144, 226, .22), rgba(255, 255, 255, 0));
    }

    .hero.has-photo::before {
        background:
            linear-gradient(rgba(4, 19, 45, .58), rgba(4, 19, 45, .58)),
            var(--hero-photo) 50% center / cover no-repeat;
    }

    .president-message-hero {
        padding: 3rem 0;
    }

    .president-portrait-shape {
        max-width: 360px;
    }

    .president-message-content {
        max-width: 100%;
        width: 100%;
    }

    .section {
        padding: 3rem 0;
    }

    .info-stat {
        background: rgba(255, 255, 255, .08);
        border: 1px solid rgba(255, 255, 255, .14);
        border-radius: var(--svf-radius);
        box-shadow: 0 14px 32px rgba(3, 15, 35, .14);
        padding: 1rem;
    }

    .impact-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .partners-grid {
        grid-template-columns: 1fr;
    }

    .about-nav-band {
        top: 72px;
    }

    .announcement-tabs {
        top: 72px;
    }

    .involved-tabs {
        top: 72px;
    }

    .history-timeline {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .history-timeline::before {
        display: none;
    }

    .club-directory-tools {
        align-items: stretch;
        grid-template-columns: 1fr;
    }

    .club-status-filter {
        align-self: start;
    }

    .hours-panel div {
        align-items: flex-start;
        flex-direction: column;
        gap: .25rem;
    }

    .hours-panel span {
        text-align: left;
    }
}

@media (max-width: 575.98px) {
    .hero {
        min-height: 620px;
    }

    .hero h1 {
        font-size: clamp(2rem, 12vw, 3rem);
        max-width: 100%;
        overflow-wrap: anywhere;
    }

    .hero p {
        font-size: 1.12rem;
    }

    .hero.has-photo::before {
        background:
            linear-gradient(rgba(4, 19, 45, .62), rgba(4, 19, 45, .62)),
            var(--hero-photo) 50% center / cover no-repeat;
    }

    .impact-grid {
        grid-template-columns: 1fr;
    }

    .partners-hero {
        padding: 3rem 0;
    }

    .partner-profile-card {
        grid-template-columns: 1fr;
        min-height: 0;
    }

    .partner-profile-logo {
        height: 112px;
    }

    .partner-priority-list {
        justify-content: flex-start;
    }

    .about-hero {
        min-height: 430px;
        padding: 3rem 0;
    }

    .governance-section::before,
    #clubs::before {
        opacity: .035;
        width: 260px;
        height: 260px;
    }

    .about-nav-band {
        position: static;
    }

    .announcement-tabs {
        position: static;
    }

    .involved-tabs {
        position: static;
    }

    .history-timeline,
    .org-chart {
        grid-template-columns: 1fr;
    }

    .authority-chart::after {
        display: none;
    }

    .org-general,
    .org-executive,
    .org-president,
    .org-vps,
    .org-secretariat,
    .org-judicial {
        grid-column: 1;
        grid-row: auto;
    }

    .org-node:not(:last-child)::after {
        background: var(--svf-blue);
        content: "";
        height: 1rem;
        left: 50%;
        opacity: .5;
        position: absolute;
        top: 100%;
        width: 2px;
    }

    .club-card-top,
    .club-card dl div {
        align-items: flex-start;
        flex-direction: column;
    }

    .club-status,
    .club-card dd {
        text-align: left;
    }

    .social-brand-list a {
        grid-template-columns: 46px minmax(0, 1fr);
    }

    .social-brand-list em {
        grid-column: 2;
    }

    .president-message-content blockquote {
        font-size: 1.12rem;
        line-height: 1.58;
    }

    .president-highlight {
        font-size: 1.1rem;
        line-height: 1.45;
    }

    .president-signature span {
        font-size: 1.45rem;
    }

    .president-signature strong {
        font-size: .95rem;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition: none !important;
    }
}
