@charset "UTF-8";
body {
	margin: 0;
	padding: 0;
	COLOR: #111;
	FONT-SIZE:20px;
font-family: "Noto Serif JP",sans-serif,'Noto Sans JP';
	font-weight: 400;
	LINE-HEIGHT: 150%;
	text-align: center;
	background: #fff;
}

/*paddingとborderをwidthに含める*/
* {	
	-webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
  }

#con{
    width:100%;
max-width: 2000px;
	height:auto;
	margin:0 auto;
	padding:0;
	position:relative;
	text-align: center;
}

/*page-top用*/
.clearfix:after{
	content:".";
	display:block;
	height:0;
	clear:both;
	visibility:hidden;
	font-size: 0;
	line-height:0;
}

img{
	border:0;
}
@media screen and (max-width:1280px){
img{
max-width: 100%;
height: auto;
width :auto;
}
}

a:link,a:visited{
	outline:0;
	color:#111;
    text-decoration: none;
}

a:hover{
	outline:0;
	color: #a99509;
    text-decoration: underline;
}

a:hover img {
opacity: 0.8;
  -ms-filter: "alpha(opacity=80)";
}

br.sp,br.spt,br.spt2,.nsp{
	display:inherit;
}
br.sm,br.smt,br.smm,br.smm2,br.spm,.nst,.nss,br.smm3{
	display:none;
}
@media only screen and (max-width: 1280px) {
br.sp,br.spm,br.smm,.smm,br.smm2,.nsp,.nss,.nsm,br.smm3{
	display:none;
}
br.spt,br.sm,br.smt,.nst{
	display:inherit;
}
}
@media only screen and (max-width: 640px) {
br.spt,br.smt,br.smm2,.nsp,.nst,.nsm,.nsm2,br.smm3{
	display:none;
}
br.spm,br.smm,.nss{
	display:inherit;
}
}
@media only screen and (max-width: 480px) {
br.spt,br.smt,.nsp,.nst,.nsm,br.spt2,br.smm3{
	display:none;
}
br.spm,br.smm,br.smm2,.nss{
	display:inherit;
}
}
@media only screen and (max-width: 414px) {
br.spt,br.smt,.nsp,.nst,.nsm,br.spt2{
	display:none;
}
br.spm,br.smm,br.smm2,.nss,br.smm3{
	display:inherit;
}
}

/*ヘッダ
--------------------------------------------------------------------------*/
header{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 20px 2% 180px;
background: url(image/header.webp) no-repeat left top/100% 100%;
}
header.mail-t{
background: url(image/header.webp) no-repeat left top/100%;
}
@media only screen and (max-width: 1600px) {
header{
padding: 20px 2% 140px;
}
}
@media only screen and (max-width: 1280px) {
header{
padding: 20px 2% 50px;
}
}
@media only screen and (max-width: 1080px) {
header{
background: url(image/header.webp) no-repeat -100px -100px/170%;
}
}
@media only screen and (max-width: 835px) {
header{
background: url(image/header-sm.webp) no-repeat right top/100%;
}
}
@media only screen and (max-width: 640px) {
header{
background: url(image/header-sm.webp) no-repeat right top/130%;
}
}
@media only screen and (max-width: 414px) {
header{
background: url(image/header-sm.webp) no-repeat right top/150%;
}
}

#header-title{
clear: both;
float: left;
width: 25%;
height: auto;
margin: 0;
padding: 0;
display: flex;
align-items: center;
flex: 1 0 auto;
}
#header-title img{
margin: 0 10px 0 0;
}
#header-title h1{
clear: none;
float: left;
font-size: 30px;
line-height: 100%;
font-weight: 500;
margin: 0;
padding: 0;
text-align: left;
}
#header-title h1 a:link,#header-title h1 a:visited{
color: #fff;
text-decoration: none;
}
#header-title h1 a:hover{
color: #f04b00;
}
@media only screen and (max-width: 1280px) {
#header-title{
width:40%;
}
}
@media only screen and (max-width: 1080px) {
#header-title{
width:45%;
}
#header-title h1{
font-size: 25px;
}
}
@media only screen and (max-width: 835px) {
#header-title{
width:80%;
}
}

#header-banner{
width: 20%;
position:fixed;
top:20px;
right: 20px;
z-index: 9999;
}
#header-banner a{
display: block;
width: 100%;
height: auto;
margin: 0 0 15px;
padding: 0;
line-height: 100%;
border: 2px solid #fff;
}
#header-banner a:link,#header-banner a:visited{
color: #fff;
text-align: center;
font-size: 35px;
padding: 0;
display: flex;
justify-content:center;
align-items: center;
background: #111;
min-height: 70px;
}
#header-banner a:hover{
text-decoration: none;
background: #f04b00;
}
#header-banner a.amail:link,#header-banner a.amail:visited{
color: #fff;
text-align: center;
font-size: 30px;
padding: 0;
display: flex;
justify-content:center;
align-items: center;
background: #f04b00;
min-height: 70px;
}
#header-banner a.amail:hover{
text-decoration: none;
background: #111;
}
#header-banner a img{
margin: 0 3% 0 0;
max-height: 50px;
}
@media only screen and (max-width: 1600px) {
#header-banner a:link,#header-banner a:visited{
font-size: 25px;
min-height: 60px;
}
#header-banner a.amail:link,#header-banner a.amail:visited{
font-size: 20px;
min-height: 60px;
}
}
@media only screen and (max-width: 1440px) {
#header-banner a:link,#header-banner a:visited{
font-size: 25px;
min-height: 60px;
}
#header-banner a.amail:link,#header-banner a.amail:visited{
font-size: 20px;
min-height: 60px;
}
#header-banner a img{
max-height: 30px;
}
#header-banner a.amail img{
max-height: 20px;
}
}
@media only screen and (max-width: 1280px) {
#header-banner{
width:40%;
top:5px;
right: 70px;
}
#header-banner a{
display: block;
float: left;
width: 48%;
margin: 0 0 0 2%;
}
}
@media only screen and (max-width: 1080px) {
#header-banner{
width:50%;
}
}
@media only screen and (max-width: 835px) {
#header-banner{
width: 100%;
position:fixed;
top:inherit;
right: 0;
bottom:0;
}
#header-banner a{
width: 50%;
margin: 0;
border: none;
border-top: 2px solid #fff;
border-left: 2px solid #fff;
border-right: 2px solid #fff;
border-bottom: 2px solid #fff;
}
#header-banner a.amail{
border-top: 2px solid #fff;
border-left: none;
border-right: 2px solid #fff;
border-bottom: 2px solid #fff;
}
}
@media only screen and (max-width: 480px) {
#header-banner a:link,#header-banner a:visited{
font-size: 20px;
min-height: 60px;
}
#header-banner a.amail:link,#header-banner a.amail:visited{
font-size: 17px;
min-height: 60px;
}
}
@media only screen and (max-width: 414px) {
#header-banner a:link,#header-banner a:visited{
font-size: 18px;
min-height: 60px;
}
#header-banner a.amail:link,#header-banner a.amail:visited{
font-size: 16px;
min-height: 60px;
}
#header-banner a img{
max-height: 25px;
}
#header-banner a.amail img{
max-height: 15px;
}
}

