/*
Theme Name:  Rajagame365
Theme URI:   https://rajagame365.com
Author:      Rajagame365 Dev
Description: Premium casino gaming theme for Raja Game – mobile-first, SEO-optimised, production-ready.
Version:     2.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 8.0
License:     Proprietary
Text Domain: rajagame365
Tags: casino, gaming, dark, mobile-first
*/

/* ─────────────────────────────────────────────
   1. DESIGN TOKENS
───────────────────────────────────────────── */
:root{
  --c-bg-deep:#070b14;
  --c-bg-dark:#0d1422;
  --c-bg-card:#111827;
  --c-gold:#d4a017;
  --c-gold-lt:#ffd700;
  --c-gold-glow:rgba(212,160,23,.3);
  --c-neon:#00ff88;
  --c-neon-blue:#00cfff;
  --c-neon-red:#ff4560;
  --c-text:#f0e6c8;
  --c-text-2:#a89b7a;
  --c-text-3:#6b6352;
  --c-border:rgba(212,160,23,.18);
  --c-border-2:rgba(212,160,23,.45);
  --grad-gold:linear-gradient(135deg,#ffd700,#d4a017,#b8860b);
  --grad-cta:linear-gradient(135deg,#ffd700,#ff8c00);
  --grad-hero:linear-gradient(135deg,#070b14 0%,#0d1422 50%,#1a0a2e 100%);
  --grad-card:linear-gradient(145deg,#111827,#0d1422);
  --shadow-gold:0 0 24px rgba(212,160,23,.4),0 4px 14px rgba(0,0,0,.6);
  --shadow-card:0 8px 32px rgba(0,0,0,.5);
  --font-head:'Cinzel',Georgia,serif;
  --font-body:'Rajdhani','Segoe UI',system-ui,sans-serif;
  --r-sm:6px;--r-md:12px;--r-lg:18px;--r-xl:24px;--r-pill:999px;
  --t-fast:.15s ease;--t-base:.3s ease;--t-slow:.6s cubic-bezier(.16,1,.3,1);
  --header-h:68px;
  --max-w:1260px;
  --gap:clamp(1rem,3vw,1.5rem);
}

/* ─────────────────────────────────────────────
   2. RESET
───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--c-bg-deep);color:var(--c-text);line-height:1.7;overflow-x:hidden;min-height:100vh}
img,video{max-width:100%;height:auto;display:block}
a{color:var(--c-gold);text-decoration:none;transition:color var(--t-base)}
a:hover{color:var(--c-gold-lt)}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}
input,select,textarea{font-family:inherit}
:focus-visible{outline:2px solid var(--c-gold);outline-offset:3px}

/* ─────────────────────────────────────────────
   3. TYPOGRAPHY
───────────────────────────────────────────── */
h1,h2,h3,h4,h5,h6{
  font-family:var(--font-head);font-weight:700;
  line-height:1.2;color:#fff;letter-spacing:.02em
}
h1{font-size:clamp(1.8rem,5vw,3.2rem)}
h2{font-size:clamp(1.5rem,3.5vw,2.25rem)}
h3{font-size:clamp(1.1rem,2.5vw,1.5rem)}
h4{font-size:1.1rem}
p{margin-bottom:1rem;color:var(--c-text-2);font-size:clamp(.9rem,2vw,1rem)}
p:last-child{margin-bottom:0}

.grad-text{
  background:var(--grad-gold);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text
}

/* ─────────────────────────────────────────────
   4. LAYOUT
───────────────────────────────────────────── */
.container{max-width:var(--max-w);margin-inline:auto;padding-inline:clamp(1rem,4vw,1.5rem)}
.section{padding-block:clamp(3rem,8vw,5rem)}
.section-sm{padding-block:clamp(1.5rem,4vw,2.5rem)}

/* Section title */
.sec-title{text-align:center;margin-bottom:clamp(1.5rem,4vw,2.5rem)}
.sec-title h2{display:inline-block;position:relative;padding-bottom:.6rem}
.sec-title h2::after{
  content:'';position:absolute;bottom:0;left:10%;width:80%;
  height:3px;background:var(--grad-gold);border-radius:var(--r-pill)
}
.sec-title p{max-width:600px;margin:1rem auto 0}

/* Grid helpers */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--gap)}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap)}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}

