@charset "UTF-8";

/* ****************************************************
Theme Name: sakura-k.co.jp
Theme URI: https://sakura-k.co.jp/
Description: さくら建設のテーマです。
Version: 1.0
Author: さくら建設
***************************************************** */

a:link    {cursor: pointer; }
a:visited {  }
a:hover   {  }
a:active  {  }

h1 {  }



/* # body
---------------------------------------------------------------------------- */
body {
}


/* -- width  --*/
.w500{width:500px; margin: 0 auto;}.w510{width:510px; margin: 0 auto;}.w520{width:520px; margin: 0 auto;}.w530{width:530px; margin: 0 auto;}.w540{width:540px; margin: 0 auto;}.w550{width:550px; margin: 0 auto;}.w560{width:560px; margin: 0 auto;}.w570{width:570px; margin: 0 auto;}.w580{width:580px; margin: 0 auto;}.w590{width:590px; margin: 0 auto;}
.w600{width:600px; margin: 0 auto;}.w610{width:610px; margin: 0 auto;}.w620{width:620px; margin: 0 auto;}.w630{width:630px; margin: 0 auto;}.w640{width:640px; margin: 0 auto;}.w650{width:650px; margin: 0 auto;}.w660{width:660px; margin: 0 auto;}.w670{width:670px; margin: 0 auto;}.w680{width:680px; margin: 0 auto;}.w690{width:690px; margin: 0 auto;}
.w700{width:700px; margin: 0 auto;}.w710{width:710px; margin: 0 auto;}.w720{width:720px; margin: 0 auto;}.w730{width:730px; margin: 0 auto;}.w740{width:740px; margin: 0 auto;}.w750{width:750px; margin: 0 auto;}.w760{width:760px; margin: 0 auto;}.w770{width:770px; margin: 0 auto;}.w780{width:780px; margin: 0 auto;}.w790{width:790px; margin: 0 auto;}
.w800{width:800px; margin: 0 auto;}.w810{width:810px; margin: 0 auto;}.w820{width:820px; margin: 0 auto;}.w830{width:830px; margin: 0 auto;}.w840{width:840px; margin: 0 auto;}.w850{width:850px; margin: 0 auto;}.w860{width:860px; margin: 0 auto;}.w870{width:870px; margin: 0 auto;}.w880{width:880px; margin: 0 auto;}.w890{width:890px; margin: 0 auto;}
.w900{width:900px; margin: 0 auto;}.w910{width:910px; margin: 0 auto;}.w920{width:920px; margin: 0 auto;}.w930{width:930px; margin: 0 auto;}.w940{width:940px; margin: 0 auto;}.w950{width:950px; margin: 0 auto;}.w960{width:960px; margin: 0 auto;}.w970{width:970px; margin: 0 auto;}.w980{width:980px; margin: 0 auto;}.w990{width:990px; margin: 0 auto;}
.w1000{width:1000px; margin: 0 auto;}.w1010{width:1010px; margin: 0 auto;}.w1020{width:1020px; margin: 0 auto;}.w1030{width:1030px; margin: 0 auto;}.w1040{width:1040px; margin: 0 auto;}.w1050{width:1050px; margin: 0 auto;}.w1060{width:1060px; margin: 0 auto;}.w1070{width:1070px; margin: 0 auto;}.w1080{width:1080px; margin: 0 auto;}.w1090{width:1090px; margin: 0 auto;}
.w1100{width:1100px; margin: 0 auto;}.w1110{width:1110px; margin: 0 auto;}.w1120{width:1120px; margin: 0 auto;}.w1130{width:1130px; margin: 0 auto;}.w1140{width:1140px; margin: 0 auto;}.w1150{width:1150px; margin: 0 auto;}.w1160{width:1160px; margin: 0 auto;}.w1170{width:1170px; margin: 0 auto;}.w1180{width:1180px; margin: 0 auto;}.w1190{width:1190px; margin: 0 auto;}
.w1200{width:1200px; margin: 0 auto;}.w1210{width:1210px; margin: 0 auto;}.w1220{width:1220px; margin: 0 auto;}.w1230{width:1230px; margin: 0 auto;}.w1240{width:1240px; margin: 0 auto;}.w1250{width:1250px; margin: 0 auto;}.w1260{width:1260px; margin: 0 auto;}.w1270{width:1270px; margin: 0 auto;}.w1280{width:1280px; margin: 0 auto;}.w1290{width:1290px; margin: 0 auto;}
.w1300{width:1300px; margin: 0 auto;}.w1310{width:1310px; margin: 0 auto;}.w1320{width:1320px; margin: 0 auto;}.w1330{width:1330px; margin: 0 auto;}.w1340{width:1340px; margin: 0 auto;}.w1350{width:1350px; margin: 0 auto;}.w1360{width:1360px; margin: 0 auto;}.w1370{width:1370px; margin: 0 auto;}.w1380{width:1380px; margin: 0 auto;}.w1390{width:1390px; margin: 0 auto;}
.w1400{width:1400px; margin: 0 auto;}
.w100{width:100%;}.w99{width:99%;}.w98{width:98%;}.w97{width:97%;}.w96{width:96%;}.w95{width:95%;}.w94{width:94%;}.w93{width:93%;}.w92{width:92%;}.w91{width:91%;}.w90{width:90%;}
.w89{width:89%;}.w88{width:88%;}.w87{width:87%;}.w86{width:86%;}.w85{width:85%;}.w84{width:84%;}.w83{width:83%;}.w82{width:82%;}.w81{width:81%;}.w80{width:80%;}
.w79{width:79%;}.w78{width:78%;}.w77{width:77%;}.w76{width:76%;}.w75{width:75%;}.w74{width:74%;}.w73{width:73%;}.w72{width:72%;}.w71{width:71%;}.w70{width:70%;}
.w69{width:69%;}.w68{width:68%;}.w67{width:67%;}.w66{width:66%;}.w65{width:65%;}.w64{width:64%;}.w63{width:63%;}.w62{width:62%;}.w61{width:61%;}.w60{width:60%;}
.w59{width:59%;}.w58{width:58%;}.w57{width:57%;}.w56{width:56%;}.w55{width:55%;}.w54{width:54%;}.w53{width:53%;}.w52{width:52%;}.w51{width:51%;}.w50{width:50%;}
.w49{width:49%;}.w48{width:48%;}.w47{width:47%;}.w46{width:46%;}.w45{width:45%;}.w44{width:44%;}.w43{width:43%;}.w42{width:42%;}.w41{width:41%;}.w40{width:40%;}
.w39{width:39%;}.w38{width:38%;}.w37{width:37%;}.w36{width:36%;}.w35{width:35%;}.w34{width:34%;}.w33{width:33%;}.w32{width:32%;}.w31{width:31%;}.w30{width:30%;}
.w29{width:29%;}.w28{width:28%;}.w27{width:27%;}.w26{width:26%;}.w25{width:25%;}.w24{width:24%;}.w23{width:23%;}.w22{width:22%;}.w21{width:21%;}.w20{width:20%;}
.w19{width:19%;}.w18{width:18%;}.w17{width:17%;}.w16{width:16%;}.w15{width:15%;}.w14{width:14%;}.w13{width:13%;}.w12{width:12%;}.w11{width:11%;}.w10{width:10%;}
.w9{width:9%;}.w8{width:8%;}.w7{width:7%;}.w6{width:6%;}.w5{width:5%;}.w4{width:4%;}.w3{width:3%;}.w2{width:2%;}.w1{width:1%;}
/* -- margin  --*/
.mb0{margin-bottom:0px !important;}.mb5{margin-bottom:5px !important;}.mb10{margin-bottom:10px !important;}.mb15{margin-bottom:15px !important;}
.mb20{margin-bottom:20px !important;}.mb25{margin-bottom:25px !important;}.mb30{margin-bottom:30px !important;}.mb35{margin-bottom:35px !important;}
.mb40{margin-bottom:40px !important;}.mb45{margin-bottom:45px !important;}.mb50{margin-bottom:50px !important;}.mb55{margin-bottom:55px !important;}
.mb60{margin-bottom:60px !important;}.mb65{margin-bottom:65px !important;}.mb70{margin-bottom:70px !important;}.mb75{margin-bottom:75px !important;}
.mb80{margin-bottom:80px !important;}.mb85{margin-bottom:85px !important;}.mb90{margin-bottom:90px !important;}.mb95{margin-bottom:95px !important;}.mb100{margin-bottom:100px !important;}

