@charset "UTF-8";
/*------------------------
共通
------------------------*/
#top-ttl::before {
	width: 922px;
	height: 90px;
	background: url(/campass/pc/img/about/en_about_w.svg) no-repeat;
	background-size: contain;
}
/*------------------------
トップイメージ
------------------------*/
.about-bg{
	background: url(/campass/pc/img/about/top_bg.jpg) center no-repeat;
	background-size: cover;
	position: relative;
}
.about-bg::after {
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(255, 255, 255, 0.15);
	position: absolute;
	top: 0;
	left: 0;
}
/*------------------------
コンセプト
------------------------*/
#concept{
	position: relative;
	margin-bottom: 100px;
}
#concept::before{
	content: "";
	width: 100px;
	height: 390px;
	background: url(/campass/pc/img/about/en_story.svg?20250912) no-repeat;
	background-size: cover;
	display: block;
	position: absolute;
	right: 0;
	top: 25px;
	opacity: .4;
	transition: all 0.8s ease 0s;
}
@media screen and (max-width:1420px) {
	#concept::before{
		opacity: 0;
	}
}
#concept .inner{
	padding: 90px 50px 180px;
	display: flex;
}
#concept .main{
	width: 475px;
	height: auto;
}
#concept .main img{
	object-fit: contain;
}
/* テキスト */
#concept .text .sub{
	background: var(--green);
	display: inline-block;
	font-size: 19px;
	padding: 4px 8px;
	font-weight: 500;
	color: #fff;
	letter-spacing: .1em;
	margin-bottom: 7px;
}
#concept .text{
	color: #fff;
	margin-left: 50px;
	flex: 1;
	text-shadow: 1px 2px 2px rgba(0, 0, 0, 0.7);
}
#concept .text h1{
	font-size: 34px;
	letter-spacing: .1em;
	font-weight: 500;
}
#concept .text h1 span{
	display: block;
	line-height: 1.4;
}
#concept .text .textarea{
	font-size: 16px;
	letter-spacing: .1em;
	margin-top: 20px;
	font-weight: 500;
	line-height: 2;
}
#concept .text .textarea p {
	margin-bottom: 30px;
}
/*------------------------
ストーリー
------------------------*/
#progress{
	position: relative;
	background: var(--green02);
	padding-top: 60px;
	margin: -100px 0 200px;
}
#progress::after {
	content: "";
	width: 100%;
	height: 80px;
	background: url(/campass/pc/img/index/scene_nami01.png) no-repeat;
	background-size: cover;
	display: block;
	position: absolute;
	top: -80px;
	left: 0;
}
#progress .image.bottom{
	height: 230px;
	width: 100%;
	position: absolute;
	bottom: -230px;
	left: 0;
}
#progress .flex{
	display: flex;
	justify-content: center;
	margin-bottom: 60px;
	position: relative;
}
#progress .flex:nth-child(1){
	flex-direction: row-reverse;
	margin-bottom: 80px;
}
#progress .flex:nth-child(3){
	flex-direction:row-reverse;
}
#progress .text-wrap{
	writing-mode: vertical-rl;
}
#progress .text-wrap .ttl .sub{
	width: 30px;
	height: fit-content;
	margin-left: 15px;
}
#progress .text-wrap .ttl h2{
	margin-left: 30px;
}
#progress .text-wrap .ttl h2 span{
	font-size: 26px;
	letter-spacing: .1em;
	font-weight: 500;
	display: block;
	line-height: 1.4;
}
#progress .text-wrap .ttl h2 span.tp{
	padding-top: 85px;
}
#progress .text-wrap .textarea {
	font-size: 16px;
	margin-top: 50px;
	font-weight: 500;
	line-height: 1.8;
	text-orientation: upright;
}
#progress .text-wrap .textarea .lr{
	writing-mode:lr;
	display: inline-block;
	line-height: 1;
}
#progress .text-wrap .textarea p{
	margin-left: 15px;
}
#progress .flex .img-wrap{
	display: flex;
	margin-left: 40px;
	position: relative;
}
#progress .flex .img-wrap .image:first-child{
	width: 300px;
	height: 220px;
	margin-top: 140px;
	margin-right: 15px;
}
#progress .flex .img-wrap .image:nth-child(2){
	display: block;
	width: 380px;
	height: 280px;
}
#progress .flex .img-wrap .image img{
	object-fit: cover;
	border-radius: 15px;
	border: 2px solid #fff;
}
/* 画像 */
#progress .main.image{
	width: 360px;
	height: 460px;
	position: relative;
	margin: 50px 80px 0 0;
}
#progress .main.image img{
	object-fit: cover;
	border: 2px solid #fff;
	border-radius: 20px;
}
/*------------------------
選ばれる理由
------------------------*/
#reason {
	position: relative;
	padding: 80px 0;
}
#reason h3{
	font-size: 22px;
	text-align: center;
	letter-spacing: .05em;
	font-weight: 600;
	margin-bottom: 12px;
}
#reason .box-wrap{
	display: flex;
	justify-content: space-between;
}
#reason .box-wrap .box{
	width: 270px;
	position: relative;
}
#reason .box-wrap .box .icon{
	position: absolute;
	top: -5px;
	left: -10px;
	background: var(--yellow);
	border-radius: 50%;
	font-size: 15px;
	text-align: center;
	line-height: 1.3;
	width: 50px;
	height: 50px;
	font-weight: bold;
	display: flex;
	align-items: center;
	justify-content: center;
	letter-spacing: -0.04em;
}
#reason .box-wrap .box .image{
	height: 170px;
	margin-bottom: 5px;
}
#reason .box-wrap .box .image img{
	object-fit: cover;
	border-radius: 12px;
}
#reason .box-wrap .box .ttl{
	font-weight: 600;
	font-size: 18px;
	margin-bottom: 2px;
}
#reason .box-wrap .box .textarea{
	font-size: 14px;
}
/*------------------------
お客様の声
------------------------*/
#voice {
	position: relative;
    margin-bottom: 80px;
}
#voice::before {
	content: "";
	width: 70vw;
	height: 100%;
	background: var(--yellow02) url(/campass/pc/img/common/pattern_w.png);
	position: absolute;
	right: 0;
	top: 0;
	border-radius: 50px 0 0 50px;
	min-width: 900px;
}
#voice .inner{
	padding: 60px 50px;
}
#voice .inner .ttl-wrap::after {
	background: #fff;
}
#voice .block-wrap{
	display: flex;
	justify-content: space-between;
}
#voice .block-wrap .block{
	width: calc((100% - 40px) / 3);
	background: #fff;
	padding: 20px 20px 20px;
	border-radius: 12px;
	border: 2px solid var(--yellow02);
}
#voice .block-wrap .block .top{
	display: flex;
	padding-bottom: 10px;
	margin-bottom: 10px;
	border-bottom: 2px solid var(--black);
}
#voice .block-wrap .block .top .icon{
	width: 80px;
	height: 80px;
	margin-right: 12px;
}
#voice .block-wrap .block .top .text{
	line-height: 1.4;
	font-weight: 500;
	flex: 1;
}
#voice .block-wrap .block .top .age{
	font-weight: bold;
	margin-bottom: 5px;
}
/*------------------------
campassを体験できる施設
------------------------*/
#facility .inner {
	padding: 20px 50px 100px;
}
#facility .inner .ttl-wrap::after{
	background: var(--yellow);
}
