@charset "UTF-8";

body {
	margin: 0;
	padding: 0;
	COLOR: #111;
	FONT-SIZE:20px;
font-family: 'Noto Sans JP', sans-serif;
	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:#80915a;
}

a:hover{
	outline:0;
	color: #25443a;
    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 3%;
background: #25443a;
text-align: left;
position: sticky;
z-index: 9999;
top:0;
}
@media only screen and (max-width: 640px) {
header{
padding: 15px 3% 15px;
}
}
@media only screen and (max-width: 480px) {
header{
min-height:80px;
padding: 15px 3% 15px;
}
}

#header-title{
clear: both;
float: left;
width: 25%;
height: auto;
margin: 0;
padding: 0;
display: flex;
align-items: center;
}
#header-title img{
max-height: 60px;
margin: 0 15px 0 0;
vertical-align: middle;
}
@media only screen and (max-width: 1280px) {
#header-title{
width: 100%;
}
}
@media only screen and (max-width: 640px) {
#header-title img{
max-height: 50px;
}
}

header h1{
clear: none;
margin: 0;
padding: 0;
color:#fff;
font-size: 30px;
line-height: 100%;
font-weight: 700;
}
header h1 a:link,header h1 a:visited{
color: #fff;
text-decoration: none;
}
header h1 a:hover{
text-decoration: underline;
}
@media only screen and (max-width: 1600px) {
header h1{
font-size: 25px;
}
}

menu{
float: right;
width: 75%;
height: auto;
margin: 0;
padding: 0;
}