/* # header
---------------------------------------------------------------------------- */
#header {width: 100%;
  background-color: #fff;
  z-index: 10;
  position: fixed;
  top:0;
  box-sizing: border-box;
}

#header #logo {
  margin-left: 30px;
    width: 20%;
}

#header .head_nav {
  width: 100%;
	height:110px;
  margin: 0 auto;
}


#header .head_nav .row_menu{
	padding-right:30px;
}

#header .head_nav #nav{
    display: flex;
    align-items: center;
  width: 100%;
}

#header .head_nav #nav > ul > li {
  text-align: center;
  line-height: 1.2;
  margin-left: 1.2em;
  margin-right: 1.2em;
}
#header .head_nav #nav li#logo {
  margin-right: auto;
  text-align: left;
}

#header .head_nav #nav li#logo img {
  width: 85%;
}


#header .head_nav #nav li span {
  display: block;
}

#header .head_nav #nav li .en {
  letter-spacing: 0.05em;
  margin-bottom: .5em;
}

#header .head_nav #nav li .ja {
  letter-spacing: 0.05em;
}

#header .head_nav #nav li .anchor a {
  text-decoration: none;
  color: #000;
	padding: 10px 0;
  cursor: pointer;
}

#header .head_nav #nav li .anchor:hover {
  color: #ccc;
}


#header .head_nav #nav li.sns {

}
#header .head_nav #nav li.sns a {
  color: #fff;
  margin-left: 15px;
  font-size: 220%;
}

/**/

#header .head_nav #navt{
    display: flex;
    align-items: center;
  width: 100%;
	    justify-content: flex-end;
}

#header .head_nav #navt > ul > li {
  text-align: center;
  line-height: 1.2;
  margin-left: 0.8em;
  margin-right: 0.8em;	
    padding: 10px 0 5px;
}

#header .head_nav #navt li span {
  display: block;
}

#header .head_nav #navt li .ja {
  letter-spacing: 0.05em;
}

#header .head_nav #navt li .anchor a {
  text-decoration: none;
    padding: 4px 19px;
    cursor: pointer;
    font-size: 14px;
    display: block;
    border-radius: 20px;
}

#header .head_nav #navt li .anchor a.res{
    color: #fff;
    background: #09204D;
	border:solid 1px #09204D;
	transition: 1s all ease 0s;
}

#header .head_nav #navt li .anchor a.res:hover {
    background: #fff;
	color:#09204D;
}

#header .head_nav #navt li .anchor a.exc{
    color: #343C58;
	border:solid 1px #E3DDC6;
    background: #E3DDC6;
	transition: 1s all ease 0s;
}

#header .head_nav #navt li .anchor a.exc:hover {
    background: #fff;
}


/**/


#header .sns #com_name {
  font-size: 80%;
  color: #fff;
  margin-bottom: 5px;
}

#header .sns ul a i {
  color: #fff;
  font-size: 100%;
  margin-left: 10px;
}

.menu > ul > li > ul > li.nav_head {
  width: 900px;
margin: 0 auto;
text-align: left;
padding-bottom: 1em;
margin-bottom: 1em;
border-bottom: 1px #ccc solid;
color: #333;
font-weight: bold;
}

.menu > ul > li > ul  li.nav_child {
  margin-right: 30px;
  font-size:90%;
}
.menu > ul > li > ul  li.nav_child a {
  color:#333;
  margin-right: 10px;
  text-decoration: underline;
}

.menu > ul > li > ul  li.nav_child a:hover {
  color: #999;
  text-decoration: none;
}







/* 
 * 
 * 
 *　▼▼▼▼▼ Gnav part2　▼▼▼▼▼
 * 
 * 
---------------------------------------------------------------------------- */
/* -- clearfix  --*/
.cf:before, .cf:after {content:' '; display:table;}
.cf:after {clear:both;}

/* #Pjax
---------------------------------------------------------------------------- */

/* Pjax用オーバーレイ */
.js-layer {
  display: none;
  position: absolute;
  top: 0;
  left: 100%;
  z-index: 2000;
  width: 100%;
  height: 100%;
  background-color: #0e3a67;
}

/* 見出しアニメーション用 */
.block-revealer__element {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #000;
  pointer-events: none;
  opacity: 0;
}


/*  #common
---------------------------------------------------------------------------- */



/* ヘッダー
   ----------------------------------------------------------------- */
