/**
 * ACM Chapter Theme — Layout & Shared Section Styles
 */

/* ── Base Reset ── */
img { max-width: 100%; height: auto; display: block; }

/* ── Container ── */
.container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-8);
}

/* ── Sections ── */
.section {
    padding: var(--space-20) var(--space-8);
}
.section-light { background: var(--bg-light); }
.section-alt   { background: var(--bg-alt); }
.section-dark  { background: var(--blue-dark); color: var(--white); }

.section-inner {
    max-width: var(--container);
    margin: 0 auto;
}

/* ── Hero ── */
.hero {
    position: relative;
    min-height: 520px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--blue-dark);
}
.hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
}
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(0, 30, 60, 0.88) 0%,
        rgba(0, 30, 60, 0.72) 50%,
        rgba(0, 30, 60, 0.28) 100%
    );
}
.hero-content {
    position: relative;
    z-index: 1;
    max-width: var(--container);
    margin: 0 auto;
    padding: var(--space-20) var(--space-8);
    width: 100%;
}
.hero-eyebrow {
    display: inline-block;
    background: var(--gold);
    color: var(--blue-dark);
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-5);
}
.hero h1 { color: var(--white); max-width: 620px; margin-bottom: var(--space-5); }
.hero p  { color: rgba(255,255,255,0.85); max-width: 540px; margin-bottom: var(--space-8); font-weight: 300; }
.hero-btns { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ── Cards ── */
.card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-8);
    transition: box-shadow var(--transition-md), transform var(--transition-md);
}
.card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}
.card-top-accent { border-top: 4px solid var(--blue); }

/* ── Pillars Grid ── */
.pillars-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}
.pillar-icon { font-size: 36px; margin-bottom: var(--space-4); display: block; }

/* ── Membership ── */
.membership-grid {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: var(--space-16);
    align-items: start;
}
.membership-card {
    background: var(--blue-dark);
    border-radius: var(--radius-lg);
    padding: 44px var(--space-8);
    text-align: center;
    color: var(--white);
    position: sticky;
    top: 90px;
}
.membership-card h3 { color: var(--white); margin-bottom: var(--space-2); }
.membership-card .subtitle { font-size: var(--text-sm); color: rgba(255,255,255,0.55); margin-bottom: var(--space-6); }
.price-amount { font-family: var(--font-serif); font-size: 52px; font-weight: 900; color: var(--gold); line-height: 1; }
.price-period { font-size: 14px; color: rgba(255,255,255,0.55); margin-top: var(--space-1); margin-bottom: var(--space-6); }
.card-divider { border: none; border-top: 1px solid rgba(255,255,255,0.12); margin: var(--space-6) 0; }
.card-note { font-size: 12.5px; color: rgba(255,255,255,0.50); line-height: 1.6; }

/* ── Benefits List ── */
.benefits-list {
    list-style: none;
    padding: 0;
    margin: var(--space-6) 0 var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.benefits-list li {
    display: flex;
    gap: var(--space-3);
    font-size: 15.5px;
    line-height: 1.55;
}
.check-icon {
    width: 24px; height: 24px; min-width: 24px;
    background: var(--blue);
    border-radius: 50%;
    color: var(--white);
    font-size: var(--text-sm);
    display: flex; align-items: center; justify-content: center;
    margin-top: 1px;
}

/* ── Events ── */
.events-list { display: flex; flex-direction: column; gap: var(--space-4); }
.event-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-left: 5px solid var(--blue);
    border-radius: var(--radius-sm);
    padding: var(--space-6) var(--space-8);
    display: grid;
    grid-template-columns: 88px 1fr auto;
    align-items: center;
    gap: var(--space-6);
    transition: box-shadow var(--transition-md), transform var(--transition);
}
.event-card:hover {
    box-shadow: var(--shadow);
    transform: translateX(4px);
}
.event-date-box {
    text-align: center;
    background: var(--blue-dark);
    border-radius: var(--radius);
    padding: var(--space-3) var(--space-2);
    color: var(--white);
}
.event-date-box .month {
    font-size: 10.5px; font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase;
    color: var(--gold); display: block;
}
.event-date-box .day {
    font-family: var(--font-serif);
    font-size: 32px; font-weight: 900;
    line-height: 1; display: block;
}
.event-date-box .year {
    font-size: 11px; color: rgba(255,255,255,0.50);
    display: block; margin-top: 2px;
}
.event-info h3 { font-family: var(--font-sans); font-size: 16.5px; font-weight: 700; color: var(--blue-dark); margin-bottom: var(--space-2); line-height: 1.4; }
.event-info p  { font-size: var(--text-sm); color: var(--text-muted); margin-bottom: var(--space-2); line-height: 1.55; }
.event-meta    { display: flex; gap: var(--space-4); font-size: var(--text-sm); color: var(--text-muted); flex-wrap: wrap; }
.events-footer { text-align: center; margin-top: var(--space-10); }