/* ─────────────────────────────────────────────
   5. BUTTONS
───────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.75rem 1.6rem;border-radius:var(--r-pill);
  font-family:var(--font-head);font-weight:700;
  font-size:clamp(.82rem,2vw,.92rem);letter-spacing:.07em;
  text-transform:uppercase;white-space:nowrap;
  transition:all var(--t-base);position:relative;overflow:hidden
}
.btn::after{content:'';position:absolute;inset:0;opacity:0;background:rgba(255,255,255,.12);transition:opacity var(--t-base)}
.btn:hover::after{opacity:1}

.btn-primary{
  background:var(--grad-cta);color:#000;
  box-shadow:0 4px 18px rgba(255,215,0,.35)
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,215,0,.55);color:#000}

.btn-secondary{
  background:transparent;color:var(--c-gold-lt);
  border:2px solid var(--c-gold);box-shadow:0 0 12px var(--c-gold-glow)
}
.btn-secondary:hover{background:var(--c-gold-glow);transform:translateY(-2px);box-shadow:var(--shadow-gold);color:var(--c-gold-lt)}

.btn-neon{
  background:linear-gradient(135deg,#00ff88,#00b865);color:#000;
  box-shadow:0 4px 18px rgba(0,255,136,.35)
}
.btn-neon:hover{transform:translateY(-2px);box-shadow:0 8px 26px rgba(0,255,136,.55);color:#000}

.btn-lg{padding:1rem 2.2rem;font-size:clamp(.88rem,2vw,1rem)}
.btn-sm{padding:.5rem 1.2rem;font-size:.8rem}

.cta-group{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}

/* ─────────────────────────────────────────────
   6. CARDS
───────────────────────────────────────────── */
.card{
  background:var(--grad-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);overflow:hidden;
  transition:all var(--t-base)
}
.card:hover{border-color:var(--c-border-2);transform:translateY(-4px);box-shadow:var(--shadow-card)}
.card-body{padding:clamp(1rem,3vw,1.5rem)}
.card-title{font-size:1rem;margin-bottom:.3rem;color:#fff}

/* Game card */
.game-card .card-image{
  position:relative;aspect-ratio:3/4;
  background:var(--c-bg-dark);
  display:flex;align-items:center;justify-content:center;font-size:3.5rem;
  overflow:hidden
}
.game-card .card-image img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.game-card:hover .card-image img{transform:scale(1.06)}
.card-overlay{
  position:absolute;inset:0;background:rgba(7,11,20,.85);
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity var(--t-base)
}
.card:hover .card-overlay{opacity:1}

/* Badge */
.badge{
  position:absolute;top:.5rem;right:.5rem;
  padding:.15rem .55rem;border-radius:var(--r-pill);
  font-size:.68rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase
}
.badge-hot{background:var(--c-neon-red);color:#fff}
.badge-new{background:var(--c-neon);color:#000}
.badge-top{background:var(--grad-gold);color:#000}
.badge-live{background:var(--c-neon-blue);color:#000;animation:pulse-badge 2s infinite}
@keyframes pulse-badge{0%,100%{box-shadow:0 0 0 0 rgba(0,207,255,.5)}50%{box-shadow:0 0 0 5px rgba(0,207,255,0)}}

/* Feature card */
.feat-card{
  background:var(--grad-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:clamp(1.25rem,3vw,1.75rem);
  text-align:center;transition:all var(--t-base)
}
.feat-card:hover{border-color:var(--c-border-2);transform:translateY(-4px);box-shadow:var(--shadow-card)}
.feat-icon{
  width:64px;height:64px;background:var(--grad-gold);
  border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;
  font-size:1.6rem;margin:0 auto 1rem;box-shadow:0 6px 20px var(--c-gold-glow)
}

/* Bonus card */
.bonus-card{
  background:var(--grad-card);border:1px solid var(--c-border);
  border-radius:var(--r-xl);padding:clamp(1.25rem,3vw,1.75rem);
  position:relative;overflow:hidden;transition:all var(--t-base)
}
.bonus-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-gold)}
.bonus-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-gold);border-color:var(--c-border-2)}
.bonus-amount{font-family:var(--font-head);font-size:clamp(1.6rem,4vw,2.2rem);font-weight:900;background:var(--grad-gold);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1;margin-bottom:.25rem}
.bonus-label{font-size:.8rem;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.75rem}

/* ─────────────────────────────────────────────
   7. HEADER
───────────────────────────────────────────── */
#masthead{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  height:var(--header-h);
  background:rgba(7,11,20,.96);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border-bottom:1px solid var(--c-border);
  transition:all var(--t-base)
}
#masthead.scrolled{background:rgba(7,11,20,.99);border-bottom-color:var(--c-border-2)}

.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:100%;gap:1rem
}

