/* ============================================================
   Casino Review V2 — design preview, iteration 3
   Site-native language: full-bleed hero band, site grid (.container),
   glossy .btn buttons, Bebas/Montserrat, navy + electric blue + glow green.
   New layout: sticky section nav + two-column body with conversion rail.
   All classes prefixed .crv- to avoid collisions with main.css.
   ============================================================ */

.crv {
  --crv-navy-950: #090d0f;
  --crv-navy-900: #001f5a;
  --crv-navy-800: #0a2455;
  --crv-navy-700: #0d2f6e;
  --crv-blue: var(--primary-blue, #1480ff);
  --crv-blue-dark: var(--primary-dark-blue, #005cc7);
  --crv-green: var(--secondary-glow-green, #61f400);
  --crv-green-deep: #3f9e02;
  --crv-ink: var(--text-primary, #102e65);
  --crv-ink-soft: var(--text-secondary, #485877);
  --crv-line: #d7deea;
  --crv-paper: #fff;
  --crv-soft: var(--background-secondary, #e1e5eb);
  --crv-gold: #f5a623;
  --crv-red: #d64545;
  --crv-font-display: var(--font-family, "Bebas Neue", sans-serif);
  --crv-font-body: var(--second-family, "Montserrat", sans-serif);

  font-family: var(--crv-font-body);
  color: var(--crv-ink);
  overflow-x: clip;            /* contain the full-bleed games band — no horizontal scroll */
}

.crv *,
.crv *::before,
.crv *::after { box-sizing: border-box; }

/* mobile guard — desktop-only preview; shown only on small screens */
.crv-mobile-guard { display: none; }
@media (max-width: 768px) {
  .crv > *:not(.crv-mobile-guard) { display: none !important; }
  .crv-mobile-guard {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 70vh;
    padding: 48px 22px;
  }
  .crv-mobile-guard__card {
    max-width: 380px;
    text-align: center;
    padding: 36px 28px;
    border-radius: 20px;
    background: linear-gradient(180deg, #001f5a 0%, #090d0f 100%);
    color: #fff;
    box-shadow: 0 24px 50px -24px rgba(16, 46, 101, 0.5);
  }
  .crv-mobile-guard__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    margin-bottom: 18px;
    border-radius: 16px;
    background: rgba(20, 128, 255, 0.16);
    color: var(--crv-green, #61f400);
  }
  .crv-mobile-guard__icon svg { width: 30px; height: 30px; }
  .crv-mobile-guard h2 {
    font-family: var(--crv-font-display, "Bebas Neue", sans-serif);
    font-weight: 400;
    font-size: 30px;
    letter-spacing: 0.01em;
    margin: 0 0 10px;
    color: #fff;
  }
  .crv-mobile-guard p {
    font-size: 14.5px;
    line-height: 1.6;
    color: rgba(240, 242, 245, 0.7);
    margin: 0;
  }
}

/* ============================================================
   HERO — full-bleed band, site pattern (under transparent header)
   ============================================================ */

.crv-hero {
  background:
    radial-gradient(1100px 540px at 78% -10%, rgba(20, 128, 255, 0.38), transparent 62%),
    radial-gradient(720px 420px at 12% 108%, rgba(97, 244, 0, 0.10), transparent 60%),
    linear-gradient(180deg, #001f5a 0%, #090d0f 100%);
  margin-top: -92px;
  padding-top: 150px;
  padding-bottom: 56px;
  border-bottom-left-radius: 24px;
  border-bottom-right-radius: 24px;
  color: var(--text-light-primary, #f0f2f5);
  position: relative;
  overflow: hidden;
}

.crv-hero .container { position: relative; z-index: 1; }

.crv-crumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  font-size: 13px;
  font-weight: 600;
  color: rgba(240, 242, 245, 0.55);
  margin-bottom: 26px;
}
.crv-crumbs a { color: rgba(240, 242, 245, 0.55); text-decoration: none; transition: color var(--time, 0.3s); }
.crv-crumbs a:hover { color: #fff; }
.crv-crumbs strong { color: rgba(240, 242, 245, 0.9); font-weight: 600; }


/* --- hero layout --- */

.crv-hero__grid {
  display: grid;
  grid-template-columns: 496px minmax(0, 1fr);
  gap: 56px;
  align-items: center;
}

/* bonuses left, identity right (DOM keeps identity first for mobile) */
.crv-hero__id { grid-column: 2; grid-row: 1; }
.crv-ticketwrap { grid-column: 1; grid-row: 1; }

.crv-hero__idrow {
  display: flex;
  gap: 26px;
  align-items: center;
  margin-bottom: 22px;
}

.crv-hero__logo {
  flex: 0 0 auto;
  min-width: 104px;
  height: 104px;
  padding: 0 18px;
  border-radius: 22px;
  background: #fff;
  display: grid;
  place-items: center;
  font-family: var(--crv-font-display);
  font-size: 36px;
  color: var(--crv-navy-900);
  letter-spacing: 0.04em;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.25),
    0 0 54px rgba(97, 244, 0, 0.22),
    0 20px 44px -18px rgba(0, 0, 0, 0.65);
}
.crv-hero__logo img {
  display: block;
  max-height: 68px;
  max-width: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}
.crv-hero__logo--transparent {
  background: rgba(255, 255, 255, 0.06);
  color: #fff;
  backdrop-filter: blur(6px);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.12),
    0 20px 44px -18px rgba(0, 0, 0, 0.65);
}

.crv-hero__title {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 64px;
  line-height: 0.95;
  letter-spacing: 0.01em;
  margin: 0 0 12px;
  color: #fff;
}

.crv-chiprow { display: flex; flex-wrap: wrap; gap: 10px; }

/* ===== Region mini-switcher at the bottom of the bonus ticket ===========
   Small flag + country pills under the T&C note. Subtle, not competing with
   the bonus value. Active state: thin green border, no glow. */
.crv-ticket__regions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 6px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.crv-ticket__region {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 9px 5px 7px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1;
  transition: color .15s ease, border-color .15s ease, background .15s ease;
}
.crv-ticket__region:hover {
  color: rgba(255, 255, 255, 0.92);
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.03);
}
.crv-ticket__region.is-active {
  color: #f4fff0;
  border-color: rgba(97, 244, 0, 0.45);
  background: rgba(97, 244, 0, 0.07);
}
.crv-ticket__region-flag {
  display: inline-block;
  width: 14px;
  height: 10px;
  border-radius: 2px;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.3);
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
}

.crv-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 15px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.06);
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.92);
}
.crv-chip svg { width: 15px; height: 15px; color: var(--crv-green); flex: 0 0 auto; }

/* expert opinion block: author head + verdict teaser as one quote */
.crv-hero__expert {
  margin-top: 30px;
  max-width: 640px;
  padding-left: 20px;
  border-left: 1px solid rgba(255, 255, 255, 0.25);
}

.crv-hero__expert-head {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-bottom: 14px;
}

.crv-hero__expert-ava {
  position: relative;
  flex: 0 0 auto;
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-family: var(--crv-font-display);
  font-size: 17px;
  color: #fff;
  background: linear-gradient(150deg, var(--crv-blue), var(--crv-navy-700));
  box-shadow: 0 0 0 2.5px var(--crv-green);
  overflow: hidden;
}
.crv-hero__expert-ava > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.crv-verdict__ava { overflow: hidden; }
.crv-verdict__ava > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.crv-hero__expert-check {
  position: absolute;
  top: -5px;
  right: -7px;
  width: 20px;
  height: 20px;
}
.crv-hero__expert-check svg { width: 100%; height: 100%; display: block; }

.crv-hero__expert-meta { font-size: 13.5px; line-height: 1.4; }
.crv-hero__expert-meta b { font-size: 15px; font-weight: 800; color: #fff; }
.crv-hero__expert-meta span { color: rgba(240, 242, 245, 0.65); }
.crv-hero__expert-meta em {
  display: block;
  font-style: normal;
  margin-top: 3px;
  font-size: 12px;
  color: rgba(240, 242, 245, 0.5);
}

.crv-hero__verdictline {
  font-size: 16.5px;
  line-height: 1.65;
  color: rgba(240, 242, 245, 0.82);
  margin: 0;
}
.crv-hero__verdictline b { color: #fff; }

/* ghost button — secondary action, leads to the full review */
.crv-btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
  padding: 13px 28px 11px;
  border: 1.5px solid rgba(255, 255, 255, 0.28);
  border-radius: 12px;
  font-family: var(--crv-font-display);
  font-size: 19px;
  letter-spacing: 0.05em;
  color: #fff;
  text-decoration: none;
  transition: all var(--time, 0.3s) ease;
}
.crv-btn-ghost svg { width: 17px; height: 17px; margin-top: -3px; transition: transform var(--time, 0.3s); }
.crv-btn-ghost:hover {
  border-color: var(--crv-green);
  color: var(--crv-green);
  background: rgba(97, 244, 0, 0.06);
}
.crv-btn-ghost:hover svg { transform: translateY(3px); }

/* --- data strip (full hero width) --- */

.crv-strip {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1.25fr repeat(4, 1fr) 1.4fr;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.045);
  backdrop-filter: blur(6px);
  overflow: hidden;
}

.crv-strip__cell {
  padding: 20px 24px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  position: relative;
}
.crv-strip__cell + .crv-strip__cell { border-left: 1px solid rgba(255, 255, 255, 0.1); }
.crv-strip__cell > b {
  font-family: var(--crv-font-display);
  font-size: 30px;
  font-weight: 400;
  line-height: 1;
  color: #fff;
}
.crv-strip__cell > span {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(240, 242, 245, 0.55);
}

/* score cell with ring */
.crv-strip__score {
  flex-direction: row;
  align-items: center;
  gap: 16px;
  background: linear-gradient(135deg, rgba(97, 244, 0, 0.12), transparent 70%);
}
.crv-gauge { position: relative; width: 80px; height: 66px; flex: 0 0 auto; }
.crv-gauge svg { width: 100%; height: 100%; display: block; overflow: visible; }
.crv-gauge [data-gauge] {
  transition: stroke-dasharray 1.3s cubic-bezier(0.22, 0.61, 0.36, 1) 0.25s;
}
.crv-gauge__val {
  position: absolute;
  inset: 12px 0 0;
  display: grid;
  place-content: center;
  font-family: var(--crv-font-display);
  font-size: 26px;
  color: #fff;
}
.crv-strip__scoretxt .reviews-slider__stars { margin: 0 0 7px; }
.crv-strip__scoretxt span { font-size: 11px; color: rgba(240, 242, 245, 0.6); }

/* payments cell — same white logo plates as the casino top-list */
.crv-strip__pay { gap: 9px; }
.crv-strip__paylogos { flex-wrap: wrap; }
.crv-strip__paylogos .top-list__item-payments-logo { overflow: hidden; }
.crv-strip__paylogos .top-list__item-payments-logo img {
  object-fit: contain;
  padding: 4px;
}
.crv-strip__paylogos .top-list__item-payments-logo a {
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform var(--time, 0.3s);
}
.crv-strip__paylogos .top-list__item-payments-logo a:hover { transform: scale(1.08); }

/* rail mini chips (kept for the sticky offer card) */
.crv-paychip {
  font-size: 11.5px;
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
  padding: 4px 9px;
  border-radius: 7px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.05);
}

/* --- bonus offer panel (hero left) --- */

.crv-ticket {
  position: relative;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    radial-gradient(420px 240px at 80% -10%, rgba(20, 128, 255, 0.28), transparent 65%),
    linear-gradient(160deg, rgba(13, 47, 110, 0.85), rgba(4, 16, 40, 0.92));
  box-shadow: 0 30px 60px -30px rgba(0, 0, 0, 0.7);
  padding: 30px 34px 26px;
}

.crv-ticket__top {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 18px;
}
.crv-ticket__kicker {
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: var(--crv-green);
}
.crv-ticket__tc { font-size: 12px; color: rgba(240, 242, 245, 0.5); }

.crv-ticket__deplabel {
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 6px;
}

.crv-ticket__amount {
  font-family: var(--crv-font-display);
  font-size: 44px;
  line-height: 1.02;
  letter-spacing: 0.015em;
  color: #fff;
  margin: 0;
}
.crv-ticket__amount em {
  font-style: normal;
  color: var(--crv-green);
  text-shadow: 0 0 26px rgba(97, 244, 0, 0.45);
}
.crv-ticket__fs { font-size: 16px; font-weight: 700; color: rgba(240, 242, 245, 0.92); margin-top: 8px; }

.crv-ticket__rows { margin-top: 18px; border-top: 1px solid rgba(255, 255, 255, 0.12); }
.crv-ticket__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 13px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.crv-ticket__row span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.72);
}
.crv-ticket__row b {
  font-family: var(--crv-font-display);
  font-size: 24px;
  font-weight: 400;
  letter-spacing: 0.03em;
  color: #fff;
  white-space: nowrap;
}
.crv-ticket__row b em {
  font-style: normal;
  color: var(--crv-green);
  margin-right: 2px;
}

