:root{
  --bg:#08111f;
  --bg-soft:#101a2c;
  --bg-card:#111d31;
  --line:rgba(255,255,255,.08);
  --text:#f8fafc;
  --muted:#9fb0c7;
  --green:#19c37d;
  --red:#f43f5e;
  --gold:#f59e0b;
  --white:#ffffff;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 10px 30px rgba(0,0,0,.18);
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:'Inter',sans-serif;
  background:linear-gradient(180deg,#07101c 0%, #0a1423 100%);
  color:var(--text);
  overflow-x:hidden;
}

img{
  max-width:100%;
  display:block;
}

a{
  text-decoration:none;
  transition:.2s ease;
}

h1,h2,h3,h4,h5,h6,
.brand-name,
.section-title,
.navbar .nav-link{
  font-family:'Oswald',sans-serif;
  letter-spacing:.2px;
}

.topbar{
  background:#050c16;
  border-bottom:1px solid var(--line);
  padding:10px 0;
  font-size:14px;
}

.topbar-left{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:10px;
  color:var(--muted);
}

.top-divider{
  opacity:.4;
}

.topbar-right{
  display:flex;
  justify-content:flex-end;
  gap:12px;
}

.topbar-right a{
  color:var(--muted);
  font-size:15px;
}

.topbar-right a:hover{
  color:var(--white);
}

.site-header{
  position:sticky;
  top:0;
  z-index:1000;
  background:#08111f;
  border-bottom:1px solid var(--line);
}

.custom-navbar{
  padding:16px 0;
}

.brand-wrap{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand-logo{
  width:50px;
  height:50px;
  border-radius:14px;
  background:linear-gradient(135deg,var(--green),#0ea5e9);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#04111f;
  font-size:20px;
  flex-shrink:0;
}

.brand-name{
  font-size:30px;
  line-height:1;
  color:var(--white);
}

.brand-tag{
  font-size:12px;
  color:var(--muted);
  margin-top:4px;
}

.navbar .nav-link{
  color:#e5edf7;
  font-size:17px;
  padding:10px 14px !important;
}

.navbar .nav-link:hover,
.navbar .nav-link.active{
  color:var(--green);
}

.nav-toggle-btn{
  color:var(--white);
  border:none;
  box-shadow:none !important;
  font-size:28px;
}

.btn-brand{
  background:var(--green);
  color:#07111d;
  border:none;
  padding:12px 22px;
  border-radius:999px;
  font-weight:700;
}

.btn-brand:hover{
  background:#14ad70;
  color:#07111d;
}

.btn-outline-light-custom{
  border:1px solid rgba(255,255,255,.16);
  color:var(--white);
  padding:12px 22px;
  border-radius:999px;
  font-weight:600;
}

.btn-outline-light-custom:hover{
  background:rgba(255,255,255,.08);
  color:var(--white);
}

.hero-section{
  padding:36px 0 10px;
}

.hero-main{
  min-height:560px;
  border-radius:24px;
  overflow:hidden;
  background:
    linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.72)),
    url('https://images.unsplash.com/photo-1540747913346-19e32dc3e97e?auto=format&fit=crop&w=1400&q=80') center/cover no-repeat;
  display:flex;
  align-items:flex-end;
  box-shadow:var(--shadow);
}

.hero-overlay{
  padding:34px;
}

.hero-title{
  font-size:clamp(36px,4vw,64px);
  line-height:1.02;
  margin:14px 0 14px;
}

.hero-text{
  color:#d5dfeb;
  font-size:16px;
  line-height:1.8;
  max-width:760px;
}

.hero-meta{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  margin:22px 0 24px;
  color:#d5dfeb;
  font-size:14px;
}

.hero-meta span{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.hero-side-wrap{
  display:flex;
  flex-direction:column;
  gap:20px;
  height:100%;
}

.hero-side-card{
  min-height:173px;
  border-radius:20px;
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow);
}

.hero-side-overlay{
  position:absolute;
  inset:0;
  padding:22px;
  background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.76));
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
}

.hero-side-card h3{
  font-size:24px;
  line-height:1.08;
  margin:10px 0 8px;
  color:var(--white);
}

.hero-side-card p{
  margin:0;
  color:#d6deea;
  font-size:14px;
}

.side-bg-1{
  background:url('https://images.unsplash.com/photo-1518609878373-06d740f60d8b?auto=format&fit=crop&w=900&q=80') center/cover no-repeat;
}

