@charset "UTF-8";

#promise figure.bg01,#promise figure.bg02{
	height: 100dvh;
	width:100%;
	position: fixed;
	top:0;
	left:0;
	z-index: 1;
}

#promise figure.bg02{
	opacity: 0;
	transition: opacity 1s;
}

#promise figure.bg02.visible{
	opacity: 1;
}

#promise .section {
    height: 100vh;
    position: relative;
    color: #fff;
}

#promise .section.box2 {
    height: 400vh;
    position: relative;
    color: #fff;
}

#promise .section__pin {
    display: flex;
    align-items: flex-end;
    position: absolute;
	top: 0;
    left: 0;
    width: calc(100vw - 80px);
    height: 100%;
	padding: min(16vw,200px) min(8vw,100px);
}

#promise .section__pin.box2 {
    display: flex;
    align-items: center;
    position: absolute;
	top: 0;
    left: 0;
    width: calc(100vw - 80px);
    height: 100%;
	padding:0 min(8vw,100px);
}

#promise .mainvisual{
	position: relative;
	z-index: 2;
	width:100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}

#promise .mainvisual h1{
	color:#e2d8c9;
	border-left:5px solid #e2d8c9;
	padding:0 0 0 25px;
	display: flex;
	flex-direction: column;
	font-size: 2.6em;
	letter-spacing: 0.1em;
	position: relative;
	margin:0 0 120px 0;
}

#promise .mainvisual h1::after{
	content: "";
	height:100%;
	border-left:1px solid #e2d8c9;
	position: absolute;
	top:0;
	left:2px;
}

#promise .mainvisual h1 span{
	font-size: 0.4em;
	letter-spacing: 0.4em;
	margin:0.3em 0 1.8em 0;
	display: block;
}

#promise .mainvisual p{
	font-size: 3.8em;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	color:#e2d8c9;
}

#promise .text_container{
	padding:100px;
	position: relative;
	z-index: 2;
}

#promise .text_container p{
	font-size: 2em;
	line-height: 2.2em;
	color:#fff;
	margin:0 0 2.5em 0;
	letter-spacing: 0.1em;
}

#promise .text_container .text_mask{
	display: flex;
	flex-direction: column;
	width:100%;
}

#promise .text_container .text_mask .name{
	margin:120px 0 0 auto;
	color:#fff;
}

#promise .text_container .text_mask .name span{
	font-size: 1.4em;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	margin:0 0 1em 0;
	display: block;
}

#promise .text_container .text_mask .name figure{
	width:166px;
}

#promise .relative_cont{
	position: relative;
	z-index: 50;
}

#promise .promise_box{
	background:#e2d8c9;
	padding:80px min(8vw,100px);
}

#promise .promise_box .promise_tlbox{
	padding:160px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background-image:url("/images/promise_logo.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	letter-spacing: 0.1em;
	margin:0 0 80px 0;
}

#promise .promise_box .promise_tlbox .subtl{
	font-size: 2.6em;
	margin:0 0 15px 0;
}

#promise .promise_box .promise_tlbox h2{
	font-size: 3.8em;
	margin:0 0 30px 0;
}

#promise .promise_box .promise_tlbox .tx{
	font-size: 1.6em;
	text-align: center;
	line-height: 2.2em;
}


#promise .promise_box .promise_txbox{
	display: flex;
	justify-content: center;
	flex-direction: row-reverse;
	width:100%;
}

#promise .promise_box .promise_txbox .box{
	writing-mode: vertical-rl;
	padding:30px;
	transition: background 0.3s;
	border-left: 1px solid #d5c5af;
	cursor: pointer;
	position: relative;
}

#promise .promise_box .promise_txbox .box:first-child{
	border-right: 1px solid #d5c5af;
}

#promise .promise_box .promise_txbox .box .tl{
	writing-mode: vertical-rl;
	font-size: 2em;
	line-height: 2.2em;
	transition: color 0.3s;
	letter-spacing: 0.1em;
}

