.cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;border:1px solid #ccc;cursor:pointer;transition:all .2s ease;font-size:clamp(1rem,4vw,1.5rem);font-weight:600;-webkit-user-select:none;user-select:none;background-color:#fff}.cell-value{animation:popIn .2s ease}.cell-notes{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);width:100%;height:100%;font-size:clamp(.5rem,1.6vw,.75rem);font-weight:500;line-height:1;color:#6b7280;pointer-events:none}.cell-note{display:flex;align-items:center;justify-content:center}.cell-note-on{color:#4b5563}@keyframes popIn{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.cell-initial{background-color:#f0f0f0;color:#1a1a1a;font-weight:700}.cell-editable{background-color:#fff;color:#2563eb}.cell-selected{background-color:#dbeafe;border:2px solid #2563eb;transform:scale(1.05);z-index:10;box-shadow:0 4px 8px #2563eb4d}.cell-conflict{background-color:#fee2e2;color:#dc2626}.cell-hinted{background-color:#ede9fe;color:#6d28d9;font-style:italic}.cell-hinted.cell-selected{background-color:#ddd6fe}.cell-same-number{background-color:#fefce8!important}.cell-selected-box,.cell-selected-row,.cell-selected-column{background-color:#e6f7e6!important}.cell:hover:not(.cell-selected){background-color:#f3f4f6;transform:scale(1.02)}.cell-box-newly-completed{animation:boxComplete .3s ease}.cell-row-newly-completed{animation:rowComplete .3s ease}.cell-column-newly-completed{animation:columnComplete .3s ease}@keyframes boxComplete{0%{transform:scale(1)}50%{background-color:#c8e6ff;transform:scale(1.1);box-shadow:0 0 20px #90c8ee4d}to{transform:scale(1)}}@keyframes rowComplete{0%{transform:scaleX(1)}50%{background-color:#c8e6ff;transform:scaleX(1.05);box-shadow:0 0 20px #90c8ee4d}to{transform:scaleX(1)}}@keyframes columnComplete{0%{transform:scaleY(1)}50%{background-color:#c8e6ff;transform:scaleY(1.05);box-shadow:0 0 20px #90c8ee4d}to{transform:scaleY(1)}}@media(max-width:768px){.cell{font-size:clamp(.875rem,5vw,1.25rem);min-height:35px}}@media(prefers-reduced-motion:reduce){.cell,.cell:hover:not(.cell-selected),.cell-selected,.cell-value,.cell-box-newly-completed,.cell-row-newly-completed,.cell-column-newly-completed{animation:none!important;transition:none!important;transform:none!important}.cell-selected{box-shadow:0 0 0 2px #2563eb inset}}.sudoku-grid-wrapper{position:relative;max-width:600px;width:100%;margin:0 auto}.sudoku-grid{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);gap:0;border:3px solid #1a1a1a;background-color:#1a1a1a;width:100%;box-shadow:0 8px 16px #0000001a}.grid-pause-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#ffffff1a;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);pointer-events:auto;z-index:10;border-radius:0;overflow:hidden}.grid-pause-overlay:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 400px 300px at 30% 50%,rgba(255,255,255,.25) 0%,rgba(255,255,255,.15) 30%,rgba(255,255,255,.05) 60%,transparent 100%);animation:wave-animation-1 4s ease-in-out infinite;transform-origin:center center}.grid-pause-overlay:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse 350px 400px at 70% 50%,rgba(255,255,255,.2) 0%,rgba(255,255,255,.12) 25%,rgba(255,255,255,.05) 55%,transparent 100%);animation:wave-animation-2 5s ease-in-out infinite;transform-origin:center center;animation-delay:.5s}@keyframes wave-animation-1{0%{transform:translate(0) scale(1) rotate(0);opacity:.6}33%{transform:translate(15%,-20%) scale(1.2) rotate(8deg);opacity:.9}66%{transform:translate(-12%,15%) scale(.9) rotate(-6deg);opacity:.7}to{transform:translate(0) scale(1) rotate(0);opacity:.6}}@keyframes wave-animation-2{0%{transform:translate(0) scale(1) rotate(0);opacity:.5}33%{transform:translate(-18%,12%) scale(1.15) rotate(-7deg);opacity:.8}66%{transform:translate(14%,-18%) scale(.85) rotate(9deg);opacity:.65}to{transform:translate(0) scale(1) rotate(0);opacity:.5}}.grid-paused,.grid-paused .sudoku-grid{pointer-events:none}.grid-generating-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:11;display:flex;align-items:center;justify-content:center;background:#ffffff8c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);pointer-events:auto;border-radius:0}.grid-generating-label{font-weight:600;font-size:1.1rem;letter-spacing:.04em;color:#1a1a1a;background:#ffffffd9;padding:.5rem 1rem;border-radius:.5rem;box-shadow:0 4px 12px #00000026}.sudoku-grid .cell:nth-child(3n){border-right:2px solid #1a1a1a}.sudoku-grid .cell:nth-child(n+19):nth-child(-n+27),.sudoku-grid .cell:nth-child(n+46):nth-child(-n+54){border-bottom:2px solid #1a1a1a}@media(max-width:768px){.sudoku-grid-wrapper{max-width:100%}.sudoku-grid{border-width:2px}.sudoku-grid .cell:nth-child(3n){border-right-width:2px}.sudoku-grid .cell:nth-child(n+19):nth-child(-n+27),.sudoku-grid .cell:nth-child(n+46):nth-child(-n+54){border-bottom-width:2px}}@media(max-width:480px){.sudoku-grid{border-width:2px}}@media(prefers-reduced-motion:reduce){.grid-pause-overlay:before,.grid-pause-overlay:after{animation:none;transform:none;opacity:.6}}.number-pad{display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1rem;max-width:600px;width:100%}.number-pad-grid{display:grid;grid-template-columns:repeat(9,1fr);gap:.5rem;width:100%}.number-button{aspect-ratio:1;border:2px solid #2563eb;background-color:#fff;color:#2563eb;font-size:clamp(1rem,2.5vw,1.5rem);font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a;-webkit-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center;position:relative}.number-button:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 12px #2563eb66;background-color:#dbeafe}.number-button:active{transform:translateY(0) scale(.98);box-shadow:0 2px 4px #0003}.number-button-obvious{background-color:#fef3c7!important;border-color:#f59e0b!important;box-shadow:0 4px 12px #f59e0b66!important}.number-button-obvious:hover{background-color:#fde68a!important;box-shadow:0 6px 16px #f59e0b80!important}.number-button-value{font-size:clamp(1rem,2.5vw,1.5rem);font-weight:600;line-height:1}.number-button-count{position:absolute;top:.25rem;right:.25rem;font-size:clamp(.625rem,1.5vw,.75rem);font-weight:500;opacity:.4;line-height:1}.number-button-disabled{background-color:#f3f4f6!important;color:#9ca3af!important;border-color:#d1d5db!important;cursor:not-allowed!important;opacity:.5}.number-button-disabled:hover{transform:none!important;box-shadow:0 4px 6px #0000001a!important;background-color:#f3f4f6!important}.number-button-disabled.number-button-obvious{background-color:#f3f4f6!important;border-color:#d1d5db!important;box-shadow:0 4px 6px #0000001a!important}@media(max-width:768px){.number-pad{margin-top:1.5rem;gap:.75rem}.number-pad-grid{gap:.375rem}.number-button{border-radius:6px}}@media(max-width:480px){.number-pad-grid{gap:.25rem}.number-button{border-radius:4px}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:16px;padding:2rem;max-width:400px;width:90%;box-shadow:0 20px 60px #0000004d;position:relative;animation:slideUp .3s ease;text-align:center}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-close{position:absolute;top:1rem;right:1rem;background:none;border:none;font-size:2rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.modal-close:hover{background-color:#f3f4f6;color:#1f2937}.modal-title{font-size:clamp(1.5rem,4vw,2rem);font-weight:700;margin-bottom:1rem;margin-top:.5rem}.modal-message{font-size:1.125rem;color:#4b5563;margin-bottom:1.5rem;line-height:1.6}.modal-button{padding:.75rem 2rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a;width:100%}.modal-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #6366f166}.modal-button:active{transform:translateY(0)}.modal-actions{display:flex;flex-direction:column;gap:.5rem}.modal-button-secondary{background:#f3f4f6;color:#1f2937;box-shadow:none}.modal-button-secondary:hover{background:#e5e7eb;box-shadow:0 4px 6px #00000014}.modal-success .modal-title{color:#10b981}.modal-failure .modal-title{color:#ef4444}@media(max-width:768px){.modal-content{padding:1.5rem;max-width:90%}.modal-close{top:.75rem;right:.75rem;font-size:1.75rem}.modal-title{font-size:1.5rem}.modal-message{font-size:1rem}}@media(prefers-reduced-motion:reduce){.modal-overlay,.modal-content,.modal-button,.modal-button:hover,.modal-button:active{animation:none!important;transition:none!important;transform:none!important}}.settings-sheet{text-align:left;max-width:480px}.settings-sheet .modal-title{text-align:center}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.875rem 0;border-top:1px solid #e5e7eb}.settings-row:first-of-type{border-top:none}.settings-row-text{display:flex;flex-direction:column;gap:.125rem;flex:1 1 auto}.settings-row-label{font-size:1rem;font-weight:600;color:#1f2937}.settings-row-description{font-size:.8125rem;color:#4b5563;line-height:1.4}.settings-toggle{flex:0 0 auto;-moz-appearance:none;appearance:none;-webkit-appearance:none;width:2.75rem;height:1.625rem;background:#d1d5db;border-radius:999px;position:relative;cursor:pointer;transition:background-color .2s ease;border:none;outline:none}.settings-toggle:after{content:"";position:absolute;top:2px;left:2px;width:1.375rem;height:1.375rem;background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;transition:transform .2s ease}.settings-toggle:checked{background:#6366f1}.settings-toggle:checked:after{transform:translate(1.125rem)}.settings-toggle:focus-visible{box-shadow:0 0 0 3px #6366f159}.settings-segmented{display:inline-flex;flex-shrink:0;border-radius:8px;overflow:hidden;border:1px solid #d1d5db}.settings-segmented-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;background:#fff;color:#374151;font-size:.8125rem;font-weight:600;padding:.4375rem .75rem;cursor:pointer;transition:background-color .15s ease,color .15s ease;border-right:1px solid #d1d5db}.settings-segmented-button:last-child{border-right:none}.settings-segmented-button:hover:not(.settings-segmented-button-active){background:#f3f4f6}.settings-segmented-button-active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}@media(max-width:480px){.settings-row{flex-direction:column;align-items:stretch;gap:.5rem}.settings-segmented{align-self:flex-end}}@media(prefers-reduced-motion:reduce){.settings-toggle,.settings-toggle:after,.settings-segmented-button{transition:none!important}}.stats-sheet{text-align:left;max-width:480px}.stats-sheet .modal-title{text-align:center}.stats-totals{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:.75rem;margin:.5rem 0 1.25rem}.stats-block{display:flex;flex-direction:column;align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:.5rem;padding:.75rem .5rem}.stats-block-value{font-size:1.5rem;font-weight:700;color:#1f2937}.stats-block-label{font-size:.75rem;color:#4b5563;margin-top:.25rem;text-transform:uppercase;letter-spacing:.04em}.stats-section-title{margin:0 0 .5rem;font-size:1rem;font-weight:700;color:#1f2937}.stats-best-times{list-style:none;padding:0;margin:0 0 1.25rem}.stats-best-time-row{display:flex;justify-content:space-between;padding:.5rem 0;border-top:1px solid #e5e7eb}.stats-best-time-row:first-child{border-top:none}.stats-best-time-label{color:#374151}.stats-best-time-value{font-variant-numeric:tabular-nums;font-weight:600;color:#1f2937}.stats-actions{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap;justify-content:flex-end;border-top:1px solid #e5e7eb;padding-top:1rem}.stats-confirm-text{flex:1 1 100%;font-size:.875rem;color:#4b5563}.stats-reset-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #d1d5db;background:#fff;color:#374151;font-weight:600;font-size:.875rem;padding:.5rem .875rem;border-radius:.375rem;cursor:pointer;transition:background-color .15s ease}.stats-reset-button:hover:not(:disabled){background:#f3f4f6}.stats-reset-button:disabled{opacity:.5;cursor:not-allowed}.stats-reset-confirm{background:#dc2626;color:#fff;border-color:#dc2626}.stats-reset-confirm:hover{background:#b91c1c}@media(prefers-reduced-motion:reduce){.stats-reset-button{transition:none!important}}.onboarding-sheet{text-align:left;max-width:520px}.onboarding-sheet .modal-title{text-align:center;margin-top:.25rem}.onboarding-card{min-height:14rem}.onboarding-body{color:#374151;line-height:1.55;margin:0 0 .75rem}.onboarding-bullets{margin:0 0 1rem;padding-left:1.25rem;color:#1f2937;line-height:1.6}.onboarding-bullets li{margin-bottom:.25rem}.onboarding-dots{display:flex;justify-content:center;gap:.5rem;margin:.5rem 0 1rem}.onboarding-dot{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:none;width:.625rem;height:.625rem;border-radius:999px;background:#d1d5db;cursor:pointer;padding:0;transition:background-color .2s ease,transform .2s ease}.onboarding-dot:hover{background:#9ca3af}.onboarding-dot-active{background:#6366f1;transform:scale(1.2)}.onboarding-actions{display:flex;align-items:center;justify-content:space-between;gap:.5rem;border-top:1px solid #e5e7eb;padding-top:.875rem}.onboarding-actions-right{display:flex;gap:.5rem}.onboarding-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid transparent;font-weight:600;font-size:.875rem;padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;transition:background-color .15s ease}.onboarding-button-primary{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff}.onboarding-button-primary:hover{filter:brightness(1.05)}.onboarding-button-secondary{background:#fff;color:#374151;border-color:#d1d5db}.onboarding-button-secondary:hover{background:#f3f4f6}@media(prefers-reduced-motion:reduce){.onboarding-dot,.onboarding-button{transition:none!important}.onboarding-dot-active{transform:none}}.replay-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:2000;animation:replayFadeIn .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}@keyframes replayFadeIn{0%{opacity:0}to{opacity:1}}.replay-container{background:#fff;border-radius:16px;padding:1.5rem;max-width:480px;width:95%;box-shadow:0 20px 60px #0006;display:flex;flex-direction:column;gap:1rem;animation:replaySlideUp .3s ease}@keyframes replaySlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.replay-header{display:flex;align-items:center;justify-content:space-between}.replay-title{font-size:1.5rem;font-weight:700;color:#1f2937;margin:0}.replay-close{background:none;border:none;font-size:2rem;line-height:1;color:#6b7280;cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.replay-close:hover{background-color:#f3f4f6;color:#1f2937}.replay-grid-wrapper{display:flex;justify-content:center}.replay-grid-wrapper .sudoku-grid{display:grid;grid-template-columns:repeat(9,1fr);grid-template-rows:repeat(9,1fr);width:min(100%,400px);aspect-ratio:1;border:3px solid #1f2937;gap:0}.replay-grid-wrapper .cell{cursor:default}.replay-grid-wrapper .cell:hover:not(.cell-selected){transform:none;background-color:inherit}.replay-info{text-align:center}.replay-action-description{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.replay-meta{font-size:.875rem;color:#6b7280;margin:0}.replay-controls{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;justify-content:center}.replay-control-button{width:44px;height:44px;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s ease;color:#1f2937}.replay-control-button:hover:not(:disabled){background-color:#f3f4f6;border-color:#9ca3af}.replay-control-button:disabled{opacity:.4;cursor:not-allowed}.replay-play-button{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:#6366f1}.replay-play-button:hover:not(:disabled){background:linear-gradient(135deg,#4f46e5,#7c3aed);border-color:#4f46e5}.replay-scrubber{flex:1;min-width:120px;height:44px;cursor:pointer;accent-color:#6366f1}.replay-speed-button{height:44px;padding:0 .75rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;font-size:.875rem;font-weight:600;cursor:pointer;color:#1f2937;transition:all .15s ease}.replay-speed-button:hover{background-color:#f3f4f6;border-color:#9ca3af}@media(max-width:768px){.replay-container{padding:1rem}.replay-title{font-size:1.25rem}.replay-control-button{width:40px;height:40px;font-size:.875rem}.replay-speed-button{height:40px;font-size:.75rem}}@media(prefers-reduced-motion:reduce){.replay-overlay,.replay-container,.replay-control-button,.replay-close{animation:none!important;transition:none!important}}.site-footer{text-align:center;padding:2rem 1rem;margin-top:2rem;border-top:1px solid rgba(0,0,0,.1);color:#6b7280;font-size:.875rem}.footer-links{display:flex;justify-content:center;gap:1.5rem;margin-bottom:.75rem;flex-wrap:wrap}.footer-links a{color:#6366f1;text-decoration:none;font-weight:500;transition:color .2s ease}.footer-links a:hover{color:#4f46e5;text-decoration:underline}.footer-copy{margin:0}@media(prefers-reduced-motion:reduce){.footer-links a{transition:none}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#e0e7ff,#f3e8ff);min-height:100vh;padding:1rem}.app{max-width:1200px;margin:0 auto;padding:1rem}.app-header{text-align:center;margin-bottom:2rem;color:#1f2937}.app-header h1{font-size:clamp(2rem,5vw,3rem);font-weight:700;margin-bottom:1rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.header-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.new-game-button{padding:.75rem 2rem;background:#fffc;border:2px solid #6366f1;color:#6366f1;font-size:1rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.new-game-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #6366f14d}.new-game-button:active{transform:translateY(0)}.timer-mistakes-container{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;width:100%;max-width:600px}.mistakes-display,.timer-box{padding-top:0}.mistakes-display>span:first-child,.timer-box>span:first-child{margin-bottom:.25rem;height:1.125rem;display:flex;align-items:center}.timer-container{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;gap:.25rem}.timer-box{color:#1f2937;font-size:1.25rem;font-weight:700;font-family:Courier New,monospace;padding:.75rem 0 0 1.5rem;min-width:140px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.25rem}.timer-display-row>span{font-size:1rem}.timer-box>span:first-child{font-size:.875rem;font-weight:600;opacity:.8}.timer-display-row{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.25rem}.timer-pause-button{aspect-ratio:1;width:2rem;height:2rem;padding:0;background:#fffc;border:2px solid #6366f1;color:#6366f1;font-size:.875rem;font-weight:600;border-radius:0;cursor:pointer;transition:background-color .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);display:flex;align-items:center;justify-content:center;overflow:visible;position:relative}.timer-icon{display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease;transform-origin:center center;line-height:1;width:100%;height:100%}.timer-pause-button:hover .timer-icon{transform:scale(2)}.timer-pause-button:active .timer-icon{transform:scale(1.9)}.mistakes-display{color:#1f2937;font-size:1.25rem;font-weight:700;font-family:Courier New,monospace;padding:.75rem 1.5rem 0;min-width:60px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:.25rem}.mistakes-display>span:first-child{font-size:.875rem;font-weight:600;opacity:.8}.mistakes-display>span:last-child{font-size:1rem}.timer-pause-button:hover{background:#fff}.timer-pause-button:active{background:#ffffffe6}.difficulty-selector{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:2rem;flex-wrap:wrap}.difficulty-button{padding:.625rem 1.25rem;background:#fffc;border:2px solid #6366f1;color:#6366f1;font-size:.9375rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);white-space:nowrap}.difficulty-button:hover{background:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #6366f14d}.difficulty-button:active{transform:translateY(0)}.difficulty-button-active{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important;border-color:#6366f1!important;box-shadow:0 4px 12px #6366f166!important}.difficulty-button-active:hover{background:linear-gradient(135deg,#5b5bf0,#7c3aed)!important;box-shadow:0 6px 16px #6366f180!important}.action-bar{display:flex;justify-content:center;align-items:center;gap:.75rem;margin-top:1rem;width:100%;max-width:600px}.action-button{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:#ffffffd9;border:2px solid #6366f1;color:#6366f1;font-size:.9375rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative}.action-button:hover:not(:disabled){background:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #6366f14d}.action-button:active:not(:disabled){transform:translateY(0)}.action-button:disabled{opacity:.45;cursor:not-allowed}.action-button-active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:#6366f1;box-shadow:0 4px 12px #6366f166}.action-button-active:hover:not(:disabled){background:linear-gradient(135deg,#5b5bf0,#7c3aed)}.action-icon{font-size:1.125rem;font-weight:700}.action-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.25rem;height:1.25rem;padding:0 .375rem;border-radius:999px;background:#6366f1;color:#fff;font-size:.75rem;font-weight:700}.win-message{text-align:center;background:#fffffff2;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 8px 16px #0003;animation:slideDown .5s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.win-message h2{color:#10b981;font-size:clamp(1.5rem,4vw,2rem);margin-bottom:.5rem}.win-message p{color:#1f2937;font-size:1.125rem}.main-content{display:flex;gap:2rem;align-items:flex-start}.game-container{display:flex;flex-direction:column;align-items:center;gap:0;flex:1}.debug-section{background:#fffffff2;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a;min-width:250px}.debug-section h3{color:#1f2937;font-size:1.25rem;font-weight:600;margin-bottom:1rem;margin-top:0}.debug-controls{display:flex;flex-direction:column;gap:1rem}.debug-controls label{display:flex;flex-direction:column;gap:.5rem;color:#1f2937;font-size:.875rem;font-weight:500}.debug-input{padding:.5rem;border:2px solid #e5e7eb;border-radius:6px;font-size:1rem;transition:border-color .2s ease}.debug-input:focus{outline:none;border-color:#6366f1}.debug-button{padding:.75rem 1.5rem;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;color:#fff;font-size:.9375rem;font-weight:600;border-radius:8px;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0000001a}.debug-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #6366f166}.debug-button:active{transform:translateY(0)}@media(max-width:768px){body,.app{padding:.5rem}.app-header{margin-bottom:1.5rem}.win-message{padding:1rem;margin-bottom:1.5rem}.main-content{flex-direction:column;gap:1rem}.debug-section{min-width:auto;width:100%}.game-container{gap:.75rem}}@media(prefers-reduced-motion:reduce){.new-game-button,.new-game-button:hover,.new-game-button:active,.difficulty-button,.difficulty-button:hover,.difficulty-button:active,.timer-pause-button,.timer-pause-button:hover .timer-icon,.timer-pause-button:active .timer-icon,.timer-icon,.win-message,.debug-button,.debug-button:hover,.debug-button:active,.action-button,.action-button:hover:not(:disabled),.action-button:active:not(:disabled){animation:none!important;transition:none!important;transform:none!important}}html[data-theme=dark] body{background:linear-gradient(135deg,#0f172a,#1e1b4b);color:#e2e8f0}html[data-theme=dark] .app-header{color:#e2e8f0}html[data-theme=dark] .app-header h1{text-shadow:2px 2px 8px rgba(0,0,0,.6)}html[data-theme=dark] .new-game-button,html[data-theme=dark] .difficulty-button,html[data-theme=dark] .action-button{background:#1e1b4bb3;color:#c7d2fe;border-color:#818cf8}html[data-theme=dark] .new-game-button:hover,html[data-theme=dark] .difficulty-button:hover,html[data-theme=dark] .action-button:hover:not(:disabled){background:#312e81d9}html[data-theme=dark] .difficulty-button-active{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;color:#fff!important}html[data-theme=dark] .timer-box,html[data-theme=dark] .mistakes-display{color:#e2e8f0}html[data-theme=dark] .timer-pause-button{background:#1e1b4bb3;border-color:#818cf8;color:#c7d2fe}html[data-theme=dark] .timer-pause-button:hover{background:#312e81d9}html[data-theme=dark] .win-message,html[data-theme=dark] .debug-section{background:#1e1b4bd9;box-shadow:0 8px 16px #0006}html[data-theme=dark] .win-message p,html[data-theme=dark] .debug-section h3,html[data-theme=dark] .debug-controls label{color:#e2e8f0}html[data-theme=dark] .debug-input{background:#0f172a99;color:#e2e8f0;border-color:#475569}html[data-theme=dark] .cell{background-color:#1e293b;border-color:#334155;color:#e2e8f0}html[data-theme=dark] .cell-initial{background-color:#0f172a;color:#f1f5f9}html[data-theme=dark] .cell-editable{background-color:#1e293b;color:#93c5fd}html[data-theme=dark] .cell-selected{background-color:#1e3a8a;border-color:#93c5fd}html[data-theme=dark] .cell-conflict{background-color:#7f1d1d;color:#fecaca}html[data-theme=dark] .cell-hinted{background-color:#4c1d95;color:#ddd6fe}html[data-theme=dark] .cell-hinted.cell-selected{background-color:#5b21b6}html[data-theme=dark] .cell-same-number{background-color:#3f3f1f!important}html[data-theme=dark] .cell-selected-box,html[data-theme=dark] .cell-selected-row,html[data-theme=dark] .cell-selected-column{background-color:#064e3b!important}html[data-theme=dark] .cell:hover:not(.cell-selected){background-color:#334155}html[data-theme=dark] .cell-notes{color:#94a3b8}html[data-theme=dark] .cell-note-on{color:#cbd5e1}html[data-theme=dark] .grid-generating-overlay{background:#0f172a8c}html[data-theme=dark] .grid-generating-label{background:#1e1b4be6;color:#e0e7ff;box-shadow:0 4px 12px #0000008c}html[data-theme=dark] .modal-overlay{background:#000000a6}html[data-theme=dark] .modal-content{background:#1e293b;color:#e2e8f0}html[data-theme=dark] .modal-button-secondary{background:#1e1b4bb3;color:#c7d2fe;border-color:#818cf8}html[data-theme=dark] .modal-button-secondary:hover{background:#312e81d9}html[data-theme=dark] .modal-message,html[data-theme=dark] .modal-close{color:#cbd5e1}html[data-theme=dark] .modal-close:hover{background-color:#334155;color:#f1f5f9}html[data-theme=dark] .settings-row{border-color:#334155}html[data-theme=dark] .settings-segmented-button{background:#1e1b4b99;color:#cbd5e1;border-color:#475569}html[data-theme=dark] .settings-segmented-button-active{background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border-color:#818cf8}html[data-theme=dark] .stats-block{background:#0f172a99;border-color:#334155}html[data-theme=dark] .stats-block-value,html[data-theme=dark] .stats-section-title,html[data-theme=dark] .stats-best-time-value{color:#f1f5f9}html[data-theme=dark] .stats-block-label,html[data-theme=dark] .stats-best-time-label,html[data-theme=dark] .stats-confirm-text{color:#cbd5e1}html[data-theme=dark] .stats-best-time-row,html[data-theme=dark] .stats-actions{border-color:#334155}html[data-theme=dark] .stats-reset-button{background:#1e1b4bb3;color:#c7d2fe;border-color:#818cf8}html[data-theme=dark] .stats-reset-button:hover:not(:disabled){background:#312e81d9}html[data-theme=dark] .stats-reset-confirm{background:#b91c1c;border-color:#b91c1c;color:#fff}html[data-theme=dark] .stats-reset-confirm:hover{background:#991b1b}html[data-theme=dark] .onboarding-body{color:#cbd5e1}html[data-theme=dark] .onboarding-bullets{color:#e2e8f0}html[data-theme=dark] .onboarding-actions{border-color:#334155}html[data-theme=dark] .onboarding-dot{background:#475569}html[data-theme=dark] .onboarding-dot:hover{background:#64748b}html[data-theme=dark] .onboarding-dot-active{background:#818cf8}html[data-theme=dark] .onboarding-button-secondary{background:#1e1b4bb3;color:#c7d2fe;border-color:#818cf8}html[data-theme=dark] .onboarding-button-secondary:hover{background:#312e81d9}.static-page{max-width:720px;margin:0 auto;padding:2rem 1rem;line-height:1.7;color:#1f2937}.static-page h1{font-size:clamp(1.75rem,4vw,2.5rem);font-weight:700;margin-bottom:1rem;color:#111827}.static-page h2{font-size:1.35rem;font-weight:600;margin-top:2rem;margin-bottom:.5rem;color:#1f2937}.static-page h3{font-size:1.1rem;font-weight:600;margin-top:1.5rem;margin-bottom:.25rem;color:#374151}.static-page p{margin:.5rem 0}.static-page ul,.static-page ol{margin:.5rem 0;padding-left:1.5rem}.static-page li{margin:.25rem 0}.static-page table{width:100%;border-collapse:collapse;margin:1rem 0;font-size:.95rem}.static-page th,.static-page td{padding:.5rem .75rem;border:1px solid #d1d5db;text-align:left}.static-page th{background:#f3f4f6;font-weight:600}.static-page code{background:#f3f4f6;padding:.15rem .4rem;border-radius:4px;font-size:.9em}.static-page kbd{background:#f3f4f6;border:1px solid #d1d5db;border-radius:4px;padding:.1rem .4rem;font-size:.85em;font-family:inherit}.static-page a{color:#6366f1;text-decoration:none}.static-page a:hover{text-decoration:underline}.printable-grid{border-collapse:collapse;margin:1.5rem 0}.printable-grid td{width:40px;height:40px;border:1px solid #6b7280;text-align:center;vertical-align:middle;font-size:1.25rem;font-weight:600;font-family:Courier New,monospace}.printable-grid td.box-border-right{border-right:3px solid #1f2937}.printable-grid td.box-border-bottom{border-bottom:3px solid #1f2937}.printable-grid tr:first-child td{border-top:3px solid #1f2937}.printable-grid tr:last-child td{border-bottom:3px solid #1f2937}.printable-grid td:first-child{border-left:3px solid #1f2937}.printable-grid td:last-child{border-right:3px solid #1f2937}@media print{body{background:#fff!important;padding:0!important}.app-header,.header-actions,.difficulty-selector,.timer-mistakes-container,.action-bar,.site-footer,.no-print{display:none!important}.static-page{max-width:none;padding:0}.static-page h1{font-size:1.5rem}.static-page p:not(:first-of-type){display:none}}
