@charset "UTF-8";
/* CSS Document */
body{
	margin: 0px !important;
	overscroll-behavior: none;
}
h1,h2,h3,h4,h5,h6{margin: 0;}
ul {
    display: block;
    list-stslideyle-type: disc;
    margin-block-start: 0;
    margin-block-end: 0;
    margin-inline-start: 0;
    margin-inline-end: 0;
    padding-inline-start: 0;
}
*{
    min-height: 0;
    min-width : 0;
	margin: 0px;
	padding: 0px;
	box-sizing: border-box;
	scroll-behavior: smooth;
}
#bl{
    padding: 0;
    font-family: aktiv-grotesk, sans-serif;
	font-style: normal;
    margin: 0 auto;
    line-height: 2.0;
    font-size: 11px;
    letter-spacing: 1px;
	width: 100%;
    box-sizing: border-box;
    color: #111;
	background: #fff;
    -webkit-text-size-adjust: 100%;
}
#bl a {
	text-decoration: none;
	color: #2b2b2b;
}
#bl p {
    margin: 0;
}
#bl　a:hover {
	opacity: 1;
}
#bl .clear{
	clear: both;
}
#bl img{
    width: 100%;
    line-height: 0;
}
#bl ul,#bl li {
	list-style: none;
	padding: 0;
	margin: 0;
}
#bl .f-en {
	font-family: "Jost", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
}
/*********************************************
                bl_header
*********************************************/
#bl #bl_header {
	width: 100%;
	background: #a5998b;
	padding: 8% 0;
	
}
#bl #bl_header .main {
	width: 100%;
	height: 120vw;
	margin: 0;
	position: relative;
	border-top: solid 4px #49230a;
	border-bottom: solid 4px #49230a;
	overflow: hidden;
}
#bl #bl_header .main .ttl {
	width: 60%;
	margin: 13% auto 12%;
	display: block;
}
#bl #bl_header .main .sub-ttl {
	width: 30%;
	position: absolute;
	right: 0;
	bottom: 9%;
	left: 0;
	margin: auto;
}
#bl #bl_header .main .line {
	margin: 1% 0;
	width: 100%;
	height: 1px;
	color: #49230a !important;
}
#bl #bl_header .main hr:nth-of-type(2) {
	bottom: 0;
	position: absolute;
}
#bl #bl_header .main img {
	display: block;
}
#bl #bl_header .main .top {
	width: 30%;
	position: absolute;
}
#bl #bl_header .main .top_box {
	position: relative;
}
#bl #bl_header .main .top_box .top:nth-of-type(1) {
	top: 5%;
	left: -9%;
	z-index: 2;
	transform: rotate(-5deg);
	transition: 1.5s all 0.3s ease;
}
#bl #bl_header .main .top_box .top:nth-of-type(2) {
	top: 0%;
	left: 21%;
	transform: rotate(5deg);
	transition: 1.5s all 0.5s ease;
}
#bl #bl_header .main .top_box .top:nth-of-type(3) {
	top: 2%;
	left: 50%;
	transform: rotate(-4deg);
	transition: 1.5s all 0.7s ease;
}
#bl #bl_header .main .top_box .top:nth-of-type(4) {
	top: 0%;
	right: -9%;
	transform: rotate(5deg);
	transition: 1.5s all 0.9s ease;
}

@media only screen and (min-width: 769px) {
	#bl #bl_header {
		padding: 40px 0;
	}
	#bl #bl_header .main {
		height: 100vw;
		max-height: 880px;
	}
	#bl #bl_header .main .ttl {
		width: 40%;
		max-width: 400px;
		margin: 70px auto 75px;
	}
	#bl #bl_header .main .top_box {
		width: 70%;
		max-width: 1000px;
		margin: 0 auto;
	}
	#bl #bl_header .main .top {
		width: 28%;
	}
	#bl #bl_header .main .line {
		margin: 5px 0;
	}
	#bl #bl_header .main .sub-ttl {
		width: 16%;
		max-width: 150px;
		bottom: 40px;
	}
}
/*********************************************
       #contents       
*********************************************/
#bl #contents {
	
	background: #fff;
	position: relative;
	padding-top: 12%;
}

@media only screen and (min-width: 769px) {
	#bl #contents {
		width: 100%;
	}
	
}
/*********************************************
       section       
*********************************************/
#bl section {
	width: 100%;
}
#bl section .box {
	position: relative;
}
#bl section .box .more {
	position: absolute;
	top: 2%;
	right: 3%;
	width: 28px;
}
#bl .cib {
	width: 100%;
	margin: 8% 0 8% 0;
	overflow: hidden;
}
#bl .ab {
	position: absolute;
}
@media only screen and (min-width: 769px) {
	#bl section {
		max-width: 1400px;
		margin: 0 auto;
		position: relative;
	}
	#bl .cib {
		width: 100%;
		margin: 12% 0 8% 0;
	}
}
/******01*****/
#bl section:nth-of-type(1) {
	
}
#bl section:nth-of-type(1) .box:nth-of-type(1) {
	width: 82%;
	margin: 0 auto 10%;
}
#bl section:nth-of-type(1) .box .text {
	font-size: 9px;
