/* ==========================================================
   casino-landing.css — Zanoza News Casino Pages
   Shared design system for lv-LV, uk-UA, ru-LV
   Version: 2026-05-20
   ========================================================== */

/* ----------------------------------------------------------
   1. GOOGLE FONTS IMPORT
   ---------------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ----------------------------------------------------------
   2. DESIGN TOKENS
   ---------------------------------------------------------- */
:root {
  /* Color palette */
  --cl-bg: #fafaf7;
  --cl-bg-card: #ffffff;
  --cl-bg-alt: #f4f4f0;
  --cl-ink: #111418;
  --cl-ink-muted: #5a6068;
  --cl-border: #e3e5e0;
  --cl-accent: #2b5dd1;
  --cl-accent-dark: #1e4196;
  --cl-accent-bg: #eef2fc;
  --cl-green: #1c8a4a;
  --cl-green-bg: #edf7f1;
  --cl-rg-amber: #b45309;
  --cl-rg-bg: #fef9ee;
  --cl-rg-border: #fbbf24;
  --cl-rank-1: #1c8a4a;
  --cl-rank-badge: #2b5dd1;

  /* Typography */
  --cl-font-body: 'Inter', system-ui, -apple-system, sans-serif;
  --cl-font-mono: 'JetBrains Mono', 'Fira Code', monospace;

  /* Spacing (8px grid) */
  --sp-1: 0.5rem;    /* 8px */
  --sp-2: 1rem;      /* 16px */
  --sp-3: 1.5rem;    /* 24px */
  --sp-4: 2rem;      /* 32px */
  --sp-6: 3rem;      /* 48px */
  --sp-9: 4.5rem;    /* 72px */

  /* Card */
  --cl-radius: 12px;
  --cl-radius-sm: 8px;
  --cl-shadow: 0 1px 2px rgba(20,30,40,.06), 0 8px 24px -8px rgba(20,30,40,.10);
  --cl-shadow-hover: 0 3px 6px rgba(20,30,40,.08), 0 16px 32px -8px rgba(20,30,40,.16);

  /* Transitions */
  --cl-transition: 150ms ease;
  --cl-transition-md: 250ms ease;
}

/* ----------------------------------------------------------
   3. RESET & BASE (scoped to .cl-page)
   ---------------------------------------------------------- */
.cl-page *,
.cl-page *::before,
.cl-page *::after {
  box-sizing: border-box;
}

.cl-page {
  font-family: var(--cl-font-body);
  font-size: 17px;
  line-height: 1.6;
  color: var(--cl-ink);
  background: var(--cl-bg);
}

.cl-page a:not(.cl-cta) {
  color: var(--cl-accent);
  text-decoration: none;
  transition: color var(--cl-transition);
}

.cl-page a:not(.cl-cta):hover {
  color: var(--cl-accent-dark);
  text-decoration: underline;
}

.cl-page a:focus-visible {
  outline: 2px solid var(--cl-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.cl-page img {
  max-width: 100%;
  height: auto;
}

.cl-page p {
  margin-bottom: var(--sp-2);
}

.cl-page ul,
.cl-page ol {
  margin: var(--sp-2) 0;
  padding-left: var(--sp-4);
}

.cl-page li {
  margin-bottom: var(--sp-1);
  line-height: 1.7;
}

/* Container */
.cl-container {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 var(--sp-3);
}

/* Section wrapper */
.cl-section {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--cl-border);
}

.cl-section:last-of-type {
  border-bottom: none;
}

.cl-section--alt {
  background: var(--cl-bg-alt);
}

/* Section headings */
.cl-section__heading {
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
  color: var(--cl-ink);
  margin: 0 0 var(--sp-4);
}

.cl-section__subheading {
  font-size: 1.375rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--cl-ink);
  margin: var(--sp-4) 0 var(--sp-2);
}

/* Eyebrow label */
.cl-eyebrow {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cl-ink-muted);
}

/* ----------------------------------------------------------
   4. HERO
   ---------------------------------------------------------- */
.cl-hero {
  background: var(--cl-bg);
  padding: var(--sp-6) 0 var(--sp-4);
  border-bottom: 1px solid var(--cl-border);
}

