@charset "UTF-8";

/*==================================================================
	page-concept.css
===================================================================*/

/* ------------------------------------------------------------------
	#concept
-------------------------------------------------------------------*/
#concept {
}

/* ------------------------------------------------------------------
	#concept .ttlArea
-------------------------------------------------------------------*/
#concept .ttlArea {
	background-image: url(../img/concept/bg_concept_ttl.jpg);
}
/* ------------------------------------------------------------------
	#concept_cont 共通
-------------------------------------------------------------------*/
#concept_cont .theta {
	height: 740px;
	background-size: cover;
	background-position: center;
	position: relative;
}
#concept_cont .theta span.block-w {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 180px;
	height: 40px;
	background-color: #fff;
	display: block;
}
#concept_cont h2 {
	display: inline-block;
	position: relative;
	padding-bottom: 20px;
	margin-bottom: 40px;
}
#concept_cont h2 img {
	height: 40px;
}

@media only screen and (max-width: 768px) {
	#concept_cont {
		padding: 0 0 0;
	}
	#concept_cont .theta {
		height: 240px;
		overflow-y: auto;
	}
	#concept_cont .theta span.block-w {
		display: none;
	}
	#concept_cont h2 {
		display: inline-block;
		padding-bottom: 10px;
		margin-bottom: 20px;
	}
	#concept_cont h2 img {
		height: 28px;
	}
}

/* ------------------------------------------------------------------
	#design
-------------------------------------------------------------------*/

#concept_cont #design .theta {
	background-image: url(../img/concept/bg_conceptDesign.jpg);
}
#concept #design .txtArea {
	padding: 70px 0 100px;
}
#concept #design .txtArea h2 {
}
#concept #design .txtArea h2 img {
}
#concept #design .txtArea p {
	color: #333333;
	font-size: 15px;
	font-weight: 700;
	width: 58%;
}

#concept #design .profile {
	margin-bottom: 140px;
	position: relative;
}
#concept #design .profile .bg-logoBlueRight {
	right: -380px;
}
#concept #design .profile .bg-logoBlueRight img {
	width: 75%;
}
#concept #design .profile .row .imgArea {
	text-align: center;
}
#concept #design .profile .row .imgArea img {
}
#concept #design .profile .row .profArea {
	padding-left: 8%;
	padding-right: 8%;
	padding-top: 80px;
}
#concept #design .profile .row .profArea p.comment {
	color: #333333;
	font-size: 16px;
	font-weight: 700;
	margin-bottom: 80px;
}
#concept #design .profile .row .profArea p.name {
	font-size: 24px;
	line-height: 29px;
	margin-bottom: 30px;
}
#concept #design .profile .row .profArea p.name small {
	font-size: 14px;
	font-weight: 700;
	vertical-align: bottom;
}
#concept #design .profile .row .profArea p.history {
	color: rgba(51, 51, 51, 0.5);
	font-size: 12px;
	line-height: 1.5em;
}

@media only screen and (max-width: 768px) {
	#concept #design .txtArea {
		padding: 40px 10px 50px;
	}
	#concept #design .txtArea p {
		font-size: 15px;
		width: 100%;
	}
	#concept_cont #design .theta iframe {
		height: 240px;
	}
	#concept #design .profile {
		margin-bottom: 20px;
	}
	#concept #design .profile .bg-logoBlueRight {
		display: none;
	}
	#concept #design .profile .row .imgArea img {
	}
	#concept #design .profile .row .profArea {
		padding-left: 4%;
		padding-right: 4%;
		padding-top: 20px;
	}
	#concept #design .profile .row .profArea p.comment {
		margin-bottom: 20px;
	}
	#concept #design .profile .row .profArea p.name {
		margin-bottom: 20px;
		vertical-align: bottom;
	}
	#concept #design .profile .row .profArea p.name small {
		font-size: 14px;
	}
	#concept #design .profile .row .profArea p.history {
	}
}

/* ------------------------------------------------------------------
	#service
-------------------------------------------------------------------*/
#concept #service {
	background-color: #8ddcdd;
	position: relative;
}
#concept #service .theta {
	background-image: url(../img/concept/bg_conceptService.jpg);
	height: 680px;
}
#concept #service .theta .block-w {
	top: 0;
	bottom: auto;
	left: auto;
	right: 0;
	width: 400px;
}
#concept #service #theme.txtArea {
	max-width: 540px;
	min-height: 300px;
	top: 380px;
	background-color: #8ddcdd;
	padding: 50px;
	z-index: 1;
	position: absolute;
}
#concept #service .txtArea p.word {
	color: #333333;
	font-size: 32px;
	font-weight: 700;
	line-height: 0.8em;
	margin-bottom: 0.8em;
}
#concept #service .txtArea p.word small {
	color: #333333;
	font-size: 16px;
	font-weight: 700;
	line-height: 0.5em;
}
#concept #service .txtArea p.concept {
	font-size: 13px;
	line-height: 20px;
}

#concept #service #serviceList {
	padding: 140px 0;
}
#concept #service #serviceList .bdr-service {
	content: '';
	display: block;
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 200px;
	background-color: #fff;
	height: 1px;
	margin-left: -100px;
}
#concept #service #serviceList h3 {
	font-family: Montserrat;
	color: #ffffff;
	font-size: 28px;
	font-weight: 700;
	line-height: 1.2em;
	margin-bottom: 30px;
}
#concept #service #serviceList p {
	color: #333333;
	font-size: 13px;
	line-height: 1.5rem;
}
#concept #service #serviceList #timeTravel {
	padding-bottom: 60px;
	margin-bottom: 50px;
}

