/* :: 1.0 Import Fonts */
@import url("https://fonts.googleapis.com/css?family=Archivo+Narrow:400,400i,500,500i,600,600i,700,700i");
@import url("https://use.fontawesome.com/releases/v6.6.0/css/all.css");

/*--------------------------------------------------------------
# General
--------------------------------------------------------------*/
body {
	font-family: "游ゴシック体", "YuGothic", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
	color: #222222;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	letter-spacing: 1px;
	color: #111111;
}

ul,
ol {
	list-style: none;
	padding: 0;
	margin: 0;
	margin-top: 0px;
}

.mt0 {
	margin-top: 0px;
}

.mt5 {
	margin-top: 5px;
}

.mt10 {
	margin-top: 10px;
}

.mt20 {
	margin-top: 20px;
}

.mt30 {
	margin-top: 30px;
}

.mt50 {
	margin-top: 50px;
}

.mt60 {
	margin-top: 60px;
}

.mt80 {
	margin-top: 80px;
}

.mt100 {
	margin-top: 100px;
}

.mt130 {
	margin-top: 130px;
}

.mt150 {
	margin-top: 150px;
}

.mb0 {
	margin-bottom: 0px;
}

.mb5 {
	margin-bottom: 5px;
}

.mb10 {
	margin-bottom: 10px;
}

.mb20 {
	margin-bottom: 20px;
}

.mb30 {
	margin-bottom: 30px;
}

.mb50 {
	margin-bottom: 50px;
}

.mb70 {
	margin-bottom: 70px;
}

.mb100 {
	margin-bottom: 100px;
}

.mt-10 {
	margin-top: -10px !important;
}

.mt-20 {
	margin-top: -20px !important;
}

.mt-30 {
	margin-top: -30px !important;
}

.mt-50 {
	margin-top: -50px !important;
}

.pt-30 {
	padding: 30px !important;
}

.img-fluid-2 {
	height: auto;
	margin: 0 auto;
}

.img-fluid-3 {
	max-width: 100%;
	height: auto;
	margin: 0 auto;
	image-rendering: -webkit-optimize-contrast;
	border-radius: 3px;
	padding: 5px 25px;
}

.img-fluid-4 {
	max-width: 100%;
	height: auto;
	margin: 0 auto;
	image-rendering: pixelated;
}

・white {
	color: #ffffff !important;
}

.black {
	color: #000 !important;
}

.red {
	color: #F00 !important;
}

.red2 {
	color: #F03 !important;
}

.blue {
	color: #00F !important;
}

.blue2 {
	color: #0080FF !important;
}

.green {
	color: #060 !important;
}

.green2 {
	color: #0E0 !important;
}

.orange {
	color: #FF8000 !important;
}

.orange2 {
	color: #f38f2c !important;
}

.yellow {
	color: #FF0 !important;
}

.yellow2 {
	color: #f1f40e !important;
}

.purple {
	color: #8000FF !important;
}

.purple2 {
	color: #C613EC !important;
}

.gray {
	color: #808080 !important;
}

.gray2 {
	color: #C0C0C0 !important;
}

.text-left {
	text-align: left !important;
}

.text-right {
	text-align: right !important;
}

.block3 {
	padding: 5px 15px;
	margin: 0 0 20px;
	font-size: 16px;
	font-weight: 600;
	border-left: 5px solid #62cfd0;
}

ol.style-1 {
	counter-reset: list;
	list-style-type: none;
	padding: 0;
}

ol.style-1 li {
	position: relative;
	padding: 0 0 0 20px;
	margin: 7px 0 7px 0px;
	font-weight: 500;
	font-size: 16px;
	line-height: 18px;
}

ol.style-1 li:before {
	counter-increment: list;
	content: "";
	display: block;
	position: absolute;
	left: 0px;
	height: 10px;
	width: 10px;
	border-radius: 50%;
	background: #ffc680;
	top: 50%;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

ol.style-2 {
	counter-reset: list;
	list-style-type: none;
	padding: 0;
}

ol.style-2 li {
	position: relative;
	padding: 0 0 0 20px;
	margin: 20px 0 7px -30px;
	font-weight: bold;
	font-size: 17px;
	line-height: 24px;
	border-bottom: dashed 1px #F6A38B;
}

ol.style-2 li:before {
	counter-increment: list;
	content: "";
	display: block;
	position: absolute;
	height: 10px;
	width: 10px;
	border-radius: 5%;
	background: #f82250;
	left: 0px;
	top: 12px;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

ol.style-3 {
	font-size: 18px;
	font-weight: 600;
	text-align: center;
}

ol.style-3 li {
	display: inline;
}

ol.style-3 i {
	color: #f82250;
	margin-right: 5px;
}

.list_ori-1 {
	list-style: none;
	/* デフォルトのアイコンを消す */
	margin: 0;
	/* デフォルト指定上書き */
	padding: 0;
	/* デフォルト指定上書き */
	counter-reset: li_count;
	/* カウンタをセット */
}

.list_color-1 {
	padding: 10px;
	/* 余白指定 */
	margin-bottom: 5px;
	/* 要素と要素の間指定 */
	font-size: 20px;
	/* 文字サイズ指定 */
}

.list_color-1:before {
	counter-increment: li_count;
	/* カウンタの値を計算していく */
	content: counter(li_count)".";
	/* 数字出力 */
	color: #F44336;
	/* 文字色指定 */
	margin-right: 5px;
	/* 余白指定 */
}

ol.style-4 {
	counter-reset: list;
	list-style-type: none;
	padding: 0;
}

ol.style-4 li {
	position: relative;
	padding: 0 0 0 20px;
	margin: 7px 0 7px 0px;
	font-weight: 500;
	font-size: 16px;
	line-height: 26px;
	/*  
  border-bottom: dashed 1px #F6A38B;
*/
}

ol.style-4 li:before {
	counter-increment: list;
	content: "";
	display: block;
	position: absolute;
	left: 0px;
	height: 10px;
	width: 10px;
	border-radius: 50%;
	background: #585858;
	top: 50%;
	-moz-transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	-o-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
}

/*--------------------------------------------------------------
# button
--------------------------------------------------------------*/

.btn-2 {
	display: inline-block;
	font-size: 20px;
	font-weight: 400;
	line-height: 1.5;
	color: #212529;
	text-align: center;
	text-decoration: none;
	vertical-align: middle;
	cursor: pointer;
	-webkit-user-select: none;
	-moz-user-select: none;
	user-select: none;
	background-color: transparent;
	border: 1px solid transparent;
	padding: 0.375rem 0.75rem;
	font-size: 1rem;
	border-radius: 0.25rem;
	transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out, box-shadow .15s ease-in-out;
	width: 220px;
}

.btn-learn-more {
	font-weight: 600;
	font-size: 15px;
	letter-spacing: 1px;
	display: inline-block;
	padding: 14px 70px;
	border-radius: 3px;
	transition: 0.3s;
	line-height: 1;
	color: #000;
	background: #fff;
	-webkit-animation-delay: 0.8s;
	animation-delay: 0.8s;
	border: 2px solid #ffaa0f;
	box-shadow: 0 2px 15px 0 rgba(185, 57, 93, 0.2);
}

.btn-learn-more:hover {
	background: #fff;
	color: #ff9a03;
	text-decoration: none;
	box-shadow: 0 2px 15px 0 rgba(255, 147, 32, 0.2);
}

.btn-learn-more i {
	font-weight: 600;
	font-size: larger;
	vertical-align: -2px;
	padding-left: 15px;
}

.btn-ori2 {
	color: #F73F52;
	transition: all 0.5s;
	-webkit-transition: all 0.5s;
	-o-transition: all 0.5s;
	-moz-transition: all 0.5s;
	border: 2px solid;
	position: relative;
	overflow: hidden;
	z-index: 2;
	margin: 3px;
	font-weight: 600;
	padding: 10px 10px;
}

.btn-ori2:hover {
	background: #ffffff;
	color: #F73F52 !important;
	border: 2px solid #F73F52 !important;
	box-shadow: 0 2px 15px 0 rgba(255, 147, 32, 0.2);
}

.btn-ori3 {
	color: #F73F52;
	transition: all 0.5s;
	-webkit-transition: all 0.5s;
	-o-transition: all 0.5s;
	-moz-transition: all 0.5s;
	border: 2px solid;
	position: relative;
	overflow: hidden;
	z-index: 2;
	margin: 3px;
	font-size: 16px;
	font-weight: 600;
	padding: 10px 20px;
}

.btn-ori3:hover {
	background: #ffffff;
	color: #F73F52 !important;
	border: 2px solid #F73F52 !important;
	box-shadow: 0 2px 15px 0 rgba(255, 147, 32, 0.2);
}

.btn-outline-ori {
	color: #1cc4ad;
	border: 3px solid #1cc4ad;
	font-weight: 600;
}

.btn-outline-ori:hover {
	color: #fff;
	background-color: #1cc4ad;
	border-color: #1cc4ad
}

.btn-outline-ori2 {
	color: #666;
	border: 3px solid #666;
	font-weight: 600;
}

.btn-outline-ori2:hover {
	color: #fff;
	background-color: #666;
	border-color: #666;
}

.btn-ori4 {
	font-weight: 600;
	font-size: 15px;
	letter-spacing: 1px;
	display: inline-block;
	border-radius: 3px;
	transition: 0.3s;
	line-height: 1;
	background: #f82250;
	padding: 8px 25px;
	border-radius: 3px;
	color: #fff;
	-webkit-animation-delay: 0.8s;
	animation-delay: 0.8s;
	border: 2px solid #ffaa0f;
	box-shadow: 0 2px 15px 0 rgba(185, 57, 93, 0.2);
}

.btn-ori4:hover {
	background: #fff;
	color: #ff9a03;
	text-decoration: none;
	box-shadow: 0 2px 15px 0 rgba(255, 147, 32, 0.2);
}

.btn-ori4 i {
	font-weight: 600;
	font-size: larger;
	vertical-align: -2px;
	padding-left: 15px;
}


/*——　border　——*/

.border {
	border-top: 2px solid rgba(236, 239, 241, 0.07);
	height: 1px;
	margin: 15px auto 0;
	position: relative;
	width: 30%;
}

.border:before {
	background-color: #fff;
	content: '';
	height: 6px;
	left: 50%;
	margin-left: -20px;
	position: absolute;
	top: -4px;
	width: 50px;
	background-color: #57cbcc;
}

.divider {
	font-size: 0;
	line-height: 0;
	height: 3px;
	width: 100%;
	background: #e1e1e1;
}

/*——　文字右ライン　——*/
.title-border-right {
	display: flex;
	align-items: center;
}

.title-border-right:after {
	border-top: 3px solid #e7eaec;
	content: "";
	flex-grow: 1;
}

.title-border-right:after {
	margin-left: 20px;
}

.title-10 {
	position: relative;
	font-size: 24px;
	font-weight: 600;
	border-bottom: 1px solid rgba(5, 62, 98, 1);
	padding: 30px 0px 5px 0px;
	margin: 30px 10px 50px 10px;
	background: linear-gradient(transparent 80%, rgb(28 205 216 / 7%) 0%);
}

.title-10 span {
	position: relative;
	z-index: 2;
}

.title-11 {
	font-size: 24px;
	font-weight: 600;
	color: rgb(3 200 212 / 90%) !important;
	margin: -5px 15px 0px -15px !important;
}

.title-10::before {
	content: attr(data-en);
	position: absolute;
	top: 0px;
	left: 0;
	color: rgba(5, 62, 98, 0.2);
	font-size: 40px;
	text-transform: uppercase;
	z-index: 1;
}

.block2 {
	padding: 5px 10px;
	margin: 0 0 20px;
	font-size: 20px;
	font-weight: 600;
	border-left: 5px solid #f73f53;
}

.block3 {
	padding: 5px 10px;
	margin: 0 0 20px;
	font-size: 20px;
	font-weight: 600;
	border-left: 5px solid #39F;
}

.block4 {
	padding: 5px 10px;
	font-size: 20px;
	font-weight: 600;
	border-left: 5px solid #1E85E1;
	background-color: aliceblue;
}

.block5 {
	padding: 5px 10px;
	margin: 5px;
	font-size: 14px;
	border-left: none;
}

.block6 {
	padding: 5px 10px;
	font-size: 20px;
	font-weight: 600;
	border-left: 5px solid #686868;
	background-color: #f6f7f4;
	text-align: left;
}

.block7 {
	padding: 5px 10px;
	font-size: 20px;
	font-weight: 600;
	text-align: left;
	border-left: 5px solid #ffe8d7;
	background-color: #fff5f0;
}

.block8 {
	padding: 5px 10px;
	font-size: 20px;
	font-weight: 600;
	text-align: left;
	border-left: 5px solid #f73f53;
	background-color: #fff5f0;
	margin: 10px 0px 0px 0px;
}


.ori1-list {
	padding-left: 0px;
}

.ori1-list.square li {
	list-style: square;
	margin-left: 25px;
	line-height: 20px;
}

/*--------------------------------------------------------------
# BOX
--------------------------------------------------------------*/


.box {
	padding: 20px;
	background: #fdfdfd;
	text-align: left;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	border: 3px solid #f4f3f3;
	font-weight: 600;
}

.box2 {
	padding: 10px 5px;
	background: #ffffff;
	text-align: left;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	border: 3px solid #f4f3f3;
	font-weight: 600;
}

.box3 {
	padding: 20px;
	background: #f3f3f30f;
	text-align: left;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	border: 3px solid #ffece4;
	font-weight: 600;
}

.box5 {
	padding: 10px 10px;
	background: #ffffff;
	text-align: left;
	position: relative;
	overflow: hidden;
	border: 3px solid #fae0e8;
	border-radius: 20px;
	font-weight: 600;
	margin: 10px 0px 20px 0px;
}

.box6 {
	padding: 10px 10px 15px 10px;
	background: #fffafb;
	position: relative;
	overflow: hidden;
	border: 2px solid #f3f3f3;
	border-radius: 5px;
	font-weight: 600;
}

.box6 i {
	font-size: 18px;
	font-weight: 600;
}

.box6 p {
	margin: 5px 0px 20px 0px;
	font-size: 18px;
	font-weight: 600;
	background-color: #fff;
}

.box7 {
	background: #ffffff;
	text-align: left;
	position: relative;
	overflow: hidden;
	border: 2px solid #eae8e8;
	border-radius: 20px;
	font-weight: 600;
	margin: 5px 0px 20px 0px;
}



/*--------------------------------------------------------------
# Disable AOS delay on mobile
--------------------------------------------------------------*/
@media screen and (max-width: 768px) {
	[data-aos-delay] {
		transition-delay: 0 !important;
	}
}

/*--------------------------------------------------------------
# Header
--------------------------------------------------------------*/
#header {
	z-index: 997;
	transition: all 0.5s;
	padding: 22px 0;
	background: rgba(255, 255, 255, 0.8);
}

#header.header-scrolled {
	box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.5);
	padding: 12px 0;
}