position: absolute;
width: 68%;
top: 3%;
left: -4%;
line-height: 1.6;
color: #535353;
}
#bl section:nth-of-type(1) .flex {
	width: 100%;
	display: flex;
	justify-content: space-between;
}
#bl section:nth-of-type(1) .flex .box {
	width: 49.4%;
	margin: 0;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(1) .box:nth-of-type(1) {
		width: 39%;
		margin: 0;
	}
	#bl section:nth-of-type(1) .flex {
		width: 52%;
		margin: 0;
		position: absolute;
		right: 0;
		bottom: -17%;
	}
	#bl section:nth-of-type(1) .flex .box {
		width: 49.4%;
		margin: 0;
	}
	#bl section:nth-of-type(1) .box .text {
		font-size: 10px;
		width: 100%;
		top: 23%;
		left: 114%;
	}
}
/******02*****/
#bl section:nth-of-type(2) {
	 position: relative;
	overflow: hidden;
}
#bl section:nth-of-type(2) .box {
	width: 83%;
	margin: 0 0 0 -3%;
}
#bl section:nth-of-type(2) .ab:nth-of-type(1) {
	width: 41%;
	right: 0;
	top: 9%;
}
#bl section:nth-of-type(2) .ab:nth-of-type(2) {
	width: 41%;
	right: 0;
	bottom: 9%
}
#bl section:nth-of-type(2) .box .more {
	right: auto;
	left: 6%;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(2) .box .more {
		left: auto;
		right: 3%;
	}
	#bl section:nth-of-type(2) .box {
		width: 35%;
		margin: 0 0 0 0%;
	}
	#bl section:nth-of-type(2) .ab:nth-of-type(1) {
		width: 24%;
		right: 45%;
		top: 13%;
	}
	#bl section:nth-of-type(2) .ab:nth-of-type(2) {
		width: 24%;
		right: 18%;
		top: 33%;
	}
}
/******03*****/
#bl section:nth-of-type(3) {
	margin: 18% auto;
}
#bl section:nth-of-type(3) .box {
	width: 64%;
	margin: 0 auto;
}

@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(3) {
		margin: 10% auto;
	}
	#bl section:nth-of-type(3) .box {
		width: 30%;
		margin: 0 auto;
	}
}
/******04*****/
#bl section:nth-of-type(4) {
	position: relative;
}
#bl section:nth-of-type(4) .sticky {
	position: sticky;
	top: 0;
}
#bl section:nth-of-type(4) .box {
	
}
#bl section:nth-of-type(4) .flex {
	width: 100%;
	display: flex;
	justify-content: space-between;
	background: #fff;
	padding: 10% 4%;
}
#bl section:nth-of-type(4) .flex .box {
	width: 49.4%;
	margin: 0;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(4) {
		
	}
	#bl section:nth-of-type(4) .grid {
		width: 80%;
		max-width: 1000px;
		margin: 0 auto 230px;
		display: grid;
		grid-template-columns: 1.7fr 1fr;
		grid-template-rows: repeat(2, 1fr);
		grid-column-gap: 15px;
		grid-row-gap: 8px;
	}
	#bl section:nth-of-type(4) .grid .box:nth-of-type(1) {
		grid-area: 1 / 1 / 3 / 2;
	}
	#bl section:nth-of-type(4) .grid .box:nth-of-type(2) {
		grid-area: 1 / 2 / 2 / 3;
	}
	#bl section:nth-of-type(4) .grid .box:nth-of-type(3) {
		grid-area: 2 / 2 / 3 / 3;
	}
}
/******05*****/
#bl section:nth-of-type(5) {
	position: relative;
}
#bl section:nth-of-type(5) .box {
	
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(5) {
		width: auto;
	}
}
/******06*****/
#bl section:nth-of-type(6) {
	
}
#bl section:nth-of-type(6) .box {
	width: 68%;
	margin: 14% auto;
}
#bl section:nth-of-type(6) .box .more {
	top: 11%;
	right: 14%;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(6) .box {
		width: 33%;
		max-width: 420px;
		margin: 14% auto;
	}
}
/******07*****/
#bl section:nth-of-type(7) {
	
}
#bl section:nth-of-type(7) .container {
  padding: 5rem;
}
#bl section:nth-of-type(7) .scroll_container {
  height: 300vh;
}
#bl section:nth-of-type(7) .horizontal_scroll {
  position: absolute;
  top: 0;
  height: 100%;
  width: 300vw;
	margin-top: -136vw;
  will-change: transform;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#bl section:nth-of-type(7) .scroll_contents {
  height: 100vw;
  width: 100vw;
}
#bl section:nth-of-type(7) .sticky_wrap {
  overflow: hidden;
  position: sticky;
  top: 0;
  height: 171vh;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(7)  {
		
	}
	#bl section:nth-of-type(7) .container-pc {
		display: flex;
		justify-content: space-between;
	}
	#bl section:nth-of-type(7) .box {
		width: 30%;
	}
	#bl section:nth-of-type(7) .container-pc img {
		
	}
}
/******08*****/
#bl section:nth-of-type(8) {
	 position: relative;
	overflow: hidden;
	margin-top: -196vw;
}
#bl section:nth-of-type(8) .box {
	width: 83%;
	margin: 0 -6% 0 auto;
	z-index: 1;
	position: relative;
}
#bl section:nth-of-type(8) .ab:nth-of-type(1) {
	width: 41%;
	left: 0;
	top: 9%;
	z-index: 2;
}
#bl section:nth-of-type(8) .ab:nth-of-type(2) {
	width: 41%;
	left: 0;
	bottom: 9%;
	z-index: 2;
}
#bl section:nth-of-type(8) .box .more {
	right: auto;
	right: 11%;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(8) {
		margin: 210px auto;
	}
	#bl section:nth-of-type(8) .box .more {
		left: auto;
		right: 3%;
	}
	#bl section:nth-of-type(8) .box {
		width: 35%;
		margin: 0 0 0 auto;
	}
	#bl section:nth-of-type(8) .ab:nth-of-type(1) {
		width: 24%;
		right: 59%;
		left: auto;
		top: 13%;
	}
	#bl section:nth-of-type(8) .ab:nth-of-type(2) {
		width: 24%;
		right: 32%;
		left: auto;
		top: 33%;
	}
}