.crv-ticket__cta { margin-top: 22px; }
.crv-ticket__cta .btn { width: 100%; height: 52px; }
.crv-ticket__cta .btn svg { width: 20px; height: 20px; margin-right: 11px; margin-top: -3px; }
.crv-ticket__note {
  margin-top: 12px;
  text-align: center;
  font-size: 11.5px;
  letter-spacing: 0.04em;
  color: rgba(240, 242, 245, 0.45);
}
.crv-ticket__more {
  display: block;
  text-align: center;
  margin-top: 14px;
  font-size: 13px;
  font-weight: 600;
  color: rgba(240, 242, 245, 0.6);
  text-decoration: none;
  transition: color var(--time, 0.3s);
}
.crv-ticket__more:hover { color: #fff; text-decoration: underline; }

/* ============================================================
   GREEN GLOSSY BUTTON — same two-layer build as site .btn
   ============================================================ */

.crv-btn-green {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 22px;
  line-height: 100%;
  letter-spacing: 0.02em;
  text-align: center;
  color: #fff;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  background: linear-gradient(180deg, #7dff2e 0%, #3f9e02 100%);
  border-radius: 12px;
  padding: 3px;
  height: 52px;
  width: 100%;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25), 0 10px 34px -8px rgba(97, 244, 0, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--time, 0.3s) ease;
  cursor: pointer;
  text-decoration: none;
  border: 0;
}
.crv-btn-green > span {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 2px 16px 0;
  border-radius: 10px;
  white-space: nowrap;
  background: linear-gradient(180deg, #46b005 0%, #71f418 100%);
  transition: all var(--time, 0.3s) ease;
}
.crv-btn-green svg { width: 20px; height: 20px; margin-top: -2px; }
.crv-btn-green:hover {
  background: linear-gradient(180deg, #3f9e02 0%, #7dff2e 100%);
  box-shadow: inset 0 4px 4px rgba(0, 0, 0, 0.2), 0 10px 38px -8px rgba(97, 244, 0, 0.6);
}
.crv-btn-green:active { box-shadow: inset 0 4px 7px 1px rgba(0, 0, 0, 0.35); }

/* ============================================================
   STICKY SECTION NAV (scrollspy)
   ============================================================ */

.crv-nav {
  position: sticky;
  top: 10px;
  z-index: 50;
  margin: 26px auto 0;
}
/* desktop header is fixed (~92px) — stick the nav just below it, not under */
@media (min-width: 1201px) {
  .crv-nav { top: 100px; }
}
.crv-nav__in {
  display: flex;
  gap: 6px;
  padding: 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(16, 46, 101, 0.08);
  box-shadow: 0 12px 34px -16px rgba(16, 46, 101, 0.35);
  overflow-x: auto;
  scrollbar-width: none;
}
.crv-nav__in::-webkit-scrollbar { display: none; }

.crv-nav a {
  flex: 0 0 auto;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--crv-ink-soft);
  text-decoration: none;
  padding: 9px 18px;
  border-radius: 999px;
  transition: all var(--time, 0.3s);
  white-space: nowrap;
}
.crv-nav a:hover { color: var(--crv-blue); background: rgba(20, 128, 255, 0.08); }
.crv-nav a.is-active {
  color: #fff;
  background: linear-gradient(180deg, var(--crv-blue), var(--crv-blue-dark));
  box-shadow: 0 6px 16px -6px rgba(20, 128, 255, 0.7);
}

/* ============================================================
   BODY — full-width content; sticky conversion lives in the bottom bar
   ============================================================ */

.crv-body { margin-top: 44px; }

.crv-main {
  display: flex;
  flex-direction: column;
  gap: 30px;
  min-width: 0;
}

.crv-section { scroll-margin-top: 92px; }
/* clear the fixed header + sticky nav when jumping to a section */
@media (min-width: 1201px) {
  .crv-section { scroll-margin-top: 176px; }
}

/* card-internal section title (prototype style) */
.crv-cardtitle {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 27px;
  line-height: 1;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--crv-ink);
  margin: 0 0 24px;
}

