/* =======================================================
plan
======================================================= */
.p-plan {
  padding: var(--spacing-xl) 0;
  background: linear-gradient(to bottom, var(--gray-50), var(--white));
}
@media (width <= 767px) {
  .p-plan {
    padding: 3rem 0;
  }
}
.p-plan__conts-wrapper {
  display: grid;
  gap: 2rem;
  margin-bottom: 3rem;
}
@media (width >= 768px) {
  .p-plan__conts-wrapper {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (width <= 767px) {
  .p-plan__conts-wrapper {
    gap: 4rem;
  }
}
.p-plan__conts {
  position: relative;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  padding: 3rem 2rem;
  background: var(--white);
  border-radius: 1.25rem;
  box-shadow: 0 0.25rem 0.9375rem rgba(0, 0, 0, 0.08);
  transition-timing-function: ease;
  transition-duration: var(--transition-duration);
  transition-property: box-shadow;
  will-change: box-shadow;
}
.p-plan__conts:focus-visible {
  box-shadow: 0 0.9375rem 2.5rem rgba(107, 79, 187, 0.2);
}
@media (any-hover: hover) {
  .p-plan__conts:hover {
    box-shadow: 0 0.9375rem 2.5rem rgba(107, 79, 187, 0.2);
  }
}
.p-plan__conts.--recommended {
  border: 0.1875rem solid var(--primary-color);
}
.p-plan__conts.--enterprise .p-plan__conts-head-price {
  font-size: 2rem;
  font-weight: 700;
  color: var(--primary-color);
}
@media (width <= 767px) {
  .p-plan__conts {
    gap: 2rem;
  }
}
.p-plan__conts-lbl {
  position: absolute;
  top: -0.9375rem;
  left: 50%;
  padding: 0.5rem 1.5rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--white);
  background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
  border-radius: 1.25rem;
  transform: translateX(-50%);
}
.p-plan__conts-head {
  align-self: center;
  text-align: center;
}
.p-plan__conts-head-ttl {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--text-primary);
}
.p-plan__conts-head-price {
  display: flex;
  gap: 0.25rem;
  align-items: baseline;
  justify-content: center;
  margin-bottom: 0.5rem;
}
.p-plan__conts-head-price-currency {
  font-size: 1.5rem;
  color: var(--text-secondary);
}
.p-plan__conts-head-price-amount {
  font-size: 3.5rem;
  font-weight: 900;
  background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}
.p-plan__conts-head-price-unit {
  font-size: 1.25rem;
  color: var(--text-secondary);
}
.p-plan__conts-head-overview {
  font-size: 0.95rem;
  color: var(--text-secondary);
}
.p-plan__conts-body-def {
  padding-top: 2rem;
  margin-bottom: 2rem;
  border-top: 0.125rem solid var(--gray-200);
}
.p-plan__conts-body-dttl {
  padding-bottom: 0.5rem;
  margin-bottom: 1rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-primary);
  border-bottom: 0.125rem solid var(--gray-200);
}
.p-plan__conts-body-btn {
  display: block;
  width: 100%;
  padding: 1rem;
  font-weight: 600;
  color: var(--white);
  text-align: center;
  text-decoration: none;
  background: linear-gradient(135deg, var(--primary-color), var(--accent-color));
  border-radius: 0.625rem;
  transition-timing-function: ease;
  transition-duration: var(--transition-duration);
  transition-property: translate box-shadow;
  will-change: translate box-shadow;
}
.p-plan__conts-body-btn:focus-visible {
  translate: 0 -0.125rem;
  box-shadow: 0 0.625rem 1.5625rem rgba(107, 79, 187, 0.3);
}
@media (any-hover: hover) {
  .p-plan__conts-body-btn:hover {
    translate: 0 -0.125rem;
    box-shadow: 0 0.625rem 1.5625rem rgba(107, 79, 187, 0.3);
  }
}
.p-plan__note-wrapper {
  display: grid;
  gap: 0.5rem;
}
.p-plan__note {
  font-size: 0.9rem;
  color: var(--text-secondary);
}
.p-plan__note .fas {
  color: var(--primary-color);
}