@charset "utf-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Serif+JP&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Hammersmith+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Abril+Fatface&display=swap');

/*===========　レスポンシブ用基礎CSS　===========*/

/*ボックスモデルをborder-boxに変更*/
* {
	box-sizing: border-box;
}

/*フルードイメージ*/
img {
	max-width: 100%;
	height: auto;
}

/*回転時の文字調整封印*/
html{
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  background: #fff;
}

/*===========　スマホ用　通常時　===========*/

body {
	color: #333;
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: 500;
	position: relative;
	max-width: 640px;
	margin: 0 auto;
	line-height: 1.2;
	padding-bottom: 14vw;
	padding-top: 60px;
	scroll-padding-top: 70px;
}
#outer_block{box-sizing: border-box;position: relative;z-index: 10;}
@media (min-width:768px){


	body {
		color: #333;
		position: relative;
		max-width: 1500px;
		margin: 0 auto;
		line-height: 1.2;
		padding-bottom: 5vw;
		padding-top: 100px;
		scroll-padding-top: 100px;
	}
}

/*===========　枠　===========*/

/*===========　ロゴ　===========*/
#header_logo{
	width: 100%;
	height: 60px;
	max-width: 640px;
	background: #6096BA;
	position: fixed;
	z-index: 999;
	top: 0;
	left: 0;
	right: 0;
	margin: 0 auto;
	display: block;
}

#header_logo a{
	display: block;
	width: 50vw;
	height: 100%;
	margin: 0 auto;
	position: absolute;
	top: 0;
	left: 0px;
	right: 0;
	background: url(../reimg/re_logo.png) no-repeat center center/100%;
}

@media (min-width:768px){
	#header_logo{
		height: 100px;
		width: 100%;
		max-width: 1500px;
	}
	#header_logo a{
		display: block;
		width: 15vw;
		height: 100%;
		margin: 0 auto;
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		background: url(../reimg/re_logo.png) no-repeat center center/100%;
		z-index: 99;
	}
}
/*===========　ヘッダー　===========*/
#html_pc, #html_sp {
    margin: 0 auto;
    z-index: 1;
    display: none;
    width: 100%;
    position: relative;
		background: #fff;
}

#html_pc{height: 72vw;}
#html_sp{height: 100.5vw;display: block;}


.slick-track{display: flex !important;}

.slider {
  position:relative;
  z-index: 1 !important;
	/*↑z-indexの値をh1のz-indexの値よりも小さくして背景に回す*/
}

/*　PC　*/

#html_pc .slider-item01 {
    background:url(../reimg/pc_slide1.png);
}

#html_pc .slider-item02 {
    background:url(../reimg/pc_slide2.png);
}

#html_pc .slider-item03 {
    background:url(../reimg/pc_slide3.png);
}

#html_pc:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: url(../reimg/pc_cover_slide.png) no-repeat center top/90%;
}

/*　SP　*/
#html_sp:before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10;
    content: "";
    display: block;
    width: 100%;
    height: 100.5vw;
    background: url(../reimg/slide_cover.png) no-repeat center top/100%;
}

#html_sp .slider-item01 {
    background:url(../reimg/top_slide1.png);
}

#html_sp .slider-item02 {
    background:url(../reimg/top_slide2.png);
}

#html_sp .slider-item03 {
    background:url(../reimg/top_slide3.png);
}

.slick-prev,
.slick-next{display: none !important;}

.slider-item {
	width: 100% !important;
	height: 100.5vw !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: 100% !important;
}

@media (min-width:768px){

}

@media (min-width:768px){
	#html_pc{
		display: block;width: 100%;
		max-height: 67vw !important;
		height: 72vw !important;
	}
	#html_sp{display: none;}

	#html_pc .slider {
		max-height: 67vw !important;
		height: 72vw !important;
	}

	#html_pc .slider-item {
		max-height: 67vw !important;
		height: 72vw !important;
		}
}



/*===========　スライドテキスト　===========*/
#top_slide_txt{
	display: block;
	width: 100%;
	height: 7vw;
	border-top: solid 1px #274C77;
	border-bottom: solid 1px #274C77;
	background: url(../reimg/slide_re_top.png) repeat-x center center/80%,#fff;
	animation: toleft 60s linear 0s infinite;
	position: absolute;
	top: 87vw;
	left: 0;
	right: 0;
	z-index: 99;
}

@keyframes toleft {
  0% { background-position-x: 0; }
  100% { background-position-x: -200vw; }
}

@media (min-width:768px){
	#top_slide_txt{
		height: 5vw;
		background: url(../reimg/slide_re_top.png) repeat-x center center/60%,#fff;
		animation: toleft 60s linear 0s infinite;
		top: 54vw;
		z-index: 99;
	}

}
/*===========　スライドテキスト　scrolldown ===========*/

