@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: 75%;
margin: 0 auto;
}

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

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

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: 14%;
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-weight: 600;
font-size: 15px;
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: #2F2F2F;
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.4em;
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: #5C5C5C;
}

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

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: 14%;
background: #e60214;
float: left;
margin: 0;
padding: 0;
text-align: center;
} 

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

@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: 21px;
padding: 0 0 0 10px;
}

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



/*---mainimg---*/
	
ul.mainimg_pc {
margin-bottom: 55px;
}

ul.mainimg_pc li {
background-repeat: no-repeat;
background-size: cover;
background-position: center center;
height: 100vh;
margin: 0;
}

ul.mainimg_pc li.img01 {
background-image: url(../images/top/mainimg01.jpg);
}

ul.mainimg_pc li.img_recruit {
background-image: url("../images/recruit/mainimg_recruit.jpg");
}

#mainimg_sp {
clear: both;
display: none;
margin-bottom: 45px;
}

#mainimg_sp img  {
width: 100%;
max-width: 100%;
}

@media only screen and ( max-width : 850px ) {
ul.mainimg_pc {
display: none;
}
	
#mainimg_sp {
display: block;
}
}

/*---scrolldown---*/

.scrolldown {
position: absolute;
bottom: 10px;
left: 50%;
}

.scrolldown span {
position: absolute;
left: 7px;
bottom: 3px;
color: #fff;
word-break: keep-all;
font-family: 'Cormorant Infant', serif;
font-weight: 600;
font-size: 0.9rem;
text-shadow: 0 0 2px #000;
letter-spacing: 0.1em;
-ms-writing-mode: tb-rl;
-webkit-writing-mode: vertical-rl;
writing-mode: vertical-rl;
}

.scrolldown:before {
content: "";
position: absolute;
bottom: 0;
left: -4px;
width: 10px;
height: 10px;
border-radius: 50%;
background: #fff;
animation:
circlemove 1.7s ease-in-out infinite,
cirlemovehide 1.7s ease-out infinite;
}

@keyframes circlemove{
0%{bottom:45px;}
100%{bottom:-5px;}
}

@keyframes cirlemovehide{
0%{opacity:0}
50%{opacity:1;}
80%{opacity:0.9;}
100%{opacity:0;}
}

.scrolldown:after {
content:"";
position: absolute;
bottom: 0;
left: 0;
width: 2px;
height: 50px;
background: #fff;
}



/*---underimg---*/

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

.undertitle ul.title h2 {
font-size: 40px;
color: #fff;
font-family: 'Montserrat', sans-serif;
text-shadow: 0 0 4px #090909;
letter-spacing: 0.06em;
padding-top: 213px;
}

.undertitle ul.title h2 .jp {
font-size: 16px;
color: #fff;
font-weight: 600;
text-shadow: 0 0 4px #090909;
letter-spacing: 0.06em;
}

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

.unimg_faq{
background:  url("../images/untitbg/untitbg_faq.jpg")no-repeat;
background-size: cover;
}

@media only screen and (max-width: 900px) {
.undertitle ul.title h2 {
font-size: 23px;
padding-top: 90px;
}

.undertitle ul.title h2 .jp {
font-size: 14px;
}

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



/*---contents---*/

#contents {
width: 100%;
max-width: 70%;
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-weight: 500;
margin-bottom: 32px;
font-size: 32px;
padding-left: 0.5em;
border-left: solid 3px #e50113;
}

h3.mt01 .en {
font-size: 14px;
letter-spacing: 0.09em;
color: #e50113;
font-family: 'Montserrat', sans-serif;
display: block;
font-weight: 600;
padding-left: 0.13em;
}

h3.mt_top_r {
font-weight: 600;
font-size: 36px;
color: #e50113;
font-family: 'Montserrat', sans-serif;
text-align: center;
margin-bottom: 35px;
letter-spacing: 0.03em;
}

h3.mt_top_r .jp {
margin-top: -2px;
color: #464646;
font-weight: 500;
font-size: 13px;
text-align: center;
letter-spacing: 0.03em;
}