menu ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
display: flex;
align-items: center;
}
menu ul li{
flex: 1 0 auto;
list-style-type: none;
font-size: 17px;
line-height: 100%;
margin: 0;
padding: 5px 0;
border-left: 1px solid #fff;
text-align: center;
}
menu li a:link,menu li a:visited{
color: #fff;
text-decoration: none;
}
menu li a:hover{
text-decoration: underline;
}
menu li.bno{
background: url(images/tel.png) no-repeat 20% 50%/auto 30px,#80915a;
border-left: none;
font-size: 25px;
margin: 0 2% 0 0;
border-radius: 50px;
font-weight: 600;
text-indent: 1em;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 18% 60%/auto 23px,#fcaa2b;
border-left: none;
font-size: 22px;
border-radius: 50px;
text-indent: 1em;
}
menu li.bno a:link,menu li.bno a:visited,menu li.bno2 a:link,menu li.bno2 a:visited{
display: block;
padding: 10px 0;
}
@media only screen and (max-width: 1600px) {
menu li.bno{
background: url(images/tel.png) no-repeat 15% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 14% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 1440px) {
menu li.bno{
background: url(images/tel.png) no-repeat 12% 50%/auto 30px,#80915a;
font-size: 25px;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 10% 60%/auto 23px,#fcaa2b;
font-size: 22px;
}
}

@media only screen and (max-width: 1280px) {
#menu-box{
clear: both;
float: none;
width: 90%;
height: auto;
margin: 0 0 0 10%;
padding: 0;
position: fixed;
top:0;
left:0;
z-index: 9999;
background: none;
}
menu{
clear: both;
float: left;
width: 100%;
height: auto;
height: 100vh;
margin: 0;
padding: 0;
text-align: left;
position: fixed;
top: 0;
background: rgba(255,255,255,1.0);
box-shadow:-5px 0 15px #ccc;
}
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 #25443a;
  border-left: none;
}
menu li a:link,menu li a:visited{
float: none;
display: block;
text-decoration: none;
color: #25443a;
margin: 0;
padding: 25px 0 25px 1em;
text-align: left;
line-height: 100%;
font-size: 17px;
font-weight:500;
}
menu li a:hover{
text-decoration: none;
}
menu li.bno{
width: 80%;
background: url(images/tel.png) no-repeat 35% 50%/auto 30px,#80915a;
border-left: none;
margin: 15px 5% 0;
border-radius: 50px;
font-weight: 600;
text-indent: 0;
border-bottom: none;
}
menu li.bno2{
width: 80%;
background: url(images/mail.png) no-repeat 35% 60%/auto 23px,#fcaa2b;
border-left: none;
margin: 15px 5% 0;
border-radius: 50px;
text-indent: 0;
border-bottom: none;
}
menu li.bno a:link,menu li.bno a:visited,menu li.bno2 a:link,menu li.bno2 a:visited{
display: block;
padding: 10px 0;
text-align: center;
color: #fff;
font-size: 25px;
}
@media only screen and (max-width: 1080px) {
menu li.bno{
background: url(images/tel.png) no-repeat 30% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 30% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 835px) {
menu li.bno{
background: url(images/tel.png) no-repeat 25% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 25% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 640px) {
menu li.bno{
background: url(images/tel.png) no-repeat 20% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 20% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 480px) {
menu li.bno a:link,menu li.bno a:visited,menu li.bno2 a:link,menu li.bno2 a:visited{
font-size: 22px;
}
menu li.bno{
background: url(images/tel.png) no-repeat 15% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 15% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 414px) {
menu li.bno{
background: url(images/tel.png) no-repeat 10% 50%/auto 30px,#80915a;
}
menu li.bno2{
background: url(images/mail.png) no-repeat 10% 60%/auto 23px,#fcaa2b;
}
}

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

/*ボタン外側※レイアウトによってpositionや形状は適宜変更してください*/
.openbtn4{
float: right;
  position: fixed;/*ボタン内側の基点となるためrelativeを指定*/
  background:#fcaa2b;
  cursor: pointer;
    width: 60px;
    height:60px;
  border-radius: 5px;
  top:10px;
  right:10px;
  z-index: 999;
  border: 2px solid #fff;
}

/* --- ボタン内側の線の基本設定 --- */
.openbtn4 span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 16px;
    height: 2px;
    border-radius: 5px;
    background: #fff;
    width: 45%;
}

/* 1本目：中央より少し上に配置 */
.openbtn4 span:nth-of-type(1) {
    top: 13px; 
}
/* 2本目：ほぼ中央に配置 */
.openbtn4 span:nth-of-type(2) {
    top: 21px;
}
/* 3本目：中央より少し下に配置 */
.openbtn4 span:nth-of-type(3) {
    top: 29px;
}

/* --- テキスト（Menu/Close）の共通設定 --- */
.openbtn4 span:nth-of-type(3)::after {
    content: "Menu";
    position: absolute;
    top: 0px; /* 線からの距離 */
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 0.9rem; /* 少し小さくするとバランスが良いです */
    text-transform: uppercase;
}

/* --- activeクラス（×印の状態） --- */
.openbtn4.active span:nth-of-type(1) {
    top: 21px; /* 2本目と同じ高さに集める */
    left: 18px;
    transform: rotate(-45deg);
    width: 40%;
}
.openbtn4.active span:nth-of-type(2) {
    opacity: 0;
}
.openbtn4.active span:nth-of-type(3) {
    top: 21px; /* 2本目と同じ高さに集める */
    left: 18px;
    transform: rotate(45deg);
    width: 40%;
}

/* Closeテキストの位置微調整 */
.openbtn4.active span:nth-of-type(3)::after {
    content: "Close";
    /* 斜めになった親要素に対して、逆回転（-45度）をかけて水平に戻し、translateXで中央へ */
    transform: rotate(-45deg) translateX(-50%); 
        /* ボタンの横幅いっぱいに領域を確保して中央揃えを安定させる */
    width: 60px; 
    text-align: center;
    /* 表示位置の微調整 */
    top: -20px;  /* 線からの距離（上下位置） */
    left: 18px; /* 回転軸からの距離（左右位置） */
}
/*.doneクラスがついたヘッダー*/
.dnone {
display: none;
}
/*メニューボタンをクリックした際に付与されるpanelactiveクラスがついたら*/
.dnone.panelactive {
display: inherit;
}
}
 
/*メイン
--------------------------------------------------------------------------*/
#photo{
clear: both;
float: left;
width: 100%;
height: 650px;
margin: 0;
padding: 200px 5% 0;
background: url(images/photo.webp) no-repeat right center/contain,#999;
}
@media only screen and (max-width: 1280px) {
#photo{
height: 600px;
padding: 150px 5% 0;
}
}
@media only screen and (max-width: 1080px) {
#photo{
height: 550px;
padding: 250px 5% 0;
}
}
@media only screen and (max-width: 835px) {
#photo{
height: auto;
    min-height: 400px; /* 背景画像を見せるための高さ */
    position: relative;
    padding: 0;
    margin-bottom: 180px; /* 突き出した要素の高さ分、下の余白を確保 */
    display: flex;
    flex-direction: column;
    justify-content: flex-end; /* 中身を下側に寄せる */
}
}
@media only screen and (max-width: 640px) {
#photo{
min-height: 350px;
}
}
@media only screen and (max-width: 480px) {
#photo{
min-height: 300px;
}
}
@media only screen and (max-width: 414px) {
#photo{
min-height: 250px;
}
}

#photo h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
text-align: left;
font-size: 45px;
font-weight: 700;
line-height: 180%;
color: #fff;
}
#photo h1 strong{
font-size: 70px;
font-weight: 700;
}
#photo h1 em{
font-size: 60px;
font-style: normal;
}
#photo p{
margin: 0;
padding: 0;
text-align: left;
color: #fff;
font-size: 25px;
line-height: 120%;
}
@media only screen and (max-width: 1280px) {
#photo h1{
text-shadow: 2px 2px 2px #666;
}
#photo p{
text-shadow: 2px 2px 2px #666;
}
}
@media only screen and (max-width: 1080px) {
#photo h1{
font-size: 40px;
margin: 0 0 30px;
}
#photo p{
font-size: 20px;
}
}
@media only screen and (max-width: 835px) {
/* h1 と p を絶対配置の「セット」として扱う */
  #photo h1, #photo p {
    position: relative; /* absoluteを解除 */
    left: auto;
    bottom: auto;
    top: auto;
    width: 90%;
    margin: 0 auto; /* 左右中央揃え */
    background-color: rgba(0,0,0,0.6);
    color: #fff;
    text-align: left;
  }