#fv{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 220px 0 0;
padding: 0 5% 0 20%;
}
@media only screen and (max-width: 1600px) {
#fv{
margin: 170px 0 0;
}
}
@media only screen and (max-width: 1440px) {
#fv{
margin: 150px 0 0;
}
}
@media only screen and (max-width: 1280px) {
#fv{
margin: 60px 0 0;
}
}
@media only screen and (max-width: 835px) {
#fv{
padding: 0 5% 0 5%;
}
}
@media only screen and (max-width: 640px) {
#fv{
margin: 30px 0 0;
}
}

#fv p{
text-align: left;
font-size: 40px;
line-height: 120%;
margin: 0 0 10px;
color: #fff;
font-weight: 600;
}
#fv h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 20px;
padding: 0 0 10px;
border-bottom: 1px solid #fff;
color: #fff;
text-align: left;
line-height: 120%;
font-size: 80px;
font-weight: 600;
}
#fv h1 strong{
font-size: 60px;
margin: 0 2% 0 0;
}
#fv h1 span{
border: 1px solid #fff;
font-size: 40px;
padding:0px 15px 3px;
margin: 0 0 0 2%;
}
@media only screen and (max-width: 1600px) {
#fv h1{
font-size: 70px;
}
#fv h1 strong{
font-size: 50px;
}
#fv h1 span{
font-size:35px;
}
}
@media only screen and (max-width: 1440px) {
#fv p{
font-size: 35px;
}
#fv h1{
font-size: 65px;
}
#fv h1 strong{
font-size: 45px;
}
#fv h1 span{
font-size:30px;
}
}
@media only screen and (max-width: 1280px) {
#fv p{
font-size: 30px;
}
#fv h1{
font-size: 55px;
}
#fv h1 strong{
font-size: 35px;
}
#fv h1 span{
font-size:25px;
}
}
@media only screen and (max-width: 1080px) {
#fv h1{
border-bottom: none;
padding: 0;
}
#fv h1 span{
display: block;
font-size:25px;
margin: 0;
padding:10px 15px 12px;
line-height: 100%;
}
}
@media only screen and (max-width: 835px) {
#fv p{
font-size: 25px;
}
#fv h1{
font-size: 45px;
}
#fv h1 strong{
font-size: 30px;
}
#fv h1 span{
font-size:20px;
background-color:rgba(255,255,255,0.3);
}
}
@media only screen and (max-width: 640px) {
#fv h1{
font-size: 40px;
text-shadow: 2px 2px 2px #682f39;
}
#fv h1 strong{
font-size: 25px;
}
}
@media only screen and (max-width: 480px) {
#fv p{
font-size: 20px;
}
#fv h1{
font-size: 35px;
}
#fv h1 strong{
font-size: 20px;
}
}
@media only screen and (max-width: 414px) {
#fv h1{
font-size: 30px;
}
}

#fv-box{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
display: flex;
align-items: center;
}
@media only screen and (max-width: 1280px) {
#fv-box{
display:inherit;
align-items: center;
}
}
#fv #fv-box p{
font-size: 25px;
font-weight: 400;
margin: 0;
line-height: 180%;
}
@media only screen and (max-width: 1600px) {
#fv #fv-box p{
font-size: 20px;
}
}
@media only screen and (max-width: 1080px) {
#fv #fv-box p{
font-size: 20px;
text-align: justify;
}
}
@media only screen and (max-width: 835px) {
#fv #fv-box p{
font-size:17px;
font-weight: 600;
}
}
@media only screen and (max-width: 480px) {
#fv #fv-box p{
line-height: 130%;
}
}

#fv-box a:link,#fv-box a:visited{
display: block;
width: 25%;
border-radius: 50px;
border: 2px solid #fff;
background: url(image/bu-ar.png) no-repeat 95% 50%,#f04b00;
color: #fff;
text-decoration: none;
text-align: center;
padding: 15px 0;
font-size: 30px;
font-weight: 600;
}
#fv-box a:hover{
background: url(image/bu-ar.png) no-repeat 95% 50%,#703234;
}
@media only screen and (max-width: 1440px) {
#fv-box a:link,#fv-box a:visited{
width: 30%;
font-size: 25px;
}
}
@media only screen and (max-width: 1280px) {
#fv-box a:link,#fv-box a:visited{
margin: 20px 0 0;
width: 50%;
font-size: 23px;
}
}
@media only screen and (max-width: 1080px) {
#fv-box a:link,#fv-box a:visited{
margin: 20px 0 0;
width: 100%;
font-size: 23px;
}
}
@media only screen and (max-width: 480px) {
#fv-box a:link,#fv-box a:visited{
padding: 10px 0;
}
}

#menu-box{
float: right;
width:75%;
height: auto;
margin: 0;
padding: 0 20% 0 0;
}

menu{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}

menu ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 15px 0;
display: flex;
align-items: center;
}
menu li{
list-style-type: none;
flex: 1 0 auto;
font-size: 20px;
line-height: 100%;
}
menu li a:link,menu li a:visited{
text-decoration: none;
color: #fff;
}
menu li a:hover{
border-bottom: 1px solid #fff;
}
@media only screen and (max-width: 1440px) {
menu li{
font-size: 17px;
}
}

@media only screen and (max-width:1280px) {
#menu-box{
clear: both;
float: none;
width: 100%;
height: auto;
margin: 0;
padding: 0;
position: fixed;
top:0;
left:0;
z-index: 9999;
background: none;
}
menu{
clear: both;
float: left;
width: 50%;
height: auto;
height: 100vh;
margin: 0 0 0 50%;
padding: 90px 0 0;
text-align: left;
position: fixed;
top: 0;
background: rgba(255,255,255,1.0);
box-shadow: -15px -15px 10px #703234;
}
menu ul{
display:inherit;
clear: both;
float: left;
width: 100%;
height: 100vh;
margin: 0;
padding: 0;
text-align: center;
background: none;
}
menu li {
  list-style-type: none;
  margin: 0;
  padding: 0;
  text-align: left;
  font-size:17px;
  line-height: 150%;
  flex: auto;
  background: none;
  border-bottom: 1px solid #ccc;
}
menu li a:link,menu li a:visited{
float: none;
display: block;
text-decoration: none;
color: #555;
margin: 0;
padding: 25px 0 25px 1em;
text-align: left;
line-height: 100%;
font-size: 17px;
font-weight:500;
background: url(image/menu-li.png) no-repeat 95% center/7px;
}
menu li a:hover{
border-bottom: none;
text-decoration: none;
}
@media only screen and (max-width: 640px) {
menu{
width: 70%;
margin: 0 0 0 30%;
padding: 50px 0 0;
}
}
@media only screen and (max-width: 480px) {
menu{
width: 85%;
margin: 0 0 0 15%;
padding: 50px 0 0;
}
menu li a:link,menu li a:visited{
float: none;
display: block;
text-decoration: none;
color: #555;
padding: 20px 0 20px 1em;
text-align: left;
line-height: 100%;
font-size: 16px;
font-weight:500;
}
}
@media only screen and (max-width: 414px) {
menu li a:link,menu li a:visited{
float: none;
display: block;
text-decoration: none;
color: #555;
padding: 20px 0 20px 1em;
text-align:left;
line-height: 100%;
font-size: 16px;
font-weight:500;
}
}
menu li a:hover{
text-decoration: underline;
}