.cl-hero__eyebrow {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cl-accent);
  margin-bottom: var(--sp-2);
  display: block;
}

.cl-hero__title {
  font-size: clamp(2rem, 4.5vw, 2.75rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--cl-ink);
  margin: 0 0 var(--sp-2);
  max-width: 800px;
}

.cl-hero__deck {
  font-size: 1.125rem;
  line-height: 1.65;
  color: var(--cl-ink-muted);
  max-width: 760px;
  margin: 0 0 var(--sp-3);
}

/* Byline */
.cl-byline {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2) 0;
  border-top: 1px solid var(--cl-border);
  flex-wrap: wrap;
}

.cl-byline__photo {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 2px solid var(--cl-border);
}

.cl-byline__meta {
  flex: 1;
  min-width: 0;
}

.cl-byline__name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--cl-ink);
  line-height: 1.3;
}

.cl-byline__role {
  font-size: 0.8125rem;
  color: var(--cl-ink-muted);
  margin-top: 2px;
}

.cl-byline__date {
  font-family: var(--cl-font-mono);
  font-size: 0.75rem;
  color: var(--cl-ink-muted);
  letter-spacing: 0.03em;
  margin-left: auto;
}

/* ----------------------------------------------------------
   5. RANKING TABLE
   ---------------------------------------------------------- */
.cl-ranking {
  background: var(--cl-bg);
  padding: var(--sp-9) 0 var(--sp-6);
  border-bottom: 1px solid var(--cl-border);
}

.cl-ranking__title {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--cl-ink);
  margin: 0 0 var(--sp-4);
}

.cl-ranking__list {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.cl-ranking__row {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius);
  box-shadow: var(--cl-shadow);
  display: grid;
  grid-template-columns: 80px 140px 1fr auto;
  align-items: center;
  min-height: 120px;
  position: relative;
  overflow: hidden;
  transition: box-shadow var(--cl-transition-md), transform var(--cl-transition-md);
}

.cl-ranking__row:hover {
  box-shadow: var(--cl-shadow-hover);
  transform: translateY(-2px);
}

.cl-ranking__row--editor-pick {
  border: 2px solid var(--cl-green);
}

.cl-ranking__row--editor-pick::before {
  content: 'EDITOR\'S PICK';
  position: absolute;
  top: 0;
  right: 0;
  background: var(--cl-green);
  color: #ffffff;
  font-family: var(--cl-font-mono);
  font-size: 0.5625rem;
  font-weight: 500;
  letter-spacing: 0.12em;
  padding: 4px 10px;
  border-radius: 0 12px 0 8px;
  z-index: 2;
}

/* Rank pill */
.cl-ranking__rank {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2);
  gap: 4px;
}

.cl-ranking__rank-pill {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--cl-bg-alt);
  color: var(--cl-ink-muted);
  font-size: 1.125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--cl-transition);
}

.cl-ranking__row--editor-pick .cl-ranking__rank-pill {
  background: var(--cl-green);
  color: #ffffff;
}

/* Stars */
.cl-stars {
  display: flex;
  gap: 2px;
  align-items: center;
}

.cl-stars__item {
  width: 14px;
  height: 14px;
  display: inline-block;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z' fill='%232b5dd1'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
}

.cl-stars__item--empty {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z' fill='none' stroke='%23c0c5cc' stroke-width='1.5'/%3E%3C/svg%3E");
}

.cl-stars__value {
  font-family: var(--cl-font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--cl-ink-muted);
  margin-left: 4px;
}

/* Logo cell */
.cl-ranking__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-2) var(--sp-1);
  border-left: 1px solid var(--cl-border);
  height: 100%;
}

.cl-ranking__logo img {
  max-width: 110px;
  max-height: 72px;
  object-fit: contain;
  display: block;
}

/* Info cell */
.cl-ranking__info {
  padding: var(--sp-2) var(--sp-3);
  border-left: 1px solid var(--cl-border);
}

.cl-ranking__name {
  font-size: 1.125rem;
  font-weight: 700;
  color: var(--cl-ink);
  margin-bottom: 6px;
  line-height: 1.3;
}

.cl-ranking__tagline {
  font-size: 0.8125rem;
  color: var(--cl-ink-muted);
  margin-bottom: 8px;
}

