:root{--bg: #ffffff;--surface: #f7f7f8;--surface2: #eeeff1;--border: #e0e0e0;--text: #1a1a1a;--text-dim: #777;--accent: #e63600;--accent-glow: rgba(230, 54, 0, .08);--live: #00b85e;--font: "Inter", -apple-system, sans-serif;--mono: "SF Mono", "Menlo", monospace}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--bg);color:var(--text);font-family:var(--font);min-height:100vh;-webkit-font-smoothing:antialiased}.header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg);z-index:100}.logo{font-size:20px;font-weight:800;letter-spacing:2px;color:var(--accent)}.logo span{color:var(--text)}.clock{font-family:var(--mono);font-size:13px;color:var(--text-dim)}.hero{padding:14px 20px;border-bottom:1px solid var(--border);background:var(--surface)}.hero-text{font-size:13px;line-height:1.6;color:var(--text-dim)}.hero-text strong{color:var(--accent);font-weight:700}.filters{display:flex;gap:6px;padding:12px 20px;overflow-x:auto;-webkit-overflow-scrolling:touch;border-bottom:1px solid var(--border)}.filter-btn{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:6px 14px;font-size:12px;color:var(--text-dim);cursor:pointer;white-space:nowrap;transition:all .15s;font-family:var(--font)}.filter-btn:hover{border-color:#bbb;color:var(--text)}.filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}.live-banner{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#00b85e0f;border-bottom:1px solid rgba(0,184,94,.12);font-size:13px;font-weight:600;color:var(--live)}.live-dot{width:8px;height:8px;background:var(--live);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.live-banner:empty{display:none}.events{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.date-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-dim);margin-top:8px}.event-card{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px;transition:border-color .15s}.event-card:hover{border-color:#ccc}.event-card.is-live{border-color:var(--live);box-shadow:0 0 12px #00b85e1f}.event-top{display:flex;align-items:center;justify-content:space-between;gap:8px}.event-festival{font-size:14px;font-weight:700}.event-live-badge{display:inline-flex;align-items:center;gap:4px;background:var(--live);color:#000;font-size:10px;font-weight:800;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.event-name{font-size:13px;color:var(--text-dim)}.event-time{font-family:var(--mono);font-size:13px;color:var(--accent)}.event-location{font-size:12px;color:var(--text-dim)}.event-genres{display:flex;gap:4px;flex-wrap:wrap}.genre-tag{font-size:10px;padding:2px 8px;border-radius:10px;font-weight:600;letter-spacing:.3px}.event-actions{display:flex;gap:8px;margin-top:4px}.btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;font-size:12px;font-weight:600;text-decoration:none;cursor:pointer;border:none;transition:opacity .15s;font-family:var(--font)}.btn:hover{opacity:.85}.btn-stream{background:var(--accent);color:#fff}.btn-calendar{background:var(--surface2);border:1px solid var(--border);color:var(--text)}.set-details{border-top:1px solid var(--border);margin-top:4px;padding-top:4px}.set-toggle{font-size:12px;color:var(--accent);cursor:pointer;padding:6px 0;-webkit-user-select:none;user-select:none;list-style:none;font-weight:600}.set-toggle::-webkit-details-marker{display:none}.set-toggle:before{content:"▸ ";font-size:10px}.set-details[open] .set-toggle:before{content:"▾ "}.set-times{display:flex;flex-direction:column;gap:10px;padding:8px 0}.stage-name{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-dim);margin-bottom:4px;padding-bottom:2px;border-bottom:1px solid var(--border)}.stage-sets{display:flex;flex-direction:column;gap:2px}.set-row{display:flex;align-items:center;gap:8px;padding:3px 0;font-size:12px}.set-row.set-live{background:#00b85e14;border-radius:4px;padding:3px 6px}.set-time{font-family:var(--mono);font-size:11px;color:var(--accent);min-width:40px}.set-artist{color:var(--text)}.set-cal{margin-left:auto;text-decoration:none;font-size:14px;opacity:.4;transition:opacity .15s;flex-shrink:0}.set-cal:hover{opacity:1}.set-row.set-live .set-cal{opacity:.7}.set-live-badge{font-size:9px;font-weight:800;color:var(--live);background:#00e67626;padding:1px 5px;border-radius:3px;flex-shrink:0}.footer{padding:24px 20px;text-align:center;font-size:11px;color:var(--text-dim);border-top:1px solid var(--border);margin-top:32px}.empty{text-align:center;padding:60px 20px;color:var(--text-dim);font-size:14px}@media (min-width: 640px){.events,.header,.filters{max-width:600px;margin:0 auto}}