/* ── LOGO ── */
.site-logo{
  display:flex;align-items:center;gap:.55rem;
  text-decoration:none;flex-shrink:0;
  max-width:200px;         /* prevent overflow */
  overflow:hidden;
}
/* The logo image — fixed small size, never goes bigger */
.site-logo .logo-img,
.site-logo img{
  width:40px  !important;
  height:40px !important;
  max-width:40px  !important;
  max-height:40px !important;
  object-fit:contain;
  object-position:center;
  flex-shrink:0;
  border-radius:6px;
  display:block;
}
.logo-text-wrap{overflow:hidden}
.logo-text-wrap .logo-name{
  display:block;
  font-family:var(--font-head);font-size:1rem;font-weight:900;
  background:var(--grad-gold);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text;
  letter-spacing:.04em;line-height:1.1;white-space:nowrap
}
.logo-text-wrap .logo-tag{
  display:block;font-size:.58rem;color:var(--c-neon);
  font-weight:700;letter-spacing:.1em;text-transform:uppercase;
  -webkit-text-fill-color:var(--c-neon);white-space:nowrap
}

/* Mobile nav header (logo + close inside drawer) */
.nav-mobile-header{
  display:none;   /* hidden on desktop */
}
.nav-close-btn{
  width:36px;height:36px;background:rgba(212,160,23,.15);
  border:1px solid rgba(212,160,23,.4);border-radius:50%;
  color:#ffd700;font-size:1.1rem;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:background .2s
}
.nav-close-btn:hover{background:rgba(212,160,23,.3)}
.nav-mobile-logo{
  display:flex;align-items:center;gap:.5rem;text-decoration:none
}
.nav-mobile-logo img{
  width:32px;height:32px;object-fit:contain;border-radius:5px
}
.nav-mobile-logo span{
  font-family:var(--font-head);font-size:.95rem;font-weight:900;
  background:var(--grad-gold);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text
}

/* Nav — desktop */
#primary-nav{flex:1}
@media(min-width:901px){
  #primary-nav{
    visibility:visible !important;
    opacity:1 !important;
    pointer-events:auto !important;
    position:static !important;
    background:transparent !important;
    padding:0 !important;
    height:auto !important;
    width:auto !important;
    overflow:visible !important;
  }
}
.nav-menu{display:flex;align-items:center;justify-content:center;gap:.25rem}
.nav-menu>li{position:relative}
.nav-menu>li>a{
  display:block;padding:.5rem .85rem;
  font-size:.82rem;font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;color:var(--c-text-2);
  border-radius:var(--r-sm);transition:all var(--t-fast)
}
.nav-menu>li>a:hover,
.nav-menu>li.current-menu-item>a,
.nav-menu>li.current_page_item>a{color:var(--c-gold-lt);background:var(--c-gold-glow)}

/* Dropdown */
.nav-menu .sub-menu{
  position:absolute;top:calc(100% + 8px);left:0;
  min-width:190px;background:var(--c-bg-card);
  border:1px solid var(--c-border);border-radius:var(--r-md);
  padding:.5rem;z-index:100;
  opacity:0;visibility:hidden;transform:translateY(-8px);
  transition:all var(--t-base)
}
.nav-menu>li:hover>.sub-menu{opacity:1;visibility:visible;transform:none}
.nav-menu .sub-menu a{
  display:block;padding:.45rem .75rem;font-size:.82rem;
  color:var(--c-text-2);border-radius:var(--r-sm);transition:all var(--t-fast)
}
.nav-menu .sub-menu a:hover{color:var(--c-gold-lt);background:var(--c-gold-glow)}

/* Header CTAs */
.header-cta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}

/* Hamburger */
.menu-toggle{
  display:none;flex-direction:column;gap:5px;
  padding:.5rem;cursor:pointer;border-radius:var(--r-sm)
}
.menu-toggle span{
  display:block;width:22px;height:2px;
  background:var(--c-gold);border-radius:2px;transition:all var(--t-base)
}
.menu-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.menu-toggle.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.menu-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ─────────────────────────────────────────────
   8. HERO
───────────────────────────────────────────── */
#hero{
  min-height:100svh;display:flex;align-items:center;
  padding-top:var(--header-h);position:relative;overflow:hidden;
  background:var(--grad-hero)
}
.hero-bg-img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;opacity:.4
}
.hero-overlay{
  position:absolute;inset:0;z-index:1;
  background:linear-gradient(135deg,rgba(7,11,20,.9) 0%,rgba(7,11,20,.6) 60%,rgba(26,10,46,.5) 100%)
}
.hero-grid-bg{
  position:absolute;inset:0;z-index:1;
  background-image:linear-gradient(rgba(212,160,23,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(212,160,23,.05) 1px,transparent 1px);
  background-size:60px 60px;
  animation:grid-drift 20s linear infinite
}
@keyframes grid-drift{to{background-position:60px 60px}}

.hero-orb{
  position:absolute;border-radius:50%;
  filter:blur(70px);pointer-events:none;z-index:1
}
.hero-orb-1{width:500px;height:500px;background:radial-gradient(circle,rgba(212,160,23,.18),transparent 70%);top:-100px;left:-80px;animation:orb 8s ease-in-out infinite}
.hero-orb-2{width:350px;height:350px;background:radial-gradient(circle,rgba(0,207,255,.1),transparent 70%);bottom:-60px;right:-40px;animation:orb 10s ease-in-out infinite reverse}
@keyframes orb{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(20px,-30px) scale(1.05)}}

