@charset "UTF-8";
/*------------------------------------------------------------
	サイト幅でセンタリング
------------------------------------------------------------*/
/*------------------------------------------------------------
	breakpoint
------------------------------------------------------------*/
/*------------------------------------------------------------
	フォント
------------------------------------------------------------*/
/*------------------------------------------------------------
	clearfix
------------------------------------------------------------*/
/*------------------------------------------------------------
	flex
------------------------------------------------------------*/
/*------------------------------------------------------------
	Other
------------------------------------------------------------*/
.lp-body {
  background: #d9e1f0;
}

.lp-header.header {
  position: sticky;
  top: 0;
  z-index: 50;
  margin: 0;
  padding-left: 15px;
}
.lp-header.header .solopra {
  margin-right: auto;
}

.lp {
  color: rgb(21, 23, 116);
  font-family: "Noto Sans JP", sans-serif;
}

.lp-container {
  width: 120rem;
  max-width: 92%;
  margin: 0 auto;
}

.lp-h2 {
  font-size: 3.2rem;
  letter-spacing: 0.02em;
  margin: 0 0 2.2rem;
  line-height: 1.25;
}
@media screen and (max-width: 600px) {
  .lp-h2 {
    font-size: 2.4rem;
  }
}

.lp-text {
  font-size: 1.6rem;
  line-height: 1.9;
  color: rgba(21, 23, 116, 0.72);
  margin: 0;
}

.lp-section {
  padding: 7.2rem 0;
}
@media screen and (max-width: 600px) {
  .lp-section {
    padding: 5.2rem 0;
  }
}

