@charset "UTF-8";
/*============================================================= 02_base
=============================================================*/
/*!  02_base
================================================ */
html { overflow: auto; }

body { min-width: 320px; font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif; color: #333; font-size: 1.3rem; line-height: 2.1538461538; overflow: hidden; }
@media all and (min-width: 769px) { body { min-width: 1200px; font-size: 1.8rem; line-height: 2.2222222222; } }

.serif { font-family: "Noto Serif JP", "ヒラギノ明朝 ProN W3", serif; font-weight: 200; }

.oswald { font-family: "Oswald", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif; font-weight: 500; }

.opensans { font-family: "Open Sans", "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Meiryo, sans-serif; font-weight: 400; }

div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video, input, select, textarea { font-size: inherit; font-weight: inherit; font-family: inherit; max-height: 999999px; }

a { color: #333; text-decoration: underline; }
@media all and (min-width: 769px) { a:hover { text-decoration: none; } }

.alpha { display: block; text-decoration: none; }
@media all and (min-width: 769px) { .alpha { transition: all 0.3s ease; }
  .alpha:hover { opacity: .7; } }

img { width: 100%; height: auto; }

.viewPc { display: none; }

@media all and (min-width: 769px) { .viewSp { display: none; }
  .viewPc { display: block; } }
.cf:after { content: ''; display: block; clear: both; }

#mediaQuery { display: none; font-family: 'sp'; }
@media all and (min-width: 769px) { #mediaQuery { font-family: 'pc'; } }

/*! layout
-------------------------------------- */
#wrapper { position: relative; padding-top: 55px; overflow: hidden; }
@media all and (min-width: 769px) { #wrapper { padding-top: 103px; } }

/*============================================================= 03_layout
=============================================================*/
/* #gHeader
================================================ */
#gHeader { position: fixed; top: 0; left: 0; width: 100%; min-width: 320px; z-index: 2000; }
@media all and (min-width: 769px) { #gHeader { width: 100%; min-width: 1200px; background: #fff; } }

@media all and (min-width: 769px) { .header-career .career-image { width: 398px; height: 163px; } .header-career .career-image img { width: 100%; height: 100%; object-fit: cover; } }

/* #hdInfo
-------------------------------------- */
#hdInfo { position: relative; width: 100%; height: 55px; background: #fff; }
#hdInfo .logo { position: absolute; top: 10px; left: 10px; }
#hdInfo .logo a { display: block; padding: 11px 0; text-decoration: none; overflow: hidden; }
#hdInfo .logo a .img { display: block; float: left; width: 113px; margin-right: 13px; }
#hdInfo .logo a .txt { display: block; float: left; font-size: 1rem; line-height: 1.2; }
#hdInfo .btnGnav { position: absolute; top: 0; right: 0; width: 55px; height: 55px; background: #1b1b1b; cursor: pointer; }
#hdInfo .btnGnav .line { position: absolute; left: 14px; width: 27px; height: 2px; content: ''; background: #fff; transition: all 0.3s ease; }
#hdInfo .btnGnav .line:nth-child(1) { top: 15px; }
#hdInfo .btnGnav .line:nth-child(2) { top: 26px; }
#hdInfo .btnGnav .line:nth-child(3) { top: 37px; }
#hdInfo .btnGnav.is_open .line:nth-child(1) { top: 26px; transform: rotate(-45deg); }
#hdInfo .btnGnav.is_open .line:nth-child(2) { opacity: 0; }
#hdInfo .btnGnav.is_open .line:nth-child(3) { top: 26px; transform: rotate(45deg); }
@media all and (min-width: 769px) { #hdInfo { float: left; width: auto; height: 103px; }
  #hdInfo .logo { top: 20px; left: 20px; }
  #hdInfo .logo a { padding-bottom: 0; }
  #hdInfo .logo a .img { float: none; width: 203px; margin-right: 0; margin-bottom: 9px; }
  #hdInfo .logo a .txt { float: none; font-size: 1.8rem; line-height: 1.1111111111; } }

/* #gNav
================================================ */
#gNav { display: none; position: absolute; top: 55px; right: 0; width: 100%; min-width: 320px; background: #eee; box-sizing: border-box; overflow-y: auto; }
#gNav .parent { border-bottom: 1px solid #c1c1c1; background: #fff; }
#gNav .parent .none { display: none; }
#gNav .parent > li { position: relative; font-size: 1.5rem; line-height: 1.2; background: #fff;}
#gNav .parent > li .link { display: block; padding: 19px 16px; border-top: 1px solid #c1c1c1; text-decoration: none; color: #1b1b1b; cursor: pointer; z-index: 2;}
#gNav .parent > li .ico { z-index: 1;position: absolute; top: 0; right: 0; width: 50px; height: 56px; cursor: pointer; }
#gNav .parent > li .ico::after { position: absolute; top: 50%; right: 13px; content: ''; width: 6px; height: 10px; margin-top: -3px; background: url(../img/common/ico_arrow01_blue.png) no-repeat; background-size: cover; transform: rotate(90deg); transition: all 0.3s ease; }
#gNav .parent > li .ico.is_open::after { transform: rotate(-90deg); }
@media all and (max-width: 768px){
  #gNav .parent > li{background: #eee;}
  #gNav .parent > li .link{position: relative;}
}
#gNav .child { display: none; background: #fff; }
#gNav .child .list01 li + li { border-top: 1px solid #c1c1c1; }
#gNav .child .list01 li a { display: block; padding: 18px 16px; text-decoration: none; }
#gNav .child .list02 li { border-top: 1px solid #c1c1c1; }
#gNav .child .list02 li a { position: relative; display: block; padding: 18px 16px; text-decoration: none; }
#gNav .child .list02 li a[target="_blank"]::after { position: absolute; top: 50%; right: 13px; content: ''; width: 9px; height: 9px; background: url(../img/common/ico_blank01.png) no-repeat; background-size: cover; }
#gNav .child .list03 { margin-bottom: -1px; overflow: hidden; }
#gNav .child .list03 li { float: left; width: 50%; border-bottom: 1px solid #c1c1c1; box-sizing: border-box; }
#gNav .child .list03 li:nth-child(2n-1) { border-right: 1px solid #c1c1c1; }
#gNav .child .list03 li a { display: block; padding: 0; text-decoration: none; }
#gNav .child .list03 li a .txtWrap { display: table; width: 100%; }
#gNav .child .list03 li a .txtWrap .position { display: table-cell; height: 44px; padding: 5px 5px 5px 12px; vertical-align: middle; }
#gNav .child .btn { border-bottom: 1px solid #c1c1c1; }
#gNav .child .btn a { position: relative; display: block; padding: 19px 16px; border-top: 1px solid #c1c1c1; background: #eee; text-decoration: none; color: #1b1b1b; }
#gNav .child .btn a::after { position: absolute; top: 50%; right: 13px; content: ''; width: 6px; height: 10px; margin-top: -5px; background: url(../img/common/ico_arrow01_blue.png) no-repeat; background-size: cover; }
#gNav .btns { overflow: hidden; border-top: 1px solid #fff; }
#gNav .btns .btn { box-sizing: border-box; font-size: 1.5rem; line-height: 1.2; }
#gNav .btns .btn a { position: relative; display: block; padding: 21px 0; background: #1b1b1b; text-align: center; text-decoration: none; overflow: hidden; }
#gNav .btns .btn a span { position: relative; color: #fff; z-index: 1; }
#gNav .btns .btn a::after { position: absolute; top: 0; right: -275%; content: ''; width: 300%; height: 100%; background: #2c2c2c; transform: skewX(-60deg); }
#gNav .btns .btn + .btn a { border-left: 1px solid #fff; background: #013858; }
#gNav .btns .btn + .btn a::after { background: #01314c; }
@media all and (min-width: 769px) { #gNav { display: block; position: static; float: right; width: auto; min-width: none; background: transparent; overflow-y: visible; }
  #gNav .parent { float: left; border-bottom: 0; padding-right: 15px; }
  #gNav .parent > li { position: static; float: left; font-size: 1.8rem; line-height: 1.2777777778; }
  #gNav .parent > li .link { display: block; padding: 0 15px; border-top: 0; background: transparent; cursor: pointer; }
  #gNav .parent > li .link .txt { position: relative; display: block; padding: 40px 0; text-decoration: none; color: #1b1b1b; overflow: hidden; }
  #gNav .parent > li .link .txt::after { position: absolute; bottom: -3px; left: 0; content: ''; width: 100%; height: 3px; background: #1b1b1b; transition: all 0.3s ease; }
  #gNav .parent > li .link.is_open .txt::after, #gNav .parent > li .link:hover .txt::after { bottom: 0; }
  #gNav .parent > li:nth-child(1) .child .list01 { float: left; width: 802px; }
  #gNav .parent > li:nth-child(1) .child .list01 .pic { height: 163px; }
  #gNav .parent > li:nth-child(1) .child .list01 .pic img { display: none; }
  #gNav .parent > li:nth-child(1) .child .list01 li:nth-child(1) .pic { background-image: url(../img/common/header/pic_gnav_company02.png); }
  /* #gNav .parent > li:nth-child(1) .child .list01 li:nth-child(2) .pic { background-image: url(../img/common/header/pic_gnav_company01.png); } */
  #gNav .parent > li:nth-child(1) .child .list01 li:nth-child(2) .pic { background-image: url(../img/common/header/pic_gnav_company03.png); background-position: center; }
  #gNav .parent > li:nth-child(1) .child .list02 { float: right; width: 360px; }
  #gNav .parent > li:nth-child(2) .child .list01 { margin-right: -3px; }
  #gNav .parent > li:nth-child(2) .child .list01 li { float: none; margin: 0 auto; }
  #gNav .parent > li:nth-child(3) .child { padding-top: 65px; overflow: auto; }
	#gNav .parent > li:nth-child(3) .child .tit { color: #005bab; float: left; margin: 15px auto 0 30px; display: table; font-size: 2.2rem; font-weight: bold;
	}
	#gNav .parent > li:nth-child(3) .child .btn { width: 228px; margin-bottom: 13px; }
	#gNav .parent > li:nth-child(3) .child .btn a span { color: #005bab; }
	#gNav .parent > li:nth-child(3) .child .list01 { width: 398px; float: left; margin-top: 74px; }
  #gNav .parent > li:nth-child(3) .child .list03 { width: 760px; float: right; margin-bottom: 50px; }
  #gNav .parent > li:nth-child(4) .child .list01 { width: 802px; margin: 0 auto; }
  #gNav .child { position: absolute; top: 103px; left: 50%; width: 1200px; padding: 20px 200%; background: #eee; transform: translateX(-50%); }
  #gNav .child .list01 li { float: left; width: 398px; margin: 0 3px 24px 0; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); }
  #gNav .child .list01 li + li { border-top: 0; }
  #gNav .child .list01 li.is_col3 { width: 264px; }
  #gNav .child .list01 li a { padding: 0; }
  #gNav .child .list01 li a .txt { position: relative; padding: 22px 0; color: #1b1b1b; font-size: 2rem; text-align: center; line-height: 1.5; overflow: hidden; }
  #gNav .child .list01 li a .txt::after { position: absolute; top: 0; right: -275%; content: ''; width: 300%; height: 100%; background: #eee; transform: skewX(-60deg); transition: all 0.3s ease; }
  #gNav .child .list01 li a .txt span { position: relative; z-index: 1; }
  #gNav .child .list01 li a:hover .txt::after { right: -104%; }
  #gNav .child .list02 li { border-top: 0; border-bottom: 1px solid #c1c1c1; }
  #gNav .child .list02 li a { padding: 25px 15px 25px 0; font-size: 1.8rem; line-height: 1.1111111111; transition: all 0.3s ease; }
  #gNav .child .list02 li a[target="_blank"]::after { right: 0; width: 18px; height: 18px; margin-top: -9px; }
  #gNav .child .list02 li a:hover { color: #1b1b1b; }
  #gNav .child .list03 { margin-right: -3px; margin-bottom: 0; }
  #gNav .child .list03 li { width: 187px; margin: 0 3px 24px 0; background: #fff; box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); border-bottom: 0; }
  #gNav .child .list03 li:nth-child(2n-1) { border-right: 0; }
  #gNav .child .list03 li a { text-align: center; }
  #gNav .child .list03 li a .txtWrap { display: block; position: relative; width: auto; padding: 16px 0 25px; overflow: hidden; }
  #gNav .child .list03 li a .txtWrap::after { position: absolute; top: 0; right: -310%; content: ''; width: 300%; height: 100%; background: #eee; transform: skewX(-60deg); transition: all 0.3s ease; }
  #gNav .child .list03 li a .txtWrap .position { display: block; position: relative; height: 40px; display: -webkit-box;	display: -ms-flexbox;	display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; padding: 0; color: #666; font-size: 1.3rem; font-weight: 500; line-height: 1.5384615385; z-index: 2; }
  #gNav .child .list03 li a .txtWrap .name { position: relative; z-index: 2; font-size: 1.6rem; font-weight: bold; line-height: 1.2222222222; }
  #gNav .child .list03 li a:hover .txtWrap::after { right: -104%; }
  #gNav .child .btn { width: 267px; margin: 0 0 28px auto; border-bottom: 0; border-radius: 3px; box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3); }
  #gNav .child .btn a { padding: 19px 16px; border-top: 0; border-radius: 3px; background: #fff; text-align: center; overflow: hidden; }
  #gNav .child .btn a span { position: relative; z-index: 2; }
  #gNav .child .btn a::after { content: none; }
  #gNav .child .btn a::before { position: absolute; top: 0; right: -273%; content: ''; width: 300%; height: 100%; background: #eee; transform: skewX(-60deg); transition: all 0.3s ease; }
  #gNav .child .btn a:hover::before { right: -104%; }
  #gNav .btns { border-top: 0; }
  #gNav .btns .btn { width: 130px; font-size: 1.8rem; line-height: 1.2777777778; }
  #gNav .btns .btn a { padding: 40px 0; }
  #gNav .btns .btn a::after { right: -304%; transition: all 0.3s ease; }
  #gNav .btns .btn a:hover::after { right: -104%; }
  #gNav .btns .btn + .btn a { border-left: 0; } }

/* #mainVisual HOME
================================================ */
#mainVisual { background: #eee; }
#mainVisual img.viewPc { display: none; }
@media all and (min-width: 769px) { #mainVisual img { max-width: 1920px; margin: 0 auto; }
  #mainVisual img.viewPc { display: block; }
  #mainVisual img.viewSp { display: none; } }

/* #breadcrumb
================================================ */
#breadcrumb { background: #eee; }
#breadcrumb .list { padding: 19px 15px; font-size: 1.2rem; line-height: 1.5; letter-spacing: -.5em; }
#breadcrumb .list .item { display: inline-block; letter-spacing: 0; }
#breadcrumb .list .item + .item { padding-left: 12px; }
#breadcrumb .list .item + .item:before { content: ">"; margin-right: 12px; }
@media screen and (max-width: 768px) { #breadcrumb { overflow-y: hidden; overflow-x: scroll; }
  #breadcrumb .list { width: max-content; } }
@media all and (min-width: 769px) { #breadcrumb .list { padding: 24px 36px; font-size: 1.4rem; line-height: 1.4285714286; }
  #breadcrumb .list .item + .item { padding-left: 16px; }
  #breadcrumb .list .item + .item:before { margin-right: 16px; } }

/* #gFooter
================================================ */
#gFooter .bnrsBg { background: url(../img/common/bg_bnr03.png) no-repeat center !important; background-size: cover; }
#gFooter .bnrsBg .mod_bnrs01 { background: transparent !important; }

/* #pagetop
================================================ */
@media all and (max-width: 768.9999px) { #pagetop { position: static !important; } }
#pagetop a { display: block; padding: 25px 0 0; background: #538689; color: #fff; text-align: center; text-decoration: none; }
#pagetop a img { width: 44px; }
@media all and (min-width: 769px) { #pagetop { opacity: 0; visibility: hidden; position: fixed; right: 0; bottom: 50px; width: 40px; height: 40px; border-radius: 50%; margin-right: 50px; overflow: hidden; transition: opacity 0.3s ease; }
  #pagetop.is_view { opacity: 1; visibility: visible; }
  #pagetop a { display: block; width: 40px; height: 40px; padding: 0; border-radius: 25px; box-sizing: border-box; }
  #pagetop a img { display: block; width: 40px; } }

/* #ftEntry
================================================ */
#ftEntry { background: url(../img/common/footer/bg_entry01.png) no-repeat 50% 50%; background-size: cover; }
#ftEntry .inner { padding-top: 29px; padding-bottom: 32px; }
#ftEntry .copy { margin-bottom: 31px; color: #fff; font-size: 2.4rem; text-align: center; line-height: 1.1111111111; }
#ftEntry .copy span { position: relative; top: 2px; font-size: 3.5rem; }
@media all and (min-width: 769px) { #ftEntry .inner { padding-top: 123px; padding-bottom: 122px; overflow: hidden; }
  #ftEntry .copy { float: left; width: 710px; margin-bottom: 0; padding-top: 4px; font-size: 4.9rem; text-align: left; line-height: 1.2244897959; }
  #ftEntry .copy span { top: 2px; font-size: 5.7rem; }
  #ftEntry .btn { float: left; overflow: hidden; } }

/* #ftNav
================================================ */
#ftNav { background: #eee url(../img/common/footer/bg_nav01_sp.png) no-repeat 0 0; background-size: 375px auto; }
#ftNav .inner { padding-right: 0; padding-left: 0; }
#ftNav .unit { position: relative; border-bottom: 1px solid #c1c1c1; }
#ftNav .unit .tit { padding: 18px 15px; font-size: 1.8rem; line-height: 1.0555555556; letter-spacing: -.5em; cursor: pointer; }
#ftNav .unit .tit .en { display: inline-block; width: 130px; color: #1b1b1b; font-weight: 700; letter-spacing: 0; }
#ftNav .unit .tit .txt { display: inline-block; font-size: 1.2rem; line-height: 1.5833333333; letter-spacing: 0; }
#ftNav .unit .ico { position: absolute; top: 0; right: 0; width: 50px; height: 55px; cursor: pointer; }
#ftNav .unit .ico::after { position: absolute; top: 50%; right: 13px; content: ''; width: 6px; height: 10px; margin-top: -3px; background: url(../img/common/ico_arrow01_blue.png) no-repeat; background-size: cover; transform: rotate(90deg); transition: all 0.3s ease; }
#ftNav .unit .ico.is_open::after { transform: rotate(-90deg); }
#ftNav .unit .list { display: none; }
#ftNav .unit .list li { border-top: 1px solid #c1c1c1; background: #fff; }
#ftNav .unit .list li.sub { text-indent: 1em; }
#ftNav .unit .list li a { display: block; padding: 10px 15px; text-decoration: none; }
#ftNav .unit .list li a[target="_blank"] { position: relative; }
#ftNav .unit .list li a[target="_blank"]::after { position: absolute; top: 50%; right: 13px; content: ''; width: 9px; height: 9px; background: url(../img/common/ico_blank01.png) no-repeat; background-size: cover; }
@media all and (max-width: 768.9999px) { #ftNav .unit .list li.index a { position: relative; background: #eee; }
  #ftNav .unit .list li.index a::after { position: absolute; top: 50%; right: 13px; content: ''; width: 6px; height: 10px; margin-top: -3px; background: url(../img/common/ico_arrow01_blue.png) no-repeat; background-size: cover; } }
#ftNav .unit .list li .child { padding-left: 30px; }
@media all and (min-width: 769px) { #ftNav { background: #eee url(../img/common/footer/bg_nav01_pc.png) no-repeat 50% 50%; background-size: cover; }
  #ftNav .inner { padding-top: 62px; padding-bottom: 87px; overflow: hidden; }
  #ftNav .unit { float: left; width: 315px; border-bottom: 0; }
  #ftNav .unit:nth-child(1) { width: 333px; }
  #ftNav .unit:nth-child(4) { width: 237px; }
  #ftNav .unit .tit { margin-bottom: 29px; padding: 0; font-size: 1.8rem; line-height: 1.5555555556; transition: all 0.3s ease; cursor: default; }
  #ftNav .unit .tit .en { width: auto; font-size: 2.4rem; line-height: 1.1666666667; padding-right: 18px; letter-spacing: .075em; }
  #ftNav .unit .tit .txt { font-size: 1.8rem; line-height: 1.5555555556; }
  #ftNav .unit .list { display: block; padding-left: 11px; }
  #ftNav .unit .list li { border-top: 0; background: transparent; font-size: 1.4rem; line-height: 2.5714285714; }
  #ftNav .unit .list li a { display: inline; padding: 0; text-decoration: none; }
  #ftNav .unit .list li a[target="_blank"] { position: static; }
  #ftNav .unit .list li a[target="_blank"]::after { position: relative; top: 2px; right: auto; display: inline-block; width: 14px; height: 14px; margin-left: 11px; }
  #ftNav .unit .list li a:hover { text-decoration: underline; }
  #ftNav .unit .list li .child { padding-top: 2px; padding-left: 22px; } }

/* #ftInfo
================================================ */
#ftInfo { padding: 40px 15px 20px; text-align: center; }
#ftInfo .logo { width: 160px; margin: 0 auto 33px; }
#ftInfo .logo a { display: block; font-size: 1.2rem; line-height: 1.5; text-decoration: none; }
#ftInfo .logo a .img { display: block; margin-bottom: 8px; }
#ftInfo .cr { color: #c1c1c1; font-size: 1rem; font-weight: 700; line-height: 1.5; }
@media all and (min-width: 769px) { #ftInfo { position: relative; padding: 54px 44px 53px; text-align: left; }
  #ftInfo .logo { width: auto; margin: 0; }
  #ftInfo .logo a { overflow: hidden; }
  #ftInfo .logo a .img { float: left; width: 309px; margin-right: 24px; margin-bottom: 0; }
  #ftInfo .logo a .txt { font-size: 2.5rem; }
  #ftInfo .cr { position: absolute; bottom: 15px; right: 44px; font-size: 1.2rem; } }

/*=============================================================
	05_helper
=============================================================*/
/*!  .js-name
================================================ */
/*=============================================================
	06_lib
=============================================================*/
