/* ==========================================================================
   pricing.css — scoped styles for the /pricing page (layouts/pricing/list.html)
   --------------------------------------------------------------------------
   Adds ONLY what the HD system doesn't already provide: the hourly/monthly
   toggle, the sticky product nav, the spec-chip row, the variable-column
   exhaustive flavor table (+ its mobile stack), the tab strip, and the
   coming-soon / CTA cards. Everything is built on --hd-* tokens and uses
   logical properties so it mirrors correctly under [dir="rtl"] (rtl.css).
   The dark spec card reuses .plan_hero_content from hd.css.
   ========================================================================== */

/* Smooth-scroll only on pages that actually contain product anchors. */
html:has(.pricing-product) { scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) {
  html:has(.pricing-product) { scroll-behavior: auto; }
}

/* --------------------------------------------------------------------------
   Hourly / monthly toggle (segmented control) — bound to Alpine.store.pricing
   -------------------------------------------------------------------------- */
.pricing-toggle-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--hd-space-sm);
  flex-wrap: wrap;
}
.pricing-toggle {
  display: inline-flex;
  border: var(--hd-button-border) solid var(--hd-color-neutral-400);
  border-radius: 999rem;
}
.pricing-toggle-btn {
  border: 0;
  border-radius: 999rem;
  padding: 0.45rem 1.1rem;
  font-size: var(--hd-text-sm);
  line-height: 1;
}
.pricing-toggle-btn.is-active {
  color: var(--hd-color-white);
  background: var(--hd-color-accent);
  box-shadow: none;
}
.pricing-toggle-note { margin: 0; }

.pricing-disclaimer {
  max-width: var(--hd-width-md);
  margin-inline: auto;
  margin-block: 0;
}

/* --------------------------------------------------------------------------
   Sticky product nav — sits directly under the (sticky, 4.75rem) site navbar
   -------------------------------------------------------------------------- */
.pricing-prodnav-wrap {
  position: sticky;
  top: var(--hd-nav-height);
  z-index: 90;                 /* below --hd-z-dropdown (100) and nav (1000) */
  background: color-mix(in srgb, var(--hd-color-white) 88%, transparent);
  backdrop-filter: blur(8px);
  border-block: var(--hd-nav-panel-border) solid var(--hd-color-border);
}
.pricing-prodnav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--hd-space-sm);
  padding-block: 0.6rem;
}
.pricing-prodnav-links {
  display: flex;
  gap: 0.4rem;
  overflow-x: auto;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
}
.pricing-prodnav-links::-webkit-scrollbar { display: none; }
.pricing-prodnav-link {
  flex: none;
  text-decoration: none;
  white-space: nowrap;
  padding: 0.4rem 0.85rem;
  border-radius: 999rem;
  font-size: var(--hd-text-sm);
  font-weight: var(--hd-weight-medium);
  color: var(--hd-color-nav-link);
  border: var(--hd-button-border) solid transparent;
  transition: color var(--hd-transition), background-color var(--hd-transition), border-color var(--hd-transition);
}
.pricing-prodnav-link:hover {
  color: var(--hd-color-accent);
  background: var(--hd-color-neutral-100);
  border-color: var(--hd-color-neutral-300);
}
.pricing-toggle-compact { flex: none; }
.pricing-toggle-compact .pricing-toggle-btn { padding: 0.35rem 0.8rem; font-size: var(--hd-text-tiny); }

/* --------------------------------------------------------------------------
   Product block
   -------------------------------------------------------------------------- */
.pricing-product { scroll-margin-top: calc(var(--hd-nav-height) + 4rem); }

.pricing-product-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: var(--hd-space-lg);
  align-items: stretch;
}

/* Dark spec-hero card (extends .plan_hero_content) */
.pricing-spec-card {
  gap: 0;
  justify-content: flex-start;
  padding: 2rem;
  color: var(--hd-color-neutral-300);   /* readable default on the black card */
}
.pricing-spec-eyebrow {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  flex-wrap: wrap;
}
.pricing-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.6rem;
  border-radius: 999rem;
  font-family: var(--hd-font-badge);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--hd-color-white);
  background: color-mix(in srgb, var(--hd-color-white) 16%, transparent);
  border: var(--hd-button-border) solid color-mix(in srgb, var(--hd-color-white) 24%, transparent);
}
.pricing-status-pill.is-soon { color: var(--hd-color-accent); background: var(--hd-color-neutral-200); border-color: transparent; }

/* spec chips */
.pricing-chips {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}
.pricing-chip {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.6rem 0.7rem;
  border-radius: var(--hd-radius);
  background: color-mix(in srgb, var(--hd-color-white) 6%, transparent);
  border: var(--hd-button-border) solid color-mix(in srgb, var(--hd-color-white) 10%, transparent);
}
.pricing-chip-label {
  font-family: var(--hd-font-badge);
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--hd-color-neutral-800);
}
.pricing-chip-value { font-size: var(--hd-text-sm); font-weight: var(--hd-weight-medium); color: var(--hd-color-white); }

.pricing-startfrom .plan_hero_price { gap: 0.4rem; }

/* Features / app cards column */
.pricing-product-side {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.pricing-feature-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.7rem; }
.pricing-feature {
  position: relative;
  padding-inline-start: 1.7rem;
  font-size: var(--hd-text-sm);
  line-height: var(--hd-line-body);
  color: var(--hd-color-nav-link);
}
.pricing-feature::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 0.15rem;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 50%;
  background: var(--hd-color-accent)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center / 0.7rem no-repeat;
}

