@charset "utf-8";
/*------------------------------------------------------------
	汎用スタイル
------------------------------------------------------------*/
/* 81-LYX */
/* clearfix */	
.clearfix:after {content: "";display: block;clear: both;}
/* flex */	
.flex,.flexA,.flexB,.flexC {display: flex;flex-wrap: wrap;}
.flexA {justify-content: space-around;}
.flexB {justify-content: space-between;}
.flexC {justify-content: center;}
.popp {
	font-family: "Poppins", sans-serif;
}
.bebas {
	font-family: "Bebas Neue", sans-serif;
}
/*------------------------------------------------------------
	comBtnUl
------------------------------------------------------------*/
.comBtnUl {
	gap: 0.5rem;
}
.comBtnUl li {
	width: 15rem;
}
button {
    background: none;
    border: none;
    padding: 0;
    margin: 0;
    font: inherit;
    color: inherit;
    cursor: pointer;
    appearance: none;
    -webkit-appearance: none;
}
.comBtnUl a,
.comBtnUl button{
	padding: 0.5rem 3rem 0.5rem 1.5rem;
	position: relative;
	display: flex;
	align-items: center;
	min-height: 4rem;
	color: #fefefe;
	font-size: 1.4rem;
	letter-spacing: 0.05em;
	background-color: #831019;
	border-radius: 2rem;
}
.comBtnUl a .ico,
.comBtnUl button .ico{
	position: absolute;
	top: calc(50% - 0.7rem);
	right: 1.25rem;
	width: 1.5rem;
	height: 1.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.comBtnUl a .ico img,
.comBtnUl button .ico img{
	transition: .1s;
}
.comBtnUl .style01 a .ico {
	animation: rotate infinite linear;
	animation-duration: 4s;
}
.comBtnUl a .ico img,
.comBtnUl button .ico img{
	width: 1rem;
	transition: 1.5s cubic-bezier(0.19, 1, 0.22, 1);
}
.comBtnUl .black a {
	background-color: #101b36;
}
@keyframes rotate {
	0% {
		transform: rotate(0deg);
	}
	100% {
		transform: rotate(360deg);
	}
}
@media all and (min-width: 897px) {
	.comBtnUl .style01 a:hover .ico img {
		transform: scale(1.5);
		-webkit-transform: scale(1.5);
	}
	.comBtnUl .li01 a:hover .ico img {
		transform: rotate(90deg);
	}
}
/*------------------------------------------------------------
	content
------------------------------------------------------------*/
.content {
	padding: 0 2rem;
	margin: 0 auto;
	max-width: 118rem;
}
@media all and (max-width: 896px) {
	.content {
		max-width: 100% !important;
	}
}
/*------------------------------------------------------------
	pageTitle
------------------------------------------------------------*/
.pageTitle {
	position: relative;
	padding: 16.7rem 0 3.6rem;
}
.pageTitle .content {
	max-width: 128rem;
	align-items: center;
}
.pageTitle .headLine01 {
	width: 50%;
}
@media all and (min-width: 1441px) {
	.pageTitle .content {
		max-width: 158rem;
	}
}
@media all and (max-width: 896px) {
	.pageTitle {
		padding: 9.8rem 0 2rem;
	}
	.pageTitle .content {
		padding: 0 3rem;
		display: block;
	}
	.pageTitle .headLine01 {
		width: auto;
	}
}
/*------------------------------------------------------------
	pagePath
------------------------------------------------------------*/
#pagePath {
	margin-bottom: 1rem;
}
#pagePath li {
	display: inline-block;
}
#pagePath li,
#pagePath a {
	font-size: 1.2rem;
	letter-spacing: 0.05em;
	color: #fefefe;
}
#pagePath a {
	padding: 0 0.8rem;
	border-right: 1px solid #fefefe;
}
#pagePath li:last-child {
	margin-left: 0.7rem;
}
#pagePath a:hover {
	opacity: 0.5;
}
@media all and (max-width: 896px) {
	#pagePath {
		margin: -0.5rem 0 0;
		text-align: right;
	}
	#pagePath li {
		margin-bottom: 0.5rem;
		display: block;
	}
	#pagePath li,
	#pagePath a {
		font-size: 1rem;
	}
	#pagePath a {
		padding: 0;
		border-right: 0;
	}
	#pagePath li:last-child {
		margin: 0;
	}
}
/*------------------------------------------------------------
	comwhiteBg
------------------------------------------------------------*/
.comwhiteBg {
	padding: 8rem 2rem;
	margin: 0 auto;
	position: relative;
	z-index: 1;
	max-width: 138rem;
	overflow: hidden;
}
.comwhiteBg::after {
	position: absolute;
	top: 0;
	left: 2rem;
	right: 2rem;
	bottom: 0;
	z-index: -1;
	content: "";
	border-radius: 3rem;
	background-color: #f6f2f2;
	pointer-events: none;
}
@media all and (min-width: 1441px) {
	.comwhiteBg {
		max-width: 158rem;
	}
}
@media all and (max-width: 896px) {
	.comwhiteBg {
		padding: 3rem 2rem;
		max-width: 100%;
	}
	.comwhiteBg::after {
		border-radius: 1rem;
	}
}
/*------------------------------------------------------------
	headLine01
------------------------------------------------------------*/
.headLine01 {
	padding-left: 5rem;
	color: #fefefe;
	font-weight: 500;
	background: url(../img/common/icon04.png) no-repeat left top 3rem / 3rem;
}
.headLine01 .en {
	display: inline-block;
	padding-bottom: 1rem;
	font-size: 6rem;
	vertical-align: middle;
}
.headLine01 .jp {
	padding-left: 2rem;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.headLine01 {
		padding-left: 3rem;
		background-size: 2rem;
		background-position: left top 1.2rem;
	}
	.headLine01 .en {
		padding-bottom: 0.5rem;
		font-size: 3rem;
	}
	.headLine01 .jp {
		padding-left: 1rem;
		font-size: 1.4rem;
	}
}
/*------------------------------------------------------------
	headLine02
------------------------------------------------------------*/
.headLine02 {
	margin-bottom: 3rem;
	padding-left: 3rem;
	color: #831019;
	font-weight: 500;
	background: url(../img/common/icon03.png) no-repeat left top 0.7rem / 2rem;
}
.headLine02 .en {
	display: inline-block;
	font-size: 2.4rem;
	vertical-align: middle;
}
.headLine02 .jp {
	padding-left: 1rem;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
}
@media all and (max-width: 896px) {
	.headLine02 {
		margin-bottom: 1.5rem;
		padding-left: 2.5rem;
		background-size: 1.5rem;
		background-position: left top 0.5rem;
	}
	.headLine02 .en {
		font-size: 2rem;
	}
	.headLine02 .jp {
		padding-left: 1rem;
	}
}
/*------------------------------------------------------------
	comLinkUl
------------------------------------------------------------*/
.comLinkUl li {
	position: relative;
	line-height: 1.41;
}
.comLinkUl li:not(:last-child)::after {
	position: absolute;
	top: 50%;
	transform: translateY(-40%);
	right: 0;
	width: 1px;
	height: 1.5rem;
	background-color: #fefefe;
	content: "";
	z-index: 1;
}
.comLinkUl a {
	padding: 0 1rem;
	display: inline-block;
	color: #fefefe;
	font-size: 1.2rem;
	letter-spacing: 0.05em;
}
.comLinkUl li:last-child a {
	padding-right: 0;
}
.comLinkUl a:hover {
	opacity: 0.5;
}
@media all and (max-width: 896px) {
}
/*------------------------------------------------------------
	comNewsUl
------------------------------------------------------------*/
.comNewsUl {
	gap: 3rem 2.9%;
}
.comNewsUl li {
	width: 31.4%;
}
.comNewsUl a {
	display: block;
}
.comNewsUl .photo {
	margin-bottom: 1.5rem;
	aspect-ratio: 390/219;
	border-radius: 1rem;
	overflow: hidden;
}
.comNewsUl .photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .6s ease;
}
.comNewsUl time {
	margin-bottom: 1rem;
	display: block;
	font-size: 1.4rem;
	color: #831019;
}
.comNewsUl time span {
	margin-right: 1rem;
	display: inline-block;
	padding-right: 2rem;
	background: url(../img/common/line02.png) no-repeat right center / 0.9rem;
}
.comNewsUl .text {
	font-size: 1.8rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}
