/* Harryhood — map-first. Warm paper + ink; color reserved for Mark's stops.
   Sibling visual register to the West Village walk: same Pennell brand thread. */
:root{
  --paper:#f4efe2; --paper-2:#efe8d8; --ink:#211f1b; --ink-soft:#544e44;
  --line:#cabfa6; --gold:#b0853a; --brick:#9c3b2e; --shadow:rgba(40,33,20,.18); --maxw:600px;
}
*{box-sizing:border-box}
html,body{margin:0;width:100%;height:100%;max-width:none}
body{background:var(--paper);color:var(--ink);font-family:"EB Garamond",Georgia,serif;font-size:19px;line-height:1.6;overflow:hidden}
img{max-width:100%;display:block}

/* ---------- map ---------- */
#map{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:var(--paper)}
#map .maplibregl-canvas{filter:sepia(.42) saturate(.72) brightness(1.04) contrast(.94) hue-rotate(-8deg)}
.maplibregl-ctrl-attrib{font-family:"Inter",sans-serif;font-size:9px}
.maplibregl-ctrl-group{border-radius:8px!important;box-shadow:0 2px 8px var(--shadow)!important}

/* ---------- markers ---------- */
.mk{appearance:none;background:none;border:0;padding:0;cursor:pointer;display:flex;flex-direction:column;align-items:center;transform:translateY(4px);transition:transform .12s}
.mk:hover{transform:translateY(1px)}
.mk-dot{width:28px;height:28px;border-radius:50%;background:var(--gold);border:2.5px solid var(--paper);
  box-shadow:0 3px 9px rgba(40,33,20,.45);display:flex;align-items:center;justify-content:center;
  color:#1c160a;font-family:"Inter",sans-serif;font-weight:700;font-size:13px;line-height:1}
.mk-start .mk-dot{width:34px;height:34px;background:var(--brick);color:#f4efe2;font-size:13px}
.mk-finale .mk-dot{background:#c2632e;color:#fff}
.mk-needsmark .mk-dot{border-style:dashed;border-color:#9c3b2e}
.mk-label{margin-top:7px;font-family:"Inter",sans-serif;font-size:11px;font-weight:600;letter-spacing:.02em;
  color:var(--ink);background:rgba(244,239,226,.86);padding:2px 7px;border-radius:99px;white-space:nowrap;box-shadow:0 1px 4px var(--shadow)}

/* ---------- masthead overlay ---------- */
#mast{position:fixed;top:0;left:0;right:0;z-index:5;padding:14px 20px 26px;text-align:center;pointer-events:none;
  background:linear-gradient(to bottom, rgba(244,239,226,.94) 45%, rgba(244,239,226,0))}
#mast .portrait{position:relative;display:inline-block;width:50px;height:59px;margin:0 0 7px;padding:0;line-height:0}
#mast .portrait-photo{position:absolute;left:4px;top:7px;width:42px;height:46px;object-fit:cover;display:block}
#mast .portrait-frame{position:relative;width:50px;height:59px;display:block;pointer-events:none}
#mast .kicker{font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-weight:600;margin:0}
#mast h1{font-family:"Playfair Display",serif;font-weight:700;font-size:30px;line-height:1;margin:3px 0 0}
#mast .chapter{font-style:italic;color:var(--ink-soft);font-size:16px;margin:4px 0 0}
.timing-badge{display:inline-block;margin-top:8px;font-family:"Inter",sans-serif;font-size:10.5px;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;color:var(--paper);background:var(--gold);padding:3px 11px;border-radius:99px}

.hint{position:fixed;left:50%;transform:translateX(-50%);top:188px;z-index:5;
  font-family:"Inter",sans-serif;font-size:12.5px;color:var(--ink);background:rgba(244,239,226,.92);
  padding:8px 15px;border-radius:99px;box-shadow:0 3px 12px var(--shadow);max-width:86vw;text-align:center}

/* PRIMARY booking button — the conversion this product exists to produce. */
.book{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:6;font-family:"Inter",sans-serif;font-weight:600;font-size:13px;
  letter-spacing:.02em;color:#1c160a;background:var(--gold);border:0;padding:13px 20px;border-radius:99px;
  cursor:pointer;box-shadow:0 4px 14px var(--shadow);max-width:92vw}
.book:hover{background:#c4954a}
.book:focus-visible{outline:2px solid var(--brick);outline-offset:2px}

/* ---------- scrim + sheet ---------- */
.scrim{position:fixed;inset:0;z-index:8;background:rgba(28,24,18,.34);opacity:0;transition:opacity .28s}
.scrim.show{opacity:1}
.sheet{position:fixed;left:0;right:0;bottom:0;z-index:9;max-height:90vh;display:flex;flex-direction:column;
  background:var(--paper);border-radius:18px 18px 0 0;box-shadow:0 -10px 40px rgba(28,24,18,.4);
  transform:translateY(102%);transition:transform .3s cubic-bezier(.2,.8,.2,1);overflow:hidden;
  background-image:radial-gradient(circle at 30% 0%, rgba(0,0,0,.02) 0, transparent 60%)}
.sheet.open{transform:translateY(0)}
.sheet::before{content:"";position:absolute;top:8px;left:50%;transform:translateX(-50%);width:40px;height:4px;border-radius:99px;background:var(--line);z-index:3}
.sheet-close{position:absolute;top:12px;right:14px;z-index:3;width:34px;height:34px;border-radius:50%;border:1px solid var(--line);
  background:var(--paper);color:var(--ink);font-size:15px;cursor:pointer;line-height:1}
#sheet-body{flex:1 1 auto;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:30px 22px 26px;max-width:var(--maxw);margin:0 auto;width:100%}

/* walk nav — pinned below the scrolling body, prev / position / next */
.sheet-nav{flex:0 0 auto;display:flex;align-items:center;justify-content:space-between;gap:10px;
  width:100%;max-width:var(--maxw);margin:0 auto;padding:10px 16px calc(12px + env(safe-area-inset-bottom));
  border-top:1px solid var(--line);background:var(--paper)}
.nav-btn{display:inline-flex;align-items:center;gap:7px;max-width:42vw;font-family:"Inter",sans-serif;font-weight:600;font-size:13px;
  color:var(--ink);background:var(--paper-2);border:1px solid var(--line);padding:9px 14px;border-radius:99px;cursor:pointer}
.nav-btn:hover{background:#e7dec9}
.nav-btn:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.nav-btn[disabled]{opacity:.32;pointer-events:none}
.nav-btn .nav-lbl{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-btn .nav-ar{font-size:15px;line-height:1;flex:0 0 auto}
.nav-finish{background:var(--gold);border-color:var(--gold);color:#1c160a}
.nav-finish:hover{background:#c4954a}
.nav-count{flex:0 0 auto;font-family:"Inter",sans-serif;font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--ink-soft)}

/* ---------- detail ---------- */
.detail-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:4px}
.detail h2{font-family:"Playfair Display",serif;font-weight:700;font-size:28px;margin:0;line-height:1.05}
.detail .addr{font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft)}
.detail .since{font-style:italic;color:var(--gold);font-size:17px;margin:3px 0 0}
.detail .blurb{color:var(--ink-soft);font-size:17px;margin:12px 0 14px}
.detail .reading-body{font-size:18px;margin:0 0 18px}
.detail .reading-body::first-letter{font-family:"Playfair Display",serif;font-weight:700;font-size:1.15em}

/* draft / needs-mark notices — honest scaffolding cues */
.notice{font-family:"Inter",sans-serif;font-size:12px;line-height:1.45;border-radius:8px;padding:9px 12px;margin:0 0 16px}
.notice.draft{color:var(--ink-soft);background:rgba(176,133,58,.10);border:1px dashed var(--line)}
.notice.mark{color:#7d2c20;background:rgba(156,59,46,.08);border:1px dashed rgba(156,59,46,.4)}
.notice b{font-weight:600}

/* song allusion panel — title/theme reference, never a quote (IP Flag A) */
.song{display:flex;gap:11px;align-items:flex-start;margin:2px 0 18px;padding:13px 15px;border-radius:10px;
  background:rgba(40,33,20,.04);border-left:3px solid var(--gold)}
.song .note-ico{font-size:17px;line-height:1.3;color:var(--gold)}
.song .song-text{font-family:"Inter",sans-serif;font-size:13.5px;line-height:1.5;color:var(--ink)}
.song .song-text b{font-weight:600;font-style:italic;font-family:"EB Garamond",serif}

/* per-stop share affordance — the distribution mechanism (Agora) */
.share-stop{display:inline-flex;align-items:center;gap:7px;margin-top:2px;font-family:"Inter",sans-serif;font-weight:600;font-size:12.5px;
  letter-spacing:.02em;color:var(--ink);background:var(--paper-2);border:1px solid var(--line);padding:9px 15px;border-radius:99px;cursor:pointer}
.share-stop:hover{background:#e7dec9}
.share-stop:focus-visible{outline:2px solid var(--gold);outline-offset:2px}

.voice{position:relative;border-radius:4px;overflow:hidden;background:#000;box-shadow:0 10px 30px var(--shadow);max-width:330px;margin:6px auto 0}
.voice video{width:100%;display:block;aspect-ratio:9/16;background:#000;object-fit:cover}
.voice .vlabel{position:absolute;left:10px;top:10px;z-index:2;background:rgba(20,18,15,.78);color:#f4efe2;
  font-family:"Inter",sans-serif;font-size:11px;letter-spacing:.05em;text-transform:uppercase;padding:5px 9px;border-radius:99px;pointer-events:none}
.voice .vlabel b{color:var(--gold);font-weight:600}

/* close / booking detail */
.close-detail{text-align:center;padding:14px 6px}
.close-detail h2{font-size:25px;margin-bottom:12px}
.close-detail .blurb{text-align:left}
.close-detail .cta{display:inline-block;margin-top:6px;font-family:"Inter",sans-serif;font-weight:600;font-size:14px;
  letter-spacing:.04em;color:#1c160a;text-decoration:none;background:var(--gold);padding:14px 26px;border-radius:99px}
.close-detail .cta.secondary{background:none;color:var(--ink-soft);text-decoration:underline;padding:8px;font-size:13px;letter-spacing:.02em}
.close-detail .cta-sub{font-family:"Inter",sans-serif;font-size:12.5px;color:var(--ink-soft);margin:14px 0 2px}
.close-detail .uber{display:inline-block;margin-top:18px;font-family:"Inter",sans-serif;font-weight:600;font-size:13px;
  color:var(--paper);text-decoration:none;background:var(--ink);padding:12px 22px;border-radius:99px}

.timing-note{font-family:"Inter",sans-serif;font-size:12.5px;line-height:1.5;color:var(--ink-soft);
  border-top:1px dotted var(--line);margin-top:22px;padding-top:14px}
.timing-note b{color:var(--ink);font-weight:600}

@media(max-width:380px){ #mast h1{font-size:26px} .detail h2{font-size:24px} .hint{top:196px} }
