:root {
  --forest: #193f22;
  --forest-deep: #0f2414;
  --forest-soft: #275833;
  --moss: #75875d;
  --gold: #d6c18a;
  --paper: #f4f1e8;
  --paper-soft: #faf8f1;
  --card: #fffdf7;
  --text: #182117;
  --muted: #667060;
  --line: rgba(24, 33, 23, .13);
  --shadow: 0 18px 44px rgba(15, 36, 20, .12);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; background: var(--paper); color: var(--text); line-height: 1.55; }
a { color: inherit; text-underline-offset: .16em; }
a:hover { color: var(--forest-soft); }
img { max-width: 100%; height: auto; display: block; }
.skip-link, .screen-reader-text { position: absolute; left: -9999px; }
.skip-link:focus { left: 1rem; top: 1rem; background: white; padding: .75rem 1rem; z-index: 999; }

.site-header { position: sticky; top: 0; z-index: 50; background: rgba(24, 61, 32, .98); color: white; backdrop-filter: blur(10px); box-shadow: 0 10px 25px rgba(0,0,0,.13); }
.header-inner, .footer-inner, .content-wrap, .page-hero > div, .hero-content { max-width: 1260px; margin: 0 auto; padding-left: 32px; padding-right: 32px; }
.header-inner { min-height: 74px; display: flex; align-items: center; justify-content: space-between; gap: 22px; }
.site-branding { display: flex; align-items: center; gap: 14px; min-width: 0; }
.site-branding-text { min-width: 0; }
.site-title { display: block; font-size: clamp(1.35rem, 1.7vw, 1.85rem); font-weight: 900; letter-spacing: -.04em; text-decoration: none; color: white; white-space: nowrap; line-height: 1.05; }
.site-description { margin: .18rem 0 0; color: rgba(255,255,255,.76); font-size: .9rem; white-space: nowrap; }
.custom-logo { max-height: 52px; width: auto; }
.main-navigation { margin-left: auto; }
.main-navigation ul { display: flex; align-items: center; gap: 4px; list-style: none; padding: 0; margin: 0; }
.main-navigation li { position: relative; }
.main-navigation a { display: block; padding: .68rem .86rem; color: white; text-decoration: none; border-radius: 999px; font-weight: 750; font-size: .94rem; }
.main-navigation a:hover, .main-navigation .current-menu-item > a { background: rgba(255,255,255,.1); color: white; }
.main-navigation .sub-menu { display: none; position: absolute; top: 100%; left: 0; min-width: 260px; background: var(--card); color: var(--text); border-radius: 18px; box-shadow: var(--shadow); padding: .5rem; }
.main-navigation li:hover > .sub-menu, .main-navigation li:focus-within > .sub-menu { display: block; }
.main-navigation .sub-menu a { color: var(--text); border-radius: 12px; }
.header-member-link { display: inline-flex; align-items: center; gap: .4rem; padding: .72rem 1.05rem; border-radius: 10px; background: rgba(214,193,138,.18); border: 1px solid rgba(214,193,138,.38); color: white; font-weight: 850; text-decoration: none; white-space: nowrap; }
.header-member-link::before { content: '▣'; font-size: .78rem; opacity: .9; }
.menu-toggle { display: none; width: 46px; height: 42px; border: 1px solid rgba(255,255,255,.22); background: transparent; border-radius: 12px; padding: 8px; }
.menu-toggle span:not(.screen-reader-text) { display: block; height: 2px; background: white; margin: 5px; }