#scroll-down {
  display: block;
  position: relative;
  padding-top: 150px;
  text-align: center;
  background: #fff;
}
.arrow-down {
  display: block;
  margin: 0 auto;
  width: 10px;
  height: 38px;
}
.arrow-down:after {
  content: '';
  display: block;
  margin: 0;
  padding: 0;
  width: 8px;
  height: 8px;
  border-top: 2px solid #8B8C89;
  border-right: 2px solid #8B8C89;
  behavior: url(-ms-transform.htc);
  -moz-transform: rotate(135deg);
  -webkit-transform: rotate(135deg);
  -o-transform: rotate(135deg);
  -ms-transform: rotate(135deg);
  transform: rotate(135deg);
}
#scroll-title {
  display: block;
  text-transform: uppercase;
  color: #8B8C89;
  font-family: "Hammersmith One", serif;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.1em;
}
#scroll-down::before {
  -webkit-animation: elasticus 1.2s cubic-bezier(1, 0, 0, 1) infinite;
  /* Safari 4+ */
  -moz-animation: elasticus 1.2s cubic-bezier(1, 0, 0, 1) infinite;
  animation: elasticus 1.2s cubic-bezier(1, 0, 0, 1) infinite;
  /* IE 10+, Fx 29+ */
  position: absolute;
  top: 70px;
  left: 50%;
  margin-left: -1px;
  width: 2px;
  height: 90px;
  background: #8B8C89;
  content: ' ';
}


@keyframes elasticus {
  0% {
    -webkit-transform-origin: 0% 0%;
    -ms-transform-origin: 0% 0%;
    -moz-transform-origin: 0% 0%;
    -o-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
    -webkit-transform: scale(1, 0);
    -ms-transform: scale(1, 0);
    -moz-transform: scale(1, 0);
    -o-transform: scale(1, 0);
    transform: scale(1, 0);
  }
  50% {
    -webkit-transform-origin: 0% 0%;
    -ms-transform-origin: 0% 0%;
    -moz-transform-origin: 0% 0%;
    -o-transform-origin: 0% 0%;
    transform-origin: 0% 0%;
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    -moz-transform: scale(1, 1);
    -o-transform: scale(1, 1);
    transform: scale(1, 1);
  }
  50.1% {
    -webkit-transform-origin: 0% 100%;
    -ms-transform-origin: 0% 100%;
    -moz-transform-origin: 0% 100%;
    -o-transform-origin: 0% 100%;
    transform-origin: 0% 100%;
    -webkit-transform: scale(1, 1);
    -ms-transform: scale(1, 1);
    -moz-transform: scale(1, 1);
    -o-transform: scale(1, 1);
    transform: scale(1, 1);
  }
  100% {
    -webkit-transform-origin: 0% 100%;
    -ms-transform-origin: 0% 100%;
    -moz-transform-origin: 0% 100%;
    -o-transform-origin: 0% 100%;
    transform-origin: 0% 100%;
    -webkit-transform: scale(1, 0);
    -ms-transform: scale(1, 0);
    -moz-transform: scale(1, 0);
    -o-transform: scale(1, 0);
    transform: scale(1, 0);
  }
}


/*===========　ナビ　===========*/



#access {
  width: 60vw;
  height: 100vh;
  margin: 0;
  position: fixed;
  top: 0;
  left: -30vw;
  opacity: 0;
  background: rgba(139, 140, 137, 0.9);
	transition: left 0.3s ease-in-out;
  z-index: 100;
}
#access.open {
    left: 0vw;
    opacity: 1;
		transition: left 0.3s ease-in-out;
    z-index: 100;
}
#access.close {/*隠れている時*/
  left: -40vw;
  opacity: 0;
	transition: left 0.3s ease-in-out;
  z-index: 100;
}


#access ul{
	width: 80%;
	height: 20vw;
	margin: 130px auto 0;
	}

#access ul li a{
	color: #A3CEF1;
	font-weight: bold;
	font-size: 0.9em;
	display: block;
	margin: 0 0 3vw;
}

.navitxt{
	font-size: 0.6em;
	color: #fff;
	padding-left: 0.5em;
	display: block;
	letter-spacing: 1px;
	font-weight: 400;
}

.site-link{padding: 7% 0 0;}

#access ul li.layer{
	font-size:0.8em;
	padding-left: 1em;
}


#access > ul > li:nth-child(7){
	padding-bottom: 1em;
}