.hero-content{position:relative;z-index:2;padding-block:clamp(2rem,6vw,4rem)}

.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.35rem 1rem;background:rgba(0,255,136,.08);
  border:1px solid rgba(0,255,136,.25);border-radius:var(--r-pill);
  font-size:.78rem;font-weight:700;color:var(--c-neon);
  letter-spacing:.1em;text-transform:uppercase;margin-bottom:1.25rem
}
.hero-badge .dot{
  width:7px;height:7px;background:var(--c-neon);
  border-radius:50%;animation:blink 1.5s ease-in-out infinite
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.hero-title{
  font-size:clamp(1.8rem,5.5vw,4.2rem);
  line-height:1.08;margin-bottom:1.25rem;color:#fff
}
.hero-title .accent{
  display:block;background:var(--grad-gold);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text
}
.hero-sub{
  font-size:clamp(.92rem,2vw,1.15rem);
  color:var(--c-text-2);max-width:540px;
  margin-bottom:2rem;line-height:1.7
}
.hero-stats{
  display:flex;flex-wrap:wrap;gap:clamp(1rem,4vw,2rem);
  margin-top:2rem;padding-top:2rem;
  border-top:1px solid var(--c-border)
}
.hero-stat .num{
  font-family:var(--font-head);font-size:clamp(1.4rem,3vw,1.9rem);font-weight:900;
  background:var(--grad-gold);-webkit-background-clip:text;
  -webkit-text-fill-color:transparent;background-clip:text
}
.hero-stat .lbl{font-size:.78rem;color:var(--c-text-3);text-transform:uppercase;letter-spacing:.06em}

/* ─────────────────────────────────────────────
   9. TRUST BAR
───────────────────────────────────────────── */
.trust-bar{
  background:var(--c-bg-card);
  border-top:1px solid var(--c-border);border-bottom:1px solid var(--c-border);
  padding:.9rem 0
}
.trust-inner{
  display:flex;flex-wrap:wrap;align-items:center;
  justify-content:center;gap:clamp(.75rem,3vw,2rem)
}
.trust-item{
  display:flex;align-items:center;gap:.45rem;
  font-size:clamp(.78rem,1.8vw,.88rem);color:var(--c-text-2);font-weight:600
}
.trust-item .ico{font-size:1rem;color:var(--c-gold)}

/* ─────────────────────────────────────────────
  10. PAGE HERO
───────────────────────────────────────────── */
.page-hero{
  padding:calc(var(--header-h) + 2.5rem) 0 2.5rem;
  background:var(--grad-hero);text-align:center;
  position:relative;overflow:hidden
}
.page-hero::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:1px;background:var(--grad-gold);opacity:.35
}
.page-hero h1{margin-bottom:.5rem}
.page-hero p{max-width:600px;margin-inline:auto;font-size:clamp(.9rem,2vw,1rem)}
.breadcrumb{
  display:flex;align-items:center;justify-content:center;
  gap:.5rem;font-size:.82rem;color:var(--c-text-3);
  margin-top:.75rem;flex-wrap:wrap
}
.breadcrumb a{color:var(--c-gold)}
.breadcrumb span{color:var(--c-text-3)}

/* ─────────────────────────────────────────────
  11. GAME TABS
───────────────────────────────────────────── */
.game-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:2rem}
.tab-btn{
  padding:.55rem 1.3rem;border-radius:var(--r-pill);
  border:1px solid var(--c-border);color:var(--c-text-2);
  font-weight:600;font-size:.84rem;letter-spacing:.04em;
  transition:all var(--t-fast);background:transparent;cursor:pointer
}
.tab-btn:hover,.tab-btn.active{
  background:var(--grad-gold);color:#000;
  border-color:transparent;box-shadow:0 4px 14px var(--c-gold-glow)
}

