/* ════════════════════════════════════════════
   POUR — "Golden Hour" design system
   Warm, editorial, map-first. Nothing like Prism.
═══════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--paper);color:var(--ink);min-height:100vh;display:flex;flex-direction:column;-webkit-font-smoothing:antialiased;overflow-x:hidden}

:root{
  --paper:#fbf2e3;
  --paper2:#fffdf8;
  --ink:#221a13;
  --muted:#7c6a58;
  --orange:#ff6a2b;
  --orange2:#e7470c;
  --gold:#ffb22e;
  --berry:#e23e6d;
  --green:#1f9d6b;
  --line:#e7d8c1;
  --line-ink:rgba(34,26,19,0.16);
  --disp:'Bricolage Grotesque','Inter',sans-serif;
  --mono:'Space Mono','DM Mono',monospace;
  --shadow:4px 4px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
  --shadow-soft:0 18px 40px -22px rgba(34,26,19,0.5);
  --r:14px;
  --r-lg:22px;
}

/* ── Top bar ── */
.bar{position:sticky;top:0;z-index:1100;display:flex;align-items:center;justify-content:space-between;padding:16px 36px;background:var(--paper);border-bottom:2px solid var(--ink)}
.logo{font-family:var(--disp);font-weight:800;font-size:26px;letter-spacing:-.02em;color:var(--ink);text-decoration:none;display:flex;align-items:center;gap:8px}
.logo .dot{width:12px;height:12px;border-radius:50%;background:var(--orange);box-shadow:0 0 0 3px rgba(255,106,43,.25);display:inline-block}
.bar-links{display:flex;gap:8px;align-items:center}
.bar-links a{font-weight:600;font-size:14px;color:var(--ink);text-decoration:none;padding:8px 14px;border-radius:999px;transition:background .15s}
.bar-links a:hover{background:#f0e2cc}
.bar-links a.active{background:var(--ink);color:var(--paper)}
.pill{font-weight:700;font-size:14px;color:var(--ink);background:var(--gold);border:2px solid var(--ink);padding:9px 18px;border-radius:999px;text-decoration:none;box-shadow:var(--shadow-sm);transition:transform .12s,box-shadow .12s;display:inline-block}
.pill:hover{transform:translate(-2px,-2px);box-shadow:5px 5px 0 var(--ink)}
.pill.orange{background:var(--orange);color:#fff}

/* ── Buttons ── */
.btn{font-family:var(--disp);font-weight:700;font-size:16px;padding:14px 26px;border:2px solid var(--ink);border-radius:999px;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow);transition:transform .12s,box-shadow .12s;background:var(--paper2);color:var(--ink)}
.btn:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}
.btn:active{transform:translate(0,0);box-shadow:2px 2px 0 var(--ink)}
.btn.orange{background:var(--orange);color:#fff}
.btn.ink{background:var(--ink);color:var(--paper)}

/* ── Hero ── */
.hero{padding:64px 36px 40px;max-width:1280px;margin:0 auto;width:100%;display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--orange2);background:#fff;border:2px solid var(--ink);border-radius:999px;padding:6px 14px;margin-bottom:24px}
.eyebrow .blink{width:8px;height:8px;border-radius:50%;background:var(--orange);animation:blink 1.6s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.hero h1{font-family:var(--disp);font-weight:800;font-size:clamp(46px,6.4vw,82px);line-height:.96;letter-spacing:-.03em;margin-bottom:22px}
.hero h1 .hl{position:relative;white-space:nowrap;color:var(--orange2)}
.hero h1 .hl::after{content:'';position:absolute;left:-2px;right:-2px;bottom:.06em;height:.28em;background:var(--gold);z-index:-1;transform:rotate(-1.2deg)}
.hero p.lead{font-size:19px;line-height:1.6;color:var(--muted);max-width:520px;margin-bottom:30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:30px}
.boro-row{display:flex;gap:8px;flex-wrap:wrap}
.boro-row span{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);background:#fff;border:1.5px solid var(--line-ink);border-radius:999px;padding:6px 12px}

/* ── Live-now card (hero right) ── */
.livecard{background:var(--ink);color:var(--paper);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow-soft);position:relative;overflow:hidden}
.livecard::before{content:'';position:absolute;top:-40%;right:-20%;width:60%;height:120%;background:radial-gradient(circle,rgba(255,106,43,.5),transparent 65%);pointer-events:none}
.livecard-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.livecard-h b{font-family:var(--disp);font-size:18px}
.livecard-h .live{font-family:var(--mono);font-size:11px;font-weight:700;color:#fff;background:var(--berry);padding:4px 9px;border-radius:999px;display:inline-flex;align-items:center;gap:6px}
.livecard-h .live::before{content:'';width:7px;height:7px;border-radius:50%;background:#fff;animation:blink 1.4s infinite}
.lc-row{padding:12px 0;border-top:1px solid rgba(251,242,227,.14)}
.lc-row:first-of-type{border-top:none}
.lc-top{display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.lc-name{font-weight:700;font-size:15px}
.lc-meta{font-size:12px;color:rgba(251,242,227,.6);margin-top:1px}
.lc-pct{font-family:var(--mono);font-weight:700;font-size:13px;white-space:nowrap}
.lc-bar{height:6px;border-radius:6px;background:rgba(251,242,227,.14);margin-top:8px;overflow:hidden}
.lc-fill{height:100%;border-radius:6px}
.lc-foot{margin-top:16px;font-size:13px;color:rgba(251,242,227,.7);text-align:center}
.lc-foot a{color:var(--gold);font-weight:700;text-decoration:none}

/* ── Sunset strip ── */
.strip{background:linear-gradient(100deg,var(--berry),var(--orange) 45%,var(--gold));border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);overflow:hidden;white-space:nowrap}
.strip-inner{display:inline-flex;gap:40px;padding:12px 0;animation:roll 32s linear infinite}
@keyframes roll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.strip-item{font-family:var(--disp);font-weight:700;font-size:15px;color:#fff;display:inline-flex;align-items:center;gap:10px;text-shadow:0 1px 0 rgba(0,0,0,.15)}
.strip-item .star{color:var(--ink)}

/* ── Section heads ── */
.wrap{max-width:1280px;margin:0 auto;padding:0 36px;width:100%}
.sec{padding:84px 0}
.sec-tag{font-family:var(--mono);font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--orange2);margin-bottom:14px}
.sec h2{font-family:var(--disp);font-weight:800;font-size:clamp(32px,4.4vw,52px);line-height:1.02;letter-spacing:-.025em;margin-bottom:16px;max-width:760px}
.sec .sub{font-size:18px;color:var(--muted);max-width:560px;line-height:1.6}

/* ── Bento ── */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:44px}
.tile{background:var(--paper2);border:2px solid var(--ink);border-radius:var(--r-lg);padding:26px;box-shadow:var(--shadow);display:flex;flex-direction:column}
.tile.w2{grid-column:span 2}
.tile.tall{grid-row:span 2}
.tile .emoji{font-size:30px;margin-bottom:16px}
.tile h3{font-family:var(--disp);font-weight:700;font-size:21px;margin-bottom:8px;letter-spacing:-.01em}
.tile p{font-size:14.5px;color:var(--muted);line-height:1.6}
.tile .tag{margin-top:auto;padding-top:16px;font-family:var(--mono);font-size:11px;font-weight:700;color:var(--orange2)}
.tile.dark{background:var(--ink);color:var(--paper)}
.tile.dark p{color:rgba(251,242,227,.7)}
.tile.dark .tag{color:var(--gold)}
.tile.gold{background:var(--gold)}
.tile.berry{background:var(--berry);color:#fff}
.tile.berry p{color:rgba(255,255,255,.85)}
.tile.berry .tag{color:#fff}
.bignum{font-family:var(--disp);font-weight:800;font-size:64px;line-height:1;letter-spacing:-.04em}

/* ── Steps strip ── */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:44px}
.step{border:2px solid var(--ink);border-radius:var(--r-lg);padding:26px;background:var(--paper2)}
.step .n{font-family:var(--mono);font-weight:700;font-size:13px;color:#fff;background:var(--ink);width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.step h3{font-family:var(--disp);font-weight:700;font-size:20px;margin-bottom:8px}
.step p{font-size:14.5px;color:var(--muted);line-height:1.6}

/* ── CTA ── */
.cta{margin:0 36px 90px;max-width:1280px;margin-left:auto;margin-right:auto}
.cta-inner{background:var(--ink);color:var(--paper);border-radius:28px;padding:72px 40px;text-align:center;position:relative;overflow:hidden;border:2px solid var(--ink)}
.cta-inner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 90% at 50% 120%,rgba(255,106,43,.55),transparent 70%);pointer-events:none}
.cta-inner h2{font-family:var(--disp);font-weight:800;font-size:clamp(34px,5vw,60px);letter-spacing:-.03em;margin-bottom:14px;position:relative}
.cta-inner p{font-size:18px;color:rgba(251,242,227,.75);margin-bottom:32px;position:relative}

/* ── Page header (subpages) ── */
.phead{padding:56px 36px 28px;max-width:1280px;margin:0 auto;width:100%}
.phead h1{font-family:var(--disp);font-weight:800;font-size:clamp(40px,5.4vw,68px);line-height:.98;letter-spacing:-.03em;margin-bottom:14px}
.phead h1 .hl{color:var(--orange2)}
.phead p{font-size:18px;color:var(--muted);max-width:620px;line-height:1.6}

/* ── Filters ── */
.filterbar{max-width:1280px;margin:0 auto;width:100%;padding:0 36px;display:flex;flex-wrap:wrap;gap:18px;align-items:center}
.fgroup{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.flabel{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-right:2px}
.chip{font-weight:600;font-size:14px;color:var(--ink);background:var(--paper2);border:2px solid var(--ink);border-radius:999px;padding:8px 16px;cursor:pointer;transition:transform .1s,box-shadow .1s;font-family:inherit}
.chip:hover{transform:translate(-1px,-1px);box-shadow:2px 2px 0 var(--ink)}
.chip.active{background:var(--orange);color:#fff}
.count{font-family:var(--mono);font-size:13px;color:var(--muted);margin-left:auto}

/* ── Venue cards ── */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:1280px;margin:0 auto;padding:30px 36px 90px;width:100%}
.card{background:var(--paper2);border:2px solid var(--ink);border-radius:var(--r-lg);padding:24px;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:transform .12s,box-shadow .12s}
.card:hover{transform:translate(-3px,-3px);box-shadow:7px 7px 0 var(--ink)}
.card-top{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.card h3{font-family:var(--disp);font-weight:700;font-size:22px;line-height:1.08;letter-spacing:-.01em}
.card .hood{font-size:13px;color:var(--muted);margin-top:3px;margin-bottom:14px}
.tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:14px}
.t{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:5px 9px;border-radius:7px;border:1.5px solid var(--ink)}
.t-free{background:#dff6e9;color:var(--green)}
.t-paid{background:#ffe7d6;color:var(--orange2)}
.t-type{background:#fff;color:var(--ink)}
.kv{font-size:13.5px;color:var(--muted);line-height:1.55;margin-bottom:9px;display:flex;gap:8px}
.kv .k{font-family:var(--mono);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--orange2);min-width:52px;flex-shrink:0;padding-top:3px}
.kv b{color:var(--ink);font-weight:700}
.hh{margin-top:auto;padding-top:14px;border-top:2px dashed var(--line);font-size:13.5px;color:var(--ink)}
.hh b{color:var(--orange2)}
.book{margin-top:12px;font-family:var(--mono);font-size:11.5px;color:var(--muted);word-break:break-word}
.empty{grid-column:1/-1;text-align:center;color:var(--muted);padding:80px 0;font-family:var(--mono)}

/* ── Map page ── */
.maparea{max-width:1280px;margin:0 auto;width:100%;padding:18px 36px 70px;display:grid;grid-template-columns:360px 1fr;gap:18px;align-items:start}
.panel{background:var(--paper2);border:2px solid var(--ink);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow);position:sticky;top:88px;max-height:calc(100vh - 110px);overflow-y:auto}
#map{height:calc(100vh - 110px);min-height:560px;border:2px solid var(--ink);border-radius:var(--r-lg);box-shadow:var(--shadow);background:#eadbc4;position:sticky;top:88px}
.nowbox{background:var(--ink);color:var(--paper);border-radius:var(--r);padding:16px 18px;margin-bottom:16px}
.nowbox .t{font-family:var(--disp);font-weight:700;font-size:21px;border:none;padding:0;color:var(--paper);letter-spacing:-.01em}
.nowbox .s{font-family:var(--mono);font-size:11px;color:rgba(251,242,227,.65);margin-top:2px}
.ctrl{margin-top:14px}
.ctrl label{font-family:var(--mono);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:rgba(251,242,227,.7);display:block;margin-bottom:7px}
.ctrl label b{color:var(--gold)}
input[type=range]{width:100%;accent-color:var(--orange)}
.legend{margin-top:16px;display:flex;flex-direction:column;gap:7px}
.legend .li{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted)}
.legend .sw{width:14px;height:14px;border-radius:5px;border:1.5px solid var(--ink);flex-shrink:0}
.spot{border-top:2px solid var(--line);padding:13px 2px;cursor:pointer;transition:background .12s;border-radius:8px}
.spot:hover{background:#f4e7d2}
.spot-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.spot-name{font-family:var(--disp);font-weight:700;font-size:15px}
.spot-meta{font-size:12px;color:var(--muted);margin-top:1px}
.spot-pct{font-family:var(--mono);font-weight:700;font-size:13px;white-space:nowrap}
.sbar{height:6px;border-radius:6px;background:#eadbc4;margin-top:8px;overflow:hidden}
.sfill{height:100%;border-radius:6px;transition:width .4s}
.livetag{display:inline-block;font-family:var(--mono);font-size:9.5px;font-weight:700;color:#fff;background:var(--berry);padding:2px 7px;border-radius:6px;margin-left:6px;vertical-align:middle}
.leaflet-popup-content-wrapper{background:var(--paper2);color:var(--ink);border:2px solid var(--ink);border-radius:12px;box-shadow:var(--shadow)}
.leaflet-popup-tip{background:var(--paper2);border:2px solid var(--ink)}
.leaflet-popup-content{font-family:'Inter',sans-serif;font-size:13px;margin:14px 16px}
.pop-name{font-family:var(--disp);font-weight:700;font-size:18px;display:block;margin-bottom:4px}
.pop-row{color:var(--muted);font-size:12.5px;margin-top:3px}

/* ── Footer ── */
footer{margin-top:auto;background:var(--ink);color:var(--paper);padding:46px 36px;display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px}
.foot-logo{font-family:var(--disp);font-weight:800;font-size:22px;display:flex;align-items:center;gap:8px}
.foot-logo .dot{width:11px;height:11px;border-radius:50%;background:var(--orange)}
.foot-copy{font-size:13px;color:rgba(251,242,227,.55);margin-top:8px;max-width:380px;line-height:1.5}
.foot-links{display:flex;gap:22px}
.foot-links a{font-size:14px;font-weight:600;color:rgba(251,242,227,.8);text-decoration:none}
.foot-links a:hover{color:var(--gold)}
.note{max-width:1280px;margin:0 auto;padding:0 36px 40px;width:100%;font-family:var(--mono);font-size:11.5px;color:var(--muted);line-height:1.6}

/* ── Responsive ── */
@media(max-width:980px){
  .hero{grid-template-columns:1fr;gap:32px}
  .bento{grid-template-columns:repeat(2,1fr)}
  .tile.w2{grid-column:span 2}
  .maparea{grid-template-columns:1fr}
  .panel{position:static;max-height:none}
  #map{position:static;height:64vh}
  .cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:640px){
  .bar{padding:14px 20px}
  .bar-links{display:none}
  .hero,.phead,.filterbar,.cards,.wrap,.note,.maparea{padding-left:20px;padding-right:20px}
  .bento,.steps{grid-template-columns:1fr}
  .tile.w2{grid-column:span 1}
  .cards{grid-template-columns:1fr}
  .cta{margin-left:20px;margin-right:20px}
  footer{flex-direction:column}
}