@media (min-width:768px){
	#access {
	  width:25vw;

	}
	#access ul{
		padding: 0;

	}

	/*ナビ下に線を出す*/
	#access ul li a{
		position: relative;
		display: block;
		padding: 0;
		line-height: 2vw;
		text-align: left;
		margin: 0 0 1vw;
		font-size: 1em;
	}
	#access ul li a:before {
		content: '';
		position: absolute;
		bottom: 0%;
		left: 0;
		display: block;
		background: none #fff;
		width: 90%;
		height: 1px;
		margin: 0 auto;
		transition: transform 0.3s cubic-bezier(0.4, 1, 0.8, 1) 0s;
		transform-origin: 100% 50%;
		transform: scale3d(0, 1, 1);
		pointer-events: none;
	}
	#access ul li a:hover:before {
	  transform-origin: 0% 50%;
	  transform: scale3d(1, 1, 1);
	}

}


/*===========　ハンバーガー・ナビ　===========*/
.hanNav	{
	position:fixed;
	top: 15px;
	left: 20px;
	z-index:9999;
	width: 5vw;
	height: 5vw;
	line-height:1.5em;
	text-align:center;
	cursor:pointer;
}

.menu-trigger,
.menu-trigger span {
  display: inline-block;
  transition: all .4s;
  box-sizing: border-box;
}
.menu-trigger {
    position: relative;
    width: 100%;
    height: 100%;
    background: none;
    border: none;
    appearance: none;
    cursor: pointer;
}
.menu-trigger span {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
  border-radius: 4px;
}
.menu-trigger span:nth-of-type(1) {
  top: 0px;
}
.menu-trigger span:nth-of-type(2) {
  top: 46%;
}
.menu-trigger span:nth-of-type(3) {
  bottom: 0px;
}

.menu-trigger.open span:nth-of-type(1) {
  -webkit-transform: translateY(4px) rotate(-315deg);
  transform: translateY(1vw) rotate(-315deg);
}
.menu-trigger.open span:nth-of-type(2) {
  opacity: 0;
}
.menu-trigger.open span:nth-of-type(3) {
  -webkit-transform: translateY(-16px) rotate(315deg);
  transform: translateY(-3.5vw) rotate(315deg);
}

@media (min-width:768px){
	.hanNav	{
		position:fixed;
		top: 30px;
		left: 20px;
		z-index:9999;
		width: 60px;
		height: 40px;
		line-height:1.5em;
		text-align:center;
		cursor:pointer;
	}

	.menu-trigger,
	.menu-trigger span {
	  display: inline-block;
	  transition: all .4s;
	  box-sizing: border-box;
	}
	.menu-trigger {
	    position: relative;
	    width: 100%;
	    height: 100%;
	    background: none;
	    border: none;
	    appearance: none;
	    cursor: pointer;
	}
	.menu-trigger span {
	  position: absolute;
	  left: 0;
	  width: 100%;
	  height: 2px;
	  background-color: #fff;
	  border-radius: 4px;
	}
	.menu-trigger span:nth-of-type(1) {
	  top: 0px;
	}
	.menu-trigger span:nth-of-type(2) {
	  top: 46%;
	}
	.menu-trigger span:nth-of-type(3) {
	  bottom: 0px;
	}

	.menu-trigger.open span:nth-of-type(1) {
	  -webkit-transform: translateY(4px) rotate(-315deg);
	  transform: translateY(19px) rotate(-315deg);
	}
	.menu-trigger.open span:nth-of-type(2) {
	  opacity: 0;
	}
	.menu-trigger.open span:nth-of-type(3) {
	  -webkit-transform: translateY(-19px) rotate(315deg);
	  tra10ths sform: translateY(-18px) rotate(315deg);
	}
}

@media (min-width:1510px){
	.hanNav	{
		position:fixed;
		top: 30px;
		left: calc(50% - 720px);
		z-index:9999;
		width: 60px;
		height: 40px;
		line-height:1.5em;
		text-align:center;
		cursor:pointer;
	}
}


/*===========　=======　コンテンツ　=======　===========*/

.outer_block{overflow: hidden;}
/*  タイトル　・　記事
___________________________________________________*/

h2.headline-title
{
	font-size: 1.5em;
	text-align: center;
	padding-bottom: 10%;
	margin-bottom: 10%;
}



h3.sub-headline-title
{
	font-size: 1.2em;
	text-align: center;
	background: #D5E9F1;
	padding: 4% 2%;
	margin-bottom: 5%;
	display: block;
	width: 100%;
}

p.common-content
{
	padding: 8% 0%;
	font-size: 0.8em;
	line-height: 1.5;
}

