/* =============================================================================
   SECOND CITY SYNDROME — shared city-map template (Tulsa · Cork · …)
   Spy/fold-out illustrated-map styling + list<->map resize + venue drill-down.
   Loaded by index.html (Tulsa) and cork.html. Pure CSS — engine in citymap.js.
   ========================================================================== */
:root{
  --blue:#3B9EFF; --pink:#ff2db2; --purple:#7a4bff;
  --navy:#0a1030; --navy-2:#0d1640; --navy-3:#121d52;
  --ink:#eaf1ff; --muted:#9fb2e6; --paper:#101a44; --river:#1f6fae;
  --zone:rgba(59,158,255,.10); --zone-line:rgba(59,158,255,.45);
  --card:rgba(255,255,255,.05);
  --hand:"Chalkboard SE","Comic Sans MS","Marker Felt","Trebuchet MS",sans-serif;
  --ui:"Avenir Next","Segoe UI",system-ui,-apple-system,sans-serif;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{
  font-family:var(--ui);color:var(--ink);
  background:
    radial-gradient(1200px 700px at 78% 8%, #18266b 0%, transparent 60%),
    radial-gradient(1000px 600px at 10% 95%, #1a1150 0%, transparent 55%),
    linear-gradient(160deg, var(--navy) 0%, var(--navy-2) 60%, #0a0e2a 100%);
  overflow:hidden;
}

/* ---------- top brand bar ---------- */
.topbar{
  height:54px;display:flex;align-items:center;gap:14px;
  padding:0 20px;border-bottom:1px solid rgba(59,158,255,.18);
  background:linear-gradient(90deg, rgba(255,45,178,.08), rgba(59,158,255,.08));
}
.logo{
  font-family:var(--hand);font-weight:700;font-size:21px;letter-spacing:.5px;
  background:linear-gradient(90deg,var(--blue),var(--pink));
  -webkit-background-clip:text;background-clip:text;color:transparent;
  text-shadow:0 0 24px rgba(255,45,178,.25);
}
.logo .dot{color:var(--pink);-webkit-text-fill-color:var(--pink)}
.tagline{font-size:12.5px;color:var(--muted);letter-spacing:.3px}
.badge{
  margin-left:auto;font-size:11px;color:var(--muted);
  border:1px dashed rgba(159,178,230,.4);border-radius:20px;padding:5px 12px;
}
.citylinks{font-size:11.5px;color:var(--muted)}
.citylinks a{color:var(--blue);text-decoration:none;font-weight:700}
.citylinks a.here{color:var(--pink)}

/* ---------- filter chips ---------- */
.filters{
  display:flex;gap:6px;align-items:center;flex-wrap:nowrap;overflow-x:auto;
  padding:8px 14px;border-bottom:1px solid rgba(59,158,255,.14);
  background:rgba(10,16,48,.55);
}
.filters::-webkit-scrollbar{height:6px}
.filters::-webkit-scrollbar-thumb{background:rgba(59,158,255,.3);border-radius:6px}
.chip{
  flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  font-family:var(--ui);font-size:11px;color:var(--muted);
  border:1px solid rgba(159,178,230,.3);border-radius:18px;padding:4px 10px;
  background:transparent;transition:all .15s ease;user-select:none;white-space:nowrap;
}
.chip .cdot{width:8px;height:8px;border-radius:50%;background:var(--blue)}
.chip.on{color:#fff;border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.08)}
.chip.off{opacity:.45;filter:saturate(.3)}
.chip.all{font-weight:700;color:#fff;border-style:dashed}

/* ---------- stage / hover resize ---------- */
.stage{display:flex;gap:14px;padding:12px;height:calc(100vh - 54px - 41px)}
.panel{
  border-radius:18px;overflow:hidden;position:relative;
  border:1px solid rgba(59,158,255,.22);
  box-shadow:0 18px 50px rgba(0,0,0,.45), inset 0 1px 0 rgba(255,255,255,.04);
  transition:flex-grow .5s cubic-bezier(.2,.85,.2,1);
  flex:1 1 0;min-height:0;
}
.events-panel{flex-grow:1.15;min-width:250px;background:linear-gradient(180deg,var(--navy-3),#0c1338);
  display:flex;flex-direction:column}
.map-panel{flex-grow:2.4;min-width:320px;background:var(--paper)}
.stage[data-focus="list"] .events-panel{flex-grow:2.9}
.stage[data-focus="list"] .map-panel{flex-grow:1}
.stage[data-focus="map"]  .events-panel{flex-grow:.62}
.stage[data-focus="map"]  .map-panel{flex-grow:4.2}
@supports selector(:has(*)){
  .stage:has(.events-panel:hover) .events-panel{flex-grow:2.9}
  .stage:has(.events-panel:hover) .map-panel{flex-grow:1}
  .stage:has(.map-panel:hover)  .events-panel{flex-grow:.62}
  .stage:has(.map-panel:hover)  .map-panel{flex-grow:4.2}
}

/* ---------- LEFT PANEL: city feed <-> venue calendar ---------- */
.events-head{
  flex:0 0 auto;padding:14px 18px 8px;position:relative;z-index:2;
  background:linear-gradient(180deg,var(--navy-3),rgba(12,19,56,.0));
}
.events-head h2{margin:0;font-size:17px;font-family:var(--hand);color:#fff}
.events-head .sub{font-size:12px;color:var(--muted);margin-top:3px}
.hint{font-size:11px;color:var(--blue);margin-top:7px;opacity:.85}
.list-scroll{flex:1 1 auto;min-height:0;overflow-y:auto;padding:6px 14px 14px}
.list-scroll::-webkit-scrollbar{width:9px}
.list-scroll::-webkit-scrollbar-thumb{background:rgba(59,158,255,.3);border-radius:9px}

/* feed event card (city mode) + calendar rows (venue mode) */
.ev{
  display:grid;grid-template-columns:54px 1fr;gap:12px;align-items:center;
  padding:10px 12px;margin:8px 2px;border-radius:14px;cursor:pointer;
  background:var(--card);border:1px solid rgba(255,255,255,.05);
  transition:transform .18s ease, background .18s ease, border-color .18s ease;
}
.ev:hover,.ev.active{
  background:linear-gradient(90deg, rgba(59,158,255,.16), rgba(255,45,178,.10));
  border-color:var(--blue);transform:translateX(4px);
}
.ev .date{
  text-align:center;border-radius:10px;padding:6px 4px;
  background:linear-gradient(160deg,var(--blue),#2b7be0);color:#04122e;
  font-weight:800;line-height:1;
}
.ev.brand .date{background:linear-gradient(160deg,var(--pink),#c81f87);color:#fff}
.ev .date .d{font-size:17px}
.ev .date .m{font-size:9.5px;letter-spacing:1px;text-transform:uppercase}
.ev .title{font-size:13.5px;font-weight:600;color:#fff;line-height:1.25}
.ev .meta{font-size:11px;color:var(--muted);margin-top:3px}
.ev .meta b{color:var(--blue);font-weight:600}

/* venue drill-down header card */
.venue-head{
  margin:6px 2px 10px;padding:12px 14px;border-radius:14px;
  background:linear-gradient(135deg, rgba(59,158,255,.14), rgba(255,45,178,.10));
  border:1.5px solid var(--vc,var(--blue));
}
.venue-head h3{margin:0;font-size:16px;font-family:var(--hand);color:#fff}
.venue-head .vh-kind{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px;margin-top:2px}
.venue-head .vh-role{font-size:11.5px;color:#eaf1ff;line-height:1.4;margin-top:7px}
.venue-head .vh-scs{font-size:10.5px;color:#ff9bd8;font-style:italic;line-height:1.4;margin-top:5px}
.backbtn{
  display:inline-flex;align-items:center;gap:6px;cursor:pointer;margin-top:9px;
  font-size:11px;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:14px;
  padding:3px 10px;background:rgba(255,255,255,.06);font-family:var(--ui);
}
.backbtn:hover{border-color:var(--pink);color:#ffd6f0}
.calendar-label{
  font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.9px;
  margin:10px 4px 2px;font-weight:700;
}
.noev{
  margin:8px 2px;padding:12px;border-radius:12px;border:1px dashed rgba(159,178,230,.35);
  font-size:11.5px;color:var(--muted);line-height:1.45;
}
.tagrow{margin-top:5px;display:flex;gap:5px;flex-wrap:wrap}
.tag{font-size:9px;letter-spacing:.4px;text-transform:uppercase;border-radius:9px;padding:2px 7px;font-weight:700}
.tag.status-active{background:rgba(79,224,160,.15);color:#7ce8b8;border:1px solid rgba(79,224,160,.4)}
.tag.status-seasonal{background:rgba(255,210,59,.13);color:#ffd96b;border:1px solid rgba(255,210,59,.35)}
.tag.status-closed{background:rgba(255,93,115,.13);color:#ff8da0;border:1px solid rgba(255,93,115,.4)}
.tag.status-lost{background:rgba(142,152,196,.13);color:#aab3d8;border:1px solid rgba(142,152,196,.4)}
.tag.status-unbuilt{background:rgba(255,138,59,.13);color:#ffb27e;border:1px solid rgba(255,138,59,.4)}
.tag.verify{background:rgba(255,178,77,.12);color:#ffc78a;border:1px dashed rgba(255,178,77,.5)}
.tag.kind{background:rgba(59,158,255,.12);color:#9fd0ff;border:1px solid rgba(59,158,255,.35)}

/* ---------- MAP ---------- */
.map-wrap{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;padding:8px}
.map-canvas{position:relative;width:100%;height:100%;aspect-ratio:1000/760;max-height:100%;max-width:100%}
.map-canvas svg{position:absolute;inset:0;width:100%;height:100%}
/* hand-drawn ink wobble — pages tag shapes with class="ink"; filter injected by engine */
.map-canvas svg .ink{filter:url(#sketchWobble)}
.map-canvas svg .ink2{filter:url(#sketchWobble2)}

.pin{
  position:absolute;transform:translate(-50%,-50%);
  background:none;border:none;padding:0;cursor:pointer;z-index:3;font-family:var(--hand);
}
.pin .dot{
  width:13px;height:13px;border-radius:50%;margin:0 auto;
  background:radial-gradient(circle at 35% 30%, #fff, var(--c,var(--blue)));
  box-shadow:0 0 0 3px rgba(59,158,255,.18), 0 4px 10px rgba(0,0,0,.5);
  transition:transform .15s ease, box-shadow .15s ease;
}
.pin .lbl{
  display:block;margin-top:2px;font-size:9.5px;color:#dfeaff;white-space:nowrap;
  text-shadow:0 2px 6px rgba(0,0,0,.85);font-weight:600;
}
.pin:hover{z-index:30}
.pin:hover .dot{transform:scale(1.4)}
.pin.pulse .dot{animation:pulse 1s ease infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.55);box-shadow:0 0 0 7px rgba(255,45,178,.25),0 4px 10px rgba(0,0,0,.5)}}
.pin.hidden{display:none}
.pin.quiet .lbl{display:none}
.pin.quiet:hover .lbl{display:block}

/* pin species */
.pin.lost .dot{background:rgba(13,22,64,.7);border:2px dashed var(--c,#8e98c4);box-shadow:none}
.pin.lost .lbl{color:#aab3d8;font-style:italic}
.pin.fest .dot{border-radius:3px;transform:rotate(45deg);background:linear-gradient(135deg,#fff,var(--c,#ffd23b))}
.pin.fest:hover .dot{transform:rotate(45deg) scale(1.35)}
.pin.sat .dot{background:rgba(13,22,64,.8);border:2.5px solid var(--c,var(--blue));box-shadow:0 0 10px rgba(59,158,255,.3)}
.pin.corr .dot{width:11px;height:11px;border-radius:3px;background:linear-gradient(135deg,#fff,var(--c,#9b6bff))}
.pin.press .dot{background:radial-gradient(circle at 35% 30%,#fff,#ff8a3b);box-shadow:0 0 0 3px rgba(255,138,59,.25),0 0 14px rgba(255,138,59,.5)}
.pin.hq .dot{width:24px;height:24px;background:radial-gradient(circle at 35% 30%,#fff,var(--pink));box-shadow:0 0 0 5px rgba(255,45,178,.3),0 0 28px rgba(255,45,178,.7)}
.pin.hq .lbl{font-size:12.5px;color:#ffd6f0;letter-spacing:.4px}
.pin.hero .dot{width:21px;height:21px;background:radial-gradient(circle at 35% 30%,#fff,#39d6a0);box-shadow:0 0 0 4px rgba(57,214,160,.3),0 0 24px rgba(57,214,160,.55)}
.pin.hero .lbl{font-size:12px;color:#bfffe9}
.pin .star{position:absolute;top:-15px;left:50%;transform:translateX(-50%);font-size:13px;filter:drop-shadow(0 0 6px rgba(255,45,178,.8))}

/* hover bubble — "what they're doing" */
.bubble{
  position:absolute;left:50%;bottom:130%;transform:translateX(-50%) translateY(8px);
  width:252px;background:rgba(12,19,56,.97);backdrop-filter:blur(6px);
  border:1.5px solid var(--c,var(--blue));border-radius:14px;padding:11px 12px;
  opacity:0;pointer-events:none;transition:opacity .16s ease, transform .16s ease;
  box-shadow:0 16px 40px rgba(0,0,0,.55);z-index:40;font-family:var(--ui);text-align:left;
}
.pin:hover .bubble{opacity:1;transform:translateX(-50%) translateY(0)}
.bubble::after{content:"";position:absolute;top:100%;left:50%;transform:translateX(-50%);
  border:8px solid transparent;border-top-color:var(--c,var(--blue))}
.bubble.flip{bottom:auto;top:130%}
.bubble.flip::after{top:auto;bottom:100%;border-top-color:transparent;border-bottom-color:var(--c,var(--blue))}
.bubble h4{margin:0 0 2px;font-size:13.5px;color:#fff;font-family:var(--hand)}
.bubble .kind{font-size:9.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.bubble .role{font-size:11px;color:#cfe0ff;line-height:1.35;margin-top:5px}
.bubble .onlbl{font-size:9px;color:var(--blue);letter-spacing:.9px;font-weight:800;margin-top:7px;text-transform:uppercase}
.bubble .be{display:flex;gap:8px;padding:5px 0;border-top:1px solid rgba(255,255,255,.08)}
.bubble .be:first-of-type{border-top:none}
.bubble .be .bd{font-size:10px;font-weight:800;color:var(--blue);min-width:44px}
.bubble .be .bt{font-size:11.5px;color:#eaf1ff;line-height:1.2}
.bubble .be .bt span{display:block;color:var(--muted);font-size:10px}
.bubble .scs{font-size:10.5px;color:#ff9bd8;font-style:italic;line-height:1.35;margin-top:6px}
.bubble .stat{margin-top:6px}

.legend{
  position:absolute;right:12px;bottom:12px;z-index:5;font-family:var(--ui);
  background:rgba(10,16,48,.78);border:1px solid rgba(59,158,255,.25);border-radius:12px;
  padding:8px 11px;font-size:10px;color:var(--muted);max-width:250px;line-height:1.55;
  columns:2;column-gap:12px;
}
.legend b{color:var(--ink)}
.legend .sw{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}

/* ---------- FEATURED / SPONSORSHIP (premium placement, not an ad eyesore) ---------- */
:root{--gold:#ffce5c;--gold-soft:rgba(255,206,92,.16)}
.pin.featured .dot{
  background:radial-gradient(circle at 35% 30%,#fff,var(--gold));
  box-shadow:0 0 0 3px rgba(255,206,92,.35), 0 0 18px rgba(255,206,92,.65), 0 4px 10px rgba(0,0,0,.5);
}
.pin.featured .star{color:var(--gold);filter:drop-shadow(0 0 6px rgba(255,206,92,.9));font-size:14px;top:-16px}
.pin.featured .lbl{color:#ffe9b3}
.pin.featured .bubble{border-color:var(--gold)}
.pin.featured .bubble::after{border-top-color:var(--gold)}
.pin.featured .bubble.flip::after{border-top-color:transparent;border-bottom-color:var(--gold)}
.tag.featured{background:var(--gold-soft);color:var(--gold);border:1px solid rgba(255,206,92,.5)}

.featured-label{
  font-size:10px;color:var(--gold);text-transform:uppercase;letter-spacing:1px;
  margin:8px 4px 0;font-weight:800;display:flex;align-items:center;gap:6px;
}
.featured-label::after{content:"";flex:1;height:1px;background:linear-gradient(90deg,rgba(255,206,92,.45),transparent)}
.ev.fcard{
  background:linear-gradient(90deg, rgba(255,206,92,.10), rgba(255,45,178,.05));
  border:1px solid rgba(255,206,92,.4);
}
.ev.fcard:hover,.ev.fcard.active{border-color:var(--gold);
  background:linear-gradient(90deg, rgba(255,206,92,.16), rgba(255,45,178,.08))}
.ev.fcard .date{background:linear-gradient(160deg,var(--gold),#e0a92e);color:#241a02}
.feed-label{
  font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:1px;
  margin:12px 4px 0;font-weight:700;
}

/* slim newsletter capture (Netlify Forms when this site deploys; privacy-clean) */
.mini-signup{flex:0 0 auto;display:flex;gap:7px;margin:2px 14px 8px}
.mini-signup .hp{display:none}
.mini-signup input[type=email]{
  flex:1;min-width:0;padding:8px 11px;border-radius:10px;font-family:var(--ui);font-size:12px;
  color:var(--ink);background:rgba(255,255,255,.05);border:1px solid rgba(159,178,230,.35);outline:none;
}
.mini-signup input[type=email]:focus{border-color:var(--pink)}
.mini-signup button{
  flex:0 0 auto;padding:8px 14px;border:none;border-radius:10px;cursor:pointer;font-family:var(--ui);
  font-weight:800;font-size:12px;color:#fff;background:linear-gradient(90deg,var(--blue),var(--pink));
}
/* map -> shop cross-link (phrasebook for this city's language) */
.pb-link{
  flex:0 0 auto;display:block;text-align:center;text-decoration:none;
  margin:0 14px 8px;padding:8px 12px;border-radius:12px;
  font-family:var(--ui);font-size:11.5px;font-weight:700;color:#bfe9ff;
  background:linear-gradient(90deg, rgba(59,158,255,.12), rgba(122,75,255,.10));
  border:1px solid rgba(95,208,255,.4);
  transition:border-color .18s ease, transform .18s ease;
}
.pb-link:hover{border-color:var(--blue);transform:translateY(-1px)}
.pb-link .sub{display:block;font-weight:500;font-size:10px;color:var(--muted);margin-top:2px}

.sponsor-cta{
  flex:0 0 auto;display:block;text-align:center;text-decoration:none;cursor:pointer;
  margin:0 14px 12px;padding:9px 12px;border-radius:12px;
  font-family:var(--ui);font-size:11.5px;font-weight:700;letter-spacing:.3px;color:#ffe9b3;
  background:linear-gradient(90deg, rgba(255,206,92,.10), rgba(255,45,178,.07));
  border:1px dashed rgba(255,206,92,.45);
  transition:border-color .18s ease, background .18s ease, transform .18s ease;
}
.sponsor-cta:hover{border-color:var(--gold);transform:translateY(-1px);
  background:linear-gradient(90deg, rgba(255,206,92,.18), rgba(255,45,178,.10))}
.sponsor-cta .sub{display:block;font-weight:500;font-size:10px;color:var(--muted);margin-top:2px}

/* ---------- GRIM HOUSE home-base treatment ----------
   Palette echoes os.grimhouse.info ("The Signal"): ink #170c0f / cream #fff8f1 /
   signal orange #ff7a1a / hot pink #ff6fba — premium home-base, never bumped. */
:root{--gh-ink:#170c0f;--gh-cream:#fff8f1;--gh-orange:#ff7a1a;--gh-pink:#ff6fba}
.pin.homebase .dot{
  width:26px;height:26px;
  background:radial-gradient(circle at 35% 30%,var(--gh-cream),var(--gh-orange) 62%,#b34a00);
  box-shadow:0 0 0 4px rgba(255,122,26,.35), 0 0 26px rgba(255,122,26,.75), 0 4px 12px rgba(0,0,0,.6);
}
.pin.homebase .crown{
  position:absolute;top:-26px;left:50%;transform:translateX(-50%);
  width:26px;height:26px;pointer-events:none;
  filter:drop-shadow(0 0 7px rgba(255,111,186,.9)) drop-shadow(0 2px 4px rgba(0,0,0,.6));
}
.pin.homebase:hover .crown{transform:translateX(-50%) scale(1.15)}
.pin.homebase .lbl{font-size:13px;color:var(--gh-cream);letter-spacing:.5px;font-weight:700;
  text-shadow:0 0 10px rgba(255,122,26,.55), 0 2px 6px rgba(0,0,0,.9)}
.pin.homebase .bubble{border-color:var(--gh-orange);background:rgba(23,12,15,.97)}
.pin.homebase .bubble::after{border-top-color:var(--gh-orange)}
.pin.homebase .bubble.flip::after{border-top-color:transparent;border-bottom-color:var(--gh-orange)}
.pin.homebase .bubble h4{color:var(--gh-cream)}
.tag.homebase{background:rgba(255,122,26,.16);color:#ffb077;border:1px solid rgba(255,122,26,.55)}
.ev.fcard.homebase{
  background:linear-gradient(90deg, rgba(255,122,26,.14), rgba(255,111,186,.07));
  border:1.5px solid rgba(255,122,26,.55);
}
.ev.fcard.homebase:hover,.ev.fcard.homebase.active{border-color:var(--gh-orange)}
.ev.fcard.homebase .date{background:linear-gradient(160deg,var(--gh-orange),#d65f06);color:#1c0c00}
.bubble .addr{font-size:10px;color:#cdb8a8;margin-top:5px;letter-spacing:.3px}

/* ---------- sponsorship inquiry form page ---------- */
.form-stage{height:calc(100vh - 54px);overflow-y:auto;display:flex;justify-content:center;padding:30px 18px}
.form-card{
  width:100%;max-width:520px;height:fit-content;border-radius:20px;padding:26px 26px 22px;
  background:linear-gradient(180deg,var(--navy-3),#0c1338);
  border:1px solid rgba(255,206,92,.35);
  box-shadow:0 18px 50px rgba(0,0,0,.45);
}
.form-card h1{margin:0;font-size:22px;font-family:var(--hand);color:#fff}
.form-card h1 .gold{color:var(--gold)}
.form-card .lede{font-size:12.5px;color:var(--muted);line-height:1.55;margin:8px 0 18px}
.form-card label{display:block;font-size:11px;color:#cdd6ff;font-weight:700;letter-spacing:.4px;
  text-transform:uppercase;margin:13px 0 5px}
.form-card input,.form-card select,.form-card textarea{
  width:100%;padding:10px 12px;border-radius:10px;font-family:var(--ui);font-size:13.5px;color:var(--ink);
  background:rgba(255,255,255,.05);border:1px solid rgba(159,178,230,.35);outline:none;
}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{border-color:var(--blue)}
.form-card textarea{min-height:96px;resize:vertical}
.form-card select{appearance:none;-webkit-appearance:none}
.form-card button{
  margin-top:18px;width:100%;padding:12px;border:none;border-radius:12px;cursor:pointer;
  font-family:var(--ui);font-weight:800;font-size:14px;color:#241a02;letter-spacing:.3px;
  background:linear-gradient(90deg,var(--gold),#ffb84d);
  box-shadow:0 10px 26px -8px rgba(255,206,92,.5);transition:transform .15s ease;
}
.form-card button:hover{transform:translateY(-2px)}
.form-card .fine{font-size:10.5px;color:var(--muted);margin-top:12px;line-height:1.5;text-align:center}

@media (max-width:760px){
  .stage{flex-direction:column}
  .events-panel,.map-panel{min-width:0}
  .legend{display:none}
}
