/* ========================================
	 Base / Reset
======================================== */
* {
	box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
figure,
blockquote,
dl,
dd {
	margin: 0;
	padding: 0;
}

ul,
ol {
	list-style: none;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
	text-decoration: none;
}

button,
input,
textarea,
select {
	font: inherit;
}

/* ========================================
	 Variables
======================================== */
:root {
	--color-text-base: #2d2d32;
	--color-white: #ffffff;
	--color-primary: #64629d;
	--color-sub-primary: #9f9ec1;
	--color-bg-accent: #edecfc;
	--color-bg-light: #f9f9f9;
	--color-black: #000000;

	--font-ja: "Noto Sans JP", sans-serif;
	--font-en: "Futura", "Montserrat", sans-serif;

	--fz-copy: 60px;
	--fz-tagline: 18px;
	--fz-body-sm: 14px;
	--fz-body: 16px;
	--fz-body-lg: 18px;
	--fz-heading-sm: 24px;
	--fz-heading-md: 28px;
	--fz-heading-lg: 36px;
	--fz-heading-xl: 48px;
	--fz-cta-sm: 16px;
	--fz-cta: 18px;
	--fz-cta-lg: 24px;

	--container-width: 1200px;
	--container-padding: 20px;

	--breakpoint-sp: 767px;
}

/* ========================================
	 Layout
======================================== */
body {
	font-family: var(--font-ja);
	font-size: var(--fz-body);
	color: var(--color-text-base);
	background-color: var(--color-white);
	line-height: 1.5;
}

body.is-menu-open {
	overflow: hidden;
}

.l-page {
	min-height: 100vh;
}

.l-container {
	width: 100%;
	max-width: calc(var(--container-width) + var(--container-padding) * 2);
	margin-inline: auto;
	padding-inline: var(--container-padding);
}

/* ========================================
	 PC First (default)
======================================== */
.l-header {
	height: 72px;
	background-color: var(--color-white);
}

.l-main {
	padding-top: 0;
}

.l-footer {
	padding-top: 56px;
	padding-bottom: 24px;
	background-color: var(--color-white);
}

/* ========================================
	 Components
======================================== */
.c-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 56px;
	padding: 12px 32px;
	border-radius: 999px;
	border: 1px solid transparent;
	font-size: var(--fz-cta-sm);
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	transition: transform 0.3s ease, box-shadow 0.3s ease, background-color 0.3s ease, color 0.3s ease,
		border-color 0.3s ease;
}

.c-btn:hover {
	transform: translateY(-4px);
	box-shadow: 0 10px 24px rgba(45, 45, 50, 0.16);
}

/* 料金表CTA用 */
.c-btn--pricing {
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.c-btn--pricing:hover {
	background-color: var(--color-bg-light);
	color: var(--color-primary);
	border-color: var(--color-primary);
}

/* ========================================
	 Header (PC)
======================================== */
.p-header {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	column-gap: 24px;
	height: 100%;
	padding-right: 116px;
}

.p-header__nav {
	margin-left: auto;
}

.p-header__logo {
	display: inline-flex;
	flex-direction: column;
	row-gap: 2px;
	color: var(--color-text-base);
}

.p-header__logo-main {
	font-family: var(--font-en);
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1;
}

.p-header__logo-sub {
	font-family: var(--font-en);
	font-size: 12px;
	font-weight: 500;
	letter-spacing: 0.16em;
	line-height: 1;
	color: var(--color-primary);
}

.p-header__nav-list {
	display: flex;
	align-items: center;
	column-gap: 16px;
}

.p-header__nav-link {
	position: relative;
	display: inline-block;
	font-size: var(--fz-body);
	font-weight: 500;
	line-height: 1;
	cursor: pointer;
	padding-bottom: 3px;
}

.p-header__nav-link::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background-color: currentcolor;
	transform: scaleX(0);
	transform-origin: right center;
	transition: transform 0.3s ease;
}