/*==================================================
　5-2-4 MENUがCLOSEに
===================================*/

/*ボタン外側※レイアウトによってpositionや形状は適宜変更してください*/
.openbtn4{
float: right;
  position: fixed;/*ボタン内側の基点となるためrelativeを指定*/
  background:#fc6723;
  cursor: pointer;
    width: 50px;
    height:50px;
  border-radius: 5px;
  top:5px;
  right:10px;
  z-index: 999;
  border: 2px solid #fff;
}
@media only screen and (max-width: 640px) {
.openbtn4{
float: right;
  position: fixed;/*ボタン内側の基点となるためrelativeを指定*/
  background:#fc6723;
  cursor: pointer;
    width: 50px;
    height:50px;
  border-radius: 5px;
  top:5px;
  right:10px;
  z-index: 999;
  border: 2px solid #fff;
}
}
/*ボタン内側*/
.openbtn4 span{
    display: inline-block;
    transition: all .4s;/*アニメーションの設定*/
    position: absolute;
    left: 13px;
    height: 2px;
    border-radius: 5px;
  background: #fff;
    width: 45%;
  }
.openbtn4 span:nth-of-type(1) {
  top:11px; 
}
.openbtn4 span:nth-of-type(2) {
  top:17px;
}
.openbtn4 span:nth-of-type(3) {
  top:23px;
}
.openbtn4 span:nth-of-type(3)::after {
  content:"Menu";/*3つ目の要素のafterにMenu表示を指定*/
  position: absolute;
  top:0px;
left: 50%; /* ここを50%に変更 */
  transform: translateX(-50%); /* これを追加 */
  color: #fff;
  font-size: 0.8rem;
  text-transform: uppercase;
}
@media only screen and (max-width: 640px) {
.openbtn4 span:nth-of-type(3)::after {
  content:"Menu";/*3つ目の要素のafterにMenu表示を指定*/
  position: absolute;
  top:-4px;
left: 50%; /* ここを50%に変更 */
  transform: translateX(-50%); /* これを追加 */
  color: #fff;
  font-size: 0.8rem;
  text-transform: uppercase;
}
}

/*activeクラスが付与されると線が回転して×になり、Menu⇒Closeに変更*/
.openbtn4.active span:nth-of-type(1) {
    top: 12px;
    left: 16px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
}
.openbtn4.active span:nth-of-type(2) {
  opacity: 0;
}
.openbtn4.active span:nth-of-type(3){
    top: 24px;
    left: 16px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
}

.openbtn4.active span:nth-of-type(3)::after {
  content:"Close";/*3つ目の要素のafterにClose表示を指定*/
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  transform: rotate(-45deg) translateY(16px); /* ここを12pxに調整 */
  font-size: 0.8rem;
}
/*.doneクラスがついたヘッダー*/
.dnone {
display: none;
}
/*メニューボタンをクリックした際に付与されるpanelactiveクラスがついたら*/
.dnone.panelactive {
display: inherit;
}
}
 
/*メイン
--------------------------------------------------------------------------*/
main{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
text-align: center;
}

#info{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 180px 10% 80px;
background: url(image/info-back.webp) no-repeat 7% 130px,#703234;
}
@media only screen and (max-width: 1440px) {
#info{
padding: 180px 10% 80px;
background: url(image/info-back.webp) no-repeat 7% 130px/30%,#703234;
}
}
@media only screen and (max-width: 1280px) {
#info{
padding: 150px 5% 80px;
background: url(image/info-back.webp) no-repeat 7% 130px/30%,#703234;
}
}
@media only screen and (max-width: 1080px) {
#info{
padding: 150px 5% 50px;
}
}
@media only screen and (max-width: 835px) {
#info{
padding: 150px 5% 50px;
background: url(image/info-back.webp) no-repeat -40px 130px/40%,#703234;
}
}
@media only screen and (max-width: 640px) {
#info{
padding: 100px 5% 50px;
background: url(image/info-back.webp) no-repeat -40px 100px/40%,#703234;
}
}

#info-photo{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 80px;
padding: 0 5%;
text-align: center;
position: relative;
}
#info-photo img{
max-width: 60%;
}
@media only screen and (max-width: 1440px) {
#info-photo img{
max-width:70%;
}
}
@media only screen and (max-width: 1280px) {
#info-photo img{
max-width:80%;
}
}
@media only screen and (max-width: 1080px) {
#info-photo img{
max-width:90%;
}
}

#info-photo p{
color: #fff;
font-size: 70px;
line-height: 120%;
font-weight:400;
margin: -40px 0 0;
text-align: left;
z-index: 9998;
position:absolute;
top:0;
left: 0;
}
#info-photo h2{
clear: none;
font-size: 60px;
margin: 0;
padding: 0;
text-align: right;
line-height: 120%;
color: #fff;
font-weight: 400;
z-index: 9998;
position:absolute;
bottom:120px;
right: 0;
}
@media only screen and (max-width: 1440px) {
#info-photo p{
font-size:60px;
margin: -40px 0 0;
}
#info-photo h2{
font-size: 50px;
bottom:120px;
}
}
@media only screen and (max-width: 1280px) {
#info-photo p{
font-size:50px;
margin: -30px 0 0;
}
#info-photo h2{
font-size: 40px;
bottom:120px;
}
}
@media only screen and (max-width: 835px) {
#info-photo p{
font-size:40px;
margin: -30px 0 0;
}
#info-photo h2{
font-size: 40px;
bottom:20px;
}
}
@media only screen and (max-width: 480px) {
#info-photo p{
font-size:35px;
margin: -30px 0 0;
}
#info-photo h2{
font-size: 35px;
bottom:-10px;
}
}
@media only screen and (max-width: 414px) {
#info-photo p{
font-size:30px;
margin: -30px 0 0;
}
#info-photo h2{
font-size: 30px;
bottom:-10px;
}
}

#info-text{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0 10%;
text-align: left;
}
@media only screen and (max-width: 1440px) {
#info-text{
padding: 0 5%;
}
}
@media only screen and (max-width: 1280px) {
#info-text{
padding: 0 0%;
}
}

#info-text p{
text-align: left;
font-size: 25px;
color: #fff;
margin: 0 0 50px;
line-height: 150%;
}
#info-text p strong{
text-align: left;
font-size: 45px;
color: #fc6723;
margin: 0 0 50px;
line-height: 150%;
}
#info-text p.f15{
font-size: 15px;
}
@media only screen and (max-width: 835px) {
#info-text p{
margin: 0 0 40px;
}
#info-text p strong{
font-size: 35px;
margin: 0 0 40px;
}
}
@media only screen and (max-width: 480px) {
#info-text p{
margin: 0 0 30px;
font-size: 20px;
}
#info-text p strong{
font-size: 30px;
margin: 0 0 30px;
}
#info-text p.f15{
font-size: 14px;
}
}