.crv-card {
  background: var(--crv-paper);
  border-radius: 24px;
  box-shadow: 0 16px 44px -24px rgba(16, 46, 101, 0.22);
  padding: 40px 44px;
}

/* reveal */
.crv-reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.7s ease, transform 0.7s cubic-bezier(0.22, 0.61, 0.36, 1); }
.crv-reveal.is-in { opacity: 1; transform: none; }

/* ============================================================
   01 EXPERT VERDICT
   ============================================================ */

/* the main review reads like a calm editorial article — trust comes
   from typography, not decoration */
.crv-expert__title {
  font-size: 23px;
  font-weight: 700;
  line-height: 1.35;
  margin: 0 0 18px;
  color: var(--crv-ink);
}

.crv-expert__body p {
  font-size: 17px;
  line-height: 1.8;
  color: var(--crv-ink-soft);
  margin: 0 0 18px;
}

/* author header — same identity pattern as the hero expert block */
.crv-verdict__author {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--crv-line);
}
.crv-verdict__ava {
  position: relative;
  flex: 0 0 auto;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 800;
  color: #fff;
  background: linear-gradient(180deg, #1480ff 0%, #005cc7 100%);
  box-shadow: 0 6px 14px -6px rgba(20, 128, 255, 0.6);
}
.crv-verdict__check {
  position: absolute;
  right: -4px;
  bottom: -4px;
  width: 21px;
  height: 21px;
}
.crv-verdict__check svg { width: 100%; height: 100%; display: block; }
.crv-verdict__who { display: flex; flex-direction: column; gap: 3px; }
.crv-verdict__who b { font-size: 16px; color: var(--crv-ink); }
.crv-verdict__who span { font-size: 13px; font-weight: 500; color: var(--crv-ink-soft); }
.crv-verdict__date {
  margin-left: auto;
  font-size: 12px;
  font-weight: 600;
  color: var(--crv-ink-soft);
  background: var(--background-primary, #f0f2f5);
  border: 1px solid var(--crv-line);
  padding: 7px 13px;
  border-radius: 999px;
  white-space: nowrap;
}


/* comments — production component (partials/rating-block); item styles come
   from style-reviews.css, the quick-comment styles below are copied from the
   component's inline push (the real include brings them along on prod) */
.crv-comments { margin-top: 34px; padding-top: 30px; border-top: 1px solid var(--crv-line); }
.crv-comments .section__reviews__list { margin-bottom: 0; }
.crv-comments .section__reviews__list > h4 {
  font-size: 17px;
  font-weight: 800;
  color: var(--crv-ink);
  margin: 0 0 20px;
}

/* review items as white cards on the gray panel */
.crv-comments .review__item {
  background: #fff;
  border: 1px solid rgba(16, 46, 101, 0.09);
  border-radius: 16px;
  padding: 18px 18px 14px 86px;
  margin-bottom: 12px;
}
.crv-comments .review__item .review__user { top: 18px; left: 18px; }
.crv-comments .review__item .review__user .review__avatar-initials {
  background: linear-gradient(180deg, #1480ff 0%, #005cc7 100%);
}
.crv-comments .review__item .reviews-slider__stars { margin-bottom: 7px; }

@media (max-width: 720px) {
  .crv-verdict__date { display: none; }
  .crv-comments .review__item { padding: 16px 14px 12px 76px; }
  .crv-comments .review__item .review__user { top: 16px; left: 14px; }
}

.quick-comment { margin-top: 24px; padding-top: 24px; border-top: 1px solid #e7ecf3; }
.quick-comment__head { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.quick-comment__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: #eaf2ff;
  color: #1480ff;
}
.quick-comment__title { margin: 0; line-height: 1; font-size: 16px; font-weight: 800; color: var(--crv-ink); }
.quick-comment__box { width: 100%; }
.quick-comment__textarea {
  width: 100%;
  min-height: 120px;
  padding: 16px 18px;
  border: 1.5px solid #e1e6ef;
  border-radius: 12px;
  font: inherit;
  font-size: 15px;
  line-height: 1.55;
  color: #0b1f44;
  resize: vertical;
  background: #f8fafd;
  transition: border-color 0.18s, background 0.18s, box-shadow 0.18s;
  box-sizing: border-box;
  outline: none;
}
.quick-comment__textarea::placeholder { color: #8c96ab; }
.quick-comment__textarea:hover { border-color: #cfd6e3; }
.quick-comment__textarea:focus {
  border-color: #1480ff;
  background: #fff;
  box-shadow: 0 0 0 4px rgba(20, 128, 255, 0.12);
}
.quick-comment__bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.quick-comment__hint { flex: 1; font-size: 13px; color: #e23434; min-height: 18px; }
.quick-comment__send {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #1480ff;
  color: #fff;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 14px;
  padding: 14px 28px;
  border: 0;
  border-radius: 12px;
  cursor: pointer;
  transition: background 0.18s, transform 0.08s, box-shadow 0.18s;
  box-shadow: 0 4px 12px rgba(20, 128, 255, 0.25);
}
.quick-comment__send:hover { background: #0d6cf0; box-shadow: 0 6px 16px rgba(20, 128, 255, 0.32); }
.quick-comment__send:active { transform: translateY(1px); }
.quick-comment__send svg { display: block; }

/* ============================================================
   02 CASINO PASSPORT
   ============================================================ */

.crv-passport { position: relative; }

.crv-passport__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 36px;
  margin-top: 6px;
}

.crv-passcol__title {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 15.5px;
  font-weight: 800;
  color: var(--crv-ink);
  margin-bottom: 6px;
}
.crv-passcol__title svg { width: 18px; height: 18px; color: var(--crv-blue); }

.crv-passcol dl { margin: 0; }
.crv-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 14px;
  padding: 11px 0;
  border-bottom: 1px solid var(--crv-line);
  font-size: 13.5px;
}
.crv-row:last-child { border-bottom: 0; }
.crv-row dt { color: var(--crv-ink-soft); }
.crv-row dd { margin: 0; font-weight: 700; color: var(--crv-ink); text-align: right; }
.crv-yes { color: var(--crv-green-deep); }

/* ============================================================
   03 PROS / CONS / SCORES
   ============================================================ */

/* 3x2 grid: pros|cons + license|security on the left, tall ratings card right */
.crv-sheet {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
}
.crv-sheet .crv-card { padding: 32px 34px; }

.crv-ledger__head {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 16px;
}
.crv-ledger__head i {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.crv-ledger__head i svg { width: 16px; height: 16px; }
.crv-ledger__head--pros i { background: rgba(97, 244, 0, 0.16); color: var(--crv-green-deep); }
.crv-ledger__head--cons i { background: rgba(214, 69, 69, 0.12); color: var(--crv-red); }
.crv-ledger__head--scores i { background: rgba(20, 128, 255, 0.12); color: var(--crv-blue); }
.crv-ledger__head h3 {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 24px;
  letter-spacing: 0.05em;
  margin: 0;
  color: var(--crv-ink);
}

.crv-list { list-style: none; margin: 0; padding: 0; }
.crv-list li {
  display: flex;
  gap: 11px;
  align-items: flex-start;
  padding: 10px 0;
  border-bottom: 1px solid var(--crv-line);
  font-size: 14px;
  line-height: 1.55;
  color: var(--crv-ink-soft);
}
.crv-list li:last-child { border-bottom: 0; }
.crv-list li b { color: var(--crv-ink); }
.crv-list__mark { flex: 0 0 auto; font-weight: 800; font-size: 15px; line-height: 1.45; }
.crv-list--pros .crv-list__mark { color: var(--crv-green-deep); }
.crv-list--cons .crv-list__mark { color: var(--crv-red); }

/* merged ratings card: expert criteria stacked above player reviews */
.crv-ratings {
  grid-column: 3;
  grid-row: 1 / span 2;
  display: flex;
  flex-direction: column;
}

.crv-ratings__crits { flex: 1; }
.crv-crit {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 14px;
  padding: 11px 0;
  border-bottom: 1px solid var(--crv-line);
}
.crv-crit:last-child { border-bottom: 0; }
.crv-crit > span { font-size: 14px; color: var(--crv-ink-soft); }
.crv-crit__val { display: flex; align-items: center; gap: 10px; }
.crv-crit__val .reviews-slider__stars { margin: 0; }
.crv-crit__val b { font-size: 14.5px; color: var(--crv-ink); min-width: 26px; text-align: right; }

.crv-ratings__overall { text-align: center; }
.crv-ratings .crv-ledger__head--scores {
  margin-top: 22px;
  padding-top: 22px;
  border-top: 1px solid var(--crv-line);
}
.crv-ratings__overall .crv-trust__head { justify-content: flex-start; margin-bottom: 18px; }

/* prod score circle (style copied from style-reviews.css .score) */
.crv-score-circle {
  position: relative;
  width: 180px;
  height: 180px;
  margin: 0 auto;
  border-radius: 50%;
  background: #e1e5eb;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}
.crv-score-circle__val { position: absolute; top: 10px; left: 10px; }
.crv-score-circle__rt { position: relative; z-index: 4; }
.crv-score-circle__num {
  font-family: var(--crv-font-display);
  font-size: 62px;
  line-height: 1;
  color: #102e65;
}
.crv-score-circle__note {
  font-size: 12px;
  font-weight: 700;
  font-family: var(--crv-font-body);
  color: #102e65;
  margin-top: -2px;
}

.crv-ratings__overall .crv-bigscore__sub { margin: 14px 0 0; }
.crv-submit-rating {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 16px auto 18px;
  padding: 14px 28px;
  background: linear-gradient(180deg, #1F8DFF 0%, #0B6BE6 100%);
  color: #fff;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  font-size: 14px;
  border-radius: 12px;
  box-shadow: 0 6px 18px rgba(20,128,255,.32);
  transition: transform .08s ease, box-shadow .18s ease, background .18s ease;
}
.crv-submit-rating:hover { background: linear-gradient(180deg, #2E97FF 0%, #0F73EF 100%); box-shadow: 0 8px 22px rgba(20,128,255,.4); color:#fff; }
.crv-submit-rating:active { transform: translateY(1px); }
.crv-submit-rating svg { width: 14px; height: 20px; }

/* ============================================================
   04 TRUST & SAFETY
   ============================================================ */

.crv-card--trust { padding: 28px 30px; }

.crv-trust__head {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.crv-trust__head svg { width: 19px; height: 19px; color: var(--crv-blue); flex: 0 0 auto; }
.crv-trust__head h3 {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 21px;
  letter-spacing: 0.05em;
  margin: 0;
  color: var(--crv-ink);
}
.crv-card--trust .crv-row { font-size: 13.5px; padding: 10px 0; }

.crv-bigscore { text-align: center; padding-top: 4px; }
.crv-bigscore__val { font-family: var(--crv-font-display); font-size: 56px; line-height: 1; color: var(--crv-gold); }
.crv-bigscore__sub { font-size: 12.5px; color: var(--crv-ink-soft); margin: 7px 0 12px; }

.crv-extlink {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin-top: 16px;
  width: 100%;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1.5px solid var(--crv-line);
  background: var(--background-primary, #f0f2f5);
  font-size: 13px;
  font-weight: 700;
  color: var(--crv-ink);
  text-decoration: none;
  transition: border-color var(--time, 0.3s), color var(--time, 0.3s);
}
.crv-extlink svg { width: 14px; height: 14px; }
.crv-extlink:hover { border-color: var(--crv-blue); color: var(--crv-blue); }

/* ============================================================
   05 GAMES
   ============================================================ */

/* dark "Games Overview" panel; the game cards straddle its bottom edge to
   break up the page on scroll */
/* override .crv-section's overflow:hidden so the band can bleed past the column */
.crv-gov { position: relative; overflow: visible; }
/* near-full-width rounded band with 24px side gutters, like the homepage slots block */
.crv-gov__panel {
  position: relative;
  margin-left: calc(50% - 50vw + 24px);
  margin-right: calc(50% - 50vw + 24px);
  border-radius: 24px;
  padding: 36px 0 150px;
  color: #fff;
  overflow: hidden;
  background: linear-gradient(180deg, #001f5a 0%, #090d0f 100%);
}
.crv-gov__inner { max-width: 1372px; margin: 0 auto; padding: 0 30px; }
.crv-gov__panel > * { position: relative; z-index: 1; }
.crv-gov .crv-cardtitle { color: #fff; }

/* counters, providers, labels recoloured for the dark panel */
.crv-gov .crv-counters { border-color: rgba(255, 255, 255, 0.14); background: rgba(255, 255, 255, 0.04); }
.crv-gov .crv-counter { background: transparent; }
.crv-gov .crv-counter + .crv-counter { border-left-color: rgba(255, 255, 255, 0.1); }
.crv-gov .crv-counter b { color: #fff; }
.crv-gov .crv-counter span { color: rgba(240, 242, 245, 0.55); }
.crv-gov .crv-sublabel { color: rgba(240, 242, 245, 0.6); }
.crv-gov .crv-provider {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.16);
  color: rgba(255, 255, 255, 0.9);
}
.crv-gov .crv-providers__more { color: rgba(240, 242, 245, 0.6); }
.crv-gov__gameslabel { margin-bottom: 0; }

/* the cards overlap the panel's bottom edge: top half on the dark, bottom on the page */
.crv-gov .crv-games {
  position: relative;
  z-index: 2;
  margin-top: -150px;
}
.crv-gov .crv-game { box-shadow: 0 22px 44px -22px rgba(4, 14, 40, 0.6); }

.crv-counters {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border: 1px solid var(--crv-line);
  border-radius: 18px;
  overflow: hidden;
  margin-bottom: 30px;
}
.crv-counter { text-align: center; padding: 18px 10px 16px; background: #fff; }
.crv-counter + .crv-counter { border-left: 1px solid var(--crv-line); }
.crv-counter b {
  display: block;
  font-family: var(--crv-font-display);
  font-size: 32px;
  font-weight: 400;
  line-height: 1;
  color: var(--crv-ink);
}
.crv-counter b em { font-style: normal; color: var(--crv-green-deep); }
.crv-counter span {
  display: block;
  margin-top: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--crv-ink-soft);
}

.crv-sublabel {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--crv-ink-soft);
  margin: 0 0 14px;
}

.crv-providers { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; margin-bottom: 30px; }
.crv-provider {
  font-size: 13px;
  font-weight: 600;
  padding: 7px 14px;
  border-radius: 9px;
  background: var(--background-primary, #f0f2f5);
  border: 1px solid var(--crv-line);
  color: var(--crv-ink-soft);
}
.crv-providers__more { font-size: 13px; font-weight: 600; color: var(--crv-ink-soft); }

.crv-games { display: grid; grid-template-columns: repeat(5, 1fr); gap: 18px; }

/* one cohesive tile: cover + footer with a round play button */
.crv-game {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  background: #fff;
  border: 3px solid #fff;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 8px 20px -14px rgba(16, 46, 101, 0.3);
}

.crv-game__cover {
  position: relative;
  display: block;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
.crv-game__cover img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.crv-game__rtp {
  position: absolute;
  top: 9px;
  left: 9px;
  z-index: 2;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: var(--crv-green);
  background: rgba(4, 18, 46, 0.78);
  padding: 4px 9px;
  border-radius: 999px;
}
.crv-game__rtp--live { color: #6db8ff; }
.crv-game__rtp--live::before {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ff4d4d;
  margin-right: 5px;
  vertical-align: 1px;
}

.crv-game__foot {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px 12px 14px;
  flex: 1;
}
.crv-game__meta { min-width: 0; }
.crv-game__name {
  display: block;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--crv-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.crv-game__provider {
  display: block;
  margin-top: 2px;
  font-size: 11px;
  font-weight: 600;
  color: var(--crv-ink-soft);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* site .btn (main.css), compact size for the card footer */
.crv-game__play.btn {
  margin-top: auto;
  height: 38px;
  font-size: 16px;
  border-radius: 10px;
}
.crv-game__play.btn > span { padding: 1px 12px 0; border-radius: 8px; }

/* ============================================================
   06 HOW TO GET STARTED
   ============================================================ */

/* prod steps-box component (blocks/casino_how-to) inside the review page:
   4 steps on this page; the block itself uses 5 columns by default */
.crv-getstart { margin-top: 48px; margin-bottom: 16px; }
.crv-getstart .section-top { margin-bottom: 30px; }
.crv-getstart .steps-box { gap: 24px; }
.crv-getstart .steps-box__item { padding: 30px 28px 28px; }
/* main.css relies on the body Bebas inheritance — restore it inside .crv */
.crv .section-title,
.crv .steps-box__title,
.crv .steps-box__num,
.crv .seo-box__title,
.crv .open_seo { font-family: var(--crv-font-display); }
.crv-getstart .section-title { font-size: 44px; }
/* 5th tile of the steps row: dark CTA card */
.crv-stepcta {
  background:
    radial-gradient(160px 110px at 70% -10%, rgba(20, 128, 255, 0.45), transparent 70%),
    linear-gradient(170deg, var(--crv-navy-800), #04122e);
  padding-bottom: 24px;
}
.crv-stepcta .steps-box__title { color: #fff; }
.crv-stepcta .steps-box__text { color: rgba(240, 242, 245, 0.75); }
.crv-stepcta .crv-stepcta__btn {
  margin-top: auto;
  height: 46px;
  font-size: 18px;
  position: relative;
  z-index: 1;
}

/* SEO text — production component (blocks/category_seotext) at page bottom */
.crv-seo { margin-top: 48px; }

/* ============================================================
   07 FAQ
   ============================================================ */

/* prod faq-item component (main.css) inside the review column:
   reset .faq-box outer margins meant for the full-width .row layout */
.crv-faqsec { margin-top: 40px; }
.crv-faqsec .section-top { margin-bottom: 24px; }
.crv-faqsec .section-title { font-size: 44px; }
.crv-faqsec .faq-box {
  margin: 0 auto;
  width: 100%;
}

/* ============================================================
   FINAL CTA
   ============================================================ */

.crv-final {
  margin-top: 200px;
  position: relative;
  overflow: visible;
  border-radius: 24px;
  text-align: center;
  color: #fff;
  padding: 64px 40px 48px;
  background:
    radial-gradient(640px 320px at 50% -20%, rgba(20, 128, 255, 0.45), transparent 70%),
    radial-gradient(520px 300px at 50% 130%, rgba(97, 244, 0, 0.16), transparent 70%),
    linear-gradient(180deg, #001f5a 0%, #090d0f 100%);
}
.crv-final::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: 24px;
  background-image: radial-gradient(rgba(255, 255, 255, 0.07) 1px, transparent 1.5px);
  background-size: 26px 26px;
  mask-image: radial-gradient(70% 90% at 50% 50%, #000, transparent);
}
.crv-final > * { position: relative; z-index: 1; }

/* mascot peeks over the top edge, leaning in and pointing down at the offer */
.crv-final__mascot {
  position: absolute;
  left: 50%;
  top: -177px;
  transform: translateX(-50%);
  z-index: 3;
  width: auto;
  height: 230px;
  pointer-events: none;
  filter: drop-shadow(0 16px 26px rgba(0, 0, 0, 0.5));
}
.crv-final__kicker {
  display: inline-block;
  margin-bottom: 12px;
  padding: 7px 16px;
  border-radius: 999px;
  border: 1px solid rgba(97, 244, 0, 0.4);
  background: rgba(97, 244, 0, 0.08);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--crv-green);
}
.crv-final__title {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 52px;
  line-height: 1;
  letter-spacing: 0.015em;
  margin: 0 0 14px;
  color: #fff;
}
.crv-final__sub {
  font-size: 16.5px;
  line-height: 1.6;
  color: rgba(240, 242, 245, 0.8);
  max-width: 540px;
  margin: 0 auto 26px;
}
.crv-final__sub b { color: var(--crv-green); }

/* bonus as one cohesive bar (single object, segmented like the hero strip) */
.crv-final__offer {
  display: flex;
  width: 528px;
  max-width: 100%;
  align-items: stretch;
  margin: 0 auto 26px;
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.05);
  backdrop-filter: blur(6px);
  overflow: hidden;
}
.crv-final__seg {
  flex: 1 1 0;               /* always exactly one third — content can't change the width */
  min-width: 0;
  padding: 16px 12px;
  display: flex;
  flex-direction: column;
  gap: 5px;
  transition: background 0.4s ease;
}
.crv-final__seg + .crv-final__seg { border-left: 1px solid rgba(255, 255, 255, 0.12); }
.crv-final__seg b {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 34px;
  line-height: 1;
  color: #fff;
  transition: color 0.4s ease;
  /* fixed box so the canvas reel and the final text share one height (no layout shift) */
  height: 1.32em;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
/* slot-reel: while spinning, the number becomes a window onto a vertical strip of
   cells (standard slot technique). The strip's translateY is animated; cells inherit
   the exact font/size/colour from .crv-final__seg b above, so no measuring needed */
.crv-final__seg b.is-reel {
  display: block;          /* window: strip flows from the top, not flex-centred */
}
.crv-reel-strip {
  display: block;
  will-change: transform;
  font: inherit;        /* don't let .crv-final__seg span shrink the reel digits */
  color: inherit;
}
.crv-reel-cell {
  display: flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-shrink: 0;
  font: inherit;
  color: inherit;
}
/* the label — direct child only, so it never matches the reel cell spans inside <b> */
.crv-final__seg > span {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(240, 242, 245, 0.55);
}
.crv-final__seg--accent { background: rgba(97, 244, 0, 0.1); }
.crv-final__seg--accent b { color: var(--crv-green); }
/* while the reel spins, suppress the green so it only "lights up" once it lands */
.crv-final__seg--accent.is-spinning { background: transparent; }
.crv-final__seg.is-spinning b { color: #fff; }

.crv-final .crv-btn-green { width: auto; display: inline-flex; padding-left: 0; padding-right: 0; }
.crv-final .crv-btn-green > span { padding: 2px 52px 0; }

.crv-final__note { margin-top: 18px; font-size: 12px; letter-spacing: 0.04em; color: rgba(240, 242, 245, 0.45); }

.crv-bottompad { padding-bottom: 86px; }

/* ============================================================
   FLOATING BONUS WIDGET (desktop) — chip that expands on hover
   ============================================================ */

.crv-fab {
  position: fixed;
  right: 22px;
  bottom: 24px;
  z-index: 90;
  opacity: 0;
  transform: translateY(16px) scale(0.9);
  pointer-events: none;
  transition: opacity 0.4s ease, transform 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.crv-fab.is-on {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}

/* collapsed chip — levitating gift orb with rotating neon ring */
.crv-fab__mini {
  position: relative;
  width: 86px;
  height: 86px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  cursor: pointer;
  filter: drop-shadow(0 16px 30px rgba(4, 18, 46, 0.65));
  animation: crv-float 3.4s ease-in-out infinite;
  transition: opacity 0.25s ease, transform 0.25s ease;
}

/* comet canvas: a head dot orbits the orb scattering a particle trail */
.crv-fab__comet {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 150px;
  height: 150px;
  margin: -75px 0 0 -75px;
  pointer-events: none;
  z-index: 2; /* above the orb: the comet rides the rim, not behind it */
}
/* dark orb */
.crv-fab__mini::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  border-radius: 50%;
  border: 1px solid rgba(97, 244, 0, 0.22);
  background:
    radial-gradient(60px 40px at 50% 8%, rgba(97, 244, 0, 0.14), transparent 70%),
    linear-gradient(170deg, var(--crv-navy-800), #04122e);
}

.crv-fab__gift {
  position: relative;
  z-index: 3;
  width: 36px;
  height: 36px;
  transform-origin: 50% 85%;
  animation: crv-wiggle 4.6s ease-in-out infinite;
}

.crv-fab__badge {
  position: absolute;
  top: -7px;
  right: -9px;
  z-index: 3;
  font-family: var(--crv-font-display);
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0.03em;
  color: #06240b;
  padding: 5px 10px 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, #8aff3d, var(--crv-green) 60%, #4cc400);
  box-shadow: 0 0 18px rgba(97, 244, 0, 0.55), 0 4px 10px -3px rgba(0, 0, 0, 0.5);
  animation: crv-badgepulse 2.6s ease-in-out infinite;
}

/* twinkling sparks */
.crv-fab__spark { position: absolute; pointer-events: none; }
.crv-fab__spark::before {
  content: "✦";
  display: block;
  color: #fff;
  text-shadow: 0 0 8px rgba(255, 255, 255, 0.8);
  animation: crv-twinkle 2.8s ease-in-out infinite;
}
.crv-fab__spark--a { top: 4px; left: -8px; }
.crv-fab__spark--a::before { font-size: 11px; animation-delay: 0s; }
.crv-fab__spark--b { bottom: 2px; left: 10px; }
.crv-fab__spark--b::before { font-size: 8px; color: var(--crv-green); text-shadow: 0 0 8px rgba(97, 244, 0, 0.8); animation-delay: 0.9s; }
.crv-fab__spark--c { top: 26px; right: -11px; }
.crv-fab__spark--c::before { font-size: 9px; color: #9fd8ff; text-shadow: 0 0 8px rgba(65, 198, 255, 0.8); animation-delay: 1.8s; }

@keyframes crv-float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
@keyframes crv-wiggle {
  0%, 52%, 100% { transform: rotate(0deg); }
  58% { transform: rotate(-11deg) scale(1.06); }
  64% { transform: rotate(9deg) scale(1.06); }
  70% { transform: rotate(-6deg) scale(1.03); }
  76% { transform: rotate(3deg); }
  82% { transform: rotate(0deg); }
}
@keyframes crv-badgepulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.1); }
}
@keyframes crv-twinkle {
  0%, 100% { opacity: 0; transform: scale(0.4) rotate(0deg); }
  50% { opacity: 1; transform: scale(1) rotate(40deg); }
}

.crv-fab__logo {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  background: #fff;
  display: grid;
  place-items: center;
  font-family: var(--crv-font-display);
  font-size: 14px;
  color: var(--crv-navy-900);
  flex: 0 0 auto;
}

/* expanded panel (anchored to the same corner) */
.crv-fab__panel {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 312px;
  padding: 20px 22px 16px;
  border-radius: 20px;
  border: 1px solid rgba(97, 244, 0, 0.4);
  background:
    radial-gradient(260px 160px at 80% -10%, rgba(20, 128, 255, 0.35), transparent 65%),
    linear-gradient(170deg, var(--crv-navy-800), #04122e);
  box-shadow:
    0 0 50px -10px rgba(97, 244, 0, 0.3),
    0 28px 60px -24px rgba(4, 18, 46, 0.85);
  color: #fff;
  opacity: 0;
  transform: translateY(10px) scale(0.96);
  transform-origin: 100% 100%;
  pointer-events: none;
  transition: opacity 0.3s ease, transform 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
}
.crv-fab:hover .crv-fab__panel,
.crv-fab.is-open .crv-fab__panel {
  opacity: 1;
  transform: none;
  pointer-events: auto;
}
.crv-fab:hover .crv-fab__mini,
.crv-fab.is-open .crv-fab__mini {
  opacity: 0;
  transform: scale(0.92);
  pointer-events: none;
}

.crv-fab__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.crv-fab__head b { display: block; font-size: 15px; font-weight: 800; }
.crv-fab__head em {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-style: normal;
  font-size: 12px;
  font-weight: 700;
  color: var(--crv-green);
  margin-top: 2px;
}
.crv-fab__head em svg { width: 12px; height: 12px; color: var(--crv-gold); }

.crv-fab__deal {
  font-family: var(--crv-font-display);
  font-weight: 400;
  font-size: 26px;
  line-height: 1.1;
  margin-bottom: 14px;
}
.crv-fab__deal em { font-style: normal; color: var(--crv-green); }
.crv-fab__deal span {
  display: block;
  font-family: var(--crv-font-body);
  font-size: 13px;
  font-weight: 700;
  color: rgba(240, 242, 245, 0.8);
  margin-top: 4px;
}

.crv-fab__note {
  margin-top: 10px;
  text-align: center;
  font-size: 10.5px;
  letter-spacing: 0.04em;
  color: rgba(240, 242, 245, 0.45);
}

/* ============================================================
   MOBILE STICKY CTA BAR
   ============================================================ */

.crv-stickybar {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 90;
  transform: translateY(110%);
  transition: transform 0.45s cubic-bezier(0.22, 0.61, 0.36, 1);
  background: rgba(4, 18, 46, 0.94);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(97, 244, 0, 0.35);
}
.crv-stickybar.is-on { transform: translateY(0); }
.crv-stickybar__in {
  max-width: 1372px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 10px 30px;
}
.crv-stickybar__brand { display: flex; align-items: center; gap: 14px; min-width: 0; }
.crv-stickybar__logo {
  flex: 0 0 auto;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: #fff;
  display: grid;
  place-items: center;
  font-family: var(--crv-font-display);
  font-size: 15px;
  color: var(--crv-navy-900);
}
.crv-stickybar__offer { font-size: 14px; font-weight: 700; color: #fff; line-height: 1.35; }
.crv-stickybar__offer span { display: block; font-size: 10.5px; font-weight: 600; color: rgba(240, 242, 245, 0.55); }
.crv-stickybar .crv-btn-green { width: auto; height: 44px; font-size: 18px; flex: 0 0 auto; }
.crv-stickybar .crv-btn-green > span { padding: 2px 22px 0; }

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width: 1280px) {
  .crv-hero__grid { grid-template-columns: 440px minmax(0, 1fr); gap: 38px; }
  .crv-strip { grid-template-columns: 1.3fr repeat(4, 1fr); }
  .crv-strip__pay { grid-column: 1 / -1; border-left: 0 !important; border-top: 1px solid rgba(255, 255, 255, 0.1); flex-direction: row; align-items: center; gap: 14px; }
}

@media (max-width: 1100px) {
  .crv-hero__grid { grid-template-columns: 1fr; }
  .crv-hero__id, .crv-ticketwrap { grid-column: auto; grid-row: auto; }
  .crv-ticketwrap { max-width: 560px; }
  .crv-passport__grid { grid-template-columns: 1fr 1fr; }
  .crv-sheet { grid-template-columns: 1fr; }
  .crv-ratings { grid-column: auto; grid-row: auto; }
  .crv-games { grid-template-columns: repeat(5, 1fr); }
  .crv-fab { display: none; }
  .crv-stickybar { display: block; }
}

@media (max-width: 860px) {
  .crv-hero { padding-top: 130px; }
  .crv-hero__title { font-size: 46px; }
  .crv-hero__logo { min-width: 80px; height: 80px; padding: 0 14px; font-size: 28px; border-radius: 18px; }
  .crv-hero__logo img { max-height: 52px; }
  .crv-cardtitle { font-size: 23px; }
  .crv-card { padding: 28px 24px; }
  .crv-gov__panel { padding: 26px 22px 150px; }
  .crv-gov .crv-games { margin-top: -130px; }
  .crv-strip { grid-template-columns: 1fr 1fr; }
  .crv-strip__score { grid-column: 1 / -1; border-left: 0 !important; }
  .crv-strip__cell { border-left: 0 !important; border-top: 1px solid rgba(255, 255, 255, 0.1); }
  .crv-strip__cell:nth-child(even) { border-left: 1px solid rgba(255, 255, 255, 0.1) !important; }
  .crv-strip__score { border-top: 0; }
  .crv-passport__grid { grid-template-columns: 1fr; gap: 24px; }
  .crv-games { grid-template-columns: repeat(3, 1fr); }
  .crv-counters { grid-template-columns: repeat(3, 1fr); }
  .crv-counter { border-left: 0 !important; }
  .crv-counter:nth-child(n + 4) { border-top: 1px solid var(--crv-line); }
  .crv-getstart .steps-box { grid-template-columns: 1fr 1fr; }
  .crv-final__title { font-size: 40px; }
  .crv-final { margin-top: 100px; padding-top: 86px; }
  .crv-final__mascot { height: 170px; top: -104px; }
  .crv-final__seg { padding: 14px 8px; }
  .crv-ticket { padding: 24px 22px 20px; }
  .crv-ticket__amount { font-size: 36px; }
}

@media (max-width: 560px) {
  .crv-hero__idrow { flex-direction: column; align-items: flex-start; gap: 16px; }
  .crv-hero__title { font-size: 40px; }
  .crv-games { grid-template-columns: 1fr 1fr; }
  .crv-counters { grid-template-columns: 1fr 1fr; }
  .crv-counter:nth-child(n + 3) { border-top: 1px solid var(--crv-line); }
  .crv-counter:nth-child(even) { border-left: 1px solid var(--crv-line) !important; }
  .crv-getstart .steps-box { grid-template-columns: 1fr; }
  .crv-ticket__grid { grid-template-columns: 1fr; }
  .crv-stickybar__offer span { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .crv-fab__mini, .crv-fab__gift, .crv-fab__badge, .crv-fab__spark::before { animation: none; }
  .crv-fab__comet { display: none; }
  .crv-reveal { opacity: 1; transform: none; transition: none; }
  .crv-ring [data-ring-fill] { transition: none; }
}