.side-bg-2{
  background:url('https://images.unsplash.com/photo-1522778119026-d647f0596c20?auto=format&fit=crop&w=900&q=80') center/cover no-repeat;
}

.side-bg-3{
  background:url('https://images.unsplash.com/photo-1517466787929-bc90951d0974?auto=format&fit=crop&w=900&q=80') center/cover no-repeat;
}

.badge-custom{
  display:inline-block;
  width:max-content;
  padding:7px 12px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
}

.badge-green{
  background:rgba(25,195,125,.16);
  color:#bfffe1;
}

.badge-red{
  background:rgba(244,63,94,.16);
  color:#ffd4dd;
}

.badge-gold{
  background:rgba(245,158,11,.16);
  color:#ffe1a8;
}

.section-block{
  padding:70px 0 0;
}

.section-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:28px;
}

.section-title{
  margin:0;
  font-size:34px;
  color:var(--white);
  position:relative;
  padding-left:16px;
}

.section-title::before{
  content:"";
  position:absolute;
  left:0;
  top:6px;
  bottom:6px;
  width:5px;
  border-radius:999px;
  background:var(--green);
}

.section-link{
  color:#d7e2ef;
  font-weight:600;
}

.section-link:hover{
  color:var(--green);
}

.scores-row{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
}

.score-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:20px;
  box-shadow:var(--shadow);
}

.score-status{
  font-size:13px;
  font-weight:700;
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:8px;
}

.live-status{ color:#ffd1da; }
.upcoming-status{ color:#ffe0a6; }
.done-status{ color:#bfffe1; }

.live-dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background:var(--red);
  display:inline-block;
}

.team-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.team-row:last-of-type{
  border-bottom:none;
}

.team-left{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:600;
}

.team-badge{
  width:36px;
  height:36px;
  border-radius:50%;
  background:#1a2941;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:13px;
  font-weight:800;
}

.score-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:10px;
  margin-top:14px;
  color:var(--muted);
  font-size:14px;
}

.score-footer a{
  color:var(--green);
  font-weight:600;
}

.news-card,
.player-card,
.ranking-card,
.subscribe-box,
.footer-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
}

.news-card{
  overflow:hidden;
  height:100%;
}

.news-img{
  width:100%;
  height:230px;
  object-fit:cover;
}

.news-body{
  padding:22px;
}

.news-body h3{
  font-size:28px;
  line-height:1.15;
  margin:14px 0 12px;
}

.news-body p{
  color:var(--muted);
  line-height:1.7;
  margin-bottom:16px;
}

.meta-line{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
  color:#c4d2e3;
  font-size:14px;
}

.player-card{
  padding:24px;
  text-align:center;
  height:100%;
}

.player-img{
  width:110px;
  height:110px;
  object-fit:cover;
  border-radius:50%;
  margin:0 auto 16px;
  border:4px solid rgba(255,255,255,.08);
}

.player-card h3{
  font-size:28px;
  margin-bottom:6px;
}

.player-role{
  color:var(--green);
  font-weight:700;
  font-size:13px;
  text-transform:uppercase;
  letter-spacing:.5px;
  margin-bottom:14px;
}

.player-card p{
  color:var(--muted);
  line-height:1.7;
}

.pill-wrap{
  display:flex;
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  margin-top:18px;
}

.pill{
  padding:8px 12px;
  border-radius:999px;
  background:#18263d;
  color:#dce6f2;
  font-size:13px;
  font-weight:600;
}

.ranking-card{
  padding:24px;
  height:100%;
}

.ranking-card h3{
  font-size:28px;
  margin-bottom:18px;
}

.ranking-list{
  list-style:none;
  padding:0;
  margin:0;
}

.ranking-list li{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,.06);
}

.ranking-list li:last-child{
  border-bottom:none;
}

.ranking-list span{
  color:#e7eef8;
  font-weight:600;
}

.ranking-list strong{
  color:var(--muted);
}

.subscribe-box{
  padding:34px;
}

.subscribe-box h2{
  font-size:44px;
  margin-bottom:12px;
}

.subscribe-box p{
  color:var(--muted);
  line-height:1.8;
  margin:0;
}

.subscribe-form .form-control{
  height:56px;
  background:#0c1627;
  border:1px solid var(--line);
  color:var(--white);
  box-shadow:none;
}