/* ── Page Hero (inner pages) ── */
.page-hero {
    background: var(--blue-dark);
    padding: var(--space-16) var(--space-8);
    text-align: center;
}
.page-hero-inner {
    max-width: var(--container);
    margin: 0 auto;
}
.page-hero .eyebrow { color: var(--gold); margin-bottom: var(--space-2); }
.page-hero h1 { color: var(--white); font-size: var(--text-hero); margin-bottom: var(--space-4); }
.page-hero p  { color: rgba(255,255,255,0.75); font-size: var(--text-md); max-width: 560px; margin: 0 auto; }

/* ── Past events — muted style ── */
.event-card--past {
    opacity: 0.70;
    border-left-color: var(--gray-400);
}
.event-card--past .event-date-box { background: var(--gray-600); }
.event-card--past:hover { opacity: 1; }

/* ── Empty state ── */
.events-empty {
    background: var(--bg-light);
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    padding: var(--space-12) var(--space-8);
    text-align: center;
    color: var(--text-muted);
    font-size: var(--text-md);
}

/* ── Events Pagination ── */
.events-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    margin-top: var(--space-8);
}
.pagination-btn {
    display: inline-block;
    padding: var(--space-2) var(--space-5);
    border: 2px solid var(--blue);
    border-radius: var(--radius);
    color: var(--blue);
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--text-sm);
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.pagination-btn:hover { background: var(--blue); color: var(--white); }
.pagination-btn--disabled {
    border-color: var(--border);
    color: var(--text-muted);
    cursor: default;
    pointer-events: none;
}
.pagination-info {
    font-size: var(--text-sm);
    color: var(--text-muted);
    font-family: var(--font-sans);
}

/* ── Single Event Page ── */
.event-single-hero .page-hero-inner { max-width: 760px; }
.event-single-date {
    color: rgba(255,255,255,0.80);
    font-size: var(--text-md);
    margin-top: var(--space-2);
}

.event-single-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: var(--space-12);
    align-items: start;
}

.event-single-content {
    font-size: var(--text-md);
    line-height: 1.75;
    color: var(--text-body);
}
.event-single-content h2,
.event-single-content h3 { color: var(--blue-dark); margin-top: var(--space-8); }
.event-single-content p  { margin-bottom: var(--space-4); }

.event-sidebar-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-6);
    position: sticky;
    top: 100px;
}
.event-sidebar-card h3 {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--blue-dark);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--blue-light);
}
.sidebar-detail {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
    align-items: flex-start;
}
.detail-icon { font-size: 18px; line-height: 1.4; flex-shrink: 0; }
.sidebar-detail div { display: flex; flex-direction: column; gap: 2px; }
.sidebar-detail strong { font-size: var(--text-sm); font-weight: 700; color: var(--blue-dark); }
.sidebar-detail span  { font-size: var(--text-sm); color: var(--text-muted); }

.sidebar-past-note {
    text-align: center;
    color: var(--text-muted);
    font-size: var(--text-sm);
    padding: var(--space-3);
    background: var(--bg-light);
    border-radius: var(--radius);
    margin-top: var(--space-4);
}

.event-back-link {
    display: inline-block;
    margin-top: var(--space-4);
    font-size: var(--text-sm);
    color: var(--blue);
    text-decoration: none;
    font-weight: 600;
}
.event-back-link:hover { text-decoration: underline; }

/* ── Single event responsive ── */
@media (max-width: 800px) {
    .event-single-layout {
        grid-template-columns: 1fr;
    }
    .event-sidebar-card { position: static; }
}

/* ── About Page ── */
.about-mission-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-12);
    align-items: start;
}
.about-mission-text h2 { font-size: var(--text-xl); color: var(--blue-dark); margin-bottom: var(--space-4); }
.about-mission-text p  { font-size: var(--text-md); color: var(--text-body); line-height: 1.75; margin-bottom: var(--space-4); }

.values-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}
.value-item {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
}
.value-icon { font-size: 22px; flex-shrink: 0; line-height: 1.3; }
.value-item strong { display: block; font-family: var(--font-sans); font-weight: 700; color: var(--blue-dark); margin-bottom: 4px; }
.value-item p { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.6; margin: 0; }