/******09*****/
#bl section:nth-of-type(9) {
	width: 92%;
	margin: 18% auto 0;
	position: relative;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
#bl section:nth-of-type(9) .box {
	width: 49%;
	position: relative;
}

@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(9) {
		width: 64%;
		margin: 200px auto 0 0;
	}
	#bl section:nth-of-type(9) .box {
	width: 49.5%;
	}
}

/******10*****/
#bl section:nth-of-type(10) {
	position: relative;
}
#bl section:nth-of-type(10) .box {
	
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(10) {
		width: auto;
	}
	#bl section:nth-of-type(10) .box {
		width: 84%;
		margin: 0 0 0 auto;
	}
}

/******11*****/
#bl section:nth-of-type(11) {
	margin: 18% auto;
}
#bl section:nth-of-type(11) .box {
	width: 64%;
	margin: 0 auto;
}
#bl section:nth-of-type(11) .box .text {
	font-size: 9px;
	position: absolute;
	width: 68%;
	bottom: -6%;
	right: -10%;
	line-height: 1.6;
	color: #535353;
	text-align: right;
}
@media only screen and (min-width: 769px) { 
	#bl section:nth-of-type(11) {
		margin: 10% auto;
	}
	#bl section:nth-of-type(11) .box {
		width: 30%;
		margin: 0 auto;
	}
	#bl section:nth-of-type(11) .box .text {
		font-size: 10px;
		bottom: -2%;
		right: -6%;
	}
}
/*********************************************
              footer
*********************************************/
footer {
	background: #2b1300;
	position: relative;
}
footer .logo {
	width: 40%;
	margin: 0 auto;
	padding: 19% 0 17%;
}
footer .copy {
	font-size: 7px;
	color: #fff;
	letter-spacing: .5px;
	text-align: center;
	padding-bottom: 2%;
}
@media only screen and (min-width: 769px) {
	footer {
	}
	footer .logo {
		width: 20%;
		max-width: 270px;
		padding: 110px 0 80px;
	}
	footer .copy {
		bottom: .5%;
		left: 50%;
		font-size: 9px;
		padding-bottom: 10px;
	}
}
/*********************************************
                js
*********************************************/
#bl .anim {
	opacity: 0;
	transition: 1.5s all 0s;
}
#bl .anim.ac {
	opacity: 1;
	transform: translate(0);
}
#bl .filter {
	filter: grayscale(1);
	transition: 2s all 0s ease;
}
#bl .filter.act {
	filter: grayscale(0);
}
/*********************************************
                view
*********************************************/
.spview {
	display: block;
}
.pcview {
	display: none;
}
@media only screen and (min-width: 768px)  {
    .spview {
		display: none;
	}	
	.pcview {
		display: block;
	}
}	
