.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;background:linear-gradient(135deg,#ff6b35,#4ecdc4)}.avatar-small{width:32px;height:32px;font-size:12px}.avatar-medium{width:40px;height:40px;font-size:14px}.avatar-large{width:64px;height:64px;font-size:24px}.avatar-image{width:100%;height:100%;object-fit:cover}.avatar-initials{color:#fff;font-weight:700;text-transform:uppercase}.lobby-page{padding:var(--spacing-md);min-height:100vh}.lobby-header{text-align:center;padding:var(--spacing-xl) 0}.lobby-header h1{font-size:var(--font-size-xxl);font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--spacing-sm)}.lobby-header p{color:var(--text-secondary)}.lobby-error{background:#ff475733;border:1px solid var(--accent-danger);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-md);color:var(--accent-danger);text-align:center}.lobby-section{margin-bottom:var(--spacing-xl)}.lobby-section h2{font-size:var(--font-size-lg);margin-bottom:var(--spacing-md);color:var(--text-secondary)}.create-match-btn{width:100%;padding:var(--spacing-md);font-size:var(--font-size-lg)}.lobby-loading{display:flex;justify-content:center;padding:var(--spacing-xl)}.lobby-empty{text-align:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg)}.lobby-empty p{color:var(--text-secondary)}.lobby-empty-hint{font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.match-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.match-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-md)}.match-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.match-status{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:600;text-transform:uppercase}.match-status.open{background:#4ecdc433;color:var(--accent-secondary)}.match-status.shop_phase{background:#ffd70033;color:var(--accent-gold)}.match-status.battle_phase{background:#ff6b3533;color:var(--accent-primary)}.match-status.completed{background:#2ed57333;color:var(--accent-success)}.match-timer{font-size:var(--font-size-sm);color:var(--text-secondary);font-variant-numeric:tabular-nums}.match-participants{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.participant{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-highlight);border-radius:var(--radius-sm)}.participant.waiting{color:var(--text-muted);font-style:italic}.participant-name{font-weight:500}.ready-badge{font-size:var(--font-size-xs);padding:2px 6px;background:var(--accent-success);color:#fff;border-radius:var(--radius-sm)}.match-actions{display:flex;gap:var(--spacing-sm)}.match-actions .btn{flex:1}.shop-page{min-height:100vh;padding-bottom:var(--spacing-xl)}.shop-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:10}.back-btn{padding:var(--spacing-xs) var(--spacing-sm)}.shop-loading{display:flex;justify-content:center;align-items:center;min-height:50vh}.shop-error-banner{background:#ff475733;border-bottom:1px solid var(--accent-danger);padding:var(--spacing-sm) var(--spacing-md);color:var(--accent-danger);text-align:center;font-size:var(--font-size-sm)}.shop-waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;min-height:50vh;gap:var(--spacing-md)}.shop-waiting h2{color:var(--accent-success)}.shop-waiting p{color:var(--text-secondary)}.shop-section{padding:var(--spacing-md)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.section-header h2{font-size:var(--font-size-lg);color:var(--text-secondary)}.reroll-btn{font-size:var(--font-size-sm)}.shop-cards{display:grid;grid-template-columns:1fr;gap:var(--spacing-lg);padding:0 var(--spacing-xs)}.shop-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:var(--spacing-md);display:flex;flex-direction:column;gap:var(--spacing-md);transition:all .2s}.shop-card.purchased{opacity:.5}.shop-card-image-container{position:relative;aspect-ratio:2/3;width:100%;overflow:hidden;border-radius:var(--radius-md);background:var(--bg-highlight)}.shop-card-image-container img{width:100%;height:100%;object-fit:cover;display:block}.shop-card-skeleton{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(90deg,var(--bg-highlight) 25%,var(--bg-secondary) 50%,var(--bg-highlight) 75%);background-size:200% 100%;animation:shimmer-effect 1.5s infinite}@keyframes shimmer-effect{0%{background-position:200% 0}to{background-position:-200% 0}}.shop-card-avatar{width:100%;aspect-ratio:2/3;border-radius:var(--radius-md);overflow:hidden;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;border:2px solid var(--accent-primary)}.shop-card-avatar img{width:100%;height:100%;object-fit:cover}.shop-card-avatar-fallback{font-size:64px;font-weight:700;color:var(--text-muted)}.shop-card-footer{display:flex;flex-direction:column;gap:var(--spacing-sm)}.shop-card-name{font-weight:600;font-size:20px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shop-card-stats-row{display:flex;justify-content:center;gap:8px;font-size:16px}.buy-btn{width:100%;padding:var(--spacing-md);font-size:18px;margin-top:auto}.purchased-badge{text-align:center;padding:var(--spacing-xs);background:var(--bg-highlight);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--text-muted)}.team-slots{display:flex;gap:var(--spacing-sm);overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;padding:0 var(--spacing-md) var(--spacing-md) var(--spacing-md);margin:0 calc(-1 * var(--spacing-md));scrollbar-width:thin;scrollbar-color:var(--accent-primary) var(--bg-secondary)}.team-slots::-webkit-scrollbar{height:10px}.team-slots::-webkit-scrollbar-track{background:var(--bg-secondary);border-radius:var(--radius-sm);margin:0 var(--spacing-md)}.team-slots::-webkit-scrollbar-thumb{background:var(--accent-primary);border-radius:var(--radius-sm);opacity:.7}.team-slots::-webkit-scrollbar-thumb:hover{background:var(--accent-primary);opacity:1}.team-slot-wrapper{flex:0 0 auto;width:min(140px,30vw);min-width:120px;display:flex;flex-direction:column;gap:var(--spacing-xs);scroll-snap-align:start}.slot-label{text-align:center;font-size:var(--font-size-xs);color:var(--text-muted);text-transform:uppercase;font-weight:600}.empty-slot{background:var(--bg-card);border:2px dashed var(--border-color);border-radius:var(--radius-md);min-height:180px;height:100%;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:var(--font-size-sm)}.team-card{background:var(--bg-card);border-radius:var(--radius-md);border:2px solid var(--accent-primary);padding:var(--spacing-sm);display:flex;flex-direction:column;gap:var(--spacing-xs);min-height:200px;height:100%;position:relative;touch-action:manipulation;-webkit-user-select:none;user-select:none;cursor:grab;-webkit-tap-highlight-color:transparent}.team-card:active{cursor:grabbing}.team-avatar{width:64px;height:64px;border-radius:50%;overflow:hidden;border:3px solid var(--accent-primary);box-shadow:0 0 16px #ff6b354d,inset 0 0 8px #0006;flex-shrink:0;margin:0 auto}.team-avatar img{width:100%;height:100%;object-fit:cover;display:block}.team-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-highlight) 0%,var(--bg-secondary) 100%);color:var(--text-secondary);font-size:24px;font-weight:700}.team-card-info{display:flex;flex-direction:column;gap:var(--spacing-xs);flex:1}.team-card-name{font-weight:600;font-size:14px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.team-card-stats-column{display:flex;flex-direction:column;gap:4px;align-items:stretch}.stat-badge-with-upgrade{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:700;gap:var(--spacing-xs)}.stat-content{display:flex;align-items:center;gap:4px;flex:1}.upgrade-count{margin-left:auto;color:var(--accent-success);font-weight:600}.stat-upgrade-btn{width:20px;height:20px;min-width:20px;min-height:20px;border-radius:50%;background:var(--accent-primary);opacity:.8;border:1px solid transparent;color:#fff;font-size:14px;font-weight:700;line-height:1;padding:0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.stat-upgrade-btn:hover{opacity:1;transform:scale(1.1)}.stat-upgrade-btn:active{transform:scale(.95)}.drag-hint{font-size:var(--font-size-xs);color:var(--text-muted);font-style:italic}.team-slots.dragging-active .team-slot-wrapper{transition:transform .2s ease}.team-slots.dragging-active .empty-slot{border-color:var(--accent-primary);background:#ff6b350d}.shop-actions{padding:var(--spacing-md);position:sticky;bottom:0;background:linear-gradient(transparent,var(--bg-primary) 20%);padding-top:var(--spacing-xl)}.submit-btn{width:100%;padding:var(--spacing-md);font-size:var(--font-size-lg)}.battle-card-v2{position:relative;display:flex;flex-direction:column;align-items:center;width:85px;padding:8px 6px;background:linear-gradient(145deg,#1a1a2ef2,#141e30e6,#11111bf2);border-radius:14px;border:2px solid rgba(255,255,255,.08);overflow:visible;transform-origin:center center}.battle-card-v2.active{border-color:transparent}.active-glow{position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:16px;background:linear-gradient(45deg,#e94560,#ff6b35,gold,#ff6b35,#e94560);background-size:300% 300%;animation:border-glow 2s ease infinite;z-index:-1;filter:blur(1px)}@keyframes border-glow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.battle-card-v2.dead{filter:grayscale(100%) brightness(.5);transform:scale(.9) rotate(-5deg)}.card-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;border:2px solid rgba(255,107,53,.6);box-shadow:0 0 12px #ff6b3540,inset 0 0 8px #0006;flex-shrink:0}.card-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2d2d44,#1a1a2e);color:var(--text-secondary);font-size:20px;font-weight:700}.card-name-v2{margin-top:6px;font-size:11px;font-weight:600;color:var(--text-primary);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;letter-spacing:.02em}.card-stats-v2{display:flex;justify-content:center;gap:4px;margin-top:4px}.stat-atk-v2{display:flex;align-items:center;gap:3px;padding:2px 8px;background:#ff6b6b26;border-radius:10px;border:1px solid rgba(255,107,107,.3)}.stat-icon{font-size:10px;color:#ff6b6b;filter:drop-shadow(0 0 2px rgba(255,107,107,.5))}.stat-value{font-size:12px;font-weight:700;color:#ff6b6b;text-shadow:0 0 4px rgba(255,107,107,.4)}.hp-bar-v2{width:100%;height:5px;background:#ffffff14;border-radius:3px;margin-top:6px;overflow:hidden;position:relative}.hp-fill-v2{height:100%;border-radius:3px;position:relative;box-shadow:0 0 6px #51cf6666}.damage-flash{position:absolute;top:0;right:0;bottom:0;left:0;background:#ff475780;border-radius:14px;pointer-events:none}.damage-number-v2{position:absolute;top:30%;left:50%;transform:translate(-50%);font-size:18px;font-weight:800;color:#ff4757;text-shadow:0 0 8px rgba(255,71,87,.8),0 2px 4px rgba(0,0,0,.5);pointer-events:none;z-index:10}.ko-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#000000b3;border-radius:14px;font-size:22px;font-weight:800;color:#e94560;text-shadow:0 0 12px #e94560,0 0 24px rgba(233,69,96,.5);letter-spacing:2px}.battle-card-v2.victorious{box-shadow:0 0 20px #ffd70066,0 0 40px #ffd70033}.battle-card-v2.victorious .card-avatar{border-color:gold;box-shadow:0 0 16px #ffd70080,inset 0 0 8px #0006}.battle-log{padding:var(--spacing-md);background:var(--bg-secondary);max-height:150px;overflow-y:auto;border-radius:var(--border-radius-sm)}.battle-log-live{max-height:150px}.battle-log-history{max-height:400px}.log-entry{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) 0;font-size:var(--font-size-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-color);animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.log-message{flex:1;word-break:break-word}.log-entry.align-left{text-align:left;justify-content:flex-start}.log-entry.align-right{text-align:right;justify-content:flex-end}.log-entry.align-center{text-align:center;justify-content:center}.health-bar-high{color:#51cf66}.health-bar-medium{color:#ffd43b}.health-bar-low{color:#ff6b6b}.log-entry-advance{color:#a0aec0;font-size:12px}.log-entry-advance .log-icon{color:#a0aec0}.log-entry-summary{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);padding:var(--spacing-sm);margin:var(--spacing-xs) 0;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:var(--spacing-sm);width:100%}.battle-log::-webkit-scrollbar{width:6px}.battle-log::-webkit-scrollbar-track{background:var(--bg-secondary)}.battle-log::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.battle-log::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}@media(max-width:768px){.battle-log{max-height:120px;font-size:var(--font-size-xs)}.log-entry{padding:var(--spacing-2xs) 0}.log-icon{font-size:12px}.log-entry-summary{padding:var(--spacing-xs);font-size:var(--font-size-xs)}}.battle-page{min-height:100vh;display:flex;flex-direction:column}.battle-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.battle-title{font-weight:600}.result-badge{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);font-weight:700;font-size:var(--font-size-sm)}.result-badge.win{background:#2ed57333;color:var(--accent-success)}.result-badge.loss{background:#ff475733;color:var(--accent-danger)}.result-badge.draw{background:#ffd43b33;color:var(--accent-gold)}.battle-loading,.battle-error,.battle-waiting{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--spacing-md);text-align:center;padding:var(--spacing-xl)}.battle-arena{display:flex;align-items:stretch;padding:var(--spacing-md);gap:var(--spacing-sm);flex:1;background:linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%)}.arena-team{flex:1;display:flex;flex-direction:column;gap:var(--spacing-sm)}.team-label{text-align:center;font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:600;text-transform:uppercase}.team-cards{display:flex;flex-direction:column;gap:var(--spacing-sm)}.arena-vs{width:60px;display:flex;align-items:center;justify-content:center;position:relative}.event-display{position:absolute;font-weight:800;font-size:var(--font-size-xl)}.damage-display{color:var(--accent-danger)}.death-display{color:var(--accent-primary)}.victory-display{color:var(--accent-gold)}.battle-card{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);padding:var(--spacing-sm);position:relative;transition:all .2s}.battle-card.active{border-color:var(--accent-primary);box-shadow:0 0 10px #ff6b354d}.battle-card.dead{filter:grayscale(1)}.battle-card-photo{width:100%;aspect-ratio:1.5;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-highlight);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-xs)}.battle-card-photo img{width:100%;height:100%;object-fit:cover}.battle-card-name{font-weight:600;font-size:var(--font-size-sm);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.battle-card-stats{display:flex;justify-content:center;gap:var(--spacing-sm);font-size:var(--font-size-xs);margin:var(--spacing-xs) 0}.stat-atk{color:var(--atk-color)}.stat-hp{color:var(--hp-color)}.hp-bar{height:4px;background:var(--bg-highlight);border-radius:2px;overflow:hidden}.hp-fill{height:100%;background:var(--hp-color);border-radius:2px}.damage-number{position:absolute;top:50%;left:50%;transform:translate(-50%);font-size:var(--font-size-lg);font-weight:800;color:var(--accent-danger);pointer-events:none}.battle-log{padding:var(--spacing-md);background:var(--bg-secondary);max-height:150px;overflow-y:auto}.log-entry{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) 0;font-size:var(--font-size-sm);color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.log-icon{flex-shrink:0;font-size:14px;width:16px;text-align:center}.log-message{flex:1}.log-entry-attack{color:var(--text-primary)}.log-entry-attack .log-icon{color:#ff6b6b}.log-entry-death{color:#f44;font-weight:600}.log-entry-death .log-icon{color:#f44}.log-entry-victory{color:#51cf66;font-weight:700}.log-entry-victory .log-icon{color:#51cf66}.log-entry-advance,.log-entry-advance .log-icon{color:#ffd43b}.battle-controls{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--bg-primary);border-top:1px solid var(--border-color)}.mute-btn{width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;background:var(--bg-highlight);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:20px;padding:0}.mute-btn:hover{background:var(--bg-card)}.icon-sound,.icon-muted{line-height:1}.play-btn{flex:2;font-size:20px;line-height:1}.skip-btn{flex:1;font-size:20px;line-height:1}.share-btn{flex:1}.event-display{position:absolute;font-weight:800;text-align:center}.event-attack .damage-value{font-size:24px;color:var(--accent-danger);text-shadow:0 0 10px rgba(255,71,87,.6),0 2px 4px rgba(0,0,0,.4)}.event-death .ko-text{font-size:28px;color:#e94560;text-shadow:0 0 15px #e94560,0 0 30px rgba(233,69,96,.4);letter-spacing:3px}.event-victory .victory-text{font-size:22px;text-shadow:0 2px 10px rgba(255,215,0,.4);filter:drop-shadow(0 0 8px rgba(255,215,0,.5))}.event-victory .victory-text.win{background:linear-gradient(135deg,#51cf66,#40c057,#51cf66);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.event-victory .victory-text.loss{background:linear-gradient(135deg,#ff6b6b,#f44,#ff6b6b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.event-victory .victory-text.draw{background:linear-gradient(135deg,#ffd43b,#fab005,#ffd43b);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.team-cards{display:flex;flex-direction:column;gap:8px;align-items:center}.leaderboard-page{padding:var(--spacing-md);padding-bottom:80px;min-height:100vh}.leaderboard-header{text-align:center;padding-bottom:var(--spacing-lg)}.leaderboard-header h1{font-size:var(--font-size-xl);font-weight:700;margin-bottom:var(--spacing-md);color:var(--text-primary)}.leaderboard-loading{display:flex;justify-content:center;padding:var(--spacing-xl)}.leaderboard-empty{text-align:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg)}.leaderboard-empty p{color:var(--text-secondary)}.leaderboard-empty-hint{font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.leaderboard-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.leaderboard-entry{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.leaderboard-entry:active{transform:scale(.98)}.leaderboard-entry.current-user{border-color:var(--accent-primary);background:#ff6b351a}.entry-rank{width:40px;text-align:center;flex-shrink:0}.rank-medal{font-size:24px}.rank-number{font-size:var(--font-size-md);font-weight:700;color:var(--text-muted)}.entry-info{flex:1;min-width:0}.entry-name{font-weight:600;font-size:var(--font-size-md);display:flex;align-items:center;gap:var(--spacing-xs);flex-wrap:wrap}.entry-username{font-weight:400;font-size:var(--font-size-sm);color:var(--text-muted)}.you-badge{font-size:var(--font-size-xs);padding:2px 6px;background:var(--accent-primary);color:#fff;border-radius:var(--radius-sm);font-weight:600}.entry-stats-container{display:flex;flex-direction:column;gap:4px;margin-top:var(--spacing-xs)}.entry-stats-row{display:flex;align-items:center;gap:var(--spacing-xs);font-size:13px}.entry-stats-row .stat-label{font-weight:500;color:var(--text-secondary);min-width:55px;font-size:12px}.entry-stats-row.casual .stat-label{color:var(--accent-info)}.entry-stats-row.ranked .stat-label{color:var(--accent-warning)}.stat-wins{color:var(--accent-success);font-weight:600}.stat-losses{color:var(--accent-danger);font-weight:600}.stat-winrate{color:var(--text-secondary);font-size:12px}.entry-arrow{color:var(--text-muted);font-size:20px;font-weight:300}.history-page{padding:var(--spacing-md);padding-bottom:80px;min-height:100vh}.history-header{text-align:center;padding-bottom:var(--spacing-lg)}.history-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.history-loading{display:flex;justify-content:center;padding:var(--spacing-xl)}.history-empty{text-align:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg)}.history-empty p{color:var(--text-secondary)}.history-empty-hint{font-size:var(--font-size-sm);margin-top:var(--spacing-sm)}.history-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.history-entry{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease;overflow:hidden}.history-entry:active{transform:scale(.98)}.history-entry.expanded{border-color:var(--accent-primary)}.entry-compact{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);gap:var(--spacing-md)}.players-section{display:flex;align-items:center;gap:var(--spacing-sm);flex:1;min-width:0}.player{display:flex;flex-direction:column;align-items:center;gap:2px}.player-name{font-size:10px;color:var(--text-muted);max-width:48px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vs-badge{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:600}.meta-section{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.result-badge{width:24px;height:24px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.result-win{background:#2ed57333;color:var(--accent-success)}.result-loss{background:#ff475733;color:var(--accent-danger)}.result-draw{background:#a0a0b033;color:var(--text-secondary)}.match-type{font-size:10px;font-weight:700;padding:2px 4px;border-radius:3px}.match-type.ranked{background:#ffd70033;color:var(--accent-gold)}.match-type.regular{background:#4ecdc433;color:var(--accent-secondary)}.match-date{font-size:var(--font-size-xs);color:var(--text-muted);min-width:48px;text-align:right}.battle-log-section{border-top:1px solid var(--border-color);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-secondary);animation:slideDown .2s ease}.battle-log-loading{display:flex;justify-content:center;padding:var(--spacing-sm)}.spinner-sm{width:20px;height:20px}.battle-log-empty{text-align:center;padding:var(--spacing-sm);color:var(--text-muted);font-size:var(--font-size-sm)}.load-more-btn{width:100%;margin-top:var(--spacing-md)}.nav-spacer{height:60px}.h2h-page{padding:var(--spacing-md);min-height:100vh}.h2h-header{display:flex;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-lg)}.back-btn{background:transparent;border:none;color:var(--accent-primary);font-size:var(--font-size-md);font-family:var(--font-family);cursor:pointer;padding:var(--spacing-sm);margin-left:calc(-1 * var(--spacing-sm))}.h2h-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.h2h-loading{display:flex;justify-content:center;padding:var(--spacing-xl)}.h2h-empty{text-align:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-secondary)}.h2h-summary{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.h2h-record{display:flex;align-items:center;justify-content:center;gap:var(--spacing-lg);margin-bottom:var(--spacing-lg)}.record-stat{display:flex;flex-direction:column;align-items:center}.record-value{font-size:48px;font-weight:800;line-height:1}.record-stat.wins .record-value{color:var(--accent-success)}.record-stat.losses .record-value{color:var(--accent-danger)}.record-label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--spacing-xs)}.record-divider{font-size:32px;font-weight:300;color:var(--text-muted)}.h2h-winrate{margin-bottom:var(--spacing-md)}.winrate-bar{height:8px;background:var(--bg-highlight);border-radius:4px;overflow:hidden;margin-bottom:var(--spacing-xs)}.winrate-fill{height:100%;background:linear-gradient(90deg,var(--accent-success),var(--accent-secondary));border-radius:4px;transition:width .5s ease}.winrate-text{font-size:var(--font-size-sm);color:var(--text-secondary);text-align:center;display:block}.h2h-last-match{text-align:center;font-size:var(--font-size-sm);color:var(--text-muted)}.h2h-recent{margin-top:var(--spacing-lg)}.h2h-recent h2{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-secondary)}.recent-match{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color)}.result-indicator{width:28px;height:28px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-sm)}.result-indicator.win{background:#2ed57333;color:var(--accent-success)}.result-indicator.loss{background:#ff475733;color:var(--accent-danger)}.result-indicator.draw{background:#a0a0b033;color:var(--text-secondary)}.match-type-badge{font-size:var(--font-size-xs);text-transform:uppercase;color:var(--text-muted);font-weight:600}.match-date{margin-left:auto;font-size:var(--font-size-sm);color:var(--text-muted)}.profile-page{padding:var(--spacing-md);min-height:100vh}.profile-header{display:flex;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-lg)}.profile-header h1{font-size:var(--font-size-xl);font-weight:700;color:var(--text-primary)}.profile-loading{display:flex;justify-content:center;padding:var(--spacing-xl)}.profile-empty{text-align:center;padding:var(--spacing-xl);background:var(--bg-secondary);border-radius:var(--radius-lg);color:var(--text-secondary)}.profile-empty-hint{margin-top:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--text-muted)}.profile-stats-cards{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.stats-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-md)}.stats-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.stats-card-label{font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px}.stats-card.ranked .stats-card-label{color:var(--accent-secondary)}.stats-card.casual .stats-card-label{color:var(--accent-primary)}.stats-card-rank{font-size:var(--font-size-lg);font-weight:800;color:var(--text-primary)}.stats-card-record{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.stats-card-record .wins{font-size:var(--font-size-xl);font-weight:700;color:var(--accent-success)}.stats-card-record .losses{font-size:var(--font-size-xl);font-weight:700;color:var(--accent-danger)}.stats-card-record .separator{font-size:var(--font-size-lg);color:var(--text-muted)}.stats-card-winrate{display:flex;align-items:center;gap:var(--spacing-sm)}.stats-card-winrate .winrate-bar{flex:1;height:6px;background:var(--bg-highlight);border-radius:3px;overflow:hidden}.stats-card-winrate .winrate-fill{height:100%;border-radius:3px;transition:width .5s ease}.stats-card-winrate .winrate-fill.ranked{background:linear-gradient(90deg,var(--accent-secondary),var(--accent-primary))}.stats-card-winrate .winrate-fill.casual{background:linear-gradient(90deg,var(--accent-primary),var(--accent-success))}.stats-card-winrate .winrate-text{font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);min-width:36px;text-align:right}.stats-card-tournaments{margin-top:var(--spacing-sm);font-size:var(--font-size-xs);color:var(--text-muted);text-align:center}.profile-streaks{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.streak-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) 0}.streak-item:not(:last-child){border-bottom:1px solid var(--border-color);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.streak-icon{font-size:var(--font-size-lg)}.streak-label{flex:1;font-size:var(--font-size-sm);color:var(--text-secondary)}.streak-value{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary)}.profile-recent{margin-top:var(--spacing-lg)}.profile-recent h2{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--spacing-md);color:var(--text-secondary)}.recent-list{display:flex;flex-direction:column;gap:var(--spacing-sm)}.recent-match-entry{background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color);cursor:pointer;transition:all .2s ease;overflow:hidden}.recent-match-entry:active{transform:scale(.98)}.recent-match-entry.expanded{border-color:var(--accent-primary)}.match-compact{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-xs) var(--spacing-sm);gap:var(--spacing-sm)}.match-players{display:flex;align-items:center;gap:var(--spacing-xs);flex:1;min-width:0}.match-player{display:flex;flex-direction:column;align-items:center;gap:1px}.match-player-name{font-size:9px;color:var(--text-muted);max-width:40px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-vs{font-size:10px;color:var(--text-muted);font-weight:600}.match-meta{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.match-result-badge{width:20px;height:20px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px}.match-result-badge.result-win{background:#2ed57333;color:var(--accent-success)}.match-result-badge.result-loss{background:#ff475733;color:var(--accent-danger)}.match-result-badge.result-draw{background:#a0a0b033;color:var(--text-secondary)}.match-type-badge{font-size:9px;font-weight:700;padding:1px 3px;border-radius:2px}.match-type-badge.ranked{background:#ffd70033;color:var(--accent-gold)}.match-type-badge.regular{background:#4ecdc433;color:var(--accent-secondary)}.match-date{font-size:10px;color:var(--text-muted);min-width:40px;text-align:right}.match-battle-log{border-top:1px solid var(--border-color);padding:var(--spacing-xs) var(--spacing-sm);background:var(--bg-secondary);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.battle-log-loading{display:flex;justify-content:center;padding:var(--spacing-xs)}.spinner-sm{width:16px;height:16px}.battle-log-header{font-size:10px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.battle-log,.battle-round{display:flex;flex-direction:column;gap:1px}.log-entry{display:flex;align-items:center;gap:var(--spacing-xs);padding:1px 0;font-size:10px}.log-icon{flex-shrink:0;width:14px;text-align:center}.log-message{color:var(--text-secondary);line-height:1.2}.log-attack .log-message{color:var(--text-primary)}.log-death .log-message{color:var(--accent-danger)}.log-victory .log-message{color:var(--accent-success);font-weight:600}.battle-log-empty{text-align:center;padding:var(--spacing-xs);color:var(--text-muted);font-size:10px}.navigation{display:flex;position:fixed;bottom:0;left:0;right:0;background:var(--bg-secondary);border-top:1px solid var(--border-color);padding:var(--spacing-xs) 0;padding-bottom:calc(var(--spacing-xs) + env(safe-area-inset-bottom,0px));z-index:100}.nav-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm) var(--spacing-xs);background:transparent;border:none;color:var(--text-muted);font-size:var(--font-size-xs);font-family:var(--font-family);cursor:pointer;transition:color .2s,transform .2s}.nav-tab:active{transform:scale(.95)}.nav-tab.active{color:var(--accent-primary)}.nav-tab-icon{font-size:20px;line-height:1}.nav-tab-label{font-weight:500}:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a24;--bg-highlight: #252532;--text-primary: #ffffff;--text-secondary: #a0a0b0;--text-muted: #606070;--accent-primary: #ff6b35;--accent-secondary: #4ecdc4;--accent-gold: #ffd700;--accent-danger: #ff4757;--accent-success: #2ed573;--atk-color: #ff6b6b;--def-color: #4dabf7;--hp-color: #51cf66;--border-color: #2a2a38;--shadow-color: rgba(0, 0, 0, .4);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 6px;--radius-md: 12px;--radius-lg: 16px;--radius-full: 50%;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-size-xs: 10px;--font-size-sm: 12px;--font-size-md: 14px;--font-size-lg: 18px;--font-size-xl: 24px;--font-size-xxl: 32px}*{margin:0;padding:0;box-sizing:border-box}html,body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes floatUp{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-30px)}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);border:none;font-family:var(--font-family);font-size:var(--font-size-md);font-weight:600;cursor:pointer;transition:all .2s ease;gap:var(--spacing-xs)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.btn-secondary{background:var(--bg-highlight);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-card)}.btn-success{background:var(--accent-success);color:#fff}.btn-danger{background:var(--accent-danger);color:#fff}.card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.stat-badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:2px 8px;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:700}.stat-atk{background:#ff6b6b33;color:var(--atk-color)}.stat-def{background:#4dabf733;color:var(--def-color)}.stat-hp{background:#51cf6633;color:var(--hp-color)}.coins{display:inline-flex;align-items:center;gap:var(--spacing-xs);color:var(--accent-gold);font-weight:700}.timer{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-xs) var(--spacing-sm);background:#ff475733;border-radius:var(--radius-sm);color:var(--accent-danger);font-weight:600;font-variant-numeric:tabular-nums}.timer.warning{animation:pulse 1s infinite}.spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.splash{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);gap:var(--spacing-lg)}.splash-title{font-size:var(--font-size-xxl);font-weight:800;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;gap:var(--spacing-md);background:var(--bg-primary)}.error-icon{font-size:64px;color:var(--accent-danger);animation:pulse 1.5s ease-in-out infinite}.error-message{color:var(--text-primary);font-size:var(--font-size-lg);max-width:300px;line-height:1.5}.tab-bar{display:flex;gap:var(--spacing-xs);padding:var(--spacing-sm);background:var(--bg-secondary);border-top:1px solid var(--border-color);position:fixed;bottom:0;left:0;right:0}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--spacing-sm);background:transparent;border:none;color:var(--text-muted);font-size:var(--font-size-xs);cursor:pointer;transition:color .2s}.tab-btn.active{color:var(--accent-primary)}.tab-btn-icon{font-size:20px}.error-boundary-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;gap:var(--spacing-md);background:var(--bg-primary);opacity:1!important;visibility:visible!important}.error-boundary-fallback .fallback-icon{font-size:64px;animation:pulse 1.5s ease-in-out infinite}.error-boundary-fallback .fallback-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:700}.error-boundary-fallback .fallback-message{color:var(--text-secondary);font-size:var(--font-size-md);max-width:300px;line-height:1.5}.invalid-state-fallback{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;gap:var(--spacing-md);background:var(--bg-primary);opacity:1!important;visibility:visible!important}.invalid-state-fallback .fallback-icon{font-size:64px;animation:pulse 1.5s ease-in-out infinite}.invalid-state-fallback .fallback-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:700}.invalid-state-fallback .fallback-message{color:var(--text-secondary);font-size:var(--font-size-md);max-width:300px;line-height:1.5}.error-display{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:var(--spacing-lg);text-align:center;gap:var(--spacing-md);background:var(--bg-primary);opacity:1!important;visibility:visible!important}.error-display-icon{font-size:64px;animation:pulse 1.5s ease-in-out infinite}.error-display-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:700}.error-display-message{color:var(--text-secondary);font-size:var(--font-size-md);max-width:300px;line-height:1.5}.error-display-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-md);flex-wrap:wrap;justify-content:center}.error-display-actions .btn{min-width:120px}
