/* =============================================
   SELSTA VILLAGE — Isometric facility map (prototype)
   POP tone, self-contained. No external 3D libs.
   ============================================= */

.mapsec { padding: 96px 0 108px; background: linear-gradient(180deg, #fbf7ef 0%, #f2efe6 100%); overflow: hidden; }
.mapsec .sec-hd h2 { letter-spacing: .02em; }
.map-badge { display: inline-flex; align-items: center; gap: 8px; height: 26px; padding: 0 14px; border-radius: 100px; background: #fde7d2; color: #b9772a; font-family: var(--ff-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 16px; }

/* Stage: fixed aspect box so % positioned pins track the SVG exactly */
.iso-stage { position: relative; width: 100%; max-width: 980px; margin: 40px auto 0; aspect-ratio: 1000 / 700; }
.iso-stage--wide { max-width: 1120px; aspect-ratio: 1200 / 880; }
.mapsec--wide .wrap { max-width: 1180px; }
/* iPhone: keep the illustrated map legible by allowing horizontal scroll */
@media (max-width: 820px) {
  .mapsec--wide .wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .iso-stage--wide { min-width: 760px; margin-top: 28px; }
  .iso-pin-card { padding: 4px 10px 4px 5px; }
  .iso-pin-txt b { font-size: 11.5px; }
}
.iso-scene { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; filter: drop-shadow(0 24px 30px rgba(60,45,25,.12)); animation: isoFloat 7s ease-in-out infinite; }
@keyframes isoFloat { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-8px); } }

/* Hotspot pins (HTML overlay, aligned to SVG coords via %) */
.iso-pin { position: absolute; transform: translate(-50%, -100%); display: flex; flex-direction: column; align-items: center; gap: 0; cursor: pointer; text-decoration: none; z-index: 3; }
.iso-pin-card { display: flex; align-items: center; gap: 10px; background: #fff; border: 1.5px solid var(--border); border-radius: 100px; padding: 7px 16px 7px 8px; box-shadow: 0 8px 22px rgba(60,45,25,.16); transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease; }
.iso-pin:hover .iso-pin-card { transform: translateY(-4px); box-shadow: 0 14px 30px rgba(60,45,25,.24); border-color: var(--accent); }
.iso-pin-emoji { width: 38px; height: 38px; flex: none; display: grid; place-items: center; border-radius: 50%; font-size: 19px; }
.iso-pin--school .iso-pin-emoji { background: #e3efd9; }
.iso-pin--okurigi .iso-pin-emoji { background: #f3e6d2; }
.iso-pin--place .iso-pin-emoji { background: #dfeaf3; }
.iso-pin-txt { display: flex; flex-direction: column; line-height: 1.25; padding-right: 6px; }
.iso-pin-txt b { font-family: var(--ff-serif); font-size: 15px; color: var(--text); font-weight: 700; white-space: nowrap; }
.iso-pin-txt span { font-family: var(--ff-mono); font-size: 9px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent); }
.iso-pin-stem { width: 2px; height: 26px; background: linear-gradient(var(--accent), rgba(126,164,126,0)); }
.iso-pin-foot { width: 12px; height: 5px; border-radius: 50%; background: rgba(60,45,25,.18); margin-top: -2px; animation: pinPulse 2.6s ease-in-out infinite; }
@keyframes pinPulse { 0%,100% { transform: scale(1); opacity:.7; } 50% { transform: scale(1.35); opacity:.35; } }
.iso-pin--school { animation: isoFloat 6.5s ease-in-out infinite; }
.iso-pin--okurigi { animation: isoFloat 6.5s ease-in-out .8s infinite; }
.iso-pin--place { animation: isoFloat 6.5s ease-in-out 1.6s infinite; }

.map-note { text-align: center; color: var(--text-muted); font-size: 12.5px; margin-top: 40px; }

@media (max-width: 680px) {
  .mapsec { padding: 64px 0 76px; }
  .iso-pin-txt b { font-size: 12.5px; }
  .iso-pin-emoji { width: 30px; height: 30px; font-size: 15px; }
  .iso-pin-card { padding: 5px 12px 5px 6px; gap: 7px; }
  .iso-pin-stem { height: 16px; }
}