#header .logo h1 {
	font-size: 30px;
	margin: 0;
	padding: 0;
	line-height: 1;
	font-weight: 700;
	letter-spacing: 1px;
}

#header .logo h1 a,
#header .logo h1 a:hover {
	color: #222222;
	text-decoration: none;
}

#header .logo img {
	padding: 0;
	margin: 0;
	max-height: 40px;
}

/*--------------------------------------------------------------
# Navigation Menu
--------------------------------------------------------------*/
/**
* Desktop Navigation 
*/
.navbar {
	padding: 0;
}

.navbar ul {
	margin: 0;
	padding: 0;
	display: flex;
	list-style: none;
	align-items: center;
}

.navbar li {
	position: relative;
}

.navbar a,
.navbar a:focus {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-size: 16px;
	font-weight: 700;
	color: #222222;
	white-space: nowrap;
	transition: 0.3s;
}

.navbar a i,
.navbar a:focus i {
	font-size: 12px;
	line-height: 0;
	margin-left: 5px;
}

.navbar a:hover,
.navbar .active,
.navbar .active:focus,
.navbar li:hover>a {
	color: #f82250;
}

.navbar .getstarted {
	background: #f82250;
	padding: 8px 25px;
	margin-left: 30px;
	border-radius: 3px;
	color: #fff;
}

.navbar .getstarted:hover {
	color: #fff;
	background: #e41c47;
}

.navbar .getstarted-2 {
	padding: 8px 25px;
	margin-left: 30px;
	border-radius: 3px;
	color: #f82250;
	border: 2px solid #f82250;
}

.navbar .getstarted-2:hover {
	background: #f82250;
	padding: 8px 25px;
	margin-left: 30px;
	border-radius: 3px;
	color: #fff;
}

.navbar .dropdown ul {
	display: block;
	position: absolute;
	left: 30px;
	top: calc(100% + 30px);
	margin: 0;
	padding: 10px 0;
	z-index: 99;
	opacity: 0;
	visibility: hidden;
	background: #fff;
	box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
	transition: 0.3s;
	border-radius: 4px;
}

.navbar .dropdown ul li {
	min-width: 200px;
}

.navbar .dropdown ul a {
	padding: 10px 20px;
	font-size: 14px;
}

.navbar .dropdown ul a i {
	font-size: 12px;
}

.navbar .dropdown ul a:hover,
.navbar .dropdown ul .active:hover,
.navbar .dropdown ul li:hover>a {
	color: #f82250;
}

.navbar .dropdown:hover>ul {
	opacity: 1;
	top: 100%;
	visibility: visible;
}

.navbar .dropdown .dropdown ul {
	top: 0;
	left: calc(100% - 30px);
	visibility: hidden;
}

.navbar .dropdown .dropdown:hover>ul {
	opacity: 1;
	top: 0;
	left: 100%;
	visibility: visible;
}

@media (max-width: 1366px) {
	.navbar .dropdown .dropdown ul {
		left: -90%;
	}

	.navbar .dropdown .dropdown:hover>ul {
		left: -100%;
	}
}

/**
* Mobile Navigation 
*/
.mobile-nav-toggle {
	color: #222222;
	font-size: 28px;
	cursor: pointer;
	display: none;
	line-height: 0;
	transition: 0.5s;
}

.mobile-nav-toggle.bi-x {
	color: #fff;
}

@media (max-width: 991px) {
	.mobile-nav-toggle {
		display: block;
	}

	.navbar ul {
		display: none;
	}
}

.navbar-mobile {
	position: fixed;
	overflow: hidden;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background: rgba(9, 9, 9, 0.9);
	transition: 0.3s;
	z-index: 999;
}

.navbar-mobile .mobile-nav-toggle {
	position: absolute;
	top: 15px;
	right: 15px;
}

.navbar-mobile ul {
	display: block;
	position: absolute;
	height: fit-content;
	top: 55px;
	right: 15px;
	bottom: 15px;
	left: 15px;
	padding: 10px 0;
	border-radius: 8px;
	background-color: #fff;
	overflow-y: auto;
	transition: 0.3s;
}

.navbar-mobile a {
	padding: 10px 20px;
	font-size: 18px;
	color: #222222;
}

.navbar-mobile a:hover,
.navbar-mobile .active,
.navbar-mobile li:hover>a {
	color: #f82250;
}

.navbar-mobile .getstarted {
	margin: 15px;
}

.navbar-mobile .dropdown ul {
	position: static;
	display: none;
	margin: 10px 20px;
	padding: 10px 0;
	z-index: 99;
	opacity: 1;
	visibility: visible;
	background: #fff;
	box-shadow: 0px 0px 30px rgba(127, 137, 161, 0.25);
}

.navbar-mobile .dropdown ul li {
	min-width: 200px;
}

.navbar-mobile .dropdown ul a {
	padding: 10px 20px;
}

.navbar-mobile .dropdown ul a i {
	font-size: 12px;
}

.navbar-mobile .dropdown ul a:hover,
.navbar-mobile .dropdown ul .active:hover,
.navbar-mobile .dropdown ul li:hover>a {
	color: #f82250;
}

.navbar-mobile .dropdown>.dropdown-active {
	display: block;
}

/*--------------------------------------------------------------
# top Section
--------------------------------------------------------------*/
#top {
	width: 100%;
	height: 435px;
	background: url(../images/home/top1.jpg) no-repeat center fixed;
	background-position: 0px -111px;
	background-size: 100%;
	margin-top: 86px;
}

#top h1 {
	margin: 0 0 10px 0;
	font-size: 36px;
	font-weight: 700;
	line-height: 56px;
	color: #ffffff;
	filter: drop-shadow(3px 2px 1px #111);
}

#top h2 {
	font-size: 20px;
	font-weight: 600;
	line-height: 24px;
	color: #ffffff;
	filter: drop-shadow(1px 1px 1px #fd5277);
}

#top p {
	margin-bottom: 50px;
	font-size: 20px;
	font-weight: 600;
	line-height: 24px;
	color: #ffffff;
	filter: drop-shadow(1px 1px 1px #F82250);
}

#top .btn-get-started {
	font-family: "Raleway", sans-serif;
	font-weight: 600;
	font-size: 16px;
	letter-spacing: 1px;
	display: inline-block;
	padding: 7px 35px;
	border-radius: 3px;
	transition: 0.5s;
	color: #ffffff;
	border: 3px solid #f82250;
	filter: drop-shadow(1px 1px 1px #111);
}

#top .btn-get-started:hover {
	background: #f82250;
	color: #fff;
}

#top .animated {
	animation: up-down 2.5s ease-in-out infinite alternate-reverse both;
	mix-blend-mode: hard-light;
	display: list-item;
	padding-top: 30px;
}

@media (min-width: 1024px) {
	#top {
		background-attachment: fixed;
	}
}

@media (max-width: 991px) {
	#top {
		height: 100vh;
	}

	#top .animated {
		-webkit-animation: none;
		animation: none;
	}

	#top .top-img {
		text-align: center;
	}

	#top .top-img img {
		width: 50%;
	}
}

@media (max-width: 768px) {
	#top {
		margin-top: 0px;
		height: 400px;
	}

	#top h1 {
		font-size: 28px;
		line-height: 36px;
	}

	#top h2 {
		font-size: 18px;
		line-height: 24px;
		margin-bottom: 30px;
	}

	#top .top-img img {
		display: none;
	}
}

@media (max-width: 575px) {}

@-webkit-keyframes up-down {
	0% {
		transform: translateY(10px);
	}

	100% {
		transform: translateY(-10px);
	}
}

@keyframes up-down {
	0% {
		transform: translateY(10px);
	}

	100% {
		transform: translateY(-10px);
	}
}

/*--------------------------------------------------------------
# Sections General
--------------------------------------------------------------*/
section {
	padding: 60px 0px 75px 0px;
	overflow: hidden;
}


.bg-top-1 {
	background-image: url(../images/home/bg1.png);
	background-repeat: no-repeat;
	background-position: center fixed;
}

.bg-top-2 {
	background-image: url(../images/home/bg2.jpg);
	background-repeat: no-repeat;
}

.bg-top-3 {
	background-image: url(../images/home/bg3.jpg);
	background-repeat: no-repeat;
	background-position: left;
}

.bg-top-4 {
	background-image: url(../images/home/bg4.png);
	background-repeat: no-repeat;
	background-position: right;
}

