/* FN SOLUTIONS — css/plans.css */
.plans {
  background: var(--bg-page)
}

.plans-controls {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 14px;
  margin-bottom: var(--space-6)
}

.plan-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  background: var(--bg-section-alt);
  border: 1px solid var(--border-light);
  padding: 4px;
  border-radius: var(--r-md)
}

.plan-tab {
  padding: 7px 13px;
  border-radius: var(--r-sm);
  font-size: .75rem;
  font-weight: 600;
  color: var(--text-muted);
  cursor: pointer;
  transition: all var(--t-base);
  border: none;
  background: none;
  white-space: nowrap
}

.plan-tab.active {
  background: var(--white);
  color: var(--accent-primary);
  box-shadow: var(--shadow-sm)
}

.plan-filter-label {
  font-size: .76rem;
  color: var(--text-secondary);
  font-weight: 500;
  align-self: center
}

.duration-pills {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-8)
}

.duration-pill {
  padding: 7px 14px;
  border-radius: var(--r-full);
  border: 1.5px solid var(--border-medium);
  font-size: .74rem;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all var(--t-base);
  background: var(--white);
  white-space: nowrap
}

.duration-pill:hover {
  border-color: var(--accent-primary);
  color: var(--accent-primary)
}

.duration-pill.active {
  background: var(--accent-primary);
  border-color: var(--accent-primary);
  color: var(--white);
  box-shadow: var(--shadow-brand)
}

.plans-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-5)
}

.plans-grid .plan-card.last-row-solo {
  grid-column: 2/3
}

@media(max-width:1024px) {
  .plans-grid {
    grid-template-columns: repeat(2, 1fr)
  }

  .plans-grid .plan-card.last-row-solo {
    grid-column: 1/-1;
    max-width: 440px;
    justify-self: center;
    width: 100%
  }
}

@media(max-width:560px) {
  .plans-grid {
    grid-template-columns: 1fr;
    gap: var(--space-4)
  }

  .plans-grid .plan-card.last-row-solo,
  .plans-grid .plan-card.last-row-pair {
    grid-column: auto;
    max-width: none;
    justify-self: auto
  }

  .plan-tabs {
    width: 100%
  }

  .plan-tab {
    flex: 1;
    text-align: center;
    padding: 7px 8px;
    font-size: .7rem
  }

  .duration-pill {
    font-size: .7rem;
    padding: 6px 11px
  }
}

.plan-card {
  background: var(--white);
  border: 1.5px solid var(--border-light);
  border-radius: var(--r-xl);
  padding: var(--space-8) var(--space-6);
  position: relative;
  transition: all var(--t-slow);
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column
}

.plan-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-xl);
  border-color: var(--border-brand-strong)
}

.plan-card.highlighted {
  border-color: var(--accent-primary);
  box-shadow: 0 0 0 2px var(--accent-primary), var(--shadow-xl)
}

.plan-popular-tag {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent-primary);
  color: var(--white);
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 4px 14px;
  border-radius: var(--r-full);
  white-space: nowrap;
  box-shadow: var(--shadow-brand)
}

.plan-tier-badge {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: var(--r-full);
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: var(--space-4);
  width: fit-content
}

.plan-card[data-tier="Silver"] .plan-tier-badge {
  background: var(--tier-silver-light);
  color: var(--tier-silver)
}

.plan-card[data-tier="Gold"] .plan-tier-badge {
  background: var(--tier-gold-light);
  color: var(--tier-gold)
}

.plan-card[data-tier="Gold Pro"] .plan-tier-badge {
  background: var(--tier-goldpro-light);
  color: var(--tier-goldpro)
}

.plan-card[data-tier="Diamond"] .plan-tier-badge {
  background: var(--tier-diamond-light);
  color: var(--tier-diamond)
}

.plan-card[data-tier="Diamond Pro"] .plan-tier-badge {
  background: var(--tier-diamondpro-light);
  color: var(--tier-diamondpro)
}

.plan-speed {
  font-family: var(--font-display);
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
  letter-spacing: -.03em;
  margin-bottom: 2px
}

.plan-speed-unit {
  font-size: .92rem;
  font-weight: 600;
  color: var(--text-muted)
}

.plan-speed-label {
  font-size: .72rem;
  color: var(--text-muted);
  margin-bottom: var(--space-4)
}

.plan-divider {
  height: 1px;
  background: var(--border-light);
  margin: var(--space-4) 0
}

.plan-duration {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: .76rem;
  font-weight: 500;
  color: var(--text-secondary);
  margin-bottom: var(--space-3)
}

.plan-price-row {
  display: flex;
  align-items: baseline;
  gap: 3px;
  margin-bottom: 4px
}

.plan-price-cur {
  font-size: .88rem;
  font-weight: 600;
  color: var(--accent-primary)
}

.plan-price-num {
  font-family: var(--font-display);
  font-size: 2.1rem;
  font-weight: 800;
  color: var(--accent-primary);
  line-height: 1;
  letter-spacing: -.03em
}

.plan-price-total {
  font-size: .72rem;
  color: var(--text-muted);
  margin-bottom: var(--space-5)
}

.plan-features {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-bottom: var(--space-6)
}

.plan-feat {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: .8rem;
  color: var(--text-secondary)
}

.pf-icon {
  width: 17px;
  height: 17px;
  border-radius: 50%;
  background: var(--accent-light);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .58rem;
  color: var(--accent-primary);
  flex-shrink: 0
}

@media(max-width:480px) {
  .plan-card {
    padding: var(--space-6) var(--space-5)
  }
}