@media screen and (min-width: 1080px) {
  .l-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    width: 100%;
  }

  .header-inner {
    position: relative;
    z-index: 1003;
  }

  /* (展開時) */
  .company-open .header-inner,
  .interview-open .header-inner,
  .career-open .header-inner,
  .works-open .header-inner,
  .entry-open .header-inner { background-color: #fff; }

  /* (スクロール時) */
  .scroll-active .header-inner {
    background-color: #fff;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
    box-shadow: 0px 2px 7px 0px rgba(0,0,0,0.05);
    -webkit-box-shadow: 0px 2px 7px 0px rgba(0,0,0,0.05);
  -moz-box-shadow: 0px 2px 7px 0px rgba(0,0,0,0.05);
  }



  /* タイトル
  　 ----------------------- */
  .header-ttl-wrap {
    display: block;
    float: left;
    text-decoration: none;
  }

  .header-ttl-wrap:hover {
    opacity: 1;
  }

  /* ロゴ */
  .header-logo {
    display: block;
    float: left;
    width: 110px;
    height: 60px;
    padding-top: 20px;
    margin-left: 10px;
    text-align: center;
    background-color: rgba(255,255,255,0);
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
  }

  .header-logo img{
    width: 95px;
  }
 .header-logo {
  background: url(img/new/logo_b.png) no-repeat center center;
  background-size: 100%;
}

.scroll-active .header-logo {
  background: url(img/new/logo_b.png) no-repeat center center;
  background-size: 100%;
}


  /* (展開時) */
  .company-open .header-logo,
  .interview-open .header-logo,
  .career-open .header-logo,
  .works-open .header-logo,
  .entry-open .header-logo {
    width: 100px;
    height: 80px;
    padding-top: 0;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
  }
  .company-open .header-logo img,
  .interview-open .header-logo img,
  .career-open .header-logo img,
  .works-open .header-logo img,
  .entry-open .header-logo img { width: 64px; }

  /* (スクロール時) */
  .scroll-active .header-logo {
    width: 110px;
    height: 80px;
    padding-top: 30px;
    margin-left: 10px;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
  }
  .scroll-active .header-logo{
    padding-top: 0px;
  }
  .scroll-active .header-logo img { width: 64px; }



  /* テキスト */
  .header-ttl {
    display: none;
    float: left;
    padding: 29px 30px 0 35px;
  }

  .header-ttl-sub {
    display: block;
    margin-bottom: 6px;
    color: #333;
    font-size: 13px;
    line-height: 1;
    letter-spacing: 0.02rem;
  }

  .header-ttl-main {
    display: block;
    color: #222;
    font-size: 28px;
    font-family: brandon-grotesque, sans-serif;
    font-weight: 700;
    letter-spacing: 0.07rem;
    line-height: 1;
  }

  /* (展開時) */
  .company-open .header-ttl,
  .interview-open .header-ttl,
  .career-open .header-ttl,
  .works-open .header-ttl,
  .entry-open .header-ttl { display: block; }

  /* (スクロール時) */
  .scroll-active .header-ttl { display: block; }

  /* メニュー
  　 ----------------------- */
  .pc-header-none { display: none; }

  .header-menu {
    float: right;
  }

  .header-menu-item {
    float: left;
    margin-right: 40px;
  }

  /* 新卒・中途採用 */
  .header-menu-open {
    position: relative;
    display: block;
    padding: 30px 22px 30px 0;
    color: #333;
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.02rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    cursor: pointer;
    -webkit-transition: all .4s ease;
    transition: all .4s ease;
  }
  .header-menu-open.enb {
    font-size: 16px;
  }
  .header-menu-open:hover {
    color: #333;
    opacity: 1;
  }
.header-menu-open.entry_btn:hover{
	color: #222;
	background: #f6f6f6;
}

  .header-menu-open.entry_btn{
  background: #F7F4E8;
  padding: 15px 10px 15px 0;
  width: 140px;
  text-align: center;
  margin-top: 15px;
}
	
  .header-menu-open.entry_btn a{
		    color: #333;
    text-decoration: none;
	}

  .header-menu-open:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    width: 6px;
    height: 6px;
    border-bottom: 1px solid #333;
    border-right: 1px solid #333 ;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
  }
  .header-menu-open:hover::before {
    top: 52%;
    border-color: #333;
  }

  .header-menu-open.entry_btn:before{
    right: 15px;    
  }


  /* 通常リンク */
  .header-menu-link {
    position: relative;
    display: block;
    padding: 30px 0 30px;
    color: #333;
    font-size: 16px;
    line-height: 1;
    letter-spacing: 0.02rem;
    text-decoration: none;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
  }
 .header-menu-link.enb{
  font-size: 20px;
  padding: 40px 0;
 }

  .header-menu-link:hover {
    color: #333;
    opacity: 1;
  }

  .header-menu-open:after,
  .header-menu-link:after {
    content: "";
    position: absolute;
    bottom: 0px;
    left: 0;
    right: 0;
    width: 100%;
    height: 3px;
    background-color: #998E73;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    opacity: 0;
  }
  .header-menu-open:hover::after,
  .header-menu-link:hover::after { opacity: 1; }


  /* 【1】メニュー展開時 */

  /* テキスト */
  .company-open .header-menu-open,
  .company-open .header-menu-link,
  .interview-open .header-menu-open,
  .interview-open .header-menu-link,
  .career-open .header-menu-open,
  .career-open .header-menu-link,
  .works-open .header-menu-open,
  .works-open .header-menu-link{ color: #292c32; }
  .entry-open .header-menu-open,
  .entry-open .header-menu-link { color: #292c32; }
  .company-open .header-menu-open.entry_btn,
  .interview-open .header-menu-open.entry_btn,
  .career-open .header-menu-open.entry_btn,
  .works-open .header-menu-open.entry_btn{color: #292c32;}
  .company-open .header-menu-open:hover,
  .company-open .header-menu-link:hover,
  .interview-open .header-menu-open:hover,
  .interview-open .header-menu-link:hover,
  .career-open .header-menu-open:hover,
  .career-open .header-menu-link:hover,
  .works-open .header-menu-open:hover,
  .works-open .header-menu-link:hover ,
  .entry-open .header-menu-open:hover,
  .entry-open .header-menu-link:hover { color: #222; }


  /* 矢印 */
  .company-open .header-menu-open:before,
  .interview-open .header-menu-open:before,
  .career-open .header-menu-open:before,
  .works-open .header-menu-open:before,
  .entry-open .header-menu-open:before { border-color: #222; }
  .company-open .header-menu-open.entry_btn:before,
  .interview-open .header-menu-open.entry_btn:before,
  .career-open .header-menu-open.entry_btn:before,
  .works-open .header-menu-open.entry_btn:before { border-color: #fff; }
  .company-open .header-menu-open:hover::before,
  .interview-open .header-menu-open:hover::before,
  .career-open .header-menu-open:hover::before,
  .works-open .header-menu-open:hover::before,
  .entry-open .header-menu-open:hover::before { border-color: #222; }

  /* アクティブ時 */
  .header-menu-open.border-active { color: #222; }
  .entry-open .header-menu-open.border-active { background: #F7F4E8; }
  .header-menu-open.border-active:before { border-color: #222; }
  .header-menu-open.border-active:after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 3px;
    background-color: #222;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    opacity: 1;
  }



  /* 【2】スクロール時 */

  /* テキスト */
  .scroll-active .header-menu-open,
  .scroll-active .header-menu-link { color: #292c32; }
  .scroll-active .header-menu-open.entry_btn { color: #222; }
  .scroll-active .header-menu-open:hover,
  .scroll-active .header-menu-link:hover {
    color: #222;
    opacity: 1;
  }

  /* 矢印 */
  .scroll-active .header-menu-open:before { border-color: #222; }
  .scroll-active .header-menu-open.entry_btn:before { border-color: #222; }
  .scroll-active .header-menu-open:hover::before { border-color: #222; }

  /* アクティブ時 */
  .scroll-active.company-open .header-menu-open.border-active,
  .scroll-active.interview-open .header-menu-open.border-active,
  .scroll-active.career-open .header-menu-open.border-active,
  .scroll-active.works-open .header-menu-open.border-active,
  .scroll-active.entry-open .header-menu-open.border-active{color: #222;}
  .scroll-active.company-open .header-menu-open.border-active:before,
  .scroll-active.interview-open .header-menu-open.border-active:before,
  .scroll-active.career-open .header-menu-open.border-active:before,
  .scroll-active.works-open .header-menu-open.border-active:before,
  .scroll-active.entry-open .header-menu-open.border-active:before { border-color: #222; }



  /* オーバーレイ
   -----------------------------*/
  .overlay-company,
  .overlay-interview,
  .overlay-career,
  .overlay-works,
  .overlay-entry {
    content: '';
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0);
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
    z-index: 1001;
  }

  /* (展開時) */
  .company-open .overlay-company,
  .interview-open .overlay-interview,
  .career-open .overlay-career,
  .works-open .overlay-works,
  .entry-open .overlay-entry {
    visibility: visible;
    background: rgba(8,15,26,.5); /* オーバーレイの色 */
    -webkit-transform: translate3d(0, 0, 0); /* メニューの幅 */
    transform: translate3d(0, 0, 0); /* メニューの幅 */
  }


  /* 展開項目
     -----------------------------*/
  .header-menu-list-company,
  .header-menu-list-interview,
  .header-menu-list-career,
  .header-menu-list-works,
  .header-menu-list-entry {
    overflow: hidden;
    display: block;
    position: fixed;
    top: -320px;
    left: 0;
    right: 0;
    width: 100%;
    max-height:220px;
    margin-top:80px;
    background-color: #dae0e6;
    z-index: 1002;
    transition: all .5s ease;
    -webkit-overflow-scrolling: touch;
    opacity: 0;
  }

  /* (展開時) */
  .company-open .header-menu-list-company,
  .interview-open .header-menu-list-interview,
  .career-open .header-menu-list-career,
  .works-open .header-menu-list-works,
  .entry-open .header-menu-list-entry {
    -webkit-transform: translate3d(0, 320px, 0);
    transform: translate3d(0, 320px, 0);
  }

  /* リスト */
  .header-job-wrap {
    width: 1180px;
    width: 84.2857142857%;
    margin: 0 auto;
    padding: 30px 0 10px;
  }

  .header-job {
    overflow: hidden;
    margin-right: -20px;
    margin-right: -1.4285714286vw;
  }

  .header-job-link {
    position: relative;
    display: block;
    color: #292c32;
    font-size: 13px;
    line-height: 1.3846153846;
    text-decoration: none;
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
    box-sizing: inherit;
  }

  .header-job-link:hover {
    opacity: 1;
    color: #0e3a67;
  }

  .header-job-link:before {
    content: "";
    position: absolute;
    top: 50%;
    right: 14px;
    right: 1vw;
    width: 6px;
    width: 0.4285714286vw;
    height: 6px;
    height: 0.4285714286vw;
    border-bottom: 1px solid #222;
    border-right: 1px solid #222 ;
    -webkit-transform: translateY(50%) rotate(-45deg);
    transform: translateY(-50%) rotate(-45deg);
    -webkit-transition: all .2s ease;
    transition: all .2s ease;
  }

  .header-job-link:hover::before {
    right: 12px;
    right: 0.8571428571vw;
  }

  .header-job-item {
    float: left;
    width: 280px;
    width: 19vw;
    margin: 0 20px 20px 0;
    margin: 0 1.4285714286vw 20px 0;
    padding: 0;
    vertical-align: middle;
    background-color: #fff;
  }

  .header-job-item img { float: left; }

  .header-job-txt {
    display: table-cell;
    padding: 0 30px;
    padding: 0 2.1428571429vw;
    height: 70px;
    vertical-align: middle;
  }

  /* 非表示 */
  .header-menu-open-sp,
  .sp-job { display: none!important; }

}


/* ヘッダー
----------------------------------------------------------------- */
@media screen and (max-width: 1080px) {
  .l-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1000;
    display: block!important;
    width: 100%;
  }
  /* タイトル
   ----------------------- */
  .header-ttl-wrap {
    display: block;
    float: left;
    text-decoration: none;
  }
.scroll-active .header-ttl-wrap{
  background-color: rgba(255,255,255,0.7);
}

  .header-ttl-wrap:hover { opacity: 1; }
  /* ロゴ */
  .header-logo {
    position: relative;
    z-index: 1003;
    display: block;
    float: left;
    width: 82px;
    height: 60px;
    padding-top: 5px;
    text-align: center;
    background-color: #0e3a67;
    -webkit-transition: all .5s ease;
    transition: all .5s ease;
    pointer-events: auto;
        text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
  }
 .header-logo {
  background: url(img/new/logo_b.png) no-repeat center center;
  background-size: 100%;
}

.side-open .header-logo{
  background: url(img/new/logo_b.png) no-repeat center center;
  background-size: 100%;
}

.scroll-active .header-logo {
  background: url(img/new/logo_b.png) no-repeat center center;
  background-size: 100%;
}
  .header-ttl-wrap:hover .header-logo {
    background-color: #0e3a67;
  }
  .header-logo-svg {
    width: 33px;
    fill: #fff;
  }
  .header-logo-txt {
    display: none;
  }
  .header-ttl {
    display: none;
  }
  /* (展開時) */
  .side-open .header-ttl {
    position: absolute;
    top: 45px;
    left: 0;
    right: 0;
    z-index: 1002;
    display: block;
    width: 100%;
    text-align: center;
    font-size: 17px;
    font-family: brandon-grotesque, sans-serif;
    font-weight: 500;
    line-height: 1;
    letter-spacing: 0.08rem;
  }
  .side-open .header-ttl-wrap {
    pointer-events: none;
  }
  .side-open .header-ttl-sub {
    display: block;
    margin-bottom: 7px;
    color: #333;
    font-size: 12px;
  }
  .side-open .header-ttl-main {
    display: block;
    color: #333;
    font-size: 24px;
    font-family: brandon-grotesque, sans-serif;
    font-weight: 700;
    letter-spacing: 0.06rem;
  }
  /* ボタン
  -----------------------------*/
  .header-btn {
    position: fixed;
    right: 0;
    top: 0;
    display: block;
    z-index: 1003;
    width: 60px;
    height: 60px;
    cursor: pointer;
    background: rgba(255,255,255,0.7);
  }
  .side-open .header-btn {
    right: 6px;
    top: 6px;
    width: 54px;
    height: 54px;
  }

  .header-btn span {
    position: absolute;
    left: 30px;
    width: 20px;
    height: 1px;
    margin-left: -10px;
    background-color: #333;
    -webkit-transition: all .2s;
    transition: all .2s;
  }
  .header-btn span:nth-of-type(1) {
    top: 20px;
  }
  .header-btn span:nth-of-type(2) {
    top: 28px;
  }
  .header-btn span:nth-of-type(3) {
    top: 36px;
  }
  /* (展開時) */
  .header-btn.active span {
    background-color: #333;
  }
  .header-btn.active span:nth-of-type(1) {
    top: 28px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .header-btn.active span:nth-of-type(2) {
    opacity: 0;
  }
  .header-btn.active span:nth-of-type(3) {
    top: 28px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  /* メニュー
   -----------------------------*/
  .header-menu-wrap {
    display: block;
    position: fixed;
    top: 0;
    right: -100%;  /* メニューの幅 */
    width: 100%; /* メニューの幅 */
    height: 100%;
    padding-top: 80px;
    background-color: #fff;
    border: 6px solid #222;
    z-index: 1001;
    transition: all .5s ease;
	box-sizing: border-box;
    -webkit-overflow-scrolling: touch;
  }
  /* (展開時) */
  .side-open .header-menu-wrap {
    -webkit-transform: translate3d(-100%, 0, 0);
    transform: translate3d(-100%, 0, 0);
  }
  /* リスト */
  .header-menu {
    height: 100%;
    overflow: auto;
  }
  .header-menu-item {
    margin: 0 27px;
    line-height: 1;
    border-bottom: 1px solid #ebeff6;
  }
  .header-menu-item:first-child {
    border-top: 1px solid #ebeff6;
  }
  .header-menu-item a {
    display: block;
    padding: 27px 5px;
    color: #333;
    font-size: 15px;
    line-height: 1;
    text-decoration: none;
  }
  .header-menu-open-sp {
    display: block;
    position: relative;
    padding: 27px 5px;
    transition: all .4s;
    font-size: 15px;
  }

    /* アイコン */
  .header-menu-open-ico {
    position: absolute;
    top: 50%;
    right: 20px;
    display: block;
    width: 13px;
    height: 13px;
    margin-top: -6px;
    transition: all .4s;
  }

  .header-menu-open-ico span {
    position: absolute;
    display: inline-block;
    width: 13px;
    height: 1px;
    background-color: #0e3a67;
    transition: all .4s;
  }

  .header-menu-open-ico span:nth-of-type(1) {
    top: 50%;
    left: 0;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }

  .header-menu-open-ico span:nth-of-type(2) {
    top: 50%;
    left: 0;
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }

  /* (クラス「active」をもつとき) */
  .header-menu-open-sp.active {
    color: #0e3a67;
  }

  .header-menu-open-sp.active .header-menu-open-ico span:nth-of-type(1) {
    display: none;
  }

  .header-menu-open-sp.active .header-menu-open-ico span:nth-of-type(2) {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }

  /* 新卒・中途 */
  .sp-job {
    display: none;
    overflow: hidden;
    margin-bottom: 25px;
  }
  .sp-job-item a {
    position: relative;
    display: block;
    margin-bottom: 10px;
    padding: 22px 0 23px 80px;
    color: #333;
    font-size: 13px;
    line-height: 1.2;
    background-color: #f8fafc;
  }
  .sp-job-item a.newline {padding: 11px 0 10px 80px;}
  .sp-job-item a img {
    position: absolute;
    top: 0;
    left: 0;
    width: 60px;
  }
  /* エントリーボタン */
  .sp-entry-btn-wrap {
    overflow: hidden;
    margin: 40px 27px 35px;
  }
  .sp-entry-btn-fresh {
    display: block;
    float: left;
    width: 44%;
    padding: 22px 0;
    color: #0e3a67;
    text-decoration: none;
    text-align: center;
    font-size: 11px;
    line-height: 1;
    background-color: #fff;
    border-radius: 2.5px;
    border:solid 1px #0e3a67;
  }
  .sp-entry-btn-career {
    display: block;
    float: left;
    width: 44%;
    margin:0 4%;
    padding: 22px 0;
    color: #bfae84;
    text-decoration: none;
    text-align: center;
    font-size: 11px;
    line-height: 1;
    background-color: #0e3a67;
    border-radius: 2.5px;
    border:solid 1px #0e3a67;
  }
  .sp-entry-btn-arbeit {
    display: block;
    float: left;
    width: 30%;
    padding: 22px 0;
    color: #0e3a67;
    text-decoration: none;
    text-align: center;
    font-size: 11px;
    line-height: 1;
    background-color: #bfae84;
    border-radius: 2.5px;
    border:solid 1px #bfae84;
  }

  /* 非表示 */
  .header-menu-open,
  .header-menu-list-company,
  .header-menu-list-interview,
  .header-menu-list-career,
  .header-menu-list-works,
  .header-menu-list-entry,
  .sp-header-none {
    display: none;
  }

}


/* 
 * 
 * 
 * ▲▲▲▲▲　Gnav part2　▲▲▲▲▲
 * 
 * 
---------------------------------------------------------------------------- */






/* # gNavi
---------------------------------------------------------------------------- */
#nav {
}


#va2 {width: 100%;margin:0 auto 50px; position: relative;padding: 100px 0 0 250px;}
#va2 img {width: 100%;}

.slick-dots {bottom: 30px;}
.slick-dots li {margin: 0 10px;}
.slick-dots li button:hover:before,
.slick-dots li button:focus:before
{
    opacity: 1;
    color: #fff;
}
.slick-dots li button:before {font-size: 14px;color: #6e6e6f; opacity: 1;}
.slick-dots li.slick-active button:before {color: #fff;opacity: 1;}

.slideArea{position: relative;}
.message{
	z-index: 3;
    width: 235px;
    text-align: center;
    background-color: rgba(255, 255, 255, .8);
    position: absolute;
    bottom: 50px;
    left: 50px;
    padding: 50px 40px 50px 60px;
}
.message img{
	width:100%;
}

.iconScrol{position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); -webkit-transform:translateX(-50%); z-index: 9;}

.iconScrol p{ color: #fff; text-align: center; border: 2px #fff solid; border-radius: 50%; width: 4em; height: 4em; line-height: 4em; position: relative; font-size: 80%;}

.iconScrol p::after{
  content: "\f107";
  font-family: "FontAwesome";
  font-weight: 900;
  position: absolute;
  left: 50%;
  bottom: -1em;
  transform: translateX(-50%);
  -webkit-transform:translateX(-50%);
  animation: scroll 2s ease-out infinite;
}

@keyframes scroll{
  40%{
    opacity: 1;
    transform: translateY(0) translateX(-50%);
  }
  80%{
    opacity: 1;
    transform: translateY(.8em) translateX(-50%);
  }
  100%{
    opacity: 0;
    transform: translateY(1em) translateX(-50%);
  }
}





/* # pageBody
---------------------------------------------------------------------------- */

#pagebody,
#footer  {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
#pagebody,
#footer {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
#pagebody,
#footer {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
#pagebody,
#footer {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
#pagebody,
#footer {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}


#pagebody .fadein,
#footer.fadein {
  opacity : 0;
  transform: translateY(20px);
  transition: all 1s;
}

.ja{
font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
}


/* # content
---------------------------------------------------------------------------- */


body#secondary #pagebody {
	    margin-top: 80px;
}

body#secondary .c_headarea {
    padding: 60px 0;
    background: #f5f5f5;
    margin-bottom: 3px;
}

body#secondary .c_headarea .head_des {
font-size: 28px;
    color: #333;
}

body#secondary #pagebody h1.cont_bar{
  font-size: 150%;
  font-weight: bold;
  margin-bottom: 50px;
}

body#secondary #pagebody h1.cont_bar span{
  /* background: linear-gradient(transparent 60%, #E3E8E9 60%);*/
}


body#secondary .header_c {
  background-color: #ffffff;
  height: 30px;
  overflow: hidden;
}
body#secondary .hc_side {
  width: 270px;
  box-sizing: border-box;
}
body#secondary .header_c .hc_side {
  background-color: #BFC6CD;
  height: 30px;
}
body#secondary .c_headarea {
}
body#secondary .c_headarea .head_des {
  background-position: bottom center;
  background-repeat: no-repeat;
  background-size: cover;
  box-sizing: border-box;
  color: #2B2B2B;
}

body#secondary .company .c_headarea .head_des {

}
body#secondary .business .c_headarea .head_des {
  background-image: url(../img/common/business_bg.png);
}
body#secondary .project .c_headarea .head_des {
  background-image: url(../img/common/project_bg.png);
}
body#secondary .contact .c_headarea .head_des {
}
body#secondary .gallery .c_headarea .head_des {
}
body#secondary .news .c_headarea .head_des {
  background-image: url(../img/common/news_bg.png);
}
body#secondary .notfound .c_headarea .head_des {
  background-image: url(../img/common/nf_bg.png);
}
body#secondary .info .c_headarea .head_des {
}
  