.section-bg {
	background: url(../images/home/bg1.png) center fixed;
	box-shadow: 1px 0px 7px 0px rgba(253, 178, 191, 0.14);
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-bg2 {
	background: url(../images/home/bg1.png) center fixed;
	box-shadow: 1px 0px 7px 0px rgba(81, 202, 94, 0.14);
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-bg3 {
	background: #fbfbfb;
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-bg4 {
	background: #fafbff;
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-bg5 {
	background: url(../images/home/banner.jpg) center fixed;
	box-shadow: 1px 0px 7px 0px rgba(253, 178, 191, 0.14);
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-bg-white {
	background: #ffffff;
	color: #222222;
	font-size: 14px;
	font-weight: 600;
}

.section-title {
	text-align: center;
	padding-bottom: 50px;
}

.section-title h1 {
	font-size: 30px;
	font-weight: bold;
	position: relative;
}

.section-title h2 {
	font-size: 28px;
	font-weight: bold;
	position: relative;
}

/*-- 両脇ボーダー
.section-title h2::before, .section-title h2::after {
  content: '';
  width: 50px;
  height: 2px;
  background: #f82250;
  display: inline-block;
}
*/

.section-title h2::before {
	margin: 0 15px 10px 0;
}

.section-title h2::after {
	margin: 0 0 10px 15px;
}

.section-title h3 {
	font-size: 28px;
	font-weight: bold;
	position: relative;
}

.section-title h3::before {
	margin: 0 15px 10px 0;
}

.section-title h3::after {
	margin: 0 0 10px 15px;
}

.section-title h4 {
	font-size: 30px;
	font-weight: bold;
	position: relative;
}

.section-title h4::before {
	margin: 0 15px 10px 0;
}

.section-title h4::after {
	margin: 0 0 10px 15px;
}

.section-title h5 {
	font-size: 26px;
	color: #056aa5;
	font-weight: bold;
	position: relative;
}

.section-title p {
	margin: 18px 0 0 0;
	font-weight: 600;
	font-size: 18px;
}

.section-title .left {
	text-align: left;
}


.section-title-black {
	text-align: center;
	padding-bottom: 60px;
}

.section-title-black h4 {
	font-size: 28px;
	font-weight: bold;
	position: relative;
	color: #ffffff;
}

.section-title-black h4::before {
	margin: 0 15px 10px 0;
}

.section-title-black h4::after {
	margin: 0 0 10px 15px;
}

.section-title-black p {
	margin: 15px 0 0 0;
	font-weight: 600;
	font-size: 18px;
	color: #ffffff;
}

.section-title-black small {
	color: #ffffff;
}

@media (max-width: 768px) {
	.section-title h2 {
		font-size: 24px;
	}

	.section-title-black h2 {
		font-size: 24px;
	}
}


/*--------------------------------------------------------------
# TOPTOP
--------------------------------------------------------------*/

.home-top {
	padding-top: 60px;
	position: relative;
}



/*---------------------------------------
  ABOUT              
-----------------------------------------*/
.about-section {
	background-color: #333333;
	position: relative;
}

.about-section .ratio {
	border-radius: 5px;
}

.about-section .description {
	font-size: 15px;
	margin-left: 40px;
	line-height: 24px;
	margin-bottom: 0;
	font-weight: 600;
	color: #ffffff;
}

.custom-video {
	border-radius: 5px;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.about-image-wrap {
	border-radius: 5px;
	position: relative;
	overflow: hidden;
}

.about-video-info {
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.01), rgba(51, 51, 51, 2.00));
	border-radius: 3px;
	bottom: 0;
	height: auto;
	padding: 40px;
}

.about-video-info h4 {
	color: #ffffff;
}

.about-section h6 {
	color: #DDA15E;
}

.team-block-wrap {
	background-color: #DDA15E;
	border-radius: 5px;
	position: relative;
	overflow: hidden;
	max-height: 450px;
	cursor: pointer;
}

.team-block-wrap:hover .team-block-image {
	transform: scale(1.2);
}

.team-block-image-wrap {
	width: 100%;
}

.team-block-image {
	display: block;
	object-fit: cover;
	width: 100%;
	height: 100%;
	transition: all 0.3s;
}

.team-block-info {
	background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.35), rgba(188, 108, 37, 1));
	position: absolute;
	z-index: 2;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 30px;
}

.team-block-info .badge {
	margin: auto;
	top: 2px;
	bottom: 0;
}


/*--------------------------------------------------------------
# Clients
--------------------------------------------------------------*/
.clients {
	background: #f3f9fd;
	padding: 10px 0;
	text-align: center;
}

.clients .col-lg-2 {
	display: flex;
	align-items: center;
	justify-content: center;
}

.clients img {
	width: 50%;
	filter: grayscale(100);
	transition: all 0.4s ease-in-out;
	display: inline-block;
	padding: 10px 0;
}

.clients img:hover {
	filter: none;
	transform: scale(1.1);
}

@media (max-width: 768px) {
	.clients img {
		width: 40%;
	}
}

@media (max-width: 575px) {
	.clients img {
		width: 30%;
	}
}

/*--------------------------------------------------------------
# About Us
--------------------------------------------------------------*/
.about .content h3 {
	font-weight: 600;
	font-size: 26px;
}

.about .content ul {
	list-style: none;
	padding: 0;
}

.about .content ul li {
	padding-left: 28px;
	position: relative;
}

.about .content ul li+li {
	margin-top: 10px;
}

.about .content ul i {
	position: absolute;
	left: 0;
	top: 2px;
	font-size: 20px;
	color: #f82250;
	line-height: 1;
}

.about .content p:last-child {
	margin-bottom: 0;
}

.about .content .btn-learn-more {
	font-family: "Raleway", sans-serif;
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 1px;
	display: inline-block;
	padding: 12px 32px;
	border-radius: 3px;
	transition: 0.3s;
	line-height: 1;
	color: #f82250;
	-webkit-animation-delay: 0.8s;
	animation-delay: 0.8s;
	margin-top: 6px;
	border: 2px solid #f82250;
}

.about .content .btn-learn-more:hover {
	background: #f82250;
	color: #fff;
	text-decoration: none;
}

/*--------------------------------------------------------------
# Counts
--------------------------------------------------------------*/
.counts {
	padding-top: 0;
}

.counts .content {
	padding: 0;
}

.counts .content h3 {
	font-weight: 700;
	font-size: 34px;
	color: #222222;
}

.counts .content p {
	margin-bottom: 0;
}

.counts .content .count-box {
	padding: 20px 0;
	width: 100%;
}

.counts .content .count-box i {
	display: block;
	font-size: 36px;
	color: #f82250;
	float: left;
	line-height: 0;
}

.counts .content .count-box span {
	font-size: 36px;
	line-height: 30px;
	display: block;
	font-weight: 700;
	color: #222222;
	margin-left: 50px;
}

.counts .content .count-box p {
	padding: 15px 0 0 0;
	margin: 0 0 0 50px;
	font-family: "Raleway", sans-serif;
	font-size: 14px;
	color: #484848;
}

.counts .content .count-box a {
	font-weight: 600;
	display: block;
	margin-top: 20px;
	color: #484848;
	font-size: 15px;
	font-family: "Poppins", sans-serif;
	transition: ease-in-out 0.3s;
}

.counts .content .count-box a:hover {
	color: #6f6f6f;
}

@media (max-width: 1024px) {
	.counts .image {
		text-align: center;
	}

	.counts .image img {
		max-width: 70%;
	}
}

@media (max-width: 667px) {
	.counts .image img {
		max-width: 100%;
	}
}

/*--------------------------------------------------------------
# Services
--------------------------------------------------------------*/

.services .icon-box {
	padding: 30px;
	position: relative;
	overflow: hidden;
	border-radius: 10px;
	background: #fff;
	box-shadow: 0 2px 29px 0 rgba(68, 88, 144, 0.12);
	transition: all 0.4s ease-in-out;
	width: 100%;
	height: 100%;
}

.services .icon-box:hover {
	transform: translateY(-10px);
	box-shadow: 0 2px 35px 0 rgba(68, 88, 144, 0.2);
}

.services .icon {
	position: absolute;
	left: -20px;
	top: calc(50% - 30px);
}

.services .icon i {
	font-size: 64px;
	line-height: 1;
	transition: 0.5s;
}

.services .title {
	margin-left: 30px;
	font-weight: 700;
	margin-bottom: 15px;
	font-size: 20px;
}

.services .title a {
	color: #2a2c39;
	transition: ease-in-out 0.3s;
}

.services .title a:hover {
	color: #ef6603;
}

.services .description {
	font-size: 16px;
	margin-left: 30px;
	line-height: 24px;
	margin-bottom: 0;
	font-weight: 600;
	color: #242424;
}




/* :: INDEX 比較-area */

.table-1 {
	border-collapse: collapse;
	width: 100%;
	table-layout: fixed;
}

.table-1 thead th {
	padding: 0.5em .8em;
	border-right: 5px solid#fff;
	color: #c7c7c7;
	text-align: center;
}

.table-1 tr {
	background-color: #fff;
	padding: .35em;
}

.table-1 tr:nth-child(even) {
	background-color: #f9f9f9;
}

.table-1 td {
	color: #686868;
	font-size: 18px;
	font-weight: 600;
	text-align: center;
	padding: 0.3em .1em;
}

.table-1 td small {
	font-size: 12px;
	font-weight: 500;
}

.table-1 th {
	font-size: 18px;
	font-weight: 600;
	padding: .7em;
}

.table-1 i {
	font-size: 2em;
	color: rgb(253, 175, 79);
}

.plan1 {
	background: #03A9F4;

}

.plan1_i {
	color: #000000 !important;
	border-right: 1px solid #f39800;
	border-left: 1px solid #f39800;
	line-height: 16px;
}

.plan2 {
	background: #cddc39;
}

.plan2_i {
	color: #cddc39;
}

.plan3 {
	background: #4caf50;
}

.plan3_i {
	color: #4caf50;
}

.plan4 {
	background: #009688;
}

.plan4_i {
	color: #009688;
}

.price {
	font-weight: bold;
	font-size: 30px;
	overflow: hidden;
}

.price span {
	font-size: .6em;
}

.price img {
	width: 60%;
}

@media (max-width: 767px) {

	.table-1 td {
		font-size: 12px;
		font-weight: 600;
		padding: 1.0em .1em;
	}

	.table-1 th {
		font-size: 12px;
		padding: 1.0em .1em;
		line-height: 14px;

	}

	.table-1 td small {
		font-size: 11px;
		font-weight: 500;
	}

	.price {
		color: #fff;
		font-weight: bold;
		font-size: 14px;
		text-align: center;
	}

	.table-1 i {
		font-size: 2em;
		display: block;
		text-align: center !important;
	}

}



/* =========================================================================================
   # function Area css
============================================================================================ */

.function {
	position: relative;
}

.function .industry-item {
	margin-bottom: 30px;
}

.function #industry-flters {
	padding: 0;
	margin: 0 0 30px 0px;
	list-style: none;
}

.function #industry-flters li {
	cursor: pointer;
	display: inline-flex;
	padding: 3px 4px 3px 4px;
	font-size: 14px;
	font-weight: 600;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	color: #222222;
	margin-bottom: 5px;
	transition: all 0.3s ease-in-out;
	border-radius: 3px;
	border: 2px solid #ffaf3c;
	width: 100px;
	height: 40px;
	line-height: 30px;
	width: calc((100% - 2.5%)/8);
}

.function #industry-flters li::before {
	position: relative;
	display: list-item;
	content: "\F231";
	padding: 0px 5px 0px 5px;
	left: -2px;
	top: 7px;
	font-size: 15px;
	line-height: 1;
	text-indent: 0;
	font-family: "bootstrap-icons";
	color: #ffaf3c;
}

@media (max-width: 767px) {
	.function #industry-flters li {
		padding: 10px 5px 10px 5px;
		font-size: 12px;
		font-weight: 600;
		line-height: 15px;
		width: calc((100% - 2.5%)/2);
	}
}

.function #industry-flters li:hover,
.function #industry-flters li.filter-active {
	color: #fff;
	background: #0d6efd;
}

.function #industry-flters li:last-child {
	margin-right: 0;
}

.function-category {
	z-index: 1;
}

.function-category a {
	display: inline-block;
	background-color: #f4f4f4;
	border: 2px solid transparent;
	padding: 6px 9px 6px 7px;
	font-size: 15px;
	font-weight: 600;
	margin: 5px 5px 5px 0px;
	border-radius: 5px;
}

@media only screen and (min-width: 991px) and (max-width: 1199px) {
	.function-category a {
		padding: 4px 7px;
		font-size: 14px;
		margin-right: 4px;
	}
}

@media only screen and (max-width: 767px) {
	.function-category a {
		padding: 4px 7px;
		font-size: 14px;
		margin-right: 5px;
		margin-bottom: 5px;
	}
}

.function-category a:hover,
.function-category a:focus,
.function-category a.active {
	border: 2px solid #000000;
}

.function-category a:first-child {
	background-color: #f4f4f4;
	border: 2px solid transparent;
	padding: 6px 9px;
	font-size: 15px;
}

@media only screen and (max-width: 767px) {
	.function-category a:first-child {
		padding: 4px 7px;
		font-size: 14px;
		margin-right: 5px;
		margin-bottom: 5px;
	}
}

.f-info {
	position: relative;
	z-index: 1;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
	padding: 15px;
	margin-bottom: 30px;
	box-shadow: 1px 2px 5px 4px rgba(68, 88, 144, 0.12);
	border-radius: 10px;
	height: 310px;
}

.f-info .event-f {
	z-index: 1;
	text-align: center;
	padding-bottom: 15px;
	border-radius: 2px;
}

.f-info .event-f img {
	position: absolute;
	bottom: 5px;
	right: 5px;
	max-width: 250px;
	z-index: -1;
	content: '';
	border-radius: 5px;
	opacity: 0.6;
	text-shadow: 2px 2px 1px #ffffff;
}

.f-info .event-f i {
	margin-right: 7px;
	color: #F82250;
}

.f-info .event-f h4 {
	font-size: 19px;
	font-weight: 600;
	margin: 20px 0px 20px 0px;
}

.f-info .event-f p {
	font-size: 16px;
	font-weight: 500;
	line-height: 24px;
	text-align: left;
	color: #000;
	margin-bottom: 0;
}

@media only screen and (max-width: 991px) {
	.f-info .event-f h4 {
		font-size: 16px;
	}

	.f-info .event-f img {
		max-width: 200px;
	}

}

.f-info:hover,
.f-info:focus {
	box-shadow: 0 5px 70px 0 rgba(0, 0, 0, 0.15);
}

.f-info-area {
	position: relative;
	z-index: 1;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
	margin-bottom: 30px;
}

.f-info-area .album-thumb {
	position: relative;
	z-index: 1;
}

.f-info-area .album-thumb .album-price p {
	position: absolute;
	top: 15px;
	left: 15px;
	background-color: #fff;
	margin-bottom: 0;
	line-height: 1;
	padding: 5px 15px;
	border-radius: 15px;
	z-index: 20;
}

.f-info-area .album-thumb .play-icon a {
	color: #fff;
	font-size: 50px;
	position: absolute;
	top: 50%;
	left: 50%;
	line-height: 1;
	-webkit-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}

.f-info-area img {
	width: 100%;
}

.f-info-area .event-f {
	display: block;
	position: relative;
	z-index: 1;
	padding-top: 15px;
	padding-bottom: 15px;
}

.f-info-area .event-f h5 {
	font-size: 18px;
	margin-bottom: 0;
	text-transform: uppercase;
}

.f-info-area .event-f p {
	margin-bottom: 0;
}


/*--------------------------------------------------------------
# More Services
--------------------------------------------------------------*/
.function-info {
	padding-top: 20px;
}

.function-info .card {
	border: 0;
	padding: 75px 10px 15px 10px;
	position: inherit;
	width: 100%;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
}

.function-info .card-body {
	z-index: 10;
	background: rgba(255, 255, 255, 0.8);
	padding: 15px 30px;
	box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
	transition: 0.3s;
	transition: ease-in-out 0.4s;
	border-radius: 5px;
}

.function-info .card-title {
	font-size: 20px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 15px;
}

.function-info .card-title a {
	color: #222222;
}

.function-info .card-text {
	font-size: 18px;
	line-height: 24px;
	margin-bottom: 0;
	font-weight: 600;
	color: #333333;
}

.function-info .read-more a {
	color: #777777;
	font-weight: 600;
	font-size: 12px;
	transition: 0.4s;
}

.function-info .read-more a:hover {
	text-decoration: underline;
}

.function-info .card:hover .card-body {
	background: rgb(33 166 210 / 80%);
}

.function-info .card:hover .read-more a,
.function-info .card:hover .card-title,
.function-info .card:hover .card-title a,
.function-info .card:hover .card-text {
	color: #fff;
}

/*--------------------------------------------------------------
# Features
--------------------------------------------------------------*/
.features .icon-box {
	display: flex;
	align-items: center;
	padding: 20px;
	background: #f6f6f6;
	transition: ease-in-out 0.3s;
}

.features .icon-box i {
	font-size: 32px;
	padding-right: 10px;
	line-height: 1;
}

.features .icon-box h3 {
	font-weight: 700;
	margin: 0;
	padding: 0;
	line-height: 1;
	font-size: 16px;
}

.features .icon-box h3 a {
	color: #222222;
	transition: ease-in-out 0.3s;
}

.features .icon-box h3 a:hover {
	color: #f82250;
}

.features .icon-box:hover {
	background: #eef7fc;
}

/*--------------------------------------------------------------
# customer
--------------------------------------------------------------*/
.customer .customer-wrap {
	padding: 0px;
}

.customer .customer-item {
	box-sizing: content-box;
	padding: 0px 0px 10px 0px;
	margin: 30px 0px 50px 0px;
	min-height: 300px;
	max-height: 375px;
	box-shadow: 0px 2px 12px rgba(0, 0, 0, 0.08);
	position: relative;
	/*	
	background: rgba(255, 247, 237, 0.62);
*/
	border-radius: 3px;
}

.customer .customer-item .customer-img {
	border-radius: 3px;
	display: block;
	max-height: 390px;
	width: 100%;
	object-fit: cover;
	image-rendering: pixelated;
	object-position: top;
}

.customer .customer-item h3 {
	font-size: 14px;
	font-weight: 500;
	text-align: center;
	margin: 15px 0 5px 0;
	color: #111;
}

.customer .customer-item h4 {
	font-size: 14px;
	text-align: center;
	color: #999;
	margin: 0;
}

.customer .customer-item p {
	font-size: 15px;
	font-weight: 600;
	text-align: center;
	margin: 8px 0 5px 0;
	color: #111;
	background-color: rgba(248, 248, 248, 0.60);
}

.customer .customer-item .quote-icon-left,
.customer .customer-item .quote-icon-right {
	color: #e1f0fa;
	font-size: 26px;
}

.customer .customer-item .quote-icon-left {
	display: inline-block;
	left: -5px;
	position: relative;
}

.customer .customer-item .quote-icon-right {
	display: inline-block;
	right: -5px;
	position: relative;
	top: 10px;
}

