:root{--bg: #0f1318;--bg-2: #121720;--panel: #141c24;--panel-2: #192232;--surface: #192232;--border: #213040;--border-2: #2c4055;--text: #eaf4ef;--text-dim: #9cb8a8;--accent: #3de8a0;--accent-dim: #0d2a1e;--danger: #ff4466;--danger-dim: #3a0818;--gold: #d4a94a;--gold-dim: rgba(212, 169, 74, .12);--green: #3de8a0;--btn-h: 1.8rem;--bg-dark: var(--bg);--bg-panel: var(--panel);--text-main: var(--text);--text-muted: var(--text-dim);--hp-low: var(--danger)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(40px)}to{opacity:1;transform:translateY(0)}}@keyframes popIn{0%{opacity:0;transform:scale(.88)}65%{transform:scale(1.03)}to{opacity:1;transform:scale(1)}}@keyframes pulseGold{0%,to{box-shadow:0 0 #ffd70000}50%{box-shadow:0 0 12px 3px #ffd70040}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes backdropIn{0%{opacity:0}to{opacity:1}}@keyframes levelUpBurst{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1);opacity:1}}@keyframes progressFill{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes barGrow{0%{transform:scaleX(0)}to{transform:scaleX(1)}}@keyframes moodLossFade{0%{opacity:.75}60%{opacity:.6}to{opacity:.25}}@keyframes taskBadgePop{0%{opacity:0;transform:translate(-50%) translateY(8px) scale(.85)}65%{transform:translate(-50%) translateY(-2px) scale(1.04)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}@keyframes floatBounce{0%{transform:translateY(0) rotate(0) scale(1)}20%{transform:translateY(-12px) rotate(2deg) scale(1.02)}45%{transform:translateY(-8px) rotate(-1.5deg) scale(1.01)}65%{transform:translateY(-14px) rotate(1deg) scale(1.025)}to{transform:translateY(0) rotate(0) scale(1)}}@keyframes gentleSway{0%{transform:translateY(0) rotate(0)}20%{transform:translateY(-6px) rotate(2.5deg)}50%{transform:translateY(-4px) rotate(-2deg)}75%{transform:translateY(-7px) rotate(1.8deg)}to{transform:translateY(0) rotate(0)}}@keyframes breatheAnim{0%{transform:translateY(0) scale(1)}30%{transform:translateY(-5px) scale(1.012)}60%{transform:translateY(-2px) scale(1.006)}to{transform:translateY(0) scale(1)}}@keyframes droopAnim{0%{transform:translateY(0) rotate(-2deg) scale(1)}25%{transform:translateY(5px) rotate(-4.5deg) scale(.98)}55%{transform:translateY(3px) rotate(-2.5deg) scale(.985)}80%{transform:translateY(7px) rotate(-5deg) scale(.975)}to{transform:translateY(0) rotate(-2deg) scale(1)}}@keyframes wiltAnim{0%{transform:translateY(0) rotate(-5deg) scale(1)}10%{transform:translateY(2px) rotate(-5.5deg) translate(-2px) scale(.98)}20%{transform:translateY(4px) rotate(-4.5deg) translate(2px) scale(.975)}30%{transform:translateY(6px) rotate(-6deg) translate(-3px) scale(.97)}40%{transform:translateY(5px) rotate(-5deg) translate(3px) scale(.972)}50%{transform:translateY(7px) rotate(-6.5deg) translate(-2px) scale(.965)}60%{transform:translateY(6px) rotate(-5.5deg) translate(2px) scale(.968)}75%{transform:translateY(8px) rotate(-7deg) translate(-1px) scale(.96)}88%{transform:translateY(5px) rotate(-5deg) translate(1px) scale(.972)}to{transform:translateY(0) rotate(-5deg) scale(1)}}.mood-elated .anima-portrait-img{animation:floatBounce 1.7s ease-in-out infinite;transform-origin:bottom center}.mood-happy .anima-portrait-img{animation:gentleSway 2.4s ease-in-out infinite;transform-origin:bottom center}.mood-neutral .anima-portrait-img{animation:breatheAnim 3.2s ease-in-out infinite;transform-origin:bottom center}.mood-sad .anima-portrait-img{animation:droopAnim 2.8s ease-in-out infinite;transform-origin:bottom center}.mood-depressed .anima-portrait-img{animation:wiltAnim 2s ease-in-out infinite;transform-origin:bottom center}.anima-card.interactive:hover{transform:translateY(-3px);box-shadow:0 8px 28px #00000059}.anima-card.selected{transform:translateY(-2px)}.fs-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;background:#050512e0;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;animation:backdropIn .2s ease-out;padding:20px 16px;overflow-y:auto}.fs-modal-box{background:var(--panel);border:1px solid var(--border-2);border-radius:16px;box-shadow:0 24px 80px #0009,0 0 0 1px #ffffff0a;width:100%;max-height:calc(100vh - 40px);overflow-y:auto;animation:slideUp .28s cubic-bezier(.22,1,.36,1);scrollbar-width:thin}@keyframes scanLine{0%{background-position:0 0}to{background-position:0 100vh}}.screen{min-height:100vh;background:var(--bg);color:var(--text);animation:fadeIn .25s ease-out}.data-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;transition:border-color .15s,background .15s}.data-card:hover{border-color:var(--border-2)}.data-card.selected{background:var(--gold-dim);border-color:var(--gold)}.data-card.interactive{cursor:pointer}.data-card.interactive:hover{background:var(--panel-2)}.section-label{font-size:.7rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim)}.stat-pill{display:inline-flex;align-items:center;gap:3px;font-size:.78rem;padding:2px 8px;border-radius:20px;background:var(--panel-2);color:var(--text-dim);border:1px solid var(--border)}.elem-stripe{width:3px;border-radius:2px;flex-shrink:0}.day-bar{display:flex;align-items:center;gap:2px}.day-bar-pip{height:6px;border-radius:3px;flex:1;background:var(--border);transition:background .2s}.day-bar-pip.done{background:var(--gold)}.day-bar-pip.today{background:var(--accent)}.btn-action{padding:12px 48px;font-size:1rem;font-weight:700;background:var(--gold);color:#000;border:none;border-radius:8px;letter-spacing:.05em;transition:background .15s,transform .1s,box-shadow .15s}.btn-action:hover:not(:disabled){background:#ffe84d;transform:translateY(-1px);box-shadow:0 4px 20px #ffd70059}.btn-action:active:not(:disabled){transform:translateY(0)}.btn-action:disabled{background:var(--panel-2);color:var(--text-dim);border:1px solid var(--border);opacity:.6}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--panel-2);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-2);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}*{scrollbar-width:thin;scrollbar-color:var(--border-2) var(--panel-2)}html,body,#root{height:100%;background:var(--bg);color:var(--text);font-family:Helvetica Neue,Arial,Hiragino Kaku Gothic ProN,Meiryo,sans-serif;font-size:14px;line-height:1.5}h1{font-size:2rem;letter-spacing:.1em;color:var(--accent)}h2{font-size:1.3rem;color:var(--accent)}h3{font-size:1rem;color:var(--text)}.flex{display:flex}.flex-col{display:flex;flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.full-h{height:100%}button{cursor:pointer;border:none;border-radius:4px;padding:.4rem 1rem;font-size:.85rem;font-weight:700;transition:background .15s,opacity .15s}button:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent);color:#000}.btn-primary:hover:not(:disabled){background:#2ef}.btn-secondary{background:var(--panel-2);color:var(--text);border:1px solid var(--border-2)}.btn-secondary:hover:not(:disabled){background:var(--panel);border-color:var(--accent)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#ff6680}.btn-gold{background:var(--gold);color:#000}.btn-gold:hover:not(:disabled){background:#ffe44d}.btn-ghost{background:transparent;color:var(--text-dim);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){color:var(--text);border-color:var(--border-2)}.panel{background:var(--panel);border:1px solid var(--border);border-radius:6px;padding:1rem}.badge{display:inline-block;font-size:.7rem;font-weight:700;padding:.15rem .5rem;border-radius:3px}.badge-fire{background:#7a1a00;color:#f84}.badge-water{background:#00237a;color:#4af}.badge-earth{background:#3a2a00;color:#ca4}.badge-nature{background:#0a3a10;color:#4c6}.badge-none{background:var(--panel-2);color:var(--text-dim)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--panel);border:1px solid var(--border-2);border-radius:8px;padding:1.5rem;width:90%;max-width:680px;max-height:85vh;display:flex;flex-direction:column;gap:1rem;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-body{overflow-y:auto;flex:1}.modal-footer{display:flex;gap:.5rem;justify-content:flex-end}.hud{display:flex;align-items:center;gap:1.5rem;background:var(--panel);border-bottom:1px solid var(--border);padding:.6rem 1.2rem;font-size:.9rem}.hud-item{display:flex;align-items:center;gap:.35rem}.hud-label{color:var(--text-dim);font-size:.75rem}.hud-value{font-weight:700}.hud-value.gold{color:var(--gold)}.hud-value.rev{color:var(--purple)}.hud-value.cost{color:var(--green)}.grid-3x3{display:grid;grid-template-columns:repeat(3,90px);grid-template-rows:repeat(3,90px);gap:4px}.grid-cell{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;position:relative;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:var(--text-dim);cursor:pointer}.grid-cell:hover{border-color:var(--border-2)}.grid-cell.occupied,.grid-cell.player{border-color:var(--accent-dim)}.grid-cell.opponent{border-color:var(--danger-dim)}.unit-card{background:var(--panel-2);border:1px solid var(--border);border-radius:6px;padding:.6rem;display:flex;flex-direction:column;gap:.3rem;cursor:pointer;transition:border-color .15s}.unit-card:hover{border-color:var(--accent)}.unit-card-name{font-weight:700;font-size:.9rem}.unit-stats{display:flex;gap:.5rem;font-size:.75rem;color:var(--text-dim)}.unit-stat{display:flex;gap:.2rem}.unit-stat-label{color:var(--text-dim)}.unit-stat-value{color:var(--text);font-weight:700}.battle-log{background:var(--bg-2);border:1px solid var(--border);border-radius:4px;padding:.75rem;font-family:monospace;font-size:.82rem;line-height:1.8;min-height:120px}.log-line-player{color:var(--accent)}.log-line-opponent{color:var(--danger)}.log-line-system{color:var(--text-dim)}.battle-cell{width:145px;height:220px;border:1px solid var(--border);border-radius:6px;overflow:visible;display:flex;flex-direction:column;flex-shrink:0;position:relative;background:var(--panel-2);transition:border-color .1s}.battle-cell.player{border-color:#246a8a}.battle-cell.opponent{border-color:#8a2444}.battle-cell.selected{border-color:var(--gold);box-shadow:0 0 6px #ffd7004d}.battle-cell:not(.empty):hover{filter:brightness(1.08)}.battle-cell.empty{border:1px dashed var(--border);border-radius:6px;display:flex;align-items:center;justify-content:center;color:var(--text-dim);font-size:.6rem;opacity:.35;background:var(--panel-2);cursor:default}.battle-portrait-wrap{position:relative;width:100%;flex:1;overflow:hidden;flex-shrink:0;min-height:0}.battle-portrait-img{width:100%;height:100%;object-fit:cover;display:block}.battle-portrait-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.8rem}.battle-portrait-stat-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,#000000b8 28%,#000000e6);padding:24px 5px 5px;pointer-events:none;z-index:5}.battle-nameplate{font-size:.74rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;margin-bottom:3px}.battle-cell-info{padding:2px 5px 3px;display:flex;flex-direction:column;gap:2px;flex-shrink:0;position:relative;z-index:6}.hp-bar-outer{height:4px;background:#ffffff14;border-radius:2px;overflow:hidden}.hp-bar-inner{height:100%;border-radius:2px;transition:width .3s ease}.battle-col-header{font-size:.62rem;color:var(--text-dim);text-align:center;padding:2px 0 4px;text-transform:uppercase;letter-spacing:.05em}.floating-log{position:fixed;top:52px;left:10px;z-index:200;width:456px;height:56vh;min-width:280px;min-height:160px;resize:both;overflow:hidden;background:#080816f5;border:1px solid var(--border-2);border-radius:6px;display:flex;flex-direction:column;box-shadow:0 4px 16px #0009}.floating-log-header{display:flex;align-items:center;justify-content:space-between;padding:.35rem .6rem;border-bottom:1px solid var(--border);font-size:.72rem;color:var(--text-dim);flex-shrink:0}.floating-log-body{overflow-y:auto;padding:.4rem .6rem;flex:1;min-height:0;font-family:monospace;font-size:.95rem;line-height:1.75}.turn-pill{padding:.18rem .5rem;border-radius:3px;font-size:.72rem;font-weight:700;background:var(--panel-2);border:1px solid var(--border);color:var(--text-dim);cursor:pointer;transition:all .1s;min-width:28px}.turn-pill:hover:not(:disabled){border-color:var(--border-2);color:var(--text)}.turn-pill.current{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}.turn-pill.end-btn{border-color:var(--gold);color:var(--gold)}.turn-pill.end-btn.current{background:#ffd70014}.screen{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem}input[type=text]{background:var(--panel-2);border:1px solid var(--border);border-radius:4px;color:var(--text);padding:.5rem .75rem;font-size:.9rem;outline:none}input[type=text]:focus{border-color:var(--accent)}.status-icon-tooltip{position:fixed;z-index:9000;background:#080816f7;border:1px solid var(--border-2);border-radius:4px;padding:.3rem .55rem;font-size:.65rem;line-height:1.65;white-space:nowrap;pointer-events:none;color:var(--text);box-shadow:0 2px 10px #00000080}.status-icon-tooltip-title{font-weight:700;color:var(--accent);margin-bottom:1px}.status-icon-tooltip-line{color:var(--text-dim)}.anima-detail-panel{position:fixed;top:var(--hud-h, 0px);right:0;bottom:0;width:400px;background:var(--panel);border-left:1px solid var(--border-2);z-index:300;overflow:hidden;padding:0;display:flex;flex-direction:column;gap:0;box-shadow:-8px 0 32px #000000b3;font-size:.85rem;animation:panelSlideIn .22s cubic-bezier(.2,.8,.3,1) both}@keyframes panelSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.skill-range-grid{display:grid;grid-template-columns:repeat(3,12px);grid-template-rows:repeat(3,12px);gap:2px}.skill-range-cell{width:12px;height:12px;border-radius:2px}.skill-range-cell.bg{background:#ffffff0f}.skill-range-cell.ally{background:#ff8c00cc;border-radius:2px}.skill-range-cell.enemy{background:#3c82ffcc;border-radius:2px}.skill-range-cell.self-fill{border-radius:50%;background:#ff8c00e6}.skill-range-cell.ring{border-radius:50%;background:transparent;border:1.5px solid #666}@keyframes anima-float{0%,to{transform:translateY(0)}50%{transform:translateY(-7px)}}@keyframes anima-move-forward-player{0%{transform:translate(0)}to{transform:translate(28px)}}@keyframes anima-move-forward-opponent{0%{transform:translate(0)}to{transform:translate(-28px)}}.anima-attack-wrap.moving-forward-player{animation:anima-move-forward-player calc(.4s / var(--anim-speed, 1)) ease-out forwards}.anima-attack-wrap.moving-forward-opponent{animation:anima-move-forward-opponent calc(.4s / var(--anim-speed, 1)) ease-out forwards}.anima-attack-wrap.held-forward-player{animation:none;transform:translate(28px)}.anima-attack-wrap.held-forward-opponent{animation:none;transform:translate(-28px)}.anima-attack-wrap.returning-player{animation:swap-return-player calc(.4s / var(--anim-speed, 1)) ease-in forwards}.anima-attack-wrap.returning-opponent{animation:swap-return-opponent calc(.4s / var(--anim-speed, 1)) ease-in forwards}@keyframes skill-name-appear{0%{opacity:0;letter-spacing:.45em}25%{opacity:1;letter-spacing:.12em}75%{opacity:1;letter-spacing:.12em}to{opacity:0;letter-spacing:.12em}}@keyframes anima-shake{0%{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(5px)}45%{transform:translate(-4px)}60%{transform:translate(3px)}75%{transform:translate(-2px)}to{transform:translate(0)}}@keyframes damage-popup{0%{opacity:0;transform:translate(-50%) translateY(0) scale(.8)}15%{opacity:1;transform:translate(-50%) translateY(-8px) scale(1.1)}65%{opacity:1;transform:translate(-50%) translateY(-20px) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-28px) scale(.9)}}@keyframes icon-popup{0%{opacity:0;transform:translateY(0) scale(.6)}20%{opacity:1;transform:translateY(-10px) scale(1.15)}65%{opacity:1;transform:translateY(-18px) scale(1)}to{opacity:0;transform:translateY(-26px) scale(.9)}}.anima-float-wrap{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}.anima-portrait-float{flex:1;min-height:0;display:flex;flex-direction:column;position:relative;animation:anima-float 3s ease-in-out infinite;animation-delay:var(--float-delay, 0s)}.anima-attack-wrap{flex:1;min-height:0;display:flex;flex-direction:column;position:relative}@keyframes anima-tilt-player{0%{transform:rotate(0)}20%{transform:rotate(8deg)}80%{transform:rotate(8deg)}to{transform:rotate(0)}}@keyframes anima-tilt-opponent{0%{transform:rotate(0)}20%{transform:rotate(-8deg)}80%{transform:rotate(-8deg)}to{transform:rotate(0)}}.anima-attack-wrap.tilting-player{transform-origin:bottom center;animation:anima-tilt-player calc(1.2s / var(--anim-speed, 1)) ease-in-out forwards}.anima-attack-wrap.tilting-opponent{transform-origin:bottom center;animation:anima-tilt-opponent calc(1.2s / var(--anim-speed, 1)) ease-in-out forwards}@keyframes swap-return-player{0%{transform:translate(28px)}to{transform:translate(0)}}@keyframes swap-return-opponent{0%{transform:translate(-28px)}to{transform:translate(0)}}.anima-attack-wrap.swap-returning-player{animation:swap-return-player calc(.4s / var(--anim-speed, 1)) ease-out forwards}.anima-attack-wrap.swap-returning-opponent{animation:swap-return-opponent calc(.4s / var(--anim-speed, 1)) ease-out forwards}.anim-shake{animation:anima-shake calc(.55s / var(--anim-speed, 1)) ease-in-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}.damage-popup{position:absolute;bottom:55%;left:50%;pointer-events:none;z-index:30;opacity:0;animation:damage-popup calc(1.2s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}.damage-popup-text{display:block;font-size:1.6rem;font-weight:900;color:#fff;white-space:nowrap;letter-spacing:-.01em;text-shadow:-1.5px -1.5px 0 rgba(0,0,0,.95),1.5px -1.5px 0 rgba(0,0,0,.95),-1.5px 1.5px 0 rgba(0,0,0,.95),1.5px 1.5px 0 rgba(0,0,0,.95),0 0 10px rgba(255,40,70,1),0 0 22px rgba(255,40,70,.55)}.heal-popup-text{display:block;font-size:1.6rem;font-weight:900;color:#4f8;white-space:nowrap;letter-spacing:-.01em;text-shadow:-1.5px -1.5px 0 rgba(0,0,0,.95),1.5px -1.5px 0 rgba(0,0,0,.95),-1.5px 1.5px 0 rgba(0,0,0,.95),1.5px 1.5px 0 rgba(0,0,0,.95),0 0 10px rgba(50,255,100,1),0 0 22px rgba(50,255,100,.55)}.icon-popup{position:absolute;bottom:60%;pointer-events:none;z-index:29;opacity:0;animation:icon-popup calc(1.2s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}.icon-popup-state{position:absolute;top:22%;left:50%;transform:translate(-50%);pointer-events:none;z-index:31;opacity:0;animation:icon-popup-state calc(1.5s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}@keyframes icon-popup-state{0%{opacity:.3;transform:translate(-50%) scale(3);filter:blur(3px)}20%{opacity:1;transform:translate(-50%) scale(1.15);filter:blur(0px)}60%{opacity:1;transform:translate(-50%) scale(1);filter:blur(0px)}85%{opacity:.9;transform:translate(-50%) translateY(-8px) scale(.9)}to{opacity:0;transform:translate(-50%) translateY(-14px) scale(.8)}}.barrier-flash-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:30;opacity:0;animation:barrier-overlay-show calc(.85s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}.barrier-flash-overlay:before{content:"";position:absolute;top:-50%;left:-80%;width:55%;height:200%;background:linear-gradient(108deg,transparent 0%,rgba(160,220,255,0) 30%,rgba(160,220,255,.55) 46%,rgba(255,255,255,.92) 50%,rgba(160,220,255,.55) 54%,rgba(160,220,255,0) 70%,transparent 100%);animation:barrier-flash-sweep calc(.85s / var(--anim-speed, 1)) ease-in-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}@keyframes barrier-overlay-show{0%{opacity:0}12%{opacity:1}80%{opacity:1}to{opacity:0}}@keyframes barrier-flash-sweep{0%{transform:translate(0)}to{transform:translate(380%)}}.icon-popup-effect{position:absolute;top:22%;left:50%;transform:translate(-50%);pointer-events:none;z-index:31;opacity:0;animation:icon-popup-effect calc(1.2s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}@keyframes icon-popup-effect{0%{opacity:0;transform:translate(-50%) scale(.8)}18%{opacity:1;transform:translate(-50%) scale(1.05)}65%{opacity:1;transform:translate(-50%) scale(1)}to{opacity:0;transform:translate(-50%) scale(.9)}}.icon-popup-remove{position:absolute;top:22%;transform:translate(-50%);pointer-events:none;z-index:31;opacity:0;animation:icon-popup-remove calc(1s / var(--anim-speed, 1)) ease-out forwards;animation-delay:calc(.7s / var(--anim-speed, 1))}@keyframes icon-popup-remove{0%{opacity:.9;transform:translate(-50%) translateY(0)}20%{opacity:1;transform:translate(-50%) translateY(-10px)}80%{opacity:.5;transform:translate(-50%) translateY(-40px)}to{opacity:0;transform:translate(-50%) translateY(-54px)}}.battle-cell.deceased{border-color:#8a244459}.battle-cell-deceased-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b3;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:20;border-radius:inherit}.battle-cell-deceased-icon{font-size:2.2rem;color:var(--danger);opacity:.8;text-shadow:0 0 14px rgba(255,40,70,.55)}.skill-name-overlay{position:absolute;top:8px;left:0;right:0;text-align:center;white-space:nowrap;pointer-events:none;z-index:20}.skill-name-text{display:block;font-size:.95rem;font-weight:900;color:#fff;letter-spacing:.12em;text-shadow:0 0 8px var(--gold),0 0 18px rgba(255,200,0,.35),0 2px 5px rgba(0,0,0,.9);animation:skill-name-appear calc(1.2s / var(--anim-speed, 1)) ease-in-out calc(.4s / var(--anim-speed, 1)) both}.battle-victory-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:50}.battle-victory-text{font-size:2.4rem;font-weight:900;letter-spacing:.22em;text-transform:uppercase;white-space:nowrap;color:gold;text-shadow:0 0 6px #ffe066,0 0 18px #ffaa00,0 0 38px #ff6600,0 0 64px #ff3300,2px 3px 0 #000,-1px -1px 0 #000;transform:rotate(-8deg);animation:victory-appear .55s cubic-bezier(.34,1.56,.64,1) both}@keyframes swap-fly{0%{transform:translate(0)}50%{transform:translate(calc(var(--swap-dx) * .5),calc(var(--swap-dy) * .5 - 18px))}to{transform:translate(var(--swap-dx),var(--swap-dy))}}.swap-flying-portrait{position:fixed;pointer-events:none;z-index:9998;overflow:hidden;border-radius:6px;animation:swap-fly var(--swap-dur, .9s) linear forwards}.swap-flying-portrait img{width:100%;height:100%;object-fit:cover;display:block}.swap-flying-portrait .swap-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:2.4rem}@keyframes victory-appear{0%{opacity:0;transform:rotate(-8deg) scale(.35)}to{opacity:1;transform:rotate(-8deg) scale(1)}}@keyframes cell-pulse{0%{box-shadow:inset 0 0 0 2px var(--pulse-color),0 0 0 0 var(--pulse-glow);opacity:.5}45%{box-shadow:inset 0 0 0 5px var(--pulse-color),0 0 14px 4px var(--pulse-glow);opacity:1}to{box-shadow:inset 0 0 0 2px transparent,0 0 0 0 transparent;opacity:0}}.cell-pulse-enemy{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;pointer-events:none;z-index:6;--pulse-color: rgba(255, 55, 25, .75);--pulse-glow: rgba(255, 80, 30, .35);animation:cell-pulse calc(.62s / var(--anim-speed, 1)) ease-out forwards}.cell-pulse-ally{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:4px;pointer-events:none;z-index:6;--pulse-color: rgba(45, 255, 160, .7);--pulse-glow: rgba(45, 255, 160, .3);animation:cell-pulse calc(.62s / var(--anim-speed, 1)) ease-out forwards}@keyframes passive-ring-expand{0%{transform:scale(0);opacity:1}60%{opacity:.7}to{transform:scale(1);opacity:0}}.passive-ring{position:absolute;top:50%;left:50%;width:200px;height:200px;margin:-100px 0 0 -100px;border-radius:50%;border:3px solid var(--color-passive-ring, #a78bfa);box-shadow:0 0 18px 6px var(--color-passive-ring, #a78bfa);pointer-events:none;z-index:10;animation:passive-ring-expand calc(.6s / var(--anim-speed, 1)) ease-out forwards}@keyframes stat-grant-glow{0%{filter:none}35%{filter:drop-shadow(0 0 5px gold) drop-shadow(0 0 12px rgba(255,215,0,.65))}to{filter:none}}.stat-grant-glow{animation:stat-grant-glow calc(1s / var(--anim-speed, 1)) ease-out forwards}.turn-banner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none;z-index:40}.turn-banner-box{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.55rem 2.4rem .65rem;background:#060614d6;border-top:2px solid rgba(255,215,50,.7);border-bottom:2px solid rgba(255,215,50,.7);white-space:nowrap;transform-origin:center;animation:turn-banner-appear calc(1.4s / var(--anim-speed, 1)) cubic-bezier(.22,1,.36,1) both}.turn-banner-turn{font-size:2.1rem;font-weight:900;letter-spacing:.18em;color:#ffe066;text-shadow:0 0 6px #ffd000,0 0 18px #ff9900,0 0 36px #ff6600,1px 2px 0 #000,-1px -1px 0 #000;line-height:1;text-transform:uppercase}.turn-banner-start{font-size:.8rem;font-weight:700;letter-spacing:.42em;color:#ffda469e;line-height:1.5;text-transform:uppercase}@keyframes turn-banner-appear{0%{opacity:0;transform:scaleX(.18)}16%{opacity:1;transform:scaleX(1.04)}22%{transform:scaleX(1)}76%{opacity:1;transform:scaleX(1)}to{opacity:0;transform:scaleX(1)}}.anima-portrait-float.hit-continuation{animation:none}
