:root{--cream: #f6f3ec;--cream-2: #ecead9;--paper: #fffdf6;--ink: #1c1b1f;--ink-2: #34323a;--muted: #6b6a64;--muted-2: #94928a;--rule: #e2dfd0;--rule-2: #cfcbb8;--teal: #1d6f62;--teal-deep: #154e44;--teal-soft: #d9eae3;--clay: #c0552d;--clay-soft: #f1ddcd;--plum: #6a3a5b;--warn: #c98a14;--warn-soft: #f4e7c5;--danger: #b13a2e;--shadow-1: 0 1px 2px rgba(0, 0, 0, .04);--shadow-2: 0 6px 18px rgba(0, 0, 0, .07);--accent: var(--teal);--accent-deep: var(--teal-deep);--accent-soft: var(--teal-soft);--sans: "Inter", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--mono: "JetBrains Mono", ui-monospace, "SFMono-Regular", monospace;--radius-sm: 6px;--radius: 8px;--radius-lg: 10px;color:var(--ink);background:var(--cream);font-family:var(--sans);font-feature-settings:"cv11","ss01"}*{box-sizing:border-box}html,body{margin:0;min-height:100vh;background:var(--cream)}body{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}button,input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}.app{min-height:100vh;display:flex;flex-direction:column}.shell{width:min(1160px,calc(100% - 40px));margin:0 auto}.topbar{position:sticky;top:0;z-index:30;background:color-mix(in oklab,var(--cream) 92%,transparent);-webkit-backdrop-filter:saturate(1.2) blur(8px);backdrop-filter:saturate(1.2) blur(8px);border-bottom:1px solid var(--rule)}.topbar-inner{display:flex;align-items:center;justify-content:space-between;height:56px}.brand{display:inline-flex;align-items:center;gap:10px;cursor:pointer;color:var(--ink)}.brand-glyph{display:inline-block;width:12px;height:12px;background:var(--ink);border-radius:2px}.brand-name{font-weight:700;font-size:15px;letter-spacing:-.01em}.brand-meta{margin-left:4px;color:var(--muted);font-size:13px}.topnav{display:flex;gap:2px;align-items:center}.topnav button{border:0;background:transparent;color:var(--muted);padding:7px 12px;border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500}.topnav button:hover{color:var(--ink);background:var(--cream-2)}.topnav button.active{color:var(--ink);background:var(--cream-2);font-weight:600}.topnav .pill-counter{display:inline-flex;margin-left:6px;padding:0 6px;height:17px;align-items:center;border-radius:999px;background:color-mix(in oklab,var(--ink) 12%,transparent);color:var(--ink);font-size:11px;font-family:var(--mono);font-weight:500}.page-head{padding:36px 0 24px;display:flex;justify-content:space-between;align-items:end;gap:16px;flex-wrap:wrap;border-bottom:1px solid var(--rule)}.page-head h1{margin:0;font-size:28px;font-weight:600;letter-spacing:-.02em;line-height:1.1}.page-head .lede{margin:6px 0 0;color:var(--muted);font-size:14px;line-height:1.5;max-width:56ch}.page-head-actions{display:flex;gap:8px;align-items:center}.studio{padding:24px 0;display:grid;grid-template-columns:minmax(340px,1fr) minmax(0,1.15fr);gap:24px;align-items:start}@media (max-width: 900px){.studio{grid-template-columns:1fr;gap:20px}}.panel-stack{display:grid;gap:14px}.panel{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg)}.uploader.empty{border:1.5px dashed var(--rule-2);background:var(--paper);border-radius:var(--radius-lg);min-height:260px;display:grid;place-items:center;text-align:center;cursor:pointer;padding:24px;transition:border-color .12s ease,background .12s ease}.uploader.empty:hover,.uploader.empty.is-dragging{border-color:var(--accent);background:var(--accent-soft)}.uploader .upload-inner{max-width:320px;display:grid;gap:8px}.uploader .icon{display:grid;place-items:center;width:40px;height:40px;border-radius:8px;background:var(--cream-2);margin:0 auto 4px;color:var(--ink)}.uploader h2{margin:0;font-size:17px;font-weight:600;letter-spacing:-.005em}.uploader p{margin:0;color:var(--muted);font-size:13.5px;line-height:1.5}.uploader .file-types{margin-top:6px;display:inline-flex;gap:6px;font-family:var(--mono);font-size:10.5px;color:var(--muted-2);flex-wrap:wrap;justify-content:center}.uploader .file-types span{padding:2px 6px;border:1px solid var(--rule);border-radius:4px}.uploader.filled{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:12px;display:grid;grid-template-columns:64px 1fr auto;gap:12px;align-items:center}.uploader.filled .thumb{width:64px;height:64px;border-radius:var(--radius);overflow:hidden;background:var(--cream-2);border:1px solid var(--rule)}.uploader.filled .thumb img{width:100%;height:100%;object-fit:cover;display:block}.uploader.filled .info{display:grid;gap:2px;min-width:0}.uploader.filled .info .name{font-weight:500;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.uploader.filled .info .sub{font-size:12px;color:var(--muted)}.controls{background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg);padding:4px;display:grid}.field{display:grid;gap:8px;padding:14px 14px 16px;border-bottom:1px solid var(--rule)}.field:last-child{border-bottom:0}.field-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px}.field-label{font-size:12px;color:var(--muted);font-weight:500;letter-spacing:.01em;text-transform:uppercase}.field-value{font-family:var(--mono);font-size:12px;color:var(--ink)}.seg{display:inline-grid;grid-auto-flow:column;grid-auto-columns:1fr;background:var(--cream-2);border:1px solid var(--rule);border-radius:var(--radius);padding:3px;gap:2px}.seg.compact{padding:2px}.seg button{border:0;background:transparent;padding:6px 10px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-2);white-space:nowrap}.seg button:hover{color:var(--ink)}.seg button.active{background:var(--paper);color:var(--ink);font-weight:600;box-shadow:var(--shadow-1)}.seg button:disabled{color:var(--muted-2);cursor:not-allowed;opacity:.6}.seg-chips{display:flex;flex-wrap:wrap;gap:6px}.chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:var(--cream-2);border:1px solid var(--rule);border-radius:var(--radius);cursor:pointer;font-size:13px;font-weight:500;color:var(--ink-2)}.chip:hover{border-color:var(--rule-2);color:var(--ink)}.chip.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.chip.disabled{opacity:.45;cursor:not-allowed}.slider-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center}input[type=range].slider{width:100%;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;height:22px}input[type=range].slider::-webkit-slider-runnable-track{height:4px;background:var(--cream-2);border:1px solid var(--rule);border-radius:999px}input[type=range].slider::-moz-range-track{height:4px;background:var(--cream-2);border:1px solid var(--rule);border-radius:999px}input[type=range].slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--paper);box-shadow:0 1px 2px #0000002e;margin-top:-7px;cursor:pointer}input[type=range].slider::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--accent);border:2px solid var(--paper);cursor:pointer}.slider-stops{display:flex;gap:4px;margin-top:4px;flex-wrap:wrap}.slider-stops .chip{padding:4px 9px;font-size:12px;font-weight:500}.slider-stops .chip.active{background:var(--accent-soft);color:var(--accent-deep);border-color:var(--accent)}.preview-card{padding:16px;display:grid;gap:12px}.preview-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:4px 4px 12px;border-bottom:1px solid var(--rule)}.preview-meta .title{font-size:14px;font-weight:600}.name-input{border:1px solid var(--rule);background:var(--paper);font:inherit;font-size:15px;font-weight:600;color:var(--ink);padding:4px 8px;border-radius:6px;min-width:80px;max-width:320px;width:100%;letter-spacing:-.005em;transition:background 80ms ease,border-color 80ms ease}.name-input:hover{background:var(--cream-2);border-color:var(--rule)}.name-input:focus{background:var(--paper);border-color:var(--accent);outline:none;box-shadow:0 0 0 3px color-mix(in oklab,var(--accent) 18%,transparent)}.name-input::placeholder{color:var(--muted-2);font-weight:500}.name-wrap{display:inline-flex;align-items:center;gap:6px;min-width:0;flex:1}.name-wrap .edit-hint{color:var(--muted);flex-shrink:0;opacity:1;transition:opacity .1s ease}.preview-meta .stamp{display:flex;gap:14px;font-family:var(--mono);font-size:11px;color:var(--muted)}.preview-meta .stamp b{color:var(--ink);font-weight:500}.preview-stage{display:grid;place-items:center;padding:16px;min-height:320px;background:var(--cream);border-radius:var(--radius);overflow:auto}.preview-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap;padding-top:4px}.preview-actions .spacer{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:36px;padding:0 14px;border-radius:var(--radius);border:1px solid var(--rule-2);background:var(--paper);color:var(--ink);font-weight:500;font-size:13px;cursor:pointer;transition:background 80ms ease,border-color 80ms ease}.btn:hover{background:var(--cream-2)}.btn.primary{background:var(--ink);color:var(--cream);border-color:var(--ink)}.btn.primary:hover{background:var(--ink-2);border-color:var(--ink-2)}.btn.accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn.accent:hover{background:var(--accent-deep);border-color:var(--accent-deep)}.btn.subtle{background:transparent;border-color:transparent;color:var(--muted)}.btn.subtle:hover{background:var(--cream-2);color:var(--ink)}.btn.danger{color:var(--danger);border-color:var(--rule-2)}.btn.danger:hover{background:color-mix(in oklab,var(--danger) 8%,var(--paper));border-color:var(--danger)}.btn .kbd{font-family:var(--mono);font-size:10.5px;padding:1px 5px;background:color-mix(in oklab,currentColor 12%,transparent);border-radius:3px}.btn .icon{width:14px;height:14px;display:grid;place-items:center}.btn.icon-only{width:36px;padding:0}.share-row{display:grid;grid-template-columns:1fr auto;gap:6px;padding:8px;background:var(--cream);border:1px solid var(--rule);border-radius:var(--radius)}.share-row input{border:0;background:transparent;padding:6px 8px;font-family:var(--mono);font-size:12px;min-width:0}.puzzle-board{display:grid;font-family:var(--mono);color:var(--ink)}.puzzle-board .pb-corner{background:transparent}.puzzle-board .pb-col-clue,.puzzle-board .pb-row-clue{display:flex;font-size:10.5px;color:var(--muted);line-height:1.15;gap:1px}.puzzle-board .pb-col-clue{flex-direction:column;justify-content:flex-end;align-items:center;padding-bottom:4px}.puzzle-board .pb-row-clue{justify-content:flex-end;align-items:center;padding-right:6px;gap:3px}.puzzle-board .pb-cell{border:1px solid var(--rule);background:var(--paper)}.puzzle-board .pb-cell.filled{background:var(--ink)}.puzzle-board .pb-cell.heavy-l{border-left-color:var(--ink)}.puzzle-board .pb-cell.heavy-t{border-top-color:var(--ink)}.library{padding:28px 0 60px}.library-head{display:flex;align-items:end;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:16px}.library-head h2{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.library-head .sub{margin:4px 0 0;color:var(--muted);font-size:13.5px}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.toolbar .search{position:relative;display:inline-flex;align-items:center}.toolbar .search input{border:1px solid var(--rule);background:var(--paper);border-radius:var(--radius);padding:7px 12px 7px 30px;font-size:13px;width:200px;color:var(--ink)}.toolbar .search input::placeholder{color:var(--muted-2)}.toolbar .search svg{position:absolute;left:9px;color:var(--muted-2)}.toolbar select{border:1px solid var(--rule);background:var(--paper);border-radius:var(--radius);padding:6px 8px;font-size:13px;color:var(--ink);cursor:pointer}.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}.library-filters{margin-bottom:18px}.gallery.dense{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px}.gallery.cozy{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:18px}.card{position:relative;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius-lg);overflow:hidden;display:grid;cursor:pointer;transition:transform .1s ease,box-shadow .1s ease,border-color .1s ease}.card:hover{transform:translateY(-1px);box-shadow:var(--shadow-2);border-color:var(--rule-2)}.card .thumb-wrap{background:var(--cream);display:grid;place-items:center;padding:12px;aspect-ratio:1 / 1;border-bottom:1px solid var(--rule)}.card .meta{padding:10px 12px 12px;display:grid;gap:4px}.card .meta .row1{display:flex;align-items:center;justify-content:space-between;gap:6px;min-width:0}.card .meta .name{min-width:0;font-weight:500;font-size:13.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;letter-spacing:-.005em}.card .meta .footer{display:flex;align-items:center;justify-content:space-between;gap:8px;min-width:0;font-size:11.5px;color:var(--muted)}.card .size{flex:0 0 auto;font-family:var(--mono);font-size:10.5px;color:var(--muted)}.card .actions{position:absolute;top:8px;right:8px;display:flex;gap:4px;opacity:0;transition:opacity .1s ease}.card:hover .actions{opacity:1}.card .actions button{width:28px;height:28px;border:1px solid var(--rule-2);background:color-mix(in oklab,var(--paper) 90%,transparent);border-radius:6px;display:grid;place-items:center;cursor:pointer;color:var(--ink);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.card .actions button:hover{background:var(--paper)}.card .actions button.danger:hover{color:var(--danger);border-color:var(--danger)}.tag{display:inline-flex;align-items:center;gap:5px;flex:0 1 auto;min-width:0;padding:2px 7px;border-radius:999px;font-size:10.5px;font-weight:600;letter-spacing:.01em}.tag .dot{width:5px;height:5px;border-radius:50%}.tag.created{background:var(--accent-soft);color:var(--accent-deep)}.tag.created .dot{background:var(--accent)}.tag.solved{background:var(--clay-soft);color:#8a3315}.tag.solved .dot{background:var(--clay)}.tag.playing{background:var(--warn-soft);color:#6e4d05}.tag.playing .dot{background:var(--warn)}.mini-grid{display:grid;width:min(132px,100%)!important;height:auto!important;aspect-ratio:1 / 1;border-radius:3px;overflow:hidden;background:var(--paper);border:1px solid var(--rule)}.mini-grid i{background:var(--ink)}.mini-grid i.off{background:transparent}.card .meta .footer>span:last-child{flex:0 0 auto;white-space:nowrap}.empty-library{border:1px dashed var(--rule-2);border-radius:var(--radius-lg);padding:32px;display:grid;place-items:center;text-align:center;color:var(--muted);gap:4px}.empty-library b{font-size:14px;color:var(--ink);font-weight:600}.player{padding:20px 0 140px;display:grid;gap:16px}.player-header{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.player-header .left{display:flex;align-items:center;gap:10px}.player-header .title{font-size:15px;font-weight:600;letter-spacing:-.005em}.player-header .sub{font-family:var(--mono);font-size:11.5px;color:var(--muted)}.player-header .right{display:flex;gap:8px;align-items:center}.timer{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--ink);color:var(--cream);border-radius:var(--radius);font-family:var(--mono);font-size:14px;font-weight:500;font-variant-numeric:tabular-nums}.timer .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);animation:pulse 1.4s ease-in-out infinite}.timer.paused .dot{background:var(--muted-2);animation:none}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.progress{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius);font-family:var(--mono);font-size:11.5px;color:var(--muted)}.progress-bar{width:80px;height:4px;background:var(--cream-2);border-radius:999px;overflow:hidden}.progress-bar i{display:block;height:100%;background:var(--accent);transition:width .2s ease}.board-wrap{display:grid;place-items:center;padding:8px;overflow:auto}.board{display:grid;background:var(--paper);border-radius:var(--radius-lg);border:1px solid var(--rule);padding:14px;box-shadow:var(--shadow-1)}.board .b-cell{border:1px solid var(--rule-2);background:var(--paper);display:grid;place-items:center;font-size:14px;color:var(--muted);cursor:pointer;-webkit-user-select:none;user-select:none;transition:background 60ms ease}.board .b-cell.heavy-l{border-left-color:var(--ink)}.board .b-cell.heavy-t{border-top-color:var(--ink)}.board .b-cell:hover{background:color-mix(in oklab,var(--accent) 12%,var(--paper))}.board .b-cell.filled{background:var(--ink)}.board .b-cell.filled:hover{background:var(--ink-2)}.board .b-cell.marked:after{content:"";width:50%;height:50%;background:linear-gradient(45deg,transparent calc(50% - 1px),var(--accent) calc(50% - 1px),var(--accent) calc(50% + 1px),transparent calc(50% + 1px)),linear-gradient(-45deg,transparent calc(50% - 1px),var(--accent) calc(50% - 1px),var(--accent) calc(50% + 1px),transparent calc(50% + 1px))}.board .b-row-clue,.board .b-col-clue{display:flex;font-family:var(--mono);font-size:12.5px;color:var(--ink);line-height:1}.board .b-row-clue{justify-content:flex-end;align-items:center;gap:5px;padding:0 8px}.board .b-col-clue{flex-direction:column;justify-content:flex-end;align-items:center;gap:2px;padding:6px 0}.board .b-row-clue.first-of-block{border-top:1px solid var(--ink)}.board .b-col-clue.first-of-block{border-left:1px solid var(--ink)}.board .b-row-clue .struck,.board .b-col-clue .struck{color:var(--muted-2);text-decoration:line-through;text-decoration-color:color-mix(in oklab,var(--muted-2) 60%,transparent)}.board .b-corner{display:grid;place-items:center;color:var(--muted-2);font-family:var(--mono);font-size:10px}.mode-toggle{position:fixed;z-index:50;bottom:24px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;background:var(--ink);color:var(--cream);padding:4px;border-radius:999px;box-shadow:var(--shadow-2);gap:2px}.mode-toggle button{border:0;background:transparent;color:color-mix(in oklab,var(--cream) 75%,transparent);padding:8px 14px;border-radius:999px;font-weight:500;font-size:13px;cursor:pointer;display:inline-flex;gap:8px;align-items:center}.mode-toggle button.active{background:var(--cream);color:var(--ink);font-weight:600}.mode-toggle .pin{width:9px;height:9px;background:currentColor;display:inline-block;border-radius:1px}.mode-toggle button .x{width:9px;height:9px;position:relative}.mode-toggle button .x:before,.mode-toggle button .x:after{content:"";position:absolute;left:50%;top:50%;width:100%;height:1.5px;background:currentColor}.mode-toggle button .x:before{transform:translate(-50%,-50%) rotate(45deg)}.mode-toggle button .x:after{transform:translate(-50%,-50%) rotate(-45deg)}.mode-toggle .kbd-hint{font-family:var(--mono);font-size:10px;padding:2px 5px;background:color-mix(in oklab,var(--cream) 14%,transparent);border-radius:3px;letter-spacing:.04em}.win-banner{position:fixed;z-index:100;top:50%;left:50%;transform:translate(-50%,-50%);background:var(--paper);border:1px solid var(--rule-2);border-radius:12px;padding:22px 26px;box-shadow:var(--shadow-2);text-align:center;display:grid;gap:6px;min-width:320px;animation:rise .28s cubic-bezier(.2,.8,.2,1)}@keyframes rise{0%{opacity:0;transform:translate(-50%,-45%) scale(.96)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.win-banner .check{width:40px;height:40px;border-radius:50%;background:var(--accent-soft);color:var(--accent-deep);display:grid;place-items:center;margin:0 auto 6px}.win-banner h3{margin:0;font-size:20px;font-weight:600;letter-spacing:-.01em}.win-banner .stats{display:flex;justify-content:center;gap:18px;margin-top:8px;font-size:11.5px;color:var(--muted)}.win-banner .stats b{display:block;font-family:var(--mono);font-size:18px;color:var(--ink);font-weight:600;margin-bottom:2px}.win-banner .actions{display:flex;justify-content:center;gap:8px;margin-top:14px}.colophon{border-top:1px solid var(--rule);padding:18px 0 24px;font-size:12px;color:var(--muted);display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}.status{font-size:13px;color:var(--muted);margin:8px 0}.status.error{color:var(--danger)}.status.warn{color:var(--warn)}.centered-message{min-height:70vh;display:grid;place-content:center;gap:12px;text-align:center}.note-inline{display:inline-flex;align-items:center;gap:6px;padding:4px 8px;border-radius:999px;font-size:11.5px}.note-inline.warn{background:var(--warn-soft);color:#6e4d05}.about{padding:36px 0 60px}.about h1{margin:0;font-size:28px;font-weight:600;letter-spacing:-.02em}.about p{color:var(--muted);font-size:14px;line-height:1.6;max-width:60ch}.shortcuts{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:8px;margin-top:18px}.shortcut{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--paper);border:1px solid var(--rule);border-radius:var(--radius);font-size:13px}.shortcut .keys{display:inline-flex;gap:4px}.shortcut kbd{font-family:var(--mono);font-size:11px;padding:2px 6px;background:var(--cream-2);border:1px solid var(--rule);border-radius:4px}.hidden{display:none!important}.row{display:flex;align-items:center;gap:8px}.row.between{justify-content:space-between}.muted{color:var(--muted)}
