/* ============================================================
   TonyBet Canada — Design System
   Brand: Purple #5C2D8B | Orange #F4610E | White | Dark BG
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400;500;600;700;800;900&family=Inter:wght@400;500;600&display=swap');

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --purple:       #5C2D8B;
  --purple-dark:  #3D1A6B;
  --purple-mid:   #7B3DB0;
  --purple-light: #9B5DD0;
  --orange:       #F4610E;
  --orange-light: #FF8C42;
  --white:        #FFFFFF;
  --off-white:    #F5F0FF;
  --text:         #1A1A2E;
  --text-light:   #666680;
  --bg:           #0F0A1E;
  --bg-card:      #1A1030;
  --bg-surface:   #231545;
  --gold:         #F5C518;
  --green:        #2ECC71;
  --shadow:       0 4px 24px rgba(92,45,139,0.35);
  --radius:       12px;
  --radius-lg:    20px;
  --transition:   0.25s cubic-bezier(0.4,0,0.2,1);
}

/* ── Reset ─────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; font-size:16px; }
body {
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--white);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }

/* ── Skip Link ─────────────────────────────────────────────── */
.skip-link {
  position:absolute; left:-9999px; top:0;
  background:var(--orange); color:#fff; padding:8px 16px;
  z-index:9999; border-radius:0 0 8px 0;
}
.skip-link:focus { left:0; }

/* ── Typography ────────────────────────────────────────────── */
h1,h2,h3,h4,h5 {
  font-family:'Montserrat',sans-serif;
  font-weight:800;
  line-height:1.2;
  color:var(--white);
}
h1 { font-size:clamp(2rem,5vw,3.2rem); }
h2 { font-size:clamp(1.5rem,3.5vw,2.2rem); }
h3 { font-size:clamp(1.1rem,2.5vw,1.5rem); }
h4 { font-size:1.1rem; }

.text-purple { color:var(--purple-light); }
.text-orange { color:var(--orange); }
.text-gold   { color:var(--gold); }
.text-green  { color:var(--green); }
.text-link {
  color:var(--orange-light);
  text-decoration:underline dotted;
  text-underline-offset:3px;
  transition:color var(--transition);
}
.text-link:hover { color:var(--orange); }

/* ── Layout ────────────────────────────────────────────────── */
.container { max-width:1200px; margin:0 auto; padding:0 20px; }
.section { padding:4rem 0; }
.section-sm { padding:2rem 0; }
.sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }

/* ── Buttons ───────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:14px 28px; border-radius:50px;
  font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.95rem;
  cursor:pointer; border:none; transition:all var(--transition);
  text-decoration:none; letter-spacing:0.3px;
}
.btn-primary {
  background:linear-gradient(135deg, var(--orange), var(--orange-light));
  color:#fff;
  box-shadow:0 4px 20px rgba(244,97,14,0.4);
}
.btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(244,97,14,0.55);
}
.btn-purple {
  background:linear-gradient(135deg, var(--purple), var(--purple-mid));
  color:#fff;
  box-shadow:0 4px 20px rgba(92,45,139,0.4);
}
.btn-purple:hover { transform:translateY(-2px); box-shadow:var(--shadow); }
.btn-outline {
  background:transparent; border:2px solid var(--orange);
  color:var(--orange);
}
.btn-outline:hover { background:var(--orange); color:#fff; }
.btn-sm { padding:10px 20px; font-size:0.85rem; }
.btn-lg { padding:18px 36px; font-size:1.1rem; }

/* ── Header ────────────────────────────────────────────────── */
.site-header {
  position:sticky; top:0; z-index:1000;
  background:rgba(15,10,30,0.95);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(92,45,139,0.3);
}
.header-inner {
  display:flex; align-items:center; gap:24px;
  padding:12px 0; min-height:64px;
}
.logo img { height:44px; width:auto; }
.main-nav {
  display:flex; align-items:center; gap:4px;
  margin-left:auto;
}
.nav-link {
  padding:8px 14px; border-radius:8px;
  font-family:'Montserrat',sans-serif; font-weight:600; font-size:0.85rem;
  color:rgba(255,255,255,0.8);
  transition:all var(--transition);
  white-space:nowrap;
}
.nav-link:hover, .nav-link.active {
  color:#fff; background:rgba(92,45,139,0.4);
}
.btn-header {
  background:linear-gradient(135deg,var(--orange),var(--orange-light));
  color:#fff; padding:10px 22px; border-radius:50px;
  font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.85rem;
  transition:all var(--transition); white-space:nowrap;
}
.btn-header:hover { transform:translateY(-1px); box-shadow:0 4px 16px rgba(244,97,14,0.5); }
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:8px;
  margin-left:auto;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--white); border-radius:2px;
  transition:all var(--transition);
}
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }
.mobile-nav {
  display:none; flex-direction:column; gap:4px;
  padding:12px 20px 16px;
  background:rgba(15,10,30,0.98);
  border-top:1px solid rgba(92,45,139,0.3);
}
.mobile-nav.open { display:flex; }
.mobile-nav .nav-link { padding:10px 12px; font-size:0.95rem; }
.mobile-cta { margin-top:8px; }
.mobile-cta .btn-header { width:100%; text-align:center; display:block; padding:14px; }