.about-acm-layout {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--space-12);
    align-items: center;
}
.about-acm-logo img { width: 100%; max-width: 180px; }
.about-acm-text h2  { font-size: var(--text-xl); color: var(--blue-dark); margin-bottom: var(--space-4); }
.about-acm-text p   { font-size: var(--text-md); color: var(--text-body); line-height: 1.75; margin-bottom: var(--space-4); }
.about-acm-links    { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-6); }

.section-cta {
    background: var(--blue-dark);
    text-align: center;
}
.section-cta .eyebrow { color: var(--gold); }
.section-cta h2 { color: var(--white); font-size: var(--text-xl); margin-bottom: var(--space-4); }
.section-cta p  { color: rgba(255,255,255,0.75); font-size: var(--text-md); max-width: 580px; margin: 0 auto var(--space-8); line-height: 1.7; }
.cta-btns { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }

.btn-outline       { border: 2px solid var(--blue); color: var(--blue); background: transparent; padding: var(--space-3) var(--space-6); border-radius: var(--radius); font-family: var(--font-sans); font-weight: 700; font-size: var(--text-sm); text-decoration: none; transition: background 0.2s, color 0.2s; }
.btn-outline:hover { background: var(--blue); color: var(--white); }
.btn-outline-light       { border: 2px solid rgba(255,255,255,0.6); color: var(--white); background: transparent; padding: var(--space-3) var(--space-6); border-radius: var(--radius); font-family: var(--font-sans); font-weight: 700; font-size: var(--text-sm); text-decoration: none; transition: background 0.2s; }
.btn-outline-light:hover { background: rgba(255,255,255,0.1); }

/* ── About page responsive ── */
@media (max-width: 860px) {
    .about-mission-layout,
    .about-acm-layout { grid-template-columns: 1fr; }
    .about-acm-logo { text-align: center; }
    .about-acm-logo img { max-width: 140px; }
}