.customer .swiper-pagination {
	margin-top: 20px;
	position: relative;
}

.customer .swiper-pagination .swiper-pagination-bullet {
	width: 12px;
	height: 12px;
	background-color: #fff;
	opacity: 1;
	border: 1px solid #f82250;
}

.customer .swiper-pagination .swiper-pagination-bullet-active {
	background-color: #f82250;
}

@media (max-width: 767px) {
	.customer .customer-wrap {
		padding-left: 0;
	}

	.customer .customer-item {
		padding: 0px 0px 5px 0px;
		margin: 15px;
	}

	.customer .customer-item .customer-img {
		position: static;
		left: auto;
		border-radius: 3px;
		display: block;
		max-height: 270px;
		width: 100%;
		object-fit: cover;
		image-rendering: -webkit-optimize-contrast;
		object-position: top;
	}
}

/*--------------------------------------------------------------
# industry
--------------------------------------------------------------*/
.industry .industry-item {
	margin-bottom: 30px;
}

.industry #industry-flters {
	padding: 0;
	margin: 0 0 20px 0px;
	list-style: none;
	text-align: left;
}

.industry #industry-flters li {
	cursor: pointer;
	display: inline-flex;
	width: calc((100% - 6.5%)/6);
	padding: 0.5em 0.1em;
	margin: 0.3em 0.3em;
	color: #5d627b;
	background: white;
	border-top: solid 5px #5d627b;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.22);
	overflow: hidden;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 13px;
	font-weight: 600;
}

.industry #industry-flters li::before {
	position: relative;
	display: list-item;
	content: '\F27E';
	padding: 0px 1px 0px 1px;
	font-size: 15px;
	text-indent: 0;
	font-family: "bootstrap-icons";
	color: #ffcd82;
}

@media (max-width: 767px) {
	.industry #industry-flters li {
		padding: 10px 5px 10px 5px;
		font-size: 12px;
		font-weight: 600;
		line-height: 15px;
		width: calc((100% - 5.5%) / 2);
	}
}

.industry #industry-flters li:hover,
.industry #industry-flters li.filter-active {
	color: #fff;
	background: #0d6efd;
}

.industry #industry-flters li:last-child {
	margin-right: 0;
}

.industry .industry-wrap {
	transition: 0.3s;
	position: relative;
	overflow: hidden;
	z-index: 1;
	background: rgba(255, 255, 255, 0.6);
}

.industry .industry-wrap::before {
	content: "";
	background: rgba(34, 34, 34, 0.6);
	position: absolute;
	left: 0;
	right: 0;
	top: 0;
	bottom: 0;
	transition: all ease-in-out 0.3s;
	z-index: 2;
	opacity: 0;
}

.industry .industry-wrap img {
	transition: all ease-in-out 0.3s;
}

.industry .industry-wrap .industry-info {
	/*	opacity: 0; */
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 3;
	padding: 10px;
}

.industry .industry-wrap .industry-info h4 {
	font-size: 16px;
	color: #fff;
	font-weight: 600;
}

.industry .industry-wrap .industry-info p {
	color: rgba(255, 255, 255, 0.7);
	font-size: 14px;
	padding: 0;
	margin: 0;
	font-style: italic;
}

.industry .industry-wrap:hover::before {
	opacity: 1;
}

.industry .industry-wrap:hover img {
	transform: scale(1.2);
}

.industry .industry-wrap:hover .industry-info {
	opacity: 1;
}

/*--------------------------------------------------------------
# industry Details
--------------------------------------------------------------*/
.industry-details {}

.industry-details .industry-details-slider img {
	width: 100%;
	border-radius: 3px;
	max-height: 233px;
}

.industry-details .industry-details-slider .swiper-pagination {
	margin-top: 20px;
	position: relative;
}

.industry-details .industry-details-slider .swiper-pagination .swiper-pagination-bullet {
	width: 12px;
	height: 12px;
	background-color: #fff;
	opacity: 1;
	border: 1px solid #f82250;
}

.industry-details .industry-details-slider .swiper-pagination .swiper-pagination-bullet-active {
	background-color: #f82250;
}

.industry-details .industry-info {
	margin: 7px;
	padding: 30px;
	box-shadow: 0px 0 30px rgba(34, 34, 34, 0.08);
	border-radius: 5px;
}

.industry-details .industry-info h3 {
	font-size: 22px;
	font-weight: 700;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid #eee;
}

.industry-details .industry-info h5 {
	font-size: 14px;
	font-weight: 700;
	padding-bottom: 5px;
}

.industry-details .industry-info ol {
	list-style: none;
	padding: 0;
	font-size: 15px;
	font-weight: 500;
}

.industry-details .industry-info ol li {
	margin: 0px 5px 0px 25px;
}

.industry-details .industry-info ul {
	list-style: none;
	padding: 0;
	font-size: 15px;
}

.industry-details .industry-info ul li+li {
	margin-top: 10px;
}

.industry-details .industry-description {
	padding-top: 30px;
}

.industry-details .industry-description h2 {
	font-size: 26px;
	font-weight: 700;
	margin-bottom: 20px;
}

.industry-details .industry-description p {
	padding: 0;
}

/*---------------------------------------
  REVIEWS  　Flow            
-----------------------------------------*/

.reviews-section {
	background-color: #ffffff;
}

.reviews-block {
	background-color: #ffffff;
	border-radius: 20px;
	position: relative;
	overflow: hidden;
}

.reviews-block .border-top {
	border-top-color: rgba(255, 255, 255, 0.35) !important;
}