/* ─────────────────────────────────────────────
  12. FAQ ACCORDION
───────────────────────────────────────────── */
.faq-item{
  border:1px solid var(--c-border);border-radius:var(--r-md);
  overflow:hidden;margin-bottom:.5rem;transition:border-color var(--t-fast)
}
.faq-item.open{border-color:var(--c-border-2)}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  padding:clamp(.9rem,2.5vw,1.25rem);cursor:pointer;
  background:var(--grad-card);transition:background var(--t-fast);gap:1rem
}
.faq-q:hover{background:rgba(17,24,39,.9)}
.faq-q h3{
  font-size:clamp(.88rem,2vw,.98rem);font-weight:600;
  font-family:var(--font-body);color:var(--c-text);margin:0
}
.faq-icon{
  width:26px;height:26px;background:var(--grad-gold);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  color:#000;font-weight:900;font-size:1rem;flex-shrink:0;
  transition:transform var(--t-base)
}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height var(--t-slow)}
.faq-a-inner{
  padding:0 clamp(.9rem,2.5vw,1.25rem) clamp(.9rem,2.5vw,1.25rem);
  color:var(--c-text-2);font-size:clamp(.87rem,2vw,.95rem);line-height:1.8
}

/* ─────────────────────────────────────────────
  13. NEWSLETTER
───────────────────────────────────────────── */
.newsletter-wrap{
  background:linear-gradient(135deg,#0d1422,#1a0a2e);
  position:relative;overflow:hidden
}
.newsletter-wrap::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 60% at 50% 50%,rgba(212,160,23,.07),transparent 70%)
}
.newsletter-content{
  position:relative;text-align:center;max-width:580px;margin:0 auto
}
.newsletter-form{
  display:flex;gap:.5rem;margin-top:1.25rem;flex-wrap:wrap
}
.newsletter-input{
  flex:1;min-width:220px;padding:.85rem 1.2rem;
  background:rgba(255,255,255,.06);border:1px solid var(--c-border);
  border-radius:var(--r-pill);color:var(--c-text);
  font-size:.95rem;outline:none;transition:border-color var(--t-fast)
}
.newsletter-input:focus{border-color:var(--c-gold)}
.newsletter-input::placeholder{color:var(--c-text-3)}

/* ─────────────────────────────────────────────
  14. SIDEBAR
───────────────────────────────────────────── */
.sidebar-widget{
  background:var(--grad-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);padding:clamp(1rem,3vw,1.5rem);
  margin-bottom:1.25rem
}
.widget-title{
  font-size:.88rem;font-family:var(--font-head);
  color:var(--c-gold-lt);margin-bottom:1rem;
  padding-bottom:.6rem;border-bottom:1px solid var(--c-border)
}

/* ─────────────────────────────────────────────
  15. FORMS
───────────────────────────────────────────── */
.form-label{
  display:block;font-size:.85rem;font-weight:600;
  color:var(--c-text-2);margin-bottom:.4rem;letter-spacing:.03em
}
.form-control{
  width:100%;padding:.75rem 1rem;
  background:rgba(255,255,255,.04);border:1px solid var(--c-border);
  border-radius:var(--r-md);color:var(--c-text);font-size:.95rem;
  font-family:var(--font-body);outline:none;
  transition:border-color var(--t-fast),background var(--t-fast)
}
.form-control:focus{border-color:var(--c-gold);background:rgba(212,160,23,.04)}
.form-control::placeholder{color:var(--c-text-3)}
textarea.form-control{resize:vertical;min-height:110px}
select.form-control{cursor:pointer;appearance:none}

/* ─────────────────────────────────────────────
  16. BLOG CARD
───────────────────────────────────────────── */
.blog-card .card-img{aspect-ratio:16/9;overflow:hidden;background:var(--c-bg-dark)}
.blog-card .card-img img{width:100%;height:100%;object-fit:cover;transition:transform var(--t-slow)}
.blog-card:hover .card-img img{transform:scale(1.05)}
.blog-cat{
  display:inline-block;padding:.15rem .6rem;
  background:var(--grad-gold);color:#000;font-size:.7rem;
  font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  border-radius:var(--r-pill);margin-bottom:.5rem
}
.blog-date{font-size:.78rem;color:var(--c-text-3);margin-bottom:.5rem}
.read-more{
  display:inline-flex;align-items:center;gap:4px;
  color:var(--c-gold);font-weight:600;font-size:.86rem;
  margin-top:.5rem;transition:gap var(--t-fast)
}
.read-more:hover{gap:8px;color:var(--c-gold-lt)}

/* ─────────────────────────────────────────────
  17. PROS / CONS
───────────────────────────────────────────── */
.pros-cons{
  display:grid;grid-template-columns:1fr 1fr;
  background:var(--c-bg-card);border:1px solid var(--c-border);
  border-radius:var(--r-lg);overflow:hidden
}
.pros{padding:1.25rem;border-right:1px solid var(--c-border)}
.cons{padding:1.25rem}
.pros-title{color:var(--c-neon);font-weight:700;margin-bottom:.75rem}
.cons-title{color:var(--c-neon-red);font-weight:700;margin-bottom:.75rem}
.pros li,.cons li{
  font-size:.88rem;color:var(--c-text-2);padding:.25rem 0 .25rem 1.25rem;
  position:relative
}
.pros li::before{content:'✓';position:absolute;left:0;color:var(--c-neon);font-weight:700}
.cons li::before{content:'✗';position:absolute;left:0;color:var(--c-neon-red);font-weight:700}