.subscribe-form .form-control::placeholder{
  color:#9fb0c7;
}

.subscribe-form .form-control:focus{
  border-color:rgba(25,195,125,.45);
  background:#0c1627;
  color:var(--white);
  box-shadow:none;
}

.site-footer{
  padding:70px 0 30px;
}

.footer-box{
  padding:32px 28px;
}

.footer-brand{
  margin-bottom:18px;
}

.footer-text{
  color:var(--muted);
  line-height:1.8;
  margin-bottom:22px;
}

.footer-social{
  display:flex;
  gap:10px;
}

.footer-social a{
  width:40px;
  height:40px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#18263d;
  color:#dce6f2;
}

.footer-social a:hover{
  color:#fff;
  background:#21334f;
}

.footer-title{
  font-size:24px;
  margin-bottom:14px;
}

.footer-links{
  list-style:none;
  padding:0;
  margin:0;
}

.footer-links li{
  margin-bottom:10px;
}

.footer-links a{
  color:var(--muted);
}

.footer-links a:hover{
  color:var(--green);
}

.footer-bottom{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  color:var(--muted);
  font-size:14px;
}

@media (max-width:1199px){
  .scores-row{
    grid-template-columns:repeat(2,1fr);
  }
}

@media (max-width:991px){
  .hero-main{
    min-height:460px;
  }

  .hero-title{
    font-size:42px;
  }

  .section-title{
    font-size:30px;
  }

  .subscribe-box h2{
    font-size:34px;
  }

  .topbar-right{
    justify-content:flex-start;
  }
}

@media (max-width:767px){
  .hero-overlay{
    padding:22px;
  }

  .hero-title{
    font-size:34px;
  }

  .hero-main{
    min-height:390px;
  }

  .scores-row{
    grid-template-columns:1fr;
  }

  .section-head{
    flex-direction:column;
    align-items:flex-start;
  }

  .news-body h3,
  .player-card h3,
  .ranking-card h3{
    font-size:24px;
  }

  .subscribe-box{
    padding:24px;
  }

  .subscribe-box h2{
    font-size:28px;
  }

  .footer-bottom{
    flex-direction:column;
    align-items:flex-start;
  }
}
.page-hero{
  padding:48px 0 28px;
}

.page-title{
  font-size:clamp(38px,4vw,64px);
  line-height:1.03;
  margin:16px 0 12px;
  color:var(--white);
  font-family:'Oswald',sans-serif;
}

.page-text{
  color:var(--muted);
  max-width:760px;
  line-height:1.8;
  font-size:16px;
  margin:0;
}

/* Featured News */
.featured-news-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.featured-news-img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
}

.featured-news-content{
  padding:34px;
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.featured-news-content h2{
  font-size:42px;
  line-height:1.08;
  margin:16px 0 14px;
}

.featured-news-content p{
  color:var(--muted);
  line-height:1.8;
  margin-bottom:18px;
}

/* Fixtures */
.fixture-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:22px;
  box-shadow:var(--shadow);
  height:100%;
}

.fixture-top{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:20px;
}

.fixture-date{
  color:var(--muted);
  font-size:14px;
  font-weight:600;
}

.fixture-match{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  margin-bottom:20px;
}

.fixture-team{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:700;
  color:var(--white);
}

.fixture-vs{
  font-family:'Oswald',sans-serif;
  font-size:26px;
  color:var(--green);
}

.fixture-bottom{
  display:flex;
  flex-wrap:wrap;
  gap:18px;
  color:var(--muted);
  font-size:14px;
}