#photo h1 {
    /* 背景画像の下端に半分かかるくらいの位置に調整 */
    transform: translateY(100px); /* 全体を下に100px突き出させる */
    padding: 20px 3% 10px;
    border-radius: 7px 7px 0 0;
    font-size: 30px;
    z-index: 10;
  }
  #photo p {
    /* h1と一緒に動くように設定 */
    transform: translateY(100px); 
    padding: 0 3% 25px;
    border-radius: 0 0 7px 7px;
    font-size: 18px;
    line-height: 1.6;
    z-index: 10;
  }
  #photo h1 strong { font-size: 45px; }
  #photo h1 em { font-size: 35px; }
}
@media only screen and (max-width: 640px) {
#photo h1 {
    font-size: 25px;
  }
  #photo h1 strong { font-size: 40px; }
  #photo h1 em { font-size: 30px; }
}
@media only screen and (max-width: 480px) {
#photo h1 strong { font-size: 35px; }
}
@media only screen and (max-width: 414px) {
#photo h1 {
    font-size: 20px;
  }
#photo h1 strong { font-size: 32px; }
}

main{
clear: both;
float: left;
width: 100%;
height: auto;
}
main p{
font-size: 18px;
line-height: 180%;
text-align: left;
margin: 0 0 40px;
}
@media only screen and (max-width: 640px) {
main p{
font-size: 17px;
}
}
@media only screen and (max-width: 480px) {
main p{
font-size: 16px;
margin: 0 0 30px;
text-align: justify;
}
}

#about{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 80px 10% 250px;
background: url(images/about.webp) no-repeat 70% 40%,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
@media only screen and (max-width: 1440px) {
#about{
padding: 80px 10% 200px;
background: url(images/about.webp) no-repeat 90% 40%,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 1280px) {
#about{
padding: 80px 5% 200px;
background: url(images/about.webp) no-repeat 95% 40%,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 1080px) {
#about{
padding: 80px 5% 150px;
background: url(images/about.webp) no-repeat 95% 20%/40%,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 835px) {
#about{
padding: 80px 5% 350px;
background: url(images/about-sm.webp) no-repeat center 90%/600px,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 640px) {
#about{
padding: 60px 5% 260px;
background: url(images/about-sm.webp) no-repeat center 90%/400px,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 480px) {
#about{
background: url(images/about-sm.webp) no-repeat center 90%/380px,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}
@media only screen and (max-width: 414px) {
#about{
padding: 60px 5% 220px;
background: url(images/about-sm.webp) no-repeat center 90%/330px,url(images/about-back.webp) no-repeat center bottom/100%,#eef2f0;
}
}

#about h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0;
text-align: left;
font-weight: 800;
line-height: 110%;
font-size: 50px;
color: #4e6b5e;
}
#about h2 span{
font-size: 25px;
font-weight: 500;
line-height: 110%;
}
@media only screen and (max-width: 640px) {
#about h2{
margin: 0 0 40px;
font-size: 45px;
}
#about h2 span{
font-size: 20px;
}
}
@media only screen and (max-width: 480px) {
#about h2{
margin: 0 0 30px;
font-size: 40px;
}
#about h2 span{
font-size: 17px;
}
}
@media only screen and (max-width: 414px) {
#about h2{
font-size: 35px;
}
}

#about h3,#business h3,#pro h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 30px;
padding: 0;
text-align: left;
font-size: 30px;
font-weight: 700;
line-height: 120%;
color: #1f3a2e;
}
@media only screen and (max-width: 640px) {
#about h3,#business h3,#pro h3{
font-size: 25px;
font-weight: 800;
}
}

#business{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 40px 10% 100px;
background: url(images/business-back.png) no-repeat 15% 80px;
}
@media only screen and (max-width: 1280px) {
#business{
padding: 40px 5% 100px;
background: url(images/business-back.png) no-repeat 15% 80px;
}
}
@media only screen and (max-width: 1080px) {
#business{
padding: 40px 5% 60px;
}
}
@media only screen and (max-width: 835px) {
#business{
padding: 40px 5% 30px;
background: url(images/business-back.png) no-repeat 15% 80px/90%;
}
}

#business h2,#pro h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0;
text-align: left;
line-height: 100%;
color: #80915a;
font-size: 50px;
font-weight: 800;
}
@media only screen and (max-width: 640px) {
#business h2,#pro h2{
margin: 0 0 40px;
font-size: 45px;
}
}
@media only screen and (max-width: 480px) {
#business h2,#pro h2{
margin: 0 0 30px;
font-size: 40px;
}
}
@media only screen and (max-width: 414px) {
#business h2,#pro h2{
font-size: 35px;
}
}

#bu-area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 40px 0 0;
padding: 0;
display: flex;
}
@media only screen and (max-width: 1080px) {
#bu-area{
margin: 30px 0 0;
flex-wrap: wrap;
}
}
@media only screen and (max-width: 640px) {
#bu-area{
margin: 10px 0 0;
flex-wrap: wrap;
}
}

