.tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  padding: 0;
}

.tier {
  background: var(--white);
  border: 1px solid var(--hairline);
  padding: 40px 36px;
  display: flex;
  flex-direction: column;
  position: relative;
  transition:
    transform 320ms cubic-bezier(0.22, 0.61, 0.36, 1),
    border-color 240ms ease,
    box-shadow 320ms ease;
}

.tier::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--navy);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 480ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.tier:hover {
  transform: translateY(-6px);
  border-color: var(--navy);
  box-shadow: 0 30px 60px -32px rgba(27,42,74,0.32);
}

.tier:hover::before {
  transform: scaleX(1);
}

.tier .price .v {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* Reserve the final width of the counting digits so the price card
   doesn't reflow as the count goes from "0,000" to "10,000" / "100,000". */
.tier .price .v [data-count] {
  display: inline-block;
  min-width: 5.9ch;
  text-align: left;
}

.tier#counsellor .price .v [data-count] {
  min-width: 6.4ch;
}

.tier .num {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--muted);
}

.tier h3 {
  font-family: var(--ff-display);
  margin: 12px 0 8px;
  color: var(--navy);
  font-size: 32px;
  font-weight: 500;
  line-height: 1.1;
}

.tier .who {
  color: var(--ink-700);
  font-size: 14.5px;
  margin: 0 0 26px;
  max-width: 30ch;
}

.tier .price {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-bottom: 22px;
  margin-bottom: 22px;
  border-bottom: 1px solid var(--hairline);
}

.tier .price .v {
  font-family: var(--ff-display);
  font-size: clamp(34px, 5.4vw, 56px);
  color: var(--navy);
  line-height: 1;
  font-weight: 500;
}

.tier .price .u {
  font-family: var(--ff-mono);
  font-size: 12px;
  color: var(--muted);
  letter-spacing: 0.1em;
}

.tier ul {
  padding: 0;
  list-style: none;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.tier ul li {
  font-size: 14.5px;
  color: var(--ink-700);
  padding-left: 22px;
  position: relative;
}

.tier ul li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 9px;
  width: 12px;
  height: 1px;
  background: var(--gold-600);
}

.tier ul li b {
  color: var(--navy);
  font-weight: 500;
}

.tier .footnote {
  font-family: var(--ff-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.06em;
  margin: 16px 0 0;
}

.tier.feature {
  background: var(--navy);
  color: var(--cream);
  border-color: var(--navy);
}

.tier.feature::before {
  background: var(--gold);
  transform: scaleX(1);
}

.tier.feature:hover {
  transform: translateY(-8px);
  box-shadow: 0 36px 70px -32px rgba(27,42,74,0.55);
}

.tier.feature .num,
.tier.feature .who {
  color: rgba(245,237,214,0.7);
}

.tier.feature h3,
.tier.feature .price .v {
  color: var(--cream);
}

.tier.feature ul li {
  color: rgba(245,237,214,0.85);
}

.tier.feature ul li::before {
  background: var(--gold);
}

.tier.feature ul li b {
  color: var(--cream);
}

.tier.feature .footnote {
  color: rgba(245,237,214,0.5);
}

.tier.feature .price {
  border-bottom-color: rgba(245,237,214,0.18);
}

.tier .badge {
  position: absolute;
  top: 0;
  left: 36px;
  transform: translateY(-50%);
  background: var(--gold);
  color: var(--navy);
  font-family: var(--ff-mono);
  font-size: 10.5px;
  padding: 6px 14px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  z-index: 2;
  box-shadow:
    0 0 0 0 rgba(201,168,76,0.5),
    0 6px 14px -6px rgba(27,42,74,0.32);
  animation: badge-pulse 3.2s ease-out infinite;
}

@keyframes badge-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201,168,76,0.5); }
  50%      { box-shadow: 0 0 0 10px rgba(201,168,76,0); }
}

.addons {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--hairline);
  border: 1px solid var(--hairline);
}

.addon {
  background: var(--white);
  padding: 26px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
  transition: background 200ms ease;
}

.addon::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 2px;
  background: var(--gold);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform 360ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.addon:hover {
  background: var(--cream-50);
}

.addon:hover::after {
  transform: scaleX(1);
}

.addon .px {
  font-variant-numeric: tabular-nums;
}

.addon .n {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--gold-600);
}

.addon h4 {
  font-family: var(--ff-display);
  margin: 6px 0 4px;
  color: var(--navy);
  font-size: 22px;
  font-weight: 500;
}

.addon .px {
  font-family: var(--ff-display);
  font-size: 22px;
  color: var(--navy);
}

.addon p {
  color: var(--ink-700);
  margin: 6px 0 0;
  font-size: 14px;
  line-height: 1.55;
}

.compare-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--white);
  border: 1px solid var(--hairline);
}

.compare-table th,
.compare-table td {
  padding: 14px 18px;
  border-bottom: 1px solid var(--hairline-2);
  text-align: center;
  font-size: 14px;
  transition: background 200ms ease;
}

.compare-table tbody tr {
  transition: background 200ms ease;
}

.compare-table tbody tr:hover {
  background: var(--cream-50);
}

.compare-table th {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--muted);
  text-transform: uppercase;
  background: var(--cream-50);
  font-weight: 500;
}

.compare-table th:first-child,
.compare-table td:first-child {
  text-align: left;
}

.compare-table td:first-child {
  font-family: var(--ff-display);
  color: var(--navy);
}

.compare-plan-price {
  display: block;
  margin-top: 6px;
  font-family: var(--ff-display);
  font-size: 17px;
  color: var(--navy);
}

.compare-table .yes {
  color: var(--ok);
  font-family: var(--ff-mono);
}

.compare-table .no {
  color: var(--muted);
  font-family: var(--ff-mono);
}

.compare-table .feat {
  background: rgba(201,168,76,0.04);
}

.refund-card {
  padding: 36px;
  background: var(--cream-50);
  border: 1px solid var(--hairline);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
}

.refund-card h3 {
  font-family: var(--ff-display);
  margin: 10px 0 0;
  color: var(--navy);
  font-size: 26px;
  font-weight: 500;
}

.refund-copy {
  color: var(--ink-700);
  font-size: 15.5px;
  line-height: 1.65;
  max-width: 50ch;
  margin-top: 10px;
}

.refund-card .point {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  align-items: start;
  padding: 10px 12px;
  margin: -10px -12px;
  border-radius: 4px;
  transition: background 200ms ease, transform 240ms cubic-bezier(0.22, 0.61, 0.36, 1);
}

.refund-card .point:hover {
  background: var(--white);
  transform: translateX(4px);
}

.refund-card .point .n {
  font-family: var(--ff-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--gold-600);
  padding-top: 4px;
}

.refund-card .point p {
  margin: 0;
  color: var(--ink-700);
  font-size: 14px;
  line-height: 1.55;
}

.refund-card .point b {
  color: var(--navy);
}

@media (max-width: 980px) {
  .tiers,
  .addons,
  .refund-card {
    grid-template-columns: 1fr;
  }

  .compare-table {
    font-size: 12px;
  }
}
