.matches-widget{background-color:#1b1838;border-radius:16px;padding:16px;width:100%;min-width:360px;color:#ffffff;font-family:Rubik,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden;box-sizing:border-box}.matches-widget::-webkit-scrollbar{width:6px}.matches-widget::-webkit-scrollbar-track{background:transparent}.matches-widget::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:3px}.matches-tabs{display:flex;gap:8px;margin-bottom:12px;border-bottom:1px solid rgba(255,255,255,.1);padding-bottom:12px}.matches-tab{background:none;border:none;color:rgba(255,255,255,.6);font-size:14px;font-weight:500;padding:8px 16px;cursor:pointer;position:relative;transition:all .2s}.matches-tab:hover{color:rgba(255,255,255,.9)}.matches-tab.active{color:#c084fc}.matches-tab.active:after{content:"";position:absolute;bottom:-13px;left:0;right:0;height:2px;background-color:#c084fc}.matches-filters{display:flex;gap:8px;margin-bottom:16px}.filter-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;background:rgba(255,255,255,.05);border:1px solid transparent;border-radius:20px;font-size:12px;font-weight:500;color:rgba(255,255,255,.7);cursor:pointer;transition:all .2s}.filter-pill:hover{background:rgba(255,255,255,.1)}.filter-pill.active{background:rgba(192,132,252,.25);border-color:transparent;color:#c084fc}.live-indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.3)}.live-indicator.active{background:#22c55e;animation:pulse-live 1.5s infinite}@keyframes pulse-live{0%,to{opacity:1}50%{opacity:.4}}.matches-content{display:flex;flex-direction:column;gap:2px}.no-matches{text-align:center;padding:40px 20px;color:rgba(255,255,255,.5);font-size:14px}.league-group{display:flex;flex-direction:column;gap:0;border-top:2px solid rgba(255,255,255,.1);margin-top:8px;padding-top:0}.league-group-header{display:flex;align-items:center;gap:10px;padding:8px 12px 4px;margin-bottom:0;border-bottom:none}.league-group-logo{width:24px;height:24px;-o-object-fit:contain;object-fit:contain}.league-group-info{flex:1;display:flex;flex-direction:column;gap:2px}.league-group-name{font-size:13px;font-weight:600;color:#ffffff}.league-group-country{display:flex;align-items:center;gap:6px;font-size:11px;color:rgba(255,255,255,.5)}.league-group-country img{width:14px;height:14px;border-radius:50%;-o-object-fit:cover;object-fit:cover}.league-group-fav{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;transition:color .2s}.league-group-fav:hover{color:#6366f1}.match-card{display:flex;align-items:center;padding:8px 16px;margin:0;border-radius:0;transition:background-color .2s;gap:0}.match-card,.match-card:hover{background:transparent}.match-time-col{width:70px;min-width:70px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding-right:12px;border-right:1px solid rgba(255,255,255,.08);min-height:52px}.match-status{font-size:13px;font-weight:600;color:rgba(255,255,255,.8)}.match-status.live{color:#ff3333;font-weight:700;font-size:12px}.live-minutes{display:inline-flex;align-items:baseline;gap:1px}.live-number-wrapper{position:relative;padding-bottom:4px}.live-tick{opacity:1}.live-pulse-bar{position:absolute;bottom:-2px;left:50%;transform:translateX(-50%);width:10px;height:2px;background:#ff3333;border-radius:1px;animation:pulse-bar 1.5s ease-in-out infinite}@keyframes pulse-bar{0%,to{opacity:1;width:10px}50%{opacity:.4;width:6px}}.match-date-sub:has(+.match-status.live),.match-status.live+.match-date-sub{display:none}.match-date-sub{font-size:10px;color:rgba(255,255,255,.5)}.match-teams-col{flex:1;display:flex;flex-direction:column;gap:8px;padding:0 16px;min-height:52px}.match-team-row{display:flex;align-items:center;gap:10px;height:22px}.match-team-logo-sm{width:20px;height:20px;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.match-team-name-sm{font-size:13px;color:#ffffff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.match-score-col{width:50px;min-width:50px;flex-direction:column;gap:8px;padding:0 12px;border-right:1px solid rgba(255,255,255,.08);min-height:52px}.match-score-col,.match-score-num{display:flex;align-items:center;justify-content:center}.match-score-num{font-size:15px;font-weight:700;color:#ffffff;height:22px}.match-score-num.live{color:#ff3333}@keyframes score-flash{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.7}}.match-score-num.changed{animation:score-flash .5s ease-out}.match-odds-col{width:110px;min-width:110px;display:flex;flex-direction:column;gap:4px;padding:0 12px;min-height:52px}.odds-row{display:flex;gap:4px;justify-content:center}.odd-box{font-size:9px;font-weight:600;color:rgba(255,255,255,.5);padding:3px 0;background:rgba(255,255,255,.08)}.odd-box,.odd-value{width:32px;text-align:center;border-radius:4px}.odd-value{font-size:11px;font-weight:700;color:#fbbf24;padding:4px 0;background:rgba(251,191,36,.12)}.match-fav-btn{width:40px;min-width:40px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:none;color:rgba(255,255,255,.3);cursor:pointer;transition:color .2s}.match-fav-btn.active,.match-fav-btn:hover{color:#6366f1}@media (max-width:768px){.matches-widget{width:100%;min-width:auto;max-width:100%;border-radius:12px;padding:12px;max-height:none}.match-odds-col{display:none}.match-card{padding:6px 8px}.match-time-col{width:60px;min-width:60px;padding-right:8px}.match-score-col{width:40px;min-width:40px;padding:0 8px}.match-teams-col{padding:0 8px}.match-fav-btn{width:32px;min-width:32px;height:28px}.match-status,.match-team-name-sm{font-size:12px}.match-score-num{font-size:14px}.matches-tab{padding:6px 12px;font-size:13px}.filter-pill{padding:5px 10px;font-size:11px}}.matches-skeleton{display:flex;flex-direction:column;gap:16px}.skeleton-league-group{display:flex;flex-direction:column;gap:8px}.skeleton-header{height:40px;background:linear-gradient(90deg,rgba(255,255,255,.05) 25%,rgba(255,255,255,.1) 50%,rgba(255,255,255,.05) 75%);background-size:200% 100%;border-radius:8px}.skeleton-match{height:56px;background:linear-gradient(90deg,rgba(255,255,255,.03) 25%,rgba(255,255,255,.06) 50%,rgba(255,255,255,.03) 75%);background-size:200% 100%;border-radius:8px}.animate-pulse{animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{background-position:200% 0}50%{background-position:-200% 0}}.live-count{background:rgba(239,68,68,.2);color:#ef4444;font-size:10px;font-weight:600;padding:2px 6px;border-radius:10px;margin-left:4px}