@charset "utf-8";

/*  ==== 全体設定 ====*/
body {
	color: #24292e;
	font-family:"游ゴシック", monospace;	
}
a {
	text-decoration: none
}
img {
	max-width: 100%;	
}
h4 {
	font-size: 1.8vh;
	font-weight: 400;
	letter-spacing: -1.5px;
	line-height: 1.8;
	text-shadow: 0px 0px 1px black;
}

/* ==== メインスライダー ==== */

.logo-slider {
	max-width: 1070px;
	width: 90%;
	height: 70px;
	display: flex;
	inset: 0;             /* 最新中央揃え */
  	margin: 20px auto 0;  /* 中央揃えセット */
	border-radius: 45px;
	background-color: rgba(255,255,255,0.80);
	position: fixed;  /* ヘッダースクロール */
 	z-index: 1;
	box-shadow: rgba(0, 0, 0, 0.16) 0px 1px 4px;
}
.logo-slider img {
	text-align: center;
	display: block;
	max-width: 68px;
	width: 100%;
	height: auto;
	inset: 0;
	margin: 15px 0 15px 35px;
}
.line-button a {
	color: #fff;
	font-size: 2.2vh;
	font-weight: 900;
	background-color: #38C961;
	border-radius: 45px;
	padding: 0 35px 0 35px;
	line-height: 48px;
	top: 12px;
	right: 32px;
	letter-spacing: 0.5px;
	display:inline-block;
	position:absolute
}
.line-button :hover {
	transition: 0.7s;
	background-color: #08FF6E;
}	
.line-arrow {      /* スライダー枠内固定！*/
	display: block;
	position: absolute;
	width: 8px;
	height: 8px;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
	right: 50px;
	top: 32px;
}

/*==== メインイメージ ====*/

.text-box p,
.text-box2 p {
	font-weight: 900;
	text-decoration: underline;
	text-underline-offset: 9px;
	font-size: 2vh; 
}
.text-box h3,
.text-box2 h3 {
	font-weight: 900;
	font-size: 3.4vh;
	text-shadow: 0px 0px 1px #24292e;
}
.text-box h1,
.text-box2 h1 {
	font-weight: 900;
	font-size: 5.8vh;
	letter-spacing: 2px;
	text-shadow: 0px 0px 1px #24292e;
	line-height: 1.3;
}
.text-box h1 span,
.text-box2 h1 span {
	letter-spacing: -5px;
}

/*==== メイン下　赤ライン ====*/

.main-second {
	width: 100%;
	background-color: rgba(55,48,251,1.00);
	text-align: center;
	padding: 0 20px 65px 20px;
}

/* 下ライン　*/
.second-inner {
	max-width: 640px;
	height: 80px;
	margin: 0 auto;
	position: relative;
}
.main-second p {
	color: #fff;
	text-align: center;
	font-weight: 900;
	font-size: 2.2vh;
	padding: 65px 0 15px 0;
	letter-spacing: -1px;
}
.line-button2 :hover {
	transition: 0.7s;
	background-color: #08FF6E;
}
div#line-arrow2 {
	position: absolute;
	display: block;
	width: 12px;
	height: 12px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	transform: rotate(45deg);
	bottom: 35px;
	right: 28px;
}

/*==== コンセプト ====*/

.concept {
	width: 100%;
	height: auto;
	text-align: center;
	background-color: rgba(211,225,252,0.6);	
}
.concept-fast ul li h4 {
	text-align:left;
	padding: 0;
}

/*====　プライベート　====*/

.private-area {
	padding: 0 40px 40px;
	display: flex;
	text-align:left;
}
.private-area ul li {
	font-weight: 900;
	font-size: 1.8vh;
	list-style: none;
}
.p-text-area li:first-child {
	padding-top: 15px;
}

