*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--green: #16a34a;--green-dark: #15803d;--green-light: #dcfce7;--red: #dc2626;--red-light: #fee2e2;--yellow: #d97706;--yellow-light: #fef3c7;--blue: #2563eb;--blue-light: #dbeafe;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-500: #6b7280;--gray-700: #374151;--gray-900: #111827;--radius: 12px;--shadow: 0 1px 3px rgba(0,0,0,.08), 0 4px 12px rgba(0,0,0,.06);--shadow-lg: 0 8px 30px rgba(0,0,0,.15)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--gray-50);color:var(--gray-900);min-height:100vh;line-height:1.5}.app{display:flex;flex-direction:column;min-height:100vh}.app-header{background:linear-gradient(135deg,#064e3b,#065f46,#047857);color:#fff;padding:20px 24px;box-shadow:0 2px 12px #0003}.header-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:16px}.header-title{display:flex;align-items:center;gap:14px}.header-icon{font-size:2.5rem;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3))}.header-title h1{font-size:1.75rem;font-weight:800;letter-spacing:-.5px}.header-title p{font-size:.9rem;opacity:.8}.live-banner{display:flex;align-items:center;gap:8px;background:#ef444433;border:1px solid rgba(239,68,68,.5);color:#fca5a5;font-weight:700;font-size:.9rem;padding:6px 14px;border-radius:999px;letter-spacing:1px}.live-dot-anim{width:8px;height:8px;background:#ef4444;border-radius:50%;animation:pulse 1.2s infinite}.app-main{max-width:1200px;margin:0 auto;padding:24px;width:100%;flex:1}.stats-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.stat{background:#fff;border-radius:var(--radius);padding:16px 20px;display:flex;flex-direction:column;align-items:center;min-width:100px;box-shadow:var(--shadow);flex:1}.stat-value{font-size:1.8rem;font-weight:800;color:var(--green);line-height:1}.stat-value.live-dot:after{content:"";display:inline-block;width:8px;height:8px;background:#ef4444;border-radius:50%;margin-left:4px;vertical-align:middle;animation:pulse 1.2s infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.stat-label{font-size:.75rem;color:var(--gray-500);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.competition-tabs-wrapper{overflow-x:auto;margin-bottom:24px;-webkit-overflow-scrolling:touch;scrollbar-width:none}.competition-tabs-wrapper::-webkit-scrollbar{display:none}.competition-tabs{display:flex;gap:8px;padding-bottom:4px;min-width:max-content}.tab{display:flex;align-items:center;gap:7px;padding:8px 16px;border:1.5px solid var(--gray-200);border-radius:999px;background:#fff;font-size:.85rem;font-weight:600;color:var(--gray-700);cursor:pointer;transition:all .15s;white-space:nowrap}.tab:hover{border-color:var(--green);color:var(--green)}.tab-active{background:var(--green);border-color:var(--green);color:#fff;box-shadow:0 2px 8px #16a34a4d}.tab-flag{font-size:1rem}.tab-name{font-size:.85rem}.date-group{margin-bottom:32px}.date-header{font-size:1rem;font-weight:700;color:var(--gray-700);margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid var(--gray-200)}.games-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.game-card{background:#fff;border-radius:var(--radius);padding:16px 18px;box-shadow:var(--shadow);border-top:4px solid var(--gray-200);transition:transform .15s,box-shadow .15s;display:flex;flex-direction:column;gap:10px}.game-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.game-card.status-live{border-top-color:#ef4444}.game-card.status-finished{border-top-color:var(--green)}.game-card.status-scheduled{border-top-color:var(--blue)}.game-card.status-postponed{border-top-color:var(--yellow)}.game-card.status-cancelled{border-top-color:var(--gray-300)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:8px}.card-meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center}.card-time{font-size:.8rem;color:var(--gray-500);font-weight:600}.badge{font-size:.7rem;font-weight:600;padding:2px 8px;border-radius:999px;letter-spacing:.3px;display:inline-flex;align-items:center;gap:4px}.badge-league{background:var(--gray-100);color:var(--gray-700)}.badge-status.status-live{background:#fee2e2;color:#b91c1c}.badge-status.status-finished{background:var(--green-light);color:var(--green-dark)}.badge-status.status-scheduled{background:var(--blue-light);color:#1d4ed8}.badge-status.status-postponed{background:var(--yellow-light);color:#92400e}.badge-status.status-cancelled{background:var(--gray-100);color:var(--gray-500)}.live-dot-sm{width:6px;height:6px;background:#ef4444;border-radius:50%;animation:pulse 1.2s infinite}.card-score{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0}.team{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.team-crest{width:36px;height:36px;object-fit:contain}.team-name{font-weight:700;font-size:.9rem;color:var(--gray-900);text-align:center;line-height:1.2}.scoreboard{flex-shrink:0;text-align:center;min-width:72px}.score{font-size:1.5rem;font-weight:900;color:var(--gray-900);letter-spacing:-1px;display:block}.halftime{font-size:.7rem;color:var(--gray-500);display:block;margin-top:2px}.score-placeholder{font-size:1.1rem;font-weight:600;color:var(--gray-300)}.card-footer{display:flex;gap:12px;border-top:1px solid var(--gray-100);padding-top:8px}.meta-item{font-size:.78rem;color:var(--gray-500)}.loading-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}.skeleton-card{height:160px;background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:200% 100%;border-radius:var(--radius);animation:shimmer 1.4s infinite}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.error-state{text-align:center;padding:60px 20px;color:var(--gray-500)}.error-icon{font-size:3rem;display:block;margin-bottom:12px}.error-state h3{font-size:1.2rem;margin-bottom:8px;color:var(--gray-700)}.error-state p{margin-bottom:20px;max-width:400px;margin-left:auto;margin-right:auto}.empty-state{text-align:center;padding:80px 20px;color:var(--gray-500)}.empty-icon{font-size:4rem;display:block;margin-bottom:16px}.empty-state h3{font-size:1.3rem;margin-bottom:8px;color:var(--gray-700)}.btn{padding:9px 18px;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s,transform .1s;display:inline-flex;align-items:center;gap:6px}.btn:active{transform:scale(.98)}.btn-primary{background:var(--green);color:#fff}.btn-primary:hover{background:var(--green-dark)}@media (max-width: 600px){.app-header,.app-main{padding:16px}.header-title h1{font-size:1.4rem}.header-icon{font-size:2rem}.games-grid{grid-template-columns:1fr}.stats-bar{gap:8px}.stat{min-width:80px;padding:12px}.stat-value{font-size:1.4rem}}
