@charset "utf-8";
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
@import url('https://fonts.cdnfonts.com/css/poppins');
/* reset  */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
		margin: 0;
		padding: 0;
		border: 0;
		font-size: 100%;
		font-family: 'Noto Sans JP', sans-serif;
		vertical-align: baseline;
		text-decoration: none;
		box-sizing: border-box;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
		display: block;
}
body {
		line-height: 1;
		font-size: 18px;
}
ol, ul {
		list-style: none;
}
blockquote, q {
		quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
		content: '';
		content: none;
}
table {
		border-collapse: collapse;
		border-spacing: 0;
}
@media only screen and (min-width: 768px) {
		.sp {
				display: none !important;
		}
}
@media only screen and (max-width: 767px) {
		.pc {
				display: none !important;
		}
}
/* common  */
body {
		color: #1D3D72;
}
img {
		max-width: 100%;
}
.red {
		color: #D01126 !important;
}
.inner {
		max-width: 1200px;
		margin: 0 auto;
}
.tac {
		text-align: center;
}
.f-pop {
		font-family: 'Poppins', sans-serif !important;
}
.fwb, .bold {
		font-weight: 700;
}
/* hero positioning variables */ :root {
		--content: 1200px; /* 想定の最大コンテンツ幅 */
		--text-left: 330px; /* .hero-copy の左位置 */
		--bg-shift: 0px; /* 背景のセンター基準からの微調整 */
}
/* header  */
.fv-wrap {
		background: url("../img/lp/bg_fv_wrap.png") no-repeat;
		background-size: cover;
		/* 画面中央を基準に、必要に応じて微調整 */
		background-position: calc(50% + var(--bg-shift)) top;
		height: 945px;
}
.site-header {
		background: rgba(255, 255, 255, 0.5);
}
.header-inner {
		display: flex;
		padding: 11px 20px;
		justify-content: space-between;
}
.logo {
		display: flex;
		align-items: center;
		justify-content: center;
}
.logo img {
		height: auto;
		max-height: 100%;
		width: auto;
		object-fit: contain;
}
.header-cta {
		display: flex;
		gap: 20px;
}
.tel {
		font-size: 38px;
		color: #1D3D72;
		font-weight: 700;
		padding-left: 35px;
		background: url(../img/lp/icon_tel.png) no-repeat left 0 bottom 0;
		text-align: center;
}
.tel .sub-txt {
		display: block;
		font-size: 14px;
		margin-left: -35px;
		font-weight: normal;
		padding: 3px 0 3px 35px;
		border: 1px solid #1D3D72;
		border-radius: 20px;
}
.btn-contact {
		background: #D01126;
		color: #fff;
		font-weight: 700;
		display: flex;
		align-items: center;
		padding: 0 60px;
		position: relative;
		border-radius: 40px;
		line-height: 1px;
}
.btn-contact::after {
		position: absolute;
		display: flex;
		content: "\203A";
		color: #D01126;
		width: 19px;
		height: 19px;
		background: #fff;
		border-radius: 50%;
		text-align: center;
		right: 22px;
		align-items: end;
		line-height: 1;
		justify-content: center;
		font-size: 24px;
}
/*  fv   */
.hero {
		height: 860px;
		/*background: url("../img/lp/img_fv.png") no-repeat right 20px;*/
		color: #1D3D72;
		position: relative;
}
.hero-copy {
		width: 769px;
		position: absolute;
		top: 50%;
		left: var(--text-left);
		transform: translate(0, -50%);
}
h1.eyebrow {
		font-size: 47px;
		color: #1D3D72;
		line-height: 1.5;
		text-align: right;
		background: url("../img/lp/bg_h1.png") no-repeat left 0px top 0;
		padding: 111px 10px 10px 35px;
}
.cell1 {
		display: inline-block;
		padding-right: 32px;
}
.hero-big1 {
		font-size: 63px;
		color: #D01126;
		display: inline-block;
		margin-left: -22px;
}
.hero-big2 {
		font-size: 63px;
}
.sub-lead {
		border-radius: 6px;
		font-size: 20px;
		background: #FFEEB5;
		padding: 5px;
		text-align: center;
		font-weight: 700;
		margin-bottom: 50px;
}
.badges {
		display: flex;
		gap: 20px;
		font-weight: 700;
		font-size: 24px;
		text-align: center;
		margin-bottom: 80px;
		justify-content: space-between;
		height: 105px;
		align-items: center;
		line-height: 1.3;
}
.badge {
		position: relative;
		padding: 0 35px;
}
.badge::before {
		position: absolute;
		left: 0;
		top: 50%;
		transform: translate(0, -50%);
		content: "";
		height: 105px;
		width: 38px;
		background: url("../img/lp/bg_usp_l.png") no-repeat;
		background-size: cover;
}
.badge::after {
		position: absolute;
		right: 0;
		top: 50%;
		transform: translate(0, -50%);
		content: "";
		height: 105px;
		width: 38px;
		background: url("../img/lp/bg_usp_r.png") no-repeat;
		background-size: cover;
}
.cta-row .btn-contact {
		height: 63px;
		margin: 0 auto;
		width: 320px;
}
/*  pain   */
.pain {
		padding: 100px 0;
}
.pain .section-ttl {
		font-size: 40px;
		font-weight: 700;
		text-align: center;
		margin-bottom: 40px;
}
.pain .bg-color-txt {
		margin-top: -18px;
		margin-bottom: 40px;
}
.pain .bg-color-txt span {
		position: relative;
		font-size: 40px;
		font-weight: bold;
		padding: 10px 20px;
		display: inline-block;
		background: #E0EAFE;
		border-radius: 6px;
}
.pain .bg-color-txt span::after {
		position: absolute;
		display: block;
		content: "";
		left: 50%;
		bottom: -18px;
		transform: translateX(-50%);
		width: 0;
		height: 0;
		border-left: 20px solid transparent;
		border-right: 20px solid transparent;
		border-top: 20px solid #E0EAFE;
}
.pain-list {
		position: relative;
		text-align: center;
		width: 530px;
		margin: 0 auto;
		background: url("../img/lp/bg_pain_list.png") bottom center no-repeat;
		padding-bottom: 110px;
}
.pain-list::before {
		display: block;
		position: absolute;
		top: 12px;
		left: -300px;
		content: "";
		height: 278px;
		width: 269px;
		background: url("../img/lp/bg_pain_left.png") no-repeat;
}
.pain-list::after {
		display: block;
		position: absolute;
		top: 12px;
		right: -300px;
		content: "";
		height: 250px;
		width: 270px;
		background: url("../img/lp/bg_pain_right.png") no-repeat;
}
.pain-list li {
		margin-bottom: 44px;
		font-size: 26px;
		position: relative;
		font-weight: 700;
}
.pain-list span {
		display: inline-block;
		position: relative;
		padding: 0 2px;
}
.pain-list li span::after {
		position: absolute;
		bottom: -3px;
		content: "";
		display: block;
		width: 100%;
		height: 10px;
		background: #FFEEB5;
		z-index: -1;
}
/* reasons  */
.reasons {
		background: #D02026;
		padding: 100px 0 0;
}
.reasons .reasons-inner-wrap {
		position: relative;
		top: -148px;
}
.reasons .section-ttl {
		margin-bottom: 40px;
}
.reasons .ttl-inner-txt {
		position: relative;
		font-size: 34px;
		font-weight: 700;
		display: inline-block;
		background: #E0EAFE;
		padding: 10px 30px 20px 30px;
		border-radius: 8px;
}
.reasons .ttl-inner-txt .red {
		font-weight: 700;
		font-size: 58px;
		margin: 0px 5px;
}
.reasons .ttl-inner-txt::after {
		position: absolute;
		display: block;
		content: "";
		left: 50%;
		bottom: -18px;
		transform: translateX(-50%);
		width: 0;
		height: 0;
		border-left: 20px solid transparent;
		border-right: 20px solid transparent;
		border-top: 20px solid #E0EAFE;
}
.reasons .kicker {
		color: #fff;
		font-size: 42px;
		font-weight: 700;
		text-align: center;
		line-height: 1.2;
		height: 279px;
		background: url("../img/lp/bg_reasons_h3.png") no-repeat center center;
		display: flex;
		justify-content: center;
		align-items: center;
		margin: 30px 0 60px;
}
.reasons .reason {
		color: #fff;
		display: flex;
		gap: 20px;
		margin-bottom: 90px;
}
.reason.reason-2 {
		flex-direction: row-reverse;
}
.reason.reason-3 {
		margin-bottom: 0;
}
.num {
		font-family: 'Poppins', sans-serif !important;
		font-size: 64px;
		font-weight: 700;
		margin-bottom: 10px;
}
.reason-ttl {
		color: #1D3D72;
		display: inline-block;
		background: #fff;
		padding: 7px 15px;
		border-radius: 6px;
		font-size: 30px;
		font-weight: 700;
		margin-bottom: 20px;
}
.reasons .reason .txt-area {
		width: 58%;
}
.reason-txt {
		line-height: 1.8;
}
.reasons .reason .img-area {
		width: 42%;
		min-width: 240px;
		padding: 0 20px;
		display: flex;
		justify-content: center;
		align-items: center;
}
.reasons .reason .img-area img {
		max-width: 370px;
}
/* CTA  */
.cta {
		padding: 75px 0;
		background: #FFEEB5;
}
.cta h2 {
		position: relative;
		font-size: 32px;
		text-align: center;
		margin-bottom: 30px;
		display: inline-block;
		left: 50%;
		transform: translate(-50%, 0);
}
.cta h2::before {
		position: absolute;
		top: 5px;
		left: -30px;
		display: block;
		content: "";
		height: 27px;
		border-left: 2px solid #1D3D72;
		transform: rotate(-25deg);
}
.cta h2::after {
		position: absolute;
		top: 5px;
		right: -30px;
		display: block;
		content: "";
		height: 27px;
		border-left: 2px solid #1D3D72;
		transform: rotate(25deg);
}
.btn-area {
		background: rgba(255, 255, 255, 0.5);
		padding: 40px 100px 30px;
		display: flex;
		gap: 30px;
}
.cta .cap {
		display: block;
		font-size: 17px;
		font-weight: normal;
		padding: 5px;
		border: 1px solid #1D3D72;
		border-radius: 20px;
		margin-bottom: 15px;
		text-align: center;
}
.tel-block {
		width: 50%;
}
.contact-block {
		width: 50%;
}
.tel-num {
		display: block;
		font-size: 60px;
		font-weight: 700;
		padding-left: 45px;
		background: url(../img/lp/icon_cta_tel.png) no-repeat left center;
		text-align: center;
		color: #1D3D72;
}
.contact-block .cta-contact {
		background: #D01126;
		color: #fff;
		font-weight: 700;
		align-items: center;
		padding: 30px 60px;
		position: relative;
		border-radius: 50px;
		font-size: 32px;
		display: block;
}
.contact-block .cta-contact::after {
		position: absolute;
		display: flex;
		content: "\203A";
		color: #D01126;
		width: 25px;
		height: 25px;
		background: #fff;
		border-radius: 50%;
		text-align: center;
		top: 50%;
		right: 50px;
		transform: translate(0, -50%);
		align-items: end;
		justify-content: center;
		line-height: 1;
}
/*  case  */
.case {
		padding: 75px 0;
		background: #EAF1FF;
}
.s-txt {
		display: block;
		font-family: 'Poppins', sans-serif !important;
		font-size: 21px;
		color: #D01126;
		text-align: center;
		margin-bottom: 20px;
}
.section-ttl {
		font-size: 38px;
		text-align: center;
		line-height: 1.6;
}
.case .section-ttl {
		padding: 20px 0 60px;
		background: url("../img/lp/bg_case_h2.png") no-repeat right 20px bottom 0;
}
.clinet-area {
		border: 4px solid #D01126;
		border-radius: 8px;
}
.client-info {
		background: #D01126;
		padding: 60px 80px;
		color: #fff;
		display: flex;
		gap: 40px;
}
.client-img {
		width: 40%;
		text-align: center;
}
.client-txt {
		width: 60%;
}
.client-info h3 {
		padding-bottom: 15px;
		font-size: 34px;
		border-bottom: 1px solid;
		margin-bottom: 30px;
}
.jobs {
		display: flex;
		gap: 10px;
		margin-bottom: 25px;
}
.jobs li {
		font-size: 18px;
		color: #1D3D72;
		background: #fff;
		padding: 5px 15px;
		line-height: 1;
		border-radius: 20px;
		font-weight: 700;
}
.client-info .content {
		line-height: 1.8;
}
.result-area {
		padding: 50px 75px;
		background: #fff;
}
.case h4 {
		color: #D01126;
		font-size: 26px;
		text-align: center;
		margin-bottom: 30px;
}
/*  client   */
.client {
		padding: 0 0 75px;
		overflow-x: clip; /* prevent horizontal scrollbar while allowing peek */
}
.client h2 {
		padding: 75px 0;
		background: url("../img/lp/bg_client_h2.png") no-repeat left 200px bottom 0;
}
.thumbs {
		position: relative;
		margin-top: -7px;
}
.thumbs:not(.slick-initialized) {
		display: flex;
		gap: 24px;
}
.thumbs.slick-initialized {
		display: block;
}
.thumbs .slick-slide {
		padding: 0 12px;
		box-sizing: border-box;
}
.thumbs .slick-list {
		margin: 0;
		overflow: visible;
}
.thumbs li {
		text-align: center;
		max-width: none;
		margin: 0;
}
.thumbs img {
		width: auto;
		margin: 0 auto 20px;
		border-radius: 10px;
}
/* slick arrows for thumbs */
.thumbs .slick-prev, .thumbs .slick-next {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		width: 44px;
		height: 44px;
		border-radius: 50%;
		background: #D01126;
		border: 2px solid #D01126;
		color: #D01126;
		display: flex;
		align-items: center;
		justify-content: center;
		z-index: 2;
		cursor: pointer;
}
.thumbs .slick-prev {
		left: 0;
}
.thumbs .slick-next {
		right: 0;
}
.thumbs .slick-prev::before, .thumbs .slick-next::before {
		content: '';
}
.thumbs .slick-prev::after, .thumbs .slick-next::after {
		content: '\2039'; /* ‹ */
		font-size: 24px;
		line-height: 1;
		color: #fff;
}
.thumbs .slick-next::after {
		content: '\203A'; /* › */
}
.thumbs .slick-prev:hover, .thumbs .slick-next:hover {
		background: #ff2e49;
}
.client-name {
		font-weight: 700;
}
/*  flow   */
.flow {
		padding: 75px 0;
		background: #F3F3F3;
}
.flow .section-ttl {
		margin-bottom: 100px;
}
.steps {
		display: flex;
		gap: 40px;
		justify-content: space-between;
}
.steps li {
		position: relative;
		text-align: center;
		padding: 50px 20px 30px;
		border: 4px solid #D01126;
		border-radius: 15px;
		line-height: 1.6;
		font-weight: 700;
}
.steps li::after {
		position: absolute;
		content: "";
		width: 33px;
		height: 29px;
		display: block;
		right: -21%;
		top: 50%;
		transform: translate(0, -50%);
		background: url("../img/lp/bg_step_arrow.png") no-repeat;
}
.steps li:last-child::after {
		display: none;
}
.step-ttl {
		font-size: 26px;
		margin-bottom: 20px;
}
.step-num {
		font-family: 'Poppins', sans-serif !important;
		font-size: 36px;
		color: #fff;
		background: #D01126;
		width: 60px;
		height: 60px;
		line-height: 1;
		display: flex;
		justify-content: center;
		align-items: center;
		border-radius: 50%;
		position: absolute;
		top: 0;
		left: 50%;
		transform: translate(-50%, -50%);
}
/*  FAQ  */
.faq {
		padding: 75px 0;
}
.faq .section-ttl {
		border-bottom: 1px solid #B7C3D8;
		padding-bottom: 50px;
}
.q, .a {
		padding: 30px 50px;
}
.q p {
		position: relative;
		font-size: 24px;
		font-weight: 700;
		padding: 10px 0 10px 90px;
}
.q p::before {
		display: flex;
		font-family: 'Poppins', sans-serif !important;
		content: "Q";
		position: absolute;
		width: 60px;
		height: 60px;
		background: #D01126;
		color: #fff;
		top: 50%;
		left: 0;
		transform: translate(0, -50%);
		font-size: 26px;
		border-radius: 50%;
		justify-content: center;
		align-items: center;
}
.a {
		background: #E0EAFE;
		border-radius: 10px;
}
.a p {
		position: relative;
		padding: 10px 0 10px 90px;
		line-height: 1.6;
}
.a p::before {
		display: flex;
		font-family: 'Poppins', sans-serif !important;
		content: "A";
		position: absolute;
		width: 60px;
		height: 60px;
		background: #fff;
		color: #D01126;
		top: 50%;
		left: 0;
		transform: translate(0, -50%);
		font-size: 26px;
		border-radius: 50%;
		justify-content: center;
		align-items: center;
}
/*  contact   */
#contact {
		background: #FFEEB5;
		padding: 75px 0;
}
#contact .section-ttl {
		margin-bottom: 50px;
}
.contact-form {
		font-weight: 700;
		max-width: 680px;
		margin: 0 auto;
}
.contact-form span.req {
		font-size: 12px;
		display: inline-block;
		padding: 3px 5px;
		background: #D01126;
		color: #fff;
		margin-left: 10px;
}
label {
		display: block;
}

