/* ============================================================
   Yakushima Deck — Forest / Editorial Aesthetic
   Palette: deep forest green, warm ivory, ink, soft moss, ember
   ============================================================ */

:root {
  --ivory: #f5f1e8;
  --ivory-warm: #ede6d3;
  --paper: #faf7ee;
  --ink: #1f2a26;
  --ink-soft: #3a4843;
  --moss-deep: #2d3f33;
  --moss: #4a6b54;
  --moss-light: #7a9c83;
  --moss-pale: #c9d6c9;
  --ember: #c4612b;
  --ember-soft: #d98847;
  --stone: #8a8a82;
  --line: #2d3f33;
  --line-soft: rgba(45, 63, 51, 0.18);

  --serif: "Noto Serif TC", "Songti TC", "Source Han Serif", serif;
  --sans: "Noto Sans TC", "PingFang TC", "Helvetica Neue", Helvetica, sans-serif;
  --mono: "Montserrat", "Helvetica Neue", Helvetica, Arial, sans-serif;
}

deck-stage {
  background: #0d100e;
}

section {
  width: 1920px;
  height: 1080px;
  position: relative;
  overflow: hidden;
  font-family: var(--sans);
  color: var(--ink);
  background: var(--ivory);
}

/* ---------- shared chrome ---------- */
.page-chrome {
  position: absolute;
  top: 56px;
  left: 80px;
  right: 80px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.18em;
  color: var(--ink-soft);
  text-transform: uppercase;
  z-index: 5;
}
.page-chrome .brand { display: flex; gap: 18px; align-items: baseline; white-space: nowrap; }
.page-chrome .brand .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ember);
  display: inline-block;
  transform: translateY(-1px);
}
.page-chrome .ch { color: var(--ink); font-weight: 500; }
.page-chrome .num { color: var(--moss); }

.page-footer {
  position: absolute;
  bottom: 48px;
  left: 80px;
  right: 80px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  color: var(--stone);
  text-transform: uppercase;
  z-index: 5;
  white-space: nowrap;
}

/* ---------- typography ---------- */
.kicker {
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ember);
  margin-bottom: 28px;
}
.title-jp {
  font-family: var(--serif);
  font-size: 22px;
  letter-spacing: 0.4em;
  color: var(--moss);
  margin-bottom: 8px;
}
h1.title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 132px;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--moss-deep);
  margin: 0;
}
h2.section-title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 96px;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--moss-deep);
  margin: 0 0 20px 0;
}
h3.place-title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 84px;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--moss-deep);
  margin: 0 0 36px 0;
}
p.body {
  font-size: 22px;
  line-height: 1.85;
  color: var(--ink-soft);
  text-wrap: pretty;
}
p.lead {
  font-size: 26px;
  line-height: 1.75;
  color: var(--ink);
  text-wrap: pretty;
}

/* ---------- 01 cover ---------- */
.cover {
  background: var(--moss-deep);
  color: var(--ivory);
}
.cover .bg-island {
  position: absolute;
  right: -120px;
  top: 50%;
  transform: translateY(-50%);
  width: 1200px;
  height: 1200px;
  opacity: 0.16;
}
.cover .stack {
  position: absolute;
  left: 140px;
  top: 50%;
  transform: translateY(-50%);
  max-width: 900px;
}
.cover .kicker { color: var(--ember-soft); }
.cover h1.title {
  color: var(--ivory);
  font-size: 220px;
  line-height: 0.92;
  letter-spacing: -0.02em;
}
.cover .jp-vert {
  position: absolute;
  right: 100px;
  top: 56px;
  font-family: var(--serif);
  writing-mode: vertical-rl;
  font-size: 28px;
  letter-spacing: 0.5em;
  color: var(--ivory-warm);
  opacity: 0.7;
}
.cover .meta {
  margin-top: 60px;
  display: flex;
  gap: 60px;
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--moss-pale);
}
.cover .meta strong { color: var(--ivory); display:block; font-size: 22px; margin-bottom: 6px; letter-spacing: 0.18em; }
.cover .page-chrome { color: var(--moss-pale); }
.cover .page-chrome .ch { color: var(--ivory); }
.cover .page-footer { color: var(--moss-pale); }

