@import url("https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;600;700&family=Instrument+Serif:ital@0;1&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}.root{min-height:100vh;background:#f7f4ee;display:flex;flex-direction:column;align-items:center;padding:32px 16px 64px;color:#1c1118;position:relative;overflow-x:hidden}.pixel-bg{position:fixed;inset:0;display:grid;grid-template-columns:repeat(12,1fr);grid-template-rows:repeat(10,1fr);pointer-events:none;z-index:0}.pixel-bg-cell{border:1px solid rgba(69,39,160,.05)}.confetti-wrap{pointer-events:none;position:fixed;inset:0;z-index:999;overflow:hidden}.confetti-dot{position:absolute;width:9px;height:9px;border-radius:2px;top:-16px;left:calc(var(--i) * 2.85%);background:hsl(calc(var(--i) * 10deg + 20deg),80%,55%);animation:cfall 2.2s ease-in forwards;animation-delay:calc(var(--i) * 45ms)}@keyframes cfall{0%{transform:translateY(0) rotate(0deg);opacity:1}85%{opacity:1}to{transform:translateY(110vh) rotate(600deg);opacity:0}}.lobby-wrap{position:relative;z-index:1;width:100%;max-width:420px;display:flex;flex-direction:column}.lobby-header{display:flex;align-items:center;margin-bottom:8px}.logo-mark{display:grid;grid-template-columns:repeat(4,13px);gap:3px;flex-shrink:0}.lm-px{width:13px;height:13px;border-radius:3px;background:#cbd5e1}.lm-on{background:#4f46e5;box-shadow:0 0 5px rgba(69,39,160,.35)}.logo-name{font-size:2rem;font-weight:400;letter-spacing:-.5px;color:#1c1118;line-height:1}.logo-sub{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:#94a3b8;margin-top:3px}.date-line{font-size:.7rem;margin-bottom:28px}.date-line,.section-eyebrow{color:#94a3b8;letter-spacing:.5px}.section-eyebrow{font-size:.8rem;text-transform:uppercase;margin-bottom:10px}.diff-stack{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.diff-card{align-items:center;justify-content:space-between;background:#fff;border:1.5px solid #e2e8f0;border-radius:16px;padding:18px 18px 18px 20px;cursor:pointer;text-align:left;transition:border-color .16s,box-shadow .16s,transform .13s,background .16s;position:relative;overflow:hidden}.diff-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--dc);border-radius:4px 0 0 4px}.diff-card:hover{border-color:var(--dc);background:color-mix(in srgb,var(--dc) 4%,#fff);box-shadow:0 6px 20px rgba(0,0,0,.08);transform:translateY(-2px)}.diff-card:active{transform:translateY(0);box-shadow:none}.diff-card-left{display:flex;align-items:center;gap:14px}.diff-card-icon{font-size:1.4rem;font-family:monospace;line-height:1;width:26px;text-align:center;flex-shrink:0}.diff-card-labels{display:flex;flex-direction:column;gap:4px}.diff-card-label{font-size:1.15rem;color:#1c1118;line-height:1}.diff-card-desc{font-size:.9rem;color:#94a3b8;line-height:1.4}.diff-card-right{margin-top:8px;gap:10px;flex-shrink:0}.diff-card-right,.diff-dots{display:flex;align-items:center}.diff-dots{gap:5px}.diff-dot{width:11px;height:11px;border-radius:50%;transition:background .2s}.diff-card-grid{font-size:.75rem;font-weight:600;color:#94a3b8;letter-spacing:.5px;white-space:nowrap}.diff-card-arrow{font-size:1rem;color:var(--dc);opacity:0;transform:translateX(-4px);transition:opacity .15s,transform .15s}.diff-card:hover .diff-card-arrow{opacity:1;transform:translateX(0)}.htp-link{background:none;border:none;font-family:IBM Plex Mono,monospace;font-size:.72rem;color:#94a3b8;cursor:pointer;text-align:center;text-decoration:underline;text-underline-offset:3px;transition:color .15s}.htp-link:hover{color:#4f46e5}.htp-overlay{position:fixed;inset:0;background:rgba(28,17,24,.5);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.htp-panel{background:#fdfaf7;border-radius:22px;padding:28px;width:100%;max-width:420px;max-height:88vh;overflow-y:auto;box-shadow:0 24px 64px rgba(0,0,0,.2);animation:slideUp .25s cubic-bezier(.34,1.36,.64,1) both}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.htp-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.htp-title{font-size:1.6rem;color:#1c1118}.htp-close{background:none;border:none;font-size:.9rem;color:#94a3b8;cursor:pointer;padding:6px;transition:color .15s}.htp-close:hover{color:#1c1118}.htp-intro{font-size:.75rem;color:#475569;line-height:1.7;margin-bottom:20px}.htp-tabs{display:flex;gap:6px;margin-bottom:18px}.htp-tab{width:32px;height:32px;border-radius:50%;border:1.5px solid #e2e8f0;background:#fff;font-family:IBM Plex Mono,monospace;font-size:.8rem;font-weight:600;color:#94a3b8;cursor:pointer;transition:all .15s}.htp-tab:hover{border-color:#4f46e5;color:#4f46e5}.htp-tab-active{background:#4f46e5;border-color:#4f46e5;color:#fff}.htp-step-body{background:#fff;border-radius:14px;padding:18px;margin-bottom:14px;min-height:160px}.htp-step-label{font-size:1.1rem;color:#1c1118;margin-bottom:8px}.htp-step-text{font-size:.72rem;color:#475569;line-height:1.7;margin-bottom:14px}.demo-block{display:flex;flex-direction:column;gap:6px}.demo-row{display:flex;align-items:center;gap:3px}.demo-clue{display:flex;gap:3px;margin-right:6px;font-size:.7rem;font-weight:600}.demo-clue,.demo-clue.ok{color:#4f46e5}.dc{width:22px;height:22px;border-radius:4px;border:1.5px solid #c7d2fe;background:#f7f4ee;display:flex;align-items:center;justify-content:center}.df{background:#4f46e5;border-color:#3730a3}.dm{background:#eef2ff;border-color:#a5b4fc}.dm-maybe{background:rgba(69,39,160,.2);border:1.5px dashed #6366f1}.demo-states{display:flex;gap:16px;align-items:flex-start}.demo-state{display:flex;flex-direction:column;align-items:center;gap:4px}.demo-state-lbl{font-size:.6rem;color:#94a3b8;text-align:center;white-space:nowrap}.demo-note{font-size:.75rem;color:#94a3b8;font-style:italic}.htp-nav{display:flex;gap:8px;justify-content:flex-end;margin-bottom:18px}.htp-nav-btn{padding:8px 18px;border-radius:10px;border:1.5px solid #e2e8f0;background:#fff;font-family:IBM Plex Mono,monospace;font-size:.75rem;font-weight:600;color:#475569;cursor:pointer;transition:all .15s}.htp-nav-btn:disabled{opacity:.35;cursor:default}.htp-nav-primary{background:#4f46e5;border-color:#4f46e5;color:#fff}.htp-nav-primary:hover{filter:brightness(1.1);color:#fff}.htp-tips{border-top:1px solid #e2e8f0;padding-top:16px}.htp-tip-title{font-size:.6rem;letter-spacing:2px;text-transform:uppercase;color:#94a3b8;margin-bottom:8px}.htp-tips ul{padding-left:16px;display:flex;flex-direction:column;gap:6px}.htp-tips li{font-size:.7rem;color:#475569;line-height:1.5}.game-header{width:100%;max-width:600px;justify-content:space-between;margin-bottom:24px;position:relative;z-index:1}.game-header,.game-logo-row{display:flex;align-items:center}.game-logo-row{gap:8px}.back-btn{background:#fff;border:1.5px solid #e2e8f0;border-radius:10px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;color:#475569;font-family:IBM Plex Mono,monospace;transition:all .15s}.back-btn:hover{border-color:#4f46e5;color:#4f46e5}.game-logo-mark{display:grid;grid-template-columns:repeat(3,9px);gap:2px;flex-shrink:0}.logo-cell{width:9px;height:9px;border-radius:2px;background:#cbd5e1}.logo-cell.on{background:#4f46e5}.game-logo-text{font-size:1.3rem;color:#1c1118;line-height:1}.game-diff-chip{font-size:.75rem;letter-spacing:.5px;padding:6px 12px;border-radius:20px;font-weight:600}.game-stats{display:flex;gap:6px}.stat-badge{padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;background:#fff;border:1.5px solid #e2e8f0;color:#4f46e5}.solved-banner{color:#fff;padding:11px 24px;border-radius:12px;font-size:.88rem;font-weight:600;margin-bottom:16px;position:relative;z-index:1;animation:popIn .3s cubic-bezier(.34,1.56,.64,1)}@keyframes popIn{0%{transform:scale(.75);opacity:0}to{transform:scale(1);opacity:1}}.board-outer{background:#fff;border-radius:20px;padding:18px;box-shadow:0 4px 24px rgba(69,39,160,.09),0 1px 4px rgba(69,39,160,.06);overflow-x:auto;max-width:100%;position:relative;z-index:1}.col-clue{flex-direction:column;padding-bottom:4px;gap:1px}.col-clue,.row-clue{display:flex;align-items:center;justify-content:flex-end}.row-clue{flex-direction:row;padding-right:5px;gap:2px}.clue-n{font-family:IBM Plex Mono,monospace;font-weight:700;color:#4f46e5;min-width:13px;text-align:center;line-height:1.3;transition:color .2s}.clue-ok .clue-n{color:#3730a3;opacity:.5}.cell{border:1.5px solid #e2e8f0;background:#fafaf8;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .07s,border-color .07s}.cell:hover{border-color:#6366f1;background:#eef2ff}.cell.filled{background:var(--fill-color,#4f46e5);border-color:color-mix(in srgb,var(--fill-color,#4f46e5) 70%,#000);box-shadow:inset 0 2px 3px rgba(0,0,0,.15)}.cell.filled:hover{filter:brightness(.88)}.cell.marked{background:#eef2ff;border-color:#a5b4fc}.cell.solution{background:#6366f1!important;border-color:#3730a3!important}.cell.thick-r{border-right:2.5px solid #94a3b8}.cell.thick-b{border-bottom:2.5px solid #94a3b8}.xmark{color:#6366f1;font-weight:700}.game-controls{display:flex;gap:12px;margin-top:18px;position:relative;z-index:1;flex-wrap:wrap;justify-content:center}.ctrl{padding:9px 20px;border-radius:10px;border:1.5px solid #e2e8f0;background:#fff;font-size:.78rem;font-weight:600;cursor:pointer;color:#4f46e5;transition:all .14s}.ctrl:hover{border-color:#4f46e5;background:#eef2ff;transform:translateY(-1px)}.ctrl-primary{color:#fff}.ctrl-primary:hover{filter:brightness(1.1);background:unset}.hint-bar{margin-top:12px;font-size:.68rem;color:#94a3b8;text-align:center;position:relative;z-index:1}