@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;0,900;1,400;1,700&family=Crimson+Text:ital,wght@0,400;0,600;1,400;1,600&family=Caveat:wght@500;700&display=swap');

:root {
  --pg: #f0e8d8;
  --ink: #1c100a;
  --red: #8b1a1a;
  --gold: #b8870a;
  --muted: #5c3d1e;
  --rule: #c8a060;
  --cream: #faf4e8;
  --max-w: 980px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 19px; }
body { font-family: 'Crimson Text', Georgia, serif; color: var(--ink); background-color: var(--pg); line-height: 1.85; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--red); text-decoration: none; }
a:hover { text-decoration: underline; }

.container { max-width: var(--max-w); margin: 0 auto; padding: 0 32px; }
.rule { border: none; border-top: 1px solid var(--rule); margin: 0; }
.rule-ink { border: none; border-top: 2.5px solid var(--ink); margin: 0; }

/* MASTHEAD */
.masthead-wrap { max-width: var(--max-w); margin: 0 auto; padding: 20px 32px 0; text-align: center; }
.masthead-meta { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); padding: 8px 0 5px; }
.masthead-chinese { font-family: 'Playfair Display', Georgia, serif; font-size: 56px; font-weight: 900; letter-spacing: 0.02em; color: var(--ink); line-height: 1.1; }
.masthead-chinese a { color: inherit; text-decoration: none; }
.masthead-english { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; letter-spacing: 0.24em; color: var(--red); text-transform: uppercase; padding: 5px 0 10px; }
.rule-pair { padding-bottom: 3px; }
.rule-pair .rule-ink { margin-bottom: 3px; }

/* NAV */
.nav-wrap { max-width: var(--max-w); margin: 0 auto; padding: 0 32px; }
nav.main-nav { display: flex; justify-content: center; flex-wrap: wrap; padding: 7px 0; align-items: stretch; }
nav.main-nav > a, .nav-group > .nav-top {
  font-family: 'Playfair Display', Georgia, serif; font-size: 13px; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--ink); text-decoration: none; padding: 4px 13px;
  border-right: 1px solid var(--rule); display: inline-flex; align-items: center; gap: 5px;
}
nav.main-nav > a:last-child, .nav-group:last-child > .nav-top { border-right: none; }
nav.main-nav > a:hover, nav.main-nav > a.active,
.nav-group:hover > .nav-top, .nav-group:focus-within > .nav-top, .nav-group > .nav-top.active { color: var(--red); text-decoration: none; }
.nav-group { position: relative; display: inline-flex; }
.nav-group > .nav-top { cursor: pointer; }
.nav-group > .nav-top .caret { font-size: 8px; line-height: 1; opacity: 0.7; }
.nav-drop {
  position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  min-width: 195px; background: var(--cream); border: 1px solid var(--rule);
  box-shadow: 0 8px 22px rgba(28, 16, 10, 0.20); padding: 6px 0; z-index: 60; display: none;
}
.nav-group:hover > .nav-drop, .nav-group:focus-within > .nav-drop { display: block; }
.nav-drop a {
  display: block; font-family: 'Playfair Display', Georgia, serif; font-size: 12.5px;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); text-decoration: none;
  padding: 8px 20px; white-space: nowrap; text-align: left; border-right: none;
}
.nav-drop a:hover, .nav-drop a.active { background: var(--pg); color: var(--red); text-decoration: none; }
.nav-toggle { display: none; width: 100%; background: none; border: 1px solid var(--rule); color: var(--ink); font-family: 'Playfair Display', Georgia, serif; text-transform: uppercase; letter-spacing: 0.14em; font-size: 13px; padding: 11px; margin: 6px 0; cursor: pointer; }
.nav-toggle:hover { color: var(--red); }
.lang-switch { display: flex; justify-content: flex-end; padding: 5px 0 0; gap: 16px; }
.lang-switch a { font-size: 13px; color: var(--muted); text-decoration: none; letter-spacing: 0.05em; }
.lang-switch a.active { color: var(--red); font-weight: 700; }
.lang-switch a:hover { color: var(--red); }

