*{box-sizing:border-box;margin:0;padding:0}html{cursor:auto}body{margin:0;min-width:320px;min-height:100vh;overflow-x:hidden;cursor:auto}#root,.app{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;cursor:auto}p,span,div{cursor:auto}a{font-weight:500;color:#646cff;text-decoration:inherit;transition:color .2s ease;cursor:pointer}a:hover{color:#535bf2}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:all .25s ease}button:hover{border-color:#646cff;transform:translateY(-2px)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9;color:#213547}button:hover{background-color:#e9e9e9}}:root{--clue-font-size-label: .98rem;--clue-font-size-value: .92rem;--clue-font-size-tag: .92rem;--clue-font-size-arrow: .92rem;--clue-font-weight-label: 600;--clue-font-weight-value: 600;--clue-font-weight-arrow: 700}@media(max-width:768px){:root{--clue-font-size-label: .9rem;--clue-font-size-value: .85rem;--clue-font-size-tag: .85rem;--clue-font-size-arrow: .85rem}}.guess-box{background:#fff;border-radius:12px;padding:1.5rem;margin-bottom:1rem;box-shadow:0 2px 8px #0000001a;text-align:left;position:relative;transform-origin:center}.guess-box.win-pulse{animation:pulseWin .6s ease-in-out;animation-iteration-count:7}.guess-box.win-pulse[data-pulse-delay]{animation-delay:var(--pulse-delay)}@keyframes pulseWin{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.guess-number-badge{position:absolute;top:.5rem;right:.5rem;font-size:.65rem;color:#999;font-weight:500}.guess-box-header{margin-bottom:1rem}.guess-song-title{font-size:1rem;font-weight:600;color:#333;margin:0}.guess-clues{display:flex;flex-wrap:wrap;gap:.6rem;align-items:center;position:relative;z-index:0}@media(max-width:768px){.guess-box{padding:1rem}.guess-song-title{font-size:.9rem;padding-right:3rem}.guess-clues{gap:.35rem;flex-wrap:wrap;align-items:center}.clue-tag{padding:.35rem .25rem;font-size:var(--clue-font-size-tag);gap:.15rem;flex:0 0 calc(50% - .2rem);min-width:calc(50% - .2rem);max-width:calc(50% - .2rem);min-height:28px;line-height:1.2;overflow:hidden;box-sizing:border-box}.clue-label{font-size:var(--clue-font-size-label);white-space:nowrap}.clue-value{font-size:var(--clue-font-size-value);white-space:nowrap;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;max-width:100%}.clue-arrow{font-size:var(--clue-font-size-arrow);margin-left:.08rem}.clue-tooltip-wrapper{margin-left:.1rem}.artist-type-icon{width:14px;height:14px}.duration-icon,.year-icon{width:12px;height:12px}.clue-icon{font-size:.75rem}.clue-help-icon{font-size:.65rem;margin-left:.2rem}.clue-help-button{width:12px;height:12px;flex-shrink:0}}.clue-tag{display:flex;align-items:center;gap:.2rem;padding:.4rem;background:#f0f0f0;border-radius:20px;font-size:var(--clue-font-size-tag);transition:all .2s ease;box-shadow:0 2px 4px #0000001a;border:1px solid rgba(0,0,0,.1);flex-shrink:0;max-width:100%;min-height:32px;line-height:1.2;position:relative;z-index:1;overflow:hidden;box-sizing:border-box}.clue-tag.clue-status-correct{background:linear-gradient(to bottom,#d4edda,#c3e6cb);border:1px solid #a3d5a3;box-shadow:0 3px 6px #22c55e33,inset 0 1px #ffffff4d}.clue-tag.clue-status-close{background:linear-gradient(to bottom,#cfe2ff,#b6d4fe);border:1px solid #9ec5fe;box-shadow:0 3px 6px #0d6efd33,inset 0 1px #ffffff4d}.clue-tag.clue-status-incorrect{background:linear-gradient(to bottom,#f8d7da,#f1aeb5);border:1px solid #ea868f;box-shadow:0 3px 6px #dc35454d,inset 0 1px #fff3}.clue-tag.clue-status-neighboring{background:linear-gradient(to bottom,#fef3c7,#fde68a);border:1px solid #fcd34d;box-shadow:0 3px 6px #f59e0b4d,inset 0 1px #ffffff4d}.clue-tag.clue-status-unknown{background:linear-gradient(to bottom,#f0f0f0,#e0e0e0);border:1px solid #d0d0d0;box-shadow:0 2px 4px #0000001a,inset 0 1px #ffffff4d}.clue-tag.tempo-clue.clue-status-close{background:linear-gradient(to bottom,#fef3c7,#fde68a);border:1px solid #fcd34d;box-shadow:0 3px 6px #f59e0b4d,inset 0 1px #ffffff4d}.tempo-arrow{font-size:1.1em;line-height:1;display:inline-block;vertical-align:-.2em}.clue-label{font-weight:var(--clue-font-weight-label);color:#666;font-size:var(--clue-font-size-label);text-transform:uppercase;display:inline-flex;align-items:center;flex-shrink:0}.clue-value{color:#333;font-weight:var(--clue-font-weight-value);font-size:var(--clue-font-size-value);display:inline-flex;align-items:center;white-space:nowrap;flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;max-width:fit-content}.clue-value.neighboring{color:#f59e0b;font-weight:600;font-style:italic}.clue-value-checkmark{font-size:1rem;font-weight:600;line-height:1}.clue-arrow{margin-left:.08rem;margin-right:0;font-size:var(--clue-font-size-arrow);font-weight:var(--clue-font-weight-arrow);line-height:1;flex-shrink:0;white-space:nowrap}.artist-type-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.artist-type-icon{width:16px;height:16px;color:#22c55e;vertical-align:middle}.genre-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;font-size:.8em;flex-shrink:0;line-height:1}.country-flag-wrapper{display:inline-flex;align-items:center;justify-content:center;font-size:1em;flex-shrink:0;line-height:1}.year-icon-wrapper,.duration-icon-wrapper,.country-icon-wrapper,.country-flag-wrapper,.gender-icon-wrapper,.artist-icon-wrapper,.album-icon-wrapper{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.clue-icon-img{display:inline-block;vertical-align:middle;flex-shrink:0}.year-icon,.duration-icon,.country-icon,.genre-icon,.gender-icon,.artist-icon,.album-icon{width:14px;height:14px;color:inherit}.tempo-icon{width:18px;height:18px}.year-icon,.duration-icon,.country-icon,.genre-icon,.gender-icon,.artist-icon,.album-icon,.tempo-icon{color:inherit;vertical-align:middle;flex-shrink:0}.artist-icon-wrapper,.album-icon-wrapper{text-transform:none}.gender-icon{font-size:14px;line-height:1;color:#666;vertical-align:middle;flex-shrink:0;display:inline-block}.clue-icon{margin-left:.4rem;font-weight:700;font-size:.9rem;display:inline-block}.clue-icon.correct{color:#22c55e}.clue-icon.incorrect{color:#ef4444}.clue-tooltip-wrapper{position:relative;display:inline-flex;align-items:center;margin-left:auto;flex-shrink:0;z-index:10001;isolation:isolate}.clue-help-button{background:none;border:none;padding:0;margin:0;display:inline-flex;align-items:center;justify-content:center;color:#667eea;opacity:.7;transition:all .2s ease;width:16px;height:16px;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;cursor:pointer}.clue-help-button:hover{opacity:1;transform:scale(1.1)}.clue-help-button:active{transform:scale(.95)}.clue-help-button svg{width:100%;height:100%;display:block}.clue-tooltip{position:fixed;padding:.75rem 1rem;background:#333;color:#fff;border-radius:8px;font-size:.8rem;line-height:1.5;max-width:min(280px,calc(100vw - 20px));min-width:200px;white-space:normal;word-wrap:break-word;z-index:99999;box-shadow:0 4px 12px #0000004d;pointer-events:auto;text-align:left;top:-9999px;left:0;opacity:0;visibility:hidden;-webkit-transform:translateZ(0);transform:translateZ(0);will-change:transform;touch-action:none;cursor:default}.clue-tooltip strong{font-weight:700;font-size:.9rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.clue-tooltip-arrow{position:absolute;top:100%;border:6px solid transparent;border-top-color:#333;pointer-events:none}@media(max-width:768px){.clue-tooltip{max-width:240px;min-width:180px;font-size:.75rem;padding:.65rem .85rem}.clue-tooltip-arrow{border-width:5px}.clue-help-button{width:14px;height:14px}.tempo-arrow{font-size:1.35em;vertical-align:-.25em}}@media(prefers-color-scheme:dark){.guess-box{background:#282828f2}.guess-song-title{color:#fff}.guess-number-badge{color:#aaa}.clue-tag{background:#3c3c3ccc}.clue-tag .clue-label,.clue-tag .clue-value{color:#14532d}}.lifeline-box{background:linear-gradient(135deg,#667eea1a,#764ba21a);border:2px solid rgba(102,126,234,.3)}.lifeline-catalog-size{margin-top:.75rem;font-size:.85rem;color:#667eea;text-align:center}.catalog-size-after-guess{margin-top:.75rem;font-size:.8rem;color:#667eea;text-align:center}@media(prefers-color-scheme:dark){.lifeline-box{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:#667eea66}.lifeline-catalog-size,.catalog-size-after-guess{color:#818cf8}}.win-confetti-container{position:fixed;inset:0;pointer-events:none;z-index:1000;overflow:hidden}.confetti-note{position:absolute;top:50%;left:50%;font-size:2rem;color:var(--color, #667eea);font-weight:700;transform-origin:center;opacity:0;animation:confettiFall 6.5s ease-out forwards;animation-delay:var(--delay);text-shadow:0 0 8px rgba(255,255,255,.6),0 0 16px var(--color),0 2px 4px rgba(0,0,0,.2);filter:drop-shadow(0 0 6px var(--color))}@keyframes confettiFall{0%{opacity:0;transform:translate(-50%,-50%) scale(0) rotate(0)}8%{opacity:1;transform:translate(-50%,-50%) scale(calc(var(--size, 1) * 1.1)) rotate(calc(var(--rotation) * .2))}75%{opacity:1;transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) scale(var(--size, 1)) rotate(var(--rotation))}to{opacity:.18;transform:translate(calc(-50% + var(--x)),calc(-50% + var(--y))) scale(var(--size, 1)) rotate(var(--rotation))}}@media(max-width:768px){.confetti-note{font-size:1.5rem}}.google-sign-in-button{display:flex;justify-content:flex-start;min-height:40px}.google-sign-in-button--compact{justify-content:center;min-height:36px}.google-sign-in-button--compact iframe{max-width:100%}.hamburger-menu-wrapper{position:fixed;top:1rem;right:1rem;z-index:1000;display:inline-block}.hamburger-button{background:#ffffffe6;border:1px solid #ddd;border-radius:8px;padding:.5rem .75rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;font-size:1.25rem;color:#333;min-width:40px;height:40px}.hamburger-button:hover{background:#fff;border-color:#667eea;box-shadow:0 2px 8px #667eea33}.hamburger-button:active{transform:scale(.95)}.hamburger-button.open{background:#667eea;color:#fff;border-color:#667eea}.hamburger-icon{font-size:1.25rem;line-height:1}.hamburger-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border-radius:12px;box-shadow:0 4px 20px #00000026;min-width:180px;max-width:min(92vw,280px);z-index:1000;overflow:hidden;animation:slideDown .2s ease-out;border:1px solid #e0e0e0}.hamburger-menu-account{padding:.65rem .85rem .75rem;border-bottom:1px solid #eee;background:#fafbfc}.hamburger-menu-account-title{font-size:.95rem;font-weight:600;color:#222}.hamburger-menu-account-sub{font-size:.75rem;color:#666;margin:.15rem 0 .5rem;line-height:1.2}.hamburger-menu-account-name{font-size:.9rem;font-weight:600;color:#222;line-height:1.2;word-break:break-word}.hamburger-menu-account-email{font-size:.72rem;color:#666;margin-top:.08rem;word-break:break-all}.hamburger-menu-account-provider{font-size:.7rem;color:#888;margin:.35rem 0 .45rem}.hamburger-menu-account-error{font-size:.72rem;color:#c0392b;margin-top:.35rem}.hamburger-menu-sign-out{width:100%;padding:.4rem .5rem;font-size:.85rem;border:1px solid #ddd;border-radius:8px;background:#fff;cursor:pointer;font-family:inherit;color:#333}.hamburger-menu-sign-out:hover:not(:disabled){background:#f5f5f5}.hamburger-menu-sign-out:disabled{opacity:.7;cursor:default}.hamburger-menu-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:1rem;color:#333;transition:background-color .2s ease;font-family:inherit;text-decoration:none;box-sizing:border-box}a.hamburger-menu-item{border:none}.hamburger-menu-item:first-child{border-top-left-radius:12px;border-top-right-radius:12px}.hamburger-menu-item:last-child{border-bottom-left-radius:12px;border-bottom-right-radius:12px}.hamburger-menu-item:hover{background:#f8f9fa}.hamburger-menu-item:active{background:#e9ecef}.menu-item-icon{font-size:1.1rem;width:20px;text-align:center}@media(max-width:768px){.hamburger-menu-wrapper{top:.75rem;right:.75rem}.hamburger-menu-dropdown{right:0;left:auto;min-width:160px;max-width:min(94vw,260px)}.hamburger-menu-account{padding:.5rem .65rem .6rem}.hamburger-menu-account-title{font-size:.88rem}.hamburger-menu-account-sub{font-size:.7rem;margin-bottom:.4rem}.google-sign-in-button--compact{min-height:32px}.hamburger-menu-item{padding:.65rem .85rem;font-size:.95rem}.menu-item-icon{font-size:1rem;width:18px}}@media(prefers-color-scheme:dark){.hamburger-button{background:#282828f2;border-color:#555;color:#e0e0e0}.hamburger-button:hover{background:#323232;border-color:#667eea}.hamburger-button.open{background:#667eea;color:#fff}.hamburger-menu-dropdown{background:#1a1a1a;border-color:#444}.hamburger-menu-account{background:#141414;border-bottom-color:#333}.hamburger-menu-account-title,.hamburger-menu-account-name{color:#e8e8e8}.hamburger-menu-account-sub,.hamburger-menu-account-email,.hamburger-menu-account-provider{color:#aaa}.hamburger-menu-sign-out{background:#222;border-color:#444;color:#e0e0e0}.hamburger-menu-sign-out:hover:not(:disabled){background:#2a2a2a}.hamburger-menu-item{color:#e0e0e0}.hamburger-menu-item:hover{background:#2a2a2a}.hamburger-menu-item:active{background:#333}}.game-top-bar{position:fixed;top:0;left:0;right:0;height:52px;background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 2px 12px #0003;display:flex;align-items:center;justify-content:space-between;padding:0 1rem;z-index:100}.game-top-bar-icons{display:flex;align-items:center;gap:.5rem}.game-top-bar-icon{width:40px;height:40px;padding:0;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:10px;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.game-top-bar-icon:hover{background:#ffffff59;transform:translateY(-2px);box-shadow:0 2px 8px #00000026}.game-top-bar-icon:active{transform:translateY(0)}.game-top-bar-hamburger{display:flex;align-items:center}.game-top-bar-hamburger .hamburger-menu-wrapper{position:relative;top:auto;right:auto}.game-top-bar-hamburger .hamburger-button{background:#fff3;border-color:#ffffff4d;color:#fff}.game-top-bar-hamburger .hamburger-button:hover{background:#ffffff59;border-color:#ffffff80}.game-top-bar-hamburger .hamburger-button.open{background:#fff6;color:#fff;border-color:#ffffff80}@media(max-width:768px){.game-top-bar{height:48px;padding:0 .75rem}.game-top-bar-icon{width:36px;height:36px;font-size:1.1rem}}.leaderboards-content{display:flex;flex-direction:column;gap:1rem}.leaderboards-explanation{border:1px solid #e0e0e0;border-radius:10px;overflow:hidden;background:#f8f9fa}.leaderboards-explanation-toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.6rem .9rem;background:transparent;border:none;font-size:.95rem;font-weight:600;color:#333;cursor:pointer;text-align:left;transition:background .2s ease}.leaderboards-explanation-toggle:hover{background:#667eea14}.leaderboards-explanation-toggle-icon{font-size:.75rem;color:#667eea}.leaderboards-explanation-content{max-height:0;overflow:hidden;transition:max-height .3s ease-out}.leaderboards-explanation-content.expanded{max-height:600px}.leaderboards-explanation-body{padding:0 .9rem .9rem;font-size:.9rem;line-height:1.5;color:#555}.leaderboards-explanation-section{margin:.6rem 0 .3rem}.leaderboards-explanation-section:first-child{margin-top:0}.leaderboards-explanation-list{margin:.3rem 0 .6rem 1.2rem;padding:0}.leaderboards-explanation-list li{margin:.35rem 0}.leaderboards-tabs{display:flex;flex-wrap:wrap;gap:.5rem;border-bottom:2px solid #e0e0e0;padding-bottom:.5rem}.leaderboards-board-header .leaderboards-refresh-button{flex-shrink:0}.leaderboards-refresh-button{background:#667eea14;border:1px solid rgba(102,126,234,.25);color:#667eea;width:36px;height:36px;padding:0;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.leaderboards-refresh-button:hover:not(:disabled){background:#667eea1f;border-color:#667eea66;transform:scale(1.05)}.leaderboards-refresh-button:disabled{opacity:.6;cursor:not-allowed}.leaderboards-refresh-icon{width:18px;height:18px}.leaderboards-refresh-icon.spinning{animation:leaderboards-refresh-spin .8s linear infinite}@keyframes leaderboards-refresh-spin{to{transform:rotate(-360deg)}}.leaderboards-tab{background:transparent;border:none;padding:.5rem 1rem;font-size:.95rem;font-weight:500;color:#666;cursor:pointer;border-radius:8px;transition:all .2s ease}.leaderboards-tab:hover{color:#667eea;background:#667eea14}.leaderboards-tab.active{color:#667eea;background:#667eea26;font-weight:600}.leaderboards-board-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem}.leaderboards-board-title{margin:0;font-size:1.25rem;font-weight:600;color:#333;flex:1;min-width:0}.leaderboards-date-range{font-weight:400;color:#666}.leaderboards-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid #e0e0e0}.leaderboards-table{width:100%;border-collapse:collapse;font-size:.95rem}.leaderboards-table th,.leaderboards-table td{padding:.6rem .8rem;text-align:left;border-bottom:1px solid #eee}.leaderboards-table th{background:#f8f9fa;font-weight:600;color:#333;white-space:normal;word-wrap:break-word}.leaderboards-table .leaderboards-col-rank{width:3.5rem;text-align:center}.leaderboards-table .leaderboards-col-player{min-width:8rem}.leaderboards-table .leaderboards-col-won{width:3.5rem;text-align:center}.leaderboards-table .leaderboards-col-avg{width:6rem;text-align:center;white-space:normal;word-wrap:break-word}.leaderboards-table .leaderboards-col-attempted{width:4rem;text-align:center}.leaderboards-col-label-full{display:none}.leaderboards-col-label-short{display:inline}@media(min-width:640px){.leaderboards-col-label-full{display:inline}.leaderboards-col-label-short{display:none}.leaderboards-table .leaderboards-col-attempted{width:5.5rem}}.leaderboards-play-to-enter{margin:.75rem 0 0;padding:.5rem 0;font-size:.9rem;color:#666;text-align:center}.leaderboards-rotate-hint{display:none;align-items:center;gap:.5rem;margin:.5rem 0 0;padding:0;font-size:.85rem;color:#666}@media(orientation:portrait)and (max-width:767px){.leaderboards-rotate-hint{display:flex}}.leaderboards-rotate-icon{display:flex;align-items:center;flex-shrink:0}.leaderboards-rotate-icon svg{width:20px;height:20px;color:#667eea}.leaderboards-table tbody tr:hover{background:#667eea0d}.leaderboards-row-you{background:#667eea26!important;border-left:3px solid #667eea}.leaderboards-player-name{display:inline;word-break:break-word}.leaderboards-you-badge{display:inline-block;margin-left:.35rem;background:#667eea;color:#fff;font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:10px}.leaderboards-edit-pencil{display:inline-flex;align-items:center;justify-content:center;margin-left:.35rem;padding:.2rem;background:transparent;border:none;color:#667eea;cursor:pointer;border-radius:4px;transition:all .2s ease}.leaderboards-edit-pencil:hover{background:#667eea26;color:#764ba2}.leaderboards-edit-pencil svg{width:14px;height:14px}.leaderboards-edit-name{display:flex;flex-wrap:wrap;align-items:center;gap:.4rem}.leaderboards-edit-input{flex:1;min-width:100px;padding:.35rem .5rem;font-size:.9rem;border:1px solid #ccc;border-radius:6px}.leaderboards-edit-input:focus{outline:none;border-color:#667eea}.leaderboards-edit-save,.leaderboards-edit-cancel{padding:.35rem .6rem;font-size:.8rem;border-radius:6px;cursor:pointer;font-weight:500}.leaderboards-edit-save{background:#667eea;color:#fff;border:none}.leaderboards-edit-save:hover:not(:disabled){background:#5a6fd6}.leaderboards-edit-cancel{background:transparent;border:1px solid #ccc;color:#666}.leaderboards-edit-cancel:hover:not(:disabled){background:#f0f0f0}.leaderboards-edit-error{width:100%;font-size:.8rem;color:#ef4444}.leaderboards-gap-row td{text-align:center;color:#999;font-size:1.2rem;padding:.5rem;border-bottom:1px dashed #ddd}.leaderboards-loading,.leaderboards-error,.leaderboards-empty{text-align:center;padding:3rem 1rem;color:#666}.leaderboards-spinner{width:40px;height:40px;border:3px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;animation:leaderboards-spin .8s linear infinite;margin:0 auto 1rem}@keyframes leaderboards-spin{to{transform:rotate(360deg)}}.leaderboards-error{color:#ef4444}.leaderboards-retry-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;margin-top:1rem;transition:all .2s ease}.leaderboards-retry-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.leaderboards-overlay-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:1rem;padding-top:max(1rem,env(safe-area-inset-top));padding-bottom:max(1rem,env(safe-area-inset-bottom));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));overflow-y:auto;animation:leaderboards-fadeIn .2s ease-out;-webkit-overflow-scrolling:touch}@keyframes leaderboards-fadeIn{0%{opacity:0}to{opacity:1}}.leaderboards-overlay-panel{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:leaderboards-slideIn .3s ease-out;flex-shrink:0;margin-top:0;-webkit-overflow-scrolling:touch}@keyframes leaderboards-slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.leaderboards-overlay-header{display:flex;justify-content:space-between;align-items:center;padding:calc(1rem + env(safe-area-inset-top,0px)) 1.5rem 1rem;border-bottom:2px solid #e0e0e0;flex-shrink:0;position:sticky;top:0;background:#fff;z-index:1}.leaderboards-overlay-title{font-size:1.5rem;font-weight:700;color:#333;margin:0;display:flex;align-items:center;gap:.5rem}.leaderboards-overlay-title .leaderboards-icon{font-size:1.5rem}.leaderboards-overlay-body{padding:1rem 1.5rem;overflow-y:auto;flex:1}@media(max-width:768px){.leaderboards-overlay-panel{max-height:95vh}.leaderboards-overlay-header{padding:calc(.75rem + env(safe-area-inset-top,0px)) 1rem 1rem}.leaderboards-overlay-body{padding:1rem}.leaderboards-overlay-title{font-size:1.25rem}}.new-daily-puzzle-banner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;box-shadow:0 2px 8px #667eea4d;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.banner-content{display:flex;align-items:center;gap:.75rem;flex:1;flex-wrap:wrap}.banner-icon{font-size:1.25rem}.banner-message{font-size:.95rem;font-weight:500;flex:1;min-width:200px}.banner-button{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s ease;white-space:nowrap}.banner-button:hover{background:#ffffff4d;border-color:#ffffff80}.banner-button:active{transform:scale(.95)}.banner-close{background:#fff3;color:#fff;width:28px;height:28px;font-size:1.1rem;margin-left:.5rem;flex-shrink:0}.banner-close:hover{background:#ffffff4d;color:#fff}@media(max-width:768px){.new-daily-puzzle-banner{padding:.65rem .85rem;flex-direction:column;align-items:stretch}.banner-content{flex-direction:column;align-items:stretch;gap:.5rem}.banner-message{min-width:auto;text-align:center}.banner-button{width:100%;padding:.6rem 1rem}.banner-close{position:absolute;top:.5rem;right:.5rem;margin-left:0}.new-daily-puzzle-banner{position:relative}}@media(prefers-color-scheme:dark){.new-daily-puzzle-banner{background:linear-gradient(135deg,#5568d3,#6a3d8f);box-shadow:0 2px 8px #5568d366}}.active-game-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.active-game-with-top-bar{padding-top:calc(52px + 2rem)}.active-game-content{--content-pad: 3rem;text-align:center;max-width:600px;width:100%;padding:var(--content-pad);background:#fffffff2;border-radius:20px;box-shadow:0 20px 60px #0000004d;animation:fadeIn .6s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.daily-song-title{font-size:2.5rem;font-weight:700;margin:0;color:#333;display:flex;align-items:center;justify-content:flex-start;gap:.5rem;flex:1 1 auto;min-width:200px}.help-link-button,.statistics-link-button,.archive-link-button{padding:.5rem 1rem;font-size:.9rem;font-weight:600;color:#667eea;background:#fff;border:2px solid #667eea;border-radius:20px;cursor:pointer;transition:all .2s;white-space:nowrap}.help-link-button:hover,.statistics-link-button:hover,.archive-link-button:hover{background:#667eea;color:#fff;transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.help-link-button:active,.statistics-link-button:active,.archive-link-button:active{transform:translateY(0)}.puzzle-loading-text{margin-top:1.5rem;margin-bottom:0;color:#555;font-size:1rem}.puzzle-page-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee;font-size:.85rem}.puzzle-footer-link{background:none;border:none;color:#667eea;cursor:pointer;padding:0;font-size:inherit;text-decoration:none;transition:opacity .2s}a.puzzle-footer-link{display:inline}.puzzle-footer-link:hover{text-decoration:underline}.puzzle-footer-sep{color:#999;margin:0 .25rem}.seo-intro{margin-top:1.5rem;padding-top:.75rem;border-top:1px solid #f4f4f9}.seo-intro-toggle{display:flex;align-items:center;gap:.35rem;background:none;border:none;padding:0;font-size:.75rem;color:#d7daf2;cursor:pointer;font-family:inherit;transition:color .2s}.seo-intro-toggle:hover{color:#667eea}.seo-intro-chevron{font-size:.6rem}.seo-intro-content{max-height:0;overflow:hidden;transition:max-height .25s ease-out}.seo-intro-content.expanded{max-height:120px}.seo-intro-title{font-size:.7rem;font-weight:600;color:#d0d3f0;margin:.25rem 0 .15rem}.seo-intro-text{font-size:.7rem;color:#d8daf0;line-height:1.5;margin:0}.music-icon{font-size:2.5rem;color:#667eea}.guess-counter{font-size:1rem;color:#666;margin-bottom:2rem;font-weight:500}.instruction-text{font-size:1rem;color:#555;margin-bottom:1rem;font-style:italic;line-height:1.5;padding:.75rem 1rem;background:#667eea14;border-left:3px solid #667eea;border-radius:6px;text-align:left;max-width:600px;margin-left:auto;margin-right:auto}.search-container{display:flex;gap:1rem;align-items:center;justify-content:center;flex-wrap:wrap}.search-box-wrapper{position:relative;flex:1;min-width:250px;max-width:400px}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.2rem;color:#999;z-index:1;pointer-events:none}.mui-autocomplete,.autocomplete-input{width:100%}.action-buttons{display:flex;gap:.5rem;align-items:center;justify-content:center;flex-wrap:wrap}.action-buttons-group{display:flex;gap:.5rem;align-items:center;flex-shrink:0}.submit-button{padding:.9rem 3rem;font-size:1.1rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;cursor:pointer;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 20px #667eea80;white-space:nowrap;min-width:140px}.give-up-button{padding:.75rem;font-size:1.2rem;color:#666;background:#c8c8c833;border:1px solid rgba(150,150,150,.3);border-radius:50%;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;line-height:1;opacity:.5}.give-up-button.enabled{opacity:1;color:#d32f2f;background:#d32f2f1a;border-color:#d32f2f66}.give-up-button.enabled:hover:not(:disabled){background:#d32f2f33;border-color:#d32f2f99;transform:translateY(-2px) scale(1.05)}.give-up-button.enabled:active:not(:disabled){transform:translateY(0) scale(.95);background:#d32f2f26}.give-up-button:disabled{opacity:.4;cursor:not-allowed;background:#c8c8c81a;border-color:#96969633;color:#999}.lifeline-button-wrapper{position:relative;display:inline-flex;align-items:center}.lifeline-button{padding:.75rem;font-size:1.2rem;color:#667eea;background:#667eea1a;border:1px solid rgba(102,126,234,.4);border-radius:50%;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;min-width:44px;opacity:.5}.lifeline-button.enabled:not(:disabled){opacity:1;color:#667eea;background:#667eea26;border-color:#667eea80}.lifeline-button:hover:not(:disabled){background:#667eea33;border-color:#667eea99;transform:translateY(-2px) scale(1.05)}.lifeline-button.enabled:hover:not(:disabled){background:#667eea40;border-color:#667eeab3}.lifeline-button:active:not(:disabled){transform:translateY(0) scale(.95)}.lifeline-button:disabled{opacity:.4;cursor:not-allowed;background:#c8c8c81a;border-color:#9696964d}.lifeline-button.activated{opacity:1;background:#22c55e26;border-color:#22c55e80;cursor:default}.lifeline-icon{font-size:1.3rem;line-height:1;display:inline-block}.lifeline-button.lifeline-pulse .lifeline-icon{animation:lifeline-pulse 3s ease-in-out 1}@keyframes lifeline-pulse{0%,to{transform:scale(1);opacity:1}15%{transform:scale(1.25);opacity:1}30%{transform:scale(1);opacity:1}45%{transform:scale(1.25);opacity:1}60%{transform:scale(1);opacity:1}75%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}.lifeline-available-bubble{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:.5rem .75rem;background:#333;color:#fff;border-radius:8px;font-size:.75rem;font-weight:500;white-space:nowrap;z-index:1000;box-shadow:0 4px 12px #0000004d;pointer-events:none;animation:lifeline-bubble-fade 3s ease-out forwards}.lifeline-available-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}@keyframes lifeline-bubble-fade{0%,60%{opacity:1}to{opacity:0}}.help-buttons-info-wrapper{position:relative;display:inline-flex;align-items:center}.help-buttons-info-icon{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:50%;background:#667eea26;color:#667eea;font-size:.7rem;font-weight:600;cursor:help;transition:all .2s;flex-shrink:0;-webkit-user-select:none;user-select:none}.help-buttons-info-icon:hover{background:#667eea40;transform:scale(1.1)}.help-buttons-tooltip{position:absolute;bottom:calc(100% + 12px);right:0;padding:.75rem 1rem;background:#333;color:#fff;border-radius:8px;font-size:.8rem;line-height:1.5;max-width:320px;min-width:250px;white-space:normal;word-wrap:break-word;z-index:10000;box-shadow:0 4px 12px #0000004d;pointer-events:auto;text-align:left}.help-buttons-tooltip:after{content:"";position:absolute;top:100%;right:20px;transform:translate(50%);border:6px solid transparent;border-top-color:#333}.lifeline-button:hover:not(:disabled) .lifeline-info-icon{background:#667eea4d;transform:scale(1.1)}.lifeline-tooltip{position:absolute;bottom:calc(100% + 12px);left:50%;transform:translate(-50%);padding:.75rem 1rem;background:#333;color:#fff;border-radius:8px;font-size:.8rem;line-height:1.5;max-width:280px;min-width:200px;white-space:normal;word-wrap:break-word;z-index:10000;box-shadow:0 4px 12px #0000004d;pointer-events:auto;text-align:left}.lifeline-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.submit-button:active{transform:translateY(0)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.error-message{margin-top:1rem;padding:1rem;background:#fee;color:#c33;border-radius:8px;font-size:.9rem}.game-status-message{margin:1rem 0;padding:1rem;border-radius:8px;font-size:1.1rem;font-weight:600;text-align:center}.game-status-message.won{background:#d4edda;color:#155724;border:none;box-shadow:none}.game-status-message.lost{background:#f8d7da;color:#721c24;border:none;box-shadow:none}.guesses-container{margin-top:2rem;width:100%;display:flex;flex-direction:column;gap:1rem}@media(prefers-color-scheme:dark){.active-game-content{background:#1e1e1ef2}.daily-song-title,.puzzle-loading-text{color:#fff}.guess-counter{color:#ccc}.instruction-text{color:#fff;background:#667eea26}.search-input{background:#ffffff1a;border-color:#444;color:#fff}.search-input::placeholder{color:#999}.search-icon{color:#999}.puzzle-page-footer{border-top-color:#444}.puzzle-footer-link{color:#9d8eff}.puzzle-footer-sep{color:#666}.seo-intro{border-top-color:#444}.seo-intro-toggle{color:#666}.seo-intro-toggle:hover{color:#9d8eff}.seo-intro-title{color:#888}.seo-intro-text{color:#777}.game-status-message.won,.game-status-message.lost{border:none;box-shadow:none}.game-status-message.won{background:#d4edda38;color:#dff5e7}}@media(max-width:768px){.active-game-container{padding:.5rem}.active-game-with-top-bar{padding-top:calc(48px + .5rem)}.active-game-content{--content-pad: 1.5rem;padding:var(--content-pad);max-width:100%}.game-header{flex-direction:column;align-items:stretch;gap:.75rem}.daily-song-title,.music-icon{font-size:1.5rem}.help-link-button,.statistics-link-button,.archive-link-button{width:auto;font-size:.7rem;padding:.3rem .6rem;white-space:nowrap}.search-container{flex-direction:column;width:100%;gap:.75rem}.search-box-wrapper{width:100%;max-width:100%;min-width:0}.submit-button{width:100%}}.share-result-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;margin-top:1rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 15px #667eea66;position:relative;overflow:hidden;animation:magicGlow 2s ease-in-out infinite}.share-result-button:before{content:"";position:absolute;top:-30%;left:-100%;width:300%;height:160%;background:radial-gradient(circle 15px at 15% 20%,rgba(255,255,255,.5) 0%,transparent 50%),radial-gradient(circle 20px at 25% 35%,rgba(255,255,255,.4) 0%,transparent 55%),radial-gradient(circle 12px at 40% 15%,rgba(255,255,255,.45) 0%,transparent 50%),radial-gradient(circle 18px at 55% 40%,rgba(255,255,255,.35) 0%,transparent 60%),radial-gradient(circle 14px at 70% 25%,rgba(255,255,255,.4) 0%,transparent 52%),radial-gradient(circle 16px at 85% 45%,rgba(255,255,255,.3) 0%,transparent 58%),radial-gradient(circle 10px at 30% 60%,rgba(255,255,255,.25) 0%,transparent 48%),radial-gradient(circle 22px at 65% 70%,rgba(255,255,255,.2) 0%,transparent 62%);animation:windBlown 4s ease-in-out infinite;pointer-events:none;z-index:1;filter:blur(2px);transform:rotate(-15deg);transform-origin:center}@keyframes windBlown{0%{left:-100%;top:-30%;transform:rotate(-15deg) translateY(0)}25%{transform:rotate(-12deg) translateY(-5px)}50%{transform:rotate(-18deg) translateY(3px)}75%{transform:rotate(-14deg) translateY(-2px)}to{left:100%;top:30%;transform:rotate(-15deg) translateY(0)}}@keyframes magicGlow{0%,to{box-shadow:0 4px 15px #667eea66;transform:scale(1)}50%{box-shadow:0 4px 20px #667eea99;transform:scale(1.02)}}.share-result-button .sparkle{position:absolute;font-size:.6rem;color:#fffc;text-shadow:0 0 4px rgba(192,192,192,.6),0 0 8px rgba(255,255,255,.4);pointer-events:none;z-index:2;opacity:0}.share-result-button .sparkle-1{top:15%;left:15%;animation:sparkleFloat1 3s ease-in-out infinite}.share-result-button .sparkle-2{top:25%;right:20%;animation:sparkleFloat2 3s ease-in-out infinite .8s}.share-result-button .sparkle-3{bottom:20%;left:30%;animation:sparkleFloat3 3s ease-in-out infinite 1.6s}@keyframes sparkleFloat1{0%,to{opacity:0;transform:translateY(0) scale(.8) rotate(0)}20%{opacity:.6}50%{opacity:1;transform:translateY(-8px) scale(1) rotate(180deg)}80%{opacity:.6}}@keyframes sparkleFloat2{0%,to{opacity:0;transform:translateY(0) scale(.8) rotate(0)}20%{opacity:.5}50%{opacity:.9;transform:translateY(-6px) scale(1) rotate(-180deg)}80%{opacity:.5}}@keyframes sparkleFloat3{0%,to{opacity:0;transform:translateY(0) scale(.8) rotate(0)}20%{opacity:.4}50%{opacity:.8;transform:translateY(-7px) scale(1) rotate(180deg)}80%{opacity:.4}}.share-result-button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 25px #667eeab3;animation:magicGlow 1s ease-in-out infinite}.share-result-button:hover:before{animation-duration:1.5s}.share-result-button:hover .sparkle{animation-duration:2s}.share-result-button:active{transform:translateY(0)}.share-icon{font-size:1.2rem;display:inline-block;position:relative;z-index:2}.share-result-button>span:not(.sparkle){position:relative;z-index:2}@media(max-width:768px){.share-result-button{padding:.6rem 1.2rem;font-size:.9rem;width:100%;justify-content:center}}.external-platform-links{margin-top:1rem;padding:0;background:transparent;border:none;border-radius:0;box-shadow:none}.external-platform-links-list{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;align-items:stretch}.external-platform-link{aspect-ratio:1 / 1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:16px;text-decoration:none;color:inherit;background:#fff6;border:1px solid rgba(255,255,255,.55);box-shadow:0 10px 28px #0000001a,inset 0 1px #fff9;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease}.external-platform-link:hover{transform:translateY(-1px);background:#ffffff80;box-shadow:0 14px 34px #00000024,inset 0 1px #ffffffb3}.external-platform-link:active{transform:translateY(0)}.external-platform-link-icon{display:inline-flex;align-items:center;justify-content:center}.external-platform-link-img{width:34px;height:34px;display:block}.external-platform-link-label{font-size:.85rem;font-weight:700;opacity:.95;white-space:nowrap}.external-platform-link--known,.external-platform-link--generic{background:#fff6}@media(prefers-color-scheme:dark){.external-platform-links{background:transparent;border:none;box-shadow:none;padding:0}.external-platform-links-list{gap:.85rem}.external-platform-link--known{background:#ffffff14;border:1px solid rgba(255,255,255,.14)}.external-platform-link--known:hover{background:#ffffff1f;border-color:#ffffff38}}.game-status-message .game-over-panel{display:flex;flex-direction:column;gap:14px;padding:18px 16px;border-radius:14px}.game-status-message .game-over-hero{display:flex;flex-direction:column;gap:10px}.game-status-message .game-over-headline{font-weight:800;font-size:18px;line-height:1.2}.game-status-message .game-over-solution{display:flex;flex-direction:column;gap:4px}.game-status-message .game-over-solution-label{font-size:12px;opacity:.75}.game-status-message .game-over-solution-title{font-weight:900;font-size:20px;line-height:1.25;letter-spacing:-.2px}.game-status-message .game-over-actions{display:flex;flex-direction:column;gap:10px}.game-status-message .game-over-save-progress{padding:12px 14px;border-radius:12px;background:#ffffff1f;border:1px solid rgba(255,255,255,.35);display:flex;flex-direction:column;gap:8px}.game-status-message .game-over-save-progress-title{font-weight:700;font-size:15px;margin:0}.game-status-message .game-over-save-progress-text{margin:0;font-size:13px;line-height:1.35;opacity:.92}.game-status-message .game-over-progress-saved{margin:0;font-size:13px;opacity:.85;font-style:italic}.game-status-message .secret-song-details{margin-top:14px;border-top:1px solid rgba(0,0,0,.1);border-top:none;width:calc(100% + 24px);max-width:none;box-sizing:border-box;margin-left:-12px;margin-right:-12px;padding:14px 16px 12px;background:#ffffff0f;border:2px solid rgba(255,255,255,.55);border-radius:16px;box-shadow:0 10px 28px #0000001a,0 0 0 1px #ffffff8c inset;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}@media(prefers-color-scheme:dark){.game-status-message .secret-song-details{background:#00000038;border:1px solid rgba(255,255,255,.1);border-top:1px solid rgba(255,255,255,.12)}}.game-status-message .secret-song-details-title{margin:0 0 10px;font-size:12px;font-weight:700;letter-spacing:.3px;text-transform:uppercase;opacity:.7}.game-status-message .secret-song-info-grid{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:8px 12px}.game-status-message .secret-song-info-item{display:flex;align-items:baseline;gap:6px;min-width:0}.game-status-message .secret-song-label{font-size:12px;font-weight:600;opacity:.65;white-space:nowrap}.game-status-message .secret-song-value{font-size:13px;font-weight:700;opacity:.95;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.game-status-message .secret-song-info-item.is-expandable{cursor:pointer}.game-status-message .secret-song-info-item.is-expandable.expanded .secret-song-value{white-space:normal;overflow:visible;text-overflow:clip}@media(max-width:420px){.game-status-message .secret-song-info-grid{grid-template-columns:1fr}}.game-status-message .secret-song-details .secret-song-info-grid{display:grid!important;grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:8px 12px}.game-status-message .secret-song-details .secret-song-info-item{grid-column:auto!important}.game-status-message .secret-song-details .secret-song-info-item.is-expandable.expanded{grid-column:1 / -1!important;align-items:flex-start}.game-status-message .secret-song-details .secret-song-info-item.is-expandable.expanded .secret-song-value{white-space:normal;overflow:visible;text-overflow:clip;display:block;line-height:1.25}.game-status-message[data-outcome=won],.game-status-message[data-outcome=lost]{border-radius:16px;overflow:hidden}.active-game-content .game-status-message{margin-left:calc(-1 * var(--content-pad));margin-right:calc(-1 * var(--content-pad));border-radius:20px}.game-status-message .feedback-result-button,.game-status-message .archive-result-button{width:100%;max-width:360px;margin:0 auto;padding:12px 14px;font-size:16px;font-weight:800;border-radius:12px;border:2px solid rgba(255,255,255,.35);background:#ffffff1a;color:inherit;cursor:pointer;transition:transform .12s ease,background-color .12s ease,opacity .12s ease}.game-status-message .feedback-result-button:active,.game-status-message .archive-result-button:active{transform:scale(.98)}.game-status-message .feedback-result-button:hover,.game-status-message .archive-result-button:hover{background:#ffffff29}.game-status-message .archive-result-button{display:inline-flex;align-items:center;justify-content:center;gap:10px}.game-status-message .archive-result-icon{width:28px;height:28px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;font-size:20px;line-height:1;background:#ffffff3d;box-shadow:0 0 0 1px #ffffff59 inset,0 1px 4px #00000038}.game-status-message .share-result-button{width:100%;max-width:520px;border:0;border-radius:999px;padding:16px 22px;font-weight:800;font-size:18px;letter-spacing:.2px;background:linear-gradient(90deg,#2dd4ff,#7c3aed 45%,#ff4fd8);color:#fff;box-shadow:0 10px 30px #7c3aed59,0 0 0 2px #fff3 inset;position:relative;overflow:hidden;transform:translateZ(0)}.game-status-message .share-result-button:before{content:"";position:absolute;inset:-40% -20%;background:radial-gradient(circle at 20% 20%,#ffffff8c,#ffffff26 35%,#fff0 60%);transform:rotate(-12deg);pointer-events:none}.game-status-message .share-result-button:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 12% 35%,rgba(255,255,255,.55) 0 2px,transparent 3px),radial-gradient(circle at 85% 30%,rgba(255,255,255,.45) 0 2px,transparent 3px),radial-gradient(circle at 70% 70%,rgba(255,255,255,.35) 0 1.5px,transparent 3px);opacity:.7;pointer-events:none}.game-status-message .share-result-button:hover{filter:brightness(1.04)}.game-status-message .share-result-button:active{transform:scale(.99)}.game-status-message .secret-song-info-item{align-items:center;gap:8px}.game-status-message .secret-song-info-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px;opacity:.9;line-height:1}.game-status-message .secret-song-info-item{align-items:center}.game-status-message .secret-song-info-icon{width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 18px;opacity:.9}.game-status-message .secret-song-info-icon img{width:18px;height:18px;display:block}.game-status-message .secret-song-flag{font-size:16px;transform:translateY(.5px)}@media(prefers-color-scheme:dark){.game-status-message[data-outcome=won],.game-status-message[data-outcome=lost]{box-shadow:0 18px 50px #0000008c,0 0 0 1px #ffffff0f inset}.game-status-message .game-over-panel{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);box-shadow:0 10px 28px #00000073,0 0 0 1px #ffffff14 inset}.game-status-message .game-over-headline,.game-status-message .game-over-solution-title{color:#ffffffeb}.game-status-message .game-over-solution-label{color:#ffffffb3}.game-status-message .secret-song-details{background:#ffffff0f;border:1px solid rgba(255,255,255,.14);box-shadow:0 6px 18px #00000059,0 0 0 1px #ffffff0f inset}.game-status-message .secret-song-details-title{color:#ffffffb3;opacity:1}.game-status-message .secret-song-label{color:#ffffffad;opacity:1}.game-status-message .secret-song-value{color:#ffffffeb;opacity:1}.game-status-message .secret-song-info-item{background:#ffffff0d;border-radius:10px}.game-status-message .secret-song-info-item.is-expandable{outline:1px solid rgba(255,255,255,.08)}.game-status-message .secret-song-info-item.is-expandable:active{background:#ffffff14}.game-status-message .archive-result-icon{background:transparent;box-shadow:none;filter:grayscale(1) brightness(2.5) contrast(.9);text-shadow:0 0 8px rgba(255,255,255,.22)}}@media(prefers-color-scheme:dark){.game-status-message .game-over-panel{background:transparent!important;box-shadow:none!important;border:0!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important}}.statistics-page-container{position:fixed;inset:0;min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;padding-top:max(2rem,env(safe-area-inset-top));padding-bottom:max(2rem,env(safe-area-inset-bottom));background:linear-gradient(135deg,#667eea,#764ba2);z-index:1000;overflow-y:auto;-webkit-overflow-scrolling:touch}.statistics-page-content{width:100%;max-width:900px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:2rem;position:relative}.statistics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0}.statistics-title{font-size:2rem;font-weight:700;color:#333;margin:0}.statistics-loading,.statistics-error{text-align:center;padding:3rem 1rem;color:#666}.statistics-error{color:#ef4444}.statistics-content{display:flex;flex-direction:column;gap:2rem}.statistics-section{display:flex;flex-direction:column;gap:1rem}.section-title{font-size:1.5rem;font-weight:600;color:#333;margin:0;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;padding:1.5rem;text-align:center;color:#fff;box-shadow:0 4px 6px #0000001a}.stat-value{font-size:2.5rem;font-weight:700;margin-bottom:.5rem}.stat-label{font-size:.9rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.wins-distribution{display:flex;flex-direction:column;gap:1rem}.distribution-item{display:flex;align-items:center;gap:1rem}.distribution-label{min-width:120px;font-weight:500;color:#333}.distribution-bar-container{flex:1;height:24px;background:#f0f0f0;border-radius:12px;overflow:hidden;position:relative}.distribution-bar{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:12px;transition:width .3s ease}.distribution-value{min-width:40px;text-align:right;font-weight:600;color:#333}.history-info{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;justify-content:space-between;padding:.75rem;background:#f8f9fa;border-radius:8px}.history-label{font-weight:500;color:#666}.history-value{font-weight:600;color:#333}.badges-section{margin-top:0}.badges-loading,.badges-error,.badges-empty{grid-column:1 / -1;text-align:center;padding:1.5rem;color:#666}.badges-error{color:#ef4444}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem;overflow:visible}.badge-card{position:relative;display:flex;flex-direction:column;align-items:center;overflow:visible}.badge-card-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem;background:#f8f9fa;border-radius:16px;box-shadow:0 2px 12px #00000014;width:100%;--badgeSize: 200px;--iconScale: .45;min-width:150px;max-width:max-content}.badge-frame-container{position:relative;width:var(--badgeSize);height:var(--badgeSize);display:grid;place-items:center;filter:drop-shadow(0 4px 8px rgba(0,0,0,.15))}.badge-frame{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;z-index:0}.badge-icon-wrapper{width:calc(var(--badgeSize) * var(--iconScale));height:calc(var(--badgeSize) * var(--iconScale));left:50%;top:50%;transform:translate(-50%,-50%);position:absolute;display:grid;place-items:center;z-index:1}.badge-icon{display:block;width:100%;height:100%;object-fit:contain;object-position:center;padding:2px;box-sizing:border-box}.badge-frame-container{position:relative}.badge-tier-number{position:absolute;left:50%;bottom:7%;transform:translate(-50%);z-index:4;pointer-events:none;width:calc(var(--badgeSize) * .26);height:calc(var(--badgeSize) * .26);border-radius:999px;display:grid;place-items:center;background:radial-gradient(circle at 30% 30%,#fff5c8,#ffe08a 22%,#f5c24a 48%,#d89a22 72%,#a86a08);border:calc(var(--badgeSize) * .014) solid rgba(120,70,0,.8);box-shadow:0 10px 18px #00000052,inset 0 4px #fff9,inset 0 -5px #78460061;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px)}.badge-tier-number{font-weight:900;font-size:calc(var(--badgeSize) * .13);line-height:1;color:#fff;-webkit-text-stroke:calc(var(--badgeSize) * .01) rgba(70,35,0,.85);text-shadow:0 2px 0 rgba(0,0,0,.25),0 6px 10px rgba(0,0,0,.25)}@media(max-width:768px){.badges-grid{grid-template-columns:repeat(2,1fr)}.badge-card-inner{--badgeSize: 120px;min-width:140px;max-width:220px;padding:.75rem}}.badge-short-name{font-weight:600;font-size:.95rem;color:#333;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;line-height:1.3}.badge-tier-pill{display:inline-block;padding:.2rem .6rem;font-size:.75rem;font-weight:500;color:#555;background:#f0f0f0;border-radius:999px}.badge-progress-section{width:100%;display:flex;flex-direction:column;gap:.25rem}.badge-progress-bar{height:8px;background:#e8e8e8;border-radius:4px;overflow:hidden}.badge-progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;transition:width .3s ease}.badge-progress-labels{display:flex;justify-content:space-between;align-items:center;font-size:.75rem}.badge-progress-left{font-weight:500;color:#333}.badge-progress-right{color:#777}.badge-info-icon{display:none;position:absolute;top:.5rem;right:.5rem;width:20px;height:20px;border-radius:50%;border:1px solid #ccc;background:#fff;color:#666;font-size:.75rem;font-weight:700;cursor:pointer;padding:0;line-height:1;font-style:italic}.badge-mobile-tooltip{position:absolute;top:calc(.75rem + 28px);right:.5rem;left:.5rem;padding:.75rem 1rem;background:#333;color:#fff;font-size:.85rem;border-radius:8px;max-width:280px;z-index:10;box-shadow:0 4px 12px #0003}@media(max-width:768px){.badge-info-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px}}@media(min-width:769px){.badge-info-icon{display:none}}.statistics-footer{margin-top:1rem;padding-top:1.5rem;border-top:2px solid #f0f0f0;display:flex;justify-content:center}.back-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a}.back-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #00000026}.back-button:active{transform:translateY(0)}@media(max-width:768px){.statistics-page-container{padding:1rem .5rem}.statistics-page-content{padding:1.5rem;border-radius:12px}.statistics-title{font-size:1.5rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem}.stat-value{font-size:2rem}.section-title{font-size:1.25rem}.distribution-label{min-width:100px;font-size:.9rem}.distribution-value{min-width:30px;font-size:.9rem}.badges-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.badge-card-inner{padding:.75rem;min-width:140px}}@media(prefers-color-scheme:dark){.statistics-page-content{background:#1e1e1ef2;color:#fff}.statistics-title{color:#fff}.section-title{color:#fff;border-bottom-color:#ffffff1a}.distribution-label,.distribution-value{color:#fff}.distribution-bar-container{background:#ffffff1a}.history-item{background:#ffffff0d}.history-label{color:#aaa}.history-value{color:#fff}.badges-loading,.badges-empty{color:#aaa}.badge-card-inner{background:#ffffff14;box-shadow:0 2px 12px #0003}.badge-short-name{color:#fff}.badge-tier-pill{color:#ccc;background:#ffffff1a}.badge-progress-bar{background:#ffffff26}.badge-progress-left{color:#fff}.badge-progress-right{color:#999}.badge-info-icon{background:#ffffff1a;border-color:#fff3;color:#ccc}.badge-mobile-tooltip{background:#444;color:#fff}.statistics-footer{border-top-color:#ffffff1a}}.help-page-container{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding:1rem;padding-top:max(1rem,env(safe-area-inset-top));padding-bottom:max(1rem,env(safe-area-inset-bottom));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));overflow-y:auto;cursor:pointer;-webkit-overflow-scrolling:touch}.help-page-content{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;position:relative;padding:2rem;padding-top:max(2rem,env(safe-area-inset-top));animation:slideIn .3s ease-out;cursor:default;margin-top:0;flex-shrink:0;-webkit-overflow-scrolling:touch}.help-page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;padding-top:calc(1rem + env(safe-area-inset-top,0px));border-bottom:2px solid #e0e0e0;position:sticky;top:0;background:#fff;z-index:1;margin:-2rem -2rem 1rem;padding-left:2rem;padding-right:2rem}.help-page-title{font-size:2rem;font-weight:700;color:#333;margin:0;display:flex;align-items:center;gap:.5rem}.help-icon{font-size:2rem}.help-close-button{flex-shrink:0}.help-subtitle{font-size:1.2rem;color:#667eea;font-weight:600;text-align:center;margin:0 0 2rem}.help-sections{display:flex;flex-direction:column;gap:1.5rem}.help-section{background:#f8f9fa;border-radius:12px;padding:1.5rem;border-left:4px solid #667eea;transition:transform .2s ease,box-shadow .2s ease}.help-section:hover{transform:translate(4px);box-shadow:0 4px 12px #0000001a}.help-section-title{font-size:1.3rem;font-weight:700;color:#333;margin:0 0 .75rem;display:flex;align-items:center;gap:.5rem}.section-icon{font-size:1.5rem}.help-section-content{color:#555;line-height:1.7}.help-paragraph{margin:.5rem 0;font-size:1rem}.help-paragraph:first-child{margin-top:0}.help-paragraph:last-child{margin-bottom:0}.help-footer{text-align:center;margin:2rem 0 1.5rem;padding-top:1.5rem;border-top:2px solid #e0e0e0;font-size:1.1rem;color:#667eea;font-weight:600}.help-actions{display:flex;justify-content:center;margin-top:1.5rem}.help-back-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.help-back-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.help-back-button:active{transform:translateY(0)}@media(max-width:768px){.help-page-content{padding:1.5rem;max-height:95vh}.help-page-header{margin-left:-1.5rem;margin-right:-1.5rem;margin-top:-1.5rem;padding-left:1.5rem;padding-right:1.5rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px))}.help-page-title,.help-icon{font-size:1.5rem}.help-subtitle{font-size:1rem}.help-section{padding:1rem}.help-section-title{font-size:1.1rem}.help-paragraph{font-size:.9rem}.help-back-button{padding:.65rem 1.5rem;font-size:.9rem}}@media(prefers-color-scheme:dark){.help-page-content{background:#1a1a1a;color:#e0e0e0}.help-page-title{color:#fff}.help-section{background:#2a2a2a;border-left-color:#667eea}.help-section-title{color:#fff}.help-section-content{color:#ccc}.help-page-header{border-bottom-color:#444;background:#1a1a1a}.help-footer{border-top-color:#444}}.archive-page{min-height:100vh;background:radial-gradient(circle at 18% 15%,#ffffff47,#fff0 38%),radial-gradient(circle at 82% 8%,#99d6ff3d,#99d6ff00 34%),linear-gradient(140deg,#4f64d7,#6f51b7 52%,#8653a2);padding:2rem;display:flex;flex-direction:column}.archive-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.archive-header h1{color:#fff;font-size:2rem;margin:0;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.archive-header .app-close-button{background:#fff3;color:#fff}.archive-header .app-close-button:hover{background:#ffffff4d}.archive-content{flex:1;background:linear-gradient(150deg,#fffffff0,#f7f9ffe6);border:1px solid rgba(255,255,255,.6);border-radius:16px;padding:2rem;box-shadow:0 16px 44px #23174f42,inset 0 1px #ffffffb8;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow-y:auto}.archive-recommended{margin-bottom:1rem;padding:.9rem 1rem;border-radius:14px;border:1px solid rgba(91,120,214,.24);background:linear-gradient(165deg,#fffffff0,#eef4ffe0);box-shadow:inset 0 1px #ffffffd9,0 8px 18px #394a821a}.recommended-header{margin-bottom:.5rem}.recommended-title{font-size:.95rem;font-weight:700;color:#2f3c73}.recommended-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:.8rem;padding:.56rem .65rem;border-radius:10px;border:1px solid transparent;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.recommended-item:hover{background:#7b92e31f;border-color:#677ac740;transform:translateY(-1px)}.recommended-item.primary{background:#748fe51a;border-color:#6580d747}.recommended-date{font-weight:700;color:#2f3157}.recommended-difficulty{color:#c37c00;font-weight:700;letter-spacing:.01em}.recommended-play{border:0;border-radius:999px;padding:.34rem .72rem;font-size:.8rem;font-weight:700;color:#fff;background:linear-gradient(180deg,#5f79e7,#4b65d8);box-shadow:0 4px 10px #4359b847;cursor:pointer}.recommended-play.secondary{color:#4861c8;background:#536cc81f;box-shadow:none;padding:.22rem .52rem}.recommended-expand{margin-top:.35rem}.recommended-toggle{border:0;background:transparent;color:#4c63c7;font-size:.82rem;font-weight:700;cursor:pointer;padding:.2rem .1rem}.recommended-list{margin-top:.2rem;display:flex;flex-direction:column;gap:.2rem}.archive-legend{display:flex;flex-wrap:wrap;gap:1.5rem 2rem;margin-bottom:2rem;padding:1rem 1.25rem 1.2rem;border-radius:14px;border:1px solid rgba(111,81,183,.18);background:linear-gradient(160deg,#ffffffd1,#eef3ffb8);box-shadow:inset 0 1px #ffffffe6,0 8px 24px #46367e1f}.legend-section{display:flex;flex-wrap:wrap;align-items:center;gap:.75rem 1rem}.legend-title{font-size:.78rem;font-weight:700;color:#5d5d7a;text-transform:uppercase;letter-spacing:.06em;margin-right:.25rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#333}.status-indicator{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.difficulty-indicator{min-width:32px;display:inline-flex;justify-content:center;color:#f2af2f;font-size:.82rem;letter-spacing:.08em;text-shadow:0 1px 0 #fff6db,0 1px 6px rgba(194,130,0,.25)}.archive-calendars{display:flex;flex-direction:column;gap:2rem}.calendar-month{margin-bottom:2rem}.month-header{font-size:1.5rem;font-weight:600;color:#2c2d56;margin-bottom:1.5rem;text-align:center;text-shadow:0 1px 0 rgba(255,255,255,.45)}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;background:linear-gradient(180deg,#d7def9,#c7d1f5);border:1px solid rgba(117,124,180,.35);border-radius:10px;overflow:visible;box-shadow:0 8px 16px #34295c1f}.calendar-day-name{background:linear-gradient(180deg,#f7f9ff,#edf2ff);padding:.58rem;text-align:center;font-weight:600;font-size:.85rem;color:#5d6486;border-bottom:1px solid rgba(123,132,178,.28)}.calendar-day{background:linear-gradient(180deg,#fff,#f8faff);min-height:70px;padding:.35rem .25rem .28rem;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;position:relative;cursor:default;transition:transform .18s ease,box-shadow .18s ease,background .2s ease}.calendar-day:before{content:"";position:absolute;left:8%;right:8%;top:5px;height:38%;border-radius:12px;background:linear-gradient(180deg,#ffffff9e,#fff0);pointer-events:none}.calendar-day.empty{background:linear-gradient(180deg,#f3f6ff,#edf2ff);cursor:default}.calendar-day.clickable{cursor:pointer}.calendar-day.clickable:hover{background:linear-gradient(180deg,#fff,#eef3ff);z-index:1;box-shadow:inset 0 1px #ffffffe6,0 8px 14px #2c32642e;transform:translateY(-1px)}.calendar-day.status-won{background:linear-gradient(180deg,#e8f5e9,#c8e6c9)}.calendar-day.status-lost{background:linear-gradient(180deg,#ffebee,#ffcdd2)}.calendar-day.status-abandoned{background:linear-gradient(180deg,#fff7e8,#ffefd0)}.calendar-day.status-not-played{background:linear-gradient(180deg,#fff,#f7f9ff)}.calendar-day.status-no-puzzle{background:linear-gradient(180deg,#f1f4fb,#e9eef8)}.calendar-day.status-unavailable{background:linear-gradient(180deg,#eff2f8,#e6eaf4);opacity:.62;cursor:not-allowed}.calendar-day.today{box-shadow:inset 0 0 0 2px #5870e6;font-weight:600}.calendar-day.today .day-number{color:#667eea;font-size:.92rem}.calendar-day.status-unavailable .day-number{color:#999}.day-number{font-size:.82rem;font-weight:600;color:#2f3157;margin-top:.25rem;z-index:1}.day-status-icon{display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;margin-top:.12rem;line-height:1;z-index:1}.day-status-icon-won{position:relative;width:22px;height:22px;border-radius:999px;overflow:hidden;background:radial-gradient(circle at 30% 25%,#ffe59a,#f7c84f 58%,#de9d1f);box-shadow:inset 0 1px #ffffffbf,0 2px 7px #b0791361}.won-icon-glyph{position:absolute;left:50%;top:50%;transform:translate(-43%,-30%);font-size:14px;line-height:1;display:block;filter:drop-shadow(0 1px 0 rgba(255,255,255,.5))}.day-status-icon-lost{color:#cd6b7f}.day-status-icon-abandoned{color:#d58500}.day-difficulty-stars{font-size:.8rem;line-height:1;margin-top:auto;padding-top:.2rem;color:#eea72d;letter-spacing:.03em;text-shadow:0 1px 0 #fff4d4;z-index:1;white-space:nowrap}.calendar-day.status-won .day-difficulty-stars{color:#d1860e}.calendar-day.status-unavailable .day-difficulty-stars{color:#b8b8b8;text-shadow:none}.calendar-day.has-difficulty.status-not-played .day-difficulty-stars,.calendar-day.has-difficulty.status-abandoned .day-difficulty-stars,.calendar-day.has-difficulty.status-lost .day-difficulty-stars{color:#f0aa31;filter:drop-shadow(0 0 1px rgba(214,137,0,.18))}.status-indicator.status-won{background:radial-gradient(circle at 30% 30%,#ffdd78,#f5ba3d 55%,#dd9f18);color:#fff}.legend-won-glyph{font-size:13px;line-height:1}.status-indicator.status-lost{background:#f1a5b3;color:#fff}.status-indicator.status-abandoned{background:linear-gradient(180deg,#fffdfa,#fff7eb);border:2px dashed #d8ad64;color:transparent}.status-indicator.status-not-played{background:linear-gradient(180deg,#fff,#f5f8ff);border:2px solid #5b648c;color:transparent}.status-indicator.status-unavailable{background:#d8deee;color:transparent;opacity:.6}.status-indicator.status-no-puzzle{background:linear-gradient(180deg,#edf2fb,#e4eaf7);border:1px solid #c5cee2;color:transparent}.calendar-day.status-won.streak-right:after{content:"";position:absolute;top:34px;right:-3px;width:10px;height:18px;background:linear-gradient(90deg,#91d2a233,#91d2a275);border-radius:12px;pointer-events:none}.calendar-day.status-won.streak-left{border-left:2px solid #c8e6c9;box-shadow:none}.calendar-day.today.streak-left{box-shadow:inset 0 0 0 2px #5870e6}.error-message{color:#f44336;text-align:center;padding:2rem}@media(max-width:768px){.archive-page{padding:1rem}.archive-header h1{font-size:1.5rem}.archive-content{padding:1rem}.archive-recommended{padding:.75rem .8rem}.recommended-item{gap:.45rem;padding:.5rem}.recommended-difficulty{font-size:.88rem}.recommended-play{padding:.28rem .56rem;font-size:.75rem}.archive-legend{gap:.9rem 1rem;padding:.85rem .9rem}.legend-section{gap:.55rem .7rem}.legend-title{width:100%;margin-right:0;margin-bottom:.15rem}.month-header{font-size:1.2rem}.calendar-day{min-height:56px;padding:.24rem .2rem .2rem}.day-number{font-size:.8rem}.day-status-icon-lost,.day-status-icon-abandoned{font-size:.6rem}.day-status-icon-won,.won-icon-glyph{width:20px;height:20px}.won-icon-glyph{font-size:13px}.day-difficulty-stars{font-size:.78rem}.calendar-day-name{font-size:.75rem;padding:.4rem}.legend-item{font-size:.8rem}.status-indicator{width:20px;height:20px;font-size:.8rem}.difficulty-indicator{min-width:24px;font-size:.74rem}}.settings-page-container{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;overflow-y:auto}.settings-page-content{background:#fff;border-radius:16px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 10px 40px #0000004d;position:relative;padding:2rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.settings-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.settings-page-title{font-size:2rem;font-weight:700;color:#333;margin:0;display:flex;align-items:center;gap:.5rem}.settings-icon{font-size:2rem}.settings-sections{display:flex;flex-direction:column;gap:1.5rem;padding:.5rem 0}.settings-account-block{padding:1rem 0 1.25rem;border-bottom:1px solid #e8e8e8}.settings-account-heading{font-size:.85rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#666;margin-bottom:.65rem}.settings-account-body{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.settings-account-line{font-weight:600;color:#222;font-size:1rem}.settings-account-email{font-size:.85rem;color:#666}.settings-account-hint{font-size:.8rem;color:#888;margin-bottom:.25rem}.settings-account-blurb{margin:0 0 .35rem;font-size:.95rem;color:#444;line-height:1.35}.settings-account-error{font-size:.85rem;color:#c0392b;margin-top:.35rem}.settings-sign-out-button{padding:.45rem 1rem;font-size:.9rem;border:1px solid #ccc;border-radius:8px;background:#fff;cursor:pointer;font-family:inherit;color:#333}.settings-sign-out-button:hover:not(:disabled){background:#f5f5f5}.settings-sign-out-button:disabled{opacity:.7}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;padding:1rem 0;border-bottom:1px solid #f0f0f0;flex-wrap:nowrap}.settings-row:last-of-type{border-bottom:none}.settings-row-display-name{flex-direction:column;align-items:stretch;gap:.5rem}.settings-display-name-label{display:inline-flex;align-items:center;gap:.35rem;flex-wrap:wrap}.settings-display-name-info-wrapper{position:relative;display:inline-flex}.settings-display-name-tooltip{position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%);padding:.5rem .75rem;background:#333;color:#fff;border-radius:8px;font-size:.85rem;line-height:1.4;max-width:280px;z-index:10001;box-shadow:0 4px 12px #0000004d;pointer-events:auto;white-space:normal}.settings-display-name-tooltip:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-top-color:#333}.settings-display-name-info-icon{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:#667eea26;color:#667eea;font-size:.65rem;font-weight:600;cursor:help;flex-shrink:0;-webkit-user-select:none;user-select:none}.settings-display-name-info-icon:hover{background:#667eea40}.settings-display-name-controls{display:flex;gap:.5rem;align-items:center}.settings-display-name-input{flex:1;min-width:0;padding:.5rem .75rem;font-size:.95rem;border:1px solid #e0e0e0;border-radius:8px}.settings-display-name-input:focus{outline:none;border-color:#667eea}.settings-display-name-save{padding:.5rem 1rem;font-size:.9rem;font-weight:600;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;flex-shrink:0}.settings-display-name-save:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 8px #667eea4d}.settings-display-name-save:disabled{opacity:.7;cursor:not-allowed}.settings-display-name-error{font-size:.85rem;color:#ef4444}.settings-display-name-success{font-size:.85rem;color:#22c55e}.settings-label{font-size:.95rem;font-weight:500;color:#555;letter-spacing:.01em;flex-shrink:0;min-width:140px}.settings-display-name-label.settings-label{min-width:0}.settings-options{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.settings-option{background:#f8f9fa;border:1.5px solid #e0e0e0;font-size:.9rem;color:#666;cursor:pointer;padding:.5rem 1rem;border-radius:6px;transition:all .2s ease;font-family:inherit;display:flex;align-items:center;gap:.5rem;min-width:60px;justify-content:center;font-weight:500}.settings-option:hover{background-color:#f0f0f0;border-color:#d0d0d0;color:#333;transform:translateY(-1px);box-shadow:0 2px 4px #0000000d}.settings-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;font-weight:600;box-shadow:0 2px 8px #667eea4d}.settings-option.selected:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);border-color:#5a6fd8;transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.option-text{font-weight:inherit}.option-indicator{font-size:.85rem;opacity:.8}.settings-actions{display:flex;justify-content:center;margin-top:1.5rem}.settings-back-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:.75rem 2rem;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #667eea66}.settings-back-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea99}.settings-back-button:active{transform:translateY(0)}@media(max-width:768px){.settings-page-content{padding:1.5rem;max-height:95vh}.settings-page-title,.settings-icon{font-size:1.5rem}.settings-row{flex-direction:row;justify-content:space-between;gap:1rem;padding:.75rem 0}.settings-row-display-name{flex-direction:column;align-items:stretch}.settings-label{font-size:.9rem;min-width:100px}.settings-option{font-size:.85rem;padding:.4rem .75rem;min-width:50px}.option-indicator{font-size:.75rem}.settings-back-button{padding:.65rem 1.5rem;font-size:.9rem}}@media(prefers-color-scheme:dark){.settings-page-content{background:#1a1a1a;color:#e0e0e0}.settings-page-title{color:#fff}.settings-row{border-bottom-color:#333}.settings-label{color:#ccc}.settings-display-name-info-icon{background:#667eea40;color:#a5b4fc}.settings-display-name-info-icon:hover{background:#667eea59}.settings-display-name-tooltip{background:#2a2a2a;color:#e0e0e0}.settings-display-name-tooltip:after{border-top-color:#2a2a2a}.settings-option{background:#2a2a2a;border-color:#444;color:#aaa}.settings-option:hover{background-color:#333;border-color:#555;color:#e0e0e0}.settings-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff}.settings-option.selected:hover{background:linear-gradient(135deg,#5a6fd8,#6a4190);border-color:#5a6fd8}.settings-page-header{border-bottom-color:#444}}.leaderboards-page-container{min-height:100vh;display:flex;justify-content:center;align-items:flex-start;padding:2rem 1rem;padding-top:max(2rem,env(safe-area-inset-top));padding-bottom:max(2rem,env(safe-area-inset-bottom));padding-left:max(1rem,env(safe-area-inset-left));padding-right:max(1rem,env(safe-area-inset-right));background:linear-gradient(135deg,#667eea,#764ba2);overflow-y:auto;-webkit-overflow-scrolling:touch}.leaderboards-page-content{width:100%;max-width:900px;background:#fff;border-radius:16px;box-shadow:0 10px 40px #0003;padding:2rem;position:relative}.leaderboards-page-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:1rem;border-bottom:2px solid #f0f0f0;position:sticky;top:0;background:#fff;z-index:1;padding-top:calc(1rem + env(safe-area-inset-top,0px));margin:-2rem -2rem 2rem;padding-left:2rem;padding-right:2rem}.leaderboards-page-title{font-size:2rem;font-weight:700;color:#333;margin:0;display:flex;align-items:center;gap:.5rem}.leaderboards-icon{font-size:2rem}@media(max-width:768px){.leaderboards-page-container{padding:1rem .5rem;padding-top:max(1rem,env(safe-area-inset-top));padding-bottom:max(1rem,env(safe-area-inset-bottom))}.leaderboards-page-content{padding:1.5rem;border-radius:12px}.leaderboards-page-header{margin-top:-1.5rem;margin-left:-1.5rem;margin-right:-1.5rem;padding-left:1.5rem;padding-right:1.5rem;padding-top:calc(.75rem + env(safe-area-inset-top,0px))}.leaderboards-page-title{font-size:1.5rem}}.privacy-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.privacy-content{max-width:700px;width:100%;padding:2rem;background:#fffffff2;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow-y:auto}.privacy-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.privacy-title{font-size:1.8rem;font-weight:700;color:#333;margin:0}.privacy-body{color:#444;font-size:.95rem;line-height:1.7}.privacy-updated{color:#888;font-size:.85rem;font-style:italic;margin-bottom:1.5rem}.privacy-body section{margin-bottom:1.5rem}.privacy-body h2{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 .5rem}.privacy-body p{margin:0 0 .75rem}.privacy-body ul{margin:.5rem 0;padding-left:1.5rem}.privacy-body li{margin-bottom:.5rem}.privacy-body a{color:#667eea;text-decoration:none}.privacy-body a:hover{text-decoration:underline}.privacy-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee}.privacy-back-button{padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;color:#667eea;background:#fff;border:2px solid #667eea;border-radius:20px;cursor:pointer;transition:all .2s}.privacy-back-button:hover{background:#667eea;color:#fff}@media(prefers-color-scheme:dark){.privacy-content{background:#1e1e1ef2}.privacy-header{border-bottom-color:#444}.privacy-title{color:#fff}.privacy-body{color:#ccc}.privacy-body h2{color:#fff}.privacy-updated{color:#888}.privacy-footer{border-top-color:#444}}@media(max-width:768px){.privacy-container{padding:1rem}.privacy-content{padding:1.5rem}.privacy-title{font-size:1.5rem}}.about-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.about-content{max-width:700px;width:100%;padding:2rem;background:#fffffff2;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow-y:auto}.about-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.about-title{font-size:1.8rem;font-weight:700;color:#333;margin:0}.about-body{color:#444;font-size:.95rem;line-height:1.7}.about-body section{margin-bottom:1.5rem}.about-body h2{font-size:1.1rem;font-weight:600;color:#333;margin:0 0 .5rem}.about-body p{margin:0 0 .75rem}.about-body ul{margin:.5rem 0;padding-left:1.5rem}.about-body li{margin-bottom:.5rem}.about-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee;display:flex;flex-direction:column;align-items:center;gap:1rem}.about-play-button{display:inline-block;padding:.75rem 2rem;font-size:1rem;font-weight:600;color:#fff;background:#667eea;border-radius:20px;text-decoration:none;transition:all .2s}.about-play-button:hover{background:#5568d3}.about-links{font-size:.9rem}.about-links a{color:#667eea;text-decoration:none}.about-links a:hover{text-decoration:underline}.about-sep{color:#999}.about-back-button{padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;color:#667eea;background:#fff;border:2px solid #667eea;border-radius:20px;cursor:pointer;transition:all .2s}.about-back-button:hover{background:#667eea;color:#fff}@media(prefers-color-scheme:dark){.about-content{background:#1e1e1ef2}.about-header{border-bottom-color:#444}.about-title{color:#fff}.about-body{color:#ccc}.about-body h2{color:#fff}.about-footer{border-top-color:#444}}@media(max-width:768px){.about-container{padding:1rem}.about-content{padding:1.5rem}.about-title{font-size:1.5rem}}.faq-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.faq-content{max-width:700px;width:100%;padding:2rem;background:#fffffff2;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow-y:auto}.faq-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #eee}.faq-title{font-size:1.8rem;font-weight:700;color:#333;margin:0}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{border:1px solid #e0e0e0;border-radius:12px;overflow:hidden}.faq-question{width:100%;padding:1rem 1.25rem;text-align:left;font-size:1rem;font-weight:600;color:#333;background:#fff;border:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;transition:background .2s}.faq-question:hover{background:#f8f8f8}.faq-toggle{font-size:1.25rem;color:#667eea;flex-shrink:0}.faq-answer{padding:0 1.25rem 1rem;color:#555;line-height:1.6;font-size:.95rem}.faq-footer{margin-top:2rem;padding-top:1rem;border-top:1px solid #eee;display:flex;flex-direction:column;align-items:center;gap:1rem}.faq-footer p{margin:0;color:#666;font-size:.95rem}.faq-footer a{color:#667eea;text-decoration:none}.faq-footer a:hover{text-decoration:underline}.faq-back-button{padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;color:#667eea;background:#fff;border:2px solid #667eea;border-radius:20px;cursor:pointer;transition:all .2s}.faq-back-button:hover{background:#667eea;color:#fff}@media(prefers-color-scheme:dark){.faq-content{background:#1e1e1ef2}.faq-header{border-bottom-color:#444}.faq-title{color:#fff}.faq-item{border-color:#444}.faq-question{background:#28282880;color:#fff}.faq-question:hover{background:#32323280}.faq-answer{color:#ccc}.faq-footer{border-top-color:#444}.faq-footer p{color:#aaa}}@media(max-width:768px){.faq-container{padding:1rem}.faq-content{padding:1.5rem}.faq-title{font-size:1.5rem}}.feedback-modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:1000;padding:0;overflow-y:auto;animation:feedback-fadeIn .2s ease-out;-webkit-overflow-scrolling:touch}@keyframes feedback-fadeIn{0%{opacity:0}to{opacity:1}}.feedback-modal-panel{background:#fff;border-radius:16px 16px 0 0;max-width:500px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 -4px 20px #0003;animation:feedback-slideUp .3s ease-out;flex-shrink:0;margin-top:auto;-webkit-overflow-scrolling:touch}@keyframes feedback-slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.feedback-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:2px solid #e0e0e0;flex-shrink:0;position:sticky;top:0;background:#fff;z-index:1}.feedback-modal-title{font-size:1.5rem;font-weight:700;color:#333;margin:0;display:flex;align-items:center;gap:.5rem}.feedback-modal-icon{font-size:1.5rem}.feedback-modal-body{padding:1rem 1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1rem}.feedback-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;overflow:hidden;pointer-events:none}.feedback-field{display:flex;flex-direction:column;gap:.35rem}.feedback-field label{font-size:.9rem;font-weight:600;color:#333}.feedback-field select,.feedback-field input[type=email],.feedback-field textarea{padding:.6rem .75rem;border:1px solid #ddd;border-radius:8px;font-size:1rem;font-family:inherit;background:#fff}.feedback-field textarea{min-height:120px;resize:vertical}.feedback-char-count{font-size:.75rem;color:#666;align-self:flex-end}.feedback-screenshot-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.feedback-file-input{font-size:.9rem}.feedback-screenshot-preview{position:relative;width:80px;height:80px}.feedback-screenshot-preview img{width:80px;height:80px;object-fit:cover;border-radius:8px;border:1px solid #ddd}.feedback-remove-screenshot{position:absolute;top:-6px;right:-6px;width:24px;height:24px;border-radius:50%;background:#e74c3c;color:#fff;border:none;font-size:1.2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}.feedback-remove-screenshot:hover:not(:disabled){background:#c0392b}.feedback-error{padding:.75rem;background:#fee;color:#c00;border-radius:8px;font-size:.9rem}.feedback-submit-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:opacity .2s;align-self:flex-start}.feedback-submit-button:hover:not(:disabled){opacity:.9}.feedback-submit-button:disabled{opacity:.7;cursor:not-allowed}@media(min-width:769px){.feedback-modal-backdrop{align-items:center;padding:1rem}.feedback-modal-panel{border-radius:16px;margin-top:0;max-height:85vh}}@media(prefers-color-scheme:dark){.feedback-modal-panel{background:#1a1a1a}.feedback-modal-header{background:#1a1a1a;border-color:#444}.feedback-modal-title,.feedback-field label{color:#e0e0e0}.feedback-field select,.feedback-field input[type=email],.feedback-field textarea{background:#2a2a2a;border-color:#444;color:#e0e0e0}.feedback-char-count{color:#999}.feedback-screenshot-preview img{border-color:#444}}.toast-container{position:fixed;bottom:max(1rem,env(safe-area-inset-bottom));left:50%;transform:translate(-50%);z-index:2000;display:flex;flex-direction:column;gap:.5rem;pointer-events:none;max-width:calc(100% - 2rem)}.toast-item{padding:.75rem 1.25rem;background:#282828f2;color:#fff;border-radius:12px;font-size:.95rem;font-weight:500;box-shadow:0 4px 20px #0000004d;animation:toast-slideIn .3s ease-out}@media(prefers-color-scheme:light){.toast-item{background:#fffffffa;color:#333;border:1px solid #e0e0e0;box-shadow:0 4px 20px #00000026}}@keyframes toast-slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.app{width:100%;min-height:100vh}.app-close-button{width:32px;height:32px;padding:0;border:none;background:#0000000f;color:#666;font-size:1.25rem;font-weight:300;line-height:1;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.app-close-button:hover{background:#0000001a;color:#333}.app-close-button:active{background:#0000001f}@media(prefers-color-scheme:dark){.app-close-button{background:#ffffff14;color:#aaa}.app-close-button:hover{background:#ffffff1f;color:#fff}}
