/* Paywall — S/E/X/Y tier picker (TRK-512).
   Mounted by app/next/js/ui/paywall.js. Cards-grid layout sits inside the
   shared modal-panel primitive; only the cards/toggle/CTA visuals live here. */

.pw-host { padding: 4px 4px 8px; }

.pw-head {
  text-align: center;
  margin: 0 0 16px;
}
.pw-head h2 {
  font-size: var(--fs-xl, 17px);
  font-weight: 700;
  margin: 0 0 4px;
}
.pw-head p {
  font-size: var(--fs-sm, 12px);
  color: var(--muted);
  margin: 0;
}

.pw-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0 0 16px;
}
.pw-toggle-btn {
  font: inherit;
  padding: 5px 14px;
  border-radius: var(--r-md, 6px);
  font-size: var(--fs-xs, 11px);
  font-weight: 600;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--muted);
  cursor: pointer;
  transition: background 120ms, border-color 120ms, color 120ms;
}
.pw-toggle-btn.is-active {
  background: rgba(10, 88, 184, 0.10);   /* light tint of --accent */
  border-color: var(--accent);
  color: var(--accent);
}
.pw-toggle-btn:hover:not(.is-active) {
  border-color: var(--accent);
  color: var(--fg);
}
.pw-save-badge {
  font-size: 10px;
  font-weight: 700;
  color: #1a7a3e;
  background: rgba(26, 122, 62, 0.12);
  padding: 2px 7px;
  border-radius: var(--r-sm, 4px);
}

.pw-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 0 0 12px;
}
@media (max-width: 720px) {
  .pw-cards { grid-template-columns: repeat(2, 1fr); }
}

.pw-card {
  border: 1px solid var(--border);
  border-radius: var(--r-lg, 14px);
  padding: 16px 14px;
  display: flex;
  flex-direction: column;
  position: relative;
  background: var(--surface);
  transition: border-color 120ms;
}
.pw-card:hover { border-color: var(--accent); }
.pw-card.is-featured {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent);
}
.pw-card-badge {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  background: var(--accent);
  color: var(--accent-fg, #fff);
  padding: 2px 10px;
  border-radius: var(--r-sm, 4px);
  white-space: nowrap;
}
.pw-card-letter {
  font-size: 36px;
  font-weight: 800;
  line-height: 1;
  color: var(--accent);
  letter-spacing: -0.04em;
  margin: 0 0 4px;
}
.pw-card-fullname {
  font-size: 11px;
  font-weight: 500;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 0 0 8px;
}
.pw-card-fullname b { color: var(--fg); font-weight: 800; }
.pw-card-price {
  font-size: 22px;
  font-weight: 800;
  margin: 0 0 2px;
}
.pw-card-price small {
  font-size: 13px;
  font-weight: 500;
  color: var(--muted);
}
.pw-card-period {
  font-size: var(--fs-xs, 11px);
  color: var(--muted);
  margin: 0 0 14px;
}
.pw-card-features {
  list-style: none;
  flex: 1;
  margin: 0 0 16px;
  padding: 0;
}
.pw-card-features li {
  font-size: var(--fs-xs, 11px);
  padding: 3px 0;
  display: flex;
  align-items: center;
  gap: 7px;
}
.pw-card-features .feat-yes { color: #1a7a3e; font-weight: 700; }
.pw-card-features .feat-no  { color: var(--muted); opacity: 0.5; }

.pw-card-cta {
  font: inherit;
  width: 100%;
  padding: 9px 0;
  border-radius: var(--r-md, 8px);
  font-size: var(--fs-base, 13px);
  font-weight: 600;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--fg);
  cursor: pointer;
  transition: background 120ms, border-color 120ms, color 120ms;
}
.pw-card-cta:hover { border-color: var(--accent); color: var(--accent); }
.pw-card-cta--primary {
  background: var(--accent);
  color: var(--accent-fg, #fff);
  border-color: var(--accent);
}
.pw-card-cta--primary:hover {
  filter: brightness(1.08);
}
.pw-card-cta:disabled {
  opacity: 0.5;
  cursor: default;
  border-color: var(--border);
  color: var(--muted);
}

.pw-foot-row {
  text-align: center;
  font-size: var(--fs-xs, 11px);
  color: var(--muted);
  margin: 8px 0 0;
}
.pw-foot-row a {
  color: var(--accent);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.pw-foot-row a:hover { filter: brightness(1.15); }
.pw-foot-restore a { color: var(--muted); }
.pw-foot-restore a:hover { color: var(--accent); }

/* The shared modal-panel sets max-width:800px for size=lg, which is right
   for the 4-card grid. We pad the body slightly less so cards fill the row. */
.modal-panel.pw-modal .modal-body { padding: 12px 16px 16px; }
.modal-panel.pw-modal .modal-head  { border-bottom: none; }
