/*
Theme Name: Aurora Core
Theme URI: https://northstar-bet.ca/
Description: Energetic Aurora micro-theme for NorthStar Bets (casino + sportsbook affiliate). Aurora gradient, neon cyan/magenta, Anton/Oswald/Inter typography. Reusable block classes; main page sections finalized later.
Author: NorthStar
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: aurora-core-x7k
*/

/* ===================== PALETTE / TOKENS ===================== */
:root{
  --bg1:#0A1A2F; --bg2:#16143A; --bg3:#2A1A4A;
  --cyan:#19E0FF; --magenta:#FF3DA5;
  --ink:#EAF6FF; --muted:#9FB3CC;
  --card:rgba(255,255,255,.04); --line:rgba(255,255,255,.10);
  --r:14px; --r-md:14px;
  --s-md:20px;
  --maxw:1200px;
}

/* ===================== RESET / BASE ===================== */
*{margin:0;padding:0;box-sizing:border-box}
html,body{overflow-x:hidden}
body{
  font-family:'Inter',sans-serif; color:var(--ink); background:var(--bg1);
  background:linear-gradient(160deg,#0A1A2F 0%,#16143A 50%,#2A1A4A 100%);
  background-attachment:fixed; line-height:1.55;
}
img,video{max-width:100%;height:auto}
table{max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--s-md)}
h1,h2,h3,.head{font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.5px}
.anton{font-family:'Anton',sans-serif;text-transform:uppercase;letter-spacing:1px;font-weight:400}
.cyan{color:var(--cyan)}.mag{color:var(--magenta)}

/* ===================== AURORA BG GLOW ===================== */
.aurora{position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden}
.aurora::before,.aurora::after{content:"";position:absolute;border-radius:50%;filter:blur(90px);opacity:.35}
.aurora::before{width:520px;height:520px;background:var(--cyan);top:-160px;left:-120px}
.aurora::after{width:560px;height:560px;background:var(--magenta);bottom:-200px;right:-140px}

/* ===================== TICKER ===================== */
.ticker{background:#06101e;border-bottom:1px solid var(--line);overflow:hidden;white-space:nowrap;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:13px;letter-spacing:.5px}
.ticker-track{display:inline-block;padding:8px 0;animation:scroll 26s linear infinite}
.ticker-track span{padding:0 26px;color:var(--muted)}
.ticker-track b{color:var(--cyan)}
.ticker-track .h{color:var(--magenta)}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ===================== HEADER ===================== */
.site-header{position:sticky;top:0;z-index:100;background:rgba(6,16,30,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:14px;padding:14px 0}
.logo{font-family:'Anton',sans-serif;font-size:24px;letter-spacing:1px;white-space:nowrap}
.logo .star{color:var(--cyan);text-shadow:0 0 12px var(--cyan)}
.nav-menu{margin-left:auto;display:flex;align-items:center;gap:26px;list-style:none}
.nav-menu a{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:14px;font-weight:600;color:var(--muted);transition:.2s;position:relative}
.nav-menu a:hover{color:var(--cyan)}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--cyan);transition:.2s;box-shadow:0 0 8px var(--cyan)}
.nav-menu a:hover::after{width:100%}

