
:root {
    --bg: #FAF8F4; --bg-alt: #F0EDE6; --bg-card: #fff;
    --text: #2C2C2C; --text-l: #5A5A5A;
    --nav-bg: #1B2A4A; --nav-txt: #E8E4DC;
    --accent: #8B6914; --accent-l: #C4A245;
    --link: #2E4A6E; --link-h: #8B6914;
    --border: #D8D2C4; --border-l: #E8E2D6;
    --heading: #1B2A4A;
    --f-body: 'Noto Serif', Georgia, 'Times New Roman', serif;
    --f-head: 'Cormorant Garamond', Georgia, serif;
    --f-nav: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
    --cw: 760px; --pw: 1060px;
    --img-shadow: 0 2px 8px rgba(0,0,0,.08);
}
[data-theme="dark"] {
    --bg: #2B2B2B; --bg-alt: #333; --bg-card: #363636;
    --text: #E0DDD5; --text-l: #A8A49A;
    --nav-bg: #1A1A1A; --nav-txt: #D4D0C8;
    --accent: #C4A245; --accent-l: #D4B86A;
    --link: #8AACCE; --link-h: #D4B86A;
    --border: #4A4640; --border-l: #3E3B36;
    --heading: #E0DDD5;
    --img-shadow: 0 2px 12px rgba(0,0,0,.3);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:19px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--f-body);color:var(--text);background:var(--bg);line-height:1.8;min-height:100vh;display:flex;flex-direction:column;transition:background .3s,color .3s}

/* ── Header ── */
.site-header{background:var(--nav-bg);color:var(--nav-txt)}
.hdr-inner{max-width:var(--pw);margin:0 auto;padding:.6rem 2rem;display:flex;align-items:center;justify-content:center;gap:1rem}
.site-logo{height:130px;width:auto;flex-shrink:0}
.hdr-img{height:170px;width:auto;max-width:900px;object-fit:contain;border-radius:4px}
.site-ttl{text-align:center;padding:.5rem 2rem .4rem}
.site-ttl a{text-decoration:none;color:var(--nav-txt);font-family:var(--f-head);font-size:1.6rem;font-weight:600;letter-spacing:.02em;line-height:1.3}

/* ── Nav ── */
.site-nav{background:var(--nav-bg);border-top:1px solid rgba(255,255,255,.1);position:sticky;top:0;z-index:100}
.nav-in{max-width:var(--pw);margin:0 auto;padding:0 1rem;display:flex;align-items:center}
.nav-ul{list-style:none;display:flex;flex-wrap:nowrap;justify-content:center;flex:1}
.nav-li{position:relative}
.nav-a{display:block;padding:.65rem .7rem;color:var(--nav-txt);text-decoration:none;font-family:var(--f-nav);font-size:.82rem;font-weight:500;letter-spacing:.02em;white-space:nowrap;transition:color .2s,background .2s}
.nav-a:hover,.nav-a.on{color:var(--accent-l);background:rgba(255,255,255,.06)}
.nav-li:hover .nav-dd,.nav-li:focus-within .nav-dd{display:block}
.nav-dd{display:none;position:absolute;top:100%;left:0;background:var(--nav-bg);border:1px solid rgba(255,255,255,.1);min-width:260px;box-shadow:0 8px 24px rgba(0,0,0,.3);z-index:200;list-style:none}
.nav-dd .nav-a{padding:.55rem 1.1rem;font-size:.8rem;border-bottom:1px solid rgba(255,255,255,.05)}
.nav-tog{display:none;background:none;border:none;color:var(--nav-txt);font-size:1.1rem;cursor:pointer;padding:.65rem .8rem;font-family:var(--f-nav);text-align:left}
.theme-btn{background:none;border:1px solid rgba(255,255,255,.2);color:var(--nav-txt);font-size:1rem;cursor:pointer;padding:.55rem .6rem;border-radius:4px;line-height:1;flex-shrink:0;transition:border-color .2s;margin-left:.5rem}
.theme-btn:hover{border-color:rgba(255,255,255,.5)}

/* ── Main ── */
.mc{flex:1;max-width:var(--cw);margin:0 auto;padding:2.5rem 2rem 3rem;width:100%}
.mc.wide{max-width:var(--pw)}