#info-text ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 35px;
padding: 0;
display: flex;
flex-wrap: wrap;
font-size: 25px;
color: #fff;
line-height: 100%;
}
#info-text li{
list-style-type: none;
border: 1px solid #fff;
font-size: 25px;
line-height: 100%;
margin: 0 1% 15px 0;
padding: 5px 2%;
flex: 1 0 auto;
justify-content:center;
color: #fff;
flex-grow: 0;
}
@media only screen and (max-width: 1080px) {
#info-text ul{
font-size: 20px;
}
#info-text li{
font-size: 20px;
}
}
@media only screen and (max-width: 835px) {
#info-text ul{
font-size: 17px;
margin: 0 0 30px;
}
#info-text li{
font-size: 17px;
}
}

#repe{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 130px 10% 200px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
@media only screen and (max-width: 1600px) {
#repe{
padding: 130px 5% 200px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}
@media only screen and (max-width: 1440px) {
#repe{
padding: 130px 0% 170px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}
@media only screen and (max-width: 1280px) {
#repe{
padding: 130px 0% 140px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}
@media only screen and (max-width: 1080px) {
#repe{
padding: 100px 0% 100px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}
@media only screen and (max-width: 835px) {
#repe{
padding: 80px 0% 80px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}
@media only screen and (max-width: 480px) {
#repe{
padding: 60px 0% 60px;
background: url(image/repa-back.webp) no-repeat center bottom/100%;
}
}

#repe h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 80px;
padding: 0 0 30px;
text-align: center;
font-size: 40px;
font-weight: 400;
line-height: 100%;
background: url(image/repa-h2.png) no-repeat center bottom;
}
@media only screen and (max-width: 1080px) {
#repe h2{
margin: 0 0 60px;
font-size: 35px;
background: url(image/repa-h2.png) no-repeat center bottom;
}
}
@media only screen and (max-width: 835px) {
#repe h2{
margin: 0 0 50px;
padding: 0 0 30px;
font-size: 30px;
background: url(image/repa-h2.png) no-repeat center bottom;
}
}
@media only screen and (max-width: 480px) {
#repe h2{
margin: 0 0 40px;
padding: 0 0 20px;
font-size: 25px;
background: url(image/repa-h2.png) no-repeat center bottom/25%;
}
}

#repe-box{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 100px;
padding: 0;
display: flex;
}
.repe-area{
flex: 1;
padding: 0 5%;
}
.repe-area:first-of-type{
border-right:1px solid #703234;
}
@media only screen and (max-width: 640px) {
#repe-box{
margin: 0 0 80px;
display:inherit;
}
.repe-area{
flex: 1;
padding: 0 5%;
margin: 0 0 30px;
}
.repe-area:first-of-type{
border-right:none;
border-bottom:1px solid #703234;
}
}

.repe-area p{
text-align: left;
font-size: 20px;
line-height: 180%;
margin: 0 0 40px;
}
.repe-area p strong{
font-weight: 600;
}
@media only screen and (max-width: 1080px) {
.repe-area p{
text-align: justify;
font-size: 17px;
margin: 0 0 30px;
}
}
@media only screen and (max-width: 414px) {
.repe-area p{
font-size: 16px;
margin: 0 0 30px;
line-height: 150%;
}
}

#flow{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0 5%;
display: flex;
flex-wrap: wrap;
}
.flow-box{
flex: 1;
background: #fff;
border-radius: 15px;
padding: 60px 3% 30px;
text-align:center;
margin: 0 2% 50px;
flex-basis:46%;
flex-grow: 0;
}
@media only screen and (max-width: 1280px) {
.flow-box{
padding: 40px 3% 10px;
margin: 0 2% 40px;
}
}
@media only screen and (max-width: 835px) {
.flow-box{
padding: 40px 3% 10px;
margin: 0 0% 30px;
flex-basis:100%;
box-shadow: 5px 5px 5px #e1d9d9;
}
}
@media only screen and (max-width: 480px) {
.flow-box{
padding: 30px 3% 0px;
margin: 0 0% 20px;
flex-basis:100%;
box-shadow: 5px 5px 5px #e1d9d9;
}
}

#flow h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
text-align: center;
font-weight: 500;
line-height: 100%;
color: #703234;
font-size: 25px;
}
#flow h3 span{
font-size: 35px;
margin: 0 10px 0 0;
}
#flow h3 strong{
font-size: 35px;
font-weight: 600;
}
@media only screen and (max-width: 1280px) {
#flow h3 span{
font-size: 30px;
}
#flow h3 strong{
font-size: 30px;
}
}
@media only screen and (max-width: 480px) {
#flow h3{
margin: 0 0 30px;
font-size: 20px;
}
#flow h3 span{
font-size: 25px;
}
#flow h3 strong{
font-size: 25px;
}
}

#flow p{
text-align: center;
font-size: 20px;
margin: 0 0 30px;
}
#flow p.f15{
font-size: 15px;
line-height: 150%;
}
@media only screen and (max-width: 1280px) {
#flow p{
font-size: 17px;
margin: 0 0 30px;
}
#flow p.f15{
font-size: 14px;
}
}
@media only screen and (max-width: 414px) {
#flow p{
font-size: 16px;
line-height: 130%;
}
}

.flow-box img{
max-height: 150px;
margin: 0 0 15px;
}
@media only screen and (max-width: 480px) {
.flow-box img{
max-height: 80px;
}
}

#prof{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 150px 3% 50px;
}
@media only screen and (max-width: 1600px) {
#prof{
padding: 150px 0 50px;
}
}
@media only screen and (max-width: 1280px) {
#prof{
padding: 100px 0 50px;
}
}
@media only screen and (max-width: 640px) {
#prof{
padding: 60px 0 10px;
}
}

#prof h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 80px;
padding: 0 0 30px;
text-align: center;
font-size: 40px;
font-weight: 400;
line-height: 100%;
background: url(image/repa-h2.png) no-repeat center bottom;
}
@media only screen and (max-width: 1080px) {
#prof h2{
margin: 0 0 60px;
font-size: 35px;
}
}
@media only screen and (max-width: 835px) {
#prof h2{
margin: 0 0 50px;
font-size: 30px;
}
}
@media only screen and (max-width: 480px) {
#prof h2{
margin: 0 0 40px;
font-size: 25px;
padding: 0 0 20px;
background: url(image/repa-h2.png) no-repeat center bottom/30%;
}
}

#prof-box{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0 15%;
display: flex;
text-align: center;
}
@media only screen and (max-width: 1600px) {
#prof-box{
padding: 0 10%;
}
}
@media only screen and (max-width: 1280px) {
#prof-box{
padding: 0 5%;
}
}
@media only screen and (max-width: 835px) {
#prof-box{
display:inherit;
}
}

#prof-text{
clear: both;
float: left;
width: 60%;
flex-basis:60%;
height: auto;
margin: 0;
padding: 0;
}
#prof img{
max-width: 100%;
}
@media only screen and (max-width: 1280px) {
#prof img{
max-width: 40%;
}
}
@media only screen and (max-width: 835px) {
#prof-text{
clear: both;
width: 100%;
flex-basis:100%;
}
#prof img{
max-width: 70%;
}
}
@media only screen and (max-width: 640px) {
#prof img{
max-width: 80%;
}
}
@media only screen and (max-width: 480px) {
#prof img{
max-width: 90%;
}
}

