*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--cell-bg: #111;--border-color: rgba(255,255,255,.1);--text-primary: rgba(255,255,255,.9);--text-secondary: rgba(255,255,255,.65)}body.light{--cell-bg: #f9f9f9;--border-color: rgba(0,0,0,.1);--text-primary: rgba(0,0,0,.9);--text-secondary: rgba(0,0,0,.65)}body{background:radial-gradient(ellipse 90% 90% at 50% 45%,#1c1c1c,#0d0d0d);color:#fff;height:100svh;display:flex;flex-direction:column;align-items:center;justify-content:center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Helvetica,sans-serif;padding:10px 8px;gap:12px;overflow:hidden;transition:background .4s ease,color .4s ease}@media(min-height:820px){body{padding:14px 8px;gap:14px}}body.light{background:radial-gradient(ellipse 90% 90% at 50% 45%,#f5f5f5,#e8e8e8);color:#1a1a1a}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:9999;opacity:.035;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");background-size:200px 200px;transition:opacity .4s ease,mix-blend-mode .4s ease}body.light:before{opacity:.025;mix-blend-mode:multiply}.app{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%}.game{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:12px;position:relative}.welcome{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;width:100%;max-width:480px;padding:24px 16px}.header{display:flex;align-items:center;justify-content:center;position:relative;width:100%;flex-shrink:0}@media(min-width:769px){.header{max-width:480px}}.btn-back{position:absolute;left:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;color:var(--text-primary);background:none;border:none;cursor:pointer;opacity:.7;padding:0;transition:opacity .2s;touch-action:manipulation}.btn-back:hover{opacity:1}.btn-back svg{width:24px;height:24px;stroke:var(--text-primary);color:var(--text-primary)}.theme-toggle{position:absolute;right:0;background:transparent;border:none;cursor:pointer;padding:6px;transition:opacity .2s;touch-action:manipulation;opacity:.65;display:flex;align-items:center;justify-content:center}.theme-toggle:hover{opacity:1}.theme-toggle svg{width:22px;height:22px;stroke:#fff9;color:#fff9;transition:stroke .4s,color .4s}body.light .theme-toggle svg{stroke:#ffb400f2;color:#ffb400f2}.title{position:relative;display:flex;align-items:center;justify-content:center;cursor:default;flex-shrink:0;animation:fade-out-title 2s ease-out forwards;min-height:60px}.title span{color:#fff;font-size:2.2rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;text-shadow:0 3px 12px rgba(0,0,0,.4),0 0 20px rgba(255,255,255,.1);transition:color .4s ease,text-shadow .4s ease}body.light .title span{color:#000;text-shadow:0 2px 8px rgba(0,0,0,.15)}.difficulty{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;width:auto;flex-shrink:0;background:#ffffff14;border:1px solid rgba(255,255,255,.15);border-radius:8px;padding:2px;position:relative}body.light .difficulty{background:#0000000f;border-color:#00000026}.difficulty:before{content:"";position:absolute;top:2px;left:2px;right:2px;width:calc(33.333% - 2px);height:calc(100% - 4px);background:#ffffff26;border-radius:6px;transition:left .5s cubic-bezier(.25,.46,.45,.94);pointer-events:none;box-shadow:0 2px 4px #0003}body.light .difficulty:before{background:#0000001f;box-shadow:none}.difficulty:has(.diff-btn:nth-child(2).active):before{left:calc(33.333% + 1px)}.difficulty:has(.diff-btn:nth-child(3).active):before{left:calc(66.666% + 1px)}.diff-btn{padding:6px 12px;background:transparent;border:none;color:#fff9;font-size:.75rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;cursor:pointer;font-family:inherit;border-radius:6px;touch-action:manipulation;transition:color .2s ease;position:relative;z-index:1}.diff-btn:hover:not(.active){color:#fffc}.diff-btn.active{color:#fffffff2}body.light .diff-btn{color:#00000080}body.light .diff-btn:hover:not(.active){color:#000000b3}body.light .diff-btn.active{color:#000000d9}.board-wrap{position:relative;flex-shrink:0;animation:fade-in .5s ease-in;margin-top:4px}.difficulty{animation:fade-in .6s ease-in .15s both}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.loading-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:#fff3;letter-spacing:.15em;z-index:10}.board{display:grid;grid-template-columns:repeat(9,1fr);width:min(calc(100vw - 24px),calc(100svh - 280px),480px);height:min(calc(100vw - 24px),calc(100svh - 280px),480px);aspect-ratio:1;border-top:2px solid rgba(255,255,255,.65);border-left:2px solid rgba(255,255,255,.45);border-right:2px solid rgba(255,255,255,.28);border-bottom:2px solid rgba(255,255,255,.12);box-shadow:0 1px #ffffff14,0 6px 24px #00000080;transition:border-color .4s ease,box-shadow .4s ease;filter:none}.board.paused{filter:blur(3px)}body.light .board{border-top:2px solid rgba(0,0,0,.65);border-left:2px solid rgba(0,0,0,.45);border-right:2px solid rgba(0,0,0,.28);border-bottom:2px solid rgba(0,0,0,.12);box-shadow:0 1px #00000014,0 6px 24px #0000001f}@media(max-width:768px){.board{width:min(calc(100vw - 24px),calc(100svh - 280px));height:min(calc(100vw - 24px),calc(100svh - 280px))}}.cell{border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:ui-rounded,system-ui,sans-serif;font-size:clamp(16px,5vw,26px);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--cell-bg, #111);color:#ffffffe6;aspect-ratio:1;transition:background .1s,box-shadow .1s,border-color .4s,color .4s}body.light .cell{border-color:#0000001a;background:var(--cell-bg, #f9f9f9);color:#000000e6}.cell.box-even{--cell-bg: #191919}body.light .cell.box-even{--cell-bg: #efefef}.cell.box-right{border-right:2px solid rgba(255,255,255,.42)}.cell.box-bottom{border-bottom:2px solid rgba(255,255,255,.42)}body.light .cell.box-right{border-right-color:#0000006b}body.light .cell.box-bottom{border-bottom-color:#0000006b}.cell.given{font-weight:600;color:#fff}body.light .cell.given{color:#000}.cell.user-entry{color:#ffffffd1;font-weight:400;text-decoration:underline;text-underline-offset:3px;text-decoration-thickness:1px;text-decoration-color:#ffffff59}body.light .cell.user-entry{color:#000000d1;text-decoration-color:#00000059}.cell.selected{--cell-bg: rgba(255,255,255,.15);box-shadow:inset 0 0 0 2px #ffffffa6}body.light .cell.selected{--cell-bg: rgba(0,0,0,.15);box-shadow:inset 0 0 0 2px #000000a6}.cell.peer{--cell-bg: rgba(255,255,255,.045)}.cell.same-num{--cell-bg: rgba(255,255,255,.085)}body.light .cell.peer{--cell-bg: rgba(0,0,0,.045)}body.light .cell.same-num{--cell-bg: rgba(0,0,0,.085)}@keyframes num-pop{0%{transform:scale(.45);opacity:0}70%{transform:scale(1.06);opacity:1}to{transform:scale(1);opacity:1}}.cell.num-entering{animation:num-pop .15s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes incorrect-color{0%{color:red}to{color:red}}@keyframes incorrect-color-light{0%{color:#c00}to{color:#c00}}.cell.incorrect{animation:incorrect-color 1s linear forwards}body.light .cell.incorrect{animation:incorrect-color-light 1s linear forwards}@keyframes solve-color{0%{color:#4ade80}to{color:#4ade80}}@keyframes solve-color-light{0%{color:#16a34a}to{color:#16a34a}}.cell.solved{animation:solve-color 1s linear forwards}body.light .cell.solved{animation:solve-color-light 1s linear forwards}.cell.hint{--cell-bg: rgba(74, 222, 128, .25);box-shadow:0 0 0 2px #4ade8066}body.light .cell.hint{--cell-bg: rgba(22, 163, 74, .15);box-shadow:0 0 0 2px #16a34a4d}.number-grid{display:grid;grid-template-columns:repeat(9,1fr);width:min(calc(100vw - 24px),calc(100svh - 280px),480px);gap:6px;flex-shrink:0;margin-top:4px}@media(max-width:768px){.number-grid{width:min(calc(100vw - 24px),calc(100svh - 280px))}}.number-grid-cell{border:1px solid rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;font-family:ui-rounded,system-ui,sans-serif;font-size:clamp(16px,5vw,26px);cursor:pointer;-webkit-user-select:none;user-select:none;background:var(--cell-bg, #111);color:#ffffffe6;aspect-ratio:1;transition:background .1s,box-shadow .1s,border-color .4s,color .4s;font-weight:700;padding:0;border-radius:6px;touch-action:manipulation;box-shadow:0 2px 8px #0000004d}.number-grid-cell:hover:not(:disabled){background:#ffffff1f;box-shadow:0 3px 12px #0006}.number-grid-cell:active:not(:disabled){background:#ffffff2e;transform:translateY(1px)}.number-grid-cell:disabled{opacity:.4;cursor:not-allowed}body.light .number-grid-cell{border-color:#0000001a;background:var(--cell-bg, #f9f9f9);color:#000000e6;box-shadow:0 2px 8px #0000001f}body.light .number-grid-cell:hover:not(:disabled){background:#0000001f;box-shadow:0 3px 12px #0000002e}body.light .number-grid-cell:active:not(:disabled){background:#0000002e;transform:translateY(1px)}.pause-modal{position:fixed;top:0;right:0;bottom:0;left:0;display:none;flex-direction:column;align-items:center;justify-content:center;gap:16px;z-index:500;background:#000000bf;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.pause-modal.visible{display:flex}.pause-modal-icon{font-size:3rem;opacity:.4}.pause-modal-text{font-size:1rem;letter-spacing:.25em;text-transform:uppercase;opacity:.45}.pause-modal-buttons{margin-top:8px}.pause-modal-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.3);color:#ffffffe0;padding:14px 36px;font-size:.85rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border-radius:8px;font-family:inherit;transition:all .15s ease}.pause-modal-btn:hover{background:#ffffff2e;border-color:#ffffff80;color:#fff}.modal{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:1000;flex-direction:column;align-items:center;justify-content:center;padding:24px;overflow-y:auto;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal.visible{display:flex}body.light .modal{background:#fffffff2}.modal-content{background:transparent;max-width:500px;width:100%;text-align:center}.modal h2{font-size:clamp(24px,6vw,36px);font-weight:200;letter-spacing:.08em;text-transform:uppercase;margin-bottom:24px;color:#fff}body.light .modal h2{color:#1a1a1a}.modal p{font-size:.9rem;line-height:1.6;margin-bottom:16px;color:#fff9}body.light .modal p{color:#0009}.modal-section{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}body.light .modal-section{border-bottom-color:#0000001a}.modal-section-title{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:#ffffff59;margin-bottom:16px}body.light .modal-section-title{color:#00000059}.modal-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.modal-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.3);color:#ffffffd9;padding:12px 28px;font-size:.8rem;letter-spacing:.15em;text-transform:uppercase;cursor:pointer;border-radius:6px;font-family:inherit;transition:all .15s ease}.modal-btn:hover{background:#ffffff26;border-color:#ffffff80;color:#fff}body.light .modal-btn{background:#0000000f;border-color:#0000004d;color:#000000bf}body.light .modal-btn:hover{background:#0000001f;border-color:#00000080;color:#000}.modal-link{color:#ffffff8c;text-decoration:none;font-size:.85rem}.modal-link:hover{color:#ffffffe6}body.light .modal-link{color:#00000080}body.light .modal-link:hover{color:#000000d9}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:16px 0}.stat-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:6px}body.light .stat-card{background:#0000000d;border-color:#0000001a}.stat-card-label{font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:#fff6}body.light .stat-card-label{color:#0006}.stat-card-value{font-size:1.2rem;font-weight:300;color:#ffffffe6}body.light .stat-card-value{color:#000000e6}.streak-display{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin:16px 0}.streak-item{width:32px;height:32px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:600;letter-spacing:0}.streak-item.win{background:#22c55e40;color:#22c55ed9}.streak-item.loss{background:#ef444440;color:#ef4444d9}.streak-item.more{background:#ffffff0f;color:#ffffff4d}.dashboard-section{margin-bottom:24px;text-align:left}.stats-table{width:100%;border-collapse:collapse;font-size:.82rem}.stats-table th{padding:6px 8px;text-align:left;font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:#ffffff59;border-bottom:1px solid rgba(255,255,255,.1)}body.light .stats-table th{color:#00000059;border-bottom-color:#0000001a}.stats-table td{padding:8px;color:#ffffffb3;border-bottom:1px solid rgba(255,255,255,.06)}body.light .stats-table td{color:#000000b3;border-bottom-color:#0000000f}.stats-table tr.win td{color:#22c55eb3}.stats-table tr.loss td{color:#ef4444b3}.print-area{display:none}@media print{body>*:not(.print-area){display:none!important}.print-area{display:block!important}}.print-page{width:210mm;min-height:297mm;padding:20mm;display:flex;flex-direction:column;align-items:center;justify-content:center;page-break-after:always;background:#fff}.print-page.landscape{width:297mm;min-height:210mm}.print-page.two-up{flex-direction:row;gap:20mm}.print-page.four-up{flex-direction:row;flex-wrap:wrap;gap:10mm}.print-puzzle-wrap{display:flex;flex-direction:column;align-items:center;gap:6mm}.print-grid{display:grid;grid-template-columns:repeat(9,1fr);border:2px solid #000;width:130mm;height:130mm}.print-page.two-up .print-grid{width:100mm;height:100mm}.print-page.four-up .print-grid{width:80mm;height:80mm}.print-cell{border:.5px solid #999;display:flex;align-items:center;justify-content:center;font-family:serif;font-size:14px;color:#000;aspect-ratio:1}.print-page.two-up .print-cell{font-size:11px}.print-page.four-up .print-cell{font-size:9px}.print-cell.box-right{border-right:2px solid #000}.print-cell.box-bottom{border-bottom:2px solid #000}.print-cell.given-cell{font-weight:700}.print-cell.solution-given{font-weight:700;color:#333}.print-cell.solution-cell{color:#0006}.print-pair-sep{width:0;border-left:1px dashed #ccc;height:100%;align-self:stretch}.print-difficulty-label{font-family:sans-serif;font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:#666}.welcome-header{display:flex;align-items:center;justify-content:center;width:100%}.welcome-title{font-size:clamp(2.8rem,10vw,4.5rem);font-weight:800;letter-spacing:.15em;text-transform:uppercase;color:var(--text-primary);text-align:center;margin:0}.welcome-subtitle{font-size:.9rem;color:var(--text-secondary);letter-spacing:.08em;text-transform:uppercase;margin:0}.welcome-game-status{font-size:.95rem;color:var(--text-secondary);letter-spacing:.05em;margin:0}.welcome-difficulty{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:320px}.welcome-diff-btn{padding:12px 16px;font-size:1rem;font-weight:600;letter-spacing:.05em;text-transform:capitalize;color:var(--text-primary);background:transparent;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;touch-action:manipulation}.welcome-diff-btn:hover{background:#ffffff0d;border-color:var(--text-primary)}.welcome-diff-btn:active{transform:scale(.95)}.welcome-resume{display:grid;grid-template-columns:1fr 1fr;gap:10px;width:100%;max-width:280px}.welcome-btn{padding:12px 16px;font-size:1rem;font-weight:600;letter-spacing:.05em;border-radius:6px;border:1px solid var(--border-color);color:var(--text-primary);background:transparent;cursor:pointer;transition:all .2s;touch-action:manipulation}.welcome-btn:hover{background:#ffffff0d;border-color:var(--text-primary)}.welcome-btn:active{transform:scale(.96)}.welcome-btn-secondary{font-size:.95rem}.welcome-divider{font-size:.85rem;color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase;margin:8px 0}.welcome .theme-toggle{position:static;opacity:.5;padding:8px;margin-top:4px}.welcome .theme-toggle:hover{opacity:.8}.welcome-boxes{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;width:100%;max-width:420px}.welcome-box{display:flex;flex-direction:column;gap:12px;padding:16px;border:1px solid var(--border-color);border-radius:8px;background:#ffffff05}.welcome-box-name{font-size:1rem;font-weight:700;color:var(--text-primary);text-transform:capitalize;text-align:center;letter-spacing:.05em}.welcome-box-buttons{display:flex;flex-direction:column;gap:8px}.welcome-btn-box{padding:10px 12px;font-size:.9rem;font-weight:600;letter-spacing:.05em;border-radius:4px;border:1px solid var(--border-color);color:var(--text-primary);background:transparent;cursor:pointer;transition:all .2s;touch-action:manipulation;white-space:nowrap}.welcome-btn-box:hover{background:#ffffff0d;border-color:var(--text-primary)}.welcome-btn-box:active{transform:scale(.96)}.resume-button-container{position:relative;overflow:hidden;border-radius:4px;display:flex;align-items:stretch}.resume-button-container .welcome-btn-box{position:relative;z-index:1;flex:1;display:flex;align-items:center;justify-content:center}.resume-progress{position:absolute;top:0;left:0;height:100%;background:#ffffff40;transition:width .3s ease;pointer-events:none;z-index:0}body.light .resume-progress{background:#00000014}@keyframes fade-out-title{0%{opacity:1}to{opacity:0}}@keyframes fade-in-stats{0%{opacity:0}to{opacity:1}}.stats-container{display:flex;gap:16px;align-items:center;flex:1;justify-content:center;pointer-events:none;min-height:60px}.stats-container.roll-in{animation:fade-in-stats 2s ease-out forwards}.stats-row{display:flex;gap:12px;align-items:center}.stat-item{display:flex;align-items:center;justify-content:center;gap:4px;color:var(--text-primary);white-space:nowrap}.stat-box{border:1px solid rgba(255,255,255,.1);background:var(--cell-bg, #111);border-radius:6px;padding:8px 12px;font-family:ui-rounded,system-ui,sans-serif;font-size:.95rem;font-weight:600;box-shadow:0 2px 8px #0000004d;transition:background .1s,box-shadow .1s,border-color .4s}body.light .stat-box{border-color:#0000001a;background:var(--cell-bg, #f9f9f9);box-shadow:0 2px 8px #0000001f}.stat-box--timer{font-weight:400;letter-spacing:.05em;min-width:90px;width:90px;gap:6px}.timer-difficulty{font-weight:700;font-size:.85rem;opacity:.75}.stat-box--hint{cursor:pointer;transition:opacity .2s,background .1s,box-shadow .1s;pointer-events:auto}.stat-box--hint:hover:not(:disabled){opacity:.85}.stat-box--hint:active:not(:disabled){transform:translateY(1px)}.stat-box--hint:disabled{opacity:.4;cursor:not-allowed}.board-wrap{position:relative;display:flex;flex-direction:column;align-items:center}.app-footer{font-size:.85rem;color:#ffffff4d;margin-top:auto;padding:8px 0;transition:color .4s ease}body.light .app-footer{color:#0000004d}.footer-link{color:inherit;text-decoration:none;transition:color .2s ease}.footer-link:hover{color:#fff9}body.light .footer-link:hover{color:#0009}.stats-table-container{width:100%;display:flex;flex-direction:column;gap:12px;flex:1;min-height:0;min-width:380px}.stats-table-container h2{font-size:1.2rem;font-weight:700;margin:0;padding:0}body.light .stats-table-container h2{color:#1a1a1a}.stats-table-scroll{overflow-y:auto;min-height:0;flex:1;border:1px solid var(--border-color);border-radius:6px;padding:0}body.light .stats-table-scroll{border-color:#0000001a}.stats-table-large{width:100%;border-collapse:collapse;font-size:.9rem}.stats-table-large th{font-weight:700;padding:10px 12px;text-align:left;border-bottom:1px solid var(--border-color);background:#1a1a1a;position:sticky;top:0;z-index:1}body.light .stats-table-large th{border-color:#0000001a;background:#f0f0f0}.stats-table-large td{padding:10px 12px;border-bottom:1px solid var(--border-color);color:var(--text-primary)}body.light .stats-table-large td{border-color:#0000000d;color:#1a1a1a}.stats-table-large tr.win td{color:#22c55ecc}.stats-table-large tr.loss td{color:#ef4444cc}.stats-table-large tr.progress td{color:#3b82f6b3}.difficulty-col{font-weight:600;letter-spacing:.05em}@media(max-width:768px){.stats-table-large{font-size:.75rem}.stats-table-large th{padding:6px 8px;font-size:.65rem}.stats-table-large td{padding:6px 8px}.stats-table-scroll{width:100%}}