/* Results */
.results-wrap{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.result-item{
  display:grid;
  grid-template-columns: 1.3fr 1fr 1fr;
  gap:18px;
  padding:20px 24px;
  border-bottom:1px solid rgba(255,255,255,.06);
  align-items:center;
}

.result-item:last-child{
  border-bottom:none;
}

.result-left{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.result-left strong{
  color:var(--white);
  font-size:17px;
}

.result-left span{
  color:var(--muted);
  font-size:14px;
}

.result-center{
  color:#dce6f2;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}

.result-sep{
  opacity:.45;
}

.result-right{
  text-align:right;
  color:var(--green);
  font-weight:700;
  font-size:15px;
}

/* Points table */
.table-wrap{
  overflow-x:auto;
}

.custom-table{
  min-width:700px;
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
}

.table-head-row,
.table-body-row{
  display:grid;
  grid-template-columns: 2.2fr .6fr .6fr .6fr 1fr .8fr;
  gap:12px;
  align-items:center;
  padding:18px 22px;
}

.table-head-row{
  background:#0d1829;
  color:#dce6f2;
  font-weight:800;
  font-size:14px;
  text-transform:uppercase;
  letter-spacing:.4px;
}

.table-body-row{
  border-top:1px solid rgba(255,255,255,.06);
  color:var(--muted);
  font-weight:600;
}

.table-team{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--white);
}

/* Featured player */
.featured-player-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:var(--shadow);
}

.featured-player-img{
  width:100%;
  height:420px;
  object-fit:cover;
  border-radius:18px;
}

.featured-player-title{
  font-size:48px;
  line-height:1.05;
  margin:16px 0 10px;
}

.featured-player-role{
  color:var(--green);
  font-size:15px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  margin-bottom:16px;
}

.featured-player-text{
  color:var(--muted);
  line-height:1.8;
  max-width:720px;
}

.featured-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:24px;
}

.featured-stat-box{
  background:#18263d;
  border-radius:14px;
  padding:18px;
}

.featured-stat-box span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-bottom:6px;
}

.featured-stat-box strong{
  font-size:24px;
  color:var(--white);
  font-family:'Oswald',sans-serif;
}

/* Responsive */
@media (max-width:991px){
  .featured-news-content h2{
    font-size:34px;
  }

  .featured-player-title{
    font-size:38px;
  }

  .featured-stats-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .result-item{
    grid-template-columns:1fr;
    text-align:left;
  }

  .result-center,
  .result-right{
    justify-content:flex-start;
    text-align:left;
  }
}

@media (max-width:767px){
  .page-hero{
    padding:36px 0 20px;
  }

  .page-title{
    font-size:34px;
  }

  .featured-news-content{
    padding:24px;
  }

  .featured-news-content h2{
    font-size:28px;
  }

  .featured-news-img{
    min-height:260px;
  }

  .featured-player-box{
    padding:20px;
  }

  .featured-player-img{
    height:280px;
  }

  .featured-player-title{
    font-size:30px;
  }

  .featured-stats-grid{
    grid-template-columns:1fr 1fr;
  }

  .fixture-match{
    flex-direction:column;
    align-items:flex-start;
  }

  .fixture-vs{
    font-size:20px;
  }
}
/* Results page */
.results-wrap{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
}

.result-item{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:18px;
  padding:20px 24px;
  border-bottom:1px solid rgba(255,255,255,.06);
  align-items:center;
}

.result-item:last-child{
  border-bottom:none;
}

.result-left{
  display:flex;
  flex-direction:column;
  gap:6px;
}

.result-left strong{
  color:var(--white);
  font-size:17px;
}

.result-left span{
  color:var(--muted);
  font-size:14px;
}

.result-center{
  color:#dce6f2;
  font-weight:700;
  display:flex;
  align-items:center;
  gap:10px;
  justify-content:center;
  flex-wrap:wrap;
}

.result-sep{
  opacity:.45;
}

.result-right{
  text-align:right;
  color:var(--green);
  font-weight:700;
  font-size:15px;
}

/* Featured player */
.featured-player-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:var(--shadow);
}

.featured-player-img{
  width:100%;
  height:420px;
  object-fit:cover;
  border-radius:18px;
}

.featured-player-title{
  font-size:48px;
  line-height:1.05;
  margin:16px 0 10px;
}

.featured-player-role{
  color:var(--green);
  font-size:15px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  margin-bottom:16px;
}

.featured-player-text{
  color:var(--muted);
  line-height:1.8;
  max-width:720px;
}

.featured-stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin-top:24px;
}

.featured-stat-box{
  background:#18263d;
  border-radius:14px;
  padding:18px;
}

.featured-stat-box span{
  display:block;
  color:var(--muted);
  font-size:13px;
  margin-bottom:6px;
}

.featured-stat-box strong{
  font-size:24px;
  color:var(--white);
  font-family:'Oswald',sans-serif;
}

/* Role / topic cards */
.info-role-card,
.blog-topic-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
  height:100%;
}

.role-icon{
  width:58px;
  height:58px;
  border-radius:16px;
  background:#18263d;
  color:var(--green);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:22px;
  margin-bottom:18px;
}

.info-role-card h3,
.blog-topic-card h3{
  font-size:28px;
  margin-bottom:10px;
}