#prof h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
text-align: left;
font-weight: 500;
line-height: 100%;
font-size: 25px;
}
#prof h3 strong{
font-size: 35px;
margin: 0 0 0 2%;
}
#prof h3 em{
font-style: normal;
font-size: 25px;
}
@media only screen and (max-width: 480px) {
#prof h3{
margin: 0 0 30px;
font-size: 20px;
}
#prof h3 strong{
font-size: 30px;
}
#prof h3 em{
font-size: 20px;
}
}
#prof p{
text-align: left;
font-size: 20px;
line-height: 200%;
margin: 0 0 40px;
}
@media only screen and (max-width: 1280px) {
#prof p{
font-size: 17px;
line-height: 180%;
margin: 0 0 40px;
}
}
@media only screen and (max-width: 835px) {
#prof p{
font-size: 17px;
margin: 0 0 30px;
}
}
@media only screen and (max-width: 480px) {
#prof p{
font-size: 16px;
margin: 0 0 30px;
}
}

#music{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0 15% 120px;
}
@media only screen and (max-width: 1600px) {
#music{
padding: 0 10% 120px;
}
}
@media only screen and (max-width: 1080px) {
#music{
padding: 0 5% 80px;
}
}
@media only screen and (max-width: 480px) {
#music{
padding: 0 5% 50px;
}
}

#music h2{
clear: both;
width: 100%;
height: auto;
margin: 0 auto;
padding: 0 25%;
text-align: center;
font-size: 30px;
font-weight: 400;
line-height: 100%;
color: #fff;
display: flex;
align-items: flex-end;
justify-content:center;
}
#music h2 img{
width: 31px;
flex-basis:31px;
}
#music h2 span{
width: 50%;
background: #703234;
padding: 15px 0 10px;
margin: 0 auto;
display: inline-block;
border-radius: 15px 15px 0 0;
flex: 1 0 auto;
}
@media only screen and (max-width: 1280px) {
#music h2{
padding: 0 20%;
}
}
@media only screen and (max-width: 1080px) {
#music h2{
padding: 0 15%;
}
}
@media only screen and (max-width: 835px) {
#music h2{
padding: 0 10%;
font-size: 25px;
}
}
@media only screen and (max-width: 640px) {
#music h2{
padding: 0 5%;
font-size: 25px;
}
}
@media only screen and (max-width: 480px) {
#music h2{
padding: 0 0%;
font-size: 20px;
}
#music h2 span{
padding: 10px 0 10px;
border-radius: 10px 10px 0 0;
}
#music h2 img{
width: 26px;
flex-basis:26px;
}
}

#mu-area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 80px 10% 40px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px,url(image/mu-back2.png) no-repeat 99% 10px;
}
@media only screen and (max-width: 1600px) {
#mu-area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 80px 5% 40px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px,url(image/mu-back2.png) no-repeat 99% 10px;
}
}
@media only screen and (max-width: 1440px) {
#mu-area{
padding: 80px 5% 0px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px/8%,url(image/mu-back2.png) no-repeat 99% 10px/8%;
}
}
@media only screen and (max-width: 1080px) {
#mu-area{
padding: 70px 5% 0px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px/9%,url(image/mu-back2.png) no-repeat 99% 10px/9%;
}
}
@media only screen and (max-width: 835px) {
#mu-area{
padding: 60px 5% 0px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px/10%,url(image/mu-back2.png) no-repeat 99% 10px/10%;
}
}
@media only screen and (max-width: 640px) {
#mu-area{
padding: 10px 5% 0px;
border: 1px solid #703234;
background: url(image/mu-back1.png) no-repeat 1% 10px/16%,url(image/mu-back2.png) no-repeat 99% 10px/16%;
}
}

.mu-box{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 60px;
padding: 50px 5% 30px 30%;
border: 1px solid #703234;
box-shadow: 7px 7px 0px #eae0e1;
background: url(image/mu-his.png) no-repeat 10% 50%/10%;
}
@media only screen and (max-width: 1440px) {
.mu-box{
padding: 40px 5% 30px 25%;
background: url(image/mu-his.png) no-repeat 5% 50%/12%;
}
}
@media only screen and (max-width: 1280px) {
.mu-box{
margin: 0 0 40px;
padding: 30px 5% 15px 20%;
background: url(image/mu-his.png) no-repeat 3% 50%/12%;
}
}
@media only screen and (max-width: 1080px) {
.mu-box{
margin: 0 0 40px;
padding: 100px 5% 15px 5%;
background: url(image/mu-his2.png) no-repeat center 15px/auto 70px;
}
}
@media only screen and (max-width: 835px) {
.mu-box{
margin: 0 0 30px;
padding: 90px 5% 15px 5%;
background: url(image/mu-his2.png) no-repeat center 15px/auto 60px;
}
}
@media only screen and (max-width: 640px) {
.mu-box{
border: none;
margin: 0 0 20px;
padding: 90px 0 0px 0;
box-shadow: none;
background: url(image/mu-his2.png) no-repeat center 15px/auto 70px;
}
}
@media only screen and (max-width: 414px) {
.mu-box{
padding: 80px 0 0px 0;
background: url(image/mu-his2.png) no-repeat center 15px/auto 60px;
}
}

.bar{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 30px;
padding: 0;
}

.mu-box h3{
clear: both;
float: left;
width: 50%;
height: auto;
margin: 0;
padding: 10px 0 7px;
background: #703234;
color: #fff;
font-size: 25px;
font-weight: 500;
line-height: 100%;
border-radius: 50px;
text-align: center;
}
.mu-box h3 em{
font-style: normal;
font-size: 17px;
font-weight: 400;
}
.mu-box h3 span{
font-size: 15px;
font-weight: 400;
margin: 0 0 0 1%;
}
@media only screen and (max-width: 1280px) {
.mu-box h3{
font-size: 20px;
}
.mu-box h3 em{
font-size: 15px;
}
.mu-box h3 span{
font-size: 14px;
}
}
@media only screen and (max-width: 1080px) {
.mu-box h3{
width: 60%;
}
}
@media only screen and (max-width: 835px) {
.mu-box h3{
width: 100%;
margin: 0 0 15px;
padding: 15px 0 12px;
font-size: 25px;
}
}
@media only screen and (max-width: 414px) {
.mu-box h3{
font-size: 20px;
}
.mu-box h3 em{
font-size: 13px;
}
.mu-box h3 span{
font-size: 13px;
}
}

.mu-box p{
text-align: left;
font-size: 17px;
line-height: 180%;
margin: 0 0 30px;
}
@media only screen and (max-width: 1440px) {
.mu-box p{
font-size: 16px;
line-height: 160%;
}
}

audio{
float: right;
width: 48%;
height: auto;
margin: 0 0 0 2%;
padding: 0;
}
@media only screen and (max-width: 1080px) {
audio{
width: 38%;
}
}
@media only screen and (max-width: 835px) {
audio{
width: 100%;
margin: 0;
}
}