/* ── Hero Section ──────────────────────────────────────────── */
.hero {
  background:linear-gradient(135deg, var(--purple-dark) 0%, var(--purple) 50%, var(--bg) 100%);
  position:relative; overflow:hidden;
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse at 70% 50%, rgba(244,97,14,0.12) 0%, transparent 60%);
}
.hero-inner {
  display:grid; grid-template-columns:1fr 1fr; gap:48px;
  align-items:center; padding:5rem 0;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:rgba(244,97,14,0.15); border:1px solid rgba(244,97,14,0.4);
  color:var(--orange-light); font-size:0.8rem; font-weight:600;
  padding:5px 12px; border-radius:50px; margin-bottom:1rem;
  font-family:'Montserrat',sans-serif;
}
.hero-title { margin-bottom:1rem; }
.hero-title span { color:var(--orange); }
.hero-subtitle { color:rgba(255,255,255,0.75); font-size:1.05rem; margin-bottom:2rem; max-width:480px; }
.hero-actions { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:2rem; }
.hero-stats {
  display:flex; gap:24px; flex-wrap:wrap;
  padding:1.5rem; background:rgba(255,255,255,0.05);
  border-radius:var(--radius); border:1px solid rgba(92,45,139,0.3);
}
.hero-stat value {
  display:block; font-family:'Montserrat',sans-serif;
  font-size:1.6rem; font-weight:800; color:var(--orange);
}
.hero-stat label { font-size:0.75rem; color:rgba(255,255,255,0.6); font-weight:500; }
.hero-image { position:relative; }
.hero-image img {
  border-radius:var(--radius-lg);
  box-shadow:0 24px 64px rgba(92,45,139,0.5);
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}