/* sp */
@media screen and (min-width: 1081px){
	.concept {
		padding: 120px 0 ;
	}
	.logo-slider p {
		font-weight: 900;
		font-size: 3.4vh;
		letter-spacing: 1px;
		text-shadow: 0px 0px 1px black;
		margin: 15px 0 15px 15px;
	}
	.line-button2 a {
		color: #fff;
		font-size: 2.6vh;
		font-weight: 900;
		background-color: #38C961;
		display:inline-block;
		border-radius: 45px;
		padding: 0 185px 0 185px;
		line-height: 80px;
		letter-spacing: 1px;
		box-shadow: rgba(0, 0, 0, 0.3) 0px 3px 5px;
	} 	
	.main-top {
		max-width: 1260px;
		width: 100%;
		margin: auto;
		text-align: center;
		position: relative;
	}
	.text-box {
		text-align:left;
		position: absolute;
		top: 24.8%;
		left: 11%;
	}
	.text-box p {
		margin-bottom: 15px;
	}
	.text-box2 {
		display: none; /*　改行文消し違うテキストに*/
	}
	.br-sp {
		display: none; /*  改行消す　*/
	}
	.concept-fast ul {
		display: flex;
		margin: 0 10px;
	}
	.concept-fast ul li {
		list-style:none;
		max-width: 310px;
		width: 100%;
		height: 350px;
		margin: 0 10px;
	}
	.concept-fast {
		width: 100%;
		max-width: 990px;
		height: auto;
		list-style: none;
		margin: 0 auto;
		padding-top: 42px;
	}	
	.item-flame {
		padding-bottom: 40px;
	}	
	.private {
		max-width: 1000px;
		height: auto;
		margin: 0 auto ;
		background-color: #FFF;
		border-radius: 15px;
	}
	.private h2 {
		padding: 40px;
		letter-spacing: 1px;
		line-height: 1.4;
		padding-bottom: 20px;
	}
	.concept h2 {
		font-weight: 900;
		font-size: 4.8vh;
		letter-spacing: -0.3px;
		text-shadow: 0px 0px 1.2px #24292e;	
	}
	.item-flame img {
		width: 258px;
		height: 165px;
	}
	.p-text-area p {
		font-size: 2.6vh;
		font-weight: 900;
		color: #D92E20;
		text-shadow: 0px 0px 1.2px #D92E20;
		letter-spacing: -1px;
		padding-top: 10px;
	}	
	.private-area img {
		width: 100%;
		max-width:410px;
		height: 240px;
		object-fit: cover;
		margin-left: 40px;
	}
	.p-text-area p {
		margin-top: 15px;
	}	
		
}

@media screen and (min-width: 661px) and (max-width: 1080px){
	.main-second {
		padding: 0 20px 165px 20px;
	}
		
}

@media screen and (min-width: 661px){
	.line-button-sp {
		display: none;
	}
	.line-button {
		display: block;
	}
	
}

@media screen and (min-width: 461px){
	
	.item-flame {
		margin-right: 40px;
	}
	
}

