@charset "utf-8";

/*---wrapper---*/

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


/*--header---*/

#header_pc {
width: 100%;
background: #fff;
padding: 10px 0;
}

#header_pc ul.navarea {
width: 85%;
margin: 0 auto;
}

.fixed {
position: fixed;
top: 0;
width: 100%;
z-index: 9999999;
box-shadow: 0px 3px 15px rgba(0,0,0,0.2);
}

#header_pc ul.navarea li.leftbox {
float: left;
width: 20%;
padding-top: 5px;
}

#header_pc ul.navarea li.rightbox {
float: right;
width: 75%;
}

#header_pc ul.navarea li.rightbox ul#gnav {
width: 100%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc {
width: 100%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu {
list-style-type: none;
padding: 0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li {
position: relative;
width: 14.2%;
float: left;
margin: 0;
padding: 0;
text-align: center;
} 

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li a {
display: block;
margin: 0;
padding: 16px 0;
font-size: 0.94em;
font-weight: 700;
line-height: 1;
letter-spacing: 0.03em;
text-decoration: none;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li p {
display: block;
margin: 0;
padding: 16px 0;
font-size: 0.94em;
font-weight: 700;
line-height: 1;
letter-spacing: 0.03em;
text-decoration: none;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li ul {
list-style: none;
position: absolute;
z-index: 100;
top: 100%;
left: 0;
width: 100%;
margin: 0;
padding: 0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li ul li {
overflow: hidden;
width: 100%;
height: 0;
background: #212121;
transition: .2s;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li ul li a {
padding: 18px 6px;
color: #fff;
opacity: 1.0;
text-align: left;
line-height: 140%;
font-size: 0.7em;
font-weight: bold;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu > li:hover > a {
opacity: 1.0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu > li:hover li:hover > a {
background: #434343;
opacity: 0.8;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li:hover > ul > li {
overflow: visible;
height: 51px;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li ul li ul {
top: 0;
left: 100%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li:last-child ul li ul {
left: -100%;
width: 100%;
}

#header_pc ul.navareao li.rightbox ul#gnav #nav_pc #dropmenu li ul li ul li a {
background: #444;
opacity: 0.8;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li:hover ul li ul li:hover > a {
background: #666;
opacity: 0.8;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng {
width: 100%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu {
list-style-type: none;
padding: 0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li {
position: relative;
width: 25%;
float: left;
margin: 0;
padding: 0;
text-align: center;
} 

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li a {
display: block;
margin: 0;
padding: 16px 0;
font-size: 14px;
font-weight: 600;
line-height: 1;
letter-spacing: 0.09em;
text-decoration: none;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li ul {
list-style: none;
position: absolute;
z-index: 100;
top: 100%;
left: 0;
width: 100%;
margin: 0;
padding: 0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li ul li {
overflow: hidden;
width: 100%;
height: 0;
background: #212121;
transition: .2s;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li ul li a {
padding: 18px 6px;
color: #fff;
opacity: 1.0;
text-align: left;
line-height: 140%;
font-size: 0.7em;
font-weight: bold;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu > li:hover > a {
opacity:1.0;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu > li:hover li:hover > a {
background: #fbaaac;
opacity: 0.8;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li:hover > ul > li {
overflow: visible;
height: 51px;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li ul li ul {
top: 0;
left: 100%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li:last-child ul li ul {
left: -100%;
width: 100%;
}

#header_pc ul.navareao li.rightbox ul#gnav #nav_pc_eng #dropmenu li ul li ul li a {
background: #444;
opacity: 0.8;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc_eng #dropmenu li:hover ul li ul li:hover > a {
background: #666;
opacity: 0.8;
}

@media only screen and (max-width: 1500px) {
#header_pc ul.navarea {
width: 90%;
}

#header_pc ul.navarea li.leftbox {
width: 15%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li a {
font-size: 0.90em;
}
}
	
@media only screen and (max-width: 1300px) {
#header_pc ul.navarea {
width: 95%;
}

#header_pc ul.navarea li.leftbox {
margin-top: 3px;
}

#header_pc ul.navarea li.leftbox {
width: 13%;
}

#header_pc ul.navarea li.rightbox {
width: 80%;
}

#header_pc ul.navarea li.rightbox ul#gnav #nav_pc #dropmenu li a {
font-size: 0.75em;
font-weight: 700;
letter-spacing: 0.02em;
}
}

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



/*---spnavi---*/

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

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



/*----mainimg---*/
	
#mainslide {
width: 95%;
margin: 0 auto;
padding-bottom: 100px;
}

#mainslide .copy {
width: 38%;
float: left;
}

#mainslide .copy li.logo {
margin: 180px auto 0 auto;
width: 70%;
}

#mainslide .copy li.txt {
margin: 40px 0 0 0;
}

#mainslide .copy li.txt p {
font-size: 15px;
line-height: 220%;
}

#mainslide .mainimg {
float: right;
width: 60%;
}

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

@media only screen and ( max-width : 850px ) {
#mainslide {
width: 95%;
}

#mainslide .copy {
width: 90%;
float: none;
margin: 0 auto;
}

#mainslide .copy li.logo {
margin: 30px auto 0 auto;
width: 70%;
}

#mainslide .copy li.txt {
margin: 40px 0 0 0;
}

#mainslide .copy li.txt p {
font-size: 15px;
line-height: 200%;
}

#mainslide .mainimg {
float: none;
width: 100%;
margin-bottom: 15px;
}
}



/*---underimg---*/

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

.undertitle ul.title h2 {
font-size: 30px;
color: #fff;
text-shadow: 0 0 4px #0F0F0F;
letter-spacing: 0.1em;
padding-top: 250px;
}

#undermainimg {
width: 100%;
height: 470px;
position: relative;
overflow: hidden;
margin-bottom: 48px;
}

.unimg_abo {
background: url("../images/untitbg/titimg_abo.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_rec {
background: url("../images/untitbg/titimg_rec.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_new {
background: url("../images/untitbg/titimg_new.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_com {
background: url("../images/untitbg/titimg_com.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_qua {
background: url("../images/untitbg/titimg_qua.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_fac {
background: url("../images/untitbg/titimg_fac.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_sho {
background: url("../images/untitbg/titimg_sho.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_con {
background: url("../images/untitbg/titimg_con.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

.unimg_pro {
background: url("../images/untitbg/titimg_pro.jpg")no-repeat;
background-size: cover;
background-position: center center;
}

@media only screen and (max-width: 850px) {
.undertitle ul.title {
max-width: 85%;
}

.undertitle ul.title h2 {
font-size: 23px;
padding-top: 75px;
}

#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 {
font-size: 30px;
text-align: center;
margin-bottom: 30px;
}

h3.mt01::first-letter {
font-size: 42px;
color: #661e6e;
}

h4 {
display: flex;
justify-content: center;
align-items: center;
font-size: 28px;
text-align: center;
margin-bottom: 40px;
}

h4::before,
h4::after {
content: '';
width: 70px;
height: 3px;
background-color: #C4C4C4;
}

h4::before {
margin-right: 20px;
}

h4::after {
margin-left: 20px;
}

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

h3.mt01::first-letter {
font-size: 32px;
}

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



/*---pagetop---*/

#page-top a {
display: flex;
justify-content: center;
align-items :center;
background: #1a1a1a;
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);
}
}



/*---fixbt---*/

ul.ftfixbt {
position: fixed;
bottom: 0;
left: 0;
width: 100%;
-webkit-transition: all 0.5s;
transition: all 0.5s;
}

ul.ftfixbt li {
float: left;
width: 50%;
}

ul.ftfixbt li img {
width: 100%;
max-width: 100%;
}


ul.ftfixbt li a:hover{
opacity: 1.0;
}

ul.ftfixbt.js_hide {
transform: translateY(100%);
}



/*---footer---*/

#footer {
width: 100%;
}

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

#footer .footerbox ul.infobox {
width: 100%;
margin: 0 auto;
text-align: center;
padding: 2% 0 4% 0;
}

#footer .footerbox ul.infobox h1 {
font-size: 11px;
padding-bottom: 8px;
}

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

#footer .footerbox ul.ftnavi {
width: 98%;
margin: 0 auto;
padding-bottom: 1%;
}

#footer .footerbox ul.ftnavi li {
position: relative;
width: 25%;
float: left;
margin: 0;
padding: 0;
text-align: center;
}

#footer .footerbox ul.ftnavi p {
font-size: 14px;
}

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

#footer ul.copy {
margin-top: 4%;
width: 100%;
font-weight: 500;
padding: 3.0% 0;
font-size: 12px;
letter-spacing: 0.03em;
text-align: center;
background: #661E6F;
color: #fff;
}

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

#footer .footerbox ul.ftnavi {
width: 100%;
}
}

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

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

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

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

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