.readmore
{
	width: 80%;
	padding: 5% 2%;
	margin: 0 auto;
}
.readmore a.rm-link
{
	display: block;
	width: 100%;
	height: 5vw;
	line-height: 1vw;
	padding: 6vw 3vw;
	text-align: center;
	background: #BD0000;
	border-radius: 3em;
	letter-spacing: 1px;
}

.readmore a.rm-link:hover
{
	background: #00A1E9;
}

@media (min-width:768px){
	h2.headline-title
	{
		font-size: 2em;
		padding-bottom: 2%;
		margin-bottom: 2%;
	}


	p.common-content
	{
		padding: 5% 2%;
		font-size: 100%;
	}

	.readmore
	{
		width: 40%;
		padding: 5% 2%;
		margin: 0 auto;
	}

	.readmore a.rm-link
	{
		height: 5vw;
		line-height: 3vw;
		padding: 1vw 3vw;
	}
}


/*  Aブロック
___________________________________________________*/
.block-a
{
	width: 100%;
	padding: 10% 15%;
	background: #fff;
}
@media (min-width:768px){
.block-a
{
	padding: 10% 15%;
}
}
/*  Bブロック
___________________________________________________*/
.block-b
{
	width: 100%;
	margin: 0 auto;
	padding: 10% 15%;
}

.b-inner
{
	width: 80%;
	padding: 5% 2%;
	margin: 0 auto;
}

.b-wrap
{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

/*  Dブロック
___________________________________________________*/

.block-d
{
	width: 100%;
	margin: 0 auto;
	padding: 10% 15%;
}

.bnr-inner
{
	width: 70%;
	padding: 0;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.bnr-1col
{
	width: 100%;
	height: 40vw;
}

.bnr-2col
{
	width: 26vw;
	height: 26vw;
	margin-bottom: 3.5vw;
	border: 1px solid #333;
}

.bnr-col a.bnr-link
{
	display: block;
	width: 100%;
	height: 100%;
	border:1px solid #333;
}


/*  Tブロック
___________________________________________________*/
.block-t
{
	width: 100%;
	margin: 0 auto;
	padding: 5% 5% 0;
}

.table-inner {
	margin-bottom: 8vw;
}

.table-inner table {
    border-collapse: collapse;
    border-spacing: 0;
    width: 100%;
}

.table-inner table  tr{
    margin-bottom: 2px;
    border-bottom: 2px solid #fff;
}
.table-inner table th,
.table-inner tbody td {
	padding: 3vw 2vw;
	font-size: 0.7em;
}

.table-inner table th {
	background-color: #D9D9D9;
	width: 40%;
	color: #333;
}

.table-inner tbody td {
	vertical-align: middle;
	background: #E7ECEF;
	text-align: center;
}

.table-wrap{
	margin: 0 0 6%;
}

.table-wrap p small{font-size: 0.6em;}

@media (min-width:768px){
	.table-inner table th,
	.table-inner tbody td
	{font-size: 1em;padding: 3%;}
	.table-inner {
	margin-bottom: 5vw;
}
}

/*===========　デザインブロック　共通　===========*/

.block-a h2.headline-title
{
	letter-spacing: 2px;
	border: 0;
	padding: 1vw 0;
	margin: 0;
	position: relative;
	z-index: 1;
	font-size: 1.8em;
}
.block-a h3.sub-headline-title
{
	text-align: center;
	font-size: 1.2em;
	background: none;
	padding: 3% 0;
	margin: 0;
}



/*  fade in
---------------------------------------------------------------------------------------------------- */

.f_down {
  opacity: 0;
  transform-origin: center;
  transition: 1s ease 0s;
	transform: translateY(100px);
}
.f_down.moved{
  opacity: 1;
	transform: translate(0px, 0px);
}


/*  text fadein span
---------------------------------------------------------------------------------------------------- */

h2.headline-title.txt_bar {
	font-size: 1.8em;
	line-height: 1.2em;
	font-family: "Hammersmith One", serif;
	font-weight: 400;
	color: #274C77;
	border-bottom: solid 2px #274C77;
	overflow: hidden;
	position: relative;
	transition: all 0.6s;
	width: max-content;
	-webkit-clip-path: inset(0 100% 0 0);
	clip-path: inset(0 100% 0 0);
}
@media (min-width:768px){
h2.headline-title.txt_bar {
	font-size: 4em;
	line-height: 1.2em;
	font-family: "Hammersmith One", serif;
	font-weight: 400;
	color: #274C77;
	border-bottom: solid 2px #274C77;
	display: block;
}
}


h2.headline-title.txt_bar.moved{
-webkit-clip-path:inset(0 0 0 0);
clip-path: inset(0 0 0 0);
}
h2.headline-title.txt_bar::after{
	content:"";
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  transition:0.6s;
  transition-delay:0.6s;
  background-color: #6096BA;
}

h2.headline-title.txt_bar.moved::after{
  left:100%;
}


/*  cmn
---------------------------------------------------------------------------------------------------- */
.ttl_block{
	margin: 0 auto 5vw;
	width: 80vw;
	display: block;
	text-align: center;
}

p.small{
	font-size: 1em;
	color: #274C77;
	display: block;
	text-align: left;
}

.handwritten{
	border-bottom: solid 2px #274C77;
	width: 50vw;
	margin-bottom: 3%;
}
.handwritten_img{
	background: url(../reimg/toriaezu.png) no-repeat center top/100%;
	display: block;
	height: 11vw;
	width: 50vw;
	opacity: 0;
	transition-delay: 2s;
	transition: 1.5s ease 0s;
	overflow: hidden;
}

.handwritten_img.moved{
  opacity: 1;
}
p.common-content{
	font-size: 0.8em;
	line-height: 1.8;
	margin: 5vw auto;
	text-align: justify;
	padding: 0;
}



.marker{
	display: inline;
	background:linear-gradient(transparent 20%, rgba(163,206,241,0.6) 20%);
  background-repeat: no-repeat;
  background-size: 0.3em 100% ;
  background-position: 0 100%;
	transition:background-size 1.5s;
}

.marker.moved{
	background-size: 100% 100%;
}

@media (min-width:768px){
.ttl_block{
	margin: 0 auto 5vw;
	width: 49vw;
	display: block;
	text-align: center;
}

p.small{
	font-size: 1.5em !important;!i;!;
	color: #274C77;
	display: block;
	margin: 0 auto;
}

h3.sub-headline-title{
	font-size: 2.5em !important;!i;!;
}
.handwritten{
	border-bottom: solid 2px #274C77;
	width: 30vw;
	margin-bottom: 3%;
}
.handwritten_img{
	background: url(../reimg/toriaezu.png) no-repeat center top/100%;
	display: block;
	height: 6vw;
	width: 30vw;
	opacity: 0;
	transition-delay: 2s;
	transition: 2s ease 0s;
	overflow: hidden;
}

.handwritten_img.moved{
  opacity: 1;
}
p.common-content{
	font-size: 1.5em;
	line-height: 2.5;
	margin: 5vw auto 5vw;
	text-align: left;
	padding: 0;
}



.marker{
	display: inline;
	background:linear-gradient(transparent 20%, rgba(163,206,241,0.6) 20%);
	background-repeat: no-repeat;
	background-size: 0.3em 100%;
	background-position: 0 100%;
	transition: background-size 2s;
}

.marker.moved{
	background-size: 100% 100%;
}

}



/*  A currentsituation
---------------------------------------------------------------------------------------------------- */
#currentsituation{
	position: relative;
	background: url(../reimg/crnt_bg.png) no-repeat center top 45vw/110%,#fff;
	padding: 19% 5% 30%;
}

#currentsituation .text_block{
	width: 53vw;
	height: 100%;
	padding-top: 11%;
	margin-left: 40%;
}