/* ---------- 02 overview ---------- */
.overview {
  display: grid;
  grid-template-columns: 580px 1fr;
  gap: 0;
}
.overview .left {
  padding: 160px 60px 100px 80px;
}
.overview .right {
  position: relative;
  background: var(--ivory-warm);
  border-left: 1px solid var(--line-soft);
}
.overview .map-wrap {
  position: absolute;
  inset: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.overview .map-wrap svg {
  width: 100%;
  height: 100%;
  max-height: 920px;
}
.overview .legend {
  margin-top: 36px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 24px;
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.1em;
  color: var(--ink);
}
.overview .legend .item {
  display: flex; align-items: center; gap: 12px;
  cursor: pointer;
  padding: 6px 8px;
  border-radius: 4px;
  transition: color 0.2s;
}
.overview .legend .item:hover {
  color: var(--ember);
}
.overview .legend .num {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--moss-deep); color: var(--ivory);
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
}
.overview .legend .item.ember .num { background: var(--ember); }

/* ---------- chapter intro ---------- */
.chapter {
  background: var(--moss-deep);
  color: var(--ivory);
  display: grid;
  grid-template-columns: 1fr 700px;
}
.chapter .meta-col {
  padding: 200px 0 100px 80px;
}
.chapter .map-col {
  position: relative;
  border-left: 1px solid rgba(245, 241, 232, 0.12);
}
.chapter .num-big {
  font-family: var(--mono);
  font-size: 22px;
  letter-spacing: 0.3em;
  color: var(--ember-soft);
  margin-bottom: 40px;
}
.chapter h2.section-title { color: var(--ivory); font-size: 160px; }
.chapter .jp { color: var(--moss-pale); font-family: var(--serif); font-size: 34px; letter-spacing: 0.4em; margin-top: 20px; }
.chapter .desc { margin-top: 60px; max-width: 600px; font-size: 24px; line-height: 1.85; color: var(--moss-pale); text-wrap: pretty; }
.chapter .page-chrome { color: var(--moss-pale); }
.chapter .page-chrome .ch { color: var(--ivory); }
.chapter .page-footer { color: var(--moss-pale); }
.chapter .mini-map {
  position: absolute;
  inset: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ---------- place page ---------- */
.place {
  display: grid;
  grid-template-columns: 1fr 760px;
}
.place .content {
  padding: 130px 70px 90px 80px;
  display: flex;
  flex-direction: column;
}
.place .map-side {
  position: relative;
  background: var(--ivory-warm);
  border-left: 1px solid var(--line-soft);
}
.place .map-side .mini-map {
  position: absolute;
  inset: 90px 80px 240px 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.place .map-side .spot-list {
  position: absolute;
  bottom: 90px;
  left: 80px;
  right: 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px 24px;
  font-size: 16px;
  font-family: var(--mono);
  letter-spacing: 0.06em;
  color: var(--ink);
  border-top: 1px solid var(--line-soft);
  padding-top: 20px;
}
.place .map-side .spot-list .row {
  display: flex; gap: 12px; align-items: baseline;
}
.place .map-side .spot-list .pin {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--ember); color: var(--ivory);
  display:inline-flex; align-items:center; justify-content:center;
  font-size: 11px; font-weight: 700;
  flex-shrink: 0;
}
.place .header-row {
  display: flex; align-items: baseline; gap: 32px;
  margin-bottom: 14px;
  white-space: nowrap;
}
.place .place-num {
  font-family: var(--mono);
  font-size: 18px;
  letter-spacing: 0.3em;
  color: var(--ember);
  white-space: nowrap;
}
.place .jp-name {
  font-family: var(--serif);
  font-size: 30px;
  letter-spacing: 0.3em;
  color: var(--moss);
  margin-top: 16px;
  margin-bottom: 36px;
}
.place .body-text {
  font-size: 19px;
  line-height: 1.85;
  color: var(--ink-soft);
  text-wrap: pretty;
  flex: 1;
  columns: 1;
  max-width: 940px;
}
.place .body-text p { margin: 0 0 14px 0; }
.place .highlight-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 28px;
  padding-top: 28px;
  border-top: 1px solid var(--line-soft);
}
.place .highlight-row .h-item {
  font-family: var(--sans);
}
.place .highlight-row .h-tag {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--ember);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.place .highlight-row .h-name {
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
}
.place .highlight-row .h-note {
  font-size: 13px;
  color: var(--stone);  margin-top: 4px;
  line-height: 1.4;
}