.info-role-card p,
.blog-topic-card p{
  color:var(--muted);
  line-height:1.8;
  margin:0;
}

/* Responsive */
@media (max-width:991px){
  .featured-player-title{
    font-size:38px;
  }

  .featured-stats-grid{
    grid-template-columns:repeat(2,1fr);
  }

  .result-item{
    grid-template-columns:1fr;
    text-align:left;
  }

  .result-center,
  .result-right{
    justify-content:flex-start;
    text-align:left;
  }
}

@media (max-width:767px){
  .featured-player-box{
    padding:20px;
  }

  .featured-player-img{
    height:280px;
  }

  .featured-player-title{
    font-size:30px;
  }

  .featured-stats-grid{
    grid-template-columns:1fr 1fr;
  }

  .info-role-card h3,
  .blog-topic-card h3{
    font-size:24px;
  }
}

/* Teams page */
.featured-team-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:var(--shadow);
}

.featured-team-img{
  width:100%;
  height:420px;
  object-fit:cover;
  border-radius:18px;
}

.featured-team-title{
  font-size:48px;
  line-height:1.05;
  margin:16px 0 10px;
}

.featured-team-meta{
  color:var(--green);
  font-size:15px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.4px;
  margin-bottom:16px;
}

.featured-team-text{
  color:var(--muted);
  line-height:1.8;
  max-width:720px;
}

.team-profile-card,
.team-type-card{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
  height:100%;
}

.team-card-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:16px;
}

.team-badge-lg{
  width:64px;
  height:64px;
  border-radius:18px;
  background:#18263d;
  color:var(--white);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:20px;
  font-family:'Oswald',sans-serif;
}

.team-profile-card h3,
.team-type-card h3{
  font-size:30px;
  margin-bottom:10px;
}

.team-profile-card p,
.team-type-card p{
  color:var(--muted);
  line-height:1.8;
  margin-bottom:14px;
}

.team-mini-meta{
  display:flex;
  flex-direction:column;
  gap:8px;
  color:#dce6f2;
  font-size:14px;
}

/* Rankings page */
.featured-ranking-box{
  background:var(--bg-card);
  border:1px solid var(--line);
  border-radius:20px;
  padding:28px;
  box-shadow:var(--shadow);
}

.featured-ranking-title{
  font-size:44px;
  line-height:1.08;
  margin:16px 0 14px;
}

.featured-ranking-text{
  color:var(--muted);
  line-height:1.8;
  max-width:760px;
}

.ranking-highlight-card{
  background:#18263d;
  border-radius:18px;
  padding:24px;
  height:100%;
}

.ranking-highlight-card h3{
  font-size:34px;
  margin:14px 0 10px;
}

.ranking-highlight-card p{
  color:var(--muted);
  line-height:1.8;
  margin:0;
}

/* Responsive */
@media (max-width:991px){
  .featured-team-title{
    font-size:38px;
  }

  .featured-ranking-title{
    font-size:34px;
  }
}

@media (max-width:767px){
  .featured-team-box,
  .featured-ranking-box{
    padding:20px;
  }

  .featured-team-img{
    height:280px;
  }

  .featured-team-title{
    font-size:30px;
  }

  .featured-ranking-title{
    font-size:28px;
  }

  .team-profile-card h3,
  .team-type-card h3{
    font-size:24px;
  }

  .ranking-highlight-card h3{
    font-size:28px;
  }
}
/* ==========================================================
   Premium Light Theme Override - GNTSports User Frontend
   Added safely at the end to avoid changing PHP features.
   ========================================================== */
:root{
  --bg:#f6f8fb;
  --bg-soft:#ffffff;
  --bg-card:#ffffff;
  --line:rgba(15,23,42,.10);
  --text:#0f172a;
  --muted:#64748b;
  --green:#16a66a;
  --red:#e11d48;
  --gold:#d97706;
  --white:#ffffff;
  --radius:20px;
  --radius-sm:14px;
  --shadow:0 18px 45px rgba(15,23,42,.08);
}

