body{background-color:#fcfcfc;overflow:hidden;margin:0;padding:0;width:100dvw;height:100dvh}*{box-sizing:border-box}body{background-color:#fcfcfc}.wrapper{display:flex;flex-direction:column;width:100dvw;height:100dvh;overflow:hidden}.top-wrapper{display:flex;flex-direction:column;width:100%;padding:5px;flex-shrink:0;flex-grow:0;flex-basis:auto}.top-buttons{display:flex;flex-direction:row;justify-content:flex-end;width:100%;height:100%}.middle-wrapper{display:flex;width:100%;flex-grow:1;padding:5px;min-height:0;position:relative;overflow:hidden}.bottom-wrapper{display:flex;flex-direction:column;flex-shrink:0;flex-grow:0;flex-basis:auto;padding:0 5px 5px;overflow:visible;align-items:center}.view-mode-toggle{z-index:999}.view-mode-toggle>button{background:#111;color:#fff;border:1px solid #555;border-radius:5px;padding:6px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.baseBtn{background:#111;color:#fff;border:1px solid #555;border-radius:4px;padding:6px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,transform .1s ease}.baseBtn:hover{background:#000000b3}.baseBtn:active{background:#000;transform:scale(.97)}.baseBtn:disabled{background:#666;cursor:not-allowed;transform:none}.menu-buttons{position:absolute;top:20px;left:20px;z-index:50;display:flex;flex-direction:column;gap:8px;background:#00000080;padding:12px;border-radius:10px;max-width:220px}.menu-buttons button,.menu-buttons select{background:#111;color:#fff;border:1px solid #555;border-radius:4px;padding:6px 10px;font-size:14px;cursor:pointer;width:100%;box-sizing:border-box}@media screen and (max-width: 600px){button{font-size:14px!important;padding:4px 8px!important}select{font-size:14px!important}.menu-buttons{top:10px;left:10px;max-width:100%;padding:10px;gap:6px}.menu-buttons button,.menu-buttons select{font-size:13px;padding:6px}}.column-toggles{position:absolute;top:20px;left:50%;transform:translate(-50%);display:flex;gap:6px;background:#00000080;padding:6px 10px;border-radius:8px;z-index:10}.row-toggles{position:absolute;top:50%;right:20px;transform:translateY(-50%);display:flex;flex-direction:column;gap:6px;background:#00000080;padding:6px 10px;border-radius:8px;z-index:10}.depth-toggles{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:6px;background:#00000080;padding:6px 10px;border-radius:8px;z-index:10}.column-toggles .axis-label-btn,.row-toggles .axis-label-btn,.depth-toggles .axis-label-btn{grid-column:span 3;justify-self:end;font-weight:700;background:#111;color:#fff;border:1px solid #555;border-radius:4px;padding:6px 12px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease,transform .1s ease}.column-toggles .axis-label-btn.hidden-btn,.row-toggles .axis-label-btn.hidden-btn,.depth-toggles .axis-label-btn.hidden-btn{background:#444}.column-toggles button,.row-toggles button,.depth-toggles button{font-size:12px;padding:6px 8px;min-width:40px;background:#111;color:#fff;border:1px solid #555;border-radius:4px;white-space:nowrap;cursor:pointer}@media screen and (max-width: 600px){.column-toggles,.row-toggles,.depth-toggles{position:absolute!important;right:10px!important;left:auto!important;transform:none!important;display:grid!important;grid-template-columns:repeat(3,auto);gap:4px;background:#00000080;padding:6px;border-radius:8px;z-index:10;width:max-content}.column-toggles{top:10px!important}.row-toggles{top:160px!important}.depth-toggles{top:310px!important;bottom:auto!important}.column-toggles span,.row-toggles span,.depth-toggles span{grid-column:span 3;text-align:right;font-weight:700;margin-bottom:4px;color:#fff;font-size:14px;white-space:nowrap}.column-toggles button,.row-toggles button,.depth-toggles button{font-size:12px;padding:6px;min-width:40px;height:auto;color:#fff;background:#111;border:1px solid #555;border-radius:4px;text-align:center;white-space:nowrap;box-sizing:border-box}}.board-view{background:#111;color:#fff;font-family:Arial,sans-serif;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding:5px;min-height:100%;min-width:100%;height:auto;width:100%;box-sizing:border-box;position:relative;overflow:hidden;border-radius:5px}.board-container{position:relative;min-width:338px;min-height:338px;max-width:100%;max-height:100%;margin:0 auto;resize:none;overflow:hidden;transition:width .1s linear,height .1s linear}.layer-selector{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:6px;margin-bottom:12px;padding:0 8px;width:100%;max-width:100%;box-sizing:border-box}@media (min-width: 768px){.layer-selector{flex-wrap:nowrap;justify-content:center;max-width:650px}}@media (max-width: 600px){.sudoku-cell{font-size:1.5rem!important}}.layer-controls{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;max-width:100%;box-sizing:border-box}.layer-section{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:12px;flex-wrap:wrap}.layer-row{display:flex;align-items:flex-start;justify-content:center;gap:12px;width:100%;margin-bottom:8px;flex-wrap:nowrap}@media (max-width: 600px){.layer-row{flex-wrap:wrap;flex-direction:row;justify-content:center;gap:8px}.layer-controls{flex:1;justify-content:flex-start;flex-wrap:wrap}.mini-cube-wrapper{flex-shrink:0;margin-top:0;align-self:flex-start}}.mini-cube-wrapper{width:72px;height:72px;padding:6px;border:1px solid #333;border-radius:6px;background:#1a1a1a;box-sizing:border-box;perspective:600px;overflow:hidden;display:flex;align-items:center;justify-content:center;cursor:grab}.mini-cube-transform-layer{width:100%;height:100%;transform:scale(.9) translate(0);transform-origin:center center;display:flex;align-items:center;justify-content:center}.mini-cube{transform-style:preserve-3d;transform-origin:center center;position:relative;pointer-events:auto}.mini-cube-cell{position:absolute;width:5px;height:5px;background:#888;border-radius:2px;border:1px solid #111;box-shadow:0 0 1px #0006;box-sizing:border-box;backface-visibility:hidden}@keyframes pulse-glow{0%{box-shadow:0 0 2px #00bfff,0 0 3px #00bfff}50%{box-shadow:0 0 4px #00bfff,0 0 6px #00bfff}to{box-shadow:0 0 2px #00bfff,0 0 3px #00bfff}}.mini-cube-cell.active{background:#00bfff;border:.5px solid #66e0ff;box-shadow:0 0 1px #00bfff99;animation:pulse-glow 1.2s infinite}.mini-cube-cell.filled{background:#2b2;border:1px solid #66ff66;box-shadow:0 0 2px #6f6}.styled-select{background:#222;color:#fff;font-size:14px;border-radius:5px;padding:6px 10px;border:1px solid #555;cursor:pointer}.layer-button.filled{background:#2b2;color:#000;font-weight:700;border-color:#6f6}.sudoku-grid{width:100%;height:100%;display:grid;grid-template-rows:repeat(9,1fr);gap:2px;box-sizing:border-box}.sudoku-row{display:grid;grid-template-columns:repeat(9,1fr);gap:2px}.sudoku-row:nth-child(3n){margin-bottom:6px}.resizable-board-container{min-width:338px;min-height:338px;width:100%;height:100%;max-width:100%;max-height:100%;margin-bottom:12px;display:flex;justify-content:center;align-items:center}.sudoku-grid-wrapper{width:338px;height:338px;margin:2px;box-sizing:content-box}.board-scale-wrapper{width:100%;height:100%;display:flex;justify-content:center;align-items:center;position:relative;overflow:hidden}.board-scale-inner{width:338px;height:338px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(var(--board-scale, 1));transform-origin:center center}.sudoku-cell{width:34px;height:34px;line-height:34px;text-align:center;background-color:#222;border:1px solid #333;cursor:pointer;box-sizing:border-box;transition:background .02s ease,box-shadow .02s ease;aspect-ratio:1 / 1;-webkit-user-select:none;user-select:none;display:flex;justify-content:center;align-items:center;flex-direction:column;font-size:clamp(10px,2vw,1.8rem);line-height:normal}.cell-value{z-index:1;position:relative;font-weight:700;pointer-events:none}.sudoku-cell:hover{background-color:#2a2a2a}.sudoku-cell:nth-child(3n){margin-right:6px}.sudoku-cell.fixed{background-color:#333;font-weight:700;color:#bbb}.sudoku-cell.selected{box-shadow:inset 0 0 0 2px #00bfff;background-color:#046}.sudoku-cell.wrong{background-color:#aa1e1e!important;color:#fff!important;font-weight:700!important;border:2px solid #ff4444!important}.sudoku-cell.held-digit{outline:2px solid #ffaa00;box-shadow:0 0 4px #fa0;font-weight:700;transition:all .2s ease}.sudoku-cell.held-digit-fixed{outline:2px dashed #aa8800;box-shadow:0 0 2px #a80;font-weight:700;transition:all .2s ease}.sudoku-cell.show-solution{opacity:.8;font-style:italic}.notes{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);font-size:.6rem;color:#555;width:100%;height:100%;text-align:center;line-height:1;pointer-events:none}.notes-overlay{position:absolute;top:2px;left:2px;right:2px;bottom:2px;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);font-size:clamp(.6rem,1.5vw,.8rem);color:#555;text-align:center;line-height:1;opacity:.6;pointer-events:none;z-index:2}.note-digit{display:flex;justify-content:center;align-items:center;font-size:inherit;line-height:1;padding:.5px}.note-digit.empty{opacity:0}.modal-overlay{position:fixed;top:0;left:0;z-index:1000;width:100dvw;height:100dvh;background:#141414cc;display:flex;align-items:center;justify-content:center;animation:fadeIn .5s ease forwards}.modal-content{background:#222;padding:2rem;border-radius:1rem;box-shadow:0 0 20px #ffd70080;animation:popIn .4s ease forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{transform:scale(.9);opacity:0}60%{transform:scale(1.05);opacity:1}to{transform:scale(1)}}.modal-close-button{position:absolute;top:1rem;right:1rem;background:none;border:none;color:gold;font-size:2rem;cursor:pointer;padding:0;line-height:1;z-index:10;text-shadow:0 0 5px rgba(255,215,0,.8)}.modal-close-button:hover{color:#fffacd;transform:scale(1.1)}.won-modal{text-align:center;background:#000000f2}.won-text{font-size:3rem;font-weight:700;color:gold;margin-bottom:1.5rem;text-shadow:0 0 10px #ffd700}.new-puzzle-button{background-color:gold;color:#000;border:none;padding:.8rem 1.5rem;font-size:1.2rem;font-weight:700;border-radius:.5rem;cursor:pointer;box-shadow:0 0 10px gold;transition:transform .2s ease}.new-puzzle-button:hover{transform:scale(1.05);background-color:#ffdf00}.digit-pad-wrapper{width:100%;display:flex;justify-content:center;padding:10px;box-sizing:border-box;flex-shrink:0}.digit-pad{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;width:100%;max-width:320px;padding:12px;background:#000000d9;border-radius:10px;position:relative;box-sizing:border-box}.digit-pad button:not(.floating-action){font-size:16px;font-weight:700;color:#fff;background:#111;border:1px solid #444;border-radius:6px;aspect-ratio:1 / 1;width:100%;padding:0;cursor:pointer;box-sizing:border-box;transition:background .2s ease}.digit-pad button.held:not(.zero-btn){background-color:#fa0;color:#000;font-weight:700}.digit-pad button.full{opacity:.4;pointer-events:none}.digit-pad button.zero-btn{background-color:#500;border-color:#a00;color:#fff}.digit-pad button.zero-btn.held{background-color:#a00;color:#fff;border-color:#f44;font-weight:700}.digit-pad button.zero-btn:hover{background-color:#a00}.digit-pad button.zero-btn:active{background-color:#c00}.floating-action{position:absolute;width:42px;height:42px;border-radius:50%;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid;padding:0;cursor:pointer;z-index:100;box-shadow:0 2px 6px #0003;background-color:#fff;text-align:center}.note-toggle{bottom:50px;left:-35px;background-color:#fff;border-color:#ccc;color:#444}.note-toggle.active{background-color:#ffd966;border-color:#e0b800;color:#000}.note-toggle:hover{background-color:#ffca77;border-color:#e1a911}@media (max-width: 600px){.floating-action{width:42px;height:42px;line-height:42px}.note-toggle{left:-15px;bottom:52px}}.board-menu-controls{position:absolute;top:5px;left:5px;z-index:1000;background:#000000d9;padding:1px;border-radius:8px;color:#fff;-webkit-user-select:none;user-select:none;box-shadow:0 0 5px #00000080;pointer-events:auto}.board-menu-controls summary{background:transparent;padding:1px;border-radius:4px;cursor:pointer;font-weight:700;color:#fff;margin-bottom:2px;z-index:50;border:none;outline:none;transition:background .2s ease}.board-menu-controls details{background:#222222e6;padding:5px;border-radius:6px}.board-menu-buttons{display:flex;flex-direction:column;gap:8px;margin-top:8px}.styled-select{background:#222;color:#fff;font-size:14px;border-radius:5px;padding:6px;border:1px solid #555;cursor:pointer;-webkit-user-select:none;user-select:none}.layer-button{flex:0 1 auto;min-width:30px;padding:6px 8px;border:1px solid #444;background:#222;color:#fff;border-radius:4px;cursor:pointer;text-align:center;-webkit-user-select:none;user-select:none}.layer-button.active{background:#00bfff;color:#000;font-weight:700}.layer-button:disabled{background:#444;color:#fff;cursor:default}
