body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.App{display:flex;flex-direction:column;height:100vh;font-family:Arial,Helvetica,sans-serif;box-sizing:border-box}.bracket{flex-grow:1;display:flex;flex-direction:column;margin-right:20px;overflow:hidden}.draw-tabs{display:flex;margin-bottom:4px}.draw-tabs button{flex:1;padding:10px;border:none}.draw-tabs button.active{background-color:#e0e0e0;font-weight:700}.quarter-tabs{display:flex;margin-bottom:20px;font-weight:700}.quarter-tabs button{flex:1;padding:10px;border:none;background-color:#f0f0f0;cursor:pointer;font-weight:700}.quarter-tabs button.active{background-color:#e0e0e0;font-weight:700}.bracket-container{display:flex;overflow-x:auto;overflow-y:auto;position:relative;height:calc(100% - 100px)}.round{position:relative;width:220px;display:flex;flex-direction:column;margin-right:20px}.match{position:absolute;width:300px;display:flex;flex-direction:column;margin-bottom:10px;box-sizing:border-box}.match div,.future-match{cursor:pointer;padding:5px;margin:2px 0;background-color:#f0f0f0;border:1px solid #ccc;border-radius:3px;height:24px;line-height:24px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:14px}.match div.winner{animation:buttonPress .2s ease-in-out}.future-match{cursor:default;display:flex;justify-content:center;align-items:center;background-color:#f0f0f0;border:1px solid #ccc;cursor:pointer}.round:not(:first-child) .match{height:auto;justify-content:center}.upsets{display:flex;flex-direction:column;height:100%;width:480px;flex-shrink:0;max-width:100vw;padding:0 0 0 8px;border-left:none;border-top:none;margin-top:0;background:#fff;overflow:hidden}.upsets-main-content{flex:1 1 0;min-height:0;overflow-y:auto}.upsets-footer{display:flex;flex-direction:row;align-items:center;justify-content:flex-start;height:60px;background:#fff;border-top:1px solid #ccc;padding:4px}.upsets-summary{display:flex;flex-direction:column;gap:4px;margin-left:12px;align-items:flex-start}.upsets-summary-item{display:flex;margin-bottom:4px}.summary-label{width:80px;text-align:left;flex-shrink:0}.summary-count{font-weight:700}.count-mismatch{color:#f73636}.upsets-only-selected{margin-left:32px;padding:0}.upsets-only-selected-button{padding:0;margin:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-sizing:border-box}.current-upset{background-color:#ffe6e6;padding:10px;margin-bottom:10px;border:2px dashed #ffcccc;border-radius:5px}.upset-item{background-color:#e6f3ff;padding:5px;margin:5px 0;border-radius:3px;font-size:14px}.spacer-round{display:flex;flex-direction:column;justify-content:space-around;height:100%}.spacer-match{height:60px}.valid-drop-target{background-color:#e6ffe6;border:2px dashed #4CAF50}.submit-button{margin-top:0;padding:10px 20px;background-color:#4caf50;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:16px}.submit-button:hover{background-color:#45a049}.submit-button:disabled{background-color:#ccc}.button-pressed{animation:buttonPress .2s ease-in-out}@keyframes buttonPress{0%{transform:scale(1)}50%{transform:scale(.95)}to{transform:scale(1)}}.login-container{background-color:#fafad2;min-height:100vh;width:100%;display:flex;flex-direction:column;align-items:center}.impersonate-banner{background-color:#ff9800;color:#fff;text-align:center;padding:6px 12px;font-weight:700;font-size:14px}.app-header{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background-color:#f4f7a9;border-bottom:4px solid #ccc;border-right:4px solid #ccc}.header-left{display:flex;align-items:center}.title-text{display:flex;flex-direction:column}.title-text h1{margin:0 320px 0 8px;font-size:2rem}.title-text h2{margin:0 0 0 8px;font-size:1.5rem}.header-controls{display:flex;flex-direction:column;gap:4px;align-items:flex-end}.header-controls-top{display:flex;gap:4px;align-items:center}.header-controls select{padding:4px 8px;border:1px solid #ccc;border-radius:4px;background-color:#fff;min-width:120px;height:24px}.header-controls-buttons{display:flex;flex-wrap:wrap;gap:4px;justify-content:flex-end}.header-controls-buttons button,.header-controls-top button{padding:4px 8px;border:1px solid #ccc;border-radius:4px;background-color:#fff;cursor:pointer;white-space:nowrap;height:24px;display:flex;align-items:center}.header-controls-buttons button:hover,.header-controls-top button:hover{background-color:#f0f0f0}.header-controls-buttons button:disabled,.header-controls-top button:disabled{background-color:#f0f0f0;opacity:.5;cursor:not-allowed}.app-main{display:flex;flex-direction:row;flex-grow:1;height:calc(100vh - 120px);padding:20px;overflow:hidden;min-height:0;overflow-y:auto}.bracket{flex:1 1 0;min-width:0;margin-right:20px;display:flex;flex-direction:column}.random-picks-button{position:absolute;top:10px;right:10px;z-index:1000;padding:12px;background-color:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:700;font-size:16px;box-shadow:0 2px 4px #0003;transition:all .2s ease;display:flex;align-items:center;gap:8px}.random-picks-button .dice-icon{width:48px;height:48px;object-fit:contain}.random-picks-button:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #0003}.random-picks-button:disabled{cursor:not-allowed;opacity:.5;transform:none;box-shadow:none}.header-title{display:flex;align-items:center}.header-image{height:128px;margin-right:10px}.header-title h1{margin:100}.header-controls{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.results-page{padding:20px;max-width:800px;margin:0 auto}.results-page h1{color:#333;margin-bottom:20px}.results-page pre{background-color:#f4f4f4;padding:15px;border-radius:5px;overflow-x:auto}.bracket-container-32{display:flex;overflow-x:auto;overflow-y:auto;position:relative;height:calc(100% - 60px)}.bracket-container-64{display:flex;overflow-x:auto;overflow-y:auto;position:relative;height:calc(100% - 100px)}.round-32{width:280px}.round-64{width:250px}.tournament-winner{position:relative;width:200px;padding:15px;margin:20px;background-color:#f8f8f8;border:2px solid #4CAF50;border-radius:8px;text-align:center;align-self:center;flex-shrink:0}.winner-label{font-size:14px;color:#666;margin-bottom:8px;text-transform:uppercase}.winner-name{font-size:16px;font-weight:700;color:#333}.login-controls{margin-top:20px;display:flex;flex-direction:column;gap:15px;align-items:center;width:100%;padding:20px}.google-signin-button{padding:12px 24px;font-size:14px;cursor:pointer;background:#040404;color:#fff;border:none;border-radius:4px;font-weight:500}.google-signin-button:hover{background:#0c4a87}.google-signin-button:disabled{opacity:.7;cursor:not-allowed}.auth-divider{display:flex;align-items:center;width:100%;max-width:300px;margin:10px 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid #ccc}.auth-divider span{padding:0 15px;color:#666;font-size:14px}.email-auth-form{display:flex;flex-direction:column;gap:12px;width:100%;max-width:300px}.auth-input{padding:12px;border:1px solid #ccc;border-radius:6px;font-size:14px;width:100%;box-sizing:border-box}.auth-input:focus{outline:none;border-color:#4285f4;box-shadow:0 0 0 2px #4285f433}.auth-submit-button{padding:12px;background:#040404;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer}.auth-submit-button:hover{background:#0c4a87}.auth-submit-button:disabled{opacity:.7;cursor:not-allowed}.auth-links{display:flex;justify-content:space-between;margin-top:4px}.auth-links button{background:none;border:none;color:#3b3b3b;cursor:pointer;font-size:13px;padding:0}.auth-links button:hover{text-decoration:underline}.auth-reset-text{font-size:14px;color:#666;margin:0 0 8px;text-align:center}.auth-error{color:#d32f2f;background:#ffebee;padding:10px;border-radius:4px;font-size:14px;text-align:center;max-width:300px}.auth-message{color:#2e7d32;background:#e8f5e9;padding:10px;border-radius:4px;font-size:14px;text-align:center;max-width:300px}.guest-access-buttons{margin-top:10px;padding-top:0;text-align:center}.guest-buttons{display:flex;gap:15px;justify-content:center}.guest-button{padding:4px 8px;border:1px solid #ccc;border-radius:4px;cursor:pointer;white-space:nowrap;height:24px;display:flex;align-items:center;font-size:12px;transition:background-color .2s}.guest-button:hover{background-color:#f0f0f0}.loading-container{display:flex;justify-content:center;align-items:center;width:100%;height:100%;background-color:#fffc}@keyframes loadingPulse{0%{opacity:.6}50%{opacity:1}to{opacity:.6}}.loading-spinner{padding:20px;background-color:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;font-size:18px;color:#333;animation:loadingPulse 1.5s infinite ease-in-out}.how-to-play-section{padding:10px;border:1px solid #ccc;border-radius:5px}.how-to-play-section h3{margin-bottom:10px;font-weight:700}.how-to-play-section p{margin-bottom:5px;text-indent:10px}.how-to-play-upset-definition{margin-left:10px;font-size:12px}.how-to-play-upset-definition ul{margin-top:0;margin-bottom:0;padding-left:20px}.how-to-play-upset-definition li{margin-bottom:3px}.how-to-play-separator{margin-top:16px;margin-bottom:10px;border-top:1px solid #ccc}.fast-mode-container{padding:20px;max-width:1200px;margin:0 auto}.upset-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:20px}.upset-card{border:1px solid #ccc;border-radius:8px;padding:15px;background-color:#fff;box-shadow:0 2px 4px #0000001a}.upset-card h3{margin:0 0 10px;color:#333}.upset-card p{margin:0 0 15px;font-size:1.1em}.upset-actions{display:flex;gap:10px}.upset-actions button{padding:8px 16px;border:none;border-radius:4px;cursor:pointer;font-weight:700}.upset-actions button:first-child{background-color:#4caf50;color:#fff}.upset-actions button:last-child{background-color:#f44336;color:#fff}.upset-actions button:hover{opacity:.9}.countdown-timer{font-size:.8rem;font-weight:400;font-style:italic;color:#333;text-align:center;padding:4px 2px;background-color:transparent;border:none;margin:0}@media (max-width: 768px){.app-header{flex-direction:column;gap:10px;padding:5px;text-align:center}.header-image{height:64px;margin-right:5px;margin-bottom:5px}.title-text{align-items:center}.title-text h1{margin:0;font-size:1.5rem}.title-text h2{margin:0;font-size:1.2rem}.app-main{flex-direction:column;padding:5px;gap:5px;height:calc(100vh - 120px)}.bracket{margin-right:0;height:75%;min-height:0;overflow:hidden}.bracket-container{height:calc(100% - 40px)}.upsets{width:100%;border-left:none;border-top:1px solid #ccc;margin-top:5px;height:40%;max-height:none;padding:5px;overflow-y:auto}.upsets-container{display:flex;flex-direction:column;gap:10px;height:100%}.upsets-column{overflow-y:auto;flex:1}.upset-list{max-height:none;overflow-y:auto}.quarter-tabs{margin-bottom:10px}.quarter-tabs button{padding:5px 2px;font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tournament-winner{display:none}.winner-label{font-size:12px;margin-bottom:4px}.winner-name{font-size:14px}.match div.winner{font-weight:700}.header-controls{align-items:center}.header-controls-top{flex-direction:row;width:auto;max-width:100%}.header-controls-top select{width:auto;min-width:120px}.header-controls-buttons{justify-content:center}.header-controls-buttons button,.header-controls-top button{font-size:12px;padding:4px 8px}.random-picks-button{position:absolute;top:8px;right:8px;padding:8px;font-size:12px;gap:4px}.random-picks-button .dice-icon{width:32px;height:32px}.round{margin-right:4px}.guest-buttons{gap:10px}.guest-button{width:100%}}@media (max-width: 480px){.match div,.future-match{font-size:12px;padding:3px;height:20px;line-height:20px}.round{width:180px}.match{width:160px}}.clickable-upset{cursor:pointer;color:inherit;position:relative;transition:color .2s ease}.clickable-upset:hover{color:#3498db;text-decoration:underline}.clickable-upset:active{color:#2980b9}.pulse-animation{animation:highlightPulse .8s ease-in-out;animation-iteration-count:3;border-radius:5px;z-index:100;background-color:#3498db33;box-shadow:0 0 5px #3498db80;width:100%;right:0;padding-right:5px;box-sizing:border-box}.pulse-animation:before{content:"";position:absolute;top:-3px;left:-3px;right:-3px;bottom:-3px;border-radius:7px;border:2px solid rgba(52,152,219,.3);z-index:-1;animation:borderPulse .8s ease-in-out infinite}@keyframes borderPulse{0%{border-color:#3498db4d}50%{border-color:#3498dbcc}to{border-color:#3498db4d}}@keyframes highlightPulse{0%{box-shadow:0 0 #3498dbcc;background-color:#3498db33;transform:scale(1)}50%{box-shadow:0 0 0 10px #3498db00;background-color:#3498db4d;transform:scale(1.02)}to{box-shadow:0 0 #3498db00;background-color:#3498db33;transform:scale(1)}}.pulse-animation .player-div{background-color:#ffffffe6;transition:background-color .3s ease}.player-div{transition:background-color .2s ease;padding:2px 4px;border-radius:3px}.complete-match{transition:all .3s ease;padding:2px}.results-page{max-width:1200px;margin:0 auto;padding:20px}.results-controls{display:flex;justify-content:center;margin-top:20px}.expand-all-button{padding:8px 16px;background-color:#333;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.expand-all-button:hover{background-color:#555}.scorecards-container{display:flex;flex-wrap:wrap;justify-content:flex-start;row-gap:10px;column-gap:20px}.scorecard{background-color:#f5f5f5;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;flex:1 1 300px;max-width:calc(33.333% - 20px);min-width:330px;margin-bottom:20px}.scorecard.collapsed{margin-bottom:5px;background-color:transparent;box-shadow:none}.scorecard-current-user{box-shadow:0 0 0 2px #007bff,0 2px 8px #007bff40}.scorecard-current-user .scorecard-header{background-color:#1a5276}.scorecard-current-user .scorecard-header:hover{background-color:#1f6391}.scorecard-current-user.collapsed{box-shadow:none}.scorecard-current-user.collapsed .scorecard-header{background-color:#1a5276}.scorecard-header{background-color:#333;color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none}.scorecard-header:hover{background-color:#444}.total-score{font-size:24px;font-weight:700;display:inline-flex;align-items:baseline}.prize-emoji{margin-right:6px}.current-score{display:inline-block;min-width:25px;text-align:right}.max-score{font-size:18px;font-style:italic;font-weight:400;opacity:.8;margin-left:8px;vertical-align:baseline}.player-name{font-size:18px}.picks-table th,.picks-table td{padding:10px;text-align:left;border-bottom:1px solid #ddd}.picks-table th{background-color:#f0f0f0;font-weight:700}.picks-table tr:last-child td{padding-bottom:0}.status-icon{font-size:1em;text-align:center}.picks-table{width:100%;border-collapse:collapse}.picks-table th,.picks-table td{padding:8px;border:1px solid #ddd}.picks-table th{background-color:#f2f2f2;font-weight:700}.score-text{font-size:1em;font-weight:700;font-family:Courier New,Courier,monospace}.score-upset-pick{font-size:.9em}@media (max-width: 1000px){.scorecard{flex:1 1 calc(50% - 20px);max-width:calc(50% - 20px)}}@media (max-width: 768px){.scorecard{flex:1 1 100%;max-width:100%}.scorecard-header{padding:8px 15px}.picks-table td{padding:6px;font-size:.9rem}.score-text{font-size:.9em}.score-upset-pick{font-size:.8em}}@media (max-width: 700px){.scorecard{flex:1 1 100%;max-width:100%}}.draw-separator td{height:2px;border-bottom:2px solid #ccc;padding:8px 0}.draw-separator+tr td{padding-top:8px}.mens-last-row td{border-bottom:2px solid #ccc;padding-bottom:8px}.mens-last-row+tr td{padding-top:8px}.reveal-button{background-color:#f0f0f0;border:1px solid #ccc;border-radius:50%;width:24px;height:24px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;font-size:16px;transition:background-color .2s}.reveal-button:hover{background-color:#e0e0e0}.reveal-button:active{background-color:#d0d0d0}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;width:80%;max-width:800px;max-height:80vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px;background-color:#fafad2}.modal-header h2{margin:0;font-size:24px;color:#333;text-align:center;flex:1}.close-button{background:none;border:none;font-size:24px;cursor:pointer;color:#666;padding:0;line-height:1}.close-button:hover{color:#333}.leaderboard-tabs{display:flex;border-bottom:2px solid #eee;background-color:#f9f9f9}.tab-button{flex:1;padding:12px 16px;border:none;background:none;font-size:16px;font-weight:500;color:#666;cursor:pointer;transition:all .2s ease;border-bottom:3px solid transparent;margin-bottom:-2px}.tab-button:hover{background-color:#f0f0f0;color:#333}.tab-button.active{color:#2196f3;border-bottom-color:#2196f3;background-color:#fff}.tab-description{padding:8px 16px;font-size:13px;color:#888;background-color:#fafafa;border-bottom:1px solid #eee;text-align:center;font-style:italic}.modal-body{padding:0}.loading{text-align:center;padding:20px;color:#666}.leaderboard-table{width:100%;border-collapse:collapse;margin-top:0}.leaderboard-table th,.leaderboard-table td{padding:8px;text-align:left;border-bottom:1px solid #eee}.leaderboard-table th{background-color:#f5f5f5;font-weight:700;color:#333}.leaderboard-table tr:hover{background-color:#f9f9f9}.leaderboard-table td:first-child{font-weight:700;color:#666;text-align:right}.leaderboard-table td:nth-child(3){font-weight:700;color:#2196f3}.leaderboard-table td:nth-child(4),.leaderboard-table td:nth-child(5),.leaderboard-table td:nth-child(6){text-align:center}.leaderboard-table th:nth-child(4),.leaderboard-table th:nth-child(5),.leaderboard-table th:nth-child(6){text-align:center}.player-name-cell{position:relative;cursor:pointer}.player-name-cell:hover{color:#2196f3;text-decoration:underline}.player-tooltip{position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:10px;background-color:#333;color:#fff;padding:12px;border-radius:6px;min-width:280px;max-width:350px;z-index:1001;box-shadow:0 4px 12px #0000004d;font-size:13px}.player-tooltip:before{content:"";position:absolute;right:100%;top:50%;transform:translateY(-50%);border:8px solid transparent;border-right-color:#333}.tooltip-header{font-weight:700;font-size:14px;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #555;color:#fafad2}.tooltip-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;gap:8px}.tooltip-row:not(:last-child){border-bottom:1px solid #444}.tooltip-event{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip-rank{min-width:45px;text-align:center;color:#aaa}.tooltip-prize{min-width:24px;text-align:center;color:#bfbfbf}.tooltip-points{min-width:40px;text-align:right;color:#90ee90;font-weight:500}@media (max-width: 768px){.player-tooltip{left:0;top:100%;transform:none;margin-left:0;margin-top:8px}.player-tooltip:before{right:auto;left:20px;top:-16px;transform:none;border:8px solid transparent;border-bottom-color:#333}}.prediction-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;overflow:hidden;transition:transform .2s ease;margin-bottom:10px}.prediction-card:hover{transform:translateY(-3px)}.prediction-card.current{border:1px solid #7d8627;box-shadow:0 4px 12px #7d86274d}.prediction-card.invalid{opacity:.6}.prediction-card.correct{border:2px solid #27ae60;box-shadow:0 4px 12px #27ae604d}.prediction-header{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background-color:#f8f8f8;border-bottom:1px solid #e0e0e0;gap:10px}.prediction-info{flex:1;min-width:0}.prediction-matchup{margin:0;font-size:1rem;line-height:1.3;color:#333;display:flex;align-items:center;gap:8px;flex-wrap:nowrap}.prediction-round-badge{font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:4px;white-space:nowrap;flex-shrink:0}.prediction-winner{color:#7d8627;font-weight:700}.prediction-loser{color:#523633;font-weight:700}.prediction-points{font-size:1rem;font-weight:700;color:#7d8627;padding:4px 10px;background-color:#f0f4e8;border-radius:4px;white-space:nowrap;flex-shrink:0}.status-correct{color:#fff;background-color:#27ae60;font-weight:700}.status-current{color:#fff;background-color:#7d8627;font-weight:700}.status-valid{color:#27ae60;background-color:#e8f8f5}.status-invalid{color:#e74c3c;background-color:#fadbd8}.prediction-upcoming{padding:6px 12px;background-color:#fff8e6;border-bottom:1px solid #f0e6cc;display:flex;gap:16px;flex-wrap:wrap;font-size:.85rem;color:#666}.prediction-upcoming-separate{flex-direction:column;gap:6px}.player-next-match{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.player-next-match .player-name{font-weight:600;color:#555}.player-next-match .next-vs{color:#999;font-style:italic;font-size:.8rem}.player-next-match .opponent-name{color:#666}.upcoming-time{color:#8b7355;font-weight:500}.upcoming-court{color:#888}.prediction-pickers{padding:8px 12px;background-color:#fff}.prediction-pickers-text{margin:0;font-size:.9rem;color:#7f8c8d;line-height:1.4}@media (max-width: 768px){.prediction-card{margin-bottom:8px}.prediction-header{flex-wrap:wrap;padding:8px 10px}.prediction-matchup,.prediction-winner,.prediction-loser{font-size:.75rem}.prediction-round-badge{font-size:.7rem;padding:2px 6px}.prediction-points{font-size:.9rem;padding:3px 8px}.prediction-pickers{padding:6px 10px}.prediction-pickers-text{font-size:.85rem}}.predictions-tab{padding:20px 0}.predictions-tab.loading,.predictions-tab.error,.predictions-tab.empty{text-align:center;padding:40px;color:#7f8c8d;font-size:1.2rem}.predictions-tab.error{color:#e74c3c}.predictions-section{margin-bottom:30px}.predictions-section-title{font-size:1.5rem;color:#523633;margin-bottom:20px;font-weight:600}.predictions-list{display:flex;flex-direction:column;gap:15px}.predictions-separator{display:flex;align-items:center;margin:30px 0;gap:15px}.predictions-separator hr{flex:1;border:none;border-top:2px solid #e0e0e0}.predictions-separator span{color:#7f8c8d;font-weight:600;font-size:1.1rem;white-space:nowrap}@media (max-width: 768px){.predictions-tab{padding:10px 0}.predictions-section{margin-bottom:20px}.predictions-section-title{font-size:1.2rem;margin-bottom:15px}.predictions-list{gap:10px}.predictions-separator{margin:20px 0;gap:10px}.predictions-separator span{font-size:.95rem}}.upset-feed{padding:20px;max-width:800px;margin:0 auto}.feed-tabs{display:flex;gap:10px;margin-bottom:0;border-bottom:2px solid #e0e0e0}.feed-tab{padding:12px 24px;background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;font-size:1rem;font-weight:500;color:#7f8c8d;transition:all .3s ease;margin-bottom:-2px}.feed-tab:hover{color:#523633}.feed-tab.active{color:#523633;border-bottom-color:#7d8627}.predictions-placeholder{text-align:center;padding:40px;color:#7f8c8d;font-size:1.2rem}.upset-feed h2{color:#333;margin-bottom:30px;text-align:center;font-size:2rem}.upset-list{display:flex;flex-direction:column;gap:20px}.upset-card{background-color:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a;overflow:hidden;transition:transform .2s ease}.upset-card:hover{transform:translateY(-5px)}.upset-header{display:flex;justify-content:space-between;align-items:center;padding:15px;background-color:#f8f8f8}.upset-image{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #523633;margin-left:15px;flex-shrink:0}.upset-info{flex:1;display:flex;flex-direction:column;justify-content:center;text-align:right}.upset-info h3{margin:0 0 8px;font-size:1.2rem;line-height:1.3}.winner,.loser{color:#7d8627;font-weight:700}.user-picks-info{margin:0;color:#7f8c8d;font-size:.9rem;line-height:1.4}.upset-feed.loading,.upset-feed.error,.upset-feed.empty{text-align:center;padding:40px;color:#7f8c8d;font-size:1.2rem}.upset-feed.error{color:#e74c3c}@media (max-width: 768px){.upset-feed{padding:4px}.upset-list{display:flex;flex-direction:column;gap:8px}.upset-card{width:auto;min-width:0;overflow:visible;padding:12px}.upset-header{flex-direction:row;justify-content:space-between;align-items:flex-start;padding:4px;flex-wrap:nowrap;overflow:visible}.upset-info{flex:1;margin-right:10px;text-align:center;vertical-align:middle;min-width:0;overflow:visible;font-size:.7rem}.upset-info h3{font-size:.85rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;margin-left:8px;margin-right:8px}.user-picks-info{font-size:.9rem;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto}.upset-card p{margin:2px}.upset-image{width:50px;height:50px;margin-left:8px;margin-right:8px;flex-shrink:0}}.event-page{width:100%}.event-tabs{display:flex;justify-content:center;gap:0;margin-bottom:20px;padding:0 1em;box-shadow:inset 0 -2px #d1d3d2}.event-tab{padding:.8em 1.2em;border:none;background:transparent;cursor:pointer;font-size:.85em;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:#74777b;line-height:1;box-shadow:inset 0 -2px #d1d3d2;transition:color .3s,box-shadow .3s}.event-tab:hover{box-shadow:inset 0 -2px #74777b;background:transparent}.event-tab.active{box-shadow:inset 0 -2px #2cc185;color:#2cc185;background:transparent}.event-content{width:100%}@media (max-width: 768px){.event-tabs{padding:0 .5em}.event-tab{padding:.7em .8em;font-size:.75em;letter-spacing:.5px}}.player-page{max-width:800px;width:100%;margin:0 auto;padding:20px;box-sizing:border-box;min-width:0;overflow-x:hidden}.player-page-loading{display:flex;justify-content:center;align-items:center;min-height:200px;color:#666}.player-page-content{display:flex;flex-direction:column;gap:30px;min-width:0}.player-section{background:#fff;border-radius:12px;padding:16px;box-shadow:0 2px 8px #00000014;box-sizing:border-box;min-width:0}.player-section h2{margin:0 0 20px;font-size:1.2rem;color:#444;padding-bottom:10px;border-bottom:1px solid #eee}.player-identity{text-align:center;padding:30px}.player-avatar-large{margin-bottom:15px;position:relative;display:inline-block}.player-avatar-large.clickable{cursor:pointer;transition:transform .2s ease}.player-avatar-large.clickable:hover{transform:scale(1.05)}.avatar-image-large{width:120px;height:120px;object-fit:contain}.avatar-edit-indicator{position:absolute;bottom:5px;right:5px;background:#ffffffe6;border-radius:4px;width:24px;height:24px;padding:3px;box-shadow:0 2px 4px #0003;pointer-events:none;object-fit:contain}.edit-icon{width:16px;height:16px;object-fit:contain}.player-name-display{margin-bottom:8px}.name-view-container{display:inline-flex;align-items:center;gap:10px}.player-name-text{font-size:1.8rem;font-weight:700;color:#333}.name-edit-button{background:none;border:none;cursor:pointer;padding:4px;opacity:.5;transition:opacity .2s;display:flex;align-items:center;justify-content:center}.name-edit-button:hover{opacity:1}.name-edit-container{display:flex;justify-content:center;gap:10px;align-items:center;flex-wrap:wrap}.name-edit-input{font-size:1.4rem;padding:8px 12px;border:2px solid #007bff;border-radius:6px;text-align:center;width:200px;max-width:100%;box-sizing:border-box}.name-save-button,.name-cancel-button{padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem}.name-save-button{background:#007bff;color:#fff;border:none}.name-save-button:disabled{background:#ccc;cursor:not-allowed}.name-cancel-button{background:none;border:1px solid #ccc;color:#666}.player-email{color:#888;font-size:.9rem}.avatar-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}@media (max-width: 600px){.avatar-grid{grid-template-columns:repeat(4,1fr)}}.avatar-option{aspect-ratio:1;border:2px solid #e0e0e0;border-radius:12px;background:#fafafa;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;padding:8px}.avatar-option:hover{border-color:#999;background:#fff;transform:scale(1.05)}.avatar-option.selected{border-color:#007bff;background:#e8f4ff;box-shadow:0 0 0 3px #007bff33}.avatar-image{width:100%;height:100%;object-fit:contain}.ranking-display{display:flex;justify-content:center;gap:40px;padding:12px 0 0;margin-top:12px;border-top:1px solid #eee}.ranking-position,.ranking-points{text-align:center}.rank-number{display:block;font-size:1.6rem;font-weight:700;color:#007bff}.rank-total{display:block;color:#888;font-size:.8rem;margin-top:2px}.points-number{display:block;font-size:1.6rem;font-weight:700;color:#28a745}.points-label{display:block;color:#888;font-size:.8rem;margin-top:2px}.no-ranking{text-align:center;color:#888;padding:10px 0 0;margin-top:12px;border-top:1px solid #eee;font-size:.85rem}.tournament-history{overflow-x:hidden}.history-table{width:100%;border-collapse:collapse;table-layout:fixed;font-size:.85rem}.history-table th,.history-table td{padding:8px 6px;text-align:left;border-bottom:1px solid #eee;word-wrap:break-word;overflow-wrap:break-word}.history-table th:first-child,.history-table td:first-child{width:40%}.history-table th{font-weight:600;color:#666;font-size:.8rem}.history-table td:nth-child(3){color:#999}.history-table td:nth-child(4){color:#28a745;font-weight:500}.history-table tbody tr:hover{background:#f9f9f9}.no-history{text-align:center;color:#888;padding:30px}.settings-list{display:flex;flex-direction:column;gap:15px}.setting-item{display:flex;justify-content:space-between;align-items:center;padding:15px;background:#f9f9f9;border-radius:8px;gap:10px;box-sizing:border-box}.setting-info{display:flex;flex-direction:column;gap:4px}.setting-label{font-weight:600;color:#333}.setting-description{font-size:.85rem;color:#888}.toggle-button{padding:8px 20px;border-radius:20px;border:none;cursor:pointer;font-weight:600;font-size:.85rem;transition:all .2s;background:#e0e0e0;color:#666}.toggle-button.active{background:#28a745;color:#fff}.toggle-button:hover{opacity:.9}