body{
  background:
    radial-gradient(circle at top left, rgba(22,166,106,.10), transparent 34%),
    radial-gradient(circle at top right, rgba(217,119,6,.10), transparent 32%),
    linear-gradient(180deg,#ffffff 0%,#f6f8fb 45%,#eef3f8 100%);
  color:var(--text);
}

a{ color:inherit; }
a:hover{ color:var(--green); }

.top-strip,
.topbar{
  background:linear-gradient(90deg,#f0fdf4,#ffffff,#fff7ed) !important;
  border-bottom:1px solid rgba(15,23,42,.08);
  color:#334155;
}

.top-strip .text-light-emphasis,
.topbar-left,
.topbar-right a{
  color:#475569 !important;
}

.topbar-right a:hover{ color:var(--green) !important; }

.site-header,
.main-navbar,
.custom-navbar{
  background:rgba(255,255,255,.92) !important;
  border-bottom:1px solid rgba(15,23,42,.08);
  backdrop-filter:blur(18px);
  box-shadow:0 12px 30px rgba(15,23,42,.06);
}

.main-navbar.sticky-top{ top:0; }

.navbar-dark .navbar-brand,
.navbar .navbar-brand,
.brand-name{
  color:#0f172a !important;
  font-weight:800;
}

.brand-logo{
  background:linear-gradient(135deg,#16a66a,#22c55e);
  color:#ffffff;
  box-shadow:0 12px 24px rgba(22,166,106,.25);
}

.brand-tag{ color:#64748b; }

.navbar-dark .navbar-nav .nav-link,
.navbar .nav-link{
  color:#334155 !important;
  border-radius:999px;
  font-weight:700;
}

.navbar-dark .navbar-nav .nav-link:hover,
.navbar-dark .navbar-nav .nav-link.active,
.navbar .nav-link:hover,
.navbar .nav-link.active{
  color:#0f7d4f !important;
  background:rgba(22,166,106,.10);
}

.navbar-toggler,
.nav-toggle-btn{
  border:1px solid rgba(15,23,42,.12) !important;
  color:#0f172a !important;
  background:#ffffff;
  border-radius:12px;
}

.navbar-dark .navbar-toggler-icon{
  filter:invert(1);
}

.btn-brand{
  background:linear-gradient(135deg,#16a66a,#22c55e);
  color:#ffffff !important;
  box-shadow:0 12px 24px rgba(22,166,106,.22);
}

.btn-brand:hover{
  background:linear-gradient(135deg,#0f8d59,#16a66a);
  color:#ffffff !important;
  transform:translateY(-1px);
}

.btn-outline-light-custom{
  border:1px solid rgba(15,23,42,.14);
  color:#0f172a;
  background:#ffffff;
}

.btn-outline-light-custom:hover{
  background:#f1f5f9;
  color:#0f172a;
}

.hero-section{ padding-top:46px; }

.hero-main,
.hero-side-card{
  box-shadow:0 24px 60px rgba(15,23,42,.16);
}

.hero-main{
  border:1px solid rgba(255,255,255,.40);
}

.hero-overlay,
.hero-side-overlay{
  background:linear-gradient(180deg,rgba(2,6,23,.05),rgba(2,6,23,.78));
}

.hero-text,
.hero-meta,
.hero-side-card p{
  color:#e2e8f0;
}

.badge-custom{
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.28);
}

.badge-green{
  background:rgba(22,166,106,.12);
  color:#047857;
}

.badge-red{
  background:rgba(225,29,72,.10);
  color:#be123c;
}

.badge-gold{
  background:rgba(217,119,6,.12);
  color:#b45309;
}

.section-title,
.page-title,
.featured-player-title,
.featured-team-title,
.featured-ranking-title,
.news-body h3,
.player-card h3,
.ranking-card h3,
.info-role-card h3,
.blog-topic-card h3,
.team-profile-card h3,
.team-type-card h3,
.footer-title,
.footer-brand{
  color:#0f172a;
}

.section-link{ color:#475569; }
.section-link:hover{ color:var(--green); }

.page-hero{
  padding:58px 0 38px;
  background:
    linear-gradient(135deg,rgba(22,166,106,.10),rgba(255,255,255,.88) 45%,rgba(217,119,6,.10)),
    radial-gradient(circle at 15% 20%, rgba(34,197,94,.12), transparent 28%);
  border-bottom:1px solid rgba(15,23,42,.08);
  margin-bottom:38px;
}

.page-text,
.news-body p,
.player-card p,
.ranking-list strong,
.subscribe-box p,
.footer-text,
.footer-links a,
.featured-news-content p,
.fixture-date,
.fixture-bottom,
.result-left span,
.table-body-row,
.featured-player-text,
.featured-stat-box span,
.info-role-card p,
.blog-topic-card p,
.featured-team-text,
.team-profile-card p,
.team-type-card p,
.featured-ranking-text,
.ranking-highlight-card p{
  color:#64748b !important;
}

.news-card,
.player-card,
.ranking-card,
.subscribe-box,
.footer-box,
.score-card,
.featured-news-box,
.fixture-card,
.results-wrap,
.custom-table,
.featured-player-box,
.info-role-card,
.blog-topic-card,
.featured-team-box,
.team-profile-card,
.team-type-card,
.featured-ranking-box{
  background:rgba(255,255,255,.94) !important;
  border:1px solid rgba(15,23,42,.08) !important;
  box-shadow:0 18px 45px rgba(15,23,42,.08) !important;
}

.news-card,
.player-card,
.ranking-card,
.fixture-card,
.team-profile-card,
.info-role-card,
.blog-topic-card{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.news-card:hover,
.player-card:hover,
.ranking-card:hover,
.fixture-card:hover,
.team-profile-card:hover,
.info-role-card:hover,
.blog-topic-card:hover{
  transform:translateY(-4px);
  border-color:rgba(22,166,106,.22) !important;
  box-shadow:0 24px 60px rgba(15,23,42,.12) !important;
}

.news-img,
.featured-news-img,
.featured-player-img,
.featured-team-img{
  filter:saturate(1.05) contrast(1.02);
}

.meta-line,
.score-footer,
.result-center,
.team-mini-meta{
  color:#64748b !important;
}

.team-row,
.ranking-list li,
.result-item,
.table-body-row,
.footer-bottom{
  border-color:rgba(15,23,42,.08) !important;
}

.team-badge,
.team-badge-lg,
.role-icon,
.featured-stat-box,
.ranking-highlight-card,
.pill,
.footer-social a,
.social-icons a{
  background:#f1f5f9 !important;
  color:#0f172a !important;
}

.role-icon,
.fixture-vs,
.featured-player-role,
.featured-team-meta,
.score-footer a,
.result-right{
  color:var(--green) !important;
}

.team-left,
.fixture-team,
.result-left strong,
.ranking-list span,
.table-team,
.featured-stat-box strong{
  color:#0f172a !important;
}

.table-head-row{
  background:linear-gradient(135deg,#f8fafc,#eef7f0) !important;
  color:#0f172a !important;
  border-bottom:1px solid rgba(15,23,42,.08);
}

.subscribe-form .form-control,
.form-control,
.form-select{
  background:#ffffff !important;
  border:1px solid rgba(15,23,42,.12) !important;
  color:#0f172a !important;
  box-shadow:none !important;
}

.subscribe-form .form-control::placeholder,
.form-control::placeholder{
  color:#94a3b8 !important;
}

.subscribe-form .form-control:focus,
.form-control:focus,
.form-select:focus{
  border-color:rgba(22,166,106,.45) !important;
  box-shadow:0 0 0 .22rem rgba(22,166,106,.12) !important;
}

.site-footer{
  background:linear-gradient(180deg,rgba(255,255,255,0),#ffffff 34%);
  color:#334155;
}

.footer-links a:hover,
.social-icons a:hover,
.footer-social a:hover{
  background:linear-gradient(135deg,#16a66a,#22c55e) !important;
  color:#ffffff !important;
}

.article-content{
  color:#1e293b !important;
}

.article-content h1,
.article-content h2,
.article-content h3,
.article-content h4{
  color:#0f172a !important;
}

.article-content blockquote{
  background:#fff7ed !important;
  color:#334155 !important;
}

.article-content table th{
  background:#f8fafc !important;
  color:#0f172a !important;
}

.article-content table td,
.article-content table th{
  border-color:#e2e8f0 !important;
}

@media (max-width:991px){
  .navbar-collapse{
    background:#ffffff;
    border:1px solid rgba(15,23,42,.08);
    border-radius:18px;
    margin-top:12px;
    padding:12px;
    box-shadow:0 18px 45px rgba(15,23,42,.10);
  }
}

@media (max-width:767px){
  .page-hero{ margin-bottom:22px; }
  .hero-section{ padding-top:24px; }
  .news-card:hover,
  .player-card:hover,
  .ranking-card:hover,
  .fixture-card:hover,
  .team-profile-card:hover,
  .info-role-card:hover,
  .blog-topic-card:hover{
    transform:none;
  }
}