.cl-ranking__bonus {
  font-size: 0.9375rem;
  color: var(--cl-ink);
  font-weight: 500;
}

.cl-ranking__bonus strong {
  color: var(--cl-accent);
}

/* CTA cell */
.cl-ranking__cta {
  padding: var(--sp-2) var(--sp-3);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--sp-1);
  border-left: 1px solid var(--cl-border);
}

.cl-ranking__review-link {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  color: var(--cl-ink-muted);
  text-decoration: none;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  transition: color var(--cl-transition);
}

.cl-ranking__review-link:hover {
  color: var(--cl-accent);
  text-decoration: underline;
}

/* "More options" mini-grid (uk-UA 7-15) */
.cl-ranking__more-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--cl-ink-muted);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--cl-font-mono);
  margin: var(--sp-4) 0 var(--sp-2);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--cl-border);
}

.cl-ranking__mini-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: var(--sp-2);
}

.cl-ranking__mini-item {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius-sm);
  border: 1px solid var(--cl-border);
  display: flex;
  align-items: center;
  gap: var(--sp-1);
  padding: var(--sp-1) var(--sp-2);
  transition: box-shadow var(--cl-transition), border-color var(--cl-transition);
}

.cl-ranking__mini-item:hover {
  border-color: var(--cl-accent);
  box-shadow: 0 2px 8px rgba(43,93,209,.12);
}

.cl-ranking__mini-rank {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--cl-ink-muted);
  width: 24px;
  text-align: center;
  flex-shrink: 0;
}

.cl-ranking__mini-logo {
  width: 48px;
  height: 32px;
  object-fit: contain;
  flex-shrink: 0;
}

.cl-ranking__mini-name {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--cl-ink);
  flex: 1;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ----------------------------------------------------------
   6. CTA BUTTONS
   ---------------------------------------------------------- */
.cl-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 14px 28px;
  border-radius: var(--cl-radius-sm);
  font-family: var(--cl-font-body);
  font-size: 0.9375rem;
  font-weight: 600;
  line-height: 1;
  text-decoration: none !important;
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--cl-transition), color var(--cl-transition), transform var(--cl-transition), box-shadow var(--cl-transition);
}

.cl-cta:focus-visible {
  outline: 2px solid var(--cl-accent);
  outline-offset: 2px;
}

.cl-cta--primary {
  background: var(--cl-accent);
  color: #ffffff;
  box-shadow: 0 2px 6px rgba(43,93,209,.30);
  min-width: 140px;
}

.cl-cta--primary:hover {
  background: var(--cl-accent-dark);
  color: #ffffff;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(43,93,209,.40);
  text-decoration: none !important;
}

.cl-cta--secondary {
  background: transparent;
  color: var(--cl-accent);
  border: 1.5px solid var(--cl-accent);
}

.cl-cta--secondary:hover {
  background: var(--cl-accent-bg);
  color: var(--cl-accent-dark);
  text-decoration: none !important;
}

.cl-cta--full {
  width: 100%;
}

/* ----------------------------------------------------------
   7. TRUST STRIP
   ---------------------------------------------------------- */
.cl-trust {
  background: var(--cl-bg-card);
  border-top: 1px solid var(--cl-border);
  border-bottom: 1px solid var(--cl-border);
  padding: var(--sp-4) 0;
}

.cl-trust__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--sp-3);
}

.cl-trust__item {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
}

.cl-trust__icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--cl-accent-bg);
  color: var(--cl-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 1rem;
}

.cl-trust__text strong {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--cl-ink);
  display: block;
  margin-bottom: 2px;
}

.cl-trust__text span {
  font-size: 0.8125rem;
  color: var(--cl-ink-muted);
  line-height: 1.4;
}

/* ----------------------------------------------------------
   8. REVIEW CARDS (deep dives)
   ---------------------------------------------------------- */
.cl-reviews {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--cl-border);
}

.cl-review {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius);
  box-shadow: var(--cl-shadow);
  padding: var(--sp-4);
  margin-bottom: var(--sp-4);
  scroll-margin-top: 80px;
}

.cl-review:last-child {
  margin-bottom: 0;
}

.cl-review__head {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  margin-bottom: var(--sp-3);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--cl-border);
  flex-wrap: wrap;
}

