/* casino-table.css - offer cards and shared casino chips */

/* Fade-up on scroll */
.fade-up {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .5s ease, transform .5s ease;
}
.fade-up.visible {
  opacity: 1;
  transform: none;
}

@media (max-width: 720px) {
  .fade-up {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

/* Section heading */
.section-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-6);
  padding: var(--space-4) var(--space-12);
  background: var(--neon-soft);
  border: 1px solid var(--line-green);
  border-radius: var(--pill);
  font-size: var(--fs-kicker);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-widest);
  text-transform: uppercase;
  color: var(--neon);
  margin-bottom: var(--space-16);
}

.casino-logo-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  padding: 0 var(--space-16);
  border-radius: var(--radius-sm);
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: var(--fw-display);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  min-width: 100px;
}
.logo-ice { background: linear-gradient(135deg, var(--ice-2), var(--ice-1)); color: #fff; }
.logo-slotoro { background: linear-gradient(135deg, var(--slotoro-1), var(--slotoro-2)); color: #fff; }
.logo-mrbet { background: linear-gradient(135deg, var(--mrbet-2), var(--mrbet-1)); color: #fff; }
.logo-verde { background: linear-gradient(135deg, var(--verde-2), var(--verde-1)); color: #fff; }
.logo-lemon { background: linear-gradient(135deg, var(--lemon-2), var(--lemon-1)); color: #080c18; }

.rating-stars {
  display: inline-flex;
  gap: var(--space-2);
  color: var(--star);
  font-size: 15px;
  letter-spacing: 0;
}

.lic-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 34px;
  padding: 0 var(--space-14);
  border: 1px solid rgba(var(--white-rgb), .14);
  border-radius: var(--radius-sm);
  background: rgba(var(--white-rgb), .08);
  color: var(--ink);
  font-size: var(--fs-sm);
  font-weight: var(--fw-bold);
}

.offers-list {
  display: grid;
  gap: var(--space-24);
}

.offer-box {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line-gold);
  border-radius: var(--radius-md);
  background: linear-gradient(145deg, rgba(20, 26, 46, .98), rgba(10, 14, 30, .96));
  box-shadow: var(--shadow-md);
}

.offer-box::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 8% 0%, rgba(var(--brand-rgb), .11), transparent 28%);
}

.offer-box:hover {
  border-color: rgba(var(--brand-rgb), .72);
  box-shadow: var(--shadow-lg);
}

.offer-rank {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  min-width: 44px;
  height: 44px;
  padding: 0 var(--space-10);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-bottom-right-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--brand), #ff7a18);
  color: #080c18;
  font-family: var(--font-display);
  font-size: 20px;
  font-weight: var(--fw-display);
  line-height: 1;
}

.offer-main {
  position: relative;
  display: grid;
  grid-template-columns: minmax(180px, .9fr) minmax(270px, 1.35fr) minmax(240px, 1.1fr) minmax(190px, .95fr);
  gap: var(--space-24);
  align-items: center;
  padding: var(--space-32) var(--space-28) var(--space-28);
}

.offer-brand {
  display: grid;
  gap: var(--space-10);
  padding-left: var(--space-8);
}

.offer-brand .casino-logo-chip {
  width: min(100%, 250px);
  height: 108px;
  border-radius: var(--radius);
  font-size: 24px;
  box-shadow: inset 0 -24px 36px rgba(0,0,0,.18);
}

.offer-brand h3 {
  color: var(--brand);
  font-size: 24px;
  letter-spacing: 0;
}

.offer-rating {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  color: var(--white);
  font-weight: var(--fw-bold);
}

.offer-terms {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  border-inline: 1px solid var(--line);
}

.offer-term {
  display: grid;
  gap: var(--space-8);
  min-height: 110px;
  padding: var(--space-10) var(--space-16);
  align-content: center;
  text-align: center;
  border-right: 1px solid var(--line);
}
.offer-term:last-child { border-right: 0; }

.offer-term span,
.offer-bonus-panel span,
.offer-features span {
  color: var(--ink-3);
  font-size: var(--fs-caption);
  font-weight: var(--fw-bold);
  letter-spacing: var(--ls-wider);
  text-transform: uppercase;
}

.offer-term strong {
  color: var(--white);
  font-size: 20px;
  line-height: 1.25;
}

.offer-bonus-panel {
  overflow: hidden;
  min-height: 126px;
  display: grid;
  align-content: start;
  border: 1px solid var(--line-gold);
  border-radius: var(--radius-sm);
  background: rgba(var(--brand-rgb), .06);
}

.offer-bonus-panel span {
  display: block;
  padding: var(--space-10) var(--space-14);
  background: linear-gradient(135deg, var(--brand), var(--brand-ink));
  color: #080c18;
  font-size: var(--fs-sm);
}

.offer-bonus-panel strong {
  padding: var(--space-16) var(--space-14) var(--space-18);
  color: var(--white);
  font-size: 21px;
  line-height: 1.35;
}

.offer-actions-panel {
  display: grid;
  gap: var(--space-10);
  justify-items: stretch;
}

.offer-actions-panel .btn {
  width: 100%;
  min-width: 0;
}

