: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;--shadow: #040608cc}*{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%)}button,input,select{font-family:inherit}button{cursor:pointer}.start{position:relative;width:min(720px,calc(100vw - 2rem));min-height:min(760px,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;overflow:hidden}.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}.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}.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:.75rem 0 2rem;line-height:1.45;text-shadow:0 1px 0 #000}.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: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.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}.start-actions{margin-top:2rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}.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;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);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);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 8px 28px #0007;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}.mode-tag{font-size:.8rem;color:var(--text);border:1px solid #30d5c866;border-radius:999px;padding:.1rem .62rem;background:#30d5c812}.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}.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:0 16px 36px #0007,inset 0 0 0 1px #ffffff08;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}.log-event h3{margin:.2rem 0;color:var(--gold);text-shadow:0 0 16px #f0c85a2a}.log-event p{margin:.2rem 0}.event-art{width:100%;max-height:220px;object-fit:cover;border-radius:8px;margin-bottom:.5rem;border:1px solid #ffffff1a;box-shadow:0 12px 28px #0007}.log-arc-end{position:relative;margin:.65rem 0 1rem;padding:.8rem .95rem;border:1px solid var(--arc-border, #f0c85a77);border-left-width:4px;border-radius:8px;background:linear-gradient(110deg,var(--arc-bg, #f0c85a18),#111721b5 72%),repeating-linear-gradient(135deg,transparent 0 16px,#ffffff06 17px 18px);box-shadow:0 10px 24px #0006,inset 0 0 0 1px #ffffff08;animation:entryReveal .42s ease both}.log-arc-end:before{content:"";position:absolute;left:.7rem;right:.7rem;top:0;height:1px;background:linear-gradient(90deg,transparent,var(--arc-glow, var(--gold)),transparent);opacity:.75}.log-arc-end.great,.log-arc-end.good{--arc-border: #5cde8688;--arc-bg: #5cde8618;--arc-glow: var(--green)}.log-arc-end.great{--arc-border: #f0c85aaa;--arc-bg: #f0c85a1f;--arc-glow: var(--gold)}.log-arc-end.neutral{--arc-border: #78dff288;--arc-bg: #30d5c814;--arc-glow: var(--accent)}.log-arc-end.bad{--arc-border: #ff9f4388;--arc-bg: #ff9f4318;--arc-glow: var(--orange)}.log-arc-end.dire{--arc-border: #ff5f628f;--arc-bg: #ff5f621a;--arc-glow: var(--red)}.arc-end-head{display:flex;align-items:center;justify-content:space-between;gap:.6rem;flex-wrap:wrap;margin-bottom:.35rem}.arc-end-kicker,.arc-end-outcome{display:inline-flex;align-items:center;min-height:1.35rem;padding:.05rem .48rem;border-radius:999px;font-size:.72rem;line-height:1.2}.arc-end-kicker{border:1px solid #f0c85a66;color:var(--gold);background:#f0c85a12}.arc-end-outcome{border:1px solid var(--arc-border, #ffffff33);color:var(--arc-glow, var(--gold));background:#1117218f;font-weight:800}.log-arc-end h3{margin:.2rem 0;color:var(--text);text-shadow:0 0 14px color-mix(in srgb,var(--arc-glow, var(--gold)) 24%,transparent)}.log-arc-end p{margin:.2rem 0 .45rem}.arc-end-meta{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem;color:var(--muted);font-size:.86rem}.arc-end-meta span{min-width:0;padding:.28rem .45rem;border:1px solid #ffffff12;border-radius:6px;background:#1117218f}.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{color:var(--green)}.item-miss{color:var(--orange)}.item-gain b,.item-miss b{color:var(--text)}.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-name{font-weight:800;display:flex;align-items:center;gap:.5rem}.action-des{color:var(--muted);font-size:.85rem;margin-top:.24rem;line-height:1.45}.badge{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:0 16px 34px #0007,inset 0 0 0 1px #ffffff08}.check-panel.armed{border-color:#30d5c855}.check-panel.rolling{border-color:#f0c85a80;box-shadow:0 16px 34px #0007,0 0 40px #f0c85a20}.check-panel.rolled.win{border-color:#5cde8670;box-shadow:0 16px 34px #0007,0 0 38px #5cde8620}.check-panel.rolled.lose{border-color:#ff5f6270;box-shadow:0 16px 34px #0007,0 0 38px #ff5f6220}.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 code{color:var(--muted);font-family:inherit;white-space:nowrap}.point-row .pos,.point-row .neg{font-weight:900}.empty-inline{color:var(--muted);font-size:.86rem}.extra-dice-control{width:min(100%,300px);padding:.55rem;border:1px solid #ffffff14;border-radius:8px;background:#1117218f}.extra-dice-head{display:flex;justify-content:space-between;color:var(--muted);font-size:.86rem;margin-bottom:.45rem}.extra-dice-head b{color:var(--gold)}.stepper{display:grid;grid-template-columns:38px minmax(0,1fr) 38px;gap:.45rem;align-items:center}.icon-btn{width:38px;height:38px;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-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}.step-value small{color:var(--muted);font-size:.72rem;font-weight:500}.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:0 0 12px #f0c85a3b}.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{filter:drop-shadow(0 14px 22px #0008)}.die3d-scene{width:60px;height:60px;perspective:520px;perspective-origin:50% 36%;flex:0 0 auto}.die3d{position:relative;width:100%;height:100%;transform-style:preserve-3d;transform:var(--die-final-transform)}.die3d.rolling{animation:dieTumble 1.45s cubic-bezier(.18,.78,.24,1) var(--die-delay) both}.die3d.settled{animation:dieSettle .52s cubic-bezier(.18,1.4,.32,1) var(--die-delay) both}.die-face{position:absolute;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;border-radius:9px;border:1px solid #ffffffaa;background:radial-gradient(circle at 28% 24%,#fff,#f7f1dc 34%,#d9dde7);box-shadow:inset -8px -10px 16px #0000002f,inset 8px 8px 14px #ffffffb8,0 10px 22px #0008;backface-visibility:hidden}.face-1{transform:rotateY(0) translateZ(30px)}.face-2{transform:rotateY(90deg) translateZ(30px)}.face-3{transform:rotateX(90deg) translateZ(30px)}.face-4{transform:rotateX(-90deg) translateZ(30px)}.face-5{transform:rotateY(-90deg) translateZ(30px)}.face-6{transform:rotateY(180deg) translateZ(30px)}.pip-grid{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:9px}.pip{width:10px;height:10px;border-radius:50%;align-self:center;justify-self:center}.pip.on{background:#151923;box-shadow:inset 0 1px 2px #0009,0 1px 1px #ffffff75}.die3d.win .die-face{border-color:#bdf7cb;box-shadow:inset -8px -10px 16px #0000002f,inset 8px 8px 14px #ffffffb8,0 0 0 3px var(--green),0 0 26px #5cde866f}.die3d.lose .die-face{border-color:#ffc0c2;box-shadow:inset -8px -10px 16px #0000002f,inset 8px 8px 14px #ffffffb8,0 0 0 3px var(--red),0 0 26px #ff5f626f}.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:.2rem;min-width:10rem}.result{font-size:clamp(1.15rem,2vw,1.45rem);font-weight:900;animation:resultPop .36s cubic-bezier(.2,1.3,.3,1) both}.result.win{color:var(--green);text-shadow:0 0 16px #5cde8645}.result.lose{color:var(--red);text-shadow:0 0 16px #ff5f6245}.result.crit-win{color:var(--gold);text-shadow:0 0 10px var(--green),0 0 24px #f0c85a55}.result.crit-lose{color:var(--gold);text-shadow:0 0 10px var(--red),0 0 24px #f0c85a55}.roll-total{color:var(--muted);font-size:.84rem;animation:resultPop .42s cubic-bezier(.2,1.3,.3,1) 80ms both}.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:0 16px 36px #0007,inset 0 0 0 1px #ffffff08}.tabs{display:flex;gap:.35rem;margin-bottom:.8rem}.tabs button{position:relative;flex:1;padding:.5rem .35rem;border-radius:8px;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))}.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}.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}.thumb{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid #ffffff1a}.thumb.placeholder{display:flex;align-items:center;justify-content:center;background:#151923;color:var(--gold);box-shadow:inset 0 0 14px #f0c85a18}.c-name{font-weight:800}.c-eff{color:var(--muted);font-size:.82rem;line-height:1.35}.stat-row{display:flex;justify-content:space-between;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)}.ended{text-align:center;padding:1rem}.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}.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 actionPulse{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes resultPop{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@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%{opacity:0;transform:translate3d(-14px,-18px,0) rotateX(18deg) rotateY(-22deg) rotate(-12deg) scale(.88)}12%{opacity:1}35%{transform:translate3d(10px,-5px,24px) var(--die-roll-transform) scale(1.08)}68%{transform:translate3d(-5px,7px,10px) rotateX(900deg) rotateY(760deg) rotate(210deg) scale(1)}to{opacity:1;transform:translateZ(0) var(--die-roll-transform) scale(1)}}@keyframes dieSettle{0%{opacity:.72;transform:translateY(-8px) var(--die-roll-transform) scale(1.02)}72%{opacity:1;transform:translateY(3px) var(--die-final-transform) scale(1.08)}to{opacity:1;transform:translateY(0) var(--die-final-transform) scale(1)}}@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)}}@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}}@media(max-width:640px){.start{margin:1rem auto;width:calc(100vw - 1rem);min-height:calc(100vh - 2rem)}.ambient{top:0;right:0;bottom:0;left:0}.tagline{max-width:18rem;margin-left:auto;margin-right:auto}.mode-select,.actions,.arc-end-meta{grid-template-columns: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}.dice-row{flex-wrap:wrap;justify-content:center}.topbar{gap:.55rem;padding:.65rem .8rem}.mode-tag{display:none}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important;scroll-behavior:auto!important}}
