.pct-toplist {
  --pct-item-bg:#17181f;
  --pct-border:#e0ab16;
  --pct-text:#fff;
  --pct-muted:#e0ab16;
  --pct-heading-size:18px;
  --pct-bonus-size:22px;
  --pct-body-size:15px;
  --pct-button-bg:#e6b626;
  --pct-button-text:#fff;
  --pct-button-hover-bg:#f0c84d;
  --pct-button-hover-text:#111;
  --pct-details-bg:#e6b626;
  --pct-details-text:#111;
  --pct-details-hover-bg:#f0c84d;
  --pct-details-hover-text:#111;
  --pct-star:#f3b400;
  --pct-glow-color:#e0ab16;
  --pct-glow-size:20px;
  display:grid;
  gap:18px;
}

.pct-card {
  position:relative;
  background:var(--pct-item-bg);
  color:var(--pct-text);
  border:2px solid var(--pct-border);
  border-radius:4px;
  padding:18px 18px 16px;
  overflow:visible;
}
.pct-toplist--glow .pct-card { box-shadow:0 0 var(--pct-glow-size) var(--pct-glow-color); }
.pct-rank {
  position:absolute;
  left:-12px;
  top:-12px;
  width:28px;
  height:28px;
  border-radius:50%;
  background:#f4f1ea;
  color:#111;
  border:2px solid #8f7d4d;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:700;
  font-size:14px;
  z-index:2;
}
.pct-card__top {
  display:grid;
  grid-template-columns: 110px minmax(220px, 1.5fr) 120px 140px 250px;
  align-items:center;
  gap:22px;
}
.pct-brand { display:flex; flex-direction:column; align-items:flex-start; gap:14px; }
.pct-brand__logo {
  width:88px;
  height:88px;
  object-fit:cover;
  border-radius:50%;
  border:3px solid #9c7707;
  display:block;
}
.pct-main { text-align:center; }
.pct-casino-name {
  margin:0 0 6px;
  font-size:var(--pct-heading-size);
  line-height:1.25;
  font-weight:700;
}
.pct-bonus {
  font-size:var(--pct-bonus-size);
  line-height:1.35;
  font-weight:700;
  max-width:330px;
  margin:0 auto;
}
.pct-rating {
  display:flex;
  gap:4px;
  justify-content:center;
  align-items:center;
  font-size:26px;
  color:rgba(243,180,0,.35);
}
.pct-star--filled { color:var(--pct-star); }
.pct-payments {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  flex-wrap:wrap;
}
.pct-payments img {
  width:28px;
  height:20px;
  object-fit:contain;
  display:block;
  background:#fff;
}
.pct-cta-wrap { text-align:center; }
.pct-play-btn,
.pct-details-toggle {
  transition:.25s ease;
  text-decoration:none !important;
}
.pct-play-btn {
  display:block;
  width:100%;
  max-width:220px;
  margin:0 auto 10px;
  background:var(--pct-button-bg);
  color:var(--pct-button-text);
  padding:17px 20px;
  border-radius:12px;
  font-size:16px;
  font-weight:700;
  border:0;
  text-align:center;
}
.pct-play-btn:hover {
  background:var(--pct-button-hover-bg);
  color:var(--pct-button-hover-text);
}
.pct-details-toggle {
  display:inline-flex;
  align-items:center;
  gap:4px;
  background:var(--pct-details-bg);
  color:var(--pct-details-text);
  border:0;
  border-radius:3px;
  padding:8px 11px;
  font-size:14px;
  cursor:pointer;
}
.pct-details-toggle:hover {
  background:var(--pct-details-hover-bg);
  color:var(--pct-details-hover-text);
}
.pct-details-toggle__icon { font-size:13px; line-height:1; }
.pct-card.is-open .pct-details-toggle__icon { transform:rotate(180deg); }
.pct-terms-row {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  color:var(--pct-muted);
  font-size:12px;
  line-height:1.35;
}
.pct-terms-info {
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:15px;
  height:15px;
  border-radius:50%;
  background:#f1d386;
  color:#111;
  font-size:11px;
  font-weight:700;
  cursor:help;
}
.pct-tooltip {
  position:absolute;
  right:-10px;
  bottom:calc(100% + 10px);
  min-width:300px;
  max-width:360px;
  background:#2c2d33;
  color:#fff;
  padding:10px 12px;
  border-radius:6px;
  box-shadow:0 12px 24px rgba(0,0,0,.35);
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:.2s ease;
  z-index:10;
  font-size:12px;
  line-height:1.45;
  text-align:left;
}
.pct-tooltip::after {
  content:"";
  position:absolute;
  right:14px;
  top:100%;
  border:7px solid transparent;
  border-top-color:#2c2d33;
}
.pct-terms-info:hover .pct-tooltip,
.pct-terms-info:focus .pct-tooltip,
.pct-terms-info:focus-within .pct-tooltip {
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}
.pct-card__details { padding-top:18px; }
.pct-card__divider {
  border-top:2px dotted var(--pct-border);
  margin:10px 0 16px;
}
.pct-details-grid {
  display:grid;
  grid-template-columns: 1.05fr 1.4fr;
  gap:24px;
  align-items:start;
}
.pct-like-box h4 {
  margin:0 0 10px;
  font-size:16px;
  font-weight:700;
}
.pct-like-box ul { margin:0; padding-left:18px; }
.pct-like-box li {
  margin:0 0 12px;
  font-size:var(--pct-body-size);
  line-height:1.55;
}
.pct-facts-grid {
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:0;
}
.pct-fact {
  text-align:center;
  padding:8px 18px 14px;
  position:relative;
}
.pct-fact:nth-child(-n+3) { border-bottom:1px solid rgba(224,171,22,.45); }
.pct-fact:not(:nth-child(3n))::after {
  content:"";
  position:absolute;
  top:8px;
  right:0;
  width:1px;
  height:56px;
  background:linear-gradient(180deg, transparent, var(--pct-border), transparent);
}
.pct-fact__label {
  font-size:var(--pct-body-size);
  line-height:1.35;
  margin-bottom:8px;
}
.pct-fact__value {
  font-size:calc(var(--pct-body-size) + 4px);
  font-weight:700;
  line-height:1.3;
}
.pct-description {
  font-size:var(--pct-body-size);
  line-height:1.65;
}

