@charset "UTF-8";
/* CSS Document */

@font-face { font-family: 'Noto Serif Japanese Light'; src: url('../fonts/NotoSerifJpLight.woff2') format('woff'); font-style: normal; font-weight: 300; }
@font-face { font-family: 'Noto Serif Japanese Regular'; src: url('../fonts/NotoSerifJpRegular.woff2') format('woff'); font-style: normal; font-weight: 400; }
@font-face { font-family: 'Noto Serif Japanese Bold'; src: url('../fonts/NotoSerifJpBold.woff2') format('woff'); font-style: normal; font-weight: 700; }
.mincho-l { font-family: "Noto Serif Japanese Light", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
.mincho-r { font-family: "Noto Serif Japanese Regular", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
.mincho-b { font-family: "Noto Serif Japanese Bold", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }


/* Reset */
* { zoom: 1; }
html, body, header, footer, h1, h2, h3, h4, h5, h6, p, pre, address, ul, ol, li, dl, dt, em, dd, caption, img, form
{ margin: 0; padding: 0; border: none; font-style: normal; font-weight: normal; font-size: 100%; text-align: left; list-style-type: none; }
html { }
img { vertical-align: bottom; width: 100%; height: auto; }
hr { display: none; }
a { color: #06C; text-decoration: none; transition: .4s; }
a:hover { color: #C00; }


/* Common */
html, body { height: 100%; }
html.active-menu { overflow-y: hidden; }
body { font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif; font-size: 15px; line-height: 1.4em; color: #333; -webkit-text-size-adjust: none; }
noscript p { line-height: 1.2em; text-align: center; font-weight: bold; color: #FFF; padding: .8em 0; background: #C00; }

#wrap { height: 100%; min-height: 100%; margin: 0 auto; position: relative; }
body > #wrap { height: auto; min-height: 100%; }
body.basic { background: #ECE8D3; }
#container { padding-bottom: 0px; zoom: 1; overflow: hidden; }
#container:after { content: ""; display: block; clear: both; }
#pagetop { position: absolute; left: 0; top: 0; }
@media only screen and (max-width: 520px) and (orientation: portrait) {
  #container { padding-bottom: 0; }
}


/* Header */
header { height: 120px; border-top: solid 5px #7E9C4F; position: relative; overflow: hidden; }
header::before { content: ""; width: 53.8%; height: 0; padding-top: 32.8%; background: #7E9C4F; clip-path: polygon(0 0, 100% 0, 0 100%); position: absolute; top: 0; left: 0; }
header::after { content: ""; width: 13.7%; height: 0; padding-top: 8.4%; background: #7E9C4F; clip-path: polygon(0 0, 100% 0, 100% 100%); position: absolute; top: 0; right: 0; }
#head-logo { width: min(45%,240px); position: absolute; top: 1.5rem; left: 4%; z-index: 5; }
#head-logo a:hover img { opacity: .8; }
@media only screen and (max-width: 520px) and (orientation: portrait) {
  header { height: 70px; border-top: none; background: #7E9C4F; }
  header::before, header::after { width: 0; padding-top: 0; background: none; display: none; }
  #head-logo { top: 50%; transform: translateY(-50%); }
}


/* Global Menu */
#gmenu { position: absolute; right: 4%; top: 90px; z-index: 10; }
#gmenu ul { display: flex; align-items: center; justify-content: flex-end; position: relative; }
#gmenu ul li { margin: 0 .5em; padding: 0 .3em; position: relative; }
#gmenu ul li.active::after { content: ""; width: 100%; height: 3px; background: #7E9C4F; position: absolute; bottom: 0; left: 50%; transform: translateX(-50%); }
#gmenu ul li a { text-align: center; color: #7E9C4F; min-height: 40px; display: flex; align-items: center; justify-content: center; }
#gmenu ul li a::after { content: ""; width: 100%; height: 3px; background: rgba(126,156,79,.4); position: absolute; bottom: 0; left: 0; transform: scale(0,1); transform-origin: left top; transition: .3s; }
#gmenu ul li a:hover::after { transform: scale(1,1); }
#gmenu ul li a strong { font-weight: normal; width: 100%; display: block; position: relative; }
#gmenu ul li ul { width: 10.5em; max-height: 0; padding-top: 1em; display: block; overflow: hidden; position: absolute; transition: .5s; z-index: 10; }
#gmenu ul li ul.show { max-height: 10rem; margin-top: -.5em; }
#gmenu ul li ul.show::before { content: ""; width: 1em; height: 1em; background: rgba(126,156,79,.8); clip-path: polygon(0 100%, 50% 0, 100% 100%); position: absolute; top: 0; left: 1.8em; transform: translateX(-50%); }
#gmenu ul li ul li { width: 100%; margin: 0; padding: 0; }
#gmenu ul li ul li:first-child a { border-radius: 5px 5px 0 0; }
#gmenu ul li ul li:last-child a { border-radius: 0 0 5px 5px; }
#gmenu ul li ul li a { text-align: center; color: #FFF; min-height: auto; padding: 0 .5rem; background: rgba(126,156,79,.8); display: block; }
#gmenu ul li ul li a:hover { color: #FFF; background: rgba(106,126,79,.8); }
#gmenu ul li ul li a:hover::after { background: none; }
#gmenu ul li ul li a strong { padding: .3rem 0; border-left: none; }
@media only screen and (max-width: 768px) {
  #gmenu { display: none; }
}


/* Hambarger Menu */
#toggle-btn { width: 60px; height: 60px; padding-right: 5px; position: fixed; top: 5px; right: 0; z-index: 1001; }
#toggle-btn ul { width: 100%; height: 100%; position: relative; }
#toggle-btn ul li { width: 70%; height: 4px; background: #FFF; box-shadow: 0 0 .3rem .3rem rgba(126,156,79,.7); display: block; position: absolute; left: 50%; }
#toggle-btn ul li:first-child { top: 25%; transform: translate(-50%,-50%); transition: .3s; }
#toggle-btn ul li:nth-child(2) { top: 50%; transform: translate(-50%,-50%); transition: .3s }
#toggle-btn ul li:last-child { top: 75%; transform: translate(-50%,-50%); transition: .3s }
#toggle-btn ul.active-menu li { box-shadow: none; }
#toggle-btn ul.active-menu li:first-child { background: #FFF; top: 50%; transform: translate(-50%,-50%) rotate(-45deg); }
#toggle-btn ul.active-menu li:nth-child(2) { opacity: 0; }
#toggle-btn ul.active-menu li:last-child { background: #FFF; top: 50%; transform: translate(-50%,-50%) rotate(45deg); }

#hmenu { width: min(60%,240px); height: calc(100svh - 70px); padding-top: 70px; border-radius: 0; background: rgba(126,156,79,.8); box-shadow: 0 0 .5rem rgba(0,0,0,.3); position: fixed; top: 0; right: -100%; bottom: auto; left: auto; transform: translateX(0); z-index: 1000; transition: .5s; }
#hmenu.active-menu { right: 0; }
#hmenu ul { flex-direction: column; justify-content: flex-start; }
#hmenu ul li { width: 100%; }
#hmenu ul li a { text-align: left; color: #FFF; min-height: auto; padding: .8rem .5rem; border-top: solid 1px rgba(255,255,255,.5); display: block; }
#hmenu ul li a:hover { color: #FFF; background: rgba(255,255,255,0.2); }
#hmenu ul li a strong { font-weight: normal; }
#hmenu ul li ul { height: 100%; border-radius: 0; background: none; box-shadow: none; position: relative; }
#hmenu ul li ul li a { font-size: 93%; line-height: 1.2; text-align: left; padding: .2rem .5rem; border-top: none; display: block; }
#hmenu ul li ul li:last-child a { padding-bottom: .8rem; }
#hmenu ul li ul li a strong { padding: .3rem 0 .3rem .8rem; position: relative; }
#hmenu ul li ul li:last-child a strong { margin-bottom: .5rem; }
#hmenu ul li ul li a strong::before { content: ""; width: 0; height: 0; border-style: solid; border-width: .25rem .35rem; border-color: transparent transparent transparent #FFF; position: absolute; top: 50%; left: .1rem; transform: translateY(-50%); }
#overlay { display: none; }
#overlay.active-menu { width: 100%; height: 100svh; background: rgba(0,0,0,.7); display: block; position: fixed; top: 0; left: 0; z-index: 999; }


/* Footer */
footer { background: #FFF; box-shadow: 0 0 .5rem rgba(0,0,0,.3); }
#boilerplate { padding: 1rem 0; background: rgba(126,156,79,.2);}
#boilerplate .inner-box { width: min(92%,1060px); margin: 0 auto; display: flex; justify-content: space-between; position: relative; }
#boilerplate dl { width: 18%; }
#boilerplate dl dt a { line-height: 1.2; text-align: center; color: #FFF; padding: .4rem 0; background: rgba(126,156,79,1); display: block; }
#boilerplate dl dt a:hover { background: rgba(126,156,79,.8); }
#boilerplate dl dd { padding-top: .2rem; }
#boilerplate dl dd ul li { line-height: 1.2; padding-top: .2rem; }
#boilerplate dl dd ul li a { color: #7E9C4F; }
#boilerplate dl dd ul li a:hover { color: #F63; }
#boilerplate dl dd ul li a strong { font-weight: normal; padding-left: .9rem; display: block; position: relative; }
#boilerplate dl dd ul li a strong::before { content: ""; width: .4rem; height: .6rem; background: #7E9C4F; clip-path: polygon(0 0,100% 50%,0 100%); position: absolute; top: .3rem; left: .2rem; transition: .3s; }
#boilerplate dl dd ul li a strong:hover::before { background: #F63; }
#boilerplate p { line-height: 1.2; width: 38.5%; position: absolute; bottom: 0; }
#boilerplate p a { text-align: center; color: #7E9C4F; padding: .5rem 0; border: solid 1px #7E9C4F; border-radius: .5rem; background: #FFF; display: block; }
#boilerplate p a:hover { color: #FFF; background: #7E9C4F; }
.foot-info { width: min(92%,1060px); margin: 0 auto; padding: 2rem 0; position: relative; }
.foot-info h2 { width: min(70%,210px); margin: 0 auto; padding-bottom: 1.2rem; }
.foot-info p { line-height: 1.4; text-align: center; }
.foot-info p i { font-style: normal; padding-left: 1em; }
.foot-info ul { display: flex; align-items: center; justify-content: flex-end; position: absolute; top: 50%; right: 0; transform: translateY(-50%); }
.foot-info ul li { width: 40px; margin-left: 10px; }
.foot-info ul li:first-child { margin-left: 0; }
.foot-info h2 a:hover, .foot-box ul li a:hover { opacity: .8; }
footer p.copyright { text-align: center; width: 92%; padding: .3rem 4%; background: #7E9C4F; }
footer p.copyright small { font-size: .8rem; line-height: 1.2; color: #FFF; }
footer p.copyright small a { color: #FFF; }
footer p.copyright small a:hover { text-decoration: underline; }
@media only screen and (max-width: 768px) {
  .foot-info p i { padding-left: 0; }
  .foot-info p i::before { content: "\A"; white-space: pre; }
}
@media only screen and (max-width: 520px) and (orientation: portrait) {
  #boilerplate .inner-box { flex-direction: column; }
  #boilerplate dl { width: 100%; margin-bottom: .5rem; }
  #boilerplate dl dd ul { display: flex; flex-wrap: wrap; justify-content: space-between; }
  #boilerplate dl dd ul li { width: 50%; }
  #boilerplate p { width: 100%; position: relative; }
  .foot-info { padding: 1.2rem 0; }
  .foot-info h2 { padding-bottom: .8rem; }
  .foot-info ul { padding-top: .8rem; justify-content: center; position: relative; top: 0; right: auto; transform: translateY(0); }
  .foot-info ul li {}
  footer p.copyright { text-align: left; }
  footer p.copyright small a::after { content: "\A"; white-space: pre; }
}


/* Return Button */
#returnbtn { width: 60px; height: 60px; position: fixed; bottom: 10px; right: 10px; z-index: 50; }
#returnbtn img { width: 100%; height: auto; }
#returnbtn a img { transition: .2s; }
#returnbtn a:hover img { transform: scale(1.05); }


/* Recruit Menu */
#reuruit-menu { width: 100%; padding: 3rem 0; background: url("../images/common/recruit_bg.jpg") center center; background-size: cover; display: flex; flex-direction: column; align-items: center; justify-content: center; }
#reuruit-menu h2 { width: min(80%,380px); margin-bottom: 3rem; position: relative; }
#reuruit-menu h2::after { content: ""; width: 2.5rem; height: 1.2rem; background: #FFF; clip-path: polygon(0 50%, 50% 0, 100% 50%, 50% 100%); position: absolute; bottom: -2rem; left: 50%; transform: translateX(-50%); }
#reuruit-menu p { font-size: 1.05rem; line-height: 1.8; text-align: center; color: #FFF; padding-bottom: 1.5rem; }
#reuruit-menu p span::before { content: "\A"; white-space: pre; }
#reuruit-menu ul { width: min(92%,520px); margin: 0 auto; display: flex; justify-content: space-between; }
#reuruit-menu ul li { font-size: 1.05rem; line-height: 1.2; width: 48%; }
#reuruit-menu ul li a { text-align: center; color: #7E9C4F; padding: .6em .3em; background: #FFF; display: block; position: relative; }
#reuruit-menu ul li a::before { content: ""; width: 100%; height: 100%; background: #FF3; mix-blend-mode: multiply; position: absolute; top: 0; left: 0; z-index: 0; transform: skewX(-45deg) scale(0,1); transform-origin: left top; transition: .2s cubic-bezier(0.45, 0, 0.55, 1); }
#reuruit-menu ul li a:hover::before { transform: skewX(0deg) scale(1,1); }
@media only screen and (max-width: 520px) and (orientation: portrait) {
  #reuruit-menu { padding: 2rem 0 1.5rem 0; }
  #reuruit-menu p { font-size: 1rem; line-height: 1.6; text-align: justify; padding: 0 4% 4% 4%; }
  #reuruit-menu ul { flex-direction: column; }
  #reuruit-menu ul li { width: 100%; margin-bottom: 2%; }
}


/* Animation */
.sa { opacity: 0; transition: all .5s ease; }
.sa.show { opacity: 1; transform: none; }
.sa--lr { transform: translate(-200px, 0); }
.sa--rl { transform: translate(200px, 0); }
.sa--up { transform: translate(0, 200px); }
.sa--down { transform: translate(0, -200px); }
.sa--scaleUp { transform: scale(.5); }
.sa--scaleDown { transform: scale(1.5); }
.sa--rotateL { transform: rotate(180deg); }
.sa--rotateR { transform: rotate(-180deg); }
@media only screen and (max-width: 520px) and (orientation: portrait) {
  .sa--lr { transform: translate(-100px, 0); }
  .sa--rl { transform: translate(100px, 0); }
  .sa--up { transform: translate(0, 100px); }
  .sa--down { transform: translate(0, -100px); }

}

