:root{color:#0f3034;background:#f7f2e8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input{font:inherit}button{border:1px solid #b9c5bd;border-radius:8px;background:#fff;color:#0f3034;min-height:44px;padding:.65rem .9rem;cursor:pointer}button:disabled,input:disabled{cursor:not-allowed;opacity:.55}button:focus-visible,input:focus-visible{outline:3px solid rgba(20,92,90,.28);outline-offset:2px}.app-shell{min-height:100vh;padding:max(1rem,env(safe-area-inset-top)) max(1rem,env(safe-area-inset-right)) max(1rem,env(safe-area-inset-bottom)) max(1rem,env(safe-area-inset-left))}.workspace{width:min(1180px,100%);margin:0 auto}.top-bar,.board-toolbar,.actions,.session-pill,.session-stack{display:flex;align-items:center}.top-bar{justify-content:space-between;gap:1rem;padding:1.25rem 0 1.5rem}h1,h2,p{margin:0}h1{font-size:clamp(2rem,5vw,4.8rem);line-height:.95}h2{font-size:1.25rem}.eyebrow{color:#d0523f;font-size:.74rem;font-weight:800;letter-spacing:0;text-transform:uppercase}.session-pill{justify-content:flex-end;gap:.6rem;max-width:100%;color:#456366;font-size:.9rem}.session-stack{justify-content:flex-end;flex-wrap:wrap;gap:.5rem}.network-pill,.install-button,.update-button{min-height:36px;border-radius:999px;padding:.4rem .7rem;font-size:.85rem;font-weight:800}.install-button{border-color:#145c5a;color:#145c5a}.network-pill.online{background:#d9ede2;color:#145c5a}.network-pill.offline{background:#ffe0d9;color:#a33b28}.session-pill span{overflow-wrap:anywhere}.content-grid{display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:1rem;align-items:start}.auth-panel,.capture-panel,.saved-panel,.board-panel{background:#ffffffb8;border:1px solid #d7ddd4;border-radius:8px;padding:1rem}.capture-panel,.saved-panel{display:grid;gap:.85rem}.panel-heading,.board-toolbar{margin-bottom:1rem}.auth-panel form{display:grid;gap:.85rem}label{display:grid;gap:.35rem;color:#456366;font-weight:700}input{width:100%;min-height:46px;border:1px solid #b9c5bd;border-radius:8px;padding:0 .75rem;background:#fff;color:#0f3034}input[type=file]{min-height:auto;border:0;padding:0;background:transparent}.file-picker{color:#456366}.preview-image{width:100%;aspect-ratio:4 / 3;object-fit:cover;border:1px solid #d7ddd4;border-radius:8px;background:#fff}.segmented-control{display:grid;grid-template-columns:repeat(3,1fr);gap:.35rem}.segmented-control button{padding-inline:.4rem;font-weight:800}.segmented-control .active{border-color:#145c5a;background:#e0f0ef}.full-width{width:100%}.primary-button{border-color:#145c5a;background:#145c5a;color:#fff;font-weight:800}.text-button{border:0;padding-inline:0;color:#145c5a;background:transparent;font-weight:800}.message{color:#456366;margin-top:.8rem;line-height:1.45}.small-note{color:#456366;font-size:.9rem;line-height:1.35}.saved-list{display:grid;gap:.45rem;max-height:260px;overflow:auto}.saved-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.4rem;align-items:stretch}.saved-main{display:grid;justify-items:start;gap:.2rem;min-width:0;text-align:left}.saved-main span,.saved-main small{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.saved-main small{color:#456366;font-size:.78rem}.delete-button{color:#a33b28;padding-inline:.65rem}.board-toolbar{justify-content:space-between;gap:1rem}.status-ok,.status-error{min-width:84px;text-align:center;border-radius:999px;padding:.35rem .7rem;font-weight:800}.status-ok{background:#d9ede2;color:#145c5a}.status-error{background:#ffe0d9;color:#a33b28}.sudoku-board{display:grid;grid-template-columns:repeat(9,1fr);width:min(100%,610px);aspect-ratio:1;border:3px solid #0f3034;background:#0f3034}.cell{display:grid;place-items:center;min-height:0;padding:0;border:1px solid #b9c5bd;border-radius:0;background:#fff;color:#145c5a;font-size:clamp(1.1rem,6vw,2.2rem);font-weight:800}.cell:nth-child(3n){border-right-color:#0f3034;border-right-width:3px}.cell:nth-child(n+19):nth-child(-n+27),.cell:nth-child(n+46):nth-child(-n+54){border-bottom-color:#0f3034;border-bottom-width:3px}.cell:nth-child(9n){border-right-width:1px}.cell.selected{background:#e0f0ef;box-shadow:inset 0 0 0 3px #d0523f}.cell.given{color:#0f3034}.digit-pad{display:grid;grid-template-columns:repeat(10,minmax(44px,1fr));gap:.4rem;margin-top:1rem}.digit-pad button{padding-inline:.3rem;font-weight:800}.actions{gap:.6rem;margin-top:1rem}@media(max-width:820px){.top-bar,.content-grid{display:grid}.content-grid{grid-template-columns:1fr}.session-pill,.session-stack{justify-content:start}.digit-pad{grid-template-columns:repeat(5,minmax(44px,1fr))}}
