:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg:oklch(93.69% .0165 91.56);--surface:oklch(92.4% .0373 68.64);--surface-soft:oklch(87.84% .0749 63.32);--surface-quiet:var(--bg);--ink:oklch(27.36% .0696 261.5);--muted:oklch(46.58% .0244 310.82);--primary:oklch(51.01% .0921 250.98);--primary-hover:oklch(50.49% .0945 252.4);--primary-soft:oklch(90.17% .0353 234.83);--accent:oklch(55.5% .111 59.07);--accent-strong:oklch(64.2% .1377 55.25);--accent-soft:oklch(76.49% .0709 54.24);--danger:oklch(42.09% .1464 25.42);--danger-soft:oklch(84.65% .0845 37.87);--pending:oklch(65.27% .0151 248.06);--line:oklch(79.58% .01 299.19);--line-strong:oklch(74.35% .0397 245.92);--bark:oklch(28.79% .0547 43.75);--shadow:0 18px 42px color-mix(in oklch, var(--ink) 14%, transparent);--active-shadow:0 8px 20px color-mix(in oklch, var(--ink) 12%, transparent);--page-max:1240px;--board-max:680px;--rail-width:360px;font-family:Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,sans-serif}*{box-sizing:border-box}body{background:var(--bg);min-width:320px;min-height:100vh;color:var(--ink);margin:0}button,input{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed}a{color:var(--primary);text-underline-offset:.18em;font-weight:800;text-decoration-thickness:.12em}.app-shell{width:min(calc(100% - 32px), var(--page-max));flex-direction:column;gap:22px;min-height:100vh;margin:0 auto;padding:24px 0 18px;display:flex}.site-header,.site-footer,.game-layout,.jigsaw-layout,.page-heading{width:100%}.site-header{border-bottom:1px solid color-mix(in oklch, var(--line) 70%, transparent);grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:18px;padding-bottom:12px;display:grid}.site-title-group{min-width:0}.eyebrow{color:var(--accent);letter-spacing:0;text-transform:uppercase;margin:0 0 4px;font-size:.78rem;font-weight:900}.app-title{color:var(--ink);margin:0;font-size:1.08rem;font-weight:900;line-height:1}.page-nav{border:1px solid color-mix(in oklch, var(--line) 80%, transparent);background:var(--primary-soft);border-radius:8px;grid-template-columns:repeat(2,minmax(0,1fr));gap:5px;padding:5px;display:grid}.page-nav-link{min-height:42px;color:var(--primary);text-align:center;border:1px solid #0000;border-radius:6px;justify-content:center;align-items:center;padding:0 14px;font-size:.9rem;font-weight:900;text-decoration:none;transition:background-color .16s,border-color .16s,color .16s,box-shadow .16s;display:inline-flex}.page-nav-link:hover{border-color:var(--accent-strong);background:color-mix(in oklch, var(--surface-soft) 74%, var(--surface-quiet));color:var(--ink)}.page-nav-link[aria-current=page]{background:var(--surface-quiet);color:var(--ink);box-shadow:var(--active-shadow)}.page-heading{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:18px;display:grid}.word-search-heading,.jigsaw-heading{text-align:center;grid-template-columns:minmax(0,1fr);justify-items:center}h1,h2,p{margin-top:0}h1{letter-spacing:0;margin-bottom:0;font-size:2.4rem;font-weight:900;line-height:1}h2{letter-spacing:0;margin-bottom:0;font-size:1rem;font-weight:900;line-height:1.2}.header-badge,.board-size,.counter-pill{border:1px solid var(--line);background:var(--surface-quiet);color:var(--primary);white-space:nowrap;border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:900}.game-layout,.jigsaw-layout{align-items:start;gap:28px;display:grid}.word-search-layout{grid-template-columns:minmax(0, var(--board-max)) minmax(320px, var(--rail-width));justify-content:center}.jigsaw-layout{grid-template-columns:minmax(0, 760px) minmax(320px, var(--rail-width));justify-content:center}.board-section,.jigsaw-stage{justify-items:center;gap:14px;width:100%;min-width:0;display:grid}.word-search-board-section{justify-self:end}.word-search-control-rail,.jigsaw-control-rail{justify-self:start}.board-title-row,.on-board-panel,.status-line,.word-board-stack{width:100%;max-width:var(--board-max)}.jigsaw-stage .board-title-row,.jigsaw-stage .status-line,.jigsaw-play-zone{max-width:760px}.board-title-row{justify-content:space-between;align-items:flex-end;gap:16px;display:flex}.board-meta{color:var(--muted);margin:4px 0 0;font-size:.92rem;font-weight:700}.word-board-stack{justify-items:center;gap:12px;display:grid}.on-board-panel{border-top:1px solid color-mix(in oklch, var(--line) 70%, transparent);border-bottom:1px solid color-mix(in oklch, var(--line) 70%, transparent);grid-template-columns:auto minmax(0,1fr);align-items:start;gap:12px;padding:10px 0 12px;display:grid}.on-board-panel .section-heading-row{padding-top:6px}.board-frame{width:min(100%, var(--board-max));aspect-ratio:1;border:1px solid var(--line-strong);background:var(--line-strong);min-width:0;max-width:100%;box-shadow:var(--shadow);touch-action:none;-webkit-user-select:none;user-select:none;border-radius:8px;grid-template-columns:repeat(14,minmax(0,1fr));gap:4px;padding:6px;display:grid}.letter-cell{min-width:0;min-inline-size:0;max-inline-size:100%;aspect-ratio:1;border:1px solid color-mix(in oklch, var(--primary) 24%, var(--line));background:var(--surface-quiet);width:auto;color:var(--ink);appearance:none;border-radius:6px;place-items:center;padding:0;font-size:1rem;font-weight:900;line-height:1;transition:background-color .16s,border-color .16s,color .16s,box-shadow .16s;display:grid}.letter-cell:hover{border-color:var(--accent-strong);background:var(--surface)}.letter-cell:focus-visible,.segmented-button:focus-visible,.jigsaw-preset-button:focus-visible,.icon-button:focus-visible,.word-suggestion:focus-visible,.chip-remove:focus-visible,.page-nav-link:focus-visible,.jigsaw-piece:focus-visible,.upload-passphrase-field input:focus-visible,.upload-button:focus-visible,.secondary-button:focus-visible,.photo-choice:focus-visible,.photo-delete:focus-visible,.generate-button:focus-visible,.word-search:focus-visible{outline:3px solid color-mix(in oklch, var(--accent-strong) 36%, transparent);outline-offset:2px}.letter-cell.is-current{border-color:var(--accent-strong);background:var(--surface-soft);color:var(--ink);box-shadow:inset 0 0 0 2px color-mix(in oklch, var(--accent-strong) 42%, transparent)}.letter-cell.is-found{border-color:var(--found-color,var(--primary));background:color-mix(in oklch, var(--found-color,var(--primary)) 36%, var(--surface-quiet));color:var(--ink);box-shadow:inset 0 0 0 2px var(--found-color,var(--primary))}.status-line{min-height:28px;color:var(--muted);margin:0;font-size:.95rem;font-weight:800}.control-rail{width:100%;max-width:var(--rail-width);border:1px solid var(--line);background:var(--surface);box-shadow:var(--shadow);border-radius:8px;gap:18px;padding:18px;display:grid;position:sticky;top:18px}.control-section{gap:12px;display:grid}.section-heading-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.segmented-control,.jigsaw-preset-grid{background:var(--primary-soft);border-radius:8px;gap:8px;padding:5px;display:grid}.segmented-control{grid-template-columns:repeat(2,minmax(0,1fr))}.segmented-control.three-up,.jigsaw-preset-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.segmented-button,.jigsaw-preset-button,.icon-button,.word-suggestion,.chip-remove,.jigsaw-piece,.secondary-button,.photo-choice,.photo-delete,.generate-button{border:0;transition:background-color .16s,color .16s,border-color .16s,opacity .16s}.segmented-button,.jigsaw-preset-button{min-height:42px;color:var(--primary);background:0 0;border-radius:6px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.segmented-button[aria-pressed=true],.jigsaw-preset-button[aria-pressed=true]{background:var(--surface-quiet);color:var(--ink);box-shadow:var(--active-shadow)}.button-icon{flex:none;width:1.05rem;height:1.05rem}.tiny-icon{flex:none;width:.9rem;height:.9rem}.search-row{grid-template-columns:minmax(0,1fr) 42px;gap:8px;display:grid}.word-search{border:1px solid var(--line);background:var(--surface-quiet);min-width:0;height:42px;color:var(--ink);border-radius:8px;padding:0 12px}.word-search::placeholder{color:var(--muted)}.icon-button{background:var(--primary);width:42px;height:42px;color:var(--surface-quiet);border-radius:8px;place-items:center;display:grid}.icon-button:hover,.generate-button:hover:not(:disabled){background:var(--primary-hover)}.suggestion-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;max-height:304px;padding-right:2px;display:grid;overflow:auto}.word-suggestion{background:color-mix(in oklch, var(--surface-quiet) 72%, var(--surface));min-width:0;min-height:34px;color:var(--bark);overflow-wrap:anywhere;border-radius:7px;justify-content:flex-start;align-items:center;gap:6px;padding:8px;font-size:.78rem;font-weight:900;display:inline-flex}.word-suggestion:hover:not(:disabled){background:var(--surface-soft);color:var(--ink)}.word-suggestion:disabled{opacity:.5}.selected-words,.word-progress-list{flex-wrap:wrap;gap:8px;display:flex}.word-progress-list{max-height:104px;padding-right:2px;overflow:auto}.selected-chip,.progress-word{overflow-wrap:anywhere;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;min-width:0;padding:7px 8px 7px 10px;font-size:.78rem;font-weight:900;display:inline-flex}.selected-chip{background:var(--primary-soft);color:var(--primary)}.chip-remove{background:color-mix(in oklch, var(--primary) 14%, transparent);color:currentColor;border-radius:50%;place-items:center;width:20px;height:20px;padding:0;display:grid}.chip-remove:hover{background:color-mix(in oklch, var(--primary) 24%, transparent)}.progress-word{background:var(--surface-quiet);border-color:var(--line);color:var(--muted)}.progress-word.is-found{background:color-mix(in oklch, var(--word-color,var(--primary)) 20%, var(--surface-quiet));border-color:var(--word-color,var(--primary));color:var(--ink);box-shadow:inset 0 0 0 1px var(--word-color,var(--primary))}.progress-word.is-missing{background:var(--danger-soft);border-color:var(--danger);color:var(--danger)}.progress-word.is-pending{background:var(--line);border-color:var(--pending);color:var(--muted)}.generate-button{background:var(--primary);width:100%;min-height:48px;color:var(--surface-quiet);border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.generate-button:disabled{opacity:.55}.secondary-button,.upload-button{border:1px solid var(--line);background:var(--surface-quiet);width:100%;min-height:48px;color:var(--primary);border-radius:8px;justify-content:center;align-items:center;gap:8px;font-weight:900;display:inline-flex}.secondary-button:hover,.upload-button:hover{border-color:var(--accent-strong);background:var(--surface-soft);color:var(--ink)}.upload-button{cursor:pointer}.upload-button.is-disabled{cursor:not-allowed;opacity:.55}.jigsaw-stage{justify-self:end}.jigsaw-play-zone{justify-items:center;gap:10px;width:100%;padding-bottom:2px;display:grid;overflow-x:auto}.jigsaw-worktable{touch-action:none;-webkit-user-select:none;user-select:none;background:0 0;max-width:100%;position:relative;overflow:visible}.jigsaw-board-guide{width:var(--jigsaw-board-width);height:var(--jigsaw-board-height);border:1px solid var(--line-strong);background:var(--surface-quiet);box-shadow:var(--shadow);left:var(--jigsaw-tab-size);top:var(--jigsaw-tab-size);border-radius:8px;position:absolute;overflow:hidden}.jigsaw-board-guide img{object-fit:cover;opacity:.26;width:100%;height:100%;display:block}.jigsaw-slot-grid{grid-template-columns:repeat(var(--jigsaw-cols), minmax(0, 1fr));grid-template-rows:repeat(var(--jigsaw-rows), minmax(0, 1fr));pointer-events:none;display:grid;position:absolute;inset:0}.jigsaw-slot-grid span{border:1px solid color-mix(in oklch, var(--ink) 12%, transparent)}.jigsaw-piece{min-width:0;color:var(--ink);touch-action:none;will-change:transform;background:0 0;border-radius:0;padding:0;position:absolute;top:0;left:0;overflow:hidden}.jigsaw-piece:hover .jigsaw-piece-outline{stroke:#0000}.jigsaw-piece.is-dragging{cursor:grabbing}.jigsaw-piece.is-dragging .jigsaw-piece-outline{stroke:#0000;stroke-width:0}.jigsaw-piece.is-placed .jigsaw-piece-outline{stroke:#0000}.jigsaw-piece-svg{width:100%;height:100%;filter:drop-shadow(0 8px 14px color-mix(in oklch, var(--ink) 18%, transparent));pointer-events:none;display:block}.jigsaw-piece-fill{fill:var(--surface-quiet);stroke:#0000}.jigsaw-piece-outline{fill:#0000;stroke:#0000;stroke-linejoin:round;stroke-width:0}.jigsaw-piece-target{fill:#0000;opacity:0;stroke:#0000}.jigsaw-source-preview{aspect-ratio:1;border:1px solid var(--line);background:var(--surface-quiet);object-fit:contain;border-radius:8px;width:100%}.upload-passphrase-field{color:var(--muted);gap:6px;font-size:.82rem;font-weight:900;display:grid}.upload-passphrase-field input{border:1px solid var(--line);background:var(--surface-quiet);width:100%;min-height:44px;color:var(--ink);border-radius:8px;padding:8px 10px}.upload-passphrase-field input:hover{border-color:var(--accent-strong)}.photo-list{gap:8px;display:grid}.photo-list-item{grid-template-columns:minmax(0,1fr) 42px;gap:8px;display:grid}.photo-choice{border:1px solid var(--line);background:var(--surface-quiet);min-width:0;min-height:54px;color:var(--ink);text-align:left;border-radius:8px;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:10px;padding:6px 8px;display:grid}.photo-choice:hover,.photo-choice[aria-pressed=true]{border-color:var(--accent-strong);background:var(--surface-soft)}.photo-choice img{object-fit:cover;border-radius:6px;width:42px;height:42px}.photo-choice span{overflow-wrap:anywhere;min-width:0;font-size:.82rem;font-weight:900}.photo-delete{background:var(--surface-quiet);width:42px;height:54px;color:var(--danger);border-radius:8px;place-items:center;display:grid}.photo-delete:hover{background:var(--danger-soft)}.site-footer{color:var(--muted);text-align:center;margin-top:auto;font-size:.9rem;font-weight:700}.visually-hidden{clip:rect(0 0 0 0);white-space:nowrap;clip-path:inset(50%);width:1px;height:1px;position:absolute;overflow:hidden}@media (width<=980px){.word-search-layout,.jigsaw-layout{grid-template-columns:minmax(0,1fr);justify-items:center}.word-search-board-section,.word-search-control-rail,.jigsaw-stage,.jigsaw-control-rail{justify-self:center}.control-rail{max-width:var(--board-max);position:static}}@media (width<=640px){.app-shell{width:min(calc(100% - 20px), var(--page-max));gap:18px;padding-top:18px}.site-header,.page-heading{text-align:left;grid-template-columns:minmax(0,1fr);justify-items:stretch}.word-search-heading,.jigsaw-heading{text-align:center;justify-items:center}.page-nav{width:100%}.page-heading{gap:12px}.header-badge{justify-self:center}.board-title-row{flex-direction:column;align-items:flex-start;gap:10px}.board-section,.jigsaw-stage{justify-items:stretch}.board-title-row,.on-board-panel,.status-line,.word-board-stack{max-width:min(100%,340px)}.jigsaw-stage .board-title-row,.jigsaw-stage .status-line,.jigsaw-play-zone{max-width:100%}.word-board-stack{justify-self:center}.on-board-panel{grid-template-columns:1fr}.on-board-panel .section-heading-row{padding-top:0}.word-progress-list{max-height:none;overflow:visible}h1{font-size:2rem}.board-frame{gap:2px;width:100%;padding:4px}.letter-cell{border-radius:4px;font-size:.68rem}.suggestion-grid{grid-template-columns:1fr}}@media (width<=360px){.board-title-row,.on-board-panel,.status-line,.word-board-stack{max-width:min(100%,308px)}.page-nav-link{padding:0 10px;font-size:.82rem}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}