.bu-box{
flex: 1;
margin: 0;
padding: 0;
position: relative;
}
.bu-box img{
max-width: 100%;
display: block;
}
@media only screen and (max-width: 1080px) {
.bu-box{
flex-basis:50%;
margin: 0 0 20px;
flex-grow: 0;
}
}
@media only screen and (max-width: 640px) {
.bu-box{
flex-basis:100%;
margin: 0 0 30px;
flex-grow: 0;
}
}

.bu-back{
clear: both;
float: left;
width: 100%;
height: 60px;
margin: 0;
padding: 0;
background: #80915a;
mix-blend-mode: multiply;
position: absolute;
bottom:0;
}

.bu-box p{
width: 100%;
text-align: left;
margin: 0;
padding: 0 0 0 7%;
color: #fff;
font-size: 18px;
line-height: 60px;
font-weight: 600;
position: absolute;
bottom:0;
background: url(images/bu-ar.png) no-repeat 90% center/40px;
}
.bu-box p a:link,.bu-box p a:visited{
display: block;
color: #fff;
text-decoration: none;
}
.bu-box p a:hover{
text-decoration: underline;
}

#bu-area h4{
clear: both;
float: left;
width: 80%;
height: auto;
margin: 0 20% 0 0;
padding: 15px 3% 10px;
text-align: left;
line-height: 100%;
color: #fff;
font-weight: 700;
background: #80915a;
font-size: 30px;
border-radius: 7px 7px 0 0;
}
#bu-area h4 span{
font-size: 18px;
font-weight: 500;
}
@media only screen and (max-width: 1440px) {
#bu-area h4{
width: 90%;
margin: 0 10% 0 0;
padding: 15px 3% 10px;
font-size: 25px;
}
}
@media only screen and (max-width: 480px) {
#bu-area h4 span{
font-size: 16px;
}
}

#riyu{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 200px 10% 500px;
background: url(images/riyu-back3.webp) no-repeat center bottom/50%,url(images/riyu-back2.png) no-repeat 95% top,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
@media only screen and (max-width: 1440px) {
#riyu{
padding: 200px 10% 450px;
background: url(images/riyu-back3.webp) no-repeat center bottom/60%,url(images/riyu-back2.png) no-repeat 95% top,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 1280px) {
#riyu{
padding: 150px 5% 400px;
background: url(images/riyu-back3.webp) no-repeat center bottom/60%,url(images/riyu-back2.png) no-repeat 95% top/25%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 1080px) {
#riyu{
padding: 150px 5% 350px;
background: url(images/riyu-back3.webp) no-repeat center bottom/70%,url(images/riyu-back2.png) no-repeat 95% top/25%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 835px) {
#riyu{
padding: 150px 5% 300px;
background: url(images/riyu-back3.webp) no-repeat center bottom/80%,url(images/riyu-back2.png) no-repeat 95% top/25%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 640px) {
#riyu{
padding: 100px 5% 280px;
background: url(images/riyu-back3sm.webp) no-repeat center bottom/90%,url(images/riyu-back2.png) no-repeat 95% top/30%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 480px) {
#riyu{
padding: 100px 5% 280px;
background: url(images/riyu-back3sm2.webp) no-repeat center bottom/96%,url(images/riyu-back2.png) no-repeat 95% top/40%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}
@media only screen and (max-width: 414px) {
#riyu{
padding: 100px 5% 230px;
background: url(images/riyu-back3sm2.webp) no-repeat center bottom/96%,url(images/riyu-back2.png) no-repeat 95% top/40%,url(images/riyu-back.png) no-repeat left top/100%,#80915a;
}
}

#riyu h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0;
text-align: left;
font-weight: 800;
line-height: 110%;
font-size: 50px;
color: #fff;
}
#riyu h2 span{
font-size: 25px;
font-weight: 500;
line-height: 110%;
}
@media only screen and (max-width: 640px) {
#riyu h2{
margin: 0 0 40px;
font-size: 45px;
}
#riyu h2 span{
font-size: 20px;
}
}
@media only screen and (max-width: 480px) {
#riyu h2{
margin: 0 0 30px;
font-size: 40px;
}
}
@media only screen and (max-width: 414px) {
#riyu h2{
font-size: 35px;
}
}

main #riyu p{
color: #fff;
}

#riyu ol{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 50px 0 0;
padding: 0;
display: flex;
}
@media only screen and (max-width: 1080px) {
#riyu ol{
display:inherit;
}
}

#riyu li{
flex: 1;
margin: 0 2% 0 0;
padding: 40px 2% 35px;
background: #fff;
border-radius: 10px;
list-style-type: none;
text-align: center;
line-height: 200%;
font-size: 18px;
position: relative;
}
#riyu li strong{
font-weight: 800;
font-size: 30px;
}
#riyu li img{
position: absolute;
top:-20px;
left: 10px;
}
@media only screen and (max-width: 1080px) {
#riyu li{
margin: 0 0 40px;
}
#riyu li br{
display: none;
}
#riyu li strong{
margin: 0 1em 0 0;
}
}
@media only screen and (max-width: 640px) {
#riyu li br{
display:inherit;
}
#riyu li strong{
margin: 0;
}
}
@media only screen and (max-width: 480px) {
#riyu li{
padding: 30px 2% 25px;
}
}