/* ── Officers Page ── */
.role-selector {
    display: flex;
    gap: 12px;
    justify-content: center;
    flex-wrap: wrap;
    margin-bottom: 40px;
}
.role-btn {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    background: var(--white);
    border: 2px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 16px 20px;
    cursor: pointer;
    transition: all 0.2s ease;
    min-width: 130px;
    position: relative;
    font-family: var(--font-sans);
}
.role-btn:hover {
    border-color: var(--blue);
    box-shadow: var(--shadow);
    transform: translateY(-2px);
}
.role-btn.active {
    border-color: var(--blue-dark);
    background: var(--blue-dark);
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
}
.role-btn.active .role-btn-name  { color: var(--white); }
.role-btn.active .role-btn-title { color: var(--gold); }
.role-btn.active::after {
    content: '';
    position: absolute;
    bottom: -9px; left: 50%;
    transform: translateX(-50%);
    width: 0; height: 0;
    border-left: 9px solid transparent;
    border-right: 9px solid transparent;
    border-top: 9px solid var(--blue-dark);
}
.role-btn-avatar {
    width: 54px; height: 54px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-serif);
    font-size: 20px; font-weight: 700;
    color: var(--white);
    overflow: hidden;
}
.role-btn-avatar img { width: 100%; height: 100%; object-fit: cover; }
.avatar-A { background: linear-gradient(135deg, #002855, #0062A3); }
.avatar-B { background: linear-gradient(135deg, #0062A3, #1a7cbf); }
.avatar-C { background: linear-gradient(135deg, #004a7c, #0062A3); }
.avatar-D { background: linear-gradient(135deg, #003566, #0062A3); }

.role-btn-name  { font-size: 13px; font-weight: 700; color: var(--blue-dark); text-align: center; line-height: 1.2; transition: color 0.2s; }
.role-btn-title { font-size: 11px; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; color: var(--blue); text-align: center; transition: color 0.2s; }

.officer-panels { position: relative; }
.officer-panel  { display: none; }
.officer-panel.active {
    display: grid;
    grid-template-columns: 300px 1fr;
    background: var(--white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    animation: officerFadeIn 0.3s ease forwards;
}
@keyframes officerFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to   { opacity: 1; transform: translateY(0); }
}

.officer-identity {
    background: var(--blue-dark);
    padding: 48px 32px;
    display: flex; flex-direction: column;
    align-items: center; text-align: center;
    gap: 16px;
    position: relative; overflow: hidden;
}
.officer-identity::before { content: ''; position: absolute; bottom: -60px; right: -60px; width: 200px; height: 200px; border-radius: 50%; background: rgba(255,255,255,0.04); }
.officer-identity::after  { content: ''; position: absolute; top: -40px; left: -40px; width: 150px; height: 150px; border-radius: 50%; background: rgba(247,168,0,0.07); }

.identity-avatar {
    width: 110px; height: 110px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--font-serif); font-size: 38px; font-weight: 700;
    color: var(--white);
    border: 3px solid rgba(255,255,255,0.15);
    position: relative; z-index: 1;
    overflow: hidden; flex-shrink: 0;
}
.identity-avatar img { width: 100%; height: 100%; object-fit: cover; }
.identity-name { font-family: var(--font-serif); font-size: 20px; font-weight: 700; color: var(--white); line-height: 1.3; position: relative; z-index: 1; }
.identity-role { display: inline-block; font-size: 11px; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: var(--blue-dark); background: var(--gold); padding: 5px 14px; border-radius: 20px; position: relative; z-index: 1; }

.identity-links { display: flex; flex-direction: column; gap: 8px; width: 100%; margin-top: 8px; position: relative; z-index: 1; }
.identity-link { display: flex; align-items: center; justify-content: center; gap: 8px; padding: 9px 14px; border-radius: var(--radius); font-size: 12px; font-weight: 600; text-decoration: none; transition: background 0.15s; }
.link-email    { background: rgba(255,255,255,0.10); color: rgba(255,255,255,0.85); border: 1px solid rgba(255,255,255,0.15); }
.link-email:hover { background: rgba(255,255,255,0.18); }
.link-linkedin { background: #0077B5; color: var(--white); }
.link-linkedin:hover { background: #005e8e; }

.officer-details { padding: 48px 44px; }
.detail-bio { font-size: 15.5px; color: var(--text-body); line-height: 1.8; margin-bottom: 32px; padding-bottom: 32px; border-bottom: 1px solid var(--border); }
.detail-bio p { margin-bottom: var(--space-3); }
.detail-section-label { font-size: 10px; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--blue); margin-bottom: 12px; }
.detail-duties { font-size: 15px; color: var(--text-muted); line-height: 1.75; padding-left: 16px; border-left: 3px solid var(--gold); }

@media (max-width: 700px) {
    .officer-panel.active { grid-template-columns: 1fr; }
    .officer-identity { padding: 36px 24px; }
    .officer-details  { padding: 32px 24px; }
    .role-btn { min-width: 90px; padding: 12px; }
}

**
 * ACM Chapter Theme — Layout & Shared Section Styles
 */

/* ── Base Reset ── */
img { max-width: 100%; height: auto; display: block; }

/* ── Container ── */
.container {
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--space-8);
}

/* ── Sections ── */
.section {
    padding: var(--space-20) var(--space-8);
}
.section-light { background: var(--bg-light); }
.section-alt   { background: var(--bg-alt); }
.section-dark  { background: var(--blue-dark); color: var(--white); }

.section-inner {
    max-width: var(--container);
    margin: 0 auto;
}

/* ── Hero ── */
.hero {
    position: relative;
    min-height: 520px;
    display: flex;
    align-items: center;
    overflow: hidden;
    background-color: var(--blue-dark);
}
.hero-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center right;
    background-repeat: no-repeat;
}
.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(0, 30, 60, 0.88) 0%,
        rgba(0, 30, 60, 0.72) 50%,
        rgba(0, 30, 60, 0.28) 100%
    );
}
.hero-content {
    position: relative;
    z-index: 1;
    max-width: var(--container);
    margin: 0 auto;
    padding: var(--space-20) var(--space-8);
    width: 100%;
}
.hero-eyebrow {
    display: inline-block;
    background: var(--gold);
    color: var(--blue-dark);
    font-size: var(--text-xs);
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    padding: 5px 14px;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-5);
}
.hero h1 { color: var(--white); max-width: 620px; margin-bottom: var(--space-5); }
.hero p  { color: rgba(255,255,255,0.85); max-width: 540px; margin-bottom: var(--space-8); font-weight: 300; }
.hero-btns { display: flex; gap: var(--space-4); flex-wrap: wrap; }

/* ── Cards ── */
.card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-8);
    transition: box-shadow var(--transition-md), transform var(--transition-md);
}
.card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-4px);
}
.card-top-accent { border-top: 4px solid var(--blue); }

/* ── Pillars Grid ── */
.pillars-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
}
.pillar-icon { font-size: 36px; margin-bottom: var(--space-4); display: block; }