.p-header__nav-link:hover::after {
	transform: scaleX(1);
	transform-origin: left center;
}

.c-btn--header {
	min-height: 46px;
	padding: 10px 28px;
	margin-left: 14px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.c-btn--header:hover {
	background-color: var(--color-sub-primary);
	border-color: var(--color-sub-primary);
}

.p-header__menu-btn {
	display: none;
	border: 0;
	background: transparent;
	padding: 0;
	width: 32px;
	height: 24px;
	cursor: pointer;
}

.p-header__menu-line {
	display: block;
	width: 100%;
	height: 2px;
	border-radius: 999px;
	background-color: var(--color-primary);
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.p-header__menu-line + .p-header__menu-line {
	margin-top: 7px;
}

.p-header__menu-cta {
	display: none;
}

/* ========================================
	 Footer (PC)
======================================== */
.l-footer {
  background-color: var(--color-black);
}

.p-footer {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	column-gap: 48px;
}

.p-footer__logo {
	display: inline-flex;
	flex-direction: column;
	row-gap: 4px;
}

.p-footer__logo-main {
	font-family: var(--font-en);
	font-size: 24px;
	font-weight: 900;
	letter-spacing: 0.01em;
	line-height: 1;
  color: var(--color-white);
}

.p-footer__left {
	display: flex;
	flex-direction: column;
	row-gap: 26px;
}

.p-footer__menu {
	display: flex;
	align-items: center;
	column-gap: 30px;
}

.p-footer__nav {
	margin-top: 4px;
}

.p-footer__nav-link {
	position: relative;
	display: inline-block;
	font-size: 14px;
	font-weight: 700;
	line-height: 1;
	padding-bottom: 3px;
  color: var(--color-white);
}

.p-footer__nav-link::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background-color: currentcolor;
	transform: scaleX(0);
	transform-origin: right;
	transition: transform 0.3s ease;
}

.p-footer__nav-link:hover::after {
	transform: scaleX(1);
	transform-origin: left;
}

.p-footer__meta {
	display: flex;
	align-items: center;
	column-gap: 24px;
	font-size: 12px;
	font-weight: 400;
	line-height: 1;
	letter-spacing: 0.04em;
	color: var(--color-white);
}

.p-footer__right {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	row-gap: 16px;
	padding-top: 16px;
}

.p-footer__sns-title {
	font-family: var(--font-en);
	font-size: 16px;
	font-weight: 500;
	line-height: 1;
	color: var(--color-white);
}

.p-footer__sns-list {
	display: flex;
	align-items: center;
	column-gap: 16px;
}

.p-footer__sns-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	color: var(--color-white);
	transition: transform 0.3s ease, color 0.3s ease;
}

.p-footer__sns-link svg {
	width: 24px;
	height: 24px;
	fill: currentColor;
}

.p-footer__sns-link:hover {
	transform: translateY(-2px);
	color: var(--color-sub-primary);
}

/* ========================================
	 First View (PC)
======================================== */
.p-fv {
	background-color: var(--color-bg-accent);
}

.p-fv__inner {
	min-height: 580px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	column-gap: 32px;
	padding-top: 24px;
	padding-bottom: 24px;
}

.p-fv__content {
	flex: 0 1 560px;
}

.p-fv__catch {
	font-size: 60px;
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: 0.02em;
	color: var(--color-text-base);
}

.p-fv__catch-line {
	white-space: nowrap;
}

.p-fv__lead {
	margin-top: 24px;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.875;
	color: var(--color-text-base);
}

.p-fv__cta {
	display: flex;
	align-items: center;
	column-gap: 16px;
	margin-top: 32px;
}

