@charset "UTF-8";

#top
{
	overflow: hidden;
}

.entry-title_p
{
	margin-bottom: 0;
	padding: 0rem 0rem 1rem
}

.entry-title_p .entry-title
{
	width: 100%;
	max-width: calc(1280px + 4rem);
	margin: 0rem auto;
	padding: 3rem 2rem 0rem 4rem;
}

.slide_linear
{
	overflow:hidden;
}

/**********************************************************************/
/******************************* Text ********************************/
/**********************************************************************/

#concept
{
	width: 100%;
	max-width: calc(1020px + 4rem);
	margin: 0rem auto;
	padding: 5rem 2rem 0rem 4rem;
	display:flex;
	justify-content: space-between;
}

body.en #concept
{
	flex-direction: column;
}

body.en #concept h2
{
	margin-bottom: 1em;
}

body:not(.en) #concept h2
{
	writing-mode: tb;
	margin-right: 3em;
}

#concept > div
{
	transition-delay: .5s;
	display:flex;
	justify-content: flex-end;
}

#concept > div > div
{
	max-width: 100%;
}

#concept > div > div p + p
{
	margin-top: 1em;
}

/**********************************************************************/
/******************************* DATA ********************************/
/**********************************************************************/

#data
{
	width: 100%;
	max-width: calc(1020px + 4rem);
	margin: 0rem auto;
	padding: 5rem 2rem 0rem 4rem;
}

#data h2
{
	font-size: 1.2rem;
	margin-bottom: 1em;
}

#data h2 > span
{
	display:inline-block;
	font-size: .7em;
	margin-left: 1em;
}

#data table
{
	line-height: 1.5;
}

#data th,
#data td
{
	padding-top: .5em;
}

#data th
{
	text-align:left;
	vertical-align: top;
	padding-right: 1em;
}

#data th > p
{
	padding-left: 1em;
}

#data th > p:before
{
	content:'';
	display:block;
	position:absolute;
	top: .5em;
	left:0;
	width:.5em;
	height:.5em;
	border-radius:50%;
	background-color: rgb(50, 50, 50);
}

/*//////////////////////////////////////////////////////////////////////////////////
///////////////////////////////// MEDIA SCREEN ////////////////////////////////
//////////////////////////////////////////////////////////////////////////////////*/

@media screen and (max-width: 1020px)
{
	.archi_cont .text_photo,
	.archi_cont:nth-child(2n) .text_photo
	{
		flex-direction: column-reverse;
	}
	.archi_cont .text_photo figure
	{
		width: 100%;
		position:static;
	}
	
	.archi_cont .text
	{
		width: 100%;
		padding-right: 2rem;
	}
	
	.archi_cont:nth-child(2n) .text
	{
		padding-right: 0rem;
		padding-left: 4rem;
	}
}

@media screen and (max-width: 900px)
{	
	body .archi_cont
	{
		padding-top:0;
	}
	
	.archi_cont .text
	{
		width: 100%;
		padding: 2rem 2rem 0rem 0rem;
	}
	.archi_cont:nth-child(2n) .text
	{
		width: calc(100% + 2rem);
		padding: 2rem 0rem 0rem 4rem;
	}
}

@media screen and (max-width: 650px)
{
	#data table th,
	#data table td
	{
		display:block;
	}
	#data td
	{
		padding-top:0;
		padding-left: 1em;
	}
}

@media screen and (max-width: 650px)
{
	body:not(.en) #concept h2
	{
		writing-mode: lr;
		margin-right: 0em;
		margin-bottom: 2em;
	}
	body:not(.en) #concept
	{
		flex-direction: column;
	}
}

@media screen and (max-width: 600px), (max-height: 600px)
{
	.entry-title_p .entry-title
	{
		padding: 2rem 2rem 0rem 2rem;
	}
	#concept,
	#data
	{
		padding: 5rem 2rem 0rem 2rem;
	}

	.archi_cont .text_photo,
	.archi_cont:nth-child(2n) .text_photo
	{
		padding: 0;
	}
	
	.archi_cont .text,
	.archi_cont:nth-child(2n) .text
	{
		width: 100%;
		padding: 2rem 2rem 0rem;
	}
}