:root{--bg: #0a0a12;--bg-card: #141422;--bg-hover: #1a1a2e;--text: #e8e8f0;--text-muted: #8888aa;--primary: #7c3aed;--primary-hover: #6d28d9;--accent: #22c55e;--danger: #ef4444;--warning: #f59e0b;--border: #2a2a3e;--radius: 8px;--navbar-height: 60px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}.app{min-height:100vh}.navbar{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--bg-card);border-bottom:1px solid var(--border)}.nav-brand{font-size:1.4rem;font-weight:700;color:var(--text);display:flex;align-items:center;gap:.5rem}.brand-icon{font-size:1.8rem}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-links a{color:var(--text-muted);font-weight:500}.nav-links a:hover{color:var(--text);text-decoration:none}.nav-profile{display:flex;align-items:center;gap:.5rem}.nav-avatar{width:28px;height:28px;border-radius:50%}.nav-auth{display:flex;gap:.5rem}.nav-play-btn{background:var(--accent);color:#000;font-weight:900;font-size:.95rem;letter-spacing:2px;text-transform:uppercase;padding:.5rem 1.5rem;border-radius:var(--radius);border:none;cursor:pointer;font-family:inherit;text-decoration:none;animation:playGlow 2s ease-in-out infinite;transition:transform .15s,box-shadow .15s}.nav-play-btn:hover{transform:scale(1.08);text-decoration:none;box-shadow:0 0 24px #22c55e99}@keyframes playGlow{0%,to{box-shadow:0 0 8px #22c55e4d}50%{box-shadow:0 0 20px #22c55e80}}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.6rem 1.2rem;border:none;border-radius:var(--radius);font-weight:600;cursor:pointer;transition:all .15s;font-size:.9rem}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--bg-hover);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.btn-small{padding:.3rem .8rem;font-size:.8rem}.btn-large{padding:.8rem 2rem;font-size:1.1rem}.btn-oauth{background:var(--bg-hover);color:var(--text);border:1px solid var(--border);font-size:.8rem;padding:.4rem .8rem}.btn-play{background:var(--accent);color:#000;font-size:2.5rem;padding:1.5rem 4rem;border-radius:16px;font-weight:900;letter-spacing:4px;box-shadow:0 0 40px #22c55e4d;transition:all .2s}.btn-play:hover{transform:scale(1.05);box-shadow:0 0 60px #22c55e80}.page{max-width:1200px;margin:0 auto;padding:2rem}.page h1{margin-bottom:1.5rem;font-size:2rem}.home-hero{position:relative;min-height:70vh;display:flex;align-items:center;justify-content:center;background:url(/images/hero-bg.png) center/cover no-repeat;overflow:hidden}.home-hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0a0a1280,#0a0a12d9)}.home-hero-content{position:relative;text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem;padding:2rem}.home-logo{max-width:500px;width:80vw;height:auto}.home-tagline{color:var(--text-muted);font-size:1.4rem;letter-spacing:3px;text-transform:uppercase;margin-bottom:1rem}.home-section{max-width:1100px;margin:0 auto;padding:3rem 2rem}.section-title{font-size:1.8rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.screenshot-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}.screenshot-img{width:100%;border-radius:var(--radius);border:1px solid var(--border);transition:transform .2s}.screenshot-img:hover{transform:scale(1.03)}.home-features{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;text-align:center}.feature-card h3{margin:1rem 0 .5rem;font-size:1.15rem}.feature-card p{color:var(--text-muted);font-size:.9rem;line-height:1.6}.feature-img{max-width:80%;max-height:60px;object-fit:contain}.home-arcade{text-align:center}.arcade-text{color:var(--text-muted);font-size:1.05rem;line-height:1.7;max-width:700px;margin:0 auto}.home-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:2rem}.info-row{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:1.5rem}.info-block{text-align:center}.info-label{display:block;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;font-weight:600;margin-bottom:.3rem}.info-value{display:block;font-weight:600}.tag-row{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.tag-pill{background:var(--bg-hover);border:1px solid var(--border);border-radius:20px;padding:.3rem .9rem;font-size:.8rem;color:var(--text-muted)}.play-container{position:relative;width:100%;height:calc(100vh - var(--navbar-height));background:#000}.play-iframe{width:100%;height:100%;border:none;display:block}.play-loading{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;background:var(--bg);z-index:5}.play-fullscreen-btn{position:absolute;bottom:1rem;right:1rem;background:#00000080;border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:var(--radius);padding:.5rem;cursor:pointer;transition:background .15s;z-index:10;display:flex;align-items:center;justify-content:center}.play-fullscreen-btn:hover{background:#000c}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.lb-table{width:100%;border-collapse:collapse}.lb-table th,.lb-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}.lb-table th{color:var(--text-muted);font-weight:600;font-size:.85rem;text-transform:uppercase}.lb-table tr:hover{background:var(--bg-hover)}.rank{font-weight:700;color:var(--warning)}.rating{font-weight:700;color:var(--accent)}.player-link{display:flex;align-items:center;gap:.5rem;color:var(--text)}.lb-avatar{width:24px;height:24px;border-radius:50%}.pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem}.pagination button{cursor:pointer}.pagination button:disabled{opacity:.5;cursor:not-allowed}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:2rem}.profile-avatar{width:80px;height:80px;border-radius:50%}.username{color:var(--text-muted)}.rank-badge{color:var(--text-muted);font-size:.6em;font-weight:400}.member-badge{display:inline-block;padding:.2rem .6rem;background:var(--primary);border-radius:4px;font-size:.75rem;font-weight:600;margin-top:.3rem}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.stat{background:var(--bg-card);padding:1.5rem;border-radius:var(--radius);text-align:center;border:1px solid var(--border)}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--accent)}.stat-label{display:block;color:var(--text-muted);font-size:.85rem;margin-top:.3rem}.match-history{display:flex;flex-direction:column;gap:.5rem}.match-card{display:flex;align-items:center;gap:1.5rem;padding:.75rem 1rem;background:var(--bg-card);border-radius:var(--radius);border-left:3px solid;color:var(--text);text-decoration:none;transition:background .15s}.match-card:hover{background:var(--bg-hover);text-decoration:none}.match-card.win{border-color:var(--accent)}.match-card.loss{border-color:var(--danger)}.result{font-weight:700;width:40px}.match-card.win .result{color:var(--accent)}.match-card.loss .result{color:var(--danger)}.match-team-badge{font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;text-transform:uppercase}.match-team-badge.blue{background:#3b82f633;color:#60a5fa}.match-team-badge.orange{background:#f9731633;color:#fb923c}.rating-change{font-weight:600;width:50px}.duration,.date{color:var(--text-muted);font-size:.85rem}.match-detail-header{text-align:center;padding:2rem;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);margin-bottom:2rem}.match-detail-header.blue{border-top:3px solid #3b82f6}.match-detail-header.orange{border-top:3px solid #f97316}.match-detail-header h1{margin-bottom:.5rem;font-size:1.8rem}.match-detail-header.blue h1{color:#60a5fa}.match-detail-header.orange h1{color:#fb923c}.match-detail-score{font-size:3rem;font-weight:700;margin-bottom:.5rem}.score-blue{color:#60a5fa}.score-orange{color:#fb923c}.score-separator{color:var(--text-muted);margin:0 .75rem}.match-detail-meta{color:var(--text-muted);display:flex;justify-content:center;gap:1.5rem}.match-rounds{margin-bottom:2rem}.match-rounds h2{margin-bottom:1rem}.rounds-timeline{display:flex;flex-direction:column;gap:.5rem}.round-item{display:flex;align-items:center;gap:1rem;padding:.6rem 1rem;background:var(--bg-card);border-radius:var(--radius);border-left:3px solid}.round-item.blue{border-color:#3b82f6}.round-item.orange{border-color:#f97316}.round-number{font-weight:600;width:80px}.round-winner{font-weight:600;width:70px}.round-winner.blue{color:#60a5fa}.round-winner.orange{color:#fb923c}.round-wintype{color:var(--text-muted);font-size:.85rem}.match-teams{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.match-team{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem}.match-team.blue{border-top:3px solid #3b82f6}.match-team.orange{border-top:3px solid #f97316}.match-team h2{margin-bottom:1rem;font-size:1.2rem}.match-team.blue h2{color:#60a5fa}.match-team.orange h2{color:#fb923c}.team-players{display:flex;flex-direction:column;gap:.5rem}.team-player{display:flex;align-items:center;gap:.75rem;padding:.5rem;border-radius:var(--radius);color:var(--text);text-decoration:none;transition:background .15s}.team-player:hover{background:var(--bg-hover);text-decoration:none}.team-player-avatar{width:28px;height:28px;border-radius:50%}.team-player-name{flex:1;font-weight:500}.team-player-rating{font-weight:600;font-size:.9rem}.team-player-rating.positive{color:var(--accent)}.team-player-rating.negative{color:var(--danger)}.rarity{font-weight:600;font-size:.8rem;text-transform:uppercase}.collection-title{font-size:1.6rem;font-weight:700;margin-bottom:.25rem}.collection-subtitle{color:var(--text-muted);margin-bottom:1rem}.hat-search{width:100%;max-width:400px;padding:.6rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);font-size:.95rem;margin-bottom:1.5rem;outline:none;transition:border-color .15s}.hat-search:focus{border-color:var(--primary)}.hat-search::placeholder{color:var(--text-muted)}.hat-collection-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:1rem}.hat-collection-item{display:flex;flex-direction:column;align-items:center;gap:.4rem;padding:.75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:transform .15s,border-color .15s}.hat-collection-item:hover{transform:translateY(-2px);border-color:var(--primary)}.hat-collection-item img{width:64px;height:64px;object-fit:contain;image-rendering:pixelated}.hat-collection-item.locked img{filter:url(#hat-outline)}.hat-collection-item.unlocked img{filter:none}.hat-collection-item span{font-size:.75rem;color:var(--text-muted);text-align:center;line-height:1.2}.hat-detail-modal{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease-out}.hat-detail-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2rem;width:360px;max-width:90vw;text-align:center;position:relative;animation:popupIn .2s ease-out}.hat-detail-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1}.hat-detail-close:hover{color:var(--text)}.hat-detail-img{width:128px;height:128px;object-fit:contain;image-rendering:pixelated;margin-bottom:1rem}.hat-detail-img.locked{filter:url(#hat-outline)}.hat-detail-card h2{margin-bottom:.25rem;font-size:1.3rem}.hat-detail-desc{color:var(--text-muted);font-size:.9rem;margin:.75rem 0 1rem;line-height:1.5}.unlock-hint{color:var(--text-muted);font-size:.85rem;font-style:italic}.tournament-list{display:flex;flex-direction:column;gap:1rem}.tournament-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);padding:1.5rem}.tournament-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.status-badge{padding:.2rem .6rem;border-radius:4px;font-size:.75rem;font-weight:600;color:#fff}.tournament-info{color:var(--text-muted);font-size:.9rem}.tournament-info p{margin:.25rem 0}.tournament-actions{margin-top:1rem;display:flex;gap:.5rem}.tournament-bracket-page{max-width:none;padding:2rem;overflow-x:auto}.tournament-bracket-header{text-align:center;margin-bottom:2rem}.tournament-bracket-header h1{display:inline;margin-right:.75rem}.tournament-bracket-header p{color:var(--text-muted);margin-top:.5rem}.bracket-container{display:flex;align-items:stretch;min-height:480px;padding:.5rem 0}.bracket-round{display:flex;flex-direction:column;flex-shrink:0}.bracket-round-name{text-align:center;font-size:.75rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:1px;font-weight:600;padding-bottom:.75rem;white-space:nowrap}.bracket-round-matches{flex:1;display:flex;flex-direction:column;justify-content:space-around}.bracket-match{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:.5rem .6rem;margin:0 .25rem;width:210px;transition:border-color .15s}.bracket-match:hover{border-color:var(--primary)}.bracket-match-teams{display:flex;flex-direction:column;gap:1px}.bracket-team{display:flex;align-items:center;gap:.4rem;padding:.2rem .3rem;border-radius:3px;font-size:.8rem;color:var(--text-muted)}.bracket-team.winner{color:var(--text);font-weight:600}.bracket-team .seed{color:var(--text-muted);font-size:.7rem;width:18px;text-align:center;flex-shrink:0}.bracket-team .team-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.bracket-team .series-score{font-weight:700;width:14px;text-align:center;font-size:.85rem}.bracket-team.winner .series-score{color:var(--accent)}.bracket-match-status{text-align:center;font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;margin-top:.2rem}.bracket-games{margin-top:.4rem;padding-top:.4rem;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:.15rem}.bracket-game{font-size:.7rem;color:var(--text-muted);padding:.1rem .3rem;border-radius:3px;display:block}.bracket-game:hover{background:var(--bg-hover);text-decoration:none}.bracket-connectors{display:flex;flex-direction:column;width:40px;flex-shrink:0}.connector-pair{flex:1;position:relative}.connector-pair:before{content:"";position:absolute;left:0;right:50%;top:25%;bottom:25%;border-top:2px solid var(--border);border-bottom:2px solid var(--border);border-right:2px solid var(--border);border-top-right-radius:3px;border-bottom-right-radius:3px}.connector-pair:after{content:"";position:absolute;left:50%;right:0;top:50%;transform:translateY(-50%);height:2px;background:var(--border)}.bracket-teams-section{margin-top:3rem;max-width:900px}.bracket-teams-section h2{margin-bottom:1rem}.bracket-teams-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.bracket-team-card{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);font-size:.9rem}.bracket-team-card .seed{color:var(--text-muted);font-weight:600}.bracket-team-card .team-name{flex:1;font-weight:600}.bracket-team-card .rating{color:var(--accent);font-size:.8rem}.bracket-team-card .placement{font-size:.7rem;font-weight:600;padding:.15rem .5rem;border-radius:4px;background:var(--bg-hover);color:var(--warning)}.membership-card{background:var(--bg-card);border:2px solid var(--primary);border-radius:12px;padding:2rem;max-width:500px;text-align:center}.membership-card h2{font-size:2.5rem;color:var(--accent);margin-bottom:1rem}.perks{list-style:none;margin-bottom:1.5rem}.perks li{padding:.4rem 0;color:var(--text-muted)}.perks li:before{content:"✓ ";color:var(--accent);font-weight:700}.active-status{color:var(--accent);font-weight:700;font-size:1.2rem;margin-bottom:.5rem}.toast{position:fixed;top:1rem;right:1rem;background:var(--bg-card);border:1px solid var(--border);padding:.75rem 1.5rem;border-radius:var(--radius);z-index:100;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1}}.unity-embed{width:100%;max-width:960px;aspect-ratio:16/9;background:#000;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;margin-top:1rem}.signin-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease-out}.signin-popup{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2rem;width:360px;max-width:90vw;position:relative;animation:popupIn .2s ease-out}@keyframes popupIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.signin-close{position:absolute;top:.75rem;right:.75rem;background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;line-height:1}.signin-close:hover{color:var(--text)}.signin-popup h2{margin-bottom:.25rem;font-size:1.3rem;text-align:center}.signin-subtitle{color:var(--text-muted);text-align:center;margin-bottom:1.5rem;font-size:.9rem}.signin-providers{display:flex;flex-direction:column;gap:.75rem}.signin-provider{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius);border:1px solid var(--border);color:var(--text);font-weight:500;font-size:.95rem;transition:background .15s;text-decoration:none}.signin-provider:hover{background:var(--bg-hover);text-decoration:none}.account-dropdown{position:relative}.account-trigger{display:flex;align-items:center;gap:.5rem;background:none;border:1px solid var(--border);border-radius:var(--radius);padding:.3rem .6rem;color:var(--text);cursor:pointer;transition:background .15s}.account-trigger:hover{background:var(--bg-hover)}.account-avatar{width:28px;height:28px;border-radius:50%}.account-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;color:#fff}.account-name{font-weight:500;font-size:.9rem}.chevron{font-size:.7rem;transition:transform .15s}.chevron.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + .4rem);right:0;min-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 8px 24px #0006;z-index:50;padding:.4rem 0;animation:dropdownIn .15s ease-out}@keyframes dropdownIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{display:flex;align-items:center;gap:.6rem;width:100%;padding:.55rem 1rem;background:none;border:none;color:var(--text);font-size:.9rem;cursor:pointer;text-decoration:none;transition:background .1s}.dropdown-item:hover{background:var(--bg-hover);text-decoration:none}.dropdown-divider{height:1px;background:var(--border);margin:.3rem 0}.dropdown-item-danger{color:var(--danger)}.dropdown-item-danger:hover{background:#ef44441a}.provider-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;font-weight:700;font-size:.75rem;color:#fff;flex-shrink:0}.provider-icon.google{background:#4285f4}.provider-icon.discord{background:#5865f2}.provider-icon.steam{background:#1b2838}.provider-icon.xbox{background:#107c10}.profile-form{display:flex;flex-direction:column;gap:.75rem;max-width:400px;margin-bottom:2rem}.profile-form label{display:flex;flex-direction:column;gap:.25rem;font-weight:500}.profile-form input{padding:.5rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg-card);color:var(--text);font-size:1rem}.connections-list{display:flex;flex-direction:column;gap:.75rem;max-width:600px}.connection-card{display:flex;align-items:center;justify-content:space-between;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem 1.25rem}.connection-card.connected{border-color:var(--accent)}.connection-info{display:flex;align-items:center;gap:.75rem}.connection-username{display:block;color:var(--text-muted);font-size:.85rem}.connection-actions{flex-shrink:0}.alert{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-radius:var(--radius);margin-bottom:1.5rem;max-width:600px;font-size:.9rem}.alert-success{background:#22c55e26;border:1px solid var(--accent);color:var(--accent)}.alert-error{background:#ef444426;border:1px solid var(--danger);color:var(--danger)}.alert-close{background:none;border:none;color:inherit;font-size:1.2rem;cursor:pointer;padding:0 .25rem;line-height:1}.game-overlay{position:fixed;z-index:40;background:#000;overflow:hidden;transition:top .3s,left .3s,width .3s,height .3s,border-radius .3s}.game-overlay--full{top:var(--navbar-height);left:0;width:100%;height:calc(100vh - var(--navbar-height));border-radius:0}.game-overlay--mini{top:calc(100vh - 1.5rem - 202px);left:calc(100vw - 1.5rem - 360px);width:360px;height:202px;border-radius:8px;box-shadow:0 8px 32px #0009}.game-overlay-iframe{width:100%;height:100%;border:none;display:block}.game-overlay-drag{position:absolute;top:0;left:0;right:0;height:24px;cursor:grab;z-index:2}.game-overlay-drag:active{cursor:grabbing}.game-overlay-close{position:absolute;top:4px;right:4px;width:24px;height:24px;background:#0009;border:none;border-radius:50%;color:#fff;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:3}.game-overlay--mini:hover .game-overlay-close{opacity:1}.game-overlay-close:hover{background:#ef4444cc}.game-overlay-expand{position:absolute;top:0;right:0;bottom:0;left:0;cursor:pointer;z-index:1}.game-overlay--mini .play-loading{border-radius:8px}.party-panel{position:fixed;bottom:1.5rem;right:1.5rem;z-index:50;display:flex;flex-direction:column;align-items:flex-end}.party-toggle{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:.85rem;font-weight:600;cursor:pointer;transition:background .15s}.party-toggle:hover{background:var(--bg-hover)}.party-chevron{font-size:.6rem;transition:transform .2s}.party-chevron.open{transform:rotate(180deg)}.party-content{width:300px;max-height:450px;overflow-y:auto;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:1rem;margin-top:.5rem;animation:partySlideUp .2s ease-out;box-shadow:0 8px 32px #0006}@keyframes partySlideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.party-error{background:#ef444426;border:1px solid var(--danger);color:var(--danger);padding:.4rem .6rem;border-radius:4px;font-size:.8rem;margin-bottom:.75rem}.party-code-section{margin-bottom:1rem}.party-code-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;font-weight:600;margin-bottom:.3rem}.party-code-display{display:flex;align-items:center;gap:.5rem}.party-code-value{font-family:Courier New,monospace;font-size:1.1rem;font-weight:700;color:var(--accent);letter-spacing:1px}.party-code-inline{margin-bottom:.75rem}.party-join-section{display:flex;gap:.4rem;margin-bottom:.75rem}.party-join-input{flex:1;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);color:var(--text);font-family:Courier New,monospace;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.party-join-input:focus{outline:none;border-color:var(--primary)}.party-create-btn{width:100%}.party-header{margin-bottom:.5rem}.party-name{font-size:1.1rem;font-weight:700;margin:0}.party-name-input{width:100%;padding:.3rem .5rem;border:1px solid var(--primary);border-radius:4px;background:var(--bg);color:var(--text);font-size:1rem;font-weight:700}.party-members{margin-bottom:.75rem}.party-team-section{margin-bottom:.5rem}.party-team-label{font-size:.7rem;text-transform:uppercase;font-weight:700;padding:.2rem 0;margin-bottom:.2rem}.team-a .party-team-label{color:#60a5fa}.team-b .party-team-label{color:#fb923c}.team-spec .party-team-label{color:var(--text-muted)}.party-member{display:flex;align-items:center;gap:.5rem;padding:.35rem .4rem;border-radius:4px;transition:background .1s}.party-member:hover{background:var(--bg-hover)}.party-member-info{display:flex;align-items:center;gap:.4rem;flex:1;min-width:0}.party-member-avatar{width:22px;height:22px;border-radius:50%;flex-shrink:0}.party-member-avatar-placeholder{width:22px;height:22px;border-radius:50%;background:var(--primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.65rem;color:#fff;flex-shrink:0}.party-member-name{font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.party-leader-badge{display:inline-block;font-size:.6rem;background:var(--warning);color:#000;padding:.05rem .3rem;border-radius:3px;margin-left:.3rem;font-weight:700;vertical-align:middle}.party-member-rating{font-size:.8rem;font-weight:600;color:var(--accent);flex-shrink:0}.party-member-actions{display:flex;gap:.2rem;flex-shrink:0}.party-action-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.9rem;padding:.1rem .2rem;border-radius:3px;line-height:1}.party-action-btn:hover{color:var(--danger);background:#ef44441a}.party-action-ban{font-size:.7rem}.party-leave-btn{width:100%;margin-top:.25rem}@media(max-width:768px){.navbar{flex-direction:column;gap:.5rem;padding:.75rem}:root{--navbar-height: 110px}.nav-links{flex-wrap:wrap;justify-content:center;gap:.75rem;font-size:.85rem}.nav-play-btn{font-size:.8rem;padding:.4rem 1rem}.btn-play{font-size:1.8rem;padding:1rem 3rem}.home-logo{max-width:280px}.home-tagline{font-size:1rem}.screenshot-row{grid-template-columns:repeat(2,1fr)}.home-features{grid-template-columns:1fr}.info-row,.stats-grid{grid-template-columns:repeat(2,1fr)}.hat-collection-grid{grid-template-columns:repeat(auto-fill,minmax(90px,1fr))}.hat-collection-item img{width:48px;height:48px}.match-teams{grid-template-columns:1fr}}
