/* ============================================================
   Pricing Page Styles — matches landing page aesthetic
   ============================================================ */

/* ── Hero ── */
.pricing-hero {
  position: relative;
  padding: 90px 32px 64px;
  overflow: hidden;
  background: var(--white);
  border-bottom: 1px solid var(--border);
  text-align: center;
}
.pricing-hero-bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.pricing-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(79,70,229,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(79,70,229,0.04) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse at center top, black 30%, transparent 70%);
}
.pricing-hero-blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  animation: float-blob 14s ease-in-out infinite;
}
.pricing-hero-blob-1 {
  width: 480px;
  height: 480px;
  background: rgba(124,58,237,0.18);
  top: -120px;
  left: -100px;
}
.pricing-hero-blob-2 {
  width: 520px;
  height: 520px;
  background: rgba(168,85,247,0.14);
  bottom: -200px;
  right: -100px;
  animation-delay: -7s;
}
.pricing-hero-inner {
  position: relative;
  max-width: 720px;
  margin: 0 auto;
}
.pricing-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border: 1px solid rgba(79,70,229,0.2);
  background: rgba(255,255,255,0.7);
  backdrop-filter: blur(8px);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: var(--brand);
  letter-spacing: 0.4px;
}
.pricing-hero-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  animation: pulse-soft 1.6s infinite;
}
.pricing-hero-h1 {
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 800;
  letter-spacing: -2px;
  line-height: 1.05;
  margin: 22px 0 14px;
}
.pricing-hero-accent {
  background: var(--grad-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.pricing-hero-p {
  font-size: 18px;
  color: var(--muted);
  line-height: 1.6;
  max-width: 540px;
  margin: 0 auto;
}

/* ── Tier Ladder ── */
.pricing-tiers {
  padding: 64px 24px;
  background: var(--bg);
}
.pricing-inner {
  max-width: 960px;
  margin: 0 auto;
}
.pricing-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 1.2px;
  color: var(--brand);
  text-align: center;
  margin-bottom: 8px;
}
.pricing-section-title {
  font-size: 28px;
  font-weight: 700;
  text-align: center;
  margin-bottom: 40px;
  letter-spacing: -0.5px;
}

.tier-ladder {
  max-width: 640px;
  margin: 0 auto 48px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* Tier row — matches checkout PricingBreakdown visual language */
.tier-row {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 16px 20px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow-sm);
  transition: box-shadow 0.2s, transform 0.15s;
}
.tier-row:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.08);
  transform: translateY(-1px);
}

/* Free tier — green accent */
.tier-row.tier-free {
  border-left: 3px solid #10b981;
}
.tier-row.tier-free .tier-range {
  color: #065f46;
}
.tier-row.tier-free .tier-price {
  color: #10b981;
}
.tier-row.tier-free .tier-bar-fill {
  background: #10b981;
}
.tier-row.tier-free .tier-bar-track {
  background: rgba(16,185,129,0.12);
}