body#secondary .c_headarea .head_des h2.en {
  font-size: 200%;
  font-weight: 600;
  padding-top: 100px;
  line-height: 1.8;
}
body#secondary .c_headarea .head_des h1.ja {
  font-weight: 600;
  letter-spacing: 0.05em;
}
body#secondary #contents {
  background-color: #FFF;
}
body#secondary .contents_area {
  flex-direction: row-reverse;
  color: #333;
}

body#secondary .pankuzu {
  margin-bottom: 10px;
    font-size: 90%;
    padding-top: 10px;
    border-top: 1px solid #e4e4e4;
}

body#secondary .pankuzu li {
  margin-right: 5px;
  color: #666;
	font-size:12px;
}

body#secondary .pankuzu li a {
  color: #707070;
  text-decoration: none;
}

body#secondary .pankuzu li a:hover{
   text-decoration: none;
 }
body#secondary .text_area {
  box-sizing: border-box;
  padding: 50px 0 90px;
  background-color: #fff;
}

body#secondary .text_area.nopt{
  padding-top: 0;
}

body#secondary #contents .totop {
  text-align: right;
  margin-top:40px;
  padding-bottom: 40px;
}

body#secondary #contents .totop a {
  color: #707070;
  text-decoration: none;
}
body#secondary #contents .totop a:hover {
  text-decoration: underline;
}

