@charset "utf-8";

/*---------wrapper---------*/

#wrapper {
width: 100%;
margin: 0 auto;
z-index: 600;
overflow: hidden;
}

/*---------header---------*/

header {
width: 100%;
position: relative;
}

header #navout {
width: 100%;
left: 0;
right: 0;
margin: auto;
position: absolute;
z-index: 999999;
background: #fff;
}

header ul.navarea {
max-width: 80%;
margin: 0 auto;
}

header ul.navarea li.logobox {
float: left;
padding-top: 16px;
width: 25%;
}

header ul.navarea li.navbox {
float: right;
width: 72%;
}

header ul.navarea li.navbox #nav {
width: 100%;
}

header ul.navarea li.navbox #nav #dropmenu {
list-style-type: none;
padding: 0;
}

header ul.navarea li.navbox #nav #dropmenu li.menu {
position: relative;
width: 25%;
float: left;
margin: 0;
padding: 0;
text-align: center;
} 

header ul.navarea li.navbox #nav #dropmenu li.menu a {
display: block;
margin: 0;
padding: 25px 0;
font-size: 15px;
color: #303030;
line-height: 1;
letter-spacing: 0.1em;
text-decoration: none;
}

header ul.navarea li.navbox #nav #dropmenu li.menu ul {
list-style: none;
width: 100%;
position: absolute;
z-index: 100;
top: 100%;
left: 0;
margin: 0;
padding: 0;
}

header ul.navarea li.navbox #nav #dropmenu li.menu ul li {
overflow: hidden;
width: 100%;
height: 0;
background: #367692;
opacity: 0.9;
transition: .2s;
}

header ul.navarea li.navbox #nav #dropmenu li.menu ul li a {
padding: 19px 6px;
color: #fff;
opacity: 1.0;
text-align: left;
line-height: 140%;
font-size: 0.7em;
letter-spacing: 0.05em;
}

header ul.navarea li.navbox #nav #dropmenu > li.menu:hover > a {
opacity: 0.6;
}

header ul.navarea li.navbox #nav #dropmenu > li.menu:hover li:hover > a {
background: #538aa1;
}

header ul.navarea li.navbox #nav #dropmenu li.menu:hover > ul > li {
overflow: visible;
height: 55px;
}

header ul.navarea li.navbox #nav #dropmenu li.menu ul li ul {
top: 0;
left: 100%;
}

header ul.navarea li.navbox #nav #dropmenu li:last-child ul li ul {
left: -100%;
width: 100%;
}

header ul.navarea li.navbox #nav #dropmenu li.menu ul li ul li a {
background: #444;
opacity: 0.8;
}

header ul.navarea li.navbox #nav #dropmenu li.menu:hover ul li ul li:hover > a {
background: #666;
opacity: 0.8;
}

header ul.navarea li.navbox #nav #dropmenu li.tel {
position: relative;
width: 25%;
float: left;
margin: 0;
padding: 0;
text-align: center;
} 

header ul.navarea li.navbox #nav #dropmenu li.tel p {
font-size: 17px;
letter-spacing: 0.05em;
padding-top: 18px;
text-align: center;
font-family: 'Montserrat', sans-serif;
} 

@media only screen and (max-width: 1200px) {
header ul.navarea {
max-width: 98%;
}

header ul.navarea li.logobox {
width: 21%;
}

header ul.navarea li.navbox {
width: 76%;
}

header ul.navarea li.navbox #nav #dropmenu li.menu a {
padding: 25px 0;
font-size: 13px;
letter-spacing: 0.05em;
}

header ul.navarea li.navbox #nav #dropmenu li.tel p {
font-size: 14px;
padding-top: 18px;
} 
}

@media only screen and (max-width: 900px) {
header {
display: none;
}
}


/*---------spnavi---------*/

#spnavi {
display: none;
overflow: hidden;
}

#splogo {
position: absolute;
top: 26px;
padding: 0 0 0 10px;
}

#spsnsbt {
position: absolute;
top: 23px;
right: 55px;
}


/*---------mainimg---------*/
	
.mainimg {
display: block;
clear: both;
margin-bottom: 18px;
}

.mainimg img  {
width: 100%;
max-width: 100%;
}


/*---------underimg---------*/

.undertitle ul.title {
width: 100%;
max-width: 75%;
margin: 0 auto;
}

.undertitle ul.title h2 {
font-size: 34px;
color: #fff;
text-shadow: 0 0 4px #3d6547;
text-align:  center;
letter-spacing: 0.06em;
padding-top: 175px;
}

#undermainimg .sub {
font-size: 14px;
text-shadow: 0 0 4px #3d6547;
text-align:  center;
letter-spacing: 0.1em;
font-family: 'Montserrat', sans-serif;
color: #fff;
margin-top: -4px;
}

#undermainimg {
position: relative;
background: rgb(25,81,158);
background: linear-gradient(180deg, rgba(25,81,158,0.8855917366946778) 0%, rgba(25,81,158,1) 100%);
height: 320px;
width: 100%;
margin-bottom: 30px;
transition-property: height;
transition-duration: 0.35s;
}

@media only screen and ( max-width : 1200px ) {
undertitle ul.title h2 {
padding-top: 15px;
}

#undermainimg {
height: 320px;
}
}
	
@media only screen and (max-width: 900px) {
.undertitle ul.title h2 {
font-size: 27px;
padding-top: 65px;
}

#undermainimg .sub {
font-size: 13px;
}