/* ---------- route slide ---------- */
.route {
  background: var(--paper);
}
.route .map-large {
  position: absolute;
  inset: 140px 80px 160px 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.route .map-large svg { width: 100%; height: 100%; max-height: 780px; }
.route .legend-bottom {
  position: absolute;
  bottom: 100px;
  left: 80px;
  right: 80px;
  display: flex;
  gap: 40px;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.14em;
  color: var(--ink);
  text-transform: uppercase;
  align-items: center;
}
.route .legend-bottom .swatch {
  display: inline-flex; align-items:center; gap: 10px;
}
.route .legend-bottom .line-sample {
  width: 36px; height: 3px;
  background: var(--ember);
}
.route .legend-bottom .line-sample.dashed {
  background: repeating-linear-gradient(90deg, var(--moss) 0 8px, transparent 8px 14px);
  height: 3px;
}

/* ---------- closing ---------- */
.closing {
  background: var(--moss-deep);
  color: var(--ivory);
}
.closing .stack {
  position: absolute;
  left: 140px;
  right: 140px;
  top: 50%;
  transform: translateY(-50%);
}
.closing h2.section-title {
  color: var(--ivory);
  font-size: 120px;
  line-height: 1.1;
  max-width: 1400px;
}
.closing .quote {
  font-family: var(--serif);
  font-size: 36px;
  line-height: 1.7;
  color: var(--moss-pale);
  margin-top: 60px;
  max-width: 1200px;
  text-wrap: pretty;
}
.closing .signoff {
  margin-top: 80px;
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: 0.3em;
  color: var(--ember-soft);
  text-transform: uppercase;
}
.closing .page-chrome { color: var(--moss-pale); }
.closing .page-chrome .ch { color: var(--ivory); }
.closing .page-footer { color: var(--moss-pale); }

/* ---------- map element shared ---------- */
.island-coast {
  fill: var(--ivory);
  stroke: var(--moss-deep);
  stroke-width: 2.5;
}
.chapter .island-coast { fill: rgba(245,241,232,0.04); stroke: var(--moss-pale); stroke-width: 2; }
.island-inner {
  fill: var(--moss-pale);
  opacity: 0.35;
}
.chapter .island-inner { fill: var(--moss); opacity: 0.25; }
.island-mountain {
  fill: none;
  stroke: var(--moss);
  stroke-width: 1.5;
  stroke-dasharray: 4 5;
  opacity: 0.65;
}
.chapter .island-mountain { stroke: var(--moss-light); opacity: 0.5; }

.zone-region {
  fill: none;
  stroke: var(--moss);
  stroke-width: 1;
  stroke-dasharray: 3 6;
  opacity: 0.5;
}
.zone-label {
  font-family: var(--mono);
  font-size: 20px;
  letter-spacing: 0.18em;
  fill: var(--moss-deep);
  text-transform: uppercase;
  opacity: 0.55;
}
.chapter .zone-label { fill: var(--moss-pale); opacity: 0.7; }

.pin-dot {
  fill: var(--ember);
  stroke: var(--ivory);
  stroke-width: 2.5;
  cursor: pointer;
  transition: transform 0.2s;
}
.pin-dot.muted {
  fill: var(--moss);
  opacity: 0.55;
}
.pin-dot.active {
  fill: var(--ember);
  r: 14;
}
.pin-dot:hover { transform: scale(1.15); transform-origin: center; transform-box: fill-box; }
.pin-num {
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 700;
  fill: var(--ivory);
  pointer-events: none;
  text-anchor: middle;
}
.pin-label {
  font-family: var(--sans);
  font-size: 20px;
  font-weight: 600;
  fill: var(--ink);
}
/* On the smaller place-page mini-maps, scale labels up so they read at
   roughly the same size as the spot-list below. */
.place .mini-map .pin-label {
  font-size: 28px;
  font-weight: 700;
}
.place .mini-map .pin-num {
  font-size: 18px;
}
.place .mini-map .pin-dot {
  stroke-width: 3.5;
}
.chapter .pin-label, .chapter .pin-label-sub { fill: var(--ivory); }
.pin-label-sub {
  font-family: var(--mono);
  font-size: 15px;
  letter-spacing: 0.15em;
  fill: var(--ink-soft);
  text-transform: uppercase;
}

.spot-pin {
  fill: var(--ember);
  stroke: var(--ivory);
  stroke-width: 1.5;
}
.spot-label {
  font-family: var(--sans);
  font-size: 14px;
  fill: var(--ink);
  font-weight: 500;
}

.compass {
  font-family: var(--mono);
  font-size: 18px;
  letter-spacing: 0.2em;
  fill: var(--moss);
  opacity: 0.7;
}
.chapter .compass { fill: var(--moss-pale); }

.scale-bar {
  font-family: var(--mono);
  font-size: 14px;
  letter-spacing: 0.15em;
  fill: var(--ink-soft);
  text-transform: uppercase;
}
.scale-bar line { stroke: var(--ink-soft); stroke-width: 1.5; }
.chapter .scale-bar { fill: var(--moss-pale); }
.chapter .scale-bar line { stroke: var(--moss-pale); }

/* ---------- place-photos secondary layout ---------- */
/* Used when a region spans 2 slides — page A has body + photo grid;
   page B has continuation + highlight-row + map-side. */
.place .photos {
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
  gap: 18px;
  margin-top: 30px;
  max-width: 940px;
  height: 540px;
}
.place .photos.three {
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr 1fr;
}
.place .photos.three .photo:first-child {
  grid-row: span 2;
}
.place .photos .photo {
  background: var(--ivory-warm);
  border: 1px solid var(--line-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--stone);
  position: relative;
  overflow: hidden;
}
.place .photos .photo::before {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px dashed rgba(45, 63, 51, 0.15);
}
.place .photos .photo .ph-label {
  position: relative;
  z-index: 1;
  text-align: center;
  line-height: 1.6;
}
.place .photos .photo .ph-tag {
  font-family: var(--serif);
  color: var(--moss);
  font-size: 14px;
  letter-spacing: 0.15em;
  display: block;
  margin-bottom: 6px;
}
.place .photos .photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
  z-index: 1;
}