.cl-review__logo {
  width: 80px;
  height: 56px;
  object-fit: contain;
  flex-shrink: 0;
}

.cl-review__head-meta {
  flex: 1;
  min-width: 0;
}

.cl-review__name {
  font-size: 1.375rem;
  font-weight: 700;
  color: var(--cl-ink);
  line-height: 1.2;
  margin-bottom: 4px;
}

.cl-review__rank-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--cl-accent-bg);
  color: var(--cl-accent);
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  padding: 3px 8px;
  border-radius: 99px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}

.cl-review__rank-badge--top {
  background: var(--cl-green-bg);
  color: var(--cl-green);
}

.cl-review__tagline {
  font-size: 0.9375rem;
  color: var(--cl-ink-muted);
  margin-top: 4px;
}

.cl-review__head-cta {
  margin-left: auto;
  flex-shrink: 0;
  align-self: center;
}

/* Pros / Cons */
.cl-pros-cons {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-3);
  margin: var(--sp-3) 0;
}

.cl-pros,
.cl-cons {
  padding: var(--sp-2) var(--sp-3);
  border-radius: var(--cl-radius-sm);
}

.cl-pros {
  background: var(--cl-green-bg);
  border-left: 3px solid var(--cl-green);
}

.cl-cons {
  background: #fafaf7;
  border-left: 3px solid var(--cl-border);
}

.cl-pros__title,
.cl-cons__title {
  font-size: 0.8125rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-family: var(--cl-font-mono);
  margin-bottom: var(--sp-1);
}

.cl-pros__title {
  color: var(--cl-green);
}

.cl-cons__title {
  color: var(--cl-ink-muted);
}

.cl-pros ul,
.cl-cons ul {
  margin: 0;
  padding-left: var(--sp-3);
  list-style: none;
}

.cl-pros li {
  position: relative;
  font-size: 0.875rem;
  color: var(--cl-ink);
  margin-bottom: 6px;
  padding-left: 4px;
}

.cl-pros li::before {
  content: '✓';
  color: var(--cl-green);
  font-weight: 700;
  margin-right: 6px;
}

.cl-cons li {
  position: relative;
  font-size: 0.875rem;
  color: var(--cl-ink-muted);
  margin-bottom: 6px;
  padding-left: 4px;
}

.cl-cons li::before {
  content: '—';
  color: var(--cl-ink-muted);
  margin-right: 6px;
}

/* Bonus block */
.cl-review__bonus {
  background: var(--cl-accent-bg);
  border-radius: var(--cl-radius-sm);
  padding: var(--sp-2) var(--sp-3);
  margin: var(--sp-2) 0;
}

.cl-review__bonus-label {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--cl-accent);
  margin-bottom: 4px;
}

.cl-review__bonus-value {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--cl-ink);
}

/* Payment chips */
.cl-review__payments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: var(--sp-2) 0;
}

.cl-chip {
  display: inline-flex;
  align-items: center;
  background: var(--cl-bg-alt);
  border: 1px solid var(--cl-border);
  border-radius: 99px;
  padding: 4px 12px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--cl-ink);
  line-height: 1;
  white-space: nowrap;
}

.cl-review__license {
  font-size: 0.8125rem;
  color: var(--cl-ink-muted);
  font-family: var(--cl-font-mono);
  margin: var(--sp-1) 0 var(--sp-2);
}

.cl-review__cta-wrap {
  margin-top: var(--sp-3);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--cl-border);
  text-align: center;
}

/* ----------------------------------------------------------
   9. EDITOR'S NOTE (why we recommend)
   ---------------------------------------------------------- */
.cl-editors-note {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius);
  border-left: 4px solid var(--cl-green);
  padding: var(--sp-4);
  margin: var(--sp-4) 0;
  box-shadow: var(--cl-shadow);
}

.cl-editors-note__label {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--cl-green);
  margin-bottom: var(--sp-1);
  display: block;
}

.cl-editors-note__title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cl-ink);
  margin-bottom: var(--sp-2);
}

.cl-editors-note p {
  font-size: 1rem;
  color: var(--cl-ink-muted);
  margin-bottom: var(--sp-2);
}

