*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--c-bg: oklch(8% .02 22);--c-bg2: oklch(11% .024 22);--c-bg3: oklch(14% .03 22);--c-surface: oklch(17.5% .036 22);--c-border: oklch(26% .052 20);--c-border2: oklch(37% .072 20);--c-text: oklch(88% .01 55);--c-text2: oklch(64% .018 40);--c-text3: oklch(43% .014 30);--c-blood: oklch(52% .228 22);--c-blood2: oklch(40% .195 22);--c-ember: oklch(72% .16 55);--c-gold: oklch(80% .13 78);--c-gold2: oklch(68% .15 72);--c-red: oklch(60% .228 22);--c-green: oklch(62% .16 150);--c-blue: oklch(62% .15 245);--c-purple: oklch(60% .18 290);--c-teal: oklch(68% .12 190);--font-main: "Segoe UI", system-ui, -apple-system, sans-serif;--radius: 8px;--radius-lg: 13px;font-size:15px}html,body,#root{height:100%;background:var(--c-bg);color:var(--c-text);font-family:var(--font-main);overflow:hidden}button{cursor:pointer;border:none;background:none;color:inherit;font:inherit}.game-shell{display:flex;flex-direction:column;height:100dvh;max-width:480px;margin:0 auto;background:var(--c-bg);position:relative;overflow:hidden}.top-bar{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;background:var(--c-bg2);border-bottom:1px solid var(--c-border);flex-shrink:0;z-index:10}.top-bar__title{font-size:13px;font-weight:800;letter-spacing:.07em;color:var(--c-gold);text-transform:uppercase}.top-bar__stats{display:flex;gap:14px;font-size:12px;color:var(--c-text2)}.top-bar__stat{display:flex;align-items:center;gap:4px}.top-bar__stat b{color:var(--c-text);font-weight:700}.screen{flex:1;overflow-y:auto;overflow-x:hidden;padding:14px 14px 86px}.bottom-nav{display:flex;position:absolute;bottom:0;left:0;right:0;height:68px;background:var(--c-bg2);border-top:1px solid var(--c-border);z-index:20}.nav-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;font-size:9px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--c-text3);transition:color .15s;padding:8px 4px;position:relative}.nav-btn:after{content:"";position:absolute;bottom:0;left:20%;right:20%;height:2px;background:var(--c-blood);border-radius:2px 2px 0 0;opacity:0;transform:scaleX(.4);transition:opacity .2s,transform .2s}.nav-btn:active{transform:scale(.94)}.nav-btn.active{color:var(--c-blood)}.nav-btn.active:after{opacity:1;transform:scaleX(1)}.nav-btn svg{width:22px;height:22px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.card{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius-lg);padding:12px 14px;margin-bottom:10px}.card--glow{border-color:var(--c-gold2);box-shadow:0 0 14px #cf87002e;box-shadow:0 0 14px oklch(68% .15 72 / .18)}.card--blood{border-color:var(--c-blood2);box-shadow:0 0 14px #c5002b33;box-shadow:0 0 14px oklch(52% .228 22 / .2)}.section-title{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--c-text3);margin:16px 0 8px;display:flex;align-items:center;gap:8px}.section-title:before{content:"";flex:1;height:1px;background:var(--c-border);max-width:20px}.section-title:after{content:"";flex:1;height:1px;background:var(--c-border)}.fam-card{background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:6px;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;overflow:hidden}.fam-card__summary{display:flex;align-items:center;gap:10px;padding:10px}.fam-card:hover{border-color:var(--c-border2);background:var(--c-surface)}.fam-card.selected{border-color:var(--c-blood);background:var(--c-surface);box-shadow:0 0 10px #c5002b38;box-shadow:0 0 10px oklch(52% .228 22 / .22)}.fam-card:not(.fam-card--expandable){display:flex;align-items:center;gap:10px;padding:10px}.fam-card--expandable{display:flex;flex-direction:column}.fam-art{width:48px;height:48px;border-radius:6px;background:var(--c-bg2);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}.fam-art img{width:100%;height:100%;object-fit:cover}.fam-info{flex:1;min-width:0}.fam-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fam-meta{font-size:11px;color:var(--c-text2);margin-top:2px;display:flex;align-items:center;flex-wrap:wrap;gap:4px}.fam-stats-mini{display:flex;gap:8px;font-size:10px;color:var(--c-text3);margin-top:4px}.fam-stats-mini span{display:flex;align-items:center;gap:2px}.fam-expand{display:grid;grid-template-rows:0fr;transition:grid-template-rows .28s cubic-bezier(.4,0,.2,1)}.fam-card--open .fam-expand{grid-template-rows:1fr}.fam-expand>div{overflow:hidden}.fam-detail-body{padding:0 10px 12px;border-top:1px solid var(--c-border);margin-top:2px}.fam-chevron{font-size:16px;color:var(--c-text3);transition:transform .22s,color .15s;flex-shrink:0;padding:4px}.fam-card--open .fam-chevron{transform:rotate(90deg);color:var(--c-blood)}.rarity-common{color:#9ca3af}.rarity-uncommon{color:#22c55e}.rarity-rare{color:#60a5fa}.rarity-epic{color:#c084fc}.rarity-legendary{color:#fbbf24}.rarity-mythic{color:#f87171}.stars{color:var(--c-gold);letter-spacing:-1px;font-size:12px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:11px 18px;border-radius:var(--radius);font-size:13px;font-weight:700;letter-spacing:.03em;border:1px solid transparent;transition:opacity .15s,transform .1s,box-shadow .15s}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.35;cursor:not-allowed}.btn-primary{background:linear-gradient(150deg,#bb0029,#7c0018);background:linear-gradient(150deg,color(xyz 0.219 0.105 0.023),color(xyz 0.098 0.041 0.004));color:#ddd6d1;border-color:#d71033;box-shadow:0 2px 12px #c5002b4d;box-shadow:0 2px 12px oklch(52% .228 22 / .3)}.btn-primary:hover:not(:disabled){background:linear-gradient(150deg,#d71033,#b80028,#98001f);background:linear-gradient(150deg,#d71033,color(xyz 0.205 0.103 0.027),color(xyz 0.14 0.067 0.014));box-shadow:0 3px 18px #c5002b73;box-shadow:0 3px 18px oklch(52% .228 22 / .45)}.btn-gold{background:linear-gradient(150deg,#dd9314,#d58800,#ca7f00 50%,#b56d00);background:linear-gradient(150deg,#dd9314,color(xyz 0.363 0.317 0.037),color(xyz 0.324 0.276 0.022) 50%,color(xyz 0.256 0.205 0));color:#160606;border-color:#e5ac4c;font-weight:800}.btn-gold:hover:not(:disabled){background:linear-gradient(150deg,#e5ac4c,#d9921f 50%,#d68c0a,#d28600 75%,#c77c00);background:linear-gradient(150deg,#e5ac4c,#d9921f 50%,#d68c0a,color(xyz 0.352 0.307 0.035) 75%,color(xyz 0.315 0.263 0.013))}.btn-danger{background:linear-gradient(150deg,#bb0029,#7c0018);background:linear-gradient(150deg,color(xyz 0.219 0.105 0.023),color(xyz 0.098 0.041 0.004));color:var(--c-text);border-color:var(--c-blood)}.btn-ghost{background:transparent;border-color:var(--c-border2);color:var(--c-text2)}.btn-ghost:hover{border-color:var(--c-text2);color:var(--c-text)}.btn-sm{padding:7px 13px;font-size:12px}.btn-full{width:100%}.row-expand{display:grid;grid-template-rows:0fr;transition:grid-template-rows .26s cubic-bezier(.4,0,.2,1)}.row-open .row-expand{grid-template-rows:1fr}.row-expand>*{overflow:hidden}.bld-row{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:8px;overflow:hidden;transition:border-color .18s,box-shadow .18s}.bld-row:not(.bld-row--locked){cursor:pointer}.bld-row:not(.bld-row--locked):hover{border-color:var(--c-border2)}.bld-row.row-open{border-color:var(--c-blood);box-shadow:0 0 0 1px #c5002b33,0 4px 16px #c5002b1f;box-shadow:0 0 0 1px oklch(52% .228 22 / .2),0 4px 16px oklch(52% .228 22 / .12)}.bld-row--locked{opacity:.42}.bld-row__header{display:flex;align-items:center;gap:12px;padding:13px 14px}.bld-row__icon{font-size:26px;flex-shrink:0}.bld-row__label{flex:1;min-width:0}.bld-row__name{font-size:14px;font-weight:700}.bld-row__status{font-size:11px;color:var(--c-text2);margin-top:1px}.bld-row__chevron{font-size:18px;color:var(--c-text3);transition:transform .22s,color .15s;flex-shrink:0}.bld-row.row-open .bld-row__chevron{transform:rotate(90deg);color:var(--c-blood)}.bld-row__body{padding:10px 14px 14px;border-top:1px solid var(--c-border);font-size:12px;color:var(--c-text2);line-height:1.5}.battle-screen{flex:1;display:flex;flex-direction:column;overflow:hidden;padding:0;gap:0;min-height:0}.battle-screen--scrollable{overflow-y:auto;padding-bottom:86px}.battle-screen--combat{position:relative}.battle-info-top{flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px;padding:0 12px;height:28px;background:#000205e6;border-bottom:1px solid var(--c-border)}.battle-info-top__floor{font-size:10px;font-weight:800;letter-spacing:.12em;color:var(--c-text3);text-transform:uppercase}.battle-info-top__zone{font-size:11px;font-weight:700;color:var(--c-text2)}.battle-info-bottom{flex-shrink:0;display:flex;align-items:center;gap:8px;padding:0 10px;height:36px;background:#000205e6;border-top:1px solid var(--c-border);overflow:hidden}.battle-info-bottom__action{flex:1;font-size:11px;font-weight:600;color:var(--c-text2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.battle-info-bottom__controls{display:flex;gap:4px;flex-shrink:0}.battle-arena{flex:1;display:flex;flex-direction:column;gap:0;min-height:0}.battle-zone{border-radius:var(--radius);padding:4px 2px;flex:1;display:flex;flex-direction:column;justify-content:center;gap:1px;min-height:0}.battle-zone--enemy,.battle-zone--player{background:none;border:none}.battle-zone__label,.battle-divider{display:none}.mob-row{display:flex;gap:1px;flex-wrap:nowrap;justify-content:center;flex:1;min-height:0}.mob-row__gap{flex:1;min-height:0}.mob-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(2,1fr);gap:4px;flex:1;min-height:0}.mob-grid>.mob-card{max-width:none;min-height:0}.mob-grid__empty{min-height:0;border-radius:8px}.mob-card{flex:1;min-width:0;display:flex;flex-direction:column;overflow:visible;position:relative;transition:border-color .15s,box-shadow .15s;max-width:160px}.mob-card--boss{flex:1.5;max-width:200px;z-index:1}.mob-card__inner-clip{border-radius:0;overflow:hidden;display:flex;flex-direction:column;flex:1;min-width:0;position:relative}.mob-card__art{display:flex;align-items:center;justify-content:center;overflow:hidden;width:100%;flex:1;min-height:0}.mob-card__art svg,.mob-card__art img{width:100%!important;height:100%!important;object-fit:cover;display:block}.mob-card__hp-bar-overlay{position:absolute;bottom:0;left:0;right:0;height:3px;background:#00000073;border-radius:0;z-index:3;pointer-events:none}.mob-card__footer{padding:5px 6px 6px;display:flex;flex-direction:column;gap:3px;flex-shrink:0}.mob-card__name{font-size:9px;font-weight:800;color:var(--c-text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:.03em;display:flex;align-items:baseline;justify-content:center}.mob-card__level{font-size:7px;font-weight:700;color:var(--c-text3);margin-right:2px;letter-spacing:.02em;flex-shrink:0}.mob-card__stars{position:absolute;top:3px;left:4px;font-size:7px;line-height:1;letter-spacing:-.5px;z-index:2;text-shadow:0 1px 3px oklch(0% 0 0 / .7);pointer-events:none}.mob-card__hp-bar{width:100%;height:4px;background:var(--c-border);border-radius:3px;overflow:hidden}.mob-card__hp-fill{height:100%;background:var(--c-green);border-radius:3px;transition:width .4s ease}.mob-card__hp-fill.low{background:#ef852e}.mob-card__hp-fill.crit{background:var(--c-red)}.mob-card__hp-text{font-size:8px;color:var(--c-text3);text-align:center}.mob-card__header{display:flex;align-items:center;justify-content:space-between;padding:2px 4px;flex-shrink:0;position:relative;z-index:2}.mob-card__race-icon{font-size:11px;line-height:1;filter:drop-shadow(0 1px 2px oklch(0% 0 0 / .7))}.mob-card__level{font-size:8px;font-weight:800;color:var(--c-text3);letter-spacing:.04em;text-shadow:0 1px 3px oklch(0% 0 0 / .8)}.mob-card__bottom-row{display:flex;align-items:flex-end;justify-content:space-between;padding:2px 3px 5px;flex-shrink:0;position:relative;z-index:3;gap:2px;min-height:20px}.mob-card__buffs{display:flex;flex-wrap:wrap;gap:2px;justify-content:flex-start;flex:1}.mob-card__debuffs{display:flex;flex-wrap:wrap;gap:2px;justify-content:flex-end;flex:1}.mob-card__boss-badge{position:absolute;bottom:12px;left:50%;transform:translate(-50%);background:#210506;color:#fb575d;font-size:8px;font-weight:900;letter-spacing:.14em;padding:2px 7px;border-radius:4px;border:1px solid oklch(52% .228 22 / .5);z-index:4;white-space:nowrap;text-transform:uppercase}.mob-card__ko-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:900;color:var(--c-red);letter-spacing:.1em;filter:drop-shadow(0 0 6px oklch(60% .228 22 / .5))}.mob-card--active{border-color:var(--c-green);box-shadow:0 0 12px #20a04e66,inset 0 0 8px #20a04e1a;animation:mobAttack .28s cubic-bezier(.2,.9,.4,1)}.mob-card--flash{animation:mobFlash .45s ease forwards}.mob-card--ko{opacity:.55;filter:grayscale(.8)}@keyframes mobAttack{0%{transform:scale(1)}35%{transform:scale(1.07)}to{transform:scale(1)}}@keyframes mobFlash{0%{border-color:var(--c-red);box-shadow:0 0 18px #e9203c80,inset 0 0 14px #e9203c40;transform:translate(0)}18%{transform:translate(-5px)}36%{transform:translate(5px)}54%{transform:translate(-3px)}72%{transform:translate(3px)}to{border-color:var(--c-border);box-shadow:none;transform:translate(0)}}@keyframes lungeRight{0%{transform:translate(0) scale(1)}40%{transform:translate(52px) scale(1.05)}60%{transform:translate(52px) scale(1.05)}to{transform:translate(0) scale(1)}}.mob-card--lunge-right{animation:lungeRight .4s ease-in-out forwards}@keyframes lungeLeft{0%{transform:translate(0) scale(1)}40%{transform:translate(-52px) scale(1.05)}60%{transform:translate(-52px) scale(1.05)}to{transform:translate(0) scale(1)}}.mob-card--lunge-left{animation:lungeLeft .4s ease-in-out forwards}@keyframes arenaShake{0%,to{transform:translate(0)}15%{transform:translate(-6px)}30%{transform:translate(6px)}45%{transform:translate(-4px)}60%{transform:translate(4px)}75%{transform:translate(-2px)}}.arena--shake{animation:arenaShake .35s ease-out forwards}.uni-card{position:relative;display:flex;flex-direction:column;background:var(--c-bg2);border:1px solid var(--c-border);border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .15s,box-shadow .15s}.uni-card--xs{max-width:56px}.uni-card--sm{max-width:72px}.uni-card--md{max-width:96px}.uni-card--xs .uni-card__footer{padding:3px 4px 4px}.uni-card--xs .uni-card__name{font-size:8px}.uni-card.selected{border-color:var(--c-purple);box-shadow:0 0 10px #6d48d140}.uni-card__stars{position:absolute;top:3px;left:4px;font-size:7px;line-height:1;letter-spacing:-.5px;z-index:2;text-shadow:0 1px 3px oklch(0% 0 0 / .7);pointer-events:none}.uni-card__qty{position:absolute;top:5px;right:5px;background:var(--c-bg);border:1px solid var(--c-border);border-radius:99px;padding:1px 5px;font-size:9px;font-weight:800;color:var(--c-text2);z-index:2}.uni-card__art{display:flex;align-items:center;justify-content:center;background:var(--c-bg2);overflow:hidden;width:100%;aspect-ratio:3 / 4}.uni-card__art svg,.uni-card__art img{width:100%!important;height:100%!important;object-fit:cover;display:block}.uni-card__footer{padding:5px 6px 6px;flex-shrink:0}.uni-card__name{font-size:9px;font-weight:800;color:var(--c-text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:baseline;justify-content:center;gap:2px}.uni-card__level{font-size:7px;font-weight:700;color:var(--c-text3);flex-shrink:0}.card-detail-expand{border-top:1px solid var(--c-border);margin-top:2px;animation:cardDetailSlideDown .22s cubic-bezier(.25,.1,.25,1)}@keyframes cardDetailSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.hit-effect{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:inherit;z-index:8;overflow:hidden}.hit-effect--physical:before{content:"";position:absolute;top:50%;left:10%;width:80%;height:3px;background:#e6f5ff;box-shadow:0 0 10px 3px #b4d2f0e6;animation:hitSlash .22s cubic-bezier(.05,.9,.2,1) forwards}@keyframes hitSlash{0%{opacity:1;transform:translateY(-50%) rotate(60deg) scaleX(0)}18%{opacity:1;transform:translateY(-50%) rotate(60deg) scaleX(1)}to{opacity:0;transform:translateY(-50%) rotate(60deg) scaleX(1)}}.hit-effect--fire{background:radial-gradient(circle at 50% 50%,rgba(255,120,0,1) 0%,rgba(255,56,0,.85) 30%,rgba(255,180,0,.4) 60%,transparent 75%);box-shadow:inset 0 0 30px 10px #ff500099;animation:hitBurst .28s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--lightning{background:#fff064f2;box-shadow:inset 0 0 40px 15px #ffdc00cc;animation:hitLightning .2s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--water{background:radial-gradient(circle at 50% 50%,rgba(0,180,255,1) 0%,rgba(0,136,255,.7) 35%,rgba(0,100,220,.25) 65%,transparent 80%);box-shadow:inset 0 0 25px 8px #0088ff80;animation:hitBurstWater .28s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--ice{background:radial-gradient(circle at 50% 50%,rgba(220,248,255,1) 0%,rgba(136,221,255,.8) 35%,rgba(80,180,255,.3) 65%,transparent 80%);box-shadow:inset 0 0 25px 8px #8df9;animation:hitBurst .24s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--nature{background:radial-gradient(circle at 50% 50%,rgba(60,230,80,1) 0%,rgba(34,204,68,.75) 35%,rgba(20,160,50,.3) 65%,transparent 80%);box-shadow:inset 0 0 25px 8px #22cc448c;animation:hitBurst .28s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--void{background:radial-gradient(circle at 50% 50%,rgba(180,0,255,1) 0%,rgba(120,0,220,.8) 30%,rgba(60,0,150,.35) 60%,transparent 80%);box-shadow:inset 0 0 30px 10px #8c00ff99;animation:hitBurstVoid .28s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--magic{background:radial-gradient(circle at 50% 50%,rgba(220,80,255,1) 0%,rgba(180,0,255,.8) 30%,rgba(140,0,200,.3) 65%,transparent 80%);box-shadow:inset 0 0 25px 8px #c832ff8c;animation:hitBurst .24s cubic-bezier(.05,.9,.2,1) forwards}.hit-effect--heal{background:radial-gradient(circle at 50% 65%,rgba(0,255,170,1) 0%,rgba(0,220,140,.7) 40%,rgba(0,180,120,.25) 70%,transparent 85%);box-shadow:inset 0 0 25px 8px #00ffaa80;animation:hitHeal .32s cubic-bezier(.05,.9,.2,1) forwards}@keyframes hitBurst{0%{opacity:1;transform:scale(.1)}12%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1.9)}}@keyframes hitBurstWater{0%{opacity:1;transform:scale(.1)}12%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(2)}}@keyframes hitBurstVoid{0%{opacity:1;transform:scale(.15)}10%{opacity:1;transform:scale(1.05)}to{opacity:0;transform:scale(1.7)}}@keyframes hitLightning{0%{opacity:1}20%{opacity:0}38%{opacity:.85}55%{opacity:0}to{opacity:0}}@keyframes hitHeal{0%{opacity:1;transform:scale(.4) translateY(0)}15%{opacity:1;transform:scale(1.1) translateY(-8px)}to{opacity:0;transform:scale(1.3) translateY(-20px)}}.mob-card__labels{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible;z-index:20}.damage-label{position:absolute;top:28%;left:50%;font-size:16px;font-weight:900;letter-spacing:.01em;text-shadow:0 1px 6px oklch(0% 0 0 / .9),0 0 10px currentColor;animation:floatDamage 1.1s cubic-bezier(.15,.85,.35,1) forwards;white-space:nowrap;pointer-events:none}.damage-label--physical{color:#f68000;color:oklch(72% .18 55)}.damage-label--magic{color:#9980fe}.damage-label--heal{color:#32c364}@keyframes floatDamage{0%{opacity:0;transform:translate(-50%) translateY(0) scale(.55)}12%{opacity:1;transform:translate(-50%) translateY(-4px) scale(1.25)}55%{opacity:1;transform:translate(-50%) translateY(-22px) scale(1)}to{opacity:0;transform:translate(-50%) translateY(-38px) scale(.85)}}@keyframes calloutPop{0%{opacity:0;transform:translate(-50%) scale(.3) rotate(-8deg)}12%{opacity:1;transform:translate(-50%) scale(1.35) rotate(3deg)}20%{opacity:1;transform:translate(-50%) scale(.95) rotate(-1deg)}28%{opacity:1;transform:translate(-50%) scale(1.08) rotate(0)}38%{opacity:1;transform:translate(-50%) scale(1) rotate(0)}75%{opacity:1;transform:translate(-50%) scale(1) rotate(0)}to{opacity:0;transform:translate(-50%) scale(.8) rotate(2deg)}}.mob-card__callout{position:absolute;top:22px;left:50%;transform:translate(-50%);z-index:10;font-size:.82rem;font-weight:900;text-transform:uppercase;letter-spacing:.08em;padding:5px 12px;border:3px solid #111;clip-path:polygon(7px 0%,calc(100% - 7px) 0%,100% 7px,100% calc(100% - 7px),calc(100% - 7px) 100%,7px 100%,0% calc(100% - 7px),0% 7px);white-space:nowrap;pointer-events:none;animation:calloutPop 1.3s cubic-bezier(.22,1,.36,1) forwards}.mob-card__buff-strip{position:absolute;top:2px;left:0;right:0;z-index:3;display:flex;flex-wrap:wrap;gap:2px;padding:2px 4px;pointer-events:none}.mob-card__debuff-strip{position:absolute;bottom:5px;left:0;right:0;z-index:3;display:flex;flex-wrap:wrap;gap:2px;padding:2px 4px;pointer-events:none}.buff-badge{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;border-radius:99px;font-size:8px;font-weight:800;background:#002b49e0;background:oklch(28% .18 245 / .88);color:#b8d8ff;border:1px solid oklch(52% .18 245 / .7);white-space:nowrap;letter-spacing:.02em;text-shadow:0 1px 2px oklch(0% 0 0 / .6)}.buff-badge small{font-size:7px;opacity:.75;margin-left:1px}.debuff-badge{display:inline-flex;align-items:center;gap:2px;padding:1px 5px;border-radius:99px;font-size:8px;font-weight:800;background:#420010e0;background:oklch(24% .18 15 / .88);color:#ffb8b8;border:1px solid oklch(50% .22 15 / .7);white-space:nowrap;letter-spacing:.02em;text-shadow:0 1px 2px oklch(0% 0 0 / .6)}.debuff-badge small{font-size:7px;opacity:.75;margin-left:1px}.buff-badge--icon,.debuff-badge--icon{padding:1px 4px;font-size:10px;min-width:20px;justify-content:center;gap:1px}.mob-card__warlord-tag{position:absolute;bottom:4px;left:50%;transform:translate(-50%);background:#d76f00;background:oklch(65% .18 55);color:#111;font-size:8px;font-weight:900;letter-spacing:.12em;padding:1px 6px;border-radius:3px;z-index:4;pointer-events:none;white-space:nowrap}.action-ticker{display:flex;align-items:center;justify-content:center;gap:6px;background:var(--c-bg2);border:1px solid;border-radius:var(--radius);padding:8px 12px;font-size:12px;font-weight:700;text-align:center;min-height:38px;animation:tickerFade .15s ease;position:relative;overflow:hidden;flex-shrink:0}.action-ticker:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:currentColor;opacity:.04;border-radius:inherit}.action-ticker__icon{font-size:13px;flex-shrink:0;filter:drop-shadow(0 0 4px currentColor)}.action-ticker__text{line-height:1.3}.action-ticker__actor{color:var(--c-text)}.action-ticker__skill{opacity:.85;font-style:italic}.action-ticker__arrow{opacity:.5;font-size:10px}.action-ticker__target{opacity:.85}.action-ticker__value{font-size:14px;font-weight:900;filter:drop-shadow(0 0 4px currentColor)}@keyframes tickerFade{0%{opacity:0;transform:translateY(5px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.battle-controls{flex-shrink:0;display:flex;flex-direction:column;gap:6px}.battle-log{background:var(--c-bg2);border:1px solid var(--c-border);border-radius:var(--radius);padding:10px 12px;max-height:160px;overflow-y:auto;font-size:11px;line-height:1.7;flex-shrink:0}.log-entry{color:var(--c-text2)}.log-entry.damage{color:#f26644}.log-entry.heal{color:var(--c-green)}.log-entry.buff{color:var(--c-purple)}.log-entry.debuff{color:#ef852e}.log-entry.phase{color:var(--c-gold);font-weight:700}.log-entry.skill{color:var(--c-blue)}.log-entry.result{color:var(--c-gold);font-weight:700;font-size:13px;text-align:center;margin:6px 0}.formation-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin:8px 0}.formation-col{background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);padding:8px;min-height:80px}.formation-col__label{font-size:9px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--c-text3);text-align:center;margin-bottom:6px}.formation-slot{background:var(--c-bg2);border:1px dashed var(--c-border);border-radius:6px;height:110px;display:flex;align-items:center;justify-content:center;font-size:20px;cursor:pointer;transition:border-color .15s;position:relative;overflow:hidden}.formation-slot:hover{border-color:var(--c-gold2)}.formation-slot.filled{border-style:solid;border-color:var(--c-border2)}.formation-slot.filled:hover{border-color:var(--c-blood)}.brigade-board{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.brigade-slot{position:relative;border-radius:10px;background:linear-gradient(160deg,var(--c-bg2) 60%,oklch(30% .04 260 / .5));border:1px solid var(--c-border);min-height:110px;display:flex;align-items:center;justify-content:center;cursor:default;transition:border-color .15s,box-shadow .15s,background .15s;overflow:hidden}.brigade-slot:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:radial-gradient(ellipse at 50% 110%,oklch(40% .05 260 / .4) 0%,transparent 70%);pointer-events:none}.brigade-slot--warlord{border-color:var(--c-gold)}.brigade-slot--filled{cursor:grab;touch-action:none;-webkit-user-select:none;user-select:none}.brigade-slot--filled:active{cursor:grabbing}.brigade-slot--dragging{opacity:.32;filter:grayscale(.35);pointer-events:none}.brigade-slot--selected{border-color:var(--c-blood);box-shadow:0 0 0 2px #d405304d}.brigade-slot--empty{border-style:dashed}.brigade-slot--drop-target{border-color:var(--c-gold2);background:#9469001f;background:oklch(55% .12 80 / .12);box-shadow:0 0 0 2px #dca33159}.brigade-slot-ghost{position:fixed;z-index:9999;pointer-events:none;border-radius:10px;overflow:hidden;transform:scale(1.08);transform-origin:center center;box-shadow:0 0 0 1.5px #e1a100e6,0 12px 36px #000000a6,0 0 28px #e1a10040;box-shadow:0 0 0 1.5px oklch(75% .18 80 / .9),0 12px 36px #000000a6,0 0 28px oklch(75% .18 80 / .25);filter:brightness(1.22)}.brigade-slot-ghost .brigade-slot{width:100%;height:100%;box-sizing:border-box;cursor:grabbing;border-color:#e1a100b3;border-color:oklch(75% .18 80 / .7)}.brigade-badge{position:absolute;top:3px;left:4px;font-size:7px;font-weight:800;color:var(--c-gold);z-index:3;letter-spacing:.05em;line-height:1;pointer-events:none}.brigade-remove-zone{border:1.5px dashed oklch(55% .22 22 / .55);border-radius:8px;padding:10px;text-align:center;font-size:11px;color:#e8575bcc;background:#5d27271f;margin-bottom:12px;pointer-events:none;animation:brigade-remove-zone-in .15s ease-out}@keyframes brigade-remove-zone-in{0%{opacity:0;transform:scaleY(.8)}to{opacity:1;transform:scaleY(1)}}.brigade-fam-ghost{position:fixed;z-index:9999;pointer-events:none;transform:scale(1.08);transform-origin:center center;opacity:.92;filter:brightness(1.18);box-shadow:0 0 0 1.5px #e1a100cc,0 12px 36px #0009,0 0 24px #e1a10033;box-shadow:0 0 0 1.5px oklch(75% .18 80 / .8),0 12px 36px #0009,0 0 24px oklch(75% .18 80 / .2);border-radius:10px;overflow:hidden}.floor-item{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);margin-bottom:6px;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s,transform .1s}.floor-item.locked{opacity:.36;cursor:not-allowed}.floor-item.cleared{border-color:#20a04e4d;background:#20a04e0d}.floor-item.boss{border-color:#c5002b66;border-color:oklch(52% .228 22 / .4);background:#c5002b0f;background:oklch(52% .228 22 / .06)}.floor-item.current{border-color:var(--c-gold2);background:#cf870014;background:oklch(68% .15 72 / .08);box-shadow:0 0 12px #cf87002e;box-shadow:0 0 12px oklch(68% .15 72 / .18)}.floor-item:not(.locked):hover{border-color:var(--c-border2);background:var(--c-surface);transform:translate(2px)}.floor-item.current:not(.locked):hover{border-color:var(--c-gold);transform:translate(2px)}.floor-num{width:36px;height:36px;border-radius:50%;background:var(--c-surface);border:1px solid var(--c-border2);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}.floor-num.boss{border-color:var(--c-blood);color:var(--c-blood)}.floor-num.cleared{border-color:var(--c-green);color:var(--c-green)}.floor-num.current{border-color:var(--c-gold);color:var(--c-gold)}.floor-info{flex:1}.floor-name{font-size:13px;font-weight:700}.floor-desc{font-size:11px;color:var(--c-text2);margin-top:2px}.tower-climb{flex:1;position:relative;overflow:hidden;display:flex;flex-direction:column;padding-bottom:68px}.tower-stair-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0}.tower-stair-svg{width:100%;height:100%;display:block}.tower-top-bar{position:relative;z-index:2;padding:10px 16px 8px;display:flex;flex-direction:column;gap:8px;background:linear-gradient(to bottom,oklch(5% .01 22 / .82) 0%,transparent 100%)}.tower-zone-badge{display:flex;align-items:center;gap:7px;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase}.tower-zone-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tower-enemy-section{position:relative;z-index:3;flex-shrink:0}.tower-enemy-pool-toggle{display:flex;align-items:center;gap:6px;width:100%;padding:7px 16px;background:#010000b3;border:none;border-bottom:1px solid oklch(20% .03 22 / .5);color:var(--c-text2);font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;cursor:pointer;text-align:left}.tower-enemy-pool-toggle:hover{color:var(--c-text)}.tower-enemy-pool-toggle-count{color:var(--c-text3);font-weight:500;letter-spacing:.03em}.tower-enemy-pool-toggle-chevron{margin-left:auto;font-size:14px;transition:transform .2s ease;display:inline-block}.tower-enemy-pool{position:relative;z-index:2;display:grid;grid-template-columns:repeat(auto-fill,minmax(52px,1fr));gap:6px;padding:8px 16px 10px;background:linear-gradient(to bottom,oklch(5% .01 22 / .55) 0%,transparent 100%)}.tower-enemy-pool .uni-card{max-width:none;width:100%}.tower-enemy-detail-panel{position:absolute;top:100%;left:0;right:0;z-index:10;max-height:220px;overflow-y:auto;background:#030101f7;border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);padding:12px 16px 14px}.tower-enemy-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.tower-enemy-detail-title{font-size:15px;font-weight:800;color:var(--c-text);letter-spacing:.02em}.tower-enemy-detail-close{background:none;border:none;color:var(--c-text3);font-size:16px;cursor:pointer;padding:2px 6px;line-height:1}.tower-floor-action-row{display:flex;align-items:center;justify-content:center;gap:16px;width:100%}.tower-arrow-btn{width:36px;height:36px;border-radius:50%;background:#180808d9;border:1px solid oklch(28% .045 22);color:var(--c-text2);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s;flex-shrink:0}.tower-arrow-btn:hover:not(:disabled){background:#301717;color:var(--c-text)}.tower-arrow-btn:disabled{opacity:.22;cursor:not-allowed}.tower-floor-display{position:relative;z-index:2;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:16px 28px 24px;text-align:center}.tower-floor-num{font-size:72px;font-weight:900;letter-spacing:-3px;line-height:1;margin-bottom:10px;text-shadow:0 0 40px currentColor;filter:drop-shadow(0 0 20px currentColor)}.tower-floor-name{font-size:18px;font-weight:700;color:var(--c-text);margin-bottom:10px;display:flex;align-items:center;gap:4px;min-height:26px}.tower-floor-desc{font-size:12px;color:var(--c-text2);max-width:270px;line-height:1.55;margin-bottom:24px;height:56px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.tower-floor-action{display:flex;justify-content:center;min-height:68px;align-items:flex-start}.tower-wall-badge{font-size:12px;color:var(--c-text3);padding:8px 16px;border:1px solid var(--c-border);border-radius:var(--radius);background:#080202cc;letter-spacing:.05em}.tower-floor-slider{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 24px 0;width:100%}.tower-slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:4px;border-radius:2px;background:#291413;outline:none;cursor:pointer}.tower-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--zone-color, #6B7280);box-shadow:0 0 8px var(--zone-color, #6B7280);cursor:pointer;transition:transform .1s,box-shadow .15s}.tower-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--zone-color, #6B7280);box-shadow:0 0 8px var(--zone-color, #6B7280);cursor:pointer;border:none;transition:transform .1s,box-shadow .15s}.tower-slider:active::-webkit-slider-thumb{transform:scale(1.25);box-shadow:0 0 16px var(--zone-color, #6B7280)}.tower-slider:active::-moz-range-thumb{transform:scale(1.25);box-shadow:0 0 16px var(--zone-color, #6B7280)}.tower-slider-label{font-size:13px;letter-spacing:.04em}.stat-row{display:flex;align-items:center;padding:5px 0;border-bottom:1px solid var(--c-border);font-size:13px}.stat-row:last-child{border-bottom:none}.stat-row__label{width:60px;color:var(--c-text3);font-size:11px}.stat-row__bar{flex:1;height:4px;background:var(--c-border);border-radius:2px;margin:0 10px;overflow:hidden}.stat-row__bar-fill{height:100%;border-radius:2px;background:var(--c-purple);transition:width .35s}.stat-row__val{font-size:13px;font-weight:600;min-width:40px;text-align:right}.camp-warlord-card{background:linear-gradient(135deg,var(--c-surface),var(--c-bg3));border:1px solid var(--c-border2);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:12px;position:relative;overflow:hidden}.camp-warlord-card:before{content:"";position:absolute;top:0;right:0;width:80px;height:80px;background:radial-gradient(circle,oklch(52% .228 22 / .12) 0%,transparent 70%);pointer-events:none}.zone-header{display:flex;align-items:center;gap:10px;margin:14px 0 8px}.zone-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;box-shadow:0 0 6px currentColor}.zone-label{font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.04em}.tag-red{background:#210506;color:#fb575d;border:1px solid oklch(52% .228 22 / .4)}.tag-green{background:#000d02;color:#28bc5e;border:1px solid oklch(62% .16 150 / .4)}.tag-blue{background:#000a17;background:oklch(14% .04 245);color:#2da6fa;border:1px solid oklch(62% .15 245 / .4)}.tag-purple{background:#0a051c;color:#9f88ff;color:oklch(70% .18 290);border:1px solid oklch(60% .18 290 / .4)}.tag-gold{background:#110700;background:oklch(14% .04 72);color:#e5ac4c;border:1px solid oklch(78% .13 78 / .4)}.tag-gray{background:#16100f;color:#867e7d;border:1px solid oklch(40% .01 30 / .4)}.toast{position:absolute;top:60px;left:50%;transform:translate(-50%);background:var(--c-surface);border:1px solid var(--c-border2);border-radius:var(--radius);padding:10px 18px;font-size:13px;z-index:100;box-shadow:0 4px 24px #00000080;animation:slideDown .25s ease;white-space:nowrap;max-width:90%}.toast.error{border-color:var(--c-blood);color:#ff8281;color:oklch(75% .16 22)}.toast.success{border-color:var(--c-green);color:#40cc6d}.toast.info{border-color:var(--c-blue);color:#59b6ff;color:oklch(75% .16 245)}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#000000b8;display:flex;align-items:flex-end;justify-content:center;z-index:50}.modal{background:var(--c-bg2);border:1px solid var(--c-border2);border-radius:var(--radius-lg) var(--radius-lg) 0 0;padding:20px 16px 30px;width:100%;max-height:78vh;overflow-y:auto}.modal__title{font-size:15px;font-weight:800;margin-bottom:14px;display:flex;align-items:center;gap:8px}.modal__close{margin-left:auto;color:var(--c-text3);font-size:22px;line-height:1}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100dvh;gap:16px;background:var(--c-bg)}.loading-title{font-size:22px;font-weight:900;color:var(--c-blood);letter-spacing:.06em;text-shadow:0 0 30px oklch(52% .228 22 / .6)}.spinner{width:36px;height:36px;border:3px solid var(--c-border);border-top-color:var(--c-blood);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.stamina-bar{display:flex;align-items:center;gap:8px;font-size:12px}.stamina-bar__track{flex:1;height:6px;background:var(--c-border);border-radius:3px;overflow:hidden}.stamina-bar__fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--c-blood2),var(--c-blood));transition:width .4s}::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--c-border2);border-radius:2px}.start-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:24px;text-align:center;gap:16px;background:radial-gradient(ellipse at 50% 30%,#190102,#040101 60%,#020000)}.start-logo{font-size:54px;margin-bottom:4px;filter:drop-shadow(0 0 20px oklch(52% .228 22 / .5))}.start-title{font-size:26px;font-weight:900;color:var(--c-gold);line-height:1.15;text-shadow:0 2px 20px oklch(80% .13 78 / .35);letter-spacing:.04em}.start-subtitle{font-size:13px;color:var(--c-text2);max-width:280px;line-height:1.7}.race-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;width:100%;max-width:340px;margin:8px 0}.race-btn{background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);padding:12px 8px;text-align:center;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.race-btn.selected,.race-btn:hover{border-color:var(--c-blood);background:var(--c-surface);box-shadow:0 0 10px #c5002b38;box-shadow:0 0 10px oklch(52% .228 22 / .22)}.race-btn__name{font-size:13px;font-weight:700}.race-btn__bonus{font-size:11px;color:var(--c-green);margin-top:3px}.race-btn__style{font-size:10px;color:var(--c-text3);margin-top:2px}.input-field{width:100%;padding:11px 13px;background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);color:var(--c-text);font-size:14px;font-family:var(--font-main);outline:none;transition:border-color .15s,box-shadow .15s}.input-field:focus{border-color:var(--c-blood);box-shadow:0 0 0 2px #c5002b2e;box-shadow:0 0 0 2px oklch(52% .228 22 / .18)}.input-field::placeholder{color:var(--c-text3)}.result-banner{text-align:center;padding:12px;border-radius:var(--radius);font-size:18px;font-weight:900;margin:10px 0 6px;letter-spacing:.04em}.result-banner--win{background:#20a04e1a;border:1px solid oklch(62% .16 150 / .35);color:#32c364}.result-banner--loss{background:#c5002b1a;background:oklch(52% .228 22 / .1);border:1px solid oklch(52% .228 22 / .35);color:#f04c55}.battle-floor-header{background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--radius);padding:8px 12px;flex-shrink:0}.battle-floor-header__num{font-size:10px;color:var(--c-text3);font-weight:700;letter-spacing:.08em;text-transform:uppercase}.battle-floor-header__name{font-size:14px;font-weight:800;color:var(--c-text)}.battle-floor-header__desc{font-size:11px;color:var(--c-text2);margin-top:1px}.slot-remove-hint{font-size:9px;color:var(--c-blood);opacity:0;transition:opacity .15s}.formation-slot:hover .slot-remove-hint{opacity:1}.lore-blurb{margin-top:16px;padding:12px 14px;background:var(--c-bg3);border:1px solid var(--c-border);border-radius:var(--radius);border-left:2px solid var(--c-blood2);font-size:11px;font-style:italic;color:var(--c-text2);line-height:1.7}.tower-progress-track{display:flex;gap:3px;flex-wrap:wrap}.tower-pip{width:20px;height:20px;border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;transition:transform .1s}@keyframes auto-node-ring{0%{transform:scale(1);opacity:.9}60%{transform:scale(1.5);opacity:0}to{transform:scale(1.5);opacity:0}}@keyframes auto-countdown{0%{transform:scaleX(1)}to{transform:scaleX(0)}}.combat-transition{position:absolute;top:0;right:0;bottom:0;left:0;z-index:60;display:flex;align-items:center;justify-content:center;pointer-events:none}.combat-transition__bg{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,#c5002b0f,#070101d9 60%,#000000f2),linear-gradient(180deg,#0000,#000 80%);background:radial-gradient(ellipse at center,color(xyz 0.246 0.119 0.026 / 0.059),#070101d9 60%,#000000f2),linear-gradient(180deg,#0000,#000 80%);opacity:0;transform:scale(1)}.combat-transition__title{position:relative;z-index:62;color:var(--c-gold);font-weight:900;font-size:26px;text-shadow:0 4px 20px oklch(0% 0 0 / .7);pointer-events:none;opacity:0;letter-spacing:.06em}.combat-transition--intro .combat-transition__bg{animation:combatIntro .7s cubic-bezier(.2,.9,.2,1) forwards}.combat-transition--intro .combat-transition__title{animation:titleIntro .7s cubic-bezier(.2,.9,.2,1) forwards}@keyframes combatIntro{0%{opacity:0;transform:scale(1.03)}30%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes titleIntro{0%{opacity:0;transform:translateY(8px) scale(.98)}40%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-6px) scale(.96)}}.combat-transition--outro{pointer-events:auto}.combat-transition--outro .combat-transition__bg{animation:combatOutro .6s cubic-bezier(.2,.9,.2,1) forwards}.combat-transition--outro .combat-transition__title{animation:titleOutro .6s cubic-bezier(.2,.9,.2,1) forwards}@keyframes combatOutro{0%{opacity:0;transform:scale(1)}to{opacity:1;transform:scale(1.02)}}@keyframes titleOutro{0%{opacity:0;transform:translateY(6px) scale(.98)}to{opacity:.85;transform:translateY(0) scale(1)}}@keyframes revealOverlayIn{0%{opacity:0}to{opacity:1}}@keyframes cardFadeIn{0%{transform:scale(.85);opacity:0}to{transform:scale(1);opacity:1}}@keyframes cardShine{0%{background-position:-250% center}to{background-position:250% center}}.familiar-reveal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;display:flex;align-items:center;justify-content:center;background:#000000c7;animation:revealOverlayIn .3s ease forwards}.familiar-reveal-card{position:relative;overflow:hidden;display:flex;flex-direction:column;align-items:center;padding:28px 36px;border-radius:18px;background:var(--c-surface);border:2px solid var(--rarity-color, #9CA3AF);box-shadow:0 0 36px var(--rarity-color, #9CA3AF),0 0 80px #000000b3;animation:cardFadeIn .35s cubic-bezier(.22,1,.36,1) forwards}.familiar-reveal-shine{position:absolute;top:0;right:0;bottom:0;left:0;z-index:1;pointer-events:none;border-radius:inherit;background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.15) 50%,transparent 80%);background-size:250% 100%;animation:cardShine 1.8s linear .35s infinite}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}