@media (max-width: 900px) {
  .pct-card__top {
    grid-template-columns: 95px minmax(180px, 1fr) 110px 120px 180px;
    gap:18px;
  }
  .pct-brand__logo { width:82px; height:82px; }
  .pct-bonus { font-size:18px; max-width:240px; }
  .pct-play-btn { max-width:155px; padding:15px 18px; }
}

@media (max-width: 899px) {
  .pct-card { padding:20px 12px 14px; }
  .pct-card__top {
    grid-template-columns:1fr;
    gap:14px;
    justify-items:center;
  }
  .pct-brand {
    width:100%;
    align-items:center;
    gap:12px;
  }
  .pct-brand__logo { width:92px; height:92px; order:1; }
  .pct-details-toggle { order:6; }
  .pct-main { order:3; }
  .pct-rating { order:2; }
  .pct-payments { order:5; }
  .pct-cta-wrap { order:4; width:100%; }
  .pct-bonus { max-width:100%; font-size:18px; }
  .pct-play-btn { max-width:350px; }
  .pct-terms-row { margin-bottom:8px; }
  .pct-details-grid {
    grid-template-columns:1fr;
    gap:8px;
  }
  .pct-facts-grid { grid-template-columns:repeat(2, minmax(0,1fr)); }
  .pct-fact:nth-child(-n+3) { border-bottom:none; }
  .pct-fact:nth-child(-n+4) { border-bottom:1px solid rgba(224,171,22,.45); }
  .pct-fact:not(:nth-child(3n))::after { display:none; }
  .pct-fact:nth-child(odd)::after {
    display:block;
    content:"";
    position:absolute;
    top:8px;
    right:0;
    width:1px;
    height:56px;
    background:linear-gradient(180deg, transparent, var(--pct-border), transparent);
  }
  .pct-tooltip {
    right:-50px;
    min-width:260px;
    max-width:300px;
  }
}