/* ── Typography ── */
h1{font-family:var(--f-head);font-size:1.5rem;font-weight:600;color:var(--heading);line-height:1.25;margin-bottom:1.5rem;text-align:center}
h2{font-family:var(--f-head);font-size:1.25rem;font-weight:600;color:var(--heading);line-height:1.3;margin-top:2.5rem;margin-bottom:1rem;padding-bottom:.4rem;border-bottom:1px solid var(--border-l)}
h3{font-family:var(--f-head);font-size:1.1rem;font-weight:600;color:var(--heading);margin-top:2rem;margin-bottom:.75rem}
p{margin-bottom:1.2rem}
a{color:var(--link);text-decoration-thickness:1px;text-underline-offset:2px;transition:color .2s}
a:hover{color:var(--link-h)}
strong{font-weight:700}em{font-style:italic;color:var(--text-l)}
hr{border:none;border-top:1px solid var(--border);margin:2.5rem 0}
blockquote{border-left:3px solid var(--accent);padding:.5rem 1.5rem;margin:1.5rem 0;color:var(--text-l);background:var(--bg-alt)}
ul,ol{margin:0 0 1.2rem 1.5rem}li{margin-bottom:.3rem}

/* Content images: clickable */
.mc img{display:block;max-width:100%;height:auto;border-radius:3px;margin:1rem auto .5rem;box-shadow:var(--img-shadow);max-height:500px;object-fit:contain;cursor:pointer;transition:box-shadow .2s}
.mc img:hover{box-shadow:0 4px 16px rgba(0,0,0,.18)}

