@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
#main {
	position: relative;
}
.op07 {
	opacity: 0.2;
}
.mainVisual {
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
	width: 100%;
	height: 100vh;
	/*height:1000px;*/
	min-height: 700px;
    }
.mainVisual .mv_txt {
	position: relative;
	z-index: 5;
	width: 100%;
	height: 100%;
}
.mainVisual .imgs {
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.mainVisual .imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.mainVisual .mv_txt .txt {
	display: block;
	width: 100%;
	height: 100%;
	position: relative;
}
.mainVisual .mv_txt h1 {
	position: absolute;
	right: 10%;
	top: 170px;
}
.mv-img {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	top: 15%;
	max-width: 240px;
	text-align: center;
}
.mv-img img {
	width: auto;
	max-width: 100%;
	max-height: 80vh;
}
.mv-img img,
.mv-logo img{
	object-fit: contain;
}
.mv-logo {
	position: absolute;
	left: 10%;
	bottom: 10%;
	max-width: 56px;
}



@media all and (max-width: 768px) {
	.mainVisual {
		box-sizing: border-box;
		position: relative;
		overflow: hidden;
		width: 100%;
		height: 100vh;
		/*height:1000px;*/
		min-height: 360px;
		}
	.mainVisual .mv_txt {
		position: relative;
		z-index: 5;
		width: 100%;
		height: 100%;
	}
	.mainVisual .imgs {
		position: absolute;
		right: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}
	.mainVisual .imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.mainVisual .mv_txt .txt {
		display: block;
		width: 100%;
		height: 100%;
		position: relative;
	}
	.mainVisual .mv_txt h1 {
		position: absolute;
		right: 4%;
		top: 90px;
	}
	.mainVisual .mv_txt h1 {
		max-width: 70px;
	}
	.mv-img {
		position: absolute;
		left: 0;
		right: 0;
		margin: auto;
		top: 15%;
		max-width: 120px;
		text-align: center;
	}
	.mv-img img {
		width: auto;
		max-width: 100%;
		max-height: 80vh;
	}
	.mv-logo {
		position: absolute;
		left: 10%;
		bottom: 10%;
		max-width: 36px;
	}
}




/* top-box1 */
.fix-1520 {
	max-width: 1520px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.fix-1350 {
	max-width: 1350px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.fix-1240 {
	max-width: 1240px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.fix-1000 {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.fix-1200 {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.fix-980 {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
	position: relative;
}
.top-box1 {
	display: block;
	padding: 220px 0 300px 0;
	position: relative;
	background: url("../images/tp1bg.jpg") top center no-repeat;
	background-size: cover;
}
.top-box1::after {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 50%;
	background: url("../images/tp1-deco.png") top center no-repeat;
	background-size: 100% auto;
}
.top-box1 .fix-1350 {
	position: relative;
	z-index: 10;
}
.top-box1 .imgs {
	display: block;
	text-align: center;
}
.top-box1 .imgs img {
	display: inline-block;
	max-width: 100%;
	width: auto;
}




@media all and (max-width: 979px) {
	.fix-980 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 999px) {
	.fix-1000 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 1560px) {
	.fix-1520 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 1379px) {
	.fix-1350 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 1199px) {
	.fix-1200 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 1239px) {
	.fix-1240 {
		margin-left: 4%;
		margin-right: 4%;
	}
}
@media all and (max-width: 768px) {
	.fix-1240 {
		margin-left: 4%;
		margin-right: 4%;
		position: relative;
	}
	.top-box1 {
		display: block;
		padding: 60px 0 70px 0;
		position: relative;
		background: url("../images/tp1bg.jpg") top center no-repeat;
		background-size: cover;
	}
	.top-box1 .fix-1350 {
		position: relative;
		z-index: 10;
	}
	.top-box1 .imgs {
		display: block;
		text-align: center;
	}
	.top-box1 .imgs img {
		display: inline-block;
		max-width: 32%;
		width: auto;
	}
}



/* top-box2 */
.top-box2 {
	display: block;
	position: relative;
	padding: 160px 0;
}
.top-box2 .fix-1350 {
	position: relative;
	z-index: 10;
}
.top-box2 .flx {
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
	position: relative;
	padding: 0 4%;
}
.top-box2 .txt {
	display: block;
}
.top-box2 .txt p {
	color: #FFF;
	font-size: 18px;
	font-style: normal;
	font-weight: 400;
	line-height: 240%; /* 25.2px */
	letter-spacing: 0.35em;
	margin-left: 45px;
}
.fix-imgs {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: none;
}
.fix-imgs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ov-ind {
	background: url("../images/tp2bg.jpg") top center no-repeat;
	background-size: cover;
	background-attachment: fixed;
}
.ov-ind2 {
	background:url("../images/tp2bg2.jpg") top center no-repeat;
	background-size: cover;
	background-attachment: fixed;
}
.ov-ind3 {
	background: url("../images/tp2bg3.jpg") top center no-repeat;
	background-size: cover;
	background-attachment: fixed;
}
.stiky-wrap {
	position: relative;
	height: 100%;
}
.stiky-wrap::after {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	z-index: 2000;
	width: 100%;
	height: 100%;
	background: url("../images/sm-b.png") bottom right no-repeat;
	background-size:  auto 125px ;
	background-attachment: fixed;
}
.stiky-wrap2 {
	position: relative;
	height: 100%;
}
.stiky-wrap2::after {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	z-index: 2000;
	width: 100%;
	height: 100%;
	background: url("../images/sm-l.png") left top 20% no-repeat;
	background-size: 70px auto;
	background-attachment: fixed;
}
.stiky-wrap2::before {
	position: absolute;
	right: 0;
	top: 0;
	content: "";
	z-index: 2000;
	width: 100%;
	height: 100%;
	background: url("../images/sm-r.png") right top 20% no-repeat;
	background-size: 60px auto;
	background-attachment: fixed;
}
/*.stiky-wrap2::before {
	position: absolute;
	right: 0;
	top: 0%;
	content: "";
	z-index: 200;
	width: 100vw;
	height: 100vh;
	background: url("../images/sm-r.png") right top no-repeat;
}*/
.parallax-slide {
	position: -webkit-sticky !important;
	position: sticky !important;
	top: 0px !important;
	box-sizing: border-box;
}
.obj {
	display:block;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2000;
	width: 100vw;
	height: 100vh;
}
.obj img {
	width: 100%;
	height: 100%;
}
.obj.ons {
	position:fixed;
	top: 0;
	left: 0;
	display: block;
}

@media all and (min-width: 769px) {
	.ov-ind {
		z-index: 1000;
	}
	.ov-ind2 {
		z-index: 1001;
	}
	.ov-ind3 {
		z-index: 1002;
	}
	.ov-ind4 {
		z-index: 1003;
	}
	.whi-rt {
		-ms-writing-mode: tb-rl;
  		writing-mode: vertical-rl;
	}
}

@media all and (max-width: 768px) {
	.top-box2 {
		display: block;
		position: relative;
		padding: 80px 0;
	}
	.top-box2 .fix-1350 {
		position: relative;
		z-index: 10;
	}
	.top-box2 .flx {
		display: block;
		position: relative;
		padding: 0 4%;
	}
	.top-box2 .txt {
		display: block;
		margin-bottom: 35px;
	}
	.top-box2 .txt p {
		color: #FFF;
		font-size: 17px;
		font-style: normal;
		font-weight: 400;
		line-height: 210%; /* 25.2px */
		letter-spacing: 0.2em;
		margin-left: 0px;
	}
	.fix-imgs {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}
	.fix-imgs img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}



/* top-box3 */
.top-box3 {
	display: block;
	position: relative;
	background: #12183A;
	padding-top: 280px;
	/*overflow: hidden;*/
}
.top-box3::after {
	position:absolute;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 100%;
	background: url("../images/tp3bgwrap.png") top center;
	background-size: 100% auto;
	background-attachment: fixed;
}
.top-box3 .fix-1520 {
	position: relative;
	z-index: 10;
}
.top-box3 .flx {
	display:flex;
	justify-content: space-between;
}
.top-box3 .flx.ri {
	flex-direction: row-reverse;
	align-items: center;
}
.top-box3 .txt {
	display: block;
	position: relative;
	flex-basis: 42%;
}
.tit1 {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 45px;
}
.tit1 h2 {
	display: block;
	color: #FFF;
	font-size: 36px;
	font-style: normal;
	font-weight: 700;
	line-height: 30px; /* 83.333% */
	letter-spacing: 1.8px;
}
.tit1 span {
	display: block;
	color: #FFF;
	font-family: "Crimson Pro", serif;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 100%; /* 16px */
	letter-spacing: 0.8px;
	margin-left: 25px;
	padding-top: 15px;
}
.txt_02 {
	display: block;
	color: #FFF;
	font-size: 20px;
	font-style: normal;
	font-weight: 700;
	line-height: 30px; /* 150% */
	letter-spacing: 4px;
	margin-bottom: 45px;
}
.top-box3 .txt_01 {
	color: #FFF;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 320%; /* 51.2px */
	letter-spacing: 2.2px;
}
.r-links {
	display: block;
	text-align: right;
	padding-top: 17px;
}
.r-links a {
	display: inline-block;
	color: #FFF;
	font-size: 18px;
	font-style: normal;
	font-weight: 500;
	line-height: 320%; /* 57.6px */
	letter-spacing: 1.8px;
	border-bottom: dashed #FFF 1px;
	position: relative;
}
.r-links a::after {
	position: absolute;
	left: 0;
	bottom: -1px;
	content: "";
	width: 0;
	height: 3px;
	background: #FFF;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}
.top-box3 .imgs {
	display: block;
	flex-basis: 50%;
}
.top-box3 .imgs img {
	width: 100%;
	border-radius: 20px;
}
.im-list {
	display: flex;
	position: relative;
	z-index: 10;
	
	margin: 170px 0 260px 0;
}
.im-list li {
	display: block;
	margin-left: 50px;
}
.im-list img {
	width: 435px !important;
	max-width:435px;
	border-radius: 10px;
	aspect-ratio: 2560 / 1700;
	object-fit: cover;
}
.im-list .slick-slide {
	width: 435px !important;
	box-sizing: border-box !important;
	padding: 0 30px !important;
}
.ov-wraps {
	width: 100%;
	overflow: hidden;
}

.tp3main {
	
	position: relative;
	padding-bottom: 250px;
	overflow: visible;
}
@media all and (min-width: 769px) {
	.tp3main {
		display:flex;
		flex-direction: column;
		padding-left: 52%;
	}
}
.tp3txtmain {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: 20;	
}
.tp3txtmain .fix-1520 {
	height: 100%;
}
.tp3txtmain .txt2 {
	position: sticky;
	top: 0;
	width: 40%;
	padding-top: 110px;
}
@media all and (min-width: 769px) {
	.tp3txtmain .txt2 {
		padding-bottom: 270px;
	}
}
.tp3main .flxs {
	flex-basis: 100%;
	max-width: 100%;
	position: relative;
	margin-bottom: 20px;
	z-index: 100;
}
.tp3main .flxs .im {
	display: block;
	flex-basis: 48%;
	position: relative;
	border-radius: 20px 0 0 20px;
	overflow: hidden;
}
.tit2 {
	position: relative;
	z-index: 5;
}
.tp3main .tit2 {
	padding: 270px 0 55px 65px;
}
.tit2 h3 {
	color: #FFF;
	display: block;
	font-size: 50px;
	font-style: normal;
	font-weight: 700;
	line-height: 140%; /* 60px */
	letter-spacing: 10.5px;
	white-space: nowrap;
}
.tit2 span {
	display: block;
	color: #FFF;
	font-size: 22px;
	font-style: normal;
	font-weight: 500;
	line-height: 120%; /* 26.4px */
	letter-spacing: 1.1px;
	margin-left: 15px;
}
.tp3main .flxs .bg-img {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
.tp3main .flxs .bg-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}


@media all and (min-width: 769px) {
	.r-links a:hover::after {
		width: 100%;
	}
	.tp3main .flxs:hover {
		opacity: 0.7;
	}
}

@media all and (min-width: 769px) and (max-width: 950px) {
	.top-box3 .flx.ri {
		display: block;
	}
	.top-box3 .flx.ri .imgs {
		margin-top: 45px;
	}
}


@media all and (max-width: 768px) {
	.tp3txtmain.js-fixed-elm {
		top:0 !important;
	}
	.top-box3 {
		display: block;
		position: relative;
		background: #12183A;
		padding-top: 70px;
	}
	.top-box3::after {
		position:absolute;
		left: 0;
		top: 0;
		content: "";
		width: 100%;
		height: 100%;
		background: url("../images/tp3bgwrap.png") top center no-repeat;
		background-size: cover;
	}
	.top-box3 .fix-1520 {
		position: relative;
		z-index: 10;
	}
	.top-box3 .flx {
		display: block;
	}
	.top-box3 .flx.ri {
		display: block;
	}
	.top-box3 .txt {
		display: block;
		position: relative;
		flex-basis: 42%;
		margin-bottom: 25px;
	}
	.tit1 {
		display: flex;
		flex-wrap: wrap;
		margin-bottom: 25px;
	}
	.tit1 h2 {
		display: block;
		color: #FFF;
		font-size: 27px;
		font-style: normal;
		font-weight: 700;
		line-height: 30px; /* 83.333% */
		letter-spacing: 1.8px;
	}
	.tit1 span {
		display: block;
		color: #FFF;
		font-family: "Crimson Pro", serif;
		font-size: 12px;
		font-style: normal;
		font-weight: 500;
		line-height: 100%; /* 16px */
		letter-spacing: 0.8px;
		margin-left: 10px;
		padding-top: 10px;
	}
	.txt_02 {
		display: block;
		color: #FFF;
		font-size: 17px;
		font-style: normal;
		font-weight: 700;
		line-height: 30px; /* 150% */
		letter-spacing: 2px;
		margin-bottom: 20px;
	}
	.top-box3 .txt_01 {
		color: #FFF;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 51.2px */
		letter-spacing: 1.2px;
	}
	.r-links {
		display: block;
		text-align: right;
		padding-top: 17px;
	}
	.r-links a {
		display: inline-block;
		color: #FFF;
		font-size: 18px;
		font-style: normal;
		font-weight: 500;
		line-height: 320%; /* 57.6px */
		letter-spacing: 1.8px;
		border-bottom: dashed #FFF 1px;
		position: relative;
	}
	.r-links a::after {
		position: absolute;
		left: 0;
		bottom: -1px;
		content: "";
		width: 0;
		height: 3px;
		background: #FFF;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
	.top-box3 .imgs {
		display: block;
		flex-basis: 50%;
	}
	.top-box3 .imgs img {
		width: 100%;
		border-radius: 20px;
	}
	.im-list {
		display: flex;
		position: relative;
		justify-content: space-between;
		flex-wrap: wrap;
		
		z-index: 10;
		margin: 40px 4% 40px 4%;
	}
	.im-list li {
		display: block;
		margin-left: 30px;
	}
	.im-list img {
		width: 235px !important;
		max-width:235px;
		border-radius: 10px;
		aspect-ratio: 2560 / 1700;
		object-fit: cover;
	}

	.tp3main {
		display: block;
		position: relative;
		padding-bottom: 50px;
	}
	.tp3txtmain {
		position:relative;
		left: 0;
		top: 0;
		width: 100%;
	}
	.tp3txtmain .txt2 {
		width: 100%;
		margin-bottom: 25px;
	}
	.tp3main .flxs {
		display: flex;
		flex-direction: row-reverse;
		position: relative;
		margin-bottom: 20px;
		z-index: 10;
	}
	.tp3main .flxs .im {
		display: block;
		flex-basis: 100%;
		box-sizing: border-box;
		margin-left: 4%;
		position: relative;
		border-radius: 20px 0 0 20px;
		overflow: hidden;
	}
	.tit2 {
		position: relative;
		z-index: 5;
	}
	.tp3main .tit2 {
		padding: 150px 0 25px 0px;
	}
	.tit2 h3 {
		color: #FFF;
		display: block;
		font-size: 24px;
		font-style: normal;
		font-weight: 700;
		line-height: 140%; /* 60px */
		letter-spacing: 3.5px;
		white-space: nowrap;
		margin-left: 15px;
	}
	.tit2 span {
		display: block;
		color: #FFF;
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 120%; /* 26.4px */
		letter-spacing: 1.1px;
		margin-left: 15px;
	}
	.tp3main .flxs .bg-img {
		position: absolute;
		left: 0;
		top: 0;
		width: 100%;
		height: 100%;
	}
	.tp3main .flxs .bg-img img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}




/* top-box4 */
.top-box4 {
	display: block;
	position: relative;
	padding: 200px 0 300px 0;
}
.top-box4::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	width: 100%;
	height: 67%;
	background: url("../images/about-bg.png") top center no-repeat;
	background-size: cover;
}
.top-box4 .fix-1520 {
	position: relative;
	z-index: 10;
}
.top-box4 .flx {
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;	
}
.top-box4 .txt {
	display: block;
	flex-basis: 43%;
	padding: 90px 0 270px 0;
}
.top-box4 .tit1 h2,
.top-box4 .tit1 span {
	color: #12183A
}
.top-box4 .txt p {
	display: block;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 320%; /* 51.2px */
	letter-spacing: 1.6px;
}
.top-box4 .imgs {
	display: block;
	flex-basis: 50%;
}
.top-box4 .imgs img {
	width: 100%;
	object-fit: cover;
	border-radius: 20px;
}
@media all and (min-width: 769px) {
	.top-box4 .imgs {
		min-height: 750px;
	}
	.top-box4 .imgs img {
		height: 100%;
		object-fit: cover;
	}
}
.r-links.bl a {
	color: #12183A;
	border-bottom: dashed #12183A 1px;
}
.r-links.bl a::after {
	background: #12183A;
	-webkit-transition: all 0.3s ease-in-out 0s;
  		transition: all 0.3s ease-in-out 0s;
}

@media all and (min-width: 769px) and (max-width: 1300px) {
	.top-box4::before {
		height: 72%;
	}
	.top-box4 {
		display: block;
		position: relative;
		padding: 130px 0 170px 0;
	}
	.top-box4 .txt {
		display: block;
		flex-basis: 43%;
		padding: 30px 0 170px 0;
	}
}

@media all and (max-width: 768px) {
	.top-box4 {
		display: block;
		position: relative;
		padding: 70px 0 60px 0;
	}
	.top-box4::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		width: 100%;
		height: 100%;
		background: url("../images/about-bg.png") top center no-repeat;
		background-size: cover;
	}
	.top-box4 .fix-1520 {
		position: relative;
		z-index: 10;
	}
	.top-box4 .flx {
		display: block;
	}
	.top-box4 .txt {
		display: block;
		flex-basis: 43%;
		padding: 0px 0 25px 0;
	}
	.top-box4 .tit1 h2,
	.top-box4 .tit1 span {
		color: #12183A
	}
	.top-box4 .txt p {
		display: block;
		font-size: 15px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 51.2px */
		letter-spacing: 1.6px;
	}
	.top-box4 .imgs {
		display: block;
		flex-basis: 50%;
	}
	.top-box4 .imgs img {
		width: 100%;
		border-radius: 20px;
	}
	.r-links.bl a {
		color: #12183A;
		border-bottom: dashed #12183A 1px;
	}
	.r-links.bl a::after {
		background: #12183A;
		-webkit-transition: all 0.3s ease-in-out 0s;
			transition: all 0.3s ease-in-out 0s;
	}
}



.top-bottom {
	display: block;
	background:url("../images/bottom-bg.jpg") center no-repeat;
	background-size: cover;
	padding: 160px 0 220px 0;
}
.top-bottom .fix-1520 {
	position: relative;
}
.top-bottom .tit3 {
	position: absolute;
	left: 0;
	top: 0;
}
.top-bottom .tit3 h3 {
	display: block;
	color: #FFF;
	font-size: 50px;
	font-style: normal;
	font-weight: 700;
	line-height: 120%; /* 60px */
	letter-spacing: 8.5px;
	white-space: nowrap;
}
.top-bottom .tit3 small {
	display: block;
	font-family: "Crimson Pro", serif;
	color: #FFF;
	font-size: 22px;
	font-style: normal;
	font-weight: 500;
	line-height: 120%; /* 26.4px */
	letter-spacing: 1.1px;
	margin-left: 18px;
}
.top-bottom .flxs {
	display: flex;
	justify-content: space-between;
	margin-left: 260px;
}
.top-bottom .flxs .tx {
	display: block;
	flex-basis: 50%;
	color: #FFF;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 320%; /* 51.2px */
	letter-spacing: 1.6px;
	padding: 55px 85px 140px 0;
	box-sizing: border-box;
	border-right: #fff dotted 1px;
}
.top-bottom .flxs .ref {
	display: block;
	flex-basis: 50%;
	padding-left: 85px;
	padding-top: 55px;
}
.top-bottom .flxs .ref ul {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 35px;
}
.top-bottom .flxs .ref li {
	display: block;
	position: relative;
	margin-bottom: 15px;
}
.top-bottom .flxs .ref li:nth-child(1) {
	margin-right: 50px;
}
.top-bottom .flxs .ref li a {
	color: #FFF;
	font-size: 20px;
	font-style: normal;
	font-weight: 600;
	line-height: 160%; /* 32px */
	letter-spacing: 2px;
}
.top-bottom .flxs .ref li a span {
	display: inline-block;
	position: relative;
	padding-left: 44px;
}
.top-bottom .flxs .ref li a span::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	background:url("../images/add_shopping_cart-f.png") center center no-repeat;
	background-size: 100% auto;
	width: 36px;
	height: 36px;
}
.top-bottom .flxs .ref li.cont a span::before {
	background:url("../images/fbt-mail.png") center center no-repeat;
	background-size: 100% auto;
}
.ftels {
	display: block;
}
.ftels a,
.ftels b {
	display: block;
	position: relative;
	color: #FFF;
	font-size: 26px;
	font-style: normal;
	font-weight: 700;
	line-height: 140%; /* 36.4px */
	letter-spacing: 2.6px;
	padding-left: 44px;
}
.ftels a::before,
.ftels b::before {
	position: absolute;
	left: 0;
	top: 0;
	content: "";
	background: url("../images/call-f.png") center center no-repeat;
	background-size: 100% auto;
	width: 36px;
	height: 36px;
}
.ftels small {
	display: block;
	color: #FFF;
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 140%; /* 22.4px */
	margin-top: 14px;
	margin-left: 4px;
}

@media all and (min-width: 769px) {
	.top-bottom .flxs .ref li a:hover {
		opacity: 0.7;
	}
}

@media all and (min-width: 769px) and (max-width: 1100px) {
	.top-bottom .flxs {
		display: block;
		margin-left: 160px;
	}
	.top-bottom .flxs .tx {
		display: block;
		flex-basis: 50%;
		color: #FFF;
		font-size: 16px;
		font-style: normal;
		font-weight: 500;
		line-height: 320%; /* 51.2px */
		letter-spacing: 1.6px;
		padding: 55px 0px 55px 0;
		box-sizing: border-box;
		border-right: #fff dotted 0px;
		border-bottom: #fff dotted 1px;
	}
	.top-bottom .flxs .ref {
		display: block;
		flex-basis: 50%;
		padding-left: 0px;
		padding-top: 55px;
	}
}

@media all and (max-width: 768px) {
	.top-bottom {
		display: block;
		background:url("../images/bottom-bg.jpg") center no-repeat;
		background-size: cover;
		padding: 60px 0 60px 0;
	}
	.top-bottom .fix-1520 {
		position: relative;
	}
	.top-bottom .tit3 {
		position:relative;
		text-align: center;
		left: 0;
		top: 0;
	}
	.top-bottom .tit3 h3 {
		display: block;
		color: #FFF;
		font-size: 25px;
		font-style: normal;
		font-weight: 700;
		line-height: 120%; /* 60px */
		letter-spacing: 2.5px;
		white-space: nowrap;
	}
	.top-bottom .tit3 small {
		display: block;
		font-family: "Crimson Pro", serif;
		color: #FFF;
		font-size: 14px;
		font-style: normal;
		font-weight: 500;
		line-height: 120%; /* 26.4px */
		letter-spacing: 1.1px;
		margin-left: 0px;
	}
	.top-bottom .flxs {
		display: block;
		margin-left: 0px;
	}
	.top-bottom .flxs .tx {
		display: block;
		flex-basis: 50%;
		color: #FFF;
		font-size: 16px;
		font-style: normal;
		font-weight: 500;
		line-height: 2; /* 51.2px */
		letter-spacing: 1.6px;
		padding: 25px 0px 35px 0;
		box-sizing: border-box;
		border-right: #fff dotted 0px;
		border-bottom: #fff dotted 1px;
	}
	.top-bottom .flxs .ref {
		display: block;
		flex-basis: 50%;
		padding-left: 0px;
		padding-top: 35px;
		text-align: center;
	}
	.top-bottom .flxs .ref ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
		margin-bottom: 35px;
	}
	.top-bottom .flxs .ref li {
		display:inline-block;
		position: relative;
		margin-bottom: 15px;
	}
	.top-bottom .flxs .ref li:nth-child(1) {
		margin-right: 0px;
	}
	.top-bottom .flxs .ref li a {
		color: #FFF;
		font-size: 20px;
		font-style: normal;
		font-weight: 600;
		line-height: 160%; /* 32px */
		letter-spacing: 2px;
	}
	.top-bottom .flxs .ref li a span {
		display: inline-block;
		position: relative;
		padding-left: 44px;
	}
	.top-bottom .flxs .ref li a span::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		background:url("../images/add_shopping_cart-f.png") center center no-repeat;
		background-size: 100% auto;
		width: 36px;
		height: 36px;
	}
	.top-bottom .flxs .ref li.cont a span::before {
		background:url("../images/fbt-mail.png") center center no-repeat;
		background-size: 100% auto;
	}
	.ftels {
		display: block;
		max-width: 260px;
		margin-left: auto;
		margin-right: auto;
	}
	.ftels a,
	.ftels b {
		display: block;
		position: relative;
		color: #FFF;
		font-size: 26px;
		font-style: normal;
		font-weight: 700;
		line-height: 140%; /* 36.4px */
		letter-spacing: 2.6px;
		padding-left: 44px;
	}
	.ftels a::before,
	.ftels b::before {
		position: absolute;
		left: 0;
		top: 0;
		content: "";
		background: url("../images/call-f.png") center center no-repeat;
		background-size: 100% auto;
		width: 36px;
		height: 36px;
	}
	.ftels small {
		display: block;
		color: #FFF;
		font-size: 16px;
		font-style: normal;
		font-weight: 500;
		line-height: 140%; /* 22.4px */
		margin-top: 14px;
		margin-left: 4px;
	}
}



.t-bg001 {
	position: relative;
	background: url("../images/t-logo.png") top center no-repeat;
}
.snss {
	display: inline-block;
	width: 25px;
	margin-right: 20px;
}
.ttl404 {
	font-size: 35px !important;
	margin-top: 50px !important;
}
@media all and (min-width: 769px) and (max-width: 980px) {
	.t-bg001 {
		position: relative;
		background: url("../images/t-logo.png") top center no-repeat;
		background-size: 60% auto;
	}
}
@media all and (min-width: 769px) {
	.t-bg001 {
		padding-top: 60px;
		padding-bottom: 0px;
		margin-top: -50px;
	}
}
@media all and (max-width: 768px) {
	.t-bg001 {
		position: relative;
		background: url("../images/t-logo.png") top center no-repeat;
		background-size: 30% auto;
	}
	.snss {
		display: block;
		width: 100%;
		text-align: center;
		margin-right: 0px;
		margin-bottom: 20px;
	}
	.snss img {
		max-width: 22px;
		display: inline-block;
	}
	.ttl404 {
		font-size: 24px !important;
		margin-top: 30px !important;
	}
}




