/* ============================================================
   HellSpin Casino AU — styles.css
   Dark "ember" theme. No external fonts, no images.
   ============================================================ */

:root{
  --bg:        #0c0a10;
  --bg-2:      #14101c;
  --bg-3:      #1c1626;
  --panel:     #181323;
  --ember:     #ff3b2f;
  --flame:     #ff8a1e;
  --gold:      #ffc24b;
  --text:      #f4eef2;
  --muted:     #a79bb0;
  --line:      rgba(255,255,255,.09);
  --line-2:    rgba(255,255,255,.05);
  --good:      #34d27b;
  --bad:       #ff5d6c;
  --radius:    16px;
  --maxw:      1120px;
  --display:   "Arial Black","Helvetica Neue",Arial,sans-serif;
  --body:      system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{ box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  margin:0;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(255,59,47,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(255,138,30,.12), transparent 55%),
    var(--bg);
  color:var(--text);
  font-family:var(--body);
  font-size:17px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}

.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 20px; }

a{ color:var(--gold); }

p{ margin:0 0 1em; }

/* ---------- Typography ---------- */
h1,h2,h3{
  font-family:var(--display);
  line-height:1.15;
  letter-spacing:.5px;
  margin:0 0 .5em;
  color:var(--text);
}
h1{ font-size:clamp(2rem,6vw,3.4rem); text-transform:uppercase; }
h2{ font-size:clamp(1.5rem,3.6vw,2.2rem); text-transform:uppercase; margin-top:0; }
h3{ font-size:clamp(1.15rem,2.4vw,1.4rem); }

.eyebrow{
  display:inline-block;
  font-family:var(--display);
  text-transform:uppercase;
  letter-spacing:3px;
  font-size:.72rem;
  color:var(--flame);
  margin-bottom:14px;
}

.section{ padding:56px 0; border-top:1px solid var(--line-2); }
.section-lead{ color:var(--muted); max-width:760px; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--display);
  text-transform:uppercase; letter-spacing:1px;
  font-size:1rem;
  border:none; cursor:pointer;
  padding:15px 30px;
  border-radius:999px;
  color:#1a0c08;
  background:linear-gradient(135deg,var(--gold),var(--flame) 55%,var(--ember));
  box-shadow:0 10px 30px rgba(255,59,47,.35), inset 0 1px 0 rgba(255,255,255,.35);
  transition:transform .15s ease, box-shadow .15s ease, filter .15s ease;
}
.btn:hover{ transform:translateY(-2px); filter:brightness(1.06); box-shadow:0 16px 40px rgba(255,59,47,.45); }
.btn:active{ transform:translateY(0); }
.btn:focus-visible{ outline:3px solid var(--gold); outline-offset:3px; }
.btn-ghost{
  background:transparent; color:var(--text);
  border:1.5px solid var(--line); box-shadow:none;
}
.btn-ghost:hover{ border-color:var(--flame); }
.btn-lg{ padding:18px 40px; font-size:1.12rem; }

/* ---------- Header ---------- */
.site-header{
  position:sticky; top:0; z-index:40;
  backdrop-filter:blur(10px);
  background:rgba(12,10,16,.78);
  border-bottom:1px solid var(--line);
}
.header-inner{
  display:flex; align-items:center; justify-content:space-between;
  height:72px;
}
.brand{ display:flex; align-items:center; gap:12px; text-decoration:none; }
.brand .logo-svg{ width:40px; height:40px; flex:none; }
.brand-name{
  font-family:var(--display); text-transform:uppercase;
  letter-spacing:1px; font-size:1.3rem; color:var(--text); white-space:nowrap;
}
.brand-name b{ color:var(--ember); }
.nav{ display:flex; gap:26px; }
.nav a{
  color:var(--muted); text-decoration:none; font-size:.95rem;
  text-transform:uppercase; letter-spacing:1px;
}
.nav a:hover{ color:var(--gold); }

