/* West Village Walking — map-first. Warm paper + ink; color reserved for Mark's stops. */
: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;height:100%}
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;inset:0;background:var(--paper)}
/* warm the monochrome basemap toward found-paper; color comes back only on our markers/route */
#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:14px}
.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:18px 20px 26px;text-align:center;pointer-events:none;
  background:linear-gradient(to bottom, rgba(244,239,226,.94) 40%, rgba(244,239,226,0))}
#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}

.hint{position:fixed;left:50%;transform:translateX(-50%);top:118px;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}

.commission{position:fixed;bottom:22px;left:14px;z-index:6;font-family:"Inter",sans-serif;font-weight:600;font-size:12px;
  letter-spacing:.03em;color:var(--paper);background:var(--brick);border:0;padding:11px 16px;border-radius:99px;
  cursor:pointer;box-shadow:0 3px 10px var(--shadow)}
.commission:hover{background:#b1462f}

/* ---------- 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;
  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)}
.sheet-close{position:absolute;top:12px;right:14px;z-index:2;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{max-height:90vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:30px 22px 48px;max-width:var(--maxw);margin:0 auto}

/* ---------- 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}

.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}

/* chooser */
.chooser{margin-top:20px}
.chooser-hint{font-family:"Inter",sans-serif;font-size:12.5px;color:var(--ink-soft);margin:0 0 10px}
.chooser-hint .star{color:var(--gold)}
.hero{position:relative;border-radius:3px;overflow:hidden;background:var(--paper-2);box-shadow:0 8px 24px var(--shadow)}
.hero img{width:100%;aspect-ratio:4/3;object-fit:cover}
.hero .pickflag{position:absolute;right:10px;bottom:10px;background:var(--gold);color:#1c160a;font-family:"Inter",sans-serif;
  font-weight:600;font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:99px;box-shadow:0 2px 8px rgba(0,0,0,.25)}
.strip{display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px;margin-top:8px}
.strip button{padding:0;border:2px solid transparent;border-radius:3px;overflow:hidden;cursor:pointer;background:none;aspect-ratio:1;line-height:0;transition:border-color .12s,transform .12s}
.strip button img{width:100%;height:100%;object-fit:cover}
.strip button[aria-pressed="true"]{border-color:var(--gold);transform:translateY(-1px);box-shadow:0 3px 10px var(--shadow)}
.strip button:focus-visible{outline:2px solid var(--brick);outline-offset:1px}
.countline{font-family:"Inter",sans-serif;font-size:11.5px;color:var(--ink-soft);margin-top:8px;text-align:right}

.cliprow{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:16px}
.cliprow video{width:100%;aspect-ratio:9/16;object-fit:cover;border-radius:4px;background:#000;box-shadow:0 6px 18px var(--shadow)}

/* readings (washington square) */
.readings{margin-top:14px}
.reading{position:relative;padding:16px 0 18px 44px;border-bottom:1px dotted var(--line)}
.reading:last-child{border-bottom:0}
.reading .num{position:absolute;left:0;top:18px;width:30px;height:30px;border-radius:50%;border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;font-family:"Inter",sans-serif;font-weight:600;font-size:14px}
.reading h3{font-family:"Playfair Display",serif;font-weight:700;font-size:21px;line-height:1.15;margin:0 0 4px}
.reading .cue{font-family:"Inter",sans-serif;font-size:12px;letter-spacing:.04em;text-transform:uppercase;color:var(--gold);font-weight:500;margin:0 0 9px}
.reading p.body{margin:0}
.reading.transition{padding-left:0;text-align:center;border-bottom:0}
.reading.transition .num{display:none}
.reading.transition h3{font-size:19px;font-style:italic;font-weight:500;color:var(--ink-soft)}
.reading.transition .arrow{font-size:24px;color:var(--gold);margin-top:4px}

/* close / commission detail */
.close-detail{text-align:center;padding:14px 6px}
.close-detail h2{font-size:25px;margin-bottom:12px}
.close-detail .cta{display:inline-block;margin-top:10px;font-family:"Inter",sans-serif;font-weight:600;font-size:14px;
  letter-spacing:.05em;text-transform:uppercase;color:var(--paper);text-decoration:none;background:var(--brick);padding:14px 26px;border-radius:99px}

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