*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Helvetica Neue',Helvetica,Arial,sans-serif;background:#fff;color:#111;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
:root{--ink:#111;--muted:#666;--border:#e8e8e4;--off:#f3f3ee;--pink:#cd2d6a;--yellow:#f5e000;--blue:#2347d6;--light-orange:#f4c27a;--pad:clamp(20px,4vw,56px)}
nav{position:sticky;top:0;z-index:300;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 var(--pad);height:62px;gap:16px}
.nav-back,.nav-title{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.page{max-width:1180px;margin:0 auto;padding:34px var(--pad) 64px}
.venue-title{font-family:'Barlow',sans-serif;font-weight:800;text-transform:uppercase;font-size:clamp(36px,5.2vw,76px);line-height:.94;letter-spacing:-.02em;margin-bottom:24px}
.hero{display:grid;grid-template-columns:minmax(320px,520px) minmax(0,1fr);gap:28px;align-items:start}
.hero-photo-wrap{width:100%}
.hero-photo,.hero-photo-placeholder{width:100%;aspect-ratio:4/3;border:1px solid var(--border);background:#f2f2ee}
.hero-photo{object-fit:cover}
.hero-photo-placeholder{display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#777}
.venue-meta{display:flex;flex-direction:column;gap:14px}
.venue-line{font-size:14px;line-height:1.7;color:#222}
.venue-line-label{display:block;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.venue-map-link{color:var(--pink);border-bottom:1px solid currentColor}
.venue-description{font-size:15px;line-height:1.82;color:#333;white-space:pre-line}
.section{margin-top:38px;padding-top:24px;border-top:1px solid var(--border)}
.section-label{font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:18px}
.programme-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:18px}
.programme-card-frame{border:2px solid var(--ink);background:#fff;padding:8px}
.programme-card{height:100%;background:var(--off);display:flex;flex-direction:column;gap:14px;padding:14px}
.programme-time{font-family:'DM Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);line-height:1.55}
.programme-artist-photo,.programme-artist-placeholder{width:100%;aspect-ratio:4/5;border:1px solid var(--ink);background:#e8e8e1}
.programme-artist-photo{object-fit:cover}
.programme-artist-placeholder{display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:#777;text-align:center;padding:18px}
.programme-title{font-family:'Barlow',sans-serif;font-weight:800;text-transform:uppercase;font-size:clamp(20px,2.3vw,30px);line-height:1.02;letter-spacing:-.02em}
.programme-artist{font-size:12px;line-height:1.5;color:#222}
.programme-bio{font-size:13px;line-height:1.72;color:#333;white-space:pre-line}
.programme-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto;padding-top:4px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:38px;padding:10px 14px;border:1px solid var(--ink);font-family:'DM Mono',monospace;font-size:10px;letter-spacing:.08em;text-transform:uppercase;transition:transform .15s ease, box-shadow .15s ease, background .15s ease}
.btn:hover{transform:translate(-1px,-1px);box-shadow:4px 4px 0 var(--ink)}
.btn-artist-page{background:var(--light-orange);color:#111}
.btn-buy-tickets{background:var(--pink);color:#fff}
.btn-workshop{background:var(--blue);color:#fff}
.btn-weekend{background:var(--yellow);color:#111}
.btn-festival{background:var(--pink);color:#fff}
.booking-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:28px}
.error-box{border:1px solid var(--border);padding:18px;font-family:'DM Mono',monospace;font-size:11px;line-height:1.8;color:#333}
@media(max-width:840px){.hero{grid-template-columns:1fr}.hero-photo-wrap{max-width:520px}}
@media(max-width:600px){
  nav{padding:0 14px;height:auto;min-height:62px;flex-wrap:wrap;row-gap:8px}
  .page,.ap-footer{padding-left:14px;padding-right:14px}
  .hero{gap:18px}
  .programme-grid{grid-template-columns:1fr}
  .programme-card{padding:12px}
  .programme-actions,.booking-row,.ap-footer-links{flex-direction:column;align-items:stretch}
  .btn{width:100%}
}