.hero { min-height: 440px; background: linear-gradient(90deg, rgba(12,27,16,.78), rgba(12,27,16,.38)), radial-gradient(circle at 75% 20%, #315635, #122417); background-size: cover; background-position: center; color: white; display: flex; align-items: center; }
.hero-redesign { border-bottom-left-radius: 0; border-bottom-right-radius: 0; }
.hero-content { width: 100%; padding-top: 72px; padding-bottom: 72px; }
.eyebrow { margin: 0 0 .75rem; text-transform: uppercase; letter-spacing: .18em; font-weight: 900; color: var(--gold); font-size: .92rem; }
.eyebrow.dark { color: #8b6b39; }
.hero h1 { font-family: Georgia, 'Times New Roman', serif; font-size: clamp(3.2rem, 5.4vw, 5.45rem); line-height: .9; max-width: 10ch; letter-spacing: -.05em; margin: 0 0 1.15rem; }
.hero p:not(.eyebrow) { max-width: 590px; font-size: clamp(1.02rem, 1.2vw, 1.18rem); color: rgba(255,255,255,.92); margin: 0; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 2rem; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: .86rem 1.25rem; border-radius: 10px; background: var(--forest); color: white; text-decoration: none; font-weight: 850; box-shadow: 0 14px 28px rgba(0,0,0,.14); border: 1px solid rgba(255,255,255,.18); }
.button:hover { color: white; transform: translateY(-1px); }
.button-soft { margin-top: 1.35rem; background: rgba(39,88,51,.86); }
.button-soft::before { content: '▤'; margin-right: .6rem; opacity: .9; }
.button-outline { background: rgba(255,255,255,.08); color: white; border: 1px solid rgba(255,255,255,.32); box-shadow: none; }

.content-wrap { padding-top: 54px; padding-bottom: 54px; }
.home-notices-wrap { background: linear-gradient(180deg, #fbfaf6 0%, var(--paper) 100%); }
.home-notices-layout { display: grid; grid-template-columns: minmax(0, 1fr) 315px; gap: 34px; align-items: start; }
.section-heading { margin-bottom: 20px; }
.notice-heading { margin-bottom: 14px; }
.section-heading h2, .page-hero h1, .single-entry h1 { margin: 0; font-family: Georgia, 'Times New Roman', serif; font-size: clamp(2.15rem, 3.4vw, 3.2rem); line-height: 1.03; letter-spacing: -.035em; }
.section-heading-split { display: flex; justify-content: space-between; align-items: end; gap: 16px; }
.section-link { font-weight: 800; color: var(--forest); text-decoration: none; white-space: nowrap; }
.section-link::after { content: ' →'; }

.notice-list { display: grid; gap: 8px; }
.notice-item { display: grid; grid-template-columns: 190px minmax(0, 1fr) auto; gap: 18px; align-items: center; min-height: 112px; background: rgba(255,253,247,.9); border: 1px solid var(--line); border-radius: 14px; padding: 8px 14px 8px 8px; box-shadow: 0 10px 24px rgba(15,36,20,.055); transition: transform .18s ease, box-shadow .18s ease; }
.notice-item:hover { transform: translateY(-1px); box-shadow: 0 16px 30px rgba(15,36,20,.09); }
.notice-image { height: 96px; border-radius: 10px; overflow: hidden; background: var(--forest); display: block; }
.notice-image img { width: 100%; height: 100%; object-fit: cover; }
.notice-body { min-width: 0; }
.notice-body .post-meta { color: var(--muted); font-size: .78rem; font-weight: 800; margin-bottom: .15rem; }
.notice-body h3 { margin: 0; font-family: Georgia, 'Times New Roman', serif; font-size: 1.35rem; line-height: 1.05; letter-spacing: -.02em; }
.notice-body h3 a { text-decoration: none; }
.notice-body .entry-summary { color: #374034; font-size: .88rem; line-height: 1.38; max-width: 62ch; }
.notice-body .entry-summary p { margin: .22rem 0 0; }
.notice-read-more { color: var(--forest); font-weight: 850; text-decoration: none; white-space: nowrap; }
.notice-read-more::after { content: ' →'; padding-left: .35rem; }

.home-side { display: grid; gap: 14px; }
.side-card { background: rgba(255,253,247,.92); border: 1px solid var(--line); border-radius: 14px; padding: 20px; box-shadow: 0 12px 30px rgba(15,36,20,.08); }
.side-card-title { display: flex; justify-content: space-between; align-items: center; gap: 12px; margin-bottom: 10px; }
.side-card-title h2 { margin: 0; font-family: Georgia, 'Times New Roman', serif; font-size: 1.55rem; }
.side-icon { display: inline-grid; place-items: center; width: 32px; height: 32px; border-radius: 999px; background: var(--forest); color: white; font-size: .82rem; }
.archive-year-list, .quick-side-list { list-style: none; padding: 0; margin: 0; }
.archive-year-list li + li, .quick-side-list li + li { border-top: 1px solid var(--line); }
.archive-year-list a, .quick-side-list a { display: flex; justify-content: space-between; align-items: center; gap: 12px; padding: .78rem 0; color: var(--forest); font-weight: 780; text-decoration: none; }
.quick-side-list a { color: var(--text); font-weight: 700; }

.members-band { background: linear-gradient(180deg, rgba(225,231,216,.8), rgba(242,240,231,.94)); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.members-inner { display: grid; grid-template-columns: 320px minmax(0,1fr); gap: 30px; align-items: center; }
.members-intro h2 { margin: 0 0 .4rem; font-family: Georgia, 'Times New Roman', serif; font-size: clamp(2rem, 3vw, 3rem); }
.members-intro p { color: #303b2d; }
.member-login { margin-top: .5rem; }
.member-login::before { content: '▣'; margin-right: .5rem; }
.member-cards { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 18px; }
.member-card { display: grid; gap: .5rem; padding: 24px; background: var(--card); border: 1px solid var(--line); border-radius: 14px; box-shadow: 0 12px 28px rgba(15,36,20,.08); text-decoration: none; color: var(--text); min-height: 150px; }
.member-card strong { font-family: Georgia, 'Times New Roman', serif; font-size: 1.35rem; }
.member-card span:last-child { color: #495244; font-size: .92rem; }
.member-icon { display: inline-grid; place-items: center; width: 48px; height: 48px; border-radius: 999px; background: rgba(25,63,34,.12); color: var(--forest); font-weight: 900; }

.bottom-info { background: #fbfaf6; }
.bottom-info-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 30px; padding-top: 28px; padding-bottom: 28px; }
.bottom-info-grid > div { border-left: 1px solid var(--line); padding-left: 24px; }
.bottom-info-grid > div:first-child { border-left: 0; padding-left: 0; }
.bottom-info-grid strong { display: block; text-transform: uppercase; letter-spacing: .08em; color: var(--forest); font-size: .9rem; margin-bottom: .4rem; }
.bottom-info-grid p { margin: 0; color: #4f584c; }

.post-grid { display: grid; gap: 24px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.post-card { background: var(--card); border: 1px solid var(--line); border-radius: 22px; overflow: hidden; box-shadow: var(--shadow); display: flex; flex-direction: column; }
.post-card-image { aspect-ratio: 16/10; background: linear-gradient(135deg, var(--forest), var(--moss)); color: rgba(255,255,255,.86); display: flex; align-items: center; justify-content: center; text-align: center; font-weight: 800; text-decoration: none; overflow: hidden; }
.post-card-image img, .post-row-image img, .featured-image img { width: 100%; height: 100%; object-fit: cover; }
.post-card-body { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.post-meta { color: var(--muted); font-size: .88rem; font-weight: 700; margin-bottom: .55rem; }
.post-card h2, .post-row h2 { margin: 0 0 .65rem; font-size: 1.35rem; line-height: 1.2; letter-spacing: -.02em; }
.post-card h2 a, .post-row h2 a { text-decoration: none; }
.entry-summary { color: #273024; font-size: .98rem; }
.read-more { display: inline-block; margin-top: auto; padding-top: 1rem; font-weight: 800; color: var(--forest); text-decoration: none; }
.read-more::after { content: ' →'; }

.page-hero { background: #ece5d5; border-bottom: 1px solid var(--line); }
.page-hero.compact > div { padding-top: 54px; padding-bottom: 46px; }
.page-lead { max-width: 60ch; margin-top: .8rem; }
.page-wrap { max-width: 960px; }
.two-column { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 36px; align-items: start; }
.primary-content, .single-entry, .sidebar .widget, .comments-area { background: rgba(252,250,245,.84); border: 1px solid var(--line); border-radius: 24px; box-shadow: 0 12px 32px rgba(16,28,17,.08); }
.primary-content, .single-entry, .comments-area { padding: 28px; }
.single-entry { background: var(--card); }
.single-entry h1 { margin-bottom: 1rem; }
.entry-content { font-size: 1.05rem; }
.entry-content h2, .entry-content h3 { line-height: 1.2; margin-top: 1.7em; }
.entry-content ul, .entry-content ol { padding-left: 1.4rem; }
.featured-image { margin: 1.2rem 0 1.6rem; border-radius: 22px; overflow: hidden; max-height: 520px; }
.post-navigation { display: flex; justify-content: space-between; gap: 18px; margin-top: 22px; font-weight: 800; }
.post-list { display: grid; gap: 18px; }
.post-row { display: grid; grid-template-columns: 220px minmax(0,1fr); gap: 22px; }
.post-row-card { padding: 22px; background: var(--card); border: 1px solid var(--line); border-radius: 24px; box-shadow: var(--shadow); }
.post-row-image { min-height: 138px; background: #d9c79f; border-radius: 18px; overflow: hidden; }
.sidebar { display: grid; gap: 18px; }
.sidebar .widget { padding: 24px; }
.widget-title { margin: 0 0 .85rem; font-size: 1.18rem; line-height: 1.15; }
.widget ul { margin: 0; padding-left: 1.1rem; }
.widget li { margin-bottom: .4rem; }
.search-form { display: flex; gap: 8px; }
.search-field { width: 100%; border: 1px solid var(--line); border-radius: 999px; padding: .8rem 1rem; background: white; }
.search-submit { border: 0; border-radius: 999px; background: var(--forest); color: white; padding: .8rem 1rem; font-weight: 800; }
.pagination-wrap, .nav-links { margin-top: 30px; display: flex; gap: 10px; flex-wrap: wrap; }
.page-numbers { padding: .6rem .85rem; background: white; border-radius: 12px; text-decoration: none; border: 1px solid var(--line); }
.page-numbers.current { background: var(--forest); color: white; }
.site-footer { background: var(--forest-deep); color: white; }
.footer-inner { padding-top: 30px; padding-bottom: 30px; display: flex; justify-content: space-between; gap: 24px; align-items: center; }
.footer-inner p { margin: .25rem 0 0; color: rgba(255,255,255,.68); }
.footer-navigation ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 14px; flex-wrap: wrap; }
.footer-navigation a { color: white; }

@media (max-width: 1100px) {
  .home-notices-layout, .members-inner { grid-template-columns: 1fr; }
  .home-side { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .post-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 920px) {
  .header-inner, .footer-inner, .content-wrap, .page-hero > div, .hero-content { padding-left: 20px; padding-right: 20px; }
  .site-title, .site-description { white-space: normal; }
  .header-member-link { display: none; }
  .menu-toggle { display: block; }
  .main-navigation { display: none; position: absolute; left: 16px; right: 16px; top: 76px; background: var(--card); color: var(--text); border-radius: 20px; padding: 10px; box-shadow: var(--shadow); }
  .main-navigation.is-open { display: block; }
  .main-navigation ul { display: block; }
  .main-navigation a { color: var(--text); border-radius: 12px; }
  .main-navigation .sub-menu { display: block; position: static; min-width: 0; box-shadow: none; padding-left: 1rem; background: transparent; }
  .hero { min-height: 410px; }
  .hero h1 { font-size: clamp(2.75rem, 9vw, 4rem); max-width: 10ch; }
  .notice-item { grid-template-columns: 150px minmax(0, 1fr); }
  .notice-read-more { grid-column: 2; }
  .two-column { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .header-inner { min-height: 72px; }
  .hero { min-height: 390px; }
  .hero-content { padding-top: 62px; padding-bottom: 62px; }
  .eyebrow { font-size: .82rem; }
  .hero h1 { font-size: clamp(2.25rem, 12vw, 3.25rem); }
  .notice-item { grid-template-columns: 1fr; padding: 10px; }
  .notice-image { height: 150px; }
  .notice-read-more { grid-column: auto; }
  .home-side, .member-cards, .bottom-info-grid, .post-grid { grid-template-columns: 1fr; }
  .bottom-info-grid > div { border-left: 0; padding-left: 0; border-top: 1px solid var(--line); padding-top: 18px; }
  .bottom-info-grid > div:first-child { border-top: 0; padding-top: 0; }
  .post-row { grid-template-columns: 1fr; }
  .footer-inner { display: block; }
  .footer-navigation ul { margin-top: 18px; }
}
