*{margin:0;padding:0;box-sizing:border-box}body{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;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}@keyframes spin{0%{transform:rotate(0deg) scale(1)}50%{transform:rotate(180deg) scale(1.1)}to{transform:rotate(1turn) scale(1)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-20px)}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:20px}.football-spinner{font-size:80px;animation:spin 2s linear infinite,bounce 2s ease-in-out infinite;display:inline-block}.loading-text{color:white;font-size:1.3rem;font-weight:500;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.container{max-width:1200px;margin:0 auto}.header{text-align:center;color:white;margin-bottom:40px;padding-bottom:20px;border-bottom:2px solid rgba(255,255,255,.2)}.header h1{font-size:2.5rem;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.header p{font-size:1.1rem;opacity:.9}.explainer-button{background:rgba(255,255,255,.2);border:2px solid rgba(255,255,255,.3);color:white;width:50px;height:50px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;flex-shrink:0}.explainer-button:hover{background:rgba(255,255,255,.3);border-color:rgba(255,255,255,.5);transform:scale(1.05)}.todays-games{background:white;border-radius:12px;padding:20px;margin-bottom:30px;box-shadow:0 10px 30px rgba(0,0,0,.2)}.todays-games h2{color:#667eea;margin-bottom:15px;font-size:1.5rem}.games-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:12px;gap:12px}.game-card{background:linear-gradient(135deg,#f8f9fa,#ffffff);border:2px solid #e9ecef;border-radius:8px;padding:12px;transition:all .3s ease}.game-card:hover{border-color:#667eea;box-shadow:0 5px 15px rgba(102,126,234,.2)}.game-teams{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.team{flex:1 1;font-weight:600;font-size:.95rem;text-align:center;padding:8px 4px;border-radius:4px;background:rgba(102,126,234,.05);gap:4px}.team,.team>div{display:flex;flex-direction:column;align-items:center}.team>div{gap:2px;width:100%}.score-container{display:flex;flex-direction:column;align-items:center;min-width:80px;gap:4px}.score{font-size:1.5rem;font-weight:700;color:#667eea;line-height:1}.status{font-size:.75rem;color:#666;font-weight:500}.game-meta{text-align:center;font-size:.8rem;color:#999;padding-top:8px;border-top:1px solid #e9ecef}.flag-icon{width:24px;height:16px;margin-right:6px;border-radius:2px;vertical-align:middle;object-fit:cover}.team-participant{font-size:.75rem;opacity:.7;font-weight:500;margin-top:2px}.modal-match-teams{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:8px}.modal-team{flex:1 1;font-weight:600;font-size:.95rem;text-align:center;padding:8px 4px;border-radius:4px;background:rgba(102,126,234,.05);gap:4px}.modal-team,.modal-team>div{display:flex;flex-direction:column;align-items:center}.modal-team>div{gap:2px;width:100%}.modal-match .match-score{display:flex;flex-direction:column;align-items:center;min-width:60px;gap:4px}.modal-match .match-score .score{font-size:1.2rem;font-weight:700;color:#667eea}.tomorrows-games{background:white;border-radius:12px;margin-bottom:30px;box-shadow:0 10px 30px rgba(0,0,0,.2)}.accordion-button{width:100%;background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;padding:16px 20px;border-radius:12px;cursor:pointer;font-size:1.1rem;font-weight:600;display:flex;justify-content:space-between;align-items:center;transition:all .3s ease}.accordion-button:hover{opacity:.9;box-shadow:0 5px 15px rgba(102,126,234,.3)}.accordion-button:active{transform:scale(.98)}.accordion-icon{transition:transform .3s ease;font-size:.9rem}.accordion-icon.open{transform:rotate(180deg)}.accordion-content{padding:20px;border-radius:0 0 12px 12px;animation:slideDown .3s ease}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.games-container{grid-template-columns:1fr}.game-card{padding:10px}.score{font-size:1.2rem}.accordion-button{font-size:1rem;padding:12px 16px}}.participants-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));grid-gap:20px;gap:20px;margin-bottom:40px}.participant-card{background:white;border-radius:12px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,.2);transition:transform .3s ease,box-shadow .3s ease}.participant-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px rgba(0,0,0,.3)}.participant-name{font-size:1.5rem;font-weight:700;color:#667eea;margin-bottom:15px;border-bottom:2px solid #667eea;padding-bottom:10px}.teams-container{display:flex;flex-direction:column;gap:10px}.team-button{background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;padding:12px 16px;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;transition:all .3s ease;text-align:left;display:flex;align-items:center;gap:8px}.team-flag{width:20px;height:14px;border-radius:2px;object-fit:cover;flex-shrink:0}.team-ranking{font-size:.8rem;opacity:.7;font-weight:600;margin-left:4px}.team-button:hover{opacity:.9;transform:translateX(5px)}.team-button:active{transform:translateX(5px) scale(.98)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:white;border-radius:16px;max-width:600px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 25px 50px rgba(0,0,0,.3)}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:white;padding:20px;border-radius:16px 16px 0 0;display:flex;justify-content:space-between;align-items:center}.modal-team-header{display:flex;flex-direction:column;align-items:center;gap:10px}.modal-flag-icon{width:40px;height:28px;border-radius:3px;object-fit:cover}.modal-header h2{font-size:1.8rem;margin:0}.modal-participant{font-size:.9rem;opacity:.9;margin:0;font-weight:500}.explainer-body{padding:20px}.explainer-section{margin-bottom:20px;padding:15px;background:rgba(102,126,234,.05);border-radius:8px;border-left:4px solid #667eea}.explainer-section h3{margin:0 0 10px;color:#667eea;font-size:1.1rem}.explainer-section p{margin:0;color:#333;line-height:1.6;font-size:.95rem}.info-box{background:rgba(102,126,234,.1);border-left-color:#667eea;font-weight:500;text-align:center}.modal-close{background:rgba(255,255,255,.2);border:none;color:white;width:40px;height:40px;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.modal-close:hover{background:rgba(255,255,255,.3)}.modal-body{padding:20px}.matches-section{margin-bottom:30px}.matches-section h3{color:#667eea;font-size:1.3rem;margin-bottom:15px;padding-bottom:10px;border-bottom:2px solid #667eea}.match-item{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:12px;border-left:4px solid #667eea}.match-teams{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-weight:600;color:#333}.match-score{text-align:center;font-size:1.2rem;color:#667eea;margin:0 10px;min-width:60px}.match-time{font-size:.85rem;color:#666;display:flex;justify-content:space-between;align-items:center}.no-matches{text-align:center;padding:20px;color:#999;font-style:italic}@media (max-width:768px){.participants-grid{grid-template-columns:1fr}.header h1{font-size:1.8rem}.modal-content{max-height:90vh}}