@charset "utf-8";

@font-face {
	font-family: 'D-DIN-PRO';
	src: url('/font/d-din-pro.woff') format('woff');
}

.din-pro {
	font-family: 'D-DIN-PRO', sans-serif;
}

/*-------
TOP用スタイル
-------------------------------------------*/
.ttl-h1 {
	font-weight: 700;
	margin-bottom: 16px;
}

.row {
	max-width: 1075px;
}

.ttl-h1 .ttl-vmc {
	font-size: 56px;
	line-height: 1;
}

h2.ttl-h2 {
	margin-bottom: 40px;
}

.ttl-h2 {
	font-weight: 700;
	font-size: 2rem;
	text-align: center;
}

.ttl-h2 .ttl-h2-small-text {
	font-size: 24px;
}

.ttl-h2-green {
	color: #009080;
}

.ttl-h2-white {
	color: #fff;
}

.bg-green {
	background: linear-gradient(113.84deg, #33A699 -0.01%, #009080 99.99%);
}

.bg-gray {
	background: #f6f6f6;
}

.ttl-h2-green-background {
	position: relative;
	text-shadow:
		2px 2px 0 #fff, -2px -2px 0 #fff,
		-2px 2px 0 #fff, 2px -2px 0 #fff,
		0px 2px 0 #fff, 2px 0px 0 #fff,
		0px -2px 0 #fff, -2px 0px 0 #fff;
}

.ttl-h2-green-background::before {
	content: "";
	position: absolute;
	background-color: #E5F4F2;
	height: 14px;
	width: 100%;
	left: 0;
	bottom: 0;
	z-index: -1;
}

.ttl-h3 {
	font-weight: 700;
	font-size: 1.5rem;
	margin: 0;
}

.ttl-h3 small {
	font-size: 0.65em;
	color: #435868;
}

.ttl-h3-white {
	color: #fff;
}

.ttl-h4 {
	font-size: 1rem;
	font-weight: 700;
}

.sp {
	display: none;
}

.pc {
	display: block;
}

table {
	font-size: 0.875rem;
}

.section-padding-top-large {
	padding-top: 80px;
}

.section-padding-bottom-large {
	padding-bottom: 80px;
}

.section-padding-top-medium {
	padding-top: 64px;
}

.section-padding-bottom-small {
	padding-bottom: 56px;
}

.section-padding-top-small {
	padding-top: 56px;
}

.fw-bold {
	font-weight: 700;
}

@media screen and (max-width:768px) {
	.sp {
		display: block
	}

	.pc {
		display: none
	}

	.ttl-h3 {
		font-size: 1.25rem;
	}

	h2.ttl-h2 {
		margin-bottom: 24px;
	}

	.ttl-h2 .ttl-h2-small-text {
		font-size: 1.25rem;
	}

	p {
		font-size: 14px;
	}

	.ttl-h4 {
		font-size: 14px;
	}

	.ttl-h2-green-background::before {
		width: 104%;
		left: -2%;
	}

	.ttl-h2-green-background-lower::before {
		left: -4%;
		width: 96%;
	}

	table {
		font-size: 0.75rem;
	}

	.table-wrap {
		overflow-x: scroll;
	}

	.price-table {
		min-width: 450px;
	}

	.section-padding-top-large {
		padding-top: 40px;
	}

	.section-padding-bottom-large {
		padding-bottom: 40px;
	}

	.section-padding-top-medium {
		padding-top: 32px;
	}

	.section-padding-bottom-small {
		padding-bottom: 24px;
	}

	.section-padding-top-small {
		padding-top: 24px;
	}
}

@media screen and (max-width: 768px) {
	.apple-device .ttl-h2-green-background::before {
		bottom: -6px;
	}

	.apple-device .ttl-h2.sp {
		font-size: 1.4rem;
	}

}

/*-------
button
-------------------------------------------*/

.lp-button {
	display: block;
	border-radius: 4px;
	text-align: center;
	color: white;
	width: 300px;
	font-weight: 700;
	font-size: 18px;
	padding-top: 16px;
	padding-bottom: 16px;
	line-height: 1;
	margin-bottom: 0;
}

.lp-button:hover {
	position: relative;
	top: 2px;
	color: #fff;
	text-decoration: none;
}

.lp-button-blue {
	background-color: #005BAC;
	box-shadow: 0px 4px 0px 0px #00335B;
}

.lp-button-blue:hover {
	background-color: #004D91;
	box-shadow: 0px 2px 0px 0px #00233E;
}

.lp-button-red {
	background-color: #F0242C;
	box-shadow: 0px 4px 0px 0px #AA161B;
}

.lp-button-red:hover {
	background-color: #BF1D23;
	box-shadow: 0px 2px 0px 0px #7C1114;
}

.lp-button-small-text {
	font-size: 18px;
}

@media screen and (max-width: 39.9375em) {
	.ttl-h1 {
		font-size: 24px;
		margin-bottom: 16px;
		text-align: center;
		margin-top: 16px;
	}

	.ttl-h1 img {
		width: 70px;
	}

	.ttl-h2 {
		font-size: 1.5rem;
	}

	.lp-button {
		padding-top: 12px;
		padding-bottom: 12px;
		font-size: 1rem;
	}
}

/*-------
kv
-------------------------------------------*/
.kv-button-wrap {
	flex-wrap: wrap;
	display: flex;
	gap: 24px;
}

.kv {
	position: relative;
	background: url(/service/vmc/img/bg_title.jpg) no-repeat 100% 50%;
	background-size: cover;
	height: 400px;
	color: #00335B;
}

.kv .kv-lead {
	font-size: 24px;
	display: inline-block;
	color: #001D1A;
	font-weight: 700;
	margin-bottom: 8px;
}

.kv-catch {
	font-size: 20px;
	color: #001D1A;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 32px;
}

.kv h2 {
	margin-bottom: 0;
	color: #fff;
	font-size: 3.8rem;
	line-height: 1.2;
	font-weight: bold;
	text-shadow: -8.7px 5px 30px rgba(0, 0, 0, 0.3);
}

.kv .more {
	display: block;
	padding: .85rem 0;
	background: url(/img/icon_arrow.png) #fff no-repeat 97% 50%;
	border-radius: 4px;
	font-weight: bold;
}

.kv .more:hover {
	text-decoration: none;
	background-color: rgba(255, 255, 255, .9)
}

.kv .border {
	padding: .8rem 1em;
	border: 1px solid #fff;
	font-size: 1.375rem;
	border-radius: 5px;
}

.kv>div {
	height: 100%;
}

.kv .row {
	height: 100%;
	padding-top: 100px;
}

@media screen and (max-width: 980px) {
	.kv>div {
		background-color: rgba(255, 255, 255, .3);
	}
}

@media screen and (min-width: 40em) and (max-width: 800px) {}

@media screen and (max-width: 39.9375em) {
	.kv {
		background: url(/service/vmc/img/bg_title_sp.jpg) no-repeat;
		height: 525px;
		background-size: cover;
	}

	.kv .row {
		padding-top: 110px;
	}

	.kv-button-wrap {
		justify-content: center;
		gap: 16px;
		margin-bottom: 40px;
	}

	.kv .columns {
		text-align: center;
	}

	.kv .kv-lead {
		letter-spacing: -0.2px;
		font-size: 20px;
		margin-top: 16px;
		margin-bottom: 24px;
		display: inline;
		text-align: center;
	}

	.ttl-h1 .ttl-vmc {
		font-size: 40px;
	}
}

/*-------
VMC (企業ロゴ所有証明書) の役割
-------------------------------------------*/
.section-vmc-role-lead {
	font-weight: 700;
	font-size: 20px;
	color: #435868;
	text-align: center;
	margin-bottom: 8px;
}

.section-vmc-role-lead {}

.vmc-role-box-wrap {
	display: flex;
	gap: 40px;
	max-width: 800px;
	margin: 0 auto;
}

.vmc-role-box {
	border: 2px solid #DCE9F5;
	border-radius: 8px;
	padding: 24px;
	width: 50%;
}

.vmc-role-box .ttl-h3 {
	margin-bottom: 8px;
}

.vmc-role-box img {
	margin-bottom: 8px;
}

.vmc-role-box p {
	margin-bottom: 0;
}

@media screen and (max-width: 768px) {
	.vmc-role-box-wrap {
		flex-direction: column;
		align-items: center;
	}

	.vmc-role-box {
		width: 100%;
	}

}

/*-------
VMC (企業ロゴ所有証明書) とは
-------------------------------------------*/
.section-about-vmc {
	background: linear-gradient(113.84deg, #478CBA -0.01%, #196FA9 99.99%);
}

.section-about-vmc .ttl-h2 {
	margin-bottom: 24px;
}


.section-about-vmc .columns {
	background-color: #fff;
	padding: 40px
}

.section-about-vmc h3 {
	font-size: 24px;
	font-weight: 700;
	padding-top: 16px;
	padding-bottom: 16px;
	display: block;
	border-top: 2px solid #E0E0E0;
	border-bottom: 2px solid #E0E0E0;
	text-align: center;
	margin-top: 48px;
	margin-bottom: 48px;
}

.about-vmc-img-wrap {
	display: flex;
	width: 100%;
	gap: 40px;
	align-items: center;
	justify-content: center;
}

.about-vmc-img-wrap img {
	max-width: 370px;
}

.about-vmc-img-wrap .triangle {
	width: 35px;
	height: 68px;
	background: linear-gradient(90deg, #D1E2EE 0%, #75A9CB 100%);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	display: block;
}

@media screen and (max-width: 950px) {
	.about-vmc-img-wrap {
		flex-direction: column;
		align-items: center;
		gap: 20px
	}

	.about-vmc-img-wrap .triangle {
		transform: rotate(90deg);
	}

	.about-vmc-img-wrap img {
		max-width: 100%;
	}
}

/*-------
VMC導入 4つのメリット
-------------------------------------------*/
.section-merit h3 {
	margin-bottom: 8px;
}

.merit-box-wrap {
	display: flex;
	flex-wrap: wrap;
	gap: 40px;
	margin: 0 auto;
	margin-bottom: 40px;
}

.merit-box {
	width: calc(50% - 20px);
	background: #F1F7FA;
	padding: 40px;
	border-radius: 8px;
	display: flex;
	flex-direction: column;
	justify-content: space-around;

}

.merit-box p {
	margin-bottom: 0;
}

.merit-num {
	font-size: 24px;
	background-color: #196FA9;
	border-radius: 50%;
	display: flex;
	color: #fff;
	font-weight: 700;
	width: 40px;
	height: 40px;
	align-items: center;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 8px;
}

.merit-box-img {
	margin-top: 24px;
}

.merit-catch {
	font-size: 24px;
	margin-bottom: 0;
}

@media screen and (max-width: 768px) {
	.merit-box {
		width: 100%;
		padding: 24px;
	}

	.merit-box-wrap {
		flex-direction: column;
		align-items: center;
	}

	.merit-catch {
		font-size: 16px;
	}
}

/*-------
料金
-------------------------------------------*/
.section-price {
	background:
		linear-gradient(0deg, rgba(0, 154, 243, 0.05), rgba(0, 154, 243, 0.05)),
		linear-gradient(0deg, #FFFFFF, #FFFFFF);
}

.price-table {
	margin-bottom: 8px;
}

.price-table th,
.price-table td {
	border: 1px solid #E0E0E0
}

.price-table th {
	background-color: #435868;
	color: #fff;
}

table.price-table tbody tr:nth-child(even) {
	background-color: #fff;
}

.price-table tbody td {
	background-color: #fff;
	font-size: 14px;

}

.price-table tbody td:first-child {
	background: #4358681A;
}

.option-tag {
	font-size: 12px;
	display: inline-block;
	font-weight: 700;
	background-color: #435868;
	border-radius: 4px;
	color: #fff;
	padding-right: 4px;
	padding-left: 4px;
	margin-right: 8px;
}

.section-price .lp-button {
	margin: 0 auto;
}


.section-price .note {
	margin-bottom: 40px;
}

/*-------
対応メーラー
-------------------------------------------*/
.section-supported-mailer .columns>div {
	max-width: 620px;
	margin: 0 auto;
}

.supported-mailer-list {
	display: flex;
	gap: 40px;
	justify-content: space-between;
}

.supported-mailer-list-item {
	display: block;
	padding-top: 16px;
	padding-bottom: 16px;
	border: 2px solid #E0E0E0;
	background: linear-gradient(0deg, rgba(67, 88, 104, 0.05), rgba(67, 88, 104, 0.05)),
		linear-gradient(0deg, #FFFFFF, #FFFFFF);
	line-height: 1;
	width: 280px;
	font-weight: 700;
	border-radius: 8px;
	text-align: center;
}

.note {
	font-size: 14px;
	margin-bottom: 0;
}

/*-------
ご利用までの流れ
-------------------------------------------*/
.section-flow .ttl-h3 {
	font-size: 20px;
}

.flow-box-wrap {
	display: flex;
	gap: 32px;
	margin-bottom: 24px;
}

.flow-box {
	border: 2px solid #E0E0E0;
	border-radius: 8px;
	position: relative;

}

.flow-box::after {
	width: 20px;
	height: 40px;
	background: linear-gradient(90deg, #D1E2EE 0%, #75A9CB 100%);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
	display: block;
	content: "";
	position: absolute;
	right: -28px;
	transform: translateY(-50%);
	top: 38%;
}

.flow-box:last-child::after {
	display: none;
}

.flow-box>div:first-child {
	text-align: center;
	padding: 12px 24px;
}

.flow-box-customer {
	width: 320px;

}

.flow-box-customer>div:first-child {
	background: #196FA9;
	color: #fff;
	border-top-left-radius: 6px;
	border-top-right-radius: 6px;
}

.flow-box-our-company {
	width: 154px;

}

.flow-box-our-company>div:first-child {
	background: #4358680D;
}

.flow-box-tag {
	padding: 4px 8px;
	display: inline-block;
	border-radius: 4px;
	font-weight: 700;
	font-size: 14px;
	margin-top: 2px;
	margin-bottom: 2px;
}

.flow-box-customer .flow-box-tag {
	color: #196FA9;
	background-color: #fff;

}

.flow-box-our-company .flow-box-tag {
	color: #fff;
	background-color: #435868;
}

.flow-box-lower {
	padding: 16px;
}

.preparation {
	display: flex;
	background-color: #4358680D;
	padding: 24px;
	justify-content: space-around;
	border-radius: 8px;
}

.preparation>div {
	display: flex;
	align-items: center;
}

.preparation ul>li:last-child {
	/* display: flex; */
	/* flex-wrap: wrap; */
}

.preparation-left {
	font-size: 20px;
	gap: 8px;
}

.preparation-list-wrap ul {
	margin-bottom: 0;
}

@media screen and (max-width: 950px) {
	.flow-box-wrap {
		flex-direction: column;
		align-items: center;
	}

	.flow-box {
		width: 100%;
	}

	.flow-box::after {
		top: inherit;
		bottom: -50px;
		transform: rotate(90deg) translateX(-50%);
		right: 49%;
	}

}

@media screen and (max-width: 768px) {
	.preparation {
		flex-direction: column;
		align-items: center;
		gap: 16px;
	}

	.preparation-list-wrap {
		flex-wrap: wrap;
	}
}

.contact {
	background-color: #D1E2EE;
}

.contact .lp-button {
	margin: 0 auto;
}

/*-------
banner
-------------------------------------------*/
.banner-area {
	padding-top: 56px;
}

.banner-area a:hover {
	opacity: 0.8;
}

/*-------
Support Section
-------------------------------------------*/
.support-section {
	background-color: #f5f5f5;
	padding: 56px 0;
}

.support-section .support-flex-container {
	display: flex;
	gap: 32px;
	align-items: center;
	justify-content: center;
	width: 100%;
}

.support-section .support-content {
	max-width: 876px;
	color: #435767;
	/* width: 100%; */
}

.support-section h2 {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: bold;
	font-size: 32px;
	line-height: 1.4;
	letter-spacing: 1.28px;
	margin: 0 0 16px 0;
}

.support-section p {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: normal;
	font-size: 16px;
	line-height: 1.8;
	letter-spacing: 0.64px;
	margin: 0;
}

.support-section .support-button {
	margin-top: 32px;
}

.lp-button-support {
	background-color: #186ea8;
	box-shadow: 0px 4px 0px 0px #0a2c44;
	font-size: 16px;
	width: auto;
	white-space: nowrap;
	padding-left: 24px;
	padding-right: 24px;
	display: inline-block;
}

.lp-button-support:hover {
	background-color: #155a93;
	box-shadow: 0px 2px 0px 0px #0a2c44;
}

.support-section .support-image {
	flex-shrink: 0;
}

.support-section .support-image img {
	width: 291px;
	height: 242px;
	object-fit: cover;
}

@media screen and (max-width: 950px) {
	.support-section .support-flex-container {
		flex-direction: column;
		text-align: center;
	}

	.support-section .support-image img {
		max-width: 100%;
		height: auto;
	}
}

@media screen and (max-width: 768px) {
	.support-section h2 {
		font-size: 24px;
	}

	.support-section p {
		font-size: 14px;
	}

	.lp-button-support {
		white-space: normal;
		width: 100%;
		max-width: 400px;
	}
}