/* ボックスサイズは全要素に border-box を適用 */

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

/* ベースの文字スタイル設定 */

body {
	color: #463B33;
	font-family: "M PLUS Rounded 1c", sans-serif;
	font-size: 14px;
	font-weight: 500;
	margin: 0;
	padding: 0;
}

/* 見出し・段落などの基本要素を初期化 */

h1,
h2,
h3,
h4,
h5,
h6,
p,
ul,
ol,
li,
dl,
dt,
dd,
table,
th,
td,
tr,
figure,
figcaption,
blockquote,
pre {
	font-size: 100%;
	font-weight: normal;
	margin: 0;
	padding: 0;
	vertical-align: baseline;
}

/* セクショニング要素の display をブロックに統一 */

header,
footer,
nav,
section,
article,
main,
aside,
figure,
figcaption {
	display: block;
}

/* リストスタイルのリセット */

ul,
ol {
	list-style: none;
}

/* 画像の扱い */

img {
	border-style: none;
	height: auto;
	max-width: 100%;
	vertical-align: middle;
}

/* リンクのリセット */

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

/* ボタンリセット */

button {
	background: transparent;
	border: none;
	box-shadow: none;
	cursor: pointer;
	font: inherit;
	margin: 0;
	padding: 0;
}

/* フォーム要素のリセット */