.lp-section--spec {
  position: relative;
  overflow: hidden;
  background: radial-gradient(900px 480px at 92% 8%, rgba(99, 102, 241, 0.14), transparent 58%), radial-gradient(700px 380px at 0% 100%, rgba(14, 165, 233, 0.09), transparent 52%), linear-gradient(185deg, #eef2ff 0%, #f8fafc 48%, #f1f5f9 100%);
}
.lp-section--spec .lp-h2 {
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.lp-section--features {
  background: #f9fafb;
  border-top: none;
  border-bottom: none;
}
.lp-section--features .lp-h2 {
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 2.8rem;
}

.lp-section--badge {
  background: radial-gradient(720px 440px at 50% -15%, rgba(99, 102, 241, 0.28), transparent 62%), linear-gradient(168deg, #070d18 0%, #0f172a 42%, #0b1120 100%);
  color: rgba(226, 232, 240, 0.96);
}
.lp-section--badge .lp-h2 {
  color: #f8fafc;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.lp-section--badge .lp-text {
  color: rgba(203, 213, 225, 0.94);
}
.lp-section--badge .lp-text strong {
  color: #7dd3fc;
  font-weight: 800;
}

.lp-section--pricing {
  background: linear-gradient(180deg, #f8fafc 0%, #eef2f7 100%);
}
.lp-section--pricing .lp-h2 {
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.lp-section--pricing .lp-pricingIntro {
  margin: -0.8rem 0 2.6rem;
  max-width: 72rem;
  color: rgba(51, 65, 85, 0.9);
}

.lp-section--audience {
  background: linear-gradient(180deg, #e8ecf4 0%, #f1f5f9 38%, #f8fafc 100%);
}
.lp-section--audience .lp-h2 {
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 2.6rem;
}

.lp-section--faq {
  background: #ffffff;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
}
.lp-section--faq .lp-h2 {
  color: #0f172a;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 2rem;
}

.lp-h3 {
  font-size: 2.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  margin: 2.4rem 0 1rem;
  line-height: 1.35;
}
.lp-h3:first-of-type {
  margin-top: 0;
}
@media screen and (max-width: 600px) {
  .lp-h3 {
    font-size: 1.75rem;
  }
}

.lp-prose {
  max-width: 72rem;
  margin-bottom: 0;
}
.lp-prose + .lp-prose {
  margin-top: 1.2rem;
}

.lp-prose--tight {
  margin-bottom: 1.8rem;
}

@keyframes lpAudienceCardReveal {
  from {
    opacity: 0;
    transform: translateY(1.4rem);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.lp-audienceCards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 2rem;
  max-width: 120rem;
  margin: 0 auto;
  align-items: stretch;
}
@media screen and (max-width: 600px) {
  .lp-audienceCards {
    grid-template-columns: 1fr;
    gap: 1.75rem;
  }
}

.lp-audienceCard {
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: #ffffff;
  border-radius: 1.35rem;
  overflow: hidden;
  border: 1px solid rgba(15, 23, 42, 0.08);
  box-shadow: 0 1px 0 rgb(255, 255, 255) inset, 0 22px 48px rgba(15, 23, 42, 0.1);
}

html.lp-scrollfx .lp-audienceCards:not(.is-inview) .lp-audienceCard {
  opacity: 0;
  transform: translateY(1.4rem);
}

@media (prefers-reduced-motion: reduce) {
  html.lp-scrollfx .lp-audienceCards:not(.is-inview) .lp-audienceCard {
    opacity: 1;
    transform: none;
  }
}
html.lp-scrollfx .lp-audienceCards.is-inview .lp-audienceCard {
  animation: lpAudienceCardReveal 0.78s cubic-bezier(0.22, 1, 0.36, 1) both;
}
html.lp-scrollfx .lp-audienceCards.is-inview .lp-audienceCard:nth-child(1) {
  animation-delay: 0.06s;
}
html.lp-scrollfx .lp-audienceCards.is-inview .lp-audienceCard:nth-child(2) {
  animation-delay: 0.2s;
}
html.lp-scrollfx .lp-audienceCards.is-inview .lp-audienceCard:nth-child(3) {
  animation-delay: 0.34s;
}

@media (prefers-reduced-motion: reduce) {
  html.lp-scrollfx .lp-audienceCards.is-inview .lp-audienceCard {
    animation: none;
  }
}
.lp-audienceCard__media {
  position: relative;
  aspect-ratio: 3/2;
  background: linear-gradient(165deg, #e2e8f0 0%, #cbd5e1 100%);
  flex-shrink: 0;
}

.lp-audienceCard__media::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(15, 23, 42, 0) 55%, rgba(15, 23, 42, 0.12) 100%);
}

.lp-audienceCard__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.lp-audienceCard__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  padding: 1.55rem 1.6rem 1.75rem;
  min-height: 0;
}

.lp-audienceCard__title {
  font-size: 1.52rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  margin: 0 0 0.85rem;
  line-height: 1.42;
}

.lp-audienceCard__text {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.82;
  color: rgba(51, 65, 85, 0.93);
}

.lp-faq {
  max-width: 80rem;
}

.lp-faq__item {
  padding: 1.85rem 0;
  border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}
.lp-faq__item:first-child {
  padding-top: 0;
}

.lp-faq__q {
  font-size: 1.58rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  margin: 0 0 0.75rem;
  line-height: 1.4;
}

.lp-faq__a {
  margin: 0;
  font-size: 1.48rem;
  line-height: 1.85;
  color: rgba(51, 65, 85, 0.92);
}

.lp-section--seo {
  position: relative;
  overflow: hidden;
  padding: 9.2rem 0 11rem;
  background: radial-gradient(900px 480px at 8% 12%, rgba(99, 102, 241, 0.16), transparent 58%), radial-gradient(720px 400px at 96% 72%, rgba(14, 165, 233, 0.1), transparent 52%), radial-gradient(520px 320px at 50% 100%, rgba(67, 56, 202, 0.06), transparent 55%), linear-gradient(188deg, #eef2ff 0%, #f8fafc 38%, #f1f5f9 100%);
  border-top: none;
}
.lp-section--seo::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, rgba(99, 102, 241, 0.45) 50%, transparent 100%);
  opacity: 0.85;
  pointer-events: none;
}
.lp-section--seo .lp-text strong {
  color: #3730a3;
  font-weight: 800;
}
.lp-section--seo .lp-btn--primary {
  color: #ffffff;
  font-weight: 700;
  border-color: rgba(255, 255, 255, 0.32);
  background: linear-gradient(135deg, #4338ca 0%, #6366f1 52%, #4f46e5 100%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.22) inset, 0 12px 32px rgba(67, 56, 202, 0.42);
}
.lp-section--seo .lp-btn--primary:hover {
  border-color: rgba(255, 255, 255, 0.5);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.28) inset, 0 16px 40px rgba(67, 56, 202, 0.5);
}
.lp-section--seo .lp-btn--primary:focus-visible {
  outline: 2px solid #a5b4fc;
  outline-offset: 3px;
}
.lp-section--seo .lp-seoCta .lp-btn--ghost {
  color: #312e81;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(49, 46, 129, 0.22);
}
.lp-section--seo .lp-seoCta .lp-btn--ghost:hover {
  background: #ffffff;
  border-color: rgba(49, 46, 129, 0.35);
}
.lp-section--seo .lp-seoCta .lp-btn--ghost:focus-visible {
  outline: 2px solid #6366f1;
  outline-offset: 3px;
}
@media screen and (max-width: 600px) {
  .lp-section--seo {
    padding: 6.4rem 0 8rem;
  }
}

.lp-seoDeco {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.lp-seoDeco__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(72px);
  opacity: 0.55;
}
.lp-seoDeco__orb--a {
  width: min(52rem, 85vw);
  height: min(52rem, 85vw);
  top: -18%;
  right: -12%;
  background: radial-gradient(circle at 40% 40%, rgba(129, 140, 248, 0.55), rgba(99, 102, 241, 0) 68%);
}
.lp-seoDeco__orb--b {
  width: min(44rem, 70vw);
  height: min(44rem, 70vw);
  bottom: -22%;
  left: -16%;
  background: radial-gradient(circle at 50% 50%, rgba(56, 189, 248, 0.35), rgba(14, 165, 233, 0) 70%);
  opacity: 0.45;
}

.lp-seoContainer {
  position: relative;
  z-index: 1;
}

.lp-seoPanel {
  max-width: 96rem;
  margin: 0 auto;
  padding: 4.2rem 3.8rem 3.2rem;
  border-radius: 2rem;
  background: linear-gradient(165deg, rgba(255, 255, 255, 0.92) 0%, rgba(255, 255, 255, 0.97) 45%, rgba(248, 250, 252, 0.94) 100%);
  border: 1px solid rgba(255, 255, 255, 0.75);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 2px 0 rgba(15, 23, 42, 0.04) inset, 0 32px 72px rgba(15, 23, 42, 0.09), 0 0 0 1px rgba(99, 102, 241, 0.07);
}
@media screen and (max-width: 600px) {
  .lp-seoPanel {
    padding: 2.8rem 1.85rem 2.4rem;
    border-radius: 1.45rem;
  }
}

.lp-seoEyebrow {
  margin: 0 0 1.35rem;
  font-family: "Roboto", sans-serif;
  font-size: 1.14rem;
  font-weight: 700;
  letter-spacing: 0.26em;
  text-transform: uppercase;
  color: #4f46e5;
}
@media screen and (max-width: 600px) {
  .lp-seoEyebrow {
    font-size: 1.02rem;
    letter-spacing: 0.2em;
  }
}

.lp-h2.lp-seoH2 {
  margin: 0 0 3rem;
  max-width: 100%;
  font-weight: 800;
  font-size: clamp(2.2rem, 3.6vw, 3.4rem);
  line-height: 1.28;
  letter-spacing: -0.03em;
  background: linear-gradient(120deg, #0f172a 0%, #1e1b4b 38%, #312e81 72%, #4338ca 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
@media screen and (max-width: 600px) {
  .lp-h2.lp-seoH2 {
    margin-bottom: 2.25rem;
  }
}

@supports not (background-clip: text) {
  .lp-h2.lp-seoH2 {
    background: none;
    color: #0f172a;
  }
}
.lp-seoArticle {
  max-width: 78rem;
  padding-bottom: 0.4rem;
}

.lp-seoArticle .lp-h3.lp-seoH3 {
  display: flex;
  align-items: flex-start;
  gap: 1.1rem;
  margin: 3.25rem 0 1.45rem;
  padding: 0 0 1.05rem;
  font-weight: 800;
  font-size: clamp(1.68rem, 2.4vw, 2.05rem);
  line-height: 1.38;
  letter-spacing: -0.025em;
  color: #0f172a;
  border-bottom: 1px solid rgba(99, 102, 241, 0.18);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.85);
}
.lp-seoArticle .lp-h3.lp-seoH3::before {
  content: "";
  flex: 0 0 auto;
  width: 0.42rem;
  margin-top: 0.38em;
  height: 1.45em;
  border-radius: 999px;
  background: linear-gradient(180deg, #818cf8 0%, #4f46e5 55%, #312e81 100%);
  box-shadow: 0 2px 8px rgba(79, 70, 229, 0.35);
}
.lp-seoArticle .lp-h3.lp-seoH3:first-of-type {
  margin-top: 1.25rem;
}

.lp-seoText {
  margin: 0 0 1.85rem;
  font-size: 1.52rem;
  line-height: 2;
  color: rgba(30, 41, 59, 0.9);
}
.lp-seoText:last-child {
  margin-bottom: 0;
}
@media screen and (max-width: 600px) {
  .lp-seoText {
    font-size: 1.42rem;
    line-height: 1.95;
  }
}

.lp-seoText--lead {
  margin-bottom: 2.15rem;
  font-size: 1.68rem;
  line-height: 1.95;
  color: rgba(15, 23, 42, 0.92);
}
@media screen and (max-width: 600px) {
  .lp-seoText--lead {
    font-size: 1.52rem;
    margin-bottom: 1.85rem;
  }
}

.lp-seoCta {
  margin-top: 3.6rem;
  padding-top: 2.85rem;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1.2rem;
  border-top: 1px solid rgba(15, 23, 42, 0.06);
  background: linear-gradient(180deg, rgba(238, 242, 255, 0.35) 0%, rgba(255, 255, 255, 0) 100%);
  margin-left: -3.8rem;
  margin-right: -3.8rem;
  margin-bottom: -3.2rem;
  padding-left: 3.8rem;
  padding-right: 3.8rem;
  padding-bottom: 3.2rem;
  border-radius: 0 0 2rem 2rem;
}
@media screen and (max-width: 600px) {
  .lp-seoCta {
    margin-left: -1.85rem;
    margin-right: -1.85rem;
    margin-bottom: -2.4rem;
    padding-left: 1.85rem;
    padding-right: 1.85rem;
    padding-bottom: 2.6rem;
    border-radius: 0 0 1.45rem 1.45rem;
  }
  .lp-seoCta .lp-btn--lg {
    width: 100%;
    max-width: 36rem;
  }
}

.lp-hero {
  position: relative;
  overflow: hidden;
  padding: 10.5rem 0 8.6rem;
  background: radial-gradient(1200px 600px at 15% 20%, rgba(74, 92, 219, 0.22) 0%, rgba(10, 25, 47, 0) 55%), radial-gradient(900px 480px at 90% 25%, rgba(21, 23, 116, 0.22) 0%, rgba(10, 25, 47, 0) 60%), linear-gradient(180deg, #0A192F 0%, #071426 100%);
}
@media screen and (max-width: 600px) {
  .lp-hero {
    padding: 8.4rem 0 6.4rem;
  }
}

.lp-hero,
.lp-hero .lp-hero__title,
.lp-hero .lp-hero__lead,
.lp-hero .lp-hero__note {
  color: #E8F0FF;
}

.lp-hero .lp-hero__lead {
  color: rgba(232, 240, 255, 0.74);
}

.lp-hero__bg {
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.72;
}

.lp-hero__digits {
  position: absolute;
  inset: -20% -10%;
  background-size: 720px 340px;
  mix-blend-mode: screen;
  filter: blur(0.2px);
  opacity: 0.22;
}
.lp-hero__digits::before {
  content: "0 1 2 3 4 5 6 7 8 9   8 7 6 5 4 3 2 1 0   0 1 2 3 4 5 6 7 8 9   9 8 7 6 5 4 3 2 1 0";
  position: absolute;
  inset: 0;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  letter-spacing: 0.34em;
  font-size: 3.2rem;
  color: rgba(232, 240, 255, 0.38);
  white-space: pre-wrap;
  line-height: 1.8;
  transform: rotate(-12deg);
}

.lp-hero__digits--a {
  animation: lpDigitsFlowA 18s linear infinite;
}

.lp-hero__digits--b {
  opacity: 0.18;
  animation: lpDigitsFlowB 24s linear infinite;
}

@keyframes lpDigitsFlowA {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(-120px, 240px, 0);
  }
}
@keyframes lpDigitsFlowB {
  0% {
    transform: translate3d(0, 0, 0);
  }
  100% {
    transform: translate3d(140px, -260px, 0);
  }
}
.lp-hero__inner {
  position: relative;
  z-index: 1;
  width: 120rem;
  max-width: 92%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 4rem 3.6rem;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .lp-hero__inner {
    grid-template-columns: 1fr;
    gap: 3.2rem;
  }
}

.lp-hero__content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  max-width: 58rem;
}

.lp-hero__title {
  margin: 0 0 1.35rem;
  font-size: 4.2rem;
  line-height: 1.2;
  letter-spacing: 0.02em;
}
@media screen and (max-width: 600px) {
  .lp-hero__title {
    font-size: 3rem;
  }
}

.lp-hero__lead {
  margin: 0 0 2.6rem;
  font-size: 1.7rem;
  line-height: 1.9;
  color: rgba(232, 240, 255, 0.74);
}

.lp-hero__cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-self: center;
  width: 100%;
  margin-bottom: 1.85rem;
}

.lp-hero__note {
  display: inline-flex;
  padding: 0.6rem 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 999px;
  color: rgba(232, 240, 255, 0.82);
  background: rgba(255, 255, 255, 0.04);
  font-size: 1.3rem;
}

.lp-hero .lp-hero__note {
  border-color: rgba(255, 255, 255, 0.22);
  background: rgba(255, 255, 255, 0.09);
  color: rgba(248, 252, 255, 0.92);
  align-self: center;
}

.lp-hero__panel {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 1.8rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.06) 0%, rgba(255, 255, 255, 0.03) 100%);
  padding: 2.5rem 2.35rem;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35);
  position: relative;
  overflow: hidden;
}
.lp-hero__panel::after {
  content: "";
  position: absolute;
  inset: -2px;
  background: radial-gradient(600px 160px at 40% 0%, rgba(74, 92, 219, 0.22) 0%, rgba(0, 0, 0, 0) 65%);
  pointer-events: none;
}

.lp-hero__panelTitle {
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.18em;
  font-weight: 700;
  font-size: 1.2rem;
  color: rgba(232, 240, 255, 0.75);
  margin-bottom: 1.2rem;
  position: relative;
  z-index: 1;
}

.lp-hero__flashStage {
  position: relative;
  z-index: 1;
  margin-bottom: 1.4rem;
  min-height: 16rem;
  border-radius: 1.2rem;
  background: #000000;
  border: 1px solid rgba(255, 255, 255, 0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.6rem 1.2rem;
  box-sizing: border-box;
}

.lp-hero__flashNum {
  font-family: "FlashAbacus", sans-serif;
  font-size: clamp(6.8rem, 16vw, 10rem);
  font-weight: normal;
  line-height: 1;
  letter-spacing: 0.05em;
  color: #00ff00;
  text-align: center;
  user-select: none;
  min-height: 1em;
  display: flex;
  align-items: center;
  justify-content: center;
  text-shadow: 0 0 24px rgba(0, 255, 0, 0.35);
}
@media screen and (max-width: 600px) {
  .lp-hero__flashNum {
    font-size: clamp(5.8rem, 21vw, 8.2rem);
  }
}

.lp-hero__panelMeta {
  position: relative;
  z-index: 1;
  font-size: 1.3rem;
  color: rgba(232, 240, 255, 0.7);
  margin: 0;
  line-height: 1.5;
}

.lp-btn {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  border-radius: 999px;
  padding: 1.2rem 1.6rem;
  font-size: 1.6rem;
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #E8F0FF;
  background: rgba(255, 255, 255, 0.04);
  transition: transform 160ms ease, background 160ms ease, border-color 160ms ease;
}
.lp-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.22);
}