/* ── Membership ── */
.membership-grid {
    display: grid;
    grid-template-columns: 1fr 420px;
    gap: var(--space-16);
    align-items: start;
}
.membership-card {
    background: var(--blue-dark);
    border-radius: var(--radius-lg);
    padding: 44px var(--space-8);
    text-align: center;
    color: var(--white);
    position: sticky;
    top: 90px;
}
.membership-card h3 { color: var(--white); margin-bottom: var(--space-2); }
.membership-card .subtitle { font-size: var(--text-sm); color: rgba(255,255,255,0.55); margin-bottom: var(--space-6); }
.price-amount { font-family: var(--font-serif); font-size: 52px; font-weight: 900; color: var(--gold); line-height: 1; }
.price-period { font-size: 14px; color: rgba(255,255,255,0.55); margin-top: var(--space-1); margin-bottom: var(--space-6); }
.card-divider { border: none; border-top: 1px solid rgba(255,255,255,0.12); margin: var(--space-6) 0; }
.card-note { font-size: 12.5px; color: rgba(255,255,255,0.50); line-height: 1.6; }

/* ── Benefits List ── */
.benefits-list {
    list-style: none;
    padding: 0;
    margin: var(--space-6) 0 var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}
.benefits-list li {
    display: flex;
    gap: var(--space-3);
    font-size: 15.5px;
    line-height: 1.55;
}
.check-icon {
    width: 24px; height: 24px; min-width: 24px;
    background: var(--blue);
    border-radius: 50%;
    color: var(--white);
    font-size: var(--text-sm);
    display: flex; align-items: center; justify-content: center;
    margin-top: 1px;
}

/* ── Events ── */
.events-list { display: flex; flex-direction: column; gap: var(--space-4); }
.event-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-left: 5px solid var(--blue);
    border-radius: var(--radius-sm);
    padding: var(--space-6) var(--space-8);
    display: grid;
    grid-template-columns: 88px 1fr auto;
    align-items: center;
    gap: var(--space-6);
    transition: box-shadow var(--transition-md), transform var(--transition);
}
.event-card:hover {
    box-shadow: var(--shadow);
    transform: translateX(4px);
}
.event-date-box {
    text-align: center;
    background: var(--blue-dark);
    border-radius: var(--radius);
    padding: var(--space-3) var(--space-2);
    color: var(--white);
}
.event-date-box .month {
    font-size: 10.5px; font-weight: 700;
    letter-spacing: 2px; text-transform: uppercase;
    color: var(--gold); display: block;
}
.event-date-box .day {
    font-family: var(--font-serif);
    font-size: 32px; font-weight: 900;
    line-height: 1; display: block;
}
.event-date-box .year {
    font-size: 11px; color: rgba(255,255,255,0.50);
    display: block; margin-top: 2px;
}
.event-info h3 { font-family: var(--font-sans); font-size: 16.5px; font-weight: 700; color: var(--blue-dark); margin-bottom: var(--space-2); line-height: 1.4; }
.event-info p  { font-size: var(--text-sm); color: var(--text-muted); margin-bottom: var(--space-2); line-height: 1.55; }
.event-meta    { display: flex; gap: var(--space-4); font-size: var(--text-sm); color: var(--text-muted); flex-wrap: wrap; }
.events-footer { text-align: center; margin-top: var(--space-10); }

/* ── Page Hero (inner pages) ── */
.page-hero {
    background: var(--blue-dark);
    padding: var(--space-16) var(--space-8);
    text-align: center;
}
.page-hero-inner {
    max-width: var(--container);
    margin: 0 auto;
}
.page-hero .eyebrow { color: var(--gold); margin-bottom: var(--space-2); }
.page-hero h1 { color: var(--white); font-size: var(--text-hero); margin-bottom: var(--space-4); }
.page-hero p  { color: rgba(255,255,255,0.75); font-size: var(--text-md); max-width: 560px; margin: 0 auto; }

/* ── Past events — muted style ── */
.event-card--past {
    opacity: 0.70;
    border-left-color: var(--gray-400);
}
.event-card--past .event-date-box { background: var(--gray-600); }
.event-card--past:hover { opacity: 1; }

/* ── Empty state ── */
.events-empty {
    background: var(--bg-light);
    border: 1px dashed var(--border);
    border-radius: var(--radius);
    padding: var(--space-12) var(--space-8);
    text-align: center;
    color: var(--text-muted);
    font-size: var(--text-md);
}

/* ── Events Pagination ── */
.events-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-4);
    margin-top: var(--space-8);
}
.pagination-btn {
    display: inline-block;
    padding: var(--space-2) var(--space-5);
    border: 2px solid var(--blue);
    border-radius: var(--radius);
    color: var(--blue);
    font-family: var(--font-sans);
    font-weight: 600;
    font-size: var(--text-sm);
    text-decoration: none;
    transition: background 0.2s, color 0.2s;
}
.pagination-btn:hover { background: var(--blue); color: var(--white); }
.pagination-btn--disabled {
    border-color: var(--border);
    color: var(--text-muted);
    cursor: default;
    pointer-events: none;
}
.pagination-info {
    font-size: var(--text-sm);
    color: var(--text-muted);
    font-family: var(--font-sans);
}

