@import"https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css";@import"https://fonts.googleapis.com/css2?family=Outfit:wght@400;600;700&display=swap";:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a24;--bg-card: #16161f;--text-primary: #f0f0f5;--text-secondary: #a0a0b0;--text-muted: #606070;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-success: #22c55e;--accent-danger: #ef4444;--accent-warning: #f59e0b;--accent-info: #3b82f6;--rarity-common: #9ca3af;--rarity-rare: #3b82f6;--rarity-epic: #a855f7;--rarity-legendary: #f59e0b;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-full: 9999px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .5)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Pretendard,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;min-height:100dvh;line-height:1.5;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:none}body.has-phaser-bg{background:transparent}#root{max-width:100%;margin:0 auto;min-height:100vh;min-height:100dvh;background:var(--bg-primary);position:relative;z-index:1;overflow-y:auto;-webkit-overflow-scrolling:touch}#root.has-phaser-bg{background:transparent}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}.font-number{font-family:Outfit,sans-serif}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;font-family:inherit}.btn-primary{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 16px #6366f166}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--bg-card)}.btn-danger{background:var(--accent-danger);color:#fff}.btn-success{background:var(--accent-success);color:#fff}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.input{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-tertiary);border:1px solid var(--bg-card);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:inherit;transition:border-color .2s}.input:focus{outline:none;border-color:var(--accent-primary)}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-group label{font-size:12px;color:var(--text-secondary);font-weight:500}.card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--spacing-md);box-shadow:var(--shadow-sm)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-md)}.card-title{font-size:16px;font-weight:600}.game-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--spacing-sm);width:80px;cursor:pointer;transition:all .2s;border:2px solid transparent}.game-card:hover{transform:translateY(-4px);border-color:var(--accent-primary)}.game-card.selected{border-color:var(--accent-success);box-shadow:0 0 12px #22c55e4d}.game-card.rarity-common{border-left:3px solid var(--rarity-common)}.game-card.rarity-rare{border-left:3px solid var(--rarity-rare)}.game-card.rarity-epic{border-left:3px solid var(--rarity-epic)}.game-card-name{font-size:11px;font-weight:600;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-card-cost{font-size:10px;color:var(--accent-info);font-family:Outfit,sans-serif}.hp-bar{height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.hp-bar-fill{height:100%;background:linear-gradient(90deg,var(--accent-danger),#f87171);border-radius:var(--radius-full);transition:width .3s ease}.hp-bar-fill.low{background:var(--accent-danger);animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.monster{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;border:2px solid transparent;min-width:80px}.monster:hover{border-color:var(--accent-danger)}.monster.selected{border-color:var(--accent-danger);box-shadow:0 0 12px #ef44444d}.monster-emoji{font-size:32px}.monster-hp{font-size:10px;font-family:Outfit,sans-serif;color:var(--accent-danger)}.party-member{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--bg-tertiary);border-radius:var(--radius-md)}.party-member-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--bg-card);display:flex;align-items:center;justify-content:center;font-size:18px}.party-member-info{flex:1;min-width:0}.party-member-name{font-size:12px;font-weight:600}.party-member-hp{font-size:10px;color:var(--text-muted);font-family:Outfit,sans-serif}.intent{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--bg-card);border-radius:var(--radius-sm);font-size:10px}.intent.attack{color:var(--accent-danger)}.intent.defend{color:var(--accent-info)}.intent.buff{color:var(--accent-success)}.page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;padding:var(--spacing-md);position:relative;z-index:2;background:var(--bg-primary);overflow-y:auto;-webkit-overflow-scrolling:touch}.page-header{padding:var(--spacing-md) 0;text-align:center}.page-title{font-size:24px;font-weight:700;margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:14px;color:var(--text-secondary)}.loading{display:flex;align-items:center;justify-content:center;padding:var(--spacing-xl)}.spinner{width:24px;height:24px;border:3px solid var(--bg-tertiary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.toast{position:fixed;bottom:var(--spacing-lg);left:50%;transform:translate(-50%);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);font-size:14px;z-index:1000;animation:slideUp .3s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes cardPlay{0%{transform:scale(1)}50%{transform:scale(1.2) rotate(5deg)}to{transform:scale(0) translateY(-100px);opacity:0}}@keyframes cardDraw{0%{opacity:0;transform:translateY(50px) scale(.5)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes damageShake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-8px)}80%{transform:translate(8px)}}@keyframes damageFlash{0%,to{filter:brightness(1)}50%{filter:brightness(2) saturate(0)}}@keyframes healPulse{0%,to{box-shadow:0 0 #22c55e00}50%{box-shadow:0 0 20px 10px #22c55e80}}@keyframes buffGlow{0%,to{box-shadow:0 0 #6366f100}50%{box-shadow:0 0 15px 5px #6366f199}}@keyframes criticalHit{0%{transform:scale(1)}25%{transform:scale(1.3);filter:brightness(2)}50%{transform:scale(1.1)}to{transform:scale(1)}}@keyframes floatUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-50px)}}.anim-card-play{animation:cardPlay .4s ease-out forwards}.anim-card-draw{animation:cardDraw .3s ease-out}.anim-damage{animation:damageShake .3s ease-out,damageFlash .3s ease-out}.anim-heal{animation:healPulse .5s ease-out}.anim-buff{animation:buffGlow .5s ease-out}.anim-critical{animation:criticalHit .4s ease-out}.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-card) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeletonLoading 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeletonLoading{0%{background-position:200% 0}to{background-position:-200% 0}}.page-header-consistent{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--bg-tertiary)}.page-title-consistent{font-size:20px;font-weight:700;display:flex;align-items:center;gap:var(--spacing-sm)}@media(max-width:480px){.deck-grid{grid-template-columns:repeat(4,1fr)!important}}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:18px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.flex-1{flex:1}.w-full{width:100%}.text-center{text-align:center}.text-sm{font-size:12px}.text-muted{color:var(--text-secondary)}.mt-auto{margin-top:auto}.mb-md{margin-bottom:var(--spacing-md)}.no-scrollbar::-webkit-scrollbar{display:none}.no-scrollbar{-ms-overflow-style:none;scrollbar-width:none}@media(max-width:480px){#root{width:100%;max-width:100%}.page,.card{padding:var(--spacing-sm)}.btn{min-height:44px;padding:var(--spacing-sm) var(--spacing-md)}body{font-size:16px}.input{font-size:16px;min-height:44px}:root{--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px}.battle-ui-top{padding:4px 8px}.battle-content{gap:4px;padding:0 4px}.monsters-area{gap:4px}.monster-container{width:auto!important;margin:0!important;flex:0 0 auto}.monster-avatar{width:56px!important;height:72px!important;border-radius:6px!important}.monster-shadow{display:none}.hp-bar-container{height:4px;width:56px}.player-area{padding:4px}.player-panel{padding:6px 10px;border-radius:8px;gap:8px}.battle-ui-bottom{padding-bottom:env(safe-area-inset-bottom,0)}.hand-area{gap:2px;padding:3px 4px 0;min-height:auto}.hand-card{width:52px!important;height:76px!important;min-width:38px!important}.hand-card-inner{padding:2px}.hand-card-name{font-size:7px;height:14px}.controls-area{padding:3px 8px 4px}.controls-area .btn{font-size:12px;padding:8px 10px;border-radius:6px}.battle-log-panel{display:none}.tooltip{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);bottom:auto;width:80vw;max-width:280px;z-index:9999;pointer-events:none;box-shadow:0 4px 30px #000c;border:1px solid var(--accent-primary);background:#0a0a14f2}}@keyframes screenShake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes cardUse{0%{transform:scale(1) translateY(0);opacity:1}50%{transform:scale(1.2) translateY(-20px);opacity:.8}to{transform:scale(0) translateY(-50px);opacity:0}}@keyframes monsterHit{0%{transform:translate(0) scale(1);filter:brightness(1)}25%{transform:translate(-10px) scale(.95);filter:brightness(2)}50%{transform:translate(10px) scale(.95);filter:brightness(1.5)}75%{transform:translate(-5px) scale(1);filter:brightness(1.2)}to{transform:translate(0) scale(1);filter:brightness(1)}}@keyframes criticalHitFlash{0%{box-shadow:0 0 #ffd70000}50%{box-shadow:0 0 30px #ffd700cc}to{box-shadow:0 0 #ffd70000}}.monster-hit{animation:monsterHit .4s ease-out!important}.card-using{animation:cardUse .4s ease-out forwards!important}.damage-number{position:fixed;font-family:Outfit,sans-serif;font-weight:700;font-size:24px;pointer-events:none;animation:floatUp 1s ease-out forwards;text-shadow:2px 2px 4px rgba(0,0,0,.8);z-index:9999}.damage-number.damage{color:#ef4444}.damage-number.critical{color:gold;font-size:32px;animation:floatUp 1s ease-out forwards,criticalHitFlash .5s ease}.damage-number.heal{color:#22c55e}@keyframes slashAnim{0%{stroke-dasharray:0 200;opacity:1}to{stroke-dasharray:200 0;opacity:0}}@keyframes explosionFlash{0%{transform:scale(0);opacity:1}50%{transform:scale(1.5);opacity:.8}to{transform:scale(2);opacity:0}}@keyframes particleFly{0%{transform:translate(0) scale(1);opacity:1}to{transform:translate(calc(cos(var(--angle)) * var(--distance)),calc(sin(var(--angle)) * var(--distance))) scale(0);opacity:0}}@keyframes buffPop{0%{transform:scale(0);opacity:0}50%{transform:scale(1.3);opacity:1}to{transform:scale(1);opacity:0}}@keyframes buffRing{0%{transform:scale(.5);opacity:1}to{transform:scale(2);opacity:0}}.battle-card:hover{transform:translateY(-8px) scale(1.05);box-shadow:0 8px 25px #6366f166}.battle-card.disabled{filter:grayscale(.5)}@keyframes monsterDeath{0%{transform:scale(1);opacity:1;filter:brightness(1)}30%{transform:scale(1.1);filter:brightness(2)}to{transform:scale(0) rotate(15deg);opacity:0}}.monster-dying{animation:monsterDeath .6s ease-out forwards!important}@keyframes turnPulse{0%,to{box-shadow:0 0 #8b5cf600}50%{box-shadow:0 0 20px #8b5cf699}}.turn-indicator{animation:turnPulse 2s ease-in-out infinite}@keyframes screenShakeAnim{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}}.screen-shake{animation:screenShakeAnim .2s ease-out}@keyframes flash-fade{0%{opacity:1}to{opacity:0}}@keyframes victory-pulse{0%{transform:scale(.5);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}@keyframes card-preview-in{0%{transform:translate(-50%) translateY(20px) scale(.9);opacity:0}to{transform:translate(-50%) translateY(0) scale(1);opacity:1}}@keyframes turn-pulse{0%{transform:scale(1.3);opacity:0}50%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.ap-gauge-container{width:140px;height:20px;background:#00000080;border:1px solid rgba(255,255,255,.1);border-radius:4px;position:relative;overflow:hidden;box-shadow:inset 0 2px 4px #00000080}.ap-gauge-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#60a5fa,#93c5fd);border-radius:2px;box-shadow:0 0 10px #60a5fa99;transition:width .3s cubic-bezier(.4,0,.2,1);position:relative}.ap-gauge-fill:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.ap-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.8);z-index:2;letter-spacing:1px}.btn-end-turn{background:#ffffff0d;border:1px solid rgba(255,255,255,.2);color:#aaa;transition:all .3s ease;position:relative;overflow:hidden}.btn-end-turn:hover{background:#ffffff1a;color:#fff}.btn-end-turn.warning{border-color:#f59e0b80;color:#fca5a5;box-shadow:0 0 10px #f59e0b1a}.btn-end-turn.safe{border-color:#22c55e80;color:#86efac;box-shadow:0 0 15px #22c55e33;background:#22c55e1a}.btn-end-turn.safe:hover{background:#22c55e33;box-shadow:0 0 20px #22c55e66}.battle-log-panel{width:100%;max-height:60px;background:#0009;padding:6px 10px;overflow-y:auto;font-size:10px;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column-reverse}.battle-log-item{margin-bottom:4px;text-shadow:0 1px 2px rgba(0,0,0,1);animation:fadeIn .3s ease-out}.hand-card{transition:all .25s cubic-bezier(.175,.885,.32,1.275);width:90px;height:130px;cursor:pointer;flex-shrink:1;min-width:60px}.hand-card:hover{z-index:1000!important}.hand-card-inner{position:relative;overflow:hidden;border-radius:6px;box-shadow:0 4px 10px #00000080;height:100%;background:var(--bg-card);padding:6px;display:flex;flex-direction:column}.hand-card-name{font-size:10px;font-weight:700;line-height:1.1;text-align:center;word-break:keep-all;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;height:22px}.battle-screen{position:fixed;top:0;left:0;width:100%;height:100%;overflow:hidden;background:transparent;display:block;z-index:100;pointer-events:none}.battle-screen canvas{display:block!important;background-color:#0a0a1a!important}.battle-ui-top{padding:12px;display:flex;justify-content:space-between;align-items:flex-start;z-index:10}.battle-content{flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:0 10px;overflow:hidden;min-height:0}.monsters-area{display:flex;justify-content:center;align-items:flex-start;gap:8px;flex-wrap:wrap;width:100%}.player-area{display:flex;justify-content:center;align-items:center;padding:6px 8px}.player-panel{background:#1e293b99;border:1px solid rgba(255,255,255,.08);border-radius:10px;padding:8px 16px;width:100%;max-width:400px;display:flex;align-items:center;gap:12px}.player-header{display:flex;justify-content:space-between;align-items:center}.class-icon{font-size:28px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#0000004d;border-radius:8px}.block-badge{background:linear-gradient(135deg,#1e40af,#1d4ed8);border:1px solid #3b82f6;padding:2px 8px;border-radius:6px;font-size:11px;font-weight:700;white-space:nowrap}.battle-ui-bottom{z-index:20;display:flex;flex-direction:column;background:linear-gradient(to top,rgba(10,10,20,.98) 0%,rgba(10,10,20,.85) 70%,transparent 100%);border-top:1px solid rgba(255,255,255,.06)}.hand-area{display:flex;justify-content:center;align-items:flex-end;gap:6px;padding:8px 12px 4px;min-height:110px;overflow:visible}.controls-area{padding:8px 16px 12px;display:flex;justify-content:center;gap:10px}.controls-area .btn{max-width:500px;width:100%;font-size:16px;font-weight:700;letter-spacing:1px;padding:14px 20px;border-radius:10px}.btn-end-turn{background:linear-gradient(135deg,#334155,#1e293b)!important;border:2px solid #475569!important;color:#94a3b8!important}.btn-end-turn.warning{background:linear-gradient(135deg,#92400e,#78350f)!important;border-color:#f59e0b!important;color:#fbbf24!important}.btn-end-turn.safe{background:linear-gradient(135deg,#065f46,#064e3b)!important;border-color:#10b981!important;color:#34d399!important}.btn-play{background:linear-gradient(135deg,#7c3aed,#6d28d9)!important;border:2px solid #a78bfa!important;color:#fff!important;animation:btn-glow 2s ease-in-out infinite}@keyframes btn-glow{0%,to{box-shadow:0 0 8px #8b5cf64d}50%{box-shadow:0 0 20px #8b5cf699}}.hand-card.disabled{filter:grayscale(.8) brightness(.7);cursor:not-allowed}.hand-card.disabled .hand-card-inner:after{content:"🔒";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:24px;opacity:.7}.card-border-common{border:2px solid #9ca3af;box-shadow:0 0 5px #9ca3af33}.card-border-rare{border:2px solid #3b82f6;box-shadow:0 0 10px #3b82f64d}.card-border-epic{border:2px solid #a855f7;box-shadow:0 0 15px #a855f766}.card-border-legendary{border:2px solid #f59e0b;box-shadow:0 0 20px #f59e0b80}.tooltip-container{position:relative}.tooltip{position:absolute;bottom:110%;left:50%;transform:translate(-50%);background:#14141ef2;border:1px solid rgba(255,255,255,.1);padding:8px 12px;border-radius:8px;width:180px;font-size:11px;color:#ddd;z-index:1000;pointer-events:none;opacity:0;transition:opacity .2s;box-shadow:0 4px 20px #00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.tooltip-container:hover .tooltip{opacity:1}.monster-container{transition:transform .2s ease;width:140px;text-align:center}.monster-container:hover{transform:scale(1.05);z-index:10}.monster-avatar{width:100px;height:140px;margin:0 auto;border-radius:10px;overflow:hidden;background:#222;border:2px solid rgba(255,255,255,.1);box-shadow:0 4px 16px #0009}.monster-container.selected .monster-avatar{border-color:#ef4444;box-shadow:0 0 20px #ef444480}.monster-info{text-align:center;margin-top:4px}.monster-name{font-weight:700;font-size:12px;margin-bottom:2px;text-shadow:0 1px 3px #000;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monster-shadow{width:70px;height:8px;margin:6px auto;background:radial-gradient(ellipse,rgba(0,0,0,.5) 0%,transparent 70%)}.hp-bar-container{width:90%;height:7px;background:#333;border-radius:4px;margin:4px auto;overflow:hidden;border:1px solid rgba(255,255,255,.08)}.hp-bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.hp-bar-fill.hp-high{background:linear-gradient(90deg,#10b981,#34d399)}.hp-bar-fill.hp-mid{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.hp-bar-fill.hp-low{background:linear-gradient(90deg,#ef4444,#f87171)}@keyframes pulse-border{0%,to{border-color:#ef44444d;box-shadow:0 0 5px #ef44441a}50%{border-color:#ef4444b3;box-shadow:0 0 15px #ef44444d}}.buff-row{display:flex;gap:2px;justify-content:center;margin-top:4px;height:16px}.buff-icon-small{width:16px;height:16px;border-radius:50%;background:#00000080;display:flex;align-items:center;justify-content:center;font-size:10px;border:1px solid rgba(255,255,255,.1)}.block-overlay{position:absolute;top:0;left:0;height:100%;background:#60a5fa99;z-index:2;border-radius:inherit;box-shadow:0 0 5px #60a5fa;border-right:1px solid #93c5fd}.battle-bg{position:absolute;top:0;left:0;width:100%;height:100%;background:radial-gradient(circle at 50% 30%,#1a1a2e,#0f0f1a);z-index:-1}.particle{position:absolute;background:#ffffff1a;border-radius:50%;animation:float-particle linear infinite}@keyframes float-particle{0%{transform:translateY(100vh) translate(0);opacity:0}50%{opacity:.5}to{transform:translateY(-100px) translate(20px);opacity:0}}.battle-overlay{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;display:flex;flex-direction:column;justify-content:space-between;z-index:10}.battle-ui-top,.battle-ui-bottom{pointer-events:auto;width:100%}.battle-ui-top{padding:16px;background:linear-gradient(to bottom,rgba(0,0,0,.8),transparent)}.battle-ui-bottom{background:linear-gradient(to top,rgba(0,0,0,.95) 0%,rgba(0,0,0,.7) 80%,transparent 100%);padding-bottom:env(safe-area-inset-bottom,20px)}.codex-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media(max-width:480px){.codex-grid{grid-template-columns:repeat(3,1fr)}}.fixed-overlay{position:fixed;top:0;left:0;width:100%;height:100%;z-index:9999;display:flex;align-items:center;justify-content:center;pointer-events:all}.loading-overlay{background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);flex-direction:column}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px}.loading-text{font-weight:600;letter-spacing:1px;animation:pulse 1.5s infinite;color:var(--text-primary);text-shadow:0 0 10px rgba(255,255,255,.3)}.error-overlay{background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:20px}.error-card{width:100%;max-width:320px;background:var(--bg-card);border:1px solid var(--accent-danger);box-shadow:0 10px 40px #000c;animation:slideUp .3s cubic-bezier(.16,1,.3,1);padding:24px;border-radius:16px}.error-card .card-title{color:var(--accent-danger);font-size:18px;margin-left:8px}.error-message{color:var(--text-secondary);margin:16px 0 24px;line-height:1.6;font-size:14px}.btn-locked{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.page-transition{animation:pageFadeIn .4s cubic-bezier(.16,1,.3,1) forwards;width:100%}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}body.game-frame-active{overflow:hidden!important;position:fixed;width:100%;height:100%}.game-frame{position:fixed;inset:0;display:flex;flex-direction:column;z-index:2;pointer-events:none;overflow:hidden}.game-frame>*{pointer-events:auto}.gf-passthrough{position:fixed;inset:0;z-index:2}.gf-vignette{position:absolute;inset:0;pointer-events:none;z-index:1;background:linear-gradient(to bottom,rgba(0,0,0,.45) 0%,transparent 18%),linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 22%),linear-gradient(to right,rgba(0,0,0,.3) 0%,transparent 12%),linear-gradient(to left,rgba(0,0,0,.3) 0%,transparent 12%)}.gf-top-bar{position:relative;z-index:10;display:flex;justify-content:space-between;align-items:flex-start;padding:12px 16px 0;pointer-events:none}.gf-top-bar>*{pointer-events:auto}.gf-top-left,.gf-top-right{display:flex;align-items:center;gap:8px}.gf-content{flex:1;position:relative;z-index:5;display:flex;flex-direction:column;justify-content:flex-end;padding:0 16px;overflow:hidden;pointer-events:none}.gf-content>*{pointer-events:auto}.gf-bottom-bar{position:relative;z-index:10;padding:0 16px 14px}.hud-player-chip{display:flex;align-items:center;gap:8px;padding:6px 12px 6px 8px;background:#0a0a14bf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:12px;min-width:180px}.hud-pc-avatar{font-size:22px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:#6366f126;border-radius:8px;flex-shrink:0}.hud-pc-info{flex:1;min-width:0}.hud-pc-name-row{display:flex;align-items:center;gap:6px}.hud-pc-name{font-size:13px;font-weight:700;color:#f0f0f5;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hud-pc-level{font-size:11px;font-weight:600;color:#fbbf24;font-family:Outfit,sans-serif;flex-shrink:0}.hud-pc-hp-track{width:100%;height:4px;margin-top:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.hud-pc-hp-fill{height:100%;border-radius:2px;background:linear-gradient(90deg,#22c55e,#16a34a);transition:width .4s ease}.hud-pc-gold{display:flex;align-items:center;gap:3px;padding:3px 8px;background:#f59e0b1a;border:1px solid rgba(245,158,11,.2);border-radius:8px;flex-shrink:0}.hud-pc-gold-icon{font-size:12px}.hud-pc-gold-val{font-family:Outfit,sans-serif;font-size:13px;font-weight:700;color:#fbbf24}.hud-action-bar{display:flex;align-items:stretch;gap:8px;height:52px}.hud-qbtn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;width:56px;min-width:56px;background:#0a0a14b3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:10px;color:var(--text-primary);font-family:inherit;cursor:pointer;transition:all .15s ease;flex-shrink:0}.hud-qbtn:hover{background:#6366f11f;border-color:#6366f140}.hud-qbtn:active{transform:scale(.93)}.hud-qbtn.active{background:#6366f133;border-color:#6366f166}.hud-qbtn.locked{opacity:.35;cursor:not-allowed}.hud-qbtn-icon{font-size:18px;line-height:1}.hud-qbtn-label{font-size:9px;color:var(--text-secondary);white-space:nowrap}.hud-primary-cta{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:1px solid rgba(59,130,246,.5);border-radius:12px;color:#fff;font-size:16px;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.5px;box-shadow:0 0 20px #3b82f640,inset 0 1px #ffffff26;animation:hudCtaPulse 2.5s ease-in-out infinite;transition:transform .12s}.hud-primary-cta:hover{filter:brightness(1.08)}.hud-primary-cta:active{transform:scale(.97)}.hud-primary-cta.resume{background:linear-gradient(135deg,#f59e0b,#d97706);border-color:#f59e0b80;box-shadow:0 0 20px #f59e0b40,inset 0 1px #ffffff26}@keyframes hudCtaPulse{0%,to{box-shadow:0 0 20px #3b82f640,inset 0 1px #ffffff26}50%{box-shadow:0 0 32px #3b82f673,inset 0 1px #ffffff26}}.hud-more-overlay{position:fixed;inset:0;z-index:100;background:#00000080;display:flex;align-items:flex-end;justify-content:center;padding-bottom:80px;animation:fadeIn .15s ease-out}.hud-more-panel{width:100%;max-width:600px;max-height:50vh;overflow-y:auto;background:#0c0c18f2;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:16px;animation:lobbyPanelSlideUp .25s cubic-bezier(.16,1,.3,1)}.hud-more-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.hud-more-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:12px 4px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);border-radius:10px;color:var(--text-primary);font-family:inherit;cursor:pointer;transition:all .15s;position:relative}.hud-more-item:hover:not(.locked){background:#6366f114;border-color:#6366f133}.hud-more-item:active:not(.locked){transform:scale(.95)}.hud-more-item.locked{opacity:.35;cursor:not-allowed}.hud-more-item.danger{border-color:#ef444426}.hud-more-item.danger .hud-more-label{color:#ef4444}.hud-more-icon{font-size:22px;line-height:1}.hud-more-label{font-size:11px;color:var(--text-secondary);white-space:nowrap}.hud-more-badge{position:absolute;top:4px;right:4px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;border-radius:8px;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif}.hud-quest-chip{display:flex;align-items:center;gap:8px;padding:6px 12px;background:#0a0a14b3;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.08);border-radius:10px;font-size:12px;color:var(--text-secondary)}.hud-quest-chip-icon{font-size:14px}.hud-quest-chip-count{font-family:Outfit,sans-serif;font-weight:600;color:var(--accent-primary)}.hub-page{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;background:linear-gradient(to bottom,transparent 0%,transparent 50%,var(--bg-primary) 65%);position:relative;z-index:2;overflow-y:auto;-webkit-overflow-scrolling:touch}.hub-hero-overlay{position:relative;z-index:2;margin-top:-80px;padding:0 12px;pointer-events:none}.hub-hero-overlay .hub-stat-card{pointer-events:auto}.hub-hero,.hub-hero-bg,.hub-hero-gradient{display:none}.hub-stat-card{position:relative;background:#0f0f1ebf;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.08);border-radius:16px;padding:14px 16px;z-index:2}.hub-stat-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.hub-stat-name-row{display:flex;align-items:center;gap:10px}.hub-stat-emoji{font-size:28px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#6366f126;border-radius:50%;border:2px solid rgba(99,102,241,.25);flex-shrink:0}.hub-stat-name{font-size:16px;font-weight:700;color:#f0f0f5}.hub-stat-class{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.hub-sp-badge{background:#fbbf24;color:#000;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:700}.hub-gold{display:flex;align-items:center;gap:4px;padding:4px 10px;background:#f59e0b1f;border-radius:8px;border:1px solid rgba(245,158,11,.2)}.hub-gold-icon{font-size:14px}.hub-gold-value{font-family:Outfit,sans-serif;font-size:14px;font-weight:700;color:#fbbf24}.hub-bar-group{margin-bottom:6px}.hub-bar-group:last-of-type{margin-bottom:8px}.hub-bar-label{display:flex;justify-content:space-between;font-size:11px;color:var(--text-secondary);margin-bottom:3px}.hub-bar-label .font-number{font-size:10px}.hub-bar{height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.hub-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.hub-bar-hp{background:linear-gradient(90deg,#22c55e,#16a34a)}.hub-bar-xp{background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.hub-stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#ffffff0a;border-radius:8px;overflow:hidden}.hub-stat-item{text-align:center;padding:6px}.hub-stat-item+.hub-stat-item{border-left:1px solid rgba(255,255,255,.06)}.hub-stat-item-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.hub-stat-item-value{font-family:Outfit,sans-serif;font-size:18px;font-weight:700}.hub-stat-atk{color:#ef4444}.hub-stat-def{color:#3b82f6}.hub-content{flex:1;padding:0 12px 16px}.hub-cta-area{margin-bottom:16px}.hub-cta{width:100%;height:56px;display:flex;align-items:center;justify-content:center;gap:10px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border:1px solid rgba(59,130,246,.5);border-radius:14px;color:#fff;font-size:18px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 0 20px #3b82f64d;animation:ctaPulse 2.5s ease-in-out infinite;transition:transform .15s}.hub-cta:active{transform:scale(.97)}.hub-cta-icon{font-size:22px}@keyframes ctaPulse{0%,to{box-shadow:0 0 20px #3b82f64d}50%{box-shadow:0 0 32px #3b82f68c}}.hub-resume-card{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:12px;margin-bottom:10px;cursor:pointer;color:var(--text-primary);font-family:inherit;text-align:left;transition:background .2s}.hub-resume-card:active{background:#f59e0b26}.hub-resume-floor{font-family:Outfit,sans-serif;font-size:22px;font-weight:800;color:#fbbf24;width:44px;text-align:center;flex-shrink:0}.hub-resume-info{flex:1;min-width:0}.hub-resume-name{font-size:14px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hub-resume-sub{font-size:11px;color:var(--text-muted)}.hub-resume-arrow{color:#fbbf24;font-size:16px;flex-shrink:0}.hub-class-advance-btn{width:100%;padding:12px;background:linear-gradient(135deg,#22c55e,#16a34a);border:1px solid rgba(34,197,94,.4);border-radius:12px;color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;margin-bottom:14px;transition:transform .15s}.hub-class-advance-btn:active{transform:scale(.97)}.hub-section{background:var(--bg-card);border-radius:14px;padding:12px 14px;margin-bottom:14px;border:1px solid rgba(255,255,255,.04)}.hub-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:14px;font-weight:600}.hub-section-count{font-size:12px;font-family:Outfit,sans-serif;color:var(--text-muted)}.hub-quest-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.04)}.hub-quest-row:last-child{border-bottom:none}.hub-quest-row.claimed{opacity:.5}.hub-quest-info{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.hub-quest-icon{font-size:14px;flex-shrink:0}.hub-quest-name{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hub-quest-claim{font-size:11px!important;padding:4px 10px!important;min-height:28px!important;flex-shrink:0}.hub-menu-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:16px}.hub-menu-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:10px 4px;background:#ffffff08;border:1px solid rgba(255,255,255,.05);border-radius:12px;color:var(--text-primary);font-family:inherit;cursor:pointer;transition:all .15s;position:relative}.hub-menu-item:active{transform:scale(.95);background:#6366f114}.hub-menu-item.locked{opacity:.4}.hub-menu-icon{font-size:22px;line-height:1}.hub-menu-label{font-size:10px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.hub-menu-badge{position:absolute;top:2px;right:2px;min-width:16px;height:16px;padding:0 4px;background:#ef4444;border-radius:8px;font-size:9px;font-weight:700;color:#fff;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif}.hub-menu-logout{border-color:#ef444426}.hub-menu-logout .hub-menu-label{color:#ef4444}.party-fab{position:fixed;bottom:80px;right:16px;width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#6366f1);border:2px solid rgba(255,255,255,.15);color:#fff;font-size:22px;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px #3b82f673;cursor:pointer;z-index:60;transition:transform .2s,box-shadow .2s;font-family:inherit}.party-fab:active{transform:scale(.9)}.party-fab-badge{position:absolute;top:-2px;right:-2px;min-width:20px;height:20px;padding:0 5px;background:#ef4444;border:2px solid var(--bg-primary);border-radius:10px;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif}.party-drawer-overlay{position:fixed;inset:0;background:#0000;z-index:100;pointer-events:none;transition:background .3s}.party-drawer-overlay.open{background:#0000008c;pointer-events:auto}.party-drawer{position:absolute;bottom:0;left:0;right:0;max-width:480px;margin:0 auto;background:#0c0f1cfa;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid rgba(99,102,241,.25);border-radius:20px 20px 0 0;padding:8px 16px calc(20px + env(safe-area-inset-bottom));transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);max-height:65vh;overflow-y:auto}.party-drawer-overlay.open .party-drawer{transform:translateY(0)}.drawer-handle{width:36px;height:4px;background:#ffffff2e;border-radius:2px;margin:0 auto 12px}.drawer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.drawer-title{font-size:15px;font-weight:700;letter-spacing:.5px;color:var(--text-primary)}.drawer-close{width:32px;height:32px;border-radius:50%;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}.drawer-close:active{background:#ffffff1f}.drawer-body{display:flex;flex-direction:column;gap:0}.party-row{display:flex;align-items:center;gap:12px;padding:12px;background:#1e293b80;border-radius:12px;margin-bottom:8px;border:1px solid rgba(71,85,105,.2);transition:background .15s}.party-row:last-of-type{margin-bottom:0}.party-avatar{width:40px;height:40px;border-radius:50%;background:#6366f11f;display:flex;align-items:center;justify-content:center;font-size:20px;border:2px solid rgba(99,102,241,.2);flex-shrink:0}.party-info{flex:1;min-width:0}.party-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary)}.party-level{font-size:11px;color:var(--text-muted);font-weight:400;margin-left:4px}.party-hp-bar{height:5px;background:#ffffff14;border-radius:3px;margin-top:4px;overflow:hidden}.party-hp-fill{height:100%;background:linear-gradient(90deg,#22c55e,#16a34a);border-radius:3px;transition:width .3s}.party-leader{font-size:18px;flex-shrink:0}.party-remove{width:28px;height:28px;border-radius:50%;background:#ef44441f;border:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:16px;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:background .15s}.party-remove:active{background:#ef444440}.party-add-slot{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;background:transparent;border:2px dashed rgba(99,102,241,.2);border-radius:12px;color:#6366f199;font-size:14px;font-family:inherit;cursor:pointer;width:100%;margin-top:8px;transition:border-color .2s,color .2s}.party-add-slot:active{border-color:#6366f180;color:#6366f1e6}@media(min-width:481px){.hub-menu-grid{grid-template-columns:repeat(5,1fr)}}@media(min-width:601px){#root{max-width:600px}}@media(min-width:769px){#root{max-width:768px}.page{padding:var(--spacing-lg)}.hub-hero-overlay{padding:0 16px}.hub-menu-grid{grid-template-columns:repeat(6,1fr);gap:14px}.hub-stat-card{padding:18px 24px}.dungeon-info-card{padding:var(--spacing-md) var(--spacing-lg)}.tooltip{width:220px}.party-drawer{max-width:600px}}@media(min-width:961px){#root{max-width:960px}.hub-menu-grid{grid-template-columns:repeat(8,1fr);gap:16px}.hub-hero-overlay{padding:0 20px}.hub-stat-card{border-radius:20px}.party-drawer{max-width:700px}}.hub-stat-card{backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.party-drawer{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}canvas{image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){canvas{image-rendering:auto}}@media(min-width:481px){body{background:#06060a}#root{border-left:1px solid rgba(99,102,241,.08);border-right:1px solid rgba(99,102,241,.08);box-shadow:0 0 60px #6366f10a}}.merc-panel-overlay{position:fixed;inset:0;z-index:10001;background:#0009;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .15s ease-out}.merc-panel{width:100%;max-width:480px;max-height:80vh;background:#0c0f1cfa;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(99,102,241,.25);border-radius:20px 20px 0 0;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.merc-panel-header{display:flex;align-items:center;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.06);gap:10px}.merc-panel-title{font-weight:700;font-size:16px;color:var(--text-primary);flex:1}.merc-panel-gold{font-size:13px;font-weight:600;color:#f59e0b;background:#f59e0b1a;padding:4px 10px;border-radius:20px;border:1px solid rgba(245,158,11,.2)}.merc-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,.06)}.merc-tab{flex:1;padding:10px 0;background:none;border:none;border-bottom:2px solid transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:color .2s,border-color .2s;display:flex;align-items:center;justify-content:center;gap:6px}.merc-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.merc-tab:hover:not(.active){color:var(--text-primary)}.merc-tab-badge{font-size:11px;background:var(--accent-primary);color:#fff;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center}.merc-panel-body{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:10px}.merc-loading,.merc-empty{text-align:center;padding:32px 16px;color:var(--text-muted);font-size:14px;line-height:1.6}.merc-card{background:#ffffff08;border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px 14px;display:flex;flex-direction:column;gap:8px;transition:border-color .2s,background .2s}.merc-card:hover{background:#ffffff0d}.merc-card-top{display:flex;align-items:center;gap:10px}.merc-card-icon{font-size:28px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;background:#ffffff0a;border-radius:12px;flex-shrink:0}.merc-card-info{display:flex;flex-direction:column;gap:2px}.merc-card-name{font-weight:700;font-size:15px}.merc-card-rarity{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.merc-card-stats{display:flex;gap:12px;font-size:13px;color:var(--text-secondary);padding:4px 0}.merc-card-desc{font-size:12px;color:var(--text-muted);line-height:1.5;padding:2px 0}.merc-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:4px}.merc-card-duration{font-size:12px;color:var(--text-muted)}.merc-buy-btn,.merc-activate-btn{padding:7px 16px!important;font-size:13px!important;border-radius:10px!important;min-width:0}.merc-buy-btn.disabled{opacity:.4;cursor:not-allowed}.merc-activate-btn{background:linear-gradient(135deg,#6366f1,#8b5cf6)!important;border:none!important;color:#fff!important}.merc-activate-btn:hover:not(:disabled){filter:brightness(1.1)}.merc-ticket{border-style:dashed}@media(min-width:769px){.merc-panel{max-width:560px;border-radius:20px;margin-bottom:40px;max-height:70vh;border:1px solid rgba(99,102,241,.2)}.merc-panel-overlay{align-items:center}}.landscape-guard{position:fixed;inset:0;z-index:99999;background:#0a0a1a;display:flex;align-items:center;justify-content:center;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)}.landscape-guard__content{display:flex;flex-direction:column;align-items:center;gap:24px;text-align:center;padding:32px;max-width:320px}.landscape-guard__icon{font-size:64px;animation:lg-bounce 2s ease-in-out infinite}.landscape-guard__title{font-size:22px;font-weight:700;color:#f0f0f5;line-height:1.3}.landscape-guard__subtitle{font-size:14px;color:#a0a0b0;line-height:1.6}.landscape-guard__hint{margin-top:16px;position:relative;width:60px;height:100px}.landscape-guard__phone-anim{display:block;width:40px;height:70px;border:3px solid #6366f1;border-radius:8px;position:absolute;top:50%;left:50%;transform-origin:center center;animation:lg-rotate 2.5s ease-in-out infinite}.landscape-guard__phone-anim:after{content:"";display:block;width:12px;height:3px;background:#6366f1;border-radius:2px;position:absolute;bottom:6px;left:50%;transform:translate(-50%)}@keyframes lg-rotate{0%,20%{transform:translate(-50%,-50%) rotate(0);border-color:#6366f1}50%,70%{transform:translate(-50%,-50%) rotate(-90deg);border-color:#22c55e}to{transform:translate(-50%,-50%) rotate(0);border-color:#6366f1}}@keyframes lg-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.orientation-hint{position:fixed;top:max(env(safe-area-inset-top,12px),12px);left:50%;transform:translate(-50%);z-index:99999;display:flex;align-items:center;gap:10px;padding:10px 18px;background:#10101eeb;border:1px solid rgba(99,102,241,.4);border-radius:12px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);box-shadow:0 4px 20px #00000080;cursor:pointer;animation:oh-slideIn .4s ease-out;user-select:none;-webkit-user-select:none}.orientation-hint__icon{font-size:20px;flex-shrink:0}.orientation-hint__text{font-size:13px;color:#e0e0f0;white-space:nowrap}.orientation-hint__close{font-size:14px;color:#808090;margin-left:4px;flex-shrink:0}@keyframes oh-slideIn{0%{opacity:0;transform:translate(-50%) translateY(-20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.lobby-field{position:relative;width:100%;height:56vh;min-height:320px;max-height:500px;overflow:hidden;flex-shrink:0;cursor:default;user-select:none;-webkit-user-select:none;background:transparent;z-index:1}.lobby-field-bg,.lobby-field-fog,.lobby-field-ground,.lobby-particles{display:none}@keyframes lobbyParticleFloat{0%{transform:translateY(0) translate(0);opacity:0}10%{opacity:.6}90%{opacity:.3}to{transform:translateY(-300px) translate(20px);opacity:0}}.lobby-party-badge{position:absolute;top:12px;right:12px;padding:4px 12px;background:#0f0f1ebf;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:20px;font-size:13px;font-weight:600;color:#e5e7eb;z-index:20}.lobby-entity{position:absolute;display:flex;flex-direction:column;align-items:center;cursor:pointer;transition:filter .2s;animation:lobbyIdle 3s ease-in-out infinite}.lobby-entity:hover{filter:brightness(1.15)}.lobby-entity.selected{filter:brightness(1.2) drop-shadow(0 0 12px rgba(99,102,241,.5))}@keyframes lobbyIdle{0%,to{transform:translate(-50%) translateY(0) scale(var(--entity-scale, 1))}50%{transform:translate(-50%) translateY(-4px) scale(var(--entity-scale, 1))}}.lobby-entity-crown{font-size:18px;margin-bottom:-4px;filter:drop-shadow(0 2px 4px rgba(0,0,0,.5));animation:crownBob 2s ease-in-out infinite;z-index:2}@keyframes crownBob{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.lobby-entity-sprite-wrap,.lobby-entity-shadow{display:none}.lobby-entity-nameplate{display:flex;align-items:center;gap:4px;margin-top:4px;padding:2px 8px;background:#0009;border-radius:10px;white-space:nowrap}.lobby-entity-name{font-size:11px;font-weight:600;color:#e5e7eb;max-width:70px;overflow:hidden;text-overflow:ellipsis}.lobby-entity-level{font-size:10px;font-weight:700;color:#fbbf24;font-family:Outfit,sans-serif}.lobby-entity-hp-track{width:60px;height:4px;margin-top:3px;background:#ffffff1a;border-radius:2px;overflow:hidden}.lobby-entity-hp-fill{height:100%;border-radius:2px;transition:width .4s ease}.lobby-entity.leader .lobby-entity-sprite-wrap{filter:drop-shadow(0 0 8px rgba(251,191,36,.25))}.lobby-empty-slot{position:absolute;display:flex;flex-direction:column;align-items:center;transform:translate(-50%);opacity:.3;transition:opacity .2s;pointer-events:none}.lobby-empty-circle{width:60px;height:80px;border:2px dashed rgba(255,255,255,.15);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff3}.lobby-info-panel{position:absolute;bottom:12px;left:12px;right:12px;background:#0f0f23d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:14px 16px;z-index:30;animation:lobbyPanelSlideUp .25s cubic-bezier(.16,1,.3,1)}@keyframes lobbyPanelSlideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.lobby-info-header{display:flex;align-items:center;gap:10px;margin-bottom:10px}.lobby-info-avatar{font-size:28px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#6366f126;border-radius:50%;border:2px solid rgba(99,102,241,.3);flex-shrink:0}.lobby-info-meta{flex:1;min-width:0}.lobby-info-name{font-size:16px;font-weight:700;color:#f0f0f5}.lobby-info-class{font-size:12px;color:var(--text-secondary);display:flex;align-items:center;gap:6px}.lobby-info-you{background:#3b82f6;color:#fff;padding:1px 6px;border-radius:4px;font-size:9px;font-weight:700;letter-spacing:.5px}.lobby-info-close{width:28px;height:28px;border-radius:50%;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#9ca3af;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-family:inherit}.lobby-info-close:active{background:#ffffff1a}.lobby-info-bars{margin-bottom:8px}.lobby-info-bar-row{display:flex;align-items:center;gap:8px}.lobby-info-bar-label{font-size:10px;font-weight:700;color:var(--text-muted);width:24px;flex-shrink:0}.lobby-info-bar-track{flex:1;height:6px;background:#ffffff14;border-radius:3px;overflow:hidden}.lobby-info-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.lobby-info-bar-fill.hp{background:linear-gradient(90deg,#22c55e,#16a34a)}.lobby-info-bar-value{font-size:10px;font-family:Outfit,sans-serif;font-weight:600;color:var(--text-secondary);width:56px;text-align:right;flex-shrink:0}.lobby-info-type{font-size:11px;color:var(--text-muted)}@media(min-width:640px)and (orientation:landscape){.lobby-field{height:60vh;max-height:500px}.lobby-entity-sprite-wrap{width:120px;height:168px}.lobby-entity-shadow{width:85px;height:14px}.lobby-info-panel{left:20%;right:20%}}@supports (padding: env(safe-area-inset-top)){.lobby-party-badge{top:calc(12px + env(safe-area-inset-top))}}@keyframes overlayFadeIn{0%{opacity:0}to{opacity:1}}@keyframes overlaySlideUp{0%{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.overlay-shell{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);animation:overlayFadeIn .2s ease-out}.overlay-panel{position:relative;width:92%;max-width:900px;height:88%;max-height:600px;background:var(--bg-primary);border:1px solid rgba(255,255,255,.08);border-radius:var(--radius-lg);box-shadow:0 16px 48px #00000080;overflow:hidden;display:flex;flex-direction:column;animation:overlaySlideUp .25s cubic-bezier(.16,1,.3,1)}.overlay-panel>.page,.overlay-panel>.page-transition>.page{min-height:0;flex:1;overflow-y:auto;background:transparent}.overlay-close-btn{position:absolute;top:8px;right:12px;z-index:10;width:32px;height:32px;border:none;border-radius:50%;background:#ffffff14;color:var(--text-secondary);font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.overlay-close-btn:hover{background:#ffffff26;color:var(--text-primary)}@media(min-aspect-ratio:4/3){.overlay-panel{width:70%;max-width:1000px;height:90%;max-height:680px}}.overlay-panel .page{padding-bottom:12px!important}.overlay-panel .btn-secondary.btn-block:last-child{display:none}.overlay-panel .page-transition{flex:1;min-height:0;display:flex;flex-direction:column}@media(min-aspect-ratio:4/3){.overlay-panel .page{padding:10px 16px!important;gap:8px!important}}.overlay-panel .card{margin-bottom:0}.overlay-panel .page-header{padding:4px 0}.overlay-panel .page-title,.overlay-panel h1{font-size:16px}.portrait-blocker{display:none;position:fixed;inset:0;z-index:99999;background:var(--bg-primary);flex-direction:column;align-items:center;justify-content:center;gap:24px;color:var(--text-primary);text-align:center;padding:32px}.portrait-blocker-icon{font-size:64px;animation:rotateHint 2s ease-in-out infinite}.portrait-blocker-title{font-size:20px;font-weight:700;color:var(--accent-warning)}.portrait-blocker-desc{font-size:14px;color:var(--text-secondary);max-width:280px;line-height:1.5}@keyframes rotateHint{0%,to{transform:rotate(0)}25%{transform:rotate(-30deg)}75%{transform:rotate(30deg)}}@media(orientation:portrait)and (max-width:900px){.portrait-blocker{display:flex}}