/* ─────────────────────────────────────────────
  18. RATING BARS
───────────────────────────────────────────── */
.rating-bar{display:flex;align-items:center;gap:.75rem;margin-bottom:.6rem}
.rating-lbl{font-size:.82rem;color:var(--c-text-2);min-width:90px}
.rating-track{flex:1;height:5px;background:rgba(255,255,255,.07);border-radius:var(--r-pill);overflow:hidden}
.rating-fill{height:100%;background:var(--grad-gold);border-radius:var(--r-pill);width:0;transition:width 1s ease}
.rating-val{font-size:.82rem;font-weight:700;color:var(--c-gold-lt);min-width:28px}

/* ─────────────────────────────────────────────
  19. FOOTER
───────────────────────────────────────────── */
#colophon{background:#040710;border-top:1px solid var(--c-border)}
.footer-top{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:clamp(1.5rem,4vw,2.5rem);
  padding-block:clamp(2.5rem,6vw,4rem)
}
.footer-brand-desc{
  font-size:.86rem;color:var(--c-text-3);
  margin:1rem 0 1.25rem;line-height:1.8
}
.footer-social{display:flex;flex-wrap:wrap;gap:.5rem}
.social-btn{
  width:36px;height:36px;border-radius:var(--r-sm);
  border:1px solid var(--c-border);display:flex;align-items:center;
  justify-content:center;color:var(--c-text-2);font-size:.88rem;
  transition:all var(--t-fast);text-decoration:none
}
.social-btn:hover{border-color:var(--c-gold);color:var(--c-gold-lt);background:var(--c-gold-glow)}
.footer-col-title{
  font-family:var(--font-head);font-size:.82rem;
  letter-spacing:.08em;text-transform:uppercase;
  color:var(--c-gold-lt);margin-bottom:1rem
}
.footer-links li{margin-bottom:.4rem}
.footer-links a{
  font-size:.84rem;color:var(--c-text-3);
  transition:color var(--t-fast)
}
.footer-links a:hover{color:var(--c-gold-lt)}
.footer-bottom{
  border-top:1px solid var(--c-border);padding:1.25rem 0;
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:.75rem
}
.footer-bottom p{font-size:.78rem;color:var(--c-text-3);margin:0}
.resp-gaming{
  background:rgba(212,160,23,.04);border:1px solid var(--c-border);
  border-radius:var(--r-md);padding:.9rem 1.25rem;
  text-align:center;margin-bottom:1.5rem
}
.resp-gaming p{font-size:.76rem;color:var(--c-text-3);margin:0}
.age-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;border:2px solid var(--c-text-3);
  border-radius:50%;font-size:.72rem;font-weight:900;
  color:var(--c-text-3);font-family:var(--font-head);
  vertical-align:middle;margin-right:5px
}

/* ─────────────────────────────────────────────
  20. ANIMATIONS
───────────────────────────────────────────── */
.fade-up{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.fade-up.visible{opacity:1;transform:none}
.fade-up:nth-child(2){transition-delay:.1s}
.fade-up:nth-child(3){transition-delay:.2s}
.fade-up:nth-child(4){transition-delay:.3s}
.fade-up:nth-child(5){transition-delay:.4s}
.fade-up:nth-child(6){transition-delay:.5s}

/* ─────────────────────────────────────────────
  21. UTILITIES
───────────────────────────────────────────── */
.text-center{text-align:center}
.text-gold{color:var(--c-gold-lt)}
.mt-sm{margin-top:.5rem}.mt-md{margin-top:1rem}.mt-lg{margin-top:1.5rem}.mt-xl{margin-top:2rem}
.mb-md{margin-bottom:1rem}.mb-lg{margin-bottom:1.5rem}.mb-xl{margin-bottom:2rem}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
.divider{height:1px;background:var(--c-border);margin:1.25rem 0}

/* Image section banner */
.img-section{
  border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 8px 40px rgba(0,0,0,.6);
  border:1px solid var(--c-border);position:relative;
  margin-bottom:clamp(1.5rem,4vw,2.5rem)
}
.img-section img{width:100%;height:auto;display:block}
.img-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to right,rgba(7,11,20,.82) 0%,transparent 55%);
  display:flex;align-items:center
}
.img-overlay-content{padding:clamp(1.25rem,4vw,2.5rem);max-width:450px}