.reviews-block-image-wrap {
	background: url(../images/flow/flow1.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 30px;
}

.reviews-block-image-wrap2 {
	background: url(../images/flow/flow2.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 30px;
}

.reviews-block-image-wrap3 {
	background: url(../images/flow/flow3.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	padding: 30px;
}


.reviews-block-image {
	border-radius: 10px;
	width: 65px;
	height: 65px;
	object-fit: cover;
	margin-right: 10px;
}

.reviews-block-info {
	padding: 20px 30px;
}

.reviews-block-info p {
	font-size: var(--btn-font-size);
	font-style: italic;
	color: rgba(255, 255, 255, 0.75);
}

.reviews-group i {
	color: var(--white-color);
}

/*---------------------------------------
  TIMELINE               
-----------------------------------------*/
.timeline {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
}

.timeline::after {
	content: '';
	position: absolute;
	width: 5px;
	background-color: #111111;
	top: 0;
	bottom: 0;
	left: 50%;
	margin-left: -3px;
}

.timeline-container {
	padding: 10px 40px;
	padding-top: 0;
	position: relative;
	background-color: inherit;
	width: 50%;
}

.timeline-container::after {
	content: '';
	position: absolute;
	width: 25px;
	height: 25px;
	right: -12px;
	background-color: #007BB6;
	border: 5px solid #7c5c52;
	top: 15px;
	border-radius: 50%;
	z-index: 1;
}

.timeline-container-left {
	left: 0;
}

.timeline-container-right {
	left: 50%;
}

.timeline-container-left::before {
	content: " ";
	height: 0;
	position: absolute;
	top: 9px;
	width: 0;
	z-index: 1;
	right: 25px;
	border: medium solid #007BB6;
	border-width: 20px 0 20px 20px;
	border-color: transparent transparent transparent #007BB6;
}

.timeline-container-right::before {
	content: " ";
	height: 0;
	position: absolute;
	top: 9px;
	width: 0;
	z-index: 1;
	left: 25px;
	border: medium solid #007BB6;
	border-width: 20px 20px 20px 0;
	border-color: transparent #007BB6 transparent transparent;
}

.timeline-container-right::after {
	left: -13px;
}

.timeline-content {
	padding: 5px;
	background-color: #ffffff;
	position: relative;
	border-radius: 20px;
	border: 5px solid #060;
}

@media screen and (max-width: 991px) {
	.timeline::after {
		left: 31px;
	}

	.timeline-container {
		width: 100%;
		padding-left: 70px;
		padding-right: 25px;
	}

	.timeline-container::before {
		left: 58px;
		border: medium solid #007BB6;
		border-width: 20px 20px 20px 0;
		border-color: transparent transparent transparent #007BB6;
	}

	.timeline-container-left::after,
	.timeline-container-right::after {
		left: 6px;
	}

	.timeline-container-right {
		left: 0%;
	}
}


/*--------------------------------------------------------------
# column
--------------------------------------------------------------*/
.column {
	margin-bottom: 20px;
	overflow: hidden;
	text-align: center;
	border-radius: 5px;
}

.column a {
	color: #000;
}

.column .column-img {
	position: relative;
	overflow: hidden;
}

.column p {
    font-size: 16px;
    line-height: 26px;
    font-weight: 600;
    text-align: left;
    color: #000;
}

.column .social {
	position: absolute;
	left: 0;
	bottom: 0;
	right: 0;
	height: 40px;
	background: rgba(35, 180, 250, 0.85);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	color: #FFF;
	font-weight: 600;
	/*
	opacity: 0;
	transition: ease-in-out 0.3s;
	*/
}

.column .social a {
	transition: color 0.3s;
	color: #222222;
	margin: 0 10px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
}

.column .social a i {
	line-height: 0;
}

.column .social a:hover {
	color: #f82250;
}

.column .social i {
	font-size: 18px;
	margin: 0 2px;
}

.column .social-2 {
	position: inherit;
	left: 0;
	top: 0;
	right: 0;
	height: 40px;
	background: rgba(35, 180, 250, 0.85);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	color: #FFF;
	font-weight: 600;
	width: 100%;
	/*
	opacity: 0;
	transition: ease-in-out 0.3s;
	*/
}

.column .column-info {
	padding: 15px 15px;
}

.column .column-info a {
	color: #222222;
	text-decoration: none;
	border-bottom: 2px solid #ff680f;
}

.column .column-info a:hover {
	color: #f82250;
}

.column .column-info h3 {
	margin-bottom: 10px;
	font-size: 22px;
	font-weight: 600;
	color: #222222;
}

.column .column-info h4 {
	font-weight: 700;
	margin-bottom: 5px;
	font-size: 18px;
	color: #222222;
}

.column .column-info h4 span {
	display: block;
	font-size: 13px;
	font-weight: 400;
	color: #aaaaaa;
	right: 0%;
}

.column .column-info p {
	font-weight: 600;
	padding: 5px;
	font-size: 18px;
	color: #000000;
	text-align: left;
	background-color: #f8f8f8;
}

.column .column-info span {
	display: block;
	font-weight: 600;
	margin: 5px;
	padding: 5px;
	font-size: 18px;
	line-height: 20px;
	color: #dcdcdc;
	text-align: right;
}

.column .column-info .time {
	display: block;
	font-weight: 600;
	margin: 0px;
	padding: 5px;
	font-size: 10px;
	line-height: 0px;
	color: #dcdcdc;
	text-align: right;
}

.column .column-info p i {
	color: #f82250;
}

.column:hover .social {
	opacity: 1;
}

.column .item {
	display: inline;
	float: left;
	padding: 30px 20px;
}

.column .item p {
	font-weight: 600;
	margin: 5px;
	padding: 5px;
	font-size: 16px;
	color: #000000;
	text-align: left;
}

.column .item .green {
	background-color: #28B6C6;
}

.column .item .tag {
	color: #fff;
	padding: 5px 10px;
	position: absolute;
	left: 5px;
	top: -25px;
	width: 85%;
	font-size: 16px;
}

.column .item .green {
	background-color: #28B6C6;
}

.column .item .tag {
	color: #fff;
	padding: 12px 15px;
	position: absolute;
	left: 5px;
	top: -25px;
	width: 75%;
	font-size: 16px;
}

.column .block2 {
	padding: 5px 10px;
	font-size: 20px;
	font-weight: 600;
	text-align: left;
	border-left: 5px solid #1E85E1;
	background-color: aliceblue;
}

.comments .title {
	font-weight: 400;
	margin-bottom: 20px;
}

.comments .title a {
	font-size: 10px;
	display: inline-block;
	margin-left: 10px;
	font-weight: 600;
	letter-spacing: 1px;
}

.comments .comment-list {
	margin-top: 10px;
}

.comments .comment-list .item {
	padding: 20px;
	margin-bottom: 20px;
}

.comments .comment-list .item .user {
	display: inline-block;
	width: 100%;
	padding: 25px 3px 5px 3px;
	margin-bottom: 20px;
	border-top: 2px solid #1ad200;
}


.block-5 {
    padding: 5px 10px;
    font-size: 18px;
    font-weight: 600;
    border-bottom: 5px solid #4e9d05;
    background-color: #f3fdde;
    text-align: center;
    margin: 15px 0px 10px 0px;
}

.block-6 {
    padding: 5px 10px;
    font-size: 18px;
    font-weight: 600;
    border-left: 5px solid #686868;
    background-color: #f6f7f4;
    text-align: left;
    margin: 15px 0px 10px 0px;
}

.block-7 {
    padding: 5px 10px;
    font-size: 18px;
    font-weight: 600;
    border-left: 5px solid #05a799;
    background-color: #f3fdde;
    text-align: left;
    margin: 15px 0px 10px 0px;
}

.block-8 {
    padding: 5px 10px;
    font-size: 18px;
    font-weight: 600;
    border-left: 5px solid #05a799;
    border-right: 5px solid #05a799;
    background-color: #fff5c6;
    text-align: left;
    margin: 15px 0px 10px 0px;
}


.block-10 {
    font-size: 18px;
    font-weight: 600;
	color: #120171;
    position: relative;
    display: inline-block;
    background: linear-gradient(transparent 0%, #77bcff 60%);
    margin: 0 auto 10px;
    padding: 0 10px 0 10px;
	display: table-cell;
}

/*--------------------------------------------------------------
# column 専用ページ
--------------------------------------------------------------*/

/* =========================================================================================
   # column 501~ Area css
============================================================================================ */

.info-box-30 {
    padding: 30px;
    box-shadow: 0px 0 30px rgba(42, 44, 57, 0.08);
    border-radius: 5px;
}

.info-box-30 h1 {
	font-size: 30px;
	font-weight: bold;
	position: relative;
}


.comments .title {
	font-weight: 400;
	margin-bottom: 20px;
  }
  
  .comments .title a {
	font-size: 10px;
	display: inline-block;
	margin-left: 10px;
	font-weight: 600;
	letter-spacing: 1px;
  }
  
  .comments .comment-list {
	margin-top: 10px;
  }
  
  .comments .comment-list .item {
	padding: 10px 3px;
	margin-bottom: 30px;
  }
  
  .comments .comment-list .item .user {
	display: inline-block;
	width: 100%;
	padding: 5px 3px 5px 3px;
	margin-bottom: 5px;
  }
  
  .comments .comment-list .item .user figure {
	overflow: hidden;
	float: left;
	display: inline-block;
	padding-left: 5px;
  }
  
  .comments .comment-list .item .user figure .name-1 {
	font-size: 12px;
	color: rgb(245, 110, 211);
	text-align: center;
	line-height: 16px;
	margin-top: 10px;
  }
  
  .comments .comment-list .item .user figure .name-2 {
	font-size: 12px;
	color: rgb(55, 147, 253);
	text-align: center;
	line-height: 16px;
	margin-top: 10px;
  }
  
  .comments .comment-list .item .user figure img {
	width: 65px;
	height: 65px;
  }
  
  .comments .comment-list .item .user .details {
	margin-left: 85px;
  }
  
  .comments .comment-list .item .user .details .name {
	font-size: 12px;
	margin: 0;
	font-weight: 600;
	text-align: left;
	color: #06F;
  }
  
  .comments .comment-list .item .user .details .time {
	color: #999;
  }
  
  .comments .comment-list .item .user .details .description {
	font-size: 16px;
	line-height: 20px;
	font-weight: 600;
	text-align: left;
	margin: 10px 0px 10px 10px;
  }
  
  @media screen and (max-width: 768px) {
	.comments .comment-list .item .user .details .description {
	  margin: 0px 0px 0px -5px;
	}
  }
  
  .comments .comment-list .item .reply-list {
	padding-left: 50px;
  }
  
  .comments .comment-list .item .reply-list .item {
	border: none;
  }
  
  .details h4 {
	font-size: 18px;
	margin-bottom: 15px;
  }
  
  .comments .comment-list.sm .item {
	border: none;
	padding: 0 0 5px 0;
	margin-bottom: 15px;
	border-bottom: 1px solid #f2f2f2;
  }
  
  .comments .comment-list.sm .item:last-child {
	border-bottom: 0;
	padding-bottom: 0;
	margin-bottom: 0;
  }
  
  .comments .comment-list.sm .item .user figure {
	width: 45px;
	height: 45px;
	font-size: 30px;
	text-align: center;
  }
  
  .comments .comment-list.sm .item .user .details {
	margin-left: 60px;
  }
  
  .comments .comment-list.sm .item .user .details .name {
	margin-top: 5px;
	font-size: 18px;
  }
  
  .comments .comment-list.sm .item .user .details .time {
	font-size: 12px;
  }
  
  .comments .comment-list.sm .item .user .details .description {
	margin-top: 10px;
	font-size: 14px;
	line-height: 24px;
  }
  
  .comments .form-control:focus {
	border-color: #484848;
  }
  
  .comments textarea.form-control {
	height: 180px;
	resize: none;
  }
  
  .comments .btn {
	padding-left: 25px;
	padding-right: 25px;
  }
  
  .comments form {
	margin-top: 30px;
  }
  
  .alert h4 {
	font-size: 16px;
	font-weight: 600;
  }
  
  .article-list {
	position: relative;
  }
  
  .article-list:last-child {
	margin-bottom: 0;
  }
  
  .article-list .badge {
	position: absolute;
	top: 0;
	right: 15px;
	border-radius: 0;
	background-color: #F73F52;
  }
  
  .article-list .inner {
	display: inline-block;
	width: 100%;
  }
  
  .article-list figure {
	width: 300px;
	height: 195px;
	overflow: hidden;
	/*
	background-color: #000;
	*/
	float: left;
	display: inline-block;
	margin-bottom: 0;
  }
  
  .article-list figure img {
	width: 100%;
  }
  
  .article-list .details {
	padding: 5px;
	margin-left: 315px;
	height: 195px;
  }
  
  @media screen and (max-width: 768px) {
	.article-list figure {
	  width: 100%;
	  height: 200px;
	  margin-bottom: 10px;
	}
  
	.article-list .details {
	  margin-left: 0;
	}
  
	.article-list .details .detail {
	  display: inline-flex;
	  display: -webkit-inline-box;
	}
  }
  
/*--------------------------------------------------------------
# term
--------------------------------------------------------------*/
.term h5 {
	color: #000000;
	font-size: 20px;
	font-weight: 600;
}

.term ul,
ol {
	color: #000000;
	font-size: 17px;
	font-weight: 500;
	margin-left: 40px;
}

.term p {
	color: #000000;
	font-size: 18px;
	font-weight: 500;
}

.term small {
	color: #000000;
	font-size: 14px;
	font-weight: 500;
}



/* =========================================================================================
   # flow Area css
============================================================================================ */

.flow-area {
	width: 100%;
	background: #FFFFFF;
}

.flow_row {
	margin-top: 50px;
	background-image: url(../images/flow/flow2.png);
	background-repeat: no-repeat;
	background-position: 5px -34px;
	background-position-x: center;
}

@media (max-width: 767px) {
	.flow_row {
		background-image: none;
	}
}

.flow .section-heading p {
	text-align: center;
}

.flow_dots {
	position: absolute;
	top: -137px;
	left: 0;
	width: 100%;
	height: 100%;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
}

.flow_icon_container {
	width: 143px;
	height: 143px;
	border-radius: 50%;
	background: #d5dfe3;
}

.flow_col:nth-child(3) .flow_icon_container {
	background: #1befc5;
}

.flow_icon_container::before {
	position: relative;
	top: 70%;
	left: 46%;
	-webkit-transform: translate(-50%, -50%);
	-moz-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	-o-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
	width: 188px;
	height: 188px;
	border-radius: 50%;
	z-index: 0;
	background: rgba(213, 223, 227, 0.25);
	content: '';
}

.flow_col:nth-child(3) .flow_icon_container::before {
	background: rgba(27, 239, 197, 0.25);
}

.flow_icon {
	width: 56px;
	height: 56px;
}

.flow_icon img {
	max-width: 100%;
}

.flow_item_content {
	padding-top: 15px;
	padding-bottom: 30px;
}

.flow_item_content i {
	padding-right: 5px;
}

.flow_item_content p {
	color: #3e3e3e;
	font-size: 17px;
	line-height: 30px;
	font-weight: 500;
	text-align: left
}


.flow h3 {
	font-size: 24px;
	font-weight: 700;
	color: #1f1d22;
	line-height: 1.2;
}

.flow p {
	margin-top: 27px;
	font-size: 17px;
	line-height: 24px;
	font-weight: 600;
	text-align: left;
	color: #222222;
}

.flow i {
	font-size: 24px;
	font-weight: 700;
	color: #f3cf00;
	margin-right: 10px;
}

.flow_button {
	width: 257px;
	height: 63px;
	border-radius: 12px;
	background: #715691;
	margin-top: 86px;
}

.flow_button:hover {
	background: #1befc5;
}

.flow_button a {
	display: block;
	font-size: 16px;
	font-weight: 700;
	color: #FFFFFF;
	line-height: 63px;
}



/*--------------------------------------------------------------
# flow
--------------------------------------------------------------*/
.flow .info {
	margin-bottom: 20px;
	overflow: hidden;
	text-align: center;
	border-radius: 5px;
	background: #fff;
	box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
	width: 100%;
}

.flow .info .info-img {
	position: relative;
	overflow: hidden;
}

.flow .info .social {
	position: absolute;
	left: 0;
	bottom: 0;
	right: 0;
	height: 40px;
	background: rgba(35, 180, 250, 0.85);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	color: #FFF;
	font-weight: 600;
	/*
	opacity: 0;
	transition: ease-in-out 0.3s;
	*/
}

.flow .info .social a {
	transition: color 0.3s;
	color: #222222;
	margin: 0 10px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
}

.flow .info .social a i {
	line-height: 0;
}

.flow .info .social a:hover {
	color: #f82250;
}

.flow .info .social i {
	font-size: 18px;
	margin: 0 2px;
}

.flow .social-2 {
	position: inherit;
	top: 0;
	/* left: 0; */
	/* right: 0; */
	height: 60px;
	background: #00b5d0;
	display: inline-flex;
	justify-content: center;
	align-items: center;
	color: #ffffff;
	font-weight: 600;
	width: 100%;
	font-size: 20px;
	border-bottom: 5px solid #ddd9;
	margin: 0px 0px 10px 0px;
	border-radius: 3px;
	/*
	opacity: 0;
	transition: ease-in-out 0.3s;
	*/
}

.flow .info .info-info {
	padding: 15px 15px;
}

.flow .info .info-info h4 {
	font-weight: 700;
	margin-bottom: 5px;
	font-size: 18px;
	color: #222222;
}

.flow .info .info-info h4 span {
	display: block;
	font-size: 13px;
	font-weight: 400;
	color: #aaaaaa;
	right: 0%;
}

.flow .info p {
	font-weight: 600;
	margin-top: 15px;
	padding: 5px;
	font-size: 20px;
	font-weight: 600;
	color: #000000;
	text-align: left;
}

.flow .info p i {
	color: #f82250;
	margin-right: 10px;
}

.flow .info:hover .social {
	opacity: 1;
}

/* :: flow　FAQ-area */



.tab-wrap {
	display: flex;
	flex-wrap: wrap;
	margin: 20px 0;
}

.tab-wrap:after {
	content: '';
	width: 100%;
	height: 3px;
	background: #325A8C;
	display: block;
	order: -1;
}

.tab-label {
	font-size: 16px;
	color: White;
	background: LightGray;
	font-weight: bold;
	white-space: nowrap;
	text-align: center;
	padding: 10px .5em;
	order: -1;
	position: relative;
	z-index: 1;
	cursor: pointer;
	border-radius: 5px 5px 0 0;
	flex: 1;
}

.tab-label:not(:last-of-type) {
	margin-right: 5px;
}

.tab-content {
	width: 100%;
	height: 0;
	overflow: hidden;
	opacity: 0;
}

.tab-switch:checked+.tab-label {
	background: #325A8C;
}

.tab-switch:checked+.tab-label+.tab-content {
	height: auto;
	overflow: auto;
	padding: 15px;
	opacity: 1;
	transition: .5s opacity;
	box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);
}

.tab-switch {
	display: none;
}




.tab-switch:checked+.tab-label:after {
	top: 100%;
	left: 50%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: absolute;
	pointer-events: none;
	border-color: rgba(136, 183, 213, 0);
	border-top-color: #325a8c;
	border-width: 14px;
	margin-left: -14px;
}

.tab-switch:checked+.tab-label {
	background: #325A8C;
	position: relative;
}




.faq-area {
	background: url(../images/flow/bg1.jpg) no-repeat;
	margin: 40px 0px;
}

#faq-links {
	padding: 10px 20px;
	display: ruby;
	text-align: center;
}

#faq-links div {
	background-color: #fff;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
	position: relative;
	z-index: 1;
	display: inline-block;
	max-width: 180px;
	min-width: 70px;
	height: 45px;
	color: #000;
	border: 1px solid #000;
	border-radius: 5px;
	padding: 0 30px;
	font-size: 16px;
	font-weight: 600;
	line-height: 43px;
	text-transform: capitalize;
	cursor: pointer;
	margin: 5px 15px;
}

#faq-links div i {
	margin-right: 5px;
}

#faq-links div:hover,
#faq-links div:focus {
	font-size: 16px;
	font-weight: 600;
	background-color: #000000;
	color: #fff;
}

@media (max-width: 991px) {
	#faq-links {
		padding: 10px 10px;
	}

	#faq-links div {
		padding: 0 10px;
		margin: 5px;
	}

	#faq-links div span {
		display: none;
	}

	#faq-links div i {
		display: none;
	}

}

.faq-group {
	padding: 0px 0px 0px 0px;
	position: relative
}

.faq-group div {
	font-weight: 700;
	text-align: center;
}

.faq-group hr {
	border: 0;
	border-top: 3px solid #ffd400;
	clear: both;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	box-sizing: content-box;
	height: 0;
}

.faq-group:after {
	left: 1.8%;
	border: solid transparent;
	content: " ";
	height: 0;
	width: 0;
	position: relative;
	pointer-events: none;
	border-top-color: #ffd400;
	border-width: 15px;
	margin-left: -15px
}

.faq-accordion ul {
	list-style: none;
}

.faq-accordion>li {
	list-style: none;
	border-top: 1px solid rgba(198, 198, 198, 0.4);
	color: #666;
	padding: 1.125em 0
}

.faq-accordion li a {
	color: #000000;
	padding: 0.25em;
	font-size: 20px;
	font-weight: 600;
}

.faq-accordion>li:last-child {
	border-bottom: 1px solid rgba(198, 198, 198, 0.4);
}

.faq-accordion>li>a:before {
	content: 'Q.';
	padding-right: 0.313em
}

/*
  .faq-accordion>li>a:after {
	color: #ff8300;
	content: '+';
	float: right;
	font-weight: 600;
	margin-right: 1.25em;
	-webkit-transform: scale(2);
	-ms-transform: scale(2);
	transform: scale(2);
	overflow-y: hidden;
  }

  */

.faq-accordion>li>a.expanded:after {
	color: #ffa326;
	content: '\2212';
	-webkit-transform: scale(2);
	-ms-transform: scale(2);
	transform: scale(2);
}

.faq-accordion>li>a.expanded {
	font-weight: 600;
	opacity: 1 !important
}

.faq-content {
	background-color: #fbf7f7;
	margin: 20px 0 -20px;
}

.faq-content p:before {
	content: 'A.';
	color: #ff8300;
	float: left;
	font-weight: 700;
	margin-right: .5em
}

.faq-content p {
	margin: 0 1.2em;
	padding: 1.250em 0
}

.faq-hide {
	display: none
}

.faq-selected {
	color: #49494b !important;
	-webkit-transition: all 1s ease;
	transition: all 1s ease;
}


