.error-boundary{display:flex;align-items:center;justify-content:center;min-height:300px;padding:2rem;background:var(--bg-surface, #f8f9fa)}.error-boundary-content{max-width:400px;text-align:center;padding:2rem;background:var(--bg-card, #ffffff);border-radius:12px;box-shadow:0 2px 8px #0000001a}.error-boundary-icon{font-size:3rem;display:block;margin-bottom:1rem}.error-boundary-title{margin:0 0 .5rem;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.error-boundary-message{margin:0 0 1.5rem;font-size:1rem;color:var(--text-secondary, #666);line-height:1.5}.error-boundary-details{margin-bottom:1.5rem;text-align:left;padding:.75rem;background:var(--bg-surface, #f8f9fa);border-radius:6px;font-size:.875rem}.error-boundary-details summary{cursor:pointer;color:var(--text-secondary, #666);margin-bottom:.5rem}.error-boundary-details pre{margin:0;padding:.5rem;overflow-x:auto;font-size:.75rem;color:var(--error-color, #dc2626);white-space:pre-wrap;word-break:break-word}.error-boundary-retry{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:var(--primary-color, #4f46e5);border:none;border-radius:8px;cursor:pointer;transition:background-color .2s}.error-boundary-retry:hover{background-color:var(--primary-hover, #4338ca)}.error-boundary-retry:focus{outline:2px solid var(--focus-color, #4f46e5);outline-offset:2px}@media (prefers-reduced-motion: reduce){.error-boundary-retry{transition:none}}.parental-consent{margin:1.5rem 0;padding:1rem;background-color:#fff3cd;border:1px solid #ffc107;border-radius:4px}.consent-box{display:flex;flex-direction:column;gap:.5rem}.consent-label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;font-weight:500}.consent-label input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;cursor:pointer}.consent-text{flex:1;line-height:1.5}.consent-note{margin:0;padding-left:1.75rem;font-size:.85rem;color:#666;font-style:italic}.typeahead-wrapper{position:relative;width:100%}.typeahead-loading{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:.85rem;opacity:.6;pointer-events:none}.typeahead-suggestions{position:absolute;top:100%;left:0;right:0;max-height:300px;overflow-y:auto;background:#1f2937fa;border:1px solid rgba(255,255,255,.2);border-radius:8px;margin-top:4px;padding:0;list-style:none;z-index:100;box-shadow:0 10px 30px #00000080;color:#fff}.typeahead-suggestions li{padding:.75rem 1rem;cursor:pointer;transition:background .15s ease;border-bottom:1px solid rgba(255,255,255,.05);color:#fff}.typeahead-suggestions li:last-child{border-bottom:none}.typeahead-suggestions li:hover,.typeahead-suggestions li.active{background:#ff6b9d33}.city-population{font-size:.85rem;opacity:.6;margin-left:.5rem}.terms-of-service{margin:1.5rem 0;padding:1.25rem;background:#ffffff0d;border-radius:8px;border:1px solid rgba(255,255,255,.1)}.terms-checkbox{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:.95rem}.terms-checkbox input[type=checkbox]{margin-top:.25rem;width:18px;height:18px;cursor:pointer;flex-shrink:0}.terms-text{line-height:1.5}.terms-text a{color:#ffc837;text-decoration:underline;transition:opacity .2s ease}.terms-text a:hover{opacity:.8}.terms-summary{margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1);font-size:.85rem;opacity:.8;line-height:1.5}.profile-form{max-width:600px;margin:0 auto;padding:2rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.alias-section{margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.alias-label{display:block;margin-bottom:.75rem;font-size:1.5rem;font-weight:700;font-style:italic;color:#333;text-align:center}.alias-input-container{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.alias-input{flex:1;padding:1.25rem 1.5rem;font-size:2rem;font-weight:700;font-style:italic;text-align:center;border:3px solid transparent;border-radius:12px;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);background-clip:padding-box;color:#fff;text-shadow:2px 2px 4px rgba(0,0,0,.3);transition:all .3s ease;min-height:70px}.alias-input::placeholder{color:#ffffffb3;font-style:italic}.alias-input:focus{outline:none;box-shadow:0 0 20px #ff6b9d99;transform:scale(1.02)}.alias-input.error{border-color:#d32f2f;animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.alias-refresh-button{padding:0;background:linear-gradient(135deg,#42b883,#5f72bd);border:none;border-radius:12px;font-size:1.8rem;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #42b88380;min-width:70px;min-height:70px;display:flex;align-items:center;justify-content:center}.alias-refresh-button:hover{transform:rotate(180deg) scale(1.05);box-shadow:0 6px 16px #42b883b3;background:linear-gradient(135deg,#5f72bd,#42b883)}.alias-refresh-button:active{transform:rotate(180deg) scale(.95)}.alias-hint{text-align:center;font-size:.9rem;color:#666;margin:.5rem 0 0;font-style:italic}.form-section{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid #e0e0e0}.form-section:last-of-type{border-bottom:none}.form-section h3{margin:0 0 1rem;font-size:1.2rem;color:#333}.form-row{display:flex;gap:1rem;margin-bottom:1rem}.form-row .form-group{flex:1;margin-bottom:0}.form-group{margin-bottom:1.5rem}.form-group-compact input,.form-group-compact select{max-width:200px}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#333}.required{color:#d32f2f}.form-group input:not(.alias-input),.form-group select{width:100%;padding:.75rem;border:1px solid #ccc;border-radius:4px;font-size:1rem;transition:border-color .2s}.form-group input:not(.alias-input):focus,.form-group select:focus{outline:none;border-color:#2196f3}.form-group input:not(.alias-input).error,.form-group select.error{border-color:#d32f2f}.error-message{display:block;margin-top:.25rem;color:#d32f2f;font-size:.875rem}.suggestions{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:4px}.suggestions p{margin:0 0 .5rem;font-weight:500}.suggestion-list{display:flex;flex-wrap:wrap;gap:.5rem}.suggestion-button{padding:.5rem 1rem;background-color:#fff;border:1px solid #ccc;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.suggestion-button:hover{background:linear-gradient(135deg,#42b883,#5f72bd);color:#fff;border-color:transparent;box-shadow:0 2px 8px #42b88366}.privacy-note{margin:1.5rem 0 0;padding:1rem;background:#f8f9fa;border-radius:8px;font-size:.9rem;color:#666;line-height:1.5;text-align:center}.form-actions{margin-top:1.5rem;text-align:center}.submit-button{padding:1rem 2rem;background:linear-gradient(135deg,#ff6b9d,#c06fbb);color:#fff;border:none;border-radius:4px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;min-width:200px;box-shadow:0 2px 8px #ff6b9d66}.submit-button:hover:not(:disabled){background:linear-gradient(135deg,#ff5a8e,#b05fac);box-shadow:0 4px 12px #ff6b9d99;transform:translateY(-1px)}.submit-button:disabled{background-color:#ccc;cursor:not-allowed}@media (max-width: 768px){.profile-form{padding:1rem}.form-section h3{font-size:1.1rem}.form-row{flex-direction:column;gap:0}.form-row .form-group{margin-bottom:1.5rem}.form-group-compact input,.form-group-compact select{max-width:100%}.alias-label{font-size:1.2rem}.alias-input-container{flex-direction:column;gap:.75rem}.alias-input{font-size:1.4rem;padding:1rem .75rem;min-height:60px;width:100%}.alias-refresh-button{font-size:1.5rem;min-width:50px;min-height:50px;width:50px;height:50px;align-self:center}.alias-hint{font-size:.8rem}}@media (max-width: 400px){.alias-input{font-size:1.2rem;padding:.875rem .5rem;min-height:55px}.alias-label{font-size:1rem}}.language-selector{display:flex;flex-direction:column;gap:.5rem}.language-option{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;cursor:pointer;transition:background-color .2s,border-color .2s}.language-option:hover{background-color:var(--bg-hover, #f8f9fa);border-color:var(--border-hover, #d0d0d0)}.language-option.selected{background-color:var(--primary-bg, #eef2ff);border-color:var(--primary-color, #4f46e5)}.language-option:focus{outline:2px solid var(--focus-color, #4f46e5);outline-offset:2px}.language-flag{font-size:1.25rem}.language-name{flex:1;font-size:1rem;font-weight:500;color:var(--text-primary, #1a1a1a);text-align:left}.language-check{font-size:1rem;color:var(--primary-color, #4f46e5);font-weight:700}.language-selector-compact{padding:.5rem .75rem;font-size:.875rem;color:var(--text-primary, #1a1a1a);background-color:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:6px;cursor:pointer;transition:border-color .2s}.language-selector-compact:hover{border-color:var(--border-hover, #d0d0d0)}.language-selector-compact:focus{outline:2px solid var(--focus-color, #4f46e5);outline-offset:2px}@media (prefers-reduced-motion: reduce){.language-option,.language-selector-compact{transition:none}}.site-footer{background:#1f2937f2;padding:2rem;margin:2rem auto 0;border-radius:12px;width:100%;max-width:1000px}.site-footer .footer-content{max-width:1200px;margin:0 auto}.site-footer .footer-links{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}.site-footer .footer-links a{color:#fffc;text-decoration:none;font-weight:500;transition:color .3s ease}.site-footer .footer-links a:hover{color:#ffc837}.site-footer .footer-copyright{text-align:center;color:#fff9;font-size:.9rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 600px){.site-footer .footer-links{flex-direction:column;align-items:center;gap:1rem}}.profile-setup-page{min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);display:flex;flex-direction:column;align-items:center;padding:2rem;position:relative}.setup-language-picker{position:absolute;top:1rem;right:1rem;z-index:100}.setup-language-picker .language-selector-compact{background:#fffffff2;border:none;box-shadow:0 2px 8px #00000026;font-weight:500}.setup-container{width:100%;max-width:700px;flex:1;display:flex;flex-direction:column;justify-content:center}.setup-header{text-align:center;margin-bottom:1rem;color:#fff}.logo-container{margin-bottom:0;display:flex;justify-content:center}.game-logo{width:220px;height:220px;object-fit:contain;filter:drop-shadow(0 4px 12px rgba(0,0,0,.3));animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.setup-header h1{font-size:3rem;margin:0 0 .5rem;font-weight:700;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.tagline{font-size:1.3rem;font-weight:600;margin:0 0 1rem;opacity:.95;text-shadow:1px 1px 4px rgba(0,0,0,.2)}.setup-header p:not(.tagline){font-size:1.1rem;opacity:.95;margin:0}.error-banner{background-color:#f44336;color:#fff;padding:1rem;border-radius:4px;margin-bottom:1.5rem;text-align:center}.error-banner p{margin:0;font-weight:500}.setup-footer{margin-top:2rem;text-align:center;color:#fff}.privacy-note{font-size:.9rem;opacity:.9;margin:0;line-height:1.5}.footer-leaderboard-link{display:inline-flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.5rem 1rem;color:#fff;text-decoration:none;font-size:.95rem;font-weight:500;background:#ffffff26;border-radius:20px;transition:all .2s ease}.footer-leaderboard-link:hover{background:#ffffff40;transform:translateY(-2px)}@media (max-width: 768px){.profile-setup-page{padding:1rem}.game-logo{width:180px;height:180px}.setup-header h1{font-size:2.2rem}.tagline{font-size:1.1rem}.setup-header p:not(.tagline){font-size:1rem}}@media (prefers-reduced-motion: reduce){.game-logo{animation:none}}.how-to-play-page{min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);display:flex;flex-direction:column;align-items:center;padding:2rem 1rem}.tutorial-container{background:#fff;border-radius:1.5rem;box-shadow:0 25px 50px -12px #00000040;max-width:1000px;width:100%;padding:2rem;flex:1;display:flex;flex-direction:column}.tutorial-title{font-size:1.75rem;font-weight:700;background:linear-gradient(135deg,#ff6b9d,#c06fbb);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 1.5rem;text-align:center}.tutorial-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:start}.game-preview{display:flex;align-items:flex-start}.game-screenshot{display:block;width:100%}.preview-image{width:100%;max-width:400px;height:auto;border-radius:.5rem;box-shadow:0 8px 20px #00000026;border:1px solid #e0e0e0}.instructions-section{display:flex;flex-direction:column;gap:1rem}.steps-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.step-item{display:flex;align-items:flex-start;gap:.75rem;padding:.5rem .75rem;background:linear-gradient(135deg,#f8f9fa,#f0f1f3);border-radius:.5rem;border-left:3px solid #5F72BD}.step-number{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:linear-gradient(135deg,#5f72bd,#42b883);color:#fff;font-weight:700;font-size:.8rem;border-radius:50%;flex-shrink:0}.step-text{color:#4a5568;font-size:.9rem;line-height:1.4}.tips-section{background:linear-gradient(135deg,#fef9e7,#fff9db);border-radius:.5rem;padding:.75rem 1rem;border:1px solid #f6e05e;margin-top:.5rem}.tips-title{font-size:.95rem;font-weight:600;color:#744210;margin:0 0 .5rem}.tips-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.25rem}.tips-list li{color:#744210;font-size:.85rem;line-height:1.3}.tutorial-footer{margin-top:1.5rem;text-align:center}.start-game-button{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;font-size:1.125rem;font-weight:700;padding:.875rem 2.5rem;border:none;border-radius:9999px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #48bb7866}.start-game-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #48bb7880}.start-game-button:active{transform:translateY(0)}@media (max-width: 768px){.how-to-play-page{padding:0;align-items:flex-start}.tutorial-container{border-radius:0;min-height:100vh;padding:1.5rem 1rem}.tutorial-title{font-size:1.5rem;margin-bottom:1rem}.tutorial-content{grid-template-columns:1fr;gap:1rem}.preview-image{max-width:100%}.step-item{padding:.5rem}.step-number{width:1.25rem;height:1.25rem;font-size:.75rem}.step-text{font-size:.85rem}.tips-section{padding:.75rem}.tutorial-footer{margin-top:1rem}.start-game-button{width:100%;font-size:1rem;padding:.75rem 2rem}}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837)}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.game-header{position:sticky;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;font-size:.95rem;font-weight:600;box-shadow:0 2px 8px #0003;z-index:1000;height:44px;flex-shrink:0}.game-header-left{display:flex;align-items:center;gap:.5rem;flex:1;flex-wrap:nowrap;min-width:0}.game-icon{font-size:1.1rem;line-height:1;flex-shrink:0}.round-progress{font-size:.95rem;font-weight:600;white-space:nowrap;flex-shrink:0}.game-header .player-info{display:inline-flex;align-items:center;gap:.5rem;margin-left:1rem;margin-top:0;padding-left:1rem;padding-top:0;border-left:1px solid rgba(255,255,255,.4);border-top:none;white-space:nowrap;flex-shrink:1;min-width:0;text-align:left}.game-header .player-alias{font-size:.9rem;font-weight:600;color:#fff;overflow:hidden;text-overflow:ellipsis}.game-header .player-streak{font-size:.8rem;font-weight:600;background:#ffffff40;padding:.15rem .5rem;border-radius:4px;color:#fff;white-space:nowrap}.game-header .player-streak.mobile-only{display:none}.game-header .player-info.desktop-only{display:inline-flex}.game-header .game-header-center{display:flex;align-items:center;justify-content:center;gap:.35rem;flex:1}.game-header .score-value{font-size:1.2rem;font-weight:600;color:#fff}.game-header .score-label{font-size:.9rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.02em}.game-header-right{display:flex;align-items:center;justify-content:flex-end;flex:1}.timer-display{font-size:.95rem;font-weight:700;padding:.25rem .75rem;border-radius:6px;background:#fff3;min-width:3rem;text-align:center;transition:all .3s ease}.timer-display.warning{color:#f44;background:#ffffffe6;font-size:1.1rem}.timer-display.flash{animation:flash-warning 1s infinite}.timer-display.paused{color:#a855f7;background:#a855f733;animation:none}.paused-indicator{margin-left:.25rem;font-size:.8em}@keyframes flash-warning{0%,to{background:#ffffffe6;transform:scale(1)}50%{background:#ff44444d;transform:scale(1.1)}}@media (max-width: 768px){.game-header{padding:.4rem .75rem;font-size:.8rem;height:42px;align-items:center}.game-header-left{gap:.35rem;align-items:center}.game-header-center,.game-header-right{align-items:center}.game-icon{font-size:1rem;line-height:1}.round-progress{font-size:.8rem;line-height:1}.game-header .player-info.desktop-only{display:none}.game-header .player-streak.mobile-only{display:inline-flex;align-items:center;font-size:.75rem;padding:.1rem .4rem;margin-left:.5rem;line-height:1}.game-header .score-value{font-size:1rem;line-height:1}.game-header .score-label{font-size:.7rem;line-height:1}.timer-display{font-size:.85rem;padding:.2rem .5rem;min-width:2.5rem;line-height:1;display:flex;align-items:center;justify-content:center}.timer-display.warning{font-size:1rem}}@media (max-width: 768px) and (orientation: landscape){.game-header .player-info.desktop-only{display:inline-flex}.game-header .player-streak.mobile-only{display:none}}@media (prefers-reduced-motion: reduce){.timer-display.flash{animation:none}.timer-display.warning{color:#f44;background:#ffffffe6}}.image-display{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.image-display.loading{display:flex;align-items:center;justify-content:center;min-height:300px}.loading-spinner{font-size:1.2rem;color:var(--text-secondary);animation:pulse 1.5s ease-in-out infinite}.image-container{position:relative;max-width:100%;max-height:100%;background:transparent;border-radius:12px;overflow:hidden;box-shadow:0 4px 20px #00000059,0 0 0 1px #ffffff1a}.game-image{max-width:100%;max-height:calc(100vh - 100px);width:auto;height:auto;display:block;object-fit:contain}@media (max-width: 768px){.game-image{max-height:calc(55vh - 50px)}}@media (prefers-contrast: high){.image-container{border:2px solid var(--border-primary)}}@media (prefers-reduced-motion: reduce){.loading-spinner{animation:none}}.item-selector{width:100%}.items-grid{display:grid;grid-template-columns:1fr;gap:.5rem;padding:0}.item-button{position:relative;display:flex;align-items:center;justify-content:center;padding:.5rem .75rem;min-height:44px;background:linear-gradient(180deg,#fff,#f0f2f5);border:1px solid rgba(0,0,0,.12);border-radius:8px;cursor:pointer;transition:all .2s ease;font-size:.9rem;font-weight:700;color:#333;text-align:center;box-shadow:0 2px 6px #0000001f,0 1px 2px #00000014,inset 0 1px #ffffffe6}.item-button:hover:not(:disabled):not(.selected){background:linear-gradient(180deg,#fff,#e4e8ec);border-color:#0003;transform:translateY(-2px);box-shadow:0 6px 16px #0003,0 2px 4px #0000001a,inset 0 1px #fffffff2}.item-button:active:not(:disabled):not(.selected){transform:translateY(0);box-shadow:0 1px 3px #0000001f,inset 0 2px 4px #00000014}.item-button:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}.item-button.selected{background:linear-gradient(180deg,#c8f7c5,#a8e6cf);border-color:#28a745;color:#155724;cursor:default;font-weight:700;box-shadow:inset 0 2px 6px #0000001f,0 2px 4px #28a74533}.item-button.disabled{opacity:.5;cursor:not-allowed}.item-text{flex:1;word-break:break-word}.selected-indicator{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--success-primary);color:#fff;border-radius:50%;font-size:1rem;font-weight:700}.selection-counter{margin-top:1rem;padding:.75rem;text-align:center;background:var(--surface-tertiary);border-radius:4px;color:var(--text-secondary);font-size:.95rem}@media (prefers-contrast: high){.item-button{border-width:3px}.item-button.selected{border-width:4px}}@media (prefers-reduced-motion: reduce){.item-button{transition:none}.item-button:hover:not(:disabled):not(.selected){transform:none}}@media (max-width: 768px){.items-grid{grid-template-columns:repeat(2,1fr);gap:.5rem;padding:.25rem}.item-button{padding:.5rem;min-height:44px;font-size:.85rem}}.round-feedback{margin-top:1.5rem;border-top:1px solid var(--border-color, #e5e7eb);padding-top:1rem}.round-feedback.submitted,.round-feedback.submitting{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;background-color:var(--success-bg, #ecfdf5);border-radius:.5rem;color:var(--success-text, #065f46)}.submitted-icon{font-size:1.25rem}.submitting-spinner{width:1rem;height:1rem;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}.feedback-accordion{border:1px solid var(--border-color, #e5e7eb);border-radius:.5rem;overflow:hidden}.feedback-summary{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:var(--bg-secondary, #f9fafb);cursor:pointer;-webkit-user-select:none;user-select:none;list-style:none}.feedback-summary::-webkit-details-marker{display:none}.feedback-summary:hover{background-color:var(--bg-hover, #f3f4f6)}.feedback-summary:focus-visible{outline:2px solid var(--focus-ring, #3b82f6);outline-offset:-2px}.feedback-title{font-weight:600;color:var(--text-primary, #1f2937)}.feedback-expand-hint{font-size:.875rem;color:var(--text-secondary, #6b7280);margin-left:.5rem}.feedback-chevron{font-size:.75rem;color:var(--text-secondary, #6b7280);transition:transform .2s}details[open] .feedback-chevron{transform:rotate(180deg)}.feedback-content{padding:1rem;background-color:var(--bg-primary, #ffffff);display:flex;flex-direction:column;gap:1rem}.rating-group{border:none;padding:0;margin:0}.rating-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937);margin-bottom:.5rem}.rating-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.rating-button{flex:1;min-width:5rem;padding:.5rem .75rem;font-size:.875rem;border:1px solid var(--border-color, #d1d5db);border-radius:.375rem;background-color:var(--bg-primary, #ffffff);color:var(--text-primary, #374151);cursor:pointer;transition:all .15s ease-in-out}.rating-button:hover:not(:disabled){background-color:var(--bg-hover, #f3f4f6);border-color:var(--border-hover, #9ca3af)}.rating-button:focus-visible{outline:2px solid var(--focus-ring, #3b82f6);outline-offset:2px}.rating-button.selected{background-color:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6);color:#fff}.rating-button:disabled{opacity:.5;cursor:not-allowed}.comment-group{display:flex;flex-direction:column;gap:.5rem}.comment-label{font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937)}.comment-textarea{width:100%;padding:.75rem;font-size:.875rem;font-family:inherit;border:1px solid var(--border-color, #d1d5db);border-radius:.375rem;resize:vertical;min-height:4rem;max-height:10rem}.comment-textarea:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px var(--focus-ring-light, rgba(59, 130, 246, .1))}.comment-textarea::placeholder{color:var(--text-placeholder, #9ca3af)}.comment-counter{font-size:.75rem;color:var(--text-secondary, #6b7280);text-align:right}.comment-counter.warning{color:var(--warning-text, #d97706)}.comment-counter.critical{color:var(--error-text, #dc2626);font-weight:500}@media (max-width: 640px){.round-feedback{margin-top:1rem}.feedback-summary{padding:.625rem .75rem}.feedback-expand-hint{display:none}.feedback-content{padding:.75rem}.rating-buttons{gap:.375rem}.rating-button{padding:.375rem .5rem;font-size:.8125rem;min-width:4rem}}@media (prefers-contrast: high){.rating-button{border-width:2px}.rating-button.selected{outline:2px solid #000;outline-offset:2px}.comment-textarea{border-width:2px}}@media (prefers-reduced-motion: reduce){.feedback-chevron,.rating-button,.submitting-spinner{transition:none}.submitting-spinner{animation:none}}.round-overview{width:100%;max-width:550px;margin:0 auto;padding:1rem;background:var(--surface-secondary);border-radius:12px;box-shadow:0 4px 12px #0000001a;max-height:95vh;overflow-y:auto}.overview-header{text-align:center;margin-bottom:.5rem}.overview-title{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.25rem}.flawless-badge{display:inline-block;padding:.35rem .75rem;background:var(--success-bg);color:var(--success-text);border:2px solid var(--success-border);border-radius:6px;font-weight:600;font-size:.9rem}.score-display{text-align:center;margin-bottom:.75rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:10px;padding:.75rem}.final-score{display:flex;flex-direction:column;align-items:center;gap:.15rem}.score-label{font-size:.8rem;color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:.1em}.score-value{font-size:2.5rem;font-weight:900;color:#fff;line-height:1}.end-cause{font-size:.8rem;color:#fff;font-weight:600;margin-top:.15rem}.score-breakdown{margin-bottom:.75rem;padding:.5rem .75rem;background:var(--surface-tertiary);border-radius:8px}.breakdown-title{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem;text-align:center}.breakdown-items{display:flex;flex-direction:column;gap:.15rem}.breakdown-item{display:flex;justify-content:space-between;align-items:center;padding:.25rem 0;border-bottom:1px solid var(--border-secondary)}.breakdown-item:last-child{border-bottom:none}.breakdown-item.total{margin-top:.15rem;padding-top:.35rem;border-top:2px solid var(--border-primary);font-weight:600;font-size:.9rem}.breakdown-label{color:var(--text-primary);font-weight:500;font-size:.8rem}.breakdown-explanation{font-size:.7rem;color:var(--text-secondary);font-style:italic;margin-left:.5rem;flex:1;text-align:right;margin-right:.5rem}.breakdown-value{font-weight:600;font-size:.85rem;min-width:60px;text-align:right}.breakdown-value.positive{color:var(--success-primary)}.breakdown-value.negative{color:var(--error-primary)}.scoring-formula{margin-top:.5rem;padding-top:.5rem;border-top:1px dashed var(--border-secondary)}.formula-text{font-size:.7rem;color:var(--text-secondary);text-align:center;font-style:italic;margin:0}.selections-review{margin-bottom:.5rem}.review-title{font-size:.85rem;font-weight:600;color:var(--text-primary);margin-bottom:.35rem;text-align:center}.selections-group{margin-bottom:.35rem}.selections-group:last-child{margin-bottom:0}.group-title{font-size:.75rem;font-weight:600;margin-bottom:.25rem}.selections-group.correct .group-title{color:var(--success-primary)}.selections-group.incorrect .group-title{color:var(--error-primary)}.selections-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:repeat(2,1fr);gap:.25rem}.selection-item{display:flex;align-items:center;gap:.35rem;padding:.3rem .5rem;border-radius:4px;background:var(--surface-secondary);font-size:.8rem}.selection-item.correct{border-left:3px solid var(--success-primary);background:var(--success-bg)}.selection-item.incorrect{border-left:3px solid var(--error-primary);background:var(--error-bg)}.selection-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;font-size:.65rem;flex-shrink:0}.selection-item.correct .selection-icon{background:var(--success-primary);color:#fff}.selection-item.incorrect .selection-icon{background:var(--error-primary);color:#fff}.selection-name{flex:1;font-weight:500;color:var(--text-primary)}.selection-sequence{font-size:.7rem;color:var(--text-secondary);font-weight:600;flex-shrink:0}.continue-button{width:100%;padding:.75rem;margin-top:.5rem;margin-bottom:0;background:linear-gradient(135deg,#ff6b9d,#c06fbb);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ff6b9d66;display:flex;align-items:center;justify-content:center;gap:.5rem}.continue-button:disabled{cursor:not-allowed;opacity:.8}.continue-button.loading{background:linear-gradient(135deg,#9ca3af,#6b7280);box-shadow:0 2px 8px #6b728066}.loading-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.continue-button:hover:not(:disabled){background:linear-gradient(135deg,#ff5a8e,#b05fac);transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d99}.continue-button:active{transform:translateY(0)}.continue-button:focus-visible{outline:3px solid var(--focus-ring);outline-offset:2px}@media (prefers-contrast: high){.round-overview{border:3px solid var(--border-primary)}.selection-item.correct,.selection-item.incorrect{border-left-width:6px}}@media (prefers-reduced-motion: reduce){.continue-button:hover{transform:none}}@media (max-width: 768px){.round-overview{padding:.75rem;margin:0 auto;border-radius:10px}.overview-title{font-size:1.1rem}.score-value{font-size:2rem}.breakdown-item{font-size:.75rem}.selections-list{grid-template-columns:repeat(2,1fr)}.selection-item{padding:.25rem .4rem;font-size:.75rem}.selection-icon{width:14px;height:14px;font-size:.6rem}.selection-sequence{display:none}}.round-view{width:100%;height:100vh;margin:0;padding:0;overflow:hidden;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);display:flex;flex-direction:column}.round-view.active{display:flex;flex-direction:column}.round-view.completed{display:flex;justify-content:center;align-items:center;padding:.75rem;overflow-y:auto;height:100vh;min-height:100vh}.game-content{flex:1;display:flex;gap:1rem;padding:.5rem;overflow:hidden;min-height:0;align-items:flex-start;justify-content:center}.image-section{flex:0 1 auto;display:flex;align-items:flex-start;justify-content:center;min-width:0;overflow:hidden;padding:.5rem;position:relative}.image-loading-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000b3;color:#fff;padding:1rem 2rem;border-radius:8px;font-weight:500;z-index:10;display:flex;align-items:center;gap:.5rem}.image-loading-overlay:before{content:"";width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.selector-section{width:280px;flex-shrink:0;display:flex;flex-direction:column;overflow-y:auto;padding:.5rem;background:transparent;align-self:flex-start;margin-top:0}.game-warning{display:flex;align-items:center;justify-content:center;gap:.35rem;background:#f59e0be6;color:#fff;padding:.4rem .75rem;font-size:.75rem;font-weight:500;text-align:center;border-radius:6px;margin-top:.5rem;width:100%}.game-warning .warning-icon{font-size:.85rem}.round-header,.round-title,.instructions{display:none}.round-loading{position:fixed;bottom:2rem;left:50%;transform:translate(-50%);padding:1rem 2rem;background:var(--surface-secondary);border:2px solid var(--border-primary);border-radius:8px;box-shadow:0 4px 12px #0003;font-weight:600;color:var(--text-primary);z-index:1000;animation:fade-in .3s ease}@keyframes fade-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@media (prefers-reduced-motion: reduce){.round-loading{animation:none}}@media (max-width: 768px){.game-content{flex-direction:column;padding:0;gap:0;align-items:stretch;justify-content:flex-start}.image-section{flex:0 0 auto;max-height:55vh;padding:.25rem}.selector-section{width:100%;flex:1;overflow-y:auto;padding:.5rem;align-self:stretch}.game-warning{font-size:.7rem;padding:.35rem .5rem}.round-loading{bottom:1rem;padding:.75rem 1.5rem;font-size:.9rem}}@media (max-width: 768px) and (orientation: landscape){.game-content{flex-direction:row;gap:.5rem}.image-section{flex:1;max-height:none;padding:.25rem}.selector-section{width:240px}}@media (min-width: 769px) and (max-width: 1024px){.selector-section{width:260px}}@media (prefers-contrast: high){.game-content{border:2px solid var(--border-primary)}}.timer-control{display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap}.timer-control-duration,.timer-control-pause{display:flex;flex-direction:column;gap:.25rem}.timer-control-label{font-size:.75rem;font-weight:500;color:#ffffffb3;text-transform:uppercase;letter-spacing:.03em}.timer-control-input-group{display:flex;gap:.375rem}.timer-control-input{width:80px;padding:.375rem .5rem;font-size:.875rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;text-align:center}.timer-control-input::placeholder{color:#fff6;font-size:.75rem}.timer-control-input:focus{outline:none;border-color:#e94560;box-shadow:0 0 0 2px #e9456033}.timer-control-btn{padding:.375rem .625rem;font-size:.75rem;font-weight:500;border:1px solid transparent;border-radius:4px;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;gap:.375rem;white-space:nowrap}.timer-control-btn:disabled{opacity:.5;cursor:not-allowed}.timer-control-btn-apply{background:#e94560;color:#fff}.timer-control-btn-apply:hover:not(:disabled){background:#d63d56}.timer-control-btn-apply:focus-visible{outline:2px solid #fff;outline-offset:2px}.timer-control-btn-clear{background:transparent;border-color:#ffffff4d;color:#fffc}.timer-control-btn-clear:hover:not(:disabled){background:#ffffff1a;border-color:#ffffff80}.timer-control-btn-clear:focus-visible{outline:2px solid #e94560;outline-offset:2px}.timer-control-btn-pause{background:#0f3460;border-color:#fff3;color:#fff;min-width:90px;justify-content:center}.timer-control-btn-pause:hover:not(:disabled){background:#1a4d7e}.timer-control-btn-pause:focus-visible{outline:2px solid #e94560;outline-offset:2px}.timer-control-btn-pause.paused{background:#4ade80;color:#000}.timer-control-btn-pause.paused:hover:not(:disabled){background:#22c55e}.pause-icon{font-size:.625rem}.timer-control-hint{font-size:.625rem;color:#ffffff80;font-style:italic}@media (max-width: 640px){.timer-control{gap:1rem;width:100%}.timer-control-duration,.timer-control-pause{flex:1;min-width:120px}.timer-control-input{width:60px;font-size:.75rem}.timer-control-btn{padding:.25rem .5rem;font-size:.6875rem}}@media (prefers-contrast: high){.timer-control-input{border-width:2px;border-color:#fff}.timer-control-btn{border-width:2px}.timer-control-btn-apply{border-color:#fff}.timer-control-hint{color:#fff}}@media (prefers-reduced-motion: reduce){.timer-control-btn{transition:none}}.admin-bar{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(180deg,#1a1a2e,#16213e);border-top:2px solid #e94560;padding:.75rem 1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;z-index:1000;box-shadow:0 -4px 12px #0000004d}.admin-bar-content{display:flex;align-items:center;gap:1.5rem;flex:1}.admin-bar-title{font-size:.875rem;font-weight:600;color:#e94560;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.admin-bar-collapse-btn{background:transparent;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:#fff;cursor:pointer;padding:.375rem .5rem;font-size:.75rem;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.admin-bar-collapse-btn:hover{background:#ffffff1a;border-color:#fff6}.admin-bar-collapse-btn:focus{outline:2px solid #e94560;outline-offset:2px}.admin-bar-collapse-btn:focus:not(:focus-visible){outline:none}.admin-bar-collapse-btn:focus-visible{outline:2px solid #e94560;outline-offset:2px}.admin-bar-reveal-icon{position:fixed;bottom:1rem;right:1rem;width:48px;height:48px;background:linear-gradient(135deg,#e94560,#c62a47);border:none;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;box-shadow:0 4px 12px #e9456066;transition:all .2s ease}.admin-bar-reveal-icon:hover{transform:scale(1.1);box-shadow:0 6px 16px #e9456080}.admin-bar-reveal-icon:focus{outline:2px solid #fff;outline-offset:2px}.admin-bar-reveal-icon:focus:not(:focus-visible){outline:none}.admin-bar-reveal-icon:focus-visible{outline:2px solid #fff;outline-offset:2px}.admin-icon{font-size:1.5rem;line-height:1}@media (max-width: 640px){.admin-bar{padding:.5rem .75rem;flex-wrap:wrap}.admin-bar-content{flex-wrap:wrap;gap:.75rem}.admin-bar-title{font-size:.75rem}.admin-bar-reveal-icon{width:40px;height:40px;bottom:.75rem;right:.75rem}.admin-icon{font-size:1.25rem}}@media (prefers-contrast: high){.admin-bar{border-top-width:3px;background:#000}.admin-bar-collapse-btn{border-width:2px;border-color:#fff}.admin-bar-reveal-icon{border:2px solid #fff}}@media (prefers-reduced-motion: reduce){.admin-bar-collapse-btn,.admin-bar-reveal-icon{transition:none}.admin-bar-reveal-icon:hover{transform:none}}.play-page{min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837)}.play-page>.round-view{background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837)}.play-container{background-color:#fff;padding:3rem;border-radius:8px;box-shadow:0 4px 12px #0003;text-align:center;max-width:600px;margin:2rem auto}.play-container h1,.play-container h2{margin:0 0 1rem;color:#333}.play-container p{color:#666;line-height:1.6}.player-info{margin-top:2rem;padding-top:2rem;border-top:1px solid #e0e0e0;text-align:left}.player-info p{margin:.5rem 0}.player-info strong{color:#333}.loading-state{padding:2rem}.loading-state h2{color:#ffc837;margin-bottom:1rem;text-shadow:1px 1px 4px rgba(0,0,0,.2)}.loading-state p{color:#666;font-size:1rem;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.error-state{padding:2rem}.error-state h2{color:#d32f2f;margin-bottom:1rem}.error-state p{color:#666;margin-bottom:1.5rem}.retry-button{padding:.75rem 2rem;background:linear-gradient(135deg,#ff6b9d,#c06fbb);color:#fff;border:none;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ff6b9d66}.retry-button:hover{background:linear-gradient(135deg,#ff5a8e,#b05fac);transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d99}.retry-button:active{transform:translateY(0)}.retry-button:focus-visible{outline:3px solid rgba(255,107,157,.6);outline-offset:2px}@media (prefers-reduced-motion: reduce){.loading-state p{animation:none}.retry-button:hover{transform:none}}@media (max-width: 768px){.play-page{padding:1rem .5rem}.play-container{padding:2rem 1.5rem}}.forfeit-notice{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:.75rem 1rem;display:flex;align-items:center;justify-content:center;gap:.5rem;font-weight:500;font-size:.95rem;z-index:1000;box-shadow:0 2px 8px #0003;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.forfeit-notice .forfeit-icon{font-size:1.25rem}.forfeit-notice .dismiss-button{background:none;border:none;color:#fff;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;margin-left:1rem;opacity:.8;transition:opacity .2s}.forfeit-notice .dismiss-button:hover{opacity:1}.completed-today-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center;padding:2rem;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.completed-today-state .celebration-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 1s ease infinite}.completed-today-state h2{font-size:2rem;margin-bottom:.75rem;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.completed-today-state p{font-size:1.1rem;color:#ffffffe6;max-width:400px;line-height:1.6;margin-bottom:1.5rem}.completed-today-state .completed-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center}.completed-today-state .leaderboard-button{background:#fff3;color:#fff;border:2px solid white;padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem}.completed-today-state .leaderboard-button:hover{background:#ffffff4d;transform:translateY(-2px)}.completed-today-state .home-button{background:#fff;color:#764ba2;border:none;padding:.75rem 2rem;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px #00000026}.completed-today-state .home-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #0003}.achievement-badge{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:linear-gradient(135deg,gold,#fa0);border-radius:12px;box-shadow:0 2px 8px #ffaa004d;transition:transform .2s ease,box-shadow .2s ease}.achievement-badge:hover{transform:translateY(-2px);box-shadow:0 4px 12px #fa06}.achievement-badge--small{padding:.5rem .75rem;gap:.5rem;border-radius:8px}.achievement-badge--small .achievement-badge__icon{font-size:1.25rem}.achievement-badge--small .achievement-badge__name{font-size:.875rem}.achievement-badge--medium .achievement-badge__icon{font-size:1.75rem}.achievement-badge--large{padding:1rem 1.5rem;gap:1rem}.achievement-badge--large .achievement-badge__icon{font-size:2.5rem}.achievement-badge--large .achievement-badge__name{font-size:1.25rem}.achievement-badge__icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:#ffffff4d;border-radius:50%}.achievement-badge--small .achievement-badge__icon{width:2rem;height:2rem}.achievement-badge--large .achievement-badge__icon{width:3.5rem;height:3.5rem}.achievement-badge__content{display:flex;flex-direction:column;gap:.125rem}.achievement-badge__name{font-weight:600;color:#1a1a1a;font-size:1rem}.achievement-badge__description{font-size:.875rem;color:#4a3600;line-height:1.3}.achievement-badge__date{font-size:.75rem;color:#6a5600;opacity:.8}@keyframes badge-pop{0%{transform:scale(.8);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.achievement-badge--new{animation:badge-pop .4s ease-out}@media (prefers-color-scheme: dark){.achievement-badge{background:linear-gradient(135deg,#b8860b,#daa520)}.achievement-badge__icon{background:#0003}.achievement-badge__name{color:#fff}.achievement-badge__description{color:#ffe4a0}.achievement-badge__date{color:#ffd070}}.achievement-list{display:flex;flex-direction:column;gap:1rem}.achievement-list__title{display:flex;align-items:center;gap:.5rem;font-size:1.25rem;font-weight:600;color:#333;margin:0}.achievement-list__count{font-size:.875rem;font-weight:400;color:#666}.achievement-list__badges--list{display:flex;flex-direction:column;gap:.75rem}.achievement-list__badges--grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.achievement-list--empty{text-align:center;padding:2rem;background:#f5f5f5;border-radius:12px}.achievement-list__empty-message{color:#666;font-size:1rem;margin:.5rem 0 0}.achievement-list__more{text-align:center;color:#666;font-size:.875rem;margin:.5rem 0 0;font-style:italic}@media (prefers-color-scheme: dark){.achievement-list__title{color:#f0f0f0}.achievement-list__count{color:#aaa}.achievement-list--empty{background:#2a2a2a}.achievement-list__empty-message,.achievement-list__more{color:#aaa}}@media (max-width: 480px){.achievement-list__badges--grid{grid-template-columns:1fr}}.narrative-section{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-radius:12px;padding:1.25rem;margin-bottom:1.5rem;text-align:left}.narrative-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.narrative-icon{font-size:1.25rem}.narrative-title{font-size:.9rem;font-weight:600;color:#4338ca;text-transform:uppercase;letter-spacing:.05em;margin:0}.narrative-text{color:#3730a3;font-size:1rem;line-height:1.6;margin:0}.narrative-question{display:inline;background:linear-gradient(135deg,#fef3c7,#fde68a);padding:.1em .3em;border-radius:4px;font-weight:500}.narrative-skeleton{display:flex;flex-direction:column;gap:.5rem}.skeleton-line{height:1rem;background:linear-gradient(90deg,#6366f133 25%,#6366f166,#6366f133 75%);background-size:200% 100%;border-radius:4px;animation:skeleton-shimmer 1.5s infinite ease-in-out}.skeleton-line:nth-child(1){width:100%}.skeleton-line:nth-child(2){width:95%}.skeleton-line:nth-child(3){width:70%}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.narrative-unavailable{color:#6b7280;font-style:italic;font-size:.95rem}.narrative-response{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(99,102,241,.2)}.response-input{width:100%;padding:.75rem;border:1px solid #c7d2fe;border-radius:8px;font-family:inherit;font-size:.95rem;resize:none;background:#fff;color:#1e1b4b;transition:border-color .2s,box-shadow .2s}.response-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.response-input:disabled{background:#f3f4f6;cursor:not-allowed}.response-input::placeholder{color:#9ca3af}.response-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem}.character-count{font-size:.8rem;color:#6b7280}.submit-response-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s,transform .2s}.submit-response-btn:hover:not(:disabled){transform:translateY(-1px);opacity:.95}.submit-response-btn:disabled{opacity:.5;cursor:not-allowed}.submit-error{color:#dc2626;font-size:.85rem;margin:.5rem 0 0}.response-submitted{display:flex;align-items:center;gap:.5rem;margin-top:1rem;padding:.75rem;background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-radius:8px;color:#065f46;font-weight:500}.submitted-icon{font-size:1.1rem}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.submit-response-btn:focus{outline:none;box-shadow:0 0 0 3px #6366f180}.submit-response-btn:focus-visible{outline:2px solid #4f46e5;outline-offset:2px;box-shadow:0 0 0 3px #6366f14d}.response-input:focus-visible{outline:2px solid #4f46e5;outline-offset:2px}@media (prefers-contrast: high){.narrative-section{border:2px solid #4338ca}.narrative-question{border:1px solid #92400e}.submit-response-btn{border:2px solid white}.response-input{border:2px solid #1e1b4b}}@media (prefers-reduced-motion: reduce){.skeleton-line{animation:none;background:#6366f14d}.submit-response-btn,.response-input{transition:none}}.daily-summary-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837)}.daily-summary{width:100%;max-width:600px}.summary-card{background:#fff;border-radius:24px;padding:2.5rem;box-shadow:0 20px 60px #0003}.celebration-header{text-align:center;margin-bottom:2rem}.celebration-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.summary-title{font-size:2rem;font-weight:700;color:#1a1a1a;margin:0 0 .5rem}.summary-date{font-size:1rem;color:#666;margin:0}.score-section{text-align:center;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e4e8eb);border-radius:16px;margin-bottom:1.5rem}.score-label{font-size:1rem;color:#666;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.5rem}.score-value{font-size:4rem;font-weight:800;background:linear-gradient(135deg,#ff6b9d,#c06fbb);-webkit-background-clip:text;background-clip:text}.streak-section{text-align:center;padding:1.5rem;background:linear-gradient(135deg,#fff3cd,#ffe4a0);border-radius:16px;margin-bottom:1.5rem}.streak-display{display:flex;align-items:center;justify-content:center;gap:1rem}.streak-icon{font-size:3rem}.streak-info{display:flex;flex-direction:column;align-items:flex-start}.streak-number{font-size:2.5rem;font-weight:800;color:#b8860b;line-height:1}.streak-label{font-size:1rem;color:#8b6914;text-transform:uppercase;letter-spacing:.05em}.streak-message{margin:.75rem 0 0;color:#8b6914;font-size:.875rem}.achievements-section{margin-bottom:1.5rem}.achievements-section .achievement-list__badges--grid{grid-template-columns:repeat(2,1fr);gap:.5rem}@media (max-width: 480px){.achievements-section .achievement-list__badges--grid{grid-template-columns:1fr}}.rounds-section{margin-bottom:1.5rem}.section-title{font-size:1.125rem;font-weight:600;color:#333;margin:0 0 1rem}.rounds-list{display:flex;flex-direction:column;gap:.5rem}.round-item{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#f5f5f5;border-radius:8px}.round-number{flex:1;font-weight:500;color:#333}.round-score{font-weight:700;color:#5f72bd;font-size:1.125rem}.flawless-badge{font-size:1.25rem}.summary-message{text-align:center;padding:1.5rem 0;border-top:1px solid #eee;margin-top:1.5rem}.summary-message p{margin:0;color:#666;font-size:1rem}.summary-actions{display:flex;flex-direction:column;gap:.75rem}.action-button{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:1rem 1.5rem;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s}.action-button:hover{transform:translateY(-2px)}.action-button:active{transform:translateY(0)}.action-button.primary{background:linear-gradient(135deg,#5f72bd,#42b883);color:#fff;box-shadow:0 4px 15px #5f72bd66}.action-button.primary:hover{box-shadow:0 6px 20px #5f72bd80}.action-button.secondary{background:#f5f5f5;color:#333}.action-button.secondary:hover{background:#ebebeb}.button-icon{font-size:1.125rem}@media (prefers-color-scheme: dark){.daily-summary-page{background:linear-gradient(135deg,#434976,#4a2f68)}.summary-card{background:#1a1a1a}.summary-title{color:#f0f0f0}.summary-date{color:#aaa}.score-section{background:linear-gradient(135deg,#2a2a2a,#333)}.score-label{color:#aaa}.streak-section{background:linear-gradient(135deg,#3d3410,#4a3f1a)}.section-title{color:#f0f0f0}.round-item{background:#2a2a2a}.round-number{color:#f0f0f0}.summary-message{border-top-color:#333}.summary-message p{color:#aaa}.action-button.secondary{background:#2a2a2a;color:#f0f0f0}.action-button.secondary:hover{background:#333}}@media (max-width: 480px){.daily-summary-page{padding:1rem}.summary-card{padding:1.5rem}.celebration-icon{font-size:3rem}.summary-title{font-size:1.5rem}.score-value{font-size:3rem}.streak-number{font-size:2rem}}.leaderboard-filters{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:transparent;border-radius:12px;margin-bottom:1.5rem}.filter-tabs{display:flex;gap:.5rem;padding:.25rem;background:#fffc;border-radius:8px;box-shadow:0 2px 8px #5f72bd1a}.filter-tab{flex:1;padding:.625rem 1rem;border:none;border-radius:6px;background:transparent;color:#5f72bd;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.filter-tab:hover:not(:disabled){color:#333;background:#5f72bd1a}.filter-tab.active{background:linear-gradient(135deg,#5f72bd,#c06fbb);color:#fff;font-weight:600}.filter-tab:disabled{opacity:.5;cursor:not-allowed}.filter-selects{display:flex;flex-wrap:wrap;gap:1rem}.filter-group{display:flex;flex-direction:column;gap:.375rem;min-width:150px}.filter-label{font-size:.75rem;font-weight:500;color:#5f72bd;text-transform:uppercase;letter-spacing:.5px}.filter-select,.filter-input{padding:.5rem .75rem;border:2px solid rgba(95,114,189,.3);border-radius:6px;background:#fffffff2;color:#333;font-size:.9rem;transition:border-color .2s ease}.filter-select:hover:not(:disabled),.filter-input:hover:not(:disabled){border-color:#5f72bd80}.filter-select:focus,.filter-input:focus{outline:none;border-color:#5f72bd;box-shadow:0 0 0 3px #5f72bd33}.filter-select:disabled,.filter-input:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 640px){.filter-tabs{flex-wrap:wrap}.filter-tab{flex:1 1 calc(50% - .25rem);font-size:.85rem;padding:.5rem .75rem}.filter-selects{flex-direction:column}.filter-group{width:100%}}.leaderboard-entry{display:grid;grid-template-columns:80px 1fr 120px 80px;align-items:center;padding:.875rem 1rem;background:#fffc;border-radius:8px;margin-bottom:.5rem;transition:all .2s ease;border:1px solid rgba(95,114,189,.1)}.leaderboard-entry:hover{background:#fffffff2;transform:translate(4px);box-shadow:0 4px 12px #5f72bd26}.leaderboard-entry.current-player{background:linear-gradient(135deg,#5f72bd26,#c06fbb26);border:2px solid #5F72BD}.leaderboard-entry.rank-gold{background:linear-gradient(135deg,rgba(255,215,0,.1),transparent);border-left:4px solid #ffd700}.leaderboard-entry.rank-silver{background:linear-gradient(135deg,rgba(192,192,192,.1),transparent);border-left:4px solid #c0c0c0}.leaderboard-entry.rank-bronze{background:linear-gradient(135deg,rgba(205,127,50,.1),transparent);border-left:4px solid #cd7f32}.entry-rank{display:flex;align-items:center;gap:.5rem}.rank-emoji{font-size:1.25rem}.rank-number{font-size:1.125rem;font-weight:700;color:#5f72bd;min-width:2ch}.entry-player{display:flex;flex-direction:column;gap:.25rem;overflow:hidden}.player-alias{font-size:1rem;font-weight:600;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.player-location{font-size:.75rem;color:#666}.leaderboard-entry .entry-score{display:flex;align-items:baseline;gap:.25rem;justify-content:flex-end}.leaderboard-entry .score-value{font-size:1.125rem;font-weight:700;color:#1a1a2e!important;background:none!important;-webkit-background-clip:unset!important;background-clip:unset!important;-webkit-text-fill-color:#1a1a2e!important}.leaderboard-entry .score-label{font-size:.75rem;color:#444;font-weight:600}.entry-time{text-align:right}.time-value{font-size:.9rem;font-family:var(--font-mono, monospace);color:#666}@media (max-width: 640px){.leaderboard-entry{grid-template-columns:60px 1fr 80px;padding:.75rem}.entry-time{display:none}.rank-emoji,.rank-number{font-size:1rem}.player-alias{font-size:.9rem}.score-value{font-size:1rem}}.leaderboard-view{width:100%}.leaderboard-view.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem}.loading-spinner{display:flex;align-items:center;justify-content:center}.spinner{width:40px;height:40px;border:3px solid rgba(95,114,189,.3);border-top-color:#5f72bd;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:#5f72bd;font-size:.9rem}.leaderboard-view.error{display:flex;flex-direction:column;align-items:center;padding:3rem;gap:1rem;background:#ef44441a;border-radius:12px;border:1px solid rgba(239,68,68,.3)}.error-icon{font-size:2rem}.error-message{color:var(--color-error, #ef4444);text-align:center}.leaderboard-view.empty{display:flex;flex-direction:column;align-items:center;padding:3rem;gap:1rem;background:#ffffff80;border-radius:12px}.empty-icon{font-size:3rem}.empty-message{color:#666;text-align:center}.leaderboard-header{display:grid;grid-template-columns:80px 1fr 120px 80px;padding:.75rem 1rem;background:linear-gradient(135deg,#5f72bd26,#c06fbb26);border-radius:8px;margin-bottom:.75rem}.leaderboard-header>div{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:#5f72bd}.header-score,.header-time{text-align:right}.leaderboard-entries{display:flex;flex-direction:column}.player-rank-summary{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem;margin-top:1rem;background:linear-gradient(135deg,#5f72bd26,#c06fbb26);border:2px solid #5F72BD;border-radius:8px}.rank-label{color:#666;font-size:.9rem}.rank-value{font-size:1.25rem;font-weight:700;color:#5f72bd}@media (max-width: 640px){.leaderboard-header{grid-template-columns:60px 1fr 80px}.header-time{display:none}}.leaderboards-page{min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);padding:24px 16px}.leaderboards-container{max-width:800px;margin:0 auto}.leaderboards-nav{margin-bottom:16px}.leaderboards-nav .back-link{display:inline-flex;align-items:center;gap:4px;color:#fff;text-decoration:none;font-size:.9rem;font-weight:500;padding:8px 12px;background:#ffffff26;border-radius:20px;transition:all .2s ease}.leaderboards-nav .back-link:hover{background:#ffffff40;transform:translateY(-2px)}.leaderboards-header{text-align:center;margin-bottom:24px}.leaderboards-header .logo-container{margin-bottom:16px}.leaderboards-header .game-logo{width:120px;height:auto;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}.leaderboards-header h1{font-size:2.5rem;font-weight:700;color:#fff;margin:0 0 8px;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.leaderboards-subtitle{font-size:1.1rem;color:#ffffffe6;margin:0}.leaderboards-content{margin-top:20px;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000026}.load-more-button{display:block;width:100%;max-width:300px;margin:20px auto;padding:12px 24px;font-size:1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#ff6b9d,#c06fbb);border:none;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #ff6b9d66}.load-more-button:hover:not(:disabled){background:linear-gradient(135deg,#ff5a8e,#b05fac);transform:translateY(-2px);box-shadow:0 4px 12px #ff6b9d99}.load-more-button:disabled{opacity:.5;cursor:not-allowed}.leaderboards-meta{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:24px;padding-top:16px;border-top:1px solid rgba(0,0,0,.1)}.entry-count{font-size:.875rem;color:#666}.refresh-button{background:#6366f11a;border:none;font-size:1.25rem;cursor:pointer;padding:8px 12px;border-radius:8px;transition:all .2s ease}.refresh-button:hover:not(:disabled){background:#6366f133;transform:rotate(180deg)}.refresh-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 600px){.leaderboards-page{padding:16px 12px}.leaderboards-header .game-logo{width:80px}.leaderboards-header h1{font-size:1.5rem}.leaderboards-subtitle{font-size:.875rem}}.landing-page{min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);position:relative}.landing-language-picker{position:absolute;top:1rem;right:1rem;z-index:100}.landing-language-picker .language-selector-compact{background:#fffffff2;border:none;box-shadow:0 2px 8px #00000026;font-weight:500}.landing-hero{flex:1;display:flex;align-items:center;justify-content:center;gap:4rem;padding:2rem;max-width:1200px;margin:0 auto}.landing-content{flex:1;max-width:500px}.landing-title{margin:0 0 .5rem;font-size:3.5rem;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.2)}.landing-tagline{margin:0 0 2rem;font-size:1.25rem;color:#ffffffe6;line-height:1.5}.landing-features{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.feature-item{display:flex;align-items:center;gap:.75rem}.feature-icon{font-size:1.5rem}.feature-text{font-size:1rem;color:#fffffff2}.landing-actions{display:flex;gap:1rem;flex-wrap:wrap}.landing-cta-primary{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;font-size:1.125rem;font-weight:600;color:#5f72bd;background:#fff;border-radius:12px;text-decoration:none;box-shadow:0 4px 15px #0003;transition:transform .2s,box-shadow .2s}.landing-cta-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00000040}.landing-cta-secondary{display:inline-flex;align-items:center;justify-content:center;padding:1rem 2rem;font-size:1.125rem;font-weight:500;color:#fff;background:#ffffff26;border:2px solid rgba(255,255,255,.5);border-radius:12px;text-decoration:none;transition:background-color .2s,border-color .2s}.landing-cta-secondary:hover{background:#ffffff40;border-color:#ffffffb3}.landing-visual{flex:1;display:flex;align-items:center;justify-content:center}.visual-card{background:#fff;border-radius:16px;padding:1.5rem;box-shadow:0 10px 40px #0003;transform:rotate(3deg)}.visual-image-placeholder{width:280px;height:200px;background:linear-gradient(135deg,#f0f0f0,#e0e0e0);border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}.visual-emoji{font-size:4rem;opacity:.5}.visual-objects{display:flex;gap:.5rem;flex-wrap:wrap}.object-tag{padding:.5rem .75rem;font-size:.875rem;background:#f5f5f5;border-radius:20px;color:#666}.object-tag.found{background:#d4edda;color:#155724}.landing-footer{background:#1f2937f2;padding:3rem 2rem 2rem;margin-top:auto}.landing-footer .footer-content{max-width:1200px;margin:0 auto}.landing-footer .footer-links{display:flex;justify-content:center;gap:2rem;flex-wrap:wrap;margin-bottom:2rem}.landing-footer .footer-link{color:#fffc;text-decoration:none;font-weight:500;font-size:.9rem;transition:color .3s ease}.landing-footer .footer-link:hover{color:#ffc837}.landing-footer .footer-copyright{text-align:center;color:#fff9;font-size:.9rem;padding-top:2rem;border-top:1px solid rgba(255,255,255,.1);margin:0}@media (max-width: 900px){.landing-hero{flex-direction:column;gap:2rem;padding:2rem 1rem}.landing-content{text-align:center}.landing-title{font-size:2.5rem}.landing-features{align-items:center}.landing-actions{justify-content:center}.landing-visual{display:none}}@media (max-width: 480px){.landing-title{font-size:2rem}.landing-tagline{font-size:1rem}.landing-actions{flex-direction:column;width:100%}.landing-cta-primary,.landing-cta-secondary{width:100%}.footer-links{flex-direction:column;gap:.75rem}}@media (prefers-reduced-motion: reduce){.landing-cta-primary,.landing-cta-secondary,.footer-link{transition:none}.landing-cta-primary:hover{transform:none}}.feedback-form{max-width:500px;margin:0 auto;padding:1.5rem;background:var(--color-surface, #fff);border-radius:12px;border:1px solid var(--color-border, #e5e5e5)}.feedback-form--success{text-align:center;padding:2rem}.feedback-success-icon{width:64px;height:64px;margin:0 auto 1rem;background:var(--color-success, #22c55e);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700}.feedback-success-title{font-size:1.25rem;font-weight:600;color:var(--color-text, #1a1a1a);margin:0 0 .5rem}.feedback-success-message{color:var(--color-text-secondary, #666);margin:0 0 1.5rem}.feedback-new-button{padding:.75rem 1.5rem;background:var(--color-primary, #6366f1);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s ease}.feedback-new-button:hover{background:var(--color-primary-hover, #4f46e5)}.feedback-description{color:var(--color-text-secondary, #666);margin:0 0 1.25rem;font-size:.9rem}.feedback-error{background:var(--color-error-bg, #fef2f2);border:1px solid var(--color-error, #dc2626);color:var(--color-error, #dc2626);padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.feedback-field{margin-bottom:1.25rem}.feedback-label{display:block;font-weight:500;color:var(--color-text, #1a1a1a);margin-bottom:.5rem;font-size:.9rem}.feedback-input,.feedback-select,.feedback-textarea{width:100%;padding:.75rem;font-size:1rem;border:1px solid var(--color-border, #d4d4d4);border-radius:8px;background:var(--color-input-bg, #fff);color:var(--color-text, #1a1a1a);transition:border-color .2s ease,box-shadow .2s ease;box-sizing:border-box}.feedback-input:focus,.feedback-select:focus,.feedback-textarea:focus{outline:none;border-color:var(--color-primary, #6366f1);box-shadow:0 0 0 3px #6366f126}.feedback-textarea{resize:vertical;min-height:120px;font-family:inherit}.feedback-char-count{display:block;text-align:right;font-size:.75rem;color:var(--color-text-muted, #999);margin-top:.25rem}.feedback-hint{display:block;font-size:.8rem;color:var(--color-text-muted, #999);margin-top:.25rem}.feedback-submit{width:100%;padding:.875rem;background:var(--color-primary, #6366f1);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .2s ease,opacity .2s ease}.feedback-submit:hover:not(:disabled){background:var(--color-primary-hover, #4f46e5)}.feedback-submit:disabled{opacity:.6;cursor:not-allowed}@media (prefers-color-scheme: dark){.feedback-form{background:var(--color-surface-dark, #1f1f1f);border-color:var(--color-border-dark, #333)}.feedback-success-title,.feedback-label{color:var(--color-text-dark, #f5f5f5)}.feedback-description,.feedback-success-message{color:var(--color-text-secondary-dark, #a3a3a3)}.feedback-input,.feedback-select,.feedback-textarea{background:var(--color-input-bg-dark, #2a2a2a);border-color:var(--color-border-dark, #404040);color:var(--color-text-dark, #f5f5f5)}}@media (prefers-contrast: high){.feedback-input,.feedback-select,.feedback-textarea{border-width:2px}.feedback-submit{border:2px solid transparent}.feedback-submit:focus{border-color:#000;outline:2px solid #fff}}@media (prefers-reduced-motion: reduce){.feedback-input,.feedback-select,.feedback-textarea,.feedback-submit,.feedback-new-button{transition:none}}.help-page{min-height:100vh;background:linear-gradient(135deg,#ff6b9d,#c06fbb,#5f72bd,#42b883,#ffc837);padding:24px 16px}.help-header{display:flex;flex-direction:column;gap:.75rem;max-width:48rem;margin:0 auto 1.5rem;text-align:center}.help-back-link{display:inline-flex;align-items:center;gap:4px;color:#fff;text-decoration:none;font-size:.9rem;font-weight:500;padding:8px 12px;background:#ffffff26;border-radius:20px;transition:all .2s ease;width:fit-content}.help-back-link:hover{background:#ffffff40;transform:translateY(-2px);text-decoration:none}.help-title{margin:0;font-size:2.5rem;font-weight:700;color:#fff;text-shadow:2px 2px 8px rgba(0,0,0,.3)}.help-content{max-width:48rem;margin:0 auto;background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000026}.help-section{margin-bottom:2rem}.help-section-title{font-size:1.25rem;font-weight:600;color:#334155;margin:0 0 1rem}.quick-links-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem}.quick-link-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;text-decoration:none;color:#334155;transition:box-shadow .15s ease,transform .15s ease}.quick-link-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.quick-link-card:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.quick-link-icon{font-size:1.5rem;flex-shrink:0}.quick-link-text{font-weight:500;font-size:.9375rem}.faq-list{display:flex;flex-direction:column;gap:.5rem}.faq-item{background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;overflow:hidden}.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem;background:none;border:none;text-align:left;cursor:pointer;font-size:1rem;font-weight:500;color:#334155;transition:background-color .15s ease}.faq-question:hover{background-color:#f8fafc}.faq-question:focus-visible{outline:none;box-shadow:inset 0 0 0 2px #3b82f6}.faq-toggle{display:flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;font-size:1.25rem;font-weight:400;color:#64748b;flex-shrink:0}.faq-answer{padding:0 1rem 1rem}.faq-answer p{margin:0;color:#64748b;line-height:1.6;font-size:.9375rem}.faq-item--expanded{border-color:#3b82f6}.faq-item--expanded .faq-question{color:#1e40af}.contact-card{background:#fff;border-radius:.75rem;border:1px solid #e2e8f0;padding:1.5rem}.contact-description{margin:0 0 1rem;color:#475569}.contact-methods{display:flex;flex-direction:column;gap:.75rem}.contact-method{display:flex;align-items:center;gap:.75rem;padding:.875rem;background:#f8fafc;border-radius:.5rem;text-decoration:none;color:inherit;transition:background-color .15s ease}.contact-method:hover{background:#f1f5f9}.contact-method:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.contact-icon{font-size:1.25rem;flex-shrink:0}.contact-text{display:flex;flex-direction:column;gap:.125rem}.contact-label{font-size:.75rem;font-weight:600;text-transform:uppercase;color:#64748b;letter-spacing:.025em}.contact-value{font-weight:500;color:#3b82f6}.contact-note{margin:1rem 0 0;font-size:.875rem;color:#64748b;font-style:italic}.legal-links{display:flex;flex-wrap:wrap;gap:1rem}.legal-link{color:#3b82f6;text-decoration:none;font-weight:500}.legal-link:hover{text-decoration:underline}.legal-link:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}@media (max-width: 640px){.help-header{padding:1rem}.help-title{font-size:1.5rem}.help-content{padding:1rem}.quick-links-grid{grid-template-columns:1fr}.quick-link-card{padding:.875rem}.faq-question{font-size:.9375rem;padding:.875rem}.contact-card{padding:1rem}}@media (prefers-reduced-motion: reduce){.quick-link-card,.faq-question,.contact-method{transition:none}}.stats-loading{display:flex;justify-content:center;padding:2rem}.stats-error{text-align:center;color:var(--color-error, #ff6b6b);padding:1rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.stat-card{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.25rem 1rem;background:var(--color-surface-elevated, #1f4287);border-radius:.75rem;border:1px solid var(--color-border, #0f3460);text-align:center;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.stat-card.highlight{background:linear-gradient(135deg,var(--color-primary, #e94560) 0%,var(--color-primary-dark, #c23150) 100%);border-color:transparent}.stat-card.highlight .stat-label{color:#ffffffe6}.stat-card.joined-card{grid-column:span 2;background:var(--color-surface, #16213e)}.stat-card.joined-card .stat-value{font-size:1rem}.stat-value{font-size:1.75rem;font-weight:700;color:var(--color-text, #ffffff);line-height:1.2;margin-bottom:.25rem}.stat-label{font-size:.75rem;font-weight:500;color:var(--color-text-secondary, #a0a0a0);text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:1rem .75rem}.stat-value{font-size:1.5rem}.stat-label{font-size:.7rem}.stat-card.joined-card{grid-column:span 2}}@media (max-width: 400px){.stat-card.joined-card .stat-value{font-size:.9rem}}@media (prefers-contrast: high){.stat-card,.stat-card.highlight{border:2px solid var(--color-text, #ffffff)}}@media (prefers-reduced-motion: reduce){.stat-card{transition:none}.stat-card:hover{transform:none}}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.section-header h2{margin:0}.achievement-count{font-size:.875rem;color:var(--color-text-secondary, #a0a0a0);background:var(--color-surface-elevated, #1f4287);padding:.25rem .75rem;border-radius:1rem}.achievements-loading{display:flex;justify-content:center;padding:2rem}.achievements-error{text-align:center;color:var(--color-error, #ff6b6b);padding:1rem}.achievements-empty{display:flex;flex-direction:column;align-items:center;padding:2rem;text-align:center;color:var(--color-text-secondary, #a0a0a0)}.achievements-empty .empty-icon{font-size:3rem;margin-bottom:.5rem;opacity:.5}.achievements-empty p{margin:0;max-width:280px}.achievements-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.achievement-card{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--color-surface-elevated, #1f4287);border-radius:.75rem;border:1px solid var(--color-border, #0f3460);cursor:default;transition:transform .2s,box-shadow .2s}.achievement-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.achievement-icon{font-size:2rem;flex-shrink:0;width:3rem;height:3rem;display:flex;align-items:center;justify-content:center;background:var(--color-surface, #16213e);border-radius:.5rem}.achievement-info{display:flex;flex-direction:column;min-width:0}.achievement-name{font-size:.9rem;font-weight:600;color:var(--color-text, #ffffff);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.achievement-date{font-size:.75rem;color:var(--color-text-secondary, #a0a0a0);margin-top:.25rem}@media (max-width: 768px){.achievements-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:.5rem}}@media (prefers-contrast: high){.achievement-card{border:2px solid var(--color-text, #ffffff)}}@media (prefers-reduced-motion: reduce){.achievement-card{transition:none}.achievement-card:hover{transform:none}}.history-loading{display:flex;justify-content:center;padding:2rem}.history-error{text-align:center;color:var(--color-error, #ff6b6b);padding:1rem}.history-empty{display:flex;flex-direction:column;align-items:center;padding:2rem;text-align:center;color:var(--color-text-secondary, #a0a0a0)}.history-empty .empty-icon{font-size:3rem;margin-bottom:.5rem;opacity:.5}.history-empty p{margin:0;max-width:280px}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-surface-elevated, #1f4287);border-radius:.75rem;border:1px solid var(--color-border, #0f3460);transition:transform .2s,box-shadow .2s}.history-item:hover{transform:translate(4px);box-shadow:-4px 0 0 var(--color-primary, #e94560)}.history-date{min-width:90px;text-align:left}.date-text{font-size:.875rem;color:var(--color-text-secondary, #a0a0a0)}.history-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.status-badge{display:inline-flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:500;padding:.25rem .5rem;border-radius:.25rem;width:fit-content}.status-completed{background:#2ecc7133;color:#2ecc71}.status-forfeited{background:#e74c3c33;color:#e74c3c}.status-in-progress{background:#f1c40f33;color:#f1c40f}.rounds-info{font-size:.75rem;color:var(--color-text-muted, #666)}.history-score{display:flex;flex-direction:column;align-items:flex-end;min-width:70px}.score-value{font-size:1.25rem;font-weight:700;color:var(--color-text, #ffffff)}.score-label{font-size:.7rem;color:var(--color-text-secondary, #a0a0a0);text-transform:uppercase}.load-more-container{display:flex;justify-content:center;margin-top:1rem}.load-more-button{padding:.75rem 1.5rem;background:var(--color-surface-elevated, #1f4287);color:var(--color-text, #ffffff);border:1px solid var(--color-primary, #e94560);border-radius:.5rem;font-size:.875rem;cursor:pointer;transition:background .2s,transform .2s}.load-more-button:hover:not(:disabled){background:var(--color-primary, #e94560);transform:translateY(-2px)}.load-more-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.history-item{flex-wrap:wrap;gap:.5rem}.history-date{min-width:auto;width:100%}.history-details{flex:1;min-width:0}.history-score{min-width:auto}}@media (prefers-contrast: high){.history-item{border:2px solid var(--color-text, #ffffff)}.status-badge{border:1px solid currentColor}}@media (prefers-reduced-motion: reduce){.history-item,.load-more-button{transition:none}.history-item:hover,.load-more-button:hover:not(:disabled){transform:none}}.accessibility-settings{display:flex;flex-direction:column;gap:.75rem}.settings-option-content{display:flex;flex-direction:column;gap:.25rem}.settings-option-description{font-size:.8125rem;color:var(--text-secondary, #666);line-height:1.4}.high-contrast{--text-primary: #000000;--text-secondary: #1a1a1a;--bg-card: #ffffff;--bg-surface: #f0f0f0;--bg-hover: #e0e0e0;--border-color: #1a1a1a;--primary-color: #0000cc;--primary-bg: #cce0ff;--focus-color: #0000ff;--error-color: #cc0000;--success-color: #006600;--warning-color: #996600}.high-contrast .settings-option-label,.high-contrast .language-name{font-weight:600}.high-contrast .toggle-slider{border:2px solid var(--text-primary, #000000)}.high-contrast .language-option{border-width:2px}.high-contrast .language-option.selected{border-width:3px;font-weight:600}.high-contrast button,.high-contrast a,.high-contrast input,.high-contrast select{border-width:2px}.reduced-motion *,.reduced-motion *:before,.reduced-motion *:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.settings-panel{display:flex;flex-direction:column;max-width:500px;margin:0 auto;background:var(--bg-card, #ffffff);border-radius:12px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color, #e0e0e0);background:var(--bg-surface, #f8f9fa)}.settings-title{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary, #1a1a1a)}.settings-close{padding:.5rem;font-size:1.25rem;background:none;border:none;color:var(--text-secondary, #666);cursor:pointer;border-radius:4px;transition:background-color .2s,color .2s}.settings-close:hover{background-color:var(--bg-hover, #f0f0f0);color:var(--text-primary, #1a1a1a)}.settings-content{padding:1rem;display:flex;flex-direction:column;gap:1.5rem}.settings-section{display:flex;flex-direction:column;gap:.75rem}.settings-section-title{margin:0 0 .5rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary, #666)}.settings-option{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--border-light, #f0f0f0)}.settings-option:last-child{border-bottom:none}.settings-option-label{font-size:1rem;color:var(--text-primary, #1a1a1a)}.settings-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;cursor:pointer}.toggle-input{position:absolute;opacity:0;width:0;height:0}.toggle-slider{position:relative;display:inline-block;width:50px;height:28px;background-color:var(--toggle-off, #ccc);border-radius:28px;transition:background-color .3s}.toggle-slider:before{content:"";position:absolute;top:3px;left:3px;width:22px;height:22px;background-color:#fff;border-radius:50%;transition:transform .3s;box-shadow:0 1px 3px #0003}.toggle-input:checked+.toggle-slider{background-color:var(--primary-color, #4f46e5)}.toggle-input:checked+.toggle-slider:before{transform:translate(22px)}.toggle-input:focus+.toggle-slider{outline:2px solid var(--focus-color, #4f46e5);outline-offset:2px}.settings-account-info{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background:var(--bg-surface, #f8f9fa);border-radius:8px;margin-bottom:1rem}.account-detail{display:flex;gap:.5rem}.account-label{font-size:.875rem;color:var(--text-secondary, #666)}.account-value{font-size:.875rem;font-weight:500;color:var(--text-primary, #1a1a1a)}.settings-signout{margin-top:.5rem}.signout-button{width:100%;padding:.875rem 1.5rem;font-size:1rem;font-weight:500;color:var(--error-color, #dc2626);background:transparent;border:1px solid var(--error-color, #dc2626);border-radius:8px;cursor:pointer;transition:background-color .2s,color .2s}.signout-button:hover{background-color:var(--error-color, #dc2626);color:#fff}.signout-confirm{padding:1rem;background:var(--warning-bg, #fef3c7);border:1px solid var(--warning-border, #f59e0b);border-radius:8px}.signout-confirm-message{margin:0 0 1rem;font-size:.9375rem;color:var(--text-primary, #1a1a1a)}.signout-confirm-actions{display:flex;gap:.75rem}.signout-confirm-yes{flex:1;padding:.75rem 1rem;font-size:.9375rem;font-weight:500;color:#fff;background-color:var(--error-color, #dc2626);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s}.signout-confirm-yes:hover{background-color:var(--error-hover, #b91c1c)}.signout-confirm-no{flex:1;padding:.75rem 1rem;font-size:.9375rem;font-weight:500;color:var(--text-primary, #1a1a1a);background-color:var(--bg-card, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:6px;cursor:pointer;transition:background-color .2s}.signout-confirm-no:hover{background-color:var(--bg-hover, #f0f0f0)}@media (max-width: 480px){.settings-panel{border-radius:0;min-height:100vh}.settings-header,.settings-content{padding:1rem}}@media (prefers-reduced-motion: reduce){.toggle-slider,.toggle-slider:before,.signout-button,.signout-confirm-yes,.signout-confirm-no,.settings-close{transition:none}}.settings-section-wrapper{margin-bottom:1rem}.settings-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:1rem;background:var(--color-surface, #16213e);border:1px solid var(--color-border, #0f3460);border-radius:8px;cursor:pointer;transition:background-color .2s ease}.settings-section-header:hover{background:var(--color-surface-hover, #1f4287)}.settings-section-header:focus{outline:2px solid var(--color-primary, #e94560);outline-offset:2px}.settings-section-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--color-text, #ffffff)}.expand-icon{font-size:.875rem;transition:transform .3s ease;color:var(--color-text-secondary, #a0a0a0)}.expand-icon.expanded{transform:rotate(180deg)}.settings-section-content{overflow:hidden;transition:max-height .3s ease,opacity .3s ease}.settings-section-content.collapsed{max-height:0;opacity:0}.settings-section-content.expanded{max-height:2000px;opacity:1;margin-top:1rem}.settings-section-content .settings-panel{border:none;box-shadow:none;background:transparent;padding:0}.settings-section-content .settings-header,.settings-section-content .settings-close{display:none}.settings-section-content .settings-section-title{color:var(--color-text-secondary, #a0a0a0)}.settings-section-content .settings-option-label{color:var(--color-text, #ffffff)}.settings-section-content .settings-account-info{background:var(--color-surface, #16213e);border:1px solid var(--color-border, #0f3460)}.settings-section-content .account-label{color:var(--color-text-secondary, #a0a0a0)}.settings-section-content .account-value{color:var(--color-text, #ffffff)}.settings-section-content .signout-confirm{background:#f59e0b26;border-color:#f59e0b}.settings-section-content .signout-confirm-message{color:var(--color-text, #ffffff)}@media (max-width: 640px){.settings-section-header{padding:.875rem}.settings-section-title{font-size:1.125rem}}.profile-page{min-height:100vh;display:flex;flex-direction:column;background:var(--color-background, #1a1a2e);color:var(--color-text, #ffffff)}.profile-header{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:var(--color-surface, #16213e);border-bottom:1px solid var(--color-border, #0f3460)}.back-button{background:none;border:none;color:var(--color-text-secondary, #a0a0a0);font-size:1rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:color .2s,background .2s}.back-button:hover{color:var(--color-text, #ffffff);background:var(--color-surface-hover, #1f4287)}.back-button:focus-visible{outline:2px solid var(--color-primary, #e94560);outline-offset:2px}.profile-header h1{flex:1;margin:0;font-size:1.5rem;font-weight:600}.player-alias{font-size:1rem;color:var(--color-primary, #e94560);font-weight:500}.profile-loading{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.profile-loading p{color:var(--color-text-secondary, #a0a0a0)}.profile-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center}.profile-error p{color:var(--color-error, #ff6b6b)}.profile-error button{padding:.75rem 1.5rem;background:var(--color-primary, #e94560);color:#fff;border:none;border-radius:.5rem;font-size:1rem;cursor:pointer;transition:background .2s}.profile-error button:hover{background:var(--color-primary-hover, #d63250)}.profile-content{flex:1;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem;max-width:800px;width:100%;margin:0 auto}.profile-section{background:var(--color-surface, #16213e);border-radius:1rem;padding:1.5rem;border:1px solid var(--color-border, #0f3460)}.profile-section h2{margin:0 0 1rem;font-size:1.25rem;font-weight:600;color:var(--color-text, #ffffff)}.placeholder{color:var(--color-text-muted, #666);font-style:italic;text-align:center;padding:2rem}@media (max-width: 768px){.profile-header{padding:1rem}.profile-header h1{font-size:1.25rem}.profile-content{padding:1rem;gap:1rem}.profile-section{padding:1rem}}@media (prefers-contrast: high){.profile-section{border:2px solid var(--color-text, #ffffff)}.back-button:focus-visible{outline-width:3px}}@media (prefers-reduced-motion: reduce){.back-button,.profile-error button{transition:none}}
