@import"https://fonts.googleapis.com/css2?family=Nunito:wght@400;500;600;700&display=swap";:root{font-family:Nunito,Segoe UI,system-ui,-apple-system,BlinkMacSystemFont,Helvetica Neue,sans-serif;line-height:1.5;font-weight:500;color:#5d4e37;background-color:#fff9e6;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden}body{margin:0;min-height:100vh;max-width:100vw;overflow-x:hidden;background:linear-gradient(135deg,#fff9e6,#fff3d4,#ffe8b8);color:inherit}#root{min-height:100vh;max-width:100vw;overflow-x:hidden}a{color:#d4a853;text-decoration:none}a:hover{color:#c9a547}.level-select{min-height:100vh;padding:32px clamp(16px,4vw,64px);background:linear-gradient(135deg,#fff9e6,#fff3d4,#ffe8b8)}.level-select-header{text-align:center;margin-bottom:40px}.level-select-header h1{font-size:2.5rem;color:#5d4e37;margin:0 0 8px}.level-select-header p{font-size:1.1rem;color:#8b7355;margin:0}.level-categories{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:40px}.level-category{background:linear-gradient(135deg,#fffdf7,#fff8e7);border-radius:24px;padding:24px;border:2px solid #e8d4a8;box-shadow:0 4px 20px #8b73551a}.category-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding-bottom:12px;border-bottom:2px solid #e8d4a8}.category-header h2{margin:0;font-size:1.5rem}.category-count{font-size:.9rem;color:#8b7355;background:#fef6e4;padding:4px 12px;border-radius:12px}.level-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.level-card{position:relative;background:#fffdf7;border:2px solid #e8d4a8;border-radius:16px;padding:16px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;align-items:center;gap:12px}.level-card:hover{transform:translateY(-4px);border-color:#d4a853;box-shadow:0 8px 24px #8b735533}.level-card.completed{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#81c784}.level-number{position:absolute;top:-10px;left:-10px;width:28px;height:28px;background:linear-gradient(135deg,#f5d76e,#f7ca45);border:2px solid #d4a853;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#5d4e37}.level-card.completed .level-number{background:linear-gradient(135deg,#81c784,#66bb6a);border-color:#4caf50;color:#fff}.level-card.locked{opacity:.7;cursor:not-allowed;filter:grayscale(.8);background:#f0e6d6}.level-card.locked:hover{transform:none;box-shadow:none;border-color:#e8d4a8}.level-preview-container{position:relative;background:#fff;border-radius:8px;padding:8px;border:1px solid #e8d4a8}.puzzle-preview{border-radius:4px;overflow:hidden}.preview-cell{box-sizing:border-box}.completed-overlay{position:absolute;inset:0;background:#4caf504d;border-radius:8px;display:flex;align-items:center;justify-content:center}.completed-overlay span{font-size:2rem;color:#2e7d32}.level-info{text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.level-info h3{margin:0;font-size:1rem;color:#5d4e37}.level-size{font-size:.8rem;color:#a89070}.difficulty-stars{display:flex;gap:2px}.difficulty-stars .star{font-size:.7rem;color:#e8d4a8}.difficulty-stars .star.filled{color:#f39c12}.level-select-footer{text-align:center;margin-top:40px;color:#a89070}.level-select-footer p{margin:0}@media(max-width:768px){.level-select{padding:24px 16px}.level-select-header h1{font-size:2rem}.level-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.level-card{padding:12px}}.victory-overlay{position:fixed;inset:0;background:#5d4e37b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .4s ease}.victory-content{background:linear-gradient(135deg,#fffdf7,#fff8e7);border:3px solid #d4a853;border-radius:28px;padding:40px 48px;text-align:center;box-shadow:0 20px 60px #5d4e3766;animation:victorySlideIn .5s ease;max-width:90vw;max-height:90vh;overflow:auto}@keyframes victorySlideIn{0%{transform:translateY(-40px) scale(.9);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.victory-header{display:flex;flex-direction:column;align-items:center;gap:8px;margin-bottom:20px}.victory-emoji{font-size:4rem;animation:bounce .6s ease infinite alternate}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.victory-header h2{margin:0;font-size:2rem;color:#d4a853;text-shadow:2px 2px 0 rgba(212,168,83,.2)}.victory-puzzle-name{margin-bottom:24px}.victory-puzzle-name h3{margin:0 0 4px;font-size:1.4rem;color:#5d4e37}.puzzle-size{font-size:.9rem;color:#8b7355}.pixel-art-container{display:flex;justify-content:center;margin-bottom:28px}.pixel-art{box-shadow:0 8px 32px #8b735533}.pixel-cell{transition:transform .1s ease}@keyframes pixelPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.victory-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.btn-next{padding:14px 36px;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#4caf50,#43a047);border:2px solid #388e3c;border-radius:16px;cursor:pointer;transition:all .2s ease}.btn-next:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4caf5066}.btn-menu{padding:14px 32px;font-size:1rem;font-weight:600;color:#5d4e37;background:linear-gradient(135deg,#f5d76e,#f7ca45);border:2px solid #d4a853;border-radius:16px;cursor:pointer;transition:all .2s ease}.btn-menu:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4a85366}@media(max-width:480px){.victory-content{padding:28px 24px}.victory-emoji{font-size:3rem}.victory-header h2{font-size:1.6rem}.victory-buttons{flex-direction:column}.btn-next,.btn-menu{width:100%}}:root{--bg-gradient: linear-gradient(135deg, #fff9e6 0%, #fff3d4 50%, #ffe8b8 100%);--card-bg: linear-gradient(135deg, #fffdf7 0%, #fff8e7 100%);--border-color: #e8d4a8;--accent-color: #d4a853;--text-primary: #5d4e37;--text-secondary: #8b7355;--text-muted: #a89070;--cell-fill: #5d4e37;--cell-empty: #fff8e7;--cell-hover: #fef3d0}*{box-sizing:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.app-shell{min-height:100vh;max-width:100vw;padding:24px clamp(8px,2vw,48px) 32px;display:flex;flex-direction:column;gap:20px;background:var(--bg-gradient);overflow-x:hidden}.modal-overlay{position:fixed;inset:0;background:#5d4e3799;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--card-bg);border:3px solid var(--accent-color);border-radius:28px;padding:40px 56px;text-align:center;box-shadow:0 20px 60px #5d4e374d;animation:scaleIn .3s ease}.modal.lose{border-color:#e57373}@keyframes scaleIn{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}.modal h2{margin:0 0 12px;font-size:1.8rem;color:var(--accent-color)}.modal.lose h2{color:#e57373}.modal p{margin:0 0 24px;font-size:1rem;color:var(--text-primary)}.modal button{padding:12px 32px;font-size:1rem;font-weight:600;color:var(--text-primary);background:linear-gradient(135deg,#f5d76e,#f7ca45);border:2px solid var(--accent-color);border-radius:14px;cursor:pointer;transition:all .2s ease}.modal button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #d4a85366}.modal button.secondary{background:transparent;border-color:var(--border-color);color:var(--text-secondary)}.modal button.secondary:hover{background:#fef6e4;border-color:var(--accent-color)}.modal-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.tool-hint-bar{position:fixed;top:0;left:0;right:0;padding:12px 24px;background:linear-gradient(90deg,#f5d76e,#f7ca45);color:var(--text-primary);display:flex;justify-content:center;align-items:center;gap:16px;font-weight:600;z-index:100;box-shadow:0 2px 12px #8b735533}.tool-hint-bar button{padding:6px 16px;background:#fff;border:2px solid var(--accent-color);border-radius:20px;color:var(--text-secondary);font-weight:600;cursor:pointer;transition:all .15s ease}.tool-hint-bar button:hover{background:#fef6e4;border-color:#c9a547}.demo-control-bar{position:fixed;top:0;left:0;right:0;padding:12px 24px;background:linear-gradient(90deg,#b8e0d2,#95d5b2);color:#2d5a3d;display:flex;flex-wrap:wrap;align-items:center;gap:16px;z-index:100;box-shadow:0 2px 12px #2d5a3d33}.demo-info{display:flex;align-items:center;gap:12px}.demo-title{font-weight:700;font-size:1rem}.demo-progress{font-size:.85rem;background:#ffffff80;padding:4px 10px;border-radius:12px}.demo-reason{flex:1;font-size:.9rem;background:#fff9;padding:8px 16px;border-radius:8px;min-width:200px}.demo-buttons{display:flex;gap:8px}.demo-buttons button{padding:8px 16px;background:#fff;border:2px solid #7bc89c;border-radius:20px;color:#2d5a3d;font-weight:600;cursor:pointer;transition:all .15s ease}.demo-buttons button:hover:not(:disabled){background:#e8f5e9;border-color:#4caf50}.demo-buttons button:disabled{opacity:.5;cursor:not-allowed}.demo-buttons .speed-btn{background:linear-gradient(135deg,gold,#fa0);border-color:#e6a800;color:#5d4e37;font-weight:700;min-width:50px}.demo-btn{padding:8px 16px;background:linear-gradient(135deg,#b8e0d2,#95d5b2);border:2px solid #7bc89c;border-radius:12px;color:#2d5a3d;font-weight:600;font-size:.85rem;cursor:pointer;transition:all .2s ease}.demo-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #7bc89c66}.demo-btn:disabled{opacity:.5;cursor:not-allowed}.chrome{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:var(--card-bg);border:2px solid var(--border-color);border-radius:20px;box-shadow:0 4px 20px #8b73551f}.chrome-left{flex:1}.chrome-back{padding:8px 16px;background:transparent;border:2px solid var(--border-color);border-radius:12px;color:var(--text-secondary);font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.chrome-back:hover{background:#fef6e4;border-color:var(--accent-color);color:var(--text-primary)}.chrome-title{text-align:center;flex:2}.chrome h1{margin:4px 0;font-size:clamp(1.5rem,2.5vw,2rem);letter-spacing:.04em;color:var(--text-primary)}.chrome-author{margin:0;opacity:.7;font-size:.9rem;color:var(--text-secondary)}.chrome-label{font-size:.75rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);margin:0}.chrome-settings{display:inline-flex;flex-direction:column;justify-content:center;gap:4px;padding:10px;border-radius:12px;border:2px solid var(--border-color);background:#fffdf7;cursor:pointer;transition:all .2s ease}.chrome-settings span{display:block;width:18px;height:2px;background:var(--text-muted);border-radius:1px}.chrome-settings:hover{background:#fff8e7;border-color:var(--accent-color)}.chrome-settings:hover span{background:var(--text-secondary)}.chrome-lives{display:flex;flex-direction:column;align-items:flex-end;gap:6px;flex:1}.life-pips{display:flex;gap:8px}.pip{width:14px;height:14px;border-radius:50%;border:2px solid var(--border-color);background:#fff8e7;transition:all .3s ease}.pip.active{background:linear-gradient(145deg,#ff8c42,#ff6b35);border-color:#ff8c42;box-shadow:0 2px 8px #ff6b3566}.pip.lost{background:#f0e6d6;border-color:#ddd0c0;animation:pipLost .4s ease}@keyframes pipLost{0%{transform:scale(1)}25%{transform:scale(1.2)}50%{transform:scale(.8)}to{transform:scale(1)}}.playfield{display:flex;flex-direction:column;gap:20px;flex:1}.board-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;flex:1}.mode-switch{display:flex;gap:8px;background:#fffdf7;border:2px solid var(--border-color);border-radius:16px;padding:6px;position:relative;overflow:hidden}.mode-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:12px;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .22s ease;position:relative;z-index:1}.mode-btn:hover{background:#fef6e4}.mode-btn.active{background:linear-gradient(135deg,#f5d76e,#f7ca45);color:var(--text-primary);box-shadow:0 2px 8px #d4a8534d;transform:translateY(-1px)}.mode-icon{width:20px;height:20px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;transition:transform .22s ease,box-shadow .22s ease}.mode-icon.fill{background:var(--cell-fill)}.mode-icon.mark{background:transparent;border:2px solid var(--text-secondary);color:var(--text-secondary)}.mode-btn.active .mode-icon{animation:modePop .26s ease;box-shadow:0 0 0 6px #f5d76e40}@keyframes modePop{0%{transform:scale(.9)}50%{transform:scale(1.1)}to{transform:scale(1)}}.board-container{background:var(--card-bg);border-radius:20px;padding:16px;border:2px solid var(--border-color);box-shadow:0 8px 32px #8b73551f}.board-grid{display:grid;grid-template-columns:var(--row-band) var(--board-width);grid-template-rows:var(--column-band) var(--board-height);gap:6px;align-items:start;justify-items:start}.board-corner{display:flex;align-items:center;justify-content:center;border:2px solid var(--border-color);border-radius:12px;background:var(--card-bg)}.board-corner strong{font-size:1.2rem;color:var(--text-primary);font-weight:800;opacity:.8}.column-clues{display:grid;grid-template-columns:repeat(var(--cols),var(--cell-size));align-items:stretch;justify-items:center;width:100%;height:var(--column-band);border:2px solid var(--border-color);border-radius:12px;background:var(--card-bg);padding:0;overflow:hidden;box-sizing:border-box}.row-clues{display:grid;grid-template-rows:repeat(var(--rows),var(--cell-size));align-items:stretch;justify-items:center;width:var(--row-band);height:100%;border:2px solid var(--border-color);border-radius:12px;background:var(--card-bg);padding:0;overflow:hidden;box-sizing:border-box}.clue-cell{display:flex;gap:2px;font-size:clamp(.7rem,2vw,.85rem);font-weight:700;color:var(--text-primary);background:#e6dcc3;border-radius:6px;box-sizing:border-box;transition:all .2s ease}.clue-cell.column{flex-direction:column;align-items:center;justify-content:flex-end;width:var(--cell-size);height:100%;padding:4px 2px}.clue-cell.row{flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:var(--cell-size);padding:2px 6px}.clue-cell span{display:flex;align-items:center;justify-content:center;flex:0 0 auto;min-width:12px;min-height:12px}.clue-cell.clickable{cursor:pointer}.clue-cell.clickable:hover{background:#d8cab2}.clue-cell.highlight{background:#ffe066!important;box-shadow:0 0 8px #ffc80099}.clue-cell.completed{background:#c8e6c9!important;color:#388e3c}.clue-cell.completed span{text-decoration:line-through;opacity:.7}.clue-cell.focused{background:#ffe066!important;color:var(--text-primary);box-shadow:0 0 0 2px #fc0,0 2px 8px #ffc80066}.clue-cell.dimmed{filter:brightness(.6)}.board-stage{width:var(--board-width);height:var(--board-height);background:var(--cell-empty);border:2px solid var(--border-color);border-radius:4px;overflow:hidden;box-sizing:border-box}.pixi-board-shell{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center;overflow:hidden}.pixi-loading{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:12px;background:#fff8e7db;color:var(--text-secondary);font-weight:700;z-index:2;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);transition:opacity .2s ease}.pixi-loading-spinner{width:32px;height:32px;border-radius:50%;border:4px solid rgba(212,168,83,.25);border-top-color:var(--accent-color);animation:spin 1s linear infinite}.pixi-canvas{width:100%;height:100%;opacity:0;transition:opacity .18s ease}.pixi-canvas.ready{opacity:1}.nonogram-board{position:relative;-webkit-user-select:none;user-select:none;touch-action:none}.cells-grid{display:grid;grid-template-columns:repeat(var(--cols),var(--cell-size));grid-template-rows:repeat(var(--rows),var(--cell-size));width:100%;height:100%;border-collapse:collapse}.cell{position:relative;background:var(--cell-empty);cursor:pointer;display:flex;align-items:center;justify-content:center;border-right:1px solid #e8d4a8;border-bottom:1px solid #e8d4a8;box-sizing:border-box}.cell.thick-right{border-right-color:#c9a547;border-right-width:2px}.cell.thick-bottom{border-bottom-color:#c9a547;border-bottom-width:2px}.cell:hover{background:var(--cell-hover)}.cell.filled{background:transparent}.cell-fill{width:100%;height:100%;background:var(--cell-fill);border-radius:2px;animation:cellFill .12s ease}@keyframes cellFill{0%{transform:scale(.7);opacity:.5}60%{transform:scale(1.05)}to{transform:scale(1);opacity:1}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cell.marked{background:var(--cell-empty)}.cell-mark-svg{color:#a89070;animation:cellMark .12s ease}.cell.locked-error{background:#ffe0e0!important}.cell.locked-error .cell-mark-svg{color:#d46a6a}@keyframes cellMark{0%{transform:scale(.5);opacity:0}to{transform:scale(1);opacity:1}}.cell.error{animation:cellError .5s ease}@keyframes cellError{0%,to{background:var(--cell-empty)}15%,45%,75%{background:#fcc;transform:translate(-2px)}30%,60%,90%{background:#fcc;transform:translate(2px)}}.cell.highlighted{background:#ffe066!important;box-shadow:inset 0 0 0 2px #fc0;animation:cellHighlight .6s ease infinite alternate}@keyframes cellHighlight{0%{background:#ffe066}to{background:#fff3b0}}.cell.completed{background:#e8f5e9}.cell.completed.filled{background:transparent}.cell.completed .cell-fill{background:#4a7c59}.cell.dimmed{filter:brightness(.5);pointer-events:none}.cell.dimmed:after{content:"";position:absolute;inset:0;background:#3c32284d;pointer-events:none}.grid-lines:before{content:"";position:absolute;inset:0;border:2px solid var(--border-color);border-radius:0 0 16px;pointer-events:none}.tool-dock{background:var(--card-bg);border-radius:20px;padding:16px 20px;border:2px solid var(--border-color);box-shadow:0 4px 16px #8b73551a}.tool-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.tool-title{font-size:1rem;font-weight:600;color:var(--text-primary)}.tool-tip{margin:0;font-size:.8rem;color:var(--text-muted)}.tool-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.tool-card{padding:12px 16px;border-radius:14px;background:#fffdf7;border:2px solid var(--border-color);display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s ease;position:relative}.tool-card:hover:not(.disabled){border-color:var(--accent-color);background:#fff8e7;transform:translateY(-2px);box-shadow:0 6px 20px #8b735526}.tool-card.active{border-color:#f5d76e;background:linear-gradient(135deg,#fff9e6,#fef3d0);box-shadow:0 0 0 3px #f5d76e66}.tool-card.disabled{opacity:.5;cursor:not-allowed}.tool-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:#fef6e4}.tool-info{display:flex;flex-direction:column;gap:4px;min-width:0}.tool-title-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.tool-title-row h3{margin:0;font-size:1rem;color:var(--text-primary);white-space:nowrap}.tool-count{display:inline-flex;align-items:center;justify-content:center;padding:2px 8px;border-radius:999px;background:#fff0c2;border:1px solid #f5d76e;color:var(--text-primary);font-weight:700;font-size:.85rem}.tool-caption{margin:0;color:var(--text-muted);font-size:.85rem;line-height:1.3}.tool-status{font-size:.8rem;color:var(--text-secondary);padding:4px 10px;border-radius:10px;background:#fef6e4;width:fit-content}.tool-status.on{background:#ffeaa7;color:var(--text-primary);font-weight:700}.tool-status.muted{opacity:.6}@media(max-width:768px){.app-shell{padding:12px 8px}.board-corner strong{font-size:.9rem}.clue-cell{font-size:.6rem;gap:1px;border-radius:4px}.clue-cell.row{padding:1px 4px}.clue-cell.column{padding:4px 1px}.column-clues,.row-clues{padding:2px}.tool-hint-bar{font-size:.8rem;padding:8px 12px}.demo-control-bar{padding:8px 12px}.demo-reason{min-width:unset;width:100%;font-size:.8rem}.tool-grid{display:flex;justify-content:space-between;gap:8px}.tool-card{flex:1;padding:8px;flex-direction:column;justify-content:center;text-align:center;gap:4px;min-width:0}.tool-icon{width:32px;height:32px;margin-bottom:2px}.tool-icon svg{width:20px;height:20px}.tool-info{display:flex;flex-direction:column;align-items:center;gap:2px}.tool-title{font-size:.8rem}.tool-tip,.tool-caption{display:none}.tool-title-row h3{font-size:.9rem}.tool-count{font-size:.75rem}.tool-status{font-size:.7rem}.chrome-back{width:42px;height:42px;padding:0;border-radius:50%;justify-content:center}.chrome-back span{display:none}}