#pro{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding:120px 10%;
background: url(images/pro-back.png) no-repeat 25% 150px;
}
@media only screen and (max-width: 1280px) {
#pro{
padding:120px 5%;
background: url(images/pro-back.png) no-repeat 35% 150px;
}
}
@media only screen and (max-width: 1080px) {
#pro{
padding:120px 5% 80px;
background: url(images/pro-back.png) no-repeat 55% 150px/90%;
}
}
@media only screen and (max-width: 835px) {
#pro{
padding:100px 5% 30px;
}
}
@media only screen and (max-width: 640px) {
#pro{
padding:80px 5% 30px;
background: url(images/pro-back.png) no-repeat 55% 120px/90%;
}
}
@media only screen and (max-width: 480px) {
#pro{
padding:80px 5% 10px;
background: url(images/pro-back.png) no-repeat 55% 120px/90%;
}
}

#pro-area{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 40px 0 0;
padding: 0;
display: flex;
}
.pro-box{
flex: 1;
margin: 0 5% 0 0;
}
.pro-box img{
max-width: 100%;
margin: 0 0 15px;
}
@media only screen and (max-width: 835px) {
#pro-area{
flex-wrap: wrap;
}
.pro-box{
flex-basis:45%;
margin: 0 5% 40px 0;
flex-grow: 0;
}
}
@media only screen and (max-width: 640px) {
.pro-box{
flex-basis:100%;
margin: 0 0% 40px 0;
}
}

.pro-box p{
margin: 0 0 30px;
text-align: justify;
}
.pro-box p span{
background: #80915a;
color: #fff;
font-size: 15px;
padding: 10px 15px;
line-height: 100%;
}

.pro-box h4{
clear: both;
float: left;
width: 100%;
font-size: 22px;
font-weight: 900;
line-height: 120%;
margin: 0 0 30px;
text-align: left;
}

.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; 
}

#photo-sub{
clear: both;
float: left;
width: 100%;
height: 350px;
margin: 0;
padding: 130px 15% 0;
background: url(images/photo-sub1.webp) no-repeat right center/auto 100%,#ccc;
}
#photo-sub.photo2{
background: url(images/photo-sub2.webp) no-repeat right center/auto 100%,#ccc;
}
#photo-sub.photo3{
background: url(images/photo-sub3.webp) no-repeat right center/auto 100%,#ccc;
}
@media only screen and (max-width: 1280px) {
#photo-sub{
padding: 130px 10% 0;
}
}
@media only screen and (max-width: 1080px) {
#photo-sub{
padding: 130px 5% 0;
}
}
@media only screen and (max-width: 835px) {
#photo-sub{
height: 300px;
padding: 100px 5% 0;
}
}
@media only screen and (max-width: 640px) {
#photo-sub{
height: 250px;
padding:0px 0% 0;
position: relative;
}
}

#photo-sub h1{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0 0 15px;
font-size: 40px;
font-weight: 700;
line-height: 100%;
color: #25443a;
text-align: left;
border-bottom: 1px solid #25443a;
}
@media only screen and (max-width: 640px) {
#photo-sub h1{
font-size: 35px;
padding: 15px 3% 15px;
background-color:rgba(37,68,58,0.7);
color: #fff;
border-bottom: none;
font-weight: 600;
position: absolute;
bottom:0;
}
}
@media only screen and (max-width: 480px) {
#photo-sub h1{
font-size: 30px;
}
}

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

#sub-page h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 10px 3%;
text-align: left;
font-size: 35px;
font-weight: 400;
line-height: 100%;
background: #80915a;
color: #fff;
border-left: 15px solid #25443a;
}
#sub-page h2 span{
font-size: 20px;
}
@media only screen and (max-width: 640px) {
#sub-page h2{
margin: 0 0 40px;
font-size: 30px;
}
#sub-page h2 span{
font-size: 16px;
}
}
@media only screen and (max-width: 480px) {
#sub-page h2{
margin: 0 0 30px;
font-size: 27px;
}
}

#sub-page h3{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 80px 0 40px;
padding: 0 0 15px;
text-align: left;
font-size: 35px;
font-weight: 600;
line-height: 100%;
color: #25443a;
border-bottom: 10px solid #25443a;
}
#sub-page h3 span{
font-size: 20px;
}
#sub-page h3.mtop{
margin: 0px 0 40px;
}
@media only screen and (max-width: 835px) {
#sub-page h3{
margin: 70px 0 40px;
font-size: 30px;
border-bottom: 8px solid #25443a;
}
}
@media only screen and (max-width: 640px) {
#sub-page h3{
margin: 60px 0 40px;
font-size: 25px;
border-bottom: 6px solid #25443a;
}
#sub-page h3 span{
font-size: 16px;
}
}

