:root{--bg:#071023;--bg-soft:#0b1630;--panel:rgba(15,27,56,0.86);--panel-solid:#0f1b38;--panel-soft:rgba(255,255,255,0.065);--panel-lift:rgba(255,255,255,0.095);--paper:#fbfaf5;--paper-line:rgba(23,32,54,0.14);--paper-line-strong:rgba(23,32,54,0.42);--text:#eef2ff;--muted:#a8b4cf;--muted-2:#7f8cac;--cell-a:#fbfaf5;--fixed:#ece5d7;--selected:#d7e7ff;--related:#edf4ff;--same:#e6f6ec;--duplicate:#ffe0df;--incorrect:#d92929;--ink:#151515;--primary:#4b86ff;--primary-dark:#2f64c8;--good:#1fa34a;--warn:#d79424;--danger:#cf4d4d;--radius-lg:28px;--radius-md:20px;--shadow-soft:0 22px 70px rgba(0,0,0,0.28);--shadow-board:0 26px 90px rgba(0,0,0,0.34)}body.light{--bg:#eef3ff;--bg-soft:#e5ecfb;--panel:rgba(255,255,255,0.86);--panel-solid:#ffffff;--panel-soft:rgba(12,35,75,0.055);--panel-lift:rgba(12,35,75,0.085);--text:#15233a;--muted:#586881;--muted-2:#7a879b;--shadow-soft:0 22px 70px rgba(45,64,98,0.16);--shadow-board:0 26px 90px rgba(45,64,98,0.20)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;padding:0;min-height:100%;min-height:100dvh;-webkit-text-size-adjust:100%;background:radial-gradient(circle at top left,rgba(75,134,255,0.22),transparent 34%),radial-gradient(circle at bottom right,rgba(31,163,74,0.10),transparent 30%),linear-gradient(145deg,var(--bg),var(--bg-soft));color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}body{overflow-x:hidden}img,video,canvas{display:block;max-width:100%;height:auto}button,input,textarea,select{font:inherit}button{border:0;border-radius:18px;min-height:54px;padding:12px 16px;background:var(--panel-soft);color:var(--text);font-size:15px;line-height:1.1;font-weight:750;cursor:pointer;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.06);transition:transform 0.16s ease,background 0.16s ease,box-shadow 0.16s ease,opacity 0.16s ease}button:hover{background:var(--panel-lift);transform:translateY(-1px)}button:active{transform:translateY(0);opacity:0.9}button.primary{background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:white;box-shadow:0 12px 34px rgba(75,134,255,0.28),inset 0 0 0 1px rgba(255,255,255,0.16)}button.good{background:var(--good);color:white}button.warn{background:var(--warn);color:white}button.danger{background:var(--danger);color:white}button.done{opacity:0.48}button.tool-active{background:var(--warn) !important;color:white !important;box-shadow:0 12px 34px rgba(215,148,36,0.28),inset 0 0 0 1px rgba(255,255,255,0.16)}h1{margin:0;font-size:clamp(34px,4vw,54px);line-height:0.95;font-weight:850;letter-spacing:-0.05em}h2,h3{margin:0 0 10px 0;letter-spacing:-0.02em}.app-shell{max-width:1320px;margin:0 auto;padding:22px}.topbar{margin-bottom:22px;display:flex;justify-content:space-between;gap:16px;align-items:flex-start;flex-wrap:wrap}.app-topbar{padding:4px 2px 0}.brand-row{display:flex;gap:14px;align-items:center}.brand-home-link{color:inherit;text-decoration:none}.brand-home-link:hover{opacity:0.88}.brand-mark{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:linear-gradient(145deg,rgba(75,134,255,0.95),rgba(31,163,74,0.88));color:white;font-size:30px;font-weight:900;box-shadow:0 16px 40px rgba(75,134,255,0.24)}.brand-icon{width:26px;height:26px;display:inline-flex;align-items:center;justify-content:center;font-size:24px;font-weight:950;line-height:1}.share-btn-x .brand-icon{font-size:22px}.topbar-copy{min-width:280px}.topbar-actions,.compact-actions{display:flex;flex-wrap:wrap;gap:10px}.meta{font-size:16px;color:var(--muted);margin-top:6px}.status{min-height:24px;font-size:15px;color:var(--muted);margin-top:10px}.main-layout,.premium-layout{display:grid;grid-template-columns:minmax(520px,1fr) 310px;gap:28px;align-items:start}.board-section{min-width:0}.board-shell{position:relative;width:min(78vw,760px);aspect-ratio:1 / 1;margin:0 auto;padding:10px;border-radius:30px;background:linear-gradient(180deg,rgba(255,255,255,0.16),rgba(255,255,255,0.04)),rgba(255,255,255,0.04);box-shadow:var(--shadow-board);contain:layout paint;transition:box-shadow 0.24s ease,background 0.24s ease,transform 0.24s ease}.board-shell.board-complete-correct{box-shadow:0 0 0 5px rgba(31,163,74,0.85),0 0 48px rgba(31,163,74,0.30),var(--shadow-board)}.board-shell.board-complete-error{box-shadow:0 0 0 5px rgba(207,77,77,0.88),0 0 48px rgba(207,77,77,0.30),var(--shadow-board)}.board{display:grid;grid-template-columns:repeat(9,1fr);width:100%;height:100%;border-radius:20px;overflow:hidden;background:var(--paper);border:3px solid var(--paper-line-strong);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.45)}.board-ink-canvas{position:absolute;inset:10px;width:calc(100% - 20px);height:calc(100% - 20px);z-index:20;background:transparent;touch-action:none;pointer-events:auto;border-radius:20px}.cell{position:relative;display:grid;place-items:center;min-width:0;min-height:0;border-right:1px solid var(--paper-line);border-bottom:1px solid var(--paper-line);background:var(--cell-a);color:var(--ink);overflow:hidden;user-select:none;cursor:pointer;font-size:clamp(24px,3.2vw,42px);font-weight:650;line-height:1;transition:background 0.14s ease,color 0.14s ease,box-shadow 0.14s ease}.cell:nth-child(3n){border-right:3px solid var(--paper-line-strong)}.cell:nth-child(n + 19):nth-child(-n + 27),.cell:nth-child(n + 46):nth-child(-n + 54){border-bottom:3px solid var(--paper-line-strong)}.cell:nth-child(9n){border-right:0}.cell:nth-child(n + 73){border-bottom:0}.cell.fixed{background:var(--fixed);font-weight:850}.cell.selected{background:linear-gradient(180deg,#dceaff,#cfe1ff);box-shadow:inset 0 0 0 3px rgba(75,134,255,0.42),inset 0 0 22px rgba(75,134,255,0.16)}.cell.related{background:var(--related)}.cell.same{background:var(--same)}.cell.duplicate{background:var(--duplicate)}.cell.incorrect,.cell .incorrect{color:var(--incorrect)}.cell-value,.cell-notes{position:absolute;inset:0;pointer-events:none}.cell-value{display:flex;align-items:center;justify-content:center;font-size:clamp(22px,3vw,42px);font-weight:650;color:var(--ink);z-index:2}.cell-value.fixed-value{font-weight:850}.cell-value.incorrect{color:var(--incorrect)}.cell-notes{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:clamp(3px,0.6vw,7px);font-size:clamp(9px,0.8vw,12px);font-weight:700;color:rgba(21,21,21,0.62);z-index:1}.note{display:flex;align-items:center;justify-content:center;line-height:1}.side-panel,.premium-panel{width:310px;background:var(--panel);border-radius:var(--radius-lg);padding:18px;box-shadow:var(--shadow-soft);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,0.08)}.panel-group{margin-bottom:18px}.panel-group:last-child{margin-bottom:0}.panel-title{font-size:12px;text-transform:uppercase;letter-spacing:0.12em;color:var(--muted);margin-bottom:10px;font-weight:800}.play-controls{display:grid;gap:16px}.play-controls .panel-group{margin-bottom:0}.keypad{display:grid;gap:10px}.keypad-digits{grid-template-columns:repeat(3,1fr)}.keypad-digits button{min-height:64px;font-size:24px;border-radius:20px}.quick-controls,.secondary-actions,.settings-actions,.input-toggles,.action-row{display:grid;gap:10px}.quick-controls,.secondary-actions,.input-toggles{grid-template-columns:1fr 1fr}.secondary-actions{margin-top:10px}.action-row{grid-template-columns:repeat(2,1fr)}.toggle-pill{position:relative}.toggle-pill.primary::after,#notesBtn.primary::after,#writeBtn.primary::after{content:"";position:absolute;inset:5px;border-radius:14px;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.18);pointer-events:none}.card{background:var(--panel);border-radius:var(--radius-md);padding:18px;box-shadow:var(--shadow-soft)}.modal-backdrop{position:fixed;inset:0;background:radial-gradient(circle at center,rgba(75,134,255,0.10),transparent 42%),rgba(3,8,23,0.72);display:flex;align-items:center;justify-content:center;padding:16px;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.hidden{display:none !important}.modal,.premium-modal{position:relative;width:min(94vw,560px);background:linear-gradient(180deg,rgba(255,255,255,0.08),transparent),var(--panel-solid);border-radius:30px;padding:26px;color:var(--text);box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,0.10)}.modal-wide{width:min(96vw,840px)}.modal h2{margin-top:0;margin-bottom:8px;font-size:clamp(28px,4vw,40px);letter-spacing:-0.04em}.modal-kicker{color:var(--primary);font-weight:850;font-size:12px;letter-spacing:0.12em;text-transform:uppercase;margin-bottom:8px}.modal-copy,.settings-copy{color:var(--muted);margin:0 0 18px 0;line-height:1.45}.modal-actions{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}.modal-actions button{min-height:54px;padding:12px 18px;border-radius:18px;font-size:15px}.modal-actions-grid{display:grid;grid-template-columns:repeat(5,1fr)}.modal-close-btn{position:absolute;top:22px;right:22px;width:42px;height:42px;border:1px solid rgba(255,255,255,0.08);border-radius:14px;background:linear-gradient( 180deg,rgba(255,255,255,0.08),rgba(255,255,255,0.04) );color:rgba(255,255,255,0.82);font-size:1rem;font-weight:700;cursor:pointer;transition:transform 0.18s ease,border-color 0.18s ease,box-shadow 0.18s ease,background 0.18s ease}.modal-close-btn:hover{transform:translateY(-1px);border-color:rgba(90,140,255,0.45);box-shadow:0 0 18px rgba(70,120,255,0.22);color:white}.difficulty-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:18px}.difficulty-grid button{min-height:76px;font-size:18px;border-radius:24px}.completion-card{text-align:left}.completion-stats{margin:18px 0 4px;padding:14px;border-radius:18px;background:var(--panel-soft);color:var(--muted);line-height:1.55}.completion-actions{justify-content:flex-start}.settings-grid{display:grid;grid-template-columns:1.2fr 0.9fr 0.9fr;gap:16px;align-items:start}.settings-section{background:var(--panel-soft);border-radius:22px;padding:16px}.settings-section h3{margin-bottom:12px}.setting-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;font-size:15px;border-bottom:1px solid rgba(255,255,255,0.07)}.setting-row:last-child{border-bottom:0}.setting-row span{display:grid;gap:3px}.setting-row small{color:var(--muted);font-size:12px;line-height:1.35}.setting-row input[type="checkbox"]{width:48px;height:28px;flex:0 0 auto;accent-color:var(--primary)}.stats-block{margin-bottom:14px;padding:12px;background:var(--panel-soft);border-radius:14px}.writing-pad-shell{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start}.writing-pad,.pad-wrap,.quick-calibration-pad-wrap{position:relative;width:100%;border-radius:22px;background:var(--paper);overflow:hidden;border:2px solid rgba(21,21,21,0.12)}.writing-pad{aspect-ratio:1.6 / 1}.writing-guide{position:absolute;inset:0;pointer-events:none;background:linear-gradient( to bottom,transparent 0,transparent calc(50% - 1px),rgba(90,105,135,0.26) calc(50% - 1px),rgba(90,105,135,0.26) calc(50% + 1px),transparent calc(50% + 1px),transparent 100%);z-index:1}#writingCanvas,#pad,#userCalCanvas,#quickCalCanvas{position:absolute;inset:0;width:100%;height:100%;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;z-index:5;background:transparent}.writing-side{display:flex;flex-direction:column;gap:10px;min-width:120px}.writing-side button{min-height:56px;font-size:15px}.writing-help{font-size:15px;color:var(--muted);margin-bottom:10px}.calibration-layout{display:grid;grid-template-columns:minmax(700px,1fr) 360px;gap:22px;align-items:start}.calibration-main,.calibration-side{min-width:0}.prompt-row{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;margin-bottom:16px}.eyebrow{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:0.12em;margin-bottom:6px;font-weight:800}.muted{color:var(--muted);font-size:15px}.status-block{text-align:right}.compare-grid{display:grid;grid-template-columns:1.3fr 0.8fr;gap:18px;align-items:stretch}.compare-card{background:var(--panel-soft);border-radius:22px;padding:14px}.compare-title{font-size:12px;color:var(--muted);margin-bottom:10px;text-transform:uppercase;letter-spacing:0.12em;font-weight:800}.pad-wrap{aspect-ratio:1.6 / 1}#userCalPadShell{position:relative}.guide{position:absolute;left:0;right:0;height:2px;background:rgba(80,110,160,0.22);z-index:2;pointer-events:none}.guide-top{top:22%}.guide-mid{top:50%}.guide-bot{top:78%}.prediction-box{width:100%;aspect-ratio:1 / 1;border-radius:22px;background:var(--paper);border:2px solid rgba(21,21,21,0.12);display:flex;align-items:center;justify-content:center}.prediction-digit{color:var(--ink);font-size:clamp(58px,9vw,120px);font-weight:850;line-height:1}.controls{display:grid;gap:10px;margin-top:14px}.controls-three{grid-template-columns:repeat(3,1fr)}.confirm-panel{margin-top:18px;padding-top:18px;border-top:1px solid rgba(255,255,255,0.08)}.confirm-question{font-size:18px;font-weight:750;margin-bottom:12px}.confirm-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}.card-divider{height:1px;background:rgba(255,255,255,0.08);margin:18px 0}.manual-panel{margin-top:4px}.side-tools{display:grid;gap:10px}.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.small{font-size:13px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.json-box{margin:0;max-height:320px;overflow:auto;font-size:12px;line-height:1.45;background:rgba(0,0,0,0.22);border-radius:14px;padding:12px;white-space:pre-wrap;word-break:break-word}.quick-calibration-modal{width:min(94vw,520px)}.quick-calibration-pad-wrap{aspect-ratio:1.45 / 1;border-radius:24px;margin:16px 0}.quick-calibration-result{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border-radius:18px;background:var(--panel-soft);color:var(--muted);margin-bottom:12px}.quick-calibration-result strong{font-size:38px;color:var(--text);line-height:1}.quick-calibration-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}.quick-cal-manual{margin-top:12px;grid-template-columns:repeat(9,1fr)}.quick-cal-manual button{min-height:44px;font-size:18px;border-radius:14px}.pad-wrap,#pad,#userCalCanvas,.writing-pad,#writingCanvas,.board-shell,.board,.cell,.board-ink-canvas,#boardInkCanvas,#quickCalCanvas{touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}#pad,#userCalCanvas,#writingCanvas,.board-ink-canvas,#quickCalCanvas{pointer-events:auto}.home-shell{min-height:100vh;max-width:1180px;margin:0 auto;padding:clamp(18px,3vw,32px);color:var(--text)}.home-shell>section{margin:0 0 clamp(28px,4vw,44px)}.home-hero-card,.home-panel,.home-card,.home-cta-card,.seo-footer{background:linear-gradient(180deg,rgba(255,255,255,0.08),transparent),var(--panel);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);border:1px solid rgba(255,255,255,0.10);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}.home-hero-card{text-align:center;padding:clamp(44px,7vw,76px) clamp(20px,4vw,40px)}.home-kicker{display:inline-flex;margin-bottom:16px;padding:8px 14px;border-radius:999px;background:var(--panel-soft);color:var(--primary);font-size:12px;font-weight:850;letter-spacing:0.12em;text-transform:uppercase}.home-hero-card h1{margin:0;font-size:clamp(54px,8vw,86px);line-height:0.9;letter-spacing:-0.06em}.home-subtitle{max-width:760px;margin:18px auto 0;color:var(--muted);font-size:clamp(18px,2.2vw,22px);line-height:1.35}.home-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:24px}.home-actions.home-primary-action{margin-bottom:30px}.home-button{min-height:52px;padding:13px 21px;border-radius:18px;display:inline-flex;align-items:center;justify-content:center;color:var(--text);background:var(--panel-soft);text-decoration:none;font-size:16px;font-weight:850;box-shadow:inset 0 0 0 1px rgba(255,255,255,0.06);transition:transform 0.16s ease,background 0.16s ease,box-shadow 0.16s ease,opacity 0.16s ease}.home-button:hover{background:var(--panel-lift);transform:translateY(-1px)}.home-button.primary{background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:white;box-shadow:0 12px 34px rgba(75,134,255,0.28),inset 0 0 0 1px rgba(255,255,255,0.16)}.home-section{margin:0 0 clamp(28px,4vw,44px)}.home-section>h2,.seo-copy-section>h2,.home-cta-card>h2{text-align:center;margin-bottom:16px;font-size:clamp(30px,5vw,44px);letter-spacing:-0.04em}.home-panel,.home-cta-card{padding:clamp(22px,3vw,32px)}.home-panel h2,.home-cta-card h2{margin:0 0 10px;font-size:clamp(26px,4vw,38px)}.home-panel p,.home-card p,.home-cta-card p{margin:0;color:var(--muted);line-height:1.55;font-size:16px}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,22px)}.home-card{min-height:145px;padding:20px}.home-card h3{margin:0 0 7px;font-size:22px}.feature-icon{width:52px;height:52px;display:grid;place-items:center;margin-bottom:14px;border-radius:18px;background:var(--panel-soft);font-size:26px}.feature-label{display:inline-block;margin-bottom:10px;padding:6px 14px;border-radius:999px;background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.08);color:#9fb4ff;font-size:12.5px;font-weight:600;letter-spacing:0.06em;text-transform:uppercase}.seo-copy-section{max-width:1180px;margin-left:auto;margin-right:auto}.seo-copy-section .home-panel{width:100%;max-width:100%;margin:0 auto 22px;text-align:center}.seo-copy-section p{max-width:780px;margin:0 auto;font-size:clamp(16px,2vw,18px);line-height:1.65}.home-cta-card{text-align:center;padding:clamp(34px,5vw,52px)}.home-cta-card p{text-align:center}.home-cta-card .home-actions{margin-top:18px}.seo-footer{margin-top:40px;padding:28px}.seo-footer-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}.seo-footer-column h3{margin-bottom:14px;font-size:18px}.seo-footer-column a{display:block;margin-bottom:10px;color:var(--muted);text-decoration:none;transition:color 0.16s ease}.seo-footer-column a:hover{color:var(--text)}.seo-footer-column p{margin:0;color:var(--muted);line-height:1.6}.daily-leaderboard-card{margin-top:0;padding:clamp(24px,4vw,36px);border-radius:30px;background:radial-gradient(circle at top,rgba(59,130,246,0.16),transparent 42%),rgba(11,25,55,0.78);border:1px solid rgba(148,163,184,0.18)}.daily-leaderboard-card>h2{text-align:center;margin-bottom:18px;font-size:clamp(30px,5vw,44px)}.daily-actions{justify-content:center;margin-top:0;margin-bottom:24px}.leaderboard-panel{margin-top:0;padding:22px 24px;border-radius:24px;background:rgba(3,10,28,0.42);border:1px solid rgba(148,163,184,0.14)}.leaderboard-header{display:flex;justify-content:space-between;gap:18px;align-items:flex-end;margin-bottom:16px;text-align:left}.leaderboard-kicker{color:#60a5fa;font-size:0.78rem;font-weight:900;letter-spacing:0.14em;text-transform:uppercase}.leaderboard-title{margin:4px 0 0;color:#f8fafc}.leaderboard-note{color:#94a3b8;font-size:0.9rem;font-weight:700}.leaderboard-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.leaderboard-card{padding:15px 16px;border-radius:18px;background:rgba(15,23,42,0.72);border:1px solid rgba(148,163,184,0.16);text-align:left}.leaderboard-card h3{margin:0 0 12px;color:#f8fafc;font-size:1.05rem}.leaderboard-card ol{margin:0;padding-left:22px;color:#cbd5e1;font-weight:700}.leaderboard-card li{padding:4px 0}.daily-completion-panel{margin-top:18px;padding:16px;border-radius:18px;background:rgba(15,23,42,0.55);border:1px solid rgba(148,163,184,0.18)}.daily-result-message{color:#dbeafe;font-weight:800;margin-bottom:14px}.leaderboard-name-area{display:grid;gap:10px;margin-bottom:16px}.leaderboard-name-area label{color:#cbd5e1;font-size:0.9rem;font-weight:800}.leaderboard-name-area input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid rgba(148,163,184,0.28);background:rgba(255,255,255,0.92);color:#020617;font-weight:800}.share-actions{display:flex;flex-wrap:wrap;gap:10px}.share-actions a,.share-actions button{padding:10px 14px;border-radius:14px;border:1px solid rgba(148,163,184,0.2);background:rgba(30,41,59,0.82);color:#f8fafc;font-weight:900;text-decoration:none;cursor:pointer}button.daily-disabled,button.daily-disabled:hover{opacity:0.35;cursor:not-allowed;transform:none;background:rgba(148,163,184,0.18);color:rgba(226,232,240,0.62)}.sudoku-rule-image{display:block;width:100%;height:auto;margin:16px 0 18px;border-radius:18px;border:1px solid rgba(148,163,184,0.18);box-shadow:0 16px 40px rgba(0,0,0,0.16)}.contribute-hero-card{padding-top:clamp(28px,4vw,48px);padding-bottom:clamp(28px,4vw,48px)}.contribute-hero-card h1{font-size:clamp(2.35rem,6vw,4.5rem);line-height:0.95;max-width:900px;margin-left:auto;margin-right:auto}.contribute-hero-card .home-subtitle{max-width:760px;margin-left:auto;margin-right:auto}.contribute-intro-panel{max-width:820px;margin:22px auto 0;padding:18px 22px}.contribute-shell{width:min(760px,calc(100% - 32px));margin:0 auto}.contribute-progress-wrap{margin-bottom:18px}.contribute-progress-top{display:flex;justify-content:space-between;gap:16px;margin-bottom:10px;font-size:0.9rem;font-weight:800;color:rgba(255,255,255,0.78)}.contribute-progress-bar{height:10px;overflow:hidden;border-radius:999px;background:rgba(255,255,255,0.12)}.contribute-progress-fill{height:100%;width:0%;border-radius:inherit;background:linear-gradient(90deg,#4b86ff,#7dd3fc);transition:width 220ms ease}.contribute-card{border-radius:28px;padding:clamp(18px,3vw,28px);background:rgba(15,23,42,0.72);border:1px solid rgba(148,163,184,0.18);box-shadow:0 24px 80px rgba(0,0,0,0.22);backdrop-filter:blur(18px)}.contribute-target-wrap{display:flex;justify-content:space-between;align-items:flex-end;gap:18px;margin-bottom:14px}.contribute-label{font-size:0.9rem;font-weight:800;color:rgba(255,255,255,0.7)}.contribute-target-digit{font-size:clamp(3.25rem,9vw,5.5rem);line-height:0.9;font-weight:950;letter-spacing:-0.08em;color:#ffffff}.contribute-pad-wrap{width:min(440px,100%);height:min(440px,calc(100vw - 64px));max-height:440px;margin:0 auto 18px;border-radius:26px;background:#fffefa;border:1px solid rgba(15,23,42,0.14);overflow:hidden;box-shadow:inset 0 0 0 1px rgba(15,23,42,0.04)}.contribute-pad-wrap canvas{display:block;width:100%;height:100%;touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}.contribute-card .quick-calibration-result{margin-top:12px}.feedback-rating-grid,.feedback-digit-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin:18px 0}.feedback-rating-btn.active{outline:2px solid rgba(125,211,252,0.95)}.feedback-digit-grid label{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:14px;background:rgba(255,255,255,0.08);cursor:pointer;font-weight:800}.feedback-comment{width:100%;min-height:110px;resize:vertical;margin-top:14px;padding:14px;border-radius:16px;border:1px solid rgba(148,163,184,0.22);background:rgba(15,23,42,0.72);color:white}.solver-shell{max-width:1320px}.solver-layout{grid-template-columns:minmax(520px,1fr) 360px}.solver-board-shell{width:min(78vw,760px)}.solver-panel{width:360px}.solver-paste{width:100%;min-height:104px;resize:vertical;padding:14px;border-radius:18px;border:1px solid rgba(255,255,255,0.08);background:var(--panel-soft);color:var(--text);outline:none;line-height:1.45}.solver-paste:focus{box-shadow:inset 0 0 0 2px rgba(75,134,255,0.38)}.solver-actions{display:grid;gap:10px;margin-top:14px}.solver-status{margin-top:16px;min-height:72px;padding:14px;border-radius:18px;background:var(--panel-soft);color:var(--muted);line-height:1.45}.solver-status.good{color:#baf7c9;box-shadow:inset 0 0 0 1px rgba(31,163,74,0.35)}.solver-status.bad{color:#ffd2d2;box-shadow:inset 0 0 0 1px rgba(207,77,77,0.38)}.solver-help{margin:14px 0 0;color:var(--muted);font-size:14px;line-height:1.45}.solver-cell-input{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:0;padding:0;background:transparent;color:var(--ink);text-align:center;font-size:clamp(22px,3vw,42px);font-weight:850;line-height:1;outline:none;caret-color:transparent;box-shadow:none;appearance:none;-webkit-appearance:none}.solver-cell-input:focus{outline:none}.cell.solved .solver-cell-input{color:var(--primary-dark)}.cell.duplicate .solver-cell-input{color:var(--incorrect)}.printable-shell{max-width:1220px}.printable-controls{width:100%;margin-bottom:24px}.printable-select{width:100%;padding:14px 16px;border-radius:16px;border:1px solid rgba(255,255,255,0.08);background:var(--panel-soft);color:var(--text);font-weight:800}.printable-actions{display:flex;flex-wrap:wrap;gap:10px}.printable-page{position:relative;overflow:hidden;width:min(100%,1160px);margin:0 auto 40px;padding:42px 34px 34px;border-radius:28px;background:#ffffff;color:#151515;box-shadow:var(--shadow-soft)}.printable-page-header{text-align:center;margin-bottom:26px}.printable-page-header h2{margin:0;font-size:clamp(34px,5vw,52px);line-height:0.95;letter-spacing:-0.055em;color:#151515}.printable-page-header p{margin:10px 0 0;color:rgba(21,21,21,0.62);font-size:20px;font-weight:900}.printable-grid-wrap{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:36px;align-items:start}.printable-puzzle-card{min-width:0}.printable-puzzle-card h3{margin:0 0 14px;font-size:23px;line-height:1;text-align:center;color:#151515}.printable-board-wrap{position:relative;overflow:hidden;background:#ffffff}.printable-grid-watermark{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%) rotate(-45deg);z-index:3;pointer-events:none;white-space:nowrap;color:rgba(20,28,45,0.075);font-size:clamp(52px,7.4vw,92px);font-weight:950;line-height:1}.printable-sudoku-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(9,1fr);aspect-ratio:1 / 1;background:transparent;border:5px solid rgba(23,32,54,0.76)}.printable-cell{display:grid;place-items:center;min-width:0;min-height:0;border-right:1px solid rgba(23,32,54,0.16);border-bottom:1px solid rgba(23,32,54,0.16);background:transparent;color:#151515;font-size:clamp(22px,3vw,38px);font-weight:900;line-height:1}.printable-cell:nth-child(3n){border-right:3px solid rgba(23,32,54,0.48)}.printable-cell:nth-child(9n){border-right:0}.printable-cell:nth-child(n + 19):nth-child(-n + 27),.printable-cell:nth-child(n + 46):nth-child(-n + 54){border-bottom:3px solid rgba(23,32,54,0.48)}.printable-cell:nth-child(n + 73){border-bottom:0}@media (max-width:1080px){.main-layout,.premium-layout,.calibration-layout,.solver-layout{grid-template-columns:1fr}.side-panel,.premium-panel,.solver-panel{width:min(92vw,760px);margin:0 auto}.board-shell,.solver-board-shell{width:min(92vw,760px)}.settings-grid{grid-template-columns:1fr}}@media (max-width:900px){.leaderboard-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:860px){.printable-grid-wrap{grid-template-columns:1fr}.printable-page{padding:26px 18px}}@media (max-width:760px){body{padding-bottom:calc(238px + env(safe-area-inset-bottom))}.app-shell{padding:10px 10px 0}.topbar{margin-bottom:10px;gap:12px;align-items:center}.topbar-copy{min-width:0}.brand-mark{width:46px;height:46px;border-radius:15px;font-size:25px}h1{font-size:32px;letter-spacing:-0.055em}.meta{font-size:13px;margin-top:4px}.status{font-size:13px;min-height:18px;margin-top:6px}.compact-actions{display:flex;gap:8px;width:auto;margin-left:auto}.compact-actions button{min-height:42px;padding:10px 12px;border-radius:14px;font-size:13px;flex:unset}.board-shell,.solver-board-shell{width:min(96vw,720px);max-height:calc(100vh - 310px);padding:6px;border-radius:22px}.board{border-width:2px;border-radius:16px}.cell,.cell-value{font-size:clamp(22px,8vw,39px)}.cell-notes{font-size:clamp(8px,2.35vw,12px);padding:3px}.board-ink-canvas{inset:6px;width:calc(100% - 12px);height:calc(100% - 12px);border-radius:16px}.side-panel,.premium-panel,.solver-panel{width:100%;padding:14px;border-radius:24px}.quick-controls,.secondary-actions,.difficulty-grid,.compare-grid,.writing-pad-shell,.controls-three,.confirm-actions,.modal-actions-grid{grid-template-columns:1fr}.writing-side{flex-direction:row;flex-wrap:wrap}.writing-side button{flex:1 1 140px}.modal-backdrop{align-items:flex-start;justify-content:center;overflow-y:auto;padding:max(14px,env(safe-area-inset-top)) 14px max(24px,env(safe-area-inset-bottom));-webkit-overflow-scrolling:touch;z-index:100}.modal,.premium-modal{max-height:calc(100dvh - 28px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding:20px;border-radius:24px}.modal-wide{width:100%}body:has(.modal-backdrop:not(.hidden)){overflow:hidden}.play-controls{position:fixed;left:10px;right:10px;bottom:calc(10px + env(safe-area-inset-bottom));z-index:40;width:auto;margin:0;padding:12px;display:grid;grid-template-areas:"keypad" "input" "actions";gap:10px;border-radius:26px;background:linear-gradient(180deg,rgba(255,255,255,0.92),rgba(255,255,255,0.84)),rgba(255,255,255,0.88);color:#142139;border:1px solid rgba(20,33,57,0.08);box-shadow:0 -18px 60px rgba(20,33,57,0.18),0 10px 26px rgba(20,33,57,0.10);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}body:not(.light) .play-controls{background:linear-gradient(180deg,rgba(19,32,65,0.96),rgba(12,22,46,0.94)),var(--panel);color:var(--text);border-color:rgba(255,255,255,0.10)}.keypad-group{grid-area:keypad}.input-group{grid-area:input}.actions-group{grid-area:actions}.play-controls .panel-title{display:none}.keypad-digits{grid-template-columns:repeat(9,1fr);gap:6px}.keypad-digits button{min-height:48px;padding:0;border-radius:15px;font-size:22px;font-weight:850;background:rgba(20,33,57,0.07);color:#142139;box-shadow:inset 0 0 0 1px rgba(20,33,57,0.06)}body:not(.light) .keypad-digits button{background:rgba(255,255,255,0.075);color:var(--text);box-shadow:inset 0 0 0 1px rgba(255,255,255,0.06)}.input-toggles{grid-template-columns:1fr 1fr;gap:8px}.input-toggles button{min-height:42px;border-radius:15px;font-size:14px;background:rgba(20,33,57,0.07);color:#142139}body:not(.light) .input-toggles button{background:rgba(255,255,255,0.075);color:var(--text)}.input-toggles button.primary{background:linear-gradient(180deg,var(--primary),var(--primary-dark));color:white}.action-row{grid-template-columns:repeat(4,1fr);gap:8px}.action-row button{min-height:38px;padding:8px 6px;border-radius:14px;font-size:12px;background:rgba(20,33,57,0.06);color:#142139}body:not(.light) .action-row button{background:rgba(255,255,255,0.065);color:var(--text)}.quick-calibration-modal{max-height:calc(100dvh - 28px)}.quick-calibration-pad-wrap{aspect-ratio:1.25 / 1}.quick-calibration-actions,.quick-cal-manual{grid-template-columns:repeat(3,1fr)}.home-shell{padding:14px}.home-shell>section{margin-bottom:28px}.home-hero-card{padding:34px 18px 36px;border-radius:24px}.home-section>h2,.seo-copy-section>h2,.home-cta-card>h2{font-size:30px}.feature-grid,.seo-footer-grid,.leaderboard-grid{grid-template-columns:1fr}.home-card{min-height:auto}.home-actions{display:grid;grid-template-columns:1fr 1fr}.home-button{width:100%;min-height:54px}.daily-leaderboard-card{padding:20px}.leaderboard-panel{padding:18px}.leaderboard-header{display:block}.seo-footer-grid{gap:20px}.contribute-progress-top{flex-direction:column;gap:4px}.contribute-target-wrap{align-items:center}.contribute-card{border-radius:24px}.solver-layout{gap:18px}}@media (max-width:420px){body{padding-bottom:calc(220px + env(safe-area-inset-bottom))}.keypad-digits button{min-height:42px;font-size:20px;border-radius:13px}.input-toggles button{min-height:38px}.action-row button{min-height:34px;font-size:11px}.board-shell{max-height:calc(100vh - 292px)}.home-actions{grid-template-columns:1fr}}@media print{@page{size:landscape;margin:6mm}html,body{width:100%;height:100%;background:#ffffff !important;overflow:hidden !important}body{padding:0 !important}.printable-no-print{display:none !important}.app-shell,.printable-shell{width:100% !important;max-width:none !important;margin:0 !important;padding:0 !important;background:#ffffff !important}.printable-page{width:100% !important;height:calc(100vh - 12mm) !important;margin:0 !important;padding:6mm 7mm 5mm !important;border-radius:0 !important;box-shadow:none !important;background:#ffffff !important;overflow:hidden !important;page-break-after:avoid !important;page-break-before:avoid !important;page-break-inside:avoid !important;break-inside:avoid !important}.printable-page-header{margin-bottom:6mm !important}.printable-page-header h2{font-size:28pt !important;line-height:1 !important}.printable-page-header p{margin-top:4mm !important;font-size:13pt !important}.printable-grid-wrap{display:grid !important;grid-template-columns:repeat(2,1fr) !important;gap:9mm !important;align-items:start !important}.printable-puzzle-card h3{font-size:14pt !important;margin-bottom:4mm !important}.printable-board-wrap{background:#ffffff !important;overflow:hidden !important}.printable-sudoku-grid{width:100% !important;aspect-ratio:1 / 1 !important;background:transparent !important;border-width:3.5pt !important}.printable-cell{background:transparent !important;font-size:21pt !important;font-weight:900 !important;print-color-adjust:exact;-webkit-print-color-adjust:exact}.printable-grid-watermark{display:block !important;z-index:4 !important;color:rgba(20,28,45,0.055) !important;font-size:46pt !important;font-weight:950 !important;print-color-adjust:exact;-webkit-print-color-adjust:exact}}.breadcrumbs{width:min(1120px,calc(100% - 28px));margin:0 auto 18px;display:flex;flex-wrap:wrap;align-items:center;gap:8px;color:var(--muted);font-size:0.92rem}.breadcrumbs a{color:var(--text);text-decoration:none;border-bottom:1px solid rgba(255,255,255,0.22)}.breadcrumbs a:hover{color:var(--primary);border-bottom-color:var(--primary)}.related-links-card{width:min(1120px,calc(100% - 28px));margin:28px auto;padding:24px;border-radius:var(--radius-lg);background:radial-gradient(circle at top left,rgba(75,134,255,0.2),transparent 36%),rgba(255,255,255,0.065);border:1px solid rgba(255,255,255,0.12);box-shadow:var(--shadow-soft)}.related-links-card h2{margin:0 0 14px}.related-links-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.related-links-grid a{display:flex;align-items:center;min-height:48px;padding:12px 14px;border-radius:16px;color:var(--text);text-decoration:none;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.1)}.related-links-grid a:hover{background:rgba(75,134,255,0.18);border-color:rgba(75,134,255,0.46)}.site-footer{width:min(1120px,calc(100% - 28px));margin:34px auto 20px;padding:26px;border-radius:var(--radius-lg);background:rgba(3,9,24,0.58);border:1px solid rgba(255,255,255,0.11);box-shadow:var(--shadow-soft)}.site-footer-inner{display:grid;grid-template-columns:minmax(220px,0.8fr) minmax(0,2.2fr);gap:28px}.site-footer-logo{display:inline-flex;margin-bottom:10px;color:var(--text);font-size:1.25rem;font-weight:850;letter-spacing:-0.02em;text-decoration:none}.site-footer-brand p{max-width:320px;margin:0;color:var(--muted);line-height:1.55}.site-footer-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.site-footer-column h2{margin:0 0 10px;font-size:0.82rem;text-transform:uppercase;letter-spacing:0.09em;color:var(--muted)}.site-footer-column ul{list-style:none;margin:0;padding:0}.site-footer-column li + li{margin-top:8px}.site-footer-column a,.site-footer-bottom a{color:var(--text);text-decoration:none}.site-footer-column a:hover,.site-footer-bottom a:hover{color:var(--primary)}.site-footer-bottom{display:flex;justify-content:space-between;gap:14px;margin-top:22px;padding-top:16px;border-top:1px solid rgba(255,255,255,0.1);color:var(--muted);font-size:0.92rem}.sitemap-panel ul{margin:0 0 18px 1.1rem}.sitemap-panel li{margin:7px 0}.home-panel code{padding:2px 6px;border-radius:8px;background:rgba(255,255,255,0.09);color:var(--text)}@media (max-width:900px){.site-footer-inner{grid-template-columns:1fr}.site-footer-grid,.related-links-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:560px){.site-footer-grid,.related-links-grid{grid-template-columns:1fr}.site-footer,.related-links-card{padding:20px}.site-footer-bottom{flex-direction:column}}.seo-page-shell a,.home-panel a,.related-links-card a,.seo-footer a{color:#8fd3ff;text-decoration:none;text-underline-offset:4px;font-weight:700;transition:color 160ms ease,text-decoration-color 160ms ease,opacity 160ms ease}.seo-page-shell a:visited,.home-panel a:visited,.related-links-card a:visited,.seo-footer a:visited{color:#b7a6ff}.seo-page-shell a:hover,.home-panel a:hover,.related-links-card a:hover,.seo-footer a:hover{color:#ffffff;text-decoration:underline;text-decoration-color:rgba(143,211,255,0.85)}.seo-page-shell a:focus-visible,.home-panel a:focus-visible,.related-links-card a:focus-visible,.seo-footer a:focus-visible{outline:3px solid rgba(143,211,255,0.7);outline-offset:3px;border-radius:6px}.home-button,.home-button:visited,.home-actions a,.home-actions a:visited,.difficulty-grid a,.difficulty-grid a:visited{color:inherit;text-decoration:none}.related-links-card{max-width:1120px;margin:44px auto 28px;padding:24px 28px;border:1px solid rgba(148,163,184,0.18);border-radius:28px;background:linear-gradient(135deg,rgba(15,23,42,0.84),rgba(30,41,59,0.58));box-shadow:0 18px 44px rgba(0,0,0,0.24)}.related-links-card h2{margin:0 0 14px}.related-links-grid{display:flex;flex-wrap:wrap;gap:10px 18px}.related-links-grid a{display:inline-flex;align-items:center;min-height:34px}.seo-footer{max-width:1120px;margin:36px auto 32px;padding:30px 32px;border:1px solid rgba(148,163,184,0.18);border-radius:28px;background:linear-gradient(135deg,rgba(15,23,42,0.9),rgba(30,41,59,0.64));box-shadow:0 18px 44px rgba(0,0,0,0.26)}.seo-footer-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:28px}.seo-footer-column h3{margin:0 0 12px;font-size:1rem;color:#f8fafc}.seo-footer-column a{display:block;margin:0 0 9px;color:#cbd5e1;font-weight:650}.seo-footer-column a:visited{color:#cbd5e1}.seo-footer-column a:hover{color:#ffffff}.seo-footer-bottom{margin-top:24px;padding-top:18px;border-top:1px solid rgba(148,163,184,0.16);color:#e2e8f0}.seo-footer-bottom p{margin:0}@media (max-width:820px){.seo-footer-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.related-links-card,.seo-footer{margin-left:14px;margin-right:14px;padding:22px}}@media (max-width:520px){.seo-footer-grid{grid-template-columns:1fr}.related-links-grid{display:grid;grid-template-columns:1fr}}.related-links-card{max-width:1120px;margin:44px auto 28px;padding:24px 28px;border:1px solid rgba(148,163,184,0.18);border-radius:28px;background:linear-gradient(135deg,rgba(15,23,42,0.88),rgba(30,41,59,0.62));box-shadow:0 18px 44px rgba(0,0,0,0.24)}.related-links-card h2{margin:0 0 16px;font-size:clamp(24px,3vw,34px);color:#f8fafc}.related-links-grid{display:flex;flex-wrap:wrap;gap:12px}.related-links-card .related-links-grid a,.related-links-card .related-links-grid a:visited{display:inline-flex;align-items:center;justify-content:center;min-height:38px;padding:9px 14px;border:1px solid rgba(148,163,184,0.24);border-radius:999px;background:rgba(15,23,42,0.62);color:#e5f3ff !important;font-size:0.94rem;font-weight:800;line-height:1;text-decoration:none !important;box-shadow:inset 0 1px 0 rgba(255,255,255,0.06)}.related-links-card .related-links-grid a:hover{border-color:rgba(96,165,250,0.72);background:rgba(37,99,235,0.28);color:#ffffff !important;text-decoration:none !important;transform:translateY(-1px)}.related-links-card .related-links-grid a:focus-visible{outline:3px solid rgba(96,165,250,0.72);outline-offset:3px}.seo-footer a,.seo-footer a:visited,.seo-footer-column a,.seo-footer-column a:visited{color:#cbd5e1 !important;text-decoration:none !important}.seo-footer a:hover,.seo-footer-column a:hover{color:#ffffff !important;text-decoration:none !important}.breadcrumbs a,.breadcrumbs a:visited{color:#93c5fd !important;text-decoration:none !important;font-weight:800}.breadcrumbs a:hover{color:#ffffff !important;text-decoration:underline !important;text-underline-offset:4px}.sitemap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:28px}.sitemap-card{padding:24px;border-radius:24px;border:1px solid rgba(148,163,184,0.16);background:linear-gradient(135deg,rgba(15,23,42,0.82),rgba(30,41,59,0.58));box-shadow:0 16px 40px rgba(0,0,0,0.22)}.sitemap-card h2{margin:0 0 18px;font-size:1.5rem}.sitemap-links{list-style:none;margin:0;padding:0}.sitemap-links li + li{margin-top:12px}.sitemap-links a,.sitemap-links a:visited{color:#dbeafe;text-decoration:none;font-weight:700;font-size:1rem}.sitemap-links a:hover{color:#ffffff;text-decoration:underline;text-underline-offset:4px}.seo-page-shell{max-width:1180px;padding-top:22px !important;padding-bottom:40px !important}.breadcrumbs{margin:0 0 14px !important;font-size:14px}.home-hero-card.seo-hero-card{min-height:auto !important;padding:clamp(34px,5vw,72px) clamp(20px,5vw,64px) !important;margin-bottom:28px !important}.seo-hero-card h1{margin:12px 0 14px !important;line-height:0.95 !important}.home-subtitle{max-width:760px;margin-left:auto;margin-right:auto}.home-section{margin-top:30px !important;margin-bottom:0 !important}.seo-copy-section{margin-top:30px !important}.home-panel,.home-card,.related-links-card,.home-cta-card{padding:clamp(18px,3vw,30px) !important}.home-panel p:last-child,.home-card p:last-child{margin-bottom:0 !important}.feature-grid{gap:18px !important}.related-links-grid{gap:12px !important}.related-links-grid a,.home-panel a,.home-card a,.seo-copy-section a{color:#7dd3fc;font-weight:750;text-decoration:none;border-bottom:1px solid rgba(125,211,252,0.45);padding-bottom:1px}.related-links-grid a:hover,.home-panel a:hover,.home-card a:hover,.seo-copy-section a:hover{color:#bae6fd;border-bottom-color:#bae6fd}.home-actions{gap:12px !important}.seo-puzzle-showcase{grid-template-columns:minmax(0,1fr) minmax(260px,360px) !important;gap:clamp(20px,4vw,42px) !important;min-height:auto !important;padding:clamp(20px,4vw,34px) !important}.seo-puzzle-copy{align-self:center}.seo-puzzle-copy p{max-width:620px}.seo-sudoku-frame{max-width:390px;margin-left:auto;margin-right:auto}@media (max-width:820px){.seo-page-shell{padding-left:14px !important;padding-right:14px !important;padding-top:14px !important}.home-hero-card.seo-hero-card{padding:30px 18px !important;margin-bottom:22px !important}.seo-hero-card h1{font-size:clamp(42px,13vw,68px) !important}.home-subtitle{font-size:17px !important;line-height:1.45 !important}.home-actions{display:grid !important;grid-template-columns:1fr !important;width:100%}.home-button{width:100%;justify-content:center;text-align:center;min-height:48px}.home-section{margin-top:22px !important}.seo-puzzle-showcase{grid-template-columns:1fr !important}.seo-sudoku-frame{order:-1;width:100%}.seo-sudoku-preview{max-width:330px}.related-links-grid{grid-template-columns:1fr !important}.related-links-grid a{display:block;padding:13px 14px;border:1px solid rgba(125,211,252,0.22);border-radius:14px;background:rgba(15,23,42,0.72)}}body.coach-body #seoFooterMount,body.coach-body .seo-footer{display:block}@media (max-width:760px){.coach-page .breadcrumbs{display:none !important}.coach-page h1{font-size:22px !important;margin-bottom:4px !important}.coach-top-hint-card{padding:8px 10px !important}.coach-result-kicker{font-size:0.58rem}#coachTopHintMeta{font-size:0.86rem}#coachTopHintText{font-size:0.76rem;line-height:1.18;margin-top:4px}.coach-step-controls{margin-top:7px}.coach-step-controls button{min-height:28px}.coach-board-area{width:min(94vw,calc(100dvh - 270px)) !important}}.app-shell,.main-layout.premium-layout{width:min(1480px,calc(100% - 32px));margin-left:auto;margin-right:auto}.app-topbar{border-radius:24px;border:1px solid rgba(148,163,184,0.22);background:linear-gradient(135deg,rgba(37,99,235,0.13),transparent 34%),linear-gradient(180deg,rgba(255,255,255,0.06),rgba(255,255,255,0.015)),rgba(9,19,42,0.82);box-shadow:0 22px 70px rgba(0,0,0,0.32);backdrop-filter:blur(18px)}.app-topbar h1,.app-topbar h1 a,.brand-home-link,.brand-home-link h1{color:#f8fafc;text-decoration:none}.app-topbar .status,.app-topbar .meta{color:#b8c3d8}.solver-shell,.printable-shell,.coach-page{padding-top:24px;padding-bottom:60px}.solver-panel,.printable-controls,.side-panel{border-radius:22px;border:1px solid rgba(148,163,184,0.22);background:linear-gradient(180deg,rgba(255,255,255,0.055),rgba(255,255,255,0.015)),rgba(9,19,42,0.78);box-shadow:0 18px 54px rgba(0,0,0,0.26)}.board-shell,.solver-board-shell,.printable-puzzle-card,.coach-page .board-section{border-radius:24px}.compact-actions .home-button,.topbar-actions button,.solver-actions button,.printable-actions button,.coach-page button{border-radius:14px}.printable-page{border-radius:24px}@media (max-width:760px){.app-shell,.main-layout.premium-layout{width:calc(100% - 20px)}.app-topbar{border-radius:20px}}@media (min-width:1081px){.premium-layout .board-shell{width:min(58vw,calc(100dvh - 190px),660px) !important}.solver-layout .solver-board-shell{width:min(56vw,calc(100dvh - 210px),640px) !important}.premium-layout{grid-template-columns:minmax(520px,1fr) 310px !important;align-items:start !important}.solver-layout{grid-template-columns:minmax(500px,1fr) 360px !important;align-items:start !important}}@media (min-width:1081px) and (max-height:820px){.premium-layout .board-shell{width:min(54vw,calc(100dvh - 170px),600px) !important}.solver-layout .solver-board-shell{width:min(52vw,calc(100dvh - 190px),585px) !important}}@media (max-width:1080px){.premium-layout .board-shell,.solver-layout .solver-board-shell{width:min(92vw,720px) !important}}@media (min-width:761px) and (max-width:920px) and (orientation:portrait){body{padding-bottom:calc(238px + env(safe-area-inset-bottom))}.main-layout,.premium-layout,.solver-layout{grid-template-columns:1fr !important;gap:18px !important}.side-panel,.premium-panel,.solver-panel{width:100% !important;margin:0 auto !important}.premium-layout .board-shell,.solver-layout .solver-board-shell{width:min(92vw,calc(100dvh - 310px),720px) !important}.play-controls{position:fixed !important;left:14px !important;right:14px !important;bottom:calc(14px + env(safe-area-inset-bottom)) !important;z-index:40 !important;width:auto !important;margin:0 !important;padding:12px !important;display:grid !important;grid-template-areas:"keypad" "input" "actions" !important;gap:10px !important;border-radius:26px !important;background:linear-gradient(180deg,rgba(19,32,65,0.96),rgba(12,22,46,0.94)),var(--panel) !important;color:var(--text) !important;border:1px solid rgba(255,255,255,0.10) !important;box-shadow:0 -18px 60px rgba(20,33,57,0.18),0 10px 26px rgba(20,33,57,0.10) !important;backdrop-filter:blur(18px) !important;-webkit-backdrop-filter:blur(18px) !important}.keypad-group{grid-area:keypad !important}.input-group{grid-area:input !important}.actions-group{grid-area:actions !important}.play-controls .panel-title{display:none !important}.keypad-digits{grid-template-columns:repeat(9,1fr) !important;gap:6px !important}.keypad-digits button{min-height:48px !important;padding:0 !important;border-radius:15px !important;font-size:22px !important;font-weight:850 !important}.input-toggles{grid-template-columns:1fr 1fr !important;gap:8px !important}.input-toggles button{min-height:42px !important;border-radius:15px !important;font-size:14px !important}.action-row{grid-template-columns:repeat(4,1fr) !important;gap:8px !important}.action-row button{min-height:38px !important;padding:8px 6px !important;border-radius:14px !important;font-size:12px !important}}@media (min-width:921px),(orientation:landscape){.play-controls{position:static}}@media (max-width:1080px) and (orientation:portrait){body{padding-bottom:0 !important}.main-layout,.premium-layout,.solver-layout{grid-template-columns:1fr !important;gap:18px !important}.premium-layout .board-shell,.solver-layout .solver-board-shell{width:min(92vw,calc(100dvh - 260px),680px) !important;aspect-ratio:1 / 1 !important;max-height:none !important}.side-panel,.premium-panel,.solver-panel,.play-controls{position:static !important;width:min(92vw,680px) !important;margin:0 auto !important}.play-controls{display:grid !important;gap:12px !important;padding:14px !important}.keypad-digits{grid-template-columns:repeat(9,1fr) !important;gap:6px !important}.keypad-digits button{min-height:44px !important;font-size:18px !important}.input-toggles{grid-template-columns:1fr 1fr !important}.action-row{grid-template-columns:repeat(4,1fr) !important}}@media (min-width:768px) and (orientation:landscape){.main-layout,.premium-layout{grid-template-columns:minmax(420px,1fr) 310px !important;align-items:start !important}.solver-layout{grid-template-columns:minmax(420px,1fr) 360px !important;align-items:start !important}.premium-layout .board-shell{width:min(58vw,calc(100dvh - 190px),660px) !important;aspect-ratio:1 / 1 !important}.solver-layout .solver-board-shell{width:min(56vw,calc(100dvh - 210px),640px) !important;aspect-ratio:1 / 1 !important}.side-panel,.premium-panel{width:310px !important;margin:0 !important}.solver-panel{width:360px !important;margin:0 !important}.play-controls{position:static !important}.keypad-digits{grid-template-columns:repeat(3,1fr) !important}.action-row{grid-template-columns:repeat(2,1fr) !important}}@media (max-width:480px){.premium-layout .board-shell,.solver-layout .solver-board-shell{width:min(96vw,calc(100dvh - 260px)) !important}.side-panel,.premium-panel,.solver-panel,.play-controls{width:96vw !important}}@media (max-width:767px){body{padding-bottom:0 !important}.main-layout,.premium-layout,.solver-layout{display:grid !important;grid-template-columns:1fr !important;gap:14px !important}.premium-layout .board-shell,.solver-layout .solver-board-shell{width:calc(100vw - 28px) !important;max-width:calc(100vw - 28px) !important;height:calc(100vw - 28px) !important;max-height:none !important;aspect-ratio:1 / 1 !important;margin:0 auto !important}.play-controls,.premium-panel,.solver-panel,.side-panel{position:static !important;width:calc(100vw - 28px) !important;max-width:calc(100vw - 28px) !important;margin:0 auto !important;padding:12px !important}.keypad-digits{grid-template-columns:repeat(9,1fr) !important;gap:5px !important}.keypad-digits button{min-height:38px !important;padding:0 !important;border-radius:12px !important;font-size:16px !important}.input-toggles{grid-template-columns:1fr 1fr !important;gap:8px !important}.action-row{grid-template-columns:repeat(4,1fr) !important;gap:8px !important}.action-row button{min-height:36px !important;font-size:11px !important}#seoFooterMount,.seo-footer{display:none !important}}body:has(.premium-layout) #seoFooterMount,body:has(.solver-shell) #seoFooterMount,body:has(.premium-layout) .seo-footer,body:has(.solver-shell) .seo-footer{display:none !important}@media (max-width:767px) and (orientation:landscape){body::before{content:"SudoSketch works best in portrait on phones.";position:fixed;z-index:9999;left:10px;right:10px;top:10px;padding:10px 12px;border-radius:14px;background:rgba(15,23,42,0.94);color:#f8fafc;text-align:center;font-weight:800;box-shadow:0 12px 34px rgba(0,0,0,0.28)}}@media (max-width:767px){body{padding-bottom:0 !important;background:radial-gradient(circle at 10% 0%,rgba(75,134,255,0.22),transparent 34%),linear-gradient(145deg,#071023,#0b1630) !important}.app-shell{width:100% !important;max-width:100% !important;padding:12px 10px 24px !important;margin:0 auto !important}.topbar.app-topbar{width:min(100%,680px) !important;margin:0 auto 12px !important;padding:12px !important}.main-layout.premium-layout{width:100% !important;max-width:100% !important;display:grid !important;grid-template-columns:1fr !important;justify-items:center !important;gap:12px !important;margin:0 auto !important}.board-section{width:100% !important;display:flex !important;justify-content:center !important}.premium-layout .board-shell{width:min(calc(100vw - 20px),680px) !important;height:min(calc(100vw - 20px),680px) !important;max-width:min(calc(100vw - 20px),680px) !important;max-height:none !important;margin:0 auto !important;padding:6px !important;aspect-ratio:1 / 1 !important}.premium-layout .board{width:100% !important;height:100% !important}.play-controls,.premium-panel{position:static !important;width:min(calc(100vw - 20px),680px) !important;max-width:min(calc(100vw - 20px),680px) !important;margin:0 auto !important;padding:12px !important;border-radius:24px !important;background:linear-gradient(180deg,rgba(19,32,65,0.98),rgba(12,22,46,0.96)) !important;border:1px solid rgba(255,255,255,0.12) !important;box-shadow:0 18px 46px rgba(0,0,0,0.32) !important;color:#f8fafc !important}.play-controls button,.premium-panel button{background:rgba(255,255,255,0.075) !important;color:#f8fafc !important;opacity:1 !important;border:1px solid rgba(255,255,255,0.08) !important}.play-controls button.primary,.premium-panel button.primary{background:linear-gradient(180deg,#4b86ff,#2f64c8) !important;color:#ffffff !important}.keypad-digits{grid-template-columns:repeat(9,1fr) !important;gap:6px !important}.keypad-digits button{min-height:42px !important;padding:0 !important;border-radius:13px !important;font-size:16px !important}.input-toggles{grid-template-columns:1fr 1fr !important;gap:8px !important}.action-row{grid-template-columns:repeat(4,1fr) !important;gap:8px !important}.action-row button{min-height:36px !important;font-size:11px !important}#seoFooterMount,.seo-footer{display:none !important}}