/* templates/blocks/pricing-table/style.css */
/* v1.2.0 — Pricing Table Custom (Hỗ trợ đa thư viện Icon) */

.pf-pt {
  width: 100%;
  max-width: var(--pt-max-width, 1180px);
  margin: var(--pt-margin, 0 auto);
  padding: var(--pt-padding, 20px 0);
  text-align: var(--pt-align, center);
}

.pf-pt *,
.pf-pt *::before,
.pf-pt *::after {
  box-sizing: border-box;
}

.pf-pt__header {
  margin: 0 0 30px;
}

.pf-pt__title {
  margin: 0 0 12px;
  color: var(--pt-title-color, #fff);
  font-size: var(--pt-title-size, 52px);
  font-weight: var(--pt-title-weight, 800);
  line-height: 1.05;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.pf-pt__subtitle {
  max-width: 780px;
  margin: 0 auto;
  color: var(--pt-subtitle-color, rgba(255,255,255,.72));
  font-size: var(--pt-subtitle-size, 17px);
  line-height: 1.7;
}

.pf-pt__grid {
  display: grid;
  grid-template-columns: repeat(var(--pt-cols-desktop, 3), minmax(0, 1fr));
  gap: var(--pt-gap, 24px);
  align-items: stretch;
}

.pf-pt__card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 100%;
  overflow: hidden;
  padding: var(--pt-plan-card-padding, var(--pt-card-padding, 34px 28px 28px));
  color: var(--pt-plan-card-color, inherit);
  background: var(--pt-plan-card-bg, var(--pt-card-bg, linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025))));
  border: var(--pt-card-border-width, 1px) solid var(--pt-plan-card-border-color, var(--pt-card-border-color, rgba(246,214,117,.28)));
  border-radius: var(--pt-plan-card-radius, var(--pt-card-radius, 22px));
  box-shadow: var(--pt-card-shadow, 0 22px 50px rgba(0,0,0,.30));
  text-align: left;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.pf-pt__card:hover {
  transform: translateY(-4px);
}

