/*
Theme Name: RankVex UK
Theme URI: https://rankvexouk.com/
Author: RankVex UK
Author URI: https://rankvexouk.com/
Description: A premium UK gambling comparison theme for rankvexouk.com. Activate to auto-create all required pages (Homepage, Rankings, Guide, Blog, FAQ, About Us, Our Method, Help, Privacy Policy, Terms of Service).
Version: 1.0.0
Requires at least: 5.8
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: rankvexouk
*/

:root{
  --bg:#07140b;
  --bg-2:#0a1a10;
  --panel:#0d2315;
  --panel-2:#102a1a;
  --border:#143524;
  --text:#e7f1ea;
  --muted:#9fb6a6;
  --gold:#f3c23c;
  --gold-2:#f5d76a;
  --green:#2fa36a;
  --green-2:#38c17f;
  --accent:#ffb86b;
  --shadow:0 10px 30px rgba(0,0,0,.35);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Inter","Helvetica Neue",Arial,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none;transition:color .2s ease}
a:hover{color:var(--gold)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:"Playfair Display","Georgia",serif;line-height:1.2;margin:0 0 .5em;color:#fff;font-weight:700}
h1{font-size:clamp(2rem,4.2vw,3.4rem)}
h2{font-size:clamp(1.5rem,2.8vw,2.1rem)}
h3{font-size:1.2rem}
p{margin:0 0 1em}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.gold{color:var(--gold)}

/* ── Header ── */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(7,20,11,.88);
  backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid var(--border);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;padding:16px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:700;color:#fff}
.brand-mark{
  width:30px;height:30px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#1e6e45,#0a3b23);
  display:grid;place-items:center;border:1px solid #2fa36a44;
}
.brand-mark svg{width:16px;height:16px;color:var(--gold)}
.nav{display:flex;gap:28px;align-items:center}
.nav a{font-size:.92rem;color:#d5e2d9;font-weight:500}
.nav a:hover{color:var(--gold)}
.menu-toggle{display:none;background:none;border:0;color:#fff;cursor:pointer}

/* ── Hero ── */
.hero{padding:72px 0 32px;text-align:center;position:relative;overflow:hidden}
.hero::before{
  content:"";position:absolute;inset:-20% -10% auto -10%;height:480px;
  background:radial-gradient(ellipse at 50% 0%, rgba(47,163,106,.18), transparent 60%);
  pointer-events:none;
}
.tag{
  display:inline-block;padding:8px 18px;border-radius:999px;
  background:rgba(243,194,60,.12);border:1px solid rgba(243,194,60,.35);
  color:var(--gold);font-size:.78rem;letter-spacing:.12em;font-weight:700;text-transform:uppercase;
}
.hero h1{margin-top:20px}
.hero h1 .hl{color:var(--gold)}
.hero h1 .hl-2{color:#b6d36a}
.hero .lead{max-width:620px;margin:14px auto 26px;color:var(--muted)}
.chips{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.chip{
  display:inline-flex;align-items:center;gap:8px;
  padding:10px 16px;border-radius:999px;
  border:1px solid var(--border);background:var(--panel);
  font-size:.88rem;color:#d9e8de;
}
.chip .dot{width:8px;height:8px;border-radius:50%;background:var(--green-2)}
.chip.star .dot{background:#6bd0ff}
.chip.bolt .dot{background:var(--accent)}

/* ── Featured cards ── */
.featured{padding:48px 0 24px;text-align:center}
.featured h2{color:var(--gold);font-family:"Playfair Display",serif}
.featured .sub{color:var(--muted);margin-bottom:28px}
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:8px}
.card{
  background:linear-gradient(180deg,var(--panel) 0%,var(--panel-2) 100%);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:22px;box-shadow:var(--shadow);
  text-align:left;transition:transform .25s ease,border-color .25s ease;
}
.card:hover{transform:translateY(-3px);border-color:#1f4c33}
.card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.rank-badge{background:#0a1a10;border:1px solid var(--border);color:#cfe3d6;font-size:.78rem;padding:6px 12px;border-radius:999px}
.score{text-align:right}
.score .num{font-size:1.9rem;font-weight:700;color:#fff;line-height:1}
.score .stars{color:var(--gold);font-size:.9rem;letter-spacing:2px}
.logo-box{
  background:transparent;border:1px solid var(--border);border-radius:10px;padding:12px;
  display:flex;align-items:center;justify-content:center;height:96px;width:100%;
  overflow:hidden;margin-bottom:18px;
}
.logo-box img{max-height:100%;max-width:100%;width:auto;height:auto;object-fit:contain;display:block}
.logo-box .ct{font-weight:800;color:#0a3b23;letter-spacing:.04em}
.logo-box .ct.red{color:#d2214b}
.offer{
  background:#081810;border:1px solid var(--border);border-radius:10px;
  padding:14px;text-align:center;margin-bottom:14px;
}
.offer .lbl{font-size:.72rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;margin-bottom:6px}
.offer .val{font-weight:700;color:#fff;font-size:.95rem}
.btn{
  display:inline-block;width:100%;text-align:center;padding:14px 18px;border-radius:10px;
  background:linear-gradient(90deg,var(--gold) 0%,var(--green-2) 100%);color:#0a1a10;
  font-weight:800;letter-spacing:.02em;border:0;cursor:pointer;
  transition:transform .2s ease,filter .2s ease;
}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05);color:#0a1a10}
.terms{text-align:center;color:var(--muted);font-size:.78rem;margin-top:10px}
.notice{
  margin:40px auto 0;max-width:900px;
  background:var(--panel);border:1px solid var(--border);border-radius:999px;
  padding:16px 24px;text-align:center;color:#cfe3d6;font-size:.88rem;
}

/* ── Sections ── */
.section{padding:56px 0;border-top:1px solid #0f2618}
.section h2{text-align:center;margin-bottom:10px}
.section .lead-center{text-align:center;color:var(--muted);max-width:760px;margin:0 auto 28px}
.panel{
  background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow);margin-top:22px;
}
.panel h3{color:var(--gold);margin-bottom:14px}
.panel h3.white{color:#fff}
.list{list-style:none;padding:0;margin:0}
.list li{padding:8px 0;color:#cfe3d6;display:flex;gap:10px}
.list li::before{content:"2713";color:var(--green-2);font-weight:700}
.kv{padding:10px 0;border-bottom:1px dashed #1a3a26}
.kv:last-child{border-bottom:0}
.kv .k{font-weight:700;color:#fff}
.kv .v{color:#cfe3d6}
.q{padding:14px 0;border-bottom:1px solid #143524}
.q:last-child{border-bottom:0}
.q h4{color:#fff;margin:0 0 6px;font-family:"Inter",sans-serif;font-size:1rem}
.q p{color:#cfe3d6;margin:0}

/* ════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════ */

.site-footer{
  background:var(--bg-2);
  border-top:1px solid var(--border);
  margin-top:40px;
  padding:56px 0 28px;
  font-size:.9rem;
}

/* Brand */
.footer-brand{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  color:#fff;
  font-weight:700;
  font-size:1.05rem;
  margin-bottom:36px;
}
.footer-brand a{
  color:#fff;
  text-decoration:none;
  transition:color .2s ease;
}
.footer-brand a:hover{color:var(--gold)}

/* Nav grid */
.footer-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:28px;
  padding-bottom:32px;
  border-bottom:1px solid var(--border);
}
.footer-grid h5{
  color:#fff;
  font-family:"Inter",sans-serif;
  font-size:.78rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  margin:0 0 14px;
}
.footer-grid a{
  display:block;
  color:var(--muted);
  padding:4px 0;
  font-size:.88rem;
  transition:color .2s ease;
}
.footer-grid a:hover{color:var(--gold)}
.footer-grid p.muted{
  font-size:.83rem;
  line-height:1.65;
  color:var(--muted);
  margin:0;
}

/* ── Affiliate notice ── */
.footer-affiliate-notice{
  margin:28px 0 0;
  padding:18px 22px;
  background:rgba(243,194,60,.06);
  border:1px solid rgba(243,194,60,.2);
  border-radius:12px;
  color:var(--muted);
  font-size:.84rem;
  line-height:1.7;
}
.footer-affiliate-notice p{margin:0}
.footer-affiliate-notice strong{color:var(--gold)}

/* ── Responsible gambling block ── */
.footer-rg-block{
  margin:18px 0 0;
  padding:18px 22px;
  background:rgba(47,163,106,.07);
  border:1px solid rgba(47,163,106,.22);
  border-radius:12px;
  color:var(--muted);
  font-size:.84rem;
  line-height:1.7;
}
.footer-rg-block p{margin:0}
.footer-rg-block p + p{margin-top:8px}
.responsibly{
  font-size:.92rem;
  font-weight:700;
  color:var(--green-2);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin:0 0 8px;
}
.footer-rg-block a{
  color:var(--green-2);
  text-decoration:underline;
  text-underline-offset:3px;
}
.footer-rg-block a:hover{color:var(--gold)}
.footer-rg-block strong{color:#e7f1ea}

/* ── 18+ age block ── */
.footer-age-block{
  margin:18px 0 0;
  padding:18px 22px;
  background:rgba(255,106,61,.06);
  border:1px solid rgba(255,106,61,.2);
  border-radius:12px;
  color:var(--muted);
  font-size:.84rem;
  line-height:1.7;
}
.footer-age-block p{margin:0}
.footer-age-block strong{color:#ff8c6b}
.footer-age-block a{
  color:#ff8c6b;
  text-decoration:underline;
  text-underline-offset:3px;
}
.footer-age-block a:hover{color:var(--gold)}

/* ── Badges ── */
.badges{
  display:flex;
  gap:12px;
  justify-content:center;
  align-items:center;
  flex-wrap:wrap;
  margin:28px 0 20px;
}
.badge{
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:10px;
  padding:12px 20px;
  color:#cfe3d6;
  font-weight:700;
  font-size:.82rem;
  min-width:100px;
  text-align:center;
  text-decoration:none;
  transition:transform .15s ease, border-color .15s ease;
}
a.badge:hover{
  transform:translateY(-2px);
  border-color:var(--gold);
  color:var(--gold);
}
.badge.age{
  background:#0a1a10;
  color:#fff;
  border-radius:50%;
  width:52px;
  height:52px;
  display:grid;
  place-items:center;
  min-width:0;
  padding:0;
  font-size:.9rem;
  border-color:#2a4a35;
}

/* ── Copyright ── */
.copy{
  text-align:center;
  color:var(--muted);
  font-size:.8rem;
  line-height:1.7;
  border-top:1px solid var(--border);
  padding-top:20px;
  margin-top:8px;
}

/* ── Page hero ── */
.page-hero{padding:60px 0 20px;text-align:center}
.page-hero h1{margin-bottom:10px}
.page-hero p{color:var(--muted);max-width:720px;margin:0 auto}

/* ── Blog ── */
.post-list{display:grid;gap:18px}
.post-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);padding:22px}
.post-card h3{color:#fff;margin-bottom:8px}
.post-card .meta{color:var(--muted);font-size:.82rem;margin-bottom:10px}
.blog-list{display:grid;gap:18px}
.blog-item h3{margin:8px 0 10px}
.blog-item h3 a{color:#fff}
.blog-item h3 a:hover{color:var(--gold)}
.post-meta-row{display:flex;gap:12px;align-items:center;font-size:.82rem;margin-bottom:6px}
.pill{display:inline-block;padding:3px 10px;border-radius:999px;background:#0a1a10;border:1px solid var(--border);color:#cfe3d6;font-size:.75rem}
.post-title{margin-top:8px;margin-bottom:18px}
.article h3{color:#fff;margin-top:26px;margin-bottom:10px;font-size:1.1rem}
.article .lead{color:#cfe3d6;font-size:1.02rem}
.article a{color:var(--gold);text-decoration:underline}
.article a:hover{color:var(--gold-2)}
.method-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}
.method-head h3{margin:0}
.weight-pill{background:rgba(243,194,60,.15);border:1px solid rgba(243,194,60,.4);color:var(--gold);font-weight:700;font-size:.78rem;padding:5px 12px;border-radius:999px}
.about-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:14px}
.about-cell{background:#081810;border:1px solid var(--border);border-radius:12px;padding:16px}
.about-cell h4{color:#fff;margin:6px 0 6px;font-family:"Inter",sans-serif;font-size:1rem}
.about-cell p{margin:0;font-size:.88rem}
.about-icon{font-size:1.2rem;margin-bottom:4px}
@media (max-width:600px){.about-grid{grid-template-columns:1fr}}

/* ── Responsive ── */
@media (max-width:820px){
  .nav{display:none}
  .menu-toggle{display:block}
  .cards{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:repeat(2,1fr)}
  .footer-affiliate-notice,
  .footer-rg-block,
  .footer-age-block{padding:14px 16px}
}
@media (max-width:480px){
  .footer-grid{grid-template-columns:1fr}
  .hero{padding:48px 0 20px}
  .badges{gap:8px}
  .badge{min-width:80px;padding:10px 14px;font-size:.78rem}
  .badge.age{width:46px;height:46px}
}