:root{color-scheme:dark;--color-bg: #0f0f1a;--color-surface: #1a1a2e;--color-card: #16213e;--color-cell-bg: #232136;--color-accent: #ffd700;--color-accent-muted: #c9a84c;--color-text: #e8e8e8;--color-text-muted: #9a9ab0;--color-error: #e63946;--color-success: #2a9d8f;--color-cell-border: rgba(255, 255, 255, .22);--color-region-border: #c9a84c;--color-overlay: rgba(5, 6, 18, .76);--shadow-panel: 0 24px 60px rgba(0, 0, 0, .35);--font-display: "Cinzel", "Times New Roman", serif;--font-body: "Manrope", system-ui, sans-serif;--board-max: min(82vw, 700px);--cell-min: 40px;--space-page: clamp(16px, 2vw, 28px)}html.light{color-scheme:light;--color-bg: #f5f0e8;--color-surface: #ffffff;--color-card: #f0ebe0;--color-cell-bg: #f3f5fd;--color-accent: #b8960c;--color-accent-muted: #8a7a5a;--color-text: #1a1a2e;--color-text-muted: #6a6a80;--color-error: #c5303c;--color-success: #228578;--color-cell-border: rgba(0, 0, 0, .18);--color-region-border: #8a7a5a;--color-overlay: rgba(20, 16, 10, .36);--shadow-panel: 0 24px 40px rgba(74, 59, 30, .14)}*{box-sizing:border-box}html,body{min-height:100%}body{margin:0;background:radial-gradient(circle at top,rgba(255,215,0,.1),transparent 32%),linear-gradient(180deg,rgba(22,33,62,.65),transparent 28%),var(--color-bg);color:var(--color-text);font-family:var(--font-body)}button,input,select{font:inherit}button{color:inherit}.app-shell{max-width:780px;margin:0 auto;min-height:100vh;display:grid;grid-template-rows:auto 1fr auto;gap:1rem;padding:max(1rem,env(safe-area-inset-top)) 1rem max(1rem,env(safe-area-inset-bottom))}.topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.topbar{display:grid;grid-template-columns:1fr auto;gap:.25rem 1rem;align-items:center;padding:16px 20px;border:1px solid rgba(201,168,76,.18);border-radius:20px;background:linear-gradient(135deg,#1a1a2ef2,#16213ed9);box-shadow:var(--shadow-panel)}html.light .topbar{background:linear-gradient(135deg,#fffffff5,#f0ebe0f0)}.brand-title{margin:0;font-family:var(--font-display);font-weight:700;letter-spacing:.15em}.brand-title{font-size:clamp(1.4rem,4vw,1.8rem)}.topbar .icon-button-group{grid-column:2;grid-row:1 / 3;align-self:center}.seed-display,.timer-chip{margin:0;color:var(--color-text-muted);font-size:.9rem;background:none;border:none;padding:0}html.light .seed-display,html.light .timer-chip,html.light .status-pill{background:#1a1a2e0a}.main{display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.footer{background:var(--color-surface);border:1px solid var(--color-cell-border);border-radius:14px;padding:.75rem;box-shadow:var(--shadow-panel)}.icon-button-group{display:flex;gap:.4rem}.icon-button{width:44px;height:44px;border:1px solid rgba(201,168,76,.24);border-radius:14px;background:#ffffff0a;cursor:pointer}.icon-button:hover,.icon-button:focus-visible{border-color:var(--color-accent);outline:none}.board-stage{position:relative;display:grid;place-items:center;width:min(100%,560px)}.board-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-content:center;gap:12px;border-radius:20px;background:#0a0a18ad;text-align:center;z-index:10}html.light .board-loading{background:#f5f0e8d1}.spinner{width:40px;height:40px;border-radius:999px;border:3px solid rgba(255,215,0,.24);border-top-color:var(--color-accent);animation:spin .9s linear infinite}.board-legend{display:flex;justify-content:center;gap:1rem;margin-top:16px;color:var(--color-text-muted);font-size:.94rem}.legend-item{display:inline-flex;align-items:center;gap:.3rem;color:var(--color-text-muted);font-size:.85rem}.legend-swatch{width:16px;height:16px;border-radius:4px;border:1px solid var(--color-cell-border)}.legend-swatch-queen{background:#ffd7003d}.legend-swatch-x{background:linear-gradient(135deg,transparent 40%,rgba(232,232,232,.35) 40%,rgba(232,232,232,.35) 60%,transparent 60%)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.hidden{display:none!important}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.app-shell{padding-inline:.65rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.board{--board-size: 5;display:grid;grid-template-columns:repeat(var(--board-size),1fr);grid-template-rows:repeat(var(--board-size),1fr);aspect-ratio:1 / 1;width:100%;max-width:var(--board-max);min-width:calc(var(--board-size) * 40px);border-right:3px solid var(--color-region-border);border-bottom:3px solid var(--color-region-border);border-radius:8px;overflow:hidden;touch-action:none;-webkit-user-select:none;user-select:none}.board.is-scrollable{justify-content:start;width:100%;overflow-x:auto;touch-action:pan-x pan-y}.board-cell{position:relative;display:grid;place-items:center;aspect-ratio:1 / 1;padding:4px;border:none;border-top-style:solid;border-left-style:solid;border-bottom-style:none;border-right-style:none;background:none;color:var(--color-text);cursor:pointer;transition:transform .14s ease,box-shadow .14s ease,filter .14s ease;-webkit-tap-highlight-color:transparent;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none;text-decoration:none}.board-cell:focus,.board-cell:active{outline:none;border-bottom-style:none;border-right-style:none;text-decoration:none}@media(hover:hover)and (pointer:fine){.board-cell:hover{transform:translateY(-1px);filter:saturate(1.04)}}.board-cell:focus-visible,.board-cell.is-focused{outline:none}.board-cell.is-conflict:after{content:"";position:absolute;top:3px;right:3px;bottom:3px;left:3px;border:3px solid var(--color-error);border-radius:10px;animation:conflict-pulse 1s ease-in-out infinite}.board-cell.is-highlighted:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,rgba(255,255,255,.16),transparent 70%)}.board-cell.is-hinted:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#ffd70026;pointer-events:none;z-index:1}.board-cell.is-hinted-target{outline:3px solid var(--color-accent);outline-offset:-3px;animation:hint-pulse 1s ease-in-out infinite;z-index:3}.board-cell.is-hint-error{outline:3px solid #e63946;outline-offset:-3px;animation:hint-pulse-error 1s ease-in-out infinite;z-index:3}.board-cell.is-hint-warning{outline:3px solid #f4a261;outline-offset:-3px;animation:hint-pulse-warning 1s ease-in-out infinite;z-index:3}.board-cell[data-state=x] .cell-mark,.board-cell[data-state=queen] .cell-mark{opacity:1;transform:scale(1)}.board-cell[data-state=empty] .cell-mark{opacity:0;transform:scale(.85)}.cell-mark{width:60%;height:60%;opacity:0;transform:scale(.85);transition:opacity .15s ease,transform .15s ease;pointer-events:none}.cell-mark svg{width:100%;height:100%;display:block}.cell-mark-queen{color:gold}.cell-mark-queen svg{filter:drop-shadow(0 1px 3px rgba(0,0,0,.4))}.cell-mark-x{color:currentColor;opacity:.35}.board-cell[data-state=queen] .cell-mark-x,.board-cell[data-state=x] .cell-mark-queen,.board-cell[data-state=empty] .cell-mark-queen,.board-cell[data-state=empty] .cell-mark-x{display:none}.board-cell[data-state=queen] .cell-mark-queen,.board-cell[data-state=x] .cell-mark-x{display:block}@keyframes conflict-pulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes hint-pulse{0%,to{outline-color:#ffd70080}50%{outline-color:gold}}@keyframes hint-pulse-error{0%,to{outline-color:#e6394680}50%{outline-color:#e63946}}@keyframes hint-pulse-warning{0%,to{outline-color:#f4a26180}50%{outline-color:#f4a261}}.hint-toast{margin-top:16px;opacity:0;transform:translateY(12px);transition:opacity .2s ease-out,transform .2s ease-out}.hint-toast.is-visible{opacity:1;transform:translateY(0)}.hint-toast-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 18px;border-left:4px solid var(--color-accent);border-radius:18px;background:color-mix(in srgb,var(--color-surface) 92%,transparent);box-shadow:var(--shadow-panel)}.hint-toast-copy{display:flex;align-items:center;gap:12px}.hint-toast-icon{flex:0 0 auto}@media(max-width:359px){.board{justify-content:start}}@media(max-width:640px){.hint-toast-card{flex-direction:column;align-items:stretch}}.controls{display:grid;gap:.6rem}.control-row{display:flex;gap:.5rem}.control-row:last-child{margin-bottom:0}.controls-row-center{align-items:center;justify-content:center}.controls-label{color:var(--color-text-muted);font-size:.95rem;white-space:nowrap}.btn{flex:1;min-height:44px;border:1px solid var(--color-cell-border);border-radius:10px;padding:.5rem .8rem;background:var(--color-cell-bg);color:var(--color-text);cursor:pointer;font-size:.95rem}.btn:disabled{opacity:.45;cursor:not-allowed}.btn.active,.btn-primary{border-color:color-mix(in srgb,var(--color-accent) 60%,var(--color-cell-border));background:color-mix(in srgb,var(--color-cell-bg) 70%,var(--color-accent) 30%)}.auto-x-btn:not(.active){opacity:.55}.size-group{display:inline-flex;gap:.4rem;margin-left:.5rem}.size-group .btn{flex:0;min-width:44px}.seed-group{display:flex;align-items:center;gap:.5rem;width:100%}.seed-label{flex-shrink:0}.seed-input{flex:1;min-height:44px;border-radius:10px;border:1px solid var(--color-cell-border);padding:.45rem .65rem;background:var(--color-cell-bg);color:var(--color-text);font-size:.95rem}.seed-input:focus{outline:2px solid var(--color-accent);outline-offset:1px}.seed-go-btn{flex:0 0 auto;min-width:56px}@media(max-width:520px){.control-row{flex-wrap:wrap}}#modal-root{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;pointer-events:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;padding:20px;background:var(--color-overlay);opacity:0;pointer-events:auto;transition:opacity .18s ease}.modal-overlay.is-open{opacity:1}.modal-card{width:min(100%,540px);max-height:min(90vh,760px);overflow:auto;padding:24px;border-radius:24px;border:1px solid rgba(201,168,76,.26);background:linear-gradient(180deg,var(--color-card),color-mix(in srgb,var(--color-surface) 86%,transparent));box-shadow:var(--shadow-panel)}.modal-card.modal-wide{width:min(100%,760px)}.modal-title{margin:0;font-family:var(--font-display);font-size:1.7rem}.modal-copy{margin:10px 0 0;color:var(--color-text-muted)}.modal-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px}.modal-close{position:absolute;top:14px;right:14px}.settings-list,.tutorial-step-list{display:grid;gap:14px;margin-top:18px}.settings-item{display:flex;justify-content:space-between;gap:12px;align-items:center;padding:12px 14px;border-radius:16px;background:#ffffff0a}.settings-copy{display:grid;gap:2px}.settings-copy strong{font-weight:600}.toggle{width:52px;height:30px;border-radius:999px;border:1px solid rgba(201,168,76,.28);background:#ffffff14;position:relative;cursor:pointer}.toggle:after{content:"";position:absolute;top:3px;left:4px;width:22px;height:22px;border-radius:999px;background:var(--color-text);transition:transform .14s ease}.toggle.is-on{background:#ffd7002e}.toggle.is-on:after{transform:translate(21px);background:var(--color-accent)}.win-stats{display:grid;gap:10px;margin-top:20px}.win-stat{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:#ffffff0d}.tutorial-board{--tutorial-size: 4;display:grid;grid-template-columns:repeat(4,minmax(54px,1fr));gap:0;max-width:260px;margin:18px auto 0;border-radius:20px;overflow:hidden;border:1px solid rgba(201,168,76,.18)}.tutorial-cell{aspect-ratio:1;display:grid;place-items:center;border:1px solid rgba(255,255,255,.08);font-size:1.4rem}.tutorial-cell.is-target{outline:3px solid var(--color-accent);outline-offset:-3px}.tutorial-cell.is-neighbor{box-shadow:inset 0 0 0 3px #e6394673}.settings-footer{display:flex;justify-content:space-between;gap:10px;margin-top:20px}:root{--cb-stroke: rgba(0,0,0,.25);--cb-stroke-light: rgba(0,0,0,.15)}html.light{--cb-stroke: rgba(0,0,0,.15)}html.colorblind .board-cell[data-region="1"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='12' x2='12' y2='0' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="2"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='6' x2='12' y2='6' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="3"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Ccircle cx='6' cy='6' r='2' fill='rgba(0,0,0,0.25)'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="4"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='6' y1='0' x2='6' y2='12' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="5"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='6' y1='0' x2='6' y2='12' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3Cline x1='0' y1='6' x2='12' y2='6' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="6"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='0' x2='12' y2='12' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3Cline x1='12' y1='0' x2='0' y2='12' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:12px 12px}html.colorblind .board-cell[data-region="7"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='12'%3E%3Cpath d='M0 6 Q6 2 12 6 Q18 10 24 6' fill='none' stroke='rgba(0,0,0,0.25)' stroke-width='1.5'/%3E%3C/svg%3E");background-size:24px 12px}html.colorblind .board-cell[data-region="8"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Crect x='0' y='0' width='6' height='6' fill='rgba(0,0,0,0.25)'/%3E%3Crect x='6' y='6' width='6' height='6' fill='rgba(0,0,0,0.25)'/%3E%3C/svg%3E");background-size:12px 12px}html.light.colorblind .board-cell[data-region="1"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='12' x2='12' y2='0' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="2"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='6' x2='12' y2='6' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="3"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Ccircle cx='6' cy='6' r='2' fill='rgba(0,0,0,0.15)'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="4"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='6' y1='0' x2='6' y2='12' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="5"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='6' y1='0' x2='6' y2='12' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3Cline x1='0' y1='6' x2='12' y2='6' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="6"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cline x1='0' y1='0' x2='12' y2='12' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3Cline x1='12' y1='0' x2='0' y2='12' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="7"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='12'%3E%3Cpath d='M0 6 Q6 2 12 6 Q18 10 24 6' fill='none' stroke='rgba(0,0,0,0.15)' stroke-width='1.5'/%3E%3C/svg%3E")}html.light.colorblind .board-cell[data-region="8"]{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Crect x='0' y='0' width='6' height='6' fill='rgba(0,0,0,0.15)'/%3E%3Crect x='6' y='6' width='6' height='6' fill='rgba(0,0,0,0.15)'/%3E%3C/svg%3E")}
