:root{--primary-color:#0c2340;--accent-color:#e4002b;--accent-gold:#ffb81c;--mexico-green:#006847;--bg-light:#f4f6f9;--text-dark:#1e293b;--text-muted:#64748b;--border-color:#e2e8f0;--card-shadow:0 4px 20px rgba(12,35,64,0.06)}body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;color:var(--text-dark);background-color:var(--bg-light);line-height:1.6;overflow-x:hidden}p,li,td{color:#334155;font-size:0.95rem}.navbar{background-color:rgba(12,35,64,0.98) !important;backdrop-filter:blur(10px);border-bottom:2px solid var(--accent-gold);padding:0.75rem 0}.navbar-brand img{max-height:40px;object-fit:contain}.navbar-brand span{color:#fff;font-weight:800;letter-spacing:0.5px}.nav-link{color:rgba(255,255,255,0.85) !important;font-weight:500;font-size:0.95rem;margin:0 0.5rem;transition:color 0.3s ease}.nav-link:hover,.nav-link.active{color:var(--accent-gold) !important}.hero-section{background:linear-gradient(135deg,#0c2340 0%,#1e3a8a 100%);color:#ffffff;padding:5rem 0;position:relative;overflow:hidden}.hero-section::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:radial-gradient(circle at 80% 20%,rgba(228,0,43,0.15) 0%,transparent 50%);pointer-events:none}.hero-title{font-weight:800;font-size:2.8rem;line-height:1.25;color:#ffffff;text-shadow:0 2px 10px rgba(0,0,0,0.3)}.hero-title span{color:var(--accent-gold)}.hero-desc{font-size:1.1rem;color:#cbd5e1;margin-bottom:2rem;line-height:1.7}.hero-badge{display:inline-flex;align-items:center;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);padding:0.5rem 1rem;border-radius:50px;font-size:0.85rem;color:var(--accent-gold);font-weight:600;margin-bottom:1.5rem}.hero-img-wrapper{position:relative;border-radius:12px;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,0.4)}.hero-img-wrapper img{width:100%;height:auto;display:block;transition:transform 0.5s ease}.hero-img-wrapper:hover img{transform:scale(1.03)}.stat-card{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:1rem;text-align:center;backdrop-filter:blur(5px)}.stat-num{font-size:1.8rem;font-weight:700;color:var(--accent-gold);display:block}.stat-label{font-size:0.8rem;color:#94a3b8}section{padding:5rem 0;border-bottom:1px solid var(--border-color)}.section-bg-white{background-color:#ffffff}.section-title-wrap{margin-bottom:3.5rem;text-align:center}.section-title{font-weight:800;font-size:2.2rem;color:var(--primary-color);position:relative;display:inline-block;padding-bottom:1rem}.section-title::after{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:60px;height:4px;background-color:var(--accent-color);border-radius:2px}.section-subtitle{color:var(--text-muted);font-size:1.05rem;margin-top:0.75rem}.table-responsive-custom{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;border:1px solid var(--border-color)}.match-ticker-card{background:#ffffff;border-radius:12px;border-left:5px solid var(--accent-color);box-shadow:var(--card-shadow);transition:transform 0.2s ease}.match-ticker-card:hover{transform:translateY(-3px)}.match-header{font-size:0.8rem;color:var(--text-muted);border-bottom:1px dashed var(--border-color);padding-bottom:0.5rem}.team-flag{width:24px;height:16px;object-fit:cover;border-radius:2px;box-shadow:0 1px 3px rgba(0,0,0,0.15)}.team-name{font-weight:600;font-size:0.95rem;color:var(--text-dark)}.match-score{font-size:1.25rem;font-weight:700;color:var(--primary-color)}.match-status-badge{font-size:0.75rem;padding:0.25rem 0.6rem;border-radius:50px;font-weight:600}.group-card{background:#ffffff;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--card-shadow);overflow:hidden;height:100%}.group-header{background:linear-gradient(135deg,var(--primary-color) 0%,#1e293b 100%);color:#ffffff;padding:0.75rem 1.25rem;font-weight:700;font-size:1.1rem;display:flex;justify-content:space-between;align-items:center}.group-header .host-flag-icon{font-size:1.2rem;color:var(--accent-gold)}.group-table{margin-bottom:0}.group-table th{font-size:0.75rem;color:var(--text-muted);text-transform:uppercase;background-color:#f8fafc}.group-table td{font-size:0.85rem;vertical-align:middle}.group-table tr:hover{background-color:#f1f5f9}.team-profile-card{background:#ffffff;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--card-shadow);overflow:hidden;transition:all 0.3s ease}.team-profile-card:hover{transform:translateY(-5px);box-shadow:0 10px 25px rgba(12,35,64,0.12)}.team-banner{height:120px;position:relative;background-size:cover;background-position:center}.team-banner-usa{background:linear-gradient(45deg,#002868,#bf0a30)}.team-banner-mex{background:linear-gradient(45deg,#006847,#ffffff,#ce1126)}.team-banner-can{background:linear-gradient(45deg,#ff0000,#ffffff,#ff0000)}.team-banner-arg{background:linear-gradient(45deg,#75aadb,#ffffff,#75aadb)}.team-avatar-wrap{margin-top:-40px;padding-left:1.25rem;position:relative;z-index:2}.team-avatar{width:80px;height:80px;border-radius:50%;border:4px solid #ffffff;background:#ffffff;box-shadow:0 4px 10px rgba(0,0,0,0.15);display:flex;align-items:center;justify-content:center;font-size:2rem}.team-profile-body{padding:1.25rem}.news-card-horizontal{background:#ffffff;border-radius:10px;border:1px solid var(--border-color);box-shadow:var(--card-shadow);overflow:hidden;display:flex;flex-direction:column;height:100%;transition:box-shadow 0.3s ease}.news-card-horizontal:hover{box-shadow:0 8px 20px rgba(12,35,64,0.1)}.news-badge{background-color:var(--accent-color);color:#ffffff;font-size:0.75rem;font-weight:600;padding:0.25rem 0.5rem;border-radius:3px;display:inline-block;margin-bottom:0.5rem}.news-title{font-weight:700;font-size:1.1rem;color:var(--primary-color);margin-bottom:0.5rem}.news-meta{font-size:0.8rem;color:var(--text-muted)}.stadium-card{background:#ffffff;border-radius:12px;border:1px solid var(--border-color);box-shadow:var(--card-shadow);overflow:hidden}.stadium-img-wrap{position:relative;overflow:hidden}.stadium-img-wrap img{width:100%;height:240px;object-fit:cover;transition:transform 0.5s ease}.stadium-img-wrap:hover img{transform:scale(1.05)}.stadium-city-tag{position:absolute;bottom:10px;left:10px;background:rgba(12,35,64,0.9);color:#ffffff;font-weight:600;font-size:0.8rem;padding:0.3rem 0.75rem;border-radius:4px}.guide-item{background:#ffffff;border-radius:10px;border:1px solid var(--border-color);padding:1.5rem;height:100%;transition:all 0.3s ease}.guide-item:hover{border-color:var(--accent-gold);transform:translateY(-3px)}.guide-icon-wrap{width:50px;height:50px;border-radius:50%;background-color:rgba(12,35,64,0.05);color:var(--primary-color);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1rem}.faq-accordion .accordion-item{border:1px solid var(--border-color);border-radius:8px !important;margin-bottom:1rem;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,0.02)}.faq-accordion .accordion-button{font-weight:600;color:var(--primary-color);font-size:1.05rem;padding:1.25rem}.faq-accordion .accordion-button:not(.collapsed){background-color:rgba(12,35,64,0.03);color:var(--accent-color);box-shadow:none}.faq-accordion .accordion-body{color:#475569;font-size:0.95rem;line-height:1.7;padding:1.25rem;background-color:#fafbfc}.info-source-card{background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);border:1px dashed var(--accent-gold);border-radius:12px;padding:2rem}.visual-banner-card{border-radius:12px;overflow:hidden;box-shadow:var(--card-shadow)}.site-footer{background-color:#060f1e;color:#94a3b8;padding:4rem 0 2rem;border-top:4px solid var(--accent-color)}.footer-heading{color:#ffffff;font-weight:700;font-size:1.1rem;margin-bottom:1.5rem;position:relative;padding-bottom:0.5rem}.footer-heading::after{content:'';position:absolute;bottom:0;left:0;width:30px;height:2px;background-color:var(--accent-gold)}.footer-links{list-style:none;padding:0;margin:0}.footer-links li{margin-bottom:0.75rem}.footer-links a{color:#94a3b8;text-decoration:none;transition:color 0.2s}.footer-links a:hover{color:#ffffff}.footer-bottom{border-top:1px solid rgba(255,255,255,0.08);padding-top:1.5rem;margin-top:3rem;font-size:0.85rem}@media (max-width:991.98px){.hero-title{font-size:2.2rem}.section-title{font-size:1.8rem}}