#sub-page h4{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 40px 0 40px;
padding: 15px 3%;
font-size: 20px;
font-weight: 600;
line-height: 120%;
background: #eee;
text-align: left;
}
@media only screen and (max-width: 640px) {
#sub-page h4{
margin: 40px 0 30px;
padding: 15px 3%;
font-size: 18px;
}
}
@media only screen and (max-width: 480px) {
#sub-page h4{
margin: 30px 0 20px;
padding: 15px 3%;
font-size: 17px;
}
}

#sub-page ul.item-ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 20px 5% 10px;
background: #eee;
border: 1px solid #aaa;
display: flex;
flex-wrap: wrap;
}
#sub-page ul.item-ul li{
flex: 1 0 auto;
margin: 0 5% 10px 0;
font-size: 16px;
flex-grow: 0;
}
@media only screen and (max-width: 835px) {
#sub-page ul.item-ul{
padding: 20px 8% 10px;
}
#sub-page ul.item-ul li{
margin: 0 8% 10px 0;
}
}
@media only screen and (max-width: 480px) {
#sub-page ul.item-ul{
padding: 15px 8% 5px;
}
#sub-page ul.item-ul li{
margin: 0 12% 10px 0;
}
}

#item1, #item2, #item3, #item4, #item5 {
scroll-margin-top: 150px;
}

#sub-page dl{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
display: flex;
flex-wrap: wrap;
}
#sub-page dt{
clear: both;
float: left;
width: 20%;
height: auto;
margin: 0 0 20px;
padding: 0 0 20px;
text-align: left;
font-size: 18px;
line-height: 130%;
border-bottom: 1px dashed #999;
}
#sub-page dd{
float: left;
width: 80%;
height: auto;
margin: 0 0 20px;
padding: 0 0 20px 5%;
text-align: left;
font-size: 18px;
line-height: 130%;
border-bottom: 1px dashed #999;
}
@media only screen and (max-width: 835px) {
#sub-page dt{
width: 25%;
}
#sub-page dd{
width: 75%;
}
}
@media only screen and (max-width: 640px) {
#sub-page dt{
width: 30%;
font-size: 17px;
margin: 0 0 15px;
padding: 0 0 15px;
}
#sub-page dd{
width: 70%;
font-size: 17px;
margin: 0 0 15px;
padding: 0 0 15px 5%;
}
}
@media only screen and (max-width: 480px) {
#sub-page dt{
clear: both;
float: left;
width: 100%;
font-size: 16px;
margin: 0 0 5px;
padding: 0;
border-bottom:none;
font-weight:700;
}
#sub-page dd{
clear: both;
float: left;
width: 100%;
font-size: 16px;
margin: 0 0 15px;
padding: 0 0 15px 0%;
}
}

#sub-page dl ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0 0 0 3%;
display: flex;
flex-wrap: wrap;
}
#sub-page dl li{
margin: 0 5% 10px 0;
padding: 0;
line-height: 130%;
text-align: left;
font-size:18px;
flex: 1 0 auto;
flex-grow: 0;
}
@media only screen and (max-width: 640px) {
#sub-page dl li{
font-size:17px;
}
}
@media only screen and (max-width: 480px) {
#sub-page dl ul{
padding: 0 0 0 5%;
}
#sub-page dl li{
font-size:16px;
margin: 0 5% 5px 0;
}
}

iframe{
clear: both;
float: left;
width: 100%;
height: 400px;
margin: 0 0 40px;
padding: 0;
}
@media only screen and (max-width: 640px) {
iframe{
height: 350px;
}
}
@media only screen and (max-width: 480px) {
iframe{
height: 300px;
margin: 0 0 30px;
}
}

.office{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
}
.office img{
max-width: 30%;
margin: 0 3.3% 0 0;
}
@media only screen and (max-width: 835px) {
.office img{
max-width: 48%;
margin: 0 2% 0 0;
}
}
@media only screen and (max-width: 480px) {
.office img{
max-width: 100%;
margin: 0;
}
}

.item{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 60px;
padding: 0;
}
@media only screen and (max-width: 1080px) {
.item{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 30px;
padding: 0;
}
}

.item-pict{
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
}
.item-pict img{
float: left;
max-width: 32%;
margin: 0 1.3% 15px 0;
}
@media only screen and (max-width: 835px) {
.item-pict img{
max-width: 48%;
margin: 0 2% 15px 0;
}
}
@media only screen and (max-width: 480px) {
.item-pict img{
max-width: 100%;
margin: 0 0% 15px 0;
}
}

.item-text{
clear: both;
float:left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
}
@media only screen and (max-width: 1080px) {
.item-pict{
float: left;
width: 100%;
height: auto;
margin: 0 0 0px;
}
}