.cl-editors-note p:last-of-type {
  margin-bottom: var(--sp-3);
}

/* ----------------------------------------------------------
   10. METHODOLOGY
   ---------------------------------------------------------- */
.cl-methodology {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--cl-border);
}

.cl-methodology__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}

.cl-methodology__item {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius-sm);
  border: 1px solid var(--cl-border);
  padding: var(--sp-3);
  position: relative;
}

.cl-methodology__num {
  font-family: var(--cl-font-mono);
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--cl-accent);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 6px;
}

.cl-methodology__item h4 {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cl-ink);
  margin-bottom: 6px;
}

.cl-methodology__item p {
  font-size: 0.875rem;
  color: var(--cl-ink-muted);
  margin: 0;
  line-height: 1.55;
}

/* ----------------------------------------------------------
   11. FAQ ACCORDION
   ---------------------------------------------------------- */
.cl-faq {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--cl-border);
}

.cl-faq__list {
  margin-top: var(--sp-4);
}

.cl-faq__item {
  border-bottom: 1px solid var(--cl-border);
}

.cl-faq__item:first-child {
  border-top: 1px solid var(--cl-border);
}

.cl-faq__item summary {
  font-size: 1rem;
  font-weight: 600;
  color: var(--cl-ink);
  cursor: pointer;
  list-style: none;
  padding: var(--sp-2) 0;
  position: relative;
  padding-right: var(--sp-4);
  user-select: none;
  line-height: 1.4;
}

.cl-faq__item summary::-webkit-details-marker {
  display: none;
}

.cl-faq__item summary::after {
  content: '';
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235a6068' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") no-repeat center;
  background-size: contain;
  transition: transform var(--cl-transition-md);
}

.cl-faq__item[open] summary::after {
  transform: translateY(-50%) rotate(180deg);
}

.cl-faq__item summary:focus-visible {
  outline: 2px solid var(--cl-accent);
  outline-offset: 2px;
  border-radius: 2px;
}

.cl-faq__answer {
  padding: 0 0 var(--sp-3);
  font-size: 0.9375rem;
  color: var(--cl-ink-muted);
  line-height: 1.65;
}

.cl-faq__answer p {
  margin-bottom: var(--sp-1);
}

.cl-faq__answer p:last-child {
  margin-bottom: 0;
}

/* ----------------------------------------------------------
   12. AUTHOR BIO CARD
   ---------------------------------------------------------- */
.cl-author-card {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius);
  border: 1px solid var(--cl-border);
  padding: var(--sp-4);
  display: flex;
  gap: var(--sp-4);
  align-items: flex-start;
  margin: var(--sp-6) 0;
}

.cl-author-card__photo {
  width: 120px;
  height: 120px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  border: 3px solid var(--cl-border);
}

.cl-author-card__meta {
  flex: 1;
}

.cl-author-card__label {
  font-family: var(--cl-font-mono);
  font-size: 0.6875rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--cl-accent);
  margin-bottom: 6px;
  display: block;
}

.cl-author-card__name {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--cl-ink);
  margin-bottom: 4px;
}

.cl-author-card__role {
  font-size: 0.875rem;
  color: var(--cl-ink-muted);
  margin-bottom: var(--sp-2);
}

.cl-author-card__bio {
  font-size: 0.9375rem;
  color: var(--cl-ink-muted);
  line-height: 1.65;
  margin: 0;
}

/* ----------------------------------------------------------
   13. RESPONSIBLE GAMBLING
   ---------------------------------------------------------- */
.cl-rg {
  background: var(--cl-rg-bg);
  border: 1.5px solid var(--cl-rg-border);
  border-radius: var(--cl-radius);
  padding: var(--sp-4);
  margin: var(--sp-6) 0 var(--sp-4);
}

.cl-rg__title {
  font-size: 1.0625rem;
  font-weight: 700;
  color: var(--cl-rg-amber);
  margin-bottom: var(--sp-2);
  display: flex;
  align-items: center;
  gap: 8px;
}

.cl-rg__title::before {
  content: '⚠';
  font-size: 1rem;
}

.cl-rg p {
  font-size: 0.9375rem;
  color: var(--cl-ink);
  margin-bottom: var(--sp-1);
  line-height: 1.6;
}