.slide-left {
	-webkit-animation-name: slide-left;
	-moz-animation-name: slide-left;
	animation-name: slide-left;
	-webkit-animation-duration: 1s;
	-moz-animation-duration: 1s;
	animation-duration: 1s;
	-webkit-animation-timing-function: ease-in-out;
	-moz-animation-timing-function: ease-in-out;
	animation-timing-function: ease-in-out;
}




/*--------------------------------------------------------------
# Pricing
--------------------------------------------------------------*/

.box-pricing {
	position: relative;
	overflow: hidden;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 30px;
	/*--
	padding: 30px 15px;
	----*/
	border-radius: 5px;
	box-shadow: 0 0 10px 0 rgba(0, 0, 0, 0.17);
}

.box-pricing .button {
	border-bottom-right-radius: 8px;
	border-bottom-left-radius: 8px;
}

.box-pricing small {
	font-size: 14px;
	color: #373535;
}

.box-pricing-black {
	color: #000000;
	background: #ffffff;
}

/*--
.box-pricing-black .box-pricing-time, .box-pricing-black .box-pricing-price, .box-pricing-black .box-pricing-title {
	color: inherit;
}
--*/
.box-pricing-black .divider {
	background: rgba(225, 225, 225, 0.2);
}

.box-pricing-black .box-pricing-list>li {
	color: #5d6264;
	font-size: 16px;
}

.box-pricing-black .box-pricing-list>li::before {
	color: #5d6264;
}

.box-pricing-black .box-pricing-list>li.active {
	color: inherit;
}

.box-pricing-black .box-pricing-list>li.active::before {
	color: #22b3f9;
}

.box-pricing-black .box-pricing-list>li.na {
	color: #ccc;
	text-decoration: line-through;
}

.box-pricing-black .box-pricing-list>li.na::before {
	color: #ccc;
}

.box-pricing-black .button-gray-4,
.box-pricing-black .button-gray-4:focus {
	color: #ffffff;
	background-color: #494c51;
	border-color: #494c51;
}

.box-pricing-divider {
	position: relative;
	padding: 20px 1px 2px 1px;
}

.box-pricing-divider>span {
	display: inline-block;
	position: absolute;
	top: 70%;
	left: 50%;
	font-size: 55px;
	line-height: 1;
	font-weight: 500;
	letter-spacing: .05em;
	color: rgba(255, 255, 255, 0.05);
	transform: translate3d(-50%, -50%, 0);
	will-change: transform;
	white-space: nowrap;
}

.box-pricing-divider>img {
	display: inline-block;
	position: absolute;
	width: 150px;
	margin: 0px 30px;
	mix-blend-mode: multiply;
}

.box-pricing-divider2 {
	position: relative;
	padding: 10px 0;
}

.box-pricing-divider2>span {
	display: inline-block;
	position: absolute;
	top: 70%;
	left: 50%;
	font-size: 55px;
	line-height: 1;
	font-weight: 500;
	letter-spacing: .05em;
	color: rgba(255, 255, 255, 0.05);
	transform: translate3d(-50%, -50%, 0);
	will-change: transform;
	white-space: nowrap;
}

.box-pricing-divider2>img {
	display: inline-block;
	position: absolute;
	width: 150px;
	margin: 15px 0px 0px 43px;
	mix-blend-mode: multiply;
}

.box-pricing-divider3 {
	position: relative;
	padding: 20px 1px 2px 1px;
}

.box-pricing-divider3>img {
	display: inline-block;
	position: absolute;
	mix-blend-mode: multiply;
	margin: -30px 0px;
}

.box-pricing-popular .box-pricing-badge {
	display: inline-block;
}

.box-pricing-body {
	text-align: center;
	max-width: 350px;
	margin-left: auto;
	margin-right: auto;
}

.box-pricing-title {
	font-size: 28px;
	letter-spacing: .1em;
	font-weight: 600;
	margin: 10px 0px 50px 0px;
	color: #ffffff !important;
	position: absolute;
	top: 4%;
	right: 45%;
}

@media screen and (max-width:482px) {
	.box-pricing-title {
		top: 2%;
		right: 45%;
	}
}

.box-pricing-time {
	font-size: 16px;
	line-height: 18px;
	font-weight: 600;
}

.info2 {
	color: #22b3f9;
	/*
    background-color: rgba(255, 255, 245, 0.24);
	*/
	margin: 5px;
	padding: 2px;
	font-size: 16px;
}

.box-pricing-button {
	margin-top: 40px;
	margin-left: -15px;
	margin-right: -15px;
}

.box-pricing-list {
	text-align: left;
}

.box-pricing-list>li {
	text-indent: -25px;
	padding-left: 25px;
	color: #9b9b9b;
	line-height: 10px;
}

.box-pricing-list>li::before {
	position: relative;
	display: inline-block;
	content: '\f633';
	left: 0;
	top: 3px;
	width: 25px;
	font-size: 15px;
	line-height: 1;
	text-indent: 0;
	font-family: "bootstrap-icons";
	color: #9b9b9b;
}

.box-pricing-list>li.active {
	color: #151515;
}

.box-pricing-list>li.active::before {
	color: #6689ff;
}

.box-pricing-list>li+li {
	margin-top: 14px;
}

.box-pricing-list2 {
	text-align: left;
}

.box-pricing-list2>li {
	text-indent: -25px;
	padding-left: 25px;
	color: #9b9b9b;
	line-height: 10px;
}

.box-pricing-list2>li::before {
	position: relative;
	display: inline-block;
	content: '\f633';
	left: 0;
	top: 3px;
	width: 25px;
	font-size: 15px;
	line-height: 1;
	text-indent: 0;
	font-family: "bootstrap-icons";
	color: #39C;
}

.box-pricing-list2>li.active {
	color: #151515;
}

.box-pricing-list2>li.active::before {
	color: #6689ff;
}

.box-pricing-list2>li+li {
	margin-top: 14px;
}

.box-pricing-badge {
	position: absolute;
	top: 15px;
	right: 15px;
	display: none;
	padding: 10px 20px;
	font-size: 14px;
	line-height: 1;
	font-weight: 600;
	letter-spacing: .075em;
	color: #ffffff;
	background: #0dc7ff;
	border-radius: 20px;
}

*+.box-pricing-price {
	font-size: 30px;
	margin: 8px 0px 5px 0px;
}

*+.box-pricing-time {
	margin-top: 6px;
}

*+.box-pricing-list {
	margin-top: 30px;
}

.divider+.box-pricing-list {
	margin-top: 0px;
}

.box-pricing-divider+.box-pricing-list {
	margin: 10px;
}

@media (min-width: 576px) {
	.box-pricing-divider>span {
		font-size: 40px;
		color: rgba(255, 246, 112, 0.1);
	}
}

@media (min-width: 992px) {
	.box-pricing-divider>span {
		font-size: 40px;
	}
}

.pricing .box {
	padding: 20px;
	background: #f9f9f9;
	text-align: center;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
	border: 2px solid #f9f9f9;
}

.pricing .box h3 {
	font-weight: 400;
	padding: 15px;
	margin-top: 15px;
	font-size: 18px;
	font-weight: 600;
	color: #222222;
}

.pricing .box h4 {
	font-size: 42px;
	color: #f82250;
	font-weight: 500;
	font-family: "Open Sans", sans-serif;
	margin-bottom: 20px;
}

.pricing .box h4 sup {
	font-size: 20px;
	top: -15px;
	left: -3px;
}

.pricing .box h4 span {
	color: #bababa;
	font-size: 16px;
	font-weight: 300;
}

.pricing .box ul {
	padding: 0;
	list-style: none;
	color: #222222;
	text-align: center;
	line-height: 20px;
	font-size: 16px;
}

.pricing .box ul li {
	padding-bottom: 16px;
}

.pricing .box ul i {
	color: #f82250;
	font-size: 18px;
	padding-right: 4px;
}

.pricing .box ul .na {
	color: #ccc;
	text-decoration: line-through;
}

.pricing .box .btn-wrap {
	padding: 15px;
	text-align: center;
}

.pricing .box .btn-buy {
	display: inline-block;
	padding: 10px 40px 12px 40px;
	border-radius: 50px;
	border: 2px solid #f82250;
	color: #f82250;
	font-size: 14px;
	font-weight: 400;
	font-family: "Raleway", sans-serif;
	font-weight: 600;
	transition: 0.3s;
}

.pricing .box .btn-buy:hover {
	background: #f82250;
	color: #fff;
}

.pricing .recommended {
	border-color: #f82250;
}

.pricing .recommended .btn-buy {
	background: #f82250;
	color: #fff;
}

.pricing .recommended .btn-buy:hover {
	background: #2383c4;
	border-color: #2383c4;
}

.price .option {
	margin-bottom: 20px;
	overflow: hidden;
	text-align: center;
	border-radius: 5px;
	background: #fff;
	box-shadow: 0px 2px 15px rgba(0, 0, 0, 0.1);
}

.price .option .option-img {
	position: relative;
	overflow: hidden;
}

.price .option .social {
	position: absolute;
	left: 0;
	bottom: 0;
	right: 0;
	height: 40px;
	background: rgba(35, 180, 250, 0.85);
	display: inline-flex;
	justify-content: center;
	align-items: center;
	color: #FFF;
	font-weight: 600;
	/*
	opacity: 0;
	transition: ease-in-out 0.3s;
	*/
}

.price .option .social a {
	transition: color 0.3s;
	color: #222222;
	margin: 0 10px;
	display: inline-flex;
	justify-content: center;
	align-items: center;
}

.price .option .social a i {
	line-height: 0;
}

.price .option .social a:hover {
	color: #f82250;
}

.price .option .social i {
	font-size: 18px;
	margin: 0 2px;
}

.price .option .option-info {
	padding: 15px 15px;
}

.price .option .option-info h4 {
	font-weight: 700;
	margin-bottom: 5px;
	font-size: 18px;
	padding: 5px 10px;
	color: #ffffff;
	border-radius: 5px;
	border-bottom: 3px solid #b9b9b9;
	background-color: #545454;
}


.price .option .option-info h4 span {
	display: block;
	font-size: 13px;
	font-weight: 400;
	color: #aaaaaa;
	right: 0%;
}

.price .option .option-price-1 {
	font-weight: 700;
	margin-bottom: 0px;
	font-size: 22px;
	line-height: normal;
	text-align: center;
	padding: 5px 5px;
	color: #222222;
}

.price .option .option-price-1 small {
	font-weight: 700;
	margin-bottom: 0px;
	font-size: 14px;
	line-height: normal;
	text-align: center;
	padding: 5px 10px;
	color: #222222;
}

.price .option .option-price-2 {
	font-weight: 600;
	font-size: 14px;
	text-align: center;
	color: #222222;
}

.price .option .option-price {
	font-weight: 700;
	margin-bottom: 0px;
	font-size: 22px;
	text-align: left;
	line-height: 22px;
	padding: 5px 5px;
	color: #222222;
}

.price .option .option-price small {
	font-weight: 700;
	margin-bottom: 5px;
	font-size: 12px;
}

.price .option .option-price span {
	font-weight: 600;
	font-size: 15px;
}

.price-info {
	color: #f82250;
	border-color: #b6effb;
	font-size: 15px;
	/* background: #08236e; */
	padding: 0px 7px;
}

.price small {
	font-weight: 500;
	font-size: 15px;
}

/*--------------------------------------------------------------
# F.A.Q
--------------------------------------------------------------*/
.faq .faq-item {
	margin: 10px 0;
	padding: 10px 0;
	border-bottom: 1px solid #eeeeee;
}

.faq .faq-item i {
	color: #F60;
	font-size: 30px;
	float: left;
	line-height: 0;
	margin: 0px 0px 0px -5px;
}

.faq .faq-item img {
	float: left;
	line-height: 0;
	margin: -4px 0px 0px -5px;
	width: 50px;
}

.faq .faq-item h4 {
	font-size: 16px;
	letter-spacing: 0px;
	line-height: 26px;
	font-weight: 600;
	margin: 5px 0px 10px 55px;
}

.faq .faq-item p {
	font-size: 16px;
	letter-spacing: 0px;
	line-height: 26px;
	font-weight: 600;
	margin: 5px 0px 10px 55px;
}

.faq .faq-item-2 i {
	color: #0cb7de;
	font-size: 30px;
	float: left;
	line-height: 0;
	margin: -10px 0px 0px -5px;
}

/*--------------------------------------------------------------
#　QA
--------------------------------------------------------------*/
/* ==========================
  アコーディオンメニュー
========================== */
.qa-title {
	font-size: 18px;
	font-weight: bold;
	background-color: #ededed;
	padding: 10px 10px 10px 10px;
	transition: 0.3s;
	cursor: pointer;
	position: relative;
}

.qa-title::before {
	content: "";
	width: 18px;
	height: 18px;
	border-right: 4px solid #555555;
	border-bottom: 4px solid #555555;
	position: absolute;
	transform: rotate(45deg);
	top: 25%;
	right: 3%;
	transition: 0.3s;
}

.qa-title.active::before {
	transform: rotate(225deg);
	top: 40%;
}

.qa-title:hover::before,
.qa-title.active::before {
	border-right: 4px solid #fff;
	border-bottom: 4px solid #fff;
}

.qa-title:hover,
.qa-title.active {
	background-color: #7e7e7e;
	color: #fff;
}

.qa-content {
	padding: 0 40px;
	opacity: 0;
	height: 0;
	line-height: 0;
	transition: 0.3s;
}

.qa-content>*+* {
	margin-top: 0;
}

.qa-content img {
	height: 0;
}

.qa-title

/* :not(:first-of-type)  */
	{
	border-top: 1px solid #f82250;
}

.qa-content.open {
	padding: 20px;
	opacity: 1;
	height: auto;
}

.qa-content.open>*+* {
	margin-top: 10px;
}

.qa-content.open img {
	height: auto;
}

/* ==========================
	タブ以外のコンテンツの中身
  ========================== */
.ly_inner {
	background-color: #ffffff;
}

.ly_inner h5 {
	font-size: 20px;
	font-weight: bold;
	line-height: 24px;
	padding: 10px 50px 10px 10px;
}

