/* ===== Shared Pricing Card Styles (for/ landing pages) ===== */

/* --- Page Hero --- */
.for-hero {
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-mid) 100%);
  color: #fff;
  padding: 64px 0 48px;
  text-align: center;
}
.for-hero .hero-tagline {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.6);
  margin-bottom: 12px;
}
.for-hero h1 {
  font-family: var(--font-sans);
  font-size: 2.4rem;
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 16px;
  color: #fff;
}
.for-hero .hero-subtitle {
  font-family: var(--font-sans);
  font-size: 1.1rem;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.85);
  max-width: 700px;
  margin: 0 auto 24px;
}
.for-hero .hero-cta {
  display: inline-block;
  background: #fff;
  color: var(--color-navy);
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: 1rem;
  padding: 14px 32px;
  border-radius: var(--radius);
  text-decoration: none;
  transition: background var(--transition), transform var(--transition);
}
.for-hero .hero-cta:hover {
  background: #f0f2f5;
  transform: translateY(-2px);
}

/* --- Pricing Grid --- */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  max-width: 1060px;
  margin: 0 auto;
  padding: 0 24px;
}
.pricing-grid-2 {
  grid-template-columns: repeat(2, 1fr);
  max-width: 780px;
}

/* --- Pricing Card --- */
.pricing-card {
  background: var(--color-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 36px 28px;
  text-align: center;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: box-shadow var(--transition), transform var(--transition);
}
.pricing-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

/* Featured / recommended card */
.pricing-card-featured {
  border-color: var(--color-navy);
  box-shadow: var(--shadow-md);
}
.pricing-card-featured::before {
  content: attr(data-badge);
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-accent) 100%);
  color: #fff;
  font-family: var(--font-sans);
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 16px;
  border-radius: 20px;
  white-space: nowrap;
}

/* Gold accent variant (for Patron, sponsors) */
.pricing-card-gold {
  border-color: var(--color-gold);
}
.pricing-card-gold::before {
  background: linear-gradient(135deg, var(--color-gold) 0%, var(--color-gold-light) 100%);
  color: var(--color-navy);
}

/* --- Card Inner Elements --- */
.pricing-name {
  font-family: var(--font-sans);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-navy);
  margin-bottom: 8px;
}
.pricing-amount {
  font-family: var(--font-sans);
  font-size: 2.2rem;
  font-weight: 800;
  color: var(--color-navy);
  margin-bottom: 4px;
}
.pricing-period {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: var(--color-muted);
  margin-bottom: 20px;
}
.pricing-desc {
  font-family: var(--font-sans);
  font-size: 0.85rem;
  color: var(--color-muted);
  line-height: 1.5;
  margin-bottom: 20px;
}

/* --- Feature List --- */
.pricing-features {
  list-style: none;
  text-align: left;
  margin-bottom: 24px;
  flex: 1;
}
.pricing-features li {
  font-family: var(--font-sans);
  font-size: 0.88rem;
  color: var(--color-body);
  padding: 6px 0 6px 24px;
  position: relative;
  line-height: 1.4;
}
.pricing-features li::before {
  content: "\2713";
  position: absolute;
  left: 0;
  color: var(--color-green);
  font-weight: 700;
}
/* Dimmed / not-included items */
.pricing-features li.dim {
  color: var(--color-light);
}
.pricing-features li.dim::before {
  content: "\2014";
  color: var(--color-light);
}

/* --- CTA Buttons --- */
.pricing-cta {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 0.95rem;
  font-weight: 700;
  padding: 12px 28px;
  border-radius: var(--radius);
  text-decoration: none;
  text-align: center;
  transition: background var(--transition), transform var(--transition);
  margin-top: auto;
}
.pricing-cta-primary {
  background: var(--color-navy);
  color: #fff;
}
.pricing-cta-primary:hover {
  background: var(--color-accent);
  transform: translateY(-1px);
}
.pricing-cta-outline {
  background: transparent;
  color: var(--color-navy);
  border: 2px solid var(--color-navy);
}
.pricing-cta-outline:hover {
  background: var(--color-navy);
  color: #fff;
  transform: translateY(-1px);
}
.pricing-cta-gold {
  background: var(--color-gold);
  color: var(--color-navy);
}
.pricing-cta-gold:hover {
  background: var(--color-gold-light);
  transform: translateY(-1px);
}

/* --- Section Wrapper --- */
.pricing-section {
  padding: 48px 0 64px;
  background: var(--color-bg);
}
.pricing-section h2 {
  text-align: center;
  font-family: var(--font-sans);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--color-navy);
  margin-bottom: 12px;
}
.pricing-section .section-subtitle {
  text-align: center;
  font-family: var(--font-sans);
  font-size: 1rem;
  color: var(--color-muted);
  margin-bottom: 36px;
}

/* --- Add-on / Callout Card --- */
.pricing-callout {
  max-width: 700px;
  margin: 24px auto 0;
  padding: 20px 28px;
  background: var(--color-card);
  border-left: 4px solid var(--color-accent);
  border-radius: var(--radius);
  font-family: var(--font-sans);
  font-size: 0.9rem;
  color: var(--color-body);
  line-height: 1.5;
}

/* --- Bottom CTA Banner --- */
.for-cta-banner {
  background: linear-gradient(135deg, var(--color-navy) 0%, var(--color-mid) 100%);
  color: #fff;
  text-align: center;
  padding: 48px 24px;
}
.for-cta-banner h2 {
  font-family: var(--font-sans);
  font-size: 1.8rem;
  font-weight: 800;
  margin-bottom: 12px;
  color: #fff;
}
.for-cta-banner p {
  font-family: var(--font-sans);
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.8);
  margin-bottom: 24px;
}
.for-cta-banner .pricing-cta-primary {
  background: #fff;
  color: var(--color-navy);
}
.for-cta-banner .pricing-cta-primary:hover {
  background: #f0f2f5;
}

/* --- Responsive --- */
@media (max-width: 768px) {
  .pricing-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
  }
  .pricing-grid-2 {
    max-width: 400px;
  }
  .for-hero h1 {
    font-size: 1.8rem;
  }
}