.c-btn--fv-primary {
	min-height: 58px;
	padding: 14px 40px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.c-btn--fv-primary:hover {
	background-color: var(--color-sub-primary);
	border-color: var(--color-sub-primary);
}

.c-btn--fv-secondary {
	min-height: 58px;
	padding: 14px 40px;
	background-color: var(--color-white);
	color: var(--color-primary);
	border-color: var(--color-primary);
}

.c-btn--fv-secondary:hover {
	background-color: var(--color-bg-light);
}

.p-fv__visual {
	flex: 0 0 515px;
	width: 515px;
	height: 515px;
}

.p-fv__visual img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* ========================================
	 About (PC)
======================================== */
.p-about {
	background-color: var(--color-white);
	padding-top: 88px;
	padding-bottom: 96px;
}

.p-about__inner {
	display: flex;
	justify-content: center;
}

.p-about__content {
	width: 100%;
	max-width: 860px;
	text-align: center;
}

.p-about__eyebrow {
	color: var(--color-sub-primary);
}

.p-about__title {
	color: var(--color-primary);
}

.p-about__text {
	margin-top: 24px;
	font-size: 16px;
	font-weight: 400;
	line-height: 2;
	color: var(--color-text-base);
}

.p-about__text-strong {
	font-weight: 700;
}

.p-about__text--sub {
	margin-top: 16px;
}

.p-about__sp-br {
	display: none;
}

.p-about__actions {
	display: flex;
	justify-content: center;
	margin-top: 36px;
}

.c-btn--about-primary {
	min-height: 58px;
	padding: 14px 36px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.c-btn--about-primary:hover {
	background-color: var(--color-sub-primary);
	border-color: var(--color-sub-primary);
}

.c-section-eyebrow {
	font-family: var(--font-en);
	font-size: 36px;
	font-weight: 700;
	line-height: 1;
}

.c-section-title {
	margin-top: 20px;
	font-size: 48px;
	font-weight: 700;
	line-height: 1.35;
}

.c-trial-cta {
	background-color: var(--color-text-base);
	padding-top: 60px;
	padding-bottom: 60px;
}

.c-trial-cta__inner {
	text-align: center;
}

.c-trial-cta__title {
	font-size: 36px;
	font-weight: 700;
	line-height: 1;
  letter-spacing: 2%;
	color: var(--color-white);
}

.c-trial-cta__btn {
	margin-top: 32px;
	min-height: 58px;
	padding: 14px 40px;
	background-color: var(--color-primary);
	color: var(--color-white);
	border-color: var(--color-primary);
}

.c-trial-cta__btn:hover {
	background-color: var(--color-sub-primary);
	border-color: var(--color-sub-primary);
}

/* ========================================
	 Feature (PC)
======================================== */
.p-feature {
	background-color: var(--color-bg-light);
	padding-top: 104px;
	padding-bottom: 120px;
}

.p-feature__inner {
	max-width: 1080px;
}

.p-feature__eyebrow {
	text-align: center;
	color: var(--color-sub-primary);
}

.p-feature__title {
	margin-top: 18px;
	text-align: center;
	color: var(--color-primary);
}

.p-feature__list {
	margin-top: 64px;
	display: flex;
	flex-direction: column;
	row-gap: 72px;
}

.p-feature__item {
	display: flex;
	align-items: center;
	justify-content: center;
}

.p-feature__text {
	flex: 0 0 auto;
	width: 742px;
	height: 367px;
	padding: 64px 40px;
	background-color: var(--color-white);
	border-radius: 20px;
	position: relative;
	z-index: 2;
}

.p-feature__head {
	display: flex;
	align-items: flex-start;
	column-gap: 18px;
}

.p-feature__num {
	font-family: var(--font-en);
	font-size: 62px;
	font-weight: 700;
	line-height: 1;
	color: var(--color-primary);
	flex-shrink: 0;
	width: 86px;
}

.p-feature__heading {
	font-size: 36px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-text-base);
}

.p-feature__heading-nowrap {
	white-space: nowrap;
}

.p-feature__desc {
	margin-top: 18px;
	margin-left: 104px;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.9;
	color: var(--color-text-base);
}

.p-feature__visual {
	flex: 0 0 520px;
	width: 520px;
	height: 520px;
	margin-left: -68px;
  margin-top: -60px;
	position: relative;
	z-index: 3;
}

.p-feature__visual img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.p-feature__item--reverse {
	flex-direction: row-reverse;
}

.p-feature__item--reverse .p-feature__visual {
	margin-left: 0;
	margin-right: -68px;
  	margin-bottom: -60px;
}

/* ========================================
	 Users (PC)
======================================== */
.p-users {
	background-color: var(--color-white);
	padding-top: 104px;
	padding-bottom: 120px;
}

.p-users__inner {
	text-align: center;
}

.p-users__eyebrow {
	color: var(--color-sub-primary);
}

.p-users__title {
	color: var(--color-primary);
}

.p-users__list {
	margin-top: 56px;
	display: grid;
	grid-template-columns: repeat(4, 213px);
	justify-content: center;
	column-gap: 40px;
	row-gap: 50px;
}

.p-users__item {
	width: 213px;
	height: 169px;
}

.p-users__item img {
	width: 213px;
	height: 169px;
	object-fit: cover;
}

/* ========================================
	 Flow (PC)
======================================== */
.p-flow {
	background-color: var(--color-bg-light);
	padding-top: 104px;
	padding-bottom: 120px;
}

.p-flow__inner {
	text-align: center;
}

.p-flow__eyebrow {
	color: var(--color-sub-primary);
}

.p-flow__title {
	color: var(--color-primary);
}

.p-flow__list {
	margin-top: 56px;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	column-gap: 57.5px;
}

.p-flow__item {
	width: 280px;
	text-align: left;
}

.p-flow__num {
	position: absolute;
	left: -15px;
	top: -17px;
	z-index: 2;
	font-family: var(--font-en);
	font-size: 48px;
	font-weight: 700;
	line-height: 1;
	color: var(--color-primary);
}

.p-flow__visual-box {
	margin-top: 12px;
	width: 280px;
	height: 191px;
	background-color: var(--color-bg-accent);
	border-radius: 30px;
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: visible;
}

.p-flow__visual-box img {
	max-width: 100%;
	max-height: 100%;
	object-fit: contain;
}

.p-flow__heading {
	margin-top: 20px;
	width: fit-content;
	max-width: 100%;
	margin-inline: auto;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.45;
	text-align: left;
	color: var(--color-text-base);
}

.p-flow__desc {
	margin-top: 8px;
	width: fit-content;
	max-width: 100%;
	margin-inline: auto;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.9;
	text-align: left;
	color: var(--color-text-base);
}

.p-flow__arrow {
	width: 0;
	height: 0;
	margin-top: 87px;
	border-top: 22px solid transparent;
	border-bottom: 22px solid transparent;
	border-left: 14px solid rgba(196, 196, 196, 1);
	flex-shrink: 0;
}

/* ========================================
	 Price (PC)
======================================== */
.p-price {
	background-color: var(--color-white);
	padding-top: 104px;
	padding-bottom: 120px;
}

.p-price__inner {
	text-align: center;
}

.p-price__eyebrow {
	color: var(--color-sub-primary);
}

.p-price__title {
	color: var(--color-primary);
}

.p-price__list {
	margin-top: 56px;
	width: 1020px;
	margin-inline: auto;
	display: grid;
	grid-template-columns: 280px repeat(3, 246.6667px);
	align-items: flex-end;
	column-gap: 0;
}

.p-price__spacer {
	width: 280px;
	height: 1px;
}

.p-price__item {
	width: 246.6667px;
	min-height: 270px;
	padding: 54px 28px 32px;
	border-radius: 0;
	background-color: var(--color-black);
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.p-price__item--basic {
	min-height: 286px;
	background-color: var(--color-primary);
  padding: 72px 28px 32px;
}

.p-price__plan {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.4;
	color: var(--color-white);
}

.p-price__value {
	margin-top: 17px;
	line-height: 1;
	color: var(--color-white);
}

.p-price__currency,
.p-price__unit {
	font-size: 20px;
	font-weight: 700;
}

.p-price__amount {
  font-size: 30px;
  font-weight: 700;
}

.p-price__features {
	margin-top: 28px;
	display: flex;
	flex-direction: column;
	row-gap: 12px;
	font-size: 16px;
	line-height: 1.8;
	color: var(--color-text-base);
}

.p-price__btn {
	margin-top: 28px;
	align-self: center;
	width: 234px;
	height: 50px;
	min-height: 50px;
	padding: 0;
	border: 2px solid rgba(255, 255, 255, 1);
	background-color: rgba(255, 255, 255, 1);
	color: var(--color-text-base);
}

.p-price__btn:hover {
	background-color: transparent;
	color: rgba(255, 255, 255, 1);
	border-color: rgba(255, 255, 255, 1);
}

.p-price__item--basic .p-price__btn {
	background-color: transparent;
	color: rgba(255, 255, 255, 1);
	border-color: rgba(255, 255, 255, 1);
}

.p-price__item--basic .p-price__btn:hover {
	background-color: rgba(255, 255, 255, 1);
	color: var(--color-primary);
	border-color: rgba(255, 255, 255, 1);
}

.p-price__table {
	width: 1020px;
	margin: 0 auto 0;
	border-collapse: collapse;
	table-layout: fixed;
}

.p-price__table tr {
	height: 60px;
}

.p-price__table tr:nth-child(odd) {
	background-color: var(--color-bg-accent);
}

.p-price__table tr:nth-child(even) {
	background-color: var(--color-white);
}

.p-price__table th,
.p-price__table td {
	vertical-align: middle;
	font-size: 24px;
	color: var(--color-text-base);
}

.p-price__table th {
	width: 27.45%;
	padding-left: 30px;
	text-align: left;
	font-weight: 400;
}

.p-price__table td {
	width: 24.18%;
	text-align: center;
	font-weight: 400;
}

.p-price__table td:nth-child(3) {
	font-weight: 700;
}

.p-price__table-actions {
	width: 1020px;
	margin: 16px auto 0;
	display: grid;
	grid-template-columns: 280px repeat(3, 246.6667px);
	column-gap: 0;
	align-items: center;
}

.p-price__table-actions-spacer {
	width: 280px;
	height: 1px;
}

.p-price__table-btn {
	width: 234px;
	height: 50px;
	min-height: 50px;
	justify-self: center;
	padding: 0;
	border: 2px solid var(--color-text-base);
	background-color: var(--color-white);
	color: var(--color-text-base);
}

.p-price__table-btn:hover {
	background-color: var(--color-bg-light);
	box-shadow: none;
}

.p-price__table-btn--basic {
	border-color: var(--color-primary);
	background-color: var(--color-primary);
	color: var(--color-white);
}

.p-price__table-btn--basic:hover {
	background-color: var(--color-sub-primary);
	border-color: var(--color-sub-primary);
	box-shadow: none;
}

/* ========================================
	 Question (PC)
======================================== */
.p-question {
	background-color: var(--color-bg-light);
	padding-top: 104px;
	padding-bottom: 120px;
}

.p-question__inner {
	text-align: center;
}

.p-question__eyebrow {
	color: var(--color-sub-primary);
}

.p-question__title {
	color: var(--color-primary);
}

.p-question__list {
	width: 1020px;
	margin: 56px auto 0;
	display: flex;
	flex-direction: column;
	row-gap: 24px;
}

.p-question__item {
	text-align: left;
	padding: 18px 24px;
	border-radius: 10px;
}

.p-question__q {
	width: 100%;
	display: flex;
	align-items: flex-start;
	column-gap: 14px;
	padding: 12px 14px;
	border: 0;
	background: var(--color-primary);
	border-radius: 8px;
	text-align: left;
	cursor: pointer;
}

.p-question__label,
.p-question__q-text,
.p-question__a {
	font-size: 18px;
	line-height: 1.8;
	color: var(--color-text-base);
}

.p-question__q .p-question__label,
.p-question__q .p-question__q-text {
	color: var(--color-white);
}

.p-question__label {
	font-weight: 700;
	color: var(--color-primary);
	flex-shrink: 0;
}

.p-question__a-wrap {
	max-height: 0;
	overflow: hidden;
	opacity: 0;
	margin-top: 0;
	transition: max-height 0.35s ease, opacity 0.25s ease, margin-top 0.25s ease;
}

.p-question__a-wrap.is-open {
	margin-top: 14px;
	opacity: 1;
}

.p-question__a {
	display: flex;
	align-items: flex-start;
	column-gap: 10px;
	padding-inline: 14px;
}

/* ========================================
	 SP (<= 767px)
======================================== */
@media screen and (max-width: 767px) {
	:root {
		--container-padding: 16px;
	}

	.l-header {
		height: auto;
	}

	.l-footer {
		padding-top: 36px;
		padding-bottom: 16px;
	}

	.p-footer {
		flex-direction: column;
		align-items: center;
		row-gap: 28px;
	}

	.p-footer__left {
		order: 2;
		width: 100%;
		align-items: center;
	}

	.p-footer__logo {
		align-items: center;
	}

	.p-footer__logo-main {
		font-size: 24px;
	}

	.p-footer__logo-sub {
		font-size: 13px;
	}

	.p-footer__nav {
		width: auto;
		margin-top: 0;
	}

	.p-footer__menu {
		flex-direction: column;
		align-items: center;
		row-gap: 10px;
		column-gap: 0;
		flex-wrap: nowrap;
	}

	.p-footer__meta {
		flex-direction: column;
		align-items: center;
		row-gap: 10px;
		text-align: center;
	}

	.p-footer__right {
		order: 1;
		width: 100%;
		padding-top: 0;
		align-items: center;
		row-gap: 14px;
	}

	.p-footer__sns-title {
		text-align: center;
		font-size: 18px;
	}

	.p-footer__sns-list {
		column-gap: 12px;
	}

	.p-header {
		height: 72px;
		position: relative;
		justify-content: space-between;
		align-items: center;
		padding-right: 0;
	}

	.p-header__logo-main {
		font-size: 20px;
	}

	.p-header__logo-sub {
		font-size: 10px;
	}

	.p-header__menu-btn {
		display: block;
		position: relative;
		z-index: 20;
		margin-right: 17px;
	}

	.p-header.is-open .p-header__menu-line:nth-child(1) {
		transform: translateY(9px) rotate(45deg);
	}

	.p-header.is-open .p-header__menu-line:nth-child(2) {
		opacity: 0;
	}

	.p-header.is-open .p-header__menu-line:nth-child(3) {
		transform: translateY(-9px) rotate(-45deg);
	}

	.p-header__nav {
		position: fixed;
		top: 72px;
		left: 0;
		width: 100%;
		height: calc(100dvh - 72px);
		padding: 56px 32px 40px;
		background-color: var(--color-bg-accent);
		border-radius: 0;
		box-shadow: none;
		overflow-y: auto;
		opacity: 0;
		visibility: hidden;
		transform: translateY(-8px);
		transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
		z-index: 10;
	}

	.p-header.is-open .p-header__nav {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
	}

	.p-header__nav-list {
		flex-direction: column;
		align-items: flex-start;
		row-gap: 34px;
	}

	.p-header__nav-list li {
		position: relative;
		padding-left: 52px;
	}

	.p-header__nav-list li::before {
		content: "";
		position: absolute;
		left: 8px;
		top: 50%;
		width: 15px;
		height: 15px;
		border: 2px solid var(--color-primary);
		transform: translateY(-50%) rotate(45deg);
	}

	.p-header__nav-link {
		font-size: 24px;
		font-weight: 700;
		line-height: 1.25;
		padding-bottom: 0;
	}

	.p-header__nav-link::after {
		display: none;
	}

	.p-header__menu-cta {
		display: flex;
		flex-direction: column;
		row-gap: 18px;
		margin-top: 64px;
	}

	.p-header__menu-cta-btn {
		width: 300px;
		justify-content: center;
		min-height: 64px;
		font-size: 18px;
		box-shadow: 0 5px 8px rgba(45, 45, 50, 0.2);
	}

	.p-header__menu-cta .c-btn--fv-secondary {
		background-color: #f8f8f8;
	}

	.c-btn--header {
		display: none;
	}

	.p-fv__inner {
		min-height: auto;
		flex-direction: column;
		align-items: flex-start;
		row-gap: 0;
		padding-top: 60px;
		padding-bottom: 60px;
	}

	.p-fv__content {
		flex: initial;
		display: contents;
	}

	.p-fv__catch {
		order: 1;
		margin-top: 6px;
		font-size: 30px;
		line-height: 1.4;
	}

	.p-fv__catch-line {
		white-space: normal;
	}

	.p-fv__lead {
		order: 2;
		margin-top: 16px;
		font-size: 16px;
		line-height: 1.75;
	}

	.p-fv__lead br {
		display: none;
	}

	.p-fv__visual {
		order: 3;
		flex: initial;
		width: 305px;
		height: 305px;
		margin-top: 20px;
		margin-inline: auto;
	}

	.p-fv__visual img {
		width: 100%;
		height: 100%;
		object-fit: contain;
	}

	.p-fv__cta {
		order: 4;
		flex-direction: column;
		align-items: stretch;
		width: 300px;
		row-gap: 16px;
		margin: 24px auto 0;
	}

	.p-fv__cta .c-btn--fv-primary,
	.p-fv__cta .c-btn--fv-secondary {
		min-height: 58px;
		padding: 14px 24px;
		font-size: 18px;
		border-width: 2px;
	}

	.p-about {
		padding-top: 56px;
		padding-bottom: 56px;
	}

	.c-section-eyebrow {
		font-size: 22px;
	}

	.c-section-title {
		margin-top: 30px;
		font-size: 32px;
		line-height: 1.45;
	}

	.p-about__text {
		margin-top: 16px;
		font-size: 16px;
		line-height: 1.8;
	}

	.p-about__text--sub {
		margin-top: 24px;
	}

	.p-about__sp-br {
		display: initial;
	}

	.p-price__spacer {
		display: none;
	}

	.p-about__actions {
		justify-content: center;
		margin-top: 24px;
	}

	.c-btn--about-primary {
		min-height: 52px;
		padding: 12px 24px;
	}

	.p-feature {
		padding-top: 64px;
		padding-bottom: 72px;
	}

	.p-feature__title {
		margin-top: 12px;
		line-height: 1.4;
	}

	.p-feature__list {
		margin-top: 100px;
		row-gap: 0;
	}

	.p-feature__item {
		flex-direction: column;
		align-items: flex-start;
		row-gap: 0;
		width: 100%;
		margin-top: 0;
	}

	.p-feature__item + .p-feature__item {
		margin-top: 100px;
	}

	.p-feature__item--reverse {
		flex-direction: column;
	}

	.p-feature__text {
		order: 2;
		width: 100vw;
		height: auto;
		max-width: none;
		padding: 24px 20px;
		border-radius: 16px;
		text-align: left;
		margin-top: -20px;
		margin-left: calc(50% - 50vw);
		margin-right: calc(50% - 50vw);
		position: relative;
		z-index: 0;
	}

	.p-feature__head {
		display: block;
	}

	.p-feature__num {
		font-size: 42px;
	}

	.p-feature__heading {
		margin-top: 8px;
		font-size: 20px;
	}

	.p-feature__desc {
		margin-left: 0;
		margin-top: 8px;
		font-size: 14px;
		line-height: 1.8;
	}

	.p-feature__visual {
		order: 1;
		flex: initial;
		width: 280px;
		height: 280px;
		display: flex;
		justify-content: center;
		align-items: center;
		margin-left: 0;
		margin-right: 0;
		margin-inline: auto;
		position: relative;
		z-index: 2;
	}

	.p-feature__visual img {
		display: block;
		width: 100%;
		height: 100%;
		object-fit: contain;
		object-position: center;
		margin-top: 80px;
	}

	.p-feature__heading-nowrap {
		white-space: normal;
	}

	.p-feature__item--reverse .p-feature__visual {
		margin-left: 0;
		margin-right: 0px;
		margin-bottom: 0px;
		margin-inline: auto;
		align-self: center;
	}

	.p-users {
		padding-top: 64px;
		padding-bottom: 72px;
	}

	.p-users__list {
		margin-top: 32px;
		grid-template-columns: repeat(4, minmax(0, 1fr));
		column-gap: 11px;
		row-gap: 12px;
	}

	.p-users__item {
		width: 100%;
		height: auto;
	}

	.p-users__item img {
		width: 100%;
		height: auto;
	}

	.p-flow {
		padding-top: 64px;
		padding-bottom: 72px;
	}

	.p-flow__list {
		margin-top: 36px;
		flex-direction: column;
		align-items: center;
		row-gap: 60px;
	}

	.p-flow__item {
		width: 100%;
		max-width: 320px;
		margin-top: 40px;
	}

	.p-flow__visual-box {
		width: 100%;
		height: auto;
		aspect-ratio: 280 / 191;
	}

	.p-flow__num {
		font-size: 48px;
		left: 0px;
		top: -24px;
	}

	.p-flow__heading {
		margin-top: 16px;
		font-size: 22px;
	}

	.p-flow__desc {
		font-size: 16px;
		line-height: 1.8;
	}

	.p-flow__arrow {
		display: none;
	}

	.p-price {
		padding-top: 64px;
		padding-bottom: 72px;
	}

	.p-price__scroll {
		margin-top: 32px;
		overflow-x: auto;
		overflow-y: hidden;
		-webkit-overflow-scrolling: touch;
	}

	.p-price__list {
		margin-top: 0;
	}

	.p-price__spacer {
		display: block;
	}

	.p-price__item,
	.p-price__item--basic {
		max-width: none;
	}

	.p-price__plan {
		font-size: 24px;
	}

	.p-price__value {
		font-size: 40px;
	}

	.p-price__currency,
	.p-price__unit {
		font-size: 16px;
	}

	.p-price__features {
		margin-top: 16px;
	}

	.p-price__table {
		margin-top: 20px;
	}

	.p-price__table-actions {
		margin-top: 14px;
	}

	.p-price__table-actions-spacer {
		display: block;
	}

	.p-price__table-btn {
		max-width: none;
	}

	.p-price__table tr {
		height: 60px;
	}

	.p-price__table th,
	.p-price__table td {
		font-size: 24px;
		padding-block: 0;
	}

	.p-price__table th {
		padding-left: 30px;
	}

	.p-question {
		padding-top: 64px;
		padding-bottom: 72px;
	}

	.p-question__list {
		width: 100%;
		margin-top: 32px;
		row-gap: 24px;
	}

	.p-question__item {
		padding: 14px 16px;
	}

	.p-question__label,
	.p-question__q-text,
	.p-question__a {
		font-size: 18px;
		line-height: 1.7;
	}

	.c-trial-cta {
		padding-top: 56px;
		padding-bottom: 56px;
	}

	.c-trial-cta__title {
		font-size: 18px;
		line-height: 1.45;
	}

	.c-trial-cta__btn {
		margin-top: 20px;
		min-height: 52px;
		padding: 12px 24px;
	}
}