.ly_inner p {
	font-size: 18px;
	font-weight: bold;
	line-height: 24px;
	;
}

.ly_inner img {
	width: 50px;
	margin-right: 10px;
}

.ly_inner .bi-question-square-fill {
	color: #ffc400;
	background-color: #555555;
	font-size: 26px;
	font-weight: 700;
}


.md_textblock>*+* {
	margin-top: 10px;
}

.md_markList {
	list-style-type: disc;
	margin-left: 1.4rem;
}





/*--------------------------------------------------------------
#　HIKAKU
--------------------------------------------------------------*/

.f10 {
	font-size: 10px;
	margin-top: -5px;
	font-weight: 600;
	color: #f82250;
}

.table-price {
	border-collapse: collapse;
	margin: 0 auto;
	padding: 0;
	width: 100%;
	table-layout: fixed;
}

.table-price thead th {
	padding: 1em .8em;
	border-right: 5px solid#fff;
	text-align: center;
}

.table-price tr {
	background-color: #fff;
	padding: .35em;
}

.table-price tr:nth-child(even) {
	background-color: #f9f9f9;
}

.table-price td {
	padding: .7em;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
}

.table-price th {
	font-size: 16px;
	padding: 5px;
}

.table-price i {
	font-size: 20px;
}

.table-price img {
	max-width: 80px;
}

.table-price .small {
	font-size: 80% !important;
}

table-price .price {
	color: #fff;
	font-weight: 600;
	font-size: 14px;
	text-align: center !important;
	margin-bottom: 10px
}

table-price .price span {
	font-size: .6em;
}

.table-price .btn {
	background: #fff;
	color: #000;
	padding: 2px;
	border-radius: 3px;
	display: block;
	text-decoration: inherit;
	font-size: 20px;
	font-weight: 600;
}

.table-price .plan1 {
	background: #f39800;
}

.table-price .plan1_i {
	color: #000000;
	border-right: 1px solid #f39800;
	border-left: 1px solid #f39800;
	line-height: 18px;
}

.table-price .plan2 {
	background: #838383;
}

.table-price .plan2_i {
	color: #3d3c3c;
	border-right: 1px solid #838383;
	line-height: 18px;
}

.table-price .plan3 {
	background: #838383;
}

.table-price .plan3_i {
	color: #3d3c3c;
	border-right: 1px solid #838383;
	line-height: 18px;
}

.table-price .plan4 {
	background: #838383;
}

.table-price .plan4_i {
	color: #3d3c3c;
	border-right: 1px solid #838383;
	line-height: 18px;
}

.table-price .plan5 {
	background: #004df3;
}

.table-price .plan6 {
	background: #f39800;
}



.table-price-2 {
	border-collapse: collapse;
	margin: 0 auto;
	padding: 0;
	width: 100%;
	table-layout: fixed;
}

.table-price-2 thead th {
	padding: 1em .8em;
	border-right: 5px solid#fff;
	font-size: 14px;
	color: #FFF;
	text-align: center;
}

.table-price-2 tr {
	background-color: #fff;
	padding: .35em;
}

.table-price2 tr:nth-child(even) {
	background-color: #f9f9f9;
}

.table-price-2 td {
	padding: .2em;
	text-align: center;
	font-size: 16px;
	font-weight: 600;
}

.table-price-2 th {
	font-size: 16px;
	padding: 5px;
}

.table-price-2 i {
	font-size: 20px;
}

.table-price-2.small {
	font-size: 80% !important;
}

.table-price-2 .price {
	color: #fff;
	font-weight: 600;
	font-size: 14px;
	text-align: center !important;
	margin-bottom: 10px
}

.table-price-2 .price span {
	font-size: .6em;
}

.table-price-2 .btn {
	background: #fff;
	color: #000;
	padding: 2px;
	border-radius: 3px;
	display: block;
	text-decoration: inherit;
	font-size: 90%;
	font-weight: 600;
}

.table-price-2 .plan1 {
	background: #0214e7;
	display: block;
}

.table-price-2 .plan1_i {
	color: #0214e7;
}

.table-price-2 .plan2 {
	background: #185803;
}

.table-price-2 .plan2_i {
	color: #185803;
}

.table-price-2 .plan3 {
	background: #4caf50;
}

.table-price-2 .plan3_i {
	color: #4caf50;
}

.table-price-2 .plan4 {
	background: #04a5d5;
}

.table-price-2 .plan4_i {
	color: #04a5d5;
}

@media screen and (max-width:482px) {
	.table-price img {
		max-width: 45px;
	}

	.table-price th {
		font-size: 12px;
		padding: 5px;
	}

	.table-price .plan1_i {
		font-size: 12px;
		line-height: 12px;
	}

	.table-price .plan2_i {
		font-size: 12px;
		line-height: 12px;
	}

	.table-price .plan3_i {
		font-size: 12px;
		line-height: 12px;
	}

	.table-price .plan4_i {
		font-size: 12px;
		line-height: 12px;
	}
}

/*--------------------------------------------------------------
# Contact
--------------------------------------------------------------*/
.contact .contact-about h3 {
	font-size: 28px;
	margin: 0 0 10px 0;
	padding: 0;
	line-height: 1;
	font-weight: 700;
	letter-spacing: 1px;
	color: #222222;
}

.contact .contact-about p {
	font-size: 14px;
	line-height: 24px;
	font-family: "Raleway", sans-serif;
	color: #888;
}

.contact .social-links {
	padding-bottom: 20px;
}

.contact .social-links a {
	font-size: 18px;
	display: inline-block;
	background: #fff;
	color: #f82250;
	line-height: 1;
	padding: 8px 0;
	margin-right: 4px;
	border-radius: 50%;
	text-align: center;
	width: 36px;
	height: 36px;
	transition: 0.3s;
	border: 1px solid #f82250;
}

.contact .social-links a:hover {
	background: #f82250;
	color: #fff;
}

.contact .info {
	color: #444444;
}

.contact .info i {
	font-size: 32px;
	color: #f82250;
	float: left;
	line-height: 1;
}

.contact .info p {
	padding: 0 0 10px 42px;
	line-height: 28px;
	font-size: 14px;
}

.contact .php-email-form .error-message {
	display: none;
	color: #fff;
	background: #ed3c0d;
	text-align: left;
	padding: 15px;
	font-weight: 600;
}

.contact .php-email-form .error-message br+br {
	margin-top: 25px;
}

.contact .php-email-form .sent-message {
	display: none;
	color: #fff;
	background: #18d26e;
	text-align: center;
	padding: 15px;
	font-weight: 600;
}

.contact .php-email-form .loading {
	display: none;
	background: #fff;
	text-align: center;
	padding: 15px;
}

.contact .php-email-form .loading:before {
	content: "";
	display: inline-block;
	border-radius: 50%;
	width: 24px;
	height: 24px;
	margin: 0 10px -6px 0;
	border: 3px solid #18d26e;
	border-top-color: #eee;
	-webkit-animation: animate-loading 1s linear infinite;
	animation: animate-loading 1s linear infinite;
}

.contact .php-email-form .form-group {
	margin-bottom: 20px;
}

.contact .php-email-form input,
.contact .php-email-form textarea {
	border-radius: 0;
	box-shadow: none;
	font-size: 14px;
	padding: 10px 15px;
}

.contact .php-email-form input:focus,
.contact .php-email-form textarea:focus {
	border-color: #f82250;
}

.contact .php-email-form button[type="submit"] {
	background: #f82250;
	border: 0;
	padding: 10px 24px;
	color: #fff;
	transition: 0.4s;
	border-radius: 50px;
}

.contact .php-email-form button[type="submit"]:hover {
	background: #e41c47;
}

@-webkit-keyframes animate-loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

@keyframes animate-loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}



/* =========================================================================================
   # column Area css
============================================================================================ */

.column-area {
	padding-top: 100px;
}

.column-area p {
	font-size: 16px;
	line-height: 26px;
	font-weight: 600;
	text-align: left;
	color: #000;
}

.column-area hr {
	color: #e7e7e7;
}

.column-box {
	position: relative;
	z-index: 1;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
}

.column-box img {
	width: 100%;
}

.column-box .event-text {
	text-align: center;
	position: relative;
	z-index: 1;
	padding: 15px 15px;
	height: 125px;
	background-color: #000;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
}

.column-box .event-text h3 {
	font-size: 16px;
	font-weight: 500;
	color: #fff;
	text-align: left;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
}

.column-box .event-text h4 {
	color: #fff;
	text-transform: uppercase;
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
}

.column-box .event-text .event-meta-data {
	position: relative;
	margin-bottom: 30px;
}

.column-box .event-text .event-meta-data a {
	-webkit-transition-duration: 500ms;
	transition-duration: 500ms;
	position: relative;
	z-index: 1;
	color: #fff;
	font-size: 15px;
	font-weight: 400;
	display: inline-block;
	padding-right: 29px;
}

.column-box .event-text .event-meta-data a:first-child::after {
	position: absolute;
	content: '|';
	top: 0;
	right: 12px;
	z-index: 1;
}

.column-box .event-text .event-meta-data a:last-child {
	padding-right: 0;
}

.column-box .event-text .see-more-btn {
	position: absolute;
	bottom: 10px;
	display: block;
	color: #84c9ff;
	width: max-content;
	font-size: 14px;
	font-weight: 600;
	line-height: 12px;
	text-align: center;
	left: 50%;
	transform: translateX(-50%);
	text-transform: uppercase;
	letter-spacing: 3px;
	border-bottom: 1px solid #84c9ff;
}

.column-box .event-text .see-more-btn:hover,
.column-box .event-text .see-more-btn:focus {
	color: #ffffff;
	border-bottom: 1px solid #ffffff;
}

.column-box:hover,
.column-box:focus {
	box-shadow: 0 5px 80px 0 rgba(0, 0, 0, 0.2);
}

.column-box:hover .event-text,
.column-box:focus .event-text {
	background-color: #a5a5a5;
}

.column-box:hover .event-text h4,
.column-box:hover .event-text .event-meta-data a,
.column-box:focus .event-text h4,
.column-box:focus .event-text .event-meta-data a {
	color: #000000;
}

.column-box:hover .event-text .see-more-btn,
.column-box:focus .event-text .see-more-btn {
	border-bottom-color: #000000;
	color: #000000;
}



/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/

#footer {
	background: url(../images/footer/cover1.png)no-repeat center fixed;
	background-position: -65px 300px;
	box-shadow: 0px 0px 12px 0px rgba(0, 0, 0, 0.1);
	color: #222222;
	font-size: 16px;
	font-weight: 600;
}

#footer .footer-info {
	font-size: 12px;
	padding-top: 5px;
	color: #222222;
}

#footer .footer-info img {
	max-width: 130px;
}

#footer .footer-newsletter {
	background: #fef8f5;
	text-align: center;
	font-size: 15px;
}

#footer .footer-newsletter h4 {
	font-size: 24px;
	margin: 0 0 20px 0;
	padding: 0;
	line-height: 1;
	font-weight: 600;
	color: #4e4039;
}

#footer .footer-top {
	padding-top: 60px;
}

#footer .footer-top h4 {
	font-size: 18px;
	margin: 0 0 30px 0;
	padding: 2px 0 2px 0;
	line-height: 1;
	font-weight: 700;
	position: relative;
}

#footer .footer-top h4::after {
	content: ' ';
	position: absolute;
	width: 15px;
	height: 2px;
	bottom: -5px;
	left: 0;
	background-color: #F73F52;
	border-bottom: 2px solid #f82250;
}

#footer .footer-top p {
	font-size: 14px;
	line-height: 17px;
	margin-bottom: 0;
}

#footer .footer-top .footer-links {
	margin-bottom: 30px;
}

#footer .footer-top .footer-links ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

#footer .footer-top .footer-links ul i {
	padding-right: 2px;
	color: #f82250;
	font-size: 20px;
	line-height: 1;
}

#footer .footer-top .footer-links ul li {
	text-indent: -25px;
	padding-left: 25px;
	color: #9b9b9b;
	font-weight: 600;
	line-height: 40px;
}

#footer .footer-top .footer-links ul li::before {
	position: relative;
	display: inline-block;
	content: '\f107';
	left: 0;
	top: 3px;
	width: 25px;
	font-size: 15px;
	line-height: 1;
	text-indent: 0;
	font-family: "bootstrap-icons";
	color: #ffcd82;
}

#footer .footer-top .footer-links ul li:first-child {
	padding-top: 0;
}

#footer .footer-top .footer-links ul a {
	color: #222222;
	transition: 0.3s;
	display: inline-block;
	line-height: 36px;
	padding-left: 22px;
}

#footer .footer-top .footer-links ul a:hover {
	text-decoration: none;
	color: #eb5d1e;
}

#footer .footer-top .social-links a {
	font-size: 18px;
	display: inline-block;
	background: #eb5d1e;
	color: #fff;
	line-height: 1;
	padding: 8px 0;
	margin-right: 4px;
	border-radius: 50%;
	text-align: center;
	width: 36px;
	height: 36px;
	transition: 0.3s;
}

#footer .footer-top .social-links a:hover {
	background: #ef7f4d;
	color: #fff;
	text-decoration: none;
}

#footer .footer-last {
	font-size: 12px;
	padding: 20px 0px 20px 0px;
	color: #555555;
	background-color: rgba(255, 255, 255, 0.3);
	margin-top: 20px;
	box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.1);
}

@media (max-width: 768px) {
	#footer .footer-top h4 {
		margin: 0 0 10px 0;
	}
}

@media (max-width: 575px) {
	#footer .footer-last {
		float: none;
		-moz-text-align-last: center;
		text-align-last: center;
		padding: 3px 0;
	}
}

/*--------------------------------------------------------------
# Breadcrumbs
--------------------------------------------------------------*/
.breadcrumbs {
	padding: 15px 0;
	min-height: 150px;
	margin-top: 86px;
}

