/* /pricing page styles. Added in t155 (pricing redesign).
   Scoped to the in-app /pricing route. The public landing carries its
   own inline copy in resources/public/landing-prelaunch.html. */

/* PricingPanel toolbar (t290): MONTHLY/YEARLY on the left, PLANS/CALCULATOR
   pinned to the right, both stretched to the same height so the SAVE 30%
   chip on the cycle toggle doesn't leave the two controls mismatched. */
.pricing-panel__toolbar {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: var(--space-3);
  max-width: 1080px;
  margin: 0 auto var(--space-6) auto;
}

.pricing-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  max-width: 1080px;
  margin-inline: auto;
}

@media (min-width: 720px) {
  .pricing-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.pricing-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  min-width: 0;
  position: relative;
}

.pricing-card__price-line {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin: 0;
}

.pricing-card__price-big {
  font-family: var(--font-sans);
  font-size: var(--text-4xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-tight);
  color: var(--color-text);
}

.pricing-card__price-suffix {
  font-family: var(--font-mono);
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
}

.pricing-card__disclosure {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0;
}

.pricing-card__capacity {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  margin: 0;
}

.pricing-card__capacity-eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin: 0 0 var(--space-1) 0;
}

.pricing-card__capacity-row {
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  margin: 0;
  line-height: var(--leading-tight);
}

.pricing-card__capacity-num {
  color: var(--color-accent);
  font-weight: var(--weight-bold);
  display: inline-block;
  min-width: 3rem;
}

.pricing-disclaimer {
  margin: var(--space-4) 0 0 0;
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  max-width: 60ch;
}

.credits-calculator {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-6);
  border: 1px solid var(--color-border);
  border-radius: var(--chamfer-md, 10px);
  background: var(--color-bg-surface);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.credits-calculator__intro {
  margin: 0;
  font-size: var(--text-base);
  color: var(--color-text-muted);
}

.credits-calculator .segmented {
  align-self: flex-start;
}

.credits-calculator__rows {
  display: flex;
  flex-direction: column;
  gap: var(--space-5);
  margin-top: var(--space-2);
}

.calc-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.calc-row--disabled {
  opacity: 0.4;
}

.calc-row__head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  font-family: var(--font-sans);
}

.calc-row__label-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.calc-row__label {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-text);
}

.calc-row__hint {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
}

.calc-row__value {
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  color: var(--color-accent);
  min-width: 3ch;
  text-align: right;
}

.calc-row__cost {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text-muted);
  min-width: 6ch;
  text-align: right;
}

.calc-row__slider {
  width: 100%;
  accent-color: var(--color-accent);
  cursor: pointer;
}

.calc-row__slider:disabled {
  cursor: not-allowed;
}

.credits-calculator__total {
  margin-top: var(--space-2);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
  color: var(--color-text);
}

.credits-calculator__total-num {
  font-family: var(--font-sans);
  font-size: var(--text-2xl);
  font-weight: var(--weight-bold);
  color: var(--color-accent);
  margin-right: var(--space-2);
  letter-spacing: var(--tracking-normal);
  text-transform: none;
}

.credits-calculator__total--over .credits-calculator__total-num {
  color: var(--color-error, #b91c1c);
}

.credits-calculator__over {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-error, #b91c1c);
}

.pricing-card__features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  flex: 1;
}

.pricing-card__features li {
  font-size: var(--text-base);
  color: var(--color-text);
}

.pricing-card__divider {
  height: 1px;
  background: var(--color-border);
  width: 100%;
  margin: var(--space-2) 0;
}

.pricing-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  white-space: nowrap;
}

.pricing-chip--toggle {
  margin-left: var(--space-2);
  background: var(--color-accent);
  color: var(--color-text-on-accent);
}

.pricing-chip--popular {
  background: var(--color-accent);
  color: var(--color-text-on-accent);
  position: absolute;
  top: 0;
  right: var(--space-6);
  transform: translateY(-50%);
}

.pricing-chip--save {
  background: var(--color-bg-surface);
  color: var(--color-text);
  border: 1px solid var(--color-text);
  position: absolute;
  top: 0;
  left: var(--space-6);
  transform: translateY(-50%);
}
