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

body { min-width: 320px; overflow: hidden; font-size: 1.5rem; line-height: 1.8; color: #fff; letter-spacing: .06em; font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif; background: #222; }

@media screen and (min-width: 600px) { body { box-sizing: border-box; min-width: 1280px; padding-left: 80px; } }

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

a { -webkit-transition: all 0.3s ease; transition: all 0.3s ease; color: inherit; text-decoration: underline; }

@media screen and (min-width: 600px) { a:hover { text-decoration: none; }
  a.opacity:hover { opacity: .8; }
  a[href^=tel] { pointer-events: none; } }

em, strong, span { font-weight: inherit; }

/* pc <--> sp切り替え
-------------------------------------- */
#mediaQuery { display: none; font-family: 'sp'; }

@media screen and (min-width: 600px) { #mediaQuery { font-family: 'pc'; } }

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

@media screen and (min-width: 600px) { .viewSp { display: none !important; } }

/* font
-------------------------------------- */
.fontOzwald { font-family: "Oswald", sans-serif; font-weight: 700; }

/* clearfix
-------------------------------------- */
.cf:after { content: ''; display: block; clear: both; }

/* layout
-------------------------------------- */
.mod_inner01 { padding: 0 20px; }

@media screen and (min-width: 600px) { .mod_inner01 { box-sizing: border-box; width: 1200px; margin-right: auto; margin-left: auto; padding: 0; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; } }

@media screen and (min-width: 600px) { #home .mod_inner01 { padding: 0 85px; } }

@media screen and (min-width: 1904px) { #home .mod_inner01 { padding: 0; } }

/*  #contents
================================================ */
#contents.is_column2 { background: #333; }

#contents.is_column2 .contentsInner { padding: 50px 20px 60px; }

@media screen and (min-width: 600px) { #contents.is_column2 .contentsInner { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 100px 0 120px; }
  #contents.is_column2 #main { width: 930px; }
  #contents.is_column2 #sidebar { width: 220px; } }

/*  03_layout
================================================ */
/* #breadcrumb
================================================ */
#breadcrumb { letter-spacing: -.5em; }

#breadcrumb li { display: inline-block; letter-spacing: 0; margin-right: 5px; }

#breadcrumb li + li:before { margin-right: 8px; content: '>'; }

/*  .ftAccess
================================================ */
#gFooter .ftAccess { background: #393939; }

#gFooter .ftAccess .bgTxt { position: absolute; top: -72px; right: -25px; text-align: right; font-size: 7.5rem; letter-spacing: .02em; color: #9a9a9a; opacity: .06; line-height: 1; }

#gFooter .ftAccess .inner { padding-top: 50px; padding-bottom: 57px; }

#gFooter .ftAccess .listMap li + li { margin-top: 35px; }

#gFooter .ftAccess .listMap .map { position: relative; }

#gFooter .ftAccess .listMap .map:before { content: ""; display: block; width: 100%; padding-top: 45%; }

#gFooter .ftAccess .listMap .map iframe { position: absolute; top: 0; right: 0; bottom: 0; left: 0; width: 100%; height: 100%; }

#gFooter .ftAccess .listMap address { margin-top: 20px; padding-left: 20px; border-left: 1px solid #fff; }

#gFooter .ftAccess .listMap address span { display: block; padding-bottom: 8px; line-height: 1; font-size: 2rem; font-weight: 700; }

#gFooter .ftAccess .facebook { 
  position: relative; 
  /* margin-top: 60px;  */
  padding: 40px 43px; 
  background: #222; 
}

#gFooter .ftAccess .facebook .tit { font-size: 3rem; }

#gFooter .ftAccess .iframe { margin-top: 25px; }

@media screen and (min-width: 600px) { #gFooter .ftAccess { position: relative; overflow: hidden; }
  #gFooter .ftAccess .bgTxt { top: auto; bottom: -10px; right: -25px; font-size: 20rem; }
  #gFooter .ftAccess .inner { padding-top: 100px; padding-bottom: 100px; }
  #gFooter .ftAccess .listMap { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  #gFooter .ftAccess .listMap li { width: calc(50% - 20px); }
  #gFooter .ftAccess .listMap li + li { margin: 0 0 0 40px; }
  #gFooter .ftAccess .listMap .map:before { padding-top: 260px; }
  #gFooter .ftAccess .listMap address { margin-top: 30px; padding-left: 30px; }
  #gFooter .ftAccess .listMap address span { padding-bottom: 12px; font-size: 1.8rem; }
  #gFooter .ftAccess .facebook { 
    overflow: hidden; 
    /* margin-top: 75px;  */
    padding: 79px 100px; 
  }
  #gFooter .ftAccess .facebook .tit { float: left; font-size: 6rem; }
  #gFooter .ftAccess .facebook .iframe { float: right; width: 500px; } }

@media screen and (min-width: 1904px) { #gFooter .ftAccess .bgTxt { font-size: 30.4rem; bottom: 30px; }
  #gFooter .ftAccess .inner { padding-top: 120px; padding-bottom: 116px; } }

/*  .ftLink
================================================ */
#gFooter .ftLink { position: relative; }

#gFooter .ftLink .pageTop { position: absolute; top: 0; right: -20px; z-index: 1; -webkit-transform: rotate(90deg); -ms-transform: rotate(90deg); transform: rotate(90deg); font-size: 1.2rem; font-weight: 700; }

#gFooter .ftLink .pageTop .arw { display: inline-block; width: 7px; height: 23px; margin-right: 20px; background: url("../img/common/ico_pagetop01_sp.png") no-repeat center; background-size: contain; -webkit-transform: rotate(-90deg); -ms-transform: rotate(-90deg); transform: rotate(-90deg); }

#gFooter .ftLink .inner { opacity: .4; padding-top: 38px; padding-bottom: 38px; }

#gFooter .ftLink .listLink { overflow: hidden; }

#gFooter .ftLink .listLink + .listLink { margin-top: 20px; }

#gFooter .ftLink .fb { position: absolute; right: 15px; bottom: 30px; width: 30px; height: 30px; }

#gFooter .ftLink .fb:hover { opacity: 0.7; }

#gFooter .ftLink .home { padding-bottom: 14px; }

#gFooter .ftLink a, #gFooter .ftLink .parent { text-decoration: none; font-weight: 700; }

#gFooter .ftLink .parent + .parent { margin-top: 15px; }

#gFooter .ftLink li { float: left; width: 100%; }

#gFooter .ftLink .half { width: 50%; }

#gFooter .ftLink .child { margin-top: 2px; font-size: 1.3rem; }

#gFooter .ftLink .child a { font-weight: 500; }

#gFooter .ftLink .child a:before { content: "ー "; }

@media screen and (min-width: 600px) { #gFooter .ftLink .pageTop { top: auto; bottom: -6px; right: 0; }
  #gFooter .ftLink .pageTop a { color: #9a9a9a; }
  #gFooter .ftLink .pageTop a:hover { text-decoration: none; }
  #gFooter .ftLink .pageTop .arw { width: 7px; height: 32px; margin: 0 28px -3px 0; background-image: url("../img/common/ico_pagetop01_pc.png"); }
  #gFooter .ftLink .inner { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; padding-top: 72px; padding-bottom: 60px; }
  #gFooter .ftLink .listLink { box-sizing: border-box; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; width: calc(50% - 48px); padding-right: 62px; }
  #gFooter .ftLink .listLink + .listLink { width: calc(50% + 48px); margin-top: 0; padding-right: 0; }
  #gFooter .ftLink .fb { position: absolute; right: 0; bottom: 50px; width: 50px; height: 50px; }
  #gFooter .ftLink li { float: none; }
  #gFooter .ftLink a:hover { text-decoration: underline; }
  #gFooter .ftLink .home { width: auto; }
  #gFooter .ftLink .parent { width: 100%; }
  #gFooter .ftLink .parent + .parent { margin-top: 0; }
  #gFooter .ftLink .half { width: auto; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  #gFooter .ftLink .has_child { -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-pack: start; -ms-flex-pack: start; justify-content: flex-start; }
  #gFooter .ftLink .has_parent_list { display: block; box-sizing: border-box; width: 374px; padding: 0 0 0 40px; letter-spacing: -.5em; }
  #gFooter .ftLink .has_parent_list .parent { display: inline-block; width: auto; letter-spacing: .06em; }
  #gFooter .ftLink .has_parent_list .parent + .parent { margin-left: 38px; }
  #gFooter .ftLink .child { width: 100%; margin-top: 20px; line-height: 2.31; } }

@media screen and (min-width: 1904px) { #gFooter .ftLink .inner { padding-top: 92px; }
  #gFooter .ftLink .listLink { padding-right: 90px; }
  #gFooter .ftLink .has_parent_list { width: 472px; }
  #gFooter .ftLink .has_parent_list .parent + .parent { margin-left: 87px; } }

/*  .ftCopyright
================================================ */
#gFooter .ftCopyright { text-align: right; font-size: 1.1rem; color: #595959; }

#gFooter .ftCopyright .inner { border-top: 1px solid #363636; padding-top: 20px; padding-bottom: 20px; }

@media screen and (min-width: 600px) { #gFooter .ftCopyright .inner { padding-top: 30px; padding-bottom: 30px; } }

/* #gHeader
================================================ */
#gHeader .areaHead { position: relative; height: 60px; background: #222; z-index: 100; }

#gHeader .logo { width: 83px; line-height: 1; text-align: center; }

#gHeader .logo a { display: block; padding: 8px 20px 0; }

#gHeader .logo .logo01 { display: inline-block; width: 32px; }

#gHeader .logo .logo02 { display: inline-block; width: 47px; margin-top: 3px; }

#gHeader .gnavBtn { position: fixed; top: 0; right: 0; width: 60px; height: 60px; cursor: pointer; background: #222; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#gHeader .gnavBtn .line { position: absolute; left: 16px; height: 2px; background: #fff; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#gHeader .gnavBtn .line:nth-child(1) { top: 14px; width: 23px; }

#gHeader .gnavBtn .line:nth-child(2) { top: 21px; width: 18px; }

#gHeader .gnavBtn .line:nth-child(3) { top: 28px; width: 13px; }

#gHeader .gnavBtn.is_active .line:nth-child(1) { top: 22px; left: 22px; width: 15px; -webkit-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }

#gHeader .gnavBtn.is_active .line:nth-child(2) { -webkit-transform: translateX(300%); -ms-transform: translateX(300%); transform: translateX(300%); }

#gHeader .gnavBtn.is_active .line:nth-child(3) { top: 22px; left: 22px; width: 15px; -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }

#gHeader .gnavBtn .txt { position: absolute; left: 16px; bottom: 11px; width: 100%; font-size: 1rem; line-height: 1; text-align: left; }

@media screen and (min-width: 600px) { #gHeader { position: fixed; top: 0; bottom: 0; left: 0; z-index: 10; }
  #gHeader .areaHead { width: 80px; height: 100%; }
  #gHeader .logo { width: 200px; height: 200px; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gHeader .logo a { box-sizing: border-box; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; width: 100%; height: 100%; padding: 0 46px; background: #222; }
  #gHeader .logo .logo01 { display: block; width: 74px; margin: 0 auto; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gHeader .logo .logo02 { display: block; width: 110px; margin: 20px auto 0; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #gHeader .logo.is_small { width: 80px; height: 80px; }
  #gHeader .logo.is_small a { padding: 0; }
  #gHeader .logo.is_small .logo01 { width: 46px; }
  #gHeader .logo.is_small .logo02 { display: none; }
  #gHeader .gnavBtn { position: absolute; top: 50%; width: 80px; height: 80px; margin-top: -40px; overflow: hidden; }
  #gHeader .gnavBtn .line { left: 22px; height: 3px; }
  #gHeader .gnavBtn .line:nth-child(1) { top: 15px; width: 36px; }
  #gHeader .gnavBtn .line:nth-child(2) { top: 27px; width: 26px; }
  #gHeader .gnavBtn .line:nth-child(3) { top: 40px; width: 16px; }
  #gHeader .gnavBtn.is_active .line:nth-child(1) { top: 37px; left: 21px; width: 36px; }
  #gHeader .gnavBtn.is_active .line:nth-child(3) { top: 37px; left: 21px; width: 36px; }
  #gHeader .gnavBtn .txt { left: 21px; bottom: 16px; font-size: 1.2rem; }
  #gHeader .gnavBtn.is_active .txt { opacity: 0; } }

/*  #gNav
================================================ */
#gNav { position: fixed; z-index: 20; top: 0; bottom: 0; right: 0; left: 0; -webkit-transform: translateX(120%); -ms-transform: translateX(120%); transform: translateX(120%); width: 100%; overflow-y: scroll; background: #222; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }

#gNav.is_active { -webkit-transform: translateX(0); -ms-transform: translateX(0); transform: translateX(0); }

#gNav .inner { padding-top: 70px; padding-bottom: 40px; }

#gNav .gNavContent { position: absolute; top: 0; left: 0; width: 100%; }

#gNav .areaLink { position: relative; padding-bottom: 40px; }

#gNav .areaLink .listLink { border-bottom: 1px solid #393939; }

#gNav .areaLink .listLink li { border-top: 1px solid #393939; }

#gNav .areaLink .listLink a, #gNav .areaLink .listLink .parent { display: block; padding: 13px 0; text-decoration: none; font-weight: 700; }

#gNav .areaLink .listLink .parent { padding-bottom: 0; }

#gNav .areaLink .listLink .child { padding: 8px 0 15px; opacity: .4; font-size: 1.3rem; }

#gNav .areaLink .listLink .child li { border: 0; }

#gNav .areaLink .listLink .child a { padding: 0; font-weight: 500; }

#gNav .areaLink .listLink .child a:before { content: "ー "; }

#gNav .areaLink .fb { position: absolute; left: 0; bottom: 0; width: 30px; height: 30px; }

#gNav .areaLink .fb:hover { opacity: 0.7; }

#gNav .listContact { margin-top: 40px; background: #393939; text-align: center; }

#gNav .listContact li { padding: 28px 28px 30px; }

#gNav .listContact li + li { border-top: 1px solid #4d4d4d; }

#gNav .listContact .tit { line-height: 1.33; font-weight: 700; }

#gNav .listContact .tel { margin-top: 12px; }

#gNav .listContact .btn { margin-top: 13px; }

#gNav .gnavClose { box-sizing: border-box; width: 175px; margin: 40px auto 0; padding: 11px; border: 1px solid #8f8f8f; text-align: center; font-size: 1.5rem; cursor: pointer; }

#gNav .gnavClose span { position: relative; display: inline-block; padding-left: 23px; font-weight: 500; }

#gNav .gnavClose span:before, #gNav .gnavClose span:after { position: absolute; top: 50%; left: 2px; content: ""; display: block; width: 15px; height: 2px; margin-top: -1px; background: #fff; }

#gNav .gnavClose span:before { -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }

#gNav .gnavClose span:after { -webkit-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }

@media screen and (min-width: 600px) { #gNav { -webkit-transform: translateX(-120%); -ms-transform: translateX(-120%); transform: translateX(-120%); }
  #gNav::-webkit-scrollbar { display: none; }
  #gNav .gNavContent { box-sizing: border-box; left: 90px; width: calc(100% - 90px); margin: 0; }
  #gNav .inner { padding: 70px 0; }
  #gNav .areaLink { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  #gNav .areaLink .fb { left: 650px; bottom: -20px; width: 50px; height: 50px; }
  #gNav .listLink { width: calc(50% - 40px); font-size: 1.8rem; }
  #gNav .listLink li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; border-top: 1px solid #393939; }
  #gNav .listLink a, #gNav .listLink .parent { padding: 24px 0; }
  #gNav .listLink a:hover, #gNav .listLink .parent:hover { text-decoration: underline; }
  #gNav .listLink .parent { width: 202px; padding-bottom: 0; }
  #gNav .listLink .parent.is_small { width: 128px; }
  #gNav .listLink .child { width: calc(100% - 202px); padding: 20px 0; font-size: 1.5rem; line-height: 2.67; }
  #gNav .listLink .child.is_column2 { overflow: hidden; }
  #gNav .listLink .child.is_column2 li { float: left; width: 50%; }
  #gNav .listLink .parent.is_small + .child { width: calc(100% - 128px); }
  #gNav .listContact { margin-top: 60px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  #gNav .listContact li { box-sizing: border-box; width: 50%; 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; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 40px 120px; }
  #gNav .listContact li + li { border-top: 0; border-left: 1px solid #4d4d4d; }
  #gNav .listContact .tit { font-size: 1.8rem; }
  #gNav .listContact .tel { margin-top: 14px; padding: 15px 0; }
  #gNav .listContact .btn { margin-top: 14px; width: 100%; } }

/*  .lNav
================================================ */
.lNav { margin-top: 32px; }

.lNav:first-child { margin-top: 0; }

.lNav .list { padding: 0 22px; text-align: center; }

.lNav .list li + li { margin-top: -1px; }

.lNav .list a { position: relative; display: block; padding: 10px 35px; border: 1px solid #d6d6d6; text-decoration: none; }

.lNav .list a:after { position: absolute; top: 15px; right: 15px; content: ""; display: block; width: 10px; height: 10px; border-style: solid; border-width: 1px 1px 0 0; -webkit-transform: rotate(135deg); -ms-transform: rotate(135deg); transform: rotate(135deg); }

.lNav .list .is_current a { background: #222; }

.lNav .list.is_no_ico a:after { display: none; }

.lNav .list .navTit_en { font-size: 3rem; font-weight: 700; line-height: 1.2; }

.lNav .list .navTit_ja { font-size: 1.5rem; font-weight: 700; }

.lNav .list .navTxt { padding: 15px 0; font-size: 1.4rem; text-align: left; }

.lNav.is_arw_bottom .list a { padding: 25px; }

.lNav.is_arw_bottom .list a:after { top: auto; right: auto; bottom: 20px; left: 50%; -webkit-transform: translateX(-50%) rotate(135deg); -ms-transform: translateX(-50%) rotate(135deg); transform: translateX(-50%) rotate(135deg); }

@media screen and (min-width: 600px) { .lNav { margin: 45px -120%; padding: 0 120%; border-width: 1px 0; border-style: solid; border-color: #d6d6d6; }
  .lNav:first-child { margin-top: 0; }
  .lNav .list { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; padding: 0; }
  .lNav .list li { -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
  .lNav .list li + li { margin-top: 0; }
  .lNav .list a { padding: 16px 30px; border-width: 0 0 0 1px; }
  .lNav .list a:after { top: 21px; right: 22px; width: 8px; height: 8px; }
  .lNav .list a:hover { background: #222; }
  .lNav .list li:last-child a { border-right-width: 1px; }
  .lNav .navTit_en { font-size: 4rem; }
  .lNav .navTit_ja { padding-top: 7px; font-size: 1.5rem; }
  .lNav .navTxt { padding: 25px 0 30px; }
  .lNav.is_arw_bottom .list a { padding: 40px 30px; }
  .lNav.is_arw_bottom .list a:after { width: 8px; height: 8px; bottom: 30px; } }

/* #mainVisual TOPページ
================================================ */
#mainVisual { position: relative; }

#mainVisual .inner { position: absolute; top: 50%; left: 0; width: 100%; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); margin-top: -14px; }

#mainVisual .mainEn { font-size: 7rem; font-weight: 700; line-height: 1; letter-spacing: 0; }

#mainVisual .mainTit { position: relative; margin-top: 24px; padding-top: 23px; font-size: 1rem; }

#mainVisual .mainTit:before { position: absolute; top: 0; left: 0; content: ""; display: block; width: 75px; height: 1px; background: #9a9a9a; }

#mainVisual .mainTit .tit { font-size: 1.8rem; font-weight: 700; line-height: 1.5; letter-spacing: .06em; }

#mainVisual .mainTit .txt { margin-top: 14px; }

#mainVisual .scroll { position: absolute; bottom: 0; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); font-size: 1rem; letter-spacing: .02em; }

#mainVisual .scroll a { position: relative; display: block; padding-bottom: 50px; text-decoration: none; }

#mainVisual .scroll .arw { position: absolute; bottom: 0; left: 50%; display: block; width: 1px; height: 40px; background: #fff; }

@media screen and (min-width: 600px) { #mainVisual .bg .img { overflow: hidden; height: 100vh; background: no-repeat center; background-size: cover; }
  #mainVisual .bg .img.img01 { background-image: url("../img/home/bg_mainimg01-pc.jpg"); }
  #mainVisual .bg .img.img02 { background-image: url("../img/home/bg_mainimg02-pc.jpg"); }
  #mainVisual .bg .img.img03 { background-image: url("../img/home/bg_mainimg03-pc.jpg"); }
  #mainVisual .listContact { position: absolute; right: 0; top: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; width: 440px; height: 140px; background: #222; line-height: 1; }
  #mainVisual .listContact li { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
  #mainVisual .listContact .tel { width: calc(100% - 132px); font-size: 2.4rem; }
  #mainVisual .listContact .tel a { text-decoration: none; }
  #mainVisual .listContact .tel span { position: relative; display: inline-block; padding-left: 22px; }
  #mainVisual .listContact .tel span:before { position: absolute; top: 3px; left: 0; content: ""; display: block; width: 16px; height: 22px; background: url("../img/common/ico_tel01.png") no-repeat center; background-size: contain; }
  #mainVisual .listContact .btn { width: 132px; }
  #mainVisual .listContact .btn a { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; width: 100%; height: 100%; }
  #mainVisual .listContact .btn a:before { position: absolute; left: 0; top: 50%; content: ""; display: block; width: 2px; height: 40px; margin-top: -20px; background: #393939; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  #mainVisual .listContact .btn a:hover { background: #1065c6; }
  #mainVisual .listContact .btn a:hover:before { background: #2875cc; }
  #mainVisual .listContact .btn img { width: 22px; }
  #mainVisual .inner { left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: 1030px; margin-top: -14px; }
  #mainVisual .mainEn { font-size: 18rem; }
  #mainVisual .mainTit { position: absolute; right: -53px; bottom: -56px; margin-top: 0; padding: 0 0 0 40px; }
  #mainVisual .mainTit:before { width: 1px; height: 100%; }
  #mainVisual .mainTit .tit { font-size: 2.6rem; line-height: 1.8; }
  #mainVisual .mainTit .txt { margin-top: 11px; font-size: 1.6rem; }
  #mainVisual .scroll { font-size: 1.2rem; }
  #mainVisual .scroll a { padding-bottom: 64px; }
  #mainVisual .scroll .arw { height: 44px; } }

/* #mainImg 下層ページ
================================================ */
#mainImg { position: relative; }

#mainImg .areaTxt { position: absolute; top: 50%; left: 0; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); text-align: center; width: 100%; }

#mainImg .mainEn { font-size: 4.3rem; font-weight: 700; letter-spacing: 0; line-height: 1; }

#mainImg .mainTit { margin-top: 8px; font-size: 1.3rem; font-weight: 700; letter-spacing: .06em; }

@media screen and (min-width: 600px) { #mainImg { position: relative; height: 100vh; }
  #mainImg .areaTxt { top: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; height: 200px; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); }
  #mainImg .mainEn { font-size: 7rem; }
  #mainImg .mainTit { margin-top: 8px; font-size: 1.8rem; }
  #mainImg .img { position: absolute; left: 0; bottom: 0; width: 100%; height: calc(100vh - 200px); background: no-repeat center; background-size: cover; }
  #mainImg .img img { width: 100%; max-width: none; }
  #mainImg .scroll { position: absolute; bottom: 0; left: 50%; -webkit-transform: translateX(-50%); -ms-transform: translateX(-50%); transform: translateX(-50%); font-size: 1.2rem; letter-spacing: .02em; }
  #mainImg .scroll a { position: relative; display: block; padding-bottom: 64px; text-decoration: none; }
  #mainImg .scroll .arw { position: absolute; bottom: 0; left: 50%; display: block; width: 1px; height: 44px; background: #fff; } }

/* #sidebar
================================================ */
#sidebar { margin-top: 45px; }

#sidebar .sidePostWrap .list { margin-top: 15px; }

#sidebar .sideCats { margin-top: 38px; }

#sidebar .sideCats .sideList { padding-top: 3px; }

#sidebar .sideCats .sideItem + .sideItem { padding-top: 2px; }

#sidebar .sideCats .sideItem a { display: block; width: 100%; text-decoration: none; }

@media screen and (min-width: 600px) { #sidebar { margin-top: 0px; }
  #sidebar .sidePostWrap .list { margin-top: 12px; }
  #sidebar .sideCats { margin-top: 35px; }
  #sidebar .sideCats .sideList { padding-top: 17px; }
  #sidebar .sideCats .sideItem a:hover { text-decoration: underline; } }

/*  05_helper
================================================ */
/*!  .js-modal-layer
<p class="js-modal-trigger" data-modal="popup01">トリガー</p>
<div class="js-modal-layer" data-modal="popup01">
	<div class="js-modal-content">
		<div class="js-modal-close" data-modal="popup01">閉じる</div>
		ここにモーダルの中身のソース
	</div>
</div>
================================================ */
.js-modal-layer { display: none; position: fixed; z-index: 20; top: 0; bottom: 0; left: 0; width: 100%; overflow-y: scroll; background: rgba(51, 51, 51, 0.9); }

.js-modal-layer .js-modal-content { box-sizing: border-box; position: absolute; top: 50%; left: 0; width: 100%; margin: 30px 0; -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); transform: translateY(-50%); }

.js-modal-layer .js-modal-close { position: absolute; top: 0; right: 0; z-index: 1; background: #333; width: 40px; height: 40px; overflow: hidden; text-indent: 200%; white-space: nowrap; cursor: pointer; }

.js-modal-layer .js-modal-close:before, .js-modal-layer .js-modal-close:after { position: absolute; top: 50%; left: 14px; content: ""; display: block; width: 14px; height: 2px; margin-top: -1px; background: #fff; }

.js-modal-layer .js-modal-close:before { -webkit-transform: rotate(45deg); -ms-transform: rotate(45deg); transform: rotate(45deg); }

.js-modal-layer .js-modal-close:after { -webkit-transform: rotate(-45deg); -ms-transform: rotate(-45deg); transform: rotate(-45deg); }

@media screen and (min-width: 600px) { .js-modal-layer .js-modal-content { box-sizing: border-box; width: 1200px; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); margin: 70px 0; padding: 0 120px; }
  .js-modal-layer .js-modal-close { top: -1px; right: 120px; width: 70px; height: 70px; -webkit-transition: all 0.3s ease; transition: all 0.3s ease; }
  .js-modal-layer .js-modal-close:hover { opacity: .7; }
  .js-modal-layer .js-modal-close:before, .js-modal-layer .js-modal-close:after { left: 22px; width: 24px; } }



.banner_area_top{
  padding: 40px 0px 10px 0px;
  position: relative;
  z-index: 111;
}

.banner_area_top .banner + .banner{
  margin-top: 20px;
}


@media screen and (min-width: 600px) {
  .banner_area_top{
    padding: 50px 0px;
    display: flex;
    justify-content: space-between;
    max-width: 1030px;
    margin: 0px auto;
  }
  .banner_area_top .banner + .banner{
    margin-top: 0px;
  }
  .banner_area_top .banner{
    width: 48%;
  }
}


@media screen and (min-width: 1280px) {
  .banner_area_top{
    padding: 90px 0px 50px 0px;
  }
  .banner_area_top .banner{
    width: 500px;
  }
  .banner_area_top .banner a{
    transition: all 0.2s ease-in-out;
  }
  .banner_area_top .banner a:hover{
    opacity: 0.8;
  }
}





