/* ============================================================
   pricing.css — styles for the /pricing page only.
   Loaded via the route's `css` list in marketing/build.mjs.
   Uses the shared design tokens from /assets/wm-tokens.css.
   ============================================================ */

/* ============ HERO ============ */
.pricing-hero { padding: 80px 0 48px; text-align: center; }
.pricing-hero .section-eyebrow { margin-bottom: 18px; }
.pricing-title {
  font-family: var(--sl-serif);
  font-weight: 400;
  font-size: clamp(44px, 6.2vw, 76px);
  line-height: 1.0;
  letter-spacing: -2.2px;
  color: var(--sl-ink);
  margin: 0 auto 24px;
  max-width: 16ch;
  text-wrap: balance;
}
.pricing-title em { font-style: normal; color: var(--wm-primary); }
.pricing-sub {
  font: 400 17px/1.55 var(--sl-sans);
  color: var(--sl-mute);
  max-width: 52ch;
  margin: 0 auto;
  text-wrap: pretty;
}

/* billing toggle */
.bill-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  margin: 36px auto 0;
  background: var(--sl-bg-2);
  border: 0.5px solid var(--sl-hair);
  border-radius: 9999px;
  padding: 4px;
}
.bill-toggle button {
  appearance: none; border: none; cursor: pointer;
  background: transparent;
  font: 600 13px/1 var(--sl-sans);
  letter-spacing: 0.2px;
  color: var(--sl-mute);
  padding: 9px 18px;
  border-radius: 9999px;
  display: inline-flex; align-items: center; gap: 8px;
  transition: color 200ms ease, background 200ms ease, box-shadow 200ms ease;
}
.bill-toggle button.active {
  background: var(--sl-panel);
  color: var(--sl-ink);
  box-shadow: 0 1px 2px rgba(10,14,28,0.06), 0 4px 12px -6px rgba(10,14,28,0.18);
}
.bill-toggle .save-tag {
  font: 600 9px/1 var(--sl-sans);
  letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--wm-green-2);
  background: rgba(101,196,102,0.12);
  border: 0.5px solid rgba(101,196,102,0.2);
  padding: 3px 6px; border-radius: 9999px;
}

/* ============ CARD GRID ============ */
.pricing-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  align-items: stretch;
  margin-top: 64px;
}
@media (max-width: 980px) {
  .pricing-grid { grid-template-columns: 1fr; max-width: 460px; margin-left: auto; margin-right: auto; gap: 20px; }
}

.tier {
  position: relative;
  background: var(--sl-panel);
  border: 0.5px solid var(--sl-hair);
  border-radius: 16px;
  padding: 34px 32px 34px;
  display: flex; flex-direction: column;
  box-shadow: 0 1px 2px rgba(10,14,28,0.04), 0 16px 40px -18px rgba(10,14,28,0.10);
}
.tier.featured {
  border: 1px solid rgba(0,123,255,0.35);
  box-shadow:
    0 1px 2px rgba(10,14,28,0.04),
    0 24px 60px -16px rgba(0,123,255,0.22);
}
@media (min-width: 981px) {
  .tier.featured { transform: translateY(-12px); }
}
.tier-flag {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  background: var(--wm-primary);
  color: #fff;
  font: 600 10px/1 var(--sl-sans);
  text-transform: uppercase; letter-spacing: 1.2px;
  padding: 6px 12px; border-radius: 9999px;
  white-space: nowrap;
  box-shadow: 0 6px 16px -6px rgba(0,123,255,0.5);
}

.tier-name {
  font-family: var(--sl-serif);
  font-weight: 400;
  font-size: 27px;
  letter-spacing: -0.6px;
  color: var(--sl-ink);
  margin-bottom: 6px;
  display: inline-flex; align-items: center; gap: 10px;
}
.tier-name .pro-badge {
  background: linear-gradient(90deg, var(--wm-amber), var(--wm-orange));
  color: #fff;
  font-family: var(--sl-sans);
  font-size: 10px; font-weight: 600; letter-spacing: 0.8px;
  padding: 4px 7px; border-radius: 4px;
}
.tier-tagline {
  font: 400 14px/1.5 var(--sl-sans);
  color: var(--sl-mute);
  margin: 0 0 24px;
  min-height: 42px;
  text-wrap: pretty;
}

.tier-price {
  display: flex; align-items: baseline; gap: 4px;
  margin-bottom: 4px;
}
.tier-price .amount {
  font-family: var(--sl-serif);
  font-weight: 400;
  font-size: 52px;
  line-height: 1;
  letter-spacing: -2px;
  color: var(--sl-ink);
}
.tier-price .currency {
  font-family: var(--sl-serif);
  font-size: 26px;
  color: var(--sl-ink);
  align-self: flex-start;
  margin-top: 6px;
}
.tier-price .period {
  font: 500 13px/1 var(--sl-sans);
  color: var(--sl-mute-2);
  margin-left: 4px;
}
.tier-price .custom {
  font-family: var(--sl-serif);
  font-weight: 400;
  font-size: 38px;
  letter-spacing: -1px;
  color: var(--sl-ink);
}
.tier-billed {
  font: 400 12px/1.4 var(--sl-sans);
  color: var(--sl-mute-2);
  margin: 0 0 26px;
  min-height: 17px;
}