#currentsituation  .sub-headline-title{
	letter-spacing: 2px;text-align: left;
}

#currentsituation .stick_block{
	display: block;
	position: relative;
	width: 90vw;
	height: 40vw;
	margin: 7vw auto 0;
	background: url(../reimg/ex.png) no-repeat top -3vw left 9vw/27%;
}

#currentsituation .stick1,
#currentsituation .stick2,
#currentsituation .stick3,
#currentsituation .stick4,
#currentsituation .stick5{
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
}
#currentsituation .stick1{
transition-delay: 0.5s;
}

#currentsituation .stick2{
	transition-delay: 1s;

}
#currentsituation .stick3{
	transition-delay: 1.5s;

}
#currentsituation .stick4{
	transition-delay: 2s;

}
#currentsituation .stick5{
	transition-delay: 2.5s;

}
@media (min-width:768px){
	#currentsituation{
		position: relative;
		background: url(../reimg/crnt_bg.png) no-repeat center top 38vw/110%,#fff;
		padding: 19% 5%;
	}

	#currentsituation .text_block{
		width: 53vw;
		height: 100%;
		padding-top: 11%;
		margin-left: 40%;
	}

	#currentsituation  .sub-headline-title{
		letter-spacing: 2px;
		text-align: left;
		font-size: 2.5em;
	}

	#currentsituation .stick_block{
		display: block;
		position: relative;
		width: 60vw;
		height: 30vw;
		margin: 7vw auto 0;
		background: url(../reimg/ex.png) no-repeat top -1vw left 7vw/20%;
	}

	}