/* ── Hero ── */
.hero{
    position:relative;
    width:660px;max-width:100%;
    margin:-2.5rem auto 2rem;
    overflow:hidden;
    container-type:inline-size;
}
.hero > img{
    display:block;width:100%;height:auto;
    max-height:none;object-fit:fill;
    border-radius:0;box-shadow:none;margin:0;cursor:default;transition:none;
}
.hero > img:hover{box-shadow:none}
.hero-ov{
    position:absolute;top:0;left:0;right:0;bottom:0;
    display:flex;flex-direction:column;justify-content:flex-start;
    padding:22% 5% 12% 15%;
    color:#F5F0E8;
    overflow:hidden;
    background:rgba(0,0,0,0.55);
    text-shadow: 0 1px 3px rgba(0,0,0,0.8);
}
[data-theme="dark"] .hero-ov{background:rgba(0,0,0,0.65)}
.hero-ov p{font-size:clamp(12px, 2.7cqw, 19px);line-height:1.5;margin-bottom:clamp(3px, 0.8cqw, 6px)}
.hero-ov p:last-child{margin-bottom:0}
.hero-ov strong{color:#fff}

/* Board */
.board h3{font-size:1.1rem;margin-top:1.5rem;margin-bottom:.5rem;color:var(--text-l)}
.bt{width:100%;border-collapse:collapse;margin:.5rem 0 1.5rem}
.bt td{padding:.4rem .6rem;vertical-align:top;font-size:.95rem;border-bottom:1px solid var(--border-l)}
.bt td:first-child{color:var(--text-l);width:170px;white-space:nowrap}
.bt td:last-child{font-weight:600}
.bt-s td:first-child{width:auto;font-weight:600;color:var(--text)}

/* List pages */
.li-item{padding:1.3rem 0;border-bottom:1px solid var(--border-l)}
.li-item:last-child{border-bottom:none}
.li-item h3{margin-top:0;margin-bottom:.4rem}
.li-item h3 a{text-decoration:none;color:var(--heading)}
.li-item h3 a:hover{color:var(--link-h)}
.li-item .desc{color:var(--text-l);font-size:.92rem;margin-bottom:.5rem}
.rm{display:inline-block;margin-top:.3rem;font-family:var(--f-nav);font-size:.82rem;font-weight:500;letter-spacing:.06em;color:var(--accent);text-decoration:none}
.rm:hover{color:var(--link-h)}

/* Photo galleries */
.gallery-group{margin-bottom:2.5rem;background:var(--bg-card);border-radius:6px;padding:1rem;box-shadow:0 1px 4px rgba(0,0,0,.06)}
[data-theme="dark"] .gallery-group{box-shadow:0 1px 6px rgba(0,0,0,.2)}
.gallery-featured-wrap{width:100%;height:420px;display:flex;align-items:center;justify-content:center;overflow:hidden;border-radius:4px;background:var(--bg-alt);margin-bottom:.8rem;cursor:pointer}
.gallery-featured{max-width:100%;max-height:100%;object-fit:contain;box-shadow:none;margin:0;border-radius:0}
.gallery-thumbs{display:flex;gap:.4rem;flex-wrap:wrap;justify-content:center}
.gallery-thumbs img{width:72px;height:54px;object-fit:cover;border-radius:3px;cursor:pointer;opacity:.6;transition:opacity .2s;box-shadow:none;margin:0}
.gallery-thumbs img:hover{opacity:1}
.gallery-thumbs img.active{opacity:1;outline:2px solid var(--accent)}
.gallery-caption{margin-top:.6rem;font-size:.88rem;color:var(--text-l);line-height:1.5;min-height:3.5em}
.gallery-caption strong{color:var(--text);display:block;font-size:.9rem}
.photo-standalone{margin-bottom:3rem;text-align:center}
.photo-standalone img{max-width:500px;max-height:400px;margin:0 auto 1rem;display:block;border-radius:4px;object-fit:contain}
.photo-standalone .caption{font-size:.95rem;color:var(--text-l);max-width:500px;margin:0 auto;line-height:1.7}

/* Lightbox */
.lightbox{display:none;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.92);z-index:1000;align-items:center;justify-content:center;cursor:pointer}
.lightbox.open{display:flex}
.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:4px;box-shadow:0 4px 40px rgba(0,0,0,.5)}
.lightbox-caption{position:fixed;bottom:1.5rem;left:50%;transform:translateX(-50%);color:#ddd;font-size:.9rem;text-align:center;max-width:600px;line-height:1.5}
.lightbox-close{position:fixed;top:1rem;right:1.5rem;color:#ccc;font-size:2rem;cursor:pointer;background:none;border:none;font-family:var(--f-nav)}

/* Video */
.vid-item{margin-bottom:2.5rem}.vid-item h3{margin-top:0;margin-bottom:.8rem}
.vid-embed{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:4px;box-shadow:var(--img-shadow);margin-bottom:.8rem}
.vid-embed iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}
.vid-desc{font-size:.92rem;color:var(--text-l);line-height:1.7}

/* Footer */
.site-ft{background:var(--nav-bg);color:var(--nav-txt);text-align:center;padding:1.5rem 2rem;font-family:var(--f-nav);font-size:.8rem;margin-top:auto}
.btt{display:block;text-align:center;padding:1.5rem;font-family:var(--f-nav);font-size:.82rem;color:var(--text-l);text-decoration:none}
.btt:hover{color:var(--accent)}

/* Responsive */
@media(max-width:768px){
    html{font-size:18px}
    .hdr-inner{padding:.5rem 1rem;gap:.8rem}
    .site-logo{height:85px}.hdr-img{height:100px}
    .site-ttl{padding:.4rem .8rem .3rem}.site-ttl a{font-size:1.15rem}
    .nav-tog{display:block}
    .nav-ul{display:none;flex-direction:column;width:100%}
    .nav-ul.open{display:flex}
    .nav-a{padding:.8rem 1.5rem;font-size:.85rem;border-bottom:1px solid rgba(255,255,255,.06)}
    .nav-dd{position:static;box-shadow:none;border:none;background:rgba(0,0,0,.15);display:block}
    .nav-dd .nav-a{padding-left:2.5rem}
    .mc{padding:1.5rem 1.2rem 2rem}
    h1{font-size:1.65rem}
    .hero{max-width:none;width:calc(100% + 2.4rem);margin-top:-1.5rem;margin-left:-1.2rem;margin-right:-1.2rem}
    .hero-ov{padding:20% 4% 10% 12%}
    .theme-btn{font-size:.95rem;padding:.4rem .55rem}
    .bt td:first-child{width:120px}
    .gallery-featured-wrap{height:280px}
    .gallery-thumbs img{width:60px;height:45px}
}
@media(max-width:480px){
    html{font-size:17px}.mc{padding:1rem}
    .bt td{display:block}.bt td:first-child{width:auto;border-bottom:none;padding-bottom:0}
    .hero{margin-left:-1rem;margin-right:-1rem;width:calc(100% + 2rem)}
    .hero-ov{padding:18% 3% 8% 8%}
    .gallery-featured-wrap{height:220px}
    .gallery-thumbs img{width:50px;height:38px}
}
@media print{.site-header,.site-nav,.site-ft,.btt,.theme-btn{display:none}.mc{max-width:100%;padding:0}}