/* On a "page B" continuation slide, the title block is omitted so the
   body sits a bit higher and breathes. */
.place.continued .content {
  padding-top: 110px;
}
/* For wishlist B-sides that include a header-row + big title, match the
   first slide's layout so the title lines up vertically. */
.place.continued:has(.wish-title) .content {
  padding-top: 130px;
}
.place.continued .place-title-mini {
  font-family: var(--sans);
  font-weight: 700;
  font-size: 28px;
  color: var(--moss-deep);
  letter-spacing: 0.05em;
  margin-bottom: 12px;
}
/* Wishlist B-side: reuse big place-title + small subtitle, no arrow */
.place.continued .wish-title {
  font-family: var(--sans);
  font-weight: 800;
  font-size: 84px;
  line-height: 1.0;
  letter-spacing: -0.01em;
  color: var(--moss-deep);
  margin: 0 0 14px 0;
}
.place.continued .wish-subtitle {
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: var(--ember);
  margin-bottom: 32px;
}

/* ---------- side narrative (replaces photos when no images) ---------- */
.place .narrative {
  position: absolute;
  inset: 110px 80px 100px 80px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.place .narrative .nrv-kicker {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ember);
  margin-bottom: 24px;
}
.place .narrative .nrv-quote {
  font-family: var(--serif);
  font-size: 34px;
  line-height: 1.55;
  color: var(--moss-deep);
  font-weight: 500;
  text-wrap: pretty;
  position: relative;
  padding-left: 28px;
  border-left: 2px solid var(--ember);
}
.place .narrative .nrv-attrib {
  margin-top: 24px;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.2em;
  color: var(--stone);
  text-transform: uppercase;
}
.place .narrative .nrv-meta {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 24px;
  border-top: 1px solid var(--line-soft);
  padding-top: 28px;
}
.place .narrative .nrv-meta .nm-item .nm-tag {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  color: var(--ember);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.place .narrative .nrv-meta .nm-item .nm-name {
  font-size: 17px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4;
}
.place .narrative .nrv-meta .nm-item .nm-note {
  font-size: 13px;
  color: var(--stone);
  margin-top: 4px;
  line-height: 1.4;
}

/* ---------- wishlist B-side ---------- */
.place .wishlist-grid {
  margin-top: 34px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
  max-width: 940px;
}
.place .wishlist-grid .w-row {
  display: grid;
  grid-template-columns: 56px 280px 1fr;
  gap: 22px;
  padding: 18px 22px;
  background: rgba(122, 156, 131, 0.08);
  border: 1px solid var(--line-soft);
  align-items: baseline;
}
.place .wishlist-grid .w-num {
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.2em;
  color: var(--ember);
  font-weight: 600;
}
.place .wishlist-grid .w-name {
  font-family: var(--sans);
  font-size: 19px;
  font-weight: 600;
  color: var(--moss-deep);
  line-height: 1.4;
}
.place .wishlist-grid .w-note {
  font-family: var(--sans);
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.5;
}
.place .wishlist-side {
  position: absolute;
  inset: 110px 80px 90px 80px;
  display: flex;
  flex-direction: column;
}
.place .wishlist-side .ws-kicker {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ember);
  margin-bottom: 18px;
}
.place .wishlist-side .ws-title {
  font-family: var(--sans);
  font-size: 36px;
  font-weight: 700;
  color: var(--moss-deep);
  margin-bottom: 14px;
  line-height: 1.2;
}
.place .wishlist-side .ws-jp {
  font-family: var(--serif);
  font-size: 18px;
  letter-spacing: 0.3em;
  color: var(--moss);
  margin-bottom: 32px;
}
.place .wishlist-side .ws-body {
  font-family: var(--serif);
  font-size: 21px;
  line-height: 1.85;
  color: var(--ink-soft);
  text-wrap: pretty;
}
.place .wishlist-side .ws-deco {
  margin-top: auto;
  padding-top: 30px;
  border-top: 1px solid var(--line-soft);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--stone);
  text-transform: uppercase;
  display: flex;
  justify-content: space-between;
}

