:root{--bg: #0e0e0e;--surface: #1a1a1a;--border: #2a2a2a;--text: #f0f0f0;--muted: #888;--accent: #f0f0f0;--accent-text: #0e0e0e;--font: system-ui, -apple-system, sans-serif;--radius: 8px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100dvh}.bg-slide{position:fixed;top:0;right:0;bottom:0;left:0;background-size:cover;background-position:center;transition:opacity 1.5s ease-in-out;z-index:-2}.bg-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:-1}.page{max-width:540px;margin:0 auto;padding:3rem 1.25rem 4rem;display:flex;flex-direction:column;gap:2.5rem}.site-header{text-align:center;display:flex;flex-direction:column;gap:.375rem}.site-name{font-size:2rem;font-weight:700;letter-spacing:-.02em}.site-location{color:var(--muted);font-size:.9rem}.links-section{display:flex;flex-direction:column;gap:.75rem}.link-btn{display:block;width:100%;padding:.875rem 1.25rem;background:#1a1a1ad9;border:1px solid var(--border);border-radius:var(--radius);color:var(--text);text-decoration:none;text-align:center;font-size:1rem;font-weight:500;transition:background .15s,border-color .15s}.link-btn:hover{background:var(--border);border-color:#3a3a3a}.section-title{font-size:.75rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:.75rem}.shows-section{display:flex;flex-direction:column}.show-row{display:flex;align-items:center;gap:1rem;padding:.875rem 0;border-bottom:1px solid var(--border)}.show-row:first-of-type{border-top:1px solid var(--border)}.show-date{font-size:.85rem;color:var(--muted);white-space:nowrap;min-width:8rem}.show-info{flex:1;display:flex;flex-direction:column;gap:.125rem;min-width:0}.show-venue{font-weight:500;font-size:.95rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.show-location,.show-time{font-size:.8rem;color:var(--muted)}.show-actions{display:flex;gap:.5rem;flex-shrink:0}.ticket-btn,.rsvp-btn{padding:.375rem .75rem;border-radius:var(--radius);font-size:.8rem;font-weight:600;text-decoration:none;white-space:nowrap;transition:opacity .15s}.ticket-btn{background:var(--accent);color:var(--accent-text)}.rsvp-btn{background:transparent;border:1px solid var(--border);color:var(--text)}.ticket-btn:hover,.rsvp-btn:hover{opacity:.8}.muted{color:var(--muted);font-size:.9rem}@media (max-width: 480px){.show-row{flex-wrap:wrap;gap:.5rem}.show-date{min-width:auto;width:100%}.show-actions{width:100%}}
