/* ============================================================
   P77PLAY — INFORMATIONAL PAGES
   Shared by: bonuses.html · how-to-play.html · refer-earn.html
   ============================================================ */

/* Section intro copy under a page-hero */
.lead-block { max-width: 820px; margin: 0 auto var(--space-2xl); }
.lead-block p { font-size: 1.03rem; line-height: 1.8; }
.lead-block p + p { margin-top: var(--space-md); }

/* ---------- Bonus / reward cards ---------- */
.bonus-grid { display: grid; grid-template-columns: 1fr; gap: var(--space-lg); }
@media (min-width: 640px)  { .bonus-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .bonus-grid { grid-template-columns: repeat(3, 1fr); } }

.bonus-card {
  position: relative;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);
}
.bonus-card:hover { transform: translateY(-6px); border-color: var(--color-border-strong); box-shadow: var(--shadow-elevated); }
.bonus-card--featured { border-color: var(--color-border-strong); box-shadow: var(--shadow-glow-gold); }
.bonus-card__icon {
  width: 52px; height: 52px;
  display: grid; place-items: center;
  border-radius: var(--radius-md);
  background: rgba(240, 180, 41, 0.1);
  border: 1px solid var(--color-border);
  font-size: 1.5rem;
}
.bonus-card__value { font-family: var(--font-mono); font-weight: 600; font-size: 1.7rem; color: var(--color-accent-gold); }
.bonus-card h3 { font-size: 1.2rem; }
.bonus-card p { font-size: 0.92rem; }
.bonus-card__terms { margin-top: auto; padding-top: 10px; border-top: 1px solid var(--color-border); font-size: 0.78rem; color: var(--color-text-muted); }

/* ---------- Numbered process steps (referral / claim flow) ---------- */
.process-steps {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  counter-reset: process;
}
@media (min-width: 768px) { .process-steps { grid-template-columns: repeat(3, 1fr); } }
.process-steps--4 { }
@media (min-width: 900px) { .process-steps--4 { grid-template-columns: repeat(4, 1fr); } }

.process-step {
  position: relative;
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg) var(--space-lg);
}
.process-step__num {
  font-family: var(--font-mono); font-weight: 600; font-size: 1.05rem;
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--color-accent-gold), var(--color-accent-gold-dim));
  color: #12100A;
  margin-bottom: var(--space-md);
  box-shadow: var(--shadow-glow-gold);
}
.process-step h3 { font-size: 1.1rem; margin-bottom: 6px; }
.process-step p { font-size: 0.9rem; }

/* connecting line between steps on desktop */
@media (min-width: 768px) {
  .process-steps .process-step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 34px; right: -calc(var(--space-lg) / 2 + 1px);
    width: var(--space-lg);
    height: 2px;
    background: linear-gradient(90deg, var(--color-border-strong), transparent);
  }
}

/* ---------- Reward tier table (referral commission etc.) ---------- */
.tier-table td:first-child, .tier-table th:first-child { color: var(--color-accent-gold); font-family: var(--font-mono); }

/* ---------- Earnings example card ---------- */
.example-card {
  background: linear-gradient(120deg, var(--color-bg-tertiary), var(--color-bg-secondary));
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  max-width: 680px;
  margin: 0 auto;
}
.example-card h3 { margin-bottom: var(--space-md); }
.example-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px dashed var(--color-border);
  font-size: 0.95rem;
}
.example-row:last-of-type { border-bottom: none; }
.example-row span:first-child { color: var(--color-text-secondary); }
.example-row span:last-child { font-family: var(--font-mono); font-weight: 600; color: var(--color-text-primary); }
.example-row--total { margin-top: 8px; padding-top: 14px; border-top: 1px solid var(--color-border-strong); }
.example-row--total span:last-child { color: var(--color-accent-gold); font-size: 1.15rem; }

/* ---------- Referral link box ---------- */
.link-box {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  background: var(--color-bg-tertiary);
  border: 1px dashed var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-md) var(--space-lg);
  max-width: 620px;
  margin: var(--space-lg) auto 0;
  font-family: var(--font-mono);
  font-size: 0.9rem;
  color: var(--color-text-secondary);
}
.link-box strong { color: var(--color-accent-gold); }

/* ---------- Two-column content + sidebar (how-to-play) ---------- */
.info-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2xl);
  align-items: start;
}
@media (min-width: 960px) { .info-layout { grid-template-columns: 1fr 300px; } }

.info-sidebar {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}
@media (min-width: 960px) { .info-sidebar { position: sticky; top: calc(var(--nav-height) + 16px); } }

.sidebar-card {
  background: var(--color-bg-secondary);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
}
.sidebar-card h4 { font-size: 0.85rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--color-accent-gold); margin-bottom: var(--space-md); }
.sidebar-card ul { display: flex; flex-direction: column; gap: 10px; }
.sidebar-card a { color: var(--color-text-secondary); font-size: 0.9rem; }
.sidebar-card a:hover { color: var(--color-accent-gold); }

/* ---------- Category explainer blocks (used on games.html too) ---------- */
.category-block {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-lg);
  align-items: center;
  padding-block: var(--space-xl);
  border-bottom: 1px solid var(--color-border);
}
.category-block:last-child { border-bottom: none; }
@media (min-width: 800px) { .category-block { grid-template-columns: 220px 1fr; } }
.category-block__icon {
  width: 84px; height: 84px;
  display: grid; place-items: center;
  border-radius: var(--radius-lg);
  background: rgba(240, 180, 41, 0.08);
  border: 1px solid var(--color-border);
  font-size: 2.2rem;
  margin-inline: auto;
}
@media (min-width: 800px) { .category-block__icon { margin-inline: 0; } }
.category-block h3 { margin-bottom: 8px; }
.category-block p { font-size: 0.95rem; }
.category-block__tags { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