.inner {
	max-width: 1140px;
	width: 100%;
	margin: 0 auto;
}

.pageTtlArea {
	height: 340px;
	margin-top: 185px;
	position: relative;
	color: #fff;
	text-align: center;
}
.pageTtlArea h2 {
	font-size: 30px;
	letter-spacing: 0.2em;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	line-height: 1;
	position: absolute;
	left: 50%;top: 80px;
	transform: translate(-50%, 0);
}


.label_list{
  width: 100%;
  max-width: 700px;
  justify-content: space-between;
  margin-top: 60px;
}

.schemelist.label_list{
  max-width: 900px;
}


.label_list li{
  -webkit-transform: skewX(150deg);
  -moz-transform: skewX(150deg);
  transform: skewX(150deg);
  border-right: 1px solid #000;
  /* margin-bottom: 100px; */
  width: 33%;
  text-align: center;
}

.label_list li:last-child{
  border-right: none;
}
.tab-label {
  color: #333;
  margin-right: 5px;
  padding:12px 12px 0;
  order: -1;
  font-weight: 600;
  font-size: 120%;
}

.tab-label a {
	    color: #333;
    text-decoration: none;
}

.tab-label a:hover {
    text-decoration: underline;
}


.tab-label span{
  display:block;
  transform: skewX(-150deg);
  padding:0 10px;
}