.offer-actions-panel p {
  color: var(--ink-3);
  font-size: var(--fs-sm);
  line-height: 1.3;
  text-align: center;
}

.offer-actions-panel .lic-badge {
  justify-self: center;
}

.offer-details {
  position: relative;
  padding: var(--space-20) var(--space-28) var(--space-28);
  border-top: 1px solid var(--line);
}

.offer-pros h4 {
  margin-bottom: var(--space-12);
  color: var(--white);
  font-size: 20px;
}

.offer-pros ul {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-10) var(--space-18);
  margin: 0 0 var(--space-20);
  padding: 0;
  list-style: none;
}

.offer-pros li {
  position: relative;
  padding-left: 24px;
  color: var(--ink);
  font-weight: var(--fw-medium);
}

.offer-pros li::before {
  content: '✓';
  position: absolute;
  left: 0;
  top: 1px;
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--brand);
  color: #080c18;
  font-size: 11px;
  font-weight: var(--fw-bold);
  line-height: 1;
}

.offer-features {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: var(--space-10);
}

.offer-features div {
  min-height: 78px;
  display: grid;
  gap: var(--space-6);
  align-content: center;
  padding: var(--space-12);
  border: 1px solid var(--line-2);
  border-radius: var(--radius-sm);
  background: rgba(var(--white-rgb), .04);
}

.offer-features strong {
  color: var(--white);
  font-size: 16px;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.offer-features div:nth-child(2) strong {
  color: var(--brand);
}

@media (max-width: 1120px) {
  .offer-main {
    grid-template-columns: minmax(180px, .85fr) minmax(250px, 1.15fr) minmax(220px, 1fr);
  }
  .offer-actions-panel {
    grid-column: 1 / -1;
    grid-template-columns: repeat(2, minmax(0, 1fr)) auto auto;
    align-items: center;
  }
  .offer-actions-panel p { text-align: left; }
  .offer-features { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

@media (max-width: 840px) {
  .offer-box { border-radius: var(--radius); }
  .offer-main {
    grid-template-columns: 1fr;
    gap: var(--space-18);
    padding: var(--space-56) var(--space-18) var(--space-20);
  }
  .offer-brand { padding-left: 0; }
  .offer-brand .casino-logo-chip { width: 100%; height: 92px; }
  .offer-brand h3 { font-size: 22px; }
  .offer-rating { flex-wrap: wrap; }
  .offer-terms { border: 1px solid var(--line); border-radius: var(--radius-sm); }
  .offer-actions-panel { grid-template-columns: 1fr; }
  .offer-actions-panel p { text-align: center; }
  .offer-details { padding: var(--space-18); }
  .offer-pros ul { display: grid; gap: var(--space-10); }
  .offer-features { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 560px) {
  .offers-list { gap: var(--space-18); }
  .offer-box {
    box-shadow: none;
    background: rgba(14, 20, 40, .96);
  }
  .offer-box::before { display: none; }
  .offer-box:hover {
    transform: none;
    box-shadow: none;
  }
  .offer-main {
    gap: var(--space-14);
    padding: var(--space-52) var(--space-12) var(--space-16);
  }
  .offer-rank {
    min-width: 42px;
    height: 42px;
    font-size: 18px;
  }
  .offer-brand .casino-logo-chip {
    height: 78px;
    font-size: 20px;
  }
  .offer-brand h3 {
    margin-top: var(--space-4);
    font-size: 21px;
  }
  .rating-stars { font-size: 13px; }
  .offer-terms { grid-template-columns: 1fr; }
  .offer-term {
    min-height: auto;
    grid-template-columns: 1fr;
    gap: var(--space-4);
    text-align: left;
    padding: var(--space-12);
    border-right: 0;
    border-bottom: 1px solid var(--line);
  }
  .offer-term strong {
    font-size: 18px;
    overflow-wrap: anywhere;
  }
  .offer-term:last-child { border-bottom: 0; }
  .offer-bonus-panel { min-height: 0; }
  .offer-bonus-panel strong {
    padding: var(--space-14) var(--space-12);
    font-size: 18px;
    line-height: 1.35;
  }
  .offer-actions-panel { gap: var(--space-8); }
  .offer-actions-panel .lic-badge { max-width: 100%; }
  .offer-details { padding: var(--space-16) var(--space-12); }
  .offer-pros h4 {
    font-size: 18px;
    margin-bottom: var(--space-8);
  }
  .offer-pros li {
    font-size: var(--fs-sm);
    line-height: 1.45;
  }
  .offer-features { grid-template-columns: 1fr; }
  .offer-features div {
    min-height: 0;
    padding: var(--space-10);
  }
}

@media (max-width: 380px) {
  .casino-logo-chip {
    min-width: 0;
    padding-inline: var(--space-10);
  }
  .offer-main {
    padding-inline: var(--space-10);
  }
  .offer-brand .casino-logo-chip {
    height: 70px;
    font-size: 18px;
  }
  .offer-brand h3 {
    font-size: 20px;
  }
  .offer-term strong,
  .offer-bonus-panel strong {
    font-size: 17px;
  }
  .offer-details {
    padding-inline: var(--space-10);
  }
}