.lp-btn--primary {
  background: linear-gradient(135deg, #151774 0%, #4a5cdb 100%);
  border-color: rgba(255, 255, 255, 0.08);
}

.lp-btn--ghost {
  background: rgba(255, 255, 255, 0.03);
}

.lp-btn.lp-btn--heroFlash {
  color: #071426;
  font-weight: 800;
  font-size: clamp(1.7rem, 2.35vw, 2.2rem);
  line-height: 1.25;
  letter-spacing: 0.02em;
  padding: 1.65rem 3.2rem;
  min-width: min(100%, 38rem);
  border: 1px solid rgba(255, 255, 255, 0.55);
  background: linear-gradient(180deg, #ffffff 0%, #e4ecff 55%, #d0dcff 100%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.75) inset, 0 10px 36px rgba(0, 0, 0, 0.38), 0 0 0 1px rgba(10, 25, 47, 0.25);
}
@media screen and (max-width: 600px) {
  .lp-btn.lp-btn--heroFlash {
    font-size: clamp(1.6rem, 4.6vw, 2rem);
    padding: 1.5rem 2.2rem;
    min-width: 0;
    width: 100%;
    max-width: 36rem;
  }
}
.lp-btn.lp-btn--heroFlash:hover {
  color: #050f1f;
  border-color: #ffffff;
  background: linear-gradient(180deg, #ffffff 0%, #f0f5ff 100%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.85) inset, 0 12px 40px rgba(0, 0, 0, 0.42), 0 0 0 1px rgba(0, 255, 128, 0.35);
}
.lp-btn.lp-btn--heroFlash:focus-visible {
  outline: 2px solid #7cffc4;
  outline-offset: 3px;
}

.lp-btn--lg {
  padding: 1.4rem 1.9rem;
}

.lp-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
@media screen and (max-width: 600px) {
  .lp-cards {
    grid-template-columns: 1fr;
  }
}

.lp-card {
  position: relative;
  border-radius: 2rem;
  padding: 2.5rem 2rem 2.2rem;
}

.lp-card__kicker {
  width: 5.2rem;
  height: 5.2rem;
  border-radius: 1.15rem;
  display: grid;
  place-items: center;
  margin-bottom: 1.15rem;
  flex-shrink: 0;
  color: #00264d;
  background: #cecece;
}

.lp-card__kickerSvg {
  width: 2.65rem;
  height: 2.65rem;
  display: block;
}

.lp-card__title {
  font-size: 2.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  margin: 0 0 0.75rem;
  line-height: 1.25;
}

.lp-card__text {
  margin: 0;
  font-size: 1.5rem;
  line-height: 1.85;
  color: rgba(51, 65, 85, 0.92);
}

.lp-featureList {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0;
  max-width: 72rem;
}

.lp-feature {
  position: relative;
  display: flex;
  gap: 1.85rem;
  align-items: flex-start;
  padding: 2.65rem 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
@media screen and (max-width: 600px) {
  .lp-feature {
    gap: 1.5rem;
    padding: 2.25rem 0;
  }
}

.lp-feature__body {
  flex: 1;
  min-width: 0;
  padding-top: 0.15rem;
}

.lp-feature__icon {
  width: 4.4rem;
  height: 4.4rem;
  display: grid;
  place-items: center;
  border-radius: 1.1rem;
  flex: 0 0 auto;
  color: #151774;
  background: #e8ecf2;
  border: none;
  box-shadow: none;
}

.lp-feature__iconSvg {
  width: 2.35rem;
  height: 2.35rem;
  display: block;
}

.lp-feature__title {
  font-size: 1.62rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
  margin: 0 0 0.28rem;
}

.lp-feature__text {
  font-size: 1.48rem;
  color: rgba(51, 65, 85, 0.9);
  line-height: 1.85;
  margin: 0;
}

.lp-badge {
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap: 2.4rem;
  align-items: center;
}
@media screen and (max-width: 600px) {
  .lp-badge {
    grid-template-columns: 1fr;
  }
}

.lp-badge__image {
  width: 100%;
  max-width: 56rem;
  margin-inline: auto;
  display: block;
  line-height: 0;
  font-size: 0;
  animation: lpBadgeReveal 0.78s cubic-bezier(0.22, 1, 0.36, 1) both;
  transition: transform 0.38s ease, box-shadow 0.38s ease;
}
@media (prefers-reduced-motion: reduce) {
  .lp-badge__image {
    animation: none;
  }
}

.lp-badge__sampleImg {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0;
  padding: 0;
}

@keyframes lpBadgeReveal {
  from {
    opacity: 0;
    transform: translateY(20px) scale(0.985);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
.lp-pricing {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  margin-bottom: 2.8rem;
}
@media screen and (max-width: 600px) {
  .lp-pricing {
    grid-template-columns: 1fr;
  }
}

.lp-plan {
  position: relative;
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 2rem;
  padding: 2.35rem 2.1rem;
  background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
  box-shadow: 0 1px 0 rgb(255, 255, 255) inset, 0 16px 40px rgba(15, 23, 42, 0.06);
  transition: border-color 180ms ease, box-shadow 180ms ease;
}
.lp-plan:hover {
  border-color: rgba(99, 102, 241, 0.18);
  box-shadow: 0 1px 0 rgb(255, 255, 255) inset, 0 20px 48px rgba(15, 23, 42, 0.08);
}

.lp-plan--featured {
  background: linear-gradient(155deg, rgba(238, 242, 255, 0.98) 0%, rgba(255, 255, 255, 0.96) 45%, rgba(224, 231, 255, 0.55) 100%);
  border-color: rgba(99, 102, 241, 0.32);
  box-shadow: 0 1px 0 rgb(255, 255, 255) inset, 0 20px 50px rgba(79, 70, 229, 0.12);
}

.lp-plan__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 1.25rem;
  gap: 1rem;
}

.lp-plan__name {
  font-size: 1.85rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #0f172a;
}

.lp-plan__price {
  font-size: 1.85rem;
  font-family: "Roboto", sans-serif;
  letter-spacing: 0.04em;
  font-weight: 700;
  color: #4338ca;
}

.lp-plan__list {
  margin: 0;
  padding-left: 1.3em;
  color: rgba(51, 65, 85, 0.9);
  font-size: 1.48rem;
  line-height: 1.85;
}

.lp-ctaBlock {
  border: 1px solid rgba(15, 23, 42, 0.08);
  border-radius: 2.2rem;
  padding: 2.5rem 2.4rem;
  background: linear-gradient(150deg, rgba(255, 255, 255, 0.98) 0%, rgba(238, 242, 255, 0.92) 45%, rgb(248, 250, 252) 100%);
  box-shadow: 0 1px 0 rgb(255, 255, 255) inset, 0 24px 56px rgba(15, 23, 42, 0.08);
}

.lp-ctaBlock__title {
  font-size: 2.05rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 1.6rem;
  color: #0f172a;
}

.lp-ctaBlock__actions {
  display: flex;
  gap: 1.2rem;
  flex-wrap: wrap;
  margin-bottom: 1.2rem;
}

.lp-ctaBlock__note {
  font-size: 1.3rem;
  color: rgba(51, 65, 85, 0.68);
}

.lp-ctaBlock .lp-btn--primary {
  color: #ffffff;
  font-weight: 700;
  border-color: rgba(255, 255, 255, 0.28);
  background: linear-gradient(135deg, #4338ca 0%, #6366f1 50%, #4f46e5 100%);
  box-shadow: 0 10px 28px rgba(67, 56, 202, 0.38);
}
.lp-ctaBlock .lp-btn--primary:hover {
  border-color: rgba(255, 255, 255, 0.45);
  box-shadow: 0 14px 36px rgba(67, 56, 202, 0.45);
}

.lp-ctaBlock .lp-btn--ghost {
  color: #312e81;
  font-weight: 600;
  background: rgba(255, 255, 255, 0.88);
  border-color: rgba(49, 46, 129, 0.22);
}
.lp-ctaBlock .lp-btn--ghost:hover {
  background: #ffffff;
  border-color: rgba(49, 46, 129, 0.35);
}

.lp-kicker {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 1.15rem;
  border-radius: 999px;
  margin-bottom: 1.4rem;
  font-size: 1.28rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #312e81;
  background: linear-gradient(135deg, rgba(224, 231, 255, 0.95), rgba(199, 210, 254, 0.75));
  border: 1px solid rgba(99, 102, 241, 0.28);
  box-shadow: 0 2px 12px rgba(79, 70, 229, 0.1);
}