/* # footer
---------------------------------------------------------------------------- */
#footer .com_link_area {
}

#footer .com_link_area .flex{

}



#footer .com_link_area .f_cont .f_com_info {
	width:30%;background: #F7F4E8;
    padding: 70px 0;}
#footer .com_link_area .f_cont .f_com_info h1 {
  font-size: 120%;
}
#footer .com_link_area .f_cont .f_com_info p{
  font-size: 100%;
}
#footer .com_link_area .f_cont .f_com_info .com_add{
  white-space: nowrap;
    width: 45%;
        padding: 0 27.5%;
}

#footer .com_link_area .f_cont .f_com_info .relation a{
  color: #FFF;
  text-decoration: none;
}
#footer .com_link_area .f_cont .f_com_info .relation a:hover{
  text-decoration: underline;
}



#footer .com_link_area .f_cont .flink_wrap{
	
}


#footer .com_link_area .f_cont .f_page_link{
  width: 70%;
	box-sizing: border-box;
    padding: 0 100px;
	background:#f7f6f6;
    align-self: stretch;
}

#footer .com_link_area .f_cont .f_page_link nav.f_link {
	
	margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: solid 1px #eee;
	
}

#footer .com_link_area .f_cont .f_page_link nav.fotr {
	margin-bottom: 30px;
    padding-bottom: 30px;
    border-bottom: solid 1px #eee;
}

#footer .com_link_area .f_cont .f_page_link nav ul.otr-link {
	font-size:90%;
}

#footer .com_link_area .f_cont .f_page_link ul.otr-link li{
	margin-right:50px;
	font-size: 100%;
    font-weight: bold;
}

#footer .com_link_area .f_cont .f_page_link ul.otr-link li:last-child{
	margin-right:0px;
}

#footer .com_link_area .f_cont .f_page_link nav.brandlinkw ul.brand-link{
	font-size:90%;
}

#footer .com_link_area .f_cont .f_page_link nav.brandlinkw ul.brand-link li{
	margin-right:50px;
	font-size: 100%;
    font-weight: bold;
}

#footer .com_link_area .f_cont .f_page_link nav.brandlinkw ul.brand-link li:last-child{
	margin-right:0px;
}



#footer .com_link_area .f_cont .f_page_link nav.f_link ul li{
  margin-bottom: 20px;
}

#footer .com_link_area .f_cont .f_page_link nav ul li:last-child{
  margin-bottom: 0px;
}
#footer .com_link_area .f_cont .f_page_link nav ul .top_nav {
  font-size: 100%;
  font-weight: 600;
  color: #FFF;
  text-decoration: none;
}
#footer .com_link_area .f_cont .f_page_link nav ul li  a {
  color: #333;
  text-decoration: none;
}
#footer .com_link_area .f_cont .f_page_link nav ul li a:hover {
  text-decoration:underline;
}

#footer .com_link_area .f_cont .f_page_link nav ul.other_link li{
  margin-bottom: 10px}

#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a{
  background:#fff;
  color: #5E6F7D;
  position: relative;
  padding: 10px 40px 10px 20px;
}

#footer .com_link_area .f_cont .f_page_link nav ul.other_link li.mem{
  display: none;
}

#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a span {
  display: block;
}
#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a i{
font-size: 240%;
margin-right: 13px;
}
#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a:hover {
  text-decoration: none;
  opacity: 0.7;
}
#footer .com_link_area .f_cont .f_page_link nav ul.other_link li.mem a i{
transform: rotate(-45deg);
}
#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a span.ja {
  font-size: 120%;
}
#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a span.en{
  font-size: 70%;
}


#footer .f_bs_link {
  background: #FFF;
  padding: 20px 0;

}

#footer .f_bs_link .flex.jc_sb.w1000 {
  align-items: center;
}

#footer .f_bs_link nav#f_navi {
  width: 65%;
}

#footer .f_bs_link nav#f_navi ul {
  width: 100%;
  align-items: center;
}
#footer .f_bs_link nav#f_navi ul li {
  width: 23%;
}
#footer .f_bs_link nav#f_navi ul li img {
  width: 100%;
}
#footer .f_bs_link nav#f_navi ul li a:hover {
  opacity: 0.7;
}

#footer .f_bs_link #f_cont2{
  font-size: 80%;
  width: 100%;
}
#footer .f_bs_link #f_cont2 .sm_pp{
  display: none;
}
#footer .f_bs_link #f_cont2 ul {
  justify-content: flex-end;
}
#footer .f_bs_link #f_cont2 ul li.sitemap a {
  padding-right: 10px;
  margin-right: 10px;
  border-right: 1px #fff solid;
}
#footer .f_bs_link #f_cont2 a{
  color: #fff;
  text-decoration: none;
}
#footer .f_bs_link #f_cont2 a:hover {
  text-decoration:underline;
}
#footer .f_bs_link .address {
  text-align: center;
  color: #09204D;
  padding:0;
  width: 30%;
  text-align: right;
  font-size: 80%;
}

.f_bs_link .flex {
  align-items: center;
}

.font_b{font-weight: 600;}


/* # lNavi
---------------------------------------------------------------------------- */
#f_nav {
}



