/* Hero two-column layout */
.pricing-hero-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-16);
  align-items: center;
}

.pricing-summary {
  background: var(--color-navy-900);
  border: 1px solid var(--color-navy-700);
  border-radius: var(--radius-xl);
  overflow: hidden;
}

.pricing-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-navy-800);
}

.pricing-summary-row:last-child {
  border-bottom: none;
}

.pricing-summary-row--featured {
  background: rgba(0, 180, 216, 0.06);
  border-color: rgba(0, 180, 216, 0.12);
}

.pricing-summary-name {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--dark-text);
}

.pricing-summary-price {
  font-size: var(--text-sm);
  color: var(--dark-text-muted);
}

.pricing-summary-price strong {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--dark-text);
}

.pricing-summary-row--featured .pricing-summary-price strong {
  color: var(--accent);
}

@media (max-width: 900px) {
  .pricing-hero-grid { grid-template-columns: 1fr; }
  .pricing-summary { max-width: 420px; margin: 0 auto; }
}

/* Plan cards — 4-column grid for pricing page */
.pricing-grid--4col {
  grid-template-columns: repeat(4, 1fr);
  align-items: stretch;
}

/* Comparison table */
.compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}
.compare-table thead th {
  padding: var(--space-4) var(--space-5);
  text-align: center;
  font-weight: var(--font-semibold);
  color: var(--light-text);
  border-bottom: 2px solid var(--light-border);
  background: var(--light-bg);
  position: sticky;
  top: 64px;
}
.compare-table thead th:first-child { text-align: left; width: 28%; }
.compare-table thead th:not(:first-child) { width: 18%; }
.compare-table thead .th-featured {
  color: var(--accent);
  border-bottom-color: var(--accent);
}
.compare-table thead .th-plan-name {
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--light-text-muted);
  display: block;
  margin-bottom: 2px;
}
.compare-table thead .th-price {
  font-size: var(--text-2xl);
  font-weight: var(--font-extrabold);
  line-height: 1;
  color: var(--light-text);
}
.compare-table thead .th-featured .th-price { color: var(--accent); }
.compare-table thead .th-period {
  font-size: var(--text-xs);
  color: var(--light-text-muted);
  font-weight: var(--font-regular);
}
.compare-table tr.group-row td {
  padding: var(--space-3) var(--space-5);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--light-text-muted);
  background: var(--light-elevated);
  border-top: 1px solid var(--light-border);
}
.compare-table tbody td {
  padding: var(--space-3) var(--space-5);
  border-bottom: 1px solid var(--light-border);
  color: var(--light-text-sub);
  vertical-align: middle;
}
.compare-table tbody td:first-child { color: var(--light-text); font-weight: var(--font-medium); }
.compare-table tbody td:not(:first-child) { text-align: center; }
.compare-table tbody tr:last-child td { border-bottom: none; }
.compare-table tbody tr:hover td { background: rgba(0,180,216,0.03); }
.compare-table .td-featured { background: rgba(0,180,216,0.03); }
.check-icon { color: var(--accent); display: inline-block; }
.minus-icon { color: var(--light-text-muted); }
.td-note { font-size: var(--text-xs); color: var(--light-text-muted); display: block; margin-top: 2px; font-weight: var(--font-regular); }

/* OSS pills */
.oss-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: white;
  font-weight: var(--font-semibold);
  font-size: 0.9375rem;
  white-space: nowrap;
  transition: background var(--transition-fast);
}
.oss-pill:hover { background: rgba(255,255,255,0.12); color: white; }

/* FAQ */
.faq-list { display: flex; flex-direction: column; gap: var(--space-1); max-width: 760px; margin: 0 auto; }
.faq-item { border: 1px solid var(--light-border); border-radius: var(--radius-lg); overflow: hidden; }
.faq-q {
  width: 100%; text-align: left;
  background: var(--light-surface); border: none;
  padding: var(--space-5) var(--space-6);
  font-size: var(--text-base); font-weight: var(--font-semibold); color: var(--light-text);
  cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
  transition: background var(--transition-fast);
  font-family: var(--font-sans);
}
.faq-q:hover { background: var(--light-elevated); }
.faq-q svg { flex-shrink: 0; color: var(--accent); transition: transform var(--transition-fast); }
.faq-q[aria-expanded="true"] svg { transform: rotate(45deg); }
.faq-a { display: none; padding: 0 var(--space-6) var(--space-5); font-size: var(--text-sm); color: var(--light-text-sub); line-height: var(--leading-relaxed); background: var(--light-surface); }
.faq-a.open { display: block; }

/* Responsive */
@media (max-width: 1024px) {
  .pricing-grid--4col { grid-template-columns: repeat(2, 1fr); }
  .compare-table { font-size: var(--text-xs); }
  .compare-table thead th, .compare-table tbody td { padding: var(--space-2) var(--space-3); }
}
@media (max-width: 768px) {
  .compare-wrap { overflow-x: auto; }
  .pricing-grid--4col { grid-template-columns: 1fr; }
}
