@keyframes point-pop{0%{transform:scale(1)}50%{transform:scale(1.14)}to{transform:scale(1)}}@keyframes line-draw{0%{stroke-dasharray:0 400}to{stroke-dasharray:400 0}}@keyframes target-pulse{0%,to{filter:drop-shadow(0 0 0 rgba(250,204,21,0));transform:scale(1)}50%{filter:drop-shadow(0 0 6px rgba(250,204,21,.72));transform:scale(1.08)}}@keyframes result-rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes confetti-fall{0%{opacity:0;transform:translateY(-26px) rotate(0) scale(.7)}to{opacity:1;transform:translateY(72px) rotate(220deg) scale(1)}}@keyframes star-burst{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes blank-flip{0%{transform:scaleX(1)}48%{transform:scaleX(.18)}to{transform:scaleX(1)}}.target-pulse circle{animation:target-pulse 1.4s ease-in-out infinite}.line-draw{animation:line-draw .28s ease-out}.result-rise{animation:result-rise .24s ease-out}.confetti-fall{animation:confetti-fall 1.35s ease-out both}.blank-flip{animation:blank-flip .26s ease-out;transform-box:fill-box;transform-origin:center}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Noto Sans SC,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.hidden{display:none}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{color:#111827;background:#e0f7fa;font-family:Nunito,Comic Sans MS,ui-rounded,Hiragino Maru Gothic ProN,Yu Gothic,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-height:100vh}button,input,select{font:inherit}#root{min-height:100vh}.game-page{min-height:100vh;overflow-x:hidden;background:radial-gradient(circle at 12px 12px,rgba(255,255,255,.7) 0 7px,transparent 8px),radial-gradient(circle at 60px 48px,rgba(255,202,40,.35) 0 6px,transparent 7px),linear-gradient(180deg,#e0f7fa,#fff7ed);background-size:72px 72px,96px 96px,auto;padding:16px}.game-page__layout{display:grid;grid-template-columns:minmax(260px,320px) minmax(0,1fr);gap:18px;align-items:start;max-width:1480px;margin:0 auto}.game-page__sidebar{position:sticky;top:16px;display:grid;gap:14px}.game-shell{--board-bg: #ffffff;--panel-bg: rgba(255, 255, 255, .86);--text: #111827;--muted: #64748b;--primary: #2563eb;--accent: #f97316;--success: #22c55e;--line: #2563eb;--point-bg: #ffffff;--point-border: #94a3b8;--target: #facc15;color:var(--text);width:100%;border:6px solid #ffb300;border-radius:30px;background:#fff;box-shadow:0 12px #ffa000,0 24px 34px #0f172a29;overflow:hidden}.game-shell[data-visual=cute]{--board-bg: #fff7ed;--panel-bg: rgba(255, 255, 255, .9);--primary: #14b8a6;--accent: #fb7185;--success: #84cc16;--line: #14b8a6;--target: #fbbf24}.game-shell[data-visual=normal]{--board-bg: #f8fafc;--panel-bg: rgba(255, 255, 255, .88);--primary: #2563eb;--accent: #f97316;--success: #22c55e;--line: #2563eb;--target: #facc15}.game-shell[data-visual=highContrast]{--board-bg: #ffffff;--panel-bg: #ffffff;--text: #000000;--muted: #111827;--primary: #000000;--accent: #d00000;--success: #007a1f;--line: #000000;--point-bg: #ffffff;--point-border: #000000;--target: #ffd400}.game-shell[data-motion=reduced] .target-pulse,.game-shell[data-motion=reduced] .line-draw,.game-shell[data-motion=reduced] .result-rise{animation:none}.mode-selector{display:grid;gap:8px;border:5px solid #29b6f6;border-radius:24px;background:#fff;box-shadow:0 8px #0288d1,0 16px 24px #0288d12e;padding:14px}.level-picker{display:grid;min-height:44px;gap:8px;border:3px solid #81d4fa;border-radius:16px;background:#e1f5fe;padding:10px;font-weight:800}.level-picker select{min-height:42px;width:100%;border:3px solid #0288d1;border-radius:14px;background:#fff;color:#111827;font-weight:800}.number-slider{display:grid;gap:10px;border:3px solid #ffb74d;border-radius:16px;background:#fff8e1;padding:12px;font-weight:900}.number-slider input{width:100%;accent-color:#ff7043}.game-header,.level-summary,.result-panel,.settings-panel{border:5px solid #ffca28;border-radius:24px;background:#fffdf7;box-shadow:0 8px #ffb300,0 16px 24px #ffb3002e}.game-header,.level-summary,.result-panel{border:0;border-radius:0;background:var(--panel-bg)}.game-header{display:grid;grid-template-columns:minmax(110px,160px) 1fr auto;gap:12px;align-items:center;border-bottom:4px dashed #ffca28;background:#fff8e1;padding:16px 20px}.game-header__target{display:grid;gap:2px}.game-header__target span,.game-header__status span,.level-summary dt,.result-panel dt{color:var(--muted);font-size:13px}.game-header__target strong{color:#ff5252;font-size:46px;line-height:1;text-shadow:2px 2px 0 #ffcdd2}.game-header__status{display:flex;flex-wrap:wrap;gap:8px 14px;align-items:center}.game-header__status p{flex-basis:100%;margin:0;font-weight:700}.game-header__actions,.result-panel__actions,.settings-panel__header,.segmented-control{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.game-shell__main{display:grid;gap:16px;margin-top:16px}.level-summary{display:flex;gap:16px;justify-content:space-between;background:#fff;padding:18px 20px}.level-summary h1{margin:6px 0 0;font-size:clamp(20px,2.2vw,30px);line-height:1.2}.level-summary dl,.result-panel__stats{display:flex;gap:14px;margin:0}.level-summary dd,.result-panel dd{margin:4px 0 0;font-weight:800}.eyebrow{margin:0;color:var(--accent);font-size:13px;font-weight:800;letter-spacing:0;text-transform:uppercase}.game-board{position:relative;min-height:58vh;border:0;border-top:4px solid rgba(255,202,40,.55);border-radius:0;background:radial-gradient(circle at 22px 22px,rgba(255,183,77,.2) 0 8px,transparent 9px),linear-gradient(rgba(148,163,184,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(148,163,184,.12) 1px,transparent 1px),var(--board-bg);background-size:64px 64px,36px 36px,36px 36px;overflow:hidden}.game-board__celebration{z-index:2}.game-board__celebration span{top:-24px;width:14px;height:22px;animation-duration:1.8s}.game-board__svg{display:block;width:100%;height:min(68vh,680px);min-height:430px}.game-board__line{stroke:var(--line);filter:drop-shadow(0 8px 10px rgba(37,99,235,.18))}.game-board__point{cursor:pointer;outline:none}.game-board__point circle{fill:var(--point-bg);stroke:var(--point-border);stroke-width:.9;transition:fill .16s ease,stroke .16s ease,transform .16s ease;transform-box:fill-box;transform-origin:center}.game-board__point text{fill:var(--text);font-weight:900;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.game-board__point:hover circle,.game-board__point:focus-visible circle{transform:scale(1.08)}.game-board__point--connected circle{fill:var(--success);stroke:#2e7d32;animation:point-pop .22s ease-out}.game-board__point--connected text{fill:#fff}.game-board__point--blank.game-board__point--connected text{fill:#111827}.game-board__point--next circle{fill:var(--target);stroke:var(--target)}.game-board__point--next text{fill:#111827}.game-board__point--blank circle{fill:#ffffffb8;stroke:var(--point-border);stroke-dasharray:1.5 1.2}.game-board__point--blank.game-board__point--revealed circle{fill:#fef3c7;stroke:var(--accent);stroke-dasharray:none}.game-board__point--blank.game-board__point--revealed text{fill:#111827}.ui-button{min-height:44px;border:3px solid transparent;border-radius:18px;padding:0 14px;cursor:pointer;font-weight:800;box-shadow:0 6px #11182738;transition:transform .08s ease,box-shadow .08s ease}.ui-button:active{transform:translateY(5px);box-shadow:0 1px #11182738}.ui-button--primary,.ui-button--active{border-color:#01579b;background:#0288d1;color:#fff}.ui-button--secondary{border-color:#94a3b880;background:#fff;color:var(--text)}.ui-button--ghost{border-color:#0288d1;background:#29b6f6;color:#fff}.ui-button--danger{border-color:#b91c1c;background:#ef4444;color:#fff}.result-panel{position:relative;display:grid;gap:14px;overflow:hidden;padding:18px}.celebration{position:absolute;inset:0;pointer-events:none}.celebration span{--piece-index: 0;position:absolute;top:-18px;left:calc((var(--piece-index) * 53px) % 100%);width:12px;height:18px;border-radius:4px;background:hsl(calc(var(--piece-index) * 39deg),88%,58%);animation:confetti-fall 1.35s ease-out both;animation-delay:calc(var(--piece-index) * 35ms)}.celebration span:nth-child(3n){width:14px;height:14px;border-radius:999px}.celebration span:nth-child(4n){clip-path:polygon(50% 0,60% 35%,98% 35%,68% 56%,80% 92%,50% 70%,20% 92%,32% 56%,2% 35%,40% 35%)}.result-panel h2{margin:4px 0;color:var(--primary);font-size:44px;line-height:1}.result-panel p{margin:0}.result-panel__note{color:var(--muted)}.settings-overlay{position:fixed;inset:0;z-index:10;display:grid;align-items:stretch;justify-items:end;background:#0f172a5c;padding:12px}.settings-panel{width:100%;padding:16px}.settings-panel__header{justify-content:space-between;margin-bottom:18px}.settings-panel__header h2{margin:0}.settings-field,.settings-check{display:grid;gap:8px;margin:14px 0;font-weight:700}.settings-field select,.settings-field input[type=range]{width:100%;accent-color:#ff7043}.settings-check{grid-template-columns:24px 1fr;align-items:center}@media(max-width:760px){.game-page{padding:10px}.game-page__layout{grid-template-columns:1fr}.game-page__sidebar{position:static}.game-header{grid-template-columns:1fr}.game-header__actions{justify-content:stretch}.game-header__actions .ui-button{flex:1}.level-summary,.level-summary dl,.result-panel__stats{display:grid}.game-board__svg{height:62vh;min-height:430px}}