/*  A idealcondition
---------------------------------------------------------------------------------------------------- */
#idealcondition{
	position: relative;
	background: url(../reimg/ideal_bg.png) no-repeat center top 38vw/110%,#274C77;
	padding: 20% 10%;
	color: #fff;
}

#idealcondition .txt_bar{
	color: #fff;
	border-color: #fff;
}

#idealcondition p.small{
	color: #fff;
}

#idealcondition .text_block{
	width: 53vw;
	height: 100%;
	padding-top: 10%;
	color: #fff;
}

#idealcondition h3{text-align: left;}

#idealcondition .handwritten{border-color: #fff;}

#idealcondition .handwritten_img{
	background-image: url(../reimg/jinsei.png);
}

@media (min-width:768px){
	#idealcondition{
		position: relative;
		background: url(../reimg/ideal_bg.png) no-repeat center top 38vw/90%,#274C77;
		padding: 20% 15%;
		color: #fff;
	}



	#idealcondition .text_block{
		width: 53vw;
		height: 100%;
		padding-top: 10%;
		color: #fff;
	}

	#idealcondition p.common-content{
		margin: 11vw auto 5vw;
	}


}



/*  A summary
---------------------------------------------------------------------------------------------------- */
#summary{
	padding: 20% 8% 8%;
	position: relative;
}
#summary:before {
    position: absolute;
    top: 14vw;
    left: 9vw;
    z-index: 0;
    content: "";
    display: block;
    width: 40vw;
    height: 7vw;
    background: url(../reimg/smr_bg.png) no-repeat center top/100%;
}
#summary .text_block{
	border:1px solid #333;
	background: url(../img/bg_square.png) repeat,#fff;
	padding: 8% 3%;
	position: relative;
	z-index: 1;
}

#summary p.common-content{
	font-size: 1em;
	text-align: center;
}
#summary .marker{
	font-size: 1.1em;
}

@media (min-width:768px){

	#summary{
		padding: 20% 14% 8%;
		position: relative;
	}
	#summary:before {
	    position: absolute;
	    top: 15vw;
	    left: 16vw;
	    z-index: 0;
	    content: "";
	    display: block;
	    width: 33vw;
	    height: 7vw;
	    background: url(../reimg/smr_bg.png) no-repeat center top/100%;
	}
	#summary .text_block{
		border:1px solid #333;
		background: url(../img/bg_square.png) repeat,#fff;
		padding: 8% 3%;
		position: relative;
		z-index: 1;
	}

	#summary p.common-content{
		font-size: 2em;
		text-align: center;
		margin-top: 5vw;
	}
	#summary .marker{
		font-size: 1.1em;
	}

}
/* ----- slide ----- */
#mid_slide_txt{
	display: block;
	width: 100%;
	height: 12vw;
	border-top: solid 1px #274C77;
	border-bottom: solid 1px #274C77;
	background: url(../reimg/slide_re_mid.png) repeat-x center center/90%,#fff;
	animation: toleft 60s linear 0s infinite;
}

/* ----- para ----- */

#para{
	position: relative;
	display: block;
	width: 100%;
	height: 50vw;
	background: transparent;
	border-top: solid 1px #274C77;
	border-bottom: solid 1px #274C77;
	max-width: 1500px;
}
#para::before {
     content:"";
     display:block;
     width: 100%;
     height: 100%;
     background: url(../reimg/para.jpg) no-repeat center center/100%;
     position: fixed;
     right: 0;
     top: 0;
     left:0;
     z-index: -1;
}

@media (min-width:768px){
	#mid_slide_txt{
		display: block;
		height: 6vw;
		background: url(../reimg/slide_re_mid.png) repeat-x center center/60%,#fff;
	}
	#para::before {
	     content:"";
	     display:block;
	     width: 100%;
	     height: 100%;
	     background: url(../reimg/para.jpg) no-repeat center center/cover;
	     background-attachment: fixed;
	     position: unset;
	}

}

/*  A　oursuggestions
---------------------------------------------------------------------------------------------------- */

#oursuggestions{
	position: relative;
	background: url(../reimg/cpt_bg.png) no-repeat center bottom 8vw/100%,#fff;
	padding: 25% 10% 45%;
	border-top: solid 10px #274C77;
}

#oursuggestions .txt_bar{
	color: #6096BA;
	border-color: #6096BA;
	text-align: center;
	display: block;
	width: 80vw;
	overflow: hidden;
}

#oursuggestions p.small{
	color: #6096BA;
	text-align: center;
}