#concept #service #serviceList #rooftop h4 {
	font-weight: bold;
	padding: 0 0 10px;
	font-size: 15px;
}
#concept #service #serviceList #rooftop .time-roof {
	margin: 10px 0 0;
	padding: 20px 0 0;
}
#concept #service #serviceList #rooftop .time-roof p {
	font-weight: bold;
	font-size: 15px;
}
#concept #service #serviceList #edge {
	padding-bottom: 60px;
	margin-bottom: 50px;
}
#concept #service #serviceList #edge .txtArea {
}
#concept #service #serviceList #edge .row .img {
	text-align: center;
}
#concept #service #serviceList #edge .row .img img {
}
#concept #service #serviceList #edge .row .txt {
}
#concept #service #serviceList #edge .row .txt h4 {
	font-family: Montserrat;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.5rem;
	margin-bottom: 15px;
}
#concept #service #serviceList #edge .row .txt p {
	color: #333333;
	font-size: 12px;
	line-height: 1.2rem;
}

#concept #service #serviceList #smoke {
	width: 50%;
}

@media only screen and (max-width: 768px) {
	#concept #service {
	}
	#concept #service .theta {
		background-image: url(../img/concept/bg_conceptService.jpg);
		height: 240px;
	}
	#concept #service #theme.txtArea {
		max-width: 100%;
		min-height: auto;
		top: auto;
		padding: 30px 10px 0;
		position: static;
	}
	#concept #service .txtArea h2 img {
		height: 25px;
	}
	#concept #service #serviceList {
		padding: 30px 0 10px;
	}
	#concept #service #serviceList .bdr-service {
		content: '';
		display: block;
		position: absolute;
		bottom: 0;
		left: 50%;
		width: 200px;
		background-color: #fff;
		height: 1px;
		margin-left: -100px;
	}
	#concept #service #serviceList h3 {
		color: #ffffff;
		font-size: 28px;
		font-weight: 700;
		line-height: 1.2em;
		margin-bottom: 30px;
	}
	#concept #service #serviceList p {
	}
	#concept #service #serviceList #timeTravel {
		padding-bottom: 40px;
		margin-bottom: 40px;
	}
	#concept #service #serviceList #timeTravel .txtArea {
		padding: 0 30px 30px;
	}
	#concept #service #serviceList #timeTravel .imgArea {
		text-align: center;
	}

	#concept #service #serviceList #rooftop {
		padding: 0 5px;
	}
	#concept #service #serviceList #rooftop .txtArea {
		padding: 0 25px 30px;
	}

	#concept #service #serviceList #rooftop .imgArea {
		padding: 0;
	}

	#concept #service #serviceList #rooftop .imgArea img {
		width: 100%;
	}

	#concept #service #serviceList #edge {
		padding-bottom: 10px;
		margin-bottom: 40px;
	}
	#concept #service #serviceList #edge .txtArea {
		padding: 0 15px 30px;
	}
	#concept #service #serviceList #edge ul.row {
		padding: 0 15px 0px;
	}
	#concept #service #serviceList #edge ul.row li {
		margin-bottom: 30px;
	}
	#concept #service #serviceList #edge .row .img {
		text-align: center;
		margin-bottom: 10px;
	}
	#concept #service #serviceList #edge .row .txt h4 {
		text-align: center;
		margin-bottom: 10px;
	}
	#concept #service #serviceList #edge .row .txt p {
		font-size: 12px;
		line-height: 1.2rem;
	}

	#concept #service #serviceList #smoke {
		width: 100%;
		padding: 0 10px 40px;
	}
}





/* ------------------------------------------------------------------
	#hotel
-------------------------------------------------------------------*/

#concept_cont #hotel {
	background-image: url(../img/concept/bg_hotel.jpg);
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
	padding: 90px 50px 150px;
	color: #fff;
	text-align: center;
}
#concept_cont #hotel .hotel__content{
}
#concept_cont #hotel .hotel__title{
	color: #8DDCDD;
	font-size: 37px;
	font-weight: bold;
	line-height: 1.2;
	width: fit-content;
	margin: 0 auto;
	padding: 0 0 17px 0;
	position: relative;
}
#concept_cont #hotel .hotel__title::after{
	content: '';
	display: block;
	height: 6px;
	width: 100%;
	background-color:  #8DDCDD;
	position: absolute;
	bottom: 0;
	left: 0;
}
#concept_cont #hotel .hotel__lead{
	display: block;
	margin: 30px auto 0;
	
}
#concept_cont #hotel .hotel__text{
	margin-top: 30px;
	
}
#concept_cont #hotel .hotel__text p{
	font-size: 16px;
	line-height: 2;
	font-weight: bold;
	margin-top: 15px;
}
#concept_cont #hotel .hotel__text p>span{
	display: block;	
}

#concept_cont #hotel .hotel__image{
	width: 100%;
	max-width: 700px;
	margin: 40px auto 0;
}
@media only screen and (max-width: 768px) {
	#concept_cont #hotel {
		padding: 80px 15px 80px;
	}
	#concept_cont #hotel .hotel__title{
		font-size: 28px;
		padding-bottom: 15px;
	}
	#concept_cont #hotel .hotel__lead{
		width: 211px;
	}
	#concept_cont #hotel .hotel__text p{
		font-size: 14px;
	}
	#concept_cont #hotel .hotel__text p>span{
		display: inline;	
	}
}