:root{--font-heading: "DM Serif Display", serif;--font-body: "Lexend", sans-serif;--color-background: #fdfaf6;--color-surface: #ffffff;--color-primary: #4a5568;--color-secondary: #a0aec0;--color-text: #2d3748;--color-accent: #e5bf56;--color-gold: #ffd700;--color-silver: #c0c0c0;--color-bronze: #cd7f32;--color-success: #48bb78;--shadow: 0 4px 15px rgba(0,0,0,.05);--shadow-hover: 0 6px 20px rgba(74, 85, 104, .15);--page-inset: clamp(24px, 4vmin, 48px);--hue: 223;--trans-dur: .3s;--trans-timing: cubic-bezier(.76,.05,.24,.95);--trans-timing-in: cubic-bezier(.76,.05,.86,.06);--trans-timing-out: cubic-bezier(.05,.76,.06,.86)}[data-theme=dark]{--color-background: #181818;--color-surface: #F7F7F7;--color-primary: #FF5722;--color-secondary: #673AB7;--color-text: #181818;--color-accent: #FFEB3B;--color-gold: #FFEB3B;--color-silver: #F7F7F7;--color-bronze: #FF5722;--color-success: #673AB7;--shadow: 0 4px 15px rgba(24, 24, 24, .3);--shadow-hover: 0 6px 20px rgba(255, 87, 34, .2)}*{box-sizing:border-box;margin:0;padding:0}*{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{scroll-behavior:smooth}body,main,.card,button,input{will-change:auto;transform:translateZ(0)}body{font-family:var(--font-body);background-color:var(--color-background);color:var(--color-text);display:flex;justify-content:center;align-items:center;min-height:100vh;padding:0;transition:background-color .4s,color .4s}main{width:100%;max-width:900px;padding:var(--page-inset);margin:0 auto;transition:background-color .4s,color .4s}main.game-state-game{width:100%;height:100%;max-width:none;padding:clamp(12px,2vmin,24px)}main.game-state-scoring{width:100%;height:100%;max-width:none}main.game-state-podium{width:70vw;max-width:none}main.game-state-qwip{width:100vw;height:100vh;max-width:none;padding:0;transform:none}main.game-state-qwkword{width:100vw;height:100vh;max-width:none;padding:clamp(12px,2vmin,24px)}html,body{height:100%}html.scaled,html.scaled body{overflow:hidden}html.scaled body{padding:0}html.scaled main{width:100%;max-width:none;height:100%;padding:var(--page-inset);margin:0 auto}html.scaled body,html.scaled main,html.scaled .card,html.scaled button,html.scaled input{transform:none}h1,h2,h3{font-family:var(--font-heading);font-weight:400;transition:color .4s}.title{font-size:14rem;margin-bottom:1rem;color:var(--color-primary);transition:color .4s}.subtitle{font-size:2.5rem;text-align:center;color:var(--color-primary);transition:color .4s}.text-center{text-align:center}main.game-state-qwkword .card{margin-top:clamp(4px,.8vmin,12px);margin-bottom:clamp(24px,3vmin,40px);max-width:min(92vw,1100px);margin-left:auto;margin-right:auto}.card.launch-card{background-color:transparent!important;box-shadow:none!important;padding:2rem 3rem}.launch-divider{border:none;height:1px;background:var(--color-border, #e5e7eb);margin:1rem auto 1.25rem;max-width:480px}.card{background-color:var(--color-surface);padding:2rem 3rem;border-radius:12px;box-shadow:var(--shadow);width:100%;transition:background-color .4s,color .4s,box-shadow .4s}button{font-family:var(--font-body);font-weight:600;font-size:clamp(1rem,1.8vw,1.25rem);padding:.9em 1.75em;border-radius:10em;border:1px solid var(--color-primary);cursor:pointer;background-color:#fff;color:var(--color-primary);transition:all .3s ease-in-out,background-color .4s,color .4s,border-color .4s;margin:.5rem;display:inline-block;box-shadow:0 0 0 0 var(--color-primary)}button:hover:not(:disabled){transform:translateY(-4px) translate(-2px);box-shadow:2px 5px 0 0 var(--color-primary)}button:active:not(:disabled){transform:translateY(2px) translate(1px);box-shadow:0 0 0 0 var(--color-primary)}button:disabled{background-color:var(--color-secondary);cursor:not-allowed;opacity:.7;transform:none;box-shadow:0 0 0 0 var(--color-secondary)}button.secondary{background-color:#fff;color:var(--color-primary);border:1px solid var(--color-primary);box-shadow:0 0 0 0 var(--color-primary)}button.secondary:hover:not(:disabled){transform:translateY(-4px) translate(-2px);box-shadow:2px 5px 0 0 var(--color-primary)}button.secondary:active:not(:disabled){transform:translateY(2px) translate(1px);box-shadow:0 0 0 0 var(--color-primary)}button.ghost{background:#fff;color:var(--color-primary);border:1px solid var(--color-primary);box-shadow:0 0 0 0 var(--color-primary)}button.ghost:hover:not(:disabled){transform:translateY(-4px) translate(-2px);box-shadow:2px 5px 0 0 var(--color-primary)}button.ghost:active:not(:disabled){transform:translateY(2px) translate(1px);box-shadow:0 0 0 0 var(--color-primary)}input[type=text],input[type=number]{font-family:var(--font-body);font-size:clamp(1rem,1.6vw,1.2rem);padding:.6rem .9rem;border:2px solid #cbd5e0;border-radius:6px;margin:0 .5rem;width:80px;transition:border-color .2s,box-shadow .2s,background-color .4s,color .4s}input[type=text]:focus,input[type=number]:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #4a55681a}input[type=text]{width:220px}.modal-overlay{position:fixed!important;top:0!important;left:0!important;width:100%!important;height:100%!important;background:linear-gradient(135deg,#ffffff1a,#ffffff0d,#ffffff14);backdrop-filter:blur(12px) saturate(1.2) brightness(1.1);-webkit-backdrop-filter:blur(12px) saturate(1.2) brightness(1.1);transition:backdrop-filter .3s ease,background .3s ease;z-index:10000!important;padding:0!important;margin:0!important;box-sizing:border-box;display:flex!important;justify-content:center;align-items:center;transform:translateZ(0);isolation:isolate}.modal-content{background-color:var(--color-surface);border-radius:12px;padding:2rem;width:90%;max-width:700px;box-shadow:0 10px 25px #0000001a;display:flex;flex-direction:column;max-height:85vh;flex-shrink:0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.modal-header h3{font-size:1.8rem}.modal-body{overflow-y:auto;padding:.5rem;margin:-.5rem}.modal-footer{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;gap:1rem}.language-toggle{display:inline-flex;border:2px solid var(--color-primary);border-radius:20px;overflow:hidden;padding:2px;background-color:var(--color-surface);position:relative;width:140px;height:44px}.language-toggle:before{content:"";position:absolute;top:2px;left:2px;width:64px;height:36px;background-color:var(--color-primary);border-radius:18px;transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:0}.language-toggle button{margin:0;border-radius:18px;background:transparent;color:var(--color-primary);padding:.5rem 1rem;border:none;box-shadow:none;transition:color .3s cubic-bezier(.4,0,.2,1);position:relative;z-index:1;width:64px;height:36px;display:flex;align-items:center;justify-content:center;font-size:1rem}.language-toggle button.active{background:transparent;color:#fff;transform:none;box-shadow:none}.language-toggle button:hover{background-color:transparent!important;transform:none!important;box-shadow:none!important;cursor:pointer}.language-toggle button:active{transform:none!important;box-shadow:none!important}.language-toggle:has(button:nth-child(2).active):before{transform:translate(64px)}.category-button{background-color:#f1f5f9;color:var(--color-text);border:2px solid transparent;padding:.5rem 1rem;border-radius:20px;cursor:pointer;transition:all .2s ease}.category-button:hover{border-color:var(--color-secondary)}.category-button.active{background-color:var(--color-primary);color:#fff;font-weight:600}.remove-team-btn{background:#f87171;color:#fff;border:none;width:32px;height:32px;border-radius:50%;font-weight:700;cursor:pointer;margin-left:.5rem;padding:0;line-height:32px;text-align:center}.remove-team-btn:hover{background:#ef4444;transform:scale(1.1);box-shadow:none}.theme-switch-wrapper{position:fixed;top:20px;right:20px;z-index:1000}.sound-toggle-wrapper{position:fixed;top:50px;right:20px;z-index:1000}.switch{margin:auto;position:relative}.switch__icon,.switch__input{display:block}.switch__icon{position:absolute;top:50%;width:.75em;transform:translateY(-50%);transition:opacity calc(var(--trans-dur) / 2),transform calc(var(--trans-dur) / 2);z-index:2}.switch__icon--light{left:1.5em}.switch__icon--dark{left:.5em}.switch__icon polyline{transition:stroke-dashoffset calc(var(--trans-dur) / 2)}.switch__icon--light,.switch__icon--light polyline{transition-delay:calc(var(--trans-dur) / 2);transition-timing-function:var(--trans-timing-out)}.switch__icon--dark{opacity:0;transform:translateY(-50%) rotate(30deg) scale(.75);transition-timing-function:var(--trans-timing-in)}.switch__input{background-color:#6eb3f7;border-radius:.75em;box-shadow:0 0 0 .125em hsla(var(--hue),90%,50%,0),.125em .125em .25em hsla(var(--hue),90%,10%,.2);outline:transparent;position:relative;width:3em;height:1.5em;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;transition:background-color var(--trans-dur) var(--trans-timing),box-shadow .15s linear}.switch__input:focus-visible{box-shadow:0 0 0 .125em hsl(var(--hue),90%,50%),.125em .125em .25em hsla(var(--hue),90%,10%,.2)}.switch__input:before,.switch__input:after{content:"";display:block;position:absolute}.switch__input:before{background-color:#f2cc0d;border-radius:inherit;mask-image:linear-gradient(120deg,#000 20%,#0000 80%);-webkit-mask-image:linear-gradient(120deg,hsl(0,0%,0%) 20%,hsla(0,0%,0%,0) 80%);top:0;right:0;bottom:0;left:0;transition:background-color var(--trans-dur) var(--trans-timing)}.switch__input:after{background-color:#fff;border-radius:50%;box-shadow:.05em .05em .05em hsla(var(--hue),90%,10%,.1);top:.125em;left:.125em;width:1.25em;height:1.25em;transition:background-color var(--trans-dur) var(--trans-timing),transform var(--trans-dur) var(--trans-timing);z-index:1}.switch__input:checked{background-color:#a30ac2}.switch__input:checked:before{background-color:#0a47c2}.switch__input:checked:after{background-color:#000;transform:translate(1.5em)}.switch__input:checked~.switch__icon--light,.switch__input:checked~.switch__icon--light polyline{transition-delay:0s;transition-timing-function:var(--trans-timing-in)}.switch__input:checked~.switch__icon--light{opacity:0;transform:translateY(-50%) rotate(-30deg) scale(.75)}.switch__input:checked~.switch__icon--light polyline{stroke-dashoffset:1.5}.switch__input:checked~.switch__icon--dark{opacity:1;transform:translateY(-50%);transition-delay:calc(var(--trans-dur) / 2);transition-timing-function:var(--trans-timing-out)}.switch__sr{overflow:hidden;position:absolute;width:1px;height:1px}.sound-switch{margin:auto;position:relative}.sound-switch__icon,.sound-switch__input{display:block}.sound-switch__icon{position:absolute;top:50%;width:.75em;transform:translateY(-50%);transition:opacity calc(var(--trans-dur) / 2),transform calc(var(--trans-dur) / 2);z-index:2}.sound-switch__icon--on{left:1.5em}.sound-switch__icon--off{left:.5em}.sound-switch__icon path{transition:stroke-dashoffset calc(var(--trans-dur) / 2)}.sound-switch__icon--on,.sound-switch__icon--on path{transition-delay:calc(var(--trans-dur) / 2);transition-timing-function:var(--trans-timing-out)}.sound-switch__icon--off{opacity:0;transform:translateY(-50%) rotate(30deg) scale(.75);transition-timing-function:var(--trans-timing-in)}.sound-switch__input{background-color:#52e052;border-radius:.75em;box-shadow:0 0 0 .125em hsla(var(--hue),90%,50%,0),.125em .125em .25em hsla(var(--hue),90%,10%,.2);outline:transparent;position:relative;width:3em;height:1.5em;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;transition:background-color var(--trans-dur) var(--trans-timing),box-shadow .15s linear}.sound-switch__input:focus-visible{box-shadow:0 0 0 .125em hsl(var(--hue),90%,50%),.125em .125em .25em hsla(var(--hue),90%,10%,.2)}.sound-switch__input:before,.sound-switch__input:after{content:"";display:block;position:absolute}.sound-switch__input:before{background-color:#f2cc0d;border-radius:inherit;mask-image:linear-gradient(120deg,#000 20%,#0000 80%);-webkit-mask-image:linear-gradient(120deg,hsl(0,0%,0%) 20%,hsla(0,0%,0%,0) 80%);top:0;right:0;bottom:0;left:0;transition:background-color var(--trans-dur) var(--trans-timing)}.sound-switch__input:after{background-color:#fff;border-radius:50%;box-shadow:.05em .05em .05em hsla(var(--hue),90%,10%,.1);top:.125em;left:.125em;width:1.25em;height:1.25em;transition:background-color var(--trans-dur) var(--trans-timing),transform var(--trans-dur) var(--trans-timing);z-index:1}.sound-switch__input:checked{background-color:#d92626}.sound-switch__input:checked:before{background-color:#c20a0a}.sound-switch__input:checked:after{background-color:#000;transform:translate(1.5em)}.sound-switch__input:checked~.sound-switch__icon--on,.sound-switch__input:checked~.sound-switch__icon--on path{transition-delay:0s;transition-timing-function:var(--trans-timing-in)}.sound-switch__input:checked~.sound-switch__icon--on{opacity:0;transform:translateY(-50%) rotate(-30deg) scale(.75)}.sound-switch__input:checked~.sound-switch__icon--on path{stroke-dashoffset:1.5}.sound-switch__input:checked~.sound-switch__icon--off{opacity:1;transform:translateY(-50%);transition-delay:calc(var(--trans-dur) / 2);transition-timing-function:var(--trans-timing-out)}.sound-switch__sr{overflow:hidden;position:absolute;width:1px;height:1px}.score-tick-btn{width:32px;height:32px;border-radius:50%;border:none;background-color:transparent;cursor:pointer;transition:all .2s ease;display:flex;justify-content:center;align-items:center;padding:0;position:relative;z-index:1;isolation:isolate}.score-tick-btn svg{width:100%;height:100%;color:var(--color-secondary);transition:all .2s ease}.score-tick-btn:hover:not(.checked){background-color:#4a55681a;transform:none;box-shadow:none}.score-tick-btn:hover:not(.checked) svg{color:var(--color-primary);transform:scale(1.1)}.score-tick-btn.checked svg{color:var(--color-success);transform:scale(1.05);will-change:transform}.score-tick-btn.checked:hover{background-color:transparent;transform:none;box-shadow:none}.score-tick-btn.checked:hover svg{color:var(--color-success);transform:scale(1.05);filter:none}.game-modes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.game-mode-button{border:none;background:var(--surface, #ffffff);border-radius:16px;padding:16px;box-shadow:0 8px 24px #12263f1a;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer;text-align:left}.game-mode-button:hover{transform:translateY(-2px);box-shadow:0 12px 28px #12263f1f}.game-mode-content{display:flex;flex-direction:column}.game-mode-title{font-size:1.25rem;font-weight:700;margin-bottom:4px;color:var(--text-strong, #121a24)}.game-mode-description{font-size:.95rem;color:var(--text-muted, #3b5162)}.hint-toast{position:fixed;top:1rem;left:50%;transform:translate(-50%);background:linear-gradient(90deg,#fff7d1,#ffe7b3);border:1px solid #F2C94C;color:#7a5b00;padding:.75rem 1rem;border-radius:12px;box-shadow:0 8px 20px #00000014;z-index:1000;font-weight:600;text-align:center;max-width:32rem}.combo-badge{background:#f3e8ff;color:#6d28d9;padding:4px 10px;border-radius:999px;font-weight:700;font-size:.9rem}.found-words-panel{background:var(--surface, #ffffff);border-radius:12px;padding:12px;border:1px solid rgba(27,31,35,.08);box-shadow:0 8px 24px #12263f14;min-height:120px}.found-words-empty{color:var(--text-muted, #6b7280)}.grid-cell-highlight{border:3px solid;border-radius:4px;animation:highlightPulse 2s ease-in-out infinite}.grid-cell-highlight.color-1{border-color:#ef4444}.grid-cell-highlight.color-2{border-color:#f97316}.grid-cell-highlight.color-3{border-color:#eab308}.grid-cell-highlight.color-4{border-color:#22c55e}.grid-cell-highlight.color-5{border-color:#06b6d4}.grid-cell-highlight.color-6{border-color:#3b82f6}.grid-cell-highlight.color-7{border-color:#8b5cf6}.grid-cell-highlight.color-8{border-color:#ec4899}@keyframes highlightPulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.05)}}.word-grid-container{position:relative}.grid-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.highlight-path{stroke:#40404099;stroke-opacity:.42;fill:none;stroke-linecap:round;stroke-linejoin:round}.highlight-path.selection{stroke:#9ba5ff;stroke-opacity:.55}.highlight-path.color-1{stroke:#f8a5c2}.highlight-path.color-2{stroke:#9fe6a0}.highlight-path.color-3{stroke:#b3a2ff}.highlight-path.color-4{stroke:#86e0e0}.highlight-path.color-5{stroke:#ffb267}.highlight-path.color-6{stroke:#6ec1ff}.highlight-path.color-7{stroke:#c3f584}.highlight-path.color-8{stroke:#ff8ac8}.grid-cell.found{color:#111;font-weight:700}.howto-wrapper{background:var(--color-surface);border:1px solid rgba(27,31,35,.08);border-radius:24px;padding:28px;box-shadow:none;-webkit-backdrop-filter:none;backdrop-filter:none}.howto-header{text-align:center;margin-bottom:20px}.howto-title{font-size:26px;font-weight:800;color:#fff;letter-spacing:.3px}.howto-sub{color:#ffffffbf;font-size:14px;margin-top:6px}.howto-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;margin-top:10px}.howto-card{position:relative;background:var(--color-surface);border:1px solid rgba(27,31,35,.08);border-radius:18px;padding:14px 16px;box-shadow:none;transition:none}.howto-card:hover{transform:none;box-shadow:none;border-color:#1b1f2314}.howto-badge{position:absolute;top:-10px;left:-10px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:999px;font-weight:700;color:#fff;font-size:13px;background:var(--color-primary);box-shadow:none}.howto-content{display:flex;align-items:center;gap:12px}.howto-icon{display:none}.howto-card-title{font-size:16px;font-weight:700;color:#fff;margin-bottom:4px}.howto-card-desc{font-size:14px;color:#ffffffd9;line-height:1.45}.howto-tips{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;justify-content:center}.howto-tip{padding:8px 12px;border-radius:999px;font-size:12px;color:var(--color-text);border:1px solid rgba(27,31,35,.08);background:var(--color-surface);box-shadow:none}.howto-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.howto-title{color:var(--color-text)}.howto-sub{color:var(--text-muted, #6b7280)}.howto-card-title{color:var(--color-text)}.howto-card-desc{color:var(--color-text);opacity:.85}.howto-tip{color:var(--color-text)}.start-game-fab{position:fixed;right:clamp(12px,2vmin,20px);bottom:clamp(12px,2vmin,20px);z-index:1200;margin:0}.start-game-fab:hover,.start-game-fab:active{transform:none;box-shadow:0 0 0 0 var(--color-primary)}html.scaled main.game-state-setup{--setup-inset: 40px;padding:var(--setup-inset);padding-top:calc(var(--setup-inset) * .35)}.setup-grid{display:grid;grid-template-columns:2.2fr 1fr;grid-template-areas:"header header" "categories options" "footer footer";gap:calc(var(--setup-inset, 40px) * .8) calc(var(--setup-inset, 40px) * 1.2);margin:calc(var(--setup-inset, 40px) * .2) calc(var(--setup-inset, 40px) * 2) var(--setup-inset, 40px)}.card.setup-grid{width:auto;min-height:calc(var(--design-height, 768px) - 4 * var(--setup-inset, 32px));padding-top:calc(var(--setup-inset, 32px) * .2);align-content:start}.card.setup-grid.custom-height{min-height:var(--setup-custom-height, 50vh)!important;padding-top:var(--setup-custom-padding-top, calc(var(--setup-inset, 40px) * .5))}.setup-header{grid-area:header}.setup-categories{grid-area:categories}.setup-options{grid-area:options;border-left:1px solid #e2e8f0;padding-left:calc(var(--setup-inset) * .8)}.setup-footer{grid-area:footer;text-align:center;margin-top:1rem}.setup-section h3{margin-bottom:1rem}.setup-section label{display:block;margin-bottom:.75rem;font-weight:600}.setup-section .input-group{display:flex;align-items:center;margin-bottom:1rem;gap:.5rem;flex:1;min-width:0}.setup-section .input-group label{min-width:fit-content;margin-bottom:0;line-height:1.2;height:20px;display:flex;align-items:center}.language-categories-row{display:flex;gap:2rem;align-items:flex-start;margin-bottom:2rem}.language-section{display:flex;flex-direction:column;gap:.5rem}.language-section label{height:20px;display:flex;align-items:center;margin-bottom:0}.language-categories-row .input-group{display:flex;flex-direction:column;gap:.5rem;align-items:flex-start}.language-categories-row .input-group label{height:20px;display:flex;align-items:center;margin-bottom:0}.category-selection-summary{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;text-align:center}.category-selection-summary p{font-size:1.2rem;font-weight:600;margin-bottom:1rem}.team-list{list-style:none;margin-bottom:1rem}.team-item{display:flex;align-items:center;margin-bottom:.5rem}.team-item input{flex-grow:1;margin:0}.category-list{display:flex;flex-wrap:wrap;gap:.5rem}.modal-footer .custom-category{display:flex;align-items:center;gap:1rem;flex-grow:1}.modal-footer .custom-category .input-group{margin-bottom:0}.modal-footer .custom-category label{margin-bottom:0;white-space:nowrap}.custom-category input{width:250px}.custom-category button{padding:.5rem 1rem;font-size:.9rem;margin-left:0}.game-container{display:grid;grid-template-columns:1.2fr 1.3fr;gap:2rem;background-color:var(--color-surface);border-radius:12px;box-shadow:var(--shadow);overflow:hidden;width:100%;height:100%}.game-letter-panel{background-color:var(--color-primary);color:#fff;display:flex;justify-content:center;align-items:center;padding:2rem}.letter-display{font-family:var(--font-heading);font-size:32rem;line-height:1}.game-main-panel{padding:2rem;display:flex;flex-direction:column;height:100%;overflow:hidden;container-type:inline-size}.game-header{text-align:right}.game-header h2{font-size:1.3rem;color:var(--color-secondary)}.timer-container{margin:0 0 .75rem}.timer-display{font-size:clamp(5rem,9cqw,8rem);font-weight:700;text-align:center}.timer-bar-background{height:28px;background:#e2e8f0;border-radius:14px;overflow:hidden}.timer-bar-foreground{height:100%;background:var(--color-accent);border-radius:10px;transition:width 1s linear,background-color .3s ease}.game-categories{flex:1 1 0;padding-top:2rem;display:flex;align-items:center;min-height:0;container-type:size;--cat-sf: 1;--cat-scale: 1}html[lang=es] .game-categories,html[lang=es] .game-categories.cat-count-10,html[lang=es] .game-categories.cat-count-11,html[lang=es] .game-categories.cat-count-12,html[lang=es] .game-categories.cat-count-13{--cat-sf: 1}.game-categories ul{list-style:none;font-size:clamp(calc(.9rem * var(--cat-sf) * var(--cat-scale)),calc(3cqmin * var(--cat-sf) * var(--cat-scale)),calc(1.35rem * var(--cat-sf) * var(--cat-scale)));font-weight:600;display:grid;grid-template-columns:1fr 1fr;gap:.5rem;padding:0;margin:0;width:100%;height:100%;align-content:start}.game-categories.cat-count-1 ul,.game-categories.cat-count-1 ul li{font-size:clamp(calc(3.6rem * var(--cat-sf) * var(--cat-scale)),calc(10cqmin * var(--cat-sf) * var(--cat-scale)),calc(4.6rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-2 ul,.game-categories.cat-count-2 ul li{font-size:clamp(calc(3.4rem * var(--cat-sf) * var(--cat-scale)),calc(9.2cqmin * var(--cat-sf) * var(--cat-scale)),calc(4.1rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-3 ul,.game-categories.cat-count-3 ul li{font-size:clamp(calc(3.2rem * var(--cat-sf) * var(--cat-scale)),calc(8.4cqmin * var(--cat-sf) * var(--cat-scale)),calc(3.9rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-4 ul,.game-categories.cat-count-4 ul li{font-size:clamp(calc(3rem * var(--cat-sf) * var(--cat-scale)),calc(8cqmin * var(--cat-sf) * var(--cat-scale)),calc(3.7rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-5 ul,.game-categories.cat-count-5 ul li{font-size:clamp(calc(2.9rem * var(--cat-sf) * var(--cat-scale)),calc(7.6cqmin * var(--cat-sf) * var(--cat-scale)),calc(3.5rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-6 ul,.game-categories.cat-count-6 ul li{font-size:clamp(calc(2.8rem * var(--cat-sf) * var(--cat-scale)),calc(7.2cqmin * var(--cat-sf) * var(--cat-scale)),calc(3.4rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-7 ul,.game-categories.cat-count-7 ul li{font-size:clamp(calc(2.3rem * var(--cat-sf) * var(--cat-scale)),calc(6cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.9rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-8 ul,.game-categories.cat-count-8 ul li{font-size:clamp(calc(2.2rem * var(--cat-sf) * var(--cat-scale)),calc(5.6cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.8rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-9 ul,.game-categories.cat-count-9 ul li{font-size:clamp(calc(2.1rem * var(--cat-sf) * var(--cat-scale)),calc(5.2cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.7rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-10 ul,.game-categories.cat-count-10 ul li{font-size:clamp(calc(1.9rem * var(--cat-sf) * var(--cat-scale)),calc(4.8cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.5rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-11 ul,.game-categories.cat-count-11 ul li{font-size:clamp(calc(1.8rem * var(--cat-sf) * var(--cat-scale)),calc(4.4cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.3rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-12 ul,.game-categories.cat-count-12 ul li{font-size:clamp(calc(1.7rem * var(--cat-sf) * var(--cat-scale)),calc(4.2cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.2rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories.cat-count-13 ul,.game-categories.cat-count-13 ul li{font-size:clamp(calc(1.6rem * var(--cat-sf) * var(--cat-scale)),calc(4cqmin * var(--cat-sf) * var(--cat-scale)),calc(2.1rem * var(--cat-sf) * var(--cat-scale)))!important}.game-categories li{padding:.5rem;border-radius:6px;transition:color .4s ease-out,background-color .4s ease-out;line-height:1.2;display:flex;align-items:center;justify-content:flex-start;text-align:left;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;text-wrap:balance;font-size:1rem}.game-categories li.obscured{background-color:var(--color-primary);color:transparent;-webkit-user-select:none;user-select:none;cursor:wait}.game-controls{text-align:center;margin-top:auto;padding-top:1rem;display:flex;justify-content:center;align-items:center;gap:1rem;flex-shrink:0}.game-controls h3{font-size:3rem}.rules-content{margin:2rem 0;padding:0}.rules-text{font-size:1.1rem;line-height:1.6;color:var(--color-text);margin:0;text-align:left;max-width:100%}.scoring-card{display:flex;flex-direction:column;height:100%;padding:2rem}.scoring-layout-grid{display:grid;grid-template-columns:3fr 1fr;gap:2rem;flex-grow:1;overflow:hidden}.scoring-table-container{overflow-y:auto;position:relative;z-index:1}.scoring-table{display:grid;grid-template-columns:minmax(200px,2fr) repeat(var(--num-teams, 4),1fr);gap:.5rem;align-items:center}.scoring-table-header{font-family:var(--font-heading);font-size:1.6rem;font-weight:800;position:sticky;top:0;background:var(--color-surface);padding-bottom:.5rem;text-align:center;z-index:10}.scoring-table-header.category-header{text-align:left;font-size:1.3rem;font-weight:700}.category-label-cell{font-weight:600;text-align:left;padding:.5rem 0;font-size:1.25rem}.score-tick-cell{display:flex;justify-content:center;align-items:center;position:relative;z-index:1}.live-scores-panel{background-color:#f8fafc;border:1px solid #e2e8f0;border-radius:8px;padding:1.5rem;overflow-y:auto}.live-scores-container{position:relative;min-height:200px}.live-scores-panel h3{font-family:var(--font-heading);font-size:2rem;color:var(--color-primary);margin-bottom:1rem;position:sticky;top:0;background:#f8fafc;padding-bottom:.75rem;z-index:10}.live-score-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;border-radius:6px;margin-bottom:.5rem;transition:all .3s ease;font-weight:600;font-size:1.25rem;background-color:#e2e8f0;position:absolute;width:calc(100% - 1.5rem);left:0;top:0;height:56px;box-sizing:border-box;z-index:1}.live-score-item.animating{transform:translateY(-60px);z-index:15;box-shadow:0 4px 12px #00000026}.live-score-item.sliding-down{transform:translateY(60px);z-index:15;box-shadow:0 4px 12px #00000026}.live-score-item.animating:not(.sliding-up):not(.sliding-down){transform:translateY(0) scale(1.02);box-shadow:0 2px 8px #0000001a}.live-score-item.gold{background-color:var(--color-gold);color:var(--color-text)}.live-score-item.silver{background-color:var(--color-silver);color:var(--color-text)}.live-score-item.bronze{background-color:var(--color-bronze);color:#fff}.scores-display{margin-top:2rem}.scores-row{display:flex;justify-content:space-around;flex-wrap:wrap;margin-top:1rem;font-size:1.2rem}.score-total{padding:.5rem 1rem;border-radius:6px;margin:.25rem}.score-total.gold{background-color:var(--color-gold)}.score-total.silver{background-color:var(--color-silver)}.score-total.bronze{background-color:var(--color-bronze);color:#fff}.navigation-buttons{margin-top:2rem;text-align:center;flex-shrink:0}.podium-display{display:flex;justify-content:center;align-items:flex-end;margin:3rem 0;height:250px}.podium-box{width:150px;padding:1rem;text-align:center;color:var(--color-text);position:relative;border-radius:8px 8px 0 0}.podium-display.three-teams .podium-box{width:120px;margin:0 .3rem}.podium-box span{position:absolute;top:-15px;left:50%;transform:translate(-50%);width:30px;height:30px;border-radius:50%;display:flex;justify-content:center;align-items:center;font-weight:700;color:#fff}.podium-box h3{font-size:2rem;margin-top:.5rem}.podium-box .team-names{display:flex;flex-direction:column;align-items:center;gap:.2rem;margin:1rem 0 .5rem;min-height:2rem}.podium-box .team-name{font-size:1.1rem;font-weight:600;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .8s ease-in-out}.podium-box .team-name.revealed{opacity:1}.team-names{display:flex;flex-direction:column;align-items:center;gap:.2rem}.team-name{font-size:1rem;font-weight:500}.tie-separator{font-weight:700;color:var(--color-text);margin:0 .2rem}.remaining-teams-display{margin-top:2rem;display:flex;flex-direction:row;gap:1rem;justify-content:center;align-items:flex-end;flex-wrap:wrap}.remaining-team-item{display:flex;align-items:center;gap:1rem;background-color:#f5f5f5;padding:.8rem 1.5rem;border-radius:8px;border:1px solid #e0e0e0;min-width:200px}.rank-badge{background-color:#9e9e9e;color:#fff;width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}.team-info{display:flex;flex-direction:column;align-items:center;gap:.2rem;flex:1;justify-content:center}.team-info .team-name{font-size:.9rem;font-weight:500;color:var(--color-text)}.team-info .score{font-size:1.1rem;font-weight:700;color:var(--color-text)}.podium-box.gold{background-color:var(--color-gold)!important;color:#fff;height:100%!important;--podium-height: 100%;position:relative;z-index:10;display:flex!important;flex-direction:column;justify-content:flex-start;align-items:center;padding-top:.5rem;visibility:visible!important}.podium-box.silver{background-color:var(--color-silver);color:#fff;height:80%;--podium-height: 80%}.podium-box.bronze{background-color:var(--color-bronze);height:60%;--podium-height: 60%;color:#fff}.podium-box.gold span{background:#c9a400}.podium-box.silver span{background:#a1a1a1}.podium-box.bronze span{background:#a16428}.suspense-display{display:flex;flex-direction:column;align-items:center;justify-content:center;height:250px;margin:3rem 0}.suspense-text{font-size:1.5rem;margin-bottom:2rem;color:var(--color-text);opacity:.8;animation:pulse 1.5s ease-in-out infinite}.loading-dots{display:flex;gap:.5rem}.loading-dots span{width:12px;height:12px;background-color:var(--color-primary);border-radius:50%;animation:loadingDots 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes pulse{0%,to{opacity:.8}50%{opacity:1}}@keyframes loadingDots{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.podium-box.hidden{opacity:0;transform:translateY(50px) scale(.8);transition:all .8s ease-out}.podium-box.revealed{opacity:1;transform:translateY(0) scale(1)}.score-hidden{opacity:0;transition:opacity .8s ease-in-out}.score-revealed{opacity:1;transform:scale(1);transition:opacity .8s ease-in-out}.winner-celebration{animation:winnerPulse 1s ease-in-out infinite;box-shadow:0 0 30px #ffd70099}@keyframes winnerPulse{0%,to{transform:scale(1);box-shadow:0 0 30px #ffd70099}50%{transform:scale(1.05);box-shadow:0 0 40px #ffd700cc}}.winner-crown{position:absolute;top:-40px;left:50%;transform:translate(-50%);font-size:2rem;animation:crownFloat 2s ease-in-out infinite}@keyframes crownFloat{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-10px)}}.congratulations-title{font-size:4rem;font-weight:700;color:var(--color-gold);text-shadow:2px 2px 4px rgba(0,0,0,.3);margin:1rem 0 2rem;white-space:nowrap;line-height:1;animation:congratulationsReveal 1s ease-out}@keyframes congratulationsReveal{0%{opacity:0;transform:scale(.5)}50%{transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.play-again-celebration{animation:buttonCelebration .5s ease-out;background-color:#fff;color:var(--color-primary);border:1px solid var(--color-primary)}@keyframes buttonCelebration{0%{transform:scale(1)}50%{transform:scale(1.1)}to{transform:scale(1)}}.team-name{font-weight:700;margin-bottom:.5rem;font-size:1.1rem}.game-setup{padding:2rem}.setup-section{max-width:400px;margin:0 auto}.setup-section h3{font-family:var(--font-heading);color:var(--color-primary);margin-bottom:1.5rem}.grid-size-selector{margin-bottom:2rem}.grid-size-selector label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--color-text)}.grid-size-selector select{width:100%;padding:.75rem;border:2px solid var(--color-primary);border-radius:8px;font-size:1rem;background-color:#fff;color:var(--color-text)}.game-header{margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.game-stats{display:flex;justify-content:flex-start;align-items:center;gap:1rem;margin-bottom:0}.score-group,.game-actions{display:flex;align-items:center;gap:.75rem}.game-actions button{padding:.5rem .9rem}.stat{display:flex;flex-direction:column;align-items:center;padding:.5rem 1rem;background-color:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.stat-label{font-size:.9rem;color:var(--color-text);opacity:.7;margin-bottom:.25rem}.stat-value{font-size:1.2rem;font-weight:700;color:var(--color-primary)}.word-grid-container{display:flex;justify-content:center;margin-bottom:2rem}.word-grid{display:grid;gap:clamp(1px,.4vw,4px);background-color:#fff;padding:clamp(.5rem,1.2vw,1rem);border-radius:12px;box-shadow:0 4px 12px #0000001a;position:relative;width:min(84vw,640px);aspect-ratio:1 / 1}.grid-cell{aspect-ratio:1 / 1;display:flex;align-items:center;justify-content:center;background-color:transparent;border:none;border-radius:0;font-size:clamp(.75rem,2vmin,1.05rem);font-weight:700;color:var(--color-text);cursor:pointer;transition:background-color .2s ease,transform .2s ease;-webkit-user-select:none;user-select:none;position:relative;z-index:3}.grid-cell:hover{background-color:#3b82f61a;border-radius:8px;transform:scale(1.05)}.grid-cell.selected{background-color:transparent;border-radius:0;transform:none}.grid-cell.found{background-color:transparent;color:var(--color-text)}.word-highlight{position:absolute;border-radius:20px;opacity:.7;z-index:1;pointer-events:none;top:50%;left:50%;transform:translate(-50%,-50%)}.word-highlight.color-1{background:#ef444466}.word-highlight.color-2{background:#9333ea66}.word-highlight.color-3{background:#22c55e66}.word-highlight.color-4{background:#ec489966}.word-highlight.color-5{background:#3b82f666}.word-highlight.color-6{background:#f59e0b66}.word-highlight.color-7{background:#10b98166}.word-highlight.color-8{background:#8b5cf666}.word-highlight.horizontal{width:40px;height:36px;border-radius:18px}.word-highlight.vertical{width:36px;height:40px;border-radius:18px}.word-highlight.diagonal{width:36px;height:36px;border-radius:12px;transform:translate(-50%,-50%) rotate(45deg)}.word-highlight.horizontal-reverse{width:40px;height:36px;border-radius:18px}.word-highlight.vertical-reverse{width:36px;height:40px;border-radius:18px}.word-highlight.diagonal-reverse{width:36px;height:36px;border-radius:12px;transform:translate(-50%,-50%) rotate(-45deg)}.line-highlight{position:absolute;border-radius:9999px;pointer-events:none;opacity:.8;z-index:2}.line-highlight.selection{background:#3b82f659;z-index:3}.line-highlight.word.color-1{background:#ef444473}.line-highlight.word.color-2{background:#9333ea73}.line-highlight.word.color-3{background:#22c55e73}.line-highlight.word.color-4{background:#ec489973}.line-highlight.word.color-5{background:#3b82f673}.line-highlight.word.color-6{background:#f59e0b73}.line-highlight.word.color-7{background:#10b98173}.line-highlight.word.color-8{background:#8b5cf673}.line-highlight{box-shadow:0 0 0 2px #ffffff26 inset}.selection-highlight{position:absolute;background:#3b82f680;border-radius:20px;opacity:.8;z-index:2;pointer-events:none;top:50%;left:50%;transform:translate(-50%,-50%)}.selection-highlight.horizontal{width:40px;height:36px;border-radius:18px}.selection-highlight.vertical{width:36px;height:40px;border-radius:18px}.selection-highlight.diagonal{width:36px;height:36px;border-radius:12px;transform:translate(-50%,-50%) rotate(45deg)}.selection-highlight.horizontal-reverse{width:40px;height:36px;border-radius:18px}.selection-highlight.vertical-reverse{width:36px;height:40px;border-radius:18px}.selection-highlight.diagonal-reverse{width:36px;height:36px;border-radius:12px;transform:translate(-50%,-50%) rotate(-45deg)}@keyframes wordFound{0%{transform:scale(1)}50%{transform:scale(1.2)}to{transform:scale(1)}}.words-to-find{margin-bottom:2rem}.word-game-layout{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:16px;align-items:start;max-width:min(92vw,1100px);margin:0 auto}.words-panel{background:var(--color-surface);border:1px solid #e2e8f0;border-radius:12px;padding:16px;box-shadow:var(--shadow)}.words-panel-title{font-family:var(--font-heading);color:var(--color-text);margin:0 0 .75rem;font-size:1.1rem}.words-to-find h3{font-family:var(--font-heading);color:var(--color-primary);margin-bottom:1rem}.words-list{display:grid;grid-auto-rows:min-content;gap:.5rem;justify-content:start}.word-to-find{background-color:#f8fafc;color:var(--color-text);padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.9rem;border:2px solid #e2e8f0;transition:all .3s ease}.word-to-find.found{background-color:var(--color-gold);color:#fff;border-color:var(--color-gold);animation:wordFound .5s ease-out;text-decoration:line-through}.game-end{background-color:#f8fafc;border:2px solid var(--color-primary);border-radius:12px;padding:2rem;margin-top:2rem}.game-end h3{font-family:var(--font-heading);color:var(--color-primary);margin-bottom:1rem}.game-end p{font-size:1.1rem;margin-bottom:.5rem;color:var(--color-text)}.game-end-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}@media(max-width:900px){.word-game-layout{grid-template-columns:1fr}.words-panel{margin:0 auto;max-width:680px}}@media(max-width:768px){.game-stats{flex-direction:column;gap:1rem}.stat{flex-direction:row;justify-content:space-between}.grid-cell{font-size:clamp(.7rem,2.8vmin,1rem)}.game-end-buttons{flex-direction:column}}.achievements-row{display:flex;flex-direction:row;justify-content:center;align-items:center;gap:2rem;flex-wrap:nowrap}.achievement-item{text-align:center;min-width:0;flex-shrink:0}.achievement-icon{width:4rem;height:4rem;border-radius:1rem;display:flex;align-items:center;justify-content:center;margin:0 auto .75rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;transition:transform .3s ease}.achievement-icon:hover{transform:scale(1.1)}.achievement-score{font-size:1.875rem;font-weight:900;color:#fff;margin-bottom:.25rem}.achievement-label{font-size:.75rem;font-weight:600;color:#ffffffb3;text-transform:uppercase;letter-spacing:.05em}.game-modes-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);gap:1rem;max-width:48rem;margin:0 auto}.game-mode-button{font-family:var(--font-body);font-weight:600;padding:1.5rem 2rem;border-radius:1.5rem;border:2px solid var(--color-primary);cursor:pointer;background-color:#fff;color:var(--color-primary);transition:all .3s ease-in-out,background-color .4s,color .4s,border-color .4s;margin:.5rem;display:flex;flex-direction:column;align-items:center;text-align:center;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;position:relative;min-height:140px;justify-content:center;gap:.75rem}.game-mode-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;background-color:var(--color-primary);color:#fff}.game-mode-button:active:not(:disabled){transform:translateY(0);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.game-mode-content{width:100%;display:flex;flex-direction:column;align-items:center;gap:.75rem}.game-mode-title{font-size:1.25rem;font-weight:800;color:inherit;margin:0;line-height:1.2;letter-spacing:-.025em}.game-mode-description{color:inherit;font-size:.875rem;margin:0;line-height:1.4;opacity:.8;max-width:280px}@media(max-width:900px){.scoring-layout-grid{grid-template-columns:1fr}.live-scores-panel{order:-1;margin-bottom:2rem}.scoring-table{grid-template-columns:minmax(150px,1fr) repeat(var(--num-teams, 4),minmax(60px,1fr))}}@media(max-width:768px){body{padding:0}main.game-state-game,main.game-state-scoring{width:100vw;height:100vh;border-radius:0}main.game-state-podium{width:70vw;height:70vh;border-radius:0}.card{padding:1.5rem}.setup-grid{grid-template-columns:1fr;grid-template-areas:"header" "categories" "options" "footer"}.setup-options{border-left:none;padding-left:0}.card.setup-grid{min-height:auto;padding-top:calc(var(--setup-inset, 32px) * .4)}.card.setup-grid.custom-height{min-height:var(--setup-custom-height, auto)!important;padding-top:var(--setup-custom-padding-top, calc(var(--setup-inset, 32px) * .4))}.game-container{grid-template-columns:1fr;grid-template-rows:auto 1fr;height:100vh;border-radius:0}.game-letter-panel{min-height:200px}.letter-display{font-size:8rem}.game-main-panel{padding:1.5rem}.game-categories ul{grid-template-columns:1fr;font-size:1.1rem}.game-controls{flex-direction:column}.game-controls button{width:80%}}
