.app{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,var(--dark-bg) 0%,var(--darker-bg) 100%)}.app-header{background:linear-gradient(135deg,rgba(0,255,255,.05) 0%,rgba(255,0,255,.05) 100%);border:1px solid rgba(255,255,255,.1);border-radius:20px;margin:2rem auto;padding:2.5rem 0 1.5rem;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 8px 32px #0000004d;max-width:1400px;width:calc(100% - 4rem);transition:all .3s ease}.header-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden}.header-glow{position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle,rgba(0,255,255,.1) 0%,transparent 70%);animation:rotate 20s linear infinite}.header-particles{position:absolute;top:0;left:0;right:0;bottom:0;background-image:radial-gradient(2px 2px at 20px 30px,rgba(255,255,255,.3),transparent),radial-gradient(2px 2px at 40px 70px,rgba(0,255,255,.3),transparent),radial-gradient(1px 1px at 90px 40px,rgba(255,0,255,.3),transparent),radial-gradient(1px 1px at 130px 80px,rgba(255,255,0,.3),transparent);background-repeat:repeat;background-size:200px 100px;animation:float 6s ease-in-out infinite}.header-content{max-width:1200px;margin:0 auto;padding:0 3rem;position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:3rem;flex-wrap:wrap}.header-left{flex:1;display:flex;align-items:center}.header-logo{display:flex;align-items:center;gap:1.5rem}.logo-icon{font-size:3.5rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.6));animation:pulse 3s ease-in-out infinite}.logo-image{width:4rem;height:4rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.6));animation:pulse 3s ease-in-out infinite;border-radius:8px}.app-title{font-size:3.5rem;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin:0}.title-glow{background:linear-gradient(135deg,var(--primary-neon) 0%,#ffffff 50%,var(--primary-neon) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 30px rgba(0,255,255,.6)}.title-accent{background:linear-gradient(135deg,var(--secondary-neon) 0%,var(--accent-neon) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-left:.75rem}.header-right{flex:1;display:flex;align-items:center;justify-content:flex-end}.header-description{display:flex;flex-direction:column;align-items:flex-end;gap:1rem;text-align:right}.app-subtitle{font-size:1.3rem;color:var(--text-secondary);font-weight:500;letter-spacing:.02em;opacity:.9;margin:0}.header-features{display:flex;gap:1rem;flex-wrap:wrap;justify-content:flex-end}.feature-tag{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:.5rem 1rem;color:var(--text-secondary);font-size:.9rem;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.feature-tag:hover{background:rgba(0,255,255,.1);border-color:#00ffff4d;color:var(--primary-neon);transform:translateY(-1px)}.header-links{display:flex;gap:2rem;align-items:center;margin-top:1rem;width:100%;justify-content:center;border-top:1px solid rgba(255,255,255,.1);padding-top:1rem}.header-link{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;padding:.5rem 1rem;border-radius:8px;transition:all .3s ease;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);cursor:pointer;font-family:inherit}.header-link:hover{color:var(--text-primary);background:rgba(0,255,255,.05);border-color:#0ff3;transform:translateY(-1px);box-shadow:0 4px 12px #00ffff1a}.link-icon{font-size:1rem;filter:drop-shadow(0 0 8px rgba(0,255,255,.3))}.discord-icon{width:1rem;height:1rem;filter:drop-shadow(0 0 8px rgba(0,255,255,.3))}.loading-indicator{display:flex;align-items:center;justify-content:center;gap:1.5rem;padding:1.5rem 2rem;margin:2rem auto;background:linear-gradient(135deg,rgba(0,255,255,.05) 0%,rgba(255,0,255,.05) 100%);border:1px solid rgba(0,255,255,.2);border-radius:16px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);box-shadow:0 4px 20px #0003;max-width:600px;width:100%;text-align:center;transition:all .3s cubic-bezier(.4,0,.2,1)}.loading-indicator.floating{position:fixed;top:1rem;left:50%;transform:translate(-50%);z-index:1000;margin:0;padding:1rem 2rem;max-width:600px;width:calc(100% - 2rem);background:linear-gradient(135deg,rgba(0,255,255,.1) 0%,rgba(255,0,255,.1) 100%);border-color:#00ffff4d;box-shadow:0 4px 20px #0006}.loading-indicator .loading-spinner{width:32px;height:32px;border:3px solid rgba(0,255,255,.2);border-top:3px solid var(--primary-neon);border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.loading-text{color:var(--text-primary);font-weight:500;font-size:1.1rem;margin:0;text-align:center}.app-main{flex:1;padding:3rem 0;display:flex;flex-direction:column;align-items:center}.container{max-width:1200px;margin:0 auto;padding:0 2rem;width:100%}.error-message{background:rgba(255,68,68,.1);border:1px solid var(--error-color);border-radius:12px;padding:1.25rem;margin:1.5rem 0;display:flex;align-items:center;gap:.75rem;color:var(--error-color);animation:slideIn .3s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);max-width:600px;margin-left:auto;margin-right:auto}.error-icon{font-size:1.3rem;flex-shrink:0}.loading-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;margin:3rem 0;color:var(--text-secondary);text-align:center}.loading-spinner{width:40px;height:40px;border:3px solid rgba(0,255,255,.2);border-top:3px solid var(--primary-neon);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes slideInFromTop{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.loading-indicator.floating.slide-in{animation:slideInFromTop .3s ease-out}@media (max-width: 768px){.app-header{padding:2rem 0 1rem;margin:1.5rem auto;width:calc(100% - 2rem)}.loading-indicator{padding:1rem 1.5rem;margin:1.5rem 0}.loading-indicator.floating{padding:.75rem 1.5rem;max-width:500px;width:calc(100% - 1.5rem);gap:1rem}.loading-indicator .loading-spinner{width:28px;height:28px}.loading-text{font-size:1rem}.header-content{flex-direction:column;gap:2rem;text-align:center;padding:0 2rem}.header-left,.header-right{justify-content:center}.header-description{align-items:center;text-align:center}.header-features{justify-content:center}.header-logo{gap:1rem}.logo-icon,.app-title{font-size:2.5rem}.app-subtitle{font-size:1.1rem}.header-features{gap:.75rem}.feature-tag{font-size:.85rem;padding:.4rem .8rem}.header-links{gap:1rem;margin-top:.75rem;padding-top:.75rem}.header-link{font-size:.8rem;padding:.4rem .8rem}.container{padding:0 1.5rem}.app-main{padding:2rem 0}}@media (max-width: 480px){.app-header{padding:1.5rem 0 .75rem;margin:1rem auto;width:calc(100% - 1rem)}.loading-indicator{padding:.75rem 1rem;margin:1rem 0}.loading-indicator.floating{padding:.5rem 1rem;max-width:450px;width:calc(100% - 1rem);gap:.75rem}.loading-indicator .loading-spinner{width:24px;height:24px}.loading-text{font-size:.9rem}.header-content{gap:1.5rem;padding:0 1.5rem}.header-logo{gap:.75rem}.logo-icon,.app-title{font-size:2rem}.app-subtitle{font-size:1rem}.header-features{gap:.5rem}.feature-tag{font-size:.8rem;padding:.3rem .6rem}.header-links{gap:.75rem;margin-top:.5rem;padding-top:.5rem}.header-link{font-size:.75rem;padding:.3rem .6rem}.container{padding:0 1rem}}.platform-note{margin:2rem auto;max-width:800px;padding:0 1rem}.note-content{background:linear-gradient(135deg,rgba(0,255,255,.05) 0%,rgba(255,0,255,.05) 100%);border:1px solid rgba(0,255,255,.2);border-radius:12px;padding:1.5rem;display:flex;align-items:center;gap:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0003;transition:all .3s ease}.note-content:hover{border-color:#00ffff4d;box-shadow:0 6px 25px #0000004d}.note-icon{font-size:1.5rem;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(0,255,255,.5))}.note-text{margin:0;color:var(--text-color);font-size:1rem;line-height:1.5;font-weight:400}@media (max-width: 768px){.platform-note{margin:1.5rem auto;padding:0 .5rem}.note-content{padding:1.25rem;gap:.75rem}.note-icon{font-size:1.25rem}.note-text{font-size:.95rem}}@media (max-width: 480px){.platform-note{margin:1rem auto}.note-content{padding:1rem;gap:.5rem;flex-direction:column;text-align:center}.note-icon{font-size:1.1rem}.note-text{font-size:.9rem}}.playlist-extractor{margin-bottom:4rem;width:100%;max-width:800px;margin-left:auto;margin-right:auto}.extractor-section{background:transparent;position:relative;padding:0}.extractor-title{font-size:2.4rem;font-weight:700;margin-bottom:2.5rem;color:var(--text-primary);display:flex;align-items:center;gap:1rem;text-align:center;justify-content:center;letter-spacing:-.02em}.title-icon{font-size:2.2rem;color:var(--primary-neon);text-shadow:0 0 15px rgba(0,255,255,.4)}.extractor-form{margin-bottom:3rem;max-width:600px;margin-left:auto;margin-right:auto;width:100%}.input-group{margin-bottom:2rem}.input-label{display:block;margin-bottom:.75rem;font-weight:600;color:var(--text-secondary);font-size:.95rem;text-transform:uppercase;letter-spacing:.8px;text-align:center}.input-wrapper{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:1.25rem;font-size:1.3rem;z-index:1;transition:all .3s ease;color:var(--primary-neon);text-shadow:0 0 8px rgba(0,255,255,.3)}.playlist-input{width:100%;padding:1.5rem 1.5rem 1.5rem 4rem;background:rgba(255,255,255,.03);border:2px solid rgba(255,255,255,.1);border-radius:16px;color:var(--text-primary);font-size:1.1rem;transition:all .3s ease;font-family:inherit;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 20px #0000001a}.playlist-input:focus{outline:none;border-color:var(--primary-neon);box-shadow:0 0 0 4px #00ffff1a,0 8px 30px #0003;background:rgba(255,255,255,.05)}.playlist-input:disabled{opacity:.6;cursor:not-allowed}.playlist-input::placeholder{color:var(--text-muted);font-style:italic}.extract-button{width:100%;padding:1.5rem 2.5rem;background:linear-gradient(135deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);border:none;border-radius:16px;color:var(--darker-bg);font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .3s ease;font-family:inherit;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 8px 25px #00ffff4d;position:relative;overflow:hidden}.extract-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.extract-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 35px #0ff6}.extract-button:hover:not(:disabled):before{left:100%}.extract-button:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 15px #00ffff4d}.extract-button:disabled{opacity:.7;cursor:not-allowed;transform:none;box-shadow:0 4px 15px #0ff3}.extract-button.processing{background:linear-gradient(135deg,var(--primary-neon) 0%,var(--accent-neon) 100%);animation:pulse 2s ease-in-out infinite}.button-icon{margin-right:.75rem;font-size:1.2rem}.button-spinner{display:inline-block;width:1.2rem;height:1.2rem;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:spin 1s linear infinite;margin-right:.75rem}.progress-container{margin-top:2rem;padding:2rem;background:rgba(255,255,255,.02);border-radius:16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 8px 25px #0000001a}.progress-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.95rem;color:var(--text-secondary)}.progress-stage{font-weight:600;color:var(--primary-neon);text-shadow:0 0 8px rgba(0,255,255,.3)}.progress-percent{font-weight:600;color:var(--text-primary)}.progress-bar{width:100%;height:8px;background:rgba(255,255,255,.1);border-radius:4px;overflow:hidden;position:relative}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);border-radius:4px;transition:width .3s ease;position:relative;overflow:hidden}.progress-fill:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}@media (max-width: 768px){.extractor-title{font-size:2rem;margin-bottom:2rem}.extractor-form{max-width:100%;padding:0 1rem}.playlist-input{padding:1.25rem 1.25rem 1.25rem 3.5rem;font-size:1rem}.extract-button{padding:1.25rem 2rem;font-size:1.1rem}.progress-container{margin:1.5rem 1rem 0;padding:1.5rem}.progress-info{font-size:.9rem}.progress-stage,.progress-percent{font-size:.85rem}}@media (max-width: 480px){.playlist-extractor{margin-bottom:3rem}.extractor-title{font-size:1.8rem;gap:.75rem}.title-icon{font-size:1.8rem}.extractor-form{padding:0 .5rem}.playlist-input{padding:1rem 1rem 1rem 3rem;font-size:.95rem}.input-icon{left:1rem;font-size:1.1rem}.extract-button{padding:1rem 1.5rem;font-size:1rem}}.song-table-container{background:transparent;border:none;border-radius:0;overflow:visible;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none;animation:slideIn .5s ease-out;width:100%;max-width:1200px;margin:0 auto}.table-header{padding:0 0 2.5rem;border-bottom:2px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:2rem;margin-bottom:2rem}.table-title{font-size:2rem;font-weight:700;color:var(--text-primary);display:flex;align-items:center;gap:1rem;margin:0;letter-spacing:-.02em}.title-icon{font-size:1.8rem;color:var(--primary-neon);text-shadow:0 0 12px rgba(0,255,255,.4)}.table-controls{display:flex;gap:1.5rem;align-items:center}.search-container{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:1rem;font-size:1.1rem;color:var(--text-muted);z-index:1}.search-input{padding:1rem 1rem 1rem 3rem;background:rgba(255,255,255,.03);border:2px solid rgba(255,255,255,.1);border-radius:12px;color:var(--text-primary);font-size:1rem;width:320px;transition:all .3s ease;font-family:inherit;-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 4px 20px #0000001a}.search-input:focus{outline:none;border-color:var(--primary-neon);box-shadow:0 0 0 3px #00ffff1a,0 8px 30px #0003;background:rgba(255,255,255,.05)}.search-input::placeholder{color:var(--text-muted);font-style:italic}.table-wrapper{overflow-x:auto;background:rgba(255,255,255,.02);border-radius:16px;border:1px solid rgba(255,255,255,.1);-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);box-shadow:0 8px 25px #0000001a}.song-table{width:100%;border-collapse:collapse;font-size:1rem;background:transparent}.song-table thead{background:rgba(255,255,255,.03);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.song-table th{padding:1.25rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary);font-size:.9rem;text-transform:uppercase;letter-spacing:.8px;border-bottom:1px solid rgba(255,255,255,.1);position:relative}.song-table th:first-child{padding-left:1.5rem}.song-table th:last-child{padding-right:1.5rem}.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .3s ease;position:relative}.sortable-header:hover{color:var(--primary-neon);text-shadow:0 0 8px rgba(0,255,255,.3)}.header-content{display:flex;align-items:center;gap:.5rem;justify-content:flex-start}.sort-icon{font-size:.8rem;transition:all .3s ease;opacity:.6}.sortable-header:hover .sort-icon{opacity:1;transform:scale(1.1)}.sort-icon-inactive{color:var(--text-muted)}.sort-icon-active{color:var(--primary-neon);text-shadow:0 0 8px rgba(0,255,255,.4);animation:sortBounce .3s ease-out}.sort-asc{transform:rotate(180deg)}.sort-desc{transform:rotate(0)}@keyframes sortBounce{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.sortable-header:hover .sort-icon-inactive{color:var(--primary-neon)}.song-table td{padding:1.25rem 1rem;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}.song-row{transition:all .3s ease;cursor:pointer}.song-row:hover{background:rgba(255,255,255,.02);transform:translate(4px)}.song-title{font-weight:600;color:var(--text-primary);max-width:300px}.title-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:1.05rem;line-height:1.4}.song-artist{color:var(--text-secondary);max-width:250px}.artist-text{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;line-height:1.4;opacity:.9}.no-results{padding:4rem 2rem;text-align:center;color:var(--text-muted)}.no-results-content{display:flex;flex-direction:column;align-items:center;gap:1rem;max-width:400px;margin:0 auto}.no-results-icon{font-size:3rem;color:var(--text-muted);opacity:.5}.no-results-content p{font-size:1.1rem;line-height:1.5}.search-results-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}@media (max-width: 768px){.table-header{flex-direction:column;align-items:stretch;gap:1.5rem;padding-bottom:2rem}.table-title{font-size:1.6rem;justify-content:center}.table-controls{justify-content:center}.search-input{width:100%;max-width:300px}.song-table th,.song-table td{padding:1rem .75rem}.title-text,.artist-text{max-width:150px}}@media (max-width: 480px){.song-table{font-size:.9rem}.song-table th,.song-table td{padding:.75rem .5rem}.title-text,.artist-text{max-width:120px}}.expand-column{width:80px;text-align:center}.expand-cell{text-align:center;padding:1rem .5rem}.expand-button{background:linear-gradient(135deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);border:none;border-radius:8px;color:var(--darker-bg);font-size:.8rem;font-weight:600;padding:.5rem .75rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.25rem;min-width:60px;justify-content:center;box-shadow:0 4px 15px #0ff3}.expand-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #00ffff4d}.expand-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.expand-button.expanded{background:linear-gradient(135deg,var(--accent-neon) 0%,var(--primary-neon) 100%)}.expand-icon{font-size:.7rem;transition:transform .3s ease}.map-count{font-size:.75rem;font-weight:700}.loading-spinner-small{width:12px;height:12px;border:1.5px solid transparent;border-top:1.5px solid currentColor;border-radius:50%;animation:spin 1s linear infinite}.expanded-row{background:rgba(255,255,255,.01)}.maps-container{padding:0}.maps-content{padding:1.5rem;background:rgba(255,255,255,.02);border-top:1px solid rgba(255,255,255,.05);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.maps-title{font-size:1.2rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem;display:flex;align-items:center;gap:.75rem;letter-spacing:-.01em}.maps-title:before{content:"🎮";font-size:1rem}.maps-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.map-card{background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:1rem;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 4px 20px #0000001a}.map-card:hover{transform:translateY(-2px);box-shadow:0 8px 30px #00000026;border-color:#0ff3}.map-header{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.25rem}.map-song-name{font-size:1rem;font-weight:600;color:var(--text-primary);line-height:1.3;margin:0}.map-sub-name{color:var(--text-muted);font-weight:400}.map-author{color:var(--primary-neon);font-size:.85rem;font-weight:500;text-shadow:0 0 8px rgba(0,255,255,.3)}.map-details{margin-bottom:1rem;display:flex;flex-direction:column;gap:.5rem}.map-info{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.25rem}.map-mapper{color:var(--text-secondary);font-size:.85rem;font-weight:500}.map-difficulty{color:var(--accent-neon);font-size:.8rem;font-weight:600;text-shadow:0 0 8px rgba(255,255,0,.3);background:rgba(255,255,0,.1);padding:.2rem .4rem;border-radius:4px}.map-stars{color:var(--accent-neon);font-weight:600;font-size:.85rem}.map-meta{display:flex;gap:.75rem;color:var(--text-muted);font-size:.8rem;flex-wrap:wrap}.map-actions{display:flex;gap:.5rem;flex-wrap:wrap}.download-button{background:linear-gradient(135deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);color:var(--darker-bg);text-decoration:none;padding:.6rem 1rem;border-radius:6px;font-weight:600;font-size:.85rem;transition:all .3s ease;display:inline-flex;align-items:center;gap:.4rem;box-shadow:0 4px 15px #0ff3;position:relative;overflow:hidden;border:none;cursor:pointer;font-family:inherit}.download-button:hover{transform:translateY(-1px);box-shadow:0 6px 20px #00ffff4d;text-decoration:none;color:var(--darker-bg)}.download-button:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.download-button:hover:before{left:100%}.no-maps{text-align:center;padding:3rem 2rem;color:var(--text-muted)}.no-maps-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.no-maps p{font-size:1.1rem;margin-bottom:.5rem}.no-maps-hint{font-size:.9rem;opacity:.7;font-style:italic}@media (max-width: 768px){.expand-column{width:60px}.expand-button{min-width:50px;padding:.4rem .5rem;font-size:.75rem}.maps-content{padding:1.5rem}.maps-grid{grid-template-columns:1fr;gap:1rem}.map-card{padding:1.25rem}.map-info{flex-direction:column;align-items:flex-start;gap:.25rem}.map-meta{flex-direction:column;gap:.5rem}}@media (max-width: 480px){.maps-content{padding:1rem}.expand-button{min-width:45px;padding:.3rem .4rem;font-size:.7rem}.map-card{padding:1rem}.maps-title{font-size:1.2rem}}.welcome-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.8);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease-out}.welcome-popup{background:linear-gradient(135deg,var(--dark-bg) 0%,var(--darker-bg) 100%);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:2.5rem;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000080;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);animation:slideIn .4s ease-out}.welcome-header{text-align:center;margin-bottom:2rem}.welcome-title{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:1rem;letter-spacing:-.02em}.welcome-icon{font-size:2.5rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.5))}.welcome-logo{width:3rem;height:3rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.5));border-radius:6px}.welcome-subtitle{font-size:1.1rem;color:var(--text-secondary);opacity:.9}.welcome-content{margin-bottom:2rem}.welcome-steps{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.step{display:flex;align-items:center;gap:1rem;padding:1rem;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.1);border-radius:12px;transition:all .3s ease}.step:hover{background:rgba(0,255,255,.05);border-color:#0ff3;transform:translate(5px)}.step-icon{font-size:1.5rem;flex-shrink:0;filter:drop-shadow(0 0 10px rgba(0,255,255,.3))}.step-text{font-size:1.1rem;color:var(--text-primary);font-weight:500}.welcome-note{text-align:center;padding:1rem;background:rgba(0,255,255,.05);border:1px solid rgba(0,255,255,.1);border-radius:12px}.welcome-note p{margin:0;color:var(--text-secondary);font-size:1rem}.note-small{font-size:.9rem!important;opacity:.8;margin-top:.5rem!important}.welcome-footer{border-top:1px solid rgba(255,255,255,.1);padding-top:1.5rem;display:flex;flex-direction:column;gap:1rem;align-items:center}.terms-section{text-align:center}.terms-checkbox{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--text-secondary);font-size:.95rem;cursor:pointer;-webkit-user-select:none;user-select:none}.terms-checkbox input[type=checkbox]{display:none}.checkmark{width:18px;height:18px;border:2px solid var(--border-color);border-radius:4px;background:rgba(255,255,255,.02);position:relative;transition:all .3s ease}.terms-checkbox input[type=checkbox]:checked+.checkmark{background:var(--primary-neon);border-color:var(--primary-neon);box-shadow:0 0 10px #00ffff4d}.terms-checkbox input[type=checkbox]:checked+.checkmark:after{content:"✓";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--darker-bg);font-weight:700;font-size:12px}.terms-link{background:none;border:none;color:var(--primary-neon);text-decoration:underline;cursor:pointer;font-size:inherit;font-family:inherit;padding:0;margin:0;text-shadow:0 0 8px rgba(0,255,255,.3);transition:all .3s ease}.terms-link:hover{color:var(--secondary-neon);text-shadow:0 0 12px rgba(255,0,255,.4)}.welcome-accept-btn{background:linear-gradient(135deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);border:none;border-radius:12px;color:var(--darker-bg);font-size:1.1rem;font-weight:700;padding:1rem 2.5rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 8px 25px #00ffff4d;position:relative;overflow:hidden}.welcome-accept-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.welcome-accept-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 35px #0ff6}.welcome-accept-btn:hover:not(:disabled):before{left:100%}.welcome-accept-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:0 4px 15px #0ff3}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideIn{0%{opacity:0;transform:translateY(30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 768px){.welcome-popup{padding:1.5rem;width:95%;max-height:85vh;overflow-y:auto}.welcome-title{font-size:1.8rem;flex-direction:column;gap:.5rem;text-align:center}.welcome-logo{width:2.5rem;height:2.5rem}.welcome-subtitle{font-size:1rem;text-align:center}.welcome-steps{gap:1rem}.step{padding:.75rem;flex-direction:column;text-align:center;gap:.5rem}.step-icon{font-size:1.25rem}.step-text{font-size:.95rem}.welcome-note{padding:.75rem;text-align:center}.welcome-note p{font-size:.9rem;margin-bottom:.5rem}.note-small{font-size:.8rem}.welcome-footer{flex-direction:column;gap:1rem;align-items:center}.terms-section{text-align:center}.terms-checkbox{font-size:.9rem;justify-content:center}.welcome-accept-btn{font-size:1rem;padding:.875rem 2rem;width:100%;max-width:250px}}@media (max-width: 480px){.welcome-popup{padding:1rem;width:98%;max-height:90vh}.welcome-title{font-size:1.5rem;gap:.25rem}.welcome-logo{width:2rem;height:2rem}.welcome-subtitle{font-size:.9rem}.welcome-steps{gap:.75rem}.step{padding:.5rem;gap:.25rem}.step-icon{font-size:1rem}.step-text{font-size:.85rem}.welcome-note{padding:.5rem}.welcome-note p{font-size:.8rem;margin-bottom:.25rem}.note-small{font-size:.7rem}.terms-checkbox{font-size:.8rem}.welcome-accept-btn{font-size:.9rem;padding:.75rem 1.5rem;max-width:200px}}.tos-page{min-height:100vh;background:linear-gradient(135deg,var(--dark-bg) 0%,var(--darker-bg) 100%);color:var(--text-primary);padding:2rem 0}.tos-container{max-width:800px;margin:0 auto;padding:0 2rem}.tos-header{text-align:center;margin-bottom:3rem;padding-bottom:2rem;border-bottom:2px solid rgba(255,255,255,.1)}.tos-title{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;justify-content:center;gap:1rem;letter-spacing:-.02em}.tos-icon{font-size:3rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.5))}.tos-logo-container{display:flex;justify-content:center;margin-bottom:1rem}.tos-logo{width:4rem;height:4rem;filter:drop-shadow(0 0 20px rgba(0,255,255,.5));border-radius:8px}.tos-subtitle{font-size:1.1rem;color:var(--text-secondary);opacity:.8}.tos-content{line-height:1.7}.tos-section{margin-bottom:2.5rem;padding:1.5rem;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.05);border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.tos-section h2{font-size:1.5rem;font-weight:700;color:var(--primary-neon);margin-bottom:1rem;text-shadow:0 0 10px rgba(0,255,255,.3)}.tos-section p{color:var(--text-secondary);font-size:1rem;margin-bottom:1rem}.tos-section ul{color:var(--text-secondary);font-size:1rem;margin:1rem 0;padding-left:1.5rem}.tos-section li{margin-bottom:.5rem;line-height:1.6}.tos-section strong{color:var(--text-primary);font-weight:600}.tos-footer{text-align:center;margin-top:3rem;padding-top:2rem;border-top:2px solid rgba(255,255,255,.1)}.tos-back-btn{background:linear-gradient(135deg,var(--primary-neon) 0%,var(--secondary-neon) 100%);border:none;border-radius:12px;color:var(--darker-bg);font-size:1.1rem;font-weight:700;padding:1rem 2.5rem;cursor:pointer;transition:all .3s ease;text-transform:uppercase;letter-spacing:.5px;box-shadow:0 8px 25px #00ffff4d;position:relative;overflow:hidden}.tos-back-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);transition:left .5s}.tos-back-btn:hover{transform:translateY(-2px);box-shadow:0 12px 35px #0ff6}.tos-back-btn:hover:before{left:100%}@media (max-width: 768px){.tos-container{padding:0 1.5rem}.tos-title,.tos-icon{font-size:2.5rem}.tos-section{padding:1.25rem;margin-bottom:2rem}.tos-section h2{font-size:1.3rem}}@media (max-width: 480px){.tos-page{padding:1rem 0}.tos-container{padding:0 1rem}.tos-title,.tos-icon{font-size:2rem}.tos-section{padding:1rem;margin-bottom:1.5rem}.tos-section h2{font-size:1.2rem}.tos-section p,.tos-section ul{font-size:.95rem}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary-neon: #00ffff;--secondary-neon: #ff00ff;--accent-neon: #ffff00;--dark-bg: #0a0a0a;--darker-bg: #050505;--card-bg: #1a1a1a;--text-primary: #ffffff;--text-secondary: #cccccc;--text-muted: #888888;--border-color: #333333;--success-color: #00ff88;--error-color: #ff4444}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,var(--dark-bg) 0%,var(--darker-bg) 100%);color:var(--text-primary);min-height:100vh;overflow-x:hidden}body:before{content:"";position:fixed;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 20% 80%,rgba(0,255,255,.1) 0%,transparent 50%),radial-gradient(circle at 80% 20%,rgba(255,0,255,.1) 0%,transparent 50%),radial-gradient(circle at 40% 40%,rgba(255,255,0,.05) 0%,transparent 50%);pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--darker-bg)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary-neon)}@keyframes glow{0%,to{box-shadow:0 0 5px var(--primary-neon)}50%{box-shadow:0 0 20px var(--primary-neon),0 0 30px var(--primary-neon)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.glow{animation:glow 2s ease-in-out infinite alternate}.pulse{animation:pulse 2s ease-in-out infinite}.slide-in{animation:slideIn .5s ease-out}