.pricing-app-cards { display: grid; grid-template-columns: 1fr; gap: 0.5rem; }
.pricing-app-card {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.7rem 0.85rem;
  border-radius: var(--hd-radius);
  border: var(--hd-button-border) solid var(--hd-color-neutral-300);
  background: var(--hd-color-neutral-50);
}
.pricing-app-card-top { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; }
.pricing-app-name { font-weight: var(--hd-weight-heading); font-size: var(--hd-text-sm); }
.pricing-app-status {
  font-family: var(--hd-font-badge);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--hd-color-neutral-900);
  padding: 0.15rem 0.45rem;
  border-radius: 999rem;
  background: var(--hd-color-neutral-200);
}
.pricing-app-note { margin: 0; }

/* --------------------------------------------------------------------------
   Tabs
   -------------------------------------------------------------------------- */
.pricing-tabstrip {
  display: flex;
  gap: 0.35rem;
  flex-wrap: wrap;
  border-block-end: var(--hd-button-border) solid var(--hd-color-neutral-300);
  margin-block-end: var(--hd-space-sm);
}
.pricing-tab {
  appearance: none;
  cursor: pointer;
  border: 0;
  background: transparent;
  font: inherit;
  font-size: var(--hd-text-sm);
  font-weight: var(--hd-weight-medium);
  color: var(--hd-color-neutral-900);
  padding: 0.6rem 0.4rem;
  border-block-end: 0.14rem solid transparent;
  margin-block-end: -0.07rem;
  transition: color var(--hd-transition), border-color var(--hd-transition);
}
.pricing-tab:hover { color: var(--hd-color-accent); }
.pricing-tab.is-active { color: var(--hd-color-accent); border-block-end-color: var(--hd-color-accent); }
.pricing-tab:focus-visible { outline: var(--hd-button-focus-width) solid var(--hd-color-accent); outline-offset: 2px; border-radius: 2px; }

/* --------------------------------------------------------------------------
   Variable-column flavor table
   -------------------------------------------------------------------------- */
.pricing-table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.pricing-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--hd-text-sm);
}
.pricing-table thead th {
  text-align: start;
  font-family: var(--hd-font-badge);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--hd-color-neutral-900);
  padding: 0.7rem 0.9rem;
  border-block-end: var(--hd-button-border) solid var(--hd-color-neutral-300);
  white-space: nowrap;
}
.pricing-table tbody td {
  padding: 0.85rem 0.9rem;
  border-block-end: var(--hd-button-border) solid var(--hd-color-neutral-200);
  vertical-align: middle;
  color: var(--hd-color-nav-link);
}
.pricing-table tbody tr:last-child td { border-block-end: 0; }
.pricing-table tbody td:first-child { font-weight: var(--hd-weight-medium); color: var(--hd-color-accent); white-space: nowrap; }
.pricing-table .is-price { text-align: end; white-space: nowrap; font-weight: var(--hd-weight-heading); color: var(--hd-color-accent); }
.pricing-table tbody tr { transition: background-color var(--hd-transition); }
.pricing-table tbody tr:hover { background: var(--hd-color-neutral-50); }
.pricing-table-addons tbody td:first-child { color: var(--hd-color-nav-link); font-weight: var(--hd-weight-regular); white-space: normal; }

/* --------------------------------------------------------------------------
   Coming-soon + CTA cards
   -------------------------------------------------------------------------- */
.pricing-comingsoon {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--hd-space-lg);
  align-items: center;
  padding: 2.25rem;
  border-radius: var(--hd-radius);
  color: var(--hd-color-neutral-300);
  background:
    radial-gradient(circle at 85% 0%, color-mix(in srgb, var(--hd-color-white) 8%, transparent) 0, transparent 16rem),
    var(--hd-color-black);
  border: var(--hd-button-border) solid color-mix(in srgb, var(--hd-color-white) 8%, transparent);
}
.pricing-comingsoon .pricing-chip-label { color: var(--hd-color-neutral-800); }
.pricing-feature-list-soon .pricing-feature { color: var(--hd-color-neutral-300); }
.pricing-feature-list-soon .pricing-feature::before {
  background: color-mix(in srgb, var(--hd-color-white) 16%, transparent)
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='12' cy='12' r='9'/%3E%3Cpath d='M12 7v5l3 2'/%3E%3C/svg%3E") center / 0.72rem no-repeat;
}

.pricing-cta {
  align-items: center;
  text-align: center;
  padding: 3rem 2rem;
}

/* --------------------------------------------------------------------------
   Responsive
   -------------------------------------------------------------------------- */
@media screen and (max-width: 991px) {
  .pricing-product-grid { grid-template-columns: 1fr; gap: var(--hd-space-md); }
  .pricing-comingsoon { grid-template-columns: 1fr; gap: var(--hd-space-md); padding: 1.75rem; }
}

@media screen and (max-width: 767px) {
  .pricing-prodnav { flex-direction: column; align-items: stretch; gap: 0.5rem; }
  .pricing-chips { grid-template-columns: 1fr 1fr; }

  /* Flavor tables collapse to stacked label/value rows (like pricing_compare_*). */
  .pricing-table thead { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
  .pricing-table,
  .pricing-table tbody,
  .pricing-table tr,
  .pricing-table td { display: block; width: 100%; }
  .pricing-table tbody tr {
    border: var(--hd-button-border) solid var(--hd-color-neutral-300);
    border-radius: var(--hd-radius);
    padding: 0.35rem 0.85rem;
    margin-block-end: 0.6rem;
  }
  .pricing-table tbody td {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
    border-block-end: var(--hd-button-border) solid var(--hd-color-neutral-200);
    padding-inline: 0;
  }
  .pricing-table tbody tr td:last-child { border-block-end: 0; }
  .pricing-table tbody td::before {
    content: attr(data-label);
    font-family: var(--hd-font-badge);
    font-size: 0.62rem;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: var(--hd-color-neutral-900);
  }
  .pricing-table .is-price { text-align: end; }
}
