:root{--primary-bg: #121212;--secondary-bg: #1e1e1e;--primary-text: #ffffff;--secondary-text: #b3b3b3;--accent-color: #007bff}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;overflow-x:hidden}body{background-color:var(--primary-bg);color:var(--primary-text);font-family:Inter,Segoe UI,Arial,sans-serif;line-height:1.6}a{color:var(--accent-color);text-decoration:none}a:hover{text-decoration:underline}button{padding:10px 16px;font-size:16px;font-weight:700;background:var(--accent-color);color:#fff!important;border:none;border-radius:5px;cursor:pointer;transition:background .3s ease;margin:5px}button:hover{background:#0056b3}button:disabled{background:#4a4a4a!important;color:#888!important;cursor:not-allowed}.page-container{padding:20px;text-align:center}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff1a;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:4px;transition:background .3s ease}::-webkit-scrollbar-thumb:hover{background:#ffffff80}*{scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.button-row{display:flex;justify-content:center;gap:15px;flex-wrap:wrap}img{max-width:100%;height:auto;border-radius:10px}.info-banner{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#3b82f61a;border:1px solid var(--accent-color);color:var(--accent-color);border-radius:8px;margin-bottom:16px;font-size:.9rem}.info-banner .close-btn{background:transparent;border:none;color:var(--accent-color);font-size:1.2rem;cursor:pointer;padding:0 8px;margin:0}.info-banner .close-btn:hover{opacity:.7}.app-container{min-height:100vh;display:flex;flex-direction:column}.app-header{background-color:var(--secondary-bg);padding:0 20px;position:sticky;top:0;z-index:1000;box-shadow:0 2px 8px #0000004d}.header-content{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:60px}.logo{font-size:1.4rem;font-weight:700;color:var(--primary-text);text-decoration:none;display:flex;align-items:center;gap:8px}.logo:hover{text-decoration:none;color:var(--accent-color)}.year-gender-selector{position:relative;display:flex;align-items:center}.selector-toggle{background:var(--primary-bg);color:var(--primary-text);border:1px solid #444;border-radius:6px;padding:8px 14px;font-size:.95rem;font-weight:600;cursor:pointer;transition:border-color .2s ease,background-color .2s ease;display:flex;align-items:center;gap:6px}.selector-toggle:hover{border-color:var(--accent-color);background-color:#ffffff0d}.selector-panel{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:var(--secondary-bg);border:1px solid #444;border-radius:8px;padding:12px;box-shadow:0 4px 16px #0006;z-index:1001;min-width:180px}.gender-toggle{display:flex;gap:0;margin-bottom:12px;border-radius:6px;overflow:hidden;border:1px solid #444}.gender-btn{flex:1;padding:8px 16px;border:none;background:var(--primary-bg);color:var(--secondary-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .2s ease}.gender-btn:first-child{border-right:1px solid #444}.gender-btn:hover{background:#ffffff1a;color:var(--primary-text)}.gender-btn.active{background:var(--accent-color);color:#fff}.year-dropdown{width:100%;background:var(--primary-bg);color:var(--primary-text);border:1px solid #444;border-radius:6px;padding:8px 12px;font-size:.95rem;font-weight:600;cursor:pointer}.year-dropdown:hover{border-color:var(--accent-color)}.year-dropdown:focus{outline:none;border-color:var(--accent-color)}.nav-menu{display:flex;gap:8px}.nav-menu button{background:transparent;border:none;color:var(--primary-text);padding:8px 16px;font-size:.95rem;cursor:pointer;border-radius:4px;transition:all .2s ease}.nav-menu button:hover{background-color:var(--accent-color);color:#fff}.user-display{color:var(--secondary-text);padding:8px 16px;font-size:.9rem;display:flex;align-items:center;gap:6px;text-decoration:none;cursor:pointer;transition:color .2s ease}.user-display:hover{color:var(--primary-text);text-decoration:none}.logout-btn{background:transparent!important;color:#ff6b6b!important;border:1px solid #ff6b6b!important}.logout-btn:hover{background:#ff6b6b1a!important}.menu-toggle{display:none;background:transparent;border:none;color:var(--primary-text);font-size:1.5rem;cursor:pointer;padding:8px}.main-content{flex:1;padding:20px;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}.main-content:has(.full-bracket-container){max-width:100%;padding:0}@media(max-width:1050px){.menu-toggle{display:block}.nav-menu{display:none;position:absolute;top:60px;left:0;right:0;background-color:var(--secondary-bg);flex-direction:column;padding:10px;box-shadow:0 4px 8px #0000004d}.nav-menu.open{display:flex}.nav-menu button{width:100%;text-align:left;padding:12px 16px}.header-content{position:relative}}.how-it-works{background:var(--secondary-bg);padding:24px;border-radius:12px}.how-it-works h2{text-align:center;margin-bottom:24px;font-size:1.4rem}.steps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.step-card p{font-size:.9rem;color:var(--secondary-text);margin:0;line-height:1.4}@media(max-width:600px){.steps-grid{grid-template-columns:1fr}}.home-container{text-align:center}.hero-section{padding:60px 20px;background:linear-gradient(135deg,var(--secondary-bg) 0%,#2a2a2a 100%);border-radius:12px;margin-bottom:40px}.hero-section h1{font-size:2.5rem;margin-bottom:16px;color:var(--primary-text)}.tagline{font-size:1.2rem;color:var(--secondary-text);margin-bottom:32px}.cta-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}.primary-button,.secondary-button{padding:14px 28px;font-size:1.1rem;font-weight:700;border-radius:8px;text-decoration:none;transition:all .3s ease}.primary-button{background:var(--accent-color);color:#fff}.primary-button:hover{background:#0056b3;transform:translateY(-2px)}.secondary-button{background:transparent;color:var(--accent-color);border:2px solid var(--accent-color)}.secondary-button:hover{background:var(--accent-color);color:#fff}.info-section{padding:40px 20px}.info-section h2{font-size:1.8rem;margin-bottom:32px}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.step{background:var(--secondary-bg);padding:24px;border-radius:12px;text-align:center}.step-number{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--accent-color);color:#fff;border-radius:50%;font-size:1.2rem;font-weight:700;margin-bottom:16px}.step h3{margin-bottom:8px;color:var(--primary-text)}.step p{color:var(--secondary-text);font-size:.95rem}@media(max-width:768px){.hero-section h1{font-size:1.8rem}.tagline{font-size:1rem}}.password-input-wrapper{position:relative;display:flex;align-items:center}.password-input-wrapper input{width:100%;padding-right:45px}.password-toggle{position:absolute;right:8px;background:transparent;border:none;padding:6px 8px;cursor:pointer;opacity:.6;transition:opacity .2s ease;margin:0;display:flex;align-items:center;justify-content:center;color:var(--secondary-text)}.password-toggle:hover:not(:disabled){opacity:1;background:transparent}.password-toggle:disabled{cursor:not-allowed;opacity:.3}.password-toggle svg{display:block}.auth-container{display:flex;justify-content:center;align-items:center;min-height:70vh;padding:20px}.auth-card{background:var(--secondary-bg);border-radius:12px;padding:40px;width:100%;max-width:400px;box-shadow:0 4px 20px #0000004d}.auth-card h1{text-align:center;margin-bottom:8px;font-size:1.8rem}.auth-subtitle{text-align:center;color:var(--secondary-text);margin-bottom:24px}.auth-error{background:#dc354533;border:1px solid #dc3545;color:#ff6b6b;padding:12px;border-radius:6px;margin-bottom:16px;text-align:center;font-size:.9rem}.auth-success{background:#28a74533;border:1px solid #28a745;color:#51cf66;padding:12px;border-radius:6px;margin-bottom:16px;text-align:center;font-size:.9rem}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:.9rem;color:var(--secondary-text)}.form-group input{padding:12px 16px;border:1px solid #333;border-radius:6px;background:var(--primary-bg);color:var(--primary-text);font-size:1rem;transition:border-color .2s ease}.form-group input:focus{outline:none;border-color:var(--accent-color)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder{color:#666}.auth-button{background:var(--accent-color);color:#fff;padding:14px;font-size:1rem;font-weight:600;border:none;border-radius:6px;cursor:pointer;transition:background .2s ease,transform .1s ease;margin-top:8px}.auth-button:hover:not(:disabled){background:#0056b3;transform:translateY(-1px)}.auth-button:disabled{background:#4a4a4a;cursor:not-allowed;transform:none}.auth-switch{text-align:center;margin-top:20px;color:var(--secondary-text)}.auth-switch a{color:var(--accent-color);font-weight:600}.auth-switch a:hover{text-decoration:underline}.cross-gender-promo{margin-top:24px;padding:20px;background:#3b82f61a;border:1px solid var(--accent-color);border-radius:12px;text-align:center;margin-bottom:24px;position:relative}.create-bracket-btn{background-color:var(--accent-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;font-weight:600;cursor:pointer;font-size:1rem;transition:background-color .2s}.create-bracket-btn:hover{background-color:#0056b3}.cross-gender-promo .close-btn{position:absolute;top:10px;right:15px;background:none;border:none;color:var(--secondary-text);font-size:1.5rem;line-height:1;cursor:pointer;padding:0;opacity:.6;transition:opacity .2s,color .2s}.cross-gender-promo .close-btn:hover{opacity:1;color:var(--primary-text)}.coming-soon-container{display:flex;justify-content:center;align-items:center;min-height:60vh;padding:20px}.coming-soon-box{background:var(--secondary-bg);padding:40px;border-radius:16px;text-align:center;max-width:500px;box-shadow:0 4px 20px #0000004d}.coming-soon-box h2{margin-bottom:20px;font-size:1.5rem}.coming-soon-box p{margin-bottom:16px;color:var(--secondary-text);line-height:1.6}.coming-soon-box strong{color:var(--accent-color)}.coming-soon-box .update-note{margin-top:24px;padding-top:16px;border-top:1px solid rgba(255,255,255,.1);font-size:.9rem;color:var(--secondary-text)}@media(max-width:768px){.coming-soon-box{padding:24px}.coming-soon-box h2{font-size:1.3rem}}.leaderboard-selector{position:relative;width:100%;max-width:400px}.selector-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:12px 16px;background:#252525;border:2px solid rgba(255,255,255,.1);border-radius:8px;color:var(--primary-text);font-size:1rem;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.selector-toggle:hover{border-color:var(--accent-color);background:#2a2a2a;box-shadow:0 4px 8px #0003}.selector-toggle:disabled{opacity:.6;cursor:not-allowed}.selector-label{font-weight:500}.selector-arrow{transition:transform .2s ease}.selector-arrow.open{transform:rotate(180deg)}.selector-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--secondary-bg);border:1px solid rgba(255,255,255,.1);border-radius:8px;box-shadow:0 8px 24px #0006;z-index:100;max-height:350px;overflow:hidden;display:flex;flex-direction:column}.selector-search{padding:12px;border-bottom:1px solid rgba(255,255,255,.1)}.selector-search input{width:100%;padding:10px 12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--primary-text);font-size:.9rem}.selector-search input::placeholder{color:var(--secondary-text)}.selector-search input:focus{outline:none;border-color:var(--accent-color)}.selector-options{overflow-y:auto;max-height:280px}.selector-option{display:flex;flex-direction:column;align-items:flex-start;width:100%;padding:12px 16px;background:transparent;border:none;color:var(--primary-text);text-align:left;cursor:pointer;transition:background .2s ease}.selector-option:hover{background:#ffffff0d}.selector-option.selected{background:#3b82f61a}.selector-option.selected:hover{background:#3b82f626}.option-name{font-weight:500;margin-bottom:2px}.option-meta{font-size:.8rem;color:var(--secondary-text)}.selector-divider{padding:8px 16px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--secondary-text);background:#ffffff05;border-top:1px solid rgba(255,255,255,.05)}.selector-empty{padding:20px 16px;text-align:center;color:var(--secondary-text);font-size:.9rem}.selector-backdrop{position:fixed;inset:0;z-index:99}@media(max-width:768px){.leaderboard-selector{max-width:100%}.selector-toggle{padding:10px 14px;font-size:.9rem}.selector-dropdown{max-height:300px}}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:var(--secondary-bg);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 8px 32px #00000080}.modal-content.modal-small{max-width:380px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;color:var(--secondary-text);font-size:1.75rem;line-height:1;cursor:pointer;padding:0;transition:color .2s ease}.modal-close:hover{color:var(--primary-text)}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:24px}.modal-message{margin:0 0 20px;color:var(--secondary-text);line-height:1.5}.modal-message strong{color:var(--primary-text)}.modal-error{padding:12px 16px;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;margin-bottom:20px;font-size:.9rem}.form-group{margin-bottom:20px}.form-group:last-child{margin-bottom:0}.form-group label{display:block;margin-bottom:8px;font-weight:500;font-size:.9rem;color:var(--primary-text)}.form-group input,.form-group textarea{width:100%;padding:12px 14px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:8px;color:var(--primary-text);font-size:1rem;font-family:inherit;transition:border-color .2s ease}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--accent-color)}.form-group input:disabled,.form-group textarea:disabled{opacity:.6;cursor:not-allowed}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--secondary-text)}.form-group textarea{resize:vertical;min-height:80px}.form-hint{margin:8px 0 0;font-size:.8rem;color:var(--secondary-text)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid rgba(255,255,255,.1)}.btn-primary,.btn-secondary{padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s ease,opacity .2s ease}.btn-primary{background:var(--accent-color);border:none;color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:transparent;border:1px solid rgba(255,255,255,.2);color:var(--primary-text)}.btn-secondary:hover{background:#ffffff0d}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.modal-overlay{padding:10px;align-items:flex-end}.modal-content{max-height:80vh;border-bottom-left-radius:0;border-bottom-right-radius:0}.modal-header{padding:16px 20px}.modal-body{padding:20px}.modal-footer{padding:16px 20px}}.leaderboard-container{max-width:900px;margin:40px auto;padding:20px}.leaderboard-actions{display:flex;gap:12px;margin-bottom:16px}.action-button-wrapper{position:relative}.action-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--accent-color);border:none;border-radius:8px;color:#fff;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 6px #0003}.action-btn:hover:not(.disabled){filter:brightness(1.1);transform:translateY(-2px);box-shadow:0 6px 12px #0000004d}.action-btn.disabled{background:#3a3a3a;color:#888;opacity:.7;cursor:not-allowed;box-shadow:none;transform:none}.action-btn.danger-btn{background:#dc3545}.action-btn.danger-btn:hover:not(.disabled){background:#c82333;filter:none}.action-btn svg{flex-shrink:0}.action-tooltip{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);padding:8px 12px;background:#000000e6;border:1px solid rgba(255,255,255,.1);border-radius:6px;color:var(--primary-text);font-size:.8rem;white-space:nowrap;z-index:50;animation:fadeIn .2s ease}.action-tooltip:before{content:"";position:absolute;bottom:100%;left:50%;transform:translate(-50%);border:6px solid transparent;border-bottom-color:#000000e6}@keyframes fadeIn{0%{opacity:0;transform:translate(-50%) translateY(4px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.custom-lb-prompt{padding:12px 20px;border-radius:8px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;position:relative;box-shadow:0 2px 8px #0000001a;background-color:#f0f7ff;border:1px solid #cce5ff;color:#004085}.custom-lb-prompt .prompt-content{display:flex;flex-direction:column;gap:4px}.custom-lb-prompt strong{font-size:1.1em}@media(min-width:768px){.custom-lb-prompt .prompt-content{flex-direction:row;gap:12px;align-items:center}}.custom-lb-prompt .close-btn{color:currentColor!important;opacity:.6;background:none;border:none;font-size:1.5rem;cursor:pointer;line-height:1;padding:0 4px}.custom-lb-prompt .close-btn:hover{opacity:1}.leaderboard-controls{display:flex;align-items:center;gap:16px;margin-bottom:20px}.leaderboard-controls .selector-row{flex:1;margin-bottom:0}.leaderboard-controls .leaderboard-actions{margin-bottom:0}.leaderboard-header{display:flex;justify-content:space-around;background:var(--secondary-bg);padding:20px;border-radius:12px;margin-bottom:24px}.header-item{text-align:center}.header-label{display:block;font-size:.85rem;color:var(--secondary-text);margin-bottom:4px}.header-value{font-size:1.3rem;font-weight:700;color:var(--primary-text)}.loading-message,.empty-message{text-align:center;padding:40px;background:var(--secondary-bg);border-radius:12px}.empty-message h3{margin-bottom:8px}.empty-message p{color:var(--secondary-text)}.table-wrapper{overflow-x:auto;border-radius:12px;background:var(--secondary-bg)}.leaderboard-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.95rem}.leaderboard-table thead{background:#3a3a3a}.leaderboard-table th{padding:14px 12px;text-align:left;text-transform:uppercase;font-size:.75rem;font-weight:600;letter-spacing:.5px;color:var(--secondary-text)}.leaderboard-table th:first-child{border-top-left-radius:12px}.leaderboard-table th:last-child{border-top-right-radius:12px}.leaderboard-table td{padding:14px 12px;border-bottom:1px solid rgba(255,255,255,.1)}.leaderboard-table tbody tr:last-child td{border-bottom:none}.leaderboard-table tbody tr:last-child td:first-child{border-bottom-left-radius:12px}.leaderboard-table tbody tr:last-child td:last-child{border-bottom-right-radius:12px}.leaderboard-table tbody tr:nth-child(2n){background:#ffffff08}.leaderboard-table tbody tr.clickable{cursor:pointer;transition:background .2s ease}.leaderboard-table tbody tr.clickable:hover{background:#3b82f61a}.leaderboard-table tbody tr.user-row{background:#3b82f626}.leaderboard-table tbody tr.user-row:hover{background:#3b82f633}.rank-cell{font-weight:700;text-align:center!important;min-width:50px}.score-cell{font-weight:600;color:var(--accent-color)}.champion-cell{text-align:center}.champion-cell img{width:36px;height:36px;border-radius:50%;object-fit:cover}.hidden-champion{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:#ffffff1a;color:var(--secondary-text)}.hidden-champion svg{opacity:.6}.leaderboard-table tbody tr.locked{cursor:not-allowed;opacity:.85}.leaderboard-table tbody tr.locked:hover{background:inherit}.leaderboard-table tbody tr.locked:nth-child(2n):hover{background:#ffffff08}.info-note{text-align:center;margin-top:20px;padding:12px;background:#ffffff0d;border-radius:8px;color:var(--secondary-text);font-size:.9rem}@media(max-width:768px){.leaderboard-container{margin:20px auto;padding:12px}.leaderboard-controls{flex-direction:column;align-items:stretch}.leaderboard-controls .selector-row{width:100%}.leaderboard-actions{flex-direction:row;width:100%}.action-btn{flex:1;justify-content:center}.action-tooltip{left:50%;transform:translate(-50%);white-space:normal;text-align:center;max-width:200px}.selector-row{margin-bottom:16px}.leaderboard-header{flex-direction:column;gap:16px;padding:16px}.header-value{font-size:1.1rem}.leaderboard-table th,.leaderboard-table td{padding:10px 8px;font-size:.85rem}.champion-cell img{width:28px;height:28px}}.info-container{text-align:center}.info-container h1{text-align:center;margin-bottom:16px}.intro-text{text-align:center;font-size:1.1rem;color:var(--secondary-text);margin-bottom:40px;line-height:1.6}.intro-text strong{color:var(--accent-color)}.info-section{background:var(--secondary-bg);padding:24px;border-radius:12px;margin-bottom:24px;text-align:center}.info-section h2{margin-bottom:20px;font-size:1.3rem}.info-section p{color:var(--secondary-text);line-height:1.6;margin-bottom:12px}.info-section p:last-child{margin-bottom:0}.info-section a{color:var(--accent-color);text-decoration:none}.info-section a:hover{text-decoration:underline}.info-section strong{color:var(--primary-text)}.steps-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.step-card{background:#ffffff0d;padding:20px;border-radius:10px;text-align:center}.step-number{display:inline-flex;width:36px;height:36px;background:var(--accent-color);color:#fff;font-weight:700;font-size:1.1rem;border-radius:50%;align-items:center;justify-content:center;margin-bottom:12px}.step-card h3{font-size:1rem;margin-bottom:8px}.step-card p{font-size:.9rem;color:var(--secondary-text);margin:0}.scoring-intro{color:var(--secondary-text);margin-bottom:20px;line-height:1.5}.scoring-table-wrapper{overflow-x:auto}.scoring-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.95rem;background:#ffffff08;border-radius:8px;overflow:hidden}.scoring-table th{background:#3a3a3a;padding:12px 16px;text-align:left;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px;color:var(--secondary-text)}.scoring-table td{padding:12px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.scoring-table tbody tr:last-child td{border-bottom:none}.scoring-table tbody tr:hover{background:#ffffff0d}.scoring-table .championship-row{background:#3b82f61a}.scoring-table .total-row{background:#ffffff14}.scoring-table .total-row td{border-top:2px solid rgba(255,255,255,.2)}.cta-section{text-align:center;margin-top:40px}.primary-button{display:inline-block;padding:14px 32px;background:var(--accent-color);color:#fff;text-decoration:none;border-radius:8px;font-weight:600;font-size:1.1rem;transition:all .2s ease}.primary-button:hover{background:#2563eb;transform:translateY(-2px)}@media(max-width:768px){.info-container{padding:24px 16px}.info-section{padding:20px 16px}.steps-grid{grid-template-columns:1fr}.scoring-table th,.scoring-table td{padding:10px 12px;font-size:.85rem}}.image-container{position:relative;display:inline-block;margin-bottom:16px}.team-card .image-container img,.region-winner-image.image-container img{margin-bottom:0}.magnify-icon{position:absolute;bottom:8px;right:8px;background:#0009;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:.7;transition:opacity .2s,background .2s,transform .2s;z-index:10}.magnify-icon:hover{opacity:1;background:#000c;transform:scale(1.1)}.image-modal-overlay{position:fixed;inset:0;background:#000000e6;z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease}.image-modal-content{position:relative;max-width:90vw;max-height:90vh;animation:scaleIn .3s ease;display:flex;justify-content:center;align-items:center}.modal-image{max-width:100%;max-height:90vh;object-fit:contain;border-radius:8px;box-shadow:0 10px 40px #00000080;display:block}.close-modal-btn{position:absolute;top:10px;right:10px;background:#00000080;border-radius:50%;border:none;color:#fff;cursor:pointer;padding:8px;transition:transform .2s,background .2s;display:flex;align-items:center;justify-content:center;z-index:20}.close-modal-btn:hover{transform:scale(1.1);background:#000c;color:var(--accent-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.winner-selection-container{max-width:900px;margin:0 auto;padding:20px;text-align:center}.winner-selection-container h2{font-size:1.8rem;margin-bottom:8px}.current-region{color:var(--secondary-text);margin-bottom:30px}.no-data-message{background:var(--secondary-bg);padding:40px;border-radius:12px;margin-top:40px}.no-data-message h2{margin-bottom:16px}.no-data-message p{color:var(--secondary-text);margin-bottom:8px}.matchup{display:flex;justify-content:center;align-items:center;gap:30px;margin-bottom:40px;flex-wrap:wrap}.team-card{background:var(--secondary-bg);border-radius:16px;padding:30px;width:280px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;border:2px solid transparent;height:350px;display:flex;flex-direction:column;justify-content:center;align-items:center}.team-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #0000004d;border-color:var(--accent-color)}.team-card img{width:150px;height:150px;object-fit:contain;margin-bottom:16px}.team-card .mascot-name{font-size:1.2rem;font-weight:700;margin-bottom:4px;color:var(--primary-text)}.team-card .team-name{color:var(--accent-color);font-size:1rem;font-weight:600}.vs{font-size:1.5rem;font-weight:700;color:var(--secondary-text);padding:0 10px}.progress-container{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;margin-top:30px}.progress-box{background:var(--secondary-bg);padding:12px 20px;border-radius:8px;min-width:100px;border:2px solid transparent;transition:border-color .2s ease,background .2s ease;cursor:pointer}.progress-box:hover{background:#333}.progress-box.active{border-color:var(--accent-color)}.progress-box.complete{background:#22c55e1a}.progress-box.complete .progress-text{color:#22c55e}.progress-box .region-title{display:block;font-size:.85rem;color:var(--secondary-text);margin-bottom:4px}.progress-box .progress-text{font-size:1.1rem;font-weight:600}.region-winner-display{background:var(--secondary-bg);padding:40px;border-radius:16px;max-width:400px;margin:0 auto 30px}.region-winner-display h3{margin-bottom:20px;font-size:1.4rem}.region-winner-image{width:180px;height:180px;object-fit:contain;margin-bottom:16px}.region-winner-display .mascot-name{font-size:1.3rem;font-weight:700;margin-bottom:4px}.split-team-card{padding:0;display:flex;flex-direction:column;overflow:hidden;justify-content:space-between;height:350px}.sub-team{flex:1;display:flex;align-items:center;justify-content:space-between;padding:10px 20px;transition:background .2s}.sub-team-info{text-align:left;display:flex;flex-direction:column;justify-content:center;flex:1;padding-right:10px}.sub-team img{width:90px;height:90px;margin:0;object-fit:contain}.sub-team .team-name{font-size:1rem;margin-bottom:2px;color:var(--accent-color);font-weight:600}.sub-team .mascot-name{font-size:.9rem;font-weight:700;color:var(--primary-text);margin-bottom:0}.split-divider{height:1px;background:#ffffff1a;width:100%;margin:0}.region-winner-display .team-name{color:var(--accent-color);font-size:1.1rem;font-weight:600;margin-bottom:16px}.winner-message{color:var(--secondary-text);font-size:.9rem;font-style:italic}.champion-display{background:var(--secondary-bg);padding:40px;border-radius:16px;max-width:500px;margin:0 auto}.champion-display h2{margin-bottom:16px}.champion-display .mascot-name{color:var(--accent-color);font-size:1.2rem;font-weight:600;margin-bottom:20px}.champion-image{width:200px;height:200px;object-fit:contain;margin:20px 0}.bracket-form{margin-top:30px}.bracket-form .form-group{margin-bottom:20px;text-align:left}.bracket-form label{display:block;margin-bottom:6px;color:var(--secondary-text)}.bracket-form input{width:100%;padding:12px;border:1px solid #444;border-radius:6px;background:var(--primary-bg);color:var(--primary-text);font-size:1rem}.bracket-form input:disabled{opacity:.6}.button-group{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:20px}.primary-btn{background:var(--accent-color);color:#fff;border:none;padding:12px 24px;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s ease}.primary-btn:hover:not(:disabled){background:#0056b3}.primary-btn:disabled{background:#4a4a4a;cursor:not-allowed}.secondary-btn{background:transparent;color:var(--primary-text);border:1px solid #444;padding:12px 24px;border-radius:6px;font-weight:600;cursor:pointer;transition:border-color .2s ease}.secondary-btn:hover{border-color:var(--accent-color)}.cutoff-warning-banner{background:#f59e0b26;border:1px solid #f59e0b;color:#fbbf24;padding:14px 18px;border-radius:8px;margin-bottom:20px;font-size:.95rem;font-weight:500;text-align:center}.secondary-btn:disabled{opacity:.5;cursor:not-allowed;border-color:#444}.secondary-btn:disabled:hover{border-color:#444}.play-in-info{max-width:600px;margin:30px auto 0;padding:20px;background:#3b82f60d;border:1px solid rgba(59,130,246,.3);border-radius:12px;text-align:left;color:var(--secondary-text);font-size:.95rem;line-height:1.5}.play-in-info p{margin-bottom:12px}.play-in-info p:last-child{margin-bottom:0}.play-in-info strong{color:var(--primary-text);font-weight:600}.play-in-info .cutoff-note{font-style:italic;color:var(--accent-color);margin-top:8px}.cross-gender-promo{margin-top:24px;padding:20px;background:#3b82f61a;border:1px solid var(--accent-color);border-radius:12px;text-align:center}.cross-gender-promo p{margin-bottom:12px;color:var(--primary-text);font-size:1.1rem;font-weight:500}@media(max-width:768px){.matchup{flex-direction:column;gap:20px}.team-card{width:100%;max-width:280px}.vs{padding:10px 0}.progress-container{gap:8px}.progress-box{min-width:70px;padding:10px 12px}.progress-box .region-title{font-size:.75rem}}.leave-warning-overlay{position:fixed;inset:0;background:#000000d9;z-index:1100;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.leave-warning-modal{background:var(--secondary-bg);border-radius:16px;padding:32px 40px;max-width:400px;width:90%;text-align:center;animation:scaleIn .2s ease;border:1px solid rgba(255,255,255,.1);box-shadow:0 20px 60px #00000080}.leave-warning-icon{font-size:3rem;margin-bottom:16px}.leave-warning-modal h3{font-size:1.5rem;margin-bottom:12px;color:var(--primary-text)}.leave-warning-modal p{color:var(--secondary-text);font-size:1rem;line-height:1.5;margin-bottom:24px}.leave-warning-buttons{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.stay-btn{background:var(--accent-color);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s ease,transform .2s ease;flex:1;min-width:120px}.stay-btn:hover{background:#0056b3;transform:translateY(-2px)}.leave-btn{background:transparent;color:var(--secondary-text);border:1px solid #444;padding:12px 24px;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:border-color .2s ease,color .2s ease;flex:1;min-width:120px}.leave-btn:hover{border-color:#ef4444;color:#ef4444}@media(max-width:480px){.leave-warning-modal{padding:24px 20px}.leave-warning-buttons{flex-direction:column}.stay-btn,.leave-btn{width:100%}}.previous-pick-star{color:var(--accent-color);font-weight:700;margin-left:4px;font-size:1.2rem;vertical-align:middle;text-shadow:0 0 8px rgba(0,123,255,.4)}.matchup-pair{margin:4px 0}.matchup-box{background:var(--secondary-bg);border-radius:4px;overflow:hidden;min-width:150px}.matchup-box .team{padding:6px 10px;font-size:.75rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-bottom:1px solid #333;display:flex;align-items:center;justify-content:space-between;gap:4px}.matchup-box .team:last-child{border-bottom:none}.matchup-box .top-team{background:#3b82f61a}.matchup-box .bottom-team{background:#3b82f60d}.matchup-box .team .team-name{flex:1;overflow:hidden;text-overflow:ellipsis}.matchup-box .team .team-score{font-size:.7rem;font-weight:600;color:var(--muted-text, #888);margin-right:2px}.matchup-box .team.winner .team-name,.matchup-box .team .actual-team.winner{font-weight:700}.status-icon{flex-shrink:0;font-size:.85rem;margin-right:4px}.matchup-box .team.correct{background:#22c55e26}.matchup-box .team.correct .correct-icon{color:#22c55e;font-weight:700}.matchup-box .team.loser{background:#ef444414}.matchup-box .team.loser .loser-icon{color:#ef4444;font-weight:700;opacity:.7}.matchup-box .team.wrong-team{background:#ef44441a;padding:4px 10px}.matchup-box .team.wrong-team .wrong-team-display{display:flex;flex-direction:column;gap:2px;width:100%}.matchup-box .team.wrong-team .wrong-team-pick-row{display:flex;align-items:center;gap:4px}.matchup-box .team.wrong-team .loser-icon{color:#ef4444;font-weight:700}.matchup-box .team.wrong-team .strikethrough-pick{text-decoration:line-through;color:#ef4444;opacity:.7;font-size:.7rem}.matchup-box .team.wrong-team .actual-team-row{display:flex;align-items:center;justify-content:space-between;gap:4px}.matchup-box .team.wrong-team .actual-team{color:var(--text-color, #fff);font-size:.75rem;flex:1}.matchup-box .team.wrong-team .actual-team.winner{font-weight:700}.matchup-box .team.wrong-team .team-score{font-size:.7rem;font-weight:600;color:var(--muted-text, #888)}.matchup-box .team.pending{opacity:.8}.bracket-segment{display:flex;gap:12px;align-items:stretch;height:600px}@media(min-width:1200px){.bracket-segment.reversed{flex-direction:row-reverse}}.round{display:flex;flex-direction:column}.round-header{font-size:.75rem;color:var(--secondary-text);text-align:center;margin-bottom:8px}.matchups-column{display:flex;flex-direction:column;flex:1}.matchup-wrapper{flex:1;display:flex;align-items:center;justify-content:center}.full-bracket-container{padding:20px;overflow-x:auto;width:100%;max-width:none!important;margin:0!important}.full-bracket-container h2{text-align:center;margin-bottom:24px}.bracket-layout{display:flex;justify-content:space-between;gap:16px;width:100%}.bracket-side{display:flex;flex-direction:column;gap:40px}.region-wrapper{background:#1e1e1e80;padding:16px;border-radius:12px}.region-wrapper h3{text-align:center;margin-bottom:12px;font-size:1.1rem}.region-wrapper.reverse h3{text-align:center}.final-four-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;min-width:300px;flex-shrink:0}.final-four-section h3{margin-bottom:8px}.final-four-matchups{display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:center}.ff-matchup{display:flex;flex-direction:column;align-items:center}.ff-matchup.championship{margin:0 8px}.ff-label{display:block;font-size:.7rem;color:var(--secondary-text);text-align:center;margin-bottom:4px;text-transform:uppercase;letter-spacing:1px}.champion-display{background:var(--secondary-bg);padding:16px 24px;border-radius:12px;text-align:center;margin-bottom:16px}.champion-display h3{margin-bottom:12px}.champion-image{width:100px;height:100px;object-fit:contain;margin:12px 0}.champion-name{font-size:1rem;font-weight:600;margin-bottom:4px}.champion-mascot{color:var(--accent-color);font-size:.9rem;text-transform:capitalize}.full-bracket-container .info-banner{text-align:center;margin-top:24px;padding:12px;background:#3b82f61a;border:1px solid var(--accent-color);color:var(--accent-color);border-radius:6px;max-width:400px;margin-left:auto;margin-right:auto}.no-data-message{text-align:center;padding:40px;background:var(--secondary-bg);border-radius:12px;max-width:400px;margin:40px auto}@media(max-width:1200px){.bracket-layout{flex-direction:column;align-items:center}.bracket-center{order:-1}.bracket-side{width:100%;max-width:600px}}@media(max-width:768px){.full-bracket-container,.region-wrapper{padding:12px}.region-wrapper h3{font-size:.95rem}}.shared-bracket-header{text-align:center;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid rgba(255,255,255,.1)}.shared-bracket-header h2{margin-bottom:4px}.shared-bracket-header .bracket-owner{color:var(--secondary-text);margin-bottom:12px}.shared-bracket-header .back-link,.bracket-error .back-link{color:var(--accent-color);text-decoration:none;font-size:.9rem}.shared-bracket-header .back-link:hover,.bracket-error .back-link:hover{text-decoration:underline}.bracket-error{text-align:center;padding:60px 20px}.bracket-error h2{margin-bottom:8px}.bracket-error p{color:var(--secondary-text);margin-bottom:20px}.history-table-container{margin-top:20px}.loading-text,.no-history{text-align:center;padding:30px;background:var(--secondary-bg);border-radius:12px;color:var(--secondary-text);font-style:italic}.empty-state{display:flex;flex-direction:column;align-items:center;gap:16px;padding:30px;background:var(--secondary-bg);border-radius:12px}.no-history{background:none;padding:0;margin:0}.create-bracket-btn{background:var(--accent-color);color:#fff;border:none;padding:14px 28px;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0003}.create-bracket-btn:hover{background:#0056b3;transform:translateY(-2px);box-shadow:0 4px 8px #0000004d}.table-wrapper{overflow-x:auto;border-radius:12px;background:var(--secondary-bg);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.history-table{width:100%;border-collapse:separate;border-spacing:0;font-size:.95rem}.history-table thead{background:#2d3748}.history-table th{padding:16px;text-align:left;text-transform:uppercase;font-size:.75rem;font-weight:700;letter-spacing:.05em;color:var(--secondary-text);border-bottom:2px solid rgba(255,255,255,.05)}.history-table td{padding:16px;border-bottom:1px solid rgba(255,255,255,.05);vertical-align:middle}.history-table tbody tr{transition:all .2s ease}.history-table tbody tr:nth-child(2n){background:#ffffff05}.history-table tbody tr.clickable{cursor:pointer}.history-table tbody tr.clickable:hover{background:#3b82f61a;transform:translateY(-1px)}.year-cell{font-weight:600;color:var(--accent-color)}.score-cell{font-weight:700;color:var(--accent-color);text-align:right;padding-right:24px}.history-table th:last-child{text-align:right;padding-right:24px}.champion-cell{text-align:center;width:60px}.history-table th:nth-child(2){text-align:center}.champion-cell img{width:36px;height:36px;border-radius:50%;object-fit:cover;border:2px solid rgba(255,255,255,.1)}@media(max-width:640px){.history-table th,.history-table td{padding:12px 8px;font-size:.85rem}.champion-cell img{width:30px;height:30px}}.profile-container{display:flex;justify-content:center;align-items:center;min-height:80vh;padding:20px}.profile-card{background:var(--secondary-bg);padding:40px;border-radius:16px;width:100%;max-width:800px;box-shadow:0 4px 20px #0000004d;border:1px solid rgba(255,255,255,.05)}.profile-header{display:flex;flex-direction:column;align-items:center;margin-bottom:30px}.profile-avatar{width:80px;height:80px;background:var(--accent-color);border-radius:50%;display:flex;justify-content:center;align-items:center;font-size:2.5rem;font-weight:700;color:#fff;margin-bottom:16px;box-shadow:0 0 15px #3b82f680}.profile-header h1{font-size:1.8rem;margin:0}.profile-details{display:flex;flex-direction:column;gap:20px;margin-bottom:30px}.detail-item{background:#ffffff08;padding:16px;border-radius:8px;border:1px solid rgba(255,255,255,.05)}.detail-item label{display:block;font-size:.8rem;color:var(--secondary-text);margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}.detail-item .detail-value{font-size:1.1rem;font-weight:500}.profile-actions{display:flex;flex-direction:column;gap:16px;align-items:center}.profile-btn{width:100%;padding:12px;border-radius:8px;border:none;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;text-decoration:none}.profile-btn.danger{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.2)}.profile-btn.danger:hover{background:#ef444433}.profile-btn.secondary{background:var(--accent-color);color:#fff}.profile-link{color:var(--secondary-text);text-decoration:none;font-size:.9rem}.profile-link:hover{color:var(--primary-text);text-decoration:underline}#root{width:100%;min-height:100vh}