/* ── Single Event Page ── */
.event-single-hero .page-hero-inner { max-width: 760px; }
.event-single-date {
    color: rgba(255,255,255,0.80);
    font-size: var(--text-md);
    margin-top: var(--space-2);
}

.event-single-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    gap: var(--space-12);
    align-items: start;
}

.event-single-content {
    font-size: var(--text-md);
    line-height: 1.75;
    color: var(--text-body);
}
.event-single-content h2,
.event-single-content h3 { color: var(--blue-dark); margin-top: var(--space-8); }
.event-single-content p  { margin-bottom: var(--space-4); }

.event-sidebar-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-6);
    position: sticky;
    top: 100px;
}
.event-sidebar-card h3 {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--blue-dark);
    margin-bottom: var(--space-5);
    padding-bottom: var(--space-3);
    border-bottom: 2px solid var(--blue-light);
}
.sidebar-detail {
    display: flex;
    gap: var(--space-3);
    margin-bottom: var(--space-4);
    align-items: flex-start;
}
.detail-icon { font-size: 18px; line-height: 1.4; flex-shrink: 0; }
.sidebar-detail div { display: flex; flex-direction: column; gap: 2px; }
.sidebar-detail strong { font-size: var(--text-sm); font-weight: 700; color: var(--blue-dark); }
.sidebar-detail span  { font-size: var(--text-sm); color: var(--text-muted); }

.sidebar-past-note {
    text-align: center;
    color: var(--text-muted);
    font-size: var(--text-sm);
    padding: var(--space-3);
    background: var(--bg-light);
    border-radius: var(--radius);
    margin-top: var(--space-4);
}

.event-back-link {
    display: inline-block;
    margin-top: var(--space-4);
    font-size: var(--text-sm);
    color: var(--blue);
    text-decoration: none;
    font-weight: 600;
}
.event-back-link:hover { text-decoration: underline; }

/* ── Single event responsive ── */
@media (max-width: 800px) {
    .event-single-layout {
        grid-template-columns: 1fr;
    }
    .event-sidebar-card { position: static; }
}

/* ── About Page ── */
.about-mission-layout {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: var(--space-12);
    align-items: start;
}
.about-mission-text h2 { font-size: var(--text-xl); color: var(--blue-dark); margin-bottom: var(--space-4); }
.about-mission-text p  { font-size: var(--text-md); color: var(--text-body); line-height: 1.75; margin-bottom: var(--space-4); }

.values-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-6);
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}
.value-item {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
}
.value-icon { font-size: 22px; flex-shrink: 0; line-height: 1.3; }
.value-item strong { display: block; font-family: var(--font-sans); font-weight: 700; color: var(--blue-dark); margin-bottom: 4px; }
.value-item p { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.6; margin: 0; }

.about-acm-layout {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: var(--space-12);
    align-items: center;
}
.about-acm-logo img { width: 100%; max-width: 180px; }
.about-acm-text h2  { font-size: var(--text-xl); color: var(--blue-dark); margin-bottom: var(--space-4); }
.about-acm-text p   { font-size: var(--text-md); color: var(--text-body); line-height: 1.75; margin-bottom: var(--space-4); }
.about-acm-links    { display: flex; gap: var(--space-3); flex-wrap: wrap; margin-top: var(--space-6); }

.section-cta {
    background: var(--blue-dark);
    text-align: center;
}
.section-cta .eyebrow { color: var(--gold); }
.section-cta h2 { color: var(--white); font-size: var(--text-xl); margin-bottom: var(--space-4); }
.section-cta p  { color: rgba(255,255,255,0.75); font-size: var(--text-md); max-width: 580px; margin: 0 auto var(--space-8); line-height: 1.7; }
.cta-btns { display: flex; gap: var(--space-4); justify-content: center; flex-wrap: wrap; }

.btn-outline       { border: 2px solid var(--blue); color: var(--blue); background: transparent; padding: var(--space-3) var(--space-6); border-radius: var(--radius); font-family: var(--font-sans); font-weight: 700; font-size: var(--text-sm); text-decoration: none; transition: background 0.2s, color 0.2s; }
.btn-outline:hover { background: var(--blue); color: var(--white); }
.btn-outline-light       { border: 2px solid rgba(255,255,255,0.6); color: var(--white); background: transparent; padding: var(--space-3) var(--space-6); border-radius: var(--radius); font-family: var(--font-sans); font-weight: 700; font-size: var(--text-sm); text-decoration: none; transition: background 0.2s; }
.btn-outline-light:hover { background: rgba(255,255,255,0.1); }

