:root{--bg: #0d1016;--bg2: #151923;--panel: #1b202b;--panel2: #232936;--panel3: #2a3140;--border: #3c4658;--border-strong: #66768f;--text: #f3efe5;--muted: #aab3bd;--accent: #30d5c8;--accent2: #6a8cff;--gold: #f0c85a;--green: #5cde86;--red: #ff5f62;--orange: #ff9f43;--violet: #b47cff;--ink: #080b10;--shadow: #040608cc;--pixel-shadow: 0 0 0 1px #ffffff0b inset, 0 0 0 2px #00000055, 0 16px 36px #0008}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:Segoe UI,PingFang SC,Microsoft YaHei,system-ui,sans-serif;background:linear-gradient(115deg,#10131a,#151826 34%,#1e1620 72%,#10131a);color:var(--text);overflow:hidden}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(#ffffff08 1px,transparent 1px),linear-gradient(90deg,#ffffff06 1px,transparent 1px);background-size:42px 42px;-webkit-mask-image:linear-gradient(to bottom,#000c,transparent 85%);mask-image:linear-gradient(to bottom,#000c,transparent 85%)}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;background:repeating-linear-gradient(0deg,transparent 0 3px,#00000014 4px 5px);mix-blend-mode:multiply;opacity:.55}button,input,select{font-family:inherit}button{cursor:pointer}.start{position:relative;width:min(860px,calc(100vw - 2rem));max-height:calc(100vh - 4rem);min-height:min(780px,calc(100vh - 4rem));margin:2rem auto;padding:clamp(1.4rem,4vw,2.4rem);text-align:center;isolation:isolate;display:flex;flex-direction:column;justify-content:center;gap:1rem;overflow-y:auto;overflow-x:hidden;scrollbar-color:#66768f #151923}.start:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:-2;border:1px solid #6f7f9655;border-radius:8px;background:linear-gradient(135deg,#1a202bfa,#111720f5),repeating-linear-gradient(45deg,#ffffff08 0 1px,transparent 1px 13px);box-shadow:0 28px 80px var(--shadow),inset 0 0 0 1px #ffffff08,inset 0 0 0 6px #00000024}.start:after{content:"";position:absolute;top:10px;right:10px;bottom:10px;left:10px;z-index:-1;border:1px solid #f0c85a44;border-radius:6px;background:linear-gradient(90deg,transparent,#30d5c815 48%,transparent 52%),repeating-linear-gradient(0deg,transparent 0 26px,#f0c85a0f 27px 28px);animation:mapSweep 5s ease-in-out infinite}.ambient{position:absolute;top:-12vh;right:-14vw;bottom:-12vh;left:-14vw;z-index:-3;overflow:hidden;pointer-events:none}.spark{position:absolute;width:2px;height:64px;background:linear-gradient(to bottom,transparent,var(--gold),transparent);opacity:.38;animation:sparkDrift 7s linear infinite}.spark.s1{left:18%;top:15%;animation-delay:-2s}.spark.s2{right:16%;top:30%;height:92px;animation-delay:-4s}.spark.s3{left:58%;bottom:4%;height:72px;animation-delay:-1s}.rift{position:absolute;left:5%;right:5%;top:48%;height:2px;background:linear-gradient(90deg,transparent,#30d5c855,#f0c85a66,transparent);transform:rotate(-7deg);animation:riftPulse 4s ease-in-out infinite}.start-orbit{position:absolute;top:1.1rem;right:1.1rem;bottom:1.1rem;left:1.1rem;pointer-events:none;color:#f0c85a99;font-size:1.35rem}.start-orbit span{position:absolute;animation:floatMark 4.2s ease-in-out infinite}.start-orbit span:nth-child(1){left:1rem;top:1rem}.start-orbit span:nth-child(2){right:1.4rem;top:44%;animation-delay:-1.3s;color:#30d5c899}.start-orbit span:nth-child(3){left:44%;bottom:1rem;animation-delay:-2.5s}.title-lockup{display:grid;justify-items:center;gap:.45rem}.pixel-mark{width:42px;height:42px;display:grid;place-items:center;border:2px solid var(--gold);background:linear-gradient(135deg,#30d5c82e,transparent 58%),#111721;color:var(--gold);font-weight:900;box-shadow:0 0 0 3px #000,0 0 22px #f0c85a28;transform:rotate(-3deg)}.start h1{font-size:clamp(3.2rem,10vw,5.8rem);line-height:.95;margin:0;letter-spacing:0;text-transform:uppercase;color:#f5d76d;-webkit-text-fill-color:#f5d76d;text-shadow:0 0 14px #f0c85a55,0 0 30px #30d5c83a,0 2px 18px #000;filter:drop-shadow(0 0 14px #30d5c83a);opacity:1}.tagline{color:var(--muted);margin:0;line-height:1.45;text-shadow:0 1px 0 #000}.start-config{padding:clamp(.8rem,2vw,1.1rem);border:1px solid #ffffff16;border-radius:8px;background:linear-gradient(180deg,#101720e0,#0c111adb),repeating-linear-gradient(90deg,transparent 0 20px,#30d5c807 21px 22px);box-shadow:inset 0 0 0 1px #0000005c}.mode-select{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.8rem}.mode{position:relative;min-height:116px;display:flex;flex-direction:column;justify-content:center;gap:.45rem;padding:1.2rem;border-radius:8px;border:1px solid var(--border);background:linear-gradient(145deg,#29313fcc,#171c27f5),repeating-linear-gradient(45deg,transparent 0 12px,#ffffff08 13px 14px);color:var(--text);overflow:hidden;transition:transform .18s ease,border-color .18s ease,box-shadow .18s ease}.mode:after{content:"";position:absolute;top:6px;right:6px;bottom:6px;left:6px;border:1px solid #ffffff0d;pointer-events:none}.mode:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 25%,#ffffff24 48%,transparent 65%);transform:translate(-120%);transition:transform .45s ease}.mode:hover:not(:disabled){transform:translateY(-3px);border-color:var(--accent);box-shadow:0 12px 28px #0008}.mode:hover:before{transform:translate(120%)}.mode b{font-size:1.08rem;letter-spacing:0}.mode span{color:var(--muted);font-size:.85rem;line-height:1.45}.mode-icon{width:30px;height:30px;display:grid;place-items:center;align-self:center;border:1px solid #ffffff22;border-radius:6px;background:#080b10a8;color:var(--gold)!important;font-size:1rem!important;font-weight:900;line-height:1}.mode.on{border-color:var(--gold);box-shadow:0 0 0 1px #f0c85a55 inset,0 0 34px #f0c85a24;animation:selectedAura 3.2s ease-in-out infinite}.theme-input{width:100%;margin-top:1rem;padding:.75rem 1rem;border-radius:8px;border:1px solid var(--border);background:#111721;color:var(--text);outline:none;transition:border-color .16s ease,box-shadow .16s ease}.theme-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #30d5c826}.profile-row{margin-bottom:1rem}.profile-row .theme-input{margin-top:0;text-align:center}.difficulty-select{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:.5rem;margin-top:1rem}.difficulty{position:relative;min-height:76px;padding:.55rem .45rem;border-radius:8px;border:1px solid var(--border);background:linear-gradient(180deg,#171d28d9,#0d121bd9),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff07 11px 12px);color:var(--muted);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.12rem;overflow:hidden;transition:transform .15s ease,border-color .15s ease,color .15s ease,box-shadow .15s ease}.difficulty:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--level-color, var(--accent));opacity:.78}.difficulty:hover{transform:translateY(-2px);border-color:var(--accent);box-shadow:0 10px 22px #0007}.difficulty b{color:var(--level-color, var(--gold));font-size:1rem}.difficulty span{max-width:100%;color:var(--text);font-size:.8rem;overflow-wrap:anywhere}.difficulty small{font-size:.72rem;color:var(--muted)}.difficulty.d-0{--level-color: #5cde86}.difficulty.d-1{--level-color: #30d5c8}.difficulty.d-2{--level-color: #78dff2}.difficulty.d-3{--level-color: #f0c85a}.difficulty.d-4{--level-color: #ff9f43}.difficulty.d-5{--level-color: #ff5f62}.difficulty.d-6{--level-color: #b47cff}.difficulty.d-7{--level-color: #ff4fd8}.difficulty.d-8{--level-color: #f6f0ff}.difficulty.d-9{--level-color: #7df6ff}.difficulty.d-10{--level-color: #ff3868}.difficulty.on{color:var(--text);border-color:var(--level-color, var(--gold));background:linear-gradient(180deg,color-mix(in srgb,var(--level-color, var(--gold)) 20%,transparent),#111721d9),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff08 11px 12px);box-shadow:0 0 0 1px color-mix(in srgb,var(--level-color, var(--gold)) 50%,transparent) inset,0 0 24px color-mix(in srgb,var(--level-color, var(--gold)) 22%,transparent)}.difficulty-note{min-height:44px;margin-top:.55rem;padding:.55rem .7rem;border:1px solid #ffffff12;border-radius:8px;background:#1117218f;color:var(--muted);display:flex;flex-direction:column;gap:.2rem;line-height:1.4;font-size:.86rem}.difficulty-note b{color:var(--text)}.rule-list{display:flex;justify-content:center;flex-wrap:wrap;gap:.35rem}.rule-list span{max-width:100%;padding:.18rem .45rem;border:1px solid #ffffff14;border-radius:6px;background:#00000026;color:var(--muted);overflow-wrap:anywhere}.difficulty-pressure{display:flex;justify-content:center;flex-wrap:wrap;gap:.35rem}.difficulty-pressure span{padding:.2rem .55rem;border:1px solid #30d5c833;border-radius:6px;background:linear-gradient(180deg,#30d5c814,#00000018),repeating-linear-gradient(90deg,transparent 0 7px,#ffffff06 8px 9px);color:#dfeff0;font-weight:800}.start-actions{margin-top:2rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}.badge-wall{margin-top:1rem;padding:.75rem;border:1px solid #ffffff12;border-radius:8px;background:linear-gradient(180deg,#111721aa,#0b1018a8),repeating-linear-gradient(135deg,transparent 0 12px,#ffffff06 13px 14px)}.badge-wall-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem;color:var(--muted);font-size:.78rem;font-weight:800}.badge-wall-head div{min-width:0;display:flex;flex-direction:column;align-items:flex-start;gap:.1rem}.badge-wall-head b{max-width:100%;color:var(--text);font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-wall-head>span{flex:0 0 auto;white-space:nowrap}.badge-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(168px,1fr));gap:.45rem}.badge-tile{--badge-color: #b47cff;position:relative;min-height:132px;padding:.55rem .55rem .55rem 2.25rem;border:1px solid color-mix(in srgb,var(--badge-color) 45%,#ffffff10);border-radius:6px;background:linear-gradient(180deg,color-mix(in srgb,var(--badge-color) 12%,transparent),#10151edf),repeating-linear-gradient(90deg,transparent 0 7px,#ffffff08 8px 9px);text-align:left;box-shadow:2px 2px #05070b;overflow:hidden}.badge-tile.d-7{--badge-color: #ff4fd8}.badge-tile.d-8{--badge-color: #f6f0ff}.badge-tile.d-9{--badge-color: #7df6ff}.badge-tile.d-10{--badge-color: #ff3868}.badge-tile:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--badge-color);opacity:.85}.badge-tile.locked{--badge-color: #8390a4;filter:saturate(.6);opacity:.72}.badge-tile.earned{box-shadow:2px 2px #05070b,0 0 18px color-mix(in srgb,var(--badge-color) 22%,transparent)}.badge-tile.d-8.earned{border-color:#ff3868;box-shadow:2px 2px #05070b,inset 3px 0 #ff3868,0 0 18px #ff38684d}.badge-tile.d-9.earned,.badge-tile.d-10.earned{border-color:#f6f0ff;box-shadow:2px 2px #05070b,inset 3px 0 0 var(--badge-color),0 0 22px color-mix(in srgb,var(--badge-color) 45%,transparent)}.badge-glyph{position:absolute;left:.5rem;top:.55rem;width:1.35rem;height:1.35rem;display:grid;place-items:center;color:var(--badge-color);font-size:.78rem;text-shadow:0 0 12px color-mix(in srgb,var(--badge-color) 45%,transparent)}.badge-glyph img{width:100%;height:100%;object-fit:cover;image-rendering:pixelated;border:1px solid color-mix(in srgb,var(--badge-color) 48%,#ffffff16);border-radius:4px;background:#05070b;box-shadow:0 0 10px color-mix(in srgb,var(--badge-color) 28%,transparent)}.badge-tile.locked .badge-glyph img{filter:grayscale(1) brightness(.58);opacity:.78}.badge-tile.earned .badge-glyph img{filter:saturate(1.15) contrast(1.08)}.badge-tile div{min-width:0;display:flex;flex-direction:column;gap:.12rem}.badge-tile b,.badge-tile span,.badge-tile small{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-tile b{color:var(--badge-color);font-size:.82rem}.badge-tile span{color:var(--text);font-size:.76rem;font-weight:900}.badge-tile small{color:var(--muted);font-size:.68rem}.badge-meta,.badge-feats{min-width:0;display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.18rem}.badge-meta i{max-width:100%;padding:.12rem .35rem;border:1px solid color-mix(in srgb,var(--badge-color) 34%,#ffffff12);border-radius:5px;background:#0002;color:#dfeff0;font-style:normal;font-size:.64rem;line-height:1.25;overflow-wrap:anywhere}.badge-tile.locked .badge-meta i{color:var(--muted);border-color:#ffffff12}.history{margin-top:1rem;padding:.75rem;border:1px solid #ffffff12;border-radius:8px;background:#1117219a}.history-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.45rem}.section-kicker{color:var(--gold);font-size:.78rem;font-weight:800}.history-list{display:grid;gap:.4rem;max-height:210px;overflow-y:auto;padding-right:.2rem}.history-row{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.35rem .7rem;text-align:left;padding:.55rem .6rem;border-radius:8px;background:#151923d9;border:1px solid #ffffff10}.history-row div{min-width:0;display:flex;flex-direction:column}.history-row b,.history-row span,.history-row small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-row span,.history-row small{color:var(--muted)}.history-row .history-feats{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:.18rem;white-space:normal;overflow:visible}.history-row strong{color:var(--gold);align-self:center;white-space:nowrap}.history-row small{grid-column:1 / -1;font-size:.78rem}.clear-badge{--badge-color: var(--gold);display:inline-block;width:fit-content;max-width:100%;margin-top:.35rem;padding:.16rem .42rem;border:1px solid color-mix(in srgb,var(--badge-color) 72%,#ffffff);border-radius:3px;background:linear-gradient(180deg,color-mix(in srgb,var(--badge-color) 18%,transparent),#070a11),repeating-linear-gradient(90deg,transparent 0 6px,#ffffff0d 7px 8px);color:var(--badge-color);font-size:.72rem;font-style:normal;font-weight:900;line-height:1.2;white-space:nowrap;box-shadow:2px 2px #05070b,0 0 16px color-mix(in srgb,var(--badge-color) 22%,transparent)}.clear-badge.d-7{--badge-color: #ff4fd8}.clear-badge.d-9{--badge-color: #7df6ff}.clear-badge.d-10{--badge-color: #ff3868;border-color:#f6f0ff}.clear-badge.d-8{--badge-color: #f6f0ff;border-color:#ff3868;box-shadow:2px 2px #05070b,inset 3px 0 #ff3868,0 0 18px #ff38684d}.clear-badge.mini{margin:0 .35rem 0 0;padding:.08rem .28rem;font-size:.66rem;vertical-align:.08rem;box-shadow:1px 1px #05070b}.feat-list{display:flex;justify-content:center;flex-wrap:wrap;gap:.35rem;margin-top:.7rem}.feat-chip{--feat-color: var(--gold);display:inline-flex;align-items:center;max-width:100%;min-height:24px;padding:.14rem .44rem;border:1px solid color-mix(in srgb,var(--feat-color) 58%,#ffffff16);border-radius:3px;background:linear-gradient(180deg,color-mix(in srgb,var(--feat-color) 16%,transparent),#070a11),repeating-linear-gradient(90deg,transparent 0 6px,#ffffff0c 7px 8px);color:var(--feat-color);font-size:.72rem;font-style:normal;font-weight:900;line-height:1.15;white-space:nowrap;box-shadow:2px 2px #05070b}.feat-chip.win{--feat-color: #5cde86}.feat-chip.scar{--feat-color: #ff5f62}.feat-chip.echo{--feat-color: #30d5c8}.feat-chip.crown{--feat-color: #f6f0ff;border-color:#ff3868;box-shadow:2px 2px #05070b,inset 3px 0 #ff3868}.feat-chip.mini{min-height:18px;padding:.06rem .24rem;font-size:.62rem;box-shadow:1px 1px #05070b}.btn{position:relative;padding:.62rem 1.1rem;border-radius:8px;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel3),var(--panel2));color:var(--text);overflow:hidden;box-shadow:inset 0 -2px #00000038;transition:transform .15s ease,border-color .15s ease,box-shadow .15s ease}.btn:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 18%,#ffffff24 45%,transparent 68%);transform:translate(-120%)}.btn:hover:not(:disabled){transform:translateY(-1px);border-color:var(--accent);box-shadow:0 8px 20px #0007}.btn:hover:not(:disabled):after{animation:buttonSheen .65s ease}.btn:active:not(:disabled){transform:translateY(1px) scale(.99)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.primary{border-color:#f0c85a66;background:linear-gradient(95deg,#187b76,#3b66c7 56%,#d29c30),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff10 9px 10px);color:#fff;box-shadow:0 0 20px #30d5c82b;animation:primaryGlow 4.2s ease-in-out infinite}.btn.big{padding:.95rem 2rem;font-size:1.08rem;font-weight:800}.btn.small{padding:.35rem .8rem;font-size:.85rem}.app{position:relative;height:100%;display:flex;flex-direction:column;isolation:isolate}.game-ambient{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;pointer-events:none;overflow:hidden}.game-ambient:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,#30d5c80b 30%,transparent 60%),repeating-linear-gradient(90deg,transparent 0 18px,#ffffff05 19px 20px);animation:boardPan 18s linear infinite}.ember{position:absolute;width:1px;height:54px;background:linear-gradient(to bottom,transparent,#f0c85aaa,transparent);opacity:.32;animation:emberRise 8s linear infinite}.ember.e1{left:12%;bottom:-10%}.ember.e2{left:52%;bottom:-20%;animation-delay:-3s;background:linear-gradient(to bottom,transparent,#30d5c8bb,transparent)}.ember.e3{right:14%;bottom:-12%;animation-delay:-5s}.scanline{position:absolute;top:0;right:0;bottom:0;left:0;background:repeating-linear-gradient(0deg,transparent 0 18px,#ffffff04 19px 20px);mix-blend-mode:screen}.topbar{position:relative;display:flex;align-items:center;gap:1rem;padding:.72rem 1.2rem;border-bottom:1px solid #66768f55;background:linear-gradient(180deg,#1b202bf2,#111720eb);box-shadow:0 4px #05070b,inset 0 -1px #ffffff0c;z-index:2}.topbar:before{content:"";position:absolute;left:0;right:0;bottom:-1px;height:1px;background:linear-gradient(90deg,transparent,var(--accent),var(--gold),transparent);opacity:.7}.logo{font-weight:900;letter-spacing:0;color:var(--gold);text-shadow:0 0 18px #f0c85a33}.topbar-meta{min-width:0;display:flex;align-items:center;gap:.55rem;flex-wrap:wrap}.mode-tag{font-size:.8rem;color:var(--text);border:1px solid #30d5c866;border-radius:2px;padding:.1rem .62rem;background:#0e2024;box-shadow:2px 2px #05070b}.topbar .btn{margin-left:auto}.layout{flex:1;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:1rem;padding:1rem;min-height:0}.center{display:flex;flex-direction:column;min-height:0;gap:.8rem}.run-status{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:.8rem;align-items:center;padding:.68rem .8rem;border:1px solid #66768f55;border-radius:8px;background:linear-gradient(90deg,#151923f0,#111721e5),repeating-linear-gradient(90deg,transparent 0 16px,#ffffff05 17px 18px);box-shadow:inset 0 0 0 1px #ffffff08}.run-event{min-width:0;display:flex;align-items:center;gap:.65rem}.run-event b{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.run-status-metrics{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.4rem}.run-status-metrics span{padding:.16rem .48rem;border:1px solid #30d5c838;border-radius:6px;background:#30d5c80f;color:var(--muted);font-size:.8rem;white-space:nowrap}.scene-stage{--scene-tone: var(--accent);position:relative;display:grid;grid-template-columns:minmax(180px,.45fr) minmax(0,1fr);grid-template-rows:auto auto;gap:.8rem;min-height:188px;padding:.8rem;border:1px solid color-mix(in srgb,var(--scene-tone) 42%,var(--border));border-radius:8px;background:linear-gradient(135deg,color-mix(in srgb,var(--scene-tone) 13%,#171c27),#111721 72%),repeating-linear-gradient(45deg,transparent 0 16px,#ffffff06 17px 18px);box-shadow:var(--pixel-shadow);overflow:hidden;animation:sceneWake .36s ease both}.scene-stage:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(90deg,transparent,color-mix(in srgb,var(--scene-tone) 26%,transparent),transparent),repeating-linear-gradient(0deg,transparent 0 10px,#00000018 11px 12px);opacity:.38;animation:sceneScan 14s linear infinite}.scene-stage:after{content:"";position:absolute;top:7px;right:7px;bottom:7px;left:7px;pointer-events:none;border:1px solid #ffffff12;border-radius:6px}.scene-stage.tone-snow{--scene-tone: #9ed8ff}.scene-stage.tone-sea{--scene-tone: #30d5c8}.scene-stage.tone-fire{--scene-tone: #ff9f43}.scene-stage.tone-forest{--scene-tone: #5cde86}.scene-stage.tone-spirit{--scene-tone: #b47cff}.scene-stage.tone-city,.scene-stage.tone-lamp{--scene-tone: #f0c85a}.scene-stage.tone-rift{--scene-tone: #ff4fd8}.scene-stage.tone-relic{--scene-tone: #78dff2}.scene-stage.tone-candle{--scene-tone: #7df6ff}.scene-stage.tone-boundary{--scene-tone: #ff3868}.scene-stage.tone-road{--scene-tone: #6a8cff}.scene-frame{position:relative;grid-row:1 / span 2;min-height:164px;aspect-ratio:3 / 2;align-self:stretch;border:2px solid #05070b;border-radius:6px;background:linear-gradient(180deg,color-mix(in srgb,var(--scene-tone) 18%,#19202c),#090d14),repeating-linear-gradient(90deg,transparent 0 12px,#ffffff08 13px 14px);box-shadow:inset 0 0 0 1px #ffffff12,0 12px 26px #0008;overflow:hidden}.scene-art,.scene-fallback{width:100%;height:100%;display:block;object-fit:cover}.scene-art,.scene-fallback{image-rendering:pixelated}.scene-fallback{position:relative;overflow:hidden;background:linear-gradient(180deg,color-mix(in srgb,var(--scene-tone) 18%,#111721) 0,color-mix(in srgb,var(--scene-tone) 18%,#111721) 44%,#0a0f16 45%,#0a0f16),repeating-linear-gradient(90deg,transparent 0 9px,#ffffff08 10px 11px)}.scene-fallback span{position:absolute;display:block;image-rendering:pixelated}.scene-fallback .px-sky{top:0;right:0;bottom:42%;left:0;background:repeating-linear-gradient(90deg,color-mix(in srgb,var(--scene-tone) 34%,#121722) 0,color-mix(in srgb,var(--scene-tone) 34%,#121722) 16px,#111721 16px,#111721 32px);opacity:.78}.scene-fallback .px-horizon{left:0;right:0;bottom:40%;height:16px;background:color-mix(in srgb,var(--scene-tone) 48%,#05070b);box-shadow:0 6px #05070b55}.scene-fallback .px-ground{left:-4%;right:-4%;bottom:0;height:44%;background:repeating-linear-gradient(90deg,#090d14 0,#090d14 18px,color-mix(in srgb,var(--scene-tone) 18%,#0c121b) 18px,color-mix(in srgb,var(--scene-tone) 18%,#0c121b) 36px)}.scene-fallback .px-path{left:38%;bottom:-8%;width:24%;height:52%;transform:skew(-10deg);background:linear-gradient(180deg,color-mix(in srgb,var(--scene-tone) 28%,#242c37),#171c27),repeating-linear-gradient(0deg,transparent 0 10px,#00000026 10px 12px);border-left:2px solid #0008;border-right:2px solid #ffffff10}.scene-fallback .px-landmark{background:color-mix(in srgb,var(--scene-tone) 62%,#111721);box-shadow:inset 0 0 0 2px #00000042,4px 4px #05070b8a}.scene-fallback .px-landmark.a{left:15%;bottom:38%;width:26px;height:52px}.scene-fallback .px-landmark.b{right:16%;bottom:38%;width:40px;height:34px}.scene-fallback.fallback-road .px-landmark.a{width:12px;height:48px;box-shadow:inset 0 0 0 2px #00000042,18px 10px color-mix(in srgb,var(--scene-tone) 54%,#101620),4px 4px #05070b8a}.scene-fallback.fallback-city .px-landmark.a,.scene-fallback.fallback-city .px-landmark.b{bottom:39%;height:60px}.scene-fallback.fallback-forest .px-landmark{clip-path:polygon(50% 0,100% 50%,72% 50%,92% 78%,58% 78%,58% 100%,42% 100%,42% 78%,8% 78%,28% 50%,0 50%)}.scene-fallback.fallback-fire .px-ground{background:repeating-linear-gradient(90deg,#130b09 0,#130b09 18px,#35120a 18px,#35120a 36px)}.scene-fallback.fallback-sea .px-ground{height:50%;background:repeating-linear-gradient(0deg,#08323a 0,#08323a 10px,#0d4d55 10px,#0d4d55 16px)}.scene-fallback.fallback-snow .px-ground{background:repeating-linear-gradient(90deg,#d7edf8 0,#d7edf8 18px,#9ed8ff 18px,#9ed8ff 36px)}.scene-fallback.fallback-spirit .px-landmark{border-radius:12px 12px 0 0;opacity:.72}.scene-fallback.fallback-lamp{background:linear-gradient(180deg,#111721 0,#111721 42%,#131015 43%,#131015),repeating-linear-gradient(90deg,transparent 0 9px,#f0c85a12 10px 11px)}.scene-fallback.fallback-lamp .px-sky{background:radial-gradient(circle at 22% 38%,#f0c85a 0 6px,#f0c85a66 7px 18px,transparent 19px),radial-gradient(circle at 68% 44%,#f0c85a 0 4px,#f0c85a55 5px 14px,transparent 15px),repeating-linear-gradient(90deg,#151923 0,#151923 16px,#101620 16px,#101620 32px)}.scene-fallback.fallback-lamp .px-landmark.a{width:10px;height:58px;background:#382514;box-shadow:0 -16px 0 4px #f0c85a,0 -16px 0 10px #f0c85a44,20px 14px #382514,20px -2px 0 4px #f0c85a,20px -2px 0 10px #f0c85a3a,4px 4px #05070b8a}.scene-fallback.fallback-lamp .px-landmark.b{height:24px;bottom:42%;background:repeating-linear-gradient(90deg,#2a1c15 0,#2a1c15 10px,#3c2a1d 10px,#3c2a1d 20px)}.scene-fallback.fallback-rift{background:linear-gradient(180deg,#121320 0,#121320 46%,#080a12 47%,#080a12),repeating-linear-gradient(90deg,transparent 0 8px,#ff4fd812 9px 10px)}.scene-fallback.fallback-rift .px-sky{background:radial-gradient(circle at 58% 34%,#f6f0ff 0 5px,#ff386866 6px 22px,transparent 23px),repeating-linear-gradient(90deg,#111721 0,#111721 16px,#171225 16px,#171225 32px)}.scene-fallback.fallback-rift .px-horizon{background:#ff3868;box-shadow:0 6px #05070b88,0 0 18px #ff386899}.scene-fallback.fallback-rift .px-path{background:linear-gradient(180deg,#f6f0ff,#ff3868 42%,#111721 43%),repeating-linear-gradient(0deg,transparent 0 8px,#00000038 8px 10px);transform:skew(14deg)}.scene-fallback.fallback-rift .px-landmark.a{width:54px;height:32px;border-radius:50%;background:transparent;border:7px solid #ff3868;box-shadow:0 0 0 2px #05070b,0 0 20px #ff386866}.scene-fallback.fallback-rift .px-landmark.b{width:14px;height:66px;background:#f6f0ff;box-shadow:12px 8px #ff3868,-10px 18px #ff4fd8,4px 4px #05070b8a}.scene-fallback.fallback-relic{background:linear-gradient(180deg,#151923 0,#151923 42%,#0b1018 43%,#0b1018),repeating-linear-gradient(90deg,transparent 0 10px,#78dff212 11px 12px)}.scene-fallback.fallback-relic .px-sky{background:repeating-linear-gradient(90deg,#17202b 0,#17202b 16px,#111721 16px,#111721 32px)}.scene-fallback.fallback-relic .px-landmark.a{left:18%;bottom:35%;width:34px;height:74px;transform:skew(-6deg);background:linear-gradient(180deg,#8ea0a8,#485662),repeating-linear-gradient(0deg,transparent 0 9px,#05070b33 9px 11px);box-shadow:inset 0 0 0 3px #05070b55,12px 18px #2e3944,4px 4px #05070b8a}.scene-fallback.fallback-relic .px-landmark.b{right:14%;bottom:39%;width:46px;height:28px;background:repeating-linear-gradient(90deg,#3d4d58 0,#3d4d58 9px,#516370 9px,#516370 18px)}.scene-fallback.fallback-relic .px-path{background:linear-gradient(180deg,#2d3a44,#111721),repeating-linear-gradient(0deg,transparent 0 10px,#78dff21f 10px 12px)}.scene-fallback.fallback-candle{background:linear-gradient(180deg,#0d1320 0,#0d1320 44%,#090d14 45%,#090d14),repeating-linear-gradient(90deg,transparent 0 8px,#7df6ff10 9px 10px)}.scene-fallback.fallback-candle .px-sky{background:radial-gradient(circle at 50% 34%,#f0c85a 0 5px,#7df6ff80 6px 20px,transparent 21px),repeating-linear-gradient(90deg,#101620 0,#101620 16px,#151923 16px,#151923 32px)}.scene-fallback.fallback-candle .px-horizon{background:#7df6ff;box-shadow:0 6px #05070b88,0 0 18px #7df6ff75}.scene-fallback.fallback-candle .px-landmark.a{left:46%;bottom:36%;width:14px;height:70px;background:#f0c85a;box-shadow:0 -18px 0 5px #7df6ff,0 -18px 0 12px #7df6ff45,4px 4px #05070b8a}.scene-fallback.fallback-candle .px-landmark.b{right:18%;bottom:40%;width:52px;height:12px;background:repeating-linear-gradient(90deg,#7df6ff 0,#7df6ff 8px,#f6f0ff 8px,#f6f0ff 16px)}.scene-fallback.fallback-boundary{background:linear-gradient(180deg,#10111a 0,#10111a 46%,#06080e 47%,#06080e),repeating-linear-gradient(90deg,transparent 0 7px,#ff386814 8px 9px)}.scene-fallback.fallback-boundary .px-sky{background:linear-gradient(90deg,transparent 0 46%,#f6f0ff 47% 53%,transparent 54%),radial-gradient(circle at 50% 42%,#ff3868 0 5px,#ff386866 6px 26px,transparent 27px),repeating-linear-gradient(90deg,#111721 0,#111721 14px,#171225 14px,#171225 28px)}.scene-fallback.fallback-boundary .px-horizon{height:10px;background:#f6f0ff;box-shadow:0 6px #ff3868,0 0 18px #ff386899}.scene-fallback.fallback-boundary .px-path{left:34%;width:32%;transform:skew(0);background:repeating-linear-gradient(0deg,#f6f0ff 0,#f6f0ff 8px,#ff3868 8px,#ff3868 13px,#111721 13px,#111721 18px)}.scene-fallback.fallback-boundary .px-landmark.a{left:48%;bottom:34%;width:10px;height:82px;background:#ff3868;box-shadow:-20px 14px #7df6ff,20px 14px #f6f0ff,0 0 18px #ff386899,4px 4px #05070b8a}.scene-fallback.fallback-boundary .px-landmark.b{right:13%;bottom:44%;width:46px;height:20px;background:linear-gradient(90deg,#ff3868 0,#ff3868 4px,#f6f0ff 4px,#f6f0ff)}.scene-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,transparent 45%,#00000070),repeating-linear-gradient(0deg,transparent 0 4px,#00000022 5px 6px);mix-blend-mode:multiply}.scene-overlay span{position:absolute;width:2px;height:44%;background:linear-gradient(to bottom,transparent,color-mix(in srgb,var(--scene-tone) 82%,white),transparent);opacity:.32;animation:sceneSpark 9s linear infinite}.scene-overlay span:nth-child(1){left:18%;top:-20%}.scene-overlay span:nth-child(2){left:54%;top:12%;animation-delay:-2s}.scene-overlay span:nth-child(3){right:14%;top:-8%;animation-delay:-3.4s}.scene-result-flash{--flash-color: var(--scene-tone);position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:0;background:repeating-linear-gradient(90deg,transparent 0 10px,color-mix(in srgb,var(--flash-color) 42%,transparent) 10px 18px,transparent 18px 28px),repeating-linear-gradient(0deg,transparent 0 12px,color-mix(in srgb,var(--flash-color) 34%,transparent) 12px 18px,transparent 18px 30px);mix-blend-mode:normal}.scene-result-burst{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.scene-result-burst span{--burst-x: 0px;--burst-y: 0px;position:absolute;left:50%;top:50%;width:7px;height:7px;opacity:0;background:color-mix(in srgb,var(--flash-color, var(--scene-tone)) 82%,white);box-shadow:2px 2px #05070b}.scene-result-burst span:nth-child(1){--burst-x: -84px;--burst-y: -36px}.scene-result-burst span:nth-child(2){--burst-x: -54px;--burst-y: -66px}.scene-result-burst span:nth-child(3){--burst-x: -24px;--burst-y: -48px}.scene-result-burst span:nth-child(4){--burst-x: 18px;--burst-y: -70px}.scene-result-burst span:nth-child(5){--burst-x: 58px;--burst-y: -38px}.scene-result-burst span:nth-child(6){--burst-x: 86px;--burst-y: -10px}.scene-result-burst span:nth-child(7){--burst-x: 48px;--burst-y: 30px}.scene-result-burst span:nth-child(8){--burst-x: 12px;--burst-y: 58px}.scene-result-burst span:nth-child(9){--burst-x: -34px;--burst-y: 42px}.scene-result-burst span:nth-child(10){--burst-x: -76px;--burst-y: 22px}.scene-result-burst span:nth-child(11){--burst-x: -98px;--burst-y: -4px}.scene-result-burst span:nth-child(12){--burst-x: 96px;--burst-y: 28px}.scene-result-burst span:nth-child(13){--burst-x: -8px;--burst-y: -88px}.scene-result-burst span:nth-child(14){--burst-x: 0px;--burst-y: 82px}.scene-stage.pulse-win .scene-result-burst span,.scene-stage.pulse-crit-win .scene-result-burst span,.scene-stage.pulse-challenge-win .scene-result-burst span{--flash-color: var(--gold);animation:scenePixelBurst .76s steps(4,end) both}.scene-stage.pulse-lose .scene-result-burst span,.scene-stage.pulse-crit-lose .scene-result-burst span,.scene-stage.pulse-challenge-lose .scene-result-burst span{--flash-color: var(--red);animation:scenePixelBurst .62s steps(3,end) both}.scene-stage.pulse-win .scene-result-flash,.scene-stage.pulse-challenge-win .scene-result-flash{--flash-color: var(--green);animation:sceneResultFlash .72s steps(4,end) both}.scene-stage.pulse-crit-win .scene-result-flash{--flash-color: var(--gold);animation:sceneCritWinFlash .92s steps(5,end) both}.scene-stage.pulse-lose .scene-result-flash,.scene-stage.pulse-challenge-lose .scene-result-flash{--flash-color: var(--red);animation:sceneResultFlash .62s steps(3,end) both}.scene-stage.pulse-crit-lose .scene-result-flash{--flash-color: var(--red);animation:sceneCritLoseFlash .78s steps(4,end) both}.scene-stage.pulse-win .scene-frame,.scene-stage.pulse-challenge-win .scene-frame{animation:sceneFrameLift .9s steps(3,end) both}.scene-stage.pulse-crit-win .scene-frame{animation:sceneFrameLift 1.15s steps(4,end) both}.scene-stage.pulse-lose .scene-frame,.scene-stage.pulse-challenge-lose .scene-frame{animation:sceneFrameJolt .62s steps(3,end) both}.scene-stage.pulse-crit-lose .scene-frame{animation:sceneFrameBreak .82s steps(4,end) both}.scene-stage.milestone-win .scene-result-burst span{--flash-color: var(--gold);animation:scenePixelBurst 1.1s steps(5,end) both}.scene-stage.milestone-win .scene-result-flash{--flash-color: var(--gold);animation:sceneCritWinFlash 1.2s steps(6,end) both}.scene-stage.milestone-win .scene-frame{border-color:color-mix(in srgb,var(--gold) 70%,#05070b);animation:sceneFrameLift 1.2s steps(4,end) both;box-shadow:inset 0 0 0 1px #ffffff18,0 12px 26px #0008,0 0 28px #f0c85a52}.scene-stage.milestone-scar .scene-result-burst span{--flash-color: #ff3868;animation:scenePixelBurst .86s steps(4,end) both}.scene-stage.milestone-scar .scene-result-flash{--flash-color: #ff3868;animation:sceneCritLoseFlash .98s steps(5,end) both}.scene-stage.milestone-scar .scene-frame{border-color:color-mix(in srgb,#ff3868 70%,#05070b);animation:sceneFrameJolt .82s steps(4,end) both;box-shadow:inset 0 0 0 1px #ffffff12,0 12px 26px #0008,0 0 24px #ff38684a}.scene-copy{position:relative;z-index:1;min-width:0;align-self:end}.scene-copy h2{margin:.22rem 0 .32rem;color:color-mix(in srgb,var(--scene-tone) 64%,var(--gold));font-size:clamp(1.3rem,2.4vw,2rem);line-height:1.1;letter-spacing:0;text-shadow:0 0 18px color-mix(in srgb,var(--scene-tone) 30%,transparent),0 2px 0 #000;overflow-wrap:anywhere}.scene-copy p{margin:0;color:var(--text);line-height:1.65;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:3;overflow:hidden}.scene-growth{position:relative;z-index:1;display:flex;flex-wrap:wrap;align-self:start;gap:.38rem}.scene-growth span{min-height:26px;display:inline-flex;align-items:center;padding:.16rem .48rem;border:1px solid color-mix(in srgb,var(--scene-tone) 42%,#ffffff18);border-radius:6px;background:#05070b78;color:var(--muted);font-size:.78rem;white-space:nowrap}.scene-growth .gain{color:var(--green);border-color:#5cde8655}.scene-growth .loss{color:var(--red);border-color:#ff5f6255}.scene-challenge-chip{position:absolute;right:.9rem;top:.9rem;z-index:2;max-width:min(280px,calc(100% - 1.8rem));display:grid;gap:.12rem;padding:.42rem .55rem;border:2px solid currentColor;border-radius:2px;background:#070b12e8;box-shadow:3px 3px #05070b;animation:challengeChipStrike .68s steps(4,end) both}.scene-challenge-chip.pass{color:var(--green)}.scene-challenge-chip.fail{color:var(--red)}.scene-challenge-chip b{font-size:.78rem;line-height:1}.scene-challenge-chip span{min-width:0;color:var(--text);font-size:.72rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.narrative{flex:1;overflow-y:auto;padding:1rem 1.15rem;background:linear-gradient(180deg,#202632f2,#171c27f2),repeating-linear-gradient(45deg,transparent 0 18px,#ffffff05 19px 20px);border:1px solid var(--border);border-radius:8px;line-height:1.7;box-shadow:var(--pixel-shadow);scrollbar-color:#66768f #151923}.log-event{position:relative;margin:.3rem 0 1rem;padding:.85rem .95rem .95rem;border-left:3px solid var(--gold);border-radius:0 8px 8px 0;background:linear-gradient(90deg,#f0c85a13,transparent 70%);animation:entryReveal .42s ease both}.event-kicker{display:inline-flex;margin-bottom:.35rem;padding:.08rem .42rem;border:1px solid #f0c85a66;border-radius:999px;color:var(--gold);font-size:.72rem;letter-spacing:0;background:#f0c85a12}.event-entry-head{display:flex;align-items:center;gap:.65rem;min-width:0}.event-art-thumb{width:76px;height:52px;flex:0 0 76px;object-fit:cover;border-radius:6px;border:1px solid #ffffff1a;box-shadow:0 5px #05070b,0 10px 18px #0007;image-rendering:pixelated}.event-art-thumb.fallback{display:grid;grid-template-columns:repeat(3,1fr);overflow:hidden;background:#151923}.event-art-thumb.fallback span{background:linear-gradient(135deg,#2a3140,#111721);box-shadow:inset 0 0 0 1px #ffffff08}.event-art-thumb.fallback span:nth-child(2n){background:linear-gradient(135deg,#32404a,#171c27)}.event-art-thumb.fallback span:nth-child(3n){background:linear-gradient(135deg,#3d3724,#151923)}.log-event h3{margin:.2rem 0;color:var(--gold);text-shadow:0 0 16px #f0c85a2a}.log-event p{margin:.2rem 0}.event-art{display:block;width:100%;aspect-ratio:3 / 2;height:auto;object-fit:contain;border-radius:8px;margin-bottom:.5rem;border:1px solid #ffffff1a;box-shadow:0 12px 28px #0007;image-rendering:pixelated}.log-items,.log-challenges{margin:.55rem 0;padding:.55rem .7rem;border-radius:8px;background:#1117217d;border:1px solid #ffffff10;animation:entryReveal .36s ease both}.item-gain,.item-miss{display:flex;align-items:center;gap:.5rem;min-height:34px}.item-gain{color:var(--green)}.item-miss{color:var(--orange)}.item-gain b,.item-miss b{color:var(--text)}.log-item-icon{width:34px;height:34px;flex:0 0 auto;border-radius:8px;object-fit:cover;border:1px solid #ffffff1a;box-shadow:0 6px 14px #0006;image-rendering:pixelated}.eff{color:var(--muted);font-size:.9em}.challenge{margin:.3rem 0}.ch-name{color:#78dff2}.ch-pass{color:var(--green);font-weight:800;margin-left:.3rem;text-shadow:0 0 14px #5cde8630}.ch-fail{color:var(--red);font-weight:800;margin-left:.3rem;text-shadow:0 0 14px #ff5f6230}.ch-info{color:var(--muted);font-style:italic;font-size:.92em}.log-action{position:relative;color:var(--accent);margin:.6rem 0;padding-left:1rem;animation:actionPulse .35s ease both}.log-action:before{content:"";position:absolute;left:0;top:.7em;width:.5rem;height:2px;background:var(--accent);box-shadow:0 0 10px var(--accent)}.log-result{font-weight:900;margin:.35rem 0 .8rem;padding:.5rem .75rem;border-radius:8px;background:#111721ad;border:1px solid #ffffff12;animation:resultPop .36s cubic-bezier(.2,1.3,.3,1) both}.log-result.win{color:var(--green);border-color:#5cde8655}.log-result.lose{color:var(--red);border-color:#ff5f6255}.log-system{color:var(--muted);font-style:italic;animation:entryReveal .3s ease both}.interaction{display:flex;flex-direction:column;gap:.8rem}.actions{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.actions.locked{opacity:.96}.action-card{position:relative;min-height:92px;text-align:left;padding:.78rem .9rem;border-radius:8px;border:1px solid var(--border);background:linear-gradient(145deg,#27303dcc,#181d27),repeating-linear-gradient(135deg,transparent 0 18px,#ffffff07 19px 20px);color:var(--text);overflow:hidden;transform:translateY(8px);animation:cardDeal .32s ease both;animation-delay:calc(var(--i, 0) * 70ms);transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease,filter .16s ease}.action-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(115deg,transparent 20%,#30d5c824 48%,transparent 68%);transform:translate(-120%)}.action-card:after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,var(--accent),var(--gold));opacity:0;transition:opacity .16s ease}.action-card:hover:not(:disabled){border-color:var(--accent);transform:translateY(-3px);box-shadow:0 16px 28px #0008,0 0 24px #30d5c81e}.action-card:hover:not(:disabled):before{animation:buttonSheen .7s ease}.action-card:hover:not(:disabled):after,.action-card.selected:after{opacity:1}.action-card:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.35)}.action-card.selected{border-color:var(--gold);box-shadow:0 0 0 1px #f0c85a55 inset,0 0 30px #f0c85a22}.action-card.has-echo:not(.selected){border-color:#f0c85a44;background:linear-gradient(90deg,#f0c85a12,transparent 38%),linear-gradient(145deg,#27303dcc,#181d27),repeating-linear-gradient(135deg,transparent 0 18px,#ffffff07 19px 20px);box-shadow:inset 3px 0 #f0c85a88}.action-card.has-echo.echo-harm:not(.selected){border-color:#ff5f6240;background:linear-gradient(90deg,#ff5f6212,transparent 38%),linear-gradient(145deg,#27303dcc,#181d27),repeating-linear-gradient(135deg,transparent 0 18px,#ffffff07 19px 20px);box-shadow:inset 3px 0 #ff5f6278}.action-card.has-echo .action-index{border-color:#f0c85a80;color:var(--gold);box-shadow:0 0 12px #f0c85a1f inset}.action-name{min-width:0;font-weight:800;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:.5rem;line-height:1.35}.action-index{flex:0 0 auto;min-width:2rem;padding:.08rem .25rem;border:1px solid #30d5c855;border-radius:5px;background:#071014b8;color:var(--accent);text-align:center;font-size:.72rem;font-weight:900;box-shadow:0 0 12px #30d5c81f inset}.action-title{min-width:0;overflow-wrap:anywhere}.risk-chip{min-width:4.8rem;min-height:1.45rem;display:inline-grid;place-items:center;padding:0 .42rem;border:1px solid var(--risk-color, var(--border));border-radius:6px;background:color-mix(in srgb,var(--risk-color, var(--accent)) 15%,#0b1018);color:var(--text);font-size:.72rem;font-weight:900;white-space:nowrap}.risk-chip.safe{--risk-color: var(--green)}.risk-chip.even{--risk-color: var(--accent)}.risk-chip.risky{--risk-color: var(--orange)}.risk-chip.dire{--risk-color: var(--red)}.risk-chip.free{--risk-color: var(--border-strong);color:var(--muted)}.action-des{color:var(--muted);font-size:.85rem;margin-top:.24rem;line-height:1.45}.action-echoes{display:flex;flex-wrap:wrap;gap:.32rem;margin-top:.45rem}.action-echo{max-width:100%;display:inline-flex;align-items:center;min-height:1.28rem;padding:.08rem .34rem;border:1px solid #f0c85a66;border-radius:2px;background:linear-gradient(180deg,#111721,#090d14),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);color:var(--gold);font-size:.66rem;font-weight:900;line-height:1.2;overflow:hidden;text-overflow:ellipsis;box-shadow:2px 2px #05070b}.action-echo.harm{border-color:#ff5f6270;color:var(--red)}.action-echo.mixed{border-color:#f0c85a66;box-shadow:inset 2px 0 0 var(--gold),inset -2px 0 0 var(--red),2px 2px #05070b}.badge{flex:0 0 auto;font-size:.7rem;color:#10131a;border:1px solid var(--gold);border-radius:6px;padding:0 .35rem;background:var(--gold)}.check-panel{position:relative;padding:1rem;border-radius:8px;border:1px solid var(--border);background:linear-gradient(145deg,#202632f5,#151923f5),repeating-linear-gradient(45deg,transparent 0 20px,#ffffff05 21px 22px);overflow:hidden;box-shadow:4px 4px #05070b,inset 0 0 0 1px #ffffff08}.check-panel.armed{border-color:#30d5c855}.check-panel.rolling{border-color:#f0c85a80;box-shadow:4px 4px #05070b,inset 0 0 0 2px #f0c85a22}.check-panel.rolled.win{border-color:#5cde8670;box-shadow:4px 4px #05070b,inset 0 0 0 2px #5cde8628}.check-panel.rolled.lose{border-color:#ff5f6270;box-shadow:4px 4px #05070b,inset 0 0 0 2px #ff5f6228}.check-sigil{position:absolute;right:-44px;top:-44px;width:160px;height:160px;border:1px solid #f0c85a35;transform:rotate(45deg);opacity:.5;animation:sigilTurn 12s linear infinite}.check-sigil:before,.check-sigil:after{content:"";position:absolute;top:24px;right:24px;bottom:24px;left:24px;border:1px solid #30d5c835}.check-sigil:after{top:49px;right:49px;bottom:49px;left:49px;border-color:#f0c85a45}.check-head{color:var(--muted);margin-bottom:.6rem}.check-grid{position:relative;display:grid;grid-template-columns:170px minmax(0,1fr);align-items:center;gap:1.2rem}.gauge{text-align:center;animation:gaugeWake .42s ease both}.gauge svg{filter:drop-shadow(0 0 12px #30d5c820)}.gauge-label{font-size:.9rem;margin-top:.2rem;font-weight:800}.check-info{display:flex;flex-direction:column;gap:.45rem;color:var(--text)}.extra-die{color:var(--muted);display:flex;align-items:center;gap:.45rem}.extra-die.locked{width:fit-content;padding:.22rem .5rem;border:1px solid #ffffff14;border-radius:6px;background:#1117218f}.point-breakdown{display:flex;flex-direction:column;gap:.28rem;width:100%;max-width:440px;margin:.1rem 0}.point-row{display:grid;grid-template-columns:minmax(4rem,1fr) auto auto;gap:.55rem;align-items:center;padding:.34rem .5rem;border-radius:6px;border:1px solid #30d5c82e;background:#30d5c80d;font-size:.88rem}.point-row>span{min-width:0}.point-source{display:block;width:fit-content;max-width:100%;margin-top:.12rem;padding:.04rem .24rem;border:1px solid #f0c85a66;color:var(--gold);background:#090d14;font-size:.66rem;font-weight:900;overflow-wrap:anywhere;box-shadow:2px 2px #05070b}.point-source.harm{border-color:#f05f6a88;color:var(--red)}.point-source.mixed{border-color:#f0c85a88;color:var(--gold);box-shadow:inset 2px 0 0 var(--gold),inset -2px 0 0 var(--red),2px 2px #05070b}.point-row code{color:var(--muted);font-family:inherit;white-space:nowrap}.point-row .pos,.point-row .neg{font-weight:900}.point-summary{display:flex;flex-wrap:wrap;align-items:center;gap:.32rem .5rem;width:min(100%,440px);padding:.38rem .5rem;border:1px solid #ffffff16;border-radius:2px;background:linear-gradient(180deg,#111721,#0a0f16),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);box-shadow:2px 2px #05070b}.point-summary b{color:var(--gold);font-size:.74rem;line-height:1.1}.point-summary span{color:var(--muted);font-size:.78rem;line-height:1.2}.point-summary.help{border-color:#f0c85a66}.point-summary.harm{border-color:#ff5f6266}.point-summary.harm b{color:var(--red)}.point-summary.mixed{border-color:#f0c85a66;box-shadow:inset 3px 0 0 var(--gold),inset -3px 0 0 var(--red),2px 2px #05070b}.empty-inline{color:var(--muted);font-size:.86rem}.extra-dice-control{width:min(100%,320px);max-width:100%;padding:.55rem;border:1px solid #ffffff14;border-radius:8px;background:#1117218f}.extra-dice-head{display:flex;flex-wrap:wrap;justify-content:space-between;gap:.25rem .5rem;color:var(--muted);font-size:.86rem;margin-bottom:.45rem}.extra-dice-head b{color:var(--gold)}.stepper{display:grid;grid-template-columns:36px minmax(0,1fr) 36px;gap:.35rem;align-items:center}.icon-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:linear-gradient(180deg,var(--panel3),var(--panel2));color:var(--text);font-size:1.15rem;font-weight:900}.icon-btn:disabled{opacity:.45;cursor:not-allowed}.step-value{min-width:0;min-height:38px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-radius:8px;border:1px solid #f0c85a3a;background:#f0c85a10;font-weight:900;padding:.25rem .35rem;line-height:1.1}.step-value small{display:block;max-width:100%;color:var(--muted);font-size:.72rem;font-weight:500;line-height:1.25;overflow-wrap:anywhere;text-align:center}.dice-cost-preview{display:grid;gap:.18rem;margin-top:.48rem;padding:.38rem .45rem;border:1px solid #ffffff16;border-radius:2px;background:linear-gradient(180deg,#090d14,#111721),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);box-shadow:2px 2px #05070b}.dice-cost-preview span,.dice-cost-preview small{min-width:0;overflow-wrap:anywhere;line-height:1.25}.dice-cost-preview span{color:var(--green);font-size:.75rem;font-weight:900}.dice-cost-preview small{color:var(--muted);font-size:.7rem}.dice-cost-preview.short{border-color:#ff5f6240}.dice-cost-preview.short span{color:var(--gold)}.check-actions{margin-top:1rem;display:flex;gap:.8rem;align-items:center;flex-wrap:wrap}.luck-line{color:var(--muted)}.luck{color:var(--gold);font-weight:900;text-shadow:1px 1px 0 #05070b}.reroll-hint{color:var(--muted);font-size:.85rem;font-style:italic}.luck-badge{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.4rem;padding:.55rem .65rem;margin-bottom:.8rem;border-radius:8px;background:linear-gradient(90deg,#f0c85a16,#232936);border:1px solid #f0c85a55;color:var(--muted);font-size:.9rem;overflow:hidden}.luck-badge:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,transparent,#f0c85a20,transparent);transform:translate(-100%);animation:luckSweep 3s ease-in-out infinite}.dice-row{display:flex;align-items:center;gap:.8rem;margin-top:1rem;min-height:82px}.dice-row.rolling,.dice-row.settling{filter:drop-shadow(4px 4px 0 #05070b)}.die3d-scene{width:60px;height:60px;flex:0 0 auto}.die3d{position:relative;width:100%;height:100%;transform:none}.die3d.rolling{animation:dieTumble .62s steps(5,end) var(--die-delay) infinite}.die3d.settling{animation:dieSettle .76s steps(4,end) var(--die-delay) both}.die3d.settled{transform:translate(0)}.die-face{position:absolute;top:0;right:0;bottom:0;left:0;display:none;place-items:center;border-radius:2px;border:2px solid #05070b;background-color:#e9dfbd;background-image:var(--die-texture),linear-gradient(135deg,#fff2c8 0,#fff2c8 48%,#c9b978 48%,#c9b978);background-size:cover,cover;background-position:center;image-rendering:pixelated;box-shadow:inset -4px -4px #9c8c58,inset 4px 4px #fff7dc,4px 4px #05070b;transform:none}.die3d.value-1 .face-1,.die3d.value-2 .face-2,.die3d.value-3 .face-3,.die3d.value-4 .face-4,.die3d.value-5 .face-5,.die3d.value-6 .face-6{display:grid}.die-pips{width:70%;height:70%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:4px;padding:2px}.die-pips i{display:block;background:transparent}.die-pips i.on{background:#17110d;box-shadow:1px 1px #6d5130}.die3d.luck .die-face{border-color:#f4d875cc;box-shadow:inset -4px -4px #836f36,inset 4px 4px #fff3b5,4px 4px #05070b}.die3d.win .die-face{border-color:#bdf7cb;box-shadow:inset -4px -4px #5d8a5f,inset 4px 4px #e5ffe9,0 0 0 3px var(--green),4px 4px #05070b}.die3d.lose .die-face{border-color:#ffc0c2;box-shadow:inset -4px -4px #935357,inset 4px 4px #ffe2e3,0 0 0 3px var(--red),4px 4px #05070b}.roll-suspense{min-width:7rem;color:var(--gold);font-weight:800;letter-spacing:0;animation:suspensePulse .9s ease-in-out infinite}.roll-reveal{display:flex;flex-direction:column;gap:.34rem;min-width:10rem}.result{width:fit-content;padding:.18rem .5rem;border:2px solid currentColor;border-radius:2px;background:#070b12;font-size:clamp(1.15rem,2vw,1.45rem);font-weight:900;box-shadow:3px 3px #05070b;animation:resultPop .32s steps(3,end) both}.result.win{color:var(--green)}.result.lose{color:var(--red)}.result.crit-win{color:var(--gold);background:#132418}.result.crit-lose{color:var(--gold);background:#2a1012}.roll-total{color:var(--muted);font-size:.84rem;animation:resultPop .42s steps(3,end) 80ms both}.fate-rail{position:relative;width:min(240px,100%);min-height:28px;padding:.35rem .45rem 0;border:1px solid #ffffff1a;background:linear-gradient(180deg,#0b1018,#070b12),repeating-linear-gradient(90deg,transparent 0 14px,#ffffff09 14px 15px);box-shadow:inset 0 0 0 1px #000,2px 2px #05070b}.fate-rail:before{content:"";position:absolute;left:.45rem;right:.45rem;bottom:7px;height:6px;background:#202632;border:1px solid #05070b}.fate-fill{position:absolute;left:.45rem;bottom:8px;height:4px;width:var(--fate-total);max-width:calc(100% - .9rem);background:var(--gold)}.fate-rail.win .fate-fill{background:var(--green)}.fate-rail.lose .fate-fill{background:var(--red)}.fate-mark{position:absolute;left:var(--fate-required);bottom:4px;width:3px;height:16px;background:var(--text);box-shadow:1px 0 #05070b}.fate-rail b{position:relative;z-index:1;display:block;margin-bottom:10px;color:var(--muted);font-size:.68rem;font-weight:800;letter-spacing:0}.side{background:linear-gradient(180deg,#202632f4,#171c27f4),repeating-linear-gradient(135deg,transparent 0 18px,#ffffff05 19px 20px);border:1px solid var(--border);border-radius:8px;padding:.8rem;overflow-y:auto;box-shadow:var(--pixel-shadow)}.tabs{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:.8rem}.tabs button{position:relative;flex:1 1 calc(50% - .35rem);min-width:0;padding:.5rem .35rem;border-radius:2px;border:1px solid var(--border);background:#151923;color:var(--muted);transition:border-color .15s ease,color .15s ease,transform .15s ease}.tabs button:hover{transform:translateY(-1px);border-color:var(--accent)}.tabs button.on{color:var(--text);border-color:var(--accent);background:#30d5c812}.tabs button.on:after{content:"";position:absolute;left:.55rem;right:.55rem;bottom:.25rem;height:2px;background:linear-gradient(90deg,var(--accent),var(--gold))}.tab-main,.tab-hint{display:block;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tab-hint{margin-top:.08rem;color:var(--gold);font-size:.62rem;font-weight:900;line-height:1.1}.count{background:var(--accent2);color:#fff;border-radius:999px;padding:0 .4rem;font-size:.75rem}.panel-list{display:flex;flex-direction:column;gap:.45rem}.empty{color:var(--muted);font-size:.9rem;padding:1rem 0;text-align:center}.echo-list{position:relative}.echo-summary{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.35rem;padding:.48rem;border:1px solid #f0c85a44;background:linear-gradient(135deg,#171d27,#0f141e),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);box-shadow:3px 3px #05070b}.echo-summary span{color:var(--muted);font-size:.72rem;font-weight:800}.echo-row{position:relative;display:grid;grid-template-columns:12px minmax(0,1fr);gap:.55rem;padding:.5rem .55rem;border:1px solid #ffffff12;background:linear-gradient(180deg,#111721,#0c111a),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff05 10px 11px);box-shadow:3px 3px #05070b;animation:entryReveal .22s steps(3,end) both}.echo-row:before{content:"";position:absolute;left:10px;top:-.45rem;bottom:100%;width:2px;background:#ffffff16}.echo-row:first-of-type:before{display:none}.echo-mark{width:10px;height:10px;margin-top:.22rem;background:var(--accent);box-shadow:2px 2px #05070b}.echo-row.win .echo-mark,.echo-row.item .echo-mark{background:var(--green)}.echo-row.loss .echo-mark,.echo-row.miss .echo-mark{background:var(--red)}.echo-row.luck .echo-mark{background:var(--gold)}.echo-row.choice .echo-mark{background:var(--accent2)}.echo-label{color:var(--gold);font-size:.66rem;font-weight:900}.echo-title{margin-top:.06rem;color:var(--text);font-weight:900;line-height:1.25}.echo-detail{margin-top:.15rem;color:var(--muted);font-size:.78rem;line-height:1.32}.collectible{display:grid;grid-template-columns:42px minmax(0,1fr);gap:.6rem;align-items:center;padding:.45rem;border-radius:8px;background:#111721ad;border:1px solid #ffffff10;animation:entryReveal .26s ease both;transition:transform .15s ease,border-color .15s ease}.collectible:hover{transform:translate(2px);border-color:#f0c85a66}.collectible.echoing{position:relative;border-color:#f0c85aaa;background:linear-gradient(90deg,#f0c85a18,#111721ad),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff08 10px 11px);box-shadow:inset 3px 0 0 var(--gold),3px 3px #05070b}.collectible.echoing.harm{border-color:#ff5f6288;background:linear-gradient(90deg,#ff5f6214,#111721ad),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff08 10px 11px);box-shadow:inset 3px 0 0 var(--red),3px 3px #05070b}.collectible.echoing.mixed{border-color:#f0c85a88;background:linear-gradient(90deg,#f0c85a16,#ff5f620f 58%,#111721ad),repeating-linear-gradient(135deg,transparent 0 10px,#ffffff08 10px 11px);box-shadow:inset 3px 0 0 var(--gold),inset -3px 0 0 var(--red),3px 3px #05070b}.c-echo-mark{position:absolute;left:32px;top:8px;z-index:1;width:8px;height:8px;background:var(--gold);box-shadow:2px 2px #05070b}.c-echo-mark.harm{background:var(--red)}.c-echo-mark.mixed{background:linear-gradient(90deg,var(--gold) 0 50%,var(--red) 50% 100%)}.c-route-badge{position:absolute;top:7px;right:7px;z-index:1;max-width:min(8.8rem,calc(100% - 68px));padding:.08rem .32rem;border:1px solid #f0c85a77;border-radius:2px;background:linear-gradient(180deg,#111721,#090d14),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);color:var(--gold);font-size:.66rem;font-weight:900;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:2px 2px #05070b}.c-route-badge.harm{border-color:#ff5f6277;color:var(--red)}.c-route-badge.mixed{border-color:#f0c85a88;color:var(--gold);box-shadow:inset 2px 0 0 var(--gold),inset -2px 0 0 var(--red),2px 2px #05070b}.thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid #ffffff1a;image-rendering:pixelated}.thumb.placeholder{display:flex;align-items:center;justify-content:center;background:#151923;color:var(--gold);box-shadow:inset 0 0 14px #f0c85a18}.item-fallback{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);gap:2px;padding:5px;background:linear-gradient(135deg,#242c37,#101620),repeating-linear-gradient(45deg,transparent 0 6px,#ffffff08 7px 8px);box-shadow:inset 0 0 0 2px #00000035,inset 0 0 18px #30d5c812}.item-fallback span{border-radius:1px;background:linear-gradient(135deg,#32404a,#171c27);box-shadow:inset 0 0 0 1px #ffffff0c}.item-fallback span:nth-child(2n){background:linear-gradient(135deg,#4a4127,#171c27)}.item-fallback span:nth-child(5){background:linear-gradient(135deg,#2c6c68,#16202a)}.c-name{font-weight:800}.c-eff{color:var(--muted);font-size:.82rem;line-height:1.35}.attrs-context{padding:.42rem .55rem;border:1px solid #f0c85a55;border-radius:2px;background:linear-gradient(180deg,#171d27,#0f141e),repeating-linear-gradient(90deg,transparent 0 8px,#ffffff08 8px 9px);color:var(--muted);font-size:.78rem;font-weight:800;box-shadow:2px 2px #05070b}.stat-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:1rem;padding:.48rem .6rem;border-radius:8px;background:#111721ad;border:1px solid #ffffff10;animation:entryReveal .26s ease both}.stat-row.active{border-color:#f0c85a88;background:linear-gradient(90deg,#f0c85a18,#30d5c80f);box-shadow:inset 3px 0 0 var(--gold),0 0 18px #f0c85a18}.stat-row .pos{color:var(--green)}.stat-row .neg{color:var(--red)}.stat-row span{min-width:0;overflow-wrap:anywhere}.stat-echo{padding:.06rem .22rem;border:1px solid #f0c85a77;color:var(--gold);background:#090d14;font-size:.66rem;font-style:normal;font-weight:900;white-space:nowrap;box-shadow:2px 2px #05070b}.stat-echo.harm{border-color:#f05f6a88;color:var(--red)}.stat-echo.mixed{border-color:#f0c85a88;color:var(--gold);background:linear-gradient(90deg,#f0c85a14,#ff5f6214);box-shadow:inset 2px 0 0 var(--gold),inset -2px 0 0 var(--red),2px 2px #05070b}.ended{text-align:center;padding:1rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.result-summary{position:relative;overflow:hidden;width:min(680px,100%);padding:1rem;border-radius:8px;border:1px solid #f0c85a55;background:linear-gradient(145deg,#202632f5,#151923f5),repeating-linear-gradient(45deg,transparent 0 20px,#ffffff05 21px 22px);box-shadow:var(--pixel-shadow)}.result-summary.pinnacle{border-color:#f6f0ff;background:linear-gradient(145deg,#231b2df7,#111824f8 52%,#090b13fa),repeating-linear-gradient(90deg,transparent 0 8px,#ff386812 9px 10px),repeating-linear-gradient(45deg,transparent 0 20px,#ffffff08 21px 22px);box-shadow:0 0 0 2px #ff386833,4px 4px #05070b,0 0 28px #ff38684f;animation:pinnaclePulse 3.8s steps(2,end) infinite}.result-summary.pinnacle:before{content:attr(data-pinnacle);display:block;width:fit-content;max-width:100%;margin:0 auto .65rem;padding:.16rem .5rem;border:1px solid #ff3868;border-radius:3px;background:#05070b;color:#f6f0ff;font-size:.68rem;font-weight:900;letter-spacing:0;box-shadow:2px 2px #000,inset 3px 0 #ff3868}.result-summary.pinnacle:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(90deg,transparent,#f6f0ff14,transparent),repeating-linear-gradient(0deg,transparent 0 5px,#ffffff08 6px 7px);mix-blend-mode:screen;transform:translate(-110%);animation:pinnacleSweep 2.8s steps(6,end) infinite}.result-summary h2{margin:.25rem 0 0;color:var(--gold);font-size:1.45rem}.result-summary.pinnacle h2{color:#f6f0ff;text-shadow:0 0 14px #ff386866}.result-summary .score{margin:.6rem 0;color:var(--gold);font-size:clamp(2rem,6vw,3.4rem);font-weight:900;text-shadow:0 0 18px #f0c85a33}.result-summary.pinnacle .score{color:#f6f0ff;text-shadow:0 0 16px #ff3868a8,0 0 28px #30d5c866}.result-summary.pinnacle .feat-chip.crown{animation:pinnacleCrown 1.8s steps(2,end) infinite}.score-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.45rem}.score-grid span{padding:.45rem;border:1px solid #ffffff12;border-radius:8px;background:#111721ad;color:var(--muted);white-space:nowrap}.result-summary p{margin:.8rem 0 0;color:var(--muted);line-height:1.6}.generating{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:#05070bd9;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);color:var(--text);z-index:10}.summon-ring{position:absolute;width:240px;height:240px;transform:rotate(45deg);opacity:.75}.summon-ring span{position:absolute;inset:calc(var(--ring, 0) * 28px);border:1px solid #30d5c866;animation:sigilTurn 6s linear infinite}.summon-ring span:nth-child(2){--ring: 1;border-color:#f0c85a66;animation-direction:reverse}.summon-ring span:nth-child(3){--ring: 2;border-color:#6a8cff66}.generating-dice{display:flex;align-items:center;justify-content:center;gap:.85rem;z-index:1;filter:drop-shadow(0 18px 28px #000b)}.generating-dice .die3d-scene{width:66px;height:66px}.spinner{width:42px;height:42px;border:4px solid #3c4658;border-top-color:var(--accent);border-right-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;box-shadow:0 0 24px #30d5c855;z-index:1}.error{color:var(--red);margin-top:1rem}.error.toast{position:fixed;bottom:1rem;left:50%;transform:translate(-50%);background:var(--panel);border:1px solid var(--red);padding:.6rem 1rem;border-radius:8px;box-shadow:0 14px 30px #0008;z-index:20}@keyframes spin{to{transform:rotate(360deg)}}@keyframes mapSweep{0%,to{opacity:.65;transform:translateY(0)}50%{opacity:1;transform:translateY(-4px)}}@keyframes titleIgnite{0%{opacity:0;transform:translateY(10px) scale(.96);filter:blur(3px)}to{opacity:1;transform:translateY(0) scale(1);filter:drop-shadow(0 0 14px #30d5c83a)}}@keyframes sparkDrift{0%{transform:translateY(20vh) rotate(22deg);opacity:0}30%{opacity:.42}to{transform:translateY(-45vh) rotate(22deg);opacity:0}}@keyframes riftPulse{0%,to{opacity:.2;transform:rotate(-7deg) scaleX(.78)}50%{opacity:.75;transform:rotate(-7deg) scaleX(1)}}@keyframes floatMark{0%,to{transform:translateY(0) rotate(0);opacity:.5}50%{transform:translateY(-10px) rotate(8deg);opacity:1}}@keyframes selectedAura{0%,to{border-color:#f0c85acc;box-shadow:0 0 0 1px #f0c85a55 inset,0 0 24px #f0c85a1f}50%{border-color:#30d5c8cc;box-shadow:0 0 0 1px #30d5c855 inset,0 0 32px #30d5c826}}@keyframes primaryGlow{0%,to{box-shadow:0 0 18px #30d5c82b}50%{box-shadow:0 0 26px #f0c85a30,0 0 18px #30d5c82b}}@keyframes buttonSheen{0%{transform:translate(-120%)}to{transform:translate(120%)}}@keyframes boardPan{0%{transform:translate(0)}to{transform:translate(120px)}}@keyframes emberRise{0%{transform:translateY(0) rotate(16deg);opacity:0}35%{opacity:.35}to{transform:translateY(-125vh) rotate(16deg);opacity:0}}@keyframes entryReveal{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes sceneWake{0%{opacity:0;transform:translateY(8px);filter:saturate(.75)}to{opacity:1;transform:translateY(0);filter:saturate(1)}}@keyframes sceneScan{0%{background-position:-220px 0,0 0}to{background-position:220px 0,0 0}}@keyframes sceneSpark{0%{transform:translateY(80%);opacity:0}35%{opacity:.34}to{transform:translateY(-130%);opacity:0}}@keyframes sceneResultFlash{0%{opacity:0;transform:translate(0)}18%{opacity:.68;transform:translate(1px)}42%{opacity:.34;transform:translate(-1px,1px)}to{opacity:0;transform:translate(0)}}@keyframes sceneCritWinFlash{0%{opacity:0;transform:translate(0);filter:brightness(1)}18%{opacity:.9;transform:translateY(-1px);filter:brightness(1.28)}44%{opacity:.48;transform:translate(1px);filter:brightness(1.12)}to{opacity:0;transform:translate(0);filter:brightness(1)}}@keyframes sceneCritLoseFlash{0%{opacity:0;transform:translate(0)}18%{opacity:.82;transform:translate(-2px)}34%{opacity:.5;transform:translate(2px)}to{opacity:0;transform:translate(0)}}@keyframes scenePixelBurst{0%{opacity:0;transform:translate(-50%,-50%)}22%{opacity:1;transform:translate(calc(-50% + var(--burst-x)),calc(-50% + var(--burst-y)))}68%{opacity:.82;transform:translate(calc(-50% + var(--burst-x)),calc(-50% + var(--burst-y)))}to{opacity:0;transform:translate(calc(-50% + var(--burst-x)),calc(-50% + var(--burst-y)))}}@keyframes sceneFrameLift{0%,to{filter:brightness(1) saturate(1);transform:translateY(0)}28%{filter:brightness(1.18) saturate(1.12);transform:translateY(-1px)}}@keyframes sceneFrameJolt{0%,to{filter:brightness(1) saturate(1);transform:translate(0)}18%{filter:brightness(.92) saturate(1.12);transform:translate(-1px)}36%{transform:translate(1px)}58%{transform:translate(-1px)}}@keyframes sceneFrameBreak{0%,to{filter:brightness(1) saturate(1);transform:translate(0)}16%{filter:brightness(.82) saturate(1.22);transform:translate(-2px)}30%{transform:translate(2px)}48%{filter:brightness(1.04) saturate(1.14);transform:translate(-1px)}70%{transform:translate(1px)}}@keyframes actionPulse{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes resultPop{0%{opacity:0;transform:translateY(4px)}55%{opacity:1;transform:translateY(-1px)}to{opacity:1;transform:translateY(0)}}@keyframes cardDeal{0%{opacity:0;transform:translateY(12px) rotateX(10deg)}to{opacity:1;transform:translateY(0) rotateX(0)}}@keyframes sigilTurn{to{transform:rotate(405deg)}}@keyframes gaugeWake{0%{opacity:0;transform:scale(.94)}to{opacity:1;transform:scale(1)}}@keyframes luckSweep{0%,45%{transform:translate(-110%)}80%,to{transform:translate(110%)}}@keyframes diceDrop{0%{opacity:0;transform:translateY(-18px) rotate(-35deg) scale(.85)}70%{opacity:1;transform:translateY(3px) rotate(8deg) scale(1.08)}to{opacity:1;transform:translateY(0) rotate(0) scale(1)}}@keyframes dieTumble{0%{transform:translate(-6px,-9px) rotate(-8deg)}20%{transform:translate(7px,-13px) rotate(13deg)}42%{transform:translate(3px,5px) rotate(-4deg)}66%{transform:translate(-8px,-2px) rotate(9deg)}to{transform:translate(-2px,2px) rotate(0)}}@keyframes dieSettle{0%{transform:translate(-8px,-14px) rotate(-12deg)}42%{transform:translate(5px,-4px) rotate(7deg)}72%{transform:translateY(4px) rotate(0)}86%{transform:translateY(-1px) rotate(0)}to{transform:translate(0) rotate(0)}}@keyframes challengeChipStrike{0%{opacity:0;transform:translateY(-6px)}28%{opacity:1;transform:translateY(2px)}44%{transform:translateY(0)}to{opacity:1;transform:translateY(0)}}@keyframes suspensePulse{0%,to{opacity:.55;transform:translateY(0)}50%{opacity:1;transform:translateY(-1px)}}@keyframes winPulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.18)}}@keyframes loseJolt{0%,to{transform:translate(0)}20%{transform:translate(-3px)}40%{transform:translate(3px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}@keyframes pinnaclePulse{0%,to{box-shadow:0 0 0 2px #ff386833,4px 4px #05070b,0 0 28px #ff38684f}50%{box-shadow:0 0 0 2px #f6f0ff66,4px 4px #05070b,0 0 34px #30d5c866}}@keyframes pinnacleSweep{0%,55%{transform:translate(-110%)}to{transform:translate(110%)}}@keyframes pinnacleCrown{0%,to{filter:brightness(1)}50%{filter:brightness(1.35)}}@media(max-width:900px){body{overflow:auto}.app{min-height:100%;height:auto}.layout{grid-template-columns:1fr;overflow:visible}.narrative{min-height:46vh}.side{max-height:260px}.start{max-height:none;justify-content:flex-start}.run-status{grid-template-columns:1fr}.run-status-metrics{justify-content:flex-start}.scene-stage{grid-template-columns:minmax(0,1fr);min-height:auto}.scene-frame{grid-row:auto;width:min(360px,100%);min-height:150px;justify-self:center}}@media(max-width:640px){.start{margin:1rem auto;width:calc(100vw - 1rem);min-height:calc(100vh - 2rem);padding:1.1rem .75rem}.ambient{top:0;right:0;bottom:0;left:0}.tagline{max-width:18rem;margin-left:auto;margin-right:auto}.mode-select,.actions{grid-template-columns:1fr}.difficulty-select{grid-template-columns:repeat(2,minmax(0,1fr))}.badge-grid{grid-template-columns:1fr}.score-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.check-grid{grid-template-columns:1fr;justify-items:center;text-align:center}.check-info{align-items:center}.point-row{grid-template-columns:1fr;text-align:center}.point-source{margin-left:auto;margin-right:auto}.dice-row{flex-wrap:wrap;justify-content:center}.topbar{gap:.55rem;padding:.65rem .8rem}.topbar-meta{display:none}.run-event{align-items:flex-start;flex-direction:column;gap:.2rem}.run-event b{white-space:normal}.scene-stage{padding:.65rem}.scene-copy p{-webkit-line-clamp:4}.scene-growth span{font-size:.74rem}.c-route-badge{top:8px;right:8px;width:9px;height:9px;padding:0;color:transparent;font-size:0;background:var(--gold)}.c-route-badge.harm{background:var(--red)}.c-route-badge.mixed{background:linear-gradient(90deg,var(--gold) 0 50%,var(--red) 50% 100%)}.event-entry-head{align-items:flex-start}.event-art-thumb{width:58px;height:42px;flex-basis:58px}.history-row{grid-template-columns:1fr}.history-row strong{justify-self:start}}@media(max-height:760px)and (min-width:641px){.start{justify-content:flex-start;min-height:auto}.start h1{font-size:clamp(2.8rem,8vw,4.8rem)}.mode{min-height:98px}.history-list{max-height:150px}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important;scroll-behavior:auto!important}.ambient,.start-orbit,.game-ambient,.scene-overlay,.scene-result-flash,.scene-result-burst,.generating .summon-ring{animation:none!important}.spark,.ember,.rift,.scanline,.scene-overlay span,.scene-result-burst span,.scene-result-flash{opacity:0!important}.scene-stage.pulse-win .scene-frame,.scene-stage.pulse-crit-win .scene-frame,.scene-stage.pulse-challenge-win .scene-frame,.scene-stage.milestone-win .scene-frame{animation:none!important;border-color:var(--green);box-shadow:inset 0 0 0 2px var(--green),var(--pixel-shadow)}.scene-stage.pulse-lose .scene-frame,.scene-stage.pulse-crit-lose .scene-frame,.scene-stage.pulse-challenge-lose .scene-frame,.scene-stage.milestone-scar .scene-frame{animation:none!important;border-color:var(--red);box-shadow:inset 0 0 0 2px var(--red),var(--pixel-shadow)}.dice-row.rolling,.dice-row.settling,.die3d.rolling,.die3d.settling,.roll-suspense{animation:none!important;filter:none}.challenge-chip,.scene-challenge-chip,.echo-row,.collectible,.stat-row,.result,.result-summary.pinnacle,.result-summary.pinnacle:after,.result-summary.pinnacle .feat-chip.crown,.roll-total{animation:none!important}.result-summary.pinnacle{box-shadow:0 0 0 2px #ff386833,4px 4px #05070b}}