#area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 120px 10%;
background: #ede9e8;
}
@media only screen and (max-width: 1600px) {
#area{
padding: 120px 5%;
}
}
@media only screen and (max-width: 1280px) {
#area{
padding: 100px 5% 80px;
}
}
@media only screen and (max-width: 1080px) {
#area{
padding: 80px 5% 50px;
}
}
@media only screen and (max-width: 480px) {
#area{
padding: 50px 5% 40px;
}
}

#area h4{
clear: both;
float: left;
width: 40%;
height: auto;
margin: 0 30% 50px;
padding: 15px 0;
text-align: center;
font-size: 35px;
line-height: 100%;
background: #fff;
font-weight: 400;
}
@media only screen and (max-width: 1440px) {
#area h4{
width: 40%;
font-size: 30px;
margin: 0 30% 50px;
}
}
@media only screen and (max-width: 1280px) {
#area h4{
width: 50%;
font-size: 30px;
margin: 0 25% 50px;
}
}
@media only screen and (max-width: 1080px) {
#area h4{
width: 60%;
font-size: 25px;
margin: 0 20% 40px;
}
}
@media only screen and (max-width: 835px) {
#area h4{
width: 70%;
font-size: 25px;
margin: 0 15% 40px;
}
}
@media only screen and (max-width: 640px) {
#area h4{
width: 80%;
font-size: 25px;
margin: 0 10% 20px;
}
}
@media only screen and (max-width: 480px) {
#area h4{
width:90%;
font-size: 20px;
margin: 0 5% 20px;
}
}

#area img{
max-width:50%;
}
@media only screen and (max-width: 1080px) {
#area img{
max-width:70%;
}
}
@media only screen and (max-width: 835px) {
#area img{
max-width:90%;
}
}
@media only screen and (max-width: 640px) {
#area img{
max-width:100%;
}
}

#area-text{
float: right;
width: 50%;
text-align: left;
}
#area-text p{
text-align: left;
font-size: 20px;
line-height: 180%;
margin: 0 0 40px;
}
#area-text p.f15{
font-size: 15px;
line-height: 130%;
text-align: justify;
}
@media only screen and (max-width: 1280px) {
#area-text p{
font-size: 17px;
margin: 0 0 30px;
}
#area-text p.f15{
color: #703234;
}
}
@media only screen and (max-width: 1080px) {
#area-text{
clear: both;
width: 100%;
}
}
@media only screen and (max-width: 480px) {
#area-text p{
font-size: 16px;
}
}

#price{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 150px 0 250px;
background: url(image/price-back.webp) no-repeat center bottom/100%;
z-index: 2;
position: relative;
}
@media only screen and (max-width: 1280px) {
#price{
padding: 120px 0 200px;
}
}
@media only screen and (max-width: 1080px) {
#price{
padding: 90px 0 160px;
}
}
@media only screen and (max-width: 835px) {
#price{
padding: 60px 0 120px;
}
}
@media only screen and (max-width: 640px) {
#price{
padding: 60px 0 80px;
}
}

#price h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 80px;
padding: 0 0 30px;
text-align: center;
font-size: 40px;
font-weight: 400;
line-height: 100%;
background: url(image/repa-h2.png) no-repeat center bottom;
}
@media only screen and (max-width: 1080px) {
#price h2{
margin: 0 0 60px;
font-size: 35px;
}
}
@media only screen and (max-width: 835px) {
#price h2{
margin: 0 0 50px;
padding: 0 0 30px;
font-size: 30px;
}
}
@media only screen and (max-width: 640px) {
#price h2{
margin: 0 0 40px;
padding: 0 0 20px;
font-size: 25px;
background: url(image/repa-h2.png) no-repeat center bottom/25%;
}
}

#price-area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 150px;
padding: 0;
display: flex;
align-items: flex-start;
}
#price-area img{
max-width: 40%;
}
#price-text{
width: 55%;
flex-basis:55%;
margin: 0 0 0 5%;
padding: 0 0 0 3%;
text-align: left;
border-left: 1px solid #111;
}
@media only screen and (max-width: 1280px) {
#price-area{
margin: 0 0 100px;
}
}
@media only screen and (max-width: 1080px) {
#price-area{
display:inherit;
align-items: flex-start;
}
#price-area img{
max-width: 70%;
}
#price-text{
width: 100%;
flex-basis:100%;
margin: 0 ;
padding: 0 5%;
border-top:none;
text-align: center;
}
}
@media only screen and (max-width: 835px) {
#price-area{
margin: 0 0 60px;
}
}
@media only screen and (max-width: 640px) {
#price-area img{
max-width: 80%;
}
}

#price p{
text-align: left;
font-size: 40px;
}
#price p strong{
font-size: 50px;
margin: 0 0 0 2%;
}
#price p strong.f-orange{
color: #f04b00;
font-size: 60px;
font-weight: 700;
}
#price p strong.f-orange span{
font-size: 50px;
font-weight: 600;
}
@media only screen and (max-width: 1280px) {
#price p{
font-size: 30px;
}
#price p strong{
font-size: 40px;
}
#price p strong.f-orange{
font-size: 50px;
}
#price p strong.f-orange span{
font-size: 40px;
}
}
@media only screen and (max-width: 1080px) {
#price p{
text-align: center;
}
}
@media only screen and (max-width: 640px) {
#price p strong.f-orange{
line-height: 150%;
}
}
@media only screen and (max-width: 414px) {
#price p{
font-size: 25px;
}
#price p strong{
font-size: 35px;
}
#price p strong.f-orange{
font-size: 40px;
}
#price p strong.f-orange span{
font-size: 30px;
}
}

#price ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
}
#price li{
list-style-type: none;
font-size: 15px;
line-height: 120%;
margin: 0 0 10px;
padding: 0;
text-align: left;
}
@media only screen and (max-width: 1080px) {
#price li{
text-align: center;
}
}

#price h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 20px;
padding: 0;
text-align: left;
font-weight: 600;
font-size: 35px;
color: #f04b00;
line-height: 100%;
}
@media only screen and (max-width: 1080px) {
#price h3{
text-align: center;
}
}

#price a{
display: block;
width: 70%;
height: auto;
margin: 0 30% 15px 0;
padding: 0;
line-height: 100%;
border: 2px solid #fff;
}
#price a:link,#price a:visited{
color: #fff;
text-align: center;
font-size: 35px;
padding: 0;
display: flex;
justify-content:center;
align-items: center;
background: #f04b00;
min-height: 70px;
border-radius: 10px;
}
#price a:hover{
text-decoration: none;
background: #111;
}
#price a img{
margin: 0 3% 0 0;
max-height: 50px;
}
@media only screen and (max-width: 1080px) {
#price a{
width: 70%;
margin: 0 15% 15px 15%;
}
}
@media only screen and (max-width: 640px) {
#price a{
width: 90%;
height: auto;
margin: 0 5% 15px 5%;
font-size: 25px;
}
#price a:link,#price a:visited{
font-size: 30px;
}
#price a img{
max-height: 30px;
}
}
@media only screen and (max-width: 480px) {
#price a{
width: 100%;
margin: 0 0% 15px 0%;
}
#price a:link,#price a:visited{
font-size: 25px;
}
#price a img{
max-height: 25px;
}
}