#oursuggestions h3{
	background: #274C77;
	color: #fff;
	padding: 5%;
	text-align: center;
	margin-bottom: 3vw;
	font-size: 0.9em;
}
@media (min-width:768px){
	#oursuggestions{
		position: relative;
		background: url(../reimg/cpt_bg.png) no-repeat center bottom 8vw/100%,#fff;
		padding: 25% 10% 50%;
		border-top: solid 10px #274C77;
	}

	#oursuggestions .txt_bar{
		margin: 0 auto;
		color: #6096BA;
		border-color: #6096BA;
		text-align: center;
		display: block;
		width: 100%;
	}

	#oursuggestions p.small{
		color: #6096BA;
		text-align: center;
	}

	#oursuggestions h3{
		background: #274C77;
		color: #fff;
		padding: 3%;
		text-align: center;
		margin-bottom: 3vw;
		font-size: 2em !important;!i;!;!Imoi;!Imoi;!Imo;!I;!;
	}


}


/*  business
---------------------------------------------------------------------------------------------------- */
#business{
	position: relative;
	background: #fff;
	padding: 25% 10% 25%;
	border-top: solid 10px #274C77;
}

#business h2{
 text-align: center;
 margin: 0 auto;
 border: none;
}
#business p.small{
	font-size: 1em;
	text-align: center;
	margin: 0 auto;
	display: block;
}

#business  .morebigger{font-size: 1.8em;}
#business  .bigger{font-size: 1.5em;}


/* --------------- pt cmn --------------- */
.ptcmn{
	border-bottom: dotted 1px #274C77;
	padding: 10% 0;
}
.pt01{border-top: dotted 1px #274C77;	margin-top: 10vw;}
.ptcmn img{
	display: block;
	margin: 0 auto;
}
.ptcmn h3.sub-headline-title{
	font-size: 1em;
	background: #E7ECEF;
	margin: 5vw 0;
}

.ptcmn a{
	color: #274C77;
	border-bottom: solid 1px #274C77;
	display: block;
	margin: 5vw auto 5vw;
	width: 35vw;
	text-align: center;
	padding: 2%;
}

/* table */
.ptcmn h4 {
  background: #6096BA;
  color: #fff;
  display: inline-block;
  padding: 2%;
  font-size: 0.9em;
  letter-spacing: 1px;
}
.caution{font-size: 0.6em !important;}
@media (min-width:768px){
#business{
	position: relative;
	background: #fff;
	padding: 15% 18% 15%;
	border-top: solid 10px #274C77;
}
.ptcmn{
	border-bottom: dotted 1px #274C77;
	padding: 10% 0;
}
.pt01{border-top: dotted 1px #274C77;	margin-top: 10vw;}
.ptcmn img{
	display: block;
	margin: 0 auto 3vw;
}
.ptcmn h3.sub-headline-title{
	font-size: 1em;
	background: #E7ECEF;
	margin: 5vw 0 0;
}

.ptcmn a{
	color: #274C77;
	border-bottom: solid 1px #274C77;
	display: block;
	margin: 5vw auto 5vw;
	width: 20vw;
	text-align: center;
	padding: 2%;
	font-size: 1.5em;
}

/* table */
.ptcmn h4 {
  background: #6096BA;
  color: #fff;
  display: inline-block;
  padding: 2%;
  font-size: 1.8em;
  letter-spacing: 1px;
}
.caution{font-size: 1em !important;}
.ptcmn p.common-content{
    margin: 1vw auto;
}
}


/*  A contact
---------------------------------------------------------------------------------------------------- */
#contact{
		background: url(../img/bg_square.png) repeat,#fff;
		padding: 10%;
}
#contact h2{margin: 0 auto;}
#contact p.small{
	font-size: 0.7em;
	text-align: center;
	margin: 0 auto;
	display: block;
}

#contact .cntct{
    margin-top: 5vw;
}
#contact .cntct .bnr-1col{
	height: 11vw;
	margin-bottom: 4vw;
}
#contact .cntct .bnr-1col a{
	border-radius: 5px;
	height: 100%;
	display: block;
	width: 100%;
	background: url(../img/bnr_line.png) no-repeat center center/100%,#00B900;
}

#contact  .cntct .bnr-1col a.mail{
	background: url(../img/bnr_mail.png) no-repeat center center/100%,#A1A3A5;
}


#contact  .cntct .bnr-1col a.tel{
	background: url(../img/bnr_tel.png) no-repeat center center/100%,#696F74;
}



#contact .sns{
	height: 13vw;
	padding: 4% 10%;
	margin-bottom: 4vw;
	display: flex;
	justify-content: space-between;
	background: #6096BA;
	border-radius: 5px;
	flex-wrap: unset;
	width: 100%;
}

#contact h3.sns_tl {
	font-size: 1.5em;
	font-family: 'Hammersmith One';
	letter-spacing: 2px;
	color: #6096BA;
}