/* TYPOGRAPHY */
.kicker { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; display: block; }
.section-label { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; color: var(--muted); margin-bottom: 20px; display: block; }
.headline { font-family: 'Playfair Display', Georgia, serif; font-size: 40px; font-weight: 900; font-style: italic; line-height: 1.18; color: var(--ink); margin-bottom: 16px; }
.deck { font-family: 'Playfair Display', Georgia, serif; font-size: 17px; color: var(--muted); font-style: italic; line-height: 1.65; border-left: 2.5px solid var(--red); padding-left: 14px; margin-bottom: 20px; }
.body-text p { font-size: 20px; line-height: 1.9; margin-bottom: 16px; }
.pull-quote { margin: 24px 0; padding: 16px 24px; border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); text-align: center; }
.pull-quote p { font-family: 'Playfair Display', Georgia, serif; font-size: 21px; font-style: italic; line-height: 1.5; margin: 0 0 8px; }
.pull-quote cite { font-size: 13px; color: var(--muted); letter-spacing: 0.06em; font-style: normal; }
.hand { font-family: 'Caveat', cursive; }

.welcome-banner { text-align: center; background: var(--cream); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); padding: 15px 18px; margin: 16px 0 0; }
.welcome-banner-head { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 21px; color: var(--red); margin: 0; }
.welcome-intro { max-width: 660px; margin: 8px auto 0; }
.welcome-intro p { font-family: 'Crimson Text', Georgia, serif; font-size: 17px; line-height: 1.6; color: var(--muted); margin: 0; }
.welcome-intro a { color: var(--red); }

/* NEWS / ANNOUNCEMENTS */
.news-item { display: grid; grid-template-columns: 200px 1fr; gap: 26px; padding: 28px 0; border-bottom: 1px solid var(--rule); align-items: start; }
.news-item:last-child { border-bottom: none; }
.news-item > img { width: 100%; height: auto; border: 1px solid var(--rule); box-shadow: 2px 3px 8px rgba(28,16,10,0.16); }
.news-item .news-date { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--gold); display: block; margin-bottom: 6px; }
.news-item h2 { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 27px; line-height: 1.2; margin-bottom: 12px; }
.news-item .news-body p { font-size: 18px; line-height: 1.8; margin-bottom: 12px; }
.news-item:only-child, .news-item.no-img { grid-template-columns: 1fr; }
@media (max-width: 720px) { .news-item { grid-template-columns: 1fr; } }

/* JUMP BAR (page navigation) */
.jump-bar { background: var(--cream); border: 1px solid var(--rule); padding: 12px 18px; margin-bottom: 30px; line-height: 2.1; }
.jump-bar .jump-label { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin-right: 8px; }
.jump-bar a { display: inline-block; font-family: 'Playfair Display', Georgia, serif; font-size: 15px; color: var(--red); padding: 2px 9px; white-space: nowrap; }
.jump-bar a:hover { text-decoration: underline; }
.jump-bar.az a { font-size: 17px; padding: 2px 7px; letter-spacing: 0.03em; }
[id] { scroll-margin-top: 16px; }

/* PAGE HEADER */
.page-header { padding: 36px 0 24px; border-bottom: 2.5px solid var(--ink); margin-bottom: 40px; }
.page-header h1 { font-family: 'Playfair Display', Georgia, serif; font-size: 44px; font-weight: 900; font-style: italic; line-height: 1.2; }

/* FEATURE GRID */
.feature-grid { display: grid; grid-template-columns: 1fr 290px; gap: 36px; padding: 24px 0 32px; align-items: start; }

/* SIDEBAR */
.sidebar-photo-wrap { background: #fdfaf2; padding: 8px 8px 38px; margin-bottom: 22px; position: relative; transform: rotate(1.5deg); box-shadow: 1px 2px 7px rgba(28,16,10,0.22); }
.sidebar-photo-wrap img { width: 100%; height: 210px; object-fit: cover; }
.sidebar-photo-caption { font-family: 'Crimson Text', Georgia, serif; font-weight: 700; font-size: 15px; color: var(--ink); text-align: center; position: absolute; bottom: 8px; left: 0; right: 0; padding: 0 8px; }
.sidebar-news-head { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--gold); margin-bottom: 12px; }
.sidebar-news-item { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; font-style: italic; color: var(--ink); line-height: 1.5; padding-bottom: 12px; margin-bottom: 12px; border-bottom: 1px solid var(--rule); text-decoration: none; display: block; font-size: 16px; }
.sidebar-news-item:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.sidebar-news-item:hover { color: var(--red); text-decoration: none; }

