body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root,body,html{height:100%}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);color:#333;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.App{position:relative}.App:before{background:radial-gradient(circle at 20% 20%,#7877c64d 0,#0000 50%),radial-gradient(circle at 80% 80%,#ff77c64d 0,#0000 50%),radial-gradient(circle at 40% 40%,#78dbff4d 0,#0000 50%);content:"";height:100%;left:0;pointer-events:none;position:fixed;top:0;width:100%;z-index:-1}.loading{align-items:center;color:#666;display:flex;font-size:18px;height:200px;justify-content:center}.primary-btn{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea66;color:#fff;cursor:pointer;font-size:16px;font-weight:600;overflow:hidden;padding:14px 28px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.primary-btn:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.primary-btn:hover:before{left:100%}.primary-btn:hover{box-shadow:0 8px 25px #667eea99;transform:translateY(-2px)}.primary-btn:active{transform:translateY(0)}.primary-btn:disabled{background:linear-gradient(135deg,#cbd5e0,#a0aec0);box-shadow:none;cursor:not-allowed;transform:none}.cancel-btn{background-color:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:16px;padding:12px 24px;transition:background-color .3s}.cancel-btn:hover{background-color:#545b62}.join-btn{background-color:#28a745;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.join-btn:hover{background-color:#218838}.finish-btn{background-color:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.finish-btn:hover{background-color:#c82333}.leave-btn{background-color:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;padding:8px 16px;transition:background-color .3s}.leave-btn:hover{background-color:#545b62}.undo-btn{background-color:#ffc107;border:none;border-radius:4px;color:#212529;cursor:pointer;font-size:14px;font-weight:500;padding:8px 16px;transition:background-color .3s}.undo-btn:hover{background-color:#e0a800}.undo-btn:disabled{border:1px solid #dee2e6;color:#6c757d;cursor:not-allowed}.undo-btn:disabled,.undo-btn:disabled:hover{background-color:#f8f9fa}.settings-btn{background:none;border:none;border-radius:4px;cursor:pointer;font-size:24px;padding:8px;transition:background-color .3s}.settings-btn:hover{background-color:#0000001a}.home-container{margin:0 auto;max-width:1200px;padding:20px}.app-header{align-items:center;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;margin-bottom:40px;padding:20px}.app-header h1{color:#333;font-size:28px}.version-info{background:#f8f9fa;border-radius:4px;color:#666;font-size:14px;padding:4px 8px}.home-content{display:flex;flex-direction:column;gap:20px}.action-buttons{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-bottom:20px;text-align:center}.rooms-section{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:20px}.rooms-section h2{color:#333;margin-bottom:20px}.rooms-list{display:flex;flex-direction:column;gap:10px}.room-card{align-items:center;border:1px solid #ddd;border-radius:6px;display:flex;justify-content:space-between;padding:15px;transition:box-shadow .3s}.room-card:hover{box-shadow:0 2px 8px #0000001a}.room-info{flex:1 1}.room-code{color:#007bff;font-size:18px;font-weight:700}.room-details,.room-host,.room-status{color:#666;font-size:14px;margin-top:4px}.room-details{color:#999;font-style:italic}.no-rooms{color:#666;font-style:italic;padding:20px;text-align:center}.game-room{display:flex;flex-direction:column;min-height:100vh}.game-header{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-bottom:1px solid #fff3;box-shadow:0 8px 32px #0000001a;display:flex;justify-content:space-between;padding:25px;position:relative}.game-header:before{background:linear-gradient(90deg,#667eea,#764ba2,#f093fb,#f5576c);content:"";height:3px;left:0;position:absolute;right:0;top:0}.room-info h1{color:#333;font-size:24px;margin-bottom:4px}.game-progress{flex:1 1;text-align:center}.round-info{color:#007bff;font-size:18px;font-weight:700;margin-bottom:4px}.match-info{color:#666;font-size:16px}.header-actions{display:flex;gap:10px}.game-content{display:flex;flex:1 1;flex-direction:column;gap:20px;padding:20px}.game-top{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 320px}.game-board-container,.match-schedule-container{min-height:400px}.game-bottom{width:100%}.game-board{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;padding:25px 40px;position:relative;text-align:center}.game-board:before{animation:rotate 20s linear infinite;background:conic-gradient(from 0deg,#0000,#667eea08,#0000);content:"";height:200%;left:-50%;pointer-events:none;position:absolute;top:-50%;width:200%}@keyframes rotate{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.match-title{margin-bottom:25px;position:relative;z-index:1}.match-title h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700;margin-bottom:8px}.finished-badge{animation:pulse 2s infinite;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:25px;box-shadow:0 4px 15px #f5576c66;color:#fff;font-size:12px;font-weight:600;padding:8px 16px;position:absolute;right:-10px;top:-10px}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.vs-container{align-items:center;display:flex;gap:40px;justify-content:center;margin-bottom:25px;position:relative;z-index:1}.player-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:2px solid #ffffff4d;border-radius:20px;min-width:220px;overflow:hidden;padding:25px;position:relative;transition:all .4s cubic-bezier(.4,0,.2,1)}.player-card:before{background:linear-gradient(135deg,#667eea1a,#764ba21a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.player-card.clickable{cursor:pointer}.player-card.clickable:hover{border-color:#667eea99;box-shadow:0 25px 50px #667eea4d;transform:translateY(-8px) scale(1.02)}.player-card.clickable:hover:before{opacity:1}.player-card.disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.6}.player-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:36px;font-weight:800;margin-bottom:12px}.player-label,.player-name{position:relative;z-index:1}.player-name{color:#4a5568;font-size:18px;font-weight:500;margin-bottom:8px}.player-name.main-name{color:#667eea;font-size:24px;font-weight:700;margin-bottom:4px}.player-label.secondary{color:#999;font-size:14px;margin-bottom:8px}.player-score{background:#48bb781a;border-radius:12px;color:#48bb78;display:inline-block;font-size:24px;font-weight:700;margin-bottom:12px;padding:8px 16px}.player-score,.win-hint{position:relative;z-index:1}.win-hint{color:#718096;font-size:12px;font-style:italic;opacity:.8}.vs-divider{-webkit-text-fill-color:#0000;animation:float 3s ease-in-out infinite;background:linear-gradient(135deg,#f093fb,#f5576c);-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:800;position:relative;z-index:1}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.score-info{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #ffffff4d;border-radius:16px;box-shadow:0 8px 32px #0000001a;margin-bottom:20px;padding:15px;position:relative;text-align:center;z-index:1}.score-tied{background:linear-gradient(135deg,#718096,#4a5568);-webkit-background-clip:text;background-clip:text}.score-difference,.score-tied{-webkit-text-fill-color:#0000;font-size:20px;font-weight:700}.score-difference{background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.score-info-mobile{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:1px solid #ffffff4d;border-radius:12px;box-shadow:0 8px 25px #0000001a;margin-bottom:10px;padding:12px;position:relative;text-align:center;z-index:1}.score-info-mobile .score-difference,.score-info-mobile .score-tied{font-size:16px;font-weight:700}.score-info-mobile .score-tied{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#718096,#4a5568);-webkit-background-clip:text;background-clip:text}.score-info-mobile .score-difference{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text}.finished-message{background:#d4edda;border-radius:8px;color:#155724;padding:20px;text-align:center}.leaderboard{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;padding:25px;position:relative}.leaderboard:before{background:linear-gradient(90deg,#667eea,#764ba2,#f093fb,#f5576c,#4facfe,#00f2fe);border-radius:20px 20px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.leaderboard-header{align-items:center;border-bottom:2px solid #667eea1a;display:flex;justify-content:space-between;margin-bottom:25px;padding-bottom:15px;position:relative;z-index:1}.leaderboard-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:22px;font-weight:700;margin:0}.final-results{animation:glow 2s ease-in-out infinite alternate;background:linear-gradient(135deg,#48bb78,#38a169);border-radius:20px;box-shadow:0 4px 15px #48bb7866;color:#fff;font-size:12px;font-weight:700;padding:8px 16px}@keyframes glow{0%{box-shadow:0 4px 15px #48bb7866}to{box-shadow:0 6px 20px #48bb7899}}.leaderboard-list{display:flex;flex-direction:column;gap:8px}.leaderboard-item{align-items:center;background:#fafafa;border:1px solid #e9ecef;border-radius:8px;display:flex;gap:15px;padding:15px;transition:all .3s ease}.leaderboard-item:hover{box-shadow:0 2px 8px #0000001a;transform:translateY(-1px)}.leaderboard-item.winner{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-color:#ffc107;box-shadow:0 4px 12px #ffc1074d}.rank{align-items:center;background:#e9ecef;border-radius:50%;color:#495057;display:flex;font-size:20px;font-weight:700;gap:5px;height:40px;justify-content:center;min-width:40px;text-align:center;width:40px}.leaderboard-item.winner .rank{background:#ffc107;color:#212529}.crown{font-size:16px}.player-info{flex:1 1;min-width:0}.player-info .player-label{color:#007bff;font-size:18px;font-weight:700;margin-bottom:4px}.player-info .player-name{color:#6c757d;font-size:14px;font-style:italic}.player-info .main-display{color:#333;font-size:16px;font-weight:700}.score{background:#e8f5e8;border-radius:6px;color:#28a745;font-size:24px;font-weight:700;min-width:50px;padding:8px 12px;text-align:center}.leaderboard-footer{border-top:2px solid #e9ecef;margin-top:15px;padding-top:15px;text-align:center}.leaderboard-footer small{color:#6c757d;font-size:12px;font-style:italic}.match-schedule{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;height:-webkit-fit-content;height:fit-content;overflow:hidden;padding:25px;position:relative}.match-schedule:before{background:linear-gradient(90deg,#4facfe,#00f2fe);border-radius:20px 20px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.schedule-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:25px;position:relative;z-index:1}.schedule-header h3{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700;margin:0}.current-round{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 4px 15px #667eea66;color:#fff;font-size:12px;font-weight:700;padding:8px 16px}.schedule-list{display:flex;flex-direction:column;gap:6px}.schedule-item{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff80;border:1px solid #fff3;border-radius:12px;display:flex;gap:8px;padding:8px 12px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1);z-index:1}.schedule-item.current{background:#667eea1a;border-color:#667eea4d;box-shadow:0 4px 15px #667eea33;transform:scale(1.02)}.schedule-item.completed{background:#48bb781a;border-color:#48bb784d;opacity:.8}.match-number{align-items:center;background:#667eea1a;border-radius:50%;color:#4a5568;display:flex;font-size:12px;height:25px;justify-content:center;min-width:25px;text-align:center;width:25px}.match-players{flex:1 1;font-size:12px;gap:4px;min-width:0}.match-players .player-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-weight:700}.match-players .player-name{color:#718096;font-size:11px;font-weight:500}.match-players .vs{color:#999;font-size:11px}.match-label{background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;box-shadow:0 2px 8px #f093fb4d;color:#fff;display:inline-block;font-size:10px;font-weight:700;margin-left:4px;padding:4px 8px;white-space:nowrap}.match-label.winners{background:linear-gradient(135deg,#48bb78,#38a169);box-shadow:0 2px 8px #48bb784d}.match-label.losers{background:linear-gradient(135deg,#f56565,#e53e3e);box-shadow:0 2px 8px #f565654d}.match-status{flex-shrink:0;min-width:60px;text-align:center}.current-indicator{animation:pulse 2s infinite;background:linear-gradient(135deg,#f093fb,#f5576c);border-radius:12px;box-shadow:0 2px 8px #f093fb4d;color:#fff;font-size:10px;font-weight:700;padding:4px 8px}.completed-indicator{color:#48bb78;font-size:16px;font-weight:700}.schedule-footer{border-top:1px solid #ddd;margin-top:15px;padding-top:15px;text-align:center}.progress-info{color:#666;font-size:12px;margin-bottom:4px}.cycle-info{color:#999;font-size:11px;font-style:italic}.modal-overlay{align-items:center;background-color:#00000080;display:flex;height:100%;justify-content:center;left:0;position:fixed;top:0;width:100%;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #ddd;display:flex;justify-content:space-between;padding:20px}.modal-header h2{color:#333}.close-btn{align-items:center;background:none;border:none;color:#666;cursor:pointer;display:flex;font-size:24px;height:30px;justify-content:center;padding:0;width:30px}.close-btn:hover{color:#333}.modal-body{padding:20px}.modal-footer{border-top:1px solid #ddd;display:flex;gap:10px;justify-content:flex-end;padding:20px}.settings-section{margin-bottom:20px}.settings-section h3{color:#333;margin-bottom:15px}.player-names-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr}.player-names-grid .input-group{flex-direction:column;gap:5px}.player-names-grid .input-group label{color:#333;font-weight:700}.player-names-grid .input-group input{border:1px solid #ddd;border-radius:4px;padding:8px 12px}.input-group{display:flex;gap:10px;margin-bottom:10px}.input-group input{border:1px solid #ddd;border-radius:4px;flex:1 1;font-size:14px;padding:8px 12px}.input-group input:focus{border-color:#007bff;outline:none}.create-room-info{background:#f8f9fa;border-radius:6px;margin-bottom:20px;padding:20px;text-align:center}.create-room-info p{color:#666;margin:8px 0}.create-room-info p:first-child{color:#333;font-weight:700}.room-name-section{background:#e3f2fd;border:1px solid #2196f3;border-radius:8px;margin:20px 0;padding:20px}.room-name-section h3{color:#1976d2;font-size:16px;margin-bottom:15px}.room-name-input input{border:1px solid #2196f3;border-radius:6px;font-size:16px;padding:12px 16px;transition:border-color .3s;width:100%}.room-name-input input:focus{border-color:#1976d2;box-shadow:0 0 0 2px #2196f31a;outline:none}.room-name-input input:disabled{background-color:#f8f9fa;cursor:not-allowed}.player-names-section{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin:20px 0;padding:20px}.player-names-section h3{color:#333;font-size:16px;margin-bottom:15px}.player-inputs{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:10px}.player-input-group{display:flex;flex-direction:column;gap:5px}.player-input-group label{color:#495057;font-size:14px;font-weight:600}.player-input-group input{border:1px solid #ced4da;border-radius:4px;font-size:14px;padding:8px 12px;transition:border-color .3s}.player-input-group input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea1a;outline:none}.player-input-group input:disabled{background-color:#f8f9fa;cursor:not-allowed}.input-hint{color:#6c757d;font-size:12px;font-style:italic;text-align:center}.history-modal{max-height:80vh;max-width:700px}.history-tabs{background:#f8f9fa;border-bottom:1px solid #ddd;display:flex}.tab-btn{background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;flex:1 1;font-size:14px;padding:12px 16px;transition:all .3s}.tab-btn:hover{background:#e9ecef;color:#333}.tab-btn.active{background:#fff;border-bottom-color:#667eea;color:#667eea}.history-overview{padding:20px 0}.game-info{background:#f8f9fa;border-radius:8px;margin-bottom:30px;padding:20px}.info-row{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:8px 0}.info-row:last-child{border-bottom:none}.info-row .label{color:#666;font-weight:600}.info-row .value{color:#333;font-weight:500}.final-ranking h3{color:#333;font-size:18px;margin-bottom:15px}.ranking-list{display:flex;flex-direction:column;gap:10px}.ranking-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;display:flex;gap:15px;padding:15px}.ranking-item.winner{background:linear-gradient(135deg,#fff3cd,#ffeaa7);border-color:#ffc107}.ranking-item .rank{align-items:center;color:#666;display:flex;font-size:18px;font-weight:700;gap:5px;min-width:50px}.ranking-item .crown{font-size:20px}.ranking-item .player-info{flex:1 1}.ranking-item .player-label{color:#667eea;font-size:16px;font-weight:700}.ranking-item .player-name{color:#666;font-size:14px}.ranking-item .score{color:#333;font-size:20px;font-weight:700}.match-history h3{color:#333;font-size:18px;margin-bottom:20px}.matches-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.match-record{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:15px}.match-info{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:10px}.match-number{color:#667eea;font-size:14px;font-weight:700;min-width:-webkit-fit-content;min-width:fit-content;white-space:nowrap}.match-time{color:#666;font-size:12px}.match-players{align-items:center;display:flex;gap:10px;margin-bottom:8px}.match-players .player{border-radius:4px;font-weight:500;padding:4px 8px}.match-players .player.winner{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.match-players .player.loser{background:#f8d7da;border:1px solid #f1b2b7;color:#721c24}.match-players .vs{color:#666;font-weight:700}.match-result{color:#333;font-size:14px;font-weight:500}.player-statistics h3{color:#333;font-size:18px;margin-bottom:20px}.stats-grid{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.player-stat-card{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:15px}.stat-header h4{color:#667eea;font-size:16px;margin-bottom:10px}.stat-body{display:flex;flex-direction:column;gap:8px}.stat-row{align-items:center;display:flex;justify-content:space-between;padding:4px 0}.stat-row span:first-child{color:#666;font-size:14px}.stat-row span:last-child{color:#333;font-weight:700}.no-history{color:#666;padding:40px;text-align:center}.no-history p{font-size:16px;font-style:italic}.history-list{display:flex;flex-direction:column;gap:15px;max-height:60vh;overflow-y:auto}.history-item{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;cursor:pointer;padding:20px;transition:all .3s ease}.history-item:hover{background:#e9ecef;box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.history-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:15px}.history-header h4{color:#667eea;font-size:18px;font-weight:700;margin:0}.history-date{background:#e9ecef;border-radius:6px;color:#666;font-size:14px;padding:4px 8px}.history-details{display:flex;flex-direction:column;gap:8px}.winner-info{color:#28a745;font-size:16px;font-weight:700}.match-count{color:#007bff;font-size:14px}.players-list{color:#6c757d;font-size:14px;font-style:italic}.settings-description{background-color:#e3f2fd;border-left:4px solid #2196f3;border-radius:4px;margin-bottom:15px;padding:10px}.settings-description p{color:#1976d2;font-size:14px;margin:0}.results-modal{max-width:600px}.winner-announcement{background:linear-gradient(135deg,gold,#ffed4a);border-radius:8px;margin-bottom:30px;padding:20px;text-align:center}.winner-crown{font-size:48px;margin-bottom:10px}.winner-announcement h3{color:#333;font-size:24px;margin-bottom:15px}.winner-info{align-items:center;display:flex;flex-direction:column;gap:5px}.winner-player{color:#007bff;font-size:32px;font-weight:700}.winner-name{color:#333;font-size:20px}.winner-score{color:#666;font-size:18px}.final-standings{margin-bottom:20px}.final-standings h4{color:#333;margin-bottom:15px}.standings-list{display:flex;flex-direction:column;gap:10px}.standing-item{align-items:center;background:#f8f9fa;border-radius:6px;display:flex;gap:15px;padding:10px}.standing-rank{color:#666;font-size:16px;font-weight:700;min-width:30px}.standing-player{align-items:center;display:flex;flex:1 1;gap:10px}.standing-player .player-label{color:#007bff;font-size:16px;font-weight:700}.standing-player .player-name{color:#666;font-size:14px}.standing-score{color:#333;font-size:16px;font-weight:700}.room-info{background:#f8f9fa;border-radius:6px;padding:15px;text-align:center}.error-message{background-color:#f8d7da;color:#721c24}.error-message,.success-message{border-radius:4px;margin-top:10px;padding:10px}.success-message{background-color:#d4edda;color:#155724}.mobile-layout{background:#0000;display:flex;flex-direction:column;min-height:100vh}.mobile-layout .game-content{display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:15px}.current-match-section{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 15px 35px #0000001a;overflow:hidden;padding:15px;position:relative;text-align:center}.current-match-section:before{background:linear-gradient(90deg,#667eea,#764ba2,#f093fb,#f5576c);border-radius:20px 20px 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.current-match-section .match-title{margin-bottom:15px;position:relative;z-index:1}.current-match-section .match-title h2{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:700;margin:0}.vs-container-mobile{align-items:center;display:flex;gap:15px;justify-content:center;margin-bottom:12px;position:relative;z-index:1}.player-card-mobile{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;border:2px solid #ffffff4d;border-radius:16px;flex:1 1;max-width:120px;overflow:hidden;padding:12px 10px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.player-card-mobile:before{background:linear-gradient(135deg,#667eea1a,#764ba21a);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.player-card-mobile.clickable{cursor:pointer}.player-card-mobile.clickable:hover{border-color:#667eea99;box-shadow:0 15px 30px #667eea4d;transform:translateY(-4px) scale(1.02)}.player-card-mobile.clickable:hover:before{opacity:1}.player-card-mobile.disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.6}.player-card-mobile .player-label{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:24px;font-weight:800;margin-bottom:6px;position:relative;z-index:1}.player-card-mobile .player-name{color:#4a5568;font-size:12px;font-weight:500;margin-bottom:4px;position:relative;z-index:1}.player-card-mobile .player-score{background:#48bb781a;border-radius:8px;color:#48bb78;display:inline-block;font-size:16px;font-weight:700;margin-bottom:4px;padding:4px 8px;position:relative;z-index:1}.player-card-mobile .win-hint{color:#718096;font-size:9px;font-style:italic;opacity:.8;position:relative;z-index:1}.vs-divider-mobile{-webkit-text-fill-color:#0000;animation:float 3s ease-in-out infinite;background:linear-gradient(135deg,#f093fb,#f5576c);-webkit-background-clip:text;background-clip:text;font-size:20px;font-weight:800;min-width:40px;position:relative;z-index:1}.game-middle{grid-gap:10px;display:grid;flex:1 1;gap:10px;grid-template-columns:2fr 1fr;min-height:0}.leaderboard-container-mobile,.match-schedule-container-mobile{display:flex;flex-direction:column}.leaderboard-container-mobile .leaderboard,.match-schedule-container-mobile .match-schedule{display:flex;flex-direction:column;padding:12px}.leaderboard-container-mobile .leaderboard h3,.match-schedule-container-mobile .match-schedule h3{flex-shrink:0;font-size:16px;margin-bottom:8px}.mobile-layout .leaderboard-list,.mobile-layout .schedule-list{display:flex;flex-direction:column;gap:4px}.mobile-layout .leaderboard-footer,.mobile-layout .schedule-footer{border-top:1px solid #ddd;margin-top:8px;padding-top:8px}.mobile-layout .schedule-item{font-size:11px;gap:6px;padding:6px 8px}.mobile-layout .match-players{font-size:10px;gap:3px}.mobile-layout .match-players .player-name{font-size:9px}.mobile-layout .match-label{display:inline-block;font-size:8px;margin-left:2px;padding:1px 4px;white-space:nowrap}.mobile-layout .schedule-footer{margin-top:10px;padding-top:10px}.mobile-layout .cycle-info,.mobile-layout .progress-info{font-size:10px}.mobile-layout .leaderboard-item{align-items:center;background:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;display:flex;gap:4px;justify-content:space-between;padding:8px 6px}.mobile-layout .rank{background:none;border-radius:0;color:#495057;display:block;font-size:14px;font-weight:700;height:auto;min-width:20px;text-align:center;width:auto}.mobile-layout .player-info{align-items:center;display:flex;flex:1 1;flex-direction:column;min-width:0;text-align:center}.mobile-layout .player-info .player-label{color:#007bff;font-size:16px;font-weight:700;line-height:1;margin:0}.mobile-layout .player-info .player-name{color:#6c757d;font-size:9px;margin:2px 0 0;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-layout .score{background:none;border-radius:0;color:#28a745;font-size:16px;font-weight:700;min-width:20px;padding:0;text-align:center}.mobile-layout .leaderboard-header{border-bottom:2px solid #007bff;margin-bottom:8px;padding-bottom:8px}.mobile-layout .leaderboard-header h3{color:#007bff;font-size:14px;margin:0;text-align:center}.mobile-layout .leaderboard-footer{border-top:1px solid #ddd;color:#666;font-size:9px;margin-top:8px;padding-top:8px;text-align:center}.mobile-layout .leaderboard{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:12px}.mobile-layout .leaderboard-item.winner{background:#fff3cd;border-color:#ffc107}.mobile-layout .leaderboard-item.winner .rank{color:#856404}.mobile-layout .crown{font-size:10px;margin-left:2px}.game-footer{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border-top:1px solid #fff3;box-shadow:0 -8px 32px #0000001a;margin-top:15px;padding:20px;position:relative}.game-footer:before{background:linear-gradient(90deg,#667eea,#764ba2,#f093fb,#f5576c);content:"";height:3px;left:0;position:absolute;right:0;top:0}.room-info-mobile{margin-bottom:15px;position:relative;text-align:center;z-index:1}.room-code-mobile{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:18px;font-weight:700;margin-bottom:8px}.round-info-mobile{color:#4a5568;font-size:14px;font-weight:600}.footer-actions{display:flex;gap:12px;justify-content:center;position:relative;z-index:1}.footer-actions button{border:none;border-radius:12px;box-shadow:0 4px 15px #0000001a;cursor:pointer;flex:1 1;font-size:12px;font-weight:600;max-width:100px;padding:10px 15px;transition:all .3s cubic-bezier(.4,0,.2,1)}.footer-actions button:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-2px)}@media (max-width:768px){.home-content{flex-direction:column}.game-top{gap:15px;grid-template-columns:1fr}.game-board-container,.match-schedule-container{min-height:auto}.game-content{gap:15px;padding:15px}.game-header{flex-direction:column;gap:15px;text-align:center}.vs-container{flex-direction:column;gap:20px}.player-card{min-width:150px}.player-names-grid{grid-template-columns:1fr}.app-header{flex-direction:column;gap:10px;text-align:center}.header-actions{flex-direction:column;width:100%}.modal-content{width:95%}.player-inputs{gap:10px;grid-template-columns:1fr}.player-names-section{padding:15px}.history-tabs{flex-direction:column}.tab-btn{border-bottom:1px solid #ddd;border-right:none}.tab-btn.active{border-bottom:1px solid #667eea;border-right:none}.stats-grid{grid-template-columns:1fr}.info-row{gap:4px}.info-row,.match-info{align-items:flex-start;flex-direction:column}.match-info{gap:5px}.match-number{font-size:12px}.match-players{flex-wrap:wrap;gap:5px}}.rotation-info{background-color:#e8f4f8;border-left:3px solid #17a2b8;border-radius:4px;margin-top:8px;padding:4px 8px}.rotation-info small{color:#17a2b8;font-weight:500}.rotation-note{background-color:#fff3cd;border-left:3px solid #ffc107;border-radius:4px;margin-top:8px;padding:4px 8px}.rotation-note small{color:#856404;font-weight:500}.schedule-item.tbc{background-color:#f8f9fa;opacity:.7}.tbc-label,.tbc-name{color:#6c757d!important;font-style:italic}.tbc-indicator{background-color:#6c757d;border-radius:10px;color:#fff;font-size:10px;font-weight:700;padding:2px 6px}.rotation-explanation{background-color:#e3f2fd;border-left:3px solid #2196f3;border-radius:4px;margin-top:8px;padding:4px 8px}.rotation-explanation small{color:#1976d2;font-weight:500}.winner-name-primary,.winner-player-primary{color:#007bff;font-size:24px;font-weight:700;margin-bottom:8px}.player-name-primary{color:#007bff;font-size:16px;font-weight:600}.player-label-primary{color:#333;font-size:16px;font-weight:600}.standing-player .player-label-primary,.standing-player .player-name-primary{display:block;font-size:14px;font-weight:500}.player-info .player-label-primary,.player-info .player-name-primary{color:#007bff;font-size:16px;font-weight:600}
/*# sourceMappingURL=main.f2b1dc87.css.map*/