@media all and (min-width: 897px) {
	.comNewsUl a:hover .photo img {
		transform: scale(1.5)
	}
}
@media all and (max-width: 896px) {
	.comNewsUl {
		display: block;
	}
	.comNewsUl li {
		margin-bottom: 2rem;
		width: auto !important;
	}
	.comNewsUl li:last-child {
		margin-bottom: 0;
	}
	.comNewsUl .photo {
		margin-bottom: 0.5rem;
		aspect-ratio: 310/174;
	}
	.comNewsUl .textBox {
		margin: 0 1rem;
	}
	.comNewsUl time {
		margin-bottom: 0.5rem;
	}
	.comNewsUl time span {
		margin-right: 0.5rem;
		padding-right: 1.5rem;
	}
}
/*------------------------------------------------------------
	comAchorUl
------------------------------------------------------------*/
.comAchorUl {
	gap: 0.5rem;
	align-items: flex-start;
}
.comAchorUl a {
	padding: 0 1rem;
	min-height: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #831019;
	font-size: 1.4rem;
	background-color: #fff;
	border-radius: 1.5rem;
}
.comAchorUl .on a {
	color: #fff;
	background-color: #831019;
}
@media all and (min-width: 897px) {
	.comAchorUl a:hover {
		color: #fff;
		background-color: #831019;
	}
}
@media all and (max-width: 896px) {
	.comAchorUl a {
		padding: 0 1rem !important;
		min-height: 3rem !important;
		font-size: 1.4rem !important;
	}
}
/*------------------------------------------------------------
	comCaseUl
------------------------------------------------------------*/
.comCaseUl {
	gap: 4rem 3.5%;
}
.comCaseUl li {
	width: 48.25%;
}
.comCaseUl a {
	display: flex;
	flex-wrap: wrap;
}
.comCaseUl .photoBox {
	margin-right: 2rem;
	width: 18rem;
	aspect-ratio: 1/1;
	border-radius: 1rem;
	overflow: hidden;
}
.comCaseUl .photoBox img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .6s ease;
}
.comCaseUl .textBox {
	margin: 0.5rem 0;
	flex: 1;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	flex-direction: column;
}
.comCaseUl .textBox .title {
	margin-bottom: 2rem;
	font-size: 2rem;
	font-weight: 700;
	color: #831019;
	line-height: 1.8;
}
.comCaseUl .textBox .text {
	font-weight: 700;
	color: #831019;
	line-height: 1.68;
}
.comCaseUl .textBox .text .sml {
	margin-top: 0.5rem;
	display: block;
	font-weight: 500;
	font-size: 1.4rem;
	color: #222;
	letter-spacing: 0.05em;
}
.comCaseUl .textBox .text .sml span {
	margin-right: 1rem;
	display: inline-block;
	padding-right: 1.7rem;
	background: url(../img/common/line04.png) no-repeat right center / 0.8rem;
}
@media all and (min-width: 897px) {
	.comCaseUl a:hover .photoBox img {
		transform: scale(1.5);
	}
}
@media all and (max-width: 896px) {
	.comCaseUl {
		display: block;
	}
	.comCaseUl li {
		margin-bottom: 3rem;
		width: auto;
	}
	.comCaseUl a {
		display: block;
	}
	.comCaseUl .photoBox {
		margin: 0 0 1.5rem;
		width: auto;
	}
	.comCaseUl .textBox {
		margin: 0;
		display: block;
	}
	.comCaseUl .textBox .title {
		margin-bottom: 1rem;
	}
}
/*------------------------------------------------------------
	comDotUl
------------------------------------------------------------*/
.comDotUl li {
	margin-bottom: 1rem;
	padding-left: 2rem;
	position: relative;
	font-weight: 500;
	line-height: 1.8;
}
.comDotUl li:last-child {
	margin-bottom: 0;
}
.comDotUl li::after {
	position: absolute;
	top: 1rem;
	left: 0;
	content: "";
	z-index: 1;
	width: 1rem;
	height: 1rem;
	border-radius: 50%;
	background-color: #831019;
}
@media all and (max-width: 896px) {
	.comDotUl li::after {
		top: 0.9rem;
	}
}
/*------------------------------------------------------------
	common
------------------------------------------------------------*/
.comTextUl {
	gap: 2rem;
}
.comTextUl li {
	padding: 3rem 1rem 4rem;
	text-align: center;
	width: 27rem;
	background-color: #831019;
	border-radius: 1rem;
}
.comTextUl .num {
	margin-bottom: 1rem;
	font-family: "Poppins", sans-serif;
	font-size: 3rem;
	color: #fefefe;
	font-style: italic;
}
.comTextUl .text {
	color: #fefefe;
	letter-spacing: 0.05em;
	line-height: 1.8;
}
@media all and (max-width: 896px) {
	.comTextUl {
		display: block;
	}
	.comTextUl li {
		margin-bottom: 1rem;
		width: auto;
	}
	.comTextUl li:last-child {
		margin-bottom: 0;
	}
}
/*------------------------------------------------------------
	fadeInUp
------------------------------------------------------------*/
@media all and (min-width: 897px) {
	.animation .fadeInUp {
		opacity: 0;
		-webkit-transform: translateY(40px);
		transform: translateY(40px);
		transition: all .5s ease;
	}
	.animation.on .fadeInUp {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	.animation.on .delay01 {
		transition-delay: 0.5s;
	}
	.animation.on .delay02 {
		transition-delay: 1s;
	}
	.animation.on .delay03 {
		transition-delay: 1.5s;
	}
	.animation.on .delay04 {
		transition-delay: 2s;
	}
}
@media all and (max-width: 896px) {
	.fadeUp {
		opacity: 0;
		-webkit-transform: translateY(40px);
		transform: translateY(40px);
		transition: all .5s ease;
	}
	.fadeUp.on {
		opacity: 1;
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