/* ---------- closing wishlist additions ---------- */
.closing .other-wish {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
  max-width: 1500px;
}
.closing .other-wish .ow-card {
  border: 1px solid rgba(245, 241, 232, 0.18);
  background: rgba(245, 241, 232, 0.04);
  padding: 24px 26px;
}
.closing .other-wish .ow-tag {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.25em;
  color: var(--ember-soft);
  text-transform: uppercase;
  margin-bottom: 10px;
}
.closing .other-wish .ow-name {
  font-family: var(--sans);
  font-size: 22px;
  font-weight: 600;
  color: var(--ivory);
  line-height: 1.3;
  margin-bottom: 8px;
}
.closing .other-wish .ow-note {
  font-family: var(--sans);
  font-size: 14px;
  line-height: 1.55;
  color: var(--moss-pale);
}

/* ---------- photo-side variant (e.g. Onoaida 2/2) ---------- */
.place .photo-side {
  position: relative;
  background: var(--moss-deep);
  border-left: 1px solid var(--line-soft);
  overflow: hidden;
}
.place .photo-side img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.place.continued.onoaida-photo .content {
  padding-top: 130px;
  padding-bottom: 80px;
}
.place.continued.kurio-photo .content {
  padding-top: 130px;
  padding-bottom: 80px;
}
/* Kurio's landscape photo: crop biased to the left so the river bank
   and the car at the far-left edge stay in frame. */