/* その他
---------------------------------------------------------------------------- */
.bold{font-weight:bold;}
.red {color:red;}
.yellow{color:#FFFFBF;}
.gray {color:#555;}
.lh18{line-height: 1.8;}
.ls3{letter-spacing: 0.18em;}
.fl {float:left;}
.fr {float:right;}
.stxt {font-size:80%;}
.sstxt {font-size:75%;}
.mstxt{font-size: 90%;}
.mtxt {font-size:115%;}
.mltxt {font-size:125%;}
.ltxt {font-size:150%;}
.xltxt {font-size:170%;}
.w900 {width:900px; margin: 0 auto;}
.w960 {width:960px; margin: 0 auto;}
.w1000 {width:1000px; margin: 0 auto;}
.w1100 {width:1100px; margin: 0 auto;}
.w1200 {width:1200px; margin: 0 auto;}
.w100{width:100%;}
.dc {display:block; text-align:center;}
.ma {margin-left: auto; margin-right: auto;}
.flex {display: -moz-flex;display: -ms-flex;display: -o-flex;display: -webkit-box;display: -ms-flexbox;display: flex;}
.jc_sb {-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;}
.jc_sa {-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-around;}
.jc_ce {-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;}
.fl_wp {flex-wrap:-webkit-wrap; flex-wrap:-moz-wrap;-ms-flex-wrap:-ms-wrap;flex-wrap:-ms-wrap;flex-wrap:wrap;}
.ai_ce{  -webkit-box-align: center;  -ms-flex-align: center;  align-items: center;}
.txtc {text-align:center;}.txtr {text-align:right;}
body .sp {display: none;}
.pc_none {display:none;}
.center_center{display: flex; align-content: center; justify-content: space-around;}
.copy_404{font-size: 24px; padding: 80px 0; font-weight: 400; line-height: 2;}


/* clearfix
---------------------------------------------------------------------------- */

.clearfix:after {
  content: ".";  /* 新しい要素を作る */
  display: block;  /* ブロックレベル要素に */
  clear: both;
  height: 0;
  visibility: hidden;
}

.clearfix {
  min-height: 1px;
}

* html .clearfix {
  height: 1px;
  /*¥*//*/
  height: auto;
  overflow: hidden;
  /**/
}

@media screen and (max-width: 740px) {

body .pc {display: none;}
body .sp {display: block;}


body.second #pagebody {background-size: cover;}
	
	.w500,.w510,.w520,.w530,.w540,.w550,.w560,.w570,.w580,.w590,.w600,.w610,.w620,.w630,.w640,.w650,.w660,.w670,.w680,.w690,.w700,.w710,.w720,.w730,.w740,.w750,.w760,.w770,.w780,.w790,.w800,.w810,.w820,.w830,.w840,.w850,.w860,.w870,.w880,.w890,.w900,.w910,.w920,.w930,.w940,.w950,.w960,.w970,.w980,.w990,.w1000,.w1010,.w1020,.w1030,.w1040,.w1050,.w1060,.w1070,.w1080,.w1090,.w1100,.w1110,.w1120,.w1130,.w1140,.w1150,.w1160,.w1170,.w1180,.w1190,.w1200,.w1210,.w1220,.w1230,.w1240,.w1250,.w1260,.w1270,.w1280,.w1290,.w1300,.w1310,.w1320,.w1330,.w1340,.w1350,.w1360,.w1370,.w1380,.w1390,.w1400{width: 100%;box-sizing: border-box;}
.w99s{width:99%;}.w98s{width:98%;}.w97s{width:97%;}.w96s{width:96%;}.w95s{width:95%;}.w94s{width:94%;}.w93s{width:93%;}.w92s{width:92%;}.w91s{width:91%;}.w90s{width:90%;}
.w89s{width:89%;}.w88s{width:88%;}.w87s{width:87%;}.w86s{width:86%;}.w85s{width:85%;}.w84s{width:84%;}.w83s{width:83%;}.w82s{width:82%;}.w81s{width:81%;}.w80s{width:80%;}
.w79s{width:79%;}.w78s{width:78%;}.w77s{width:77%;}.w76s{width:76%;}.w75s{width:75%;}.w74s{width:74%;}.w73s{width:73%;}.w72s{width:72%;}.w71s{width:71%;}.w70s{width:70%;}
.w69s{width:69%;}.w68s{width:68%;}.w67s{width:67%;}.w66s{width:66%;}.w65s{width:65%;}.w64s{width:64%;}.w63s{width:63%;}.w62s{width:62%;}.w61s{width:61%;}.w60s{width:60%;}
.w59s{width:59%;}.w58s{width:58%;}.w57s{width:57%;}.w56s{width:56%;}.w55s{width:55%;}.w54s{width:54%;}.w53s{width:53%;}.w52s{width:52%;}.w51s{width:51%;}.w50s{width:50%;}
.w49s{width:49%;}.w48s{width:48%;}.w47s{width:47%;}.w46s{width:46%;}.w45s{width:45%;}.w44s{width:44%;}.w43s{width:43%;}.w42s{width:42%;}.w41s{width:41%;}.w40s{width:40%;}
.w39s{width:39%;}.w38s{width:38%;}.w37s{width:37%;}.w36s{width:36%;}.w35s{width:35%;}.w34s{width:34%;}.w33s{width:33%;}.w32s{width:32%;}.w31s{width:31%;}.w30s{width:30%;}
.w29s{width:29%;}.w28s{width:28%;}.w27s{width:27%;}.w26s{width:26%;}.w25s{width:25%;}.w24s{width:24%;}.w23s{width:23%;}.w22s{width:22%;}.w21s{width:21%;}.w20s{width:20%;}
.w19s{width:19%;}.w18s{width:18%;}.w17s{width:17%;}.w16s{width:16%;}.w15s{width:15%;}.w14s{width:14%;}.w13s{width:13%;}.w12s{width:12%;}.w11s{width:11%;}.w10s{width:10%;}
.w9s{width:9%;}.w8s{width:8%;}.w7s{width:7%;}.w6s{width:6%;}.w5s{width:5%;}.w4s{width:4%;}.w3s{width:3%;}.w2s{width:2%;}.w1s{width:1%;}
.w100s{width:100%;}

.flexsp {display: -moz-flex;display: -ms-flex;display: -o-flex;display: -webkit-box;display: -ms-flexbox;display: flex;}
.jc_sbsp {-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-between;}
.jc_sasp {-webkit-box-pack:justify;-ms-flex-pack:justify;justify-content:space-around;}
.jc_cesp {-webkit-box-pack:center;-ms-flex-pack:center;justify-content:center;}
.fl_wpsp {flex-wrap:-webkit-wrap; flex-wrap:-moz-wrap;-ms-flex-wrap:-ms-wrap;flex-wrap:-ms-wrap;flex-wrap:wrap;}
.ai_ce{  -webkit-box-align: center;  -ms-flex-align: center;  align-items: center;}
/* -- margin  --*/
.mb0s{margin-bottom:0px !important;}.mb5s{margin-bottom:5px !important;}.mb10s{margin-bottom:10px !important;}.mb15s{margin-bottom:15px !important;}
.mb20s{margin-bottom:20px !important;}.mb25s{margin-bottom:25px !important;}.mb30s{margin-bottom:30px !important;}.mb35s{margin-bottom:35px !important;}
.mb40s{margin-bottom:40px !important;}.mb45s{margin-bottom:45px !important;}.mb50s{margin-bottom:50px !important;}.mb55s{margin-bottom:55px !important;}
.mb60s{margin-bottom:60px !important;}.mb65s{margin-bottom:65px !important;}.mb70s{margin-bottom:70px !important;}.mb75s{margin-bottom:75px !important;}
.mb80s{margin-bottom:80px !important;}.mb85s{margin-bottom:85px !important;}.mb90s{margin-bottom:90px !important;}.mb95s{margin-bottom:95px !important;}.mb100s{margin-bottom:100px !important;}

/* header 
===================*/
#header .head_nav #nav .logoham{
padding: 2px 10px 2px 5px;
box-sizing: border-box;
}
#header .head_nav #nav #splogo {
width: 50%;
}
#header .head_nav #nav #splogo img {
width: 100%;
}

#header .head_nav #nav li#logo {
display: none;
}

#header .head_nav #nav > ul > li {
margin-left: 0;
margin-right: 0;
text-align: left;
}

#header .head_nav #nav > ul > li span {
padding-left: 20px;
}
#header .head_nav #nav > ul{
border-top: solid 1px #ccc;
}

#header .head_nav #nav li .anchor {
padding: 10px 0;
border-bottom: solid 1px #ccc;
}

	
	#header .head_nav #nav li .anchor a{
		padding:0;
	}
	
.menu > ul > li > ul {
padding: 20px 20px 5px 20px;
}

.menu > ul > li > ul > li.nav_head{
width: 100%;
margin-bottom: 0;
}

.menu > ul > li > ul li.nav_child {
margin-right: 0;
width: 100%;
box-sizing: border-box;
padding-right: 1.5em;
border-bottom: solid 1px #ccc;
}

.menu > ul > li > ul li.nav_child:last-child{
border-bottom: none;
}

.menu > ul > li > ul li.nav_child  a{
text-decoration: none;
}

#header .sns #com_name {
display: none;
}

#header .sns .fr {
float: none;
}

#header .sns .fr div {
width: 50%;
}
#header .head_nav #nav li.sns a {
margin-left: 0;
padding: 1.5em 0;
}

#header .head_nav #nav li.sns a i {
font-size: 200%;
text-align: center;
display: block;
}


