:root{--bg: #f5f5f0;--surface: #ffffff;--text: #2d2d2d;--text-muted: #777;--border: #e0ddd5;--shadow: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--accent: #4a90d9;--accent-hover: #357abd;--radius: 6px;--c1: #1a5cba;--c2: #2e7d32;--c3: #c62828;--c4: #6a1b9a;--c5: #8b0000;--c6: #00838f;--c7: #212121;--c8: #757575}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100dvh}.app-header{text-align:center;padding:32px 20px 0}.logo{font-size:2rem;font-weight:700;letter-spacing:-.5px;color:var(--text);margin-bottom:16px}.tabs{display:inline-flex;gap:4px;background:var(--border);padding:3px;border-radius:8px}.tab{font-family:inherit;font-size:.875rem;font-weight:500;padding:8px 20px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:6px;transition:all .15s ease}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.tab-content{display:none;padding:24px 20px 40px}.tab-content.active{display:flex;flex-direction:column;align-items:center}.game-controls{margin-bottom:16px}.difficulty-selector{display:inline-flex;gap:4px;background:var(--border);padding:3px;border-radius:8px}.diff-btn{font-family:inherit;font-size:.8125rem;font-weight:500;padding:6px 16px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;border-radius:5px;transition:all .15s ease}.diff-btn:hover{color:var(--text)}.diff-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 3px #00000014}.no-guess-toggle{display:flex;align-items:center;justify-content:center;gap:6px;font-size:.8125rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;margin-top:10px}.no-guess-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.gen-status{font-size:.8125rem;color:var(--accent);text-align:center;padding:4px 0;animation:pulse 1.2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.game-bar{display:flex;align-items:center;justify-content:space-between;width:100%;max-width:520px;margin-bottom:12px;padding:0 4px}.mine-counter,.timer{font-variant-numeric:tabular-nums;font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:6px;min-width:70px;color:var(--text)}.timer{justify-content:flex-end}.mine-counter .icon,.timer .icon{font-size:1rem}.new-game-btn{font-size:1.5rem;width:44px;height:44px;border:none;background:var(--surface);border-radius:50%;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s ease,box-shadow .15s ease;display:flex;align-items:center;justify-content:center;line-height:1}.new-game-btn:hover{transform:scale(1.08);box-shadow:var(--shadow-lg)}.new-game-btn:active{transform:scale(.95)}.grid-container{background:var(--surface);border-radius:10px;box-shadow:var(--shadow-lg);padding:8px;overflow-x:auto;max-width:100%}.grid{display:grid;gap:1px;background:var(--border);border-radius:6px;overflow:hidden;user-select:none;-webkit-user-select:none;touch-action:manipulation}.cell{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:700;cursor:pointer;border:none;padding:0;position:relative;transition:background .08s ease}.cell.hidden{background:#d8d4cc}.cell.hidden:hover{background:#ccc8bf}.cell.hidden:active{background:#c0bbb2}.cell.revealed{background:var(--surface);cursor:default}.cell.flagged{background:#d8d4cc}.cell.mine-hit{background:#ffcdd2}.cell.mine-revealed{background:#f5f5f0}.cell.reveal-anim{animation:cellReveal .15s ease-out}@keyframes cellReveal{0%{transform:scale(.85);opacity:.6}to{transform:scale(1);opacity:1}}.cell[data-num="1"]{color:var(--c1)}.cell[data-num="2"]{color:var(--c2)}.cell[data-num="3"]{color:var(--c3)}.cell[data-num="4"]{color:var(--c4)}.cell[data-num="5"]{color:var(--c5)}.cell[data-num="6"]{color:var(--c6)}.cell[data-num="7"]{color:var(--c7)}.cell[data-num="8"]{color:var(--c8)}.cell .flag{font-size:.8rem;line-height:1}.cell .mine{font-size:.9rem;line-height:1}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);opacity:1;transition:opacity .2s ease}.modal-overlay.hidden{opacity:0;pointer-events:none}.modal{background:var(--surface);border-radius:16px;padding:40px 48px;text-align:center;box-shadow:var(--shadow-lg);transform:scale(1);transition:transform .2s ease;max-width:360px;width:90%}.modal-overlay.hidden .modal{transform:scale(.92)}.modal-emoji{font-size:3rem;margin-bottom:12px;line-height:1}.modal h2{font-size:1.5rem;font-weight:700;margin-bottom:8px}.modal p{color:var(--text-muted);font-size:.9375rem;margin-bottom:24px}.modal-btn{font-family:inherit;font-size:.9375rem;font-weight:600;padding:12px 32px;border:none;background:var(--text);color:var(--bg);border-radius:8px;cursor:pointer;transition:opacity .15s ease}.modal-btn:hover{opacity:.85}@media (max-width: 600px){.app-header{padding:20px 16px 0}.logo{font-size:1.5rem;margin-bottom:12px}.cell{width:28px;height:28px;font-size:.75rem}.game-bar{max-width:100%}.modal{padding:32px 24px}}@media (max-width: 400px){.cell{width:24px;height:24px;font-size:.6875rem}}.learn-article{max-width:680px;width:100%;text-align:left}.learn-h1{font-size:2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:12px;color:var(--text)}.learn-intro{font-size:1.0625rem;line-height:1.7;color:var(--text-muted);margin-bottom:40px}.learn-section{margin-bottom:48px}.learn-section>h2{font-size:1.375rem;font-weight:700;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid var(--border);color:var(--text)}.section-intro{font-size:.9375rem;line-height:1.6;color:var(--text-muted);margin-bottom:20px}.learn-card{background:var(--surface);border-radius:10px;padding:24px;margin-bottom:16px;box-shadow:var(--shadow)}.learn-card h3{font-size:1.0625rem;font-weight:600;margin-bottom:8px;color:var(--text)}.learn-card p{font-size:.9375rem;line-height:1.65;color:var(--text-muted);margin-bottom:0}.learn-card p+p{margin-top:8px}.controls-list{display:flex;flex-direction:column;gap:8px;margin-top:4px}.control-item{display:flex;align-items:center;gap:12px;font-size:.9375rem;color:var(--text-muted)}.control-key{font-size:.8125rem;font-weight:600;padding:4px 10px;background:var(--bg);border-radius:5px;color:var(--text);white-space:nowrap;min-width:110px;text-align:center}.tips-list{margin:8px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:6px}.tips-list li{font-size:.9375rem;line-height:1.6;color:var(--text-muted)}.mini-grid-slot{margin:16px 0 8px}.mini-grid{display:inline-grid;gap:1px;background:var(--border);border-radius:6px;overflow:hidden;user-select:none;-webkit-user-select:none}.mini-cell{width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1rem;font-weight:700;transition:background .08s ease}.mini-cell.revealed{background:var(--surface)}.mini-cell.hidden{background:#d8d4cc}.mini-cell.hidden.interactive{cursor:pointer}.mini-cell.hidden.interactive:hover{background:#ccc8bf}.mini-cell.flagged{background:#d8d4cc}.mini-cell.highlight{background:#e8f0fe}.mini-cell.diagram-mine{background:#fff0f0}.mini-cell.mine-hit{background:#ffcdd2}.mini-cell.mine-revealed{background:#f5f5f0}.mini-cell .flag{font-size:.9rem;line-height:1}.mini-cell .mine{font-size:1rem;line-height:1}.diagram-container{margin:16px 0 8px}.diagram-caption{font-size:.8125rem;color:var(--text-muted);font-style:italic;margin-top:8px}.pattern-card .mini-grid-slot{margin:16px 0}.pattern-feedback{font-size:.875rem;font-weight:500;min-height:24px;margin-bottom:8px;transition:color .15s ease}.pattern-feedback.correct{color:var(--c2)}.pattern-feedback.wrong{color:var(--c3)}.pattern-reset{font-family:inherit;font-size:.8125rem;font-weight:500;padding:6px 16px;border:1px solid var(--border);background:var(--bg);color:var(--text-muted);border-radius:6px;cursor:pointer;transition:all .12s ease}.pattern-reset:hover{background:var(--border);color:var(--text)}.learn-cta{text-align:center;padding:40px 0;border-top:2px solid var(--border);margin-top:8px}.learn-cta p{font-size:1.125rem;font-weight:500;color:var(--text);margin-bottom:16px}.cta-button{font-family:inherit;font-size:1rem;font-weight:600;padding:14px 36px;border:none;background:var(--text);color:var(--bg);border-radius:8px;cursor:pointer;transition:opacity .15s ease,transform .1s ease}.cta-button:hover{opacity:.85}.cta-button:active{transform:scale(.97)}@media (max-width: 600px){.learn-h1{font-size:1.5rem}.learn-intro{font-size:.9375rem;margin-bottom:28px}.learn-card{padding:20px 16px}.mini-cell{width:36px;height:36px;font-size:.875rem}.control-key{min-width:90px;font-size:.75rem}}.action-bar{display:flex;align-items:center;gap:12px;margin-bottom:8px;flex-wrap:wrap;justify-content:center}.action-group{display:flex;gap:4px}.action-btn{font-family:inherit;font-size:1rem;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;cursor:pointer;transition:all .12s ease;line-height:1}.action-btn:hover:not(:disabled){background:var(--border)}.action-btn:disabled{opacity:.3;cursor:default}.hint-btn{font-family:inherit;font-size:.8125rem;font-weight:600;padding:7px 16px;border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:6px;cursor:pointer;transition:all .12s ease}.hint-btn:hover:not(:disabled){background:var(--border)}.hint-btn:disabled{opacity:.4;cursor:default}.auto-hint-toggle{display:flex;align-items:center;gap:6px;font-size:.8125rem;color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none}.auto-hint-toggle input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}.cell.hint-safe,.cell.hidden.hint-safe{background:#a5d6a7!important;box-shadow:inset 0 0 0 2px #388e3c}.cell.hint-mine,.cell.hidden.hint-mine{background:#ef9a9a!important;box-shadow:inset 0 0 0 2px #c62828}.cell.hint-prob{cursor:default}.hint-overlay{position:absolute;font-size:.625rem;font-weight:700;color:#000000b3;pointer-events:none;line-height:1;z-index:2;text-shadow:0 0 2px rgba(255,255,255,.6)}.grid.solving{pointer-events:none;opacity:.85}.solver-article{max-width:680px;width:100%;text-align:left}.solver-h1{font-size:2rem;font-weight:700;letter-spacing:-.5px;margin-bottom:12px;color:var(--text)}.solver-intro{font-size:1.0625rem;line-height:1.7;color:var(--text-muted);margin-bottom:32px}.solver-card{background:var(--surface);border-radius:10px;padding:24px;margin-bottom:20px;box-shadow:var(--shadow)}.solver-card h2{font-size:1.25rem;font-weight:700;margin-bottom:8px;color:var(--text)}.solver-card>p{font-size:.9375rem;line-height:1.6;color:var(--text-muted);margin-bottom:16px}.solver-dropzone{border:2px dashed var(--border);border-radius:10px;padding:40px 20px;text-align:center;cursor:pointer;transition:all .15s ease}.solver-dropzone:hover,.solver-dropzone.dragover{border-color:var(--accent);background:#4a90d90a}.dropzone-content{display:flex;flex-direction:column;align-items:center;gap:8px}.dropzone-icon{font-size:2rem}.dropzone-label{font-size:.9375rem;font-weight:500;color:var(--text)}.dropzone-hint{font-size:.8125rem;color:var(--text-muted)}.solver-preview{margin-top:16px;border-radius:8px;overflow:hidden}.solver-preview img{width:100%;max-height:400px;object-fit:contain;display:block;background:#f0f0f0;border-radius:8px}.solver-status{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:.875rem;color:var(--text-muted)}.solver-spinner{width:18px;height:18px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.solver-setup{margin-bottom:16px}.solver-presets{display:inline-flex;gap:4px;background:var(--border);padding:3px;border-radius:8px;flex-wrap:wrap;margin-bottom:12px}.solver-custom-size{display:flex;align-items:center;gap:10px;margin-bottom:12px;font-size:.875rem;color:var(--text-muted)}.hidden-util{display:none!important}.solver-instructions{font-size:.8125rem;color:var(--text-muted);background:var(--bg);padding:10px 14px;border-radius:6px;margin-bottom:16px;display:flex;flex-wrap:wrap;gap:4px 8px}.solver-instructions strong{color:var(--text)}.beta-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;background:var(--border);color:var(--text-muted);padding:2px 6px;border-radius:4px;vertical-align:middle}.solver-config{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.solver-mine-label{font-size:.875rem;color:var(--text-muted);display:flex;align-items:center;gap:6px}.solver-mine-input{font-family:inherit;font-size:.875rem;width:60px;padding:4px 8px;border:1px solid var(--border);border-radius:4px;background:var(--bg);color:var(--text)}.solver-results .grid-container{margin-bottom:16px}.solver-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:.8125rem;color:var(--text-muted)}.legend-item{display:flex;align-items:center;gap:6px}.legend-swatch{width:16px;height:16px;border-radius:3px}.legend-swatch.safe{background:#2e7d324d;box-shadow:inset 0 0 0 2px #2e7d3299}.legend-swatch.mine{background:#c628284d;box-shadow:inset 0 0 0 2px #c6282899}.legend-swatch.uncertain{background:linear-gradient(90deg,#bbeba2,#ebeba2,#eba2a2);box-shadow:inset 0 0 0 2px #00000026}.solver-preview.hidden,.solver-status.hidden{display:none!important}@media (max-width: 600px){.solver-h1{font-size:1.5rem}.solver-card{padding:20px 16px}.solver-dropzone{padding:28px 16px}}