.place.continued.kurio-photo .photo-side img {
  object-position: left 35%;
}
.place .photo-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--moss-deep);
  color: var(--moss-pale);
  position: relative;
}
.place .photo-placeholder::before {
  content: "";
  position: absolute;
  inset: 60px;
  border: 1px dashed rgba(201, 214, 201, 0.25);
}
.place .photo-placeholder .ph-label {
  position: relative;
  z-index: 1;
  text-align: center;
  font-family: var(--mono);
  font-size: 13px;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  line-height: 1.8;
  color: var(--moss-pale);
}
.place .photo-placeholder .ph-tag {
  font-family: var(--serif);
  color: var(--ember-soft);
  font-size: 16px;
  letter-spacing: 0.3em;
  display: block;
  margin-bottom: 10px;
}
.place .photo-caption-overlay {
  position: absolute;
  left: 32px;
  bottom: 80px;
  right: 32px;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 20px 24px;
  background: rgba(13, 16, 14, 0.6);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.place .photo-caption-overlay .pc-time { color: var(--ember-soft); }
.place .photo-caption-overlay .pc-loc { color: var(--ivory-warm); }

/* ---------- dusk-strip (returns from old narrative panel) ---------- */
.place .dusk-strip {
  margin-top: 32px;
  padding-top: 26px;
  border-top: 1px solid var(--line-soft);
  display: grid;
  grid-template-columns: 320px 1fr;
  gap: 32px;
  align-items: end;
}
.place .dusk-strip .ds-kicker {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--ember);
  margin-bottom: 14px;
}
.place .dusk-strip .ds-quote {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.45;
  color: var(--moss-deep);
  font-weight: 500;
  text-wrap: pretty;
  padding-left: 18px;
  border-left: 2px solid var(--ember);
}
.place .dusk-strip .ds-attrib {
  margin-top: 14px;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--stone);
  text-transform: uppercase;
}
.place .dusk-strip .ds-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px 22px;
}
.place .dusk-strip .ds-item .ds-tag {
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  color: var(--ember);
  text-transform: uppercase;
  margin-bottom: 5px;
}
.place .dusk-strip .ds-item .ds-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.35;
  margin-bottom: 3px;
}
.place .dusk-strip .ds-item .ds-note {
  font-size: 12px;
  color: var(--stone);
  line-height: 1.4;
}

/* ---------- credit link (cover footer + closing signoff) ---------- */
.credit-link {
  color: var(--ember);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: opacity 0.2s;
}
.credit-link:hover {
  opacity: 0.7;
}
.cover .credit-link,
.closing .credit-link {
  color: var(--ember-soft);
}

/* ---------- shop links ---------- */
.shop-link {
  color: var(--ember);
  text-decoration: none;
  border-bottom: 1px dashed rgba(196, 97, 43, 0.5);
  transition: all 0.2s;
  cursor: pointer;
}
.shop-link:hover {
  color: var(--moss-deep);
  border-bottom-color: var(--moss-deep);
  background: rgba(196, 97, 43, 0.08);
}
.shop-link::after {
  content: " ↗";
  font-size: 0.75em;
  opacity: 0.6;
}

/* ---------- print ---------- */
@media print {
  section { background: var(--ivory) !important; }
}