/* ---------- Hero / top bonus banner ---------- */
.hero{ padding:30px 0 10px; }
.bonus-hero{
  position:relative; overflow:hidden;
  border-radius:24px;
  border:1px solid rgba(255,194,75,.35);
  background:
    radial-gradient(700px 300px at 85% 0%, rgba(255,138,30,.35), transparent 60%),
    linear-gradient(135deg,#2a1018,#160b16 70%);
  padding:42px 36px;
  box-shadow:0 30px 80px rgba(0,0,0,.55);
}
.bonus-hero::before{
  content:""; position:absolute; inset:-2px;
  background:radial-gradient(400px 200px at 10% 120%, rgba(255,59,47,.25), transparent 60%);
  pointer-events:none;
}
.bonus-flag{
  display:inline-block; font-family:var(--display); text-transform:uppercase;
  font-size:.7rem; letter-spacing:2px; color:var(--gold);
  border:1px solid rgba(255,194,75,.5); border-radius:999px;
  padding:6px 14px; margin-bottom:16px;
}
.bonus-hero .bonus-title{
  font-family:var(--display);
  text-transform:uppercase;
  line-height:1.15;
  font-size:clamp(1.8rem,5vw,3rem);
  margin:0 0 10px;
  background:linear-gradient(90deg,var(--gold),var(--flame),var(--ember));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.bonus-hero p{ color:#e9dce4; max-width:620px; }
.bonus-hero .cta-row{ display:flex; flex-wrap:wrap; gap:14px; margin-top:22px; align-items:center; }
.bonus-fine{ font-size:.8rem; color:var(--muted); margin-top:14px; }

/* ---------- Intro ---------- */
.intro{ padding:40px 0 8px; }
.lede{ font-size:1.18rem; color:#e6dce6; max-width:820px; }

/* ---------- Quick facts strip ---------- */
.facts{
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:28px;
}
.fact{
  background:var(--bg-3); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px;
}
.fact .k{ font-family:var(--display); color:var(--gold); font-size:1.25rem; }
.fact .l{ color:var(--muted); font-size:.85rem; text-transform:uppercase; letter-spacing:1px; }

/* ---------- Cards ---------- */
.cards{ display:grid; gap:18px; margin-top:26px; }
.cards.cols-3{ grid-template-columns:repeat(3,1fr); }
.cards.cols-2{ grid-template-columns:repeat(2,1fr); }
.card{
  background:linear-gradient(180deg,var(--bg-3),var(--bg-2));
  border:1px solid var(--line); border-radius:var(--radius);
  padding:22px; position:relative;
}
.card h3{ margin-top:6px; }
.card .ico{ width:42px; height:42px; display:block; margin-bottom:6px; }
.card p{ color:var(--muted); font-size:.97rem; margin-bottom:0; }

/* steps */
.steps{ counter-reset:step; display:grid; gap:14px; margin-top:24px; }
.step{
  display:grid; grid-template-columns:54px 1fr; gap:16px; align-items:start;
  background:var(--bg-2); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 20px;
}
.step .num{
  counter-increment:step;
  width:46px; height:46px; border-radius:12px;
  display:grid; place-items:center;
  font-family:var(--display); font-size:1.2rem; color:#1a0c08;
  background:linear-gradient(135deg,var(--gold),var(--ember));
}
.step .num::before{ content:counter(step); }
.step h3{ margin:0 0 4px; font-size:1.1rem; }
.step p{ margin:0; color:var(--muted); font-size:.95rem; }

/* ---------- Tables ---------- */
.table-scroll{
  overflow-x:auto; -webkit-overflow-scrolling:touch;
  border:1px solid var(--line); border-radius:var(--radius);
  margin-top:24px;
}
table{ width:100%; border-collapse:collapse; min-width:560px; }
caption{ caption-side:top; text-align:left; color:var(--muted); font-size:.85rem; padding:12px 16px; }
th,td{ padding:14px 16px; text-align:left; border-bottom:1px solid var(--line-2); font-size:.96rem; }
thead th{
  background:var(--bg-3); color:var(--gold);
  font-family:var(--display); text-transform:uppercase; letter-spacing:1px;
  font-size:.8rem; position:sticky; top:0;
}
tbody tr:hover{ background:rgba(255,138,30,.06); }
.scroll-hint{ font-size:.8rem; color:var(--muted); margin-top:10px; }

/* ---------- Mid bonus strip ---------- */
.bonus-strip{
  margin:14px 0 0;
  display:flex; flex-wrap:wrap; align-items:center; justify-content:space-between; gap:18px;
  border-radius:20px; padding:26px 30px;
  background:linear-gradient(100deg,#3a1116,#1d0d1a 60%,#2a1208);
  border:1px solid rgba(255,59,47,.35);
}
.bonus-strip .txt h3{
  margin:0 0 4px;
  background:linear-gradient(90deg,var(--gold),var(--ember));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.bonus-strip .txt p{ margin:0; color:#e3d7df; }

/* ---------- Pros / Cons ---------- */
.pc{ display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-top:24px; }
.pc-box{ border-radius:var(--radius); padding:22px; border:1px solid var(--line); background:var(--bg-2); }
.pc-box h3{ display:flex; align-items:center; gap:10px; }
.pc-box ul{ list-style:none; margin:0; padding:0; }
.pc-box li{ padding:8px 0 8px 28px; position:relative; color:var(--muted); border-bottom:1px solid var(--line-2); }
.pc-box li:last-child{ border-bottom:none; }
.pc-good li::before{ content:"✦"; position:absolute; left:4px; color:var(--good); }
.pc-bad li::before{ content:"✕"; position:absolute; left:4px; color:var(--bad); }

/* ---------- FAQ accordion (no JS, native details) ---------- */
.faq{ margin-top:26px; display:grid; gap:12px; }
details.qa{
  background:var(--bg-2); border:1px solid var(--line);
  border-radius:14px; padding:0 20px; overflow:hidden;
}
details.qa summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:14px;
  padding:18px 0; font-family:var(--display); font-size:1.05rem; color:var(--text);
}
details.qa summary::-webkit-details-marker{ display:none; }
details.qa summary .plus{
  flex:none; width:26px; height:26px; border-radius:50%;
  border:1.5px solid var(--flame); display:grid; place-items:center;
  color:var(--flame); font-family:var(--display); transition:transform .2s ease;
}
details.qa[open] summary .plus{ transform:rotate(45deg); }
details.qa .ans{ padding:0 0 18px; color:var(--muted); }
details.qa[open]{ border-color:rgba(255,138,30,.45); }

/* ---------- Footer ---------- */
.site-footer{
  border-top:1px solid var(--line);
  background:var(--bg-2);
  padding:44px 0 30px; margin-top:30px;
}
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; }
.footer-grid h4{
  font-family:var(--display); text-transform:uppercase; letter-spacing:1px;
  font-size:.85rem; color:var(--gold); margin:0 0 12px;
}
.footer-grid a, .footer-grid p{ color:var(--muted); text-decoration:none; display:block; margin:6px 0; font-size:.92rem; }
.footer-grid a:hover{ color:var(--gold); }
.rg-badge{
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--line); border-radius:999px; padding:6px 14px;
  font-family:var(--display); color:var(--ember); margin-right:8px; margin-bottom:8px;
}
.footer-bottom{ border-top:1px solid var(--line-2); margin-top:26px; padding-top:18px; color:var(--muted); font-size:.82rem; }

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .facts{ grid-template-columns:repeat(2,1fr); }
  .cards.cols-3{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .nav{ display:none; }
}
@media (max-width:640px){
  body{ font-size:16px; }
  .section{ padding:42px 0; }
  .bonus-hero{ padding:30px 22px; }
  .cards.cols-3, .cards.cols-2{ grid-template-columns:1fr; }
  .pc{ grid-template-columns:1fr; }
  .facts{ grid-template-columns:1fr 1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .bonus-strip{ flex-direction:column; align-items:flex-start; }
  .step{ grid-template-columns:42px 1fr; }
}

@media (prefers-reduced-motion:reduce){
  *{ scroll-behavior:auto; transition:none !important; }
}
