/* =====================
   Hero
   ===================== */
.clubs-hero {
  padding-top: 120px;
  padding-bottom: var(--space-3xl);
  text-align: center;
  background-image:
    linear-gradient(rgba(255, 245, 195, 0.78), rgba(255, 245, 195, 0.92)),
    url('/images/brands japanSiteSize.webp');
  background-size: cover;
  background-position: center;
}

.clubs-hero .badge {
  margin-bottom: var(--space-lg);
}

.clubs-hero__title {
  margin-bottom: var(--space-md);
  line-height: 1.1;
  text-transform: uppercase;
}

.clubs-hero__subtitle {
  font-family: var(--font-heading);
  font-size: var(--text-xl);
  color: var(--color-text);
  margin-bottom: var(--space-lg);
  line-height: 1.2;
}

.clubs-hero__text {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  max-width: 580px;
  margin: 0 auto var(--space-xl);
  line-height: var(--leading-relaxed);
}

/* =====================
   How it works (steps)
   ===================== */
.clubs-how {
  padding: var(--space-3xl) 0;
}

.clubs-how .step {
  text-align: center;
}

.clubs-how .step__number {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  background-color: var(--color-primary);
  color: #fff;
  font-size: var(--text-xl);
  font-weight: var(--weight-bold);
  margin: 0 auto var(--space-lg);
}

.clubs-how .step__title {
  font-size: var(--text-xl);
  margin-bottom: var(--space-sm);
}

.clubs-how .step__text {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  max-width: 320px;
  margin: 0 auto;
  line-height: var(--leading-relaxed);
}

/* =====================
   Offline → online
   ===================== */
.clubs-offline {
  padding: var(--space-3xl) 0;
}

/* Lede: body text + pull-quote card side by side */
.clubs-offline__lede {
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  gap: var(--space-2xl);
  align-items: start;
  margin-top: var(--space-xl);
}

.clubs-offline__lede-text p {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-md);
}

.clubs-offline__lede-text p:last-child {
  margin-bottom: 0;
}

.clubs-offline__pull-card {
  position: relative;
  padding: var(--space-2xl) var(--space-xl);
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.clubs-offline__pull-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 6px;
  height: 100%;
  background-color: var(--color-primary);
}

.clubs-offline__pull-eyebrow {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-heading);
  margin-bottom: var(--space-md);
}

.clubs-offline__pull {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  color: var(--color-primary);
  line-height: 1.2;
  margin: 0;
}

@media (max-width: 768px) {
  .clubs-offline__lede {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
  .clubs-offline__pull {
    font-size: var(--text-xl);
  }
}

/* =====================
   Sponsor prize
   ===================== */
.clubs-sponsor {
  padding: var(--space-3xl) 0;
}

/* Three "win" beneficiaries */
.clubs-sponsor__wins {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-2xl);
}

.clubs-sponsor__win-item {
  padding: var(--space-xl);
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-top: 4px solid var(--color-primary);
  border-radius: var(--radius-md);
}

.clubs-sponsor__win-tag {
  display: inline-block;
  font-family: var(--font-heading);
  font-size: var(--text-xs);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
  margin-bottom: var(--space-md);
}

.clubs-sponsor__win-text {
  font-size: var(--text-base);
  color: var(--color-text);
  line-height: var(--leading-normal);
  margin: 0;
}

.clubs-sponsor__cta {
  text-align: center;
  margin-top: var(--space-2xl);
}

.clubs-sponsor__cta-note {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  margin: 0 0 var(--space-md);
}

@media (max-width: 768px) {
  .clubs-sponsor__wins {
    grid-template-columns: 1fr;
  }
}

/* =====================
   What you get
   ===================== */
.clubs-get {
  padding: var(--space-3xl) 0;
}

.clubs-get__grid {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: var(--space-3xl);
  align-items: center;
}

.clubs-get__title {
  font-size: var(--text-3xl);
  line-height: 1.15;
  margin: var(--space-md) 0 var(--space-md);
}

.clubs-get__intro {
  font-size: var(--text-lg);
  color: var(--color-text);
  margin-bottom: var(--space-lg);
  font-weight: var(--weight-bold);
}

.clubs-get__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.clubs-get__list li {
  font-size: var(--text-base);
  color: var(--color-text-secondary);
  padding: var(--space-sm) 0 var(--space-sm) var(--space-lg);
  position: relative;
  line-height: var(--leading-normal);
  border-bottom: 1px solid var(--color-border-light);
}

.clubs-get__list li:last-child {
  border-bottom: none;
}

.clubs-get__list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: var(--weight-bold);
}

.clubs-get__quote {
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl);
}

.clubs-get__pull {
  font-family: var(--font-heading);
  font-size: var(--text-2xl);
  color: var(--color-primary);
  line-height: 1.2;
  margin-bottom: var(--space-lg);
}

.clubs-get__support {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-md);
}

.clubs-get__support:last-child {
  margin-bottom: 0;
}

@media (max-width: 768px) {
  .clubs-get__grid {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }
}

/* =====================
   For who (tags)
   ===================== */
.clubs-who {
  padding: var(--space-3xl) 0;
}

.clubs-who__tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-sm);
  margin-top: var(--space-xl);
}

.clubs-who__tag {
  display: inline-block;
  padding: var(--space-sm) var(--space-lg);
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-sm);
  color: var(--color-text);
  font-weight: var(--weight-medium);
}

/* =====================
   Numbers
   ===================== */
.clubs-numbers {
  padding: var(--space-3xl) 0;
}

.clubs-numbers__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-lg);
  margin-top: var(--space-xl);
}

.clubs-number {
  padding: var(--space-2xl) var(--space-xl);
  background-color: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-top: 4px solid var(--color-primary);
  border-radius: var(--radius-lg);
  text-align: center;
}

.clubs-number__value {
  display: block;
  font-family: var(--font-heading);
  font-size: var(--text-3xl);
  color: var(--color-heading);
  margin-bottom: var(--space-sm);
  line-height: 1.1;
}

.clubs-number__label {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}

@media (max-width: 768px) {
  .clubs-numbers__grid {
    grid-template-columns: 1fr;
  }
}

/* =====================
   FAQ
   ===================== */
.clubs-faq {
  padding: var(--space-3xl) 0;
}

.clubs-faq .faq {
  max-width: 800px;
  margin: 0 auto;
}

/* =====================
   CTA
   ===================== */
.clubs-cta {
  text-align: center;
  padding: var(--space-3xl) 0 var(--space-4xl);
}

.clubs-cta__title {
  font-size: var(--text-3xl);
  margin-bottom: var(--space-md);
  line-height: 1.2;
  text-transform: uppercase;
}

.clubs-cta__text {
  font-size: var(--text-lg);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-xl);
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}

.clubs-cta__note {
  margin-top: var(--space-md);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}
