@import"https://fonts.googleapis.com/css2?family=Nunito:wght@600;700;800&display=swap";:root{--bg: #1f2430;--panel: #2a3140;--panel-soft: #343d4f;--panel-soft-2: #293143;--text: #f8f2df;--muted: #c3b998;--gold: #efb546;--danger: #d95a52;--green: #4e9e65;--blue: #4f7dcc;--red: #cf5246;--yellow: #d0a03b}*{box-sizing:border-box}html,body{height:100vh;min-height:100%;margin:0;width:100%;overflow:hidden;overscroll-behavior:none}#app{position:fixed;inset:0;overflow:hidden;display:flex;justify-content:center;align-items:stretch}body{font-family:Nunito,Segoe UI,sans-serif;background:var(--bg);color:var(--text)}button{border:0;border-radius:10px;padding:8px 10px;font-weight:800;background:var(--gold);color:#221810;cursor:pointer;-webkit-tap-highlight-color:transparent}button:disabled{opacity:.55;cursor:not-allowed}button:focus-visible{outline:2px solid #f8df9c;outline-offset:1px}.danger-button{background:var(--danger);color:#fff0ed}.flat-button{background:#56617b;color:var(--text)}.app-root{width:min(100%,430px);margin:0 auto;height:100%;min-height:0;max-height:100%;padding-top:calc(8px + env(safe-area-inset-top));padding-right:calc(10px + env(safe-area-inset-right));padding-bottom:calc(10px + env(safe-area-inset-bottom));padding-left:calc(10px + env(safe-area-inset-left));display:flex;flex-direction:column;gap:8px;position:relative;overflow:hidden}.app-root--gameplay{background-image:url(/assets/backgrounds/dungeon-main.png);background-size:cover;background-position:center;background-repeat:no-repeat}.app-root--gameplay:before{content:"";position:absolute;inset:0;background:#0f131e57;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);pointer-events:none;z-index:0}.app-root--gameplay>*{position:relative;z-index:1}.app-stage{flex:1 1 auto;min-height:0;position:relative;display:flex;flex-direction:column}.topbar{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:8px 10px;border-radius:12px;background:var(--panel)}.topbar-stats{display:flex;gap:7px;flex-wrap:wrap}.topbar-stat{font-size:.8rem;font-weight:800;background:var(--panel-soft);border-radius:999px;padding:4px 8px;display:inline-flex;align-items:center;gap:5px}.topbar-stat img{width:14px;height:14px;object-fit:contain}.topbar-stat--pulse{animation:stat-pulse .32s ease-out}.topbar-actions{display:flex;gap:6px}.button-pulse{position:relative;animation:button-pulse 1.35s ease-in-out infinite}.button-badge{margin-left:6px;min-width:18px;height:18px;border-radius:999px;background:var(--danger);color:#fff;display:inline-grid;place-items:center;font-size:.68rem;padding:0 5px}.effect-strip-wrap{position:relative;min-height:34px}.effect-strip-wrap:before,.effect-strip-wrap:after{content:"";position:absolute;top:0;bottom:0;width:16px;z-index:2;pointer-events:none}.effect-strip-wrap:before{left:0;background:linear-gradient(to right,var(--bg),transparent)}.effect-strip-wrap:after{right:0;background:linear-gradient(to left,var(--bg),transparent)}.effect-strip{display:flex;gap:6px;overflow-x:auto;white-space:nowrap;padding:2px 16px;scrollbar-width:none}.effect-strip::-webkit-scrollbar{display:none}.effect-chip{background:#141821d9;border-radius:999px;padding:4px 7px;display:inline-flex;align-items:center;gap:4px;font-size:.72rem}.effect-chip-source,.effect-chip-metric{width:16px;height:16px;object-fit:contain}.effect-chip em{font-style:normal;color:var(--text);font-weight:700}.gameplay-layout{flex:1 1 auto;min-height:0;display:flex;flex-direction:column;gap:6px}.boss-card{--boss-art-scale: 1.5;--boss-art-drop: 34px;--boss-art-top: 56px;flex:0 0 auto;min-height:124px;flex-basis:clamp(124px,22%,186px);border-radius:10px;overflow:visible;position:relative;z-index:1;background:transparent;isolation:isolate}.boss-art-layer{position:absolute;inset:var(--boss-art-top) 0 calc(-1 * var(--boss-art-drop));z-index:0;pointer-events:none;overflow:visible}.boss-art-inner{position:absolute;left:50%;top:0;transform:translate(-50%) scale(var(--boss-art-scale));transform-origin:center top;width:min(100%,360px);height:100%;display:flex;justify-content:center;align-items:flex-start}.boss-content-layer{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:space-between;gap:6px;padding:6px 8px 8px}.boss-top-info{display:grid;gap:4px}.boss-portrait{width:auto;max-width:100%;height:100%;object-fit:contain;object-position:center top;filter:drop-shadow(0 12px 14px rgba(0,0,0,.4));transform-origin:center top;animation:boss-idle 2.8s ease-in-out infinite}.boss-tombstone{width:min(102px,42vw);height:min(112px,88%);border-radius:48px 48px 12px 12px;background:#656c7b;border:3px solid #81889a;display:grid;place-items:center;align-content:center;box-shadow:0 8px 12px #00000059}.boss-tombstone span{font-size:1.4rem;line-height:1}.boss-tombstone small{font-size:.7rem;color:#eceef7}.boss-flash{position:absolute;inset:0;background:#ff463c6b;opacity:0}.boss-card--hurt-a,.boss-card--hurt-b{animation:boss-hurt .22s ease}.boss-card--hurt-a .boss-flash,.boss-card--hurt-b .boss-flash{animation:boss-flash .22s ease}.boss-hp{position:relative;height:18px;background:#2c1717;border-radius:999px;overflow:hidden}.boss-hp-fill{position:absolute;inset:0 auto 0 0;background:#d9514b;transition:width .14s linear}.boss-hp span{position:relative;display:grid;place-items:center;width:100%;height:100%;font-size:.74rem;font-weight:800}.boss-name{margin:0;font-size:.74rem;font-weight:800;color:#efe4c4;text-shadow:0 1px 1px rgba(0,0,0,.4)}.relic-row-wrap{position:relative;min-height:32px}.relic-row-wrap:before,.relic-row-wrap:after{content:"";position:absolute;top:0;bottom:0;width:18px;z-index:2;pointer-events:none;opacity:0;transition:opacity .12s ease-out}.relic-row-wrap:before{left:0;background:linear-gradient(to right,var(--bg),transparent)}.relic-row-wrap:after{right:0;background:linear-gradient(to left,var(--bg),transparent)}.boss-relic-row:before{background:linear-gradient(to right,rgba(12,16,24,.95),transparent)}.boss-relic-row:after{background:linear-gradient(to left,rgba(12,16,24,.95),transparent)}.boss-relic-row--fade-left:before{opacity:1}.boss-relic-row--fade-right:after{opacity:1}.relic-strip{display:flex;gap:6px;flex-wrap:nowrap;align-items:center;overflow-x:auto;white-space:nowrap;padding:1px 18px;scrollbar-width:none}.relic-strip::-webkit-scrollbar{display:none}.relic-chip{width:30px;height:30px;display:inline-grid;place-items:center;background:#0e1016b3;border-radius:999px;padding:0;flex:0 0 auto}.relic-chip img{width:24px;height:24px;object-fit:contain}.board-card{position:relative;flex:1 1 auto;min-height:0;overflow:hidden;z-index:2}.board-card--proc-pulse:after{content:"";position:absolute;inset:6px;border-radius:10px;border:2px solid rgba(130,238,146,.85);box-shadow:0 0 18px #82ee9266;pointer-events:none;animation:board-proc-pulse .46s ease-out}.board-shell{--board-playfield-inset: 4.6%;position:absolute;inset:0;width:100%;height:100%;min-width:0;max-width:none;max-height:none;overflow:hidden;margin:0}.game-canvas{width:100%;height:100%;display:block}.board-notice{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);z-index:12;background:#121721e0;border-radius:999px;padding:8px 14px;font-size:.9rem;font-weight:800;letter-spacing:.02em;pointer-events:none;animation:board-notice 1.2s ease-out}.board-notice--turn{color:#c5ecff}.board-notice--proc{color:#96ff9b}.projectile-layer{position:fixed;inset:0;pointer-events:none;z-index:18;overflow:hidden}.projectile{position:fixed;left:var(--projectile-start-x, 0px);top:var(--projectile-start-y, 0px);width:7px;height:7px;border-radius:999px;background:#af6cff;box-shadow:0 0 12px #a06bffcc;transform:translate(-50%,-50%);animation:projectile-fly-targeted .62s cubic-bezier(.15,.78,.22,1) forwards;animation-delay:var(--projectile-delay, 0ms)}.objectives-card{background:var(--panel);border-radius:10px;padding:6px}.objectives-card--pulse{animation:panel-pulse .42s ease-out}.objectives-grid{display:grid;gap:6px;grid-template-columns:repeat(4,minmax(0,1fr))}.objective-item{border-radius:8px;background:var(--panel-soft);position:relative}.objective-item-button{border:0;padding:5px;margin:0;width:100%;background:transparent;color:inherit;text-align:left;border-radius:inherit}.objective-item-button:focus,.objective-item-button:active{outline:none;background:#ffffff0a}.objective-icon-wrap{width:100%;aspect-ratio:1;border-radius:8px;background:#212939;display:grid;place-items:center;overflow:hidden}.objective-icon-wrap img{width:58%;height:58%;object-fit:contain}.objective-icon-placeholder{font-size:1rem;color:#9aa3b7;font-weight:800}.objective-main{margin-top:4px}.objective-reward{margin:0;font-size:.66rem;font-weight:800;line-height:1.1;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.objective-target{margin:2px 0 0;font-size:.64rem;color:var(--muted);display:inline-flex;align-items:center;gap:4px}.color-dot{width:9px;height:9px;border-radius:999px;display:inline-block}.color-dot--red{background:var(--red)}.color-dot--blue{background:var(--blue)}.color-dot--green{background:var(--green)}.color-dot--yellow{background:var(--yellow)}.objective-progress{margin-top:4px;height:6px;border-radius:999px;background:#222835;overflow:hidden}.objective-progress>div{height:100%;background:var(--gold)}.shop-layout{border-radius:10px;background:var(--panel);padding:10px;display:grid;gap:10px;overflow-y:auto}.shop-header{display:grid;gap:8px}.shop-header h2{margin:0}.shop-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.shop-showcase h3,.shop-boxes h3{margin:0 0 6px}.shop-grid{display:grid;gap:6px;grid-template-columns:repeat(auto-fit,minmax(112px,1fr))}.shop-card{border-radius:10px;background:var(--panel-soft);padding:8px;display:grid;gap:5px;justify-items:center;text-align:center}.shop-card img{width:52px;height:52px;object-fit:contain}.shop-item-name{margin:0;font-size:.78rem;width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-card p{margin:0;font-size:.75rem}.shop-price{display:inline-flex;align-items:center;gap:4px}.shop-price img{width:13px;height:13px}.result-backdrop{position:fixed;inset:0;background:#080b0ead;display:grid;place-items:center;padding:12px;z-index:26}.overlay-card{width:min(360px,100%);border-radius:12px;background:var(--panel);padding:14px;display:grid;gap:8px;text-align:center}.overlay-card--danger{background:#452728}.overlay-card h2,.overlay-card p{margin:0}.modal-backdrop{position:fixed;inset:0;background:#080b0ebf;display:grid;place-items:center;z-index:32}.modal-card{width:min(430px,100%);max-height:90dvh;overflow:auto;border-radius:12px;background:var(--panel);padding:10px;display:grid;gap:8px}.modal-header{display:flex;align-items:center;justify-content:space-between}.modal-header h2{margin:0;font-size:1rem}.modal-card--runestones-full{width:100%;height:100%;max-height:100%;border-radius:0;padding-top:calc(8px + env(safe-area-inset-top));padding-right:calc(10px + env(safe-area-inset-right));padding-bottom:calc(10px + env(safe-area-inset-bottom));padding-left:calc(10px + env(safe-area-inset-left));overflow:hidden;display:grid;grid-template-rows:auto 1fr;gap:8px}.runestones-header{position:relative;z-index:2;background:var(--panel);border-radius:10px;padding:2px 2px 6px}.runestones-modal-layout{min-height:0;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:8px}.runestones-list{flex:1 1 auto;min-height:0;overflow-y:auto;display:grid;align-content:start;gap:6px;padding-right:2px}.runestone-row{border-radius:10px;background:var(--panel-soft);padding:8px;display:grid;grid-template-columns:auto 1fr auto auto;align-items:flex-start;gap:8px}.runestone-row-main{align-self:flex-start}.runestone-row img{width:40px;height:40px;object-fit:contain}.runestone-row-main p,.runestone-row-main small{margin:0}.runestone-row-main p{font-size:.84rem}.runestone-row-main small{font-size:.72rem;color:var(--muted)}.runestone-equip-badge{align-self:flex-start;font-size:.68rem;padding:2px 6px;border-radius:999px;background:#efb54633;color:#ffd889}.runestone-plus{align-self:flex-start;width:28px;height:28px;border-radius:8px;display:grid;place-items:center;padding:0;font-size:1rem}.runestone-row--selected{box-shadow:inset 0 0 0 2px #74c2ffbf}.runestone-row--merge-base{box-shadow:inset 0 0 0 2px #efb546cc}.runestone-row--merge-fuel{box-shadow:inset 0 0 0 2px #ffa174cc}.runestones-panel{border-radius:10px;background:var(--panel-soft-2);border:1px solid rgba(248,242,223,.16);border-top-width:2px;padding:8px;display:grid;flex:0 0 auto;gap:7px;box-shadow:inset 0 1px #ffffff1a}.runestones-panel h3,.runestones-panel p{margin:0}.runestones-panel-title{display:grid;grid-template-columns:auto 1fr;gap:8px;align-items:center}.runestones-panel-title img{width:44px;height:44px;object-fit:contain}.runestones-panel-title h3{font-size:.9rem}.runestones-panel-title p{font-size:.74rem;color:var(--muted)}.runestone-desc{font-size:.78rem;color:var(--muted)}.runestone-base-stat{font-size:.78rem}.runestones-panel-actions{display:flex;gap:6px;flex-wrap:wrap}.bonus-lines{margin:0;padding:0;list-style:none;display:grid;gap:4px}.bonus-lines li{border-radius:7px;padding:4px 6px;display:grid;gap:2px}.bonus-lines li span{font-size:.74rem;font-weight:700}.bonus-lines li small{font-size:.68rem;color:var(--muted)}.bonus-lines__item--open{background:#75c9832e}.bonus-lines__item--locked{background:#30343dc7}.merge-slots{display:grid;grid-template-columns:1fr 1fr;gap:6px}.merge-slot{border-radius:8px;border:1px solid transparent;background:var(--panel-soft);color:var(--text);padding:6px;display:grid;gap:4px;text-align:left}.merge-slot--active{border-color:var(--gold)}.merge-slot-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.03em;color:var(--muted)}.merge-slot-body{display:inline-flex;align-items:center;gap:6px;font-size:.74rem}.merge-slot-body img{width:24px;height:24px;object-fit:contain}.merge-slot-placeholder{font-size:.72rem;color:var(--muted)}.merge-help,.empty-state{font-size:.74rem;color:var(--muted)}.modal-card--item-info{width:min(390px,calc(100% - 20px))}.item-info-icon{width:86px;height:86px;object-fit:contain;margin:0 auto}.item-info-subtitle{margin:0;text-align:center;font-size:.76rem;letter-spacing:.05em;color:var(--muted)}.item-info-description{margin:0;font-size:.84rem;text-align:center}.item-info-progression{background:#181f2cb3;border-radius:10px;padding:7px}.item-info-progression h3{margin:0 0 6px;font-size:.78rem;color:#ffd889}.item-info-progression-grid{display:grid;gap:4px;grid-template-columns:repeat(5,minmax(0,1fr))}.item-info-progression-cell{border-radius:7px;background:#343d4fe6;padding:4px 5px;display:grid;justify-items:center;gap:2px}.item-info-progression-cell strong{font-size:.64rem;color:#9fb4db}.item-info-progression-cell em{font-size:.67rem;font-style:normal;color:#f9f0cf}.item-info-progression-cell--active{background:#efb54638}.item-info-lines{margin:0;padding:0;list-style:none;display:grid;gap:6px}.item-info-lines li{border-radius:9px;background:#1d2330bf;padding:7px;display:grid;gap:4px}.item-info-line-head{display:flex;justify-content:space-between;align-items:center;gap:8px}.item-info-skill{font-size:.78rem;color:#ffdc8b;font-weight:800}.item-info-level-tag{font-size:.66rem;color:#9fc2ff}.item-info-line-detail{display:inline-flex;align-items:center;gap:5px;font-size:.74rem;color:#f0ead5}.item-info-line-detail img{width:13px;height:13px;object-fit:contain}.toast-stack{position:fixed;right:max(8px,calc((100vw - 430px)/2 + 8px));left:max(8px,calc((100vw - 430px)/2 + 8px));bottom:calc(8px + env(safe-area-inset-bottom));display:grid;gap:8px;z-index:36;pointer-events:none}.item-toast{border-radius:10px;background:#131822f0;border:1px solid rgba(255,255,255,.09);padding:8px;display:grid;grid-template-columns:auto 1fr auto;gap:8px;align-items:center;pointer-events:auto}.item-toast img{width:42px;height:42px;object-fit:contain}.item-toast-body{display:grid;gap:2px}.item-toast-body strong{font-size:.8rem}.item-toast-body span{font-size:.72rem;color:var(--muted)}.item-toast-actions{display:grid;gap:5px}.item-toast-actions button{padding:6px 8px;font-size:.72rem}@keyframes projectile-fly-targeted{0%{opacity:0;transform:translate(-50%,-50%) scale(.82)}12%{opacity:1}85%{opacity:1}to{opacity:0;transform:translate(calc(-50% + var(--projectile-dx, 0px)),calc(-50% + var(--projectile-dy, 0px))) scale(.22)}}@keyframes boss-hurt{0%{transform:scale(1) skew(0)}38%{transform:scale(1.03) skew(-2.4deg)}to{transform:scale(1) skew(0)}}@keyframes boss-flash{0%{opacity:0}26%{opacity:.85}to{opacity:0}}@keyframes boss-idle{0%{transform:scale(1)}50%{transform:scale(1.025)}to{transform:scale(1)}}@keyframes stat-pulse{0%{transform:scale(1)}30%{transform:scale(1.05)}to{transform:scale(1)}}@keyframes board-proc-pulse{0%{opacity:.1}to{opacity:0}}@keyframes panel-pulse{0%{box-shadow:0 0 #ffdc6b00}35%{box-shadow:0 0 14px #ffdc6b47}to{box-shadow:0 0 #ffdc6b00}}@keyframes board-notice{0%{opacity:0;transform:translate(-50%,-35%)}20%{opacity:1;transform:translate(-50%,-50%)}to{opacity:0;transform:translate(-50%,-62%)}}@keyframes button-pulse{0%{transform:scale(1)}40%{transform:scale(1.04)}to{transform:scale(1)}}@media(min-width:700px){.app-root{width:min(100%,460px)}.toast-stack{right:max(10px,calc((100vw - 460px)/2 + 10px));left:max(10px,calc((100vw - 460px)/2 + 10px))}}@media(max-height:700px){.app-root{padding-top:calc(6px + env(safe-area-inset-top));gap:6px}.topbar{padding:6px 8px}.topbar-stat{font-size:.74rem;padding:3px 7px}.boss-card{--boss-art-scale: 1.5;--boss-art-drop: 20px;--boss-art-top: 46px;min-height:112px;flex-basis:clamp(112px,20%,156px)}.boss-portrait{max-height:98px}.board-shell{height:100%;width:100%;aspect-ratio:auto}.objective-reward{font-size:.62rem}.objective-target{font-size:.6rem}}
