@import url("https://fonts.googleapis.com/css2?family=Clear+Sans:wght@400;500;700&display=swap");*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246/0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/*
! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com
*/*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.invisible{visibility:hidden}.flex{display:flex}.grid{display:grid}.hidden{display:none}.flex-col{flex-direction:column}.items-center{align-items:center}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.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))}.outline{outline-style:solid}.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:#ffffff;--color-bg-card:#ffffff;--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:#cc3333;--color-success:#34a853;--tile-size:62px;--tile-gap:5px;--key-height:58px;--header-height:50px}html.dark{--color-bg:#121213;--color-bg-card:#1e1e1e;--color-bg-key:#818384;--color-text:#ffffff;--color-text-muted:#818384;--color-tile-empty:#3a3a3c;--color-tile-filled:#565758;--color-border:#3a3a3c;--color-correct:#538d4e;--color-present:#b59f3b;--color-absent:#3a3a3c}*,:after,:before{box-sizing:border-box}html{font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;transition:background-color .2s ease,color .2s ease}body,html{background-color:var(--color-bg);color:var(--color-text)}body{margin:0;padding:0}button{font-family:inherit}.page-wrapper{flex-direction:column;min-height:100vh}.game-header,.page-wrapper{display:flex;align-items:center}.game-header{position:sticky;top:0;z-index:100;width:100%;max-width:500px;height:var(--header-height);justify-content:center;border-bottom:1px solid var(--color-border);background-color:var(--color-bg);padding:0 12px}.game-header-actions{position:absolute;right:12px;display:flex;align-items:center;gap:8px}.game-content{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px;padding:12px 16px 32px;gap:10px;overflow-y:auto;flex:1}.title{font-size:1.75rem;font-weight:700;font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;text-transform:uppercase;letter-spacing:4px;color:var(--color-text);margin:0;line-height:1}.welcome-text{margin:0}.difficulty-row,.welcome-text{font-size:.85rem;font-weight:500;color:var(--color-text-muted)}.difficulty-row{display:flex;align-items:center;gap:12px}.difficulty-row input[type=range],.setup-range-row input[type=range]{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:140px;height:4px;border-radius:2px;outline:none;cursor:pointer;accent-color:var(--color-text)}.difficulty-row input[type=range]::-webkit-slider-thumb,.setup-range-row input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;margin-top:-7px;border-radius:50%;background:var(--color-text);cursor:pointer}.difficulty-row input[type=range]::-moz-range-thumb,.setup-range-row input[type=range]::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--color-text);cursor:pointer;border:none}.difficulty-row input[type=range]::-webkit-slider-runnable-track,.setup-range-row input[type=range]::-webkit-slider-runnable-track{border-radius:2px;height:4px}.setup-panel{display:flex;flex-direction:column;align-items:center;gap:14px;padding:8px 0 4px;width:100%}.setup-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin:0}.setup-length-number{font-size:4rem;font-weight:700;line-height:1;color:var(--color-text);font-family:Clear Sans,Helvetica Neue,Arial,sans-serif;margin:0}.setup-range-row{display:flex;align-items:center;gap:10px;font-size:.75rem;font-weight:700;color:var(--color-text-muted)}.setup-start-btn{min-width:160px}.playing-meta{display:flex;align-items:center;gap:10px;font-size:.78rem}.change-length-link,.playing-meta{font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.change-length-link{background:none;border:1px solid var(--color-border);border-radius:4px;font-size:.65rem;cursor:pointer;padding:3px 9px;font-family:inherit;transition:color .15s,border-color .15s}.change-length-link:hover{color:var(--color-text);border-color:var(--color-text-muted)}.game-nav{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;-moz-column-gap:16px;column-gap:16px;row-gap:6px;padding:10px 0 4px;border-top:1px solid var(--color-border);width:100%;max-width:500px;margin-top:6px}.game-nav-btn{background:none;border:none;font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);cursor:pointer;padding:2px 4px;font-family:inherit;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)}.restart-button,.scoreboard-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background-color:var(--color-text);color:var(--color-bg);border:none;border-radius:4px;cursor:pointer;transition:opacity .15s;margin-top:0}.restart-button:hover,.scoreboard-button:hover{opacity:.8}.restart-button:disabled,.scoreboard-button:disabled{opacity:.4;cursor:not-allowed}.logout-button{display:inline-flex;align-items:center;justify-content:center;padding:10px 20px;font-size:.8rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;background-color:var(--color-danger);color:#fff;border:none;border-radius:4px;cursor:pointer;transition:opacity .15s}.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{flex-direction:column;align-items:center;overflow-x:auto;width:100%}.grid,.grid-row{display:flex;gap:var(--tile-gap)}.grid-row{justify-content:center;transition:gap .25s ease}.grid-row--shake{animation:shake .5s ease}.grid-row--bounce .cell:first-child{animation:bounce .6s ease 0s forwards}.grid-row--bounce .cell:nth-child(2){animation:bounce .6s ease .1s forwards}.grid-row--bounce .cell:nth-child(3){animation:bounce .6s ease .2s forwards}.grid-row--bounce .cell:nth-child(4){animation:bounce .6s ease .3s forwards}.grid-row--bounce .cell:nth-child(5){animation:bounce .6s ease .4s forwards}.cell{width:var(--tile-size);height:var(--tile-size);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:700;border:2px solid var(--color-tile-empty);text-transform:uppercase;-webkit-user-select:none;-moz-user-select:none;user-select:none;color:var(--color-text);background-color:var(--color-bg);transition:width .25s ease,height .25s ease,border-color .05s}.cell--filled{border-color:var(--color-tile-filled);animation:pop .1s ease}.cell--flip-in{animation:flipIn .25s ease-in forwards}.cell--flip-out{animation:flipOut .25s ease-out both}.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{position:absolute;opacity:0;pointer-events:none;width:1px;height:1px;overflow:hidden}.input-box{padding:12px 16px;border:2px solid var(--color-tile-filled);font-size:1rem;font-family:inherit;font-weight:500;color:var(--color-text);background-color:var(--color-bg);text-align:center;width:240px;border-radius:4px;outline:none;transition:border-color .15s,background-color .2s;letter-spacing:.1em;text-transform:uppercase}.input-box:focus{border-color:var(--color-text)}.error-message{color:var(--color-danger);font-size:.9rem;font-weight:600;text-align:center}.game-over{color:var(--color-danger)}.game-over,.win-message{font-size:1rem;font-weight:700;text-align:center;letter-spacing:.05em}.win-message{color:var(--color-correct)}html.dark .win-message{color:#6aaa64}.pretty-error{background-color:#ffe6e6;color:#b30000;border-left:4px solid #ff4d4d;max-width:360px}.pretty-error,.pretty-success{padding:10px 16px;border-radius:4px;font-weight:500;font-size:.9rem;width:100%;text-align:left}.pretty-success{background-color:#e6f4ea;color:#1a6e31;border-left:4px solid var(--color-success)}html.dark .pretty-error{background-color:#3b1a1a;color:#ff8080;border-color:var(--color-danger)}html.dark .pretty-success{background-color:#1a3b22;color:#7dce94;border-color:#2e7d46}.login-page{min-height:100vh;justify-content:center;gap:24px;padding:24px 16px;background-color:var(--color-bg)}.login-page,.login-tiles-stack{display:flex;flex-direction:column;align-items:center}.login-tiles-stack{gap:6px}.login-tiles{display:flex;gap:5px}.login-tile{width:44px;height:44px;font-size:1.4rem;border:none;border-radius:2px}.login-tiles>.cell.bg-green-500,.login-tiles>.cell.bg-yellow-500{color:#fff!important}.login-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:4px;padding:36px 32px;width:100%;max-width:420px;display:flex;flex-direction:column;align-items:center;gap:8px}.login-subtitle{font-size:.9rem;color:var(--color-text-muted);margin-bottom:8px;text-align:center}.login-form{align-items:stretch;gap:14px}.login-field,.login-form{display:flex;flex-direction:column;width:100%}.login-field{gap:5px}.login-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-muted);text-align:left}.login-input{width:100%;margin-top:0;box-sizing:border-box;text-transform:none;letter-spacing:normal;text-align:left}.login-input:-webkit-autofill,.login-input:-webkit-autofill:active,.login-input:-webkit-autofill:focus,.login-input:-webkit-autofill:hover{-webkit-text-fill-color:var(--color-text)!important;box-shadow:0 0 0 1000px var(--color-bg) inset!important}.password-wrapper{position:relative;width:100%}.password-wrapper .login-input{padding-right:48px}.show-password-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:2px;color:var(--color-text-muted);opacity:.7;transition:opacity .15s;display:flex;align-items:center}.show-password-btn:hover{opacity:1}.login-submit{width:100%;margin-top:4px;padding:12px;font-size:.9rem;letter-spacing:.08em}.login-submit:disabled{opacity:.5;cursor:not-allowed}.login-switch-mode{background:none;border:none;color:var(--color-text);font-size:.85rem;font-weight:500;cursor:pointer;padding:4px 0;text-align:center;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.login-switch-mode:hover{color:var(--color-text-muted)}.dark-mode-switch{display:inline-block;width:50px;height:26px;cursor:pointer;position:relative;flex-shrink:0}.dark-mode-switch input{opacity:0;width:0;height:0;position:absolute}.slider{position:absolute;inset:0;background-color:var(--color-tile-empty);border-radius:26px;transition:background-color .2s}.slider:before{position:absolute;content:"";height:18px;width:18px;left:4px;top:50%;transform:translateY(-50%);background-color:#fff;border-radius:50%;transition:transform .2s}.dark-mode-switch input:checked+.slider{background-color:var(--color-text)}.dark-mode-switch input:checked+.slider:before{transform:translateY(-50%) translateX(24px)}.keyboard{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;max-width:500px;padding:0 8px}.keyboard-row{gap:6px;width:100%}.key,.keyboard-row{display:flex;justify-content:center}.key{height:var(--key-height);flex:1;min-width:43px;max-width:43px;align-items:center;font-size:.8rem;font-weight:700;font-family:inherit;border-radius:4px;border:none;background-color:var(--color-bg-key);color:var(--color-text);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;transition:background-color .1s}.key:hover{filter:brightness(.9)}.key:active{filter:brightness(.75)}.key:disabled{opacity:.5;cursor:not-allowed}.large-key{min-width:65px;max-width:65px;font-size:.72rem;letter-spacing:.02em}.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-filter-group{flex-wrap:wrap;justify-content:center}.scoreboard-filter-group,.scoreboard-list{display:flex;gap:6px;width:100%;max-width:500px}.scoreboard-list{list-style:none;padding:0;margin:0;flex-direction:column}.scoreboard-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:4px;border:1px solid var(--color-border);font-size:.9rem;background-color:var(--color-bg-card);color:var(--color-text)}.scoreboard-item--win{border-left:4px solid var(--color-correct)}.scoreboard-item--loss{border-left:4px solid var(--color-danger)}.scoreboard-word{font-weight:700;letter-spacing:.08em;text-transform:uppercase}.multiplayer-lobby{align-items:center;gap:16px;padding:32px 16px}.multiplayer-lobby,.room-id-join{display:flex;flex-direction:column}.room-id-join{align-items:stretch;gap:8px;width:100%;max-width:280px}.room-id-join .input-box{width:100%}.room-badge{display:inline-flex;align-items:center;gap:6px;font-size:.8rem;font-weight:700;letter-spacing:.08em;color:var(--color-text-muted);background-color:var(--color-tile-empty);padding:4px 12px;border-radius:20px}.multiplayer-boards{display:flex;flex-direction:column;align-items:center;gap:24px;width:100%}.multiplayer-board-grid{--tile-size:52px}@media (min-width:700px){.multiplayer-boards{flex-direction:row;align-items:flex-start;justify-content:center;gap:16px}.multiplayer-board-grid{--tile-size:40px}}.board-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted);margin-bottom:4px;text-align:center}.challenge-link-box{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:1px solid var(--color-border);border-radius:4px;width:100%;max-width:420px;word-break:break-all;font-size:.85rem;background-color:var(--color-bg-card)}.challenge-link-box a{color:var(--color-text);font-weight:600;text-decoration:underline;text-underline-offset:3px}@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes flipIn{0%{transform:rotateX(0deg)}to{transform:rotateX(-90deg)}}@keyframes flipOut{0%{transform:rotateX(-90deg)}to{transform:rotateX(0deg)}}@keyframes shake{0%,to{transform:translateX(0)}10%{transform:translateX(-6px)}30%{transform:translateX(6px)}50%{transform:translateX(-4px)}70%{transform:translateX(4px)}90%{transform:translateX(-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}.title{font-size:1.25rem;letter-spacing:3px}.game-content{padding:8px 10px 24px;gap:8px}.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{padding:0 2px;gap:6px}.logout-button,.restart-button,.scoreboard-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}}