@import "https://fonts.googleapis.com/css2?family=Clear+Sans:wght@400;500;700&display=swap";
*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.invisible{visibility:hidden}.fixed{position:fixed}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-1{gap:.25rem}.border{border-width:1px}.bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity,1))}.bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity,1))}.bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity,1))}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity,1))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity,1))}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow,0 0 #0000)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--color-bg:#fff;--color-bg-card:#fff;--color-bg-key:#d3d6da;--color-text:#1a1a1b;--color-text-muted:#787c7e;--color-tile-empty:#d3d6da;--color-tile-filled:#878a8c;--color-border:#e6e6e6;--color-correct:#6aaa64;--color-present:#c9b458;--color-absent:#787c7e;--color-danger:#c33;--color-success:#34a853;--tile-size:62px;--tile-gap:5px;--tile-border-width:3px;--key-height:58px;--header-height:50px;--game-header-app-bar:56px;--game-header-app-total:calc(var(--game-header-app-bar) + 1px)}html.dark{--color-bg:#121213;--color-bg-card:#1e1e1e;--color-bg-key:#818384;--color-text:#fff;--color-text-muted:#818384;--color-tile-empty:#4a4a4d;--color-tile-filled:#565758;--color-border:#3a3a3c;--color-correct:#538d4e;--color-present:#b59f3b;--color-absent:#3a3a3c}*,:before,:after{box-sizing:border-box}html{background-color:var(--color-bg);color:var(--color-text);font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;transition:background-color .2s,color .2s}body{background-color:var(--color-bg);color:var(--color-text);margin:0;padding:0}button{font-family:inherit}.page-wrapper{box-sizing:border-box;width:100%;min-height:100dvh;padding-inline:env(safe-area-inset-left) env(safe-area-inset-right);grid-template-rows:auto minmax(0,1fr);justify-items:stretch;display:grid}.app-header-wrap{box-sizing:border-box;width:100%;padding-top:env(safe-area-inset-top);justify-self:center}.app-header-wrap.app-header-wrap--wide{width:min(1120px,100%)}.app-header-wrap.app-header-wrap--wide .game-header{max-width:none}.coming-soon-landing{text-align:center;position:relative}.coming-soon-top-bar{top:max(16px, env(safe-area-inset-top));right:max(16px, env(safe-area-inset-right));z-index:10;position:absolute}.coming-soon-auth-trigger.restart-button{letter-spacing:.06em;white-space:nowrap;padding-inline:16px}@media (max-width:420px){.coming-soon-auth-trigger.restart-button{padding-inline:12px;font-size:.82rem}}.coming-soon-auth-overlay{z-index:300;padding:max(16px, env(safe-area-inset-top)) 16px max(16px, env(safe-area-inset-bottom));box-sizing:border-box;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.coming-soon-auth-backdrop{cursor:pointer;-webkit-backdrop-filter:blur(5px);background-color:#00000080;border:none;margin:0;padding:0;position:fixed;inset:0}.coming-soon-auth-dialog-shell{z-index:1;outline:none;width:100%;max-width:min(420px,100%);position:relative}.coming-soon-auth-card-frame{width:100%;position:relative}.coming-soon-auth-close{z-index:2;box-sizing:border-box;appearance:none;width:40px;height:40px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;margin:0;padding:0;transition:background-color .15s,color .15s;display:flex;position:absolute;top:12px;right:12px}.coming-soon-auth-close svg{flex-shrink:0;display:block}.coming-soon-auth-close:hover{background-color:var(--color-border);color:var(--color-text)}.login-card--embedded-modal{padding-top:44px}.coming-soon__subtitle{letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);margin:0;font-size:1.15rem;font-weight:600}.game-header{z-index:100;width:100%;max-width:none;height:var(--header-height);border-bottom:1px solid var(--color-border);background-color:var(--color-bg);flex-shrink:0;justify-content:center;align-items:center;padding:0 12px;display:flex;position:sticky;top:0}.game-header-actions{align-items:center;gap:8px;display:flex;position:absolute;right:12px}.game-header--app{height:var(--game-header-app-bar);justify-content:space-between;padding:0 8px}.game-header--app .title{pointer-events:none;box-sizing:border-box;letter-spacing:clamp(0px,.18vw + 1px,4px);white-space:nowrap;text-overflow:ellipsis;max-width:min(320px,100% - 104px);padding:0 6px;font-size:clamp(.65rem,2.4vw + .35rem,1.75rem);line-height:1.05;position:absolute;left:50%;overflow:hidden;transform:translate(-50%)}.game-header-left,.game-header-right{align-items:center;gap:4px;min-width:44px;display:flex;position:relative}.game-header-right{justify-content:flex-end}.header-icon-btn{width:40px;height:40px;color:var(--color-text);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;font-family:inherit;transition:background-color .15s,color .15s;display:inline-flex}.header-icon-btn:hover{background-color:var(--color-border)}.header-icon-btn:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}.menu-panel{z-index:200;background-color:var(--color-bg-card);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;gap:2px;min-width:240px;padding:8px;animation:.14s ease-out menu-pop;display:flex;position:absolute;top:calc(100% + 6px);right:0;box-shadow:0 12px 32px #0000002e}@keyframes menu-pop{0%{opacity:0;transform:translateY(-4px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}.menu-greeting{flex-direction:column;gap:2px;padding:8px 10px 4px;display:flex}.menu-greeting-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);font-size:.65rem;font-weight:700}.menu-greeting-name{color:var(--color-text);text-overflow:ellipsis;white-space:nowrap;font-size:.95rem;font-weight:600;overflow:hidden}.menu-divider{background-color:var(--color-border);height:1px;margin:4px 2px}.menu-item{width:100%;color:var(--color-text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:12px;padding:10px;font-family:inherit;font-size:.9rem;font-weight:500;transition:background-color .12s,color .12s;display:flex}.menu-item:hover:not(:disabled){background-color:var(--color-border)}.menu-item:disabled{opacity:.4;cursor:not-allowed}.menu-item-icon{width:22px;color:var(--color-text-muted);justify-content:center;align-items:center;display:inline-flex}.menu-item:hover:not(:disabled) .menu-item-icon{color:var(--color-text)}.menu-item--danger,.menu-item--danger .menu-item-icon{color:var(--color-danger)}.menu-item--danger:hover:not(:disabled){color:var(--color-danger);background-color:#cc33331a}.menu-item--danger:hover:not(:disabled) .menu-item-icon{color:var(--color-danger)}.game-content{width:min(560px,100%);padding:12px 16px max(32px, env(safe-area-inset-bottom));flex-direction:column;justify-self:center;align-items:center;gap:10px;min-height:0;display:flex;overflow-y:auto}.game-content.game-content--centered,.game-content.game-content--wordle-home{align-self:stretch;height:100%}.game-content.game-content--multiplayer{width:min(1120px,100%)}.game-stage{flex-direction:column;flex-shrink:0;align-items:center;gap:10px;width:100%;margin-top:auto;margin-bottom:auto;display:flex}.game-stage.game-stage--multiplayer{margin-top:8px;margin-bottom:0}.title{text-transform:uppercase;letter-spacing:4px;color:var(--color-text);margin:0;font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;font-size:1.75rem;font-weight:700;line-height:1}.welcome-text{color:var(--color-text-muted);margin:0;font-size:.85rem;font-weight:500}.difficulty-row{color:var(--color-text-muted);align-items:center;gap:12px;font-size:.85rem;font-weight:500;display:flex}.difficulty-row input[type=range],.setup-range-row input[type=range]{appearance:none;cursor:pointer;width:140px;height:4px;accent-color:var(--color-text);border-radius:2px;outline:none}.difficulty-row input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-text);cursor:pointer;border-radius:50%;width:18px;height:18px;margin-top:-7px}.setup-range-row input[type=range]::-webkit-slider-thumb{appearance:none;background:var(--color-text);cursor:pointer;border-radius:50%;width:18px;height:18px;margin-top:-7px}.difficulty-row input[type=range]::-moz-range-thumb{background:var(--color-text);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.setup-range-row input[type=range]::-moz-range-thumb{background:var(--color-text);cursor:pointer;border:none;border-radius:50%;width:16px;height:16px}.difficulty-row input[type=range]::-webkit-slider-runnable-track{border-radius:2px;height:4px}.setup-range-row input[type=range]::-webkit-slider-runnable-track{border-radius:2px;height:4px}.setup-panel{flex-direction:column;align-items:center;gap:14px;width:100%;padding:8px 0 4px;display:flex}.setup-panel--card{border:1px solid var(--color-border);background-color:var(--color-bg-card);border-radius:16px;width:100%;max-width:440px;margin-top:0;padding:28px 20px 24px;box-shadow:0 4px 18px #0000000a}.setup-panel--card .welcome-text{margin-bottom:4px}html.dark .setup-panel--card{box-shadow:0 4px 18px #00000059}.setup-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin:0;font-size:.75rem;font-weight:700}.setup-length-number{color:var(--color-text);margin:0;font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;font-size:4rem;font-weight:700;line-height:1}.setup-length-tiles{--setup-tile-size:40px;justify-content:center;align-items:center;gap:4px;width:100%;max-width:460px;display:flex}.setup-length-tile{width:var(--setup-tile-size);height:var(--setup-tile-size);border:var(--tile-border-width) solid var(--color-tile-empty);background-color:var(--color-bg);border-radius:2px}.setup-range-row{color:var(--color-text-muted);align-items:center;gap:10px;font-size:.75rem;font-weight:700;display:flex}.setup-start-btn{min-width:160px}.playing-meta{border:1px solid var(--color-border);letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);background-color:var(--color-bg-card);border-radius:999px;align-items:center;gap:8px;padding:4px 12px;font-size:.72rem;font-weight:700;display:inline-flex}.game-over-card{border:1px solid var(--color-border);background-color:var(--color-bg-card);border-radius:14px;flex-direction:column;align-items:center;gap:12px;margin-top:6px;padding:18px 22px;display:flex;box-shadow:0 4px 18px #0000000d}.game-over-card .win-message,.game-over-card .game-over{margin:0;font-size:1.05rem}html.dark .game-over-card{box-shadow:0 4px 18px #00000059}.change-length-link{border:1px solid var(--color-border);letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:4px;padding:3px 9px;font-family:inherit;font-size:.65rem;font-weight:700;transition:color .15s,border-color .15s}.change-length-link:hover{color:var(--color-text);border-color:var(--color-text-muted)}.game-nav{-moz-column-gap:16px;border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:center;align-items:center;gap:6px 16px;width:100%;max-width:560px;margin-top:6px;padding:10px 0 4px;display:flex}.game-nav-btn{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:2px 4px;font-family:inherit;font-size:.7rem;font-weight:700;transition:color .15s}.game-nav-btn:hover{color:var(--color-text)}.game-nav-btn:disabled{opacity:.4;cursor:not-allowed}.game-nav-btn--primary{color:var(--color-text)}.game-nav-btn--danger{color:var(--color-danger)}.game-nav-btn--danger:hover{opacity:.75;color:var(--color-danger)}.scoreboard-button,.restart-button{letter-spacing:.06em;text-transform:uppercase;background-color:var(--color-text);color:var(--color-bg);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;gap:8px;margin-top:0;padding:10px 20px;font-size:.8rem;font-weight:700;transition:opacity .15s,transform .1s;display:inline-flex}.restart-button:active:not(:disabled){transform:scale(.98)}.scoreboard-button:hover,.restart-button:hover{opacity:.8}.scoreboard-button:disabled,.restart-button:disabled{opacity:.4;cursor:not-allowed}.logout-button{letter-spacing:.06em;text-transform:uppercase;background-color:var(--color-danger);color:#fff;cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;padding:10px 20px;font-size:.8rem;font-weight:700;transition:opacity .15s;display:inline-flex}.logout-button:hover{opacity:.85}.active-button{background-color:var(--color-text)!important;color:var(--color-bg)!important;border-color:var(--color-text)!important;opacity:1!important}.grid{align-items:center;gap:var(--tile-gap);flex-direction:column;width:100%;display:flex;overflow-x:auto}.grid-row{gap:var(--tile-gap);justify-content:center;transition:gap .25s;display:flex}.grid-row--shake{animation:.5s shake}.grid-row--bounce .cell:first-child{animation:.6s forwards bounce}.grid-row--bounce .cell:nth-child(2){animation:.6s .1s forwards bounce}.grid-row--bounce .cell:nth-child(3){animation:.6s .2s forwards bounce}.grid-row--bounce .cell:nth-child(4){animation:.6s .3s forwards bounce}.grid-row--bounce .cell:nth-child(5){animation:.6s .4s forwards bounce}.cell{width:var(--tile-size);height:var(--tile-size);border:var(--tile-border-width) solid var(--color-tile-empty);text-transform:uppercase;-webkit-user-select:none;user-select:none;color:var(--color-text);background-color:var(--color-bg);flex-shrink:0;justify-content:center;align-items:center;font-size:1.75rem;font-weight:700;transition:width .25s,height .25s,border-color 50ms;display:flex}.cell--filled{border-color:var(--color-tile-filled);animation:.1s pop}.cell--flip-in{animation:.25s ease-in forwards flipIn}.cell--flip-out{animation:.25s ease-out both flipOut}.bg-green-500{background-color:var(--color-correct)!important;border-color:var(--color-correct)!important;color:#fff!important}.bg-yellow-500{background-color:var(--color-present)!important;border-color:var(--color-present)!important;color:#fff!important}.bg-gray-400{background-color:var(--color-absent)!important;border-color:var(--color-absent)!important;color:#fff!important}.hidden-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute;overflow:hidden}.input-box{border:2px solid var(--color-tile-filled);color:var(--color-text);background-color:var(--color-bg);text-align:center;letter-spacing:.1em;text-transform:uppercase;border-radius:4px;outline:none;width:240px;padding:12px 16px;font-family:inherit;font-size:1rem;font-weight:500;transition:border-color .15s,background-color .2s}.input-box:focus{border-color:var(--color-text)}.error-message{color:var(--color-danger);text-align:center;font-size:.9rem;font-weight:600}.game-over{color:var(--color-danger);text-align:center;letter-spacing:.05em;font-size:1rem;font-weight:700}.win-message{color:var(--color-correct);text-align:center;letter-spacing:.05em;font-size:1rem;font-weight:700}html.dark .win-message{color:#6aaa64}.pretty-error{color:#b30000;text-align:left;background-color:#ffe6e6;border-left:4px solid #ff4d4d;border-radius:4px;width:100%;max-width:360px;padding:10px 16px;font-size:.9rem;font-weight:500}.pretty-success{color:#1a6e31;border-left:4px solid var(--color-success);text-align:left;background-color:#e6f4ea;border-radius:4px;width:100%;padding:10px 16px;font-size:.9rem;font-weight:500}html.dark .pretty-error{color:#ff8080;border-color:var(--color-danger);background-color:#3b1a1a}html.dark .pretty-success{color:#7dce94;background-color:#1a3b22;border-color:#2e7d46}.login-page{min-height:100dvh;padding:max(24px, env(safe-area-inset-top)) max(16px, env(safe-area-inset-right)) max(24px, env(safe-area-inset-bottom)) max(16px, env(safe-area-inset-left));background-color:var(--color-bg);box-sizing:border-box;flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex}.login-tiles-stack{flex-direction:column;align-items:center;gap:6px;display:flex}.login-tiles{gap:5px;display:flex}.login-tile{border:var(--tile-border-width) solid var(--color-tile-filled);width:44px;height:44px;color:var(--color-text);background-color:#0000;border-radius:2px;font-size:1.4rem}.login-tile--reveal{animation:.5s forwards loginTileReveal}@keyframes loginTileReveal{0%{transform:rotateX(0)}50%{border-color:var(--color-tile-filled);color:var(--color-text);background-color:#0000;transform:rotateX(-90deg)}50.01%{background-color:var(--reveal-bg);border-color:var(--reveal-bg);color:#fff}to{background-color:var(--reveal-bg);border-color:var(--reveal-bg);color:#fff;transform:rotateX(0)}}.login-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:4px;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:420px;padding:36px 32px;display:flex}.login-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:8px;font-size:.9rem}.login-form{flex-direction:column;align-items:stretch;gap:14px;width:100%;display:flex}.login-field{flex-direction:column;gap:5px;width:100%;display:flex}.login-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);text-align:left;font-size:.75rem;font-weight:700}.login-input{box-sizing:border-box;text-transform:none;letter-spacing:normal;text-align:left;width:100%;margin-top:0}.login-input:-webkit-autofill{-webkit-text-fill-color:var(--color-text)!important;box-shadow:0 0 0 1000px var(--color-bg) inset!important}.login-input:-webkit-autofill:hover{-webkit-text-fill-color:var(--color-text)!important;box-shadow:0 0 0 1000px var(--color-bg) inset!important}.login-input:-webkit-autofill:focus{-webkit-text-fill-color:var(--color-text)!important;box-shadow:0 0 0 1000px var(--color-bg) inset!important}.login-input:-webkit-autofill:active{-webkit-text-fill-color:var(--color-text)!important;box-shadow:0 0 0 1000px var(--color-bg) inset!important}.password-wrapper{width:100%;position:relative}.password-wrapper .login-input{padding-right:48px}.show-password-btn{cursor:pointer;color:var(--color-text-muted);opacity:.7;background:0 0;border:none;align-items:center;padding:2px;transition:opacity .15s;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.show-password-btn:hover{opacity:1}.login-submit{letter-spacing:.08em;width:100%;margin-top:4px;padding:12px;font-size:.9rem}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-switch-mode{color:var(--color-text);cursor:pointer;text-align:center;text-underline-offset:3px;background:0 0;border:none;padding:4px 0;font-size:.85rem;font-weight:500;text-decoration:underline;transition:color .15s}.login-switch-mode:hover{color:var(--color-text-muted)}.dark-mode-switch{cursor:pointer;flex-shrink:0;width:50px;height:26px;display:inline-block;position:relative}.dark-mode-switch input{opacity:0;width:0;height:0;position:absolute}.slider{background-color:var(--color-tile-empty);border-radius:26px;transition:background-color .2s;position:absolute;inset:0}.slider:before{content:"";background-color:#fff;border-radius:50%;width:18px;height:18px;transition:transform .2s;position:absolute;top:50%;left:4px;transform:translateY(-50%)}.dark-mode-switch input:checked+.slider{background-color:var(--color-text)}.dark-mode-switch input:checked+.slider:before{transform:translateY(-50%)translate(24px)}.keyboard{flex-direction:column;align-items:center;gap:8px;width:100%;max-width:500px;padding:0 8px;display:flex}.keyboard-row{justify-content:center;gap:6px;width:100%;display:flex}.key{height:var(--key-height);background-color:var(--color-bg-key);min-width:43px;max-width:43px;color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;border:none;border-radius:4px;flex:1;justify-content:center;align-items:center;font-family:inherit;font-size:.8rem;font-weight:700;transition:background-color .1s;display:flex}.key:hover{filter:brightness(.9)}.key:active{filter:brightness(.75)}.key:disabled{opacity:.5;cursor:not-allowed}.large-key{letter-spacing:.02em;min-width:65px;max-width:65px;font-size:.72rem}.key.bg-green-500{background-color:var(--color-correct)!important;color:#fff!important}.key.bg-yellow-500{background-color:var(--color-present)!important;color:#fff!important}.key.bg-gray-400{background-color:var(--color-absent)!important;color:#fff!important}.scoreboard-stats{border:1px solid var(--color-border);background-color:var(--color-bg-card);border-radius:12px;width:100%;max-width:500px;display:flex;overflow:hidden}.scoreboard-stat{border-right:1px solid var(--color-border);flex-direction:column;flex:1;align-items:center;gap:2px;padding:14px 8px;display:flex}.scoreboard-stat:last-child{border-right:none}.scoreboard-stat-value{color:var(--color-text);font-size:1.6rem;font-weight:700;line-height:1}.scoreboard-stat-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-text-muted);font-size:.65rem;font-weight:700}.scoreboard-filters-card{border:1px solid var(--color-border);background-color:var(--color-bg-card);border-radius:12px;flex-direction:column;gap:14px;width:100%;max-width:500px;padding:16px 18px;display:flex}.scoreboard-filter-section{flex-direction:column;gap:8px;display:flex}.scoreboard-filter-group{flex-wrap:wrap;gap:6px;width:100%;display:flex}.scoreboard-chip{letter-spacing:.06em;text-transform:uppercase;min-width:36px;color:var(--color-text);border:1px solid var(--color-border);cursor:pointer;background-color:#0000;border-radius:999px;justify-content:center;align-items:center;padding:6px 12px;font-size:.72rem;font-weight:700;transition:background-color .15s,color .15s,border-color .15s;display:inline-flex}.scoreboard-chip:hover:not(.active-button){background-color:var(--color-tile-empty)}.scoreboard-list{flex-direction:column;gap:6px;width:100%;max-width:500px;margin:0;padding:0;list-style:none;display:flex}.scoreboard-item{border:1px solid var(--color-border);background-color:var(--color-bg-card);color:var(--color-text);border-radius:8px;align-items:center;gap:10px;padding:10px 14px;font-size:.9rem;display:flex}.scoreboard-item--win{border-left:4px solid var(--color-correct)}.scoreboard-item--loss{border-left:4px solid var(--color-danger)}.scoreboard-result-icon{text-align:center;width:18px;font-size:1rem;font-weight:700}.scoreboard-word{letter-spacing:.08em;text-transform:uppercase;font-weight:700}.scoreboard-meta{color:var(--color-text-muted);letter-spacing:.04em;text-transform:uppercase;margin-left:auto;font-size:.75rem;font-weight:600}.scoreboard-meta+.scoreboard-meta{margin-left:0}.scoreboard-empty{color:var(--color-text-muted);padding:24px 0;font-size:.9rem}.scoreboard-reset{letter-spacing:.08em;text-transform:uppercase;color:var(--color-danger);border:1px solid var(--color-border);cursor:pointer;background-color:#0000;border-radius:6px;justify-content:center;align-items:center;margin-top:8px;padding:8px 16px;font-size:.7rem;font-weight:700;transition:background-color .15s,border-color .15s;display:inline-flex}.scoreboard-reset:hover{border-color:var(--color-danger);background-color:#cc333314}.multiplayer-lobby{box-sizing:border-box;flex-direction:column;align-items:center;gap:16px;width:100%;padding:20px 12px;display:flex}.room-id-join{flex-direction:column;align-items:stretch;gap:8px;width:100%;max-width:280px;display:flex}.room-id-join .input-box{width:100%}.room-badge{letter-spacing:.08em;color:var(--color-text-muted);background-color:var(--color-tile-empty);border-radius:20px;align-items:center;gap:8px;padding:4px 6px 4px 12px;font-size:.8rem;font-weight:700;display:inline-flex}.room-copy-btn{font:inherit;letter-spacing:.06em;background:var(--color-text);color:var(--color-bg);cursor:pointer;border:none;border-radius:14px;padding:3px 10px;font-size:.7rem;transition:opacity .12s}.room-copy-btn:hover{opacity:.85}.room-copy-btn:active{opacity:.7}.mp-presence-toast{background:var(--color-tile-empty);color:var(--color-text);border:1px solid var(--color-border,transparent);border-radius:999px;align-items:center;gap:8px;margin:4px auto 8px;padding:8px 14px;font-size:.85rem;font-weight:600;animation:.22s ease-out mp-presence-slide;display:inline-flex}.mp-presence-toast--join{border-color:#3fa84a}.mp-presence-toast--leave{border-color:#e25555}.mp-presence-dot{background:currentColor;border-radius:50%;width:8px;height:8px}.mp-presence-toast--join .mp-presence-dot{background:#3fa84a}.mp-presence-toast--leave .mp-presence-dot{background:#e25555}@keyframes mp-presence-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.mp-waiting-card{background:var(--color-bg);border:1px solid var(--color-tile-empty);text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:10px;max-width:90%;margin:24px auto;padding:20px 28px;display:flex;box-shadow:0 6px 24px #0000001f}.mp-waiting-text{color:var(--color-text);font-size:1rem;font-weight:700}.mp-waiting-sub{opacity:.75;color:var(--color-text);font-size:.85rem}.mp-waiting-dots{gap:6px;display:inline-flex}.mp-waiting-dots span{opacity:.4;background:currentColor;border-radius:50%;width:8px;height:8px;animation:1.2s ease-in-out infinite both mp-waiting-bounce}.mp-waiting-dots span:first-child{animation-delay:-.32s}.mp-waiting-dots span:nth-child(2){animation-delay:-.16s}@keyframes mp-waiting-bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.multiplayer-boards{flex-direction:column;align-items:center;gap:24px;width:100%;display:flex}.multiplayer-board-grid{--tile-size:52px}@media (min-width:960px){.multiplayer-boards{flex-direction:row;justify-content:center;align-items:flex-start;gap:16px}.multiplayer-board-grid{--tile-size:40px}}.board-label{text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);text-align:center;margin-bottom:4px;font-size:.72rem;font-weight:700}.chat-panel{border:1px solid var(--color-border);background-color:var(--color-bg-card);border-radius:12px;flex-direction:column;width:100%;max-width:560px;margin:16px auto 0;display:flex;overflow:hidden}.chat-log{flex-direction:column;gap:4px;height:160px;padding:10px 12px;font-size:.85rem;line-height:1.4;display:flex;overflow-y:auto}.chat-empty{color:var(--color-text-muted);text-align:center;margin:auto;font-style:italic}.chat-line{word-break:break-word}.chat-line--system{color:var(--color-text-muted);font-size:.8rem;font-style:italic}.chat-line--user{color:var(--color-text)}.chat-line--user .chat-from{color:#4a90e2;font-weight:700}.chat-line--typing{color:var(--color-text-muted);align-items:center;gap:2px;font-size:.8rem;font-style:italic;display:flex}.chat-line--typing .chat-from{font-style:normal;font-weight:700}.chat-typing-text{margin-left:4px}.chat-typing-dots{gap:3px;margin-left:4px;display:inline-flex}.chat-typing-dots span{opacity:.4;background:currentColor;border-radius:50%;width:4px;height:4px;animation:1.2s ease-in-out infinite chat-typing-bounce}.chat-typing-dots span:nth-child(2){animation-delay:.15s}.chat-typing-dots span:nth-child(3){animation-delay:.3s}@keyframes chat-typing-bounce{0%,80%,to{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}.mp-color-preview{text-align:center;border:1px dashed var(--color-border);background:var(--color-bg);border-radius:8px;padding:8px 10px;font-size:.9rem}.mp-color-row{grid-template-columns:repeat(8,1fr);gap:8px;display:grid}.mp-color-swatch{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:50%;padding:0;transition:transform .1s,border-color .15s,box-shadow .15s}.mp-color-swatch:hover{transform:scale(1.08)}.mp-color-swatch:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}.mp-color-swatch--sel{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-bg-card) inset;transform:scale(1.08)}@media (max-width:420px){.mp-color-row{grid-template-columns:repeat(4,1fr)}}.mp-color-custom{border:1px solid var(--color-border);background:var(--color-bg);cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:8px 10px;display:flex}.mp-color-custom-label{letter-spacing:.14em;text-transform:uppercase;color:var(--color-text);font-size:.7rem;font-weight:800}.mp-color-custom-input{appearance:none;border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:50%;width:32px;height:32px;padding:0;overflow:hidden}.mp-color-custom-input::-webkit-color-swatch-wrapper{padding:0}.mp-color-custom-input::-webkit-color-swatch{border:none;border-radius:50%}.mp-color-custom-input::-moz-color-swatch{border:none;border-radius:50%}.mp-color-custom-hex{color:var(--color-text-muted);margin-left:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.8rem}.chat-input-row{border-top:1px solid var(--color-border);background-color:var(--color-bg);gap:6px;padding:8px;display:flex}.chat-input{border:1px solid var(--color-border);background-color:var(--color-bg-card);color:var(--color-text);border-radius:8px;outline:none;flex:1;padding:8px 10px;font-size:.9rem}.chat-input:focus{border-color:var(--color-text-muted)}.chat-send{background-color:var(--color-text);color:var(--color-bg);cursor:pointer;border:none;border-radius:8px;padding:8px 14px;font-size:.85rem;font-weight:700}.chat-send:disabled{opacity:.4;cursor:not-allowed}.challenge-link-box{border:1px solid var(--color-border);word-break:break-all;background-color:var(--color-bg-card);border-radius:12px;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:420px;padding:16px;font-size:.85rem;display:flex}.challenge-link-box a{color:var(--color-text);text-underline-offset:3px;font-weight:600;text-decoration:underline}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes flipIn{0%{transform:rotateX(0)}to{transform:rotateX(-90deg)}}@keyframes flipOut{0%{transform:rotateX(-90deg)}to{transform:rotateX(0)}}@keyframes shake{0%,to{transform:translate(0)}10%{transform:translate(-6px)}30%{transform:translate(6px)}50%{transform:translate(-4px)}70%{transform:translate(4px)}90%{transform:translate(-2px)}}@keyframes bounce{0%{transform:translateY(0)}40%{transform:translateY(-30px)}60%{transform:translateY(-15px)}80%{transform:translateY(-6px)}to{transform:translateY(0)}}@media (max-width:640px){:root{--tile-size:52px;--key-height:48px;--header-height:46px;--game-header-app-bar:52px}.login-card .title{letter-spacing:3px;font-size:1.25rem}.game-content{padding:8px 10px max(24px, env(safe-area-inset-bottom));gap:8px}.game-content.game-content--multiplayer{width:100%}.game-header--app{height:var(--game-header-app-bar);padding:0 4px}.header-icon-btn{width:38px;height:38px}.menu-panel{min-width:220px}.setup-panel--card{margin-top:0;padding:22px 16px 20px}.login-card{padding:28px 20px}.key{min-width:30px;max-width:30px;font-size:.68rem}.large-key{min-width:44px;max-width:44px;font-size:.6rem}.keyboard-row{gap:4px}.keyboard{gap:6px;padding:0 2px}.scoreboard-button,.restart-button,.logout-button{padding:9px 14px;font-size:.75rem}.setup-length-number{font-size:3.5rem}.game-nav{-moz-column-gap:12px;column-gap:12px}.game-nav-btn{font-size:.65rem}.welcome-text{font-size:.78rem}}@media (max-width:380px){:root{--tile-size:44px}.key{min-width:26px;max-width:26px}.large-key{min-width:40px;max-width:40px}}.mp-tabs{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:10px;grid-template-columns:1fr 1fr;gap:6px;width:100%;max-width:360px;margin:0 auto 4px;padding:4px;display:grid}.mp-tab{letter-spacing:.16em;text-transform:uppercase;width:100%;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:9px 10px;font-family:inherit;font-size:.72rem;font-weight:800;transition:background-color .15s,color .15s}.mp-tab:hover{color:var(--color-text)}.mp-tab--active,.mp-tab--active:hover{background:var(--color-text);color:var(--color-bg)}.mp-settings-panel{border:1.5px solid var(--color-border);background:var(--color-bg-card);border-radius:12px;flex-direction:column;gap:14px;width:100%;max-width:420px;margin:0 auto;padding:18px 16px 14px;display:flex}.mp-card{margin-top:0;border:1px solid var(--color-border);background-color:var(--color-bg-card);box-sizing:border-box;border-radius:16px;flex-direction:column;align-items:center;gap:14px;width:100%;max-width:440px;margin-inline:auto;padding:24px 20px 20px;display:flex;box-shadow:0 4px 18px #0000000a}html.dark .mp-card{box-shadow:0 4px 18px #00000059}.mp-card .setup-panel{padding:0}.mp-card .mp-settings-panel{background:0 0;border:none;max-width:100%;padding:0}.mp-settings-title{text-align:center;letter-spacing:.18em;text-transform:uppercase;color:var(--color-text);font-size:.7rem;font-weight:800}.mp-settings-foot{text-align:center;color:var(--color-text-muted);margin-top:4px;font-size:.95rem}.mp-layout-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.mp-layout-card{border:1.5px solid var(--color-border);background:var(--color-bg);color:var(--color-text);cursor:pointer;border-radius:10px;flex-direction:column;align-items:center;gap:8px;padding:14px 12px 12px;transition:background-color .15s,color .15s,border-color .15s;display:flex;position:relative}.mp-layout-card:focus-visible{outline:2px solid var(--color-text);outline-offset:2px}.mp-layout-card--sel{background:var(--color-text);color:var(--color-bg);border-color:var(--color-text)}.mp-layout-check{font-size:.7rem;font-weight:800;position:absolute;top:4px;right:6px}.mp-layout-label{letter-spacing:.14em;text-transform:uppercase;font-size:.7rem;font-weight:800}.mp-layout-sub{letter-spacing:.1em;text-transform:uppercase;opacity:.7;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.6rem}.mp-layout-preview{width:100%;display:block}.pv-svg{color:currentColor;width:100%;height:auto;display:block}.mp-pill-tabs{gap:6px;width:100%;max-width:420px;margin:0 auto 4px;padding:0 4px;display:flex}.mp-pill{letter-spacing:.12em;text-transform:uppercase;background:var(--color-bg);border:1.5px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;border-radius:999px;flex:1;padding:7px 6px;font-size:.7rem;font-weight:800;transition:background-color .15s,color .15s,border-color .15s}.mp-pill--on{color:var(--color-text);border-color:var(--color-text)}@media (max-width:760px){.multiplayer-lobby{padding:12px 8px}.multiplayer-boards--split-mobile{flex-direction:row;justify-content:center;align-items:flex-start;gap:10px}.multiplayer-boards--split-mobile .multiplayer-board-grid{--tile-size:clamp(20px, 7.5vw, 32px)}.multiplayer-boards--split-mobile .board-label{font-size:.62rem}}.feedback-trigger{border:1px solid var(--color-border);color:var(--color-text);letter-spacing:.05em;text-transform:uppercase;cursor:pointer;background:0 0;border-radius:6px;padding:6px 12px;font-family:inherit;font-size:.75rem;font-weight:600;transition:background-color .15s,border-color .15s}.feedback-trigger:hover{background-color:var(--color-border)}.feedback-overlay{z-index:400;padding:max(16px, env(safe-area-inset-top)) 16px max(16px, env(safe-area-inset-bottom));box-sizing:border-box;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow-y:auto}.feedback-backdrop{cursor:pointer;-webkit-backdrop-filter:blur(5px);background-color:#0000008c;border:none;margin:0;padding:0;position:fixed;inset:0}.feedback-dialog{z-index:1;background:var(--color-bg);border:1px solid var(--color-border);box-sizing:border-box;border-radius:12px;width:100%;max-width:min(480px,100%);padding:28px 24px 22px;position:relative;box-shadow:0 20px 60px #00000040}.feedback-close{width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;transition:background-color .15s,color .15s;display:flex;position:absolute;top:10px;right:10px}.feedback-close:hover{background-color:var(--color-border);color:var(--color-text)}.feedback-title{color:var(--color-text);margin:0 0 4px;font-size:1.25rem;font-weight:700}.feedback-subtitle{color:var(--color-text-muted);margin:0 0 18px;font-size:.85rem}.feedback-form{flex-direction:column;gap:14px;display:flex}.feedback-field{flex-direction:column;gap:6px;display:flex}.feedback-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);font-size:.7rem;font-weight:700}.feedback-optional{text-transform:none;letter-spacing:0;color:var(--color-text-muted);font-weight:500}.feedback-input{border:1px solid var(--color-border);background:var(--color-bg);width:100%;color:var(--color-text);box-sizing:border-box;border-radius:6px;outline:none;padding:10px 12px;font-family:inherit;font-size:.95rem;transition:border-color .15s}.feedback-input:focus{border-color:var(--color-text)}.feedback-textarea{resize:vertical;min-height:110px;font-family:inherit}.feedback-file-input{display:none}.feedback-file-btn{border:1px dashed var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:6px;align-self:flex-start;padding:8px 14px;font-family:inherit;font-size:.85rem;font-weight:600;transition:border-color .15s,background-color .15s}.feedback-file-btn:hover:not(:disabled){border-color:var(--color-text);background-color:var(--color-border)}.feedback-file-btn:disabled{opacity:.5;cursor:not-allowed}.feedback-file-list{flex-direction:column;gap:4px;margin:4px 0 0;padding:0;list-style:none;display:flex}.feedback-file-item{background:var(--color-tile-empty,#f3f3f3);border-radius:4px;align-items:center;gap:8px;padding:6px 10px;font-size:.82rem;display:flex}.feedback-file-name{text-overflow:ellipsis;white-space:nowrap;color:var(--color-text);flex:1;overflow:hidden}.feedback-file-size{color:var(--color-text-muted);font-size:.75rem}.feedback-file-remove{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:1.2rem;line-height:1}.feedback-file-remove:hover{color:var(--color-danger)}.feedback-file-total{color:var(--color-text-muted);margin-top:2px;font-size:.75rem}.feedback-submit{width:100%;margin-top:4px}.feedback-success{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:12px 0 4px;display:flex}.feedback-success-check{color:#fff;background:#6aaa64;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:32px;font-weight:700;display:flex}.feedback-success-text{color:var(--color-text-muted);margin:0;font-size:.9rem}.feedback-ticket-id{border:1px solid var(--color-border);color:var(--color-text);letter-spacing:.05em;border-radius:6px;padding:10px 16px;font-family:SFMono-Regular,Menlo,monospace;font-size:.95rem;font-weight:700}