/* ── About page responsive ── */
@media (max-width: 860px) {
    .about-mission-layout,
    .about-acm-layout { grid-template-columns: 1fr; }
    .about-acm-logo { text-align: center; }
    .about-acm-logo img { max-width: 140px; }
}

/* ── Officers Page ── */
.officers-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(480px, 1fr));
    gap: var(--space-8);
}
.officer-card {
    display: flex;
    gap: var(--space-6);
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: var(--space-6);
    transition: box-shadow 0.2s;
}
.officer-card:hover { box-shadow: 0 4px 20px rgba(0,0,0,0.08); }

.officer-photo { flex-shrink: 0; }
.officer-photo img {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    object-fit: cover;
    border: 3px solid var(--blue-light);
}
.officer-photo-placeholder {
    width: 110px;
    height: 110px;
    border-radius: 50%;
    background: var(--blue-dark);
    display: flex;
    align-items: center;
    justify-content: center;
}
.officer-photo-placeholder span {
    font-size: 40px;
    font-weight: 700;
    color: var(--white);
    font-family: var(--font-serif);
    line-height: 1;
}

.officer-info { flex: 1; min-width: 0; }
.officer-info h3 {
    font-family: var(--font-sans);
    font-size: var(--text-md);
    font-weight: 700;
    color: var(--blue-dark);
    margin-bottom: var(--space-1);
}
.officer-title {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: 600;
    color: var(--blue);
    background: var(--blue-light);
    padding: 2px 10px;
    border-radius: 20px;
    margin-bottom: var(--space-3);
}
.officer-bio { font-size: var(--text-sm); color: var(--text-body); line-height: 1.65; margin-bottom: var(--space-3); }
.officer-bio p { margin-bottom: var(--space-2); }

.officer-duties { margin-bottom: var(--space-3); }
.officer-duties strong { display: block; font-size: var(--text-sm); font-weight: 700; color: var(--blue-dark); margin-bottom: 4px; }
.officer-duties p { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.6; margin: 0; }

.officer-links { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-3); }
.officer-link {
    font-size: var(--text-sm);
    color: var(--blue);
    text-decoration: none;
    font-weight: 500;
}
.officer-link:hover { text-decoration: underline; }

/* ── Officers responsive ── */
@media (max-width: 600px) {
    .officers-grid { grid-template-columns: 1fr; }
    .officer-card { flex-direction: column; align-items: center; text-align: center; }
    .officer-links { justify-content: center; }
}
/* ── Contact Page ── */
.contact-cards-layout {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--space-6);
}
.contact-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    display: flex;
    flex-direction: column;
    gap: var(--space-3);
    transition: box-shadow 0.2s, transform 0.2s;
}
.contact-card:hover {
    box-shadow: var(--shadow);
    transform: translateY(-2px);
}
.contact-card-icon { font-size: 36px; line-height: 1; margin-bottom: var(--space-2); }
.contact-card h3 { font-family: var(--font-sans); font-size: var(--text-lg); font-weight: 700; color: var(--blue-dark); }
.contact-card p  { font-size: var(--text-base); color: var(--text-muted); line-height: 1.7; flex: 1; }
.contact-card-action {
    display: inline-block;
    margin-top: var(--space-2);
    font-size: var(--text-sm);
    font-weight: 700;
    color: var(--blue);
    text-decoration: none;
    border-bottom: 2px solid var(--blue-light);
    padding-bottom: 2px;
    transition: border-color 0.15s, color 0.15s;
}
.contact-card-action:hover { color: var(--blue-dark); border-color: var(--blue); }

@media (max-width: 700px) {
    .contact-cards-layout { grid-template-columns: 1fr; }
}

/* ── Membership Page ── */
.membership-hero p { max-width: 620px; }

.membership-notice {
    background: #FEF9E7;
    border-top: 3px solid var(--gold);
    border-bottom: 1px solid #F0D080;
    padding: var(--space-5) var(--space-8);
}
.membership-notice-inner {
    max-width: var(--container);
    margin: 0 auto;
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
}
.notice-icon { font-size: 20px; flex-shrink: 0; line-height: 1.5; }
.membership-notice p { font-size: var(--text-sm); color: var(--gray-900); line-height: 1.7; margin: 0; }
.membership-notice a { color: var(--blue); }