/* va
======================*/
#va2 {
margin: 65px auto 50px;
  padding: 0;
}
.message {
    width: 120px;
    bottom: 60px;
    left: 20px;
    padding: 30px;
}
	
	
/* secondary
======================*/
	body#secondary .c_headarea {
    padding: 30px 0;
	margin-top: 60px;
}
	
body#secondary .pankuzu{
  margin-bottom: 0px;
  padding: 0 20px;
}

body#secondary .contents_area{width: 95%;}
body#secondary .text_area{padding: 50px 5%;}
body#secondary .section{width: 100%;line-height: 1.8;}

body#secondary #contents .totop{
  text-align: center;
  margin-top: 0;
  padding-bottom: 0;
}
body#secondary #contents .totop a {
  padding: 20px 0;
  display: block;
}
  
body#secondary .c_headarea .head_des {

}


  
body#secondary .c_headarea .head_des h2.en {
  padding-top: 50px;
}

	.inner {
		width: calc(100% - 30px);
		margin: 0 auto;
	}

	.pageTtlArea {
		height: 230px;
		margin-top: 50px;
	}
	.pageTtlArea h2 {
		font-size: 26px;
		letter-spacing: 0.1em;
		position: absolute;
		left: 50%;top: 50px;
		transform: translate(-50%, 0);
	}
	.pageTtlArea .en {
		position: absolute;
		left: 50%;top: 200px;
		transform: translate(-50%, 0);
	}


/* Footer 
======================*/
#footer .com_link_area {
padding: 0;
}

#footer .com_link_area > .flex {
    flex-direction: column;
}

#footer .com_link_area .f_cont .f_page_link{
  width: 100%;
    padding: 50px 5% 50px;
}
	#footer .sp_ft_add {
		padding:15px 10px 15px 0;
	}
#footer .com_link_area .f_cont .f_com_info {
padding-right: 0;
margin-right: 0;
border-right:none;
text-align: center;
width: 100%;
}

	#footer .com_link_area .f_cont .f_page_link nav.f_link{
		border-bottom:none;
		padding-bottom: 0;
	}
	
	#footer .com_link_area .f_cont .f_page_link nav.fotr{
		border-bottom:none;
	}
	#footer .com_link_area .f_cont .f_page_link nav.fotr ul.otr-link li {
    margin:0 0 20px;
    width: 48%;
}
#footer .com_link_area .f_cont .f_page_link nav.f_link ul{
width: 48%;
margin-bottom: 20px;
}


  
#footer .com_link_area .f_cont .f_page_link nav ul .top_nav{
font-weight: bold;
}

#footer .com_link_area .f_cont .f_page_link nav ul li{
font-size: 90%;
}

#footer .com_link_area .f_cont .f_page_link nav ul li a {
display: block;
width: 100%;
border-bottom: #ccc dotted 1px;
box-sizing: border-box;
padding: 0 0 3px 10px;
}


#footer .com_link_area .f_cont .f_page_link nav ul.other_link{
width:100%;
}

#footer .com_link_area .f_cont .f_page_link nav ul.other_link li a {
display: flex;
}

#footer .f_bs_link {
padding: 20px;
}
  
 #footer .f_bs_link nav#f_navi {
    width: 100%;
} 

#footer .f_bs_link nav#f_navi ul{
width:100%;
margin-bottom: 10px;
flex-wrap: wrap;
}

#footer .f_bs_link nav#f_navi ul li{
width: 49%;
margin-bottom: 10px;
}

#footer .f_bs_link #f_cont2 {
width: 100%;
}

  #footer .f_bs_link .address{
      width: 100%;
    text-align: center;
  }

}

.jp {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
}
#container {
    position: relative;
    height: 100%;
}
#side_button {
  position:fixed; top:149px; z-index:100; opacity:0;
  -webkit-transition: left 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0s; transition: left 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0s;
}
#side_button a { font-size:14px; display:block; height:60px; line-height:60px; padding:0 40px 0 62px;  position:relative; }
#side_button .raijo a{background:#F7F4E8;color:#3F342D;transition: all 0.5s 0s ease;}
#side_button .raijo a:hover { background:#fff; }
#side_button .bunjo a{background:#998E73;color:#fff;transition: all 0.5s 0s ease;}
#side_button .bunjo a:hover { background:#BFA06B; }

#side_button.left a { padding:0 62px 0 40px; }

#side_button .item { position:relative; }
#side_button .item:before {
  font-family: "FontAwesome"; font-size:18px; color:#fff; font-weight:normal;
  position:absolute; left:0px; text-align:center; z-index:1;
  width:60px; height:60px; line-height:62px;
}
#side_button .raijo:before {content:"\f015";color:#3F342D;}
#side_button .bunjo:before {content:"\f2b5"; }

#side_button.right{width: 250px; left: calc(100% - 60px); opacity: 1;}
#side_button.right:hover{left: calc(100% - 250px);}
body.home #side_button.right { margin-left:60px; }
body.home #side_button.right.animate {
  -webkit-animation: side_button_animation 0.7s cubic-bezier(0.165, 0.84, 0.44, 1) forwards 3.5s;
  animation: side_button_animation 0.7s cubic-bezier(0.165, 0.84, 0.44, 1) forwards 3.5s;
}
@-webkit-keyframes side_button_animation {
  0% { margin-left:60px; }
  100% { margin-left:0px; }
}
@keyframes side_button_animation {
  0% { margin-left:60px; }
  100% { margin-left:0px; }
}


.to_home {
    text-align: center;
    margin: 100px auto;
}

.to_home a {
    text-decoration: none;
    display: inline-block;
}

.sakuraBtn{
	width:220px;
	height:32px;
	line-height:32px;
  position: relative;
  z-index: 0;
}
.btn_b{
	border-left: 2px solid #000;
}
.btn_b::before{
  content: "";
  position: absolute;
  top: 0px;
  left: -8px;
  width: calc(100% + 2px);
  min-height: 100%;
  border-left: 4px solid #000;
  z-index: 1;
}
.btn_b span,.btn_b input{
	display:block;
	width:95%;
	height:100%;
	text-align:center;
	border-bottom: 2px solid #000;
	color:#000;
	margin-left: 2px;
	z-index: 2;

}
/*
.btn_b span:hover{
	background:rgb(133, 131, 131);
}
*/
.btn_b input:hover{
	background:rgb(133, 131, 131);
}

/* --å…±é€š btn-- white type-- */
.btn_w{
	border-left: 2px solid #FFF;
}
.btn_w:before{
  content: "";
  position: absolute;
  top: 0px;
  left: -8px;
  width: calc(100% + 2px);
  min-height: 100%;
  border-left: 4px solid #FFF;
  z-index: 1;
}
.btn_w span{
	display:block;
	width:95%;
	height:100%;
	text-align:center;
	border-bottom: 2px solid #FFF;
	color:#FFF;
	margin-left: 2px;
}

/*
.btn_w span:hover{
	background:#DEDEDE;
}
*/


/*
 * pager ページャー 
*/
.pager {
}
.pager ul.pagination {
  display: flex;
  justify-content: center;
  margin: 0;
  padding: 0;
}
.pager .pagination li {
  display: inline;
  margin: 0 5px;
  padding: 0;
  display: inline-block;
  background:#e0e0e0;
  width: 30px;
  height: 30px;
  text-align: center;
  position: relative;
}
.pager .pagination li a{
  vertical-align: middle;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  display:table;
  color: #000;
  text-decoration: none;
}
.pager .pagination li a span{
  display:table-cell;
  vertical-align:middle;
}
.pager .pagination li.blank{
  vertical-align: 50%;
  background-color: inherit;
  margin: 0 5px;
}
.pager .pagination li a:hover,
.pager .pagination li a.active{
  color: #fff;
  background: #000;
}