#promise .promise_box .promise_txbox .box .lead{
	display: grid; 
	grid-template-rows: 0fr;
    transition: .3s grid-template-rows;
	transition-timing-function: cubic-bezier(.67,.03,.4,.94);
	overflow: hidden;
}

#promise .promise_box .promise_txbox .box .lead > p {
  	overflow: hidden;
	writing-mode: vertical-rl;
	font-size: 1.6em;
	line-height: 2.2em;
	transition: padding 0.3s;
	letter-spacing: 0.1em;
	
}

#promise .promise_box .promise_txbox .box .lead > p span{
	text-combine-upright: all;
	margin:0 0 0.1em 0;
}

#promise .bottom_btnbox{
	padding:180px min(8vw,100px) 50px;
	background:#1c1818;
	display: flex;
	justify-content: center;
	align-items: center;
}

#promise .bottom_btnbox .innerbox{
	display: flex;
	flex-direction: column;
}

#promise .bottom_btnbox h3{
	font-size: 2.6rem;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	text-align: center;
	color:#e2d8c9;
	margin:0 0 40px 0;
}

@media screen and (max-width:750px) {
#promise figure.bg01,#promise figure.bg02{
	height: 100dvh;
	width:100%;
	position: fixed;
	top:0;
	left:0;
	z-index: 1;
}

#promise figure.bg02{
	opacity: 0;
	transition: opacity 1s;
}

#promise figure.bg02.visible{
	opacity: 1;
}

#promise .section {
    height: 100vh;
    position: relative;
    color: #fff;
}

#promise .section.box2 {
    height: 400vh;
    position: relative;
    color: #fff;
}

#promise .section__pin {
    display: flex;
    align-items: flex-end;
    position: absolute;
	top: 0;
    left: 0;
    width: 100vw;
    height: 100%;
	box-sizing: border-box;
	padding: 70px 5%;
}

#promise .section__pin.box2 {
    display: flex;
    align-items: center;
    position: absolute;
	top: 0;
    left: 0;
    width: 100vw;
    height: 100dvh !important;
	padding:0 5%;
	box-sizing: border-box;
}

#promise .mainvisual{
	position: relative;
	z-index: 2;
	width:100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: flex-start;
}
	
#promise .mainvisual .innerbox{
	top:0 !important;
}

#promise .mainvisual h1{
	color:#e2d8c9;
	border-left:3px solid #e2d8c9;
	padding:0 0 0 15px;
	display: flex;
	flex-direction: column;
	font-size: 2em;
	letter-spacing: 0.1em;
	position: relative;
	margin:0 0 60px 0;
}

#promise .mainvisual h1::after{
	content: "";
	height:100%;
	border-left:1px solid #e2d8c9;
	position: absolute;
	top:0;
	left:2px;
}

#promise .mainvisual h1 span{
	font-size: 0.4em;
	letter-spacing: 0.4em;
	margin:0.3em 0 1.8em 0;
	display: block;
}

#promise .mainvisual p{
	font-size: 2.5em;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	color:#e2d8c9;
}

#promise .text_container{
	padding:0;
	position: relative;
	z-index: 2;
}

#promise .text_container p{
	font-size: 1.3em;
	line-height: 2.2em;
	color:#fff;
	margin:0 0 2.5em 0;
	letter-spacing: 0.1em;
}

#promise .text_container .text_mask{
	display: flex;
	flex-direction: column;
	width:100%;
}

#promise .text_container .text_mask .name{
	margin:60px 0 60px auto;
	color:#fff;
}

#promise .text_container .text_mask .name span{
	font-size: 1.2em;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	margin:0 0 1em 0;
	display: block;
}

#promise .text_container .text_mask .name figure{
	width:140px;
}

#promise .relative_cont{
	position: relative;
	z-index: 50;
}

#promise .promise_box{
	background:#e2d8c9;
	padding:70px 5%;
}

#promise .promise_box .promise_tlbox{
	padding:80px 0;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	background-image:url("/images/promise_logo.svg");
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	letter-spacing: 0.1em;
	margin:0 0 50px 0;
}

#promise .promise_box .promise_tlbox .subtl{
	font-size: 1.8em;
	margin:0 0 10px 0;
}

