:root {
  --paper: #f0ebe3;
  --ink: #1c1917;
  --sepia: #8b6914;
  --accent: #a0522d;
  --frame: #2a2520;
  --muted: #6b6560;
  --serif: "Playfair Display", Georgia, serif;
  --sans: "IBM Plex Sans", system-ui, sans-serif;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: var(--sans); background: var(--paper); color: var(--ink); line-height: 1.6; }
.wrap { max-width: 1120px; margin: 0 auto; padding: 0 24px; }
a { color: inherit; text-decoration: none; }
.header { border-bottom: 1px solid rgba(0,0,0,.08); background: rgba(240,235,227,.95); position: sticky; top: 0; z-index: 5; }
.bar { display: flex; align-items: center; justify-content: space-between; min-height: 68px; gap: 16px; flex-wrap: wrap; }
.wordmark { font-family: var(--serif); font-size: 1.35rem; font-weight: 700; letter-spacing: .02em; }
.wordmark em { font-style: italic; font-weight: 500; color: var(--sepia); }
.bar nav { display: flex; align-items: center; gap: 22px; font-size: .9rem; font-weight: 500; flex-wrap: wrap; }
.pill { padding: 8px 16px; background: var(--frame); color: var(--paper); border-radius: 999px; font-size: .85rem; }
.masthead { padding: 56px 0 72px; border-bottom: 3px double rgba(0,0,0,.12); }
.masthead-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: center; }
@media (max-width: 860px) { .masthead-inner { grid-template-columns: 1fr; } }
.tag { font-size: .75rem; letter-spacing: .2em; text-transform: uppercase; color: var(--sepia); margin-bottom: 12px; }
.masthead h1 { font-family: var(--serif); font-size: clamp(2.2rem, 4.5vw, 3.2rem); line-height: 1.15; margin-bottom: 16px; }
.masthead-copy p:last-child { color: var(--muted); max-width: 28rem; }
.masthead-frame { background: var(--frame); padding: 16px; box-shadow: 0 24px 60px rgba(0,0,0,.25); max-width: 480px; margin-left: auto; }
.frame-inner { display: grid; grid-template-columns: 1.1fr 1fr; grid-template-rows: 1fr 1fr; gap: 8px; min-height: 320px; }
.ph { width: 100%; height: 100%; min-height: 0; object-fit: cover; filter: sepia(.35) contrast(1.05); display: block; }
.ph-1 { grid-row: 1 / span 2; grid-column: 1; min-height: 280px; }
.ph-2 { grid-row: 1; grid-column: 2; }
.ph-3 { grid-row: 2; grid-column: 2; }
.caption { display: block; margin-top: 10px; font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: rgba(255,255,255,.55); text-align: center; }
.section { padding: 64px 0; }
.section h2 { font-family: var(--serif); font-size: 2rem; margin-bottom: 28px; }
.gallery { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
@media (max-width: 900px) { .gallery { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .gallery { grid-template-columns: 1fr; } }
.tile { margin: 0; }
.thumb { width: 100%; aspect-ratio: 4/5; object-fit: cover; border: 8px solid #fff; box-shadow: 0 4px 20px rgba(0,0,0,.12); margin-bottom: 12px; display: block; filter: sepia(.25) contrast(1.04); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: center; max-width: 960px; }
.about-grid img { width: 100%; border: 10px solid #fff; box-shadow: 0 8px 28px rgba(0,0,0,.12); filter: sepia(.2); aspect-ratio: 4/3; object-fit: cover; }
@media (max-width: 768px) { .about-grid { grid-template-columns: 1fr; } .masthead-frame { margin: 0 auto; } }
.tile figcaption strong { display: block; font-size: .95rem; }
.tile figcaption span { font-size: .8rem; color: var(--muted); }
.band { background: var(--frame); color: var(--paper); }
.band h2 { color: #fff; }
.band-grid { display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items: center; }
@media (max-width: 768px) { .band-grid { grid-template-columns: 1fr; } }
.band p { opacity: .88; }
.tiers { list-style: none; }
.tiers li { display: flex; justify-content: space-between; padding: 14px 0; border-bottom: 1px solid rgba(255,255,255,.12); }
.tiers strong { color: var(--sepia); font-size: 1.1rem; }
.narrow { max-width: 640px; }
.narrow p { color: var(--muted); font-size: 1.05rem; }
.contact { text-align: center; border-top: 1px solid rgba(0,0,0,.08); }
.contact-inner { max-width: 480px; margin: 0 auto; }
.contact form { display: flex; gap: 8px; margin-top: 20px; flex-wrap: wrap; justify-content: center; }
.contact input { flex: 1; min-width: 200px; padding: 14px 16px; border: 1px solid #ccc; border-radius: 4px; font: inherit; background: #fff; }
.contact button { padding: 14px 22px; background: var(--accent); color: #fff; border: none; border-radius: 4px; font-weight: 600; cursor: pointer; font: inherit; }
.bar nav a.is-active { color: var(--sepia); font-weight: 600; }
.page-hero { padding: 48px 0 32px; border-bottom: 1px solid rgba(0,0,0,.08); }
.page-hero h1 { font-family: var(--serif); font-size: clamp(2rem, 4vw, 2.8rem); margin-bottom: 12px; }
.page-hero p { color: var(--muted); max-width: 34rem; }
.page-body { padding: 48px 0 72px; }
.page-body h2 { font-family: var(--serif); font-size: 1.65rem; margin: 28px 0 14px; }
.page-body p, .page-body li { color: var(--muted); margin-bottom: 14px; }
.page-body ul { margin: 0 0 20px 1.2rem; }
.content-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 36px; align-items: start; }
@media (max-width: 768px) { .content-grid { grid-template-columns: 1fr; } }
.content-img { width: 100%; border: 10px solid #fff; box-shadow: 0 8px 28px rgba(0,0,0,.12); filter: sepia(.2); aspect-ratio: 4/3; object-fit: cover; }
.breadcrumb { font-size: .82rem; color: var(--muted); margin-bottom: 10px; letter-spacing: .04em; }
.breadcrumb a:hover { color: var(--sepia); }
.footer a { color: var(--sepia); }
.footer-links { display: flex; justify-content: center; gap: 20px; flex-wrap: wrap; margin-top: 8px; }
.footer { padding: 24px 0 32px; font-size: .82rem; color: var(--muted); text-align: center; }