/* SCRAPBOOK */
.photo-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; padding: 10px 0 28px; }
.polaroid { background: #fdfaf2; padding: 7px 7px 34px; position: relative; display: block; color: inherit; text-decoration: none; box-shadow: 1px 2px 7px rgba(28,16,10,0.22); }
.polaroid:hover { opacity: 0.9; text-decoration: none; }
.polaroid img { width: 100%; height: 115px; object-fit: cover; display: block; }
.polaroid-caption { font-family: 'Crimson Text', Georgia, serif; font-weight: 700; font-size: 15px; color: var(--ink); text-align: center; position: absolute; bottom: 7px; left: 0; right: 0; padding: 0 6px; }
.polaroid:nth-child(1) { transform: rotate(-2.8deg); }
.polaroid:nth-child(2) { transform: rotate(2.1deg); margin-top: -6px; }
.polaroid:nth-child(3) { transform: rotate(-1.2deg); margin-top: 5px; }
.polaroid:nth-child(4) { transform: rotate(3deg); margin-top: -8px; }
.polaroid:nth-child(5) { transform: rotate(-1.8deg); margin-top: 4px; }
.polaroid:nth-child(6) { transform: rotate(2.5deg); margin-top: -4px; }

/* ABOUT STRIP */
.about-strip { background: var(--cream); border-top: 2.5px solid var(--ink); border-bottom: 2.5px solid var(--ink); padding: 36px 0; margin-bottom: 36px; }
.about-grid { max-width: var(--max-w); margin: 0 auto; padding: 0 32px; display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.about-grid h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 28px; font-style: italic; line-height: 1.35; margin-bottom: 18px; }
.about-grid p { font-size: 20px; line-height: 1.85; margin-bottom: 16px; }
.about-grid p:last-child { margin-bottom: 0; }

/* TRIBUTE TEASERS */
.tribute-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; padding-bottom: 36px; }
.tribute-card { display: flex; gap: 16px; align-items: flex-start; }
.tribute-card img { width: 90px; height: 110px; object-fit: cover; flex-shrink: 0; }
.tribute-card h3 { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 21px; margin-bottom: 10px; }
.tribute-card p { font-size: 17px; line-height: 1.75; color: var(--muted); margin-bottom: 8px; }

/* EVENTS */
.event-item { display: grid; grid-template-columns: 130px 1fr; gap: 32px; padding: 32px 0; border-bottom: 1px solid var(--rule); align-items: start; }
.event-item:last-child { border-bottom: none; }
.event-date-col { text-align: right; padding-top: 4px; }
.event-date-col .year { font-family: 'Playfair Display', Georgia, serif; font-size: 32px; font-weight: 900; color: var(--red); display: block; line-height: 1; }
.event-date-col .month-day { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; color: var(--muted); letter-spacing: 0.05em; display: block; margin-top: 4px; }
.event-body h3 { font-family: 'Playfair Display', Georgia, serif; font-size: 24px; font-style: italic; margin-bottom: 10px; }
.event-body .event-meta { font-size: 14px; color: var(--gold); letter-spacing: 0.08em; margin-bottom: 12px; font-family: 'Playfair Display', Georgia, serif; text-transform: uppercase; }
.event-body p { font-size: 20px; line-height: 1.85; margin-bottom: 12px; }
.event-photo-strip { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.event-photo-strip img { height: 120px; width: auto; max-width: 180px; object-fit: cover; }

/* GALLERY */
.gallery-section { margin-bottom: 40px; scroll-margin-top: 16px; }
.gallery-section h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 26px; font-style: italic; margin-bottom: 18px; padding-bottom: 12px; border-bottom: 1px solid var(--rule); }
.gallery-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px; }
.gallery-item img { width: 100%; height: 180px; object-fit: cover; }
.gallery-cap { font-family: 'Crimson Text', Georgia, serif; font-size: 17px; line-height: 1.5; padding: 7px 0 3px; color: var(--muted); }