.pf-pt__card.is-featured {
  background: var(--pt-plan-card-bg, var(--pt-featured-bg, linear-gradient(180deg, rgba(246,214,117,.10), rgba(255,255,255,.035))));
  border-color: var(--pt-plan-card-border-color, var(--pt-featured-border-color, #f6d675));
  transform: scale(var(--pt-featured-scale, 1.03));
  z-index: 2;
}

.pf-pt__card.is-featured:hover {
  transform: scale(var(--pt-featured-scale, 1.03)) translateY(-4px);
}

.pf-pt__badge {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
  padding: 7px 12px;
  border-radius: 999px;
  color: var(--pt-badge-color, #151515);
  background: var(--pt-badge-bg, #f6d675);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.pf-pt__icon {
  width: var(--pt-icon-box-size, 68px);
  height: var(--pt-icon-box-size, 68px);
  min-width: var(--pt-icon-box-size, 68px);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  border-radius: 999px;
  color: var(--pt-plan-icon-color, var(--pt-icon-color, #f6d675));
  background: var(--pt-plan-icon-bg, var(--pt-icon-bg, rgba(246,214,117,.08)));
  border: 1px solid rgba(246,214,117,.20);
  font-size: var(--pt-icon-size, 22px);
  line-height: 1;
}

/* Các tuỳ chỉnh đa thư viện Icon (Google, Hero, Ion) */
.pf-pt__icon .material-symbols-rounded {
  font-family: 'Material Symbols Rounded';
  font-weight: normal;
  font-style: normal;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: 'liga';
  -webkit-font-feature-settings: 'liga';
}
.pf-pt__icon .pt-icon-hero {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.pf-pt__icon .pt-icon-hero svg {
  width: 1em;
  height: 1em;
  display: block;
}
.pf-pt__icon ion-icon {
  display: block;
  font-size: 1em;
}

.pf-pt__name {
  margin: 0;
  text-align: center;
  color: var(--pt-plan-name-color, var(--pt-plan-title-color, #fff));
  font-size: var(--pt-plan-title-size, 26px);
  font-weight: var(--pt-plan-title-weight, 800);
  line-height: 1.22;
}

.pf-pt__plan-subtitle {
  margin: 8px 0 18px;
  text-align: center;
  color: var(--pt-plan-subtitle-color, rgba(255,255,255,.70));
  font-size: var(--pt-plan-subtitle-size, 14px);
  line-height: 1.5;
}

.pf-pt__price {
  margin: 0 0 16px;
  text-align: center;
  color: var(--pt-plan-price-color, var(--pt-price-color, #f6d675));
  font-size: var(--pt-price-size, 58px);
  font-weight: var(--pt-price-weight, 800);
  line-height: 1;
  letter-spacing: -.04em;
}

.pf-pt__price span {
  font-size: .55em;
  vertical-align: top;
  letter-spacing: 0;
}

.pf-pt__price small {
  font-size: .32em;
  letter-spacing: 0;
  opacity: .7;
  margin-left: 4px;
}

.pf-pt__desc {
  margin: 0 0 20px;
  padding: 0 0 20px;
  color: var(--pt-plan-desc-color, var(--pt-desc-color, rgba(255,255,255,.72)));
  border-bottom: 1px solid rgba(255,255,255,.10);
  font-size: var(--pt-desc-size, 15px);
  line-height: 1.7;
  text-align: center;
}

.pf-pt__features {
  display: grid;
  gap: var(--pt-feature-gap, 14px);
  margin: 0;
  padding: 0;
  list-style: none;
}

.pf-pt__features li {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  color: var(--pt-plan-feature-color, var(--pt-feature-color, #f4f4f5));
  font-size: var(--pt-feature-size, 16px);
  line-height: 1.6;
}

.pf-pt__check {
  color: var(--pt-check-color, #f6d675);
  font-size: 14px;
  line-height: 1;
  padding-top: 4px;
}

.pf-pt__footer {
  margin-top: auto;
  padding-top: 28px;
}

.pf-pt__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 54px;
  width: 100%;
  padding: var(--pt-button-padding, 14px 22px);
  border-radius: var(--pt-button-radius, 14px);
  color: var(--pt-plan-button-color, var(--pt-button-color, #1b1b1b));
  background: var(--pt-plan-button-bg, var(--pt-button-bg, #f6d675));
  border: 1px solid var(--pt-plan-button-border-color, var(--pt-button-border-color, #f6d675));
  text-decoration: none;
  font-size: var(--pt-button-size, 17px);
  font-weight: var(--pt-button-weight, 800);
  line-height: 1.2;
  transition: transform .18s ease, filter .18s ease;
}

.pf-pt__btn:hover {
  transform: translateY(-1px);
  filter: brightness(1.05);
}

/* Compact layout */
.pf-pt--compact .pf-pt__card {
  padding: 24px;
}

.pf-pt--compact .pf-pt__icon {
  width: 48px;
  height: 48px;
  min-width: 48px;
}

.pf-pt--compact .pf-pt__price {
  font-size: calc(var(--pt-price-size, 58px) * .78);
}

@media (max-width: 991px) {
  .pf-pt__grid {
    grid-template-columns: repeat(var(--pt-cols-tablet, 2), minmax(0, 1fr));
  }

  .pf-pt__card.is-featured,
  .pf-pt__card.is-featured:hover {
    transform: none;
  }

  .pf-pt__title {
    font-size: min(var(--pt-title-size, 52px), 42px);
  }
}

@media (max-width: 640px) {
  .pf-pt__grid {
    grid-template-columns: repeat(var(--pt-cols-mobile, 1), minmax(0, 1fr));
  }

  .pf-pt {
    padding-left: 0;
    padding-right: 0;
  }

  .pf-pt__title {
    font-size: min(var(--pt-title-size, 52px), 34px);
  }

  .pf-pt__subtitle {
    font-size: 15px;
  }

  .pf-pt__card {
    padding: 24px 18px 20px;
  }

  .pf-pt__price {
    font-size: min(var(--pt-price-size, 58px), 46px);
  }
}

/* Builder preview */
.b-block-preview .pf-pt {
  width: 100%;
}

.b-block-preview .pf-pt__title,
.b-block-preview .pf-pt__subtitle,
.b-block-preview .pf-pt__name,
.b-block-preview .pf-pt__price,
.b-block-preview .pf-pt__desc,
.b-block-preview .pf-pt__features,
.b-block-preview .pf-pt__btn {
  font-family: inherit;
}

/* v1.6 safety: pricing table visible anywhere */
.pf-pt {
  display: block !important;
  visibility: visible !important;
  width: 100%;
  max-width: var(--pt-max-width, 1180px);
  margin: var(--pt-margin, 0 auto);
  padding: var(--pt-padding, 20px 0);
  text-align: var(--pt-align, center);
  box-sizing: border-box;
}
.pf-pt *, .pf-pt *::before, .pf-pt *::after { box-sizing: border-box; }
.pf-pt__header { margin: 0 0 30px; }
.pf-pt__title {
  margin: 0 0 12px;
  color: var(--pt-title-color, #fff);
  font-size: var(--pt-title-size, 52px);
  font-weight: var(--pt-title-weight, 800);
  line-height: 1.05;
  letter-spacing: .02em;
  text-transform: uppercase;
}
.pf-pt__subtitle {
  max-width: 780px;
  margin: 0 auto;
  color: var(--pt-subtitle-color, rgba(255,255,255,.72));
  font-size: var(--pt-subtitle-size, 17px);
  line-height: 1.7;
}
.pf-pt__grid {
  display: grid;
  grid-template-columns: repeat(var(--pt-cols-desktop, 3), minmax(0, 1fr));
  gap: var(--pt-gap, 24px);
  align-items: stretch;
}
.pf-pt__card {
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 100%;
  overflow: hidden;
  padding: var(--pt-plan-card-padding, var(--pt-card-padding, 34px 28px 28px));
  color: var(--pt-plan-card-color, inherit);
  background: var(--pt-plan-card-bg, var(--pt-card-bg, linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.025))));
  border: var(--pt-card-border-width, 1px) solid var(--pt-plan-card-border-color, var(--pt-card-border-color, rgba(246,214,117,.28)));
  border-radius: var(--pt-plan-card-radius, var(--pt-card-radius, 22px));
  box-shadow: var(--pt-card-shadow, 0 22px 50px rgba(0,0,0,.30));
  text-align: left;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease, background .2s ease;
}
.pf-pt__card:hover { transform: translateY(-4px); }
.pf-pt__card.is-featured {
  background: var(--pt-plan-card-bg, var(--pt-featured-bg, linear-gradient(180deg, rgba(246,214,117,.10), rgba(255,255,255,.035))));
  border-color: var(--pt-plan-card-border-color, var(--pt-featured-border-color, #f6d675));
  transform: scale(var(--pt-featured-scale, 1.03));
  z-index: 2;
}
.pf-pt__card.is-featured:hover { transform: scale(var(--pt-featured-scale, 1.03)) translateY(-4px); }
.pf-pt__badge {
  position: absolute;
  top: 16px;
  right: 16px;
  z-index: 3;
  padding: 7px 12px;
  border-radius: 999px;
  color: var(--pt-badge-color, #151515);
  background: var(--pt-badge-bg, #f6d675);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.pf-pt__icon {
  width: var(--pt-icon-box-size, 68px);
  height: var(--pt-icon-box-size, 68px);
  min-width: var(--pt-icon-box-size, 68px);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  border-radius: 999px;
  color: var(--pt-plan-icon-color, var(--pt-icon-color, #f6d675));
  background: var(--pt-plan-icon-bg, var(--pt-icon-bg, rgba(246,214,117,.08)));
  border: 1px solid rgba(246,214,117,.20);
  font-size: var(--pt-icon-size, 22px);
  line-height: 1;
}
.pf-pt__icon i, .pf-pt__icon span, .pf-pt__icon ion-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.pf-pt__icon .material-symbols-rounded {
  font-family: 'Material Symbols Rounded';
  font-weight: normal;
  font-style: normal;
  font-size: 1.2em;
  line-height: 1;
  letter-spacing: normal;
  text-transform: none;
  white-space: nowrap;
  word-wrap: normal;
  direction: ltr;
  font-feature-settings: 'liga';
  -webkit-font-feature-settings: 'liga';
}
.pf-pt__name {
  margin: 0;
  text-align: center;
  color: var(--pt-plan-name-color, var(--pt-plan-title-color, #fff));
  font-size: var(--pt-plan-title-size, 26px);
  font-weight: var(--pt-plan-title-weight, 800);
  line-height: 1.22;
}
.pf-pt__plan-subtitle {
  margin: 8px 0 18px;
  text-align: center;
  color: var(--pt-plan-subtitle-custom-color, var(--pt-plan-subtitle-color, rgba(255,255,255,.70)));
  font-size: var(--pt-plan-subtitle-size, 14px);
  line-height: 1.5;
}
.pf-pt__price {
  margin: 0 0 16px;
  text-align: center;
  color: var(--pt-plan-price-color, var(--pt-price-color, #f6d675));
  font-size: var(--pt-price-size, 58px);
  font-weight: var(--pt-price-weight, 800);
  line-height: 1;
  letter-spacing: -.04em;
}
.pf-pt__price span { font-size: .55em; vertical-align: top; letter-spacing: 0; }
.pf-pt__price small { font-size: .32em; letter-spacing: 0; opacity: .7; margin-left: 4px; }
.pf-pt__desc {
  margin: 0 0 20px;
  padding: 0 0 20px;
  color: var(--pt-plan-desc-color, var(--pt-desc-color, rgba(255,255,255,.72)));
  border-bottom: 1px solid rgba(255,255,255,.10);
  font-size: var(--pt-desc-size, 15px);
  line-height: 1.7;
  text-align: center;
}
.pf-pt__features {
  display: grid;
  gap: var(--pt-feature-gap, 14px);
  margin: 0;
  padding: 0;
  list-style: none;
}
.pf-pt__features li {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  color: var(--pt-plan-feature-color, var(--pt-feature-color, #f4f4f5));
  font-size: var(--pt-feature-size, 16px);
  line-height: 1.6;
}
.pf-pt__check { color: var(--pt-check-color, #f6d675); font-size: 14px; line-height: 1; padding-top: 4px; }
.pf-pt__footer { margin-top: auto; padding-top: 28px; }
.pf-pt__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  min-height: 54px;
  width: 100%;
  padding: var(--pt-button-padding, 14px 22px);
  border-radius: var(--pt-button-radius, 14px);
  color: var(--pt-plan-button-color, var(--pt-button-color, #1b1b1b));
  background: var(--pt-plan-button-bg, var(--pt-button-bg, #f6d675));
  border: 1px solid var(--pt-plan-button-border-color, var(--pt-button-border-color, #f6d675));
  text-decoration: none;
  font-size: var(--pt-button-size, 17px);
  font-weight: var(--pt-button-weight, 800);
  line-height: 1.2;
  transition: transform .18s ease, filter .18s ease, background .18s ease, color .18s ease, border-color .18s ease;
}
.pf-pt__btn:hover { transform: translateY(-1px); filter: brightness(1.05); text-decoration: none; }
.pf-pt--compact .pf-pt__card { padding: 24px; }
.pf-pt--compact .pf-pt__icon { width: 48px; height: 48px; min-width: 48px; }
.pf-pt--compact .pf-pt__price { font-size: calc(var(--pt-price-size, 58px) * .78); }
@media (max-width: 991px) {
  .pf-pt__grid { grid-template-columns: repeat(var(--pt-cols-tablet, 2), minmax(0, 1fr)); }
  .pf-pt__card.is-featured, .pf-pt__card.is-featured:hover { transform: none; }
  .pf-pt__title { font-size: min(var(--pt-title-size, 52px), 42px); }
}
@media (max-width: 640px) {
  .pf-pt__grid { grid-template-columns: repeat(var(--pt-cols-mobile, 1), minmax(0, 1fr)); }
  .pf-pt { padding-left: 0; padding-right: 0; }
  .pf-pt__title { font-size: min(var(--pt-title-size, 52px), 34px); }
  .pf-pt__subtitle { font-size: 15px; }
  .pf-pt__card { padding: 24px 18px 20px; }
  .pf-pt__price { font-size: min(var(--pt-price-size, 58px), 46px); }
}