/* Pagination */
.pagination ul{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:2rem;list-style:none}
.pagination a,.pagination span{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:38px;height:38px;padding:.25rem .6rem;
  background:var(--grad-card);border:1px solid var(--c-border);
  border-radius:var(--r-sm);color:var(--c-text-2);font-size:.85rem;
  transition:all var(--t-fast)
}
.pagination a:hover,.pagination .current span{
  background:var(--grad-gold);color:#000;border-color:transparent
}

/* Entry content (blog / page prose) */
.entry-content h2,.entry-content h3,.entry-content h4{margin:1.5rem 0 .75rem;color:#fff}
.entry-content p{color:var(--c-text-2);line-height:1.85}
.entry-content ul,.entry-content ol{padding-left:1.5rem;color:var(--c-text-2);line-height:1.85}
.entry-content ul{list-style:disc}.entry-content ol{list-style:decimal}
.entry-content a{color:var(--c-gold);text-decoration:underline}
.entry-content img{border-radius:var(--r-md);margin:1rem 0}
.entry-content table{width:100%;border-collapse:collapse;margin:1rem 0}
.entry-content th{background:rgba(212,160,23,.1);color:var(--c-gold-lt);padding:.7rem 1rem;text-align:left;border-bottom:2px solid var(--c-border-2)}
.entry-content td{padding:.7rem 1rem;border-bottom:1px solid var(--c-border);color:var(--c-text-2)}
.entry-content blockquote{
  border-left:3px solid var(--c-gold);padding:.75rem 1.25rem;
  background:rgba(212,160,23,.05);border-radius:0 var(--r-md) var(--r-md) 0;
  margin:1.25rem 0;color:var(--c-text-2);font-style:italic
}

/* ─────────────────────────────────────────────
  22. RESPONSIVE — TABLET ≤1024
───────────────────────────────────────────── */
@media(max-width:1024px){
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
}

/* ═══════════════════════════════════════════════
   MOBILE MENU — THE DEFINITIVE FIX
   Uses body.menu-open approach so there's zero
   conflict between CSS display:none and JS toggle.
═══════════════════════════════════════════════ */

/* Step 1: On mobile, hide nav by default */
@media (max-width: 900px) {

  /* ── HAMBURGER: always show ── */
  .menu-toggle {
    display: flex !important;
    flex-direction: column;
    gap: 5px;
    padding: 8px 10px;
    background: rgba(212,160,23,.12);
    border: 1px solid rgba(212,160,23,.4);
    border-radius: 8px;
    cursor: pointer;
    z-index: 1001;
    position: relative;
  }
  .menu-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: #ffd700;
    border-radius: 2px;
    transition: all 0.3s ease;
    transform-origin: center;
  }
  /* X when open */
  .menu-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .menu-toggle.open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
  .menu-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

  /* ── NAV: hidden by default on mobile ── */
  #primary-nav {
    visibility: hidden;
    opacity: 0;
    pointer-events: none;

    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh;
    background: rgba(7,11,20,0.98);
    z-index: 9000;
    padding: 0 0 30px 0;   /* no top pad — header handles it */
    overflow-y: auto;
    transition: opacity 0.3s ease, visibility 0.3s ease;
    display: block !important;
  }

  /* Show mobile header row INSIDE nav drawer */
  .nav-mobile-header {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    padding: 14px 20px 14px;
    border-bottom: 1px solid rgba(212,160,23,.2);
    margin-bottom: 8px;
    position: sticky;
    top: 0;
    background: rgba(7,11,20,.98);
    z-index: 1;
  }

  /* Step 2: body.menu-open reveals it */
  body.menu-open #primary-nav {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  /* Optional: also support .open class directly on nav */
  #primary-nav.open {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
  }

  /* ── MENU ITEMS ── */
  .nav-menu {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 0 !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }
  .nav-menu > li {
    border-bottom: 1px solid rgba(212,160,23,.15);
  }
  .nav-menu > li > a {
    display: block !important;
    padding: 16px 20px !important;
    font-size: 1.1rem !important;
    font-weight: 600 !important;
    color: #f0e6c8 !important;
    letter-spacing: 0.03em !important;
    transition: color 0.2s, background 0.2s !important;
  }
  .nav-menu > li > a:hover {
    color: #ffd700 !important;
    background: rgba(212,160,23,.08) !important;
  }

  /* ── CLOSE BUTTON inside nav ── */
  #navClose {
    position: absolute;
    top: 18px;
    right: 20px;
    width: 38px;
    height: 38px;
    background: rgba(212,160,23,.15);
    border: 1px solid rgba(212,160,23,.4);
    border-radius: 50%;
    color: #ffd700;
    font-size: 1.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    font-weight: 900;
    line-height: 1;
    transition: background 0.2s;
  }
  #navClose:hover { background: rgba(212,160,23,.3); }

  /* ── NAV HEADER (logo inside menu) ── */
  #navHeader {
    position: absolute;
    top: 15px;
    left: 20px;
    display: flex;
    align-items: center;
    gap: 8px;
  }
  #navHeader img {
    height: 34px;
    width: auto;
  }

  /* ── SUB MENU ── */
  .nav-menu .sub-menu {
    position: static !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    background: rgba(212,160,23,.05) !important;
    border: none !important;
    border-left: 3px solid rgba(212,160,23,.5) !important;
    border-radius: 0 !important;
    padding: 4px 0 4px 12px !important;
    margin: 0 0 0 20px !important;
    min-width: unset !important;
  }
  .nav-menu .sub-menu a {
    font-size: 0.95rem !important;
    padding: 10px 14px !important;
    color: #a89b7a !important;
  }

  /* ── HIDE desktop-only ── */
  .header-cta .btn-secondary { display: none !important; }

  /* ── Prevent body scroll when menu open ── */
  body.menu-open { overflow: hidden !important; }

}

