@charset "UTF-8";
/* CSS Document */

body,
header,
nav,
footer {
	margin: 0;
	padding: 0;
}

*{
	/*emmet:-bxz*/
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

/*clearfix*/
.clr::after{
	content: "";
	display: block;
	clear: both;
}



/*サイトの基本レイアウト*/
header{	
	color: #333;
	top: 0;
	z-index: 3;
	width: 100%;
}

/*ボックスの背景色*/
/*.entry-box-two,
.entry-box-three,
.entry-box-four,
.entry-box-two-thirds,
.entry-box-three-quarters,
.entry-box-two-fifths,
.entry-box-three-fifths{
	background: rgba(240,240,240,0.6);
}*/

.pagebody{
	margin: 0 1.5rem;
}

/*子要素の並べ方*/
.flex,
.flex-bp1025,
.flex-bp600{
	/*emmet:d:f*/
	display: flex;
	/*emmet:fxw:w*/
	flex-wrap: wrap;
	/*emmet:jtc:sb*/
	justify-content: space-between;
}

/*header*/
#heroheader{
	position: relative;
	margin-bottom: 0;
	top: 60px;
	background-color: var(--color-base);
	margin-top: -2rem;
}

#heroheader-copy{
	position: absolute;
	/*-----
	top: 20%;
	------*/
	top: 15%;
	left: 5%;
	/*------
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	---------*/
	display: none;
}

#heroheader-copy li p{
    font-size: 4.5rem;
    letter-spacing: 0.5rem;
    line-height: 1;
    font-weight: bold;
	padding: 0.5rem;
}

#header-inner{
	display: flex;
	justify-content: space-between;
	align-items: center;
}
#header-logo{
	flex-basis: 200px;
	padding: 0 1rem;
}
nav{
	flex-basis: 80%;
}

#header-sns-button{
	flex-basis: 10%;
}
#header-contact-button{
	flex-basis: 300px;
}
.header-contact-button-items{
	width: 45%;
}
/*gnaviの基本的なデザイン*/
#gnavi li{
	font-size: 1.2rem;
	letter-spacing: 0.56px;
}


/*基本の並べ方*/
.flex .entry-box-two{
	width: 49%;
	}
.flex .entry-box-three{
	width: 32%;
	}
.flex .entry-box-four{
	width: 23.5%;
	}
.flex .entry-box-two-thirds	{
	width: 66%;
	}
.flex .entry-box-three-quarters {
	width: 74.5%;
	}
.flex .entry-box-two-fifths{
	width: 39%;
}
.flex .entry-box-three-fifths{
	width: 59%;
	background: #FFEEDD;
}

#heroheader {
	position: relative;
}

#heroheader::before {
	position: absolute;
	content: "";
	background-image: url('../img/top_catch.png');
	width: 12rem;
    height: 10rem;
	background-size: cover;
	background-repeat: no-repeat;
	right: 5%;
	top: 66%;
}

/*レスポンシブデバイス対応*/

@media screen and (min-width: 1025px){
	#menu-item-61 {
		width: 12rem;
		margin-right: 1rem;
	}
	#menu-item-60 {
		width: 12rem;
		margin-right: 1rem;
	}

	#gnavi{
		display: flex!important;
		justify-content: space-between;
		align-items: center;
	}
	
	/*gnav-itemsの並べ方*/
	#gnavi ul{
		display: flex;
		justify-content: space-around;
	}

	#gnavi li a {
		font-size: 1.2rem;
	}

	.bp1025-none{
		display: none;
	}
	
	/*ボックスの並べ方*/		
	.flex-bp1025 .entry-box-two{
		width: 49%;
	}
	.flex-bp1025 .entry-box-three{
		width: 32%;
	}
	.flex-bp1025 .entry-box-four{
		width: 23.5%;
	}
	.flex-bp1025 .entry-box-two-thirds	{
		width: 66%;
	}
	.flex-bp1025 .entry-box-three-quarters {
		width: 74.5%;
	}
	.flex .entry-box-two-fifths{
		width: 39%;
	}
	.flex .entry-box-three-fifths{
		width: 59%;
		background: #FFEEDD;
	}

	#heroheader::before {
		width: 24rem;
		height: 21rem;
		right: 10%;
		top: 10%;
	}

	/*pagebody内のコンテンツとサイドバーが縦に並ぶ*/
	#alpha{
		flex: 1;
	}
	#beta{
		flex-basis: 250px;
		flex-shrink: 0;
	}
}

