:root {
  --ink: #18201e;
  --paper: #f4f1ea;
  --white: #fff;
  --forest: #24443c;
  --coral: #d86d50;
  --line: rgba(24, 32, 30, .16);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--paper);
  font-family: "DM Sans", sans-serif;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button { color: inherit; font: inherit; }
.site-header {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 92px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5vw;
  color: var(--white);
  border-bottom: 1px solid rgba(255,255,255,.25);
}
.brand { display: inline-flex; align-items: baseline; gap: 8px; }
.brand span { font: 700 26px/1 "Noto Serif SC", serif; }
.brand small { font-size: 9px; letter-spacing: 4px; }
nav { display: flex; gap: 38px; font-size: 13px; }
nav a { opacity: .8; }
nav a:hover { opacity: 1; }
.menu-button { display: none; border: 0; background: none; }
.hero {
  position: relative;
  min-height: 92vh;
  overflow: hidden;
  color: var(--white);
  background: #53665e;
}
.hero-media, .hero-media img, .photo-placeholder { width: 100%; height: 100%; }
.hero-media { position: absolute; inset: 0; }
.hero-media img { display: block; object-fit: cover; }
.photo-placeholder {
  display: grid;
  place-items: center;
  background:
    linear-gradient(115deg, rgba(23,49,43,.25), rgba(194,117,83,.18)),
    linear-gradient(145deg, #738279 0%, #394d45 48%, #bea58c 100%);
}
.photo-placeholder span {
  color: rgba(255,255,255,.3);
  font: 600 clamp(30px, 7vw, 96px)/1 "Noto Serif SC", serif;
  letter-spacing: 8px;
  text-align: center;
}
.photo-placeholder.warm { min-height: 640px; background: linear-gradient(145deg, #c7a589, #725e51); }
.photo-placeholder.warm span { font-size: clamp(28px, 4vw, 64px); line-height: 1.15; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(12,24,21,.72), rgba(12,24,21,.04) 68%), linear-gradient(0deg, rgba(12,24,21,.5), transparent 50%); }
.hero-content {
  position: relative;
  z-index: 2;
  width: min(760px, 90vw);
  padding: 25vh 0 12vh 8vw;
}
.kicker, .eyebrow { margin: 0 0 22px; font-size: 11px; font-weight: 600; letter-spacing: 3px; }
.hero h1 {
  margin: 0;
  font: 600 clamp(44px, 5.1vw, 68px)/1.15 "Noto Serif SC", serif;
  letter-spacing: 0;
}
.hero-copy { max-width: 520px; margin: 28px 0 38px; color: rgba(255,255,255,.82); font-size: 16px; line-height: 1.9; }
.explore-link { display: inline-flex; align-items: center; gap: 14px; padding-bottom: 8px; border-bottom: 1px solid rgba(255,255,255,.6); font-size: 13px; }
.hero-index { position: absolute; z-index: 2; right: 5vw; bottom: 7vh; display: flex; align-items: baseline; gap: 10px; }
.hero-index strong { font: 500 50px/1 "Noto Serif SC", serif; }
.hero-index span { font-size: 11px; letter-spacing: 2px; }
.intro {
  display: grid;
  grid-template-columns: 80px minmax(280px, .8fr) minmax(300px, 1fr);
  gap: 5vw;
  padding: 130px 8vw;
  align-items: start;
}
.section-number { color: var(--coral); font-size: 12px; }
.intro h2, .map-heading h2, .gallery-heading h2 {
  margin: 0;
  font: 600 clamp(34px, 4vw, 58px)/1.3 "Noto Serif SC", serif;
}
.intro-copy { max-width: 570px; margin: 42px 0 0; color: #5c625f; font: 500 17px/2 "Noto Serif SC", serif; }
.featured { display: grid; grid-template-columns: 42% 58%; min-height: 720px; background: var(--forest); color: var(--white); }
.featured-copy { align-self: center; padding: 8vw; }
.featured-copy .eyebrow { color: #e29b85; }
.featured-date { margin: 80px 0 12px; color: rgba(255,255,255,.55); font-size: 12px; letter-spacing: 2px; }
.featured-copy h2 { margin: 0 0 28px; font: 600 clamp(36px, 4vw, 60px)/1.3 "Noto Serif SC", serif; }
.featured-copy > p:not(.eyebrow):not(.featured-date) { max-width: 460px; color: rgba(255,255,255,.72); line-height: 1.9; }
.location-line { display: flex; align-items: center; gap: 10px; margin-top: 34px; font-size: 13px; }
.pin { width: 9px; height: 9px; border: 2px solid var(--coral); border-radius: 50%; box-shadow: 0 0 0 4px rgba(216,109,80,.16); }
.featured-image { min-height: 720px; overflow: hidden; }
.featured-image img { width: 100%; height: 100%; display: block; object-fit: cover; }
.map-section { padding: 130px 8vw 90px; background: #e8e5dc; }
.map-heading, .gallery-heading { display: flex; justify-content: space-between; align-items: end; gap: 40px; }
.map-heading > p { max-width: 330px; color: #69706c; line-height: 1.8; }
.map-stage { position: relative; max-width: 1200px; margin: 70px auto 20px; }
.world-map { width: 100%; fill: #c6c9bf; stroke: #e8e5dc; stroke-width: 3; }
.map-empty { position: absolute; inset: 0; display: grid; place-content: center; text-align: center; }
.map-empty[hidden] { display: none; }
.map-empty strong { font: 600 22px "Noto Serif SC", serif; }
.map-empty span { margin-top: 8px; color: #757b77; font-size: 12px; }
.map-pins { position: absolute; inset: 0; }
.map-dot { position: absolute; width: 12px; height: 12px; border: 3px solid var(--white); border-radius: 50%; background: var(--coral); box-shadow: 0 2px 10px rgba(24,32,30,.3); }
.map-stats { display: flex; justify-content: center; gap: 9vw; border-top: 1px solid var(--line); padding-top: 36px; }
.map-stats div { display: flex; align-items: baseline; gap: 10px; }
.map-stats strong { font: 600 40px "Noto Serif SC", serif; }
.map-stats span { color: #6a706d; font-size: 11px; letter-spacing: 1px; }
.gallery-section { padding: 130px 5vw; background: #faf9f6; }
.gallery-heading { padding: 0 3vw 55px; }
.filters { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 24px; }
.filters button { padding: 5px 0; border: 0; border-bottom: 1px solid transparent; background: none; font-size: 12px; cursor: pointer; }
.filters button.active { border-color: var(--coral); color: var(--coral); }
.gallery-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 18px; }
.gallery-card { grid-column: span 4; position: relative; min-height: 460px; overflow: hidden; border: 0; padding: 0; background: #ddd; cursor: pointer; }
.gallery-card:nth-child(5n + 1), .gallery-card:nth-child(5n + 4) { grid-column: span 5; }
.gallery-card:nth-child(5n + 2), .gallery-card:nth-child(5n + 3) { grid-column: span 7; }
.gallery-card img { width: 100%; height: 100%; display: block; object-fit: cover; transition: transform .6s ease; }
.gallery-card:hover img { transform: scale(1.03); }
.gallery-sentinel {
  min-height: 80px;
  display: grid;
  place-items: center;
  color: #777d79;
  font-size: 11px;
  letter-spacing: 1px;
}
.gallery-sentinel[hidden] { display: none; }
.card-caption { position: absolute; inset: auto 0 0; padding: 70px 24px 22px; color: white; text-align: left; background: linear-gradient(transparent, rgba(12,20,18,.72)); }
.card-caption strong, .card-caption span { display: block; }
.card-caption strong { font: 600 21px "Noto Serif SC", serif; }
.card-caption span { margin-top: 7px; font-size: 11px; opacity: .75; }
.empty-gallery { grid-column: 1/-1; min-height: 460px; display: grid; place-content: center; justify-items: center; border: 1px solid var(--line); color: #686e6a; text-align: center; }
.empty-mark { color: #c7c1b6; font: 600 60px "Noto Serif SC", serif; }
.empty-gallery h3 { margin: 24px 0 8px; color: var(--ink); font: 600 24px "Noto Serif SC", serif; }
.empty-gallery p { margin: 0; font-size: 13px; }
.quote-section { padding: 150px 5vw; color: white; background: var(--coral); text-align: center; }
.quote-section p { margin: 0; font: 600 clamp(28px, 4vw, 52px)/1.7 "Noto Serif SC", serif; }
.quote-section span { display: block; margin-top: 35px; font-size: 10px; letter-spacing: 5px; }
footer { min-height: 220px; display: flex; align-items: center; justify-content: space-between; gap: 30px; padding: 50px 8vw; color: rgba(255,255,255,.68); background: #17241f; font-size: 11px; }
.footer-brand { color: white; }
.photo-dialog { width: min(1080px, 92vw); padding: 0; border: 0; background: var(--paper); }
.photo-dialog::backdrop { background: rgba(10,18,15,.8); backdrop-filter: blur(8px); }
.dialog-close { position: absolute; z-index: 2; top: 16px; right: 18px; width: 38px; height: 38px; border: 0; border-radius: 50%; background: rgba(255,255,255,.85); font-size: 25px; cursor: pointer; }
.photo-dialog[open] { display: grid; grid-template-columns: 62% 38%; }
.dialog-media { min-height: 70vh; background: #ddd; }
.dialog-media img { width: 100%; height: 100%; display: block; object-fit: cover; }
.dialog-info { align-self: center; padding: 48px; }
.dialog-info h2 { font: 600 34px "Noto Serif SC", serif; }
.dialog-info > p:not(.eyebrow) { color: #606763; line-height: 1.8; }
.map-link { display: inline-block; margin-top: 22px; padding-bottom: 5px; border-bottom: 1px solid var(--coral); color: var(--coral); font-size: 12px; }
.map-link[hidden] { display: none; }

@media (max-width: 800px) {
  .site-header { height: 72px; }
  nav { position: fixed; inset: 72px 0 auto; display: none; flex-direction: column; padding: 32px 5vw; color: var(--ink); background: var(--paper); }
  body.menu-open nav { display: flex; }
  .menu-button { display: grid; gap: 6px; padding: 10px; }
  .menu-button span { width: 24px; height: 1px; background: white; }
  .hero { min-height: 88vh; }
  .hero-content { padding: 24vh 6vw 120px; }
  .hero h1 { font-size: 32px; }
  .hero-media img { object-position: 58% center; }
  .hero-index { right: 6vw; bottom: 4vh; }
  .hero-index strong { font-size: 34px; }
  .intro { grid-template-columns: 34px 1fr; padding: 90px 6vw; }
  .intro-copy { grid-column: 2; margin-top: 0; }
  .featured { grid-template-columns: 1fr; }
  .featured-copy { padding: 90px 7vw; }
  .featured-date { margin-top: 50px; }
  .featured-image, .photo-placeholder.warm { min-height: 70vh; }
  .map-section, .gallery-section { padding: 90px 6vw; }
  .map-heading, .gallery-heading { display: block; }
  .map-heading > p { margin-top: 25px; }
  .map-stage { margin-top: 45px; }
  .map-empty span { max-width: 200px; }
  .map-stats { gap: 24px; justify-content: space-between; }
  .map-stats div { display: block; }
  .map-stats strong, .map-stats span { display: block; }
  .map-stats strong { font-size: 30px; }
  .filters { justify-content: flex-start; margin-top: 30px; }
  .gallery-grid { display: block; }
  .gallery-card { width: 100%; min-height: 60vh; margin-bottom: 14px; }
  .empty-gallery { min-height: 400px; padding: 30px; }
  .quote-section { padding: 100px 7vw; }
  footer { flex-direction: column; align-items: flex-start; }
  .photo-dialog[open] { grid-template-columns: 1fr; max-height: 92vh; overflow: auto; }
  .dialog-media { min-height: 55vh; }
  .dialog-info { padding: 35px 25px; }
}

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; }
}