.company-name,
.form-name,
.form-tel,
.form-mail{
		display: block;
		margin: 10px 0 30px;
		width: 100%;
		height: 30px;
}

a.underline {
    text-decoration: underline;
}
/*input:not(.submit):not(.privacy) {
		display: block;
		margin: 10px 0 30px;
		width: 100%;
		height: 30px;
}*/
textarea {
		display: block;
		margin: 10px 0 30px;
		width: 100%;
		height: 150px;
}
.btn.primary {
		background: #D01126;
		color: #fff;
		font-weight: 700;
		display: flex;
		align-items: center;
		padding: 0 100px;
		position: relative;
		border-radius: 60px;
		height: 100px;
		font-size: 32px;
		margin: 0 auto;
}
.btn-contact-wrap {
		position: relative;
		display: inline-block;
		top: 0;
		left: 50%;
		transform: translate(-50%, 0);
}
.btn-contact-wrap::after {
		position: absolute;
		display: flex;
		content: "\203A";
		color: #D01126;
		width: 25px;
		height: 25px;
		background: #fff;
		border-radius: 50%;
		text-align: center;
		top: 50%;
		right: 15px;
		transform: translate(0, -50%);
		align-items: end;
		justify-content: center;
		line-height: 1;
		font-size: 36px;
}
.privacy-wrap {
		padding: 15px 0;
		text-align: center;
}
.consent_small {
		font-size: 14px;
		text-align: center;
		margin-bottom: 40px;
}
.form-content {
		position: relative;
}
.error {
		background: #D01126;
		padding: 3px 4px;
		color: #fff!important;
		display: inline-block;
		position: absolute;
		right: 0;
		top: 0;
}