/* ═══════════════════════════════════════════════
   MOBILE FONT SIZES (comfortable reading)
═══════════════════════════════════════════════ */
@media (max-width: 768px) {

  html { font-size: 16px; }

  h1 { font-size: 1.7rem !important; line-height: 1.15; }
  h2 { font-size: 1.4rem !important; }
  h3 { font-size: 1.1rem !important; }
  h4 { font-size: 1rem !important; }
  p  { font-size: 0.97rem !important; line-height: 1.78; }

  .hero-title { font-size: 1.7rem !important; }
  .hero-sub   { font-size: 1rem !important; }
  .hero-cards-grid { display: none !important; }
  .hero-stat .num { font-size: 1.4rem !important; }

  .cta-group { gap: 0.6rem !important; }
  .cta-group .btn {
    flex: 1 1 calc(50% - 0.3rem) !important;
    justify-content: center !important;
    font-size: 0.85rem !important;
    padding: 0.8rem 0.6rem !important;
  }
  .cta-group .btn:nth-child(3) { flex: 1 1 100% !important; }
  .btn-lg { font-size: 0.9rem !important; padding: 0.85rem 1.4rem !important; }

  .grid-2,
  .grid-3,
  .grid-4 { grid-template-columns: 1fr !important; }

  .footer-top { grid-template-columns: 1fr !important; }
  .footer-bottom { flex-direction: column !important; text-align: center !important; }

  .pros-cons { grid-template-columns: 1fr !important; }
  .pros { border-right: none !important; border-bottom: 1px solid var(--c-border) !important; }

  .section   { padding-block: 2.5rem !important; }
  .section-sm{ padding-block: 1.25rem !important; }

  .newsletter-form { flex-direction: column !important; }
  .newsletter-input { min-width: unset !important; }

  .trust-inner { gap: 0.5rem !important; }
  .trust-item  { font-size: 0.8rem !important; }

  .game-tabs { gap: 0.3rem !important; }
  .tab-btn   { font-size: 0.78rem !important; padding: 0.45rem 0.9rem !important; }

  /* sidebar stacks below */
  [style*="grid-template-columns:1fr 300px"] {
    display: block !important;
  }
  .sidebar { margin-top: 2rem; }

}

@media (max-width: 480px) {
  h1 { font-size: 1.5rem !important; }
  h2 { font-size: 1.25rem !important; }
  .hero-title { font-size: 1.45rem !important; }
  .cta-group .btn { flex: 1 1 100% !important; }
  .header-cta .btn { font-size: 0.78rem !important; padding: 0.5rem 0.9rem !important; }
}

@media print {
  #masthead, #colophon, .btn, #wa-sticky { display: none; }
  body { background: #fff; color: #000; }
}

/* ── LOGO SIZE SAFETY — prevent any override ── */
/* These rules lock the logo to 40px on all screen sizes */
.site-logo .logo-img,
#masthead .site-logo img,
.header-inner .site-logo img {
  width:  40px !important;
  height: 40px !important;
  max-width:  40px !important;
  max-height: 40px !important;
  min-width:  unset !important;
  min-height: unset !important;
  object-fit: contain !important;
}

/* On small mobile, slightly smaller logo */
@media(max-width:480px){
  .site-logo .logo-img,
  #masthead .site-logo img,
  .header-inner .site-logo img {
    width:  34px !important;
    height: 34px !important;
    max-width:  34px !important;
    max-height: 34px !important;
  }
  .logo-text-wrap .logo-name{ font-size:.88rem !important }
  .logo-text-wrap .logo-tag { font-size:.54rem !important }
}

/* Ensure header-inner never lets logo escape */
.header-inner {
  overflow: hidden;
}
.site-logo {
  max-width: 180px;
  flex-shrink: 0;
  overflow: hidden;
}