/* ===================== BUTTONS ===================== */
.btn{display:inline-block;font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;letter-spacing:.5px;border-radius:10px;padding:12px 22px;cursor:pointer;transition:.2s;text-align:center}
.btn-cyan{background:linear-gradient(135deg,var(--cyan),#0bb6d6);color:#03121b;box-shadow:0 0 22px rgba(25,224,255,.45)}
.btn-cyan:hover{transform:translateY(-2px);box-shadow:0 0 30px rgba(25,224,255,.7)}
.btn-mag{background:linear-gradient(135deg,var(--magenta),#c41e7a);color:#fff;box-shadow:0 0 22px rgba(255,61,165,.4)}
.btn-mag:hover{transform:translateY(-2px);box-shadow:0 0 30px rgba(255,61,165,.65)}
.btn-ghost{background:transparent;border:1.5px solid var(--cyan);color:var(--cyan)}
.btn-ghost:hover{background:rgba(25,224,255,.12)}
.mobile-cta{margin-left:auto}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:26px;height:3px;background:var(--cyan);border-radius:2px;box-shadow:0 0 6px var(--cyan)}

/* ===================== HERO ===================== */
.hero{position:relative;padding:70px 0 120px;clip-path:polygon(0 0,100% 0,100% 92%,0 100%)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.badge{display:inline-block;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:12px;font-weight:700;letter-spacing:1.5px;color:var(--cyan);border:1px solid rgba(25,224,255,.4);border-radius:40px;padding:7px 16px;margin-bottom:22px;background:rgba(25,224,255,.06)}
.hero h1,.hero .hero-h{font-size:clamp(40px,7vw,76px);line-height:.96;font-weight:700;margin-bottom:8px}
.hero h1 .skew,.hero .hero-h .skew{display:inline-block;transform:skewX(-8deg);background:linear-gradient(120deg,var(--cyan),var(--magenta));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero .offer{font-family:'Anton',sans-serif;font-size:clamp(34px,6vw,60px);background:linear-gradient(120deg,#fff,var(--cyan));-webkit-background-clip:text;background-clip:text;color:transparent;margin:14px 0 18px}
.hero p.lead{color:var(--muted);max-width:480px;margin-bottom:28px;font-size:17px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-cta .btn{font-size:16px;padding:15px 30px}
.trust{margin-top:26px;display:flex;gap:22px;flex-wrap:wrap;color:var(--muted);font-size:13px;font-family:'Oswald',sans-serif;text-transform:uppercase;letter-spacing:.5px}
.trust b{color:var(--ink)}

/* hero visual card */
.hero-visual{position:relative}
.glass{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:22px;backdrop-filter:blur(6px);position:relative;overflow:hidden}
.glass::before{content:"";position:absolute;inset:0;border-radius:20px;padding:1px;background:linear-gradient(135deg,var(--cyan),transparent 40%,var(--magenta));-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:.6}
.slot-mock{height:150px;border-radius:14px;background:
   radial-gradient(circle at 25% 30%,rgba(25,224,255,.5),transparent 40%),
   radial-gradient(circle at 80% 70%,rgba(255,61,165,.5),transparent 45%),
   linear-gradient(135deg,#142447,#241644);display:flex;align-items:center;justify-content:center;font-family:'Anton',sans-serif;font-size:38px;color:rgba(255,255,255,.85);letter-spacing:3px}
.mini-row{display:flex;gap:10px;margin-top:14px}
.mini{flex:1;height:62px;border-radius:10px;background:linear-gradient(135deg,#1a2c52,#2a1a4a);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:'Oswald',sans-serif;font-size:13px;color:var(--muted);text-transform:uppercase}
.jackpot-pill{position:absolute;top:14px;right:14px;background:rgba(6,16,30,.7);border:1px solid var(--cyan);color:var(--cyan);font-family:'Oswald',sans-serif;font-size:12px;font-weight:700;padding:5px 12px;border-radius:30px;text-transform:uppercase;box-shadow:0 0 14px rgba(25,224,255,.4)}

/* ===================== DUAL FOCUS ===================== */
.dual{padding:30px 0 60px;margin-top:-40px}
.dual-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.focus-card{position:relative;border-radius:18px;padding:30px;overflow:hidden;border:1px solid var(--line);min-height:230px;display:flex;flex-direction:column;justify-content:flex-end}
.fc-casino{background:linear-gradient(140deg,rgba(25,224,255,.16),rgba(10,26,47,.6))}
.fc-sport{background:linear-gradient(140deg,rgba(255,61,165,.16),rgba(42,26,74,.6))}
.focus-card .ic{font-size:30px;position:absolute;top:24px;left:30px;opacity:.9}
.focus-card .head{font-size:28px;margin-bottom:8px}
.focus-card p{color:var(--muted);font-size:14px;margin-bottom:18px;max-width:340px}
.focus-card .btn{align-self:flex-start;font-size:14px;padding:12px 24px}

/* ===================== SECTION TITLE ===================== */
.sec{padding:60px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:30px;flex-wrap:wrap}
.sec-head h2,.sec-head .sec-title{font-size:clamp(28px,4vw,42px)}
.sec-head .ln{flex:1;height:2px;background:linear-gradient(90deg,var(--cyan),transparent);margin-bottom:8px;min-width:60px}
.sec-head span.tag{color:var(--magenta);font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:13px;letter-spacing:1px}

/* games grid */
.games{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.game{border-radius:14px;overflow:hidden;border:1px solid var(--line);background:var(--card);transition:.2s;cursor:pointer}
.game:hover{transform:translateY(-4px);border-color:var(--cyan);box-shadow:0 0 24px rgba(25,224,255,.25)}
.game .thumb{height:140px;display:flex;align-items:center;justify-content:center;font-family:'Anton',sans-serif;font-size:18px;color:rgba(255,255,255,.8);text-align:center;padding:10px}
.g1{background:linear-gradient(135deg,#19324f,#0e7a8c)}
.g2{background:linear-gradient(135deg,#3a1a4a,#c41e7a)}
.g3{background:linear-gradient(135deg,#142447,#19a0d6)}
.g4{background:linear-gradient(135deg,#2a1a4a,#7a1e6a)}
.g5{background:linear-gradient(135deg,#0e3a4a,#19e0ff44)}
.g6{background:linear-gradient(135deg,#241644,#ff3da544)}
.g7{background:linear-gradient(135deg,#16304a,#0bb6d6)}
.g8{background:linear-gradient(135deg,#321a44,#c41e7a)}
.game .gmeta{padding:12px 14px;display:flex;justify-content:space-between;align-items:center}
.game .gmeta b{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:13px}
.game .gmeta small{color:var(--cyan);font-size:11px;font-family:'Oswald',sans-serif}

/* ===================== SPORT EVENTS ===================== */
.sport-sec{position:relative;padding:70px 0;clip-path:polygon(0 5%,100% 0,100% 95%,0 100%);background:linear-gradient(135deg,rgba(42,26,74,.55),rgba(10,26,47,.2))}
.events{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.event{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:18px;transition:.2s}
.event:hover{border-color:var(--magenta);box-shadow:0 0 22px rgba(255,61,165,.22)}
.event .lg{display:flex;justify-content:space-between;color:var(--muted);font-size:11px;font-family:'Oswald',sans-serif;text-transform:uppercase;margin-bottom:14px}
.event .lg .live{color:var(--magenta)}
.event .teams{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}
.event .team{display:flex;align-items:center;gap:10px;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:15px}
.event .dot{width:26px;height:26px;border-radius:7px;background:linear-gradient(135deg,#19324f,#2a1a4a);flex:none}
.odds{display:flex;gap:8px}
.odd{flex:1;text-align:center;border:1px solid var(--line);border-radius:9px;padding:9px 4px;font-family:'Oswald',sans-serif;cursor:pointer;transition:.2s;background:rgba(255,255,255,.02)}
.odd:hover{border-color:var(--cyan);background:rgba(25,224,255,.1)}
.odd small{display:block;color:var(--muted);font-size:10px;text-transform:uppercase}
.odd b{color:var(--cyan);font-size:16px}

/* ===================== STATS STRIP ===================== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.stat{padding:26px 14px;border:1px solid var(--line);border-radius:14px;background:var(--card)}
.stat .num{font-family:'Anton',sans-serif;font-size:clamp(30px,4vw,46px);background:linear-gradient(120deg,var(--cyan),var(--magenta));-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .lbl{color:var(--muted);font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:12px;letter-spacing:.5px;margin-top:6px}

/* ===================== PROMOS ===================== */
.promos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.promo{border-radius:16px;padding:26px;border:1px solid var(--line);position:relative;overflow:hidden;min-height:180px;display:flex;flex-direction:column;justify-content:space-between}
.p1{background:linear-gradient(140deg,rgba(25,224,255,.18),rgba(10,26,47,.5))}
.p2{background:linear-gradient(140deg,rgba(255,61,165,.18),rgba(42,26,74,.5))}
.p3{background:linear-gradient(140deg,rgba(123,30,106,.3),rgba(10,26,47,.5))}
.promo .head{font-size:22px;margin-bottom:8px}
.promo p{color:var(--muted);font-size:13px;margin-bottom:18px}
.promo .ptag{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:11px;letter-spacing:1px;color:var(--cyan);margin-bottom:14px}

/* ===================== CTA BAND ===================== */
.cta-band{margin:50px 0;border-radius:22px;padding:50px 40px;text-align:center;position:relative;overflow:hidden;border:1px solid var(--line);background:linear-gradient(135deg,rgba(25,224,255,.12),rgba(255,61,165,.12))}
.cta-band h2{font-size:clamp(30px,5vw,52px);margin-bottom:10px}
.cta-band p{color:var(--muted);margin-bottom:26px;font-size:16px}
.cta-band .btn{font-size:17px;padding:16px 38px}

/* ===================== PAGE CONTENT (page.php / posts) ===================== */
.page-main{padding:50px 0}
.content-area{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--s-md)}
.entry-content{max-width:860px;margin:0 auto}
.entry-content h1,.entry-content h2,.entry-content h3{margin:1.4rem 0 .8rem}
.entry-content h1{font-size:clamp(30px,5vw,48px)}
.entry-content h2{font-size:clamp(24px,3.5vw,34px)}
.entry-content h3{font-size:clamp(19px,2.5vw,24px)}
.entry-content p,.entry-content ul,.entry-content ol{margin-bottom:1.1rem;color:var(--ink)}
.entry-content ul,.entry-content ol{padding-left:1.4rem}
.entry-content li{margin-bottom:.5rem}
.entry-content a{color:var(--cyan);text-decoration:underline}
.entry-content a:hover{color:var(--magenta)}
.entry-content img{border-radius:var(--r-md)}
.content-img{display:block;max-width:800px;width:100%;height:auto;margin:1.5rem auto;aspect-ratio:16/9;object-fit:cover;border-radius:var(--r-md)}
/* wide tables scroll on mobile instead of breaking layout */
.entry-content table{width:100%;border-collapse:collapse;margin:1.5rem 0}
.entry-content th,.entry-content td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.entry-content th{font-family:'Oswald',sans-serif;text-transform:uppercase;color:var(--cyan);font-size:13px}

/* ===================== CONTENT COMPONENTS (writer HTML) ===================== */
.entry-content .lead{font-size:clamp(17px,2.2vw,20px);color:var(--ink);line-height:1.6;margin-bottom:1.4rem}
/* wide tables scroll on mobile instead of breaking layout */
.table-wrap{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:1.5rem 0}
.table-wrap table{margin:0}
/* TL;DR / key-facts box */
.keybox{background:var(--card);border:1px solid var(--line);border-left:3px solid var(--cyan);border-radius:var(--r-md);padding:18px 20px;margin:1.5rem 0}
.keybox h2,.keybox h3{margin-top:0}
/* pros & cons */
.pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin:1.6rem 0}
.pros,.cons{background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:18px 20px}
.pros{border-top:3px solid var(--cyan)}.cons{border-top:3px solid var(--magenta)}
.pros h3,.cons h3{margin-top:0;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:15px}
.pros ul,.cons ul{list-style:none;padding-left:0}
.pros li,.cons li{position:relative;padding-left:24px;margin-bottom:.6rem}
.pros li::before{content:"+";position:absolute;left:0;color:var(--cyan);font-weight:700}
.cons li::before{content:"–";position:absolute;left:0;color:var(--magenta);font-weight:700}
/* review / rating block (visible — must equal JSON-LD) */
.review-block{display:flex;align-items:center;gap:20px;flex-wrap:wrap;background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);padding:22px 24px;margin:1.6rem 0}
.review-block .score{font-family:'Anton',sans-serif;font-size:46px;line-height:1;color:var(--cyan);text-shadow:0 0 16px rgba(25,224,255,.4)}
.review-block .stars{color:var(--cyan);font-size:20px;letter-spacing:2px}
.review-block .rmeta{color:var(--muted);font-size:14px}
.review-block .rmeta b{color:var(--ink)}
/* in-content CTA button */
.btn-cta{display:inline-block;font-family:'Oswald',sans-serif;text-transform:uppercase;font-weight:700;letter-spacing:.5px;padding:14px 30px;border-radius:40px;background:linear-gradient(135deg,var(--cyan),#0bb6d6);color:#03121b;box-shadow:0 0 22px rgba(25,224,255,.45);margin:1.2rem 0;transition:.2s}
.btn-cta:hover{transform:translateY(-2px);text-decoration:none;filter:brightness(1.08)}
.cta-band{text-align:center;background:linear-gradient(135deg,rgba(25,224,255,.08),rgba(255,61,165,.08));border:1px solid var(--line);border-radius:18px;padding:30px 24px;margin:2rem 0}
/* FAQ — details/summary */
.faq{margin:1.6rem 0}
.faq details{border:1px solid var(--line);border-radius:var(--r-md);background:var(--card);margin-bottom:12px;padding:0 18px}
.faq summary{cursor:pointer;font-family:'Oswald',sans-serif;font-size:16px;color:var(--ink);padding:16px 0;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--cyan);font-weight:700}
.faq details[open] summary::after{content:"–";color:var(--magenta)}
.faq details[open] summary{border-bottom:1px solid var(--line)}
.faq details p{padding:14px 0;margin:0;color:var(--muted)}
/* small affiliate disclosure inline */
.aff-note{font-size:13px;color:var(--muted);font-style:italic;margin:1rem 0}
@media(max-width:600px){.pros-cons{grid-template-columns:1fr}}

/* ===================== FOOTER ===================== */
.site-footer{background:#06101e;border-top:1px solid var(--line);padding:60px 0 30px;margin-top:30px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;margin-bottom:40px}
.fcol h4{font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:14px;color:var(--cyan);margin-bottom:16px;letter-spacing:.5px}
.fcol a{display:block;color:var(--muted);font-size:14px;margin-bottom:10px;transition:.2s}
.fcol a:hover{color:var(--ink)}
.fcol .logo{margin-bottom:14px;display:block}
.fcol p.ab{color:var(--muted);font-size:13px;max-width:280px}
.fcol ul{list-style:none}
.compliance{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:18px 0}
.chip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:30px;padding:8px 16px;font-family:'Oswald',sans-serif;text-transform:uppercase;font-size:12px;color:var(--muted)}
.chip b{color:var(--cyan)}
.age{width:40px;height:40px;border-radius:50%;border:2px solid var(--magenta);color:var(--magenta);display:flex;align-items:center;justify-content:center;font-family:'Anton',sans-serif;font-size:14px}
.fbottom{border-top:1px solid var(--line);padding-top:22px;color:var(--muted);font-size:12px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap}

/* ===================== RESPONSIVE ===================== */
@media(max-width:900px){
  .nav-menu{position:absolute;top:100%;left:0;right:0;background:#06101e;border-bottom:1px solid var(--line);flex-direction:column;align-items:flex-start;gap:0;padding:10px 20px;display:none;z-index:99}
  .nav-menu.open{display:flex}
  .nav-menu a{width:100%;padding:13px 0;border-bottom:1px solid var(--line)}
  .nav-menu li{width:100%}
  .burger{display:flex;order:3}
  .mobile-cta{margin-left:auto;order:2}
  .mobile-cta .btn{padding:10px 16px;font-size:13px}
  .logo{order:1}
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero{padding:50px 0 90px}
  .dual-grid,.games,.events,.stats,.promos,.fgrid{grid-template-columns:1fr 1fr}
  .fgrid{grid-template-columns:1fr 1fr}
}
@media(max-width:560px){
  .games,.events,.stats,.promos,.dual-grid,.fgrid{grid-template-columns:1fr}
  .nav-menu{display:none}
  .nav-menu.open{display:flex}
  .hero h1,.hero .hero-h{font-size:42px}
  .cta-band{padding:36px 22px}
}