/* GALLERY — browse index + category dividers (combined gallery) */
.gallery-index { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px 40px; background: var(--cream); border: 1px solid var(--rule); padding: 26px 30px; margin-bottom: 12px; }
.gallery-index-col h4 { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); margin-bottom: 9px; }
.gallery-index-col h4 a { color: var(--gold); text-decoration: none; }
.gallery-index-col a { display: block; font-family: 'Crimson Text', Georgia, serif; font-size: 15px; line-height: 1.4; color: var(--muted); text-decoration: none; padding: 2px 0; }
.gallery-index-col a:hover { color: var(--red); }
.gallery-cat { text-align: center; margin: 60px 0 30px; scroll-margin-top: 16px; }
.gallery-cat h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 33px; font-weight: 900; font-style: italic; color: var(--ink); margin-top: 16px; }
.gallery-cat .rule-ink { margin: 0; }

/* HISTORY */
.history-article { max-width: 720px; }
.history-article p { font-size: 20px; line-height: 1.9; margin-bottom: 20px; }
.history-article h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 28px; font-style: italic; margin: 36px 0 16px; }
.person-card { display: flex; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--rule); align-items: flex-start; }
.person-card:last-child { border-bottom: none; }
.person-card-info h3 { font-family: 'Playfair Display', Georgia, serif; font-size: 18px; font-style: italic; margin-bottom: 5px; }
.person-card-info .dates { font-size: 14px; color: var(--gold); letter-spacing: 0.06em; margin-bottom: 7px; font-family: 'Playfair Display', Georgia, serif; display: block; }
.person-card-info p { font-size: 17px; line-height: 1.7; color: var(--muted); }
.school-photos { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin: 28px 0; }
.school-photos figure img { width: 100%; height: 150px; object-fit: cover; }
.school-photos figcaption { font-family: 'Crimson Text', Georgia, serif; font-size: 16px; line-height: 1.5; color: var(--muted); padding: 6px 0; }
.nostalgia-strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin: 18px 0; }
.nostalgia-strip img { width: 100%; height: 120px; object-fit: cover; }

/* IN MEMORIAM */
.tribute-section { padding: 36px 0; border-bottom: 1px solid var(--rule); }
.tribute-section:last-child { border-bottom: none; }
.tribute-section h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 32px; font-style: italic; margin-bottom: 6px; }
.tribute-section .subtitle { font-size: 15px; color: var(--gold); letter-spacing: 0.08em; text-transform: uppercase; font-family: 'Playfair Display', Georgia, serif; margin-bottom: 22px; display: block; }
.tribute-two-col { display: grid; grid-template-columns: 210px 1fr; gap: 36px; align-items: start; }
.tribute-two-col img { width: 210px; object-fit: cover; }
.tribute-two-col p { font-size: 20px; line-height: 1.88; margin-bottom: 16px; }