.cl-rg a {
  color: var(--cl-rg-amber);
  font-weight: 500;
}

.cl-rg a:hover {
  color: #92400e;
}

.cl-rg ul {
  margin: var(--sp-1) 0 var(--sp-2);
  padding-left: var(--sp-3);
}

.cl-rg li {
  font-size: 0.9375rem;
  color: var(--cl-ink);
  margin-bottom: 6px;
}

/* ----------------------------------------------------------
   14. LAST UPDATED STAMP
   ---------------------------------------------------------- */
.cl-stamp {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--cl-font-mono);
  font-size: 0.75rem;
  color: var(--cl-ink-muted);
  letter-spacing: 0.04em;
  margin-top: var(--sp-2);
}

.cl-stamp::before {
  content: '';
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--cl-green);
}

/* ----------------------------------------------------------
   15. COMPARISON TABLE
   ---------------------------------------------------------- */
.cl-table-wrap {
  overflow-x: auto;
  border-radius: var(--cl-radius-sm);
  border: 1px solid var(--cl-border);
  margin: var(--sp-3) 0;
}

.cl-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.cl-table thead tr {
  background: var(--cl-ink);
  color: #ffffff;
}

.cl-table th {
  padding: 14px 16px;
  text-align: left;
  font-size: 0.8125rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  white-space: nowrap;
}

.cl-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--cl-border);
  font-size: 0.9rem;
  color: var(--cl-ink);
  vertical-align: top;
}

.cl-table tbody tr:last-child td {
  border-bottom: none;
}

.cl-table tbody tr:hover {
  background: var(--cl-bg-alt);
}

/* ----------------------------------------------------------
   16. PAYMENT CHIPS STRIP
   ---------------------------------------------------------- */
.cl-payments {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: var(--sp-3) 0;
}

/* ----------------------------------------------------------
   17. DISCLAIMER BANNER
   ---------------------------------------------------------- */
.cl-disclaimer {
  background: var(--cl-bg-card);
  border: 1px solid var(--cl-border);
  border-radius: var(--cl-radius-sm);
  padding: var(--sp-2) var(--sp-3);
  font-size: 0.8125rem;
  color: var(--cl-ink-muted);
  text-align: center;
  margin-top: var(--sp-4);
}

/* ----------------------------------------------------------
   18. GENERAL EDITORIAL CONTENT
   ---------------------------------------------------------- */
.cl-content-section {
  padding: var(--sp-9) 0;
  border-bottom: 1px solid var(--cl-border);
}

.cl-content-section h2 {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--cl-ink);
  margin: 0 0 var(--sp-3);
  line-height: 1.2;
}

.cl-content-section h3 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--cl-ink);
  margin: var(--sp-4) 0 var(--sp-2);
  line-height: 1.3;
}

.cl-content-section p {
  font-size: 1rem;
  color: var(--cl-ink);
  line-height: 1.7;
  margin-bottom: var(--sp-2);
}

.cl-content-section ul,
.cl-content-section ol {
  margin: var(--sp-2) 0;
  padding-left: var(--sp-4);
}

.cl-content-section li {
  margin-bottom: var(--sp-1);
  font-size: 1rem;
  color: var(--cl-ink);
  line-height: 1.65;
}

.cl-content-section strong {
  font-weight: 600;
  color: var(--cl-ink);
}

/* Step cards */
.cl-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: var(--sp-3);
  margin: var(--sp-4) 0;
}

.cl-step {
  background: var(--cl-bg-card);
  border-radius: var(--cl-radius-sm);
  border: 1px solid var(--cl-border);
  padding: var(--sp-3);
  text-align: center;
}

.cl-step__num {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--cl-accent-bg);
  color: var(--cl-accent);
  font-size: 1.125rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto var(--sp-2);
}

.cl-step h4 {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--cl-ink);
  margin-bottom: 8px;
}

.cl-step p {
  font-size: 0.875rem;
  color: var(--cl-ink-muted);
  margin: 0;
  line-height: 1.55;
}

/* ----------------------------------------------------------
   19. RESPONSIVE — Tablet 720–1023px
   ---------------------------------------------------------- */