#news{
clear: both;
float: left;
width: 70%;
height: auto;
margin: 0 15%;
padding: 60px 5%;
background: #fff;
border-radius: 15px;
}
@media only screen and (max-width: 1280px) {
#news{
width: 80%;
margin: 0 10%;
padding: 50px 5%;
}
}
@media only screen and (max-width: 1080px) {
#news{
width: 90%;
margin: 0 5%;
padding: 40px 5%;
}
}
@media only screen and (max-width: 640px) {
#news{
border-radius: 10px;
}
}

#price #news h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
text-align: center;
font-size: 35px;
line-height: 100%;
font-weight: 400;
background: none;
}
@media only screen and (max-width: 1280px) {
#price #news h2{
margin: 0 0 40px;
font-size: 30px;
}
}
@media only screen and (max-width: 835px) {
#price #news h2{
margin: 0 0 30px;
font-size: 25px;
}
}

#news-box{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}
#news-pict{
clear: both;
float: left;
width: 30%;
height: auto;
margin: 0;
padding: 0;
}
#news-text{
float: right;
width:70%;
height: auto;
margin: 0;
padding: 0 0 0 3%;
text-align: left;
}
@media only screen and (max-width: 835px) {
#news-pict{
width: 100%;
margin: 0 0 20px;
text-align: center;
}
#news-text{
clear: both;
float: right;
width:100%;
padding: 0;
}
}

#news-pict img{
max-width: 100%;
}
@media only screen and (max-width: 835px) {
#news-pict img{
max-width: 50%;
}
}
@media only screen and (max-width: 480px) {
#news-pict img{
max-width: 60%;
}
}

#price #news p{
text-align: left;
font-size: 17px;
line-height: 180%;
margin: 0 0 30px;
font-weight: 400;
}
#price #news p.pday{
margin: 0 0 10px;
font-size: 15px;
}
@media only screen and (max-width: 480px) {
#price #news p{
font-size: 16px;
line-height: 160%;
}
}

#price #news a{
display: inherit;
width: auto;
margin: 0;
border: none;
}
#price #news a:link,#price #news a:visited{
color: #111;
text-align: left;
font-size: 17px;
display: inherit;
justify-content: flex-start;
align-items: flex-start;
background: none;
min-height: auto;
border-radius: 0;
}
#price #news a:hover{
background: none;
}

#price #news h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 30px;
padding: 0 0 10px;
line-height: 120%;
border-bottom: 1px solid #111;
text-align: left;
font-weight: 600;
font-size: 25px;
}
#price #news h3 a:link,#price #news h3 a:visited{
font-size: 25px;
}
@media only screen and (max-width: 1080px) {
#price #news h3 a:link,#price #news h3 a:visited{
font-size: 20px;
}
}

#news-link{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 10px 0 0;
padding: 0;
text-align: right;
}
#news-link span{
display: block;
float: right;
width: auto;
font-size: 17px;
border: 1px solid #111;
padding: 5px 30px 5px 15px;
text-align: center;
line-height: 100%;
background: url(image/news-ar.png) no-repeat 95% center/10px;
}
#price #news-link span a:link,#price #news-link span a:visited{
font-size: 17px;
}
@media only screen and (max-width: 1080px) {
#price #news-link span a:link,#price #news-link span a:visited{
font-size: 16px;
}
}
@media only screen and (max-width: 480px) {
#price #news-link span a:link,#price #news-link span a:visited{
font-size: 14px;
}
}

#toi{
clear: both;
float: left;
width: 100%;
height: auto;
margin: -250px 0 0;
padding: 350px 5% 60px;
background: url(image/toi-back.webp) no-repeat center center/100%;
z-index: 1;
position: relative;
}
@media only screen and (max-width: 1080px) {
#toi{
margin: -300px 0 0;
padding: 380px 5% 20px;
background: url(image/toi-back.webp) no-repeat center center/100% 100%;
}
}

#toi h5{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 80px;
padding: 0 0 30px;
text-align: center;
font-size: 40px;
font-weight: 400;
line-height: 100%;
color: #fc6723;
background: url(image/toi-h5.png) no-repeat center bottom;
}
@media only screen and (max-width: 1080px) {
#toi h5{
margin: 0 0 30px;
}
}
@media only screen and (max-width: 835px) {
#toi h5{
font-size: 35px;
}
}
@media only screen and (max-width: 640px) {
#toi h5{
font-size: 30px;
}
}

#toi-left{
clear: both;
float: left;
width: 40%;
height: auto;
margin: 0;
padding: 0 0 500px;
background: url(image/toi-left.webp) no-repeat center bottom/70%;
}
#toi-left p{
width: 100%;
border: 1px solid #fff;
text-align: justify;
font-size: 25px;
line-height: 150%;
margin: 0;
padding: 50px 10%;
color: #fff;
}
@media only screen and (max-width: 1440px) {
#toi-left{
width: 40%;
padding: 0 0 400px;
background: url(image/toi-left.webp) no-repeat center bottom/70%;
}
#toi-left p{
font-size: 25px;
padding: 30px 10%;
}
}
@media only screen and (max-width: 1280px) {
#toi-left{
width: 30%;
padding: 0 0 250px;
background: url(image/toi-left.webp) no-repeat center bottom/80%;
}
#toi-left p{
font-size: 20px;
padding: 20px 5%;
}
}
@media only screen and (max-width: 1080px) {
#toi-left{
width: 100%;
padding: 280px 0 60px;
background: url(image/toi-left.webp) no-repeat center top/auto 250px;
}
}
@media only screen and (max-width: 835px) {
#toi-left{
padding: 230px 0 60px;
background: url(image/toi-left.webp) no-repeat center top/auto 200px;
}
}
@media only screen and (max-width: 640px) {
#toi-left{
padding: 180px 0 60px;
background: url(image/toi-left.webp) no-repeat center top/auto 150px;
}
#toi-left p{
font-size: 17px;
padding: 15px 5%;
}
}

#mail{
float: right;
width: 60%;
margin: 0;
padding: 0 5% 0 3%;
}
@media only screen and (max-width: 1600px) {
#mail{
padding: 0 0% 0 2%;
}
}
@media only screen and (max-width: 1280px) {
#mail{
width: 70%;
}
}
@media only screen and (max-width: 1080px) {
#mail{
clear: both;
float: left;
width: 100%;
margin: 0 0 30px;
}
}