/* Paid tiers — blue-purple gradient color coding (cycles through palette) */
.tier-row.tier-paid-0 {
  border-left: 3px solid #667eea;
}
.tier-row.tier-paid-0 .tier-range { color: #3730a3; }
.tier-row.tier-paid-0 .tier-price { color: #667eea; }
.tier-row.tier-paid-0 .tier-bar-fill { background: #667eea; }
.tier-row.tier-paid-0 .tier-bar-track { background: rgba(102,126,234,0.12); }

.tier-row.tier-paid-1 {
  border-left: 3px solid #6366f1;
}
.tier-row.tier-paid-1 .tier-range { color: #3730a3; }
.tier-row.tier-paid-1 .tier-price { color: #6366f1; }
.tier-row.tier-paid-1 .tier-bar-fill { background: #6366f1; }
.tier-row.tier-paid-1 .tier-bar-track { background: rgba(99,102,241,0.12); }

.tier-row.tier-paid-2 {
  border-left: 3px solid #8b5cf6;
}
.tier-row.tier-paid-2 .tier-range { color: #5b21b6; }
.tier-row.tier-paid-2 .tier-price { color: #8b5cf6; }
.tier-row.tier-paid-2 .tier-bar-fill { background: #8b5cf6; }
.tier-row.tier-paid-2 .tier-bar-track { background: rgba(139,92,246,0.12); }

.tier-row.tier-paid-3 {
  border-left: 3px solid #7c3aed;
}
.tier-row.tier-paid-3 .tier-range { color: #5b21b6; }
.tier-row.tier-paid-3 .tier-price { color: #7c3aed; }
.tier-row.tier-paid-3 .tier-bar-fill { background: #7c3aed; }
.tier-row.tier-paid-3 .tier-bar-track { background: rgba(124,58,237,0.12); }

/* Tier row inner layout */
.tier-row-top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.tier-range {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  min-width: 140px;
}
.tier-price {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--brand);
}
.tier-desc {
  font-size: 12px;
  color: var(--muted);
  text-align: right;
  margin-left: auto;
}

/* Tier bar — animated fill matching checkout breakdown */
.tier-bar-track {
  height: 6px;
  border-radius: 3px;
  overflow: hidden;
  margin-top: 2px;
  background: rgba(99,102,241,0.12);
}
.tier-bar-fill {
  height: 100%;
  border-radius: 3px;
  width: 0;
  background: var(--brand);
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1);
}

/* Running cumulative total display */
.tier-cumulative {
  font-size: 11px;
  color: var(--muted);
  font-style: italic;
  text-align: right;
}

/* ── Free Preview Banner ── */
.tier-free-preview {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  padding: 32px 24px;
  background: linear-gradient(135deg, rgba(34,197,94,0.06), rgba(79,70,229,0.06));
  border: 1px solid rgba(34,197,94,0.2);
  border-radius: var(--radius);
}
.tier-free-icon {
  font-size: 40px;
  margin-bottom: 12px;
}
.tier-free-title {
  font-size: 20px;
  font-weight: 700;
  margin-bottom: 8px;
  color: var(--text);
}
.tier-free-text {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
  max-width: 480px;
  margin: 0 auto;
}

/* ── Satisfaction Guarantee ── */
.pricing-guarantee {
  padding: 64px 24px;
  background: var(--white);
  border-top: 1px solid var(--border);
}
.guarantee-card {
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
}
.guarantee-icon {
  font-size: 48px;
  margin-bottom: 16px;
}
.guarantee-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 14px;
  letter-spacing: -0.5px;
}
.guarantee-text {
  font-size: 16px;
  color: var(--muted);
  line-height: 1.6;
  margin-bottom: 24px;
}
.guarantee-list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  text-align: left;
  display: inline-block;
}
.guarantee-list li {
  font-size: 15px;
  color: var(--text);
  line-height: 1.8;
  padding-left: 24px;
  position: relative;
}
.guarantee-list li::before {
  content: '✓';
  position: absolute;
  left: 0;
  color: var(--brand);
  font-weight: 700;
}
.guarantee-list li strong {
  font-weight: 600;
}
.guarantee-bottom {
  font-size: 15px;
  color: var(--muted);
  line-height: 1.6;
}

/* ── CTA Section ── */
.pricing-cta {
  padding: 64px 24px;
  text-align: center;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.pricing-cta-inner {
  max-width: 480px;
  margin: 0 auto;
}
.pricing-cta h2 {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
  letter-spacing: -0.5px;
}
.pricing-cta-btn {
  display: inline-block;
  padding: 12px 32px;
  background: var(--brand);
  color: #fff;
  font-size: 15px;
  font-weight: 600;
  border-radius: 999px;
  text-decoration: none;
  transition: opacity 0.2s;
}
.pricing-cta-btn:hover {
  opacity: 0.9;
}

/* ── Calculator Widget ── */
.pricing-calculator {
  padding: 64px 24px;
  background: var(--bg);
  border-top: 1px solid var(--border);
}
.pricing-calc-subtitle {
  font-size: 16px;
  color: var(--muted);
  text-align: center;
  margin-bottom: 32px;
}
.pricing-calc-widget {
  max-width: 640px;
  margin: 0 auto;
}
.pricing-calc-input-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 24px;
}
.pricing-calc-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
}
.pricing-calc-input {
  flex: 1;
  padding: 10px 14px;
  font-size: 15px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--white);
  color: var(--text);
  outline: none;
  transition: border-color 0.2s;
}
.pricing-calc-input:focus {
  border-color: var(--brand);
}
.pricing-calc-btn {
  padding: 10px 24px;
  font-size: 14px;
  font-weight: 600;
  color: #fff;
  background: var(--brand);
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  transition: opacity 0.2s;
}
.pricing-calc-btn:hover {
  opacity: 0.9;
}
.pricing-calc-result {
  min-height: 80px;
}

/* ── PricingBreakdown overrides for calculator ── */
.pb-loading {
  text-align: center;
  padding: 24px;
  color: var(--muted);
  font-size: 14px;
}
.pb-empty {
  text-align: center;
  padding: 24px;
  color: var(--muted);
  font-size: 14px;
}
.pb-header {
  font-size: 15px;
  color: var(--muted);
  margin-bottom: 16px;
}
.pb-header strong {
  color: var(--text);
}
.pb-tier-row {
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}
.pb-tier-row:last-child {
  border-bottom: none;
}
.pb-tier-info {
  display: flex;
  justify-content: space-between;
  margin-bottom: 4px;
}
.pb-tier-label {
  font-size: 14px;
  font-weight: 600;
}
.pb-tier-subtotal {
  font-size: 14px;
  font-weight: 600;
}
.pb-tier-detail {
  display: flex;
  justify-content: space-between;
  font-size: 12px;
  color: var(--muted);
  margin-bottom: 6px;
}
.pb-tier-bar-track {
  height: 6px;
  border-radius: 3px;
  overflow: hidden;
}
.pb-tier-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.5s ease;
}
.pb-total-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 0 0;
  margin-top: 12px;
  border-top: 2px solid var(--border);
}
.pb-total-label {
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.pb-total-value {
  font-size: 24px;
  font-weight: 800;
  color: var(--brand);
  letter-spacing: -0.5px;
}

/* ── Dark mode ── */
[data-theme="dark"] .pricing-hero {
  background: var(--bg);
}
[data-theme="dark"] .pricing-hero-badge {
  background: rgba(31,41,55,0.7);
  border-color: rgba(99,102,241,0.3);
}
[data-theme="dark"] .tier-row {
  background: var(--white);
  box-shadow: 0 1px 3px rgba(0,0,0,.3), 0 4px 12px rgba(0,0,0,.25);
}
[data-theme="dark"] .tier-row:hover {
  box-shadow: 0 4px 20px rgba(0,0,0,.4);
}
/* Free tier — lighten text for dark bg */
[data-theme="dark"] .tier-row.tier-free .tier-range {
  color: #6ee7b7;
}
[data-theme="dark"] .tier-row.tier-free .tier-price {
  color: #34d399;
}
[data-theme="dark"] .tier-row.tier-free .tier-bar-fill {
  background: #34d399;
}
[data-theme="dark"] .tier-row.tier-free .tier-bar-track {
  background: rgba(16,185,129,0.2);
}
/* Paid tiers — lighten text for dark bg */
[data-theme="dark"] .tier-row.tier-paid-0 .tier-range {
  color: #a5b4fc;
}
[data-theme="dark"] .tier-row.tier-paid-0 .tier-price {
  color: #818cf8;
}
[data-theme="dark"] .tier-row.tier-paid-0 .tier-bar-fill {
  background: #818cf8;
}
[data-theme="dark"] .tier-row.tier-paid-0 .tier-bar-track {
  background: rgba(102,126,234,0.2);
}
[data-theme="dark"] .tier-row.tier-paid-1 .tier-range {
  color: #a5b4fc;
}
[data-theme="dark"] .tier-row.tier-paid-1 .tier-price {
  color: #818cf8;
}
[data-theme="dark"] .tier-row.tier-paid-1 .tier-bar-fill {
  background: #818cf8;
}
[data-theme="dark"] .tier-row.tier-paid-1 .tier-bar-track {
  background: rgba(99,102,241,0.2);
}
[data-theme="dark"] .tier-row.tier-paid-2 .tier-range {
  color: #c4b5fd;
}
[data-theme="dark"] .tier-row.tier-paid-2 .tier-price {
  color: #a78bfa;
}
[data-theme="dark"] .tier-row.tier-paid-2 .tier-bar-fill {
  background: #a78bfa;
}
[data-theme="dark"] .tier-row.tier-paid-2 .tier-bar-track {
  background: rgba(139,92,246,0.2);
}
[data-theme="dark"] .tier-row.tier-paid-3 .tier-range {
  color: #c4b5fd;
}
[data-theme="dark"] .tier-row.tier-paid-3 .tier-price {
  color: #a78bfa;
}
[data-theme="dark"] .tier-row.tier-paid-3 .tier-bar-fill {
  background: #a78bfa;
}
[data-theme="dark"] .tier-row.tier-paid-3 .tier-bar-track {
  background: rgba(124,58,237,0.2);
}
[data-theme="dark"] .tier-desc {
  color: var(--muted);
}
[data-theme="dark"] .tier-cumulative {
  color: var(--muted);
}
[data-theme="dark"] .tier-free-preview {
  background: linear-gradient(135deg, rgba(34,197,94,0.1), rgba(79,70,229,0.1));
}
[data-theme="dark"] .tier-free-title {
  color: var(--text);
}
[data-theme="dark"] .pricing-calculator {
  background: var(--white);
}
[data-theme="dark"] .pricing-calc-input {
  background: var(--bg);
  border-color: var(--border);
  color: var(--text);
}
[data-theme="dark"] .pricing-calc-btn {
  background: var(--brand);
}
[data-theme="dark"] .pricing-guarantee {
  background: var(--bg);
}
[data-theme="dark"] .guarantee-title {
  color: var(--text);
}
[data-theme="dark"] .guarantee-list li {
  color: var(--text);
}
[data-theme="dark"] .guarantee-bottom {
  color: var(--muted);
}
[data-theme="dark"] .pricing-cta {
  background: var(--white);
}
[data-theme="dark"] .pricing-cta-btn {
  background: var(--brand);
}
/* PricingBreakdown dark mode overrides */
[data-theme="dark"] .pb-tier-label {
  color: var(--text);
}
[data-theme="dark"] .pb-tier-subtotal {
  color: var(--text);
}
[data-theme="dark"] .pb-total-label {
  color: var(--text);
}
[data-theme="dark"] .pb-total-value {
  color: var(--brand);
}

/* ── Responsive ── */
@media (max-width: 640px) {
  .pricing-hero {
    padding: 72px 20px 48px;
  }
  .tier-row {
    padding: 14px 16px;
  }
  .tier-row-top {
    flex-wrap: wrap;
    gap: 4px;
  }
  .tier-range {
    min-width: 100px;
    font-size: 13px;
  }
  .tier-price {
    font-size: 14px;
  }
  .tier-desc {
    display: none;
  }
  .tier-cumulative {
    font-size: 10px;
  }
  .pricing-calc-input-row {
    flex-wrap: wrap;
  }
  .pricing-calc-label {
    width: 100%;
    margin-bottom: 4px;
  }
  .pricing-calc-input {
    min-width: 0;
    flex: 1;
  }
  .pricing-calc-btn {
    width: 100%;
  }
  .pricing-tiers {
    padding: 40px 16px;
  }
  .pricing-guarantee {
    padding: 40px 16px;
  }
  .pricing-cta {
    padding: 40px 16px;
  }
  .pricing-calculator {
    padding: 40px 16px;
  }
  .pricing-section-title {
    font-size: 22px;
    margin-bottom: 28px;
  }
  .tier-ladder {
    gap: 6px;
  }
  .tier-free-preview {
    padding: 24px 16px;
  }
  .guarantee-card {
    padding: 0 8px;
  }
  .pb-total-value {
    font-size: 20px;
  }
}
