:root{--ocean-deep: #062d3e;--ocean: #0b4f6c;--ocean-light: #1a7a9e;--seafoam: #20bf96;--seafoam-light: #a8edda;--cream: #f7f5f0;--mist: #e8e6e1;--slate: #3d4f5f;--white: #fff;--radius: 16px;--target-min: 96px}body[data-target-size=medium]{--target-min: 80px}body[data-target-size=large]{--target-min: 120px}body[data-target-size=xlarge]{--target-min: 160px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{font-family:Outfit,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--slate);background:var(--cream);line-height:1.6}#app{max-width:980px;margin:0 auto;padding:24px 16px 64px}.app-header h1{font-family:Lora,Georgia,serif;color:var(--ocean-deep);font-weight:400;margin:8px 0 4px}.tagline{margin:0 0 24px;color:var(--ocean)}.card{background:var(--white);border:1px solid rgba(0,0,0,.04);border-radius:20px;box-shadow:0 8px 40px #062d3e1a;overflow:hidden;margin-bottom:24px}.card-head{background:linear-gradient(135deg,var(--ocean) 0%,var(--ocean-deep) 100%);padding:22px 28px}.card-head h2{font-family:Lora,Georgia,serif;font-weight:400;font-size:21px;line-height:1.3;color:var(--white);margin:0}.card-sub{margin:6px 0 0;font-size:13.5px;line-height:1.5;color:#ffffff9e}.card-body{padding:28px}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.settings-toggles{display:flex;flex-wrap:wrap;gap:6px 28px;margin-top:20px;padding-top:18px;border-top:1px solid var(--mist)}.settings-toggles .field-toggle{flex:1 1 170px}.field{display:flex;flex-direction:column;gap:7px;font-size:15px}.field-label{font-weight:600;font-size:13px;color:var(--ocean-deep)}.field select{width:100%;padding:14px 44px 14px 16px;border:1.5px solid var(--mist);border-radius:12px;background-color:var(--cream);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14' fill='none' stroke='%233D4F5F' stroke-width='1.5' stroke-linecap='round'%3E%3Cpath d='M4 5.5L7 8.5 10 5.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;font-family:inherit;font-size:15px;color:var(--slate);-moz-appearance:none;appearance:none;-webkit-appearance:none;cursor:pointer;outline:none;transition:border-color .2s}.field select:focus{border-color:var(--ocean-light)}.field-toggle{flex-direction:row;align-items:center;justify-content:space-between;gap:12px;padding:6px 0;cursor:pointer}.field-toggle input[type=checkbox]{position:absolute;width:1px;height:1px;opacity:0;pointer-events:none}.switch-ui{position:relative;flex:0 0 auto;width:52px;height:30px;border-radius:999px;background:var(--mist);transition:background .2s ease}.switch-ui:after{content:"";position:absolute;top:3px;left:3px;width:24px;height:24px;border-radius:50%;background:var(--white);box-shadow:0 1px 3px #00000040;transition:transform .2s ease}.field-toggle input[type=checkbox]:checked+.switch-ui{background:var(--seafoam)}.field-toggle input[type=checkbox]:checked+.switch-ui:after{transform:translate(22px)}.field-toggle input[type=checkbox]:focus-visible+.switch-ui{outline:3px solid var(--ocean-light);outline-offset:2px}#picker.card{border-top:4px solid var(--seafoam)}#picker .card-head{background:var(--cream);border-bottom:1px solid var(--mist);padding:20px 28px}#picker .card-head h2{color:var(--ocean-deep)}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.game-card{display:flex;flex-direction:column;align-items:center;gap:8px;min-height:140px;padding:20px;border:2px solid var(--mist);border-radius:var(--radius);background:var(--white);cursor:pointer;font:inherit;transition:border-color .15s ease}.game-card:hover,.game-card:focus-visible{border-color:var(--seafoam);outline:none}.game-emoji{font-size:48px}.game-title{font-weight:600;color:var(--ocean-deep)}.game-bands{font-size:13px;color:#6b7a88}#stage{background:var(--white);border:1px solid var(--mist);border-radius:var(--radius);overflow:hidden}#stage-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--ocean-deep)}.ui-btn{min-height:48px;padding:10px 18px;border:none;border-radius:10px;background:var(--seafoam);color:var(--ocean-deep);font:inherit;font-weight:600;cursor:pointer}#switch-bar{display:flex;gap:12px}.switch-btn{min-width:140px;min-height:64px;padding:8px 16px;border:none;border-radius:12px;font:inherit;font-weight:600;color:var(--white);cursor:pointer;touch-action:manipulation}.switch-a{background:var(--seafoam);color:var(--ocean-deep)}.switch-b{background:var(--ocean-light)}.switch-btn kbd{display:inline-block;margin-left:6px;padding:2px 6px;border-radius:6px;background:#ffffff40;font-size:12px}#game-container{min-height:70vh;display:flex;align-items:stretch;justify-content:center}.target{position:relative;min-width:64px;min-height:64px;font:inherit}.target:before{content:"";position:absolute;top:-20px;right:-20px;bottom:-20px;left:-20px}.scan-focus{outline:6px solid var(--seafoam);outline-offset:4px}@media(prefers-reduced-motion:no-preference){.scan-focus{animation:scanPulse 1s ease-in-out infinite}}@keyframes scanPulse{50%{outline-color:var(--ocean-light)}}body.reduce-motion .scan-focus{animation:none}body.high-contrast{--cream: #ffffff;--slate: #000000;--mist: #000000;background:#fff}body.high-contrast .card,body.high-contrast #stage{border-color:#000}body.high-contrast .scan-focus{outline-color:#ffeb00}body.large-text,body.large-text .field select{font-size:20px}.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}@media(max-width:600px){#app{padding:20px 12px 56px}body[data-target-size=medium]{--target-min: 72px}body[data-target-size=large]{--target-min: 92px}body[data-target-size=xlarge]{--target-min: 112px}.card-head{padding:18px 20px}.card-head h2{font-size:19px}.card-body{padding:18px}.settings-grid{gap:14px}.settings-toggles{gap:2px 20px;margin-top:16px;padding-top:14px}.settings-toggles .field-toggle{flex:1 1 100%}#stage-bar{padding:10px 12px;gap:10px}.ui-btn{flex:1 1 100%}#switch-bar{flex:1 1 100%;gap:10px}.switch-btn{flex:1 1 0;min-width:0}}.ta-stage{position:relative;flex:1;display:flex;align-items:center;justify-content:center;min-height:70vh;overflow:hidden;background:radial-gradient(1200px 600px at 18% 8%,rgba(168,237,218,.55),transparent 60%),radial-gradient(900px 500px at 88% 92%,rgba(26,122,158,.18),transparent 55%),linear-gradient(160deg,#fbfaf6,#eef4f0 70%,#e6efe9);touch-action:manipulation}.ta-pad{position:relative;z-index:2;width:clamp(var(--target-min, 160px),44vmin,420px);height:clamp(var(--target-min, 160px),44vmin,420px);font-size:clamp(88px,28vmin,260px);line-height:1;display:grid;place-items:center;border:none;border-radius:50%;background:radial-gradient(circle at 36% 30%,#fff,#f3f7f5 62%,#e4ece8);color:#fff;cursor:pointer;-webkit-user-select:none;user-select:none;touch-action:manipulation;box-shadow:0 10px 40px #062d3e2e,0 0 0 10px color-mix(in srgb,var(--glow, #20bf96) 22%,transparent),0 0 60px 6px color-mix(in srgb,var(--glow, #20bf96) 38%,transparent);transition:box-shadow .45s ease,background .45s ease}.ta-pad:before{content:"";position:absolute;top:-100vmax;right:-100vmax;bottom:-100vmax;left:-100vmax;border-radius:0}@media(prefers-reduced-motion:no-preference){.ta-pad{animation:taPulse 2.4s ease-in-out infinite}.ta-bounce{animation:taBounce .45s ease,taPulse 2.4s ease-in-out infinite .45s}}@keyframes taPulse{0%,to{transform:scale(1)}50%{transform:scale(1.035)}}@keyframes taBounce{0%{transform:scale(1)}35%{transform:scale(1.16)}to{transform:scale(1)}}body.reduce-motion .ta-pad{animation:none}.ta-pad.scan-focus{outline:8px solid var(--seafoam, #20bf96);outline-offset:8px}body.high-contrast .ta-pad.scan-focus{outline-color:#ffeb00}.ta-friend{position:absolute;z-index:1;font-size:clamp(40px,9vmin,86px);pointer-events:none;transform:translate(-50%,-50%);animation:taFriendPop 1.7s cubic-bezier(.18,.9,.3,1) forwards;will-change:transform,opacity}@keyframes taFriendPop{0%{transform:translate(-50%,-50%) scale(.2) rotate(0);opacity:0}18%{transform:translate(-50%,-50%) scale(1.1) rotate(var(--spin, 0deg));opacity:1}70%{opacity:1}to{transform:translate(-50%,-160%) scale(.9) rotate(var(--spin, 0deg));opacity:0}}.ta-particle{position:absolute;top:50%;left:50%;z-index:1;width:16px;height:16px;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);animation:taSpark .9s ease-out forwards;will-change:transform,opacity}@keyframes taSpark{0%{transform:translate(-50%,-50%) scale(.4);opacity:0}15%{opacity:1}to{transform:translate(calc(-50% + var(--dx, 0px)),calc(-50% + var(--dy, 0px))) scale(.9);opacity:0}}body.reduce-motion .ta-friend,body.reduce-motion .ta-particle{display:none}body.high-contrast .ta-stage{background:#fff}body.high-contrast .ta-pad{background:#fff;border:6px solid #000;box-shadow:0 0 0 10px color-mix(in srgb,var(--glow, #20bf96) 40%,#000 10%)}.bp-stage{position:relative;flex:1;min-height:70vh;overflow:hidden;background:radial-gradient(1000px 520px at 20% 12%,rgba(168,237,218,.5),transparent 60%),linear-gradient(160deg,#f3f9fb,#e9f2f0 70%,#e0ebee);touch-action:manipulation}.bp-stage .bp-bubble{position:absolute;width:clamp(var(--target-min, 96px),22vmin,190px);height:clamp(var(--target-min, 96px),22vmin,190px);border:none;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer;touch-action:manipulation;background:radial-gradient(circle at 36% 30%,hsl(var(--hue, 200) 95% 88%),hsl(var(--hue, 200) 80% 56%) 58%,hsl(var(--hue, 200) 72% 42%));box-shadow:0 8px 26px #062d3e2e,inset 0 -8px 18px #0000001f,inset 8px 8px 20px #fff6}@media(prefers-reduced-motion:no-preference){.bp-stage .bp-bubble{animation:bpBob var(--bob, 3s) ease-in-out infinite}}@keyframes bpBob{0%,to{transform:translate(-50%,-50%)}50%{transform:translate(-50%,calc(-50% - 14px))}}.bp-stage .bp-bubble.bp-pop{animation:bpPop .38s ease-out forwards;pointer-events:none}@keyframes bpPop{0%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(1.55);opacity:0}}body.reduce-motion .bp-stage .bp-bubble{animation:none}.bp-bubble.scan-focus{outline:8px solid var(--seafoam, #20bf96);outline-offset:6px}body.high-contrast .bp-stage{background:#fff}body.high-contrast .bp-stage .bp-bubble{background:hsl(var(--hue, 200) 70% 45%);border:5px solid #000}body.high-contrast .bp-bubble.scan-focus{outline-color:#ffeb00}@media(max-width:600px){.bp-stage .bp-bubble{width:clamp(84px,27vmin,150px);height:clamp(84px,27vmin,150px)}}.mp-grid{flex:1;min-height:70vh;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(88px,1fr);gap:14px;padding:18px;background:linear-gradient(160deg,#0d2330,#08303f 70%,#062d3e)}.mp-grid .mp-pad{position:relative;border:none;border-radius:18px;min-height:0;cursor:pointer;touch-action:manipulation;background:linear-gradient(160deg,hsl(var(--hue, 200) 85% 62%),hsl(var(--hue, 200) 78% 48%));box-shadow:0 8px 22px #00000047,inset 0 2px #ffffff40;transition:transform .12s ease,box-shadow .25s ease,filter .25s ease}.mp-grid .mp-pad.mp-on{filter:brightness(1.35) saturate(1.1);transform:scale(.97);box-shadow:0 0 0 4px #ffffff80,0 0 38px 6px hsl(var(--hue, 200) 90% 60%)}.mp-pad.scan-focus{outline:6px solid #fff;outline-offset:4px}@media(max-width:640px){.mp-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:12px}}body.high-contrast .mp-grid{background:#000;gap:18px}body.high-contrast .mp-grid .mp-pad{background:hsl(var(--hue, 200) 80% 55%);border:4px solid #fff}body.high-contrast .mp-pad.scan-focus{outline-color:#ffeb00}.ci-root{flex:1;min-height:70vh;display:flex;flex-direction:column;gap:18px;padding:24px;background:linear-gradient(160deg,#fbfaf6,#eef4f0 70%,#e6efe9)}.ci-display{flex:1;min-height:38vh;display:flex;flex-wrap:wrap;align-content:center;justify-content:center;gap:14px;padding:24px;background:#fff;border-radius:22px;box-shadow:0 8px 28px #062d3e1a}.ci-item{font-size:clamp(44px,13vmin,104px);line-height:1}.ci-prompt{margin:0;text-align:center;color:var(--ocean, #0b4f6c);font-size:18px;font-weight:600}.ci-choices{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.ci-choices .ci-choice{width:clamp(var(--target-min, 96px),16vmin,132px);height:clamp(var(--target-min, 96px),16vmin,132px);display:grid;place-items:center;border:none;border-radius:20px;font-family:Lora,Georgia,serif;font-size:clamp(36px,9vmin,60px);color:#fff;cursor:pointer;touch-action:manipulation;background:linear-gradient(150deg,var(--ocean, #0b4f6c),var(--ocean-deep, #062d3e));box-shadow:0 8px 22px #062d3e33;transition:transform .12s ease}.ci-choice.scan-focus{outline:6px solid var(--seafoam, #20bf96);outline-offset:4px}.ci-choice.ci-nudge{animation:ciNudge .4s ease}@keyframes ciNudge{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}body.reduce-motion .ci-choice.ci-nudge{animation:none}@media(max-width:600px){.ci-root{padding:16px;gap:14px}.ci-display{padding:16px;min-height:30vh}.ci-choices{gap:10px}.ci-choices .ci-choice{width:clamp(76px,24vmin,110px);height:clamp(76px,24vmin,110px);font-size:clamp(30px,11vmin,48px)}}body.high-contrast .ci-root{background:#fff}body.high-contrast .ci-display{border:3px solid #000}body.high-contrast .ci-choices .ci-choice{background:#000;border:3px solid #000}body.high-contrast .ci-choice.scan-focus{outline-color:#ffeb00}.mm-grid{flex:1;min-height:70vh;display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-content:center;justify-items:center;padding:24px;background:linear-gradient(160deg,#fbfaf6,#eef4f0 70%,#e6efe9)}.mm-grid .mm-card{width:100%;max-width:200px;aspect-ratio:3 / 4;min-height:clamp(var(--target-min, 96px),26vmin,240px);display:grid;place-items:center;border:none;border-radius:18px;font-size:clamp(40px,12vmin,96px);line-height:1;cursor:pointer;touch-action:manipulation;color:#fff;background:linear-gradient(150deg,var(--ocean, #0b4f6c),var(--ocean-deep, #062d3e));box-shadow:0 8px 24px #062d3e33;transition:transform .15s ease,background .2s ease,box-shadow .2s ease}.mm-grid .mm-card:not(.mm-up):after{content:"?";font-family:Lora,Georgia,serif;font-size:clamp(34px,9vmin,72px);color:#fff9}.mm-grid .mm-card.mm-up{background:#fff;box-shadow:0 10px 28px #062d3e29}.mm-grid .mm-card.mm-matched{background:#e6f9f1;box-shadow:inset 0 0 0 3px var(--seafoam, #20bf96);cursor:default}.mm-card.scan-focus{outline:6px solid var(--seafoam, #20bf96);outline-offset:4px}@media(max-width:560px){.mm-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}.mm-grid .mm-card{aspect-ratio:1 / 1;max-width:170px;min-height:0;font-size:clamp(38px,17vmin,84px)}}body.high-contrast .mm-grid{background:#fff}body.high-contrast .mm-grid .mm-card{background:#000;border:3px solid #000}body.high-contrast .mm-grid .mm-card.mm-up{background:#fff;color:#000;border-color:#000}body.high-contrast .mm-card.scan-focus{outline-color:#ffeb00}.ss-root{flex:1;min-height:70vh;display:flex;flex-direction:column;justify-content:space-between;gap:16px;padding:28px 20px;background:linear-gradient(160deg,#fbfaf6,#eef4f0 70%,#e6efe9)}.ss-holes,.ss-pieces{display:flex;flex-wrap:wrap;gap:16px;justify-content:center}.ss-hint{text-align:center;font-size:16px;color:var(--ocean, #0b4f6c);margin:0}.ss-root .ss-hole,.ss-root .ss-piece{width:clamp(var(--target-min, 96px),20vmin,168px);height:clamp(var(--target-min, 96px),20vmin,168px);display:grid;place-items:center;border-radius:22px;font-size:clamp(44px,11vmin,92px);line-height:1;cursor:pointer;touch-action:manipulation;background:none;border:none}.ss-root .ss-hole{border:3px dashed #b9c6cf;background:#ffffff80}.ss-root .ss-hole:not(.ss-filled){opacity:.85;filter:grayscale(.5)}.ss-root .ss-hole:not(.ss-filled)>*{opacity:.35}.ss-root .ss-hole:not(.ss-filled){color:transparent;text-shadow:0 0 0 rgba(11,79,108,.32)}.ss-root .ss-hole.ss-filled{border-style:solid;border-color:var(--seafoam, #20bf96);background:#e6f9f1;box-shadow:0 8px 22px #20bf9638;cursor:default}.ss-root .ss-piece{background:#fff;box-shadow:0 8px 22px #062d3e24;transition:transform .15s ease,box-shadow .2s ease,opacity .3s ease}.ss-root .ss-piece.ss-selected{box-shadow:0 0 0 4px var(--seafoam, #20bf96),0 10px 26px #20bf964d;transform:translateY(-6px) scale(1.04)}.ss-root .ss-piece.ss-placed{opacity:.18;pointer-events:none}@media(prefers-reduced-motion:reduce){.ss-root .ss-piece{transition:none}.ss-root .ss-piece.ss-selected{transform:none}}.ss-hole.scan-focus,.ss-piece.scan-focus{outline:6px solid var(--ocean-light, #1a7a9e);outline-offset:4px}@media(max-width:600px){.ss-root{padding:18px 14px;gap:12px}.ss-holes,.ss-pieces{gap:12px}.ss-root .ss-hole,.ss-root .ss-piece{width:clamp(84px,27vmin,128px);height:clamp(84px,27vmin,128px);font-size:clamp(40px,14vmin,72px);border-radius:18px}.ss-hint{font-size:15px}}body.high-contrast .ss-root{background:#fff}body.high-contrast .ss-root .ss-hole{border-color:#000}body.high-contrast .ss-root .ss-piece{border:3px solid #000}body.high-contrast .ss-hole.scan-focus,body.high-contrast .ss-piece.scan-focus{outline-color:#ffeb00}.oo-grid{flex:1;min-height:70vh;display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:minmax(110px,1fr);gap:16px;align-content:center;padding:24px;background:linear-gradient(160deg,#fbfaf6,#eef4f0 70%,#e6efe9)}.oo-grid .oo-cell{border:none;border-radius:18px;min-height:0;display:grid;place-items:center;font-size:clamp(40px,12vmin,92px);line-height:1;cursor:pointer;touch-action:manipulation;background:#fff;box-shadow:0 6px 20px #062d3e1f;transition:transform .12s ease,box-shadow .2s ease}.oo-cell.scan-focus{outline:6px solid var(--ocean-light, #1a7a9e);outline-offset:4px}.oo-cell.oo-nudge{animation:ooNudge .4s ease}@keyframes ooNudge{0%,to{transform:translate(0)}25%{transform:translate(-7px)}75%{transform:translate(7px)}}body.reduce-motion .oo-cell.oo-nudge{animation:none}@media(max-width:560px){.oo-grid{grid-template-columns:repeat(2,1fr);gap:12px;padding:16px}}body.high-contrast .oo-grid{background:#fff}body.high-contrast .oo-grid .oo-cell{background:#fff;border:3px solid #000}body.high-contrast .oo-cell.scan-focus{outline-color:#ffeb00}.pe-wrap{flex:1;min-height:70vh;display:flex;flex-direction:column;gap:14px;padding:20px;background:linear-gradient(160deg,#0d2330,#08303f 70%,#062d3e)}.pe-status{margin:0;min-height:1.5em;text-align:center;color:#fff;font-size:19px;font-weight:600}.pe-grid{flex:1;display:grid;grid-template-columns:repeat(2,1fr);grid-auto-rows:minmax(110px,1fr);gap:16px}.pe-grid .pe-pad{border:none;border-radius:22px;min-height:0;cursor:pointer;touch-action:manipulation;background:linear-gradient(160deg,hsl(var(--hue, 200) 80% 60%),hsl(var(--hue, 200) 75% 46%));box-shadow:0 8px 22px #0000004d;filter:brightness(.62) saturate(.85);transition:filter .18s ease,transform .12s ease,box-shadow .25s ease}.pe-grid .pe-pad.pe-on{filter:brightness(1.4) saturate(1.15);transform:scale(.98);box-shadow:0 0 0 4px #ffffff8c,0 0 42px 8px hsl(var(--hue, 200) 90% 60%)}.pe-pad.scan-focus{outline:6px solid #fff;outline-offset:4px}@media(max-width:600px){.pe-wrap{padding:14px;gap:10px}.pe-grid{gap:12px}}body.high-contrast .pe-wrap{background:#000}body.high-contrast .pe-grid .pe-pad{background:hsl(var(--hue, 200) 80% 55%);border:4px solid #fff;filter:brightness(.5)}body.high-contrast .pe-grid .pe-pad.pe-on{filter:brightness(1.4)}body.high-contrast .pe-pad.scan-focus{outline-color:#ffeb00}.pg-root{flex:1;min-height:70vh;display:flex;flex-direction:column;gap:16px;padding:18px;background:linear-gradient(160deg,#f3f9fb,#e9f2f0 70%,#e0ebee)}.pg-palette{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;padding:10px;background:#fff;border-radius:16px;box-shadow:0 6px 18px #062d3e1a}.pg-palette .pg-swatch{width:64px;height:64px;border:3px solid rgba(0,0,0,.12);border-radius:50%;cursor:pointer;touch-action:manipulation;transition:transform .12s ease,outline .12s ease}.pg-swatch.pg-selected{outline:4px solid var(--ocean-deep, #062d3e);outline-offset:3px;transform:scale(1.08)}.pg-grid{flex:1;display:grid;grid-template-columns:repeat(6,1fr);gap:6px;padding:8px;background:#fff;border-radius:16px;box-shadow:0 6px 18px #062d3e1a}.pg-grid .pg-cell{aspect-ratio:1 / 1;min-height:0;min-width:0;border:1px solid var(--mist, #e8e6e1);border-radius:10px;background:#fbfaf7;cursor:pointer;touch-action:manipulation;transition:transform .08s ease}.pg-grid .pg-cell.pg-filled{border-color:transparent}.pg-swatch.scan-focus,.pg-cell.scan-focus{outline:4px solid var(--ocean-light, #1a7a9e);outline-offset:2px;z-index:1}@media(max-width:600px){.pg-grid{grid-template-columns:repeat(4,1fr)}.pg-palette .pg-swatch{width:56px;height:56px}}body.high-contrast .pg-root{background:#fff}body.high-contrast .pg-palette,body.high-contrast .pg-grid{border:2px solid #000}body.high-contrast .pg-grid .pg-cell{border-color:#000}body.high-contrast .pg-swatch.scan-focus,body.high-contrast .pg-cell.scan-focus{outline-color:#ffeb00}.sl-root{flex:1;min-height:70vh;display:flex;flex-direction:column;gap:14px;padding:24px;background:radial-gradient(120% 90% at 50% 8%,#0b4f6c,#062d3e 55%,#03161f)}.sl-sky{position:relative;flex:1;min-height:56vh;border-radius:22px;overflow:hidden;box-shadow:inset 0 0 60px #00000073}.sl-lines{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;pointer-events:none}.sl-line{stroke:var(--seafoam, #20bf96);stroke-width:.9;stroke-linecap:round;vector-effect:non-scaling-stroke;filter:drop-shadow(0 0 3px rgba(32,191,150,.8));animation:slLineIn .45s ease both}@keyframes slLineIn{0%{opacity:0}to{opacity:1}}.sl-star{position:absolute;transform:translate(-50%,-50%);width:clamp(64px,11vmin,104px);height:clamp(64px,11vmin,104px);display:grid;place-items:center;padding:0;border:none;border-radius:50%;background:transparent;cursor:pointer;touch-action:manipulation}.sl-star-glyph{width:46%;height:46%;border-radius:50%;background:#ffffff29;border:3px solid rgba(168,237,218,.7);box-shadow:0 0 10px #a8edda59;transition:all .25s ease}@media(prefers-reduced-motion:no-preference){.sl-star-glyph{animation:slTwinkle 2.4s ease-in-out infinite}}@keyframes slTwinkle{50%{opacity:.55}}.sl-star.sl-lit .sl-star-glyph{width:58%;height:58%;background:var(--seafoam-light, #a8edda);border-color:#fff;box-shadow:0 0 14px #a8eddaf2,0 0 30px #20bf9699;animation:none}.sl-star.sl-done .sl-star-glyph{background:#fff;box-shadow:0 0 18px #fff,0 0 40px #20bf96cc}.sl-star.scan-focus{outline:6px solid var(--seafoam, #20bf96);outline-offset:6px;border-radius:50%}.sl-name{margin:0;min-height:1.4em;text-align:center;font-family:Lora,Georgia,serif;font-size:clamp(22px,5vmin,34px);color:var(--seafoam-light, #a8edda);opacity:0;transform:translateY(6px)}.sl-name.sl-name-show{opacity:1;transform:translateY(0);transition:opacity .5s ease,transform .5s ease}body.reduce-motion .sl-name.sl-name-show{transition:none;transform:none}@media(max-width:600px){.sl-root{padding:16px}.sl-sky{min-height:52vh}.sl-star{width:clamp(64px,17vmin,92px);height:clamp(64px,17vmin,92px)}}body.high-contrast .sl-root{background:#000}body.high-contrast .sl-sky{border:3px solid #fff}body.high-contrast .sl-line{stroke:#ffeb00;stroke-width:1.4;filter:none}body.high-contrast .sl-star-glyph{background:transparent;border-color:#fff;box-shadow:none;animation:none}body.high-contrast .sl-star.sl-lit .sl-star-glyph,body.high-contrast .sl-star.sl-done .sl-star-glyph{background:#ffeb00;border-color:#fff;box-shadow:none}body.high-contrast .sl-star.scan-focus{outline-color:#ffeb00}body.high-contrast .sl-name{color:#ffeb00}
