: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-sm{padding:var(--space-xs) var(--space-sm);font-size:.8rem}.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}.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}.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)}.theme-toggle{display:flex;gap:var(--space-sm)}.theme-btn{flex:1;padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-family:var(--font-display);font-size:.9rem;cursor:pointer;transition:all var(--transition-fast)}.theme-btn.active{border-color:var(--accent-primary);color:var(--accent-primary);background:#00f0ff0d}.settings-hint{font-size:.75rem;color:var(--text-muted);margin-top:var(--space-xs)}.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}@keyframes spin{to{transform:rotate(360deg)}}.btn-loader{width:16px;height:16px;border:2px solid transparent;border-top-color:currentColor;border-radius:50%;animation:spin .8s linear infinite}.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:fixed}#data-table .col-nickname{width:35%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}#data-table .col-role{width:15%}#data-table .col-rating{width:20%}#data-table .col-heroes{width:30%;overflow:hidden}#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 tbody tr{transition:background var(--transition-fast)}#data-table tbody tr:hover{background:#00f0ff08}#data-table tbody tr:last-child td{border-bottom:none}.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)}.github-link{display:flex;align-items:center;color:var(--text-muted);transition:color var(--transition-fast),opacity var(--transition-fast)}.github-link:hover{color:var(--text-primary);opacity:1}.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:space-between;align-items:center;margin-bottom:var(--space-lg);gap:var(--space-lg)}.tabs-nav{display:flex;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}.tabs-nav[hidden]{display:none}.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)}.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,minmax(320px,1fr));gap:var(--space-lg)}.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:flex;align-items:center;gap:var(--space-md);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;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{flex:1;font-size:.9rem;color:var(--text-primary)}.player-rating{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.player-rating.rank-badge .rank-icon{width:24px;height:24px}.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{display:grid;grid-template-columns:1fr 760px;gap:var(--space-xl);min-height:500px}@media (max-width: 1400px){.players-layout{grid-template-columns:1fr 500px}}@media (max-width: 1024px){.players-layout{grid-template-columns:1fr;gap:var(--space-lg)}}.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)}.players-details-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);display:flex;flex-direction:column;max-height:calc(100vh - 250px);overflow-y:auto}.players-details-panel .panel-title{font-size:.9rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-lg) 0;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}#player-details-content{flex:1}#player-details-content .player-details-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);text-align:center}.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-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{display:grid;grid-template-columns:1fr 760px;gap:var(--space-xl);min-height:500px}@media (max-width: 1400px){.teams-layout{grid-template-columns:1fr 500px}}@media (max-width: 1024px){.teams-layout{grid-template-columns:1fr;gap:var(--space-lg)}}.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)}.teams-details-panel{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-card);display:flex;flex-direction:column;max-height:calc(100vh - 250px);overflow-y:auto}.teams-details-panel .panel-title{font-size:.9rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--space-lg) 0;padding-bottom:var(--space-sm);border-bottom:1px solid var(--border-color)}#teams-player-details-content{flex:1}#teams-player-details-content .player-details-empty{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);text-align:center}.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}.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}.modal-content-wide{max-width:600px}#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}.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)}
