*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#000;color:#fff;min-height:100vh}#root{width:100%;min-height:100vh}.container{max-width:800px;margin:0 auto;padding:20px}.header{text-align:center;padding:40px 0 24px;color:#fff;position:relative}.emoji{font-size:48px;margin-bottom:8px}.title{font-size:56px;font-weight:800;margin-bottom:8px;letter-spacing:-1px;font-family:Plus Jakarta Sans,sans-serif}.subtitle{font-size:clamp(13px,3.5vw,18px);color:#a3a3a3;font-family:Plus Jakarta Sans,sans-serif;font-weight:600;letter-spacing:.01em;line-height:1.45}.header-auth{position:absolute;top:40px;right:0;display:flex;align-items:center;gap:8px}.auth-btn{background:transparent;color:#a3a3a3;border:1px solid #2a2a2a;padding:6px 14px;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;font-family:Inter,sans-serif;white-space:nowrap}.auth-btn:hover{border-color:#555;color:#fff}.auth-user-email{font-size:12px;color:#555;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-box{background:#111;border:1px solid #2a2a2a;padding:14px 16px;border-radius:12px;margin-bottom:16px;position:sticky;top:0;z-index:50;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.search-title{font-size:18px;font-weight:600;color:#fff;margin-bottom:4px}.search-subtitle{font-size:13px;color:#a3a3a3;margin-bottom:14px}.input{width:100%;padding:10px 14px;font-size:15px;font-family:Inter,sans-serif;border:1px solid #2a2a2a;border-radius:8px;margin-bottom:12px;background:#1a1a1a;color:#fff}.input::placeholder{color:#555}.input:focus{outline:none;border-color:#555}.radius-row{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}.radius-btn{flex:1;min-width:52px;padding:8px 6px;background:#1a1a1a;color:#a3a3a3;border:1px solid #2a2a2a;border-radius:6px;cursor:pointer;font-size:13px;font-family:Inter,sans-serif;font-weight:500}.radius-btn.active{background:#fff;color:#000;border-color:#fff}.radius-custom{width:100%;padding:8px 14px;font-size:13px;font-family:Inter,sans-serif;border:1px solid #2a2a2a;border-radius:8px;margin-bottom:12px;background:#1a1a1a;color:#fff}.radius-custom::placeholder{color:#555}.radius-label{font-size:12px;font-weight:500;color:#a3a3a3;margin-bottom:6px}.btn{width:100%;padding:12px;background:#fff;color:#000;border:none;border-radius:8px;font-size:15px;font-weight:600;font-family:Inter,sans-serif;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.btn:hover{background:#f0f0f0;transform:translateY(-1px);box-shadow:0 6px 20px #ffffff21}.btn:active{transform:translateY(0);box-shadow:none}.event-card{background:#111;border:1px solid #2a2a2a;padding:8px 12px;border-radius:10px;margin-bottom:6px}.meta-sep{color:#444;font-size:11px;flex-shrink:0}.event-title{font-size:14px;font-weight:700;color:#fff;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.event-info{font-size:13px;color:#a3a3a3;margin-bottom:0}.event-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:4px}.event-header{display:flex;justify-content:space-between;align-items:flex-start}.event-body{flex:1;min-width:0}.add-btn{background:transparent;color:#a3a3a3;border:1px solid #333;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;line-height:1;margin-left:8px;flex-shrink:0;white-space:nowrap}.add-btn.saved{color:#22c55e}.spotify-badge{background:#1db954;color:#fff;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:600}.youtube-badge{background:red;color:#fff;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:600}.lastfm-badge{background:#9b59b6;color:#fff;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:600}.svc-card{flex:1;border:1px solid #2a2a2a;border-radius:8px;padding:8px 6px;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0;transition:border-color .15s}.svc-name{font-size:10px;font-weight:600;color:#ccc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.svc-status{font-size:9px;font-weight:600}.svc-status.connected{color:#22c55e}.svc-status.warn{color:#f59e0b}.svc-status.soon{color:#555}.svc-action-btn{font-size:9px;font-weight:600;font-family:Inter,sans-serif;border-radius:4px;padding:2px 7px;cursor:pointer;background:#1a1a1a;color:#a3a3a3;border:1px solid #333;white-space:nowrap}.svc-action-btn.connect{background:#ffffff18;color:#fff;border-color:#555}.svc-action-btn:hover{border-color:#888;color:#fff}.price-badge{font-size:12px;color:#fff;font-weight:600}.loading{text-align:center;color:#a3a3a3;padding:40px}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:12px;margin-bottom:16px}.feature-card{background:#111;border:1px solid #2a2a2a;padding:16px;border-radius:10px;color:#fff;cursor:pointer;transition:border-color .15s}.feature-card:hover{border-color:#555}.feature-icon{font-size:24px;margin-bottom:8px}.tabs{display:flex;gap:8px;margin-bottom:16px}.tab-btn{flex:1;padding:11px;background:#111;color:#a3a3a3;border:1px solid #2a2a2a;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;font-family:Inter,sans-serif}.tab-btn.active{background:#fff;color:#000;border-color:#fff}.tab-btn-icon{width:20px;height:20px;display:inline-block;vertical-align:middle;margin-right:6px;border-radius:4px}.suggestions-tab{padding:24px 0;text-align:center}.suggestions-empty{color:#888;font-size:14px}.spotify-connect-btn{width:100%;padding:11px;background:#1db954;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:600;font-family:Inter,sans-serif;margin-top:10px;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.spotify-connect-btn:hover{background:#1ed760;transform:translateY(-1px);box-shadow:0 6px 24px #1db95473}.spotify-connect-btn:active{transform:translateY(0);box-shadow:none}.spotify-connected{color:#22c55e;font-weight:600;font-size:13px;margin-top:10px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.playlist-section{margin-bottom:20px}.empty-playlist{text-align:center;color:#a3a3a3;padding:40px;background:#111;border:1px solid #2a2a2a;border-radius:12px}.playlist-input-section{background:#111;border:1px solid #2a2a2a;padding:18px;border-radius:12px;margin-bottom:16px}.export-btn{background:#1db954!important;color:#fff!important;transition:transform .14s ease,box-shadow .14s ease,filter .14s ease!important}.export-btn:hover:not(:disabled){transform:translateY(-1px)!important;filter:brightness(1.1)!important;box-shadow:0 6px 24px #00000059!important}.export-btn:active{transform:translateY(0)!important;box-shadow:none!important}.saved-artist-card{background:#111;border:1px solid #2a2a2a;padding:14px;border-radius:10px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.artist-info{display:flex;gap:12px;flex:1}.artist-image{width:52px;height:52px;border-radius:6px;object-fit:cover}.artist-details{flex:1}.artist-name{font-size:15px;font-weight:700;color:#fff;margin-bottom:3px}.artist-event,.artist-venue{font-size:12px;color:#a3a3a3;margin-bottom:2px}.artist-date{font-size:12px;color:#555;margin-bottom:3px}.spotify-link a{color:#1db954;text-decoration:none;font-size:12px;font-weight:500}.remove-btn{background:transparent;color:#555;border:1px solid #2a2a2a;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px}.remove-btn:hover{color:#ef4444;border-color:#ef4444}.where-btn{background:transparent;color:#a3a3a3;border:1px solid #2a2a2a;padding:3px 8px;border-radius:6px;cursor:pointer;font-size:10px;font-weight:600;font-family:Inter,sans-serif;line-height:1.4;flex-shrink:0;white-space:nowrap}.where-btn:hover{color:#fff;border-color:#555}.ticket-btn{background:transparent;color:#f59e0b;border:1px solid #f59e0b44;padding:4px 6px;border-radius:6px;cursor:pointer;font-size:15px;line-height:1;flex-shrink:0;text-decoration:none;display:inline-flex;align-items:center}.ticket-btn:hover{border-color:#f59e0b;background:#f59e0b18}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000d1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-box{background:linear-gradient(158deg,#1a1a1a,#111 60%);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:28px 24px;max-width:340px;width:90%;text-align:center;box-shadow:0 32px 72px #000000b3,0 0 0 1px #ffffff08 inset}.results-header{color:#fff;font-size:15px;font-weight:600;margin-bottom:12px}.view-toggle{display:flex;gap:8px;margin-bottom:12px}.view-btn{flex:1;padding:8px;background:#1a1a1a;color:#a3a3a3;border:1px solid #2a2a2a;border-radius:8px;cursor:pointer;font-size:13px;font-weight:500;font-family:Inter,sans-serif}.view-btn.active{background:#fff;color:#000;border-color:#fff}#event-map{height:400px;border-radius:10px;margin-bottom:16px;border:1px solid #2a2a2a}#event-map .leaflet-popup-content-wrapper{background:#1a1a1a;color:#fff;border:1px solid #2a2a2a}#event-map .leaflet-popup-tip{background:#1a1a1a}.saved-searches{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}.search-chip{padding:4px 10px;background:#1a1a1a;border:1px solid #2a2a2a;border-radius:20px;font-size:12px;color:#a3a3a3;cursor:pointer;display:flex;align-items:center;gap:6px}.search-chip:hover{border-color:#555;color:#fff}.search-chip-del{background:none;border:none;color:#555;cursor:pointer;font-size:11px;padding:0;line-height:1}.search-chip-del:hover{color:#ef4444}.saved-playlists-btn{background:transparent;color:#a3a3a3;border:1px solid #2a2a2a;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-family:Inter,sans-serif;transition:border-color .14s ease,color .14s ease}.saved-playlists-btn:hover{border-color:#555;color:#fff}.google-signin-btn{transition:transform .14s ease,box-shadow .14s ease,background .14s ease!important}.google-signin-btn:hover{background:#f0f0f0!important;transform:translateY(-1px)!important;box-shadow:0 6px 20px #ffffff1f!important}.google-signin-btn:active{transform:translateY(0)!important}.btn-service-cta{transition:transform .14s ease,box-shadow .14s ease,filter .14s ease!important}.btn-service-cta:hover{transform:translateY(-1px)!important;filter:brightness(1.1)!important;box-shadow:0 8px 28px var(--svc-glow, rgba(29,185,84,.4))!important}.btn-service-cta:active{transform:translateY(0)!important}.save-section-card{background:linear-gradient(135deg,#1e1e1e,#161616);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:14px;margin-bottom:20px}.btn-load{background:#fff;color:#000;border:none;padding:5px 12px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,background .14s ease}.btn-load:hover{background:#f0f0f0;transform:translateY(-1px);box-shadow:0 4px 12px #ffffff1f}.btn-load:active{transform:translateY(0)}