#undermainimg {
height: 170px;
background-position: 50% center;
padding-top: 0px;
margin-bottom: 27px;
}
}


/*---------contents---------*/

#contents {
width: 100%;
max-width: 75%;
margin: 0 auto 40px auto;
box-sizing: border-box;
}

@media only screen and (max-width: 1200px) {
#contents {
max-width: 100%;
padding: 0 3%;
}
}


/*---------title---------*/

h3.mt01 {
padding: 0.4% 0.5%;
border-bottom: solid .125em #D5DBE3;
font-size: 29px;
letter-spacing: 0.06em;
margin-bottom: 20px;
position: relative;
}

h3.mt01::after {
position: absolute;
content: '';
display: block;
left: 0;
bottom: -.120em ;
border-bottom: .125em solid #19519E;
width: 10%;
height: 100%;
}

h3.mt02 {
font-size: 40px;
font-weight: 400;
color: #19519e;
font-family: 'Montserrat', sans-serif;
letter-spacing: 0.05em;
text-align: center;
margin-bottom: 40px;
line-height: 140%;
}

h3 .jp {
font-family: 'Montserrat', "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, Verdana, Arial, Helvetica,"ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
text-align: center;
margin-bottom: 10px;
letter-spacing: 0.06em;
}

h4 {
font-size: 20px;
background: #19519e;
color:#fff;
border-radius: 4px;
letter-spacing: 0.06em;
padding: 10px 10px 8px 10px;
margin-bottom: 20px;
}

@media only screen and (max-width: 850px) {
h3.mt01 {
margin-bottom: 30px;
font-size: 26px;
}

h3.mt01 hr {
width: 60%;
}

h3.mt02 {
font-size: 30px;
padding: 5px 5px 7px 8px;
margin-bottom: 20px;
}

h3 .jp {
font-size: 14px;
}

h4 {
margin-bottom: 10px;
font-size: 18px;
}

h5 {
font-size: 17px;
padding: 1.8%;
}
}


/*---------pagetop---------*/

#page-top a {
display: flex;
justify-content: center;
align-items :center;
background: #222;
border-radius: 2px;
width: 48px;
height: 48px;
color: #fff;
text-align: center;
text-transform: uppercase; 
text-decoration: none;
letter-spacing: 0.1em;
font-family: 'Montserrat', sans-serif;
transition:all 0.3s;
opacity: 0.9;
}

#page-top a:hover {
opacity: 0.6;
}

#page-top {
position: fixed;
right: 10px;
bottom: 20px;
z-index: 2;
opacity: 0;
transform: translateY(100px);
}

#page-top.UpMove {
animation: UpAnime 0.5s forwards;
}

@keyframes UpAnime{
from {
opacity: 0;
transform: translateY(100px);
}

to {
opacity: 1;
transform: translateY(0);
}
}

#page-top.DownMove{
animation: DownAnime 0.5s forwards;
}

@keyframes DownAnime{
from {
opacity: 1;
transform: translateY(0);
}

to {
opacity: 1;
transform: translateY(100px);
}
}


/*---------footer---------*/

#footer {
width: 100%;
background: #19519E;
}

#footer .footerbox {
width: 100%;
max-width: 75%;
margin: 0 auto;
}

#footer .footerbox ul.infobox {
float: left;
width: 50%;
padding: 2% 0;
}

#footer .footerbox ul.infobox h1 {
color: #fff;
font-size: 11px;
letter-spacing: 0.08em;
padding-bottom: 8px;
}

#footer .footerbox ul.infobox p {
font-size: 14px;
line-height: 120%;
margin: 10px 0;
color: #fff;
}

#footer .footerbox ul.infobox p a {
font-size: 14px;
color: #fff;
text-decoration: none;
}

#footer .footerbox ul.infobox .ftlogo {
padding-bottom: 12px;
}

#footer .footerbox ul.copy {
clear: both;
width: 100%;
padding: 2% 0;
font-size: 13px;
font-weight: 500;
color: #fff;
letter-spacing: 0.07em;
font-family: 'Montserrat', sans-serif;
text-align: center;
}

#footer .footerbox ul.ftnavi {
float: right;
width: 25%;
padding: 3% 0;
}

#footer .footerbox ul.ftnavi li {
float: left;
margin-right: 30px;
}

#footer .footerbox ul.ftnavi li p {
line-height: 250%;
font-size: 14px;
font-weight: bold;
color: #fff;
letter-spacing: 0.08em;
}

#footer .footerbox ul.ftnavi li p a {
font-size: 14px;
font-weight: bold;
color: #fff;
text-decoration: none;
}

@media only screen and ( max-width : 1200px ) {
#footer .footerbox {
width: 98%;
margin: 0 auto;
}

#footer .footerbox ul.ftnavi {
width: 35%;
padding: 5% 0 3% 0;
}
}

@media only screen and (max-width: 900px) {
#footer {
text-align: center;
padding: 3% 0;
}

#footer .footerbox {
width: 100%;
max-width: 95%;
margin: 0 auto;
}

#footer .footerbox ul.infobox {
width: 97%;
margin: 0 auto;
}

#footer .footerbox ul.infobox h1 {
	display: none;
}

#footer .footerbox ul.ftnavi {
display: none;
}

#footer .footerbox ul.infobox li.copy {
padding: 2% 0;
}
}