#function {
	background: url(../images/function/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#price {
	background: url(../images/price/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#industry {
	background: url(../images/industry/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#flow {
	background: url(../images/flow/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#qa {
	background: url(../images/qa/top.jpg) no-repeat center fixed;
	background-position: 0px -600px;
}

#column {
	background: url(../images/column/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#contact {
	background: url(../images/contact/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#freeid {
	background: url(../images/freeid/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#term {
	background: url(../images/terms/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#display {
	background: url(../images/display/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#privacy {
	background: url(../images/privacy/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#security {
	background: url(../images/security/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#law {
	background: url(../images/law/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#sitemap {
	background: url(../images/sitemap/top.jpg) no-repeat center fixed;
	background-position: 0px -350px;
}

#partner {
	background: url(../images/partner/top.jpg) no-repeat center fixed;
	background-position: 0px -600px;
}

@media (max-width: 992px) {
	.breadcrumbs {
		margin-top: 72px;
	}
}

.breadcrumbs h2 {
	color: #ffffff;
	font-size: 26px;
	font-weight: 600;
	margin: 45px 0px 45px 0px;
}

.breadcrumbs h2 span {
	color: #ffffff;
	font-size: 14px;
	font-weight: 600;
	margin: 45px 0px 45px 0px;
	padding: 0px 0px 0px 10px;
}

.breadcrumbs ol {
	color: #ffffff;
	display: flex;
	flex-wrap: wrap;
	list-style: none;
	margin: 100px 0px 0px 0px;
	font-size: 12px;
}

@media (max-width: 992px) {
	.breadcrumbs ol {
		margin-top: 10px;
	}
}

.breadcrumbs ol li+li {
	padding-left: 10px;
}

.breadcrumbs ol li+li::before {
	display: inline-block;
	padding-right: 8px;
	color: #ffffff;
	content: "/";
}

@media (max-width: 768px) {
	.breadcrumbs .d-flex {
		display: block !important;
	}

	.breadcrumbs ol {
		display: block;
	}

	.breadcrumbs ol li {
		display: inline-block;
	}
}

/*------------------------------------------
    -  social   -
--------------------------------------------*/

.social {
	padding: 0;
	margin: 0;
}

.social li {
	display: inline-block;
}

.social li a {
	display: block;
	height: 68px;
	margin: 0 5px;
	margin-bottom: 10px;
	position: relative;
	transition: all .5s;
	-moz-transition: all .5s;
	-webkit-transition: all .5s;
	-o-transition: all .5s;
}

.social li a img {
	display: block;
	width: 100%;
	height: 68px;
	position: absolute;
	transition: all .5s;
	-moz-transition: all .5s;
	-webkit-transition: all .5s;
	-o-transition: all .5s;
	border-radius: 3px;
}

.social li a p {
	display: block;
	position: relative;
	color: #ffffff;
	font-weight: 600;
	line-height: 16px;
	background-color: rgba(0, 0, 0, 0.25);
	margin: 0px 3px 0px 3px;
	padding: 5px;
	top: 20%;
}

.social li a:hover p {
	color: #FFE300;
}

.social li a svg {
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}

.social li a svg rect {
	width: inherit;
	height: inherit;
	fill: transparent;
	stroke: transparent;
	stroke-dasharray: 0;
	stroke-width: 3;
	transition: all 1.5s;
	-moz-transition: all 1.5s;
	-webkit-transition: all 1.5s;
	-o-transition: all 1.5s;
	border-radius: 3px;
}

.social li a i:before {
	transform: scale(1.3);
	-webkit-transform: scale(1.3);
	-moz-transform: scale(1.3);
	-o-transform: scale(1.3);
}

.social li a:first-child {
	margin-left: 0;
}

.social li a:hover {
	opacity: .8;
}

.social.trp li a:hover {
	background-color: #333333;
}

.social.trp li a:hover svg rect {
	border-radius: 3px;
	stroke: #f73f53;
	stroke-dasharray: 200;
}

.social.trp li a.facebook:hover {
	color: #3b5998 !important;
}

.social.trp li a.facebook:hover svg rect {
	stroke: #3b5998;
}

.social.trp li a.twitter:hover {
	color: #4099FF !important;
}

.social.trp li a.twitter:hover svg rect {
	stroke: #4099FF;
}

.social.trp li a.youtube:hover {
	color: #C4302B !important;
}

.social.trp li a.youtube:hover svg rect {
	stroke: #C4302B;
}

.social.trp li a.googleplus:hover {
	color: #DE5245 !important;
}

.social.trp li a.googleplus:hover svg rect {
	stroke: #DE5245;
}

.social.trp li a.instagram:hover {
	color: #885343 !important;
}

.social.trp li a.instagram:hover svg rect {
	stroke: #885343;
}

.social.trp li a.tumblr:hover {
	color: #36465D !important;
}

.social.trp li a.tumblr:hover svg rect {
	stroke: #36465D;
}

.social.trp li a.dribbble:hover {
	color: #E14C86 !important;
}

.social.trp li a.dribbble:hover svg rect {
	stroke: #E14C86;
}

.social.trp li a.linkedin:hover {
	color: #007BB6 !important;
}

.social.trp li a.linkedin:hover svg rect {
	stroke: #007BB6;
}

.social.trp li a.skype:hover {
	color: #00AFF0 !important;
}

.social.trp li a.skype:hover svg rect {
	stroke: #00AFF0;
}

.social.trp li a.rss:hover {
	color: #ee802f !important;
}

.social.trp li a.rss:hover svg rect {
	stroke: #ee802f;
}

.social.trp li a.github:hover {
	color: #000 !important;
}

.social.trp li a.github:hover svg rect {
	stroke: #000;
}

.social.trp li a.whatsapp:hover {
	color: #25D366 !important;
}

.social.trp li a.whatsapp:hover svg rect {
	stroke: #25D366;
}

.social.trp li a.snapchat:hover {
	color: #FFFC01 !important;
}

.social.trp li a.snapchat:hover svg rect {
	stroke: #FFFC01;
}

.social.trp li a.foursquare:hover {
	color: #EF4B78 !important;
}

.social.trp li a.foursquare:hover svg rect {
	stroke: #EF4B78;
}

.social.trp li a.pinterest:hover {
	color: #B82B38 !important;
}

.social.trp li a.pinterest:hover svg rect {
	stroke: #B82B38;
}

.social.trp li a.wordpress:hover {
	color: #21759A !important;
}

.social.trp li a.wordpress:hover svg rect {
	stroke: #21759A;
}

.social.trp li a.reddit:hover {
	color: #1288DF !important;
}

.social.trp li a.reddit:hover svg rect {
	stroke: #1288DF;
}

.social.trp li a.hackernews:hover {
	color: #FF6600 !important;
}

.social.trp li a.hackernews:hover svg rect {
	stroke: #FF6600;
}

.social.trp li a.designernews:hover {
	color: #3275D6 !important;
}

.social.trp li a.designernews:hover svg rect {
	stroke: #3275D6;
}

.social.trp li a.yahoo:hover {
	color: #420297 !important;
}

.social.trp li a.yahoo:hover svg rect {
	stroke: #420297;
}

.social.trp li a.buffer:hover {
	color: #000000 !important;
}

.social.trp li a.buffer:hover svg rect {
	stroke: #000000;
}

.social.trp li a.vimeo:hover {
	color: #1AB7EA !important;
}

.social.trp li a.vimeo:hover svg rect {
	stroke: #1AB7EA;
}

.social.trp li a.twitch:hover {
	color: #6441A4 !important;
}

.social.trp li a.twitch:hover svg rect {
	stroke: #6441A4;
}

/*------------------------------------------
    -    -
--------------------------------------------*/
/*------------------------------------------
    -    -
--------------------------------------------*/


/*CheckBox */
label.checkbox {
	cursor: pointer;
	width: 20px;
	height: 20px;
	border: 1px solid #B3B3B3;
	background: #fff;
	overflow: hidden;
	position: relative;
	display: inline-block;
	box-sizing: border-box;
}

label.checkbox input[type="checkbox"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	margin: 0;
	padding: 0;
	position: absolute;
	left: 20px;
	width: 20px;
	height: 20px;
	left: -40px;
	box-shadow: 39px 0px #FFF;
	z-index: 2;
}

label.checkbox input[type="checkbox"]:checked {
	box-shadow: none;
}

label.checkbox input[type="checkbox"]:checked:focus {
	box-shadow: 39px 0px #666;
	opacity: 0.1;
}

label.checkbox input[type="checkbox"]:focus {
	box-shadow: 39px 0px #EEE;
}

label.checkbox:after {
	content: '';
	position: absolute;
	top: 50%;
	left: 5px;
	display: block;
	margin-top: -8px;
	width: 8px;
	height: 12px;
	border-right: 3px solid #D65;
	border-bottom: 3px solid #D65;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	z-index: 1;
}

/* CheckBoxとText */
label.checkbox_text {
	cursor: pointer;
	position: relative;
	padding-left: 25px;
	margin-right: 20px;
	overflow: hidden;
	position: relative;
	padding-left: 25px;
	display: inline-block;
	box-sizing: border-box;
	line-height: 22px;
	color: #222222 !important;
	font-size: 15px;
}

label.checkbox_text:before {
	content: '';
	position: absolute;
	width: 20px;
	height: 20px;
	left: 0px;
	top: 0px;
	border: 1px solid #B3B3B3;
	z-index: 3;
}

label.checkbox_text:after {
	content: '';
	position: absolute;
	top: 55%;
	left: 2px;
	display: block;
	margin-top: -15px;
	width: 14px;
	height: 20px;
	border-right: 4px solid #D65;
	border-bottom: 4px solid #D65;
	transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	z-index: 1;
}

@media screen and (max-width: 482px) {
	label.checkbox_text:after {
		content: '';
		position: absolute;
		top: 55%;
		left: 2px;
		display: block;
		width: 14px;
		height: 20px;
		border-right: 4px solid #D65;
		border-bottom: 4px solid #D65;
		transform: rotate(45deg);
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		z-index: 1;
	}
}

label.checkbox_text input[type="checkbox"] {
	-moz-appearance: none;
	-webkit-appearance: none;
	position: absolute;
	left: -40px;
	width: 20px;
	height: 20px;
	display: block;
	box-shadow: 41px 0px #FFF;
	z-index: 2;
	margin: 0px;
	padding: 0px;
}

label.checkbox_text input[type="checkbox"]:checked {
	box-shadow: none;
}

label.checkbox_text input[type="checkbox"]:checked:focus {
	box-shadow: 40px 0px #666;
	opacity: 0.1;
}

label.checkbox_text input[type="checkbox"]:focus {
	box-shadow: 41px 0px #EEE;
}


.btm-yoko {
	display: flex;
	/*コレ*/
	width: 100%;
	margin: 0;
}

.btm-yoko>div {
	width: 48%;
	margin: 0 1%;
	background: #FFF;
}


/*--------------------------------------------------------------
# Back to top button
--------------------------------------------------------------*/


.back-to-top {
	position: fixed;
	visibility: hidden;
	opacity: 0;
	right: 15px;
	bottom: 5px;
	z-index: 99999;
	width: 60px;
	height: 35px;
	border-radius: 4px 4px 0 0;
	border: 2px solid #57cbcc;
	transition: all 0.4s;
	color: #57cbcc;
	background-color: rgba(255, 255, 255, 0.1);
	font-weight: 600;
}

.back-to-top i {
	font-size: 18px;
}

.back-to-top:hover {
	background-color: #4ac4c5;
	color: #ffffff;
}

.back-to-top.active {
	visibility: visible;
	opacity: 1;
}


/********************** modal ***********************************/

.modal-wrapper {
	z-index: 999;
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 40px 10px;
	text-align: center;
}

.modal-button {
	color: #4f96f6;
	border: 1px solid #2c80ee;
	background-color: #ffffff;
	font-weight: 600;
	text-align: center;
	cursor: pointer;
	transition: all 0.3s;
	padding: 0px 10px;
	border-radius: 5px;
	max-width: 300px;
	text-decoration: none;
	margin: 10px 10px;
}

.modal-button:active {
	/*ボタンを押したとき*/
	-webkit-transform: translateY(2px);
	transform: translateY(2px);
	/*下に動く*/

}

/*アイコンを表示*/
.modal-button:after {
	padding-left: 8px;
}

/*ラベルホバー時*/
.modal-button:hover {
	color: #FFFFFF;
	background-color: #4f96f6;
	transition: .6s;
}

.modal-wrapper:not(:target) {
	opacity: 0;
	visibility: hidden;
	transition: opacity .3s, visibility .3s;
}

.modal-wrapper:target {
	opacity: 1;
	visibility: visible;
	transition: opacity .4s, visibility .4s;
}

.modal-wrapper::after {
	display: inline-block;
	height: 100%;
	margin-left: -.05em;
	vertical-align: middle;
	content: ""
}

.modal-wrapper .modal-window {
	box-sizing: border-box;
	display: inline-block;
	z-index: 20;
	position: relative;
	width: 70%;
	max-width: 1000px;
	padding: 20px 5px 10px 15px;
	border-radius: 5px;
	background: #fff;
	box-shadow: 0 0 30px rgba(0, 0, 0, .6);
	vertical-align: middle
}

.modal-wrapper .modal-window .modal-content {
	max-height: 80vh;
	overflow-y: auto;
	text-align: left
}

.modal_title {
	font-size: 18px;
	font-weight: 500;
	position: relative;
	padding: 0;
	border-bottom: 4px solid #6bb6ff;
}

.modal-content p {
	font-size: 14px;
	font-weight: 500;
	margin: 10px 0 0 0;
}

.modal-content hr {
	border: 1px solid #ffffff;
	margin: 5px 0px;
}

.modal-content img {
	display: block;
}

.modal-overlay {
	z-index: 10;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	background: rgba(0, 0, 0, .8)
}

.modal-wrapper .modal-close {
	z-index: 20;
	position: absolute;
	top: 8px;
	right: 30px;
	width: 35px;
	color: #000;
	font-size: 30px;
	font-weight: 500;
	line-height: 35px;
	text-align: center;
	text-decoration: none;
	text-indent: 0
}

.modal-wrapper .modal-close:hover {
	color: #2b2e38 !important
}

.ichi img {
	vertical-align: middle;
	display: inline-block;
}

.ichi span {
	display: inline-block;
}



/*　print 印刷範囲指定*/

@media print {
	#header {
		display: none;
	}

	#footer {
		display: none;
	}

	.function-info .card {
		display: none;
	}
}