/* Benefits grid */
.membership-benefits-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--space-6);
    margin-top: var(--space-10);
}
.membership-benefit {
    display: flex;
    gap: var(--space-4);
    align-items: flex-start;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-6);
    transition: box-shadow 0.2s, transform 0.2s;
}
.membership-benefit:hover { box-shadow: var(--shadow); transform: translateY(-2px); }
.benefit-icon { font-size: 28px; flex-shrink: 0; line-height: 1; }
.membership-benefit h3 { font-family: var(--font-sans); font-size: var(--text-base); font-weight: 700; color: var(--blue-dark); margin-bottom: var(--space-2); }
.membership-benefit p  { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.65; margin: 0; }

/* Transparency layout */
.membership-transparency-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: var(--space-12);
    align-items: start;
}
.transparency-text h2 { font-size: var(--text-xl); color: var(--blue-dark); margin-bottom: var(--space-5); }
.transparency-text p  { font-size: var(--text-md); color: var(--text-body); line-height: 1.8; margin-bottom: var(--space-4); }

.transparency-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: var(--space-8);
    text-align: center;
    box-shadow: var(--shadow);
    position: sticky;
    top: 100px;
}
.pricing-label  { font-size: var(--text-sm); font-weight: 700; color: var(--blue); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: var(--space-3); }
.pricing-amount { font-family: var(--font-serif); font-size: 56px; font-weight: 900; color: var(--blue-dark); line-height: 1; }
.pricing-period { font-size: var(--text-sm); color: var(--text-muted); margin-bottom: var(--space-2); }
.pricing-note   { font-size: var(--text-sm); color: var(--text-muted); background: var(--bg-light); border-radius: var(--radius); padding: var(--space-2) var(--space-4); margin-bottom: var(--space-4); }
.pricing-divider { border: none; border-top: 1px solid var(--border); margin: var(--space-5) 0; }
.pricing-includes { list-style: none; text-align: left; margin-bottom: var(--space-6); }
.pricing-includes li { font-size: var(--text-sm); color: var(--text-body); padding: var(--space-2) 0; border-bottom: 1px solid var(--border); }
.pricing-includes li:last-child { border-bottom: none; }
.pricing-footer { font-size: 12px; color: var(--text-muted); margin-top: var(--space-3); margin-bottom: 0; }

/* FAQ */
.membership-faq-layout {
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: var(--space-12);
    align-items: start;
}
.membership-faq-layout h2 { font-size: var(--text-xl); color: var(--blue-dark); margin-top: var(--space-3); }
.faq-list { display: flex; flex-direction: column; gap: 0; }
.faq-item { padding: var(--space-6) 0; border-bottom: 1px solid var(--border); }
.faq-item:first-child { padding-top: 0; }
.faq-item h4 { font-family: var(--font-sans); font-size: var(--text-base); font-weight: 700; color: var(--blue-dark); margin-bottom: var(--space-2); }
.faq-item p  { font-size: var(--text-sm); color: var(--text-muted); line-height: 1.7; margin: 0; }
.faq-item a  { color: var(--blue); }

@media (max-width: 900px) {
    .membership-benefits-grid       { grid-template-columns: repeat(2, 1fr); }
    .membership-transparency-layout { grid-template-columns: 1fr; }
    .transparency-card              { position: static; }
    .membership-faq-layout          { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
    .membership-benefits-grid { grid-template-columns: 1fr; }
    .membership-notice        { padding: var(--space-4); }
}

/* ── Payment Placeholder ── */
.payment-placeholder {
    max-width: 560px;
    margin: var(--space-10) auto 0;
    background: var(--white);
    border: 2px dashed var(--gray-200);
    border-radius: var(--radius-lg);
    padding: var(--space-10) var(--space-8);
    text-align: center;
}
.payment-placeholder-icon { font-size: 48px; margin-bottom: var(--space-4); }
.payment-placeholder h3 { font-family: var(--font-sans); font-size: var(--text-lg); font-weight: 700; color: var(--blue-dark); margin-bottom: var(--space-3); }
.payment-placeholder p  { font-size: var(--text-base); color: var(--text-muted); line-height: 1.7; margin-bottom: var(--space-4); }
.payment-placeholder a  { color: var(--blue); font-weight: 600; }
.payment-divider {
    display: flex;
    align-items: center;
    gap: var(--space-4);
    margin: var(--space-6) 0;
}
.payment-divider::before,
.payment-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--border);
}
.payment-divider span { font-size: var(--text-sm); color: var(--text-muted); font-weight: 600; white-space: nowrap; }
