*, *::before, *::after { box-sizing: border-box; }

body { color: #28140a; background: #f6f5f4; font-size: 1.4vw; letter-spacing: .08em; line-height: 1.6; font-family: "Zen Kaku Gothic New", sans-serif; font-weight: 500; font-style: normal; font-feature-settings: "palt"; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
@media screen and (max-width: 599px) { body { font-size: 2.8vw; } }
body.no-scroll { overflow: hidden; height: 100vh; }

_:lang(x)::-ms-backdrop, .selector { font-family: "Segoe UI", Meiryo, sans-serif; }

.fnt-Jost { font-family: "Jost", sans-serif; font-optical-sizing: auto; font-weight: 500; font-style: normal; }

p { line-height: 1.8; }

img { border: 0; vertical-align: top; }

input, select { position: relative; top: 1px; }

table, th, td { border-collapse: collapse; border-spacing: 0; }

ul, li { list-style: none; }

a:link, a:visited { color: #28140a; text-decoration: none; transition: opacity .5s; }
a:hover, a:active { opacity: .6; }

#cover { width: 100%; height: 100%; position: fixed; background: #ffffff; top: 0; left: 0; z-index: 10000; }

#loader { opacity: 0; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; width: 300px; height: 250px; }
#loader img { width: 100%; height: auto; }

#wrapper { position: relative; }

#page-top { opacity: 0; position: fixed; bottom: 20px; right: 20px; z-index: 9000; width: 40px; pointer-events: none; }
#page-top img { width: 100%; height: auto; }
#page-top.fade { opacity: 1; transition: opacity .5s; pointer-events: auto; }

.dd599 { display: none; }
@media screen and (max-width: 599px) { .dd599 { display: block !important; } }

@media screen and (max-width: 599px) { .nn599 { display: none !important; } }

.fadeinS, .fadein1, .fadein2, .fadein3, .fadein4, .fadein5, .fadein6, .fadein7, .fadeinF { opacity: 0; transform: translateY(30px); transition: opacity 1s ease-in, transform 1s ease-out; }
.fadeinS.active, .fadein1.active, .fadein2.active, .fadein3.active, .fadein4.active, .fadein5.active, .fadein6.active, .fadein7.active, .fadeinF.active { opacity: 1; transform: translateY(0); }

#header { overflow: hidden; position: fixed; top: 0; left: 0; z-index: 9001; justify-content: space-between; width: 100%; transition: .5s; box-shadow: 0 1px 5px 0 rgba(0, 0, 0, 0.1); }
#header .inner1 { position: relative; display: flex; justify-content: space-between; width: 100%; padding: .8em 3% .7em; background: #ffffff; }
@media screen and (max-width: 599px) { #header .inner1 { padding: 1.2em 5% 1em; } }
#header .inner1 h1 { position: relative; width: 16em; }
@media screen and (max-width: 599px) { #header .inner1 h1 { width: 20em; } }
#header .inner1 h1 img { width: 100%; height: auto; }
#header .inner1 nav .gMenu { position: relative; padding: .3em .2em 0 0; }
@media screen and (max-width: 599px) { #header .inner1 nav .gMenu { position: fixed; display: block; top: 0; left: 0; width: 100%; margin: 0 auto; z-index: 999; opacity: 0; height: 0; max-height: 0; overflow: hidden; transition: max-height 0s, opacity .4s; }
  #header .inner1 nav .gMenu.active { opacity: 1; height: 100%; max-height: 100%; background: rgba(255, 255, 255, 0.95) url("../../img/logo.svg") no-repeat 11.5% 1.2em/20em; } }
#header .inner1 nav .gMenu > ul { position: relative; display: flex; width: 100%; }
@media screen and (max-width: 599px) { #header .inner1 nav .gMenu > ul { display: block; text-align: center; padding: 8.8em 0 0; } }
#header .inner1 nav .gMenu > ul > li { padding-left: 2em; }
@media screen and (max-width: 599px) { #header .inner1 nav .gMenu > ul > li { padding-left: 0; } }
#header .inner1 nav .gMenu > ul > li > a { position: relative; display: block; padding-left: 1.4em; font-size: 80%; }
#header .inner1 nav .gMenu > ul > li > a::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 1em; height: 1em; background: url("../img/icn_arrow_r.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { #header .inner1 nav .gMenu > ul > li > a { width: 100%; font-size: 160%; padding: .7em 0; border-top: 1px solid #beb9b4; }
  #header .inner1 nav .gMenu > ul > li > a::before { left: 7%; } }
#header .inner1 nav .gMenu > ul > li .subMenu { position: relative; display: none; }
@media screen and (max-width: 599px) { #header .inner1 nav .gMenu > ul > li .subMenu { display: block; } }
#header .inner1 nav .gMenu > ul > li .subMenu > li a { display: block; }
#header .inner1 nav .gMenu > ul > li .subMenu > li a span { display: inline-block; color: #827d78; font-size: 140%; letter-spacing: .03em; background: url("../img/icn_arrow.svg") no-repeat 2% center/0.6em; padding: .3em 1.4em 1em; }
#header .inner1 nav .gMenu > ul > li .subMenu > li:last-child a { border-bottom: 1px solid #beb9b4; }
#header .inner1 nav .menu-trigger { display: none; }
@media screen and (max-width: 599px) { #header .inner1 nav .menu-trigger { display: inline-block; transition: all .4s; position: absolute; z-index: 9999; width: 2.5em; height: 1em; top: 2em; right: 6%; }
  #header .inner1 nav .menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; position: absolute; width: 100%; height: 3px; background-color: #28140a; border-radius: 2px; }
  #header .inner1 nav .menu-trigger span:nth-of-type(1) { top: 0; }
  #header .inner1 nav .menu-trigger span:nth-of-type(2) { bottom: 0; } }
@media screen and (max-width: 599px) { #header .inner1 nav .menu-trigger.active { position: fixed; }
  #header .inner1 nav .menu-trigger.active span:nth-of-type(1) { transform: translateY(0.4em) rotate(-45deg); }
  #header .inner1 nav .menu-trigger.active span:nth-of-type(2) { transform: translateY(-0.4em) rotate(45deg); } }
#header .inner2 { position: relative; display: flex; justify-content: space-between; align-items: center; width: 100%; background: #f6f5f4; }
#header .inner2 h2 { font-size: 80%; letter-spacing: .02em; margin-left: 3.3%; }
@media screen and (max-width: 599px) { #header .inner2 h2 { font-size: 120%; margin-left: 5.5%; } }
#header .inner2 h2 span { color: #e6002d; }
#header .inner2 nav .rMenu { position: relative; }
#header .inner2 nav .rMenu ul { position: relative; display: flex; align-items: center; }
#header .inner2 nav .rMenu ul li { padding-left: 2em; }
@media screen and (max-width: 599px) { #header .inner2 nav .rMenu ul li { display: none; } }
#header .inner2 nav .rMenu ul li a { position: relative; display: block; padding-left: 1.3em; font-size: 70%; letter-spacing: .02em; line-height: 1.2; }
#header .inner2 nav .rMenu ul li a::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 1em; height: 1em; background: url("../img/icn_arrow_r.svg") no-repeat center center/contain; }
@media screen and (max-width: 599px) { #header .inner2 nav .rMenu ul li.entry { display: block; } }
#header .inner2 nav .rMenu ul li.entry a { padding: 1.1em 3em 1em; background-image: linear-gradient(45deg, #e6002d, #fa9600); color: #ffffff; transition: all .3s; }
#header .inner2 nav .rMenu ul li.entry a::before { display: none; }
#header .inner2 nav .rMenu ul li.entry a:hover { opacity: .6; background: linear-gradient(45deg, #fa9600, #e6002d); }
@media screen and (max-width: 599px) { #header .inner2 nav .rMenu ul li.entry a { font-size: 120%; padding: 1.3em 2.2em 1.2em; } }

main { position: relative; }
main section { position: relative; }
main section .btn-wb { text-align: right; }
@media screen and (max-width: 599px) { main section .btn-wb { text-align: center; } }
main section .btn-wb a { position: relative; display: inline-block; text-align: center; color: #ffffff; font-size: 80%; letter-spacing: .03em; line-height: 1.4; padding: .8em 0; width: 14em; border: 2px solid #ffffff; border-radius: 2em; transition: all .3s; }
@media screen and (max-width: 599px) { main section .btn-wb a { font-size: 130%; width: 70%; padding: 1em 0; } }
main section .btn-wb a::before { content: ""; position: absolute; left: .8em; top: 50%; transform: translateY(-50%); width: 1.4em; height: 1.4em; background: url("../img/icn_arrow_w2.svg") no-repeat center center/contain; }
main section .btn-wb a:hover { opacity: 1; background: #ffffff; color: #28140a; }
main section .btn-wb a:hover::before { background-image: url("../img/icn_arrow_b.svg"); }
main section .btn-gb { margin: 1em 0; }
@media screen and (max-width: 599px) { main section .btn-gb { margin: 1.6em 0; } }
main section .btn-gb a { position: relative; display: inline-block; text-align: center; color: #ffffff; font-size: 80%; letter-spacing: .03em; line-height: 1.4; padding: 1em 0; width: 24em; border-radius: 2em; background: linear-gradient(45deg, #e6002d, #fa9600); transition: all .3s; }
@media screen and (max-width: 599px) { main section .btn-gb a { font-size: 130%; width: 100%; padding: 1.1em 0; } }
main section .btn-gb a::before { content: ""; position: absolute; left: 1em; top: 50%; transform: translateY(-50%); width: 1.4em; height: 1.4em; background: url("../img/icn_arrow_w.svg") no-repeat center center/contain; }
main section .btn-gb a:hover { opacity: .6; background: linear-gradient(45deg, #fa9600, #e6002d); }
@media screen and (max-width: 599px) { main section .btn-gb.l2 a { line-height: 1.3; padding: .55em 0; } }
main section .btn-gbl { margin: 1em 0; }
@media screen and (max-width: 599px) { main section .btn-gbl { margin: 1.6em 0; } }
main section .btn-gbl a { position: relative; display: inline-block; text-align: center; color: #ffffff; font-size: 80%; letter-spacing: .03em; line-height: 1.4; padding: 1em 0; width: 24em; border-radius: 2em; background: linear-gradient(45deg, #e6002d, #fa9600); transition: all .3s; }
@media screen and (max-width: 599px) { main section .btn-gbl a { font-size: 130%; width: 100%; padding: 1.1em 0; } }
main section .btn-gbl a::before { content: ""; position: absolute; right: 1.6em; top: 50%; transform: translateY(-50%); width: 1.4em; height: 1.4em; background: url("../img/icn_link_w.svg") no-repeat center center/contain; }
main section .btn-gbl a:hover { opacity: .6; background: linear-gradient(45deg, #fa9600, #e6002d); }
main section#topMainSct .lowBgPic { position: relative; z-index: 1; }
@media screen and (max-width: 599px) { main section#topMainSct .lowBgPic { top: -.5em; margin-bottom: -.5em; } }
main section#topMainSct .lowBgPic img { width: 100%; height: auto; }
main section#topMainSct .lowBnrPic { position: relative; z-index: 9; display: block; width: 93.75%; height: auto; padding-top: 19em; margin-left: 6.25%; }
@media screen and (max-width: 599px) { main section#topMainSct .lowBnrPic { width: 93.3%; padding-top: 28em; margin-left: 6.7%; } }
main section#topMainSct .lowBnrPic img { display: block; width: 100%; height: auto; border-top-left-radius: 1.2em; border-bottom-left-radius: 1.2em; }
main section#topMainSct .lowCopyB { position: absolute; z-index: 15; top: 7.5em; left: 6%; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB { top: 16.5em; left: 6.7%; } }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB.bottom { top: inherit; bottom: 8em; } }
main section#topMainSct .lowCopyB .breadcrumb { display: flex; font-size: 70%; margin-bottom: 3.5em; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB .breadcrumb { display: none; } }
main section#topMainSct .lowCopyB .breadcrumb li { position: relative; padding-right: .5em; }
main section#topMainSct .lowCopyB .breadcrumb li::after { content: ">"; display: inline-block; color: #ffffff; margin-left: .5em; }
main section#topMainSct .lowCopyB .breadcrumb li a { color: #ffffff; }
main section#topMainSct .lowCopyB .breadcrumb li a:hover { color: #e6002d; }
main section#topMainSct .lowCopyB .breadcrumb li:last-child { padding-right: 0; }
main section#topMainSct .lowCopyB .breadcrumb li:last-child::after { display: none; }
main section#topMainSct .lowCopyB .breadcrumb.brown li::after { color: #28140a; }
main section#topMainSct .lowCopyB .breadcrumb.brown li a { color: #28140a; }
main section#topMainSct .lowCopyB h2 { color: #ffffff; }
main section#topMainSct .lowCopyB h2 .jp { display: block; font-size: 90%; font-weight: 700; letter-spacing: .05em; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB h2 .jp { white-space: nowrap; font-size: 145%; margin-bottom: .2em; } }
main section#topMainSct .lowCopyB h2 .en { display: block; font-size: 320%; line-height: 1.3; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB h2 .en { white-space: nowrap; font-size: 350%; line-height: 1.1; } }
main section#topMainSct .lowCopyB h2.color .jp { color: #28140a; }
main section#topMainSct .lowCopyB h2.color .en { color: #e6002d; }
main section#topMainSct .lowCopyB h2.bottom { margin-top: 13em; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB h2.bottom { position: absolute; bottom: 0; left: 0; } }
main section#topMainSct .lowCopyB h2.bottom .jp { font-size: 130%; }
@media screen and (max-width: 599px) { main section#topMainSct .lowCopyB h2.bottom .jp { font-size: 145%; } }
main section#topMainSct .lowCopyB.txtSd .breadcrumb li a { text-shadow: 1px 1px 3px rgba(0, 0, 0, 0.4); }
main section#topMainSct .lowCopyB.txtSd h2 .jp { text-shadow: 1px 1px 5px rgba(0, 0, 0, 0.4); }
main section#topMainSct .lowCopyB.txtSd h2 .en { text-shadow: 1px 1px 8px rgba(0, 0, 0, 0.4); }
main section#topMainSct .wiener05 { position: absolute; z-index: 3; top: 7em; right: 0; width: 22em; height: auto; }
@media screen and (max-width: 599px) { main section#topMainSct .wiener05 { top: 11em; width: 50%; } }
@media screen and (max-width: 599px) { main section#topMainSct .wiener05.v2 { top: -2em; } }
main section#topMainSct .wiener06 { position: absolute; z-index: 2; top: 31em; left: 0; width: 19em; height: auto; }
@media screen and (max-width: 599px) { main section#topMainSct .wiener06 { top: 61em; width: 45%; } }
main section#recContentsSct { background: #f6f5f4; }
main section#recContentsSct.cover { position: relative; z-index: 8; top: -2.8em; margin-bottom: -2.8em; background: #f6f5f4; border-top-left-radius: 1.2em; border-top-right-radius: 1.2em; padding: 5em 0 0; }
@media screen and (max-width: 599px) { main section#recContentsSct.cover { padding: 5em 0 0; top: -4.3em; margin-bottom: -4.3em; } }
main section#recContentsSct.cover .lowerCmnBox { padding: 0 1.25% 1em; }
@media screen and (max-width: 599px) { main section#recContentsSct.cover .lowerCmnBox { padding: 0 2.7% 1em; } }
main section#recContentsSct .lowerCmnBox { position: relative; padding: 7em 1.25% 1em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox { padding: 8em 2.7% 1em; } }
main section#recContentsSct .lowerCmnBox .wiener04 { position: absolute; z-index: 1; top: 0; left: 0; width: 16em; height: auto; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .wiener04 { width: 33%; } }
main section#recContentsSct .lowerCmnBox .wiener04.down { top: 10em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .wiener04.down { top: 34em; } }
main section#recContentsSct .lowerCmnBox .wiener04.up { top: -10em; }
main section#recContentsSct .lowerCmnBox .wiener04.up2 { top: -5em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .wiener04.up2 { top: -2em; } }
main section#recContentsSct .lowerCmnBox .box { position: relative; z-index: 5; background: #ffffff; padding: 4em 0 3em; border-radius: 1.2em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .box { padding: 6.5em 9% 5em; } }
main section#recContentsSct .lowerCmnBox .box h3 { display: block; text-align: center; margin-bottom: 3.5em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .box h3 { font-size: 145%; } }
main section#recContentsSct .lowerCmnBox .box h3 .en { display: block; color: #e6002d; letter-spacing: 0; }
main section#recContentsSct .lowerCmnBox .box h3 .jp { display: block; font-size: 130%; }
main section#recContentsSct .lowerCmnBox .box .btn-3 { position: relative; display: flex; flex-wrap: wrap; width: 70%; margin: 0 auto; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .box .btn-3 { width: 100%; } }
main section#recContentsSct .lowerCmnBox .box .btn-3 li { width: calc(100% / 3); padding: 0 1.3em; margin-bottom: 2em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .box .btn-3 li { margin-bottom: 2.6em; width: 100%; } }
main section#recContentsSct .lowerCmnBox .box .btn-3 li a { display: inline-block; font-size: 90%; width: 100%; padding: .3em .5em; border-bottom: 1px solid #28140a; background: url("../img/icn_arrow_g.svg") no-repeat 98% center/1em; }
@media screen and (max-width: 599px) { main section#recContentsSct .lowerCmnBox .box .btn-3 li a { font-size: 165%; width: 100%; padding: .5em 0; background: url("../img/icn_arrow_g2.svg") no-repeat right center/1.5em; } }
main section#recContentsSct .lowerCmnBox .box .btn-3 li:nth-child(4) { margin-bottom: 5em; }
main section#cmnRecruitSct { z-index: 10; background: #ffffff; }
main section#cmnRecruitSct .innerB { background: #f6f5f4 url("../img/r_bottom_bg.webp") no-repeat center center/cover; padding: 6em 12.5% 10em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .innerB { padding: 8em 10% 8em; } }
main section#cmnRecruitSct .innerB h3 { display: inline-block; width: 100%; text-align: center; color: #ffffff; margin-bottom: 3.5em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .innerB h3 { font-size: 130%; margin-bottom: 4.5em; } }
main section#cmnRecruitSct .innerB h3 small { display: block; font-size: 90%; letter-spacing: .02em; margin-bottom: .4em; }
main section#cmnRecruitSct .innerB h3 span { display: block; font-size: 210%; letter-spacing: .2em; }
main section#cmnRecruitSct .innerB .btn-3 { position: relative; display: flex; justify-content: center; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .innerB .btn-3 { flex-wrap: wrap; } }
main section#cmnRecruitSct .innerB .btn-3 li { padding: 0 1.3em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .innerB .btn-3 li { margin-bottom: 2.6em; width: 100%; } }
main section#cmnRecruitSct .innerB .btn-3 li a { display: inline-block; color: #ffffff; font-size: 90%; font-weight: 700; width: 15em; padding: .3em .5em; border-bottom: 1px solid #ffffff; background: url("../img/icn_arrow_w.svg") no-repeat 98% center/1em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .innerB .btn-3 li a { font-size: 165%; width: 100%; padding: .5em 0; background: url("../img/icn_arrow_lw2.svg") no-repeat right center/1.5em; } }
main section#cmnRecruitSct .btn-ent { position: relative; padding: 3.5em 0 .5em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .btn-ent { padding: 6em 0 0; margin-bottom: -5em; } }
main section#cmnRecruitSct .btn-ent a { background: linear-gradient(45deg, #e6002d, #fa9600); padding: 1em 0; border-radius: 8em; width: 23em; display: flex; align-items: center; color: #ffffff; text-align: center; transition: all .3s; box-shadow: 2px 2px 8px 2px rgba(0, 0, 0, 0.1); margin: 0 auto; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .btn-ent a { display: block; width: 60%; padding: 1.8em 0 2em; margin: 0 auto; } }
main section#cmnRecruitSct .btn-ent a span { width: 50%; font-size: 120%; line-height: 1; border-right: 1px solid #ffffff; padding: .7em 0 .6em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .btn-ent a span { display: block; width: 100%; border: none; font-size: 225%; letter-spacing: .06em; padding: 0 0 .3em 0; } }
main section#cmnRecruitSct .btn-ent a small { width: 50%; font-size: 70%; letter-spacing: .03em; line-height: 1; white-space: nowrap; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct .btn-ent a small { display: block; width: 100%; font-size: 120%; } }
main section#cmnRecruitSct .btn-ent a:hover { opacity: 1; background: #28140a; }
main section#cmnRecruitSct.nonList .btn-ent { position: relative; padding: 3.5em 0 .5em; }
@media screen and (max-width: 599px) { main section#cmnRecruitSct.nonList .btn-ent { padding: 6em 0 0; margin-bottom: -5em; } }

#footer { overflow: hidden; position: relative; padding: 5em 0 4em; background: #ffffff; }
@media screen and (max-width: 599px) { #footer { padding: 11em 0 2.5em; } }
#footer .box1 { position: relative; display: flex; justify-content: space-between; margin-bottom: 2em; }
@media screen and (max-width: 599px) { #footer .box1 { display: block; margin-bottom: 0; } }
#footer .box1 > div { width: 50%; padding: 0 6.25%; }
@media screen and (max-width: 599px) { #footer .box1 > div { width: 100%; padding: 0; } }
#footer .box1 > div .logo { position: relative; width: 16em; margin-bottom: 1.8em; }
@media screen and (max-width: 599px) { #footer .box1 > div .logo { width: 75%; margin: 0 auto 3em; } }
#footer .box1 > div .logo img { width: 100%; height: auto; }
#footer .box1 > div .recTtl { position: relative; display: block; letter-spacing: .05em; margin-bottom: 1.8em; }
@media screen and (max-width: 599px) { #footer .box1 > div .recTtl { text-align: center; font-size: 170%; line-height: 1.4; margin-top: 3.4em; } }
#footer .box1 > div .recTtl span { color: #e6002d; }
@media screen and (max-width: 599px) { #footer .box1 > div .recTtl span { display: block; } }
#footer .box1 > div .menuF { position: relative; display: flex; flex-wrap: wrap; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF { display: block; text-align: center; border-bottom: 1px solid #beb9b4; margin-bottom: 3.5em; } }
#footer .box1 > div .menuF > li { position: relative; padding: 0 3em 1.6em 0; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF > li { width: 100%; padding: 0; border-top: 1px solid #beb9b4; } }
#footer .box1 > div .menuF > li .ttl { position: relative; display: block; margin-bottom: .2em; }
#footer .box1 > div .menuF > li .ttl a { position: relative; white-space: nowrap; font-size: 70%; letter-spacing: .05em; padding-left: 1.4em; background: url("../img/icn_arrow_r.svg") no-repeat left center/1em; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF > li .ttl a { display: block; font-size: 160%; padding: .55em 0; background-position: 7% center; } }
#footer .box1 > div .menuF > li .ttl .openB { display: none; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF > li .ttl .openB { display: block; position: absolute; z-index: 10; right: 7%; top: 50%; transform: translateY(-50%); width: 2.4em; height: 2.4em; background: url("../img/icn_plus.svg") no-repeat center center/cover; cursor: pointer; transition: transform .3s; }
  #footer .box1 > div .menuF > li .ttl .openB.open { transform: translateY(-50%) rotate(45deg); } }
#footer .box1 > div .menuF > li .subM { position: relative; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF > li .subM { height: 0; overflow: hidden; transition: all .3s; }
  #footer .box1 > div .menuF > li .subM.open { height: auto; top: -.6em; margin-bottom: .2em; } }
#footer .box1 > div .menuF > li .subM > li a { color: #827d78; font-size: 70%; letter-spacing: .03em; padding-left: 1.4em; background: url("../img/icn_arrow.svg") no-repeat 2% center/0.6em; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF > li .subM > li a { display: inline-block; font-size: 140%; padding: .5em 0 .5em 1.4em; } }
#footer .box1 > div .menuF.w3 > li { width: calc(100% / 3); padding-right: 0; }
@media screen and (max-width: 599px) { #footer .box1 > div .menuF.w3 > li { width: 100%; } }
#footer .box2 { position: relative; display: flex; justify-content: space-between; }
@media screen and (max-width: 599px) { #footer .box2 { display: block; } }
#footer .box2 > div { width: 50%; padding: 0 6.25%; }
@media screen and (max-width: 599px) { #footer .box2 > div { width: 100%; padding: 0; } }
#footer .box2 > div .menuF2 { display: flex; }
@media screen and (max-width: 599px) { #footer .box2 > div .menuF2 { display: block; text-align: center; margin-bottom: 3em; } }
#footer .box2 > div .menuF2 > li a { display: block; font-size: 70%; letter-spacing: .03em; padding-left: 3em; }
@media screen and (max-width: 599px) { #footer .box2 > div .menuF2 > li a { display: inline-block; font-size: 120%; padding-left: 0; margin-bottom: 1em; } }
#footer .box2 > div .menuF2 > li a.outL { letter-spacing: 0; padding-left: 0; padding-right: 1.2em; background: url("../img/icn_link.svg") no-repeat right center/1.2em; }
#footer .box2 > div .cpr { color: #827d78; text-align: right; font-size: 60%; letter-spacing: .02em; }
@media screen and (max-width: 599px) { #footer .box2 > div .cpr { text-align: center; font-size: 100%; } }
