.concert-tracker{min-height:100vh;padding-top:var(--header-height);padding-bottom:4rem;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.concert-content{padding-top:1rem;padding-bottom:4rem;position:relative;z-index:1}.concert-hero{text-align:center;padding:4rem 2rem 3rem;background:linear-gradient(135deg,#8b5cf614,#ec489914)}.concert-hero h1{font-size:clamp(2rem,5vw,3rem);font-weight:800;background:linear-gradient(135deg,#8b5cf6,#ec4899);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;letter-spacing:-.02em}.hero-subtitle{color:var(--text-secondary);font-size:1.125rem;margin-bottom:2rem}.distance-control{max-width:400px;margin:0 auto 2rem}.distance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.distance-label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.distance-value{font-size:1.125rem;font-weight:700;color:var(--primary)}.distance-slider{width:100%;height:6px;border-radius:3px;background:linear-gradient(to right,#22c55e,#f59e0b,#ef4444);outline:none;-webkit-appearance:none;cursor:pointer}.distance-slider::-webkit-slider-thumb{-webkit-appearance:none;width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--primary);cursor:grab;box-shadow:0 2px 8px #00000026;transition:transform .15s ease,box-shadow .15s ease}.distance-slider::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 12px #8b5cf64d}.distance-slider::-webkit-slider-thumb:active{cursor:grabbing}.distance-slider::-moz-range-thumb{width:22px;height:22px;border-radius:50%;background:#fff;border:3px solid var(--primary);cursor:grab;box-shadow:0 2px 8px #00000026}.distance-markers{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.75rem;color:var(--text-tertiary)}.concert-stats{display:flex;justify-content:center;gap:3rem;margin-top:2rem}.stat{text-align:center}.stat-value{display:block;font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1}.stat-label{display:block;font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.view-toggle{display:flex;gap:.5rem;margin-bottom:1.25rem}.view-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border);border-radius:.5rem;background:transparent;color:var(--text-secondary);font-family:DM Sans,-apple-system,sans-serif;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.view-toggle-btn:hover{border-color:var(--primary);color:var(--primary)}.view-toggle-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.view-toggle-btn svg{flex-shrink:0}.concert-filters{background:var(--card-bg);border-bottom:1px solid var(--border);padding:1.25rem 0;position:sticky;top:var(--header-height, 64px);z-index:10;backdrop-filter:blur(12px);background:#0f0f14eb}.filters-row{display:flex;gap:2rem;flex-wrap:wrap;align-items:flex-start}.filter-group{flex:1;min-width:200px}.filter-group label{display:block;font-family:DM Sans,-apple-system,sans-serif;font-size:.6875rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.08em}.filter-group--select{flex:0 0 auto;min-width:160px}.filter-group select{width:100%;padding:.625rem 1rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg-secondary);color:var(--text-primary);font-family:DM Sans,-apple-system,sans-serif;font-size:.8125rem;font-weight:500;cursor:pointer}.filter-group select:focus{outline:none;border-color:var(--primary)}.artist-chips{display:flex;flex-wrap:wrap;gap:.5rem}.artist-chip{padding:.375rem .875rem;border-radius:9999px;font-family:DM Sans,-apple-system,sans-serif;font-size:.8125rem;font-weight:500;border:1px solid var(--border);background:transparent;color:var(--text-secondary);cursor:pointer;transition:all .15s ease;white-space:nowrap}.artist-chip:hover{border-color:var(--primary);color:var(--primary)}.artist-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.selected-artists{display:flex;flex-wrap:wrap;gap:.375rem;margin-top:.5rem}.selected-artist-tag{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:9999px;background:#8b5cf626;border:1px solid rgba(139,92,246,.3);color:#c4b5fd;font-family:DM Sans,-apple-system,sans-serif;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease}.selected-artist-tag:hover{background:#ef444426;border-color:#ef444466;color:#fca5a5}.selected-artist-x{font-size:.875rem;line-height:1;opacity:.7}.selected-artist-tag:hover .selected-artist-x{opacity:1}.clear-filters{display:inline-block;margin-top:1rem;padding:0;background:none;border:none;color:var(--primary);font-size:.875rem;font-weight:500;cursor:pointer}.clear-filters:hover{text-decoration:underline}.concerts-list{display:flex;flex-direction:column;gap:3rem}.month-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--border)}.month-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0}.month-count{padding:.25rem .75rem;background:#8b5cf61a;color:var(--primary);border-radius:9999px;font-family:DM Sans,-apple-system,sans-serif;font-size:.75rem;font-weight:600}.month-concerts{display:flex;flex-direction:column;gap:1rem}.concert-map-container{position:relative;background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;overflow:hidden}.map-legend{display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 1.5rem;background:#0000004d;border-bottom:1px solid var(--border)}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary)}.legend-marker{width:12px;height:12px;border-radius:50%;border:2px solid white}.legend-marker--home{background:#9f70fd}.legend-marker--local{background:#10b981}.legend-marker--regional{background:#f59e0b}.legend-marker--far{background:#ef4444}.concert-map-svg{display:block;width:100%;height:auto;min-height:350px}.concert-map-svg text{pointer-events:none;user-select:none}.venue-marker{transition:transform .2s ease}.venue-marker:hover{transform:scale(1.1)}.map-tooltip{position:absolute;top:1rem;right:1rem;background:var(--card-bg);border:1px solid var(--border);border-radius:.75rem;padding:1rem;width:240px;box-shadow:0 8px 24px #0003;z-index:10}.map-tooltip h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.map-tooltip>p{font-size:.8125rem;color:var(--text-secondary);margin:0 0 .75rem}.map-tooltip ul{list-style:none;margin:0;padding:0}.map-tooltip li{display:flex;justify-content:space-between;align-items:center;padding:.375rem 0;border-bottom:1px solid var(--border);font-size:.8125rem}.map-tooltip li:last-child{border-bottom:none}.map-tooltip li strong{color:var(--text-primary);font-weight:600}.map-tooltip li span{color:var(--text-secondary)}.map-tooltip li.more{color:var(--primary);font-style:italic;justify-content:center}.tooltip-hint{font-size:.75rem;color:var(--text-tertiary);text-align:center;margin-top:.75rem;font-style:italic}.map-city-list{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem 1.5rem;background:var(--bg-secondary);border-top:1px solid var(--border)}.city-chip{display:flex;align-items:center;gap:.5rem;padding:.5rem .875rem;border-radius:9999px;border:1px solid var(--border);background:transparent;color:var(--text-primary);font-size:.8125rem;cursor:pointer;transition:all .15s ease}.city-chip:hover{border-color:var(--primary);background:#8b5cf61a}.city-chip.local{border-color:#10b9814d}.city-chip.local:hover{border-color:#10b981;background:#10b9811a}.city-chip.regional{border-color:#f59e0b4d}.city-chip.regional:hover{border-color:#f59e0b;background:#f59e0b1a}.city-chip.far{border-color:#ef44444d}.city-chip.far:hover{border-color:#ef4444;background:#ef44441a}.city-name{font-weight:500}.city-count{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 .375rem;background:#8b5cf633;color:var(--primary);border-radius:9999px;font-size:.75rem;font-weight:600}.city-chip.local .city-count{background:#10b98133;color:#10b981}.city-chip.regional .city-count{background:#f59e0b33;color:#f59e0b}.city-chip.far .city-count{background:#ef444433;color:#ef4444}.map-link{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem 1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.75rem;color:var(--text-primary);font-weight:500;text-decoration:none;transition:all .15s ease}.map-link:hover{border-color:var(--primary);background:#8b5cf61a;color:var(--primary)}.map-link svg{flex-shrink:0}.concert-card{display:grid;grid-template-columns:80px 1fr auto;gap:1.25rem;padding:1.25rem;background:var(--card-bg);border:1px solid var(--border);border-radius:1rem;cursor:pointer;transition:all .2s ease}.concert-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #8b5cf61f;transform:translateY(-2px)}.concert-card:focus{outline:2px solid var(--primary);outline-offset:2px}.concert-card.local{border-left:4px solid #22c55e}.concert-card.regional{border-left:4px solid #f59e0b}.concert-card.far{border-left:4px solid #ef4444}.concert-date{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.75rem;background:linear-gradient(135deg,#8b5cf6,#ec4899);border-radius:.75rem;color:#fff;text-align:center}.concert-weekday{font-size:.6875rem;text-transform:uppercase;opacity:.9;letter-spacing:.05em}.concert-day{font-size:1.75rem;font-weight:800;line-height:1;margin:.125rem 0}.concert-month-abbr{font-size:.75rem;font-weight:600;text-transform:uppercase}.concert-details{display:flex;flex-direction:column;gap:.375rem;min-width:0}.concert-artist{font-family:DM Sans,-apple-system,sans-serif;font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.concert-tour{font-family:DM Sans,-apple-system,sans-serif;font-size:.8125rem;color:var(--text-secondary)}.concert-venue{display:flex;align-items:center;gap:.5rem;font-family:DM Sans,-apple-system,sans-serif;font-size:.875rem;color:var(--text-primary);margin-top:.25rem}.concert-venue svg{flex-shrink:0;color:var(--primary)}.concert-meta{display:flex;gap:.75rem;font-family:DM Sans,-apple-system,sans-serif;font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.concert-distance,.concert-drive-time{display:flex;align-items:center;gap:.25rem}.concert-drive-time:before{content:"·";margin-right:.25rem}.concert-actions{display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;min-width:120px}.ticket-status{padding:.375rem .75rem;border-radius:9999px;font-family:DM Sans,-apple-system,sans-serif;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.interest-badges{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end}.interest-badge{font-size:.75rem;color:var(--text-secondary)}.interest-badge.going{color:#22c55e}.interest-badge.interested{color:#8b5cf6}.action-buttons{display:flex;gap:.5rem}.action-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.action-btn:hover{border-color:var(--primary);color:var(--primary);background:#8b5cf61a}.action-btn--going:hover{border-color:#22c55e;color:#22c55e;background:#22c55e1a}.carpool-badge{display:flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#3b82f61a;color:#3b82f6;border-radius:.5rem;font-size:.75rem;font-weight:500}.empty-state,.error-state{text-align:center;padding:4rem 2rem;background:var(--card-bg);border:1px solid var(--border);border-radius:1.5rem;max-width:500px;margin:2rem auto}.empty-icon{font-size:4rem;margin-bottom:1rem}.error-icon{width:60px;height:60px;margin:0 auto 1rem;border-radius:50%;background:#ef44441a;color:#ef4444;font-size:2rem;font-weight:700;display:flex;align-items:center;justify-content:center}.empty-state h3,.error-state h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.empty-state p,.error-state p{color:var(--text-secondary);margin-bottom:1.5rem;max-width:320px;margin-left:auto;margin-right:auto}.empty-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.empty-tip{margin-top:2rem;padding:1rem;background:#8b5cf60d;border-radius:.75rem;font-size:.875rem;color:var(--text-secondary)}.empty-tip strong{color:var(--primary)}.loading-concerts{display:flex;flex-direction:column;gap:1rem}.loading-concert-card{height:120px;background:linear-gradient(90deg,var(--bg-secondary) 0%,var(--border) 50%,var(--bg-secondary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:1rem}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.concert-modal-overlay{position:fixed;inset:0;background:#000000b3;backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.concert-modal{position:relative;background:var(--card-bg);border-radius:1.5rem;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:0 25px 50px -12px #00000040}.modal-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border-radius:50%;background:var(--bg-secondary);border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;z-index:10}.modal-close:hover{background:var(--bg-primary);transform:scale(1.05)}.modal-header{padding:2rem 2rem 1.5rem;background:linear-gradient(135deg,#8b5cf61a,#ec48991a);border-bottom:1px solid var(--border)}.modal-poster{width:100%;max-height:200px;object-fit:cover;border-radius:.75rem;margin-bottom:1rem}.modal-title{padding-right:3rem}.modal-artist{font-size:1.75rem;font-weight:800;color:var(--text-primary);margin:0 0 .25rem}.modal-tour{font-size:1rem;color:var(--text-secondary)}.modal-body{padding:1.5rem 2rem 2rem}.modal-section{margin-bottom:2rem}.modal-section:last-child{margin-bottom:0}.modal-section h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.modal-section h3 svg{color:var(--primary)}.modal-info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.modal-info-item{display:flex;align-items:flex-start;gap:.75rem}.modal-info-icon{width:36px;height:36px;border-radius:.5rem;background:var(--bg-secondary);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--primary)}.modal-info-text{display:flex;flex-direction:column;min-width:0}.modal-info-label{font-size:.6875rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}.modal-info-value{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.interest-actions{display:flex;gap:.75rem;margin-bottom:1rem}.interest-btn{flex:1;padding:.875rem 1rem;border-radius:.75rem;border:2px solid var(--border);background:transparent;color:var(--text-primary);font-weight:600;font-size:.9375rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .15s ease}.interest-btn:hover{border-color:var(--primary);color:var(--primary)}.interest-btn.interested:hover{border-color:#8b5cf6;color:#8b5cf6;background:#8b5cf61a}.interest-btn.going:hover{border-color:#22c55e;color:#22c55e;background:#22c55e1a}.ticket-link{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#ec4899);color:#fff;text-decoration:none;border-radius:.75rem;font-weight:600;transition:all .2s ease}.ticket-link:hover{transform:translateY(-2px);box-shadow:0 8px 20px #8b5cf64d}.no-carpools{text-align:center;padding:1.5rem;background:var(--bg-secondary);border-radius:.75rem}.no-carpools p{color:var(--text-secondary);margin-bottom:1rem}.carpool-signin-hint{font-size:.875rem;color:var(--text-tertiary);font-style:italic}.carpool-groups{display:flex;flex-direction:column;gap:1rem}.carpool-card{padding:1.25rem;background:var(--bg-secondary);border-radius:.75rem;border:1px solid var(--border)}.carpool-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.carpool-driver{display:flex;align-items:center;gap:.75rem}.driver-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,#8b5cf6,#ec4899);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:1.125rem;overflow:hidden}.driver-avatar img{width:100%;height:100%;object-fit:cover}.driver-info h4{font-size:.9375rem;font-weight:600;margin:0 0 .125rem}.driver-info p{font-size:.8125rem;color:var(--text-secondary);margin:0}.seats-badge{padding:.375rem .75rem;background:#22c55e26;color:#22c55e;border-radius:9999px;font-size:.8125rem;font-weight:600}.seats-badge.full{background:#ef444426;color:#ef4444}.carpool-details{display:flex;gap:1.5rem;margin-bottom:1rem;padding:.75rem;background:var(--bg-primary);border-radius:.5rem}.carpool-detail{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.carpool-detail svg{color:var(--primary)}.join-carpool-btn{width:100%;padding:.75rem;background:var(--primary);color:#fff;border:none;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .15s ease}.join-carpool-btn:hover{background:var(--primary-dark, #7c3aed)}.concert-tips{background:var(--bg-secondary);padding:1.25rem;border-radius:.75rem}.concert-tips h4{font-size:.9375rem;font-weight:600;margin:0 0 .75rem}.concert-tips ul{margin:0;padding-left:1.25rem}.concert-tips li{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.concert-tips li:last-child{margin-bottom:0}.concert-cta{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#8b5cf614,#ec489914);margin-top:4rem}.concert-cta h2{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.concert-cta p{color:var(--text-secondary);margin-bottom:1.5rem}@media (max-width: 768px){.concert-hero{padding:3rem 1rem 2rem}.concert-stats{gap:2rem}.stat-value{font-size:1.5rem}.view-toggle{justify-content:center}.filters-row{flex-direction:column;gap:1rem}.filter-group{min-width:100%}.map-legend{padding:.75rem 1rem;gap:.75rem;justify-content:center}.legend-item{font-size:.75rem}.concert-map-svg{min-height:280px}.map-tooltip{position:static;width:100%;margin:0;border-radius:0;border-left:none;border-right:none}.map-city-list{padding:.75rem 1rem}.city-chip{padding:.375rem .75rem;font-size:.75rem}.concert-card{grid-template-columns:1fr;gap:1rem}.concert-date{flex-direction:row;justify-content:flex-start;gap:.5rem;width:auto;padding:.5rem 1rem}.concert-day{font-size:1.25rem}.concert-actions{flex-direction:row;flex-wrap:wrap;justify-content:flex-start;align-items:center}.modal-info-grid{grid-template-columns:1fr}.interest-actions{flex-direction:column}}@media (max-width: 480px){.concert-stats{flex-direction:column;gap:1rem}.empty-actions{flex-direction:column}.empty-actions button{width:100%}.carpool-details{flex-direction:column;gap:.75rem}}
