/* ==========================================================================
   Promotion — Nortefy
   Stone ground per branding (inverse mark surface); Clay as the single accent.
   No gradients — brand forbids gradient effects on the mark's territory.
   ========================================================================== */

.promotion {
  padding-top: var(--section-y);
  padding-bottom: var(--section-y);
  text-align: center;
}

.promo-banner {
  background-color: var(--stone);
  color: var(--oyster);
  padding: var(--space-12) var(--space-8);
  border-radius: var(--radius-lg);
  max-width: 900px;
  margin: 0 auto;
  position: relative;
  overflow: hidden;
}

.promo-banner .mono-label {
  display: inline-block;
  margin-bottom: var(--space-5);
  color: rgba(238, 240, 236, 0.65);
}

.promo-banner h1 {
  font-size: var(--fs-display);
  line-height: var(--lh-display);
  letter-spacing: var(--ls-display);
  color: var(--oyster);
  margin-bottom: var(--space-4);
}

.promo-banner h1 em {
  font-style: italic;
  color: var(--oyster);
  font-weight: var(--fw-regular);
}

.promo-banner > p {
  font-family: var(--font-serif);
  font-style: italic;
  color: var(--inverse-text-soft);
  font-size: var(--fs-lede);
  line-height: 1.5;
  margin-bottom: var(--space-8);
  max-width: 56ch;
  margin-left: auto;
  margin-right: auto;
}

.promo-offer {
  background-color: var(--oyster);
  color: var(--ink);
  padding: var(--space-6) var(--space-7);
  border-radius: var(--radius);
  display: inline-block;
  margin-bottom: var(--space-8);
}

.promo-offer .original-price {
  text-decoration: line-through;
  color: var(--muted-color);
  font-family: var(--font-serif);
  font-size: var(--fs-lede);
  font-weight: var(--fw-regular);
  margin-right: var(--space-4);
}

.promo-offer .new-price {
  font-family: var(--font-serif);
  font-size: var(--fs-h1);
  font-weight: var(--fw-medium);
  color: var(--clay-deep);
  letter-spacing: -0.02em;
}

.promo-offer > p {
  margin: var(--space-2) 0 0 !important;
  color: var(--moss) !important;
  font-family: var(--font-mono) !important;
  font-size: var(--fs-mono) !important;
  letter-spacing: var(--ls-mono) !important;
  text-transform: uppercase;
  font-style: normal !important;
}

.countdown {
  display: flex;
  justify-content: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}

.countdown-item {
  background-color: rgba(238, 240, 236, 0.06);
  border: 1px solid rgba(238, 240, 236, 0.14);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius);
  min-width: 84px;
}

.countdown-value {
  font-family: var(--font-serif);
  font-size: var(--fs-h2);
  font-weight: var(--fw-medium);
  line-height: 1;
  color: var(--oyster);
  letter-spacing: -0.02em;
}

.countdown-label {
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--ls-mono);
  text-transform: uppercase;
  color: rgba(238, 240, 236, 0.65);
  margin-top: var(--space-3);
}

.btn-promo {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--btn-padding-y) calc(var(--btn-padding-x) * 1.4);
  border-radius: var(--btn-radius);
  background-color: var(--clay);
  border: 1px solid var(--clay);
  color: var(--oyster);
  font-family: var(--font-sans);
  font-weight: var(--fw-medium);
  font-size: var(--fs-body);
  cursor: pointer;
  transition: var(--transition-fast);
  text-decoration: none;
}

.btn-promo:hover {
  opacity: var(--btn-hover-opacity);
  color: var(--oyster);
}

.promo-banner > .promo-guarantee {
  font-family: var(--font-mono);
  font-size: var(--fs-mono);
  letter-spacing: var(--ls-mono);
  text-transform: uppercase;
  margin-top: var(--space-5);
  margin-bottom: 0;
  opacity: 0.8;
  font-style: normal;
}

@media (max-width: 640px) {
  .promo-banner { padding: var(--space-8) var(--space-5); }
  .countdown { gap: var(--space-3); }
  .countdown-item { min-width: 66px; padding: var(--space-3); }
  .countdown-value { font-size: var(--fs-h3); }
  .promo-offer .new-price { font-size: var(--fs-h2); }
}

.promo-confetti {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 999;
}

/* ==========================================================================
   Claim modal — promotion-specific bits (modal base lives in style.css)
   ========================================================================== */

.coupon-code {
  font-family: var(--font-mono);
  font-size: var(--fs-h4);
  letter-spacing: 0.1em;
  color: var(--clay-deep);
  background-color: rgba(178, 105, 74, 0.08);
  border: 1px dashed var(--clay);
  border-radius: var(--radius);
  padding: var(--space-5) var(--space-6);
  margin: 0 0 var(--space-6);
  user-select: all;
}