.mw_wp_form_confirm .form-item-name {
    display: block;
    padding: 10px;
    background: #e0eafe;
}

.mw_wp_form_confirm .form-content p {
    padding: 15px;
}

.mw_wp_form_confirm .privacy-wrap {
    text-align: left;
}
.mw_wp_form_confirm .consent_small {
    display: none;
}

.mw_wp_form_confirm .btn-contact-wrap {
    display: none;
}

.center.btn-contact-wrap-confirm {
    text-align: center;
    padding-top: 40px;
}

input.back {
		width: 25%;
		box-sizing: border-box;
		cursor: pointer;
		height: 80px;
		text-align: center;
		color: #fff;
		font-size: 25px;
		background: #211514;
		border: none;
		margin: 0 auto;
}

button.send{
		width: 25%;
		box-sizing: border-box;
		cursor: pointer;
		height: 80px;
		text-align: center;
		color: #fff;
		font-size: 25px;
		background: #D01126;
		border: none;
		margin: 0 auto;
}

.contact_txt {
		font-size: 21px;
		font-weight: 700;
		text-align: center;
		margin-bottom: 40px;
}

.contact_thanks_txt {
		line-height: 1.5;
}


/*  footer  */
.site-footer .inner {
		padding-bottom: 20px;
}
.f-wrap {
		display: flex;
		padding: 30px 0 0;
		justify-content: space-between;
}
.f-menu ul {
		display: flex;
}
.f-menu ul li a {
		color: #1D3D72;
		padding: 0 15px;
}
.f-menu ul li:first-child a {
		border-right: 1px solid #1D3D72;
}
.f-menu ul li:last-child a {
		padding-right: 0;
}
small {
		font-size: 14px;
		text-align: right;
		display: block;
}
.thumbs .slick-list {
		overflow: visible;
}
/* responsive tuning for hero background/text alignment */
@media (max-width: 1200px) {
		:root {
				--content: 100vw; /* コンテンツ幅 = 画面幅 とみなす */
				--text-left: 40px; /* 左余白を縮める */
				--bg-shift: 0px; /* 原則センター */
		}
		.pain-list::after, .pain-list::before {
				display: none;
		}
}
@media (max-width: 920px) {
		/* header  */
		.site-header {
				background: rgba(255, 255, 255, 1);
		}
		.header-inner {
				padding: 0;
				height: 60px;
		}
		.header-cta {
				display: flex;
				gap: 0;
		}
		.logo {
				display: flex;
				align-items: center;
				justify-content: center;
				width: 40%;
				max-width: 200px;
		}
		.site-header .tel {
				position: relative;
				font-size: 13px;
				color: #fff;
				background: #002469;
				background-image: url("../img/lp/icon_tel_sp.png");
				background-repeat: no-repeat;
				background-size: 14px;
				background-position: top 5px center;
				padding: 25px 20px 10px 10px;
				min-width: 122px;
		}
		.site-header .tel .sub-txt {
				font-size: 12px;
				padding: 0;
				margin: 0;
				border: none;
		}
		.site-header .tel::after {
				position: absolute;
				display: flex;
				content: "\203A";
				color: #fff;
				width: auto;
				height: auto;
				background: none;
				border-radius: none;
				text-align: center;
				right: 2px;
				align-items: center;
				line-height: 1;
				justify-content: center;
				font-size: 24px;
				top: 50%;
				transform: translate(0, -50%);
		}
		.site-header .btn-contact {
				position: relative;
				font-size: 16px;
				border-radius: unset;
				background-image: url("../img/lp/icon_mail_sp.png");
				background-repeat: no-repeat;
				background-size: 20px;
				background-position: top 8px center;
				padding: 25px 15px 5px 10px;
				min-width: 122px;
				justify-content: center;
		}
		.site-header .btn-contact::after {
				position: absolute;
				display: flex;
				content: "\203A";
				color: #fff;
				width: auto;
				height: auto;
				background: none;
				border-radius: none;
				text-align: center;
				right: 2px;
				align-items: center;
				line-height: 1;
				justify-content: center;
				font-size: 24px;
				top: 50%;
				transform: translate(0, -50%);
		}
		.reasons .reason .img-area img {
				max-width: 100%;
		}
}
@media (min-width: 2000px) {
		.fv-wrap {
				background: url("../img/lp/bg_fv.png") no-repeat;
				background-size: cover;
				background-position: calc(50% + var(--bg-shift)) top;
				height: 945px;
		}
		.hero-copy {
				left: 40%;
				transform: translate(-50%, -50%);
				backdrop-filter: blur(12px);
				border-radius: 130px;
				display: flex;
				height: 860px;
				flex-direction: column;
				align-items: center;
				justify-content: center;
				/* padding-right: 830px; */
		}
		.hero-copy::before {
				content: "";
				position: absolute;
				inset: -10px;
				filter: blur(28px);
				transform: scale(0.8);
				z-index: -1;
				background: rgba(255, 255, 255, 0.5);
		}
		.hero-copy::after {
				content: "";
				position: absolute;
				display: block;
				width: 813px;
				height: 860px;
				right: -840px;
				background: url("../img/lp/img_fv.png") no-repeat;
		}
		/*.hero{
		background: url("../img/lp/img_fv.png") no-repeat;
		background-position: right 8% center;
	}*/
}
@media (min-width: 2500px) {
		.hero {
				background-position: right 20% center;
		}
}
@media (min-width: 2600px) {
		.hero {
				background-position: right 28% center;
		}
}
@media (min-width: 1400px) and (max-width: 1550px) {
		:root {
				--text-left: 8%;
		}
}
@media (min-width: 900px) and (max-width: 1400px) {
		:root {
				--text-left: 5%;
		}
}
@media (min-width: 768px) and (max-width: 1070px) {
		.fv-wrap {
				background: url("../img/lp/bg_fv.png") no-repeat;
				background-size: cover;
				background-position: calc(50% + var(--bg-shift)) top;
				height: 945px;
		}
		.hero-copy {
				width: 769px;
				position: absolute;
				top: 50%;
				left: 50%;
				transform: translate(-50%, -50%);
		}
}
@media (min-width: 768px) and (max-width: 1200px) {
		.reasons .reasons-inner-wrap {
				padding: 0 15px;
		}
		.btn-area {
				padding: 20px 15px;
				display: block;
				gap: 0;
		}
		.cta .cap {
				display: block;
				font-size: 14px;
				font-weight: normal;
				padding: 5px;
				border: 1px solid #1D3D72;
				border-radius: 20px;
				margin-bottom: 15px;
				text-align: center;
		}
		.tel-block {
				width: 485px;
				margin: 0 auto 20px;
		}
		.contact-block {
				width: 485px;
				margin: 0 auto;
		}
		.steps {
				display: flex;
				gap: 15px;
				justify-content: center;
		}
		.steps li::after {
				display: none;
		}
		.steps li {
				position: relative;
				text-align: center;
				padding: 50px 10px 30px;
				border: 4px solid #D01126;
				border-radius: 15px;
				line-height: 1.6;
				font-weight: 700;
		}
}
@media (max-width: 1100px) {
		.client h2 {
				background: none;
		}
		.client-name {
				font-size: 16px;
		}
}
@media (max-width: 1000px) {
		.case .section-ttl {
				background-size: 190px;
		}
		.jobs li {
				font-size: 13px;
		}
		.step-ttl {
				font-size: 20px;
		}
		p.step-txt {
				font-size: 14px;
		}
}
@media (max-width: 767px) {
		:root {
				--text-left: 24px; /* スマホでさらに内側へ */
				--bg-shift: 0px; /* スマホはセンター寄せ */
		}
		.logo {
				width: 28%;
				padding-left: 5px;
		}
		/*   fv    */
		.fv-wrap {
				background: url("../img/lp/bg_fv_sp.png") no-repeat center center;
				height: 660px;
				background-size: cover;
		}
		.hero {
				height: auto;
				background: none;
		}
		.main-catch-area {
				padding-bottom: 220px;
				background: url("../img/lp/bg_fv_womeen_sp.png") no-repeat center bottom;
				background-size: 150px;
		}
		h1.eyebrow {
				font-size: 20px;
				padding: 5px;
				text-align: center;
				background-size: 100px;
				background-position: 0px 4px;
				display: inline-block;
				left: 50%;
				transform: translate(-50%, 0);
				position: relative;
				background: none;
				margin-bottom: 10px;
		}
		span.sp-catch-first {
				display: inline-block;
				padding: 50px 0 0 68px;
				background: url(../img/lp/bg_h1.png) no-repeat left -3px top -10px;
				background-size: 94px;
		}
		span.hero-big1 {
				font-size: 29px;
				margin-left: -10px;
		}
		.hero-big2 {
				font-size: 29px;
		}
		.hero-copy {
				width: 100%;
				position: relative;
				top: 0;
				left: 0;
				transform: none;
				padding: 10px;
		}
		.sub-lead {
				background: none;
				font-size: 14px;
				margin-bottom: 15px;
		}
		.cell1 {
				padding-right: 0;
		}
		span.sp-block-txt {
				display: inline-block;
				background: #FFEEB5;
				padding: 5px 15px;
				border-radius: 6px;
				margin: 0 0 7px;
		}
		span.badge {
				font-size: 12px;
				padding: 0px 15px;
		}
		.badges {
				gap: 5px;
				height: auto;
				margin: 0;
				justify-content: center;
		}
		.badge::before, .badge::after {
				height: 47px;
				width: 17px;
				background-size: contain;
		}
		.cta-row .btn-contact {
				height: 45px;
				margin: 0 auto;
				width: 250px;
				font-size: 16px;
				padding: 0;
				text-align: center;
				justify-content: center;
		}
		.cta-row .btn-contact::after {
				position: absolute;
				display: flex;
				content: "\203A";
				color: #D01126;
				width: 15px;
				height: 12px;
				padding-bottom: 3px;
				background: #fff;
				border-radius: 50%;
				text-align: center;
				right: 10px;
				align-items: center;
				line-height: 0;
				justify-content: center;
				font-size: 20px;
		}
		/*  pain  */
		.pain {
				padding: 40px 10px;
		}
		.pain .section-ttl {
				font-size: 22px;
				margin-bottom: 20px;
		}
		.pain-img {
				width: 80%;
				margin: 0 auto;
		}
		.pain .bg-color-txt span {
				font-size: 18px;
		}
		.pain-list {
				width: 100%;
				margin: 0 auto;
				background: url(../img/lp/bg_pain_list.png) bottom 40px center no-repeat;
				padding-bottom: 110px;
				background-size: 120px;
		}
		.pain-list li {
				margin-bottom: 20px;
				font-size: 16px;
				position: relative;
				font-weight: 700;
		}
		/*  reasons  */
		.reasons {
				padding: 0px 10px 0px;
		}
		.reasons .ttl-inner-txt {
				font-size: 19px;
				font-weight: 700;
				padding: 3px 15px 3px 15px;
		}
		.reasons .ttl-inner-txt .red {
				font-weight: 700;
				font-size: 32px;
				margin: 0px 5px;
		}
		.reason-img {
				width: 60%;
				margin: 0 auto;
		}
		.reasons .kicker {
				font-size: 18px;
				height: 116px;
				margin: 20px 0 30px;
				background-size: contain;
		}
		.num {
				font-size: 38px;
				text-align: center;
		}
		.reasons .reason {
				display: block;
				gap: 0;
				margin-bottom: 40px;
		}
		.reasons .reasons-inner-wrap {
				top: -40px;
		}
		.reasons .reason .txt-area {
				width: 100%;
		}
		.reason-ttl {
				font-size: 20px;
				position: relative;
				left: 50%;
				transform: translate(-50%, 0px);
		}
		.reason-txt {
				line-height: 1.8;
				font-size: 16px;
				margin-bottom: 30px;
		}
		.reasons .reason .img-area {
				width: 70%;
				margin: 0 auto;
		}
		.reason.reason-3 {
				margin-bottom: 0;
		}
		/*  cta  */
		.cta {
				padding: 50px 10px;
		}
		.cta h2 {
				font-size: 22px;
				margin-bottom: 15px;
		}
		.cta h2::before {
				top: 5px;
				left: -12px;
				height: 20px;
				transform: rotate(-25deg);
		}
		.cta h2::after {
				top: 5px;
				right: -12px;
				height: 20px;
				transform: rotate(25deg);
		}
		.btn-area {
				padding: 40px 10px;
				display: block;
				gap: 0px;
		}
		.tel-block {
				width: 100%;
		}
		.cta .cap {
				font-weight: 700;
				display: block;
				font-size: 12px;
				/* font-weight: normal; */
				padding: 5px;
				border: none;
				border-radius: unset;
				margin-bottom: 0px;
				text-align: center;
				color: #fff;
		}
		.tel-block {
				width: 335px;
				background: #1D3D72;
				border-radius: 40px;
				margin: 0 auto;
				padding: 5px 0;
				position: relative;
				margin-bottom: 15px;
		}
		.tel-block::after {
				font-size: 35px;
				position: absolute;
				display: flex;
				content: "\203A";
				color: #1D3D72;
				width: 25px;
				height: 25px;
				background: #fff;
				border-radius: 50%;
				text-align: center;
				top: 50%;
				right: 11px;
				transform: translate(0, -50%);
				align-items: end;
				justify-content: center;
				line-height: 1;
		}
		.tel-num {
				display: block;
				font-size: 31px;
				font-weight: 700;
				padding-left: 0px;
				background: url(../img/lp/icon_tel_sp.png) no-repeat left 35px center;
				background-size: 24px;
				text-align: center;
				color: #fff;
				padding: 5px 0px 5px 20px;
		}
		.contact-block {
				width: 335px;
				border-radius: 40px;
				margin: 0 auto;
				padding: 5px 0;
				position: relative;
				background: #D01126;
		}
		.contact-block .cta-contact {
				color: #fff;
				height: 63px;
				font-weight: 700;
				align-items: center;
				padding: 0;
				position: relative;
				border-radius: 50px;
				font-size: 20px;
				display: flex;
				justify-content: center;
				background: url(../img/lp/icon_mail_sp.png) no-repeat left 35px center;
				background-size: 29px;
		}
		.contact-block .cta-contact::after {
				font-size: 35px;
				position: absolute;
				display: flex;
				content: "\203A";
				width: 25px;
				height: 25px;
				background: #fff;
				border-radius: 50%;
				text-align: center;
				top: 50%;
				right: 11px;
				transform: translate(0, -50%);
				align-items: end;
				justify-content: center;
				line-height: 1;
		}
		/*  case   */
		.case {
				padding: 50px 10px;
				background: #EAF1FF;
		}
		.s-txt {
				font-size: 16px;
				margin-bottom: 0px;
		}
		.section-ttl {
				font-size: 22px;
		}
		.case .section-ttl {
				padding: 0 0 115px;
				background: url("../img/lp/bg_case_h2.png") no-repeat center bottom;
				background-size: 103px;
		}
		.client-info {
				padding: 30px 20px;
				color: #fff;
				display: flex;
				gap: 0;
				flex-direction: column-reverse;
		}
		.client-img {
				width: 100%;
				text-align: center;
		}
		.client-img p {
				width: 80%;
				margin: 0 auto;
		}
		.client-txt {
				width: 100%;
				margin-bottom: 30px;
		}
		.client-info h3 {
				padding-bottom: 15px;
				font-size: 20px;
				margin-bottom: 15px;
		}
		.jobs {
				gap: 5px;
		}
		.jobs li {
				font-size: 13px;
				padding: 5px 5px;
		}
		.result-area {
				padding: 30px 10px;
		}
		.case h4 {
				font-size: 18px;
				margin-bottom: 30px;
				line-height: 1.6;
		}
		/*  client   */
		.client {
				padding: 50px 10px;
		}
		.client h2 {
				padding: 0;
				background: none;
				margin-bottom: 30px;
		}
		/*  flow  */
		.flow {
				padding: 50px 10px;
		}
		.flow .section-ttl {
				margin-bottom: 40px;
		}
		.steps {
				display: block;
				gap: 0;
		}
		.steps li {
				position: relative;
				text-align: left;
				padding: 15px 10px 10px;
				border: 4px solid #D01126;
				border-radius: 15px;
				line-height: 1.6;
				font-weight: 700;
				width: 355px;
				margin: 0 auto 50px;
				font-size: 16px;
		}
		.steps li.step-last {
				margin-bottom: 0;
		}
		.step-num {
				font-family: 'Poppins', sans-serif !important;
				font-size: 21px;
				color: #fff;
				background: #D01126;
				width: 40px;
				height: 40px;
				line-height: 1;
				display: flex;
				justify-content: center;
				align-items: center;
				border-radius: 50%;
				position: absolute;
				top: -24px;
				left: 50px;
				transform: none;
		}
		.step-num::after {
				position: absolute;
				display: block;
				content: "";
				left: 50%;
				bottom: -7px;
				transform: translateX(-50%);
				width: 0;
				height: 0;
				border-left: 5px solid transparent;
				border-right: 5px solid transparent;
				border-top: 10px solid #D01126;
		}
		.step-box-inner {
				display: flex;
				gap: 15px;
				align-items: center;
		}
		p.step-sp-img.sp {
				width: 118px;
		}
		.step-ttl {
				font-size: 18px;
				margin-bottom: 15px;
		}
		.steps li::after {
				position: absolute;
				content: "";
				width: 33px;
				height: 29px;
				display: block;
				right: unset;
				top: unset;
				bottom: -40px;
				left: 50%;
				transform: translate(-50%, 0);
				transform: rotate(90deg) translate(0, 50%);
				background: url("../img/lp/bg_step_arrow.png") no-repeat;
		}
		/*  FAQ   */
		.faq {
				padding: 50px 10px;
		}
		.faq .section-ttl {
				padding-bottom: 20px;
		}
		.qa {
				margin-bottom: 20px;
		}
		.q, .a {
				padding: 20px 10px;
		}
		.q p {
				font-size: 18px;
				padding: 10px 0 10px 50px;
		}
		.q p::before, .a p::before {
				top: 20px;
				width: 45px;
				height: 45px;
				font-size: 18px;
		}
		.a p {
				position: relative;
				padding: 0 0 0 50px;
				line-height: 1.6;
				font-size: 16px;
		}
		/*  contact   */
		#contact {
				background: #FFEEB5;
				padding: 50px 10px;
		}
		.btn.primary {
				background: #D01126;
				color: #fff;
				font-weight: 700;
				display: flex;
				align-items: center;
				padding: 0;
				position: relative;
				border-radius: 60px;
				height: 45px;
				font-size: 16px;
				width: 250px;
				margin: 0 auto;
				justify-content: center;
		}
		.btn.primary::after {
				font-size: 20px;
				position: absolute;
				display: flex;
				color: #D01126;
				content: "\203A";
				width: 15px;
				height: 15px;
				background: #fff;
				border-radius: 50%;
				text-align: center;
				top: 50%;
				right: 11px;
				transform: translate(0, -50%);
				align-items: end;
				justify-content: center;
				line-height: 1;
		}
		#contact .section-ttl {
				margin-bottom: 30px;
		}
		label {
				display: block;
				font-size: 16px;
		}
		input:not(.submit):not(.privacy) {
				display: block;
				margin: 10px 0 20px;
				width: 99%;
		}
		textarea {
				display: block;
				margin: 10px 0 30px;
				width: 99%;
				height: 100px;
		}
		.btn-contact-wrap::after {
				position: absolute;
				display: flex;
				content: "\203A";
				color: #D01126;
				width: 15px;
				height: 15px;
				background: #fff;
				border-radius: 50%;
				text-align: center;
				top: 50%;
				right: 15px;
				transform: translate(0, -50%);
				align-items: end;
				justify-content: center;
				line-height: 1;
				font-size: 22px;
		}
		/*  footer  */
		.f-wrap {
				display: block;
				padding: 20px 0 0;
				text-align: center;
		}
		.f-logo {
				max-width: 210px;
				margin: 0 auto 30px;
		}
		.f-menu ul {
				display: flex;
				justify-content: center;
				margin-bottom: 20px;
		}
		.f-menu ul li a {
				font-size: 12px;
		}
		small {
				font-size: 12px;
				text-align: center;
				display: block;
		}
}