@media screen and (max-width: 1080px){
	div#wrapper {
		width: 100%;
		max-width: 750px;
		margin: 0 auto;
		height: auto;	
	}
	.concept {
		padding: 40px 0 ;
	}
	.logo-slider p {
		font-weight: 900;
		font-size: calc(1.8vw + 0.9rem);	
		text-shadow: 0px 0px 1px black;
		margin: 15px 0 15px 15px;
	}
	.line-button a {
		font-size: calc(0.8vw + 0.5rem);
		padding: 0 30px 0 26px;
		line-height: 45px;	
	}
	.line-arrow {      /* スライダー枠内固定！*/
		right: 44px;
		top: 30px;
	}	
	.line-button2 a {
		margin: 0 auto;
		color: #fff;
		font-size: calc(2.6vw + 0.8rem);
		font-weight: 900;
		background-color: #38C961;
		display:block;
		border-radius: 55px;
		padding: 30px 130px 30px 130px;
		line-height: 55px;
		letter-spacing: 1px;
		box-shadow: rgba(0, 0, 0, 0.3) 0px 10px 10px;	
} 
	div#line-arrow2 {
		position: absolute;
		display: block;
		width: 12px;
		height: 12px;
		border-top: 3px solid #fff;
		border-right: 3px solid #fff;
		transform: rotate(45deg);
		bottom: 18px;
		right: 30px;
	}
	.main-top  {
		margin: 0 auto;
		text-align: center;		
	}	
	.main-top img {
		width: 100%;
	}
	.text-box {
		display: none;
	}	
	.text-box2 {
		text-align: center;
		padding-top: 5%;
		margin-bottom: 6.5%;
	}
	.text-box2 p{
		font-size: calc(2vw + 0.5rem);		
	}
	.text-box2 h3 {
		padding-top: 1.5%;
		font-size: calc(3.1vw + 0.8rem);
		letter-spacing: -1px;
	}
	.text-box2 h1 {
		font-size: calc(5vw + 1rem);
		text-shadow: 0px 0px 1.5px #24292e;
	}
	.main-second p {
		font-size: calc(2vw + 0.7rem);
		padding-top: 10%;	
	}
	
	/*=== コンセプト sp　=== */
	.concept h2 {
		font-size: calc(4.4vw + 1rem);
		letter-spacing: -2px;
		line-height: 1.5;
		text-shadow: 0px 0px 2px #24292e;
	}

	.concept h4 {
		font-size: calc(2vw + 0.6rem);
		letter-spacing: -2px;
		line-height: 1.5;
		text-shadow: 0px 0px 1.2px #24292e;
	}
	
	
	/* ====== 3つの画像 ========*/
	.concept-fast {
		width: 100%;
		padding: 6% 8% 8% 8%;	
	}	
	.concept-fast ul li{
		display: flex;		
	}	
	.item-flame  {
		max-width: 230px;
		margin-bottom: 20px;
	}
	.item-flame img {
		width: 100%;	
	}	
	.concept-fast h4 {
		font-size: calc(2vw + 0.3rem);
		letter-spacing: 3.5px;
		line-height: 1.8;		
	}	
	.text {
		width: 360px;
		margin-bottom: 20px;
	}	
	
	/*==== プライベート ===*/
	.private {
		width: 100%;
		height: auto;
		text-align: center;
	}
	.private-speac {
		display: block;   /* tp　確認！*/
		width: 100%;
		max-width: 630px;
		height: auto;
		text-align: center;
		background-color: #fff;
		border-radius: 15px;
		margin: 0 auto;
		padding-top: 42px;
	}
	.private-area {       /*  縦並び  */
  		flex-direction: column;
  		padding-top: 6%;
	}
	.private h2 {
		font-size: calc(3.5vw + 1rem);
		text-shadow: 0px 0px 1.5px #24292e;
		letter-spacing: 1px;
	}
	.p-text-area li:first-child {	
	}
	.private-area ul li {
		text-indent: -1em;  /*  箇条書対策　*/
   		padding-left: 1em;
		padding-top: 1.5%;
		font-size: calc(1.7vw + 0.8rem);
		letter-spacing: -2px;
	}
	.p-text-area p {
		padding-top: 12px;
		font-size: calc(2.5vw + 0.8rem);
		letter-spacing: -1px;
		font-weight: 900;
		color: #D92E20;
		text-shadow: 0px 0px 1.2px #D92E20;		
	}
	.private-area img {
		padding-top: 20px;
	}
	
}
	
@media screen and (max-width: 660px){
	.line-button-sp {
		display: block;
	}
	.line-button {
		display: none;
	}
	.logo-slider img {	
		width: 30px;
		margin: 15px 10px 15px 15px;
	}
	.logo-slider {
		height: 56px;	
	}
	.logo-slider p {	
		margin: 10px 10px 10px 5px;
	}
	.line-button-sp a {
		color: #fff;
		font-size: 1.6vh;
		font-weight: 900;
		background-color: #38C961;
		border-radius: 45px;
		padding: 0 15px 0 12px;
		line-height: 48px;
		top: 4px;
		right: 5px;
		letter-spacing: 0.5px;
		display:inline-block;
		position:absolute
	}
	
	.line-arrow {      /* スライダー枠内固定！*/
		right: 12px;
		top: 24px;
	}
	.line-button-sp :hover {
		transition: 0.7s;
		background-color: #08FF6E;
	}
	
	.line-button2 a {
		width: 90%;
		font-size: calc(2.3vw + 0.7rem);
		border-radius: 55px;
		padding: 20px 20px 20px 20px;
		line-height: 35px;
		letter-spacing: -1px;
	} 
	div#line-arrow2 {
		width: 10px;
		height: 10px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		bottom: 38px;
		right: 50px;
	}
	
}

@media screen and (max-width: 460px){
	
	.item-flame {
		margin-right: 15px;
	}	
	.logo-slider p {
		font-weight: 700;
		font-size: 18px;
		margin: 18px 10px 10px -5px;
	}
	.line-button2 a {
		width: 90%;
		font-size: calc(2.6vw + 0.8rem);
		border-radius: 55px;
		padding: 12px 15px 12px 15px;
		line-height: 30px;
		letter-spacing: -1px;
	} 
	div#line-arrow2 {
		width: 8px;
		height: 8px;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		bottom: 50px;
		right: 30px;
	}
	.main-second {
	padding: 0 20px 65px 20px;
}

}


