:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;color:#e8ecf3;font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#05070d;font-family:Inter,Hiragino Sans,system-ui,-apple-system,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*,:before,:after{box-sizing:border-box}html,body,#root{min-height:100vh;margin:0;padding:0}body{background-color:#0000;background-image:radial-gradient(circle at 20% 10%,#5078ff2e,#0000 50%),radial-gradient(circle at 80% 90%,#ff50c824,#0000 55%),linear-gradient(#07090f 0%,#02030a 100%);background-position:0 0,0 0,0 0;background-repeat:repeat,repeat,repeat;background-size:auto,auto,auto;background-attachment:fixed;background-origin:padding-box,padding-box,padding-box;background-clip:border-box,border-box,border-box;overflow-x:hidden}button{cursor:pointer;font-family:inherit}button:disabled{cursor:not-allowed}:root{--bg-deep:#05070d;--bg-card:#121624b8;--border:#ffffff14;--border-strong:#ffffff2e;--text:#e8ecf3;--text-mute:#8b94a8;--accent:#7df9ff;--accent2:#ff5db1;--gold:#ffd166;--green:#4ade80;--board-felt:#0c2a1f;--board-felt-2:#051712}.app{flex-direction:column;align-items:center;min-height:100vh;padding:0 16px 32px;display:flex}.title-screen{text-align:center;z-index:1;width:100%;max-width:760px;margin:0 auto;padding:60px 20px;position:relative}.title-screen__bg{pointer-events:none;z-index:-1;position:absolute;inset:0;overflow:hidden}.title-disc{opacity:.18;border-radius:50%;width:18px;height:18px;animation:6s ease-in-out infinite floaty;position:absolute}.title-disc--black{background:radial-gradient(circle at 35% 35%,#555,#000);box-shadow:0 0 12px #00000080}.title-disc--white{background:radial-gradient(circle at 35% 35%,#fff,#d8dde8);box-shadow:0 0 16px #fff9}@keyframes floaty{0%,to{transform:translateY(0)scale(1)}50%{transform:translateY(-20px)scale(1.15)}}.title-main{letter-spacing:.02em;filter:drop-shadow(0 0 28px #7df9ff66);margin-bottom:8px;font-size:clamp(40px,8vw,76px);font-weight:900;line-height:1}.title-main__shin{background:linear-gradient(135deg,#7df9ff,#ff5db1);color:#0000;-webkit-background-clip:text;background-clip:text}.title-main__name{color:#fff;text-shadow:0 0 16px #ffffff4d}.title-sub{color:var(--text-mute);letter-spacing:.3em;margin-bottom:40px;font-size:16px}.mode-grid{grid-template-columns:repeat(3,1fr);gap:14px;max-width:680px;margin:0 auto 24px;display:grid}@media (width<=640px){.mode-grid{grid-template-columns:1fr;max-width:320px}}.mode-card{border:1px solid var(--border-strong);background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text);border-radius:18px;padding:32px 18px;transition:border-color .2s;position:relative;overflow:hidden}.mode-card:hover{border-color:#fff6}.mode-card--ai:before{content:"";filter:blur(20px);z-index:0;background:radial-gradient(circle,#7df9ff66,#0000 70%);border-radius:18px;position:absolute;inset:-2px}.mode-card--human:before{content:"";filter:blur(20px);z-index:0;background:radial-gradient(circle,#ff5db166,#0000 70%);border-radius:18px;position:absolute;inset:-2px}.mode-card--online:before{content:"";filter:blur(20px);z-index:0;background:radial-gradient(circle,#4ade8073,#0000 70%);border-radius:18px;position:absolute;inset:-2px}.online-panel{flex-direction:column;gap:16px;max-width:420px;margin:0 auto 16px;display:flex}.online-join{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:10px;padding:16px;display:flex}.online-join__title{color:var(--text-mute);letter-spacing:.15em;font-size:12px}.online-input{letter-spacing:.3em;text-align:center;border:1px solid var(--border-strong);width:100%;color:var(--accent);text-transform:uppercase;background:#0006;border-radius:10px;padding:14px 16px;font-family:SF Mono,Menlo,monospace;font-size:22px;font-weight:800}.online-input:focus{border-color:var(--accent);outline:none;box-shadow:0 0 20px #7df9ff4d}.online-join__btn{align-self:stretch}.online-error{color:#ff7676;text-align:center;padding:8px;font-size:13px}.waiting-banner{background:var(--bg-card);border:1px solid var(--accent);text-align:center;border-radius:14px;padding:16px;animation:2s ease-in-out infinite waitingPulse;box-shadow:0 0 32px #7df9ff33}.waiting-banner__title{color:var(--text-mute);margin-bottom:8px;font-size:14px}.waiting-banner__code{letter-spacing:.3em;margin-bottom:12px;font-family:SF Mono,Menlo,monospace;font-size:28px;font-weight:900}.waiting-banner__code strong{color:var(--accent);text-shadow:0 0 16px var(--accent)}@keyframes waitingPulse{0%,to{box-shadow:0 0 24px #7df9ff26}50%{box-shadow:0 0 36px #7df9ff73}}.mode-card__icon,.mode-card__label,.mode-card__sub{z-index:1;position:relative}.mode-card__icon{margin-bottom:12px;font-size:38px;line-height:1}.mode-card__label{letter-spacing:.05em;margin-bottom:4px;font-size:22px;font-weight:800}.mode-card__sub{color:var(--text-mute);letter-spacing:.1em;font-size:12px}.title-back{color:var(--text-mute);letter-spacing:.05em;background:0 0;border:none;border-radius:8px;margin-top:12px;padding:8px 14px;font-size:13px;font-weight:600;transition:color .15s}.title-back:hover{color:var(--accent)}.difficulty-grid{grid-template-columns:repeat(2,1fr);gap:16px;max-width:560px;margin:0 auto 16px;display:grid}.diff-card{border:1px solid var(--border-strong);background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text);border-radius:16px;padding:24px 18px;transition:border-color .2s;position:relative;overflow:hidden}.diff-card:hover{border-color:#fff6}.diff-card__aura{opacity:.5;z-index:0;filter:blur(18px);border-radius:16px;position:absolute;inset:-2px}.aura-easy{background:radial-gradient(circle,#4ade8080,#0000 70%)}.aura-normal{background:radial-gradient(circle,#7df9ff80,#0000 70%)}.aura-hard{background:radial-gradient(circle,#ffd1668c,#0000 70%)}.aura-oni{background:radial-gradient(circle,#ff3c64a6,#0000 70%)}.diff-card__label,.diff-card__sub{z-index:1;position:relative}.diff-card__label{letter-spacing:.05em;margin-bottom:4px;font-size:24px;font-weight:800}.diff-card__sub{color:var(--text-mute);letter-spacing:.15em;font-size:12px}.title-hint{color:var(--text-mute);min-height:1.2em;margin-top:12px;font-size:13px}.play-screen{flex-direction:column;gap:14px;width:100%;max-width:760px;margin:0 auto;padding-top:16px;display:flex}.play-header{background:var(--bg-card);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:14px;justify-content:space-between;align-items:center;gap:8px;padding:10px 14px;display:flex}.play-header__title{letter-spacing:.05em;text-align:center;flex-direction:column;gap:2px;font-size:16px;font-weight:800;display:flex}.play-header__diff{color:var(--accent);letter-spacing:.15em;font-size:11px;font-weight:600}.ghost-btn{border:1px solid var(--border-strong);color:var(--text);background:0 0;border-radius:10px;padding:8px 12px;font-size:12px;font-weight:600;transition:all .15s}.ghost-btn:hover{border-color:var(--accent);color:var(--accent);background:#ffffff0f}.ghost-btn--icon{padding:8px 10px;font-size:16px}.ghost-btn--corner{z-index:10;position:absolute;top:12px;right:12px}.play-header__actions{gap:8px;display:flex}.scoreboard{background:var(--bg-card);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;padding:12px 16px}.scoreboard__row{grid-template-columns:1fr auto 1fr;align-items:center;gap:12px;display:grid}.score{border-radius:10px;align-items:center;gap:10px;padding:6px 12px;transition:all .2s;display:flex}.score--black{justify-content:flex-start}.score--white{justify-content:flex-end}.score--active{background:#7df9ff14;box-shadow:0 0 24px #7df9ff33}.score__disc{border-radius:50%;flex-shrink:0;width:24px;height:24px}.score__disc--black{background:radial-gradient(circle at 35% 30%,#555,#000 65%);box-shadow:inset 0 -3px 4px #0009,0 0 6px #0009}.score__disc--white{background:radial-gradient(circle at 35% 30%,#fff,#cdd2dc 70%);box-shadow:inset 0 -3px 4px #00000040,0 0 8px #fff6}.score__num{letter-spacing:.05em;font-size:22px;font-weight:800}.scoreboard__status{text-align:center;color:var(--text-mute);letter-spacing:.08em;font-size:13px;font-weight:600}.progress-bar{background:#ffffffd9;border-radius:99px;height:6px;margin-top:10px;position:relative;overflow:hidden}.progress-bar__black{background:linear-gradient(90deg,#000,#1a1a1a);height:100%;box-shadow:0 0 8px #0009}.game-area{grid-template-columns:minmax(0,1fr) auto minmax(0,1fr);align-items:start;gap:16px;display:grid}.board-wrap{justify-content:center;display:flex}.board-frame{aspect-ratio:9/9;background:radial-gradient(circle at 50% 50%, var(--board-felt) 0%, var(--board-felt-2) 100%);border:1px solid #7df9ff2e;border-radius:18px;grid-template-columns:28px repeat(8,1fr);grid-auto-rows:minmax(0,1fr);width:min(80vw,520px);padding:8px;display:grid;position:relative;box-shadow:0 0 0 1px #0009,0 30px 60px -20px #000c,inset 0 0 60px #00000080}.board-corner{background:0 0}.board-label{color:#ffffff4d;letter-spacing:.08em;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.cell{background:linear-gradient(135deg,#ffffff08,#00000040);border:1px solid #ffffff0d;border-radius:4px;justify-content:center;align-items:center;margin:1px;transition:background .15s;display:flex;position:relative}.cell--legal{cursor:pointer;background:linear-gradient(135deg,#7df9ff0f,#7df9ff05)}.cell--legal:hover{background:#7df9ff2e;box-shadow:inset 0 0 16px #7df9ff4d}.cell--last{box-shadow:inset 0 0 0 2px #ffd16699}.cell--flipped{animation:.6s ease-out cellFlash}.cell--blast-flipped{animation:.6s ease-out cellFlashBlast}.cell--cross-flipped{animation:.6s ease-out cellFlashCross}@keyframes cellFlash{0%{background:#ffffff80;box-shadow:inset 0 0 30px #fffc}to{background:inherit}}@keyframes cellFlashBlast{0%{background:#ff5b3cd9;box-shadow:inset 0 0 50px #ff5b3c}to{background:inherit}}@keyframes cellFlashCross{0%{background:#7df9ffd9;box-shadow:inset 0 0 50px #7df9ff}to{background:inherit}}.hint{opacity:.7;border-radius:50%;width:30%;height:30%;animation:1.6s ease-in-out infinite hintPulse}.hint--black{background:radial-gradient(circle,#000 0%,#0000 70%)}.hint--white{background:radial-gradient(circle,#fff 0%,#0000 70%)}@keyframes hintPulse{0%,to{opacity:.4;transform:scale(.8)}50%{opacity:.85;transform:scale(1.1)}}.star-point{background:#ffffff40;border-radius:50%;width:6px;height:6px}.disc{width:82%;height:82%;transform-style:preserve-3d;border-radius:50%;justify-content:center;align-items:center;display:flex;position:relative}.disc--black{background:radial-gradient(circle at 30% 28%,#4a4a4a 0%,#1a1a1a 40%,#000 100%);box-shadow:inset 0 -4px 8px #000c,inset 0 3px 6px #ffffff26,0 4px 10px #000000b3,0 0 12px #7df9ff33}.disc--white{background:radial-gradient(circle at 30% 28%,#fff 0%,#e2e6ee 50%,#b9c0cf 100%);box-shadow:inset 0 -4px 8px #0003,inset 0 3px 6px #fffffff2,0 4px 10px #00000080,0 0 16px #fff6}.disc__shine{pointer-events:none;background:radial-gradient(#fff9,#0000 70%);border-radius:50%;width:30%;height:22%;position:absolute;top:12%;left:18%}.disc--black .disc__shine{opacity:.35}.disc--placed{animation:.4s ease-out discDrop}@keyframes discDrop{0%{filter:brightness(1.5);transform:scale(1.3)}to{filter:brightness();transform:scale(1)}}.disc--locked{animation:2s ease-in-out infinite lockGlow;box-shadow:inset 0 -4px 8px #000000b3,0 0 0 2px #ffd166b3,0 0 20px #ffd166b3}@keyframes lockGlow{0%,to{box-shadow:inset 0 -4px 8px #000000b3,0 0 0 2px #ffd16680,0 0 14px #ffd16673}50%{box-shadow:inset 0 -4px 8px #000000b3,0 0 0 2px #ffd166e6,0 0 28px #ffd166d9}}.disc__lock{filter:drop-shadow(0 0 4px #ffd166e6);font-size:60%;position:absolute}.disc--blast{box-shadow:inset 0 -4px 8px #0009,0 0 0 2px #ff5b3cb3,0 0 22px #ff5b3ccc}.disc--cross{box-shadow:inset 0 -4px 8px #0009,0 0 0 2px #7df9ffb3,0 0 22px #7df9ffcc}.disc__badge{filter:drop-shadow(0 0 4px #7df9ffe6);font-size:55%;position:absolute}.disc--burst-lock{animation:.9s ease-out burstLock}.disc--burst-blast{animation:.9s ease-out burstBlast}.disc--burst-cross{animation:.9s ease-out burstCross}@keyframes burstLock{0%{filter:brightness(2.5)drop-shadow(0 0 30px #ffd166);transform:scale(1.8)}60%{filter:brightness(1.2);transform:scale(.92)}to{filter:brightness();transform:scale(1)}}@keyframes burstBlast{0%{filter:brightness(2.8)drop-shadow(0 0 40px #ff5b3c);transform:scale(2)}60%{filter:brightness(1.2);transform:scale(.9)}to{filter:brightness();transform:scale(1)}}@keyframes burstCross{0%{filter:brightness(2.5)drop-shadow(0 0 30px #7df9ff);transform:scale(1.8)}60%{filter:brightness(1.2);transform:scale(.92)}to{filter:brightness();transform:scale(1)}}.screen-flash{pointer-events:none;z-index:90;mix-blend-mode:screen;position:fixed;inset:0}.board-frame--burst{animation:.6s ease-out boardPulse}.board-frame--replay,.board-frame--replay .cell--legal{cursor:wait}.board-frame--replay .cell--blast-flipped,.board-frame--replay .cell--cross-flipped{animation-duration:2.1s!important}@keyframes boardPulse{0%{box-shadow:0 0 0 1px #0009,0 30px 60px -20px #000c,inset 0 0 60px #00000080,0 0 80px #ffffff80}to{box-shadow:0 0 0 1px #0009,0 30px 60px -20px #000c,inset 0 0 60px #00000080}}.burst{pointer-events:none;z-index:10;position:absolute;transform:translate(-50%,-50%)}.burst__svg{pointer-events:none;z-index:9;width:100%;height:100%;position:absolute;inset:0}.burst__ring{border:3px solid;border-radius:50%;width:60px;height:60px;margin:-30px 0 0 -30px;position:absolute;top:50%;left:50%}.burst__flash{filter:blur(4px);border-radius:50%;width:80px;height:80px;margin:-40px 0 0 -40px;position:absolute;top:50%;left:50%}.burst__spark{border-radius:50%;width:6px;height:6px;margin:-3px 0 0 -3px;position:absolute;top:50%;left:50%}.burst__shockwave{border:4px solid;border-radius:50%;width:80px;height:80px;margin:-40px 0 0 -40px;position:absolute;top:50%;left:50%}.burst__beam{position:absolute;top:50%;left:50%}.burst__beam--h{transform-origin:50%;filter:blur(1px);width:600px;height:12px;margin:-6px 0 0 -300px}.burst__beam--v{transform-origin:50%;filter:blur(1px);width:12px;height:600px;margin:-300px 0 0 -6px}.burst__label{letter-spacing:.1em;white-space:nowrap;font-size:22px;font-weight:900;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.special-panel{background:var(--bg-card);border:1px solid var(--border);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:14px;flex-direction:column;gap:10px;padding:12px;transition:all .2s;display:flex}.special-panel--active{border-color:var(--accent);box-shadow:0 0 32px #7df9ff26}.special-panel__label{color:var(--text-mute);letter-spacing:.1em;text-align:center;border-bottom:1px solid var(--border);padding-bottom:6px;font-size:12px;font-weight:700}.special-panel__lockmsg{color:var(--gold);text-align:center;letter-spacing:.08em;padding:2px 0;font-size:11px;font-weight:600}.special-panel__lockmsg strong{color:#fff;font-size:13px}.special-btn{border:1px solid var(--border-strong);color:var(--text);background:#ffffff08;border-radius:12px;flex-direction:column;align-items:center;gap:4px;padding:12px 8px;font-size:12px;font-weight:700;transition:all .15s;display:flex;position:relative}.special-btn:not(:disabled):hover{background:#ffffff14}.special-btn:disabled{opacity:.35}.special-btn__icon{font-size:22px;line-height:1}.special-btn__name{font-size:13px}.special-btn__count{color:var(--text-mute);font-size:11px;font-weight:600}.special-btn--lock.special-btn--selected{border-color:var(--gold);background:#ffd1661f;animation:1.2s ease-in-out infinite pulseGold;box-shadow:0 0 24px #ffd16673}.special-btn--blast.special-btn--selected{background:#ff5b3c26;border-color:#ff5b3c;animation:1.2s ease-in-out infinite pulseRed;box-shadow:0 0 24px #ff5b3c80}.special-btn--cross.special-btn--selected{border-color:var(--accent);background:#7df9ff1f;animation:1.2s ease-in-out infinite pulseCyan;box-shadow:0 0 24px #7df9ff73}@keyframes pulseGold{0%,to{box-shadow:0 0 14px #ffd16666}50%{box-shadow:0 0 32px #ffd166cc}}@keyframes pulseRed{0%,to{box-shadow:0 0 14px #ff5b3c73}50%{box-shadow:0 0 32px #ff5b3ce6}}@keyframes pulseCyan{0%,to{box-shadow:0 0 14px #7df9ff66}50%{box-shadow:0 0 32px #7df9ffcc}}.special-btn__tooltip{color:#e8ecf3;border:1px solid var(--border-strong);text-align:left;opacity:0;pointer-events:none;z-index:20;background:#0a0d18;border-radius:10px;width:200px;padding:10px 12px;font-size:11px;font-weight:500;line-height:1.5;transition:opacity .18s;position:absolute;bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.special-btn:hover:not(:disabled) .special-btn__tooltip{opacity:1}.game-help{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;padding:10px 16px;font-size:13px}.game-help summary{cursor:pointer;color:var(--text-mute);letter-spacing:.05em;font-weight:700}.game-help ul{color:var(--text-mute);margin:10px 0 4px;padding-left:20px;line-height:1.7}.game-help strong{color:var(--text)}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;background:#02040cc7;justify-content:center;align-items:center;display:flex;position:fixed;inset:0;overflow:hidden}.modal{border:1px solid var(--border-strong);text-align:center;background:linear-gradient(160deg,#161b2c,#0a0d18);border-radius:22px;min-width:280px;max-width:90vw;padding:28px 32px 24px;box-shadow:0 30px 80px #000000b3,0 0 120px #7df9ff33}.modal__banner{letter-spacing:.3em;border-radius:99px;margin-bottom:12px;padding:4px 14px;font-size:11px;font-weight:900;display:inline-block}.modal__banner--black{color:#0a0d18;background:linear-gradient(135deg,#ffd166,#ff5db1);box-shadow:0 0 30px #ffd16699}.modal__banner--white{color:var(--text-mute);border:1px solid var(--border-strong)}.modal__banner--draw{color:var(--accent);border:1px solid var(--accent)}.modal__title{letter-spacing:.02em;margin-bottom:18px;font-size:28px;font-weight:900}.modal__scores{justify-content:center;align-items:center;gap:18px;margin-bottom:22px;font-size:24px;font-weight:800;display:flex}.modal__score{align-items:center;gap:8px;display:inline-flex}.modal__vs{color:var(--text-mute);font-size:14px}.modal__actions{justify-content:center;gap:10px;display:flex}.btn{border:1px solid var(--border-strong);color:var(--text);background:0 0;border-radius:12px;padding:12px 22px;font-size:14px;font-weight:700;transition:all .15s}.btn--ghost:hover{background:#ffffff0f}.btn--primary{background:linear-gradient(135deg, var(--accent), var(--accent2));color:#0a0d18;border-color:#0000;box-shadow:0 0 24px #7df9ff66}.btn--primary:hover{transform:translateY(-1px);box-shadow:0 0 36px #7df9ff99}.confetti{pointer-events:none;position:absolute;inset:0;overflow:hidden}.confetti__piece{border-radius:2px;width:10px;height:14px;animation:linear forwards confettiFall;position:absolute;top:-20px}.confetti__piece--b{background:linear-gradient(135deg,#1a1a1a,#000);box-shadow:0 0 8px #0009}.confetti__piece--w{background:linear-gradient(135deg,#fff,#cfd5e2);box-shadow:0 0 8px #fff9}@keyframes confettiFall{0%{transform:translateY(-20px)rotate(0)}to{transform:translateY(110vh)rotate(720deg)}}@media (width<=640px){.game-area{grid-template-columns:1fr;grid-template-areas:"board""panelB""panelW";gap:12px}.board-wrap{grid-area:board}.special-panel--black{flex-direction:row;grid-area:panelB}.special-panel--white{flex-direction:row;grid-area:panelW}.special-panel{flex-flow:wrap}.special-panel__label{width:100%}.special-btn{flex:1;min-width:90px}.difficulty-grid{grid-template-columns:1fr 1fr}.title-main{font-size:48px}.play-header__title{font-size:14px}}
