:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--bg-card: #15151f;--text-primary: #e8e8ec;--text-secondary: #9898a8;--text-muted: #5a5a6a;--accent-primary: #00f0ff;--accent-secondary: #ff3366;--accent-tertiary: #a855f7;--accent-success: #22c55e;--accent-warning: #f59e0b;--accent-error: #ef4444;--border-color: #2a2a3a;--border-glow: rgba(0, 240, 255, .3);--font-display: "Outfit", system-ui, sans-serif;--font-mono: "JetBrains Mono", "Consolas", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--shadow-glow: 0 0 20px rgba(0, 240, 255, .15);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4);--transition-fast: .15s ease;--transition-normal: .25s ease}[data-theme=light]{--bg-primary: #f5f5f7;--bg-secondary: #ffffff;--bg-tertiary: #e8e8ec;--bg-card: #ffffff;--text-primary: #1a1a25;--text-secondary: #5a5a6a;--text-muted: #9898a8;--accent-primary: #0891b2;--accent-secondary: #e11d48;--border-color: #d4d4d8;--border-glow: rgba(8, 145, 178, .2);--shadow-glow: 0 0 20px rgba(8, 145, 178, .1);--shadow-card: 0 4px 24px rgba(0, 0, 0, .08)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-primary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px;border:2px solid var(--bg-primary)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}::-webkit-scrollbar-corner{background:var(--bg-primary)}*{scrollbar-width:thin;scrollbar-color:var(--border-color) var(--bg-primary)}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-display);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.5}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at 20% 20%,rgba(0,240,255,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(255,51,102,.03) 0%,transparent 50%),linear-gradient(180deg,var(--bg-primary) 0%,var(--bg-secondary) 100%);pointer-events:none;z-index:-1}#app{display:flex;flex-direction:column;min-height:100vh}.app-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-xl);border-bottom:1px solid var(--border-color);background:var(--bg-secondary);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.header-right{display:flex;align-items:center;gap:var(--space-sm)}.logo{font-size:1.5rem;font-weight:700;letter-spacing:-.02em;display:flex;gap:0}.logo-over{color:var(--text-primary)}.logo-draft{color:var(--accent-primary);text-shadow:0 0 20px rgba(0,240,255,.5)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-family:var(--font-display);font-size:.9rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:var(--accent-primary);color:var(--bg-primary)}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-glow),0 0 30px #00f0ff66;transform:translateY(-1px)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{border-color:var(--accent-primary);background:var(--bg-secondary)}.btn-danger{background:#dc2626;color:#fff;border:1px solid #dc2626}.btn-danger:hover{background:#b91c1c;border-color:#b91c1c}.btn-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.btn-icon:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#00f0ff0d}.theme-toggle-btn{position:relative}.theme-toggle-btn .theme-icon{position:absolute;transition:opacity var(--transition-fast),transform var(--transition-fast)}[data-theme=dark] .theme-toggle-btn .theme-icon-sun{opacity:1;transform:rotate(0)}[data-theme=dark] .theme-toggle-btn .theme-icon-moon{opacity:0;transform:rotate(-90deg)}[data-theme=light] .theme-toggle-btn .theme-icon-sun{opacity:0;transform:rotate(90deg)}[data-theme=light] .theme-toggle-btn .theme-icon-moon{opacity:1;transform:rotate(0)}.theme-toggle-btn .theme-icon-sun{opacity:1}.theme-toggle-btn .theme-icon-moon{opacity:0}.btn-lang{display:flex;align-items:center;justify-content:center;min-width:40px;height:40px;padding:0 var(--space-sm);background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);font-family:var(--font-mono);font-size:.8rem;font-weight:600;letter-spacing:.05em}.btn-lang:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:#00f0ff0d}.btn-lang:active{transform:scale(.95)}.modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-lg)}.modal[hidden]{display:none}.modal-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#000c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{position:relative;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:100%;max-width:480px;max-height:90vh;display:flex;flex-direction:column;box-shadow:var(--shadow-card);animation:modalSlideIn .3s ease}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-xl);padding-bottom:var(--space-md);border-bottom:1px solid var(--border-color)}.modal-header h2{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.modal-subtitle{color:var(--text-secondary);font-size:.9rem}#settings-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}.modal-body{padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-lg);overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:var(--space-lg) var(--space-xl);border-top:1px solid var(--border-color);display:flex;justify-content:flex-end}.setup-footer{justify-content:space-between;align-items:center}.setup-footer-left{display:flex;gap:var(--space-sm)}.input-group{display:flex;flex-direction:column;gap:var(--space-sm)}.input-group label{font-size:.85rem;font-weight:500;color:var(--text-secondary)}.input-group input{padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);font-size:.9rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.input-group input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00f0ff1a}.input-group input::placeholder{color:var(--text-muted)}.feedback{font-size:.8rem;min-height:1.2em}.feedback.error{color:var(--accent-error)}.feedback.success{color:var(--accent-success)}.source-toggle{display:flex;gap:var(--space-sm);padding:var(--space-xs);background:var(--bg-primary);border-radius:var(--radius-md);border:1px solid var(--border-color)}.source-option{flex:1;cursor:pointer}.source-option input[type=radio]{display:none}.source-label{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.source-option input[type=radio]:checked+.source-label{color:var(--accent-primary);background:var(--bg-tertiary);box-shadow:0 0 0 1px var(--accent-primary)}.source-option:hover .source-label{color:var(--text-primary);background:var(--bg-tertiary)}.source-label svg{flex-shrink:0}.file-input-wrapper{position:relative}.file-input-wrapper input[type=file]{position:absolute;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.file-input-display{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);font-family:var(--font-mono);font-size:.9rem;color:var(--text-secondary);background:var(--bg-primary);border:2px dashed var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.file-input-wrapper:hover .file-input-display{border-color:var(--accent-primary);color:var(--text-primary)}.file-input-display svg{flex-shrink:0;color:var(--text-muted)}.file-input-wrapper:hover .file-input-display svg{color:var(--accent-primary)}.file-input-display.has-file{border-style:solid;border-color:var(--accent-success)}.file-input-display.has-file svg{color:var(--accent-success)}.help-section{padding:var(--space-md) var(--space-xl) var(--space-xl)}.help-section details{background:var(--bg-primary);border-radius:var(--radius-md);padding:var(--space-md)}.help-section summary{cursor:pointer;color:var(--text-secondary);font-size:.85rem}.help-section ol{margin-top:var(--space-md);padding-left:var(--space-lg);color:var(--text-secondary);font-size:.85rem;line-height:1.6}.help-section li{margin-bottom:var(--space-xs)}.settings-section{display:flex;flex-direction:column;gap:var(--space-md)}.settings-section h3{font-size:.9rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.sheet-info{padding:var(--space-md);background:var(--bg-primary);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.sheet-info-row{overflow-x:auto;white-space:nowrap;scrollbar-width:none;-ms-overflow-style:none}.sheet-info-row::-webkit-scrollbar{display:none}.sheet-info-row+.sheet-info-row{margin-top:var(--space-xs);color:var(--text-muted)}#teams-sheet-section .btn{margin-top:var(--space-md)}.slider-group{display:flex;align-items:center;gap:var(--space-md)}.slider-group input[type=range]{flex:1;height:4px;background:var(--bg-primary);border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-primary);border-radius:50%;cursor:pointer;box-shadow:0 0 10px #00f0ff80}.slider-group span{min-width:40px;text-align:right;font-family:var(--font-mono);font-size:.9rem;color:var(--accent-primary)}.app-main{flex:1;padding:var(--space-xl);overflow:auto}.state-container{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-lg);min-height:300px;color:var(--text-secondary)}.state-container[hidden]{display:none}.loader{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.btn-loader{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.loading-indicator{color:var(--accent-primary)}.status-spinner{display:inline-block;width:12px;height:12px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:var(--space-xs)}.error-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#ef44441a;border:2px solid var(--accent-error);border-radius:50%;font-size:1.5rem;font-weight:700;color:var(--accent-error)}.error-instructions,.setup-instructions{width:100%;max-width:500px;margin-top:var(--space-md)}.error-instructions[hidden],.setup-instructions[hidden]{display:none}.setup-instructions{padding:0 var(--space-xl)}.instruction-box{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:left}.instruction-box.warning{background:#f59e0b0d;border-color:var(--accent-warning)}.instruction-box h3{font-size:1rem;font-weight:600;color:var(--accent-warning);margin-bottom:var(--space-md)}.instruction-box>p{color:var(--text-secondary);font-size:.9rem;margin-bottom:var(--space-md)}.instruction-box ol{padding-left:var(--space-lg);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--space-md)}.instruction-box li{margin-bottom:var(--space-xs)}.instruction-note{font-size:.85rem;color:var(--text-muted);padding:var(--space-md);background:var(--bg-primary);border-radius:var(--radius-md);border-left:3px solid var(--accent-warning)}.instruction-note strong{color:var(--accent-warning)}.table-container{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card)}#data-table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:auto}#data-table .col-name{min-width:120px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#data-table .col-role{width:60px;min-width:60px}#data-table .col-rating{width:100px;min-width:100px}#data-table .col-heroes{min-width:150px;overflow:hidden}#data-table .col-text{min-width:80px;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#data-table .col-endorsement{width:100px;min-width:100px;text-align:center}.col-endorsement,.cell-endorsement,td.col-endorsement,td.cell-endorsement,.role-table .col-endorsement,.role-table td.col-endorsement{text-align:center!important}#data-table th,#data-table td{padding:var(--space-md) var(--space-lg);text-align:left;border-bottom:1px solid var(--border-color)}#data-table th{background:var(--bg-tertiary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);position:sticky;top:0;z-index:10}#data-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background var(--transition-fast),color var(--transition-fast)}#data-table th.sortable:hover{background:var(--bg-hover);color:var(--text-primary)}#data-table th.sortable .header-text{display:inline}#data-table th.sortable .sort-indicator{display:inline-block;width:16px;height:16px;margin-left:var(--space-xs);vertical-align:middle;opacity:.3;transition:opacity var(--transition-fast)}#data-table th.sortable .sort-indicator:after{content:"⇅";font-size:.75rem}#data-table th.sortable:hover .sort-indicator{opacity:.6}#data-table th.sortable.sorted{color:var(--accent-primary);background:var(--bg-hover)}#data-table th.sortable.sorted .sort-indicator{opacity:1;color:var(--accent-primary)}#data-table th.sortable.sorted.sort-desc .sort-indicator:after{content:"↓"}#data-table th.sortable.sorted.sort-asc .sort-indicator:after{content:"↑"}#data-table tbody tr{transition:background var(--transition-fast)}#data-table tbody tr:hover{background:#00f0ff08}#data-table tbody tr:last-child td{border-bottom:none}#data-table.density-compact th,#data-table.density-compact td{padding:var(--space-xs) var(--space-sm);font-size:.8rem}#data-table.density-compact .hero-icon{width:20px;height:20px}#data-table.density-compact .role-icon{width:16px;height:16px}#data-table.density-compact .rank-icon{width:18px;height:18px}#data-table.density-compact .rank-number{font-size:.75rem}#data-table.density-normal th,#data-table.density-normal td{padding:var(--space-sm) var(--space-md);font-size:.85rem}#data-table.density-normal .hero-icon{width:24px;height:24px}#data-table.density-normal .role-icon{width:18px;height:18px}#data-table.density-normal .rank-icon{width:22px;height:22px}#data-table.density-normal .rank-number{font-size:.8rem}#data-table.density-comfortable th,#data-table.density-comfortable td{padding:var(--space-md) var(--space-lg);font-size:.9rem}.role-tank{color:#facc15}.role-dps,.role-damage{color:#ef4444}.role-support,.role-healer{color:#22c55e}.rating-badge{display:inline-block;padding:2px 8px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85rem;font-weight:500}.rating-bronze{background:#cd7f3233;color:#cd7f32}.rating-silver{background:#c0c0c033;color:silver}.rating-gold{background:#ffd70033;color:gold}.rating-platinum{background:#4fd1c533;color:#4fd1c5}.rating-diamond{background:#60a5fa33;color:#60a5fa}.rating-master{background:#f59e0b33;color:#f59e0b}.rating-grandmaster{background:#ef444433;color:#ef4444}.rating-champion{background:#a855f733;color:#a855f7}.app-footer{padding:var(--space-sm) var(--space-xl);border-top:1px solid var(--border-color);background:var(--bg-secondary)}.status-bar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md)}.status-item{display:flex;align-items:center;gap:var(--space-sm);font-size:.8rem;color:var(--text-muted)}.status-item[hidden]{display:none}.indicator{width:8px;height:8px;border-radius:50%;background:var(--accent-success);animation:pulse 2s infinite}.indicator.error{background:var(--accent-error);animation:none}.indicator.paused{background:var(--text-muted);animation:none}.version-info{font-family:var(--font-mono);font-size:.75rem;opacity:.6}.status-bar .copyright{margin-left:auto;font-size:.75rem;opacity:.5;display:flex;align-items:center;gap:var(--space-sm)}.discord-link{color:inherit;text-decoration:none;transition:color var(--transition-fast),opacity var(--transition-fast)}.discord-link:hover{color:var(--text-primary);opacity:1}.version-section{border-top:1px solid var(--border-color);margin-top:var(--space-lg);padding-top:var(--space-lg)}.version-details{display:flex;flex-direction:column;gap:var(--space-xs);font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted)}.version-details .build-time{font-size:.7rem;opacity:.7}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.status-item.error{color:var(--accent-error)}@media (max-width: 768px){.app-header,.app-main{padding:var(--space-md)}.modal-content{max-height:90vh;overflow-y:auto}#data-table th,#data-table td{padding:var(--space-sm) var(--space-md);font-size:.8rem}.table-container{overflow-x:auto}.teams-layout-params{grid-template-columns:repeat(2,1fr)}.teams-layout-preview{max-height:200px}}.tabs-bar{display:flex;justify-content:flex-start;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-lg)}.tabs-bar-left{display:flex;align-items:center;gap:var(--space-sm)}.tabs-nav{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);width:fit-content;min-height:46px;box-sizing:border-box}.tabs-nav[hidden]{display:none}.filters-container{display:flex;align-items:center;gap:var(--space-sm)}.filters-group{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.filters-group[hidden]{display:none}.filter-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.filter-btn:hover{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--border-color)}.filter-btn.active{background:#00f0ff1a;border-color:var(--accent-primary);color:var(--accent-primary);box-shadow:0 0 10px #00f0ff33}.filter-btn[data-filter=tank].active{background:#facc1526;border-color:#facc15;color:#facc15;box-shadow:0 0 10px #facc1533}.filter-btn[data-filter=dps].active{background:#ef444426;border-color:#ef4444;color:#ef4444;box-shadow:0 0 10px #ef444433}.filter-btn[data-filter=support].active{background:#22c55e26;border-color:#22c55e;color:#22c55e;box-shadow:0 0 10px #22c55e33}.filter-btn svg{width:18px;height:18px}.filter-btn .role-filter-icon{display:none}.filter-btn .role-filter-img{width:18px;height:18px;opacity:.6;transition:opacity var(--transition-fast)}.filter-btn:hover .role-filter-img{opacity:.8}.filter-btn.active .role-filter-img{opacity:1}.filter-divider{width:1px;height:24px;background:var(--border-color);margin:0 var(--space-xs)}.density-controls{margin-left:auto}.density-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:1px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.density-btn:hover{color:var(--text-primary);background:var(--bg-tertiary);border-color:var(--border-color)}.density-btn:active{transform:scale(.95)}.density-btn:disabled{opacity:.3;cursor:not-allowed}.density-btn svg{width:16px;height:16px}.tab-btn{padding:var(--space-sm) var(--space-lg);font-family:var(--font-display);font-size:.9rem;font-weight:500;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.tab-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-btn.active{background:var(--accent-primary);color:var(--bg-primary);box-shadow:0 0 15px #00f0ff4d}.tab-content{animation:fadeIn .2s ease}.tab-content[hidden]{display:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.sheet-config-section{padding-bottom:var(--space-lg);border-bottom:1px solid var(--border-color)}.sheet-config-section:last-child{padding-bottom:0;border-bottom:none}.section-title{font-size:.9rem;font-weight:600;color:var(--accent-primary);margin-bottom:var(--space-md)}.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,320px);gap:var(--space-lg);justify-content:center}.team-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card);transition:all var(--transition-normal)}.team-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.team-card-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg);background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.team-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.team-rating{font-family:var(--font-mono);font-size:.9rem;padding:var(--space-xs) var(--space-sm);background:#00f0ff1a;border-radius:var(--radius-sm);color:var(--accent-primary)}.team-players{padding:var(--space-md)}.team-player{display:grid;align-items:center;gap:var(--space-sm);padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color)}.team-player:last-child{border-bottom:none}.player-role{width:24px;height:24px;display:flex;align-items:center;justify-content:center;justify-self:center;font-size:.75rem;font-weight:700;border-radius:var(--radius-sm);text-transform:uppercase}.player-role.tank{background:#facc1533;color:#facc15}.player-role.dps{background:#ef444433;color:#ef4444}.player-role.support{background:#22c55e33;color:#22c55e}.player-nickname{font-size:.9rem;color:var(--text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.player-rating{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary);justify-self:end}.player-rating.rank-badge .rank-icon{width:24px;height:24px}.player-heroes{display:flex;gap:2px;min-width:0;overflow:hidden}.player-heroes .hero-icon{width:20px;height:20px;flex-shrink:0}.validation-error-box{background:#ef44440d;border:1px solid var(--accent-error);border-radius:var(--radius-lg);padding:var(--space-lg);margin-bottom:var(--space-lg)}.validation-error-box[hidden]{display:none}.validation-error-box .error-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);color:var(--accent-error)}.validation-error-box .error-icon-small{font-size:1.2rem}.validation-error-box pre{background:var(--bg-primary);padding:var(--space-md);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary);white-space:pre-wrap;overflow-x:auto;margin:0}.schema-help{margin-top:var(--space-md)}.schema-help summary{cursor:pointer;color:var(--text-muted);font-size:.85rem;padding:var(--space-sm) 0}.schema-help pre{margin-top:var(--space-sm);color:var(--text-muted);font-size:.8rem}.teams-not-configured{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-2xl);text-align:center;color:var(--text-secondary)}.teams-not-configured svg{width:48px;height:48px;margin-bottom:var(--space-md);opacity:.5}.teams-not-configured p{margin-bottom:var(--space-lg)}#data-display[hidden]{display:none}.players-layout{min-height:500px}.players-table-panel{min-width:0;overflow:hidden}.players-table-panel .table-container{max-height:calc(100vh - 250px);overflow-y:auto}.player-table-row{cursor:pointer;transition:background var(--transition-fast)}.player-table-row:hover{background:#00f0ff0d}.player-table-row.selected{background:#00f0ff1a;box-shadow:inset 3px 0 0 var(--accent-primary)}.player-info-card{animation:fadeIn .2s ease}.player-info-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.player-role-badge{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.player-role-badge.tank{background:#facc1526}.player-role-badge.dps{background:#ef444426}.player-role-badge.support{background:#22c55e26}.player-role-badge .role-icon{width:28px;height:28px}.player-info-name{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.player-info-main-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);margin-bottom:var(--space-xl)}.player-info-key-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xs) var(--space-sm);margin-bottom:var(--space-md)}.player-info-key-columns .player-info-heroes{grid-column:1 / -1}.player-info-key-columns .player-info-stat{grid-column:span 1;min-width:0}.player-info-stat{display:flex;flex-direction:column;gap:var(--space-xs)}.player-info-stat .stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.player-info-stat .stat-value{font-size:1.1rem;font-weight:500;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-xs)}.player-info-stat .stat-role{display:flex;align-items:center;gap:var(--space-sm)}.player-info-heroes{margin-bottom:var(--space-xl)}.player-info-heroes .stat-label{display:block;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-sm)}.player-info-heroes .heroes-list{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.player-info-heroes .hero-icon{width:36px;height:36px}.player-info-additional{padding-top:var(--space-lg);border-top:1px solid var(--border-color)}.player-info-additional .section-label{display:block;font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--space-md)}.player-info-fields{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-sm)}@media (max-width: 1024px){.player-info-fields{grid-template-columns:1fr}}.player-info-field{display:flex;flex-direction:column;gap:2px;padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-sm)}.player-info-field .field-label{font-size:.75rem;color:var(--text-muted);font-weight:500}.player-info-field .field-value{font-size:.9rem;color:var(--text-primary);word-break:break-word}@keyframes rowHighlight{0%{background:#00f0ff1a}to{background:transparent}}.row-updated{animation:rowHighlight 1s ease-out}.teams-layout{min-height:500px}.teams-grid-panel{min-width:0;overflow:hidden}.teams-grid-panel .teams-grid{max-height:calc(100vh - 250px);overflow-y:auto;padding-top:var(--space-sm)}.team-player{cursor:pointer;transition:background var(--transition-fast);border-radius:var(--radius-sm);margin:-2px -4px;padding:2px 4px}.team-player:hover{background:#00f0ff0d}.team-player.selected{background:#00f0ff1a;box-shadow:inset 2px 0 0 var(--accent-primary)}.player-nickname.player-unknown{color:var(--text-muted);font-style:italic}.player-role.unknown{background:var(--bg-tertiary);color:var(--text-muted)}.player-rating.unknown{color:var(--text-muted)}.team-card{cursor:default}.team-player{display:grid;grid-template-columns:4fr 1fr 2fr 3fr;align-items:center;gap:.5em}.team-player .player-nickname{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.team-player .player-role{display:flex;justify-content:center}.team-player .player-rating{justify-self:end}.team-player .player-heroes .hero-icons-container{flex-wrap:nowrap!important;gap:.15em}.team-player .player-heroes .hero-icon{width:1.2em;height:1.2em}.player-details-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);text-align:center}.player-details-card{animation:fadeIn .2s ease}.player-details-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.player-role-large{width:48px;height:48px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;font-weight:700;border-radius:var(--radius-md)}.player-role-large.tank{background:#facc1533;color:#facc15}.player-role-large.dps{background:#ef444433;color:#ef4444}.player-role-large.support{background:#22c55e33;color:#22c55e}.player-details-name{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.player-details-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-lg);margin-bottom:var(--space-xl)}.player-stat{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:1.1rem;font-weight:500;color:var(--text-primary)}.stat-value.rating-bronze{color:#cd7f32}.stat-value.rating-silver{color:silver}.stat-value.rating-gold{color:gold}.stat-value.rating-platinum{color:#4fd1c5}.stat-value.rating-diamond{color:#60a5fa}.stat-value.rating-master{color:#f59e0b}.stat-value.rating-grandmaster{color:#ef4444}.stat-value.rating-champion{color:#a855f7}.player-details-heroes{margin-top:var(--space-lg)}.heroes-list{margin-top:var(--space-sm);color:var(--text-secondary);line-height:1.6}.role-icon{display:inline-block;vertical-align:middle;object-fit:contain}.role-icon-sm{width:18px;height:18px}.role-icon-md{width:24px;height:24px}.role-icon-lg{width:32px;height:32px}.role-badge-text{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;font-size:.7rem;font-weight:700;border-radius:var(--radius-sm)}.role-badge-text.role-tank{background:#facc1533;color:#facc15}.role-badge-text.role-damage,.role-badge-text.role-dps{background:#ef444433;color:#ef4444}.role-badge-text.role-support{background:#22c55e33;color:#22c55e}.hero-icon{display:inline-block;vertical-align:middle;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border-color);background:var(--bg-tertiary)}.hero-icon-sm{width:24px;height:24px}.hero-icon-md{width:32px;height:32px}.hero-icon-lg{width:48px;height:48px}.hero-icons-container{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap}.hero-icons-more{display:inline-flex;align-items:center;justify-content:center;min-width:24px;height:24px;padding:0 4px;font-size:.7rem;font-weight:600;color:var(--text-muted);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-color)}.rank-badge{display:inline-flex;align-items:center;gap:6px}.rank-badge-sm .rank-icon{width:28px;height:28px}.rank-badge-md .rank-icon{width:36px;height:36px}.rank-badge-lg .rank-icon{width:48px;height:48px}.rank-icon{display:inline-block;vertical-align:middle;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.4));transition:transform var(--transition-fast),filter var(--transition-fast)}.rank-badge:hover .rank-icon{transform:scale(1.1);filter:drop-shadow(0 3px 6px rgba(0,0,0,.5)) brightness(1.1)}.rank-number{font-family:var(--font-mono);font-size:.85rem;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);letter-spacing:.02em}.rank-badge.rank-bronze .rank-number{background:#cd7f3226;border-color:#cd7f324d;color:#cd7f32}.rank-badge.rank-silver .rank-number{background:#c0c0c026;border-color:#c0c0c04d;color:silver}.rank-badge.rank-gold .rank-number{background:#ffd70026;border-color:#ffd7004d;color:gold}.rank-badge.rank-platinum .rank-number{background:#4fd1c526;border-color:#4fd1c54d;color:#4fd1c5}.rank-badge.rank-diamond .rank-number{background:#60a5fa26;border-color:#60a5fa4d;color:#60a5fa}.rank-badge.rank-master .rank-number{background:#f59e0b26;border-color:#f59e0b4d;color:#f59e0b}.rank-badge.rank-grandmaster .rank-number{background:#ef444426;border-color:#ef44444d;color:#ef4444}.rank-badge.rank-champion .rank-number{background:#a855f726;border-color:#a855f74d;color:#a855f7}.cell-role{text-align:center}.cell-rating{white-space:nowrap}.cell-heroes{min-width:100px}.player-role{width:auto;min-width:24px;height:24px;padding:0 2px}.player-role .role-icon{filter:drop-shadow(0 0 2px currentColor)}.player-row-role{display:flex;align-items:center;justify-content:center;width:24px;height:24px;flex-shrink:0}.player-row-role .role-icon{width:20px;height:20px}.player-row-rating.rank-badge{gap:4px}.player-row-rating .rank-icon{width:24px;height:24px}.player-row-rating .rank-number{font-size:.8rem;padding:1px 6px}.player-role-large{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.player-role-large.tank{background:#facc1526}.player-role-large.dps{background:#ef444426}.player-role-large.support{background:#22c55e26}.player-role-large .role-icon{width:28px;height:28px}.player-details-heroes .heroes-list{margin-top:var(--space-sm)}.player-details-heroes .hero-icon{width:36px;height:36px}.rank-bronze{color:#cd7f32}.rank-silver{color:silver}.rank-gold{color:gold}.rank-platinum{color:#4fd1c5}.rank-diamond{color:#60a5fa}.rank-master{color:#f59e0b}.rank-grandmaster{color:#ef4444}.rank-champion{color:#a855f7}.team-card-header .team-rating{background:transparent;padding:0}.team-card-header .team-rating .rank-icon{width:28px;height:28px}.endorsement-badge{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-weight:700;position:relative;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.endorsement-badge-sm{width:28px;height:28px;font-size:.85rem}.endorsement-badge-md{width:36px;height:36px;font-size:1rem}.endorsement-badge-lg{width:48px;height:48px;font-size:1.25rem}.endorsement-number{position:relative;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.5)}.endorsement-5{background:linear-gradient(135deg,#166534,#22c55e,#16a34a);box-shadow:0 0 12px #22c55e80,inset 0 -2px 4px #0003,inset 0 2px 4px #fff3;border:2px solid rgba(34,197,94,.6);color:#fff}.endorsement-5:before{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:conic-gradient(from 0deg,transparent 0deg 60deg,rgba(34,197,94,.3) 60deg 120deg,transparent 120deg 180deg,rgba(34,197,94,.3) 180deg 240deg,transparent 240deg 300deg,rgba(34,197,94,.3) 300deg 360deg);z-index:-1;animation:endorsement-glow 3s linear infinite}.endorsement-4{background:linear-gradient(135deg,#0369a1,#00b4d8,#0284c7);box-shadow:0 0 12px #00b4d880,inset 0 -2px 4px #0003,inset 0 2px 4px #fff3;border:2px solid rgba(0,180,216,.6);color:#fff}.endorsement-4:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;background:conic-gradient(from 45deg,transparent 0deg 90deg,rgba(0,180,216,.25) 90deg 180deg,transparent 180deg 270deg,rgba(0,180,216,.25) 270deg 360deg);z-index:-1}.endorsement-3{background:linear-gradient(135deg,#b45309,#f59e0b,#d97706);box-shadow:0 0 12px #f59e0b80,inset 0 -2px 4px #0003,inset 0 2px 4px #fff3;border:2px solid rgba(245,158,11,.6);color:#fff}.endorsement-3:before{content:"";position:absolute;top:-3px;right:-3px;bottom:-3px;left:-3px;border-radius:50%;background:conic-gradient(from 60deg,transparent 0deg 120deg,rgba(245,158,11,.2) 120deg 240deg,transparent 240deg 360deg);z-index:-1}.endorsement-2{background:linear-gradient(135deg,#7c3aed,#a855f7,#9333ea);box-shadow:0 0 12px #a855f780,inset 0 -2px 4px #0003,inset 0 2px 4px #fff3;border:2px solid rgba(168,85,247,.6);color:#fff}.endorsement-2:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:50%;border:1px dashed rgba(168,85,247,.4);z-index:-1}.endorsement-1{background:linear-gradient(135deg,#374151,#6b7280,#4b5563);box-shadow:0 0 8px #6b72804d,inset 0 -2px 4px #0003,inset 0 2px 4px #ffffff1a;border:2px solid rgba(107,114,128,.5);color:#d1d5db}.endorsement-empty{background:var(--bg-tertiary);box-shadow:none;border:2px dashed var(--border-color);color:var(--text-muted)}.endorsement-empty .endorsement-number{text-shadow:none;opacity:.6}.endorsement-badge:hover{transform:scale(1.1)}.endorsement-5:hover{box-shadow:0 0 20px #22c55eb3}.endorsement-4:hover{box-shadow:0 0 20px #00b4d8b3}.endorsement-3:hover{box-shadow:0 0 20px #f59e0bb3}.endorsement-2:hover{box-shadow:0 0 20px #a855f7b3}.endorsement-1:hover{box-shadow:0 0 16px #6b728080}@keyframes endorsement-glow{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.cell-endorsement,.col-endorsement{text-align:center}td.col-endorsement,td.cell-endorsement{display:table-cell;vertical-align:middle}td.col-endorsement .endorsement-badge,td.cell-endorsement .endorsement-badge{display:inline-flex}#data-table.density-compact .endorsement-badge-sm{width:22px;height:22px;font-size:.75rem}#data-table.density-normal .endorsement-badge-sm{width:26px;height:26px;font-size:.8rem}.modal-content-wide{max-width:700px}.modal-content-player-info{width:min(800px,95vw);max-width:none}@media (max-width: 640px){.modal-content-player-info{width:95vw}}#player-info-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}#player-info-modal .modal-header h2{font-size:.9rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0}#player-info-modal .modal-body{padding:var(--space-lg)}#player-info-modal-content .player-details-empty{display:flex;align-items:center;justify-content:center;height:120px;color:var(--text-muted);text-align:center}#player-info-modal-content .player-info-key-columns{grid-template-columns:repeat(3,1fr);gap:var(--space-md) var(--space-lg)}#player-info-modal-content .player-info-key-columns .player-info-stat,#player-info-modal-content .player-info-key-columns .player-info-heroes{grid-column:auto}#player-info-modal-content .player-info-main-stats{grid-template-columns:repeat(3,1fr);gap:var(--space-md) var(--space-lg)}#player-info-modal-content .player-info-additional{margin-top:var(--space-lg)}#player-info-modal-content .player-info-fields{grid-template-columns:repeat(3,1fr)}@media (max-width: 700px){#player-info-modal-content .player-info-key-columns,#player-info-modal-content .player-info-main-stats,#player-info-modal-content .player-info-fields{grid-template-columns:repeat(2,1fr)}}#column-mapping-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}.modal-description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.column-mapping-table{display:flex;flex-direction:column;gap:var(--space-md)}.column-mapping-row{display:grid;grid-template-columns:140px auto 28px;gap:var(--space-md);align-items:center;padding:var(--space-sm) 0;border-bottom:1px solid var(--border-color)}.column-mapping-row:last-child{border-bottom:none}.column-mapping-label{font-weight:500;color:var(--text-primary);font-size:.9rem}.column-mapping-label.required:after{content:" *";color:var(--accent-error)}.column-mapping-select{flex:1;padding:var(--space-sm) var(--space-md);font-family:var(--font-display);font-size:.9rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%239898a8' stroke-width='2'%3E%3Cpath d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.column-mapping-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00f0ff1a}.column-mapping-select:hover{border-color:var(--text-muted)}.column-mapping-select.error{border-color:var(--accent-error);background-color:#ef44440d}.column-mapping-select.success{border-color:var(--accent-success)}.column-mapping-status{width:28px;height:28px;display:flex;align-items:center;justify-content:center;font-size:1rem}.column-mapping-status.valid{color:var(--accent-success)}.column-mapping-status.invalid{color:var(--accent-error)}.column-mapping-status.warning{color:var(--accent-warning)}.column-mapping-row-error{grid-column:2 / -1;font-size:.8rem;color:var(--accent-error);display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) 0}.column-mapping-row-error:before{content:"⚠"}.column-mapping-error{padding:var(--space-md);background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius-md);color:var(--accent-error);font-size:.9rem}.column-mapping-error[hidden]{display:none}#column-config-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}.column-config-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-md)}.column-config-row{display:grid;grid-template-columns:32px 1fr 180px 100px 32px;gap:var(--space-sm);align-items:center;padding:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.column-config-row:hover{border-color:var(--text-muted)}.column-config-row.is-name{background:#00f0ff0d;border-color:var(--accent-primary)}.column-config-row.dragging{opacity:.5;border-style:dashed}.column-config-row.drag-over{border-color:var(--accent-primary);background:#00f0ff1a}.column-config-drag-handle{cursor:grab;color:var(--text-muted);display:flex;align-items:center;justify-content:center;padding:var(--space-xs)}.column-config-drag-handle:active{cursor:grabbing}.column-config-row.is-name .column-config-drag-handle{visibility:hidden}.column-config-input{padding:var(--space-xs) var(--space-sm);font-family:var(--font-display);font-size:.85rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);transition:all var(--transition-fast)}.column-config-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #00f0ff1a}.column-config-input:disabled{opacity:.6;cursor:not-allowed}.column-config-select{padding:var(--space-xs) var(--space-sm);font-family:var(--font-display);font-size:.85rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;transition:all var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%239898a8' stroke-width='2'%3E%3Cpath d='M3 5l3 3 3-3'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;padding-right:28px}.column-config-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #00f0ff1a}.column-config-delete-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:transparent;border:1px solid transparent;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast)}.column-config-delete-btn:hover{background:#ef44441a;border-color:var(--accent-error);color:var(--accent-error)}.column-config-row.is-name .column-config-delete-btn{visibility:hidden}.add-column-btn{display:flex;align-items:center;gap:var(--space-sm);width:100%;justify-content:center;padding:var(--space-sm) var(--space-md);margin-top:var(--space-sm)}.column-config-error{padding:var(--space-md);background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius-md);color:var(--accent-error);font-size:.9rem;margin-top:var(--space-md)}.column-config-error[hidden]{display:none}.column-type-name{color:var(--accent-primary)}.column-type-role{color:var(--role-tank)}.column-type-rating{color:var(--accent-success)}.column-type-heroes{color:var(--accent-warning)}.column-type-text{color:var(--text-secondary)}#teams-display-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}.teams-display-columns{display:flex;flex-direction:column;gap:var(--space-sm)}.teams-display-column-row{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.teams-display-column-row:hover{background:var(--bg-tertiary);border-color:var(--text-muted)}.teams-display-column-row.checked{border-color:var(--accent-primary);background:#00f0ff0d}.teams-display-column-row.is-name{opacity:.7;cursor:not-allowed}.teams-display-columns.teams-display-fixed .teams-display-column-row{cursor:default}.teams-display-columns.teams-display-fixed .teams-display-column-row:hover{background:#00f0ff0d;border-color:var(--accent-primary)}.teams-display-column-row.fixed{cursor:default}.teams-display-check-icon{width:18px;height:18px;display:flex;align-items:center;justify-content:center;color:var(--accent-primary);font-weight:700;font-size:.9rem}.teams-display-checkbox{width:18px;height:18px;accent-color:var(--accent-primary);cursor:pointer}.teams-display-column-row.is-name .teams-display-checkbox{pointer-events:none}.teams-display-column-name{flex:1;font-weight:500;color:var(--text-primary)}.teams-display-column-type{font-size:.8rem;padding:2px 8px;border-radius:var(--radius-sm);background:var(--bg-primary)}.teams-display-slots{display:flex;flex-direction:column;gap:var(--space-md)}.teams-display-slot{display:flex;align-items:center;gap:var(--space-md)}.teams-display-slot label{min-width:80px;font-weight:500;color:var(--text-primary)}.teams-display-select{flex:1;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color var(--transition-fast)}.teams-display-select:hover{border-color:var(--text-muted)}.teams-display-select:focus{outline:none;border-color:var(--accent-primary)}.teams-display-select option{background:var(--bg-secondary);color:var(--text-primary)}.modal-content-xl{max-width:800px;width:90vw;max-height:90vh;display:flex;flex-direction:column}#teams-layout-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center;padding:var(--space-md) var(--space-lg)}#teams-layout-modal .modal-body{padding:var(--space-md) var(--space-lg);overflow-y:auto;flex:1;min-height:0}.teams-layout-params{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-sm) var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.teams-layout-params .param-group{display:flex;flex-direction:column;gap:var(--space-xs)}.teams-layout-params .param-group label{font-size:.7rem;color:var(--text-muted);white-space:nowrap}.teams-layout-params .param-group input{padding:var(--space-xs) var(--space-sm);font-size:.85rem}.param-group{display:flex;flex-direction:column;gap:var(--space-xs)}.param-group label{font-size:.8rem;font-weight:500;color:var(--text-secondary)}.param-group input[type=number]{padding:var(--space-sm) var(--space-md);font-family:var(--font-mono);font-size:.95rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast);width:100%}.param-group input[type=number]:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00f0ff1a}.param-group input[type=number]:hover{border-color:var(--text-muted)}.teams-layout-preview-section{margin-bottom:var(--space-sm)}.teams-layout-preview-section h3{font-size:.8rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm);text-transform:uppercase;letter-spacing:.05em}.teams-layout-preview-wrapper{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-primary)}.teams-layout-preview{overflow:auto;max-height:300px;position:relative}.teams-preview-table{border-collapse:collapse;font-family:var(--font-mono);font-size:.75rem;white-space:nowrap}.teams-preview-table td{padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);min-width:60px;max-width:120px;overflow:hidden;text-overflow:ellipsis;color:var(--text-secondary);background:var(--bg-secondary);position:relative}.teams-preview-table td.empty-cell{background:var(--bg-tertiary);color:var(--text-muted)}.teams-preview-table td.team-border-top{border-top:2px solid var(--accent-primary)}.teams-preview-table td.team-border-bottom{border-bottom:2px solid var(--accent-primary)}.teams-preview-table td.team-border-left{border-left:2px solid var(--accent-primary)}.teams-preview-table td.team-border-right{border-right:2px solid var(--accent-primary)}.teams-preview-table td.team-header-cell{background:#00f0ff1a;color:var(--accent-primary);font-weight:600}.teams-preview-table td.player-nickname-cell{color:var(--text-primary);font-weight:500;background:#00f0ff0d}.teams-preview-table td.ignored-cell{color:var(--text-muted);opacity:.5}.teams-preview-table td.error-cell{background:#ef444433;border:2px solid var(--accent-error);animation:pulse-error 1.5s ease-in-out infinite}@keyframes pulse-error{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 4px #ef444433}}.teams-preview-table td.row-number{background:var(--bg-tertiary);color:var(--text-muted);font-size:.7rem;text-align:right;padding-right:var(--space-md);border-right:2px solid var(--border-color);min-width:40px}.teams-preview-table td.col-header{background:var(--bg-tertiary);color:var(--text-muted);font-size:.7rem;text-align:center;border-bottom:2px solid var(--border-color)}.teams-preview-table td.separator-cell{background:repeating-linear-gradient(45deg,var(--bg-tertiary),var(--bg-tertiary) 4px,var(--bg-secondary) 4px,var(--bg-secondary) 8px);opacity:.5}.teams-preview-table td.offset-cell{background:var(--bg-tertiary);opacity:.3}.teams-layout-error{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius-md);color:var(--accent-error);font-size:.9rem;line-height:1.4}.teams-layout-error .error-icon{flex-shrink:0}.teams-layout-error[hidden]{display:none}#teams-layout-modal .modal-footer{display:flex;gap:var(--space-md);justify-content:flex-end;padding:var(--space-md) var(--space-lg)}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.85rem;gap:var(--space-xs)}.btn-user{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:var(--transition-fast)}.btn-user:hover{border-color:var(--accent-primary);color:var(--text-primary)}.btn-user #user-email{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-xs);min-width:180px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-card);z-index:1000;overflow:hidden}.dropdown-menu[hidden]{display:none}.dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:var(--transition-fast)}.dropdown-item:hover{background:var(--bg-tertiary);color:var(--accent-primary)}.dropdown-item svg{opacity:.7}.header-right{position:relative}#dashboard-modal .modal-header{flex-direction:row;justify-content:space-between;align-items:center}.dashboard-tabs{display:flex;gap:var(--space-sm);margin-bottom:var(--space-lg);border-bottom:1px solid var(--border-color);padding-bottom:var(--space-sm)}.dashboard-tab{padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--text-secondary);font-size:.95rem;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:var(--transition-fast)}.dashboard-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary)}.dashboard-tab:hover:not(.active){color:var(--text-primary)}.dashboard-tab-content[hidden]{display:none}.tournaments-list{display:flex;flex-direction:column;gap:var(--space-sm);max-height:400px;overflow-y:auto;margin-bottom:var(--space-lg)}.tournaments-empty{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.tournament-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-fast)}.tournament-card:hover{border-color:var(--accent-primary)}.tournament-card-info{flex:1;min-width:0}.tournament-card-name-row{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.tournament-card-name{font-weight:600;color:var(--text-primary)}.tournament-card-meta{font-size:.85rem;color:var(--text-muted)}.tournament-card-actions{display:flex;gap:var(--space-xs);align-items:center}.status-badge{display:inline-block;padding:2px 8px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;border-radius:var(--radius-sm);white-space:nowrap}.status-badge-draft{background:#9e9e9e33;color:#9e9e9e;border:1px solid rgba(158,158,158,.3)}.status-badge-active{background:#22c55e26;color:var(--accent-success);border:1px solid rgba(34,197,94,.3)}.status-badge-completed{background:#a855f726;color:var(--accent-tertiary);border:1px solid rgba(168,85,247,.3)}.status-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:var(--radius-sm);padding:4px 24px 4px 8px;font-size:.75rem;font-family:var(--font-display);cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239898a8' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 6px center;transition:var(--transition-fast)}.status-select:hover{border-color:var(--accent-primary)}.status-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px #00f0ff26}.create-step{display:flex;flex-direction:column;gap:var(--space-md)}.create-step[hidden]{display:none}.step-description{color:var(--text-secondary);margin-bottom:var(--space-sm)}.column-mapping-grid{display:grid;gap:var(--space-sm)}.mapping-row{display:flex;align-items:center;gap:var(--space-md)}.mapping-row label{flex:1;color:var(--text-primary)}.mapping-row.optional label{color:var(--text-secondary)}.col-input{width:60px;text-align:center;text-transform:uppercase;font-family:var(--font-mono)}.create-progress{display:flex;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xl);color:var(--text-secondary)}.create-progress .spinner{width:24px;height:24px;border:2px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.create-error{padding:var(--space-md);background:#ef44441a;border:1px solid var(--accent-error);border-radius:var(--radius-md);color:var(--accent-error)}.create-error[hidden]{display:none}#create-tournament-modal .modal-footer{display:flex;gap:var(--space-md);justify-content:flex-end}.landing-container{max-width:900px;width:100%;padding:var(--space-2xl);text-align:center}.landing-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-xl);margin-bottom:var(--space-2xl)}.landing-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;transition:var(--transition-normal);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.landing-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);transform:translateY(-2px)}.landing-card h3{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.landing-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.landing-card .btn{margin-top:auto;width:100%}.landing-share-input .btn{flex-shrink:0;width:auto;margin-top:0}.home-btn{margin-right:var(--space-sm)}.home-btn[hidden]{display:none}@media (max-width: 768px){.landing-container{padding:var(--space-lg)}.landing-logo{font-size:2.5rem}.landing-options{grid-template-columns:1fr}.landing-share-input{flex-direction:column}.landing-share-input .btn{width:100%}}.dashboard-actions{display:flex;gap:var(--space-sm);margin-top:var(--space-md)}.league-select{padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.75rem;cursor:pointer;max-width:120px}.league-select:hover{border-color:var(--accent-tertiary)}.league-select:focus{outline:none;border-color:var(--accent-tertiary)}.leagues-list{display:flex;flex-direction:column;gap:var(--space-sm);padding-bottom:var(--space-md)}.leagues-empty{text-align:center;color:var(--text-muted);padding:var(--space-xl)}.league-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:var(--transition-fast)}.league-card:hover{border-color:var(--accent-tertiary)}.league-card-info{flex:1;min-width:0}.league-card-name{font-weight:600;color:var(--text-primary);margin-bottom:var(--space-xs)}.league-card-meta{font-size:.85rem;color:var(--text-muted)}.league-card-actions{display:flex;gap:var(--space-xs);align-items:center}.league-tournaments-list{display:flex;flex-direction:column;gap:var(--space-sm)}.league-empty{text-align:center;color:var(--text-muted);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.league-tournament-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast)}.league-tournament-card:hover{border-color:var(--accent-primary)}.league-tournament-info{flex:1;min-width:0}.league-tournament-name{font-family:var(--font-display);font-weight:600;font-size:1rem;color:var(--text-primary)}.league-tournament-stats{display:flex;gap:var(--space-lg);align-items:center;font-size:.85rem;color:var(--text-secondary);margin-top:var(--space-xs)}.league-stat{display:flex;align-items:center;gap:var(--space-xs)}.league-stat svg{color:var(--accent-primary);opacity:.8}.league-tournament-current{border-color:var(--accent-primary);background:linear-gradient(135deg,rgba(0,240,255,.05),transparent)}.league-tournament-name-row{display:flex;align-items:center;gap:var(--space-sm)}.league-current-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;background:#00f0ff1a;color:var(--accent-primary);border:1px solid rgba(0,240,255,.3)}.tournament-banner{display:flex;align-items:center;padding:var(--space-xs);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);border-left:3px solid var(--accent-primary);min-height:46px;box-sizing:border-box}.tournament-banner[hidden]{display:none}.tournament-name{margin:0;padding:var(--space-sm) var(--space-lg);font-family:var(--font-display);font-size:.9rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.players-roles-view{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-lg);min-height:500px}.players-roles-view[hidden]{display:none}.role-column{display:flex;flex-direction:column;min-width:0;overflow:hidden}.role-column-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0;font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.role-column-header img{opacity:.9}.role-column[data-role=tank] .role-column-header{border-left:3px solid #facc15}.role-column[data-role=dps] .role-column-header{border-left:3px solid #ef4444}.role-column[data-role=support] .role-column-header{border-left:3px solid #22c55e}.role-column .table-container{flex:1;border-radius:0 0 var(--radius-lg) var(--radius-lg);max-height:calc(100vh - 300px);overflow-y:auto}.role-table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:auto}.role-table th,.role-table td{padding:var(--space-md) var(--space-lg);text-align:left;border-bottom:1px solid var(--border-color)}.role-table th{background:var(--bg-tertiary);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);position:sticky;top:0;z-index:10}.role-table tbody tr{transition:background var(--transition-fast);cursor:pointer}.role-table tbody tr:hover{background:#00f0ff08}.role-table tbody tr:last-child td{border-bottom:none}.role-table tbody tr.selected{background:#00f0ff1a;box-shadow:inset 3px 0 0 var(--accent-primary)}.role-table .col-name{min-width:100px;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-table .col-rating{width:90px;min-width:90px}.role-table .col-heroes{min-width:120px;overflow:hidden}.role-table .col-text{min-width:60px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.role-table.density-compact th,.role-table.density-compact td{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.role-table.density-normal th,.role-table.density-normal td{padding:var(--space-sm) var(--space-md);font-size:.85rem}.role-table.density-comfortable th,.role-table.density-comfortable td{padding:var(--space-md) var(--space-lg);font-size:.9rem}.filter-btn[data-view-mode].active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary)}@media (max-width: 1200px){.players-roles-view{grid-template-columns:1fr;gap:var(--space-md)}.role-column .table-container{max-height:300px}}.tournament-info-layout{max-width:900px;margin:0 auto;padding:var(--space-xl);display:flex;flex-direction:column;gap:var(--space-xl)}.tournament-header-section{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.tournament-info-name{margin:0;font-family:var(--font-display);font-size:1.75rem;font-weight:600;color:var(--text-primary)}.tournament-status-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.tournament-status-badge.status-draft{background:#64646433;color:var(--text-secondary);border:1px solid var(--border-color)}.tournament-status-badge.status-active{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.tournament-status-badge.status-completed{background:#00f0ff1a;color:var(--accent-primary);border:1px solid rgba(0,240,255,.3)}.tournament-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-lg)}.stat-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:border-color var(--transition-fast)}.stat-card:hover{border-color:var(--accent-primary)}.stat-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#00f0ff1a;border-radius:var(--radius-md);color:var(--accent-primary)}.stat-content{display:flex;flex-direction:column;gap:var(--space-xs)}.stat-value{display:flex;align-items:center;gap:var(--space-xs);font-family:var(--font-mono);font-size:1.5rem;font-weight:600;color:var(--text-primary)}.stat-rank-icon{width:20px;height:20px}.stat-label{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.tournament-section{display:flex;flex-direction:column;gap:var(--space-md)}.tournament-section .section-title{margin:0;font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.rating-distribution-chart{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.tier-bar-row{display:grid;grid-template-columns:140px 1fr 50px;align-items:center;gap:var(--space-md)}.tier-label{display:flex;align-items:center;gap:var(--space-sm)}.tier-icon{width:20px;height:20px}.tier-name{font-size:.85rem;color:var(--text-secondary)}.tier-bar-wrapper{height:20px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.tier-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease;min-width:2px}.tier-count{font-family:var(--font-mono);font-size:.85rem;font-weight:500;color:var(--text-primary);text-align:right}.tournament-links{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.link-row{display:flex;align-items:center;gap:var(--space-md)}.link-label{min-width:80px;font-size:.85rem;color:var(--text-secondary)}.link-value{color:var(--accent-primary);text-decoration:none;font-size:.9rem;transition:color var(--transition-fast)}.link-value:hover{color:var(--accent-secondary);text-decoration:underline}.link-placeholder{font-size:.9rem;color:var(--text-tertiary);font-style:italic}.bracket-link-wrapper{display:flex;align-items:center;gap:var(--space-sm);flex:1}.bracket-url-input{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;font-family:var(--font-mono)}.bracket-url-input:focus{outline:none;border-color:var(--accent-primary)}.bracket-url-input.error{border-color:var(--error);animation:shake .3s ease}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.btn-edit-bracket,.btn-save-bracket,.btn-cancel-bracket{padding:var(--space-xs);background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.btn-edit-bracket:hover{color:var(--accent-primary);background:#00f0ff1a}.btn-save-bracket:hover{color:#22c55e;background:#22c55e1a}.btn-cancel-bracket:hover{color:var(--error);background:#ef44441a}@media (max-width: 900px){.tournament-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 600px){.tournament-info-layout{padding:var(--space-lg)}.tournament-stats-grid{grid-template-columns:1fr}.tier-bar-row{grid-template-columns:100px 1fr 40px}.stat-card{padding:var(--space-md)}.stat-value{font-size:1.25rem}}.match-layout{padding:var(--space-lg);max-width:500px;margin:0 auto}.match-container{display:flex;flex-direction:column;gap:var(--space-xl)}.match-setup{display:flex;flex-direction:column;align-items:center;gap:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.match-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.match-subtitle{color:var(--text-secondary);font-size:.85rem;margin:0}.match-team-selectors{display:flex;flex-direction:column;align-items:center;gap:var(--space-md);width:100%}.match-team-select{display:flex;flex-direction:column;gap:var(--space-xs);width:100%;max-width:280px}.match-team-select label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.match-select{padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.9rem;cursor:pointer;transition:border-color .2s,box-shadow .2s;width:100%}.match-select:hover{border-color:var(--accent-primary)}.match-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px rgba(var(--accent-primary-rgb),.15)}.match-select option{background:var(--bg-secondary);color:var(--text-primary)}.match-vs{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-muted)}.match-start-btn{min-width:160px;padding:var(--space-sm) var(--space-lg);font-size:.9rem}.match-error{color:var(--color-error);font-size:.9rem;padding:var(--space-sm) var(--space-md);background:#ef44441a;border-radius:var(--radius-md);text-align:center}.match-error[hidden]{display:none}.match-role-assignment{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.match-players-list{display:flex;flex-direction:column;gap:var(--space-xs)}.match-player-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border-subtle)}.match-player-name{font-weight:500;font-size:.9rem;color:var(--text-primary)}.match-role-select{padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.85rem;min-width:100px}.match-role-select:disabled{opacity:.6;cursor:not-allowed}.match-role-select option{background:var(--bg-secondary);color:var(--text-primary)}.match-status{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);text-align:center;font-weight:500;font-size:.9rem}.match-status.waiting{background:#fbbf2426;color:var(--color-warning);animation:pulse 2s ease-in-out infinite}.match-status.info{background:#3b82f626;color:var(--color-info)}.match-status.success{background:#22c55e26;color:var(--color-success)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.match-submit-btn{align-self:center;min-width:160px;padding:var(--space-sm) var(--space-lg)}.match-invite-section{display:flex;flex-direction:column;gap:var(--space-xs);padding-top:var(--space-md);border-top:1px solid var(--border-subtle)}.match-invite-section label{font-size:.8rem;color:var(--text-secondary);font-weight:500}.match-invite-row{display:flex;gap:var(--space-xs)}.match-invite-input{flex:1;padding:var(--space-xs) var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-mono);font-size:.8rem}.match-copy-btn{white-space:nowrap;padding:var(--space-xs) var(--space-sm);font-size:.8rem}.match-results{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg)}.match-results-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:var(--space-md);align-items:start}.match-result-team{display:flex;flex-direction:column;gap:var(--space-xs)}.match-team-name{font-family:var(--font-display);font-size:.9rem;font-weight:600;color:var(--text-primary);margin:0;text-align:center;padding-bottom:var(--space-xs);border-bottom:2px solid var(--accent-primary)}.match-team-players{display:flex;flex-direction:column;gap:2px}.match-result-player{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--bg-elevated);border-radius:var(--radius-sm)}.match-role-icon{flex-shrink:0;width:16px;height:16px}.match-result-name{color:var(--text-primary);font-size:.85rem}.match-result-vs{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text-muted);align-self:center}.match-team-pending{color:var(--text-muted);font-style:italic;text-align:center;padding:var(--space-lg)}.match-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.match-header-row .match-title{margin-bottom:0}.match-reset-btn{font-size:.85rem;padding:var(--space-xs) var(--space-md)}.btn-outline{background:transparent;border:1px solid currentColor}.btn-outline:hover{background:#ffffff0d}.btn-danger{color:var(--color-error);border-color:var(--color-error)}.btn-danger:hover{background:#ef44441a}.match-history-section{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--border-color);width:100%}.match-history-title{font-family:var(--font-display);font-size:.85rem;font-weight:500;color:var(--text-secondary);margin:0 0 var(--space-sm) 0}.match-history-list{display:flex;flex-direction:column;gap:var(--space-xs)}.match-history-item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-sm);transition:border-color .2s ease}.match-history-item:hover{border-color:var(--accent-primary)}.match-history-teams{font-weight:500;font-size:.85rem;color:var(--text-primary);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.match-history-meta{font-size:.7rem;color:var(--text-muted);text-align:center;flex-shrink:0}.match-history-role{background:var(--bg-card);padding:2px var(--space-xs);border-radius:var(--radius-sm);font-size:.7rem}.match-resume-btn{flex-shrink:0;padding:var(--space-xs) var(--space-sm);font-size:.75rem}.btn-sm{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.match-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);color:var(--text-muted);text-align:center}@media (max-width: 500px){.match-layout{padding:var(--space-md)}.match-results-grid{grid-template-columns:1fr;gap:var(--space-md)}.match-result-vs{text-align:center}}.app-header[hidden],.app-main[hidden],.app-footer[hidden],[hidden]{display:none!important}.user-menu{position:relative;display:inline-block}.user-menu[hidden]{display:none!important}.user-menu .btn{display:flex;align-items:center;gap:var(--space-xs)}.user-menu #user-email{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu .dropdown-menu{position:absolute;top:100%;right:0;margin-top:var(--space-xs);min-width:180px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:var(--shadow-card);z-index:1000;padding:var(--space-xs) 0}.user-menu .dropdown-item{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--text-secondary);font-size:.875rem;cursor:pointer;transition:var(--transition-fast);text-align:left}.user-menu .dropdown-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.user-menu .dropdown-item svg{flex-shrink:0;opacity:.7}#login-btn{display:flex;align-items:center;gap:var(--space-xs);height:36px;padding:0 var(--space-md)}#login-btn svg{flex-shrink:0}#user-menu-btn{height:36px}.landing-page{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;z-index:9999;overflow:auto}.landing-page[hidden]{display:none!important}.landing-container{max-width:800px;width:100%;padding:var(--space-2xl);text-align:center}.landing-hero{margin-bottom:var(--space-2xl)}.landing-logo{font-family:var(--font-display);font-size:4rem;font-weight:700;letter-spacing:-.02em;margin-bottom:var(--space-md)}.landing-logo .logo-over{color:var(--text-primary)}.landing-logo .logo-draft{color:var(--accent-primary);text-shadow:0 0 30px var(--accent-primary)}.landing-tagline{font-size:1.25rem;color:var(--text-secondary);font-weight:300}.landing-options{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-xl);margin-bottom:var(--space-2xl)}@media (max-width: 700px){.landing-options{grid-template-columns:1fr}}.landing-card{background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;transition:var(--transition-normal);display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.landing-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow);transform:translateY(-4px)}.landing-card-icon{width:80px;height:80px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-radius:50%;color:var(--accent-primary);margin-bottom:var(--space-sm)}.landing-card h3{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0}.landing-card p{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.landing-card .btn{margin-top:auto;min-width:180px}.btn-discord{display:flex;align-items:center;gap:var(--space-xs);background:#5865f2;color:#fff;border:none;padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-weight:500;cursor:pointer;transition:var(--transition-fast)}.btn-discord:hover{background:#4752c4;transform:translateY(-1px)}.btn-discord svg{flex-shrink:0}.landing-share-input{display:flex;gap:var(--space-sm);width:100%;margin-top:var(--space-sm)}.landing-share-input input{flex:1;min-width:0;padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem}.landing-share-input input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--border-glow)}.landing-share-input .btn{flex-shrink:0;min-width:auto;margin-top:0}#landing-share-error{font-size:.85rem;margin-top:var(--space-sm);text-align:left}.landing-share-section{margin-bottom:var(--space-2xl)}.landing-divider{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-xl)}.landing-divider:before,.landing-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.landing-divider span{color:var(--text-muted);font-size:.9rem;text-transform:uppercase;letter-spacing:.05em}.landing-share-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg) var(--space-xl);max-width:500px;margin:0 auto}.landing-share-card h3{font-size:1rem;font-weight:500;color:var(--text-secondary);margin:0 0 var(--space-md) 0}.landing-footer{color:var(--text-muted);font-size:.9rem}@media (max-width: 768px){.landing-container{padding:var(--space-lg)}.landing-logo{font-size:2.5rem}.landing-share-input{flex-direction:column}.landing-share-input .btn{width:100%}}
