*{box-sizing:border-box}body{margin:0;font-family:SF Pro Text,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;background:radial-gradient(120% 80% at 50% -20%,#1a2a3a,#0f1419 45%);color:#e7e9ea;min-height:100vh;min-height:100dvh}.app{display:flex;flex-direction:column;align-items:center;justify-content:flex-start;min-height:100vh;min-height:100dvh;padding:clamp(.75rem,3vw,1.5rem) clamp(.75rem,4vw,1.25rem) clamp(1.5rem,5vw,2.5rem);text-align:center;gap:clamp(.85rem,3vw,1.35rem);max-width:32rem;margin-inline:auto}.app-header{display:flex;flex-direction:column;align-items:center;gap:.35rem}h1{font-size:clamp(1.25rem,4.2vw,1.75rem);font-weight:700;letter-spacing:-.02em;margin:0;color:#f7f9f9}.api-status{margin:0;font-size:clamp(.75rem,2.8vw,.85rem);color:#8b98a5}.card-surface{background:#1a2228b8;border:1px solid rgba(255,255,255,.06);border-radius:14px;box-shadow:0 1px #ffffff0a inset,0 12px 40px #00000059;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.55rem 1rem;width:100%;padding:.65rem .85rem}.toolbar-label{font-size:.72rem;color:#8b98a5;text-transform:uppercase;letter-spacing:.08em;font-weight:600}.size-toggle{display:flex;gap:.35rem;flex-wrap:wrap;justify-content:center}.size-toggle button{padding:.42rem .72rem;min-height:40px;border:1px solid rgba(255,255,255,.08);border-radius:10px;background:#0f141999;color:#e7e9ea;font-size:.8125rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease}.size-toggle button:hover{background:#22303cd9}.size-toggle button.active{border-color:#1d9bf08c;background:#1d9bf01f;color:#8ecdf9}.sudoku-stage{width:100%;display:flex;flex-direction:column;align-items:center;gap:.5rem}.sudoku-scroll{width:100%;max-width:100%;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;overscroll-behavior-x:contain;padding:2px 0 6px;display:flex;justify-content:center}.sudoku-scroll--loading{pointer-events:none}.sudoku-wrap{--n: 9;--box: 3;position:relative;width:min(100%,calc(var(--n) * min(2.55rem,11vw) + 14px));flex-shrink:0;margin-inline:auto;padding:7px}.sudoku-grid{display:grid;grid-template-columns:repeat(var(--n),minmax(0,1fr));gap:0;padding:3px;background:#2f3d4a;border-radius:10px;border:2px solid rgba(255,255,255,.12);box-shadow:0 4px 24px #00000040}.sudoku-cell{width:100%;aspect-ratio:1;min-width:0;min-height:28px;border:1px solid rgba(47,61,74,.9);margin:0;text-align:center;font-variant-numeric:tabular-nums;font-weight:600;color:#f0f3f5;font-size:clamp(.65rem,calc(2.8vw + .35rem),1.05rem);padding:0;transition:background .12s ease,color .12s ease}.sudoku-cell--box-a{background:#1e2a36}.sudoku-cell--box-b{background:#17212c}.sudoku-cell--box-solved-a{background:#152a22}.sudoku-cell--box-solved-b{background:#12231c}.sudoku-cell:focus{outline:2px solid #1d9bf0;outline-offset:-2px;z-index:2;position:relative}.sudoku-cell.thick-right{border-right-width:3px;border-right-color:#ffffff38}.sudoku-cell.thick-bottom{border-bottom-width:3px;border-bottom-color:#ffffff38}.sudoku-cell--given{color:#0a0a0a!important;background:#e8ecf0!important}.sudoku-cell--solved{color:#4ade80}.sudoku-cell--locked{cursor:default;pointer-events:none}.sudoku-cell--locked:focus{outline:none}.sudoku-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.85rem;background:#0a0e12c7;border-radius:14px;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:10}.sudoku-loading__spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.12);border-top-color:#1d9bf0;border-radius:50%;animation:spin .75s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sudoku-loading__text{margin:0;font-size:.95rem;font-weight:600;color:#e7e9ea}.hint-text{margin:0;font-size:clamp(.78rem,2.5vw,.88rem);color:#8b98a5;max-width:20rem;line-height:1.4}.error-banner{display:flex;align-items:flex-start;gap:.65rem;width:100%;max-width:100%;padding:.65rem .85rem;text-align:left;border-radius:12px;background:#f4212e1a;border:1px solid rgba(244,33,46,.35)}.error-banner__icon{flex-shrink:0;width:1.35rem;height:1.35rem;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#f4212e40;color:#ff8a90;font-size:.85rem;font-weight:800;line-height:1}.error-banner__msg{margin:0;font-size:clamp(.8rem,2.6vw,.9rem);color:#ff9ba3;line-height:1.45}.action-bar{display:flex;flex-wrap:wrap;align-items:stretch;justify-content:center;gap:.45rem .55rem;width:100%}.action-bar .btn-secondary,.action-bar .solve-btn{flex:1 1 auto;min-width:min(100%,7.5rem);min-height:44px}.btn-secondary{padding:.55rem 1rem;font-size:.875rem;font-weight:600;border:1px solid rgba(255,255,255,.1);border-radius:12px;background:#161e26e6;color:#e7e9ea;cursor:pointer;transition:background .15s ease}.btn-secondary:hover:not(:disabled){background:#22303cf2}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.solve-btn{padding:.55rem 1.25rem;font-size:.9375rem;font-weight:700;border:none;border-radius:12px;background:linear-gradient(165deg,#1d9bf0,#1886d0);color:#fff;cursor:pointer;box-shadow:0 4px 16px #1d9bf047;transition:filter .15s ease,box-shadow .15s ease}.solve-btn:hover:not(:disabled){filter:brightness(1.06);box-shadow:0 6px 20px #1d9bf059}.solve-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}@media(min-width:380px){.action-bar{flex-wrap:nowrap}.action-bar .btn-secondary{flex:0 1 auto;min-width:unset}.action-bar .solve-btn{flex:1.15 1 auto}}@media(min-width:480px){.app{max-width:36rem}.sudoku-wrap{width:min(100%,calc(var(--n) * 2.65rem + 14px))}}