#promise .promise_box .promise_tlbox h2{
	font-size: 2.6em;
	margin:0 0 20px 0;
}

#promise .promise_box .promise_tlbox .tx{
	font-size: 1.3em;
	text-align: center;
	line-height: 2.2em;
}


#promise .promise_box .promise_txbox{
	display: flex;
	justify-content: center;
	flex-direction: column;
	width:100%;
}

#promise .promise_box .promise_txbox .box{
	writing-mode:horizontal-tb;
	padding:20px;
	transition: background 0.3s;
	border-bottom: 1px solid #d5c5af;
	border-left: none;
	cursor: pointer;
}

#promise .promise_box .promise_txbox .box:first-child{
	border-top: 1px solid #d5c5af;
	border-right: none;
}

#promise .promise_box .promise_txbox .box .tl{
	writing-mode:horizontal-tb;
	font-size: 1.5em;
	line-height: 1.57em;
	transition: color 0.3s;
	letter-spacing: 0.1em;
}

#promise .promise_box .promise_txbox .box .lead{
	display: grid; 
	grid-template-rows: 0fr;
    transition: .3s grid-template-rows;
	transition-timing-function: cubic-bezier(.67,.03,.4,.94);
	overflow: hidden;
}
	
#promise .promise_box .promise_txbox .box.active .lead{
  	grid-template-rows: 1fr;
}
	
#promise .promise_box .promise_txbox .box.active{
  	background:#1c1818;
}

#promise .promise_box .promise_txbox .box.active .tl{
  	color:#fff;
}

#promise .promise_box .promise_txbox .box.active .lead{
  	grid-template-rows: 1fr;
}

#promise .promise_box .promise_txbox .box.active .lead > p{
  	color:#fff;
	padding:1em 0 0 0;
}

#promise .promise_box .promise_txbox .box .lead > p {
  	overflow: hidden;
	writing-mode:horizontal-tb;
	font-size: 1.3em;
	line-height: 2.2em;
	transition: padding 0.3s;
	letter-spacing: 0.1em;
	
}
	
#promise .promise_box .promise_txbox .box .lead > p span{
	text-combine-upright: all;
	margin:0 0 0.1em 0;
}

#promise .bottom_btnbox{
	padding:70px 5% 0;
	background:#1c1818;
	display: flex;
	justify-content: center;
	align-items: center;
}

#promise .bottom_btnbox .innerbox{
	display: flex;
	flex-direction: column;
}

#promise .bottom_btnbox h3{
	font-size: 2rem;
	line-height: 1.57em;
	letter-spacing: 0.1em;
	text-align: center;
	color:#e2d8c9;
	margin:0 0 30px 0;
}
	
#promise .bottom_btnbox a {
	width:90vw;
	max-width: 300px;
}
}

span.onbtn{
	width:100%;
	height: 100%;
	position: absolute;
	top:0;
	left:0;
}
@media (any-hover: hover) {
span.onbtn{
	display: none;
}
#promise .promise_box .promise_txbox .box:hover,#promise .promise_box .promise_txbox .box.active:hover{
  	background:#1c1818;
}

#promise .promise_box .promise_txbox .box.active{
  	background:none;
}

#promise .promise_box .promise_txbox .box:hover .tl,#promise .promise_box .promise_txbox .box.active:hover .tl{
  	color:#fff;
}
	
#promise .promise_box .promise_txbox .box.active .tl{
  	color:#000;
}

#promise .promise_box .promise_txbox .box:hover .lead ,#promise .promise_box .promise_txbox .box.active:hover .lead{
  	grid-template-rows: 1fr;
}
	
#promise .promise_box .promise_txbox .box.active .lead{
  	grid-template-rows: 0fr;
}

#promise .promise_box .promise_txbox .box:hover .lead > p{
  	color:#fff;
	padding:0 0 0 0;
}

@media screen and (max-width:750px) {
	#promise .promise_box .promise_txbox .box:hover .lead > p{
  	color:#fff;
	padding:1em 0 0 0;
}
}
	
}