/* ==========================================================================
   Page: New Member Coupon (newmember-coupon-v3)
   ========================================================================== */

/* === Hero Override (dark variant) === */
.s26-hero { text-align: center; }
.s26-hero__card {
  background: linear-gradient(160deg, #0a0a0a 0%, #1a1d22 50%, #20252d 100%);
  border: none;
  text-align: left;
  position: relative;
  overflow: hidden;
}
/* === Hero Camera Image === */
.s26-hero__camera {
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  height: 100%;
  display: flex;
  align-items: center;
}
.s26-hero__camera-img {
  height: 100%;
  width: auto;
  display: block;
}
.s26-hero__body {
  position: relative;
  z-index: 1;
}
.s26-hero__label {
  display: inline-block;
  font-size: var(--label-xs-size);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-primary);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: var(--space-md);
}
.s26-hero__title {
  color: var(--color-text-default-on-dark);
  font-size: clamp(32px, 4vw, 48px);
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: var(--space-xs);
}
.s26-hero__subtitle {
  color: var(--color-text-default-on-dark-transparent);
  margin-bottom: var(--space-2xs);
}
.s26-hero__value {
  font-size: clamp(72px, 10vw, 120px);
  font-weight: var(--font-weight-bold);
  color: var(--color-gold);
  line-height: 0.9;
  letter-spacing: -0.04em;
  margin-bottom: var(--space-md);
}
.s26-hero__value span {
  font-size: 0.45em;
  letter-spacing: -0.02em;
  vertical-align: baseline;
}
.s26-hero__rule { background: var(--color-white); margin-top: auto; }
.s26-hero__intro { color: var(--color-text-default-on-dark-transparent); }

/* === Section: Feature Section — center-aligned header === */
.newmember-coupon-features-section .s26-section-header { text-align: center; }

/* === Section: Feature Cards === */
.newmember-coupon-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xl);
}
.newmember-coupon-feature-card {
  text-align: center;
  padding: var(--space-md) 0;
}
.newmember-coupon-feature-card__icon {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-md);
}
.newmember-coupon-feature-card__icon :is(img, svg) { width: 72px; height: 72px; }
.newmember-coupon-feature-card__title {
  color: var(--color-brand-primary);
  margin-bottom: var(--space-xs);
}
.newmember-coupon-feature-card__desc { color: var(--color-text-default-sub); line-height: var(--leading-body-md-plus-loose); }

/* === Section: Flow Cards === */
.newmember-coupon-flow-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-2xl);
}
.newmember-coupon-flow-card {
  background: var(--color-bg-page);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  text-align: center;
  position: relative;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06);
}
.newmember-coupon-flow-card:not(:last-child)::after {
  content: "";
  position: absolute;
  left: calc(100% + var(--space-2xl) / 2);
  top: 40%;
  transform: translate(-50%, -50%);
  width: 0;
  height: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 12px solid var(--color-brand-primary);
}
.newmember-coupon-flow-card__icon {
  margin-bottom: var(--space-md);
}
.newmember-coupon-flow-card__icon :is(img, svg) {
  width: 72px;
  height: 72px;
  display: block;
  margin-inline: auto;
}
.newmember-coupon-flow-card__number {
  display: inline-block;
  font-size: var(--label-xs-size);
  font-weight: var(--font-weight-bold);
  color: var(--color-brand-primary);
  background: rgba(1, 145, 109, 0.1);
  padding: var(--space-5xs) var(--space-sm);
  border-radius: var(--radius-full);
  margin-bottom: var(--space-sm);
  letter-spacing: 0.05em;
}
.newmember-coupon-flow-card__number--gold {
  color: var(--color-gold);
  background: var(--color-gold-light);
}
.newmember-coupon-flow-card__title {
  font-weight: var(--font-weight-bold);
  margin-bottom: var(--space-xs);
}
.newmember-coupon-flow-card__desc { color: var(--color-text-default-sub); line-height: var(--leading-body-md-plus-loose); text-align: left; }

/* === Section: Info Box Extension === */
.s26-info-box__note {
  color: var(--color-text-default-sub);
  margin-top: var(--space-md);
}

/* === Section: Print & Gifts === */
.newmember-coupon-printgifts {
  display: flex;
  align-items: center;
  gap: var(--space-2xl);
}
.newmember-coupon-printgifts__photo {
  width: 280px;
  flex-shrink: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.newmember-coupon-printgifts__photo img {
  width: 100%;
  height: auto;
  display: block;
}
.newmember-coupon-printgifts__body { flex: 1; }
.newmember-coupon-printgifts__title {
  margin-bottom: var(--space-3xs);
}
.newmember-coupon-printgifts__desc {
  color: var(--color-text-default-sub);
  line-height: 1.8;
}
.newmember-coupon-printgifts__link,
.newmember-coupon-printgifts__link:link,
.newmember-coupon-printgifts__link:visited {
  display: inline-block;
  color: var(--color-brand-primary);
  margin-top: var(--space-md);
  padding: var(--space-xs) var(--space-lg);
  background: var(--color-bg-accent);
  border-radius: var(--radius-full);
  text-decoration: none;
  transition: background 0.15s;
}
.newmember-coupon-printgifts__link:hover {
  background: var(--color-border-default);
}

/* === Placeholder Variant === */
.s26-placeholder--picto-lg {
  width: 56px;
  height: 56px;
  border: 2px dashed var(--color-border-default);
  border-radius: var(--radius-md);
}
.newmember-coupon-feature-card__note { margin-top: var(--space-xs); }

/* === Mobile Overrides === */
@media (max-width: 767px) {
  .s26-hero__card { padding: var(--space-2xl) var(--space-xl); flex-direction: column; text-align: center; }
  .s26-hero__camera {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    top: auto;
    transform: none;
    height: auto;
    display: block;
  }
  .s26-hero__camera-img {
    width: 100%;
    height: auto;
  }
  .s26-hero__body { padding-bottom: 67vw; }
  .s26-hero__card { padding-bottom: 0; }
  .s26-hero__rule { margin-inline: auto; }
  .newmember-coupon-features { grid-template-columns: 1fr; gap: var(--margin-x); }
  .newmember-coupon-feature-card { padding: var(--space-sm) 0; }
  .newmember-coupon-feature-card { padding: var(--space-md) 0; }
  .newmember-coupon-flow-cards { grid-template-columns: 1fr; gap: var(--space-xl); }
  .newmember-coupon-flow-card { padding: var(--space-lg); }
  .newmember-coupon-flow-card:not(:last-child)::after {
    left: 50%;
    top: auto;
    bottom: calc(-1 * var(--space-xl) / 2);
    transform: translate(-50%, 50%);
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    border-top: 10px solid var(--color-brand-primary);
    border-bottom: none;
  }
  .newmember-coupon-printgifts { flex-direction: column; gap: var(--space-lg); padding-inline: var(--space-md); }
  .newmember-coupon-printgifts__body { width: 100%; }
  .newmember-coupon-printgifts__photo { width: 100%; border-radius: 0; overflow: visible; }
  .newmember-coupon-printgifts__photo img { border-radius: var(--radius-md); }
  .newmember-coupon-printgifts__link { display: block; width: 100%; text-align: center; font-size: var(--label-md-size); }
}
