:root{--color-bg-primary: #ffffff;--color-bg-secondary: #f8f9fa;--color-bg-tertiary: #e9ecef;--color-bg-elevated: #ffffff;--color-text-primary: #000000;--color-text-secondary: #000000;--color-text-muted: #000000;--color-text-disabled: #adb5bd;--color-border: rgba(0, 0, 0, .12);--color-border-focus: rgba(0, 0, 0, .3);--color-lane-0: #e74c3c;--color-lane-1: #2ecc71;--color-lane-2: #3498db;--color-lane-3: #f1c40f;--color-success: #2ecc71;--color-warning: #f39c12;--color-error: #e74c3c;--color-info: #3498db;--color-perfect: #ffd700;--color-good: #90ee90;--color-miss: #666;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;--font-mono: "Courier New", Courier, monospace;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-md: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--border-width: 1px;--border-width-thick: 2px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-2xl: 0 16px 48px rgba(0, 0, 0, .18);--transition-fast: .15s ease;--transition-base: .25s ease;--transition-normal: .3s ease;--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--glow-blue: 0 0 12px rgba(52, 152, 219, .45);--glow-green: 0 0 12px rgba(46, 204, 113, .45);--glow-yellow: 0 0 12px rgba(243, 196, 18, .45);--glow-red: 0 0 12px rgba(231, 76, 60, .45);--glow-perfect: 0 0 16px rgba(255, 215, 0, .6);--glow-good: 0 0 12px rgba(144, 238, 144, .5)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-sans);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary);overflow:hidden}#root{width:100vw;height:100vh;overflow:hidden}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:1.2;margin-bottom:var(--space-sm)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}p{margin-bottom:var(--space-md)}:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}button:focus-visible,input:focus-visible,select:focus-visible{outline:2px solid var(--color-info);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-bg-elevated);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:root{--lane-width: 100px;--hud-scale: 1;--touch-target-min: 32px}@media (max-width: 768px){:root{--space-xs: .2rem;--space-sm: .4rem;--space-md: .85rem;--space-lg: 1.25rem;--space-xl: 1.65rem;--space-2xl: 2.5rem;--space-3xl: 3.25rem;--font-size-4xl: 2.25rem;--font-size-3xl: 1.75rem;--font-size-2xl: 1.35rem;--font-size-xl: 1.125rem;--lane-width: 80px;--hud-scale: .85;--touch-target-min: 36px}}@media (max-width: 480px){:root{--space-xs: .175rem;--space-sm: .35rem;--space-md: .7rem;--space-lg: 1.05rem;--space-xl: 1.4rem;--space-2xl: 2.1rem;--space-3xl: 2.8rem;--font-size-xs: .6875rem;--font-size-sm: .75rem;--font-size-md: .875rem;--font-size-lg: 1rem;--font-size-xl: 1.0625rem;--font-size-2xl: 1.125rem;--font-size-3xl: 1.375rem;--font-size-4xl: 1.75rem;--lane-width: calc((100vw - 32px)/4) ;--hud-scale: .75;--touch-target-min: 44px}button,[role=button],input[type=button],input[type=submit],input[type=reset]{min-height:var(--touch-target-min);min-width:var(--touch-target-min)}input[type=range]{min-height:var(--touch-target-min);cursor:pointer}input[type=range]::-webkit-slider-thumb{width:28px;height:28px}input[type=range]::-moz-range-thumb{width:28px;height:28px}a[role=button]{display:inline-flex;align-items:center;min-height:var(--touch-target-min)}}.mobile-hidden{display:revert}@media (max-width: 480px){.mobile-hidden{display:none!important}}.desktop-hidden{display:none!important}@media (max-width: 768px){.desktop-hidden{display:revert!important}}.tablet-hidden{display:revert}@media (max-width: 768px){.tablet-hidden{display:none!important}}.app{width:100%;height:100%;display:flex;flex-direction:column;position:relative}.btn{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);font-family:var(--font-sans);color:#000;background:var(--color-bg-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);-webkit-user-select:none;-moz-user-select:none;user-select:none;box-shadow:var(--shadow-sm)}.btn:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn:active:not(:disabled){transform:translateY(0)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-info) 0%,#2980b9 100%);border-color:var(--color-info)}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #3498db66;transform:translateY(-2px)}.btn-success{background:linear-gradient(135deg,var(--color-success) 0%,#27ae60 100%);border-color:var(--color-success)}.btn-success:hover:not(:disabled){box-shadow:0 4px 12px #2ecc7166;transform:translateY(-2px)}.menu{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:var(--space-2xl);background:linear-gradient(135deg,#f0f4ff 0%,var(--color-bg-primary) 100%);overflow-y:auto;min-height:0}.menu__header{text-align:center;margin-bottom:var(--space-3xl)}.menu__title{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);background:linear-gradient(135deg,#2c3e50 0%,var(--color-info) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-sm)}.menu__subtitle{font-size:var(--font-size-lg);color:var(--color-text-secondary)}.menu__content{width:100%;max-width:900px;flex-shrink:0}.menu__footer{margin-top:var(--space-2xl);display:flex;gap:var(--space-md);justify-content:center}.menu .btn,.menu__settings-btn{color:#000}.song-select{background:var(--color-bg-secondary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-lg)}.song-select__header{margin-bottom:var(--space-lg)}.song-select__title{font-size:var(--font-size-2xl);margin-bottom:var(--space-sm)}.song-select__description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.song-select__file-input{width:100%;padding:var(--space-lg);border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-tertiary);cursor:pointer;transition:all var(--transition-base);text-align:center}.song-select__file-input:hover{border-color:var(--color-info);background:var(--color-bg-elevated)}.song-select__file-input.dragging{border-color:var(--color-success);background:#2ecc711a}.song-select__file-label{display:block;font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--space-sm)}.song-select__file-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-success)}.song-select__songs{display:flex;flex-direction:column;gap:var(--space-sm);max-height:300px;overflow-y:auto;margin-bottom:var(--space-lg)}.song-item{padding:var(--space-md);background:var(--color-bg-tertiary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.song-item:hover{background:var(--color-bg-elevated);border-color:var(--color-info);transform:translate(4px)}.song-item.selected{border-color:var(--color-info);box-shadow:var(--glow-blue)}.song-item__name{font-size:var(--font-size-md);font-weight:var(--font-weight-medium);margin-bottom:var(--space-xs)}.song-item__details{font-size:var(--font-size-sm);color:var(--color-text-muted)}.song-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto;margin:var(--space-lg) 0;padding:var(--space-xs)}.song-list__empty{text-align:center;padding:var(--space-2xl) var(--space-lg);color:var(--color-text-muted);font-size:var(--font-size-md)}.song-list__item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border:var(--border-width) solid rgba(0,0,0,.15);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;font-size:var(--font-size-md);color:#1a1a2e;font-weight:var(--font-weight-medium)}.song-list__item:hover{filter:brightness(1.08);transform:translate(4px);box-shadow:var(--shadow-md)}.song-list__item.selected{box-shadow:0 0 0 3px #000,var(--shadow-md);transform:scale(1.02)}.song-list__entry{display:flex;flex-direction:column}.song-list__selected-actions{margin:var(--space-sm) 0 var(--space-sm) var(--space-md);padding:var(--space-sm) var(--space-md);border-left:var(--border-width) solid var(--color-border)}.song-list__icon{font-size:var(--font-size-xl);flex-shrink:0}.song-list__info{flex:1;min-width:0}.song-list__name{font-weight:var(--font-weight-medium);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.song-list__meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-top:2px}.song-list__best{font-size:var(--font-size-xs);color:var(--color-info);margin-top:2px;font-weight:var(--font-weight-medium)}.song-list__delete{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--color-text-muted);font-size:var(--font-size-md);cursor:pointer;transition:all var(--transition-fast);opacity:0}.song-list__item:hover .song-list__delete{opacity:1}.song-list__delete:hover{background:#e74c3c26;border-color:#e74c3c66;color:#e74c3c}.song-upload{position:relative;padding:var(--space-xl) var(--space-lg);border:2px dashed var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-tertiary);text-align:center;transition:all var(--transition-base);margin-bottom:var(--space-md)}.song-upload:hover{border-color:var(--color-info);background:var(--color-bg-elevated)}.song-upload--dragging{border-color:var(--color-success);background:#2ecc7114;box-shadow:inset 0 0 20px #2ecc7114}.song-upload__icon{font-size:2rem;margin-bottom:var(--space-sm)}.song-upload__text{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.song-upload__browse{background:none;border:none;color:var(--color-info);font-weight:var(--font-weight-medium);cursor:pointer;text-decoration:underline;font-size:inherit;padding:0}.song-upload__browse:hover{color:#2980b9}.song-upload__hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.song-upload__hidden-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.song-upload--compact{padding:var(--space-sm) var(--space-md);margin-bottom:var(--space-sm)}:root{--top-controls-y: 14px}.top-controls{position:absolute;top:var(--top-controls-y);left:calc(50% + 120px);transform:translate(-50%);display:flex;align-items:center;gap:18px;z-index:40}.top-right-controls{position:absolute;top:var(--top-controls-y);right:28px;display:flex;align-items:center;gap:14px;z-index:60}.beat-multiplier-large{display:inline-block;transform:translateY(6px)}.game-speed-indicator{text-align:center}.game-speed-indicator__label{font-size:11px;color:#ffffffa6}.game-speed-indicator__value{font-size:20px;font-weight:700}.combo-top-wrapper{position:absolute;top:var(--top-controls-y);left:calc(50% + 300px);transform:translateY(0);z-index:45;pointer-events:none}.combo-display{pointer-events:auto}.combo-display--centered{position:relative}.combo-display__count{font-size:36px;font-weight:800;color:var(--color-info);text-shadow:0 4px 18px rgba(0,0,0,.6);text-align:center}.combo-display__label{font-size:12px;color:#fffc;text-align:center}.song-upload--compact .song-upload__icon,.song-upload--compact .song-upload__hint{display:none}.song-tabs{display:flex;align-items:center;gap:0;margin-bottom:var(--space-lg);background:var(--color-bg-secondary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.song-tabs__tab{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-sans);color:var(--color-text-secondary);background:var(--color-bg-secondary);border:none;border-right:var(--border-width) solid var(--color-border);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.song-tabs__tab:last-child{border-right:none}.song-tabs__tab:hover{background:var(--color-bg-elevated);color:var(--color-text-primary)}.song-tabs__tab--active{background:#b3d4fc;color:#1a1a2e;font-weight:var(--font-weight-bold)}.song-tabs__brand{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-text-primary);text-align:center;background:var(--color-bg-secondary);border-right:var(--border-width) solid var(--color-border);white-space:nowrap;-webkit-user-select:none;-moz-user-select:none;user-select:none}.yt-section{background:var(--color-bg-tertiary);border:var(--border-width) solid var(--color-border);border-top:none;border-radius:0 0 var(--radius-md) var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg)}.yt-section__header{display:flex;align-items:flex-start;gap:var(--space-md);margin-bottom:var(--space-lg)}.yt-section__icon{font-size:2rem;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ff00001f;border-radius:var(--radius-md);color:#f44}.yt-section__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:4px}.yt-section__subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.yt-section__api-key{background:#3b82f614;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-md);padding:var(--space-md);margin-bottom:var(--space-lg)}.yt-section__api-key-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.yt-section__api-key-link{font-size:var(--font-size-xs);color:#60a5fa;text-decoration:none;transition:color .2s}.yt-section__api-key-link:hover{color:#3b82f6;text-decoration:underline}.yt-section__api-key-input{width:100%;padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-primary);font-family:Courier New,monospace;font-size:var(--font-size-sm);transition:border-color .2s,box-shadow .2s;margin-bottom:var(--space-xs)}.yt-section__api-key-input:focus{outline:none;border-color:#3b82f699;box-shadow:0 0 0 3px #3b82f61a}.yt-section__api-key-input:disabled{opacity:.5;cursor:not-allowed}.yt-section__api-key-info{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.yt-section__input-row{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.yt-section__input{flex:1;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-md);font-family:var(--font-sans);color:var(--color-text-primary);background:var(--color-bg-primary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--transition-fast)}.yt-section__input:focus{border-color:var(--color-info);box-shadow:0 0 0 3px #3498db26}.yt-section__input:disabled{opacity:.6;cursor:not-allowed}.yt-section__btn{flex-shrink:0;padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-md);font-weight:var(--font-weight-medium);font-family:var(--font-sans);color:#fff;background:#f44;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.yt-section__btn:hover:not(:disabled){background:#e03030;transform:translateY(-1px);box-shadow:0 4px 12px #ff444459}.yt-section__btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.yt-section__progress{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#3498db1a;border:1px solid rgba(52,152,219,.25);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-md)}.yt-section__progress-spinner{width:16px;height:16px;border:2px solid rgba(52,152,219,.3);border-top-color:var(--color-info);border-radius:50%;animation:ytSpin .8s linear infinite;flex-shrink:0}@keyframes ytSpin{to{transform:rotate(360deg)}}.yt-section__error{padding:var(--space-sm) var(--space-md);background:#e74c3c1a;border:1px solid rgba(231,76,60,.3);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:#e74c3c;margin-bottom:var(--space-md);white-space:pre-line}.yt-section__tips{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.5}.yt-section__tips strong{color:var(--color-text-secondary)}.yt-section__tips ul{margin:4px 0 0;padding-left:1.2em}.yt-section__tips li{margin-bottom:2px}.yt-results{display:flex;flex-direction:column;gap:var(--space-xs);max-height:400px;overflow-y:auto;margin-top:var(--space-sm)}.yt-results__item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--color-bg-primary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%;font-size:var(--font-size-sm);color:var(--color-text-primary);font-family:var(--font-sans)}.yt-results__item:hover:not(:disabled){background:var(--color-bg-elevated);border-color:#f44;transform:translate(4px)}.yt-results__item--active{border-color:var(--color-info);background:#3498db14}.yt-results__item:disabled{opacity:.5;cursor:not-allowed;transform:none}.yt-results__thumb{width:80px;height:45px;-o-object-fit:cover;object-fit:cover;border-radius:var(--radius-sm);flex-shrink:0;background:var(--color-bg-tertiary)}.yt-results__info{flex:1;min-width:0}.yt-results__title{font-weight:var(--font-weight-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px}.yt-results__meta{font-size:var(--font-size-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.yt-results__spinner{width:20px;height:20px;border:2px solid rgba(52,152,219,.3);border-top-color:var(--color-info);border-radius:50%;animation:ytSpin .8s linear infinite;flex-shrink:0}.difficulty-selector{margin-bottom:var(--space-lg)}.difficulty-selector__label{display:block;font-size:var(--font-size-md);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-md)}.difficulty-selector__options{display:flex;flex-direction:column;gap:var(--space-sm)}.difficulty-option{min-height:60px;padding:var(--space-md) var(--space-lg);border:var(--border-width-thick) solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);text-align:center;position:relative;z-index:1;color:#000;font-weight:var(--font-weight-bold)}.difficulty-option.easy{background:#0f0;border-color:#0c0}.difficulty-option.medium{background:orange;border-color:#e69500}.difficulty-option.hard{background:red;border-color:#c00}.difficulty-option.extreme{background:#9b30ff;border-color:#7b20cf;color:#fff}.difficulty-option.deadly{background:#8b0000;border-color:#6b0000;color:#fff}.difficulty-option:hover{transform:translateY(-2px);filter:brightness(1.1)}.difficulty-option.selected{box-shadow:0 0 0 3px #000,0 0 16px #0000004d;transform:scale(1.03)}.difficulty-option.easy.selected{box-shadow:0 0 0 3px #000,var(--glow-green)}.difficulty-option.medium.selected{box-shadow:0 0 0 3px #000,var(--glow-yellow)}.difficulty-option.hard.selected{box-shadow:0 0 0 3px #000,var(--glow-red)}.difficulty-option.extreme.selected{box-shadow:0 0 0 3px #000,0 0 16px #9b30ff80}.difficulty-option.deadly.selected{box-shadow:0 0 0 3px #000,0 0 16px #8b000080}.difficulty-option__name{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);margin-bottom:var(--space-xs)}.difficulty-option__description{font-size:var(--font-size-sm);color:var(--color-text-muted)}.difficulty-option__best{margin-top:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-info);font-weight:var(--font-weight-medium)}.wl{font-weight:600}.wl-win{color:#4ade80;margin-left:6px}.wl-loss{color:#fb7185;margin-left:4px}.game{position:relative;width:100%;height:100%;overflow:hidden;background:#0a0a0f;color:#fff}.game__canvas{position:absolute;top:0;left:0;width:100%;height:100%}.game__ui{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column}.game.video-active .game__ui{z-index:999}.game.video-active .game-over{background:#0a0a0f!important;z-index:1000}.game.video-active .game-over__stats{background:var(--color-bg-secondary)}.game.video-active .scoreboard{background:linear-gradient(180deg,#0a0a0f 0% 100%);z-index:1001}.game.video-active .game-over{color:#111}.game.video-active .game-over__title{color:#111!important;-webkit-text-fill-color:#111!important;background:none!important}.game.video-active .game-over__stat-label{color:#444!important}.game.video-active .game-over__stat-value{color:#111!important;opacity:1!important}.game.video-active .scoreboard__item,.game.video-active .scoreboard__item--accuracy{color:#fff!important}.game__ui>*{pointer-events:auto}.health-bar{position:absolute;top:0;left:0;width:100%;height:8px;background:#ffffff1f;pointer-events:none;z-index:45}.health-bar__fill{height:100%;background:#ff003c;box-shadow:0 0 18px #ff003cf2,0 0 30px #ff003cbf;transition:width .12s linear}.pause-menu-actions{position:absolute;top:calc(50% + 70px);left:50%;transform:translate(-50%);z-index:55;display:flex;flex-direction:column;gap:var(--space-md);align-items:center}.pause-menu-return{color:#fff;font-size:24px;font-weight:700;font-family:Arial,sans-serif;cursor:pointer;text-align:center;-webkit-user-select:none;-moz-user-select:none;user-select:none}.game-volume-controls{position:absolute;right:var(--space-lg);bottom:var(--space-lg);width:min(320px,38vw);background:#0a0a0fc7;border:var(--border-width) solid rgba(255,255,255,.14);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);backdrop-filter:blur(6px);box-shadow:var(--shadow-lg);z-index:40}.game-volume-controls__row{display:grid;grid-template-columns:1fr;gap:4px;margin-bottom:var(--space-sm)}.game-volume-controls__row:last-child{margin-bottom:0}.game-volume-controls__label{font-size:var(--font-size-xs);color:#fff;font-weight:var(--font-weight-semibold)}.game-volume-controls__slider{width:100%;accent-color:var(--color-info)}.game-volume-controls__select{width:100%;background:#ffffffe6;border:var(--border-width) solid rgba(255,255,255,.4);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--font-size-xs);color:var(--color-text-primary)}.scoreboard{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-lg);background:linear-gradient(180deg,rgba(10,10,15,.9) 0%,transparent 100%);pointer-events:none}.scoreboard__left,.scoreboard__right{display:flex;flex-direction:column;gap:var(--space-sm)}.scoreboard__item{font-family:var(--font-mono);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);text-shadow:0 2px 8px rgba(0,0,0,.8)}.scoreboard__item--score{font-size:var(--font-size-3xl);color:var(--color-perfect);text-shadow:var(--glow-perfect)}.scoreboard__item--combo{font-size:var(--font-size-2xl);color:var(--color-info)}.scoreboard__item--multiplier{font-size:var(--font-size-xl);color:var(--color-warning);transition:all .3s ease}.scoreboard__item--multiplier.max-multiplier{font-size:var(--font-size-2xl);color:var(--color-perfect);text-shadow:var(--glow-perfect);animation:pulse-max 1.5s ease-in-out infinite}@keyframes pulse-max{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.9}}.scoreboard__item--accuracy{font-size:2rem;color:#fff}.combo-display{position:absolute;top:var(--space-xl);right:18%;pointer-events:none;text-align:center}.combo-display--inline{position:relative;top:auto;right:auto;pointer-events:none;text-align:center}.combo-display.combo-display--centered{position:absolute;top:calc(50% - 220px);left:calc(50% + 220px);transform:translate(-50%);pointer-events:none;text-align:center;z-index:70}.combo-display__count{font-family:var(--font-mono);font-size:3.5rem;font-weight:var(--font-weight-bold);color:var(--color-perfect);text-shadow:var(--glow-perfect);animation:comboPulse .3s var(--ease-out-expo);line-height:1}.combo-display__label{font-size:var(--font-size-xl);color:#fff;text-transform:uppercase;letter-spacing:.2em;margin-top:var(--space-sm)}.game-speed-indicator{pointer-events:none;text-align:center;z-index:60}.top-controls{position:absolute;top:var(--space-xl);right:calc(var(--space-lg) - .8rem);display:flex;align-items:center;gap:2rem;pointer-events:none}.game-speed-indicator{margin-left:.6rem}.beat-multiplier-large{font-family:var(--font-mono);font-size:3.6rem;font-weight:var(--font-weight-bold);color:var(--color-warning);text-shadow:0 4px 18px rgba(255,255,255,.06)}.game-speed-indicator__label{font-size:.8rem;color:#ffffffd9;text-transform:uppercase;letter-spacing:.08em}.game-speed-indicator__value{font-family:var(--font-mono);font-size:2.6rem;font-weight:var(--font-weight-bold);color:#fff;text-shadow:0 4px 18px rgba(255,255,255,.08)}@keyframes comboPulse{0%{transform:scale(1.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.progress-bar{position:absolute;bottom:0;left:0;width:100%;height:4px;background:#ffffff1a;pointer-events:none}.progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--color-info) 0%,var(--color-success) 100%);box-shadow:0 0 12px var(--color-info);transition:width .1s linear}.hit-feedback{position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.map-leaderboard{position:absolute;left:8px;top:50%;transform:translateY(-50%);width:clamp(200px,22vw,280px);background:#0a0a0fc7;border:var(--border-width) solid rgba(255,255,255,.14);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);box-shadow:var(--shadow-lg);backdrop-filter:blur(6px);z-index:40}.map-leaderboard__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:#fff;margin-bottom:var(--space-sm)}.map-leaderboard__empty{font-size:var(--font-size-sm);color:#fff;opacity:.7}.map-leaderboard__list{display:grid;gap:6px}.map-leaderboard__row{display:grid;grid-template-columns:42px 1fr auto;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:var(--font-size-sm)}.map-leaderboard__rank{color:var(--color-warning);font-weight:var(--font-weight-semibold)}.map-leaderboard__score{color:var(--color-perfect);font-weight:var(--font-weight-semibold)}.map-leaderboard__acc{color:var(--color-text-primary);opacity:.9}.hit-feedback__text{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);text-transform:uppercase;animation:hitFeedbackAnim .6s var(--ease-out-expo) forwards;display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.hit-feedback__judgment{font-size:var(--font-size-3xl)}.hit-feedback__points{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);opacity:.95}.hit-feedback__multiplier{font-size:var(--font-size-lg);opacity:.85;margin-left:var(--space-xs)}.hit-feedback__text.perfect{color:var(--color-perfect);text-shadow:var(--glow-perfect)}.hit-feedback__text.good{color:var(--color-good);text-shadow:var(--glow-good)}.hit-feedback__text.miss{color:var(--color-miss)}@keyframes hitFeedbackAnim{0%{transform:scale(1.8) translateY(0);opacity:1}to{transform:scale(1) translateY(-50px);opacity:0}}.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg)}.loading__spinner{width:48px;height:48px;border:4px solid var(--color-border);border-top-color:var(--color-info);border-radius:var(--radius-full);animation:spin .8s linear infinite}.loading__text{font-size:var(--font-size-lg);color:var(--color-text-secondary)}.loading__progress{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-success);text-shadow:0 0 20px rgba(46,204,113,.6);margin-top:var(--space-md)}.game-over{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0a0a0ff2;backdrop-filter:blur(8px);animation:fadeIn .4s var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.game-over__title{font-size:var(--font-size-4xl);margin-bottom:var(--space-xl);background:linear-gradient(135deg,var(--color-perfect) 0%,var(--color-warning) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes creditsCoinDrop{0%{opacity:0;transform:translateY(-80px)}60%{opacity:1;transform:translateY(0)}75%{transform:translateY(-12px)}90%{transform:translateY(0)}to{opacity:1;transform:translateY(0)}}.credits-earned-display{min-height:96px;margin-bottom:var(--space-md);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-xs)}.credits-earned-display__coin{font-size:var(--font-size-3xl);line-height:1;animation:creditsCoinDrop .52s cubic-bezier(.2,1.15,.3,1);will-change:transform}.credits-earned-display__value{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);border:1px solid rgba(255,215,0,.5);background:#ffd70029;color:var(--color-warning);font-weight:var(--font-weight-bold);letter-spacing:.02em}.credits-earned-display--none{min-height:40px;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);border:var(--border-width) solid var(--color-border);background:var(--color-bg-secondary);color:var(--color-text-secondary);font-weight:var(--font-weight-semibold)}@keyframes creditsBannerIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.credits-earned-banner{margin-bottom:var(--space-md);padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-full);border:1px solid rgba(255,215,0,.5);background:#ffd70029;color:var(--color-warning);font-weight:var(--font-weight-bold);letter-spacing:.02em;animation:creditsBannerIn .28s ease-out}.credits-earned-banner--zero{border-color:#ef444473;background:#ef444426;color:#fecaca}.game-over__stats{background:var(--color-bg-secondary);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-xl);margin-bottom:var(--space-2xl);min-width:400px}.game-over__stat{display:flex;justify-content:space-between;padding:var(--space-md) 0;border-bottom:var(--border-width) solid var(--color-border);font-size:var(--font-size-lg)}.game-over__stat:last-child{border-bottom:none}.game-over__stat-label{color:var(--color-text-secondary)}.game-over__stat-value{font-family:var(--font-mono);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.game-over__actions{display:flex;gap:var(--space-md)}.game-over__actions .btn,.mp-results__actions .btn{color:#000}.rank-display{display:flex;flex-direction:column;align-items:center;margin-bottom:var(--space-xl);position:relative}.rank-display--entering{animation:rankEnter .6s cubic-bezier(.34,1.56,.64,1) forwards}.rank-display--visible{opacity:1;transform:scale(1)}@keyframes rankEnter{0%{opacity:0;transform:scale(3);filter:blur(10px)}60%{opacity:1;transform:scale(.9);filter:blur(0)}80%{transform:scale(1.05)}to{opacity:1;transform:scale(1);filter:blur(0)}}.rank-display__letter{font-size:7rem;font-weight:900;font-family:var(--font-mono);line-height:1;letter-spacing:-2px;text-shadow:0 2px 20px rgba(0,0,0,.5);position:relative;z-index:2}.rank-display__label{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:4px;margin-top:var(--space-sm);opacity:0;animation:labelFade .4s ease-out .8s forwards}@keyframes labelFade{0%{opacity:0;transform:translateY(10px)}to{opacity:.9;transform:translateY(0)}}.rank-display--special .rank-display__letter{animation:rankEnter .6s cubic-bezier(.34,1.56,.64,1) forwards,sssShimmer 2s ease-in-out .8s infinite}@keyframes sssShimmer{0%,to{filter:brightness(1) drop-shadow(0 0 8px rgba(255,215,0,.6))}50%{filter:brightness(1.3) drop-shadow(0 0 25px rgba(255,215,0,.9))}}.rank-display__glow{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,rgba(255,215,0,.3) 0%,rgba(255,170,0,.15) 40%,transparent 70%);animation:glowPulse 2s ease-in-out infinite;pointer-events:none;z-index:1}@keyframes glowPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.6}50%{transform:translate(-50%,-50%) scale(1.4);opacity:1}}.rank-display__particles{position:absolute;top:50%;left:50%;width:0;height:0;pointer-events:none;z-index:3}.rank-particle{position:absolute;width:6px;height:6px;border-radius:50%;background:gold;animation:particleBurst 1.5s ease-out var(--delay) forwards,particleGlow .8s ease-in-out var(--delay) infinite alternate;opacity:0}@keyframes particleBurst{0%{opacity:1;transform:rotate(var(--angle)) translate(0)}60%{opacity:1}to{opacity:0;transform:rotate(var(--angle)) translate(var(--distance))}}@keyframes particleGlow{0%{box-shadow:0 0 4px #ffd700cc;background:gold}to{box-shadow:0 0 8px #ffffb4;background:#fffacd}}.settings-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn var(--transition-normal) ease-out}.settings-panel{background:var(--color-bg-elevated);border:var(--border-width) solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);min-width:500px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-2xl),var(--glow-blue);animation:slideUp var(--transition-normal) ease-out}.settings-panel--light{background:#fff;border-color:#cbd5e1;color:#0f172a;box-shadow:var(--shadow-2xl)}.settings-panel--light .settings__title,.settings-panel--light .settings__section-title,.settings-panel--light .settings__audio-label,.settings-panel--light .settings__audio-toggle-label,.settings-panel--light .settings__fps-label,.settings-panel--light .settings__close{color:#0f172a}.settings-panel--light .settings__section-desc,.settings-panel--light .settings__audio-value,.settings-panel--light .settings__fps-desc,.settings-panel--light .settings__info{color:#334155}.settings-panel--light .settings__audio-select,.settings-panel--light .settings__audio-slider,.settings-panel--light .settings__fps-option,.settings-panel--light .settings__reset-btn,.settings-panel--light .keybind-button{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2xl);padding-bottom:var(--space-lg);border-bottom:var(--border-width) solid var(--color-border)}.settings__title{font-size:var(--font-size-3xl);color:var(--color-text-primary);margin:0}.settings__close{background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-3xl);line-height:1;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.settings__close:hover{color:var(--color-text-primary);background:var(--color-bg-secondary)}.settings__section{margin-bottom:var(--space-2xl)}.settings__section-title{font-size:var(--font-size-xl);color:var(--color-text-primary);margin:0 0 var(--space-sm) 0}.settings__section-desc{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin:0 0 var(--space-lg) 0;line-height:1.6}.settings__audio-controls{display:grid;gap:var(--space-md)}.settings__audio-row{display:grid;grid-template-columns:180px 1fr 56px;align-items:center;gap:var(--space-md)}.settings__audio-label{color:var(--color-text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.settings__audio-slider{width:100%;accent-color:var(--color-info)}.settings__audio-select{width:100%;border:var(--border-width) solid var(--color-border);border-radius:var(--radius-sm);padding:8px 10px;background:var(--color-bg-primary);color:var(--color-text-primary);font-size:var(--font-size-sm)}.settings__audio-toggle-label{display:inline-flex;align-items:center;gap:var(--space-sm);color:var(--color-text-primary);font-size:var(--font-size-sm)}.settings__audio-checkbox{accent-color:var(--color-info)}.settings__audio-value{text-align:right;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-family:var(--font-mono)}.settings__fps-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md)}.settings__fps-option{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-fast);text-align:center}.settings__fps-option:hover{border-color:var(--color-border-focus);background:var(--color-bg-tertiary);transform:translateY(-2px)}.settings__fps-option.active{border-color:var(--color-info);background:var(--color-bg-tertiary);box-shadow:var(--glow-blue)}.settings__fps-label{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-xs)}.settings__fps-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.settings__info{background:var(--color-bg-secondary);border-left:3px solid var(--color-info);padding:var(--space-md);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:1.6}.settings__info strong{color:var(--color-info)}.settings__keybinds{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-lg)}.keybind-item{display:flex;flex-direction:column;gap:var(--space-sm);align-items:center}.keybind-item__label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.keybind-item__button{width:100%;padding:var(--space-lg) var(--space-md);background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);font-family:var(--font-mono);color:var(--color-text-primary);cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase}.keybind-item__button:hover:not(:disabled){border-color:var(--color-border-focus);background:var(--color-bg-tertiary);transform:translateY(-2px)}.keybind-item__button.editing{border-color:var(--color-warning);background:var(--color-bg-tertiary);box-shadow:var(--glow-yellow);cursor:wait;animation:pulse 1s ease-in-out infinite}.settings__reset-btn{padding:var(--space-sm) var(--space-lg);background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.settings__reset-btn:hover{border-color:var(--color-warning);color:var(--color-warning);background:var(--color-bg-tertiary)}.slava-flag-particle{position:absolute;width:80px;height:auto;pointer-events:none;z-index:100;animation:flagFloat .8s ease-out forwards}@keyframes flagFloat{0%{opacity:1;transform:translateY(0) scale(1) rotate(0)}50%{opacity:1;transform:translateY(-40px) scale(1.1) rotate(10deg)}to{opacity:0;transform:translateY(-100px) scale(.6) rotate(-15deg)}}.slava-miss-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:200;animation:missFlash .3s ease-out forwards}.slava-miss-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.4}@keyframes missFlash{0%{opacity:1}70%{opacity:1}to{opacity:0}}.slava-spam-particle{position:absolute;width:100px;height:auto;pointer-events:none;z-index:150;opacity:.75;filter:drop-shadow(0 4px 8px rgba(0,0,0,.35));will-change:transform;transition:left .08s steps(1,end),top .08s steps(1,end);animation-iteration-count:infinite;animation-timing-function:cubic-bezier(.2,.8,.2,1.2)}.slava-spam-motion-1{animation-name:slavaSpamJump1}.slava-spam-motion-2{animation-name:slavaSpamJump2}.slava-spam-motion-3{animation-name:slavaSpamJump3}.slava-spam-motion-4{animation-name:slavaSpamJump4}@keyframes slavaSpamJump1{0%{transform:translate(0) rotate(0) scale(1)}15%{transform:translate(34px,-36px) rotate(18deg) scale(1.15)}35%{transform:translate(-32px,20px) rotate(-14deg) scale(.92)}60%{transform:translate(28px,-40px) rotate(22deg) scale(1.18)}80%{transform:translate(-24px,22px) rotate(-16deg) scale(.9)}to{transform:translate(0) rotate(0) scale(1)}}@keyframes slavaSpamJump2{0%{transform:translate(0) rotate(0) scale(1)}25%{transform:translate(-38px,-26px) rotate(-20deg) scale(1.16)}50%{transform:translate(34px,20px) rotate(14deg) scale(.88)}75%{transform:translate(-22px,-36px) rotate(-24deg) scale(1.1)}to{transform:translate(0) rotate(0) scale(1)}}@keyframes slavaSpamJump3{0%{transform:translate(0) rotate(0) scale(1)}20%{transform:translate(20px,-44px) rotate(12deg) scale(1.2)}45%{transform:translate(-40px,14px) rotate(-15deg) scale(.9)}70%{transform:translate(38px,-18px) rotate(20deg) scale(1.08)}to{transform:translate(0) rotate(0) scale(1)}}@keyframes slavaSpamJump4{0%{transform:translate(0) rotate(0) scale(1)}22%{transform:translate(-28px,-34px) rotate(-14deg) scale(1.14)}48%{transform:translate(42px,16px) rotate(17deg) scale(.9)}74%{transform:translate(-32px,-22px) rotate(-20deg) scale(1.1)}to{transform:translate(0) rotate(0) scale(1)}}@keyframes spamBurst{0%{opacity:1;transform:scale(.3) rotate(0)}30%{opacity:1;transform:scale(1.3) rotate(15deg)}60%{opacity:.8;transform:scale(1) rotate(-5deg)}to{opacity:0;transform:scale(.5) rotate(20deg) translateY(-60px)}}.slava-omega-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:130}.slava-omega-video{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.28}.slava-yakub-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:125}.slava-yakub-image{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;opacity:.26}.mp-lobby{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-xl);max-width:420px;margin:0 auto}.mp-lobby__title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.mp-lobby__error{background:#ef444426;border:1px solid rgba(239,68,68,.4);color:var(--color-miss);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);text-align:center;width:100%}.mp-lobby__choices{display:flex;flex-direction:column;gap:var(--space-md);width:100%}.mp-lobby__btn{width:100%;font-size:var(--font-size-lg);padding:var(--space-md) var(--space-lg)}.mp-lobby__btn--back{margin-top:var(--space-sm);opacity:.7}.mp-lobby__join{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.mp-lobby__hint{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.mp-lobby__input{width:220px;text-align:center;font-size:var(--font-size-2xl);font-family:var(--font-mono);letter-spacing:.2em;padding:var(--space-md);background:#ffffff14;border:2px solid rgba(255,255,255,.2);border-radius:var(--radius-md);color:var(--color-text-primary);text-transform:uppercase}.mp-lobby__input:focus{outline:none;border-color:var(--color-info);box-shadow:0 0 12px #3b82f64d}.mp-lobby__join-actions{display:flex;gap:var(--space-md)}.mp-lobby__connecting{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);color:var(--color-text-secondary)}.mp-waiting{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-xl);max-width:480px;margin:0 auto}.mp-waiting__title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.mp-waiting__code-box{display:flex;align-items:center;gap:var(--space-md);background:#ffffff0f;border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);padding:var(--space-md) var(--space-lg)}.mp-waiting__code-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.mp-waiting__code{font-family:var(--font-mono);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);letter-spacing:.15em;color:var(--color-perfect);text-shadow:var(--glow-perfect)}.mp-waiting__copy{font-size:var(--font-size-sm)!important;padding:var(--space-xs) var(--space-md)!important}.mp-waiting__status{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.mp-waiting__dot{width:10px;height:10px;border-radius:50%;background:var(--color-miss);transition:background .3s ease}.mp-waiting__dot--on{background:var(--color-success);box-shadow:0 0 8px var(--color-success)}.mp-waiting__song-pick{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.mp-waiting__file{width:100%}.mp-waiting__file-name{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-info);word-break:break-all}.mp-waiting__diff-row{display:flex;gap:var(--space-sm)}.mp-waiting__diff-btn{font-size:var(--font-size-sm)!important;padding:var(--space-xs) var(--space-md)!important}.mp-waiting__status-msg{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);color:var(--color-text-secondary)}.mp-waiting__ready{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.mp-waiting__ready-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-success)}.mp-waiting__start-btn{font-size:var(--font-size-lg)!important;padding:var(--space-md) var(--space-xl)!important}.mp-waiting__leave{margin-top:var(--space-md);opacity:.6}.mp-hud{position:absolute;right:var(--space-lg);top:50%;transform:translateY(-50%);width:min(200px,24vw);background:#0a0a0fc7;border:var(--border-width) solid rgba(255,255,255,.14);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);backdrop-filter:blur(6px);box-shadow:var(--shadow-lg);z-index:40;text-align:center}.mp-hud__title{font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-xs)}.mp-hud__opp-score{font-family:var(--font-mono);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-warning)}.mp-hud__opp-combo{font-family:var(--font-mono);font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.mp-hud__diff{font-family:var(--font-mono);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold)}.mp-hud__diff--ahead{color:var(--color-success)}.mp-hud__diff--behind{color:var(--color-miss)}.mp-results{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);background:#000000d9;z-index:60}.mp-results__verdict{font-size:clamp(2rem,6vw,4rem);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.08em}.mp-results__verdict--win{color:var(--color-perfect);text-shadow:var(--glow-perfect)}.mp-results__verdict--lose{color:var(--color-miss)}.mp-results__verdict--tie{color:var(--color-info);text-shadow:0 0 20px var(--color-info)}.mp-results__cards{display:flex;gap:var(--space-lg);flex-wrap:wrap;justify-content:center}.mp-results__card{background:#ffffff0f;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-lg);padding:var(--space-lg);min-width:220px;text-align:center}.mp-results__card--winner{border-color:var(--color-perfect);box-shadow:0 0 16px #ffd70033}.mp-results__card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-sm)}.mp-results__card-score{font-family:var(--font-mono);font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--color-perfect);margin-bottom:var(--space-sm)}.mp-results__card-stat{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:4px}.mp-results__card-waiting{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);padding:var(--space-lg);color:var(--color-text-secondary)}.mp-results__actions{display:flex;gap:var(--space-md);margin-top:var(--space-md)}.mp-menu-btn{margin-right:var(--space-sm)}.mp-lobby__btn,.mp-lobby__btn--back,.mp-menu-btn,.mp-waiting__copy,.mp-waiting__leave{color:#000!important}.builder-overlay{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;background:#000000e0;backdrop-filter:blur(12px)}.builder-upload-panel{position:relative;width:90%;max-width:480px;background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(56,189,248,.15);border-radius:20px;padding:44px 40px;text-align:center;box-shadow:0 20px 60px #00000080,0 0 40px #38bdf80d}.builder-close-btn{position:absolute;top:14px;right:16px;background:none;border:none;color:#94a3b8;font-size:20px;cursor:pointer;transition:color .15s,transform .15s}.builder-close-btn:hover{color:#fff;transform:scale(1.1)}.builder-title{font-size:28px;font-weight:900;color:#fff;margin:0 0 6px;letter-spacing:-.02em}.builder-subtitle{color:#94a3b8;font-size:14px;margin:0 0 28px}.builder-upload-area{margin:0 0 24px}.builder-upload-label{display:flex;flex-direction:column;align-items:center;gap:10px;padding:36px 20px;border:2px dashed #475569;border-radius:14px;cursor:pointer;color:#cbd5e1;transition:all .25s ease;font-size:15px;font-weight:600;background:#0f172a66}.builder-upload-label:hover{border-color:#38bdf8;background:#38bdf814;color:#fff;transform:translateY(-2px);box-shadow:0 8px 24px #38bdf81a}.builder-upload-icon{font-size:40px}.builder-divider{height:1px;background:linear-gradient(90deg,transparent,#334155,transparent);margin:0 0 20px}.builder-drafts-btn{display:inline-block;padding:12px 28px;border:1px solid #475569;border-radius:10px;background:#0f172a80;color:#94a3b8;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.builder-drafts-btn:hover{border-color:#38bdf8;color:#fff;background:#38bdf814}.builder-drafts-list{display:flex;flex-direction:column;gap:10px;margin-top:16px;max-height:400px;overflow-y:auto}.builder-draft-card{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:#0f172a99;border:1px solid #334155;border-radius:12px;transition:border-color .2s,background .2s}.builder-draft-card:hover{border-color:#475569;background:#0f172acc}.builder-draft-info{display:flex;flex-direction:column;gap:3px;text-align:left}.builder-draft-name{color:#fff;font-weight:700;font-size:14px}.builder-draft-meta{color:#64748b;font-size:11px}.builder-draft-actions{display:flex;gap:6px}.builder-btn-sm{padding:5px 14px;font-size:11px;font-weight:700;border-radius:6px;border:1px solid transparent;cursor:pointer;transition:all .15s}.builder-btn-primary{background:#3b82f6;color:#fff;border-color:#3b82f6}.builder-btn-primary:hover{background:#2563eb;transform:translateY(-1px)}.builder-btn-danger{background:#ef4444;color:#fff;border-color:#ef4444}.builder-btn-danger:hover{background:#dc2626}.builder-editor{position:fixed;inset:0;z-index:100;display:flex;flex-direction:column;background:#080b14;color:#e2e8f0;overflow:hidden}.builder-toolbar{display:flex;align-items:center;gap:6px;padding:6px 12px;background:linear-gradient(180deg,#1a1a2e,#151525);border-bottom:1px solid rgba(56,189,248,.1);flex-wrap:wrap;min-height:44px}.builder-toolbar-section{display:flex;align-items:center;gap:5px;padding:2px 6px;border-radius:6px}.builder-toolbar-section+.builder-toolbar-section{border-left:1px solid rgba(148,163,184,.15);padding-left:10px}.builder-toolbar-divider{width:1px;height:20px;background:#94a3b833;margin:0 2px}.builder-toolbar-btn{padding:5px 10px;background:#33415599;border:1px solid rgba(71,85,105,.6);border-radius:6px;color:#cbd5e1;font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;line-height:1.2}.builder-toolbar-btn:hover:not(:disabled){background:#475569cc;border-color:#94a3b8;color:#fff}.builder-toolbar-btn:disabled{opacity:.35;cursor:not-allowed}.builder-toolbar-btn--active{background:#3b82f6!important;border-color:#60a5fa!important;color:#fff!important;box-shadow:0 0 8px #3b82f64d}.builder-transport-btn{font-size:16px;padding:4px 10px;min-width:36px;text-align:center}.builder-transport-btn--playing{background:#f43f5e33!important;border-color:#f43f5e!important;color:#f43f5e!important}.builder-tap-mode-btn{background:#7c3aed!important;border-color:#a78bfa!important;animation:builder-pulse 1.5s ease-in-out infinite}@keyframes builder-pulse{0%,to{box-shadow:0 0 4px #7c3aed4d}50%{box-shadow:0 0 12px #7c3aed99}}.builder-bpm-tap-btn{background:#eab30826!important;border-color:#eab30866!important;color:#eab308!important}.builder-bpm-tap-btn:hover{background:#eab30840!important}.builder-bpm-apply-btn{background:#22c55e26!important;border-color:#22c55e66!important;color:#22c55e!important;font-weight:800;font-size:11px}.builder-btn-danger-sm{background:#ef444433!important;border-color:#ef444466!important;color:#ef4444!important}.builder-btn-danger-sm:hover{background:#ef444459!important}.builder-btn-save{background:#0d9488cc!important;border-color:#0d9488!important;color:#fff!important}.builder-btn-save:hover{background:#0f766e!important}.builder-btn-finish{background:#22c55e!important;border-color:#22c55e!important;color:#000!important;font-weight:800}.builder-btn-finish:hover{background:#16a34a!important}.builder-btn-share{background:#7c3aedb3!important;border-color:#7c3aed!important;color:#fff!important}.builder-btn-share:hover{background:#7c3aed!important}.builder-autosave-indicator{font-size:11px;color:#64748b;min-width:70px;text-align:right;transition:color .3s}.builder-song-name-input{padding:4px 10px;background:#0f172a99;border:1px solid #475569;border-radius:6px;color:#fff;font-size:13px;font-weight:700;width:160px;outline:none;transition:border-color .2s,box-shadow .2s}.builder-song-name-input:focus{border-color:#38bdf8;box-shadow:0 0 0 2px #38bdf826}.builder-toolbar-right{margin-left:auto}.builder-toolbar-label{display:flex;align-items:center;gap:4px;color:#94a3b8;font-size:11px;font-weight:600;white-space:nowrap}.builder-toolbar-input{width:48px;padding:2px 4px;background:#0f172a99;border:1px solid #475569;border-radius:4px;color:#fff;font-size:11px;text-align:center;outline:none}.builder-toolbar-input:focus{border-color:#38bdf8}.builder-toolbar-select{padding:2px 4px;background:#0f172a99;border:1px solid #475569;border-radius:4px;color:#fff;font-size:11px;outline:none}.builder-toolbar-range{width:60px;accent-color:#38bdf8}.builder-time-display{font-family:JetBrains Mono,Fira Code,monospace;font-size:13px;color:#38bdf8;min-width:100px;font-weight:600;letter-spacing:-.02em}.builder-tap-banner{display:flex;align-items:center;gap:10px;padding:6px 16px;background:linear-gradient(90deg,#7c3aed33,#7c3aed14);border-bottom:1px solid rgba(124,58,237,.3);font-size:13px;color:#c4b5fd;font-weight:600}.builder-tap-banner-pulse{width:8px;height:8px;border-radius:50%;background:#a78bfa;animation:builder-tap-pulse 1s ease-in-out infinite}@keyframes builder-tap-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.builder-minimap-container{position:relative;height:32px;background:#0c1021;border-bottom:1px solid rgba(56,189,248,.1);cursor:pointer;overflow:hidden}.builder-minimap-canvas{display:block;width:100%;height:32px}.builder-minimap-stats{position:absolute;top:50%;right:12px;transform:translateY(-50%);display:flex;gap:12px;font-size:10px;font-weight:700;color:#94a3b899;text-transform:uppercase;letter-spacing:.05em;pointer-events:none}.builder-waveform-container{position:relative;height:80px;background:#0f172a;border-bottom:1px solid rgba(56,189,248,.1);overflow:hidden;cursor:pointer}.builder-waveform-canvas{display:block;width:100%;height:80px}.builder-playhead{position:absolute;top:0;width:2px;height:100%;background:#f43f5e;pointer-events:none;z-index:2;box-shadow:0 0 6px #f43f5e80}.builder-lanes-wrapper{display:flex;flex:1;min-height:420px;overflow:hidden}.builder-lane-labels{display:flex;flex-direction:column;width:56px;height:100%;flex-shrink:0;background:linear-gradient(180deg,#1a1a2e,#151525);border-right:1px solid rgba(56,189,248,.1)}.builder-lane-label{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-weight:900;font-size:20px;color:#e2e8f0;border-left:3px solid;transition:background .15s}.builder-lane-label:hover{background:#ffffff08}.builder-lane-letter{line-height:1}.builder-lane-tap-hint{font-size:8px;font-weight:700;text-transform:uppercase;color:#a78bfa;opacity:.7;letter-spacing:.05em}.builder-timeline{flex:1;position:relative;overflow-x:auto;overflow-y:hidden;height:100%;cursor:crosshair}.builder-timeline-inner{position:relative;height:100%}.builder-lane-bg{position:absolute;left:0;right:0}.builder-grid-line{position:absolute;top:0;width:1px;height:100%;pointer-events:none}.builder-grid-line--measure{width:1.5px}.builder-grid-label{position:absolute;top:2px;font-size:9px;pointer-events:none;font-family:JetBrains Mono,monospace;display:flex;flex-direction:column;gap:0}.builder-grid-measure-num{color:#94a3b8;font-weight:700;font-size:10px}.builder-grid-time{color:#475569;font-size:8px}.builder-grid-beat-label{position:absolute;top:3px;font-size:8px;color:#334155;pointer-events:none;font-family:JetBrains Mono,monospace}.builder-lane-divider{position:absolute;left:0;right:0;height:1px;background:#94a3b826;pointer-events:none}.builder-note{position:absolute;border-radius:5px;cursor:pointer;transition:box-shadow .1s,transform .1s;z-index:5;box-shadow:0 1px 4px #00000080,inset 0 1px #ffffff26}.builder-note:hover{box-shadow:0 0 12px #ffffff59,inset 0 1px #fff3;transform:scaleY(1.05)}.builder-note--selected{box-shadow:0 0 0 2px #fff,0 0 16px #38bdf899!important;z-index:6}.builder-ghost-note{position:absolute;border-radius:5px;z-index:3;opacity:.3;pointer-events:none;border:2px dashed rgba(255,255,255,.4);animation:builder-ghost-fade .8s ease-in-out infinite}@keyframes builder-ghost-fade{0%,to{opacity:.25}50%{opacity:.4}}.builder-note-hold{position:absolute;border-radius:4px;border:1px solid;z-index:4;background-image:repeating-linear-gradient(90deg,transparent,transparent 4px,rgba(255,255,255,.05) 4px,rgba(255,255,255,.05) 8px)}.builder-note-hold-handle{position:absolute;right:-5px;top:-2px;width:10px;height:calc(100% + 4px);border-radius:4px;background:#ffffffd9;border:1px solid rgba(15,23,42,.7);cursor:ew-resize;transition:background .15s}.builder-note-hold-handle:hover{background:#fff;box-shadow:0 0 6px #ffffff80}.builder-timeline-playhead{position:absolute;top:0;width:2px;height:100%;background:#f43f5e;pointer-events:none;z-index:10;box-shadow:0 0 8px #f43f5e80}.builder-timeline-playhead:before{content:"";position:absolute;top:0;left:-4px;width:10px;height:10px;background:#f43f5e;border-radius:50%;box-shadow:0 0 6px #f43f5e99}.builder-info-bar{display:flex;align-items:center;gap:12px;padding:5px 16px;background:linear-gradient(180deg,#151525,#1a1a2e);border-top:1px solid rgba(56,189,248,.1);font-size:11px;color:#475569;flex-wrap:nowrap;overflow-x:auto;min-height:32px}.builder-info-stats{display:flex;gap:8px;flex-shrink:0}.builder-stat{padding:2px 8px;background:#38bdf80f;border-radius:4px;color:#64748b;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.03em}.builder-info-hints{display:flex;gap:6px;color:#334155;font-size:10px}.builder-info-hints span{white-space:nowrap}.builder-info-hints span:after{content:"·";margin-left:6px;color:#1e293b}.builder-info-hints span:last-child:after{content:""}.builder-info-selection{display:flex;align-items:center;gap:6px;margin-left:auto;flex-shrink:0}.builder-modal-backdrop{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:#000000b3;backdrop-filter:blur(4px)}.builder-modal{background:linear-gradient(135deg,#1a1a2e,#16213e);border:1px solid rgba(56,189,248,.15);border-radius:16px;padding:24px 28px;max-width:520px;width:90%;box-shadow:0 16px 48px #00000080,0 0 40px #38bdf80d}.builder-modal-btn{padding:8px 20px;background:#33415599;color:#e2e8f0;border:1px solid #475569;border-radius:8px;cursor:pointer;font-weight:600;font-size:14px;transition:all .15s}.builder-modal-btn:hover{background:#475569}.builder-modal-btn--primary{background:#3b82f6!important;border-color:#3b82f6!important;color:#fff!important}.builder-modal-btn--primary:hover{background:#2563eb!important}.builder-shortcuts-modal{max-width:560px;max-height:80vh;overflow-y:auto}.builder-shortcuts-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px 16px}.builder-shortcut-row{display:flex;align-items:center;justify-content:space-between;padding:5px 8px;border-radius:6px;transition:background .1s}.builder-shortcut-row:hover{background:#38bdf80d}.builder-shortcut-keys{display:flex;align-items:center;gap:3px;flex-shrink:0}.builder-shortcut-sep{color:#475569;font-size:11px;margin:0 1px}.builder-kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:2px 6px;background:#0f172a99;border:1px solid #334155;border-radius:4px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700;color:#e2e8f0;box-shadow:0 1px 2px #0000004d}.builder-shortcut-desc{font-size:12px;color:#94a3b8;text-align:right}.builder-test-modal-backdrop{position:absolute;inset:0;z-index:120;background:#020617b8;display:flex;align-items:center;justify-content:center}.builder-test-modal{width:min(320px,90%);background:#0f172a;border:1px solid #334155;border-radius:12px;padding:20px;text-align:center;color:#e2e8f0}.builder-test-modal h3{margin:0 0 8px;font-size:18px;font-weight:800}.builder-test-modal p{margin:0 0 16px;color:#94a3b8;font-size:14px}.built-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:#3b82f6;border-radius:6px;line-height:1.4}.demo-badge{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:#fff;background:#10b981;border-radius:6px;line-height:1.4;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}.menu-root--light{background:#f8fafc!important}.menu-root--light,.menu-root--light *{color:#000!important}.menu-root--light .song-card,.menu-root--light .song-list,.menu-root--light [class*=bg-game-panel]{background-color:#fff!important}.menu-root--light a{color:#1d4ed8!important}.touch-lane-overlay{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:95vw;height:20%;display:none;grid-template-columns:repeat(4,1fr);z-index:70;pointer-events:auto;touch-action:none}@media (max-width: 768px){.touch-lane-overlay{display:grid}}.touch-lane-overlay__zone{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;outline:none;padding:0;margin:0;cursor:pointer;background:var(--lane-bg, rgba(255, 255, 255, .06));border-right:1px solid rgba(255,255,255,.08);display:flex;align-items:center;justify-content:center;transition:background 60ms ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;user-select:none;touch-action:none}.touch-lane-overlay__zone:last-child{border-right:none}.touch-lane-overlay__zone[data-pressed=true]{background:var(--lane-active-bg, rgba(255, 255, 255, .25))}.touch-lane-overlay__label{font-family:var(--font-mono, monospace);font-size:1.25rem;font-weight:700;color:#ffffff2e;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;text-transform:uppercase}.touch-lane-overlay__zone[data-pressed=true] .touch-lane-overlay__label{color:#ffffff73}.settings__audio-slider--mobile{height:24px;cursor:pointer}.settings__audio-slider--mobile::-webkit-slider-runnable-track{height:24px;border-radius:12px}.settings__audio-slider--mobile::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:28px;height:28px;border-radius:50%;background:var(--color-info, #38bdf8);margin-top:-2px;cursor:pointer}.settings__audio-slider--mobile::-moz-range-track{height:24px;border-radius:12px}.settings__audio-slider--mobile::-moz-range-thumb{width:28px;height:28px;border-radius:50%;background:var(--color-info, #38bdf8);border:none;cursor:pointer}.shop-preview{width:80px;height:80px;border-radius:4px;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;background:#1e293b}.shop-preview.preview-bg-neon-city{background:linear-gradient(to bottom,#0f172a,#312e81 60%,#000)}.shop-preview.preview-bg-neon-city:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(236,72,153,.5) 50%,transparent 100%) 0 30px / 100% 2px no-repeat,linear-gradient(90deg,transparent 0%,rgba(6,182,212,.5) 50%,transparent 100%) 0 50px / 100% 2px no-repeat}.shop-preview.preview-bg-neon-city:after{content:"";position:absolute;bottom:0;left:0;right:0;height:30px;background:linear-gradient(to top,#000 0%,transparent 100%);border-top:1px solid #ec4899;box-shadow:0 -2px 10px #ec48994d}.shop-preview.preview-bg-deep-space{background:#000}.shop-preview.preview-bg-deep-space:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 30%,rgba(139,92,246,.4) 0%,transparent 60%),radial-gradient(circle at 70% 70%,rgba(59,130,246,.4) 0%,transparent 60%)}.shop-preview.preview-bg-deep-space:after{content:"";position:absolute;inset:0;background-image:radial-gradient(white 1px,transparent 1px),radial-gradient(white 1px,transparent 1px);background-size:20px 20px,30px 30px;background-position:0 0,15px 15px;opacity:.5}@keyframes petalFall{0%{transform:translateY(-10px) rotate(0);opacity:0}20%{opacity:1}80%{opacity:1}to{transform:translateY(90px) rotate(180deg);opacity:0}}.shop-preview.preview-bg-cherry-blossom{background:linear-gradient(135deg,#fdf2f8,#fbcfe8)}.shop-preview.preview-bg-cherry-blossom:before,.shop-preview.preview-bg-cherry-blossom:after{content:"";position:absolute;width:8px;height:8px;background:#f472b6;border-radius:8px 0;top:-10px;animation:petalFall 3s linear infinite}.shop-preview.preview-bg-cherry-blossom:before{left:20px;animation-delay:0s}.shop-preview.preview-bg-cherry-blossom:after{left:50px;animation-delay:1.5s;width:6px;height:6px;background:#fb7185}@keyframes infernoFlicker{0%,to{opacity:.8}50%{opacity:1}}.shop-preview.preview-bg-inferno{background:linear-gradient(to top,#7f1d1d,#ea580c,#450a0a);animation:infernoFlicker 2s ease-in-out infinite}.shop-preview.preview-bg-inferno:before{content:"";position:absolute;bottom:0;left:0;right:0;height:40px;background:radial-gradient(ellipse at bottom,rgba(253,186,116,.4) 0%,transparent 70%)}@keyframes matrixScroll{0%{background-position:0 -80px}to{background-position:0 80px}}.shop-preview.preview-bg-matrix{background:#000}.shop-preview.preview-bg-matrix:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(to bottom,transparent 0,transparent 4px,rgba(34,197,94,.8) 4px,rgba(34,197,94,.8) 8px);background-size:100% 80px;animation:matrixScroll 2s linear infinite;mask-image:linear-gradient(to bottom,transparent,black);-webkit-mask-image:linear-gradient(to bottom,transparent,black)}.shop-preview[class*=preview-hit-]:before{content:"PERF";font-weight:700;font-size:18px;letter-spacing:1px}.shop-preview.preview-hit-japanese:before{content:"完";font-family:Yu Gothic,Meiryo,sans-serif;color:#fff;font-size:32px;text-shadow:0 0 10px #0088ff,0 0 20px #0088ff}@keyframes flameFlicker{0%,to{text-shadow:0 0 4px #ea580c,0 -2px 8px #dc2626,0 -4px 12px #991b1b}50%{text-shadow:0 0 6px #f97316,0 -4px 10px #ef4444,0 -6px 16px #b91c1c}}.shop-preview.preview-hit-flame:before{color:#fdba74;animation:flameFlicker .5s ease-in-out infinite alternate}.shop-preview.preview-hit-ice:before{color:#bae6fd;text-shadow:0 0 5px #e0f2fe,0 0 10px #7dd3fc,0 0 15px #38bdf8;filter:blur(.5px)}.shop-preview.preview-hit-gold:before{color:transparent;background:linear-gradient(to bottom,#fef08a,#eab308,#a16207);-webkit-background-clip:text;background-clip:text;text-shadow:0 2px 4px rgba(202,138,4,.5)}@keyframes glitchAnim{0%{clip-path:inset(10% 0 80% 0);transform:translate(-2px,1px)}20%{clip-path:inset(80% 0 5% 0);transform:translate(2px,-1px)}40%{clip-path:inset(40% 0 40% 0);transform:translate(-2px,2px)}60%{clip-path:inset(60% 0 20% 0);transform:translate(2px,-2px)}80%{clip-path:inset(20% 0 60% 0);transform:translate(-1px,1px)}to{clip-path:inset(50% 0 30% 0);transform:translate(1px,-1px)}}.shop-preview.preview-hit-glitch{position:relative}.shop-preview.preview-hit-glitch:before{color:#fff;position:relative;z-index:2}.shop-preview.preview-hit-glitch:after{content:"PERF";font-weight:700;font-size:18px;letter-spacing:1px;position:absolute;color:#fff;text-shadow:-2px 0 red,2px 0 cyan;animation:glitchAnim .3s infinite linear alternate-reverse;z-index:1}.shop-preview[class*=preview-trail-]:before{content:"";position:absolute;width:16px;height:40px;bottom:10px;border-radius:8px}.shop-preview.preview-trail-sparkle:before{background:#fff;box-shadow:0 -10px 0 -6px #fff,-8px -20px 0 -7px #fff,8px -15px 0 -6px #fff,-5px -30px 0 -7px #fff,5px -25px 0 -7px #fff}.shop-preview.preview-trail-neon:before{background:#d8b4fe;box-shadow:0 0 10px #a855f7,0 0 20px #9333ea,0 0 30px #7e22ce}@keyframes fireTrailFlicker{0%,to{opacity:.8;transform:scaleX(1)}50%{opacity:1;transform:scaleX(.9)}}.shop-preview.preview-trail-fire:before{background:linear-gradient(to top,#f97316 0%,#ef4444 50%,transparent 100%);animation:fireTrailFlicker .2s infinite alternate}.shop-preview.preview-trail-ghost:before{background:#fffc;box-shadow:0 -15px #ffffff80,0 -30px #fff3}@keyframes rainbowCycle{0%{filter:hue-rotate(0deg)}to{filter:hue-rotate(360deg)}}.shop-preview.preview-trail-rainbow:before{background:linear-gradient(to top,#ef4444,#eab308,#22c55e,#3b82f6,#a855f7);animation:rainbowCycle 2s linear infinite}.shop-preview[class*=preview-hz-]{background:#0f172a}@keyframes shockwaveAnim{0%{transform:scale(.5);opacity:1;border-width:4px}to{transform:scale(1.5);opacity:0;border-width:1px}}.shop-preview.preview-hz-shockwave:before{content:"";position:absolute;width:30px;height:30px;border-radius:50%;border:4px solid #38bdf8;animation:shockwaveAnim 1s ease-out infinite}@keyframes rippleAnim{0%{transform:scale(.2);opacity:.8}to{transform:scale(2);opacity:0}}.shop-preview.preview-hz-ripple:before,.shop-preview.preview-hz-ripple:after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;border:2px solid #60a5fa;animation:rippleAnim 1.5s cubic-bezier(.1,.8,.3,1) infinite}.shop-preview.preview-hz-ripple:after{animation-delay:.4s}@keyframes flashAnim{0%,to{background:transparent}10%,30%{background:#fffc}}.shop-preview.preview-hz-flash:before{content:"";position:absolute;inset:0;animation:flashAnim 2s ease-out infinite}@keyframes bloomAnim{0%{transform:scale(0);opacity:1}50%{transform:scale(1.5);opacity:.5}to{transform:scale(2);opacity:0}}.shop-preview.preview-hz-bloom:before{content:"";position:absolute;width:40px;height:40px;border-radius:50%;background:radial-gradient(circle,rgba(250,204,21,.8) 0%,transparent 70%);animation:bloomAnim 1.5s ease-out infinite}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}html,body,#root{width:100%;height:100%}body{--tw-bg-opacity: 1;background-color:rgb(11 15 20 / var(--tw-bg-opacity, 1));--tw-text-opacity: 1;color:rgb(248 250 252 / var(--tw-text-opacity, 1));-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*:focus-visible{outline:2px solid transparent;outline-offset:2px;--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000);--tw-ring-opacity: 1;--tw-ring-color: rgb(56 189 248 / var(--tw-ring-opacity, 1));--tw-ring-offset-width: 2px;--tw-ring-offset-color: #0b0f14}.container{width:100%}@media (min-width: 640px){.container{max-width:640px}}@media (min-width: 768px){.container{max-width:768px}}@media (min-width: 1024px){.container{max-width:1024px}}@media (min-width: 1280px){.container{max-width:1280px}}@media (min-width: 1536px){.container{max-width:1536px}}.song-list .song-card{transform:translate(0) scale(1);transition:transform .7s cubic-bezier(.22,1,.36,1),border-color .32s ease;will-change:transform;backface-visibility:hidden;transform-origin:center center}.song-list .song-card.song-card--selected{transform:translate(30px) scale(1.08)}.song-list .song-card.song-card--selected:hover{transform:translate(34px) scale(1.1)}.song-list .song-card:hover{transform:translate(20px) scale(1.06)}.song-list{scroll-behavior:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y;contain:layout paint;transform:translateZ(0);scrollbar-gutter:stable;scrollbar-width:thin;scrollbar-color:rgba(148,163,184,.65) rgba(15,23,42,.45)}.song-list::-webkit-scrollbar{width:12px}.song-list::-webkit-scrollbar-track{background:linear-gradient(180deg,#0f172a80,#020617bf);border-radius:999px;border:1px solid rgba(100,116,139,.25)}.song-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#e2e8f0d9,#94a3b8e6);border-radius:999px;border:2px solid rgba(15,23,42,.55)}.song-list::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#f1f5f9,#bae6fdf2)}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.\!visible{visibility:visible!important}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{inset:0}.inset-x-0{left:0;right:0}.-bottom-1\/4{bottom:-25%}.-left-1\/4{left:-25%}.-right-1\/4{right:-25%}.-top-1\/4{top:-25%}.bottom-0{bottom:0}.bottom-24{bottom:6rem}.bottom-3{bottom:.75rem}.bottom-4{bottom:1rem}.bottom-8{bottom:2rem}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\/4{right:25%}.right-2{right:.5rem}.right-3{right:.75rem}.right-4{right:1rem}.top-0{top:0}.top-1\/2{top:50%}.top-1\/3{top:33.333333%}.top-11{top:2.75rem}.top-2{top:.5rem}.top-3{top:.75rem}.top-4{top:1rem}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-50{z-index:50}.z-\[100\]{z-index:100}.z-\[2000\]{z-index:2000}.mx-2{margin-left:.5rem;margin-right:.5rem}.mx-4{margin-left:1rem;margin-right:1rem}.mx-auto{margin-left:auto;margin-right:auto}.my-4{margin-top:1rem;margin-bottom:1rem}.my-5{margin-top:1.25rem;margin-bottom:1.25rem}.mb-1{margin-bottom:.25rem}.mb-10{margin-bottom:2.5rem}.mb-12{margin-bottom:3rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.ml-2{margin-left:.5rem}.ml-auto{margin-left:auto}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-10{margin-top:2.5rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mt-6{margin-top:1.5rem}.mt-8{margin-top:2rem}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-1\/2{height:50%}.h-1\/3{height:33.333333%}.h-10{height:2.5rem}.h-11{height:2.75rem}.h-12{height:3rem}.h-2{height:.5rem}.h-20{height:5rem}.h-24{height:6rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-6{height:1.5rem}.h-8{height:2rem}.h-9{height:2.25rem}.h-full{height:100%}.h-px{height:1px}.max-h-\[420px\]{max-height:420px}.max-h-\[85vh\]{max-height:85vh}.min-h-\[400px\]{min-height:400px}.min-h-\[44px\]{min-height:44px}.min-h-\[85vh\]{min-height:85vh}.min-h-screen{min-height:100vh}.w-1\/2{width:50%}.w-1\/3{width:33.333333%}.w-10{width:2.5rem}.w-11{width:2.75rem}.w-12{width:3rem}.w-20{width:5rem}.w-4{width:1rem}.w-5{width:1.25rem}.w-6{width:1.5rem}.w-64{width:16rem}.w-8{width:2rem}.w-9{width:2.25rem}.w-full{width:100%}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-\[150px\]{max-width:150px}.max-w-\[640px\]{max-width:640px}.max-w-\[900px\]{max-width:900px}.max-w-md{max-width:28rem}.max-w-sm{max-width:24rem}.max-w-xl{max-width:36rem}.flex-1{flex:1 1 0%}.flex-shrink-0{flex-shrink:0}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}@keyframes bounce{0%,to{transform:translateY(-25%);animation-timing-function:cubic-bezier(.8,0,1,1)}50%{transform:none;animation-timing-function:cubic-bezier(0,0,.2,1)}}.animate-bounce{animation:bounce 1s infinite}@keyframes pulse{50%{opacity:.5}}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}.cursor-not-allowed{cursor:not-allowed}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.resize{resize:both}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-6{gap:1.5rem}.gap-8{gap:2rem}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.5rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-6>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1.5rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:.25rem}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:.5rem}.rounded-md{border-radius:.375rem}.rounded-xl{border-radius:.75rem}.border{border-width:1px}.border-2{border-width:2px}.border-4{border-width:4px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-blue-500{--tw-border-opacity: 1;border-color:rgb(59 130 246 / var(--tw-border-opacity, 1))}.border-blue-500\/70{border-color:#3b82f6b3}.border-game-accent{--tw-border-opacity: 1;border-color:rgb(56 189 248 / var(--tw-border-opacity, 1))}.border-game-accent\/20{border-color:#38bdf833}.border-game-accent\/30{border-color:#38bdf84d}.border-game-border{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-gray-500{--tw-border-opacity: 1;border-color:rgb(107 114 128 / var(--tw-border-opacity, 1))}.border-gray-600{--tw-border-opacity: 1;border-color:rgb(75 85 99 / var(--tw-border-opacity, 1))}.border-gray-700{--tw-border-opacity: 1;border-color:rgb(55 65 81 / var(--tw-border-opacity, 1))}.border-gray-700\/50{border-color:#37415180}.border-gray-800{--tw-border-opacity: 1;border-color:rgb(31 41 55 / var(--tw-border-opacity, 1))}.border-green-700{--tw-border-opacity: 1;border-color:rgb(21 128 61 / var(--tw-border-opacity, 1))}.border-indigo-500{--tw-border-opacity: 1;border-color:rgb(99 102 241 / var(--tw-border-opacity, 1))}.border-purple-500{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.border-purple-500\/20{border-color:#a855f733}.border-purple-500\/30{border-color:#a855f74d}.border-purple-600\/50{border-color:#9333ea80}.border-red-500\/70{border-color:#ef4444b3}.border-red-700{--tw-border-opacity: 1;border-color:rgb(185 28 28 / var(--tw-border-opacity, 1))}.border-sky-300{--tw-border-opacity: 1;border-color:rgb(125 211 252 / var(--tw-border-opacity, 1))}.border-slate-700{--tw-border-opacity: 1;border-color:rgb(51 65 85 / var(--tw-border-opacity, 1))}.border-white{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.border-white\/20{border-color:#fff3}.border-yellow-500\/30{border-color:#eab3084d}.border-t-transparent{border-top-color:transparent}.bg-black\/30{background-color:#0000004d}.bg-black\/70{background-color:#000000b3}.bg-black\/75{background-color:#000000bf}.bg-black\/80{background-color:#000c}.bg-blue-500\/10{background-color:#3b82f61a}.bg-blue-600{--tw-bg-opacity: 1;background-color:rgb(37 99 235 / var(--tw-bg-opacity, 1))}.bg-blue-600\/10{background-color:#2563eb1a}.bg-cyan-600\/5{background-color:#0891b20d}.bg-emerald-500{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.bg-emerald-600{--tw-bg-opacity: 1;background-color:rgb(5 150 105 / var(--tw-bg-opacity, 1))}.bg-game-accent{--tw-bg-opacity: 1;background-color:rgb(56 189 248 / var(--tw-bg-opacity, 1))}.bg-game-accent\/10{background-color:#38bdf81a}.bg-game-bg{--tw-bg-opacity: 1;background-color:rgb(11 15 20 / var(--tw-bg-opacity, 1))}.bg-game-bg\/80{background-color:#0b0f14cc}.bg-game-bg\/85{background-color:#0b0f14d9}.bg-game-bg\/90{background-color:#0b0f14e6}.bg-game-panel{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-game-panel\/30{background-color:#1f29374d}.bg-game-panel\/40{background-color:#1f293766}.bg-game-panel\/50{background-color:#1f293780}.bg-game-panel\/60{background-color:#1f293799}.bg-game-panel\/80{background-color:#1f2937cc}.bg-game-surface{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-700{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.bg-gray-800{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.bg-gray-800\/30{background-color:#1f29374d}.bg-gray-800\/50{background-color:#1f293780}.bg-gray-800\/80{background-color:#1f2937cc}.bg-gray-900{--tw-bg-opacity: 1;background-color:rgb(17 24 39 / var(--tw-bg-opacity, 1))}.bg-gray-900\/60{background-color:#11182799}.bg-gray-900\/80{background-color:#111827cc}.bg-green-500{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.bg-green-600{--tw-bg-opacity: 1;background-color:rgb(22 163 74 / var(--tw-bg-opacity, 1))}.bg-green-900\/30{background-color:#14532d4d}.bg-green-900\/40{background-color:#14532d66}.bg-indigo-500\/10{background-color:#6366f11a}.bg-indigo-600{--tw-bg-opacity: 1;background-color:rgb(79 70 229 / var(--tw-bg-opacity, 1))}.bg-orange-500{--tw-bg-opacity: 1;background-color:rgb(249 115 22 / var(--tw-bg-opacity, 1))}.bg-purple-500{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.bg-purple-500\/10{background-color:#a855f71a}.bg-purple-600{--tw-bg-opacity: 1;background-color:rgb(147 51 234 / var(--tw-bg-opacity, 1))}.bg-purple-600\/10{background-color:#9333ea1a}.bg-purple-600\/20{background-color:#9333ea33}.bg-purple-600\/30{background-color:#9333ea4d}.bg-red-500{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.bg-red-500\/80{background-color:#ef4444cc}.bg-red-900{--tw-bg-opacity: 1;background-color:rgb(127 29 29 / var(--tw-bg-opacity, 1))}.bg-red-900\/40{background-color:#7f1d1d66}.bg-sky-500{--tw-bg-opacity: 1;background-color:rgb(14 165 233 / var(--tw-bg-opacity, 1))}.bg-sky-500\/15{background-color:#0ea5e926}.bg-sky-500\/20{background-color:#0ea5e933}.bg-sky-600{--tw-bg-opacity: 1;background-color:rgb(2 132 199 / var(--tw-bg-opacity, 1))}.bg-slate-700{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity, 1))}.bg-slate-800{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity, 1))}.bg-slate-800\/30{background-color:#1e293b4d}.bg-slate-800\/50{background-color:#1e293b80}.bg-slate-900{--tw-bg-opacity: 1;background-color:rgb(15 23 42 / var(--tw-bg-opacity, 1))}.bg-slate-950{--tw-bg-opacity: 1;background-color:rgb(2 6 23 / var(--tw-bg-opacity, 1))}.bg-white{--tw-bg-opacity: 1;background-color:rgb(255 255 255 / var(--tw-bg-opacity, 1))}.bg-white\/90{background-color:#ffffffe6}.bg-yellow-400\/10{background-color:#facc151a}.bg-gradient-to-br{background-image:linear-gradient(to bottom right,var(--tw-gradient-stops))}.bg-gradient-to-r{background-image:linear-gradient(to right,var(--tw-gradient-stops))}.from-game-accent{--tw-gradient-from: #38bdf8 var(--tw-gradient-from-position);--tw-gradient-to: rgb(56 189 248 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-gray-950{--tw-gradient-from: #030712 var(--tw-gradient-from-position);--tw-gradient-to: rgb(3 7 18 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.from-purple-600{--tw-gradient-from: #9333ea var(--tw-gradient-from-position);--tw-gradient-to: rgb(147 51 234 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), var(--tw-gradient-to)}.via-cyan-300{--tw-gradient-to: rgb(103 232 249 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #67e8f9 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-gray-900{--tw-gradient-to: rgb(17 24 39 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #111827 var(--tw-gradient-via-position), var(--tw-gradient-to)}.via-indigo-950{--tw-gradient-to: rgb(30 27 75 / 0) var(--tw-gradient-to-position);--tw-gradient-stops: var(--tw-gradient-from), #1e1b4b var(--tw-gradient-via-position), var(--tw-gradient-to)}.to-blue-400{--tw-gradient-to: #60a5fa var(--tw-gradient-to-position)}.to-cyan-300{--tw-gradient-to: #67e8f9 var(--tw-gradient-to-position)}.to-indigo-600{--tw-gradient-to: #4f46e5 var(--tw-gradient-to-position)}.to-purple-950{--tw-gradient-to: #3b0764 var(--tw-gradient-to-position)}.bg-clip-text{-webkit-background-clip:text;background-clip:text}.object-cover{-o-object-fit:cover;object-fit:cover}.p-2{padding:.5rem}.p-3{padding:.75rem}.p-4{padding:1rem}.p-5{padding:1.25rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-1\.5{padding-left:.375rem;padding-right:.375rem}.px-2{padding-left:.5rem;padding-right:.5rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-0\.5{padding-top:.125rem;padding-bottom:.125rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-12{padding-top:3rem;padding-bottom:3rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-20{padding-top:5rem;padding-bottom:5rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.py-5{padding-top:1.25rem;padding-bottom:1.25rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.pb-0\.5{padding-bottom:.125rem}.pb-20{padding-bottom:5rem}.pl-10{padding-left:2.5rem}.pr-2{padding-right:.5rem}.pr-20{padding-right:5rem}.pr-4{padding-right:1rem}.pt-32{padding-top:8rem}.text-left{text-align:left}.text-center{text-align:center}.font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.text-2xl{font-size:1.5rem;line-height:2rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-5xl{font-size:3rem;line-height:1}.text-6xl{font-size:3.75rem;line-height:1}.text-\[10px\]{font-size:10px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-black{font-weight:900}.font-bold{font-weight:700}.font-extrabold{font-weight:800}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.italic{font-style:italic}.leading-none{line-height:1}.leading-relaxed{line-height:1.625}.leading-tight{line-height:1.25}.tracking-tight{letter-spacing:-.025em}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.text-black{--tw-text-opacity: 1;color:rgb(0 0 0 / var(--tw-text-opacity, 1))}.text-blue-200{--tw-text-opacity: 1;color:rgb(191 219 254 / var(--tw-text-opacity, 1))}.text-blue-300{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.text-blue-400{--tw-text-opacity: 1;color:rgb(96 165 250 / var(--tw-text-opacity, 1))}.text-emerald-400{--tw-text-opacity: 1;color:rgb(52 211 153 / var(--tw-text-opacity, 1))}.text-game-accent{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-game-muted{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-game-muted\/40{color:#9ca3af66}.text-game-muted\/60{color:#9ca3af99}.text-game-text{--tw-text-opacity: 1;color:rgb(248 250 252 / var(--tw-text-opacity, 1))}.text-gray-200{--tw-text-opacity: 1;color:rgb(229 231 235 / var(--tw-text-opacity, 1))}.text-gray-300{--tw-text-opacity: 1;color:rgb(209 213 219 / var(--tw-text-opacity, 1))}.text-gray-400{--tw-text-opacity: 1;color:rgb(156 163 175 / var(--tw-text-opacity, 1))}.text-gray-500{--tw-text-opacity: 1;color:rgb(107 114 128 / var(--tw-text-opacity, 1))}.text-gray-600{--tw-text-opacity: 1;color:rgb(75 85 99 / var(--tw-text-opacity, 1))}.text-gray-700{--tw-text-opacity: 1;color:rgb(55 65 81 / var(--tw-text-opacity, 1))}.text-gray-900{--tw-text-opacity: 1;color:rgb(17 24 39 / var(--tw-text-opacity, 1))}.text-green-300{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.text-green-400{--tw-text-opacity: 1;color:rgb(74 222 128 / var(--tw-text-opacity, 1))}.text-indigo-200{--tw-text-opacity: 1;color:rgb(199 210 254 / var(--tw-text-opacity, 1))}.text-purple-200{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.text-purple-300{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.text-purple-300\/80{color:#d8b4fecc}.text-purple-400{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.text-red-300{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.text-red-400{--tw-text-opacity: 1;color:rgb(248 113 113 / var(--tw-text-opacity, 1))}.text-sky-300{--tw-text-opacity: 1;color:rgb(125 211 252 / var(--tw-text-opacity, 1))}.text-sky-400{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.text-slate-100{--tw-text-opacity: 1;color:rgb(241 245 249 / var(--tw-text-opacity, 1))}.text-slate-300{--tw-text-opacity: 1;color:rgb(203 213 225 / var(--tw-text-opacity, 1))}.text-slate-400{--tw-text-opacity: 1;color:rgb(148 163 184 / var(--tw-text-opacity, 1))}.text-slate-500{--tw-text-opacity: 1;color:rgb(100 116 139 / var(--tw-text-opacity, 1))}.text-slate-900{--tw-text-opacity: 1;color:rgb(15 23 42 / var(--tw-text-opacity, 1))}.text-transparent{color:transparent}.text-white{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.text-yellow-400{--tw-text-opacity: 1;color:rgb(250 204 21 / var(--tw-text-opacity, 1))}.text-yellow-500\/80{color:#eab308cc}.underline{text-decoration-line:underline}.placeholder-gray-500::-moz-placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.placeholder-gray-500::placeholder{--tw-placeholder-opacity: 1;color:rgb(107 114 128 / var(--tw-placeholder-opacity, 1))}.opacity-25{opacity:.25}.opacity-75{opacity:.75}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-2xl{--tw-shadow: 0 25px 50px -12px rgb(0 0 0 / .25);--tw-shadow-colored: 0 25px 50px -12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_12px_rgba\(255\,255\,255\,0\.4\)\]{--tw-shadow: 0 0 12px rgba(255,255,255,.4);--tw-shadow-colored: 0 0 12px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-\[0_0_8px_rgba\(255\,255\,255\,0\.3\)\]{--tw-shadow: 0 0 8px rgba(255,255,255,.3);--tw-shadow-colored: 0 0 8px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-glow{--tw-shadow: 0 0 0 2px rgba(56, 189, 248, .25);--tw-shadow-colored: 0 0 0 2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-blue-500\/10{--tw-shadow-color: rgb(59 130 246 / .1);--tw-shadow: var(--tw-shadow-colored)}.shadow-blue-500\/20{--tw-shadow-color: rgb(59 130 246 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-game-accent\/25{--tw-shadow-color: rgb(56 189 248 / .25);--tw-shadow: var(--tw-shadow-colored)}.shadow-game-accent\/30{--tw-shadow-color: rgb(56 189 248 / .3);--tw-shadow: var(--tw-shadow-colored)}.shadow-game-accent\/5{--tw-shadow-color: rgb(56 189 248 / .05);--tw-shadow: var(--tw-shadow-colored)}.shadow-purple-900\/20{--tw-shadow-color: rgb(88 28 135 / .2);--tw-shadow: var(--tw-shadow-colored)}.shadow-white\/10{--tw-shadow-color: rgb(255 255 255 / .1);--tw-shadow: var(--tw-shadow-colored)}.outline{outline-style:solid}.ring{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-game-accent\/0{--tw-ring-color: rgb(56 189 248 / 0)}.ring-white\/0{--tw-ring-color: rgb(255 255 255 / 0)}.blur-3xl{--tw-blur: blur(64px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.backdrop-blur{--tw-backdrop-blur: blur(8px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-md{--tw-backdrop-blur: blur(12px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.backdrop-blur-sm{--tw-backdrop-blur: blur(4px);backdrop-filter:var(--tw-backdrop-blur) var(--tw-backdrop-brightness) var(--tw-backdrop-contrast) var(--tw-backdrop-grayscale) var(--tw-backdrop-hue-rotate) var(--tw-backdrop-invert) var(--tw-backdrop-opacity) var(--tw-backdrop-saturate) var(--tw-backdrop-sepia)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.duration-200{transition-duration:.2s}.duration-300{transition-duration:.3s}.ease-out{transition-timing-function:cubic-bezier(0,0,.2,1)}@keyframes float-up{0%{transform:translateY(0) rotate(0);opacity:var(--particle-opacity, .12)}to{transform:translateY(-110vh) rotate(360deg);opacity:0}}.animate-float-up{animation:float-up linear infinite}.hover\:z-10:hover{z-index:10}.hover\:-translate-y-0\.5:hover{--tw-translate-y: -.125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:scale-105:hover{--tw-scale-x: 1.05;--tw-scale-y: 1.05;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.hover\:border-blue-400:hover{--tw-border-opacity: 1;border-color:rgb(96 165 250 / var(--tw-border-opacity, 1))}.hover\:border-game-accent\/30:hover{border-color:#38bdf84d}.hover\:border-purple-500\/40:hover{border-color:#a855f766}.hover\:border-red-400:hover{--tw-border-opacity: 1;border-color:rgb(248 113 113 / var(--tw-border-opacity, 1))}.hover\:border-sky-300\/50:hover{border-color:#7dd3fc80}.hover\:border-slate-600:hover{--tw-border-opacity: 1;border-color:rgb(71 85 105 / var(--tw-border-opacity, 1))}.hover\:border-white:hover{--tw-border-opacity: 1;border-color:rgb(255 255 255 / var(--tw-border-opacity, 1))}.hover\:bg-blue-500\/20:hover{background-color:#3b82f633}.hover\:bg-emerald-400:hover{--tw-bg-opacity: 1;background-color:rgb(52 211 153 / var(--tw-bg-opacity, 1))}.hover\:bg-emerald-500:hover{--tw-bg-opacity: 1;background-color:rgb(16 185 129 / var(--tw-bg-opacity, 1))}.hover\:bg-game-accent\/20:hover{background-color:#38bdf833}.hover\:bg-game-accentStrong:hover{--tw-bg-opacity: 1;background-color:rgb(14 165 233 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-200:hover{--tw-bg-opacity: 1;background-color:rgb(229 231 235 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-600:hover{--tw-bg-opacity: 1;background-color:rgb(75 85 99 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700:hover{--tw-bg-opacity: 1;background-color:rgb(55 65 81 / var(--tw-bg-opacity, 1))}.hover\:bg-gray-700\/50:hover{background-color:#37415180}.hover\:bg-gray-700\/80:hover{background-color:#374151cc}.hover\:bg-gray-800:hover{--tw-bg-opacity: 1;background-color:rgb(31 41 55 / var(--tw-bg-opacity, 1))}.hover\:bg-green-400:hover{--tw-bg-opacity: 1;background-color:rgb(74 222 128 / var(--tw-bg-opacity, 1))}.hover\:bg-green-500:hover{--tw-bg-opacity: 1;background-color:rgb(34 197 94 / var(--tw-bg-opacity, 1))}.hover\:bg-indigo-500\/20:hover{background-color:#6366f133}.hover\:bg-orange-400:hover{--tw-bg-opacity: 1;background-color:rgb(251 146 60 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-400:hover{--tw-bg-opacity: 1;background-color:rgb(192 132 252 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-500:hover{--tw-bg-opacity: 1;background-color:rgb(168 85 247 / var(--tw-bg-opacity, 1))}.hover\:bg-purple-500\/20:hover{background-color:#a855f733}.hover\:bg-red-400:hover{--tw-bg-opacity: 1;background-color:rgb(248 113 113 / var(--tw-bg-opacity, 1))}.hover\:bg-red-500:hover{--tw-bg-opacity: 1;background-color:rgb(239 68 68 / var(--tw-bg-opacity, 1))}.hover\:bg-red-800:hover{--tw-bg-opacity: 1;background-color:rgb(153 27 27 / var(--tw-bg-opacity, 1))}.hover\:bg-red-900\/20:hover{background-color:#7f1d1d33}.hover\:bg-sky-400:hover{--tw-bg-opacity: 1;background-color:rgb(56 189 248 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-600\/40:hover{background-color:#47556966}.hover\:bg-slate-700:hover{--tw-bg-opacity: 1;background-color:rgb(51 65 85 / var(--tw-bg-opacity, 1))}.hover\:bg-slate-700\/40:hover{background-color:#33415566}.hover\:bg-slate-800:hover{--tw-bg-opacity: 1;background-color:rgb(30 41 59 / var(--tw-bg-opacity, 1))}.hover\:text-blue-100:hover{--tw-text-opacity: 1;color:rgb(219 234 254 / var(--tw-text-opacity, 1))}.hover\:text-blue-300:hover{--tw-text-opacity: 1;color:rgb(147 197 253 / var(--tw-text-opacity, 1))}.hover\:text-green-300:hover{--tw-text-opacity: 1;color:rgb(134 239 172 / var(--tw-text-opacity, 1))}.hover\:text-purple-200:hover{--tw-text-opacity: 1;color:rgb(233 213 255 / var(--tw-text-opacity, 1))}.hover\:text-purple-300:hover{--tw-text-opacity: 1;color:rgb(216 180 254 / var(--tw-text-opacity, 1))}.hover\:text-purple-400:hover{--tw-text-opacity: 1;color:rgb(192 132 252 / var(--tw-text-opacity, 1))}.hover\:text-red-200:hover{--tw-text-opacity: 1;color:rgb(254 202 202 / var(--tw-text-opacity, 1))}.hover\:text-red-300:hover{--tw-text-opacity: 1;color:rgb(252 165 165 / var(--tw-text-opacity, 1))}.hover\:text-white:hover{--tw-text-opacity: 1;color:rgb(255 255 255 / var(--tw-text-opacity, 1))}.hover\:shadow-lg:hover{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.hover\:shadow-md:hover{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:border-purple-500:focus{--tw-border-opacity: 1;border-color:rgb(168 85 247 / var(--tw-border-opacity, 1))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.active\:scale-95:active{--tw-scale-x: .95;--tw-scale-y: .95;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-40:disabled{opacity:.4}.disabled\:opacity-50:disabled{opacity:.5}.disabled\:opacity-60:disabled{opacity:.6}.group:hover .group-hover\:text-game-accent{--tw-text-opacity: 1;color:rgb(56 189 248 / var(--tw-text-opacity, 1))}.group:hover .group-hover\:ring-game-accent\/30{--tw-ring-color: rgb(56 189 248 / .3)}.group:hover .group-hover\:ring-game-accent\/40{--tw-ring-color: rgb(56 189 248 / .4)}.group:hover .group-hover\:ring-white\/30{--tw-ring-color: rgb(255 255 255 / .3)}@media (min-width: 640px){.sm\:mb-10{margin-bottom:2.5rem}.sm\:mr-6{margin-right:1.5rem}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:contents{display:contents}.sm\:hidden{display:none}.sm\:min-h-0{min-height:0px}.sm\:w-72{width:18rem}.sm\:w-auto{width:auto}.sm\:max-w-\[200px\]{max-width:200px}.sm\:max-w-\[320px\]{max-width:320px}.sm\:shrink-0{flex-shrink:0}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:flex-wrap{flex-wrap:wrap}.sm\:items-center{align-items:center}.sm\:gap-10{gap:2.5rem}.sm\:gap-4{gap:1rem}.sm\:px-3{padding-left:.75rem;padding-right:.75rem}.sm\:px-6{padding-left:1.5rem;padding-right:1.5rem}.sm\:py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.sm\:py-6{padding-top:1.5rem;padding-bottom:1.5rem}.sm\:pr-8{padding-right:2rem}.sm\:text-4xl{font-size:2.25rem;line-height:2.5rem}.sm\:text-6xl{font-size:3.75rem;line-height:1}.sm\:text-xl{font-size:1.25rem;line-height:1.75rem}}@media (min-width: 768px){.md\:px-10{padding-left:2.5rem;padding-right:2.5rem}.md\:text-7xl{font-size:4.5rem;line-height:1}}@media (min-width: 1024px){.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:gap-20{gap:5rem}.lg\:px-16{padding-left:4rem;padding-right:4rem}}