/* ── Bonus Band ─────────────────────────────────────────────── */
.bonus-band {
  background:linear-gradient(90deg, var(--orange), #FF8C42, var(--orange));
  padding:20px 0;
}
.bonus-band-inner {
  display:flex; align-items:center; justify-content:center; gap:32px; flex-wrap:wrap;
}
.bonus-item {
  text-align:center;
  font-family:'Montserrat',sans-serif;
}
.bonus-item strong { display:block; font-size:1.6rem; font-weight:900; color:#fff; }
.bonus-item span { font-size:0.8rem; font-weight:600; color:rgba(255,255,255,0.85); }
.bonus-sep { font-size:2rem; color:rgba(255,255,255,0.4); }

/* ── Cards ───────────────────────────────────────────────────  */
.card {
  background:var(--bg-card);
  border:1px solid rgba(92,45,139,0.25);
  border-radius:var(--radius); padding:1.5rem;
  transition:all var(--transition);
}
.card:hover { border-color:var(--orange); transform:translateY(-3px); box-shadow:var(--shadow); }
.card-grid { display:grid; gap:20px; }
.card-grid-2 { grid-template-columns:repeat(2,1fr); }
.card-grid-3 { grid-template-columns:repeat(3,1fr); }
.card-grid-4 { grid-template-columns:repeat(4,1fr); }

.score-card {
  background:var(--bg-surface);
  border:1px solid rgba(92,45,139,0.3);
  border-radius:var(--radius); padding:1.25rem;
  text-align:center;
}
.score-card .score {
  font-family:'Montserrat',sans-serif;
  font-size:2.5rem; font-weight:900;
  color:var(--orange); display:block;
}
.score-card .score-label { font-size:0.8rem; color:rgba(255,255,255,0.6); font-weight:500; }

/* ── Rating Stars ────────────────────────────────────────────  */
.stars { color:var(--gold); font-size:1.1rem; letter-spacing:2px; }

/* ── Tables ───────────────────────────────────────────────── */
.table-wrap { overflow-x:auto; border-radius:var(--radius); }
table {
  width:100%; border-collapse:collapse;
  background:var(--bg-card);
}
caption {
  padding:12px; text-align:left;
  font-family:'Montserrat',sans-serif; font-weight:700;
  color:var(--white); background:var(--bg-surface);
  border-radius:var(--radius) var(--radius) 0 0;
}
th {
  background:var(--purple); color:#fff;
  padding:12px 16px; text-align:left;
  font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.85rem;
  white-space:nowrap;
}
td {
  padding:12px 16px;
  border-bottom:1px solid rgba(92,45,139,0.15);
  font-size:0.9rem;
}
tr:last-child td { border-bottom:none; }
tr:hover td { background:rgba(92,45,139,0.08); }
td.good { color:var(--green); font-weight:600; }
td.warn { color:var(--gold); font-weight:600; }
td.bad  { color:#FF6B6B; font-weight:600; }

/* ── Bar Charts ──────────────────────────────────────────── */
.bar-chart { display:flex; flex-direction:column; gap:14px; }
.bar-item {}
.bar-header { display:flex; justify-content:space-between; margin-bottom:5px; }
.bar-label { font-size:0.85rem; font-weight:600; }
.bar-val { font-size:0.85rem; font-weight:700; color:var(--orange); }
.bar-track {
  height:10px; background:rgba(255,255,255,0.08);
  border-radius:50px; overflow:hidden;
}
.bar-fill {
  height:100%; border-radius:50px;
  background:linear-gradient(90deg, var(--orange), var(--orange-light));
  width:0; transition:width 1.2s cubic-bezier(0.4,0,0.2,1);
}
.bar-fill.purple { background:linear-gradient(90deg, var(--purple), var(--purple-light)); }
.bar-fill.gold   { background:linear-gradient(90deg, #E6A800, var(--gold)); }

/* ── Donut Charts ─────────────────────────────────────────── */
.ring-chart-wrap {
  display:flex; flex-wrap:wrap; gap:24px; justify-content:center;
}
.ring-chart { text-align:center; }
.ring-chart svg { transform:rotate(-90deg); }
.ring-track { fill:none; stroke:rgba(255,255,255,0.07); }
.ring-fill  { fill:none; stroke-linecap:round; transition:stroke-dashoffset 1.4s cubic-bezier(0.4,0,0.2,1); }
.ring-inner { position:relative; display:inline-block; }
.ring-center {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
}
.ring-pct { font-family:'Montserrat',sans-serif; font-weight:800; font-size:1.1rem; color:var(--orange); }
.ring-name { font-size:0.75rem; color:rgba(255,255,255,0.6); margin-top:6px; }

/* ── Highlight / Callout ─────────────────────────────────── */
.highlight {
  background:var(--bg-surface); border-left:4px solid var(--orange);
  border-radius:0 var(--radius) var(--radius) 0;
  padding:1rem 1.25rem; margin:1.5rem 0;
}
.highlight.purple { border-left-color:var(--purple-light); }
.highlight.green  { border-left-color:var(--green); }

/* ── FAQ / Accordion ─────────────────────────────────────── */
.faq-list { display:flex; flex-direction:column; gap:10px; }
.faq-item {
  background:var(--bg-card); border:1px solid rgba(92,45,139,0.25);
  border-radius:var(--radius); overflow:hidden;
}
.faq-q {
  width:100%; display:flex; justify-content:space-between; align-items:center;
  padding:16px 20px; background:none; border:none; cursor:pointer;
  font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.95rem;
  color:var(--white); text-align:left; gap:12px;
}
.faq-icon {
  font-size:1.2rem; transition:transform var(--transition);
  flex-shrink:0; color:var(--orange);
}
.faq-item.open .faq-icon { transform:rotate(45deg); }
.faq-a { max-height:0; overflow:hidden; transition:max-height 0.35s ease; }
.faq-a-inner { padding:0 20px 16px; color:rgba(255,255,255,0.8); font-size:0.9rem; }

/* ── Author Block ─────────────────────────────────────────── */
.author-box {
  display:flex; gap:20px; align-items:flex-start;
  background:var(--bg-surface); border-radius:var(--radius);
  padding:1.5rem; border:1px solid rgba(92,45,139,0.3);
  margin:2.5rem 0;
}
.author-img { width:72px; height:72px; border-radius:50%; object-fit:cover; flex-shrink:0; border:3px solid var(--orange); }
.author-name { font-family:'Montserrat',sans-serif; font-weight:800; font-size:1rem; }
.author-title { font-size:0.8rem; color:var(--orange); font-weight:600; margin-bottom:4px; }
.author-bio { font-size:0.85rem; color:rgba(255,255,255,0.7); }

/* ── SEO Content Section ─────────────────────────────────── */
.seo-section { padding:4rem 0; }
.seo-article {
  max-width:860px;
  font-size:0.95rem;
  color:rgba(255,255,255,0.85);
}
.seo-article p { margin-bottom:1.2rem; }
.seo-article h2 { margin:2.5rem 0 1rem; font-size:1.6rem; }
.seo-article h3 { margin:1.8rem 0 0.75rem; font-size:1.2rem; }
.seo-article ul { padding-left:1.5rem; list-style:disc; margin-bottom:1.2rem; }
.seo-article ul li { margin-bottom:6px; }
.seo-article strong { color:var(--white); }

/* ── Pros / Cons ─────────────────────────────────────────── */
.pros-cons { display:grid; grid-template-columns:1fr 1fr; gap:20px; margin:2rem 0; }
.pros, .cons {
  background:var(--bg-card); border-radius:var(--radius); padding:1.25rem;
}
.pros { border-top:3px solid var(--green); }
.cons { border-top:3px solid #FF6B6B; }
.pros h4 { color:var(--green); margin-bottom:10px; }
.cons h4 { color:#FF6B6B; margin-bottom:10px; }
.pros li, .cons li {
  padding:6px 0; border-bottom:1px solid rgba(255,255,255,0.07);
  font-size:0.875rem; display:flex; align-items:flex-start; gap:8px;
}
.pros li:last-child, .cons li:last-child { border-bottom:none; }
.pros li::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; }
.cons li::before { content:'✗'; color:#FF6B6B; font-weight:700; flex-shrink:0; }

/* ── Breadcrumb ───────────────────────────────────────────── */
.breadcrumb {
  display:flex; align-items:center; gap:6px; flex-wrap:wrap;
  font-size:0.8rem; color:rgba(255,255,255,0.5); margin-bottom:1rem;
}
.breadcrumb a:hover { color:var(--orange); }
.breadcrumb .sep { color:rgba(255,255,255,0.25); }
.breadcrumb .current { color:rgba(255,255,255,0.8); }

/* ── Page Hero ───────────────────────────────────────────── */
.page-hero {
  background:linear-gradient(135deg, var(--purple-dark), var(--bg-surface));
  padding:3rem 0;
  border-bottom:1px solid rgba(92,45,139,0.3);
}
.page-hero-img {
  width:100%; max-height:320px;
  object-fit:cover; border-radius:var(--radius-lg);
  margin-top:2rem;
  aspect-ratio:3/1;
}

/* ── Footer ───────────────────────────────────────────────── */
.site-footer {
  background:var(--bg-card);
  border-top:1px solid rgba(92,45,139,0.25);
  padding:3rem 0 1.5rem;
  margin-top:4rem;
}
.footer-top {
  display:grid; grid-template-columns:240px 1fr; gap:48px;
  margin-bottom:2rem;
}
.footer-brand p { font-size:0.85rem; color:rgba(255,255,255,0.5); margin-top:12px; }
.footer-logo img { height:40px; }
.footer-nav { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.footer-col h4 {
  font-family:'Montserrat',sans-serif; font-weight:700; font-size:0.8rem;
  color:var(--orange); text-transform:uppercase; letter-spacing:1px;
  margin-bottom:12px;
}
.footer-col a {
  display:block; font-size:0.85rem; color:rgba(255,255,255,0.55);
  padding:4px 0; transition:color var(--transition);
}
.footer-col a:hover { color:var(--white); }
.footer-bottom {
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
  padding-top:1.5rem; border-top:1px solid rgba(92,45,139,0.15);
}
.footer-badges { display:flex; gap:8px; flex-wrap:wrap; }
.footer-badge {
  background:rgba(92,45,139,0.3); border:1px solid rgba(92,45,139,0.5);
  color:rgba(255,255,255,0.7); padding:4px 12px;
  border-radius:50px; font-size:0.75rem; font-weight:600;
}
.footer-badge.age { background:rgba(244,97,14,0.2); border-color:var(--orange); color:var(--orange); }
.footer-legal { font-size:0.75rem; color:rgba(255,255,255,0.35); max-width:680px; }

/* ── Responsive ───────────────────────────────────────────── */
@media (max-width:1024px) {
  .card-grid-4 { grid-template-columns:repeat(2,1fr); }
  .hero-inner { grid-template-columns:1fr; }
  .hero-image { display:none; }
}
@media (max-width:768px) {
  .main-nav { display:none; }
  .hamburger { display:flex; }
  /* Show compact CTA in mobile header */
  .btn-header {
    display:inline-flex;
    padding:9px 14px;
    font-size:0.78rem;
    white-space:nowrap;
    margin-left:auto;
  }
  /* Move hamburger after btn-header using order */
  .header-inner { gap:10px; }
  .logo { flex-shrink:0; }
  .btn-header { order:2; }
  .hamburger { order:3; margin-left:0; }
  .card-grid-3, .card-grid-2 { grid-template-columns:1fr; }
  .card-grid-4 { grid-template-columns:1fr 1fr; }
  .pros-cons { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .footer-nav { grid-template-columns:repeat(2,1fr); }
  .hero-stats { gap:16px; }
  .bonus-band-inner { gap:16px; }
  .bonus-sep { display:none; }
}
@media (max-width:480px) {
  .card-grid-4 { grid-template-columns:1fr; }
  .footer-nav { grid-template-columns:1fr 1fr; }
  h1 { font-size:1.8rem; }
}