table{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 40px;
padding: 0;
border-left: 1px solid #999;
border-top: 1px solid #999;
border-collapse:separate;
border-spacing:0px;
}
table th{
width: 15%;
background: #eee;
border-bottom: 1px solid #999;
border-right: 1px solid #999;
text-align: center;
font-size: 18px;
line-height: 130%;
padding: 10px;
font-weight: 400;
}
table td{
border-bottom: 1px solid #999;
border-right: 1px solid #999;
text-align: left;
font-size: 18px;
line-height: 130%;
padding: 10px;
}
@media only screen and (max-width: 835px) {
table th{
width: 20%;
}
}
@media only screen and (max-width: 640px) {
table th{
width: 25%;
font-size: 17px;
}
table td{
font-size: 17px;
}
#mail table th{
width: 30%;
font-size: 16px;
}
#mail table td{
font-size: 16px;
}
}
@media only screen and (max-width: 480px) {
table th{
font-size: 16px;
}
table td{
font-size: 16px;
}
#mail table th{
clear: both;
float: left;
width: 100%;
text-align: left;
}
#mail table td{
clear: both;
float: left;
width: 100%;
}
}

#mail{
}
#mail p{
text-align: left;
margin: 0 0 50px;
}

textarea,input[type="text"] ,input[type="email"]{
width: 100%;
}
input[type="text"].s70{
width: 75%;
}
select{
width: 20%;
margin: 0 2% 0 0;
}
@media only screen and (max-width: 640px) {
textarea,input[type="text"] ,input[type="email"]{
width: 100%;
line-height: 150%;
}
input[type="text"].s70{
width: 100%;
margin: 5px 0 0;
}
select{
width: 23%;
margin: 0 2% 0 0;
}
select.s30{
width: 35%;
margin: 0 2% 0 0;
}
}
@media only screen and (max-width: 480px) {
textarea,input[type="text"] ,input[type="email"]{
width: 100%;
padding: 5px;
}
textarea{
font-size: 14px;
}
}

input.btn_submit,input.btn_submit2{
 width:30%;
 height:50px;
 background: #fcaa2b;
 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:20%;
 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:35%;
}
input.btn_submit2{
 width:25%;
}
}
@media only screen and (max-width: 480px) {
input.btn_submit,input.btn_submit2{
 width:45%;
}
input.btn_submit2{
 width:35%;
}
}

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

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

form strong{
color: #ef3876;
}
label{
 cursor: pointer;
}

form{
clear: both;
width:100%;
height: auto;
margin: 0 auto;
padding: 0;
text-align: center;
}

.hissu{
font-size: 12px;
border-radius: 5px;
background: #80915a;
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;
}
@media only screen and (max-width: 640px) {
#mail-check{
	clear:both;
	float:left;
	width:100%;
	height:auto;
	margin:0 0 50px;
	padding:0;
	text-align:center;
}
}

#mail-title{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 30px 0 40px;
padding: 30px 0;
border-top:2px solid #80915a;
border-bottom:2px solid #80915a;
}
#mail-title h2{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
text-align: center;
font-size: 30px;
font-weight: 600;
line-height: 100%;
color: #80915a;
background: none;
border-left: none;
}
@media only screen and (max-width: 1080px) {
#mail-title{
margin: 30px 0 30px;
padding: 20px 0;
}
#mail-title h2{
font-size: 25px;
}
}
@media only screen and (max-width: 640px) {
#mail-title h2{
line-height: 120%;
}
}

#mail-ok{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 60px;
padding: 0;
}
@media only screen and (max-width: 640px) {
#mail-ok{
margin: 0 0 40px;
}
}
@media only screen and (max-width: 480px) {
#mail-ok{
margin: 0 0 20px;
}
}

/*フッタ
--------------------------------------------------------------------------*/
#page-top{
	width:40px;
	height:40px;
	display:none;
	position:fixed;
	right:16px;
	bottom:16px;
	color:#fff;
}
@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:65px;
}
}
@media only screen and (max-width: 480px) {
#page-top{
	width:35px;
	height:35px;
	right:10px;
	bottom:65px;
}
}
 
#page-top p{
	margin:0;
	padding:0;
	text-align:center;
	background:#25443a;
	transition:all 0.3s;
	color:#fff;
} 
#page-top p:hover{
	background:#fcaa2b;
	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;
}
}

#toi{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 60px 10% 60px 40%;
background: url(images/toi-back.webp) no-repeat left top/contain,#f5f6f6;
}
@media only screen and (max-width: 1280px) {
#toi{
padding: 50px 5% 50px 35%;
background: url(images/toi-back.webp) no-repeat left top/contain,#f5f6f6;
}
}
@media only screen and (max-width: 835px) {
#toi{
padding: 50px 5% 50px 40%;
background: url(images/toi-back.webp) no-repeat left top/contain,#f5f6f6;
}
}
@media only screen and (max-width: 640px) {
#toi{
padding: 40px 5% 40px 5%;
background: url(images/toi-back-sm.webp) no-repeat right top/contain,#f5f6f6;
}
}
@media only screen and (max-width: 480px) {
#toi{
padding: 30px 5% 30px 5%;
background: url(images/toi-back-sm.webp) no-repeat right top/contain,#f5f6f6;
}
}