/* OFFICERS */
.officers-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: 36px; }
.officers-section h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 20px; font-style: italic; margin-bottom: 16px; padding-bottom: 8px; border-bottom: 1px solid var(--rule); }
.officer-row { display: flex; justify-content: space-between; align-items: baseline; padding: 9px 0; border-bottom: 1px solid #e8d8b8; font-size: 18px; gap: 12px; }
.officer-row:last-child { border-bottom: none; }
.officer-title { color: var(--muted); font-size: 16px; flex-shrink: 0; }
.director-list { font-size: 18px; line-height: 2; }

/* SHARE FORM */
.memory-form { max-width: 640px; }
.memory-form label { display: block; font-family: 'Playfair Display', Georgia, serif; font-size: 15px; letter-spacing: 0.04em; color: var(--ink); margin-bottom: 18px; }
.memory-form .req { color: var(--red); }
.memory-form input[type=text], .memory-form input[type=email], .memory-form textarea {
  display: block; width: 100%; margin-top: 6px; padding: 11px 13px;
  font-family: 'Crimson Text', Georgia, serif; font-size: 17px; color: var(--ink);
  background: #fdfaf2; border: 1px solid var(--rule);
}
.memory-form input[type=file] { display: block; margin-top: 7px; font-family: 'Crimson Text', Georgia, serif; font-size: 16px; color: var(--muted); }
.memory-form input:focus, .memory-form textarea:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 2px rgba(139,26,26,0.12); }
.memory-form button { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--cream); background: var(--red); border: none; padding: 13px 30px; cursor: pointer; margin-top: 4px; }
.memory-form button:hover { background: #6f1414; }

/* SEARCH */
.search-box { width: 100%; max-width: 560px; padding: 13px 16px; font-family: 'Crimson Text', Georgia, serif; font-size: 19px; color: var(--ink); background: #fdfaf2; border: 1px solid var(--rule); }
.search-box:focus { outline: none; border-color: var(--red); box-shadow: 0 0 0 2px rgba(139,26,26,0.12); }
.search-result { padding: 16px 0; border-bottom: 1px solid var(--rule); }
.search-result a { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 21px; color: var(--red); }
.search-result .sr-page { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--gold); display: block; margin-bottom: 4px; }
.search-result .sr-snip { font-size: 16px; color: var(--muted); margin-top: 5px; line-height: 1.55; }
.search-result .sr-snip mark { background: #f3e0a8; color: var(--ink); padding: 0 2px; }

/* MINUTES */
.minutes-section { padding: 36px 0; border-bottom: 1px solid var(--rule); }
.minutes-section:last-child { border-bottom: none; }
.minutes-section h2 { font-family: 'Playfair Display', Georgia, serif; font-size: 24px; font-style: italic; margin-bottom: 8px; }
.minutes-meta { margin-bottom: 18px; }
.minutes-date { font-family: 'Playfair Display', Georgia, serif; font-size: 20px; font-weight: 700; color: var(--ink); display: block; margin-bottom: 3px; }
.minutes-location { font-family: 'Playfair Display', Georgia, serif; font-size: 15px; color: var(--gold); letter-spacing: 0.05em; display: block; }
.minutes-body h3 { font-family: 'Playfair Display', Georgia, serif; font-size: 20px; font-style: italic; margin-bottom: 12px; color: var(--ink); }
.minutes-body p, .minutes-body li { font-size: 18px; line-height: 1.85; margin-bottom: 12px; }
.minutes-body ol, .minutes-body ul { padding-left: 26px; margin-bottom: 16px; }
.minutes-attendees { background: var(--cream); padding: 16px 20px; margin-bottom: 18px; border-left: 3px solid var(--rule); font-size: 17px; line-height: 1.75; }
.minutes-recorder { font-family: 'Playfair Display', Georgia, serif; font-style: italic; color: var(--muted); margin-top: 16px; font-size: 16px; }

/* CONTACT */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; padding: 20px 0 40px; align-items: start; }
.contact-item { padding: 20px 0; border-bottom: 1px solid var(--rule); }
.contact-item:last-child { border-bottom: none; }
.contact-item h3 { font-family: 'Playfair Display', Georgia, serif; font-style: italic; font-size: 22px; margin-bottom: 12px; }
.contact-item p { font-size: 20px; line-height: 1.82; }

/* FOOTER */
footer { background: var(--ink); color: #c8a060; padding: 40px 32px 32px; margin-top: 56px; }
.footer-nav { max-width: var(--max-w); margin: 0 auto 26px; display: grid; grid-template-columns: repeat(5, 1fr); gap: 24px; padding-bottom: 26px; border-bottom: 1px solid #3a2a1c; }
.footer-col h4 { font-family: 'Playfair Display', Georgia, serif; font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: #d4b870; margin-bottom: 10px; }
.footer-col a { display: block; font-family: 'Crimson Text', Georgia, serif; font-size: 15.5px; color: #b89a6a; text-decoration: none; padding: 3px 0; letter-spacing: 0.02em; }
.footer-col a:hover { color: #ecd4a4; text-decoration: none; }
.footer-base { text-align: center; }
footer .footer-school { font-family: 'Playfair Display', Georgia, serif; font-size: 14px; font-style: italic; color: #d4b870; margin-bottom: 8px; letter-spacing: 0.04em; }
.footer-base p { font-family: 'Playfair Display', Georgia, serif; font-size: 13px; color: #9a7840; letter-spacing: 0.06em; margin-bottom: 4px; }
.footer-base a { color: #c8a060; text-decoration: none; }
.footer-base a:hover { text-decoration: underline; }

/* LIGHTBOX (shared full-size photo viewer with prev/next) */
.gallery-item { cursor: zoom-in; }
.gallery-item img:hover { opacity: .88; transition: opacity .15s; }
.lightbox { display: none; position: fixed; inset: 0; background: rgba(28,16,10,.92); z-index: 999; align-items: center; justify-content: center; padding: 24px; }
.lightbox.open { display: flex; }
.lightbox img { max-width: 86vw; max-height: 88vh; object-fit: contain; }
.lightbox-close { position: fixed; top: 16px; right: 22px; color: #c8a060; font-size: 34px; cursor: pointer; font-family: Georgia, serif; line-height: 1; z-index: 1001; }
.lightbox-close:hover { color: #f0dcb0; }
.lightbox-cap { position: fixed; bottom: 0; left: 0; right: 0; text-align: center; color: #f0e2c4; font-family: 'Crimson Text', Georgia, serif; font-size: 18px; line-height: 1.55; padding: 12px 26px; background: rgba(20,11,6,0.78); max-height: 32vh; overflow-y: auto; }
.lightbox-nav { position: fixed; top: 50%; transform: translateY(-50%); color: #c8a060; font-size: 56px; cursor: pointer; font-family: Georgia, serif; line-height: 1; -webkit-user-select: none; user-select: none; padding: 12px 18px; z-index: 1001; transition: color .15s; }
.lightbox-nav:hover { color: #f0dcb0; }
.lightbox-prev { left: 6px; }
.lightbox-next { right: 6px; }

/* RESPONSIVE */
@media (max-width: 720px) {
  .lightbox-nav { font-size: 38px; padding: 10px 8px; }
  .lightbox img { max-width: 96vw; }
  .masthead-chinese { font-size: 38px; }
  .headline { font-size: 30px; }
  .page-header h1 { font-size: 32px; }
  .feature-grid { grid-template-columns: 1fr; }
  .photo-strip { grid-template-columns: repeat(2, 1fr); }
  .about-grid { grid-template-columns: 1fr; gap: 28px; }
  .tribute-grid { grid-template-columns: 1fr; }
  .event-item { grid-template-columns: 70px 1fr; gap: 16px; }
  .event-date-col .year { font-size: 24px; }
  .officers-grid { grid-template-columns: 1fr; }
  .tribute-two-col { grid-template-columns: 1fr; }
  .tribute-two-col img { width: 100%; }
  .contact-grid { grid-template-columns: 1fr; }
  .school-photos { grid-template-columns: repeat(2, 1fr); }
  .container, .nav-wrap, .masthead-wrap { padding-left: 18px; padding-right: 18px; }
  .about-grid { padding: 0 18px; }

  /* Nav: collapsible hamburger menu with tap-to-expand groups */
  .nav-toggle { display: block; }
  nav.main-nav { display: none; flex-direction: column; align-items: stretch; padding: 0 0 6px; }
  .nav-wrap.nav-open nav.main-nav { display: flex; }
  nav.main-nav > a, .nav-group, .nav-group > .nav-top { border-right: none; width: 100%; }
  nav.main-nav > a { padding: 11px 8px; font-size: 13px; justify-content: center; border-top: 1px solid var(--rule); }
  .nav-group { display: block; border-top: 1px solid var(--rule); }
  .nav-group > .nav-top { display: flex; justify-content: center; align-items: center; gap: 7px; padding: 11px 8px; font-size: 13px; }
  .nav-group > .nav-top .caret { display: inline; font-size: 9px; transition: transform .15s; }
  .nav-group.open > .nav-top .caret { transform: rotate(180deg); }
  .nav-drop { position: static; transform: none; display: none; box-shadow: none; border: none; background: var(--cream); padding: 4px 0 8px; min-width: 0; }
  .nav-group.open > .nav-drop { display: block; }
  .nav-drop a { text-align: center; text-transform: none; font-size: 14px; padding: 8px 0; color: var(--muted); }

  .footer-nav { grid-template-columns: repeat(2, 1fr); gap: 18px; text-align: center; }
  .gallery-index { grid-template-columns: 1fr; gap: 16px; }
}