#mail dl{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}
#mail dt{
clear: both;
float: left;
width: 25%;
height: auto;
margin: 0 0 30px;
padding: 0;
text-align: left;
color: #fff;
font-size:20px;
line-height: 120%;
font-weight: 400;
}
#mail  dd{
clear: none;
float: left;
width: 75%;
height: auto;
margin: 0 0 30px;
padding: 0 0 0 3%;
text-align: left;
font-size: 20px;
line-height: 120%;
font-weight: 400;
color: #fff;
}
@media only screen and (max-width: 1440px) {
#mail dt{
width: 30%;
margin: 0 0 30px;
font-size:20px;
}
#mail  dd{
width: 70%;
margin: 0 0 30px;
padding: 0 0 0 3%;
font-size: 20px;
}
}
@media only screen and (max-width: 835px) {
#mail dt{
font-size:17px;
}
#mail  dd{
font-size: 17px;
}
}
@media only screen and (max-width: 640px) {
#mail dt{
clear: both;
width: 100%;
font-size:16px;
margin: 0 0 10px;
}
#mail  dd{
clear: both;
width: 100%;
font-size: 16px;
margin: 0 0 25px;
padding: 0 0 25px;
border-bottom:1px dotted #fff;
}
#mail  dd:last-of-type{
border-bottom:none;
margin: 0;
padding: 0;
}
}

form{
clear: both;
width:100%;
height: auto;
margin: 0 auto;
padding: 0;
text-align: center;
}
.hissu{
font-size: 12px;
border-radius: 5px;
background: #111;
color:#fff;
padding: 0 5px 1px;
margin: 0 0 0 2%;
}
.nini{
font-size: 12px;
border-radius: 5px;
background: #888;
color:#fff;
padding: 0 5px 1px;
margin: 0 0 0 2%;
}
#mail-check{
	clear:both;
	float:left;
	width:100%;
	height:auto;
	margin:10px 0 50px;
	padding:10px 0;
	text-align:center;
}

textarea,input[type="text"] ,input[type="email"]{
width: 100%;
background: #f2f2f2;
border: 1px solid #6992a6;
padding: 5px;
}
select{
width: 20%;
margin: 0 2% 0 0;
}

input.btn_submit,input.btn_submit2{
 width:50%;
 height:50px;
 background: #fc6723;
 border-radius: 10px;
 box-shadow: 2px 2px 3px #aaa;
 border: 2px solid #fff;
 font-size: 20px;
 font-weight: 500;
 color: #fff;
 line-height: 46px;
}
input.btn_submit2{
 width:25%;
 height:40px;
  line-height: 36px;
   background: #dddddd;
 color: #555;
 font-size: 15px;
 margin: 0 0 0 2%;
}
@media only screen and (max-width: 640px) {
input.btn_submit,input.btn_submit2{
 width:60%;
}
input.btn_submit2{
 width:25%;
}
}

input.btn_submit:hover {
 background: #333;
 cursor: pointer;
}

input.btn_submit2:hover {
 background: #ccc;
  cursor: pointer;
}
label{
 cursor: pointer;
}

#sub-page{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 100px 25% 0;
}
@media only screen and (max-width: 1280px) {
#sub-page{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 100px 15% 0;
}
}
@media only screen and (max-width: 1080px) {
#sub-page{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 100px 10% 0;
}
}
@media only screen and (max-width: 835px) {
#sub-page{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 60px 5% 0;
}
}

#sub-page h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0 0 15px;
text-align: center;
font-size: 40px;
font-weight: 700;
line-height: 100%;
color: #703234;
border-bottom: 1px solid #703234;
}
#sub-page p{
text-align: center;
font-size: 18px;
line-height: 200%;
margin: 0 0 50px;
}
@media only screen and (max-width: 1080px) {
#sub-page h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0 0 15px;
text-align: center;
font-size: 35px;
font-weight: 700;
line-height: 100%;
}
#sub-page p{
text-align: center;
font-size: 16px;
line-height: 200%;
margin: 0 0 50px;
}
}
@media only screen and (max-width: 835px) {
#sub-page h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0 0 15px;
text-align: center;
font-size: 30px;
font-weight: 700;
line-height: 100%;
}
#sub-page p{
text-align: center;
font-size: 15px;
line-height: 200%;
margin: 0 0 50px;
}
}
@media only screen and (max-width: 480px) {
#sub-page h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0 0 15px;
text-align: center;
font-size: 25px;
font-weight: 700;
line-height: 100%;
}
#sub-page p{
text-align: left;
font-size: 15px;
line-height: 200%;
margin: 0 0 40px;
}
}
@media only screen and (max-width: 414px) {
#sub-page p{
text-align: left;
font-size: 14px;
line-height: 200%;
margin: 0 0 30px;
}
}

#news-list{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}

#news-list ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}
#news-list li{
display: block;
clear: both;
float: left;
width: 100%;
height: auto;
list-style-type: none;
margin: 0 0 50px;
padding: 0;
font-size: 17px;
line-height: 180%;
}

#news-list p{
text-align: left;
font-size: 17px;
line-height: 180%;
margin: 0 0 30px;
font-weight: 400;
}
#news-list p.pday{
margin: 0 0 10px;
font-size: 15px;
}
@media only screen and (max-width: 480px) {
#news-list p{
font-size: 16px;
line-height: 160%;
}
}

#news-list a{
display: inherit;
width: auto;
margin: 0;
border: none;
}
#news-list a:link,#news-list a:visited{
color: #111;
text-align: left;
font-size: 17px;
display: inherit;
justify-content: flex-start;
align-items: flex-start;
background: none;
min-height: auto;
border-radius: 0;
}
#news-list a:hover{
background: none;
}

#news-list h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 30px;
padding: 0 0 10px;
line-height: 120%;
border-bottom: 1px solid #111;
text-align: left;
font-weight: 600;
font-size: 25px;
}
#news-list h3 a:link,#news-list h3 a:visited{
font-size: 25px;
}
@media only screen and (max-width: 1080px) {
#news-list a:link,#news-list a:visited{
font-size: 20px;
}
}

.detailText div,.detailText div p,.detailText{
text-align: left;
margin: 0 0 40px;
padding: 0;
font-size: 17px;
line-height: 180%;
}
@media only screen and (max-width: 640px) {
.detailText div,.detailText div p,.detailText{
margin: 0 0 30px;
font-size: 16px;
line-height: 150%;
}
}

.js-fadeUp {
  opacity: 0; 
  transform: translateY(50px);
  transition: opacity .8s, transform 1.2s; 
}
.js-fadeUp.is-inview {
  opacity: 1;
  transform: translateY(0);
  transition-delay: 0.4s; 
}

/*フッタ
--------------------------------------------------------------------------*/
#page-top{
	width:40px;
	height:40px;
	display:none;
	position:fixed;
	right:16px;
	bottom:16px;
	color:#fff;
    z-index: 9997;
}
@media only screen and (max-width: 1080px) {
#page-top{
	right:16px;
	bottom:70px;
}
}
@media only screen and (max-width: 640px) {
#page-top{
	right:10px;
	bottom:70px;
}
}
@media only screen and (max-width: 480px) {
#page-top{
	width:35px;
	height:35px;
	right:10px;
	bottom:70px;
}
}
 
#page-top p{
	margin:0;
	padding:0;
	text-align:center;
	background:#f04b00;
	transition:all 0.3s;
	color:#fff;
} 
#page-top p:hover{
	background:#111;
	color:#fff;
} 
#move-page-top{
	color:#fff;
	line-height:40px;
	text-decoration:none;
	display:block;
	cursor:pointer;
}
@media only screen and (max-width: 480px) {
#page-top p{
font-size: 15px;
} 
#move-page-top{
	line-height:35px;
}
}