#toi h5{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 50px;
padding: 0;
text-align: left;
font-weight: 800;
line-height: 110%;
font-size: 40px;
color: #4e6b5e;
}
#toi h5 span{
font-size: 25px;
font-weight: 500;
line-height: 110%;
}
#toi p{
text-align: left;
font-size: 18px;
line-height: 200%;
margin: 0;
}
@media only screen and (max-width: 835px) {
#toi h5{
margin: 0 0 40px;
font-size: 35px;
}
#toi h5 span{
font-size: 20px;
}
#toi p{
line-height: 150%;
}
}
@media only screen and (max-width: 640px) {
#toi h5{
margin: 0 0 30px;
font-size: 30px;
}
}
@media only screen and (max-width: 480px) {
#toi h5{
text-shadow: 2px 2px 2px #fff;
}
#toi p{
text-shadow: 2px 2px 2px #fff;
font-size: 16px;
}
}

#toi a{
display: block;
float: left;
width: 35%;
background: url(images/tel.png) no-repeat 14% 50%/auto 30px,#80915a;
border-left: none;
font-size: 25px;
margin: 30px 2% 0 0;
border-radius: 50px;
font-weight: 600;
text-indent: 1em;
color: #fff;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 18% 60%/auto 23px,#fcaa2b;
border-left: none;
font-size: 22px;
border-radius: 50px;
text-indent: 1em;
}
#toi a:link,#toi a:visited{
display: block;
padding: 10px 0;
text-decoration: none;
}
#toi a:hover{
text-decoration: underline;
}
#toi a strong{
font-weight: 600;
}
#toi a span{
display: none;
}
@media only screen and (max-width: 1600px) {
#toi a{
width: 40%;
}
}
@media only screen and (max-width: 1080px) {
#toi a{
width: 48%;
background: url(images/tel.png) no-repeat 9% 50%/auto 30px,#80915a;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 10% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 835px) {
#toi a{
width: 50%;
margin: 0;
background: url(images/tel.png) no-repeat 24% 60%/auto 30px,#25443a;
position: fixed;
bottom:0;
left: 0;
border-radius: 0;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 34% 60%/auto 23px,#fcaa2b;
position: fixed;
bottom:0;
left: inherit;
right: 0;
border-radius: 0;
}
#toi a strong{
display: none;
}
#toi a span{
display: inherit;
}
}
@media only screen and (max-width: 640px) {
#toi a{
background: url(images/tel.png) no-repeat 12% 60%/auto 30px,#25443a;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 25% 60%/auto 23px,#fcaa2b;
}
}
@media only screen and (max-width: 480px) {
#toi a{
background: url(images/tel.png) no-repeat 7% 60%/auto 30px,#25443a;
font-size: 20px;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 22% 60%/auto 23px,#fcaa2b;
font-size: 20px;
}
}
@media only screen and (max-width: 414px) {
#toi a{
background: url(images/tel.png) no-repeat 6% 60%/auto 30px,#25443a;
}
#toi a.bno{
background: url(images/mail.png) no-repeat 18% 60%/auto 23px,#fcaa2b;
}
}

footer{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 40px 10%;
background: #80915a;
}
@media only screen and (max-width: 1080px) {
footer{
padding: 30px 5%;
}
}
@media only screen and (max-width: 835px) {
footer{
padding: 30px 5% 80px;
}
}
@media only screen and (max-width: 640px) {
footer{
padding: 20px 5% 70px;
}
}
@media only screen and (max-width: 480px) {
footer{
padding: 15px 5% 60px;
}
}

address{
clear: both;
float: left;
width: 30%;
height: auto;
margin: 0;
padding: 0;
text-align: left;
line-height: 150%;
font-style: normal;
font-size: 17px;
color: #fff;
}
address h6{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0 0 20px;
padding: 0;
font-weight: 800;
line-height: 100%;
font-size: 25px;
text-align: left;
}
address p{
text-align: left;
font-size: 17px;
line-height: 120%;
margin: 0;
}
@media only screen and (max-width: 1080px) {
address{
width: 100%;
}
address h6{
text-align: center;
}
address p{
text-align: center;
font-size: 16px;
}
}
@media only screen and (max-width: 640px) {
address h6{
margin: 0 0 10px;
}
}
@media only screen and (max-width: 480px) {
address h6{
font-size: 20px;
}
address p{
font-size: 15px;
}
}

nav{
float: right;
width: 70%;
height: auto;
margin: 0;
padding: 0;
}
nav ul{
clear: both;
float: left;
width: 100%;
height: auto;
margin: 0;
padding: 0;
display: flex;
justify-content:flex-end;
}
nav li{
list-style-type: none;
margin: 0 0 0 5%;
font-size: 17px;
line-height: 100%;
color: #fff;
}
nav li a:link,nav li a:visited{
text-decoration: none;
color: #fff;
}
nav li a:hover{
text-decoration: underline;
}
@media only screen and (max-width: 1080px) {
nav{
display: none;
}
}