@media screen and (max-width: 1024px) {
	.flex-bp1025 .entry-box-two,
	.flex-bp1025 .entry-box-three,
	.flex-bp1025 .entry-box-four,
	.flex-bp1025 .entry-box-two-thirds,
	.flex-bp1025 .entry-box-three-quarters,
	.flex-bp1025 .entry-box-two-fifths,
	.flex-bp1025 .entry-box-three-fifths{
		width: 100%;
	}
	
	.menu-trigger {
		position: relative;
		width: 3rem;
		height: 3rem;
		background: transparent;
		border: 0;
		z-index: 4;
		margin: 2rem;
	}
	.menu-trigger span {
		position: absolute;
		background: var(--color-text);
		width: 35px;
		height: 2px;
		left: 0;
		right: 0;
		margin: auto;
		-webkit-transition: 0.5s ease-in-out;
		transition: 0.5s ease-in-out;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 1rem;
	}
	.menu-trigger span:nth-of-type(2) {
		bottom: 0.75rem;
	}
	.menu-trigger.active span:nth-of-type(1) {
		top: 0.5rem;
		-webkit-transform: translateY(0.9rem) rotate(45deg);
		transform: translateY(0.9rem) rotate(45deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		bottom: 0.5rem;
		-webkit-transform: translateY(-0.9rem) rotate(-45deg);
		transform: translateY(-0.9rem) rotate(-45deg);
	}
	
	#heroheader-copy{
		/*----
		top: 18%;
		---*/
		top: 8%;
		left: 24%;
	}
	#heroheader-copy li p{
		font-size: 3rem;
	}
	#gnavi {
		display: none;
		position: fixed;
		top: 0;
		z-index: 3;
		background: #fff;
		width: 100vw;
		height: 100vh;
	}
	#menu-gnavi li {
		border-bottom: 1px dashed var(--color-text);
		font-size: 1.6rem;
	}
	
	#menu-gnavi li a {
		text-align: center;
		color: var(--color-text);
		padding: 0.6rem 0;
	}
	#menu-gnavi li a:hover {
		background: rgba(255,255,255,.4);
		transition: .3s;
	}
	#header-contact-button ul,
	#header-sns-button ul{
		display: flex;
		margin-left: 1rem;
	}
	.header-contact-button-items{
		flex-basis: 30%;
		margin-right: 1rem;
	}
	.header-sns-button-items{
		width: 20px;
		margin: 0.75rem 1rem;
	}
	#message p {

	}
}

@media screen and (min-width:850px){
	/*#message section*/
	#message p{
		font-size:1.2rem;
		line-height: 4rem;
	}
	#message h2{
		font-size: 2.5rem;
		margin-bottom: 4rem;
	}
	#bg-message img{
		max-width: 90%;
	}
	.message-items{
		width: 70%;
	}	
}
@media screen and (min-width: 600px) and (max-width: 1024px){
	#beta{
		display: -webkit-flex;
		display: -moz-flex;
		display: -ms-flex;
		display: -o-flex;
		display: flex;
		justify-content: space-between;
	}
	#beta aside{
		width: 49%;
	}
}

@media screen and (min-width: 728px) and (max-width: 1024px){ 
	#heroheader::before {
		width: 20rem;
		height: 17rem;
		right: 10%;
		top: 20%;
	}
}

@media screen and (min-width: 600px){
	.flex-bp600 .entry-box-two{
		width: 49%;
	}
	.flex-bp600 .entry-box-three{
		width: 32%;
	}
	.flex-bp600 .entry-box-four{
		width: 23.5%;
	}
	.flex-bp600 .entry-box-two-thirds	{
		width: 66%;
	}
	.flex-bp600 .entry-box-three-quarters {
		width: 74.5%;
	}
	.flex-bp600 .entry-box-two-fifths{
		width: 40%;
	}
	.flex-bp600 .entry-box-three-fifths{
		width: 60%;
	}
}

@media screen and (max-width: 599px){
	.flex-bp600 .entry-box-two,
	.flex-bp600 .entry-box-three,
	.flex-bp600 .entry-box-four,
	.flex-bp600 .entry-box-two-thirds,
	.flex-bp600 .entry-box-three-quarters,
	.flex-bp600 .entry-box-two-fifths,
	.flex-bp600 .entry-box-three-fifths{
		width: 100%;
	}
	
	#heroheader-copy{
		top: 56%;
		left: 46%;
		transform: translate(-50%,-50%);
	}

	#heroheader-copy li p{
		font-size: 2.8rem;
	}
	html{
		font-size:12px;
	}
}


@media screen and (min-width: 1600px){
	#bg-message img {
		max-width: 100%;
	}
	#message p {
		font-size: 2rem;
		line-height: 6rem;
		width: 100%;
		margin: auto;
		letter-spacing: 0.26rem;
		margin-top: 8rem;
	}
	#message h2 {
		font-size: 4rem;
		margin-bottom: 2rem;
		margin-top: 3rem;
	}
}

@media screen and (min-width: 1190px) {
	.pagebody{
		width: 85.41%;
		margin: 0 auto;
		max-width: 1640px;
	}
}


@media screen and (min-width: 1600px)  {
	#gnavi li a {
		font-size: 2rem;
	}
	#header-logo{
		margin-left: 10rem;
	}

	.header-contact-button-items{
		width: 21rem;
		padding: 1rem 0;
	}
	#menu-item-61 {
		width: 15rem;
		margin-right: 4rem;
	}
	#menu-item-60 {
		width: 20rem;
		margin-right: 3rem;
	}
	#header-logo{
		margin-left: 10rem;
	}
	#message p {
		letter-spacing: 0.085rem;
	}
}

@media screen and (min-width: 1750px) {
	#message p {
		letter-spacing: 0.26rem;
		line-height: 4;
	}
}