#contact .sns .bnr-1col{
	height: 9vw;
	width: 7vw;
	margin: 0;
}

#contact .sns .bnr-1col a{
	background: url(../img/x.png) no-repeat center center/100%;
}

#contact .sns .bnr-1col  a.insta{
	background-image: url(../img/insta.png);
}
#contact .sns .bnr-1col  a.tiktok{
	background-image: url(../img/tiktok.png);
}
#contact .sns .bnr-1col  a.youtube{
	background-image: url(../img/youtube.png);
}

@media (min-width:768px){
	#contact{
    padding: 10% 15%;
 }
	#contact .cntct{
    margin-top: 5vw;
}
	#contact a{transition: 0.3s;}
	#contact a:hover{opacity: 0.7;}
	#contact .cntct .bnr-1col{
		height: 11vw;
		max-height: 200px;
		margin-bottom: 4vw;
	}
	#contact .cntct .bnr-1col a{
		border-radius: 10px;
		height: 100%;
		display: block;
		width: 100%;
		background: url(../img/bnr_line.png) no-repeat center center/70%,#00B900;
	}

	#contact  .cntct .bnr-1col a.mail{
		background: url(../img/bnr_mail.png) no-repeat center center/70%,#A1A3A5;
	}


	#contact  .cntct .bnr-1col a.tel{
		background: url(../img/bnr_tel.png) no-repeat center center/70%,#696F74;
	}


	#contact .sns{
		height: 11vw;
		max-height: 200px;
		padding: 4% 7%;
		border-radius: 10px;
		width: 100%;
	}

	#contact h3.sns_tl {
		font-size: 3.5em !important;
		letter-spacing: 2px;
	}
	#contact .sns .bnr-1col{
		height: 7vw;
		width: 8vw;
		margin: 0;
	}

	#contact .sns .bnr-1col a{
		background: url(../img/x.png) no-repeat center center/100%;
	}



}

/*  A privacy
---------------------------------------------------------------------------------------------------- */

#privacy ul li{
	font-size: 13px;
line-height: 2;
list-style: square outside none;
margin: 0 0 0 20px;
padding: 0;
}

#privacy h3{
	margin-top: 3vw;
	margin-bottom: 2vw;
}

#privacy  p.common-content{margin-bottom: 2vw;}

#privacy  .table-inner table th{width: 35%;}

span._bold{
	font-weight: bold;
}
/*  footer
---------------------------------------------------------------------------------------------------- */

.footer_btn{
	width: 100%;
	max-width: 1500px;
	height: 14vw;
	position: fixed;
	bottom: 0;
	right: 0;
	left: 0;
	margin: 0 auto;
	background: #6096BA;
	z-index: 999;
}
.footer_btn ul{
	width: 100%;
	height: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
}
.footer_btn ul li{
	position: relative;
	width: calc(100% / 3);

}

.footer_btn ul li::after{
    content: '';
    position: absolute;
    top: 30%;
    right: 0;
    width: 2px;
    height: 20px;
    border-right: 1px solid #fff;
}
.footer_btn ul li:nth-child(3)::after{
	display: none;
}

.footer_btn ul li a
{
	width: 100%;
	 height: 14vw;
	 display: block;
	 text-align: center;
	 color: #fff;
	 position:relative;
	 background: url(../img/tel.png) no-repeat center center/20%;
	 }


.footer_btn ul li:nth-child(2) > a{
	background: url(../img/line.png) no-repeat center center/20%;
}
.footer_btn ul li:nth-child(3) > a{
	background: url(../img/mail.png) no-repeat center center/20%;
}


@media (min-width:768px){
	.footer_btn{
		width: 100%;
    max-width: 1500px;
    height: 5vw;
    position: fixed;
    bottom: 0;
    right: 0;
    left: 0;
    margin: 0 auto;
	}
	.footer_btn ul li{width: 100%;}

	.footer_btn ul li a.footer_btn
	{
		 width: 100%;
		 height: 5vw;
		 display: block;
		 text-align: center;
		position:relative;
		transition: 0.3s;
		background-size: 7%;
		 }
	.footer_btn ul li a:hover{
		opacity: 0.7;
	}

}


.copy{
	font-size: 0.6em;
	padding: 2% 0;
	text-align: center;
	background: #8B8C89;
	position: relative;
	z-index: 10;
	color: #fff;
}

@media (min-width:768px){
	.copy{
		text-align: center;
		background: #909090;
		max-width: 1500px;
		width: 100%;
		margin: 0 auto;
	}
}

.privacy-link{
	font-size: 0.6em;
	padding: 2% 0;
	text-align: center;
	display: block;
	text-decoration: underline;
	background: #fff;
}