input,
select,
textarea {
	background: none;
	border: none;
	box-shadow: none;
	color: inherit;
	font: inherit;
	margin: 0;
	padding: 0;
	vertical-align: top;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

html,
body {
	overflow-x: hidden !important;
}

body {
	box-sizing: border-box;
	color: #222;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
}

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

a {
	color: inherit;
}

/* スムーススクロール化 */

html {
	scroll-behavior: smooth;
}

/* 固定ヘッダーで見出しが隠れないように上マージンを確保 */

:root {
	--header-h: 64px;
}

/* ヘッダーの実高さに合わせて調整 */

[id] {
	scroll-margin-top: calc(var(--header-h) + 12px);
}

/* もしブレークポイントでヘッダー高さが変わるなら上書き */

.l-footer {
	padding-bottom: 64px;
	position: relative;
}

.l-footer--sp {
	display: block;
}

.l-footer--pc {
	display: none;
}

.l-faq {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-voice {
	background-color: #CAD6DF;
	padding-top: 120px;
}

.l-business {
	padding-top: 120px;
}

.l-projects {
	padding-top: 120px;
}

.l-projects.lower {
	padding-bottom: 120px;
	padding-top: 96px;
}

.l-concept {
	overflow: hidden;
	padding-top: 120px;
}

.l-concept--sp {
	display: block;
}

.l-concept--pc {
	display: none;
}

.l-about--sp {
	display: block;
}

.l-about--pc {
	display: none;
}

.l-sectionTitle {
	margin-bottom: 40px;
}

.l-can {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-can__sectionTitle {
	margin-bottom: 40px;
}

.l-can--sp {
	display: block;
}

.l-can--pc {
	display: none;
}

.l-inner {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--contact {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--introduce {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--flow {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--faq {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--voice {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--drawer {
	padding-left: 20px;
	padding-right: 20px;
}

.l-inner--price {
	padding-left: 0px;
	padding-right: 0px;
}

.l-cta {
	background: #3e3b3f;
	border: 1px solid #D9D9D9;
	border-radius: 15px;
	margin-bottom: 64px;
	overflow: hidden;
	padding-bottom: 64px;
	padding-top: 64px;
	position: relative;
}

.l-cta.top {
	margin-bottom: 0;
}

.l-cta::after {
	animation: rotate-deco 20s linear infinite; /* ← 回転アニメーション */
	background: url(../../assets/img/cta-deco.png) no-repeat center center/cover;
	content: "";
	height: 413px;
	position: absolute;
	right: -244px;
	top: -216px;
	width: 421px;
}

.l-cta__sectionTitle {
	margin-bottom: 40px !important;
}

.l-ceo {
	padding-top: 120px;
}

.l-ceo__sectionTitle {
	margin-bottom: 80px !important;
}

.l-aboutUs {
	background: #f5f5f5;
	padding-top: 120px;
}

.l-aboutUs--sp {
	display: block;
}

.l-aboutUs--pc {
	display: none;
}

.l-commitment {
	background: #3e3b3f;
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-commitment__sectionTitle {
	color: #fff;
	margin-bottom: 80px !important;
}

.l-lower-catch {
	padding-bottom: 64px;
	padding-top: 32px;
}

.l-lower-catch.contact {
	padding-bottom: 0;
}

.l-lower-catch.projects {
	padding-bottom: 80px;
}

.l-lower-catch.thanks {
	padding-bottom: 0;
	padding-top: 0;
}

.l-lower-flow {
	padding-top: 32px;
}

.l-lower-flow.thanks {
	padding-bottom: 64px;
	padding-top: 64px;
}

.l-lower-contact {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-pp {
	padding-bottom: 80px;
	padding-top: 80px;
}

.l-pp.immunity {
	background-color: #f5f5f5;
}

.l-lower-field {
	background: #3e3d3f;
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-lower-field__sectionTitle {
	color: #fff;
}

.l-lower-businessFlow {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-lower-business {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-lower-faq {
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-lower-voice {
	background-color: #CAD6DF;
	padding-bottom: 120px;
	padding-top: 120px;
}

.l-header {
	left: 0;
	position: fixed;
	top: 0;
	width: 100%;
}

:root {
	--header-h: 64px;
}

/* 本文の食い込み防止：ページ全体に余白を足す */

body {
	padding-top: var(--header-h);
}

.l-header__inner {
	padding-left: 20px;
	padding-right: 20px;
}

.l-header__wrapper {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	height: 64px;
	justify-content: space-between;
}

.l-header__logo {
	flex: 0 0 151px;
	max-width: 151px;
}

.l-header__logo img {
	height: 38px;
	width: 122px;
}

.l-header__right {
	position: relative;
}

.l-header__right .c-button-drawer {
	display: block;
}

.l-lower-projects {
	padding-bottom: 120px;
}

.l-lower-price {
	padding-bottom: 120px;
}

.l-price {
	padding-bottom: 64px;
}

.c-sectionTitle {
	display: flex;
	flex-direction: column;
}

.c-sectionTitle.clients {
	gap: 5px;
}

.c-sectionTitle-sub {
	align-items: center;
	display: flex;
	font-size: 16px;
	gap: 8px;
}

.c-sectionTitle-sub.projects {
	gap: 5px;
}

.c-sectionTitle-sub__icon img {
	height: 20px;
	width: 18px;
}

.c-sectionTitle-sub__text {
	font-weight: 700;
}

.c-sectionTitle-sub__text.clients {
	font-size: 20px;
	letter-spacing: 0.8px;
}

.c-sectionTitle-sub__text.projects {
	font-size: 16px;
	letter-spacing: 0.05em;
}

.c-sectionTitle-sub__text--white {
	color: #fff;
}

.c-sectionTitle-main {
	font-size: 32px;
	font-weight: 700;
	letter-spacing: 0.84px;
	margin-top: 4px;
}

.c-sectionTitle-main.clients {
	font-size: 12px;
	letter-spacing: 0.8px;
	padding-left: 25px;
}

.c-sectionTitle-main.projects {
	font-size: 12px;
	padding-left: 22px;
}

.c-sectionTitle-main--white {
	color: #fff;
}

.c-button {
	background: #222;
	display: inline-block;
	padding: 10px 40px;
	transition: background-color 0.3s ease;
}

.c-button:hover {
	background: #444;
}

.c-button--cta {
	background: #FFF;
	border-radius: 20px;
	transition: all 0.3s ease;
}

.c-button--cta:hover {
	background: #3e3b3f;
	border: 2px solid #fff;
	color: #fff;
}

.c-button-text {
	color: #FFF;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 2.8px;
	line-height: 16px; /* 114.286% */
	padding-right: 10px;
	transition: all 0.3s ease;
}

.c-button-icon {
	display: inline-block;
	line-height: 0; /* SVGの上下ずれ防止 */
	margin-left: 8px; /* テキストとの間隔 */
	transform: translateX(0);
	transition: transform 0.3s ease;
}

.c-button:hover .c-button-icon {
	transform: translateX(6px); /* 矢印を右へ動かす */
}

.c-button-text--cta {
	color: inherit;
}

.c-requestTitle {
	align-items: center;
	display: flex;
	gap: 14px;
}

.c-requestTitle-icon img {
	height: 19px;
	width: 24px;
}

.c-requestTitle-en {
	color: #AAA;
	font-size: 10px;
	line-height: 16px; /* 160% */
}

.c-requestTitle-ja {
	line-height: 16px; /* 114.286% */
}

.c-solutionsTitle {
	background: #FFF;
	padding: 5px 25px;
}

.c-solutionsTitle-en {
	color: #1B9AFF;
	font-family: "Noto Sans JP";
	font-size: 10px;
	line-height: 16px; /* 160% */
}

.c-solutionsTitle-ja {
	color: #1B9AFF;
	font-weight: 700;
	line-height: 16px; /* 114.286% */
}

.c-businessTitle {
	display: flex;
	gap: 20px;
}

.c-businessTitle-num {
	color: #0A5096;
	font-size: 20px;
	line-height: 26px; /* 130% */
}

.c-businessTitle-text {
	font-size: 20px;
	font-weight: 700;
	line-height: 26px; /* 130% */
}

.c-footerLink {
	display: flex;
	flex-direction: column;
	gap: 6px;
}

.c-footerLink-en {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 16px; /* 80% */
}

.c-footerLink-ja {
	font-size: 10px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 16px; /* 160% */
}

.c-footerLink-item {
	font-size: 10px;
	font-weight: 400;
	font-weight: 500;
	line-height: 16px; /* 160% */
}

.c-copyright {
	background: url(../../assets/img/top/copyright.png) no-repeat center center/cover;
	height: 230px;
}

.c-copyright__text {
	color: #fff;
	font-size: 12px;
	font-weight: 700;
	line-height: 1.2;
	position: relative;
	text-align: center;
	top: 57%;
	transform: translateY(-50%);
}

.c-faqTitle {
	background: #2773AF;
	display: block;
	padding: 10px;
	text-align: center;
}

.c-faqTitle__text {
	color: #FFF;
	font-family: "Noto Sans JP";
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1.4px;
	line-height: 24px; /* 171.429% */
}

.c-lower__catch--en {
	font-size: 48px;
	font-weight: 700;
	letter-spacing: 1.2px;
	line-height: 1.2;
}

.c-lower__catch--color {
	color: #1B9AFF;
}

.c-lower__catch--sp {
	display: block;
}

.c-lower__catch--sm {
	display: none;
}

.c-lower__catch--sm2 {
	display: block;
}

.c-lower__catch--md {
	display: block;
}

.c-lower__catch--pc {
	display: none;
}

.c-lower__catch--ja {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.2;
	margin-top: 20px;
}

.fade-in-right {
	opacity: 0;
	transform: translateX(80px);
	transition: all 1.2s ease-out;
}

.fade-in-right.is-visible {
	opacity: 1;
	transform: translateX(0);
}

.c-lower__breadcrumb {
	color: #1f1f1f;
	font-size: 14px;
	font-weight: 400;
}

.c-lower__breadcrumb.projects {
	font-size: 12px;
	margin-bottom: 40px;
}

.c-lower__breadcrumb a {
	color: #1B9AFF;
}

.c-lower__breadcrumb ol {
	display: flex;
	gap: 6px;
	justify-content: end;
}

.c-lower__breadcrumb li::after {
	color: #1f1f1f;
	content: "＞";
	font-weight: 400;
	margin-left: 6px;
}

.c-lower__breadcrumb li:last-child::after {
	content: "";
}

.c-lower__pagination {
	align-items: center;
	display: flex;
	gap: 15px;
	justify-content: center;
	padding-top: 64px;
}

.c-lower__pagination-info {
	background-color: #444;
	color: #fff;
	font-size: 13px;
	font-weight: 700;
	line-height: 20px; /* 153.846% */
	padding: 7px 15px;
}

.c-lower__pagination-page {
	border: 2px solid #222;
	font-size: 13px;
	font-weight: 700;
	line-height: 20px; /* 153.846% */
	padding: 5px 10px;
}

.c-lower__pagination-page.current {
	border: none;
}

.c-lower__pagination-arrow {
	font-size: 13px;
	font-weight: 700;
	line-height: 20px; /* 153.846% */
	padding: 5px 10px;
}

.c-contactTitle {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.c-contactTitle-icon img {
	height: 20px;
	width: 18px;
}

.c-contactTitle-sub {
	margin-top: 8px;
}

.c-contactTitle-sub__text {
	font-size: 12px;
	font-weight: 600;
	line-height: 18px; /* 114.286% */
}

.c-contactTitle-main {
	margin-top: 4px;
}

.c-contactTitle-main__text {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.84px;
	line-height: 18px; /* 57.143% */
}

.c-ppTitle {
	display: flex;
	flex-direction: column;
	gap: 5px;
	margin-bottom: 60px;
}

.c-ppTitle.flow {
	margin-bottom: 32px;
}

.c-ppTitle.faq {
	margin-bottom: 32px;
}

.c-ppTitle.contactLink {
	gap: 0;
	left: 15px;
	margin-bottom: 40px;
	position: relative;
}

.c-ppTitle.contactLink.bottom {
	margin-bottom: 0;
}

.c-ppTitle-main {
	align-items: center;
	display: flex;
	gap: 8px;
}

.c-ppTitle-icon img {
	height: 20px;
	width: 18px;
}

.c-ppTitle-main__text {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.84px;
	line-height: 16px; /* 57.143% */
}

.c-ppTitle-main__text.contactLink {
	color: #9a9a9a;
	font-size: 18px;
	padding-bottom: 6px;
	transition: color 0.3s;
}

.c-ppTitle-sub {
	padding-left: 25px;
}

.c-ppTitle-sub.flow {
	margin-top: 3px;
}

.c-ppTitle-sub.contactLink {
	padding-left: 0;
}

.c-ppTitle-sub__text {
	font-size: 12px;
	font-weight: 700;
	line-height: 16px; /* 114.286% */
}

.c-ppTitle-sub__text.contactLink {
	color: #9a9a9a;
	transition: color 0.3s;
}

.c-button-drawer {
	background: url(../../assets/img/header-open.png) no-repeat center center/contain;
	height: 34px;
	margin-left: 0; /* ← margin-left は不要 */
	position: fixed; /* ← ヘッダーのレイアウトから独立 */
	right: 20px; /* 右寄せ */
	top: 15px; /* ヘッダー内の見せたい位置に調整 */
	transition: transform 0.3s;
	width: 34px;
	z-index: 60; /* 背景より前面 */
}

.c-button-drawer.is-checked {
	background: url(../../assets/img/header-close.png) no-repeat center center/contain;
	transform: rotate(180deg); /* 回転アニメーション例 */
}

.c-slider__projects {
	margin-top: 40px;
	position: relative;
}

.c-slider__projects.projects {
	margin-top: 40px;
}

.c-slider__projects--container {
	margin-left: 0;
	overflow: visible;
	position: relative;
}

.c-slider__projects--wrapper {
	list-style-type: none;
	margin-bottom: 0;
	padding: 0;
}

.swiper-wrapper {
	min-width: 0;
	will-change: transform;
}

.c-slider__projects--slide {
	margin-right: 20px;
}

.swiper-slide {
	flex-shrink: 0;
	flex-wrap: wrap;
}

.c-card__projects {
	display: flex;
	flex-direction: column;
	flex-wrap: wrap;
	height: 100%;
	position: relative;
	width: 100%;
}

.c-card__projects-archive {
	flex-direction: row;
}

.c-card__projects--wrapper {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}

.c-slider__projects--wrapper > li:not(:first-child) .c-card__projects-archive {
	margin-top: 40px;
}

.c-card__projects--image {
	flex: 0 0 33.3333%;
	max-width: 33.3333%;
}

.c-card__projects--thumbnail {
	margin-bottom: 0;
	overflow: hidden;
	padding-top: 147.5%;
	position: relative;
}

.c-card__projects--thumbnail-bg {
	background-position: 50%;
	background-repeat: no-repeat;
	background-size: cover;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scale(1);
	width: 100%;
}

.c-card__projects__contents {
	display: block;
	flex: 0 0 66.6666%;
	max-width: 66.6666%;
	padding-left: 20px;
	position: relative;
}

.c-card__projects--heading {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
	padding-top: 20px;
}

.c-card__projects--heading.lower {
	padding-top: 0;
}

.-compname {
	align-items: flex-start;
	display: flex;
	gap: 5px;
}

.-compname-text {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.6;
}

.-compname-icon {
	height: 20px;
	position: relative;
	top: -2px;
	width: 20px;
}

.c-card__projects--meta {
	font-size: 10px;
	margin-top: auto;
	overflow: hidden;
	padding: 8px 0 0;
	position: relative;
}

.c-card__projects--label {
	background-color: #3e3b3f;
	color: #fff;
	display: inline-block;
	font-size: 12px;
	font-weight: 700;
	margin: 8px 16px 0 0;
	padding: 4px 12px;
	position: relative;
	text-align: center;
	text-decoration: none;
	z-index: 2;
}

.c-slider__projects--nav {
	margin-left: auto;
	margin-right: auto;
	margin-top: 80px;
	max-width: 800px;
	width: 100%;
}

.c-slider__projects--nav-inner {
	align-items: center; /* 矢印とバーを上下中央に */
	display: flex;
	gap: 50px;
	justify-content: space-between;
	position: relative;
}

.c-slider__projects--arrow {
	align-items: center;
	background-color: #1f1f1f;
	border: none;
	display: flex;
	flex-shrink: 0;
	height: 40px;
	justify-content: center;
	margin: 0;
	padding: 0;
	position: relative;
	width: 40px;
}

.c-slider__projects--arrow svg {
	display: block;
	height: 22px;
	width: 16px;
}

.c-slider__projects--arrow svg path {
	fill: #fff !important;
}

.c-slider__projects--arrow:hover {
	background-color: #4a4a4a; /* 明るめの色に変化 */
	transition: background-color 0.3s ease;
}

.c-slider__projects--arrow:hover svg path {
	fill: rgba(255, 255, 255, 0.5); /* 矢印の白色を薄くする */
	transition: fill 0.3s ease;
}

/* スクロールバー */

.c-slider__projects--scrollbar {
	align-self: center;
	background-color: #b3b3b3;
	border-radius: 2px;
	flex-grow: 1;
	height: 4px;
	left: 0 !important;
	position: relative;
	position: relative !important;
}

/* ドラッグ可能部分 */

.swiper-scrollbar-drag {
	background-color: #1f1f1f;
	border-radius: 2px;
	height: 100%;
}

.swiper-button-prev,
.swiper-button-next {
	position: relative !important;
	top: 0 !important;
}

.swiper-button-prev::after,
.swiper-button-next::after {
	display: none;
}

.c-slider__gallery {
	overflow: hidden;
	padding-bottom: 64px;
	padding-top: 64px;
}

.c-slider__gallery .swiper-wrapper {
	transition-timing-function: linear !important; /* 連続スクロールを滑らかに */
}

#js-gallery {
	pointer-events: none;
}

#js-gallery img {
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	-webkit-user-drag: none;
	pointer-events: none;
}

.c-slider__gallery .swiper-slide {
	align-items: center;
	display: flex;
	justify-content: center;
	width: auto; /* 画像幅ベースで良い場合 */
}

.c-slider__gallery .swiper-slide img {
	display: block;
	height: 130px;
	width: 130px;
	-o-object-fit: cover;
	border-radius: 14px;
	object-fit: cover;
	object-fit: cover;
	-o-object-position: var(--obj, 50% 50%);
	object-position: var(--obj, 50% 50%);
}

.c-lower-serviceTitle {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin-bottom: 40px;
	position: relative;
}

.c-lower-serviceTitle--mod {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin-bottom: 64px;
	position: relative;
}

.c-lower-serviceTitle-icon img {
	height: 20px;
	width: 18px;
}

.c-lower-serviceTitle-sub {
	margin-top: 8px;
}

.c-lower-serviceTitle-sub__text {
	font-size: 12px;
	font-weight: 600;
	line-height: 18px; /* 114.286% */
}

.c-lower-serviceTitle-main {
	margin-top: 4px;
}

.c-lower-serviceTitle-main__text {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.84px;
	line-height: 18px; /* 57.143% */
}

.c-lower-titleCatch {
	color: #f5f5f5;
	font-size: 36px;
	font-weight: 700;
	left: 0;
	line-height: 0.75;
	position: absolute;
	text-align: center;
	top: 45%;
	transform: translateY(-50%);
	white-space: nowrap;
	width: 100%;
	z-index: -1;
}

.c-lower-pojects__container {
	padding-top: 32px;
}

.c-lower-pojects__title {
	margin-bottom: 16px;
}

.c-lower-pojects__title--icon img {
	height: 20px;
	width: 18px;
}

.c-lower-pojects__title--text {
	font-weight: 700;
}

.c-lower-pojects__heading--company {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.6;
}

.c-lower-pojects__heading--type {
	font-size: 16px;
	font-weight: 600;
	line-height: 1.6;
}

.c-lower-pojects__heading--example {
	margin-top: 5px;
}

.c-lower-pojects__meta {
	font-size: 12px;
	line-height: 1.25;
	margin-bottom: 25px;
	margin-top: 16px;
}

.c-lower-pojects__meta--label {
	background-color: #3e3b3f;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	margin: 8px 12px 0 0;
	max-width: 116px;
	padding: 8px;
	position: relative;
	text-align: center;
	text-decoration: none;
	transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	z-index: 2;
}

.p-footer-nav {
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.p-footer-nav__subitem {
	margin-top: 15px;
}

.p-footer-subNav {
	display: flex;
	flex-direction: column;
	gap: 5px;
}

.p-footer-logo {
	position: absolute;
	right: 20px;
	top: 14px;
}

.p-footer-logoImg img {
	height: 37px;
	width: 119px;
}

.p-footer-cta {
	background: rgba(255, 255, 255, 0.85);
	bottom: 0;
	left: 0;
	padding-left: 20px;
	padding-right: 20px;
	position: fixed;
	width: 100%;
	z-index: 39;
}

.p-footer-cta__wrapper {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 10%;
	height: 60px;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
	max-width: 400px;
}

.p-footer-cta__menu {
	align-items: center;
	display: flex;
	gap: 3px;
}

.p-footer-cta__menuText {
	font-size: 16px;
	font-weight: 700;
}

.p-footer-cta__right {
	background: #1B9AFF;
	border-radius: 8px;
	box-shadow: 1px 4px 3px 0px rgba(115, 74, 44, 0.3);
}

.p-footer-cta__contact {
	align-items: center;
	display: flex;
	gap: 6px;
	padding-bottom: 4px;
	padding-left: 20px;
	padding-right: 20px;
	padding-top: 4px;
}

.p-footer-cta__contactText {
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.6px;
}

.p-footer-cta__contactText--big {
	color: #FFF;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.8px;
}

.p-footer-cta__contactText--sm {
	display: block;
}

.p-faq-item__q {
	align-items: center;
	background: #DFF1FD;
	border-radius: 10px 30px 0px 0px;
	display: flex;
	gap: 20px;
	padding-bottom: 24px;
	padding-left: 20px;
	padding-right: 20px;
	padding-top: 24px;
}

.p-faq-item__q-icon {
	color: #FFF;
	font-size: 16px;
	font-weight: 700;
	line-height: 16px; /* 100% */
	position: relative;
	z-index: 1;
}

.p-faq-item__q-icon::after {
	background: #1B9AFF;
	border-radius: 50%;
	content: "";
	height: 35px;
	left: -11px;
	position: absolute;
	top: -7px;
	width: 35px;
	z-index: -1;
}

.p-faq-item__q-text {
	line-height: 120%; /* 16.8px */
}

.p-faq-item__a {
	border: 5px solid #DFF1FD;
	border-radius: 0px 0px 10px 10px;
	padding-bottom: 15px;
	padding-left: 20px;
	padding-right: 20px;
	padding-top: 15px;
}

.p-faq-item__a-text {
	line-height: 130%; /* 18.2px */
}

.p-voice-item {
	background: #fff;
	border-radius: 5px 50px 5px 5px;
}

.p-voice-item__title {
	color: #2773AF;
	font-size: clamp(0.875rem, 0.666rem + 0.89vw, 1rem);
	font-weight: 700;
	line-height: 16px; /* 114.286% */
	text-align: center;
}

.p-voice-item__rating {
	align-items: end;
	display: flex;
	gap: 15px;
	margin-bottom: 20px;
	margin-top: 20px;
	padding-left: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
	padding-right: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
}

.p-voice-item__rating.half {
	align-items: center;
}

.p-voice-item__rating-label {
	font-size: clamp(0.75rem, 0.331rem + 1.79vw, 1rem);
	line-height: 1.2; /* 133.333% */
}

.p-voice-item__stars {
	color: #0A5096;
	font-size: clamp(1rem, 0.791rem + 0.89vw, 1.125rem);
	line-height: 1.2; /* 100% */
	position: relative;
}

.p-voice-item__ratings {
	background: #EFF0F0;
	display: grid;
	gap: 10px 7px;
	grid-template-columns: 1fr 1fr; /* 2列 */
	margin-bottom: 30px;
	max-width: 100%;
	padding-bottom: 10px;
	padding-left: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
	padding-right: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
	padding-top: 10px;
}

.p-voice-item__pair {
	align-items: center;
	display: flex;
	font-size: 0.95rem;
	gap: clamp(0.375rem, -1.039rem + 6.11vw, 1.25rem); /* ラベルとスコアの間隔 */
	justify-content: flex-start;
}

.p-voice-item__label {
	font-size: clamp(0.625rem, 0.416rem + 0.89vw, 0.75rem);
	letter-spacing: 0;
	line-height: 1.2; /* 160% */
	white-space: nowrap;
	width: clamp(4.375rem, 2.282rem + 8.93vw, 5.625rem);
}

.p-voice-item__score {
	color: #0A5096;
	font-size: clamp(0.75rem, 0.541rem + 0.89vw, 0.875rem);
	line-height: 1.2; /* 133.333% */
}

.p-voice-item__profile {
	align-items: center;
	display: flex;
	gap: clamp(1.25rem, -1.889rem + 13.39vw, 3.125rem);
	justify-content: center;
	margin-bottom: 30px;
	padding-left: 10px;
	padding-right: 10px;
}

.p-voice-item__photo {
	height: clamp(6.25rem, 3.111rem + 13.39vw, 8.125rem);
	width: clamp(6.25rem, 3.111rem + 13.39vw, 8.125rem);
}

.p-voice-item__info {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.p-voice-item__company {
	align-items: center;
	display: flex;
	gap: 10px;
}

.p-voice-item__name {
	align-items: center;
	display: flex;
	gap: 10px;
}

.p-voice-item__product {
	align-items: center;
	display: flex;
	gap: 10px;
}

.p-voice-item__left {
	background: #DFF1FD;
	min-width: 47.5px;
	padding: 4px 8px;
	text-align: center;
}

.p-voice-item__left-text {
	color: #1B9AFF;
	font-size: clamp(0.625rem, 0.416rem + 0.89vw, 0.75rem);
	font-weight: 700;
	letter-spacing: 0.5px;
	line-height: 1.2; /* 160% */
}

.p-voice-item__right-text {
	font-size: clamp(0.625rem, 0.416rem + 0.89vw, 0.75rem);
	font-weight: 700;
	letter-spacing: 0.5px;
	line-height: 1.2; /* 160% */
}

.p-voice-item__comment {
	padding-left: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
	padding-right: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
}

.p-voice-item__comment-text {
	font-size: clamp(0.75rem, 0.541rem + 0.89vw, 0.875rem);
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 180%; /* 18px */
}

.p-voice-item--tab {
	background: #FFF;
	border-radius: 5px 70px 5px 5px;
	padding: 30px 15px;
}

.p-voice-item--tab__inner {
	align-items: center;
	display: flex;
	gap: 15px;
	justify-content: center;
}

.p-voice-item--tab__photo {
	height: 150px;
	width: 150px;
}

.p-voice-item--tab__content {
	width: 360px;
}

.p-voice-item--tab__title {
	color: #2773AF;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 40px;
	text-align: center;
}

.p-voice-item--tab__rating {
	align-items: center;
	display: flex;
	gap: 10px;
	margin-bottom: 20px;
}

.p-voice-item--tab__rating-label {
	font-size: 16px;
	line-height: 1.2;
}

.p-voice-item--tab__stars {
	color: #0A5096;
	font-size: 18px;
	line-height: 1.2;
}

.p-voice-item--tab__ratings {
	background: #EFF0F0;
	border-radius: 8px;
	display: grid;
	font-size: 12px;
	gap: 10px 10px;
	grid-template-columns: 1fr 1fr;
	margin-bottom: 20px;
	padding: 10px;
}

.p-voice-item--tab__pair {
	align-items: center;
	display: flex;
	gap: 8px;
}

.p-voice-item--tab__label {
	font-size: 10px;
	letter-spacing: 0;
	line-height: 1.2; /* 160% */
	width: 70px;
}

.p-voice-item--tab__score {
	color: #0A5096;
	font-size: 12px;
	font-weight: bold;
	letter-spacing: 0;
}

.p-voice-item--tab__info-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
	margin-bottom: 16px;
}

.p-voice-item--tab__info-item {
	align-items: center;
	display: flex;
	gap: 6px;
}

.p-voice-item--tab__info-label {
	background: #DFF1FD;
	color: #1B9AFF;
	font-size: 10px;
	letter-spacing: 0.5px;
	line-height: 1.2;
	padding: 2px 5px;
}

.p-voice-item--tab__info-value {
	font-size: 10px;
	letter-spacing: 0.5px;
	line-height: 1.2;
}

.p-voice-item--tab__comment-text {
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 180%; /* 22.4px */
	margin-top: 30px;
}

.p-voice-item--pc {
	background: #FFF;
	border-radius: 5px 70px 5px 5px;
	padding: 40px 20px;
}

.p-voice-item--pc__inner {
	align-items: center;
	display: flex;
	gap: 30px;
	justify-content: center;
}

.p-voice-item--pc__photo {
	height: 160px;
	width: 160px;
}

.p-voice-item--pc__content {
	width: 700px;
}

.p-voice-item--pc__title {
	color: #2773AF;
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 32px;
	text-align: left;
}

.p-voice-item--pc__rating {
	align-items: center;
	display: flex;
	gap: 19px;
	margin-bottom: 25px;
}

.p-voice-item--pc__rating-label {
	font-size: 16px;
	letter-spacing: 0.07em;
	line-height: 1.2;
}

.p-voice-item--pc__stars {
	color: #0A5096;
	font-size: 18px;
	line-height: 1.2;
}

.p-voice-item--pc__ratings {
	background: #EFF0F0;
	border-radius: 8px;
	display: flex;
	font-size: 12px;
	gap: 16px;
	margin-bottom: 20px;
	padding: 15px 10px;
}

.p-voice-item--pc__pair {
	align-items: center;
	display: flex;
	gap: 5px;
}

.p-voice-item--pc__label {
	font-size: 12px;
	letter-spacing: 0;
	line-height: 1.2;
}

.p-voice-item--pc__score {
	color: #0A5096;
	font-size: 13px;
	letter-spacing: 0;
}

.p-voice-item--pc__info-list {
	display: flex;
	flex-wrap: wrap;
	gap: 12px 24px;
	margin-bottom: 16px;
}

.p-voice-item--pc__info-item {
	align-items: center;
	display: flex;
	gap: 6px;
}

.p-voice-item--pc__info-label {
	background: #DFF1FD;
	color: #1B9AFF;
	font-size: 14px;
	letter-spacing: 0.5px;
	line-height: 1.2;
	padding: 5px 8px;
}

.p-voice-item--pc__info-value {
	font-size: 14px;
	letter-spacing: 0.5px;
	line-height: 1.2;
}

.p-voice-item--pc__comment-text {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 180%; /* 22.4px */
	margin-top: 30px;
}

.p-top-voice__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-top-voice__items {
	display: flex;
	flex-direction: column;
	gap: 64px;
}

.p-top-voice__item {
	padding-bottom: 20px;
	padding-top: 20px;
}

.p-top-voice__button {
	padding-bottom: 120px;
	padding-top: 80px;
	text-align: center;
}

.p-business-item__image img {
	height: clamp(10.438rem, 3.762rem + 28.48vw, 21.563rem);
	width: 100%;
	-o-object-fit: cover;
	border-radius: 5px 30px 5px 5px;
	object-fit: cover;
}

.p-business-item__image--reverse img {
	border-radius: 30px 5px 5px 5px;
}

.p-business-item__body {
	padding-top: 40px;
}

.p-business-item__heading {
	align-items: center;
	display: flex;
	gap: 16px;
	margin-bottom: 20px;
}

.p-business-item__number img {
	height: 60px;
	width: 55px;
}

.p-business-item__titleBox {
	display: flex;
	flex-direction: column;
}

.p-business-item__subTitle {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
}

.p-business-item__title {
	font-size: 23px;
	font-weight: 700;
	line-height: 1.2; /* 130% */
	margin-top: 8px;
}

.p-business-item__text {
	font-weight: 700;
	line-height: 2; /* 25.2px */
}

.p-top-business__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-top-business__text--pc {
	display: none;
}

.p-top-business__button {
	padding-bottom: 120px;
	padding-top: 80px;
	text-align: center;
}

.p-top-projects__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	padding-bottom: 20px;
}

.p-top-projects__button {
	padding-top: 80px;
	text-align: center;
}

.p-top-projects__button.projects {
	padding-bottom: 0;
}

.p-top-concept {
	margin-top: 20px;
	padding-bottom: 120px;
	position: relative;
}

.p-top-concept::after {
	aspect-ratio: 262/286;
	background: url(../../assets/img/top/concept-bg.png) no-repeat center center/cover;
	content: "";
	height: auto;
	max-width: 70%;
	position: absolute;
	right: -25px;
	top: -75px;
	width: 100%;
	z-index: -1;
}

.p-top-concept__catch {
	font-size: clamp(1.625rem, -0.308rem + 8.84vw, 3rem);
	font-weight: 700;
	letter-spacing: 0.15em;
	line-height: 1.6;
}

.stroke-fill {
	-webkit-text-stroke: 1px #222; /* 背景グラデで塗りを作る */
	background: linear-gradient(to right, #222 50%, transparent 50%);
	background-position: 100% 0;
	background-size: 200% 100%; /* 白抜き（黒線）状態 */
	color: transparent;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent; /* アニメ前状態（非表示） */
	opacity: 0;
	transform: translateY(20px);
	transition: opacity 0.6s ease, transform 0.6s ease;
}

.stroke-fill.is-visible {
	animation: fillText 2s ease forwards;
	opacity: 1;
	transform: translateY(0);
}

.p-top-concept__image {
	height: 100%;
	width: 100%;
}

.p-top-concept__body {
	margin-top: 64px;
}

.p-top-concept__fade-paragraph {
	font-size: 18px;
	font-weight: 700;
	line-height: 200%; /* 22.4px */
	opacity: 0;
	transform: translateY(100px);
	transition: all 1s ease;
}

.p-top-concept__fade-paragraph:not(:first-of-type) {
	margin-top: 40px;
}

.p-top-concept__fade-paragraph.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.fade-paragraph--sm {
	display: none;
}

.fade-paragraph--sm2 {
	display: none;
}

.fade-paragraph--md {
	display: none;
}

.fade-paragraph--lg {
	display: none;
}

.p-top-concept__right {
	max-width: 452px;
}

.p-top-about__contents {
	display: flex;
}

.p-top-about__catch {
	display: flex;
	flex-direction: column;
	gap: 10px;
	justify-content: center;
	text-orientation: upright; /* 文字を縦に並べる */
	white-space: nowrap; /* 改行を防止 */
	width: 52%;
	writing-mode: vertical-rl; /* 縦書き・右から左 */
}

.p-top-about__catchText1 {
	font-size: clamp(1.25rem, 0.622rem + 2.68vw, 1.625rem);
	font-weight: 700;
	letter-spacing: 0.25em;
	line-height: 120%; /* 24px */
}

.p-top-about__catchText2 {
	font-size: clamp(1.25rem, 0.622rem + 2.68vw, 1.625rem);
	font-weight: 700;
	letter-spacing: 0.15em;
	line-height: 120%; /* 24px */
}

.p-top-about__space {
	display: none;
}

.p-top-about__image {
	border-radius: 50px 0 0 10px;
	overflow: hidden;
	text-align: right;
	width: 48%; /* デフォルト焦点（中央） */
	--pos-x: 53%;
	--pos-y: 50%;
}

.p-top-about__image img {
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover;
	-o-object-position: var(--pos-x) var(--pos-y);
	display: block;
	object-position: var(--pos-x) var(--pos-y);
}

.p-top-about__desc {
	font-size: 16px;
	font-weight: 700;
	line-height: 180%; /* 22.4px */
	margin-top: 50px;
}

.p-top-about__button {
	padding-top: 80px;
	text-align: center;
}

.p-top-about__left {
	width: 54%;
}

.p-top-about__right {
	width: 46%;
}

.p-top-do__items {
	display: flex;
	flex-direction: column;
	gap: 60px;
}

.p-top-do__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-do-item {
	background: #DFF1FD;
	padding-left: 20px;
}

.p-do-item__request {
	background: #FFF;
	padding: 48px 20px 40px;
	position: relative;
}

.p-do-item__request::after {
	background: url(../../assets/img/top/do-arrow-icon.png) no-repeat center center/cover;
	bottom: -21px;
	content: "";
	height: 23px;
	left: 45px;
	position: absolute;
	width: 26px;
}

.p-do-item__request-title {
	display: flex;
	gap: 10px;
	left: 17px;
	position: absolute;
	top: -12px;
}

.p-do-item__request-title--left img {
	height: 26px;
	width: 32px;
}

.p-do-item__label-en {
	color: #AAA;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 16px; /* 160% */
}

.p-do-item__title {
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 16px; /* 114.286% */
}

.p-do-item__balloon {
	align-items: center;
	display: flex;
	flex-wrap: nowrap;
	width: 100%;
}

.p-do-item__icon {
	flex: 0 0 50px;
	height: 50px;
	max-width: 50px;
}

.p-do-item__text {
	flex-basis: calc(100% - 50px);
	font-weight: 700;
	line-height: 180%; /* 21px */
	max-width: calc(100% - 50px);
	padding-left: 12px;
}

.p-do-item__solution {
	padding: 40px 20px 40px;
}

.p-do-item__solution-title {
	background: #FFF;
	display: inline-block;
	padding: 5px 25px;
}

.p-do-item__label--solution {
	color: #1B9AFF;
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 16px; /* 160% */
}

.p-do-item__title--solution {
	color: #1B9AFF;
	font-weight: 700;
	left: 2px;
	letter-spacing: 0.05em;
	line-height: 16px; /* 114.286% */
	position: relative;
}

.p-do-item__description {
	font-weight: 700;
	line-height: 180%; /* 22.4px */
	margin-top: 10px;
}

.p-top-cta__text {
	color: #FFF;
	font-weight: 700;
	line-height: 180%; /* 25.2px */
	margin-bottom: 50px;
}

.p-top-cta__button {
	text-align: center;
}

.p-lower-ceo {
	background: #62BAFF;
	display: flex;
	flex-direction: column;
	gap: 20px;
	padding-bottom: 120px;
}

.p-lower-ceo__photo {
	display: flex;
	justify-content: end;
}

.p-lower-ceo__img {
	max-width: 60%;
	position: relative;
	top: -45px;
}

.p-lower-ceo__title {
	color: #fff;
	font-size: clamp(1.25rem, 0.622rem + 2.68vw, 1.625rem);
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: clamp(1.875rem, 0.829rem + 4.46vw, 2.5rem); /* 150% */
	margin-bottom: 40px;
}

.p-lower-ceo__greeting {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 2;
}

.p-lower-aboutUs {
	font-family: DotGothic16;
}

.p-lower-aboutUs__header {
	background: #2773AF;
}

.p-lower-aboutUs__header--text {
	-webkit-text-stroke-color: #FFF;
	-webkit-text-stroke-width: 0.8px;
	color: #fff;
	display: flex;
	flex-direction: column;
	font-size: 18px;
	font-weight: 400;
	gap: 10px;
	letter-spacing: 1.8px;
	line-height: 160%;
	padding: 10px 20px;
	text-shadow: 4px 4px 4px rgba(0, 0, 0, 0.25);
}

.p-lower-aboutUs__header--main {
	text-align: left;
}

.p-lower-aboutUs__header--sub {
	text-align: right;
}

.p-lower-aboutUs__boxes {
	margin-top: 64px;
}

.p-lower-aboutUs__box {
	display: flex;
}

.p-aboutUs-box__top {
	margin-bottom: 30px;
}

.p-aboutUs-box {
	align-items: center;
	border: 4px solid #000;
	display: flex;
	justify-content: center;
	position: relative;
}

.p-aboutUs-box--s {
	align-self: center; /* 縦方向 */
	height: clamp(8.938rem, 3.706rem + 22.32vw, 12.063rem);
	justify-self: center;
	margin-left: auto;
	margin-right: auto;
	width: clamp(8.563rem, 3.331rem + 22.32vw, 11.688rem);
}

.p-aboutUs-box__grid {
	align-items: stretch;
	display: grid;
	gap: 40px 30px;
	grid-template-columns: repeat(2, 1fr);
}

.p-aboutUs-box__bottom {
	margin-top: 40px;
	padding-bottom: 120px;
}

.p-aboutUs-box__title {
	-webkit-text-stroke-color: #000;
	-webkit-text-stroke-width: 0.8px;
	background: #f5f5f5;
	color: #000;
	font-size: 18px;
	font-weight: 400;
	left: 50%;
	letter-spacing: 2px;
	padding-left: 20px;
	padding-right: 20px;
	position: absolute;
	text-align: center;
	top: -17px;
	transform: translateX(-50%);
	white-space: nowrap;
	z-index: 1;
}

.p-aboutUs-box__title--top {
	font-size: 20px;
}

.p-aboutUs-box__body {
	display: flex;
	flex-direction: column;
	padding: 10px;
}

.p-aboutUs-box__body--s {
	padding-left: 30px;
	position: relative;
}

.p-aboutUs-box__body--s::after {
	background: url(../../assets/img/about/about-us-arrow.png) no-repeat center center/cover;
	content: "";
	height: 18px;
	left: 13px;
	position: absolute;
	top: 59px;
	width: 12px;
}

.p-aboutUs-box__body--top {
	padding: 15px 20px 10px 20px;
}

.p-aboutUs-box__text {
	-webkit-text-stroke-color: #000;
	-webkit-text-stroke-width: 0.5px;
	color: #000;
	display: inline-block;
	font-size: 16px;
	font-weight: 400;
	height: -moz-fit-content;
	height: fit-content;
	letter-spacing: 1.5px;
	line-height: 38px;
	width: -moz-fit-content;
	width: fit-content;
}

.p-aboutUs-box__text--big {
	font-size: 18px;
}

.p-aboutUs-box__text--small {
	font-size: 13px;
	line-height: 25px;
}

.p-lower-commitment__items {
	display: flex;
	flex-direction: column;
	gap: 80px;
}

.p-commitment-item {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.p-commitment-item__number {
	color: #FFF;
	font-size: 32px;
	font-weight: 900;
	line-height: 0.85;
}

.p-commitment-item__body {
	display: flex;
	flex-direction: column;
	gap: 32px;
}

.p-commitment-item__title {
	color: #FFF;
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.6;
}

.p-commitment-item__text {
	color: #FFF;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 2;
}

.p-for-clients__header {
	box-sizing: border-box;
	position: relative;
}

.p-for-clients__header::before {
	background-color: #444;
	content: "";
	height: 50%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.p-for-clients__header-wrapper {
	background-color: #fff;
	margin: 0 auto;
	max-width: calc(100% - 40px);
	padding: 40px 20px;
	position: relative;
	z-index: 3;
}

.p-for-clients__text {
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 180%;
	margin-top: 20px;
}

.p-for-clients__item {
	display: flex;
	gap: 16px;
	padding: 0 8px;
}

.p-for-clients__item--2 {
	border-top: 1px solid #3e3b3f;
	display: flex;
	gap: 16px;
	margin-top: 20px;
	padding: 0 8px;
	padding-top: 20px;
}

.p-for-clients__item--3 {
	border-top: 1px solid #3e3b3f;
	display: flex;
	gap: 16px;
	margin-top: 20px;
	padding: 0 8px;
	padding-top: 20px;
}

.p-for-clients__icon {
	flex-shrink: 0;
	height: 50px;
	position: relative;
	width: 50px;
}

.p-for-clients__icon img {
	height: 100%;
	width: 100%;
}

.p-for-clients__heading-number {
	color: #9a9a9a;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 16px; /* 133.333% */
}

.p-for-clients__heading-text {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.6px;
	line-height: 180%; /* 18px */
	margin-top: 5px;
}

.p-lower-catch {
	margin-top: 40px;
}

.p-lower-catch__image {
	height: 100%;
	width: 100%;
}

.p-lower-catch__image img {
	display: block;
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover; /* ← 追加：ここで切り抜き位置を制御 */
	-o-object-position: var(--focus-x) var(--focus-y);
	object-position: var(--focus-x) var(--focus-y);
}

.p-lower-catch__breadcrumd {
	margin-top: 20px;
}

.p-lower-catch__breadcrumd.faq {
	margin-top: 0;
}

.p-faq-link__item {
	display: block;
	position: relative;
}

.p-faq-link__item::before {
	border-left: 2px solid #9a9a9a;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	transition: border-color 0.3s;
}

.p-faq-link__item:hover::before {
	border-color: #1B9AFF;
}

.p-faq-link__item:hover .c-ppTitle-main__text.contactLink,
.p-faq-link__item:hover .c-ppTitle-sub__text.contactLink {
	color: #1B9AFF;
}

.p-lower-flow__text {
	font-weight: 700;
	letter-spacing: 1.4px;
	line-height: 1.6;
}

.p-lower-flow__text.tel {
	margin-top: 20px;
}

.p-lower-flow__text--tel {
	border-bottom: 1px solid #1B9AFF;
	color: #1B9AFF;
}

.p-lower-flow__body {
	margin-top: 64px;
}

.p-lower-contact__text {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 180%; /* 23.8px */
	margin-bottom: 60px;
	margin-top: 40px;
}

.p-contactForm__lists {
	display: flex;
	flex-direction: column;
	gap: 25px;
	margin-bottom: 30px;
}

.p-contactForm__list {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

.p-contactForm__list.textarea {
	gap: 2px;
}

.p-contactForm__list.radios {
	gap: 15px;
}

.p-contactForm__button {
	background: #1B9AFF;
	display: inline-block;
	left: 50%;
	margin-top: 50px;
	padding: 10px 25px;
	position: relative;
	transform: translateX(-50%);
	transition: all 0.3s ease;
}

.p-contactForm__button:hover {
	background: #fff;
	border: 1px solid #1B9AFF;
}

.p-contactForm__button:hover .p-contactForm__button-submit {
	color: #1B9AFF;
}

.p-contactForm__button-submit {
	color: #fff;
	font-size: 14px;
	font-weight: 400;
	letter-spacing: 0.7px;
	line-height: 25px; /* 178.571% */
}

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

.p-contactForm__checkbox-input {
	height: 1px;
	overflow: hidden;
	position: absolute;
	width: 1px;
	clip: rect(0, 0, 0, 0);
}

.p-contactForm__checkbox-input:checked + .p-contactForm__checkbox-text::after {
	opacity: 1;
}

.p-contactForm__checkbox-input:checked + .p-contactForm__checkbox-text::before {
	background-color: #62BAFF;
}

.p-contactForm__checkbox-text {
	font-size: 14px;
	font-weight: 400;
	padding-left: 30px;
	position: relative;
}

.p-contactForm__checkbox-text::before,
.p-contactForm__checkbox-text::after {
	content: "";
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.p-contactForm__checkbox-text::before {
	border: 1px solid #AAA;
	border-radius: 5px;
	height: 20px;
	width: 20px;
}

.p-contactForm__checkbox-text::after {
	background-image: url(../../assets/img/contact/radios-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 9px;
	left: 4px;
	opacity: 0;
	width: 12px;
}

.p-contactForm__checkbox-link {
	text-decoration: underline;
	text-underline-offset: 2px;
	-webkit-text-decoration-skip-ink: none;
	color: #1B9AFF;
	text-decoration-skip-ink: none;
}

.g-recaptcha {
	display: flex;
	justify-content: center;
	margin-top: 64px;
}

.p-contact-control.radios {
	margin-bottom: 10px;
	margin-top: 10px;
}

.p-contact-control__left {
	align-items: center;
	display: flex;
	gap: 10px;
}

.p-contact-control__label {
	color: #6c757d;
	font-weight: 700;
	line-height: 25px; /* 178.571% */
}

.p-contact-control__required {
	align-items: center; /* ← 中央寄せ */
	background: #1B9AFF;
	color: #FFF;
	display: inline-flex; /* ← 内容に合わせて最小化 */
	font-size: 12px;
	height: 25px;
	justify-content: center;
	line-height: 25px; /* 208.333% */
	padding: 0px 8px;
	padding-bottom: 2px;
}

.p-contact-control__right {
	border: 1px solid #AAA;
	border-radius: 5px;
}

.p-contact-control__right.radios {
	border: none;
}

.p-contact-control__right.textarea {
	margin-top: 10px;
}

.p-contact-control__text {
	border: none;
	height: 42px;
	outline: none;
	padding: 10px;
	width: 100%;
}

.p-contact-control__text:focus {
	border: 1px solid #AAA;
	border-radius: 5px;
	box-shadow: -2px -2px 6px 0 rgba(27, 154, 255, 0.4), 2px 2px 6px 0 rgba(27, 154, 255, 0.4);
}

.p-contact-control__text::-moz-placeholder {
	color: #AAA;
	font-size: 14px;
	font-weight: 300;
}

.p-contact-control__text::placeholder {
	color: #AAA;
	font-size: 14px;
	font-weight: 300;
}

.p-contact-control__radios {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.p-contact-control__radioInput {
	height: 1px;
	position: absolute;
	width: 1px;
	clip: rect(0, 0, 0, 0);
	overflow: hidden;
}

.p-contact-control__radioInput:checked + .p-contact-control__radioText::after {
	opacity: 1;
}

.p-contact-control__radioInput:checked + .p-contact-control__radioText::before {
	background-color: #62BAFF;
}

.p-contact-control__radioInput:focus + .p-contact-control__radioText::before {
	outline: none;
}

.p-contact-control__radioText {
	color: #1f1f1f;
	font-size: 14px;
	font-weight: 400;
	padding-left: 30px;
	position: relative;
}

.p-contact-control__radioText::before,
.p-contact-control__radioText::after {
	content: "";
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.p-contact-control__radioText::before {
	border: 1px solid #AAA;
	border-radius: 5px;
	height: 20px;
	left: 0;
	width: 20px;
}

.p-contact-control__radioText::after {
	background-image: url(../../assets/img/contact/radios-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 9px;
	left: 4px;
	opacity: 0;
	width: 12px;
}

.p-contact-control__textarea {
	border: none;
	border-radius: 5px;
	height: 210px;
	outline: none;
	padding-left: 10px;
	padding-top: 10px;
	width: 100%;
}

.p-contact-control__textarea:focus {
	border: 1px solid #AAA;
	border-radius: 5px;
	box-shadow: -2px -2px 6px 0 rgba(27, 154, 255, 0.4), 2px 2px 6px 0 rgba(27, 154, 255, 0.4);
}

.p-contact-control__textarea::-moz-placeholder {
	color: #AAA;
	font-size: 14px;
	font-weight: 300;
}

.p-contact-control__textarea::placeholder {
	color: #AAA;
	font-size: 14px;
	font-weight: 300;
}

.p-pp-anchors {
	margin-top: 50px;
}

.p-pp-anchors__container {
	display: flex;
	flex-direction: column;
	gap: 30px;
}

.p-pp-anchors__button {
	background-color: #fff;
	border: 1px solid #c1c1c1;
	color: #222;
	overflow: hidden;
	padding: 15px;
	position: relative;
	transition: color 0.3s ease;
}

.p-pp-anchors__button::before {
	background-color: #222;
	bottom: 0;
	content: "";
	height: 0%;
	left: 0;
	position: absolute;
	transition: height 0.3s ease;
	width: 100%;
	z-index: 0;
}

.p-pp-anchors__button:hover::before {
	height: 100%;
}

.p-pp-anchors__button:hover {
	color: #222;
}

.p-pp-anchors__button:hover .p-pp-anchors__text {
	color: #fff;
}

.p-pp-anchors__text {
	font-weight: 700;
	letter-spacing: 1.2px;
	line-height: 1.5;
	position: relative;
	text-align: center;
	transition: color 0.3s ease;
	z-index: 1;
}

.p-pp__title {
	border-bottom: 1px solid #1f1f1f;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-bottom: 20px;
	padding-bottom: 15px;
}

.p-pp__content {
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.7;
	margin-bottom: 40px;
}

.p-pp__text {
	margin-bottom: 20px;
}

.p-pp__ul {
	display: block;
	list-style-type: disc;
	margin-block-end: 1em;
	margin-block-start: 1em;
	padding-inline-start: 40px;
	unicode-bidi: isolate;
}

.p-pp__li {
	display: list-item;
	text-align: -webkit-match-parent;
	unicode-bidi: isolate;
}

.p-pp__li::marker {
	font-variant-numeric: tabular-nums;
	text-align: start !important;
	text-indent: 0px !important;
	text-transform: none;
	unicode-bidi: isolate;
	-moz-text-align-last: auto !important;
	text-align-last: auto !important;
}

.p-pp__table {
	border-collapse: collapse;
	table-layout: fixed;
	width: 100%;
}

.p-pp__table th,
.p-pp__table td {
	border: 1px solid #e8e8e8;
	padding: 10px;
	text-align: left;
	vertical-align: middle;
}

.p-pp__table th {
	font-weight: 700;
	width: clamp(6.25rem, 1.018rem + 22.32vw, 9.375rem);
}

.p-pp__table td {
	word-break: break-all;
}

.p-pp__content-link {
	color: #1B9AFF;
}

.p-lower-field__right {
	margin-left: auto;
	margin-right: auto;
	max-height: 535px;
	max-width: 540px;
}

.p-lower-field__left {
	margin-top: 64px;
}

/* コンテナ：正方形で中央寄せ。背景は任意 */

.venn-pics {
	aspect-ratio: 1/1;
	background: #3e3d3f; /* 画像の例に近い色 */
	left: 50%;
	overflow: visible;
	position: relative;
	transform: translateX(-50%);
	width: min(520px, 92vw);
}

/* 各丸（PNG画像） */

.bubble {
	aspect-ratio: 1/1;
	image-rendering: auto;
	opacity: 0;
	position: absolute;
	transform: scale(0.9);
	transition: transform 0.8s cubic-bezier(0.2, 0.8, 0.2, 1), opacity 0.6s ease;
	width: 55%; /* 直径。好みで調整 */
	will-change: transform, opacity;
}

/* 最終配置（ベン図） */

.b-top {
	left: 50%;
	top: 5%;
	transform-origin: 50% 50%;
	translate: -50% 0;
	z-index: 3;
	--d: 0ms;
}

.b-left {
	left: 3%;
	top: 43%;
	transform-origin: 50% 50%;
	z-index: 2;
	--d: 600ms;
}

.b-right {
	right: 3%;
	top: 43%;
	transform-origin: 50% 50%;
	z-index: 1;
	--d: 1200ms;
}

/* 再生トリガーが付いたら順番にフェード＆ズームイン */

.venn-pics.is-in .bubble {
	opacity: 1;
	transform: scale(1);
	transition-delay: var(--d);
}

.p-field-list--2 {
	margin-top: 40px;
}

.p-field-list__heading {
	border-top: 1px solid #fff;
	color: #fff;
	padding-top: 20px;
}

.p-field-list__heading--en {
	font-size: 24px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
}

.p-field-list__heading--ja {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-top: 5px;
}

.p-field-list__item {
	color: #9a9a9a;
	font-size: 12px;
	font-weight: 400;
	line-height: 1.7;
	list-style: disc inside;
	margin-top: 20px;
}

.p-field-list__item--li {
	display: list-item;
	list-style-type: circle;
	margin-top: 5px;
	text-align: -webkit-match-parent;
	unicode-bidi: isolate;
}

.p-field-list__item--li::marker {
	font-variant-numeric: tabular-nums;
	text-align: start !important;
	text-indent: 0px !important;
	text-transform: none;
	unicode-bidi: isolate;
	-moz-text-align-last: auto !important;
	text-align-last: auto !important;
}

.p-lower-businessFlow__img {
	margin-left: auto;
	margin-right: auto;
	max-height: 550px;
	max-width: 540px;
}

.fade-in-trigger {
	opacity: 0;
	transform: translateY(40px);
	transition: all 1.5s ease;
}

.fade-in-trigger.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.p-lower-businessFlow__items {
	margin-top: 64px;
}

.p-businessFlow-item {
	border-top: 1px solid #1f1f1f;
	margin-top: 20px;
	padding: 20px 0 0;
}

.p-businessFlow-item__heading__num {
	border-bottom: 4px solid #1f1f1f;
	display: inline-block;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
	padding-bottom: 5px;
}

.p-businessFlow-item__heading--ja {
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-top: 8px;
}

.p-businessFlow-item__text {
	font-size: 12px;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.7;
	margin-top: 16px;
}

.p-lower-business__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-lower-business__items {
	display: flex;
	flex-direction: column;
	gap: 64px;
}

.p-lower-business__button {
	padding-top: 80px;
	text-align: center;
}

.p-lower-introduce {
	background-color: #f5f5f5;
}

.p-lower-introduce__wrapper {
	padding-bottom: 96px;
	padding-top: 96px;
}

.p-lower-introduce__header {
	border-top: 1px solid #1f1f1f;
	padding-top: 8px;
}

.p-lower-introduce__header--title {
	color: #9a9a9a;
	font-weight: 700;
	margin-bottom: 0;
}

.p-lower-introduce__body {
	margin-top: 40px;
}

.p-lower-introduce__body--title {
	font-size: 32px;
	font-weight: 700;
}

.p-lower-introduce__body--desc {
	font-weight: 700;
	line-height: 2;
	margin-top: 40px;
}

.p-lower-faq__text {
	font-weight: 700;
	letter-spacing: 1.4px;
	line-height: 180%;
	margin-bottom: 64px;
}

.p-lower-faq__content.top {
	padding-top: 100px;
}

.p-lower-faq__content.about {
	border-top: 1px solid #1f1f1f;
	margin-top: 80px;
	padding-top: 80px;
}

.p-lower-faq__items {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.p-lower-faq__button {
	padding-bottom: 64px;
	padding-top: 80px;
	text-align: center;
}

.p-top-faq__text {
	font-weight: 700;
	line-height: 180%;
	margin-bottom: 64px;
}

.p-top-faq__content.top {
	padding-top: 100px;
}

.p-top-faq__content.about {
	border-top: 1px solid #1f1f1f;
	margin-top: 80px;
	padding-top: 80px;
}

.p-top-faq__items {
	display: flex;
	flex-direction: column;
	gap: 40px;
}

.p-top-faq__button {
	padding-top: 80px;
	text-align: center;
}

.p-top-business.service-sync {
	align-items: flex-start;
	display: flex;
	flex-wrap: wrap;
	--col-gap: clamp(1rem, 4vw, 1.8rem);
	--nav-dot: clamp(28px, 7.5vw, 36px); /* ●丸の直径 */
	--nav-num: calc(var(--nav-dot) * .42); /* 01 の数字 */
	--nav-fs: clamp(12px, 3.8vw, 14px); /* ラベル文字 */
	-moz-column-gap: var(--col-gap);
	column-gap: var(--col-gap);
	--inner-sp: 510px; /* 例: 92vw 相当など */
	--inner-md: 690px; /* md以上の内側幅 */
}

.service-sync__image-swiper {
	aspect-ratio: 4/3;
	border-radius: 6px;
	box-sizing: border-box;
	flex: 1 1 0;
	order: 1;
	overflow: hidden;
	position: relative;
	width: 100%;
	z-index: 0;
}

.service-sync__image-swiper img {
	height: 100%;
	width: 100%;
	-o-object-fit: cover;
	object-fit: cover; /* 要素を埋める。上下左右に余白を作らない */
	-o-object-position: center;
	min-height: 100%; /* ← 要素より小さくならないよう保証 */
	min-width: 100%;
	object-position: center;
}

.service-sync__image-swiper .swiper-wrapper,
.service-sync__image-swiper .swiper-slide {
	height: 100%;
	min-height: 100%;
}

.service-top__swiper-slide {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	block-size: 100%;
	inline-size: 100%;
	overflow: hidden;
	position: relative;
}

.service-top__swiper-slide::before {
	content: "";
	inset: 0;
	position: absolute;
	z-index: 0;
}

/* テキストスライダー */

.service-sync__text-swiper {
	margin-top: 40px;
}

.service-sync__heading {
	align-items: center;
	display: flex;
	gap: 12px;
	margin-bottom: 20px;
}

.service-sync__number img {
	height: auto;
	width: 45px;
}

.service-sync__titleBox {
	display: flex;
	flex-direction: column;
}

.service-sync__subTitle {
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.02em;
}

.service-sync__title {
	font-size: 24px;
	font-weight: 700;
	line-height: 1.2;
	margin-top: 6px;
}

.service-sync__text {
	font-weight: 400;
	line-height: 1.8;
}

/* 元スライド内テキストは出さない */

.service-sync .p-service-swiper__textWrapper {
	display: none !important;
}

/* 左ナビ */

/* 進捗リング（既存） */

.service-sync__dot {
	--deg: 0deg;
	background: radial-gradient(circle at center, #fff 60%, transparent 70%), conic-gradient(#111 calc(360deg - var(--deg)), #e6e6e6 0);
	border-radius: 9999px;
	display: grid;
	height: var(--nav-dot);
	place-items: center;
	width: var(--nav-dot);
}

.service-sync__num {
	color: #111;
	font: 800 16px/1 system-ui;
}

/* 非アクティブは灰色ベース */

.service-sync__navItem:not(.is-active) .service-sync__dot {
	background: radial-gradient(circle at center, #fff 60%, transparent 70%), conic-gradient(#e6e6e6 100%, #e6e6e6 0);
}

/* 進捗リング（逆回転） */

.service-sync__dot {
	--deg: 0deg;
	background: radial-gradient(circle at center, #fff 60%, transparent 70%), conic-gradient(#111 calc(360deg - var(--deg)), #e6e6e6 0);
	border-radius: 9999px;
	display: grid;
	height: 30px;
	place-items: center;
	width: 30px;
}

.service-sync__label {
	-webkit-text-stroke: 1.5px #222;
	color: transparent;
	font-size: 20px;
	font-weight: 800;
	letter-spacing: 0.06em;
}

.service-sync__navItem.is-active .service-sync__label {
	-webkit-text-stroke: 0;
	color: #111;
}

.service-sync__side {
	align-self: flex-start;
	display: flex;
	flex: 0 0 110px;
	flex-direction: column;
	justify-content: flex-start;
	margin-top: 0;
	order: 0;
}

.service-sync__nav {
	display: grid;
	gap: 12px;
	list-style: none;
	margin: 0;
	padding: 0;
}

.service-sync__navItem {
	align-items: center;
	cursor: pointer;
	display: flex;
	gap: 8px;
	position: relative;
	white-space: nowrap;
}

.service-sync__navItem::after {
	background: #111;
	content: "";
	height: 2px;
	left: 90%;
	margin-left: var(--col-gap);
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) scaleX(0);
	transform-origin: left center;
	transition: transform 0.25s ease, opacity 0.25s ease;
	width: 30px;
}

.service-sync__navItem.is-active::after {
	opacity: 1;
	transform: translateY(-50%) scaleX(1);
}

.service-sync__num {
	color: #111;
	font: 800 var(--nav-num)/1 system-ui;
}

/* 非アクティブは灰色フルで固定 */

.service-sync__navItem:not(.is-active) .service-sync__dot {
	--deg: 0deg;
	background: radial-gradient(circle at center, #fff 60%, transparent 70%), conic-gradient(#e6e6e6 100%, #e6e6e6 0);
}

/* ラベル */

.service-sync__label {
	-webkit-text-stroke: 0.8px #222; /* SPは線を薄めて太って見えるのを抑制 */
	color: transparent;
	font-size: var(--nav-fs);
	font-weight: 800;
	letter-spacing: 0.04em;
}

.service-sync__navItem.is-active .service-sync__label {
	-webkit-text-stroke: 0;
	color: #111;
}

/* Swiper内部に高さを伝える */

.service-sync__image-swiper .swiper-wrapper,
.service-sync__image-swiper .swiper-slide {
	height: 100%;
}

/* テキスト／ボタンの段配置 */

.service-sync__text-swiper {
	flex: 0 0 100%;
	margin-top: 40px;
	order: 2;
}

.p-top-business__button {
	flex: 0 0 100%;
	order: 3;
	padding-top: 80px;
}

.p-header-nav {
	display: flex;
	display: none;
	gap: 30px;
	margin-left: 80px;
}

.p-header-nav__link {
	display: inline-block;
	position: relative;
	text-decoration: none;
}

.p-header-nav__link span {
	position: relative;
	transition: color 0.3s ease;
}

.p-header-nav__link::after {
	background-color: #9a9a9a;
	bottom: -6px;
	content: "";
	height: 2px;
	left: 0;
	position: absolute;
	transition: width 0.4s ease;
	width: 0%;
}

.p-header-nav__link:hover span {
	color: #9a9a9a;
}

.p-header-nav__link:hover::after {
	width: 100%;
}

.p-header-nav__text--en {
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 1px;
	line-height: 1.2;
}

#js-drawerMenu {
	background-color: #1f1f1f;
	height: 100%;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: fixed;
	top: 0;
	transform: translateY(-100%);
	transition: transform 0.5s ease, opacity 1s ease;
	width: 100%;
	z-index: 30;
}

#js-drawerMenu.is-checked {
	opacity: 1;
	pointer-events: auto;
	transform: translateY(0);
}

.p-drawerMenu {
	align-items: flex-start;
	background-color: #1f1f1f;
	display: flex;
	height: 100vw;
	overflow-y: auto;
	width: 100%;
}

.p-drawerMenu.is-checked {
	transform: translateY(0);
}

.p-drawerMenu__container {
	margin-left: auto;
	margin-right: auto;
	width: 100%;
}

.p-drawerMenu__wrapper {
	display: flex;
	flex-wrap: wrap;
	padding: 120px 0;
	position: relative;
}

.p-drawerMenu__nav {
	color: #fff;
	display: flex;
	flex-direction: column;
	gap: 40px;
	height: 100%;
	list-style: none;
	margin: 0 20px;
	padding: 0;
	width: 100%;
}

.p-drawerMenu__nav.second {
	margin-top: 40px;
}

.p-drawerMenu__nav-link {
	display: flex;
	flex-direction: column;
	font-weight: 700;
	letter-spacing: 1.2px;
	overflow: hidden;
	text-decoration: none;
}

.p-drawerMenu__nav-link--en {
	font-size: 24px;
}

.p-drawerMenu__nav-link--ja {
	font-size: 10px;
	margin-top: 10px;
}

.p-drawerMenu__nav--children {
	display: flex;
	flex-direction: column;
	gap: 10px;
	margin-top: 20px;
}

.p-drawerMenu__nav--children-item--sp {
	display: block;
}

.p-drawerMenu__nav--children-item--pc {
	display: none;
}

.p-drawerMenu__nav--children-text {
	color: #9a9a9a;
	font-weight: 400;
	line-height: 1.7;
}

.p-drawerMenu__nav-profile {
	align-items: center;
	display: flex;
	gap: 20px;
	margin-top: 24px;
}

.p-drawerMenu__nav-profile--logo img {
	height: 37px;
	width: 119px;
}

.p-drawerMenu__nav-profile--sns {
	display: flex;
	gap: 20px;
}

.p-drawerMenu__nav-profile--sns-line img {
	height: 30px;
	width: 30px;
}

.p-drawerMenu__nav-profile--sns-instagram img {
	height: 30px;
	width: 30px;
}

.p-drawerMenu__nav-profile--sns a {
	display: inline-block;
	position: relative;
}

.p-drawerMenu__nav-profile--sns a img:nth-child(2) {
	left: 0;
	opacity: 0;
	position: absolute;
	top: 0;
	transition: opacity 0.9s ease;
}

.p-drawerMenu__nav-profile--sns a:hover img:nth-child(2) {
	opacity: 1;
}

.p-drawerMenu__nav-profile--sns a:hover img:nth-child(1) {
	opacity: 0;
}

.p-footer__body {
	display: flex;
	flex-wrap: wrap;
	height: 100%;
	justify-content: center;
	width: 100%;
}

.p-footer__nav {
	display: flex;
	flex: 0 0 50%;
	flex-direction: column;
	gap: 20px;
	max-width: 50%;
}

.p-footer__nav-profile {
	margin-top: 20px;
}

.p-footer__nav-link {
	transition: color 0.3s ease;
}

.p-footer__nav-link:hover {
	color: #9a9a9a;
}

.p-footer__nav-text {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1.2px;
}

.p-footer__nav-profile--logo img {
	height: 37px;
	width: 119px;
}

.p-footer__nav-profile--sns {
	display: flex;
	gap: 20px;
}

.p-drawerMenu__nav-profile--sns-line img {
	height: 30px;
	width: 30px;
}

.p-footer__nav-profile--sns-instagram img {
	height: 30px;
	width: 30px;
}

.p-footer__nav--children {
	display: flex;
	flex-direction: column;
	margin-top: 12px;
}

.p-footer__nav--children-item {
	margin-top: 10px;
}

.p-footer__nav--children-link {
	transition: color 0.3s ease;
}

.p-footer__nav--children-link:hover {
	color: #9a9a9a;
}

.p-footer__nav--children-text {
	font-size: 12px;
	font-weight: 700;
	line-height: 1.7;
}

.p-footer__nav-profile--tel {
	margin-top: 10px;
	padding-left: 5px;
}

.p-footer__nav-profile--telNum {
	font-size: 12px;
	font-weight: 500;
}

.p-fv__catch {
	left: 15px;
	position: absolute;
	top: 20px;
	z-index: 12;
}

.p-fv__catch-primary {
	font-size: clamp(2rem, 4vw + 1rem, 6rem);
	font-weight: 900;
	letter-spacing: -0.12em;
	line-height: 1.2;
}

.p-fv__catch-secondary {
	font-size: clamp(2rem, 4vw + 1rem, 6rem);
	font-weight: 900;
	letter-spacing: -0.12em;
	line-height: 1.2;
	margin-top: 5px;
}

.hero__str,
.char {
	animation: typingFade 0.4s ease forwards;
	display: inline-block;
	opacity: 0;
}

:root {
	--text-base-delay: 2.5s; /* スマホ演出が落ち着いたあとに開始 */
}

.hero__str:nth-child(1) {
	animation-delay: calc(var(--text-base-delay) + 0.3s);
}

.hero__str:nth-child(2) {
	animation-delay: calc(var(--text-base-delay) + 0.4s);
}

.hero__str:nth-child(3) {
	animation-delay: calc(var(--text-base-delay) + 0.5s);
}

.hero__str:nth-child(4) {
	animation-delay: calc(var(--text-base-delay) + 0.6s);
}

.hero__str:nth-child(5) {
	animation-delay: calc(var(--text-base-delay) + 0.7s);
}

.hero__str:nth-child(6) {
	animation-delay: calc(var(--text-base-delay) + 0.8s);
}

.hero__str:nth-child(7) {
	animation-delay: calc(var(--text-base-delay) + 0.9s);
}

.hero__str:nth-child(8) {
	animation-delay: calc(var(--text-base-delay) + 1s);
}

.hero__str:nth-child(9) {
	animation-delay: calc(var(--text-base-delay) + 1.1s);
}

.hero__str:nth-child(10) {
	animation-delay: calc(var(--text-base-delay) + 1.2s);
}

.hero__str:nth-child(11) {
	animation-delay: calc(var(--text-base-delay) + 1.3s);
}

.char:nth-child(1) {
	animation-delay: calc(var(--text-base-delay) + 1.4s);
}

.char:nth-child(2) {
	animation-delay: calc(var(--text-base-delay) + 1.5s);
}

.char:nth-child(3) {
	animation-delay: calc(var(--text-base-delay) + 1.6s);
}

.char:nth-child(4) {
	animation-delay: calc(var(--text-base-delay) + 1.7s);
}

.char:nth-child(5) {
	animation-delay: calc(var(--text-base-delay) + 1.8s);
}

.char:nth-child(6) {
	animation-delay: calc(var(--text-base-delay) + 1.9s);
}

.char:nth-child(7) {
	animation-delay: calc(var(--text-base-delay) + 2s);
}

.char:nth-child(8) {
	animation-delay: calc(var(--text-base-delay) + 2.1s);
}

.char:nth-child(9) {
	animation-delay: calc(var(--text-base-delay) + 2.2s);
}

.p-fv {
	align-items: center;
	display: flex;
	height: auto; /* 全画面高さ */
	justify-content: center;
	padding-top: 180px;
	perspective: 1000px; /* 立体感の奥行き(2DでもOK) */
	position: relative;
	position: relative;
	width: 100%;
	z-index: 15; /* 演出トークン */
	--enter-delay: 1.4s; /* いつ開始するか */
	--phone-dur: 1800ms; /* 所要時間（ゆっくり） */
	--start-scale: 2.6; /* 画面に近い(=大きい)スタート */
	--start-y: 42px; /* 下から入る距離 */
	--overshoot-up: -8px; /* 行き過ぎ位置(上) */
	--overshoot-down: 4px; /* 戻り位置(下) */ /* テキストの開始をスマホ完了に連動（余韻0.3s） */
	--text-base-delay: calc(var(--enter-delay) + var(--phone-dur) + 100ms);
}

/* スライダー全体 */

.p-fv__swiper {
	height: 100%;
	width: 100%;
}

.p-fv__swiper .swiper-wrapper {
	align-items: center;
}

.p-fv__swiper .swiper-slide {
	align-items: center;
	display: flex;
	justify-content: center;
}

/* スマホ枠 */

.p-fv__phone {
	animation: parallaxRise var(--phone-dur) cubic-bezier(0.2, 0.8, 0.2, 1) var(--enter-delay) forwards;
	left: 50%; /* 初期＝0% と一致させる */
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: var(--phone-top, 60%);
	transform: translate(-50%, calc(-50% + var(--start-y))) scale(var(--start-scale));
	transform-origin: center;
	will-change: transform, opacity;
	z-index: 10;
}

/* ▼ 3) ゆっくり近距離パララックス */

/* ▼ 4) 低モーション配慮 */

.p-fv__phoneFrame {
	display: block;
	transform: scale(1.3); /* 倍率を調整 */
	transform-origin: center; /* 中心から拡大 */
}

.p-lower-price__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-lower-price__link {
	padding-bottom: 64px;
}

.p-price-link__item {
	display: block;
	position: relative;
}

.p-price-link__item::before {
	border-left: 2px solid #9a9a9a;
	content: "";
	inset: 0;
	pointer-events: none;
	position: absolute;
	transition: border-color 0.3s;
}

.p-price-link__item:hover::before {
	border-color: #1B9AFF;
}

.p-price-link__item:hover .c-ppTitle-main__text.contactLink,
.p-price-link__item:hover .c-ppTitle-sub__text.contactLink {
	color: #1B9AFF;
}

.p-lower-projects__exampleBox {
	align-items: center;
	display: flex;
	gap: 5px;
	margin-bottom: 30px;
}

.p-lower-projects__exampleBox.top {
	margin-bottom: 0;
	padding-top: 10px;
}

.p-lower-projects__exampleBox.lower {
	padding-top: 30px;
}

.p-lower-projects__example-icon {
	width: 30px;
}

.p-lower-projects__example-icon.top {
	width: 25px;
}

.p-lower-projects__example-icon.lower {
	width: 25px;
}

.p-lower-projects__example-text {
	font-size: 15px;
	font-weight: 700;
}

.p-lower-projects__example-text.top {
	font-size: 14px;
}

.p-lower-projects__example-text.lower {
	font-size: 14px;
}

.p-price-web__icon {
	height: 47px;
	width: 35px;
}

.p-price-web__text {
	font-weight: 700;
	line-height: 180%; /* 21px */
	margin-bottom: 64px;
}

.p-price-web__list {
	display: grid;
	grid-template-columns: 1fr;
}

.p-price-web__item {
	border-bottom: 1px solid #1f1f1f;
	padding-bottom: 30px;
	padding-top: 30px;
}

.p-price-web__item.top {
	border-top: 1px solid #1f1f1f;
}

.p-price-web__heading {
	align-items: center;
	display: flex;
	gap: 10px;
}

.p-price-web__icon {
	align-items: center;
	flex-shrink: 0;
	height: 28px;
	justify-content: center;
	width: 28px;
}

.p-price-web__icon img {
	display: block;
	height: 100%;
	width: 100%;
	-o-object-fit: contain;
	object-fit: contain;
}

.p-price-web__title {
	font-size: 18px;
	font-weight: 700;
}

.p-price-web__desc {
	font-size: 12px;
	font-weight: 400;
	line-height: 1.7;
	margin-top: 20px;
}

.p-price-web__desc.design {
	margin-top: 30px;
}

.p-price-web__price {
	align-items: center;
	display: flex;
	font-size: 12px;
	font-weight: 700;
	justify-content: flex-end;
	line-height: 1.7;
	margin-top: 20px;
	text-align: right;
}

.p-price-web__price::before {
	background-color: #AAA;
	content: "";
	display: inline-block;
	flex-grow: 1;
	height: 1px;
	margin-left: 20px;
	margin-right: 10px;
	max-width: 300px;
}

.p-price-web__price.design {
	margin-top: 10px;
}

.p-price-web__price--big {
	font-size: 18px;
	font-weight: 700;
	padding-right: 3px;
}

.p-price-web__price--big.SNS {
	font-size: 16px;
}

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

.p-price-web__bottom-text {
	font-size: 12px;
	font-weight: 400;
	line-height: 1.7;
}

.p-price-web__bottom-text--second {
	display: block;
	margin-top: 7px;
}

.p-price-design__menu--item.second {
	margin-top: 20px;
}

.p-price-design-title {
	font-size: 16px;
	font-weight: 700;
	line-height: 1.7;
}

.p-pojects__main {
	background-color: #1B9AFF;
	position: relative;
	z-index: 1;
}

.p-pojects__main--wrapper {
	padding-bottom: 96px;
}

.p-pojects__main--container {
	padding-left: 20px;
}

.p-pojects__main--container::before {
	background-color: #fdfdfd;
	content: "";
	height: 50%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.p-projects__outline--wrapper {
	padding-bottom: 96px;
	padding-top: 96px;
}

.p-projects__outline--container {
	display: flex;
	flex-direction: column-reverse;
	flex-wrap: wrap;
	justify-content: space-between;
}

.p-projects__outline--primary {
	flex-basis: 100%;
	flex-grow: 0;
	flex-shrink: 0;
	margin-top: 64px;
	max-width: 100%;
	position: relative;
	width: 100%;
}

.p-projects__outline--overview-header {
	border-top: 1px solid #1f1f1f;
	padding-top: 8px;
}

.p-projects__outline--overview-header h2 {
	color: #9a9a9a;
	font-weight: 700;
}

.p-projects__outline--overview-body {
	margin-top: 64px;
}

.p-projects__outline--overview-body-blog p {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.8;
	margin-bottom: 40px;
}

.p-projects__outline--overview-body-blog h2 {
	border-bottom: 1px solid #1f1f1f;
	font-size: 24px;
	font-weight: 700;
	line-height: 140%;
	margin-bottom: 20px;
	margin-top: 64px;
	padding-bottom: 12px;
}

.p-projects__outline--overview-body-blog h3 {
	background-color: #3e3b3f;
	color: #fff;
	font-size: 20px;
	font-weight: 700;
	line-height: 140%;
	margin-bottom: 20px;
	margin-top: 48px;
	padding: 12px;
}

.blog-marker {
	background: linear-gradient(transparent 60%, #ff6 0);
}

.p-projects__outline--secondary-inner {
	position: relative;
}

.c-title__thirdly {
	align-items: center;
	display: flex;
	gap: 5px;
}

.c-title__thirdly--mark img {
	height: 20px;
	width: 18px;
}

.c-title__thirdly--text {
	font-weight: 700;
}

.p-projects__outline--info {
	margin-top: 24px;
}

.p-projects__outline--info-item {
	display: flex;
	flex-wrap: wrap;
}

.onomichi-basic {
	font-size: 12px;
	margin-top: 8px;
}

.onomichi-basic-marker {
	font-size: 13px;
	font-weight: 500;
	text-decoration: underline;
}

.p-projects__outline--info-item:not(:first-of-type) {
	margin-top: 20px;
}

.p-projects__outline--info-item dt {
	color: #9a9a9a;
	flex: 0 0 100%;
	font-weight: 700;
	line-height: 1.7;
	max-width: 100%;
}

.p-projects__outline--info-item dd {
	flex: 0 0 100%;
	font-weight: 400;
	line-height: 1.7;
	margin-top: 4px;
	max-width: 100%;
	padding-left: 0;
}

.p-projects__outline--info-item dd a {
	font-weight: 400;
	line-height: 1.6;
	padding-left: 24px;
	position: relative;
	text-decoration: underline;
	word-break: break-all;
}

.p-projects__outline--info-item dd a::before {
	background: url(../../assets/img/single/url-icon.png) no-repeat center center/cover;
	content: "";
	height: 20px;
	left: 0;
	position: absolute;
	top: 0;
	width: 20px;
}

.p-projects__outline--info-item-cat {
	font-size: 12px;
}

.p-projects__outline--info-item-cat-label {
	background-color: #3e3b3f;
	color: #fff;
	display: inline-block;
	font-weight: 700;
	margin: 0 8px 8px 0;
	padding: 4px 8px;
	position: relative;
	text-align: center;
	text-decoration: none;
	transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
	transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	z-index: 2;
}

.p-projects__screenshots {
	background-color: #CAD6DF;
}

.p-projects__screenshots--wrapper {
	padding-bottom: 96px;
	padding-top: 96px;
}

/* 各ブロック（行） */

.p-projects__screenshots--laptop,
.p-projects__screenshots--grid,
.p-projects__screenshots--logos,
.p-projects__screenshots--cards {
	display: grid;
	gap: 24px;
}

/* 行間の余白 */

.p-projects__screenshots--laptop + .p-projects__screenshots--grid,
.p-projects__screenshots--grid + .p-projects__screenshots--logos,
.p-projects__screenshots--logos + .p-projects__screenshots--cards {
	margin-top: 64px;
}

.p-projects__screenshots--grid.third {
	margin-top: 64px;
}

.p-projects__screenshots--col.Renwayve-logo {
	align-self: center;
}

/* 列数 */

.p-projects__screenshots--laptop {
	grid-template-columns: 1fr 1fr;
}

.p-projects__screenshots--laptop.single {
	grid-template-columns: 1fr;
	justify-items: center; /* 中央寄せ */
}

.p-projects__screenshots--grid {
	grid-template-columns: 1fr 1fr;
}

.p-projects__screenshots--grid .two-cols {
	margin-top: 64px;
}

/* 「HP5＋ロゴ」を同一行で2カラムにする時に付ける修飾 */

.p-projects__screenshots--grid.two-cols {
	align-items: start;
	grid-template-columns: 1fr 1fr; /* 左:HP5 右:ロゴ */
	margin-top: 64px;
}

/* ロゴの並べ方（右カラム内） */

.p-projects__screenshots--logos {
	gap: 16px;
	grid-template-columns: 1fr; /* 縦並び */
}

.p-projects__screenshots--logos.cols-2 {
	grid-template-columns: 1fr 1fr; /* 横並びにしたい場合は class追加 */
}

/* 名刺（表裏） */

.p-projects__screenshots--cards {
	grid-template-columns: 1fr 1fr;
	margin-top: 64px;
}

/* カード（写真枠） */

.p-projects__screenshots--card {
	align-items: center;
	border-radius: 12px;
	display: flex;
	justify-content: center;
	margin: 0; /* 縦長スクショをもっと小さく見せたい時に付ける任意クラス */
}

.p-projects__screenshots--card.logo {
	background-color: #fff;
	padding: 24px;
}

.p-projects__screenshots--card.second {
	margin-top: 64px;
}

.p-projects__screenshots--card.is-thumb img {
	max-height: 580px;
}

/* 中の画像（スクロール無しで全体表示） */

.p-projects__screenshots--item {
	display: block;
	height: auto; /* 比率維持で縮小 */
	max-width: 100%;
	-o-object-fit: contain;
	object-fit: contain;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
}

.p-plan__wrapper {
	display: flex;
	flex-direction: column;
	gap: 60px;
}

.p-plan__body {
	display: flex;
	flex-direction: column;
	min-width: 0;
}

/* ========= Block: p-plan ========= */

.p-plan {
	border: 1px solid #e6ecee;
	border-radius: 16px;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.08);
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	isolation: isolate; /* 下部の飾りSVGがはみ出さないように */
	margin-bottom: 20px;
	min-height: 100%;
	overflow: hidden;
	position: relative;
}

/* --- Elements: head --- */

.p-plan__head {
	background: #66B5C1;
	color: #fff;
	padding: 20px 20px;
	text-align: center;
}

.p-plan__head.basic {
	background: #ADDB6E;
}

.p-plan__head.premium {
	background: #FCB369;
}

.p-plan__head.example {
	background: #E9DF68;
}

.p-plan__badge {
	background: rgba(255, 255, 255, 0.25);
	border-radius: 999px;
	display: inline-block;
	font-size: 12px;
	letter-spacing: 0.06em;
	margin-bottom: 8px;
	padding: 4px 10px;
}

.p-plan__title {
	font-size: 20px;
	font-weight: 700;
	letter-spacing: 0.12em;
	margin: 0;
}

/* --- Elements: notes --- */

.p-plan__notes {
	background: #FAFAF8;
	margin-bottom: 20px;
	padding: 10px 20px;
}

.p-plan__note {
	align-items: center;
	display: flex;
	font-weight: 600;
	gap: 12px;
	margin: 10px 0 !important;
}

.p-plan__check {
	display: grid;
	flex: 0 0 auto;
	height: 22px;
	place-items: center;
	width: 22px;
}

/* --- Elements: features --- */

.p-plan__features {
	margin-bottom: 20px;
	padding-left: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
	padding-right: clamp(0.625rem, -0.421rem + 4.46vw, 1.25rem);
}

.p-plan__feature {
	align-items: center;
	border-bottom: 1px solid #e9eef0;
	display: grid;
	font-weight: 700;
	gap: 12px;
	grid-template-columns: 1fr auto;
	letter-spacing: 0.12em;
	padding: 20px clamp(0rem, -2.093rem + 8.93vw, 1.25rem);
}

.p-plan__feature:last-child {
	border-bottom: none;
}

.p-plan__feature-left {
	align-items: center;
	display: flex;
	gap: clamp(0.625rem, -3.141rem + 16.74vw, 3.125rem);
}

.p-plan__feature-left.example {
	font-size: 14px;
}

.p-plan__crumb {
	flex-shrink: 0;
	height: 30px;
	min-height: 30px; /* 縮ませないための保険 */
	min-width: 60px;
	width: 60px;
}

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

.p-plan__icon {
	height: 22px;
	margin-right: 26px;
	width: 20px;
}

.p-plan__icon.lower {
	margin-right: 0;
	width: 72px;
}

.p-plan__icon.example-x-L {
	height: 52px;
	margin-right: 13px;
	width: 48px;
}

.p-plan__icon.example-x-M {
	margin-right: 13px;
	width: 48px;
}

.p-plan__icon.leo {
	height: 52px;
	margin-right: 0;
	width: 72px;
}

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

/* --- Elements: bottom/price --- */

.p-plan__bottom {
	align-items: center;
	background: #66B5C1;
	display: flex;
	justify-content: space-between;
	margin-top: auto;
	padding: 20px;
	position: relative;
}

.p-plan__bottom.basic {
	background: #ADDB6E;
}

.p-plan__bottom.premium {
	background: #FCB369;
}

.p-plan__bottom.example {
	background: #E9DF68;
}

.p-plan__burger {
	height: 64px;
	position: relative;
	width: 80px;
}

.p-plan__price__text {
	display: flex;
	gap: 10px;
	justify-content: flex-end;
	margin-bottom: 5px;
}

.p-plan__price-caption {
	color: #fff;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.08em;
	margin-bottom: 0 !important;
}

.p-plan__price-value {
	color: #fff;
	font-size: 26px;
	font-weight: 700;
	letter-spacing: 0.06em;
}

.p-plan__en {
	color: #fff;
	font-size: 12px;
}

.p-plan__tax {
	color: #fff;
	font-size: 12px;
	margin-left: 3px;
}

.p-plan__bottom-text {
	font-weight: 400;
	line-height: 2;
}

.p-plan__feature-left-text {
	display: flex;
	flex-direction: column;
	margin-bottom: 0 !important;
}

.p-plan__feature-left-textMain {
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.12em;
}

.p-plan__feature-left-textSub {
	font-size: 11px;
	font-weight: 600;
	line-height: 1.8;
}

.p-plan__feature-left-textSub.top {
	margin-top: 5px;
}

.u-separate {
	margin-bottom: 30px;
	margin-top: 30px;
}

.u-hidden-sp {
	display: block;
}

.u-hidden-tab {
	display: none;
}

.u-hidden-pc {
	display: none;
}

@media (prefers-reduced-motion: reduce) {

.p-fv__phone {
	animation: none !important;
	opacity: 1 !important;
	transform: translate(-50%, -50%) !important;
}

}

@media screen and (min-width: 600px) {

.l-footer {
	padding-bottom: 96px;
}

.l-inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--contact {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--introduce {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--flow {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--faq {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--voice {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--drawer {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-inner--price {
	margin-left: auto;
	margin-right: auto;
	max-width: 550px;
}

.l-cta {
	margin-bottom: 96px;
}

.l-cta__sectionTitle {
	margin-bottom: 50px !important;
}

.l-commitment__sectionTitle {
	margin-bottom: 120px !important;
}

.l-lower-catch {
	padding-bottom: 80px;
	padding-top: 64px;
}

.l-lower-flow {
	padding-top: 40px;
}

.l-lower-flow.thanks {
	padding-bottom: 96px;
}

.c-copyright {
	height: 260px;
}

.c-faqTitle__text {
	font-size: 16px;
}

.c-lower__catch--sp {
	display: none;
}

.c-lower__catch--sm {
	display: block;
}

.c-lower__catch--sm2 {
	display: none;
}

.c-slider__projects--container {
	max-width: calc(100vw - (100vw - 510px) / 2);
}

.c-slider__gallery .swiper-slide img {
	height: 160px;
	width: 160px;
}

.c-lower-pojects__container {
	padding-top: 64px;
}

.p-footer-cta__wrapper {
	max-width: 510px;
}

.p-footer-cta__contactText {
	font-size: 16px;
}

.p-footer-cta__contactText--big {
	font-size: 16px;
}

.p-footer-cta__contactText--sm {
	display: none;
}

.p-faq-item__q {
	gap: 25px;
}

.p-voice-item__stars {
	padding-bottom: 5px;
}

.p-voice-item--tab__info-label {
	font-size: 12px;
}

.p-voice-item--tab__info-value {
	font-size: 12px;
}

.p-business-item__title {
	font-size: 24px;
}

.p-top-concept__catch {
	font-size: 44px;
}

.p-top-concept__fade-paragraph {
	letter-spacing: 0;
}

.fade-paragraph--sm {
	display: block;
}

.fade-paragraph--sm2 {
	display: block;
}

.p-top-about__catchText1 {
	font-size: 28px;
}

.p-top-about__catchText2 {
	font-size: 28px;
}

.p-do-item__request {
	padding: 48px 40px 40px;
}

.p-do-item__request::after {
	background: url(../../assets/img/top/do-arrow-icon-tab.png) no-repeat center center/cover;
	bottom: -30px;
	height: 35px;
	left: 146px;
	width: 183px;
}

.p-do-item__text {
	font-size: 16px;
}

.p-do-item__solution {
	padding: 48px 40px 40px;
}

.p-do-item__description {
	font-size: 16px;
}

.p-top-cta__text {
	font-size: 16px;
}

.p-lower-ceo {
	gap: 30px;
}

.p-lower-ceo__img img {
	height: 245px;
	width: 294px;
}

.p-lower-ceo__greeting {
	font-size: 18px;
}

.p-lower-aboutUs__header--text {
	margin-left: auto;
	margin-right: auto;
	max-width: 510px;
}

.p-lower-commitment__items {
	gap: 120px;
}

.p-commitment-item {
	flex-direction: row;
	gap: 40px;
}

.p-commitment-item__number {
	font-size: 48px;
}

.p-for-clients__header-wrapper {
	padding: 40px;
}

.p-for-clients__container {
	margin-left: auto;
	margin-right: auto;
	max-width: 510px;
}

.p-lower-catch__image {
	height: 344px;
}

.p-lower-contact__text {
	text-align: center;
}

.service-sync__dot {
	background: radial-gradient(circle at center, #fff 55%, transparent 70%), conic-gradient(#111 calc(360deg - var(--deg)), #e6e6e6 0);
	height: 36px;
	width: 36px;
}

.service-sync__num {
	color: #111;
	font: 800 16px/1 system-ui;
}

.service-sync__label {
	font-size: 15px;
}

.p-drawerMenu__wrapper {
	flex-wrap: nowrap;
}

.p-drawerMenu__nav.second {
	margin-top: 0;
}

.p-footer__nav-text {
	font-size: 16px;
}

.p-fv__catch {
	top: 40px;
}

.p-fv {
	padding-top: 240px;
}

.p-fv__phoneFrame {
	transform: scale(1.25); /* 倍率を調整 */
}

.p-price-web__price::before {
	margin-right: 20px;
}

.p-pojects__main--container {
	padding-left: calc(50% - 255px);
}

.u-hidden-sp {
	display: none;
}

.u-hidden-tab {
	display: block;
}

}

@media screen and (min-width: 768px) {

.l-footer--sp {
	display: none;
}

.l-footer--pc {
	display: block;
}

.l-inner {
	max-width: 730px;
}

.l-inner--contact {
	max-width: 730px;
}

.l-inner--introduce {
	max-width: 730px;
}

.l-inner--flow {
	max-width: 730px;
}

.l-inner--faq {
	max-width: 730px;
}

.l-inner--voice {
	max-width: 730px;
}

.l-inner--drawer {
	max-width: 730px;
}

.l-inner--price {
	max-width: 730px;
}

.l-cta::after {
	height: 471px;
	top: -24px;
	width: 480px;
}

.l-ceo {
	background: #62BAFF;
	margin-top: 120px;
}

.l-aboutUs--sp {
	display: none;
}

.l-aboutUs--pc {
	display: block;
}

.l-lower-catch {
	padding-bottom: 120px;
	padding-top: 96px;
}

.l-lower-catch.projects {
	padding-bottom: 120px;
}

.l-lower-flow {
	padding-top: 64px;
}

.l-header__logo img {
	height: 47px;
	width: 151px;
}

.l-price {
	padding-bottom: 120px;
}

.c-sectionTitle-sub__text.projects {
	font-size: 20px;
}

.c-copyright {
	height: 280px;
	--focus-x: 50%;
	--focus-y: 55%;
	background-position: var(--focus-x) var(--focus-y);
}

.c-lower__catch--md {
	display: none;
}

.c-lower__catch--pc {
	display: block;
}

.c-lower__catch--ja {
	font-size: 20px;
}

.c-lower__pagination {
	padding-top: 80px;
}

.c-ppTitle.contactLink {
	left: 0;
	margin-bottom: 10px;
}

.c-ppTitle-main__text.contactLink {
	font-size: 17px;
}

.c-ppTitle-sub__text.support {
	padding-bottom: 10px;
}

.c-slider__projects--container {
	max-width: calc(100vw - (100vw - 690px) / 2);
}

.c-card__projects-archive {
	flex-direction: column;
	flex-wrap: nowrap;
}

.c-slider__projects--wrapper > li:not(:first-child) .c-card__projects-archive {
	margin-top: 0;
}

.c-card__projects--image {
	max-width: 100%;
}

.c-card__projects__contents {
	max-width: 100%;
	padding-left: 0;
	padding-top: 20px;
}

.c-slider__projects--nav {
	margin-top: 100px;
}

.c-slider__projects--arrow {
	height: 50px;
	width: 50px;
}

.c-slider__projects--arrow svg {
	height: 18px;
	width: 25px;
}

.c-slider__gallery {
	padding-bottom: 120px;
	padding-top: 120px;
}

.c-slider__gallery .swiper-slide img {
	height: 190px;
	width: 190px;
}

.c-lower-titleCatch {
	font-size: 78px;
}

.c-lower-pojects__container {
	padding-top: 96px;
}

.c-lower-pojects__heading--company {
	font-size: 32px;
}

.c-lower-pojects__heading--type {
	font-size: 20px;
}

.p-footer-cta__wrapper {
	max-width: 600px;
}

.p-footer-cta__menuText {
	font-size: 18px;
}

.p-footer-cta__contactText {
	font-size: 18px;
}

.p-footer-cta__contactText--big {
	font-size: 18px;
}

.p-faq-item__a {
	padding-bottom: 30px;
	padding-top: 30px;
}

.p-voice-item--tab {
	padding: 40px 20px;
}

.p-voice-item--tab__inner {
	gap: 30px;
}

.p-voice-item--tab__content {
	width: 470px;
}

.p-voice-item--tab__title {
	font-size: 22px;
	margin-bottom: 40px;
}

.p-voice-item--tab__rating {
	margin-bottom: 25px;
}

.p-voice-item--tab__rating-label {
	font-size: 18px;
	letter-spacing: 0.06em;
}

.p-voice-item--tab__ratings {
	gap: 15px 10px;
	padding: 15px;
}

.p-voice-item--tab__pair {
	gap: 15px;
}

.p-voice-item--tab__label {
	font-size: 12px;
	width: 86px;
}

.p-voice-item--tab__score {
	font-size: 14px;
}

.p-voice-item--tab__info-label {
	font-size: 14px;
}

.p-voice-item--tab__info-value {
	font-size: 14px;
}

.p-voice-item--tab__comment-text {
	font-size: 16px;
}

.p-top-voice__text {
	font-size: 16px;
}

.p-top-voice__button {
	padding-top: 104px;
}

.p-business-item__image img {
	border-radius: 5px 50px 5px 5px;
}

.p-business-item__image--reverse img {
	border-radius: 50px 5px 5px 5px;
}

.p-business-item__number img {
	height: 77px;
	width: 70px;
}

.p-business-item__subTitle {
	font-size: 16px;
}

.p-business-item__title {
	font-size: 32px;
}

.p-business-item__text {
	font-size: 16px;
}

.p-top-business__text {
	font-size: 16px;
}

.p-top-business__text--pc {
	display: block;
}

.p-top-business__button {
	padding-top: 104px;
}

.p-top-projects__text {
	font-size: 16px;
}

.p-top-projects__button {
	padding-top: 104px;
}

.p-top-concept__catch {
	font-size: 48px;
}

.p-top-concept__body {
	margin-top: 80px;
}

.p-top-concept__fade-paragraph {
	font-size: 22px;
	letter-spacing: 0.05em;
}

.fade-paragraph--sm2 {
	display: none;
}

.fade-paragraph--md {
	display: block;
}

.p-top-about__space {
	display: inline;
}

.p-top-about__desc {
	font-size: 18px;
}

.p-top-about__button {
	padding-top: 104px;
}

.p-top-about__catchText1--pc {
	font-size: 20px;
	font-weight: 700;
	line-height: 150%; /* 42px */
}

.p-top-about__catchText2--pc {
	font-size: 20px;
	font-weight: 700;
	line-height: 150%; /* 42px */
}

.p-top-do__text {
	font-size: 16px;
}

.p-do-item__request::after {
	bottom: -30px;
	left: 235px;
}

.p-do-item__text {
	font-size: 18px;
}

.p-lower-ceo {
	padding-top: 64px;
}

.p-lower-ceo__photo {
	position: relative;
}

.p-lower-ceo__img {
	position: absolute;
	top: -350px;
}

.p-lower-ceo__img img {
	height: 275px;
	width: 330px;
}

.p-lower-ceo__title {
	font-size: 28px;
}

.p-lower-ceo__greeting {
	font-size: 18px;
}

.p-lower-aboutUs__header--text {
	flex-direction: row;
	font-size: 20px;
	justify-content: space-between;
	max-width: 690px;
	padding: 20px;
}

.p-aboutUs-box--s {
	width: 100%;
}

.p-aboutUs-box__grid {
	gap: 35px;
	grid-template-columns: repeat(3, 1fr);
}

.p-aboutUs-box__grid2 {
	display: grid;
	gap: 35px;
	grid-template-columns: 7.5fr 2.5fr;
	margin-top: 35px;
	padding-bottom: 120px;
}

.p-commitment-item {
	gap: 64px;
}

.p-commitment-item__number {
	font-size: 64px;
}

.p-commitment-item__text {
	font-size: 16px;
	line-height: 200%; /* 23.1px */
}

.p-for-clients__container {
	max-width: 690px;
}

.p-for-clients__items {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.p-for-clients__item {
	flex-direction: column;
	padding-left: 25px;
	padding-right: 25px;
}

.p-for-clients__item--2 {
	border-left: 1px solid #3e3b3f;
	border-top: none;
	flex-direction: column;
	margin-top: 0;
	padding: 0 25px;
	padding-top: 0;
}

.p-for-clients__item--3 {
	border-left: 1px solid #3e3b3f;
	border-top: none;
	flex-direction: column;
	margin-top: 0;
	padding-left: 25px;
	padding-right: 25px;
	padding-top: 0;
}

.p-for-clients__heading-text {
	margin-top: 10px;
}

.p-lower-catch__image {
	height: 465px;
}

.p-faq-link__item::before {
	border-bottom: 2px solid #9a9a9a;
	border-left: none;
}

.p-faq-link__menu {
	display: grid;
	gap: 30px;
	grid-template-columns: repeat(3, 1fr);
}

.p-contactForm__lists {
	gap: 30px;
	margin-bottom: 64px;
}

.p-contactForm__list {
	flex-direction: row;
	justify-content: space-between;
}

.p-contactForm__button {
	margin-top: 70px;
}

.p-contact-control__left.textarea {
	align-items: start;
	margin-top: 15px;
}

.p-contact-control__left.radios {
	align-items: start;
}

.p-contact-control__left {
	flex: 0 0 240px;
}

.p-contact-control__right {
	flex: 1;
}

.p-contact-control__text {
	padding-left: 15px;
}

.p-pp-anchors__container {
	display: grid;
	gap: 40px;
	grid-template-columns: repeat(2, 1fr);
}

.p-lower-businessFlow__items {
	display: flex;
	flex-wrap: wrap;
}

.p-lower-businessFlow__card {
	flex: 0 0 50%;
	max-width: 50%;
	padding-left: 20px;
	padding-right: 20px;
}

.p-businessFlow-item {
	padding-bottom: 20px;
	padding-top: 20px;
}

.p-lower-business__text {
	font-size: 16px;
}

.p-lower-business__items {
	gap: 80px;
}

.p-lower-business__button {
	padding-top: 104px;
}

.p-lower-introduce__body--desc {
	font-size: 16px;
}

.p-lower-faq__text {
	font-size: 16px;
}

.p-lower-faq__button {
	padding-top: 104px;
}

.p-top-faq__text {
	font-size: 16px;
}

.p-top-faq__button {
	padding-top: 104px;
}

.service-sync__heading {
	gap: 16px;
}

.service-sync__heading {
	gap: 20px;
}

.service-sync__number img {
	width: 80px;
}

.service-sync__subTitle {
	font-size: 14px;
}

.service-sync__title {
	font-size: 26px;
}

.service-sync__text {
	font-size: 16px;
}

.service-sync__dot {
	background: radial-gradient(circle at center, #fff 50%, transparent 70%), conic-gradient(#111 calc(360deg - var(--deg)), #e6e6e6 0);
	height: 40px;
	width: 40px;
}

.service-sync__nav {
	gap: 20px;
}

.service-sync__navItem {
	gap: 12px;
}

.service-sync__navItem::after {
	width: 44px;
}

.service-sync__label {
	font-size: 18px;
}

.p-top-business.service-sync {
	align-items: flex-start; /* 親で上端そろえ */
}

.service-sync__side {
	align-self: flex-start; /* 各アイテムも上端に固定 */
	margin-top: 0 !important; /* 万一の上マージンを打ち消し */
}

.service-sync__nav,
.service-sync__navItem {
	margin-top: 0; /* リスト側のズレ要因をゼロに */
}

.p-drawerMenu__nav-link--en {
	font-size: 30px;
}

.p-drawerMenu__nav-link--ja {
	font-size: 14px;
}

.p-drawerMenu__nav--children-item--sp {
	display: none;
}

.p-drawerMenu__nav--children-item--pc {
	display: block;
}

.p-footer__body {
	flex-direction: column;
}

.p-footer__nav {
	display: grid;
	flex: 1 1 auto;
	flex-direction: row;
	grid-template-columns: repeat(4, 1fr);
	max-width: none;
	padding-left: 40px;
}

.p-footer__nav.second {
	margin-top: 40px;
}

.p-footer__nav.third {
	display: flex;
	justify-content: space-between;
	margin-bottom: 64px;
	padding-left: 0;
}

.p-footer__nav-text {
	font-size: 14px;
}

.p-lower-price__text {
	font-size: 16px;
}

.p-lower-price__link {
	padding-bottom: 120px;
}

.p-price-link__item::before {
	border-bottom: 2px solid #9a9a9a;
	border-left: none;
}

.p-price-link__menu {
	display: grid;
	gap: 30px;
	grid-template-columns: repeat(3, 1fr);
}

.p-lower-projects__example-text.top {
	font-size: 16px;
}

.p-projects-list {
	display: flex;
	flex-wrap: wrap;
	gap: 50px 30px;
}

.p-projects-list__item {
	width: calc(50% - 15px);
}

.p-price-web__text {
	font-size: 16px;
}

.p-price-web__list {
	gap: 0px 50px;
	grid-template-columns: repeat(2, 1fr);
}

.p-price-web__item {
	padding-bottom: 50px;
}

.p-price-web__item.second {
	border-top: 1px solid #1f1f1f;
}

.p-price-web__desc.genko {
	height: 82px;
}

.p-price-web__desc.lower-s {
	height: 102px;
}

.p-price-web__desc.lower-l {
	height: 82px;
}

.p-price-web__bottom {
	padding-bottom: 120px;
}

.p-pojects__main--container {
	padding-left: calc(50% - 345px);
}

.p-projects__screenshots--laptop,
.p-projects__screenshots--grid,
.p-projects__screenshots--logos,
.p-projects__screenshots--cards {
	gap: 28px;
}

.p-plan__note {
	font-size: 16px;
}

.p-plan__feature-left {
	font-size: 16px;
}

.p-plan__price-caption {
	font-size: 14px;
}

.p-plan__en {
	font-size: 14px;
}

.p-plan__tax {
	font-size: 14px;
}

.p-plan__bottom-text {
	font-size: 16px;
}

.p-plan__feature-left-textMain.x-design {
	font-size: 16px;
}

.p-plan__feature-left-textSub.x-design {
	font-size: 13px;
}

}

@media (min-width: 1000px) {

:root {
	--header-h: 80px;
}

}

@media screen and (min-width: 1000px) {

.l-footer {
	padding-bottom: 144px;
}

.l-faq {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-voice {
	padding-top: 180px;
}

.l-business {
	padding-top: 0px;
}

.l-projects {
	padding-top: 180px;
}

.l-projects.lower {
	padding-bottom: 180px;
	padding-top: 144px;
}

.l-concept {
	padding-top: 180px;
}

.l-concept--sp {
	display: none;
}

.l-concept--pc {
	display: block;
}

.l-about--sp {
	display: none;
}

.l-about--pc {
	display: block;
}

.l-sectionTitle {
	margin-bottom: 60px;
}

.l-can {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-can__sectionTitle {
	margin-bottom: 60px;
}

.l-can--sp {
	display: none;
}

.l-can--pc {
	display: block;
}

.l-inner {
	max-width: 970px;
}

.l-inner--introduce {
	max-width: 815px;
}

.l-inner--flow {
	max-width: 815px;
}

.l-inner--faq {
	max-width: 815px;
}

.l-inner--voice {
	max-width: 815px;
}

.l-inner--price {
	max-width: 970px;
}

.l-cta {
	margin-bottom: 144px;
}

.l-cta::after {
	top: 4px;
}

.l-cta__sectionTitle {
	margin-bottom: 70px !important;
}

.l-ceo {
	margin-top: 180px;
}

.l-aboutUs {
	padding-top: 180px;
}

.l-commitment {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-commitment__sectionTitle {
	margin-bottom: 160px !important;
}

.l-lower-catch {
	padding-bottom: 180px;
}

.l-lower-flow.thanks {
	padding-bottom: 144px;
}

.l-lower-contact {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-lower-field {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-lower-businessFlow {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-lower-business {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-lower-faq {
	padding-bottom: 180px;
	padding-top: 180px;
}

.l-lower-voice {
	padding-bottom: 180px;
	padding-top: 180px;
}

:root {
	--header-h: 80px;
}

.l-header__inner {
	padding-left: 30px;
	padding-right: 30px;
}

.l-header__wrapper {
	height: 80px;
}

.l-header__right {
	align-items: center;
	display: flex;
	justify-content: flex-end;
}

.l-lower-projects {
	padding-bottom: 180px;
}

.l-lower-price {
	margin-bottom: 180px;
}

.l-price {
	padding-bottom: 390px;
}

.c-sectionTitle-sub {
	font-size: 20px;
}

.c-sectionTitle-sub__icon img {
	height: 24px;
	width: 22px;
}

.c-sectionTitle-sub__text {
	font-size: 22px;
	letter-spacing: 3.8px;
}

.c-sectionTitle-sub__text.clients {
	font-size: 22px;
}

.c-sectionTitle-main {
	font-size: 48px;
	letter-spacing: 3.8px;
	margin-top: 6px;
}

.c-sectionTitle-main.clients {
	font-size: 14px;
}

.c-button {
	padding: 15px 50px;
}

.c-button--cta {
	border-radius: 30px;
}

.c-button-text {
	font-size: 18px;
}

.c-copyright {
	height: 300px;
	--focus-x: 50%;
	--focus-y: 55%;
	background-position: var(--focus-x) var(--focus-y);
}

.c-faqTitle {
	padding: 15px;
}

.c-faqTitle__text {
	font-size: 18px;
}

.c-lower__catch--en {
	font-size: 64px;
}

.c-lower__catch--ja {
	font-size: 24px;
	margin-top: 30px;
}

.c-contactTitle-icon img {
	height: 24px;
	width: 22px;
}

.c-contactTitle-main {
	margin-top: 8px;
}

.c-contactTitle-main__text {
	font-size: 24px;
}

.c-ppTitle.flow {
	flex: 0 0 33.33333333%;
	max-width: 33.33333333%;
}

.c-ppTitle.faq {
	margin-bottom: 60px;
}

.c-ppTitle-main__text.faq {
	font-size: 22px;
}

.c-ppTitle-main__text.contactLink {
	font-size: 18px;
}

.c-ppTitle-sub__text.faq {
	font-size: 14px;
	margin-top: 4px;
}

.c-ppTitle-sub__text.contactLink {
	margin-top: 2px;
}

.c-button-drawer {
	top: 23px;
}

.c-slider__projects--container {
	max-width: calc(100vw - (100vw - 930px) / 2);
}

.c-slider__gallery {
	padding-bottom: 180px;
	padding-top: 180px;
}

.c-slider__gallery .swiper-slide img {
	height: 220px;
	width: 220px;
}

.c-lower-serviceTitle {
	margin-bottom: 80px;
}

.c-lower-serviceTitle--mod {
	margin-bottom: 80px;
}

.c-lower-serviceTitle-icon img {
	height: 24px;
	width: 22px;
}

.c-lower-serviceTitle-main {
	margin-top: 8px;
}

.c-lower-serviceTitle-main__text {
	font-size: 24px;
}

.c-lower-titleCatch {
	font-size: 105px;
}

.c-lower-pojects__title--icon img {
	height: 24px;
	width: 22px;
}

.c-lower-pojects__heading--type {
	font-size: 24px;
}

.p-footer-nav {
	flex-direction: row;
	gap: 60px;
	justify-content: center;
}

.p-footer-subNav {
	gap: 15px;
}

.p-footer-logo {
	left: 60px;
	top: 119px;
}

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

.p-faq-item__q {
	gap: 25px;
}

.p-faq-item__q-text {
	font-size: 16px;
}

.p-faq-item__a-text {
	font-size: 16px;
}

.p-top-voice__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-top-voice__items {
	gap: 80px;
}

.p-top-voice__button {
	padding-bottom: 180px;
}

.p-business-item {
	align-items: end;
	display: flex;
	gap: 40px;
}

.p-business-item--reverse {
	flex-direction: row-reverse;
}

.p-business-item__image {
	position: relative;
	top: 50%;
	width: 70%;
}

.p-business-item__body {
	max-width: 700px;
	padding-top: 0;
}

.p-business-item__heading {
	align-items: start;
	gap: 20px;
	margin-bottom: 30px;
}

.p-business-item__subTitle {
	font-size: 16px;
}

.p-business-item__title {
	font-size: 32px;
}

.p-top-business__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-top-business__button {
	padding-bottom: 180px;
}

.p-top-projects__text {
	font-size: 18px;
}

.p-top-projects__button {
	padding-bottom: 180px;
}

.p-top-concept {
	padding-bottom: 180px;
}

.p-top-concept {
	margin-top: 30px;
}

.p-top-concept__catch {
	font-size: 60px;
}

.p-top-concept__fade-paragraph:not(:first-of-type) {
	margin-top: 64px;
}

.p-top-concept__fade-paragraph {
	font-size: 24px;
}

.fade-paragraph--lg {
	display: block;
}

.p-top-about {
	display: flex;
	gap: 30px;
}

.p-top-about__space {
	display: none;
}

.p-top-about__image {
	width: 100%;
}

.p-top-about__desc {
	font-size: 16px;
	margin-top: 25px;
}

.p-top-about__catchText1--pc {
	font-size: 26px;
	letter-spacing: 0.15em;
}

.p-top-about__catchText2--pc {
	font-size: 26px;
	letter-spacing: 0.15em;
}

.p-top-do__items {
	gap: 80px;
}

.p-top-do__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-do-item {
	display: flex;
	flex-wrap: wrap;
	height: 280px;
	max-width: 100%;
}

.p-do-item__request {
	align-items: center;
	display: flex;
	max-width: 48%;
	padding: 0 20px 0 40px;
}

.p-do-item__request::after {
	background: url(../../assets/img/top/do-arrow-icon-pc.png) no-repeat center center/cover;
	bottom: 0;
	height: 280px;
	left: 436px;
	width: 24px;
}

.p-do-item__request-title {
	font-size: 16px;
	gap: 20px;
}

.p-do-item__request-title--right {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

.p-do-item__text {
	padding-left: 20px;
}

.p-do-item__solution {
	align-items: start;
	display: flex;
	flex-direction: column;
	gap: 20px;
	justify-content: center;
	max-width: 52%;
	padding: 0 40px 0 64px;
}

.p-do-item__description {
	margin-top: 0;
}

.p-top-cta__text {
	font-size: 18px;
}

.p-lower-ceo {
	padding-bottom: 180px;
}

.p-lower-ceo__img {
	right: 40px;
	top: -410px;
}

.p-lower-ceo__img img {
	height: 309px;
	width: 370px;
}

.p-lower-ceo__title {
	font-size: 32px;
	margin-bottom: 64px;
}

.p-lower-ceo__greeting {
	font-size: 20px;
	width: 930px;
}

.p-lower-aboutUs__header--text {
	font-size: 24px;
	max-width: 930px;
}

.p-lower-aboutUs__boxes {
	margin-top: 80px;
}

.p-aboutUs-box__grid2 {
	padding-bottom: 180px;
}

.p-aboutUs-box__title {
	font-size: 22px;
	top: -19px;
}

.p-aboutUs-box__body {
	gap: 5px;
	padding: 25px 20px 20px 20px;
}

.p-aboutUs-box__body--s::after {
	left: 0;
	top: 78px;
}

.p-aboutUs-box__text {
	font-size: 20px;
}

.p-aboutUs-box__text--small {
	font-size: 18px;
	line-height: 35px;
}

.p-lower-commitment__items {
	gap: 160px;
}

.p-commitment-item {
	align-items: start;
	gap: 96px;
}

.p-commitment-item__number {
	font-size: 96px;
}

.p-commitment-item__body {
	gap: 40px;
	margin-top: 0;
}

.p-commitment-item__title {
	font-size: 32px;
}

.p-for-clients__container {
	max-width: 930px;
}

.p-for-clients__text {
	font-size: 16px;
}

.p-for-clients__heading-number {
	font-size: 18px;
}

.p-for-clients__heading-text {
	font-size: 18px;
	margin-top: 15px;
}

.p-lower-catch {
	margin-top: 64px;
}

.p-lower-catch.contact {
	margin-top: 40px;
}

.p-lower-catch__image {
	height: 484px;
}

.p-lower-catch__image.about { /* ← 追加：デフォルトの焦点（中央） */
	--focus-x: 50%;
	--focus-y: 100%;
}

.p-lower-catch__image.faq { /* ← 追加：デフォルトの焦点（中央） */
	--focus-x: 50%;
	--focus-y: 100%;
}

.p-lower-catch__image.voice { /* ← 追加：デフォルトの焦点（中央） */
	--focus-x: 50%;
	--focus-y: 90%;
}

.p-faq-link__menu {
	gap: 50px;
}

.p-lower-flow {
	display: flex;
	flex-wrap: wrap;
}

.p-lower-flow__text {
	flex: 0 0 66.66666667%;
	max-width: 66.66666667%;
}

.p-lower-flow__text.thanks {
	font-size: 16px;
}

.p-lower-flow__text.tel {
	font-size: 16px;
}

.p-lower-field__wrapper {
	display: flex;
	flex-direction: row-reverse;
	flex-wrap: wrap;
	justify-content: space-between;
}

.p-lower-field__right {
	align-items: flex-start;
	display: flex;
	flex: 0 0 58.33333333%;
	justify-content: flex-end;
	max-width: 58.33333333%;
}

.p-lower-field__left {
	flex: 0 0 33.33333333%;
	max-width: 33.33333333%;
}

.p-lower-field__lists {
	padding-left: 15px;
	padding-right: 15px;
}

.venn-pics {
	left: 59%;
	width: min(550px, 92vw);
}

.p-field-list__heading--en {
	font-size: 32px;
}

.p-field-list__item {
	padding-left: 5px;
}

.p-lower-businessFlow__wrapper {
	display: flex;
	flex-wrap: wrap;
	gap: 60px;
	justify-content: space-between;
}

.p-lower-businessFlow__img {
	flex: 0 0 50%;
	max-width: 50%;
}

.p-lower-businessFlow__items {
	flex: 0 0 41.66666667%;
	margin-top: 0;
	max-width: 41.66666667%;
}

.p-businessFlow-item {
	margin-top: 0;
}

.p-businessFlow-item__heading__num {
	font-size: 18px;
}

.p-lower-business__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-lower-business__items {
	gap: 100px;
}

.p-lower-introduce__wrapper {
	padding-bottom: 144px;
	padding-top: 144px;
}

.p-lower-introduce__body {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.p-lower-introduce__body--title {
	flex: 0 0 50%;
	font-size: 48px;
	max-width: 50%;
}

.p-lower-introduce__body--desc {
	flex: 0 0 50%;
	margin-top: 0;
	max-width: 50%;
}

.p-lower-faq__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-lower-faq__content.top {
	padding-top: 120px;
}

.p-lower-faq__content.about {
	margin-top: 100px;
	padding-top: 100px;
}

.p-lower-faq__items {
	gap: 64px;
}

.p-top-faq__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-top-faq__content.top {
	padding-top: 120px;
}

.p-top-faq__content.about {
	margin-top: 100px;
	padding-top: 100px;
}

.p-top-faq__items {
	gap: 64px;
}

.service-sync__image-swiper {
	aspect-ratio: 6/3;
}

.service-sync__text-swiper {
	margin-top: 64px;
}

.service-sync__number img {
	width: 70px;
}

.service-sync__subTitle {
	font-size: 16px;
}

.service-sync__title {
	font-size: 32px;
}

.service-sync__dot {
	height: 56px;
	width: 56px;
}

.service-sync__num {
	color: #111;
	font: 800 22px/1 system-ui;
}

.service-sync__label {
	font-size: 24px;
}

.service-sync__text-swiper {
	margin-top: 64px;
}

.p-header-nav {
	display: flex;
	gap: 30px;
	margin-left: 80px;
	margin-right: 80px;
}

.p-footer__nav {
	padding-left: 80px;
}

.p-footer__nav-text {
	font-size: 16px;
}

.p-fv {
	padding-top: 300px;
}

.p-fv__phone {
	top: 65%;
}

.p-fv__phoneFrame {
	transform: scale(1);
}

.p-lower-price__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-lower-price__link {
	padding-bottom: 180px;
}

.p-price-link__menu {
	gap: 50px;
}

.p-lower-projects__exampleBox.top {
	padding-top: 30px;
}

.p-lower-projects__example-text.top {
	font-size: 18px;
}

.p-projects-list__item {
	width: calc(33.3333% - 20px);
}

.p-price-web__text {
	font-size: 18px;
	margin-bottom: 80px;
}

.p-price-web__title {
	font-size: 22px;
}

.p-price-web__desc {
	font-size: 14px;
	margin-top: 40px;
}

.p-price-web__desc.genko {
	height: 95px;
}

.p-price-web__desc.lower-s {
	height: 95px;
}

.p-price-web__desc.lower-l {
	height: 95px;
}

.p-price-web__price {
	font-size: 14px;
	margin-top: 40px;
}

.p-price-web__price--big {
	font-size: 20px;
}

.p-price-web__bottom {
	padding-bottom: 180px;
}

.p-pojects__main--wrapper {
	padding-bottom: 144px;
}

.p-projects__outline--wrapper {
	padding-bottom: 144px;
	padding-top: 144px;
}

.p-projects__outline--container {
	align-items: flex-start;
	flex-direction: row;
}

.p-projects__outline--primary {
	flex-basis: calc(100% - 410px);
	flex-grow: 0;
	flex-shrink: 0;
	margin-top: 0;
	max-width: calc(100% - 410px);
	padding-left: 20px;
	padding-right: 20px;
	position: relative;
	width: 100%;
}

.p-projects__outline--secondary {
	flex: 0 0 330px;
	max-width: 330px;
	position: relative;
	width: 100%;
}

.p-projects__outline--secondary-inner {
	transition: transform 0.16s ease-out;
	will-change: transform;
}

.c-title__thirdly--mark img {
	height: 24px;
	width: 22px;
}

.p-projects__screenshots--wrapper {
	padding-bottom: 144px;
	padding-top: 144px;
}

.p-projects__screenshots--laptop,
.p-projects__screenshots--grid,
.p-projects__screenshots--logos,
.p-projects__screenshots--cards {
	gap: 32px;
}

.p-plan__wrapper {
	align-items: stretch;
	display: grid;
	gap: 220px 40px;
	grid-auto-rows: 1fr;
	grid-template-columns: repeat(2, 1fr);
}

.u-hidden-tab {
	display: none;
}

.u-hidden-pc {
	display: block;
}

}

@media screen and (min-width: 1200px) {

.l-inner {
	max-width: 1150px;
}

.l-inner--introduce {
	max-width: 965px;
}

.l-inner--flow {
	max-width: 965px;
}

.l-inner--faq {
	max-width: 965px;
}

.l-inner--voice {
	max-width: 965px;
}

.l-inner--price {
	max-width: 1150px;
}

.l-cta::after {
	right: -200px;
}

.l-price {
	padding-bottom: 325px;
}

.c-copyright {
	height: 330px;
	--focus-x: 50%;
	--focus-y: 60%;
	background-position: var(--focus-x) var(--focus-y);
}

.c-lower__catch--en {
	font-size: 80px;
}

.c-slider__projects--container {
	max-width: calc(100vw - (100vw - 1110px) / 2);
}

.c-slider__gallery .swiper-slide img {
	height: 250px;
	width: 250px;
}

.c-lower-titleCatch {
	font-size: 126px;
}

.c-lower-pojects__heading--company {
	font-size: 48px;
}

.c-lower-pojects__heading--type {
	font-size: 28px;
}

.p-voice-item--pc__photo {
	height: 200px;
	width: 200px;
}

.p-voice-item--pc__content {
	width: 850px;
}

.p-voice-item--pc__title {
	font-size: 26px;
}

.p-voice-item--pc__rating {
	margin-bottom: 25px;
}

.p-voice-item--pc__rating-label {
	font-size: 18px;
}

.p-voice-item--pc__stars {
	font-size: 20px;
}

.p-voice-item--pc__ratings {
	gap: 23px;
	margin-bottom: 25px;
}

.p-voice-item--pc__label {
	font-size: 14px;
}

.p-voice-item--pc__score {
	font-size: 16px;
}

.p-business-item__text {
	font-size: 18px;
}

.p-top-concept__catch {
	font-size: 68px;
}

.p-top-concept__fade-paragraph {
	font-size: 26px;
}

.p-top-about__desc {
	font-size: 18px;
}

.p-top-about__catchText1--pc {
	font-size: 28px;
}

.p-top-about__catchText2--pc {
	font-size: 28px;
}

.p-do-item__request::after {
	left: 523px;
}

.p-lower-ceo__img img {
	height: 371px;
	width: 445px;
}

.p-lower-ceo__greeting {
	width: 1110px;
}

.p-for-clients__container {
	max-width: 1110px;
}

.p-lower-catch__image {
	height: 484px;
}

.p-faq-link__menu {
	gap: 90px;
}

.venn-pics {
	width: min(700px, 92vw);
}

.service-sync__text {
	font-size: 18px;
}

.service-sync__navItem::after {
	width: 55px;
}

.p-header-nav {
	gap: 40px;
	margin-right: 120px;
}

.p-footer__nav {
	padding-left: 115px;
}

.p-price-link__menu {
	gap: 90px;
}

.p-price-web__desc.sp {
	height: 71px;
}

.p-price-web__desc.simple {
	height: 71px;
}

.p-plan__features {
	display: flex;
	flex: 1 1 auto;
	flex-direction: column;
	margin-bottom: 8px;
	padding-left: 10px;
	padding-right: 10px;
}

}

@media (max-width: 400px) {

.service-sync__image-swiper {
	aspect-ratio: 3/3.2;
}

}

@keyframes rotate-deco {

0% {
	transform: rotate(0deg);
}

100% {
	transform: rotate(360deg);
}

}

@keyframes fillText {

to {
	background-position: 0 0;
}

}

@keyframes typingFade {

from {
	opacity: 0;
	transform: translateY(5px);
}

to {
	opacity: 1;
	transform: translateY(0);
}

}

@keyframes parallaxRise {

0% {
	opacity: 0;
	transform: translate(-50%, calc(-50% + var(--start-y))) scale(var(--start-scale));
}

60% {
	opacity: 1;
	transform: translate(-50%, calc(-50% + var(--overshoot-up))) scale(1.02); /* 行き過ぎ */
}

80% {
	transform: translate(-50%, calc(-50% + var(--overshoot-down))) scale(1.01); /* 戻り */
}

100% {
	opacity: 1;
	transform: translate(-50%, -50%) scale(1); /* 着地 */
}

}

