:root{--color-bg: #f8f6f3;--color-bg-secondary: #ffffff;--color-bg-tertiary: #eeebe6;--color-text: #2a2825;--color-text-muted: #7a756e;--color-border: #d8d4ce;--color-border-subtle: #e8e4de;--color-accent: #b86d4a;--color-accent-hover: #a55f3c;--color-accent-muted: #c9917a;--color-accent-bg: rgba(184, 109, 74, .1);--color-verified: #5f8a5c;--color-verified-bg: rgba(95, 138, 92, .12);--color-error: #a85555;--color-error-bg: rgba(168, 85, 85, .1);--color-warning: #a68840;--color-warning-bg: rgba(166, 136, 64, .1);--color-cell-bg: #ffffff;--color-cell-selected: #f0e6d6;--color-cell-word: #f7f2ea;--color-cell-blocked: #2a2825;--color-keyboard-bg: #e8e4de;--color-keyboard-key: #ffffff;--color-keyboard-key-active: #d8d4ce}[data-theme=dark]{--color-bg: #141414;--color-bg-secondary: #1c1c1c;--color-bg-tertiary: #262626;--color-text: #f0ebe3;--color-text-muted: #9a9590;--color-border: #3a3836;--color-border-subtle: #2a2826;--color-accent: #c47d5a;--color-accent-hover: #d4906b;--color-accent-muted: #8b5a3c;--color-accent-bg: rgba(196, 125, 90, .15);--color-verified: #7d9a7a;--color-verified-bg: rgba(125, 154, 122, .2);--color-error: #b87070;--color-error-bg: rgba(184, 112, 112, .15);--color-warning: #c9a86c;--color-warning-bg: rgba(201, 168, 108, .15);--color-cell-bg: #1f1e1d;--color-cell-selected: #4a4030;--color-cell-word: #2e2a24;--color-cell-blocked: #0a0a09;--color-keyboard-bg: #1c1c1c;--color-keyboard-key: #333230;--color-keyboard-key-active: #403e3a}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{font-family:system-ui,sans-serif;line-height:1.5;font-weight:400;color:#f0ebe3;background-color:#141414;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html,body{min-width:320px;height:100%;height:100dvh;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none}#root{height:100%;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);padding-left:env(safe-area-inset-left,0);padding-right:env(safe-area-inset-right,0)}input,textarea,[contenteditable=true],.selectable-text{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text;-webkit-touch-callout:default}.crossword-grid-container{--cell-size: 30px;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.crossword-grid{--grid-gap: 2px;--transition-duration: .12s;display:grid;gap:var(--grid-gap);justify-content:center;background-color:var(--color-border);padding:2px;border-radius:4px}.crossword-cell{position:relative;display:flex;align-items:center;justify-content:center;width:var(--cell-size);height:var(--cell-size);border:1px solid var(--color-border);-webkit-user-select:none;user-select:none;transition:background-color var(--transition-duration) ease,border-color var(--transition-duration) ease}.crossword-cell.cell--white{background-color:var(--color-cell-bg);cursor:pointer;-webkit-tap-highlight-color:transparent}.crossword-cell.cell--white:hover{background-color:var(--color-cell-word)}.crossword-cell.cell--black{background-color:var(--color-cell-blocked);cursor:default}.crossword-cell.cell--selected{border:2px solid var(--color-accent);background-color:var(--color-cell-selected)}.crossword-cell.cell--selected-custom{position:relative}.crossword-cell.cell--in-word{background-color:var(--color-cell-word)}.clue-number{position:absolute;top:1px;left:2px;font-size:clamp(.4rem,calc(var(--cell-size) * .25),.55rem);font-weight:500;color:var(--color-text-muted);line-height:1;z-index:1;pointer-events:none}.cell-letter{font-size:clamp(.7rem,calc(var(--cell-size) * .55),1.2rem);font-weight:600;text-transform:uppercase;color:var(--color-text);line-height:1;position:relative;z-index:2}@keyframes letter-reveal{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.crossword-grid-container--animating-letters .cell-letter:not(:empty){animation:letter-reveal .35s ease-out both}.cell--verified:after{content:"";position:absolute;bottom:2px;right:2px;width:4px;height:4px;background-color:var(--color-verified);border-radius:50%;opacity:.8;z-index:1;pointer-events:none}.cell--error{background-color:color-mix(in srgb,var(--color-error) 25%,transparent)!important}.cell--error .cell-letter{color:var(--color-error)}@keyframes cell-shake{0%,to{transform:translate(0)}20%{transform:translate(-2px)}40%{transform:translate(2px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}.cell--error{animation:cell-shake .3s ease-in-out}.cell--collaborator-cursor,.cell--collaborator-overlap{position:relative}.cell--collaborator-overlap.cell--overlap-single:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 10px 10px 0;border-color:transparent var(--collab-color, #888) transparent transparent;z-index:15;pointer-events:none}.cell--collaborator-overlap.cell--overlap-double:before{content:"";position:absolute;top:0;right:0;width:0;height:0;border-style:solid;border-width:0 10px 10px 0;border-color:transparent var(--collab-color-1, #888) transparent transparent;z-index:15;pointer-events:none}.cell--collaborator-overlap.cell--overlap-double:after{content:"";position:absolute;bottom:0;left:0;width:0;height:0;border-style:solid;border-width:10px 0 0 10px;border-color:transparent transparent transparent var(--collab-color-2, #888);z-index:15;pointer-events:none}.cell--collaborator-crowd{position:relative}.cell--collaborator-crowd:before{content:"";position:absolute;top:-1px;right:-1px;width:12px;height:12px;background:linear-gradient(135deg,var(--collab-color-1, #888) 50%,var(--collab-color-2, #666) 50%);border-radius:0 0 0 100%;z-index:15;pointer-events:none;animation:crowd-pulse 2s ease-in-out infinite}.cell--collaborator-crowd:after{content:attr(data-collab-count);position:absolute;top:-2px;right:-2px;min-width:14px;height:14px;background:var(--color-surface);color:var(--color-text);font-size:9px;font-weight:700;line-height:14px;text-align:center;border-radius:7px;border:1px solid var(--collab-color-1, var(--color-border));z-index:16;pointer-events:none}@keyframes crowd-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.cell--selected-custom.cell--collaborator-crowd:after{background:var(--color-warning-bg);border-color:var(--color-warning)}.cell--referenced-clue{background-color:var(--color-warning-bg)!important}.cell--referenced-letter{background-color:color-mix(in srgb,var(--color-warning) 25%,transparent)!important;outline:2px solid var(--color-warning)!important;outline-offset:-2px;position:relative;z-index:3}.crossword-cell.cell--in-word.cell--referenced-letter,.crossword-cell.cell--selected.cell--referenced-letter{outline:2px solid var(--color-warning)!important;outline-offset:-2px}.cell--meta-clue{background-color:color-mix(in srgb,var(--color-accent) 12%,transparent)!important;outline:2px dashed var(--color-accent-muted)!important;outline-offset:-2px;position:relative;z-index:2}.crossword-grid--zoomed{transition:transform .2s ease-in-out}.crossword-grid-container{touch-action:pan-x pan-y}.crossword-cell--edge{width:100%;height:100%;opacity:.85;overflow:hidden;position:relative;cursor:pointer}.crossword-cell--edge-top{display:flex;align-items:flex-end;justify-content:center;mask-image:linear-gradient(to bottom,#0000004d,#000);-webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,.3) 0%,rgba(0,0,0,1) 100%)}.crossword-cell--edge-top .cell-letter{transform:translateY(calc(var(--cell-size) * .3))}.crossword-cell--edge-bottom{display:flex;align-items:flex-start;justify-content:center;mask-image:linear-gradient(to top,#0000004d,#000);-webkit-mask-image:linear-gradient(to top,rgba(0,0,0,.3) 0%,rgba(0,0,0,1) 100%)}.crossword-cell--edge-bottom .cell-letter{transform:translateY(calc(var(--cell-size) * -.3))}.crossword-cell--edge-left{display:flex;align-items:center;justify-content:flex-end;mask-image:linear-gradient(to right,#0000004d,#000);-webkit-mask-image:linear-gradient(to right,rgba(0,0,0,.3) 0%,rgba(0,0,0,1) 100%)}.crossword-cell--edge-left .cell-letter{transform:translate(calc(var(--cell-size) * .3))}.crossword-cell--edge-right{display:flex;align-items:center;justify-content:flex-start;mask-image:linear-gradient(to left,#0000004d,#000);-webkit-mask-image:linear-gradient(to left,rgba(0,0,0,.3) 0%,rgba(0,0,0,1) 100%)}.crossword-cell--edge-right .cell-letter{transform:translate(calc(var(--cell-size) * -.3))}.crossword-cell--corner{width:100%;height:100%;background:transparent;border:none;pointer-events:none}.crossword-grid--zoomed{border-radius:0;position:relative}.crossword-grid--zoomed.grid--rounded-tl{border-top-left-radius:4px}.crossword-grid--zoomed.grid--rounded-tr{border-top-right-radius:4px}.crossword-grid--zoomed.grid--rounded-bl{border-bottom-left-radius:4px}.crossword-grid--zoomed.grid--rounded-br{border-bottom-right-radius:4px}.crossword-grid--zoomed:before{content:"";position:absolute;inset:0;pointer-events:none;z-index:20;box-shadow:var(--edge-shadow, none);border-radius:inherit}.notification{position:fixed;z-index:1000;display:flex;align-items:center;gap:.375rem;pointer-events:auto;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;will-change:transform,opacity;backface-visibility:hidden}.notification--compact{top:calc(.5rem + env(safe-area-inset-top,0px));left:50%;transform:translate(-50%);padding:.375rem .75rem;font-size:.75rem;font-weight:500;color:var(--color-text);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:1rem;box-shadow:0 2px 8px #0000001a;animation:notification-compact-enter .25s cubic-bezier(.16,1,.3,1) both}.notification--compact.notification--exiting{animation:notification-compact-exit .15s cubic-bezier(.4,0,1,1) both}@keyframes notification-compact-enter{0%{opacity:0;transform:translate(-50%) translateY(-8px) scale(.95)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes notification-compact-exit{0%{opacity:1;transform:translate(-50%) translateY(0) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-4px) scale(.98)}}.notification--normal{top:calc(3.5rem + env(safe-area-inset-top,0px));right:calc(1rem + env(safe-area-inset-right,0px));padding:.5rem .875rem;font-size:.8125rem;font-weight:500;color:var(--color-text);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:.5rem;box-shadow:0 4px 12px #0000001a,0 1px 3px #00000014;animation:notification-normal-enter .25s cubic-bezier(.16,1,.3,1) both}.notification--normal.notification--exiting{animation:notification-normal-exit .15s cubic-bezier(.4,0,1,1) both}@keyframes notification-normal-enter{0%{opacity:0;transform:translate(8px) scale(.97)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes notification-normal-exit{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(4px) scale(.98)}}.notification__icon{flex-shrink:0;font-size:.875em;line-height:1}.notification__message{line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.notification--normal .notification__message{max-width:280px}@media(prefers-reduced-motion:reduce){.notification--compact,.notification--normal,.notification--compact.notification--exiting,.notification--normal.notification--exiting{animation:none;opacity:1;transform:none}.notification--compact.notification--exiting,.notification--normal.notification--exiting{opacity:0}}@media(prefers-color-scheme:dark){.notification--compact,.notification--normal{box-shadow:0 2px 12px #0000004d}}.clue-bar{display:flex;align-items:center;gap:.5rem;width:100%;max-width:500px;height:56px;padding:.5rem;background-color:var(--color-bg-secondary);border-radius:8px;font-size:.9375rem;line-height:1.4;user-select:none;-webkit-user-select:none}.clue-bar--empty{justify-content:center;align-items:center;padding:.75rem 1rem}.clue-bar__placeholder{color:var(--color-text-muted);font-style:italic}.clue-bar__nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--color-text);background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));border-radius:8px;cursor:pointer;flex-shrink:0;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.clue-bar__nav-btn:hover:not(:disabled){background:var(--color-border);border-color:var(--color-border)}.clue-bar__nav-btn:active:not(:disabled){transform:scale(.96)}.clue-bar__nav-btn:disabled{opacity:.35;cursor:not-allowed}.clue-bar__nav-btn:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.clue-bar__nav-btn:focus{outline:none}.clue-bar__nav-icon{width:16px;height:16px}.clue-bar__content{flex:1;display:flex;align-items:center;justify-content:center;min-width:0;text-align:center;overflow:hidden}.clue-bar__clue-text{line-height:1.4;color:var(--color-text)}.clue-bar__number{font-weight:700;color:var(--color-accent)}.clue-bar__content--tappable{cursor:pointer;-webkit-tap-highlight-color:transparent}.clue-bar__content--tappable:focus{outline:none}@media(max-width:360px){.clue-bar{gap:.375rem;padding:.375rem}.clue-bar__nav-btn{width:32px;height:32px;font-size:.75rem}.clue-bar__content{font-size:.875rem}}.clue-bar-skeleton{display:flex;align-items:center;gap:.5rem;width:100%;max-width:500px;height:56px;padding:.5rem;background-color:var(--color-bg-secondary);border-radius:8px;box-sizing:border-box}.clue-bar-skeleton__nav{width:36px;height:36px;background-color:var(--color-bg-tertiary);border-radius:8px;flex-shrink:0;animation:skeleton-pulse 1.5s ease-in-out infinite}.clue-bar-skeleton__content{flex:1;display:flex;align-items:center;justify-content:center;min-width:0}.clue-bar-skeleton__text{height:1rem;width:70%;max-width:280px;background-color:var(--color-bg-tertiary);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite;animation-delay:.1s}@media(max-width:360px){.clue-bar-skeleton{gap:.375rem;padding:.375rem}.clue-bar-skeleton__nav{width:32px;height:32px}}.puzzle-skeleton{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;min-height:0;overflow:hidden;width:100%}.puzzle-skeleton__header{flex:0 0 auto;text-align:center;padding-bottom:.25rem;width:100%;max-width:100%;display:flex;flex-direction:column;align-items:center;gap:.375rem}.puzzle-skeleton__title{height:1.5rem;width:50%;max-width:240px;background-color:var(--color-bg-tertiary);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.puzzle-skeleton__author{height:.875rem;width:25%;max-width:120px;background-color:var(--color-bg-tertiary);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite;animation-delay:.1s}.puzzle-skeleton__grid-wrapper{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;width:100%;overflow:hidden;padding:.5rem}.puzzle-skeleton__grid{background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite;animation-delay:.2s;flex-shrink:0}.keyboard-skeleton{width:100%;max-width:100vw;padding:8px;box-sizing:border-box;overflow:hidden}.keyboard-skeleton__container{background:var(--color-keyboard-bg);border-radius:8px 8px 0 0;padding:8px;width:100%;max-width:100%;box-sizing:border-box}.keyboard-skeleton__row{display:flex;justify-content:center;gap:4px;margin-bottom:4px;width:100%}.keyboard-skeleton__row:last-child{margin-bottom:0}.keyboard-skeleton__key{background:var(--color-keyboard-key);border-radius:6px;height:44px;min-width:0;flex:1 1 0;animation:skeleton-pulse 1.5s ease-in-out infinite}.keyboard-skeleton__row:nth-child(2) .keyboard-skeleton__key{animation-delay:.1s}.keyboard-skeleton__row:nth-child(3) .keyboard-skeleton__key{animation-delay:.2s}.keyboard-skeleton__key--wide{flex:1.5 1 0}@media(max-width:360px){.keyboard-skeleton__key{height:40px}}@media(min-width:768px){.keyboard-skeleton{max-width:500px}.keyboard-skeleton__container{border-radius:8px}}.dialog{position:fixed;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;padding:0;margin:0;border:none;background:transparent;overflow:visible;display:flex;align-items:center;justify-content:center}.dialog::backdrop{background-color:#000000b3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.dialog__content{position:relative;display:flex;flex-direction:column;padding:2rem 1.5rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:12px;box-shadow:0 8px 32px #0000004d;min-width:280px;max-width:90vw;max-height:90vh;overflow:auto;box-sizing:border-box}.dialog__close{position:absolute;top:.75rem;right:.75rem;padding:0;width:2rem;height:2rem;font-size:1.5rem;font-weight:300;line-height:1;color:var(--color-text-muted);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:background-color .12s ease,color .12s ease}.dialog__close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.dialog__close:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.dialog[open]{animation:dialog-appear .15s ease-out}.dialog[open]::backdrop{animation:backdrop-appear .15s ease-out}.dialog[open].dialog--closing{animation:dialog-disappear .15s ease-in forwards}.dialog[open].dialog--closing::backdrop{animation:backdrop-disappear .15s ease-in forwards}@keyframes dialog-appear{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes dialog-disappear{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes backdrop-appear{0%{opacity:0}to{opacity:1}}@keyframes backdrop-disappear{0%{opacity:1}to{opacity:0}}@media(max-width:400px){.dialog__content{padding:1.5rem 1rem;min-width:unset;width:calc(100vw - 2rem)}}.share-dialog.dialog .dialog__content{align-items:center;gap:1.25rem}.share-dialog__heading{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0;text-align:center}.share-dialog__qr-container{padding:1rem;background-color:#fff;border-radius:8px;display:flex;align-items:center;justify-content:center}.share-dialog__url-container{width:100%;max-width:300px}.share-dialog__url-input{width:100%;padding:.625rem .75rem;font-family:SF Mono,Monaco,Cascadia Code,monospace;font-size:.75rem;color:var(--color-text-muted);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;text-overflow:ellipsis;cursor:pointer;box-sizing:border-box}.share-dialog__url-input:focus{outline:none;border-color:var(--color-accent);color:var(--color-text)}.share-dialog__url-input:hover{border-color:var(--color-text-muted)}.share-dialog__url-feedback,.share-dialog__url-hint{margin-top:.375rem;font-size:.75rem;text-align:center}.share-dialog__url-feedback{color:var(--color-success, #22c55e);font-weight:500}.share-dialog__url-hint{color:var(--color-text-muted)}.share-dialog__actions{display:flex;gap:.75rem;width:100%;max-width:300px}.share-dialog__button{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-text);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease}.share-dialog__button:hover{background-color:var(--color-bg);border-color:var(--color-text-muted)}.share-dialog__button:active{transform:scale(.98)}.share-dialog__button:focus{outline:2px solid var(--color-accent);outline-offset:2px}.share-dialog__button--share{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.share-dialog__button--share:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.share-dialog__button--share:active{background-color:var(--color-accent-hover)}.share-dialog__button--copy{min-width:100px}@media(max-width:400px){.share-dialog__url-container,.share-dialog__actions{max-width:100%}.share-dialog__qr-container svg{width:180px!important;height:180px!important}}.join-dialog.dialog .dialog__content{align-items:center;gap:1rem;min-width:320px;max-width:400px;box-shadow:0 8px 32px #00000080}.join-dialog__heading{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0;text-align:center}.join-dialog__puzzle-title{font-size:.875rem;color:var(--color-text-muted);margin:0;text-align:center;font-style:italic}.join-dialog__message{font-size:.9375rem;color:var(--color-text);margin:.5rem 0 0;text-align:center;line-height:1.5}.join-dialog__question{font-size:.875rem;color:var(--color-text-muted);margin:.25rem 0 .5rem;text-align:center}.join-dialog__options{display:flex;flex-direction:column;gap:.75rem;width:100%;margin-top:.5rem}.join-dialog__option{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.875rem 1rem;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease;text-align:left;width:100%}.join-dialog__option:hover{background-color:var(--color-border);border-color:var(--color-text-muted)}.join-dialog__option:active{transform:scale(.98)}.join-dialog__option:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.join-dialog__option:focus{outline:none}.join-dialog__option-title{font-size:.9375rem;font-weight:600;color:var(--color-text)}.join-dialog__option-description{font-size:.8125rem;color:var(--color-text-muted);line-height:1.4}.join-dialog__option--merge{background-color:var(--color-accent);border-color:var(--color-accent)}.join-dialog__option--merge .join-dialog__option-title{color:#fff}.join-dialog__option--merge .join-dialog__option-description{color:#fffc}.join-dialog__option--merge:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.join-dialog__option--merge:active{transform:scale(.98)}.join-dialog__option--fresh{background-color:var(--color-bg-tertiary);border-color:var(--color-border)}.join-dialog__option--fresh:hover{background-color:var(--color-border);border-color:var(--color-text-muted)}.join-dialog__option--cancel{background-color:transparent;border-color:var(--color-border)}.join-dialog__option--cancel .join-dialog__option-title{color:var(--color-text-muted)}.join-dialog__option--cancel:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-muted)}@media(max-width:400px){.join-dialog.dialog .dialog__content{min-width:unset;max-width:100%}}.success-dialog.dialog .dialog__content{align-items:center;gap:.875rem;padding:2rem 2rem 1.75rem}.success-dialog.dialog[open]{animation:success-dialog-appear .2s cubic-bezier(.34,1.56,.64,1)}.success-dialog.dialog[open].dialog--closing{animation:dialog-disappear .15s ease-in forwards}.success-dialog__icon{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#22c55e,#16a34a);display:flex;align-items:center;justify-content:center;color:#fff;margin-bottom:.25rem;box-shadow:0 4px 16px #22c55e4d}.success-dialog__icon svg{width:36px;height:36px}.success-dialog__heading{font-size:1.375rem;font-weight:700;color:var(--color-text);margin:0;text-align:center;letter-spacing:-.01em}.success-dialog__puzzle-title{font-size:.9375rem;color:var(--color-text-muted);margin:0;text-align:center;max-width:280px;line-height:1.4}.success-dialog__duration{display:flex;flex-direction:column;align-items:center;gap:.125rem;margin:.25rem 0 0}.success-dialog__duration-label{font-size:.6875rem;font-weight:500;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted)}.success-dialog__duration-value{font-size:1.5rem;font-weight:600;color:var(--color-text);font-variant-numeric:tabular-nums;letter-spacing:-.02em}.success-dialog__multiplayer-note{font-size:.8125rem;color:var(--color-accent);margin:0;text-align:center}.success-dialog__actions{display:flex;gap:.75rem;width:100%;max-width:300px;margin-top:.5rem}.success-dialog__button{flex:1;padding:.75rem 1rem;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease}.success-dialog__button:active{transform:scale(.98)}.success-dialog__button:focus{outline:2px solid var(--color-accent);outline-offset:2px}.success-dialog__button--secondary{color:var(--color-text);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border)}.success-dialog__button--secondary:hover{background-color:var(--color-bg);border-color:var(--color-text-muted)}.success-dialog__button--primary{background-color:var(--color-accent);border:1px solid var(--color-accent);color:#fff}.success-dialog__button--primary:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}@media(max-width:400px){.success-dialog.dialog .dialog__content{padding:1.75rem 1.25rem 1.5rem}.success-dialog__actions{max-width:100%;flex-direction:column}.success-dialog__icon{width:56px;height:56px}.success-dialog__icon svg{width:32px;height:32px}}@keyframes success-dialog-appear{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.success-dialog.dialog[open]:not(.dialog--closing) .success-dialog__icon svg{animation:checkmark-draw .4s ease-out .1s both}@keyframes checkmark-draw{0%{stroke-dasharray:50;stroke-dashoffset:50}to{stroke-dasharray:50;stroke-dashoffset:0}}.settings-menu{position:relative}.settings-menu__button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));color:var(--color-text);border-radius:8px;cursor:pointer;font-size:1rem;transition:all .15s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent}.settings-menu__button:hover{background:var(--color-border);border-color:var(--color-border)}.settings-menu__button:active{transform:scale(.96)}.settings-menu__button:focus{outline:none}.settings-menu__button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.settings-menu__dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;overflow:hidden;z-index:100;min-width:140px;box-shadow:0 4px 12px #00000040}.settings-menu__section{padding:.75rem}.settings-menu__label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.5rem}.settings-menu__options{display:flex;flex-direction:column;gap:2px}.settings-menu__option{display:flex;align-items:center;gap:.5rem;width:100%;text-align:left;padding:.5rem .75rem;background:none;border:none;border-radius:4px;color:var(--color-text);cursor:pointer;font-size:.875rem;transition:background .15s}.settings-menu__option:hover{background:var(--color-bg-tertiary)}.settings-menu__option--active{background:var(--color-accent);color:#fff}.settings-menu__option--active:hover{background:var(--color-accent-hover)}.settings-menu__button-row{display:flex;gap:.375rem}.settings-menu__action-btn{flex:1;padding:.5rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s}.settings-menu__action-btn:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.settings-menu__action-btn:active{transform:scale(.97)}.settings-menu__divider{height:1px;background:var(--color-border);margin:.25rem 0}.settings-menu__toggle-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;cursor:pointer}.settings-menu__toggle-label{font-size:.875rem;color:var(--color-text)}.settings-menu__toggle{position:relative;width:44px;height:24px;padding:0;background:none;border:none;cursor:pointer;flex-shrink:0}.settings-menu__toggle-track{position:absolute;inset:0;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:12px;transition:background .2s,border-color .2s}.settings-menu__toggle-knob{position:absolute;top:2px;left:2px;width:20px;height:20px;background:var(--color-text-muted);border-radius:50%;transition:transform .2s,background .2s;box-shadow:0 1px 3px #0003}.settings-menu__toggle--active .settings-menu__toggle-track{background:var(--color-accent);border-color:var(--color-accent)}.settings-menu__toggle--active .settings-menu__toggle-knob{transform:translate(20px);background:#fff}.settings-menu__segmented{display:flex;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;padding:3px;gap:2px}.settings-menu__segment{flex:1;padding:.4rem .75rem;background:transparent;border:none;border-radius:4px;color:var(--color-text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.settings-menu__segment:hover:not(.settings-menu__segment--active){color:var(--color-text);background:var(--color-bg-secondary)}.settings-menu__segment--active{background:var(--color-accent);color:#fff;box-shadow:0 1px 2px #0000001a}.settings-menu__reset-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.settings-menu__reset-label{font-size:.875rem;color:var(--color-text)}.settings-menu__reset-hint{font-size:.75rem;color:var(--color-text-muted);font-weight:400}.settings-menu__reset-btn{position:relative;padding:.375rem .75rem;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-muted);font-size:.8125rem;font-weight:500;cursor:pointer;overflow:hidden;transition:border-color .15s ease,color .15s ease;-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}.settings-menu__reset-fill{position:absolute;inset:0;background:var(--color-error, #dc3545);transform-origin:left;transform:scaleX(0);pointer-events:none}.settings-menu__reset-text{position:relative;z-index:1}@media(hover:hover){.settings-menu__reset-btn:hover{border-color:var(--color-error, #dc3545);color:var(--color-error, #dc3545)}.settings-menu__reset-btn:hover:active{background:var(--color-error, #dc3545);color:#fff}}.settings-menu__reset-btn--pressing{border-color:var(--color-error, #dc3545)}.settings-menu__reset-btn--pressing .settings-menu__reset-text{color:#fff}.puzzle-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;-webkit-touch-callout:none;touch-action:manipulation}.puzzle-card:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent)}.puzzle-card:active{transform:scale(.99)}.puzzle-card--pressed{background-color:var(--color-bg-tertiary)}.puzzle-card:focus{outline:2px solid var(--color-accent);outline-offset:2px}.puzzle-card__content{flex:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-width:0}.puzzle-card__info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.puzzle-card__title{font-size:.9375rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.puzzle-card__subtitle{font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.puzzle-card__progress{flex-shrink:0;min-width:32px;display:flex;justify-content:center}.puzzle-card__delete{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;font-size:1.125rem;font-weight:400;line-height:1;color:var(--color-text-muted);background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));border-radius:6px;cursor:pointer;flex-shrink:0;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.puzzle-card__delete:hover{background-color:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.puzzle-card__delete:active{transform:scale(.95)}.puzzle-card__delete:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.progress-circle{flex-shrink:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.progress-circle__track{stroke:var(--color-border);stroke-width:2}.progress-circle__progress{stroke:var(--color-accent);stroke-width:2.5;stroke-linecap:round;transform:rotate(-90deg);transform-origin:center;transition:stroke-dashoffset .4s cubic-bezier(.4,0,.2,1)}.progress-circle--complete .progress-circle__complete-bg{fill:var(--color-verified);opacity:0;animation:checkmark-bg-appear .3s ease forwards}.progress-circle--complete .progress-circle__checkmark{stroke:var(--color-bg);stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:24;stroke-dashoffset:24;animation:checkmark-draw .4s ease .15s forwards}@keyframes checkmark-bg-appear{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes checkmark-draw{to{stroke-dashoffset:0}}.progress-circle--complete{filter:drop-shadow(0 0 6px var(--color-verified-bg, rgba(125, 154, 122, .3)))}.loading-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.loading-card__content{flex:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-width:0}.loading-card__info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.loading-card__title{font-size:.9375rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-card__subtitle{font-size:.8125rem;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.loading-card__progress{display:flex;align-items:center;justify-content:center;gap:.5rem;flex-shrink:0;min-width:32px}.loading-card__spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-card__status{font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.loading-card__spacer{width:1.75rem;height:1.75rem;flex-shrink:0}@media(max-width:600px){.loading-card__status{display:none}}.skeleton-card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px}.skeleton-card__content{flex:1;display:flex;align-items:center;justify-content:space-between;gap:1rem;min-width:0}.skeleton-card__info{display:flex;flex-direction:column;gap:.375rem;min-width:0;flex:1}.skeleton-card__title{height:1rem;width:60%;max-width:180px;background-color:var(--color-bg-tertiary);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton-card__subtitle{height:.75rem;width:40%;max-width:120px;background-color:var(--color-bg-tertiary);border-radius:4px;animation:skeleton-pulse 1.5s ease-in-out infinite;animation-delay:.1s}.skeleton-card__progress{width:32px;height:32px;background-color:var(--color-bg-tertiary);border-radius:50%;flex-shrink:0;animation:skeleton-pulse 1.5s ease-in-out infinite;animation-delay:.2s}.skeleton-card__spacer{width:2rem;height:2rem;flex-shrink:0}@keyframes skeleton-pulse{0%,to{opacity:1}50%{opacity:.4}}.fab{position:fixed;right:calc(1rem + env(safe-area-inset-right,0px));bottom:calc(1rem + env(safe-area-inset-bottom,0px));display:flex;flex-direction:column;align-items:flex-end;gap:.75rem;z-index:100}.fab__main{width:56px;height:56px;border-radius:50%;background-color:var(--color-accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d;transition:background-color .15s ease,transform .15s ease,box-shadow .15s ease}.fab__main:hover{background-color:var(--color-accent-hover, #d03050);box-shadow:0 6px 16px #0006}.fab__main:active{transform:scale(.95)}.fab__main:focus{outline:2px solid var(--color-text);outline-offset:2px}.fab__icon{width:24px;height:24px;color:#fff;transition:transform .2s ease}.fab--expanded .fab__icon{transform:rotate(45deg)}.fab__options{display:flex;flex-direction:column;gap:.5rem;opacity:0;transform:translateY(10px) scale(.9);pointer-events:none;transition:opacity .15s ease,transform .15s ease}.fab--expanded .fab__options{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}.fab__option{display:flex;align-items:center;gap:.75rem;padding:.625rem 1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:28px;cursor:pointer;white-space:nowrap;box-shadow:0 2px 8px #0003;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease}.fab__option:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-accent)}.fab__option:active{transform:scale(.98)}.fab__option:focus{outline:2px solid var(--color-accent);outline-offset:2px}.fab__option-icon{width:20px;height:20px;color:var(--color-accent);flex-shrink:0}.fab__option-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.fab--expanded:before{content:"";position:fixed;inset:0;background:#0000001a;z-index:-1;pointer-events:none}@media(max-width:600px){.fab{right:calc(1rem + env(safe-area-inset-right,0px));bottom:calc(1rem + env(safe-area-inset-bottom,0px))}.fab__main{width:52px;height:52px}.fab__icon{width:22px;height:22px}}@media(max-height:500px){.fab{bottom:calc(1rem + env(safe-area-inset-bottom,0px))}.fab__main{width:48px;height:48px}}.datepicker{position:relative;width:100%}.datepicker__trigger{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.625rem .75rem;font-size:.9375rem;color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:border-color .15s ease,background-color .15s ease,box-shadow .15s ease}.datepicker__trigger:hover{border-color:var(--color-accent)}.datepicker__trigger:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #e9456033}.datepicker__trigger--open{border-color:var(--color-accent)}.datepicker__trigger-text{font-weight:450}.datepicker__trigger-icon{width:18px;height:18px;opacity:.6;flex-shrink:0}.datepicker__dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:10px;box-shadow:0 4px 20px #00000026,0 0 0 1px #0000000d;z-index:100;overflow:hidden;animation:datepicker-slide-in .15s ease-out}.datepicker__dropdown--fixed{position:fixed;inset:auto;z-index:10001}.datepicker__dropdown--measuring{visibility:hidden;pointer-events:none}@keyframes datepicker-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.datepicker__dropdown--upward{top:auto;bottom:calc(100% + 6px);animation:datepicker-slide-in-upward .15s ease-out}@keyframes datepicker-slide-in-upward{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(max-height:500px){.datepicker__dropdown{max-height:calc(100vh - 120px);overflow-y:auto}}.datepicker__header{display:flex;align-items:center;justify-content:space-between;padding:.875rem .75rem .5rem;border-bottom:1px solid var(--color-border);background:linear-gradient(to bottom,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 100%)}.datepicker__nav-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;padding:0;color:var(--color-text);background:transparent;border:1px solid transparent;border-radius:6px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease}.datepicker__nav-btn:hover:not(:disabled){background-color:var(--color-bg-tertiary);border-color:var(--color-border)}.datepicker__nav-btn:disabled{opacity:.3;cursor:not-allowed}.datepicker__nav-btn svg{width:16px;height:16px}.datepicker__month-year{display:flex;align-items:baseline;gap:.375rem}.datepicker__month{font-size:1rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.datepicker__year{font-size:.875rem;font-weight:400;color:var(--color-text-muted)}.datepicker__availability{display:flex;align-items:center;justify-content:center;gap:.375rem;padding:.5rem;font-size:.75rem;color:var(--color-text-muted);background-color:var(--color-bg)}.datepicker__availability-dot{width:6px;height:6px;background-color:var(--color-accent);border-radius:50%}.datepicker__availability-text{font-weight:500;text-transform:uppercase;letter-spacing:.05em}.datepicker__weekdays{display:grid;grid-template-columns:repeat(7,1fr);padding:.5rem .5rem .25rem;gap:2px}.datepicker__weekday{font-size:.6875rem;font-weight:600;color:var(--color-text-muted);text-align:center;text-transform:uppercase;letter-spacing:.04em;padding:.25rem 0}.datepicker__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;padding:.25rem .5rem .5rem}.datepicker__day{position:relative;aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:0;font-size:.8125rem;font-weight:500;color:var(--color-text);background-color:var(--color-cell-bg);border:1px solid var(--color-border);border-radius:4px;cursor:pointer;transition:background-color .1s ease,border-color .1s ease,transform 80ms ease,box-shadow .1s ease}.datepicker__day:hover:not(:disabled):not(.datepicker__day--empty){background-color:var(--color-cell-word);border-color:var(--color-accent);transform:translateY(-1px);box-shadow:0 2px 4px #0000001a}.datepicker__day:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #e9456040;z-index:1}.datepicker__day--empty{background:transparent;border-color:transparent;cursor:default;pointer-events:none}.datepicker__day--today{font-weight:700}.datepicker__day--today:after{content:"";position:absolute;bottom:3px;left:50%;transform:translate(-50%);width:4px;height:4px;background-color:var(--color-accent);border-radius:50%}.datepicker__day--selected{color:var(--color-text);background-color:var(--color-cell-selected);border-color:var(--color-accent);font-weight:700}.datepicker__day--selected:hover:not(:disabled){background-color:var(--color-cell-selected)}.datepicker__day--disabled{color:var(--color-text-muted);opacity:.4;cursor:not-allowed}.datepicker__day--disabled:hover{transform:none;box-shadow:none}.datepicker__day--blocked{color:var(--color-text-muted);background-color:var(--color-cell-blocked);border-color:var(--color-cell-blocked);opacity:.6}.datepicker__day--blocked .datepicker__day-num{opacity:.5}.datepicker__day--blocked:before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(255,255,255,.08) 2px,rgba(255,255,255,.08) 4px);border-radius:3px;pointer-events:none}:root:not(.dark) .datepicker__day--blocked{background-color:var(--color-bg-tertiary);border-color:var(--color-border)}:root:not(.dark) .datepicker__day--blocked:before{background-image:repeating-linear-gradient(45deg,transparent,transparent 2px,rgba(0,0,0,.06) 2px,rgba(0,0,0,.06) 4px)}.datepicker__day-num{position:relative;z-index:1}.datepicker__footer{display:flex;justify-content:center;padding:.5rem;border-top:1px solid var(--color-border);background-color:var(--color-bg)}.datepicker__today-btn{padding:.375rem 1rem;font-size:.75rem;font-weight:600;color:var(--color-accent);background:transparent;border:1px solid var(--color-accent);border-radius:4px;cursor:pointer;text-transform:uppercase;letter-spacing:.03em;transition:background-color .12s ease,color .12s ease}.datepicker__today-btn:hover{color:#fff;background-color:var(--color-accent)}.datepicker__today-btn:focus{outline:none;box-shadow:0 0 0 2px #e9456040}@media(max-width:360px){.datepicker__day{font-size:.75rem}.datepicker__weekday{font-size:.625rem}}.download-dialog.dialog .dialog__content{width:100%;max-width:360px;padding:1.5rem}.download-dialog__title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0 0 1.25rem;text-align:center}.download-dialog__content{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.download-dialog__field{display:flex;flex-direction:column;gap:.375rem}.download-dialog__label{font-size:.8125rem;font-weight:500;color:var(--color-text-muted)}.download-dialog__select{width:100%;padding:.625rem 2.25rem .625rem .75rem;font-size:.9375rem;color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:border-color .15s ease,background-color .15s ease;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23666' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:16px}.download-dialog__select:hover{border-color:var(--color-accent)}.download-dialog__select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #e9456033}.dark .download-dialog__select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E")}.download-dialog__actions{display:flex;gap:.75rem;justify-content:flex-end}.download-dialog__button{padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,transform 80ms ease}.download-dialog__button:active{transform:scale(.98)}.download-dialog__button:focus{outline:2px solid var(--color-accent);outline-offset:2px}.download-dialog__button--secondary{color:var(--color-text);background-color:transparent;border:1px solid var(--color-border)}.download-dialog__button--secondary:hover{background-color:var(--color-bg-tertiary);border-color:var(--color-text-muted)}.download-dialog__button--primary{color:#fff;background-color:var(--color-accent);border:1px solid var(--color-accent)}.download-dialog__button--primary:hover:not(:disabled){background-color:var(--color-accent-hover, #d03050);border-color:var(--color-accent-hover, #d03050)}.download-dialog__button--primary:disabled{opacity:.5;cursor:not-allowed}@media(max-width:400px){.download-dialog.dialog .dialog__content{padding:1.25rem}.download-dialog__actions{flex-direction:column}.download-dialog__button{width:100%;justify-content:center}}.puzzle-options-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .15s ease-out}.puzzle-options-overlay--closing{animation:fadeOut .2s ease-out forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}.puzzle-options-dialog{background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:12px;max-width:400px;width:100%;box-shadow:0 4px 24px #0000004d;animation:slideUp .15s ease-out;transition:transform .15s ease-out}.puzzle-options-dialog--closing{animation:slideDown .2s ease-out forwards}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(20px);opacity:0}}.puzzle-options-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--color-border)}.puzzle-options-title-group{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1;padding-right:1rem}.puzzle-options-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.puzzle-options-date{font-size:.8125rem;color:var(--color-text-muted);font-weight:400}.puzzle-options-close{display:flex;align-items:center;justify-content:center;width:2rem;height:2rem;padding:0;font-size:1.5rem;line-height:1;color:var(--color-text-muted);background:transparent;border:none;border-radius:6px;cursor:pointer;flex-shrink:0;transition:background-color .12s ease,color .12s ease}.puzzle-options-close:hover{background-color:var(--color-bg-tertiary);color:var(--color-text)}.puzzle-options-close:active{transform:scale(.95)}.puzzle-options-actions{display:flex;flex-direction:column;padding:.5rem}.puzzle-options-button{display:flex;align-items:center;gap:1rem;padding:1rem;background:transparent;border:none;border-radius:8px;cursor:pointer;text-align:left;transition:background-color .12s ease;color:var(--color-text)}.puzzle-options-button:hover{background-color:var(--color-bg-tertiary)}.puzzle-options-button:active{transform:scale(.98)}.puzzle-options-button--danger:hover{background-color:var(--color-error-bg)}.puzzle-options-button--danger:hover .puzzle-options-button-label{color:var(--color-error)}.puzzle-options-button-icon{width:1.5rem;height:1.5rem;flex-shrink:0;color:var(--color-text);transition:color .12s ease}.puzzle-options-button--danger .puzzle-options-button-icon{color:var(--color-text-muted)}.puzzle-options-button--danger:hover .puzzle-options-button-icon{color:var(--color-error)}.puzzle-options-button-text{display:flex;flex-direction:column;gap:.25rem;min-width:0}.puzzle-options-button-label{font-size:.9375rem;font-weight:500;color:var(--color-text)}.puzzle-options-button-desc{font-size:.8125rem;color:var(--color-text-muted);line-height:1.3}@media(max-width:480px){.puzzle-options-dialog{max-width:none;border-radius:12px 12px 0 0;position:fixed;bottom:0;left:0;right:0}@keyframes slideUp{0%{transform:translateY(100%);opacity:1}to{transform:translateY(0);opacity:1}}@keyframes slideDown{0%{transform:translateY(0);opacity:1}to{transform:translateY(100%);opacity:1}}}.profile-dialog.dialog .dialog__content{align-items:center;gap:1rem;min-width:300px}.profile-dialog__heading{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0;text-align:center}.profile-dialog__avatar-section{display:flex;align-items:center;gap:1.25rem}.profile-dialog__avatar-preview{width:128px;height:128px;border-radius:50%;overflow:hidden;background-color:var(--color-bg-tertiary);border:3px solid var(--color-border);flex-shrink:0}.profile-dialog__avatar-image{width:100%;height:100%;object-fit:cover}.profile-dialog__avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.profile-dialog__avatar-placeholder svg{width:64px;height:64px}.profile-dialog__avatar-actions{display:flex;flex-direction:column;gap:.5rem}.profile-dialog__button{padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:var(--color-text);background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:background-color .12s ease,border-color .12s ease,transform 80ms ease}.profile-dialog__button:hover:not(:disabled){background-color:var(--color-bg);border-color:var(--color-text-muted)}.profile-dialog__button:active:not(:disabled){transform:scale(.98)}.profile-dialog__button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.profile-dialog__button:disabled{opacity:.6;cursor:not-allowed}.profile-dialog__button--primary{background-color:var(--color-accent);border-color:var(--color-accent);color:#fff}.profile-dialog__button--primary:hover:not(:disabled){background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.profile-dialog__button--danger{color:var(--color-error, #dc3545);border-color:var(--color-error, #dc3545);background-color:transparent}.profile-dialog__button--danger:hover:not(:disabled){background-color:var(--color-error, #dc3545);color:#fff}.profile-dialog__file-input{display:none}.profile-dialog__error{padding:.5rem 1rem;font-size:.875rem;color:var(--color-error, #dc3545);background-color:#dc35451a;border:1px solid var(--color-error, #dc3545);border-radius:6px;text-align:center}.profile-dialog__nickname-section{width:100%;max-width:280px}.profile-dialog__label{display:block;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:.5rem}.profile-dialog__nickname-row{display:flex;gap:.5rem}.profile-dialog__nickname-input{flex:1;padding:.625rem .75rem;font-size:.9375rem;color:var(--color-text);background-color:var(--color-bg);border:1px solid var(--color-border);border-radius:6px;box-sizing:border-box}.profile-dialog__nickname-input:focus{outline:none;border-color:var(--color-accent)}.profile-dialog__nickname-input::placeholder{color:var(--color-text-muted)}.profile-dialog__randomize{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background-color:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text-muted);cursor:pointer;flex-shrink:0;transition:background-color .12s ease,color .12s ease}.profile-dialog__randomize:hover{background-color:var(--color-bg);color:var(--color-text)}.profile-dialog__randomize:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.profile-dialog__randomize svg{width:18px;height:18px}.profile-dialog__max-hint{margin-top:.375rem;font-size:.75rem;color:var(--color-warning, #f0ad4e);text-align:center;animation:hint-fade 2s ease-out forwards}@keyframes hint-fade{0%{opacity:1}70%{opacity:1}to{opacity:0}}@media(max-width:400px){.profile-dialog.dialog .dialog__content{min-width:unset}.profile-dialog__avatar-section{flex-direction:column}.profile-dialog__avatar-actions{flex-direction:row;flex-wrap:wrap;justify-content:center}.profile-dialog__nickname-section{max-width:100%}}.profile-button{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));color:var(--color-text);border-radius:8px;cursor:pointer;transition:all .15s ease;flex-shrink:0;-webkit-tap-highlight-color:transparent;overflow:hidden}.profile-button:hover{background:var(--color-border);border-color:var(--color-border)}.profile-button:active{transform:scale(.96)}.profile-button:focus{outline:none}.profile-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.profile-button__icon{width:18px;height:18px}.profile-button__avatar{width:100%;height:100%;object-fit:cover;border-radius:6px}.library-view{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-height:100vh;max-height:100dvh;background-color:var(--color-bg);color:var(--color-text)}.library-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;height:48px;padding:0 1rem;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);flex-shrink:0;box-sizing:border-box}.library-header__left{display:flex;align-items:center;gap:.5rem}.library-logo{width:28px;height:28px;flex-shrink:0}.library-title{font-size:1.375rem;font-weight:600;color:var(--color-text);margin:0}.library-actions{display:flex;align-items:center;gap:.5rem}.library-content{flex:1;overflow-y:auto;padding:1rem 1.5rem 2rem}.library-skeleton{display:flex;flex-direction:column;gap:.5rem}.library-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:300px;text-align:center}.library-empty__title{font-size:1.125rem;font-weight:500;color:var(--color-text);margin:0 0 .5rem}.library-empty__subtitle{font-size:.9375rem;color:var(--color-text-muted);margin:0}.library-groups{display:flex;flex-direction:column;gap:1.5rem}.library-group{display:flex;flex-direction:column;gap:.5rem}.library-group__date{font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0;padding:0 .25rem}.library-group__puzzles{display:flex;flex-direction:column;gap:.5rem}.library-file-input{display:none}@media(max-width:600px){.library-header{padding:0 .75rem}.library-logo{width:24px;height:24px}.library-title{font-size:1.125rem}.library-content{padding:.875rem 1rem 1.5rem}}@media(min-width:768px){.library-content{max-width:600px;margin:0 auto;width:100%}}.solve-layout{--header-height: 48px;--clue-bar-height: 52px;--keyboard-height: 160px;--grid-padding: 8px;display:flex;flex-direction:column;height:100vh;height:100dvh;width:100%;overflow:hidden;background-color:var(--color-bg)}.solve-layout__header{flex:0 0 auto;min-height:var(--header-height);position:relative;z-index:100}.solve-layout__grid{flex:1 1 auto;display:flex;flex-direction:column;overflow:hidden;padding:var(--grid-padding);min-height:0;position:relative}.puzzle-grid-area{flex:1 1 auto;display:flex;flex-direction:column;align-items:center;min-height:0;overflow:hidden;width:100%;animation:puzzle-entrance .35s ease-out both}@keyframes puzzle-entrance{0%{opacity:0;transform:scale(.98) translateY(4px)}to{opacity:1;transform:scale(1) translateY(0)}}.puzzle-grid-header{flex:0 0 auto;text-align:center;padding-bottom:.25rem;width:100%;max-width:100%;overflow:hidden}.puzzle-grid-header .puzzle-title-above-grid{margin:0 0 .25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 .5rem}.puzzle-grid-header .puzzle-author{margin:0 0 .25rem;font-size:.75rem}.puzzle-grid-wrapper{flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;width:100%;overflow:hidden;position:relative}.solve-layout__clue-bar{flex:0 0 auto;display:flex;justify-content:center;padding:.25rem .5rem}.solve-layout__keyboard{flex:0 0 auto}.solve-layout__keyboard:empty{display:none}@media(min-width:768px){.solve-layout__grid{flex:1 1 auto;justify-content:center}.solve-layout__clue-bar{margin-top:1rem}.solve-layout__keyboard{display:none}}@media(min-width:768px)and (min-height:700px){.solve-layout__keyboard{margin-top:.5rem;display:flex;justify-content:center}}.collaborator-avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:default;flex-shrink:0;overflow:hidden;box-sizing:border-box;border-style:solid;opacity:0;transform:scale(.8);transition:opacity .25s cubic-bezier(.4,0,.2,1),transform .25s cubic-bezier(.34,1.56,.64,1)}.collaborator-avatar--visible{opacity:1;transform:scale(1)}.collaborator-avatar--small{width:24px;height:24px;border-width:2px}.collaborator-avatar--medium{width:32px;height:32px;border-width:3px}.collaborator-avatar--overlapping{margin-left:-8px}.collaborator-avatar--overlapping:first-child{margin-left:0}.collaborator-avatar__image{width:100%;height:100%;object-fit:cover;border-radius:50%}.collaborator-avatar__initials{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff;text-transform:uppercase;line-height:1;border-radius:50%;text-shadow:0 1px 2px rgba(0,0,0,.15)}.collaborator-avatar--small .collaborator-avatar__initials{font-size:9px}.collaborator-avatar--medium .collaborator-avatar__initials{font-size:12px}.collaborator-avatar--overflow{background-color:var(--color-bg-tertiary);border-color:var(--color-border)}.collaborator-avatar--overflow .collaborator-avatar__initials{color:var(--color-text);text-shadow:none;font-size:10px}.collaborator-avatar--medium.collaborator-avatar--overflow .collaborator-avatar__initials{font-size:12px}.solve-header{display:flex;align-items:center;gap:.75rem;height:48px;padding:0 .75rem;background-color:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);overflow:visible;width:100%;box-sizing:border-box}.solve-header__back{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;color:var(--color-text);background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));border-radius:8px;cursor:pointer;flex-shrink:0;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.solve-header__back:hover{background:var(--color-border);border-color:var(--color-border)}.solve-header__back:active{transform:scale(.96)}.solve-header__back:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.solve-header__back:focus{outline:none}.solve-header__back-icon{width:18px;height:18px}.solve-header__spacer{flex:1;min-width:.5rem}.solve-header__collaborators{display:flex;flex-shrink:0}.solve-header__follow{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--color-bg-tertiary);border:2px solid var(--color-border-subtle, var(--color-border));color:var(--color-text-secondary);border-radius:8px;cursor:pointer;flex-shrink:0;transition:all .2s ease;-webkit-tap-highlight-color:transparent;opacity:0;animation:followButtonFadeIn .2s ease forwards}@keyframes followButtonFadeIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.solve-header__follow:hover{background:var(--color-border);color:var(--color-text)}.solve-header__follow:active{transform:scale(.96)}.solve-header__follow:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.solve-header__follow:focus{outline:none}.solve-header__follow--active{background:var(--color-bg-tertiary);color:var(--color-text);border-width:2px;box-shadow:0 0 0 1px var(--color-bg-secondary)}.solve-header__follow--active:hover{background:var(--color-bg-tertiary);opacity:.9}.solve-header__follow:disabled{opacity:.4;cursor:not-allowed;animation:none}.solve-header__follow:disabled:hover{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.solve-header__follow:disabled:active{transform:none}.solve-header__follow-icon{width:18px;height:18px}.solve-header__share{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:var(--color-bg-tertiary);border:1px solid var(--color-border-subtle, var(--color-border));color:var(--color-text);border-radius:8px;cursor:pointer;flex-shrink:0;transition:all .15s ease;-webkit-tap-highlight-color:transparent}.solve-header__share:hover{background:var(--color-border);border-color:var(--color-border)}.solve-header__share:active{transform:scale(.96)}.solve-header__share:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.solve-header__share:focus{outline:none}.solve-header__share-svg{width:18px;height:18px}@media(max-width:360px){.solve-header{gap:.5rem;padding:0 .5rem}}.hg-theme-default{background-color:#ececec;border-radius:5px;box-sizing:border-box;font-family:HelveticaNeue-Light,Helvetica Neue Light,Helvetica Neue,Helvetica,Arial,Lucida Grande,sans-serif;overflow:hidden;padding:5px;touch-action:manipulation;-webkit-user-select:none;-moz-user-select:none;user-select:none;width:100%}.hg-theme-default .hg-button span,.hg-theme-default .hg-button span svg{pointer-events:none}.hg-theme-default button.hg-button{border-width:0;font-size:inherit}.hg-theme-default .hg-button{display:inline-block;flex-grow:1}.hg-theme-default .hg-row{display:flex}.hg-theme-default .hg-row:not(:last-child){margin-bottom:5px}.hg-theme-default .hg-row .hg-button-container,.hg-theme-default .hg-row .hg-button:not(:last-child){margin-right:5px}.hg-theme-default .hg-row>div:last-child{margin-right:0}.hg-theme-default .hg-row .hg-button-container{display:flex}.hg-theme-default .hg-button{align-items:center;background:#fff;border-bottom:1px solid #b5b5b5;border-radius:5px;box-shadow:0 0 3px -1px #0000004d;box-sizing:border-box;cursor:pointer;display:flex;height:40px;justify-content:center;padding:5px;-webkit-tap-highlight-color:rgba(0,0,0,0)}.hg-theme-default .hg-button.hg-standardBtn{width:20px}.hg-theme-default .hg-button.hg-activeButton{background:#efefef}.hg-theme-default.hg-layout-numeric .hg-button{align-items:center;display:flex;height:60px;justify-content:center;width:33.3%}.hg-theme-default .hg-button.hg-button-numpadadd,.hg-theme-default .hg-button.hg-button-numpadenter{height:85px}.hg-theme-default .hg-button.hg-button-numpad0{width:105px}.hg-theme-default .hg-button.hg-button-com{max-width:85px}.hg-theme-default .hg-button.hg-standardBtn.hg-button-at{max-width:45px}.hg-theme-default .hg-button.hg-selectedButton{background:#05194687;color:#fff}.hg-theme-default .hg-button.hg-standardBtn[data-skbtn=".com"]{max-width:82px}.hg-theme-default .hg-button.hg-standardBtn[data-skbtn="@"]{max-width:60px}.hg-candidate-box{background:#ececec;border-bottom:2px solid #b5b5b5;border-radius:5px;display:inline-flex;margin-top:-10px;position:absolute;transform:translateY(-100%);-webkit-user-select:none;-moz-user-select:none;user-select:none}ul.hg-candidate-box-list{display:flex;flex:1;list-style:none;margin:0;padding:0}li.hg-candidate-box-list-item{align-items:center;display:flex;height:40px;justify-content:center;width:40px}li.hg-candidate-box-list-item:hover{background:#00000008;cursor:pointer}li.hg-candidate-box-list-item:active{background:#0000001a}.hg-candidate-box-prev:before{content:"◄"}.hg-candidate-box-next:before{content:"►"}.hg-candidate-box-next,.hg-candidate-box-prev{align-items:center;color:#969696;cursor:pointer;display:flex;padding:0 10px}.hg-candidate-box-next{border-bottom-right-radius:5px;border-top-right-radius:5px}.hg-candidate-box-prev{border-bottom-left-radius:5px;border-top-left-radius:5px}.hg-candidate-box-btn-active{color:#444}.crossword-keyboard{width:100%;max-width:100vw;padding:8px;box-sizing:border-box;overflow:hidden}.crossword-keyboard-theme.simple-keyboard{background:var(--color-keyboard-bg);border-radius:8px 8px 0 0;padding:8px;font-family:inherit;width:100%;max-width:100%;box-sizing:border-box}.crossword-keyboard-theme .hg-row{display:flex;justify-content:center;gap:4px;margin-bottom:4px;width:100%}.crossword-keyboard-theme .hg-row:last-child{margin-bottom:0}.crossword-keyboard-theme .hg-button{background:var(--color-keyboard-key);border:none;border-radius:6px;color:var(--color-text);font-size:16px;font-weight:500;height:44px;min-width:0;flex:1 1 0;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .1s ease;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;box-shadow:0 1px 2px #0000001a}.crossword-keyboard-theme .hg-button:active,.crossword-keyboard-theme .hg-button.hg-activeButton{background:var(--color-keyboard-key-active)}.crossword-keyboard-theme .hg-button[data-skbtn="{bksp}"]{flex:1.5 1 0;font-size:20px}.crossword-keyboard-theme .hg-button:focus{outline:none}@media(max-width:360px){.crossword-keyboard-theme .hg-button{font-size:14px;height:40px}.crossword-keyboard-theme .hg-button[data-skbtn="{bksp}"]{font-size:18px}}@media(min-width:768px){.crossword-keyboard{max-width:500px}.crossword-keyboard-theme.simple-keyboard{border-radius:8px}}.app-shell{display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:1rem}.app-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;width:100%;max-width:600px;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--color-border)}.header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.back-button{display:inline-flex;align-items:center;gap:.25rem;padding:.5rem .75rem;font-size:.875rem;font-weight:500;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-border);border-radius:6px;cursor:pointer;transition:color .12s ease,border-color .12s ease,background-color .12s ease;flex-shrink:0}.back-button:hover{color:var(--color-text);border-color:var(--color-text-muted);background-color:var(--color-bg-tertiary)}.back-button:focus{outline:2px solid var(--color-accent);outline-offset:2px}.puzzle-header-title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.puzzle-import{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.75rem;margin-top:1rem}.puzzle-import__separator{color:var(--color-text-muted);font-size:.875rem}.header-actions{display:flex;align-items:center;gap:.75rem}.share-button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;font-weight:500;color:#fff;background-color:var(--color-accent);border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;box-shadow:0 1px 2px #0000001a,inset 0 1px #ffffff1a}.share-button:hover{background-color:var(--color-accent-hover)}.share-button:active{transform:translateY(1px);box-shadow:0 0 #0000001a}.share-button:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.puzzle-container{display:flex;flex-direction:column;align-items:center;width:100%;max-width:500px}.puzzle-title{font-size:1.25rem;font-weight:600;margin-bottom:.25rem}.puzzle-title-above-grid{font-size:1.25rem;font-weight:600;color:var(--color-text);text-align:center;margin:0 0 .25rem}.puzzle-author{color:var(--color-text-muted);font-size:.875rem;margin-bottom:1rem;text-align:center}.error-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;max-width:500px;padding:.75rem 1rem;margin-bottom:1rem;background-color:var(--color-error-bg);border:1px solid var(--color-error);border-radius:8px}.error-banner__message{color:var(--color-error);font-size:.875rem;line-height:1.4}.error-banner__dismiss{flex-shrink:0;padding:0;width:1.5rem;height:1.5rem;font-size:1.25rem;font-weight:400;line-height:1;color:var(--color-error);background:transparent;border:none;border-radius:4px;cursor:pointer;transition:background-color .12s ease}.error-banner__dismiss:hover{background-color:var(--color-error-bg)}.error-banner--floating{position:fixed;bottom:calc(1rem + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);z-index:100}.puzzle-status-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10;pointer-events:none}.puzzle-status-overlay__text{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;font-size:.8125rem;font-weight:500;color:var(--color-text);background-color:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:8px;box-shadow:0 2px 8px #00000026;animation:status-pulse 2s ease-in-out infinite}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.7}}.connection-indicator{position:fixed;top:calc(.75rem + env(safe-area-inset-top,0px));right:calc(.75rem + env(safe-area-inset-right,0px));display:flex;align-items:center;gap:.375rem;padding:.25rem .5rem;border-radius:1rem;background-color:var(--color-bg-secondary);border:1px solid var(--color-border-subtle, var(--color-border));font-size:.75rem;z-index:100}.connection-indicator__dot{width:.5rem;height:.5rem;border-radius:50%;flex-shrink:0}.connection-indicator__label{color:var(--color-text-muted)}.connection-indicator--connected .connection-indicator__dot{background-color:var(--color-verified)}.connection-indicator--connecting .connection-indicator__dot{background-color:var(--color-warning);animation:pulse 1.5s ease-in-out infinite}.connection-indicator--disconnected .connection-indicator__dot{background-color:var(--color-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}