.tier-cta {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%;
  min-height: 48px;
  padding: 14px 18px;
  border-radius: 8px;
  font: 600 14px/1 var(--sl-sans);
  letter-spacing: 0.2px;
  cursor: pointer; border: none;
  margin-bottom: 28px;
  transition: transform 200ms ease, background 200ms ease, box-shadow 200ms ease, color 200ms ease;
}
.tier-cta:active { transform: scale(0.985); }
.tier-cta svg { width: 15px; height: 15px; stroke-width: 2.2; }
.tier-cta.primary { background: var(--wm-primary); color: #fff; }
.tier-cta.primary:hover { background: #0066d6; }
.tier-cta.ghost {
  background: transparent; color: var(--sl-ink);
  box-shadow: inset 0 0 0 1px var(--sl-hair);
}
.tier-cta.ghost:hover { box-shadow: inset 0 0 0 1px var(--sl-ink); }
.tier-cta.dark { background: var(--sl-ink); color: #fff; }
.tier-cta.dark:hover { background: #000; }

.tier-feats-label {
  font: 500 10px/1 var(--sl-sans);
  text-transform: uppercase; letter-spacing: 1.6px;
  color: var(--sl-mute-2);
  margin-bottom: 16px;
}
.tier-feats { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.tier-feats li {
  display: flex; align-items: flex-start; gap: 11px;
  font: 400 14px/1.5 var(--sl-sans);
  color: var(--sl-ink-2);
  text-wrap: pretty;
}
.tier-feats li .ic {
  flex-shrink: 0; margin-top: 1px;
  width: 18px; height: 18px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}
.tier-feats li .ic svg { width: 11px; height: 11px; stroke-width: 3; }
.tier-feats li.yes .ic { background: rgba(101,196,102,0.14); color: var(--wm-green-2); }
.tier-feats li.muted .ic { background: var(--sl-bg-2); color: var(--sl-mute-2); box-shadow: inset 0 0 0 0.5px var(--sl-hair); }
.tier-feats li.muted { color: var(--sl-mute); }
.tier-feats li b { font-weight: 600; color: var(--sl-ink); }

/* ============ COMPARISON TABLE ============ */
.compare { padding: 130px 0 40px; }
.compare-wrap {
  overflow-x: auto;
  border: 0.5px solid var(--sl-hair);
  border-radius: 16px;
  background: var(--sl-panel);
  box-shadow: 0 1px 2px rgba(10,14,28,0.04), 0 18px 50px -28px rgba(10,14,28,0.12);
}
table.compare-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 640px;
}
.compare-table th, .compare-table td {
  text-align: left;
  padding: 18px 24px;
  border-bottom: 0.5px solid var(--sl-hair);
}
.compare-table thead th { border-bottom: 0.5px solid var(--sl-hair); }
.compare-table tr:last-child td { border-bottom: none; }
.compare-table .col-feature { width: 40%; }
.compare-table thead .col-tier {
  text-align: center;
  font-family: var(--sl-serif);
  font-weight: 400;
  font-size: 20px;
  letter-spacing: -0.4px;
  color: var(--sl-ink);
}
.compare-table thead .col-tier.pro { color: var(--wm-primary); }
.compare-table thead .col-feature {
  font: 500 10px/1 var(--sl-sans);
  text-transform: uppercase; letter-spacing: 1.6px;
  color: var(--sl-mute-2);
}
.compare-table tbody .row-group td {
  background: var(--sl-bg-2);
  font: 500 10px/1 var(--sl-sans);
  text-transform: uppercase; letter-spacing: 1.6px;
  color: var(--sl-mute-2);
  padding: 12px 24px;
}
.compare-table tbody .feat {
  font: 400 14px/1.4 var(--sl-sans);
  color: var(--sl-ink-2);
}
.compare-table tbody .feat .feat-name {
  display: inline-flex; align-items: center; gap: 7px;
}
.feat-info {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  width: 16px; height: 16px;
  color: var(--sl-mute-2);
  cursor: help;
  border-radius: 50%;
  transition: color 160ms ease, background 160ms ease;
}
.feat-info svg { width: 14px; height: 14px; stroke-width: 2; }
.feat-info:hover, .feat-info:focus-visible {
  color: var(--wm-primary);
  background: rgba(0,123,255,0.10);
  outline: none;
}

/* floating tooltip (attached to body) */
.feat-tip {
  position: fixed;
  z-index: 9999;
  max-width: 260px;
  background: var(--sl-ink);
  color: #fff;
  font: 400 12.5px/1.45 var(--sl-sans);
  text-wrap: pretty;
  padding: 10px 12px;
  border-radius: 9px;
  box-shadow: 0 10px 30px -8px rgba(10,14,28,0.45);
  pointer-events: none;
  opacity: 0;
  transform: translateY(3px);
  transition: opacity 140ms ease, transform 140ms ease;
}
.feat-tip.show { opacity: 1; transform: translateY(0); }
.feat-tip::after {
  content: "";
  position: absolute;
  left: var(--arrow-x, 50%);
  width: 9px; height: 9px;
  background: var(--sl-ink);
  transform: translateX(-50%) rotate(45deg);
}
.feat-tip.below::after { top: -4px; }
.feat-tip.above::after { bottom: -4px; }
.compare-table tbody td.cell { text-align: center; }
.compare-table tbody td.cell.pro-col { background: rgba(0,123,255,0.03); }
.cmp-yes { color: var(--wm-green-2); display: inline-flex; }
.cmp-yes svg { width: 18px; height: 18px; stroke-width: 2.4; }
.cmp-no { color: var(--sl-mute-2); font-size: 18px; line-height: 1; }
.cmp-text {
  font: 500 12.5px/1.3 var(--sl-sans);
  color: var(--sl-ink-2);
}
.cmp-text.dim { color: var(--sl-mute); }

/* ============ PRICING FAQ ============ */
.pricing-faq { padding: 100px 0 40px; }

@media (max-width: 560px) {
  .tier { padding: 30px 24px; }
  .bill-toggle { flex-wrap: wrap; }
}
