: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-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.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 input{accent-color:var(--gold);width:1rem;height:1rem}.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:66px}.die{width:56px;height:56px;border-radius:8px;animation:diceDrop .56s cubic-bezier(.18,1.4,.32,1) both;transform-origin:center}.die:nth-child(2){animation-delay:70ms}.die:nth-child(3){animation-delay:.14s}.die-img{object-fit:contain;background:#ffffff12;padding:2px;border:1px solid #ffffff20}.die-pips{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:8px;background:linear-gradient(145deg,#fffdf6,#d8dce6);border:1px solid #0004}.pip{width:10px;height:10px;border-radius:50%;align-self:center;justify-self:center}.pip.on{background:#171c27;box-shadow:inset 0 1px 2px #0008}.die.win{box-shadow:0 0 0 3px var(--green),0 0 24px #5cde8666;animation-name:diceDrop,winPulse;animation-duration:.56s,1.4s;animation-delay:0ms,.52s;animation-iteration-count:1,infinite}.die.lose{box-shadow:0 0 0 3px var(--red),0 0 24px #ff5f6266;animation-name:diceDrop,loseJolt;animation-duration:.56s,1.2s;animation-delay:0ms,.52s;animation-iteration-count:1,1}.result{font-size:clamp(1.15rem,2vw,1.45rem);font-weight:900;margin-left:.3rem;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}.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 .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 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{grid-template-columns:1fr}.check-grid{grid-template-columns:1fr;justify-items:center;text-align:center}.check-info{align-items: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}}