h3.mt_top_b {
font-weight: 600;
font-size: 36px;
color: #132880;
font-family: 'Montserrat', sans-serif;
text-align: center;
margin-bottom: 35px;
letter-spacing: 0.03em;
}

h3.mt_top_b .jp {
margin-top: -2px;
color: #545454;
font-size: 13px;
text-align: center;
letter-spacing: 0.03em;
}

h3.mt_top_w {
font-weight: 600;
font-size: 36px;
color: #fff;
font-family: 'Montserrat', sans-serif;
margin-bottom: 35px;
letter-spacing: 0.03em;
}

h3.mt_top_w .jp {
margin-top: -2px;
color: #fff;
font-size: 13px;
letter-spacing: 0.03em;
}

h4 {
font-size: 24px;
color: #e50113;
letter-spacing: 0.06em;
padding-bottom: 8px;
margin-bottom: 14px;
}

h4 hr {
border-bottom: 4px double #DFAD00;
width: 40%;
padding-top: 5px;
margin: 0 auto;
}

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

h3.mt01 .en {
font-size: 11px;
}

h3.mt_top_r {
margin-bottom: 32px;
font-size: 30px;
}

h3.mt_top_r .jp {
margin-top: -2px;
font-size: 12px;
}

h3.mt_top_b {
margin-bottom: 32px;
font-size: 30px;
}

h3.mt_top_b .jp {
margin-top: -2px;
font-size: 12px;
}

h3.mt_top_w {
margin-bottom: 32px;
font-size: 30px;
}

h3.mt_top_w .jp {
margin-top: -2px;
font-size: 12px;
}

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


/*---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);
}
}



/*---contactarea---*/

#contactarea_outer {
background: #FACCD0;
border-bottom: 4px solid #e50113;
}

ul#contactarea {
background: #e50113;
padding: 5% 0;
clip-path: circle(77.2% at 28% 0);
}

ul#contactarea li.catch {
margin-bottom: 10px;
}

ul#contactarea li.catch p{
color: #fff;
font-size: 28px;
line-height: 140%;
}

ul#contactarea li.tel {
margin-bottom: 5px;
}

ul#contactarea li.tel p {
color: #fff;
font-family: 'Montserrat', sans-serif;
font-size: 40px;
font-weight: 600;
}

ul#contactarea li.tel p a {
color: #fff;
font-size: 40px;
text-decoration: none;
}

ul#contactarea li.time {
margin-bottom: 20px;
}

ul#contactarea li.time p {
color: #fff;
font-size: 15px;
font-weight: 600;
}

@media only screen and (max-width: 850px) {
ul#contactarea {
padding: 5% 0;
clip-path: circle(77.2% at 34% 22%);
}

ul#contactarea li.catch {
margin-bottom: 10px;
}

ul#contactarea li.catch p {
font-size: 14px;
font-weight: 600;
}

ul#contactarea li.tel p {
font-size: 20px;
}

ul#contactarea li.tel p a {
font-size: 20px;
}

ul#contactarea li.time p {
font-size: 13px;
}
}



/*---footer---*/

#footer {
width: 100%;
background-size: 10px 10px;
}

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

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

#footer .footerbox ul.infobox h1 {
font-size: 10px;
letter-spacing: 0.08em;
padding-bottom: 12px;
}

#footer .footerbox ul.infobox p.address {
line-height: 145%;
font-size: 12px;
letter-spacing: 0.08em;
padding: 17px 0 10px 0;
}

#footer .footerbox ul.infobox p a {
font-size: 14px;
letter-spacing: 0.08em;
text-decoration: none;
}

#footer .footerbox ul.ftnavi {
float: right;
padding: 25px 0 2% 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: 500;
letter-spacing: 0.08em;
}

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

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

@media only screen and ( max-width : 1200px ) {
#footer .footerbox {
width: 100%;
max-width: 90%;
}
}

@media only screen and (max-width: 850px) {
#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;
}
}