@media (max-width: 1023px) {
  .cl-page {
    font-size: 16px;
    line-height: 1.6;
  }

  .cl-hero__title {
    font-size: clamp(1.75rem, 4vw, 2.25rem);
  }

  .cl-trust__grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .cl-ranking__row {
    grid-template-columns: 64px 1fr auto;
    grid-template-rows: auto auto;
  }

  .cl-ranking__logo {
    grid-row: 1;
    grid-column: 2;
    border-left: none;
    border-bottom: 1px solid var(--cl-border);
    justify-content: flex-start;
    padding-left: var(--sp-2);
    height: auto;
    padding-top: var(--sp-2);
  }

  .cl-ranking__rank {
    grid-row: 1 / 3;
    grid-column: 1;
    border-right: 1px solid var(--cl-border);
  }

  .cl-ranking__info {
    grid-row: 2;
    grid-column: 2;
    border-left: none;
    padding-top: var(--sp-1);
  }

  .cl-ranking__cta {
    grid-row: 1 / 3;
    grid-column: 3;
    border-left: 1px solid var(--cl-border);
  }

  .cl-author-card {
    gap: var(--sp-3);
  }

  .cl-author-card__photo {
    width: 96px;
    height: 96px;
  }
}

/* ----------------------------------------------------------
   20. RESPONSIVE — Mobile <720px
   ---------------------------------------------------------- */
@media (max-width: 719px) {
  .cl-page {
    font-size: 16px;
    line-height: 1.55;
  }

  .cl-section {
    padding: var(--sp-6) 0;
  }

  .cl-hero {
    padding: var(--sp-4) 0 var(--sp-3);
  }

  .cl-hero__title {
    font-size: 1.625rem;
    letter-spacing: -0.015em;
  }

  .cl-hero__deck {
    font-size: 1rem;
  }

  .cl-byline {
    gap: var(--sp-1);
  }

  .cl-byline__photo {
    width: 48px;
    height: 48px;
  }

  .cl-byline__date {
    margin-left: 0;
    width: 100%;
    margin-top: 4px;
  }

  /* Ranking: single column */
  .cl-ranking {
    padding: var(--sp-4) 0;
  }

  .cl-ranking__row {
    grid-template-columns: 1fr;
    grid-template-rows: auto;
    text-align: center;
  }

  .cl-ranking__rank {
    padding: var(--sp-2);
    border-right: none;
    border-bottom: 1px solid var(--cl-border);
    flex-direction: row;
    justify-content: center;
  }

  .cl-ranking__logo {
    border-left: none;
    border-bottom: 1px solid var(--cl-border);
    padding: var(--sp-2);
    justify-content: center;
  }

  .cl-ranking__info {
    border-left: none;
    border-bottom: 1px solid var(--cl-border);
    padding: var(--sp-2);
    text-align: center;
  }

  .cl-ranking__cta {
    border-left: none;
    padding: var(--sp-2);
  }

  .cl-ranking__row--editor-pick::before {
    font-size: 0.5rem;
    padding: 3px 8px;
  }

  /* Trust strip */
  .cl-trust__grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-2);
  }

  /* Pros/cons */
  .cl-pros-cons {
    grid-template-columns: 1fr;
    gap: var(--sp-2);
  }

  /* Review */
  .cl-review {
    padding: var(--sp-3);
  }

  .cl-review__head {
    flex-direction: column;
    gap: var(--sp-2);
  }

  .cl-review__head-cta {
    margin-left: 0;
    width: 100%;
  }

  .cl-review__head-cta .cl-cta {
    width: 100%;
  }

  /* Author card */
  .cl-author-card {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .cl-author-card__photo {
    width: 120px;
    height: 120px;
  }

  /* Section headings */
  .cl-section__heading,
  .cl-content-section h2,
  .cl-ranking__title {
    font-size: 1.375rem;
  }

  /* Mini grid */
  .cl-ranking__mini-grid {
    grid-template-columns: 1fr;
  }

  /* Methodology */
  .cl-methodology__grid {
    grid-template-columns: 1fr;
  }

  /* Steps */
  .cl-steps {
    grid-template-columns: 1fr;
  }

  /* Table */
  .cl-table td,
  .cl-table th {
    padding: 10px 12px;
    font-size: 0.8125rem;
  }
}
