html , body {
  position: relative;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 18px;
  color: #000;
  margin: 0;
  padding: 0;
  width: 100%;
  overflow-x: hidden;
  animation: fadeIn 2s ease 0s 1 normal;
  -webkit-animation: fadeIn 2s ease 0s 1 normal;
}

/*--- 画面全体をフェードイン(animation設定) ---*/
@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}

@keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
    0% {opacity: 0}
    100% {opacity: 1}
}
a {
  color: #000;
  -webkit-transition: 0.5s;
  -o-transition: 0.5s;
  transition: 0.5s;
}
a:hover, a:active, a:focus {
  outline: none;
  text-decoration: none;
  color: rgba(0, 0, 0, 0.5);
}
a img {
  opacity: 1;
  -webkit-transition: 0.3s;
  -o-transition: 0.3s;
  transition: 0.3s;
}
a img:hover {
  opacity: 0.7;
}
a.tel-link { text-decoration: underline; }
a.tel-link:hover { text-decoration: none; opacity: 0.6; }

#cpage .content-wrap a {
	color: #007bff;
	text-decoration: underline;
}
#cpage .content-wrap .btn02 a {
	color: #fff;
	text-decoration: none;
}

h1 {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 600;
  font-size: 2.4em;
  line-height: 1.3;
  letter-spacing: 0.1em;
}
h2 {
  font-family: geom-graphic, 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-style: italic;

  font-size: 2.2em;
  line-height: 1.3;
  letter-spacing: 0.2em;
  text-align: center;
}
h2 span.titsub, h3 span.titsub {
  display: block;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1rem;
  margin: 0 auto;
  padding: 0;
  letter-spacing: 0.2em;
}
h3 span.titsub { font-weight: normal; padding: 5px 0 0; }
h3 {
  font-family: /*vdl-gigag, */'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-style: normal;

  font-size: 3.3em;
  line-height: 1.3;
  margin: 0 auto;
  padding: 80px 0 60px;
  text-align: center;
  letter-spacing: 0.1em;
}
h3 span.titsmall {
  display: block;
  font-size: 0.75em;
}
h4 {
  font-family: geom-graphic, 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-style: italic;

  font-size: 2.5em;
  line-height: 1.3;
  letter-spacing: 0.2em;
  margin: 45px auto 10px;
}
h4 span {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 0.4em;
  font-weight: bold;
  font-style: normal;
  letter-spacing: 0.1em;
  padding-left: 15px;
}
h5 {
  font-family: Avenir, "Helvetica Neue", Helvetica, Arial, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, 游ゴシック体, "Hiragino Sans", ヒラギノ角ゴシック, メイリオ, Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.25em;
  font-weight: bold;
  line-height: 1.3;
  margin: 15px auto 10px;
}
h6 {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.1em;
  font-weight: bold;
  line-height: 1.3;
  letter-spacing: 0.02em;
  margin-bottom: 1rem;
}


/*--- 要素のフェードイン ---*/
.effect-fade {
    opacity : 0;
    transform : translate(0, 30px);
    transform: none !important;
    transition : all 800ms;
}
.effect-fade.effect-scroll {
    opacity : 1;
    transform : translate(0, 0);
    transform: none !important;
}

/*----- btn01 -----*/
.btn01 {
    position: relative;
    width: 100%;
    max-width: 286px;
    height: 84px;
    text-align: center;
    margin: 0 auto 25px;
    padding: 0;
    background-color: #fff;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}
.btn01 a {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    width: 100%;
    display: inline-block;
    color: #1F1F1F;
    font-family: "Century Gothic", CenturyGothic, AppleGothic, 'Noto Sans JP', sans-serif;
    font-size: 1em;
    font-weight: bold;
    letter-spacing: 0.2em;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}
.btn01:hover { background-color: rgba(255, 255, 255, 0.3); }
.btn01:hover a { color: #fff; font-size: 1.25em; }

/*----- btn02 -----*/
.btn02 {
    width: 100%;
    text-align: center;
    margin: 25px auto;
    padding: 0;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}
.btn02 a {
    width: auto;
    display: inline-block;
    color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 0.9em;
    font-weight: bold;
    letter-spacing: 0.2em;
    margin: 0 auto;
    padding: 20px 70px;
    border: 1.5px solid #fff;
    background-color: transparent;
    -moz-transition: all 0.5s ease 0s;
    -o-transition: all 0.5s ease 0s;
    -webkit-transition: all 0.5s ease;
    -webkit-transition: all 0.5s ease 0s;
    transition: all 0.5s ease 0s;
}
.btn02 a:hover { background-color: #3B506C; border-color: #3B506C; }

/*----- btn03（伸びるボタン） -----*/
.btn03-wrap {
    position: relative;
    display: inline-block;
    width: auto;
    margin-top: 15px;
    padding: 0 2px 5px;
    text-align: left;
    transition: all .3s ease 0s;
    cursor: pointer;
}
.btn03-wrap::before {
    content: "";
    vertical-align: middle;
    position: absolute;
    bottom: -1px;
    left: 0;
    background-color: #fff;
    width: 100%;
    height: 1px;
    transition: all .5s ease 0s;
}
.btn03 a {
    color: #fff;
    font-size: 1em;
    font-weight: bold;
    letter-spacing: 0.2em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.btn03-wrap:hover::before {
    background-color: #3B506C;
    width: 110%;
}
.btn03-wrap:hover .btn03 a {
    color: #3B506C;
}



/*----- 背景 ------*/
.bg-black {
    background-color: #000;
    color: #fff;
}
.bg-blue {
    background-color: #256AD8;
    color: #fff;
}

/*--- .sns-box ---*/
.sns-tit {
  font-family: geom-graphic, 'Noto Sans JP', sans-serif;
  font-weight: 400;
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.1em;
  margin-top: 15px;
  margin-bottom: 6px;
}
.sns-box { display: flex; margin-bottom: 2rem; }
.sns-box svg { width: 30px; height: 30px; fill: #fff; }
.sns-box a:not(:first-child) { margin-right: 3px; }
.sns-box a:hover { opacity: 0.8; }

.sns-iframe {
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    padding: 3.5em 0;
}
.sns-iframe iframe { width: 100%; }
.sns-iframe .sns-iframe-txt {
  color:#fff;
  font-size:13px;
  text-align:center;
  display:block;
  padding-top: 10px;
}
.sns-iframe .sns-iframe-txt > a {
  color: #fff;
  text-decoration: underline;
}


/* --------------------------------------------
    nav
-------------------------------------------- */
#drawer-checkbox {
  display: none;
}
#drawer-icon {
  display: inline-block;
  width: 95px;
  height: 100%;
  background-color: #707070;
  margin: 0 auto;
  padding: 20px;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 999;
  cursor: pointer;
}

#drawer-icon span {
  background:  #fff;
  border-radius: 0px;
  display: block;
  height: 2px;
  margin: 0;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  transition: all 0.3s ease-in-out;
  width: 36px;
}
#drawer-icon span::before,
#drawer-icon span::after {
  -webkit-transform: rotate(0);
  background: #fff;
  border-radius: 0px;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  margin: 0;
  transform: rotate(0);
  transition: all 0.3s ease-in-out;
}
#drawer-icon span::before { margin-top: -17px; }
#drawer-icon span::after { margin-top: 34px; }
#drawer-checkbox:checked ~ #drawer-icon { background: #000; }
#drawer-checkbox:checked ~ #drawer-icon span {
  background: rgba(51, 51, 51, 0);
  top: 50%;
}
#drawer-checkbox:checked ~ #drawer-icon span::before,
#drawer-checkbox:checked ~ #drawer-icon span::after {
  content: "";
  display: block;
  width: 105%;
  height: 100%;
  position: absolute;
}
#drawer-checkbox:checked ~ #drawer-icon span::before {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  margin-top: 0;
}
#drawer-checkbox:checked ~ #drawer-icon span::after {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  margin-top: 0;
}
/*--- メニューコンテンツ ---*/
#drawer-content {
  color: #fff;
  overflow: auto;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.8);
  -webkit-background: rgba(0, 0, 0, 0.8);
  transition: all 0.3s ease-in-out 0s;
  /*transform: translateY(-1050px);*/
  display: none;
}
/*
#drawer-content .menu-box {
  display: inline-block;
  margin: 10px;
  padding: 0 25px 25px;
  vertical-align: top;
}
*/
#drawer-content .menu-box {
    width: 90%;
    max-width: 1000px;
    margin: 100px auto 35px;
}
#drawer-content .menu-box a { color: #fff; }

#drawer-content .menu-hd01 {
    display: block;
    border-bottom: 1px solid #fff;
    padding: 30px 0;
}
#drawer-content .menu-hd01 .menu-logo {
    display: inline-block;
}
#drawer-content .menu-hd01 .menu-logo img {
    width: 200px;
    height: auto;
    object-fit: contain;
    padding: 8px 0;
}
#drawer-content .menu-hd01 .menu-btn01 {
    list-style: none;
    display: inline-block;
    margin: 0;
    padding: 0;
    float: right;
}
#drawer-content .menu-hd01 .menu-btn01 li {
    display: inline-block;
    margin: 0 6px;
}
#drawer-content .menu-hd01 .menu-btn01 li a {
    color: #fff;
    display: block;
    background-color: #ADADAD;
    padding: 10px 25px;
    font-weight: bold;
    letter-spacing: 0.1em;
}
#drawer-content .menu-hd01 .menu-btn01 li:first-child a { background-color: transparent; }
#drawer-content .menu-hd01 .menu-btn01 li:not(:first-child) a:hover { background-color: #3B506C;  }

#drawer-content .menu-box01 {
    display: inline-block;
    margin: 50px 80px 50px 0;
    vertical-align: top;
}
#drawer-content .menu-box01:last-child {
    margin-right: 0;
}
#drawer-content .menu-box01 h4 {
    font-size: 1.4em;
    margin: 30px auto 25px;
}
#drawer-content .menu-box01 h4 .titsub {
    font-size: 0.7em;
    padding-left: 1em;
}

#drawer-content .menu-box01 .menu-list01 li {
    list-style: none;
    margin-bottom: 15px;
}
#drawer-content .menu-box01 .menu-list01 li:before {
    content:  "";
    width:  15px;
    height:  1px;
    display:  inline-block;
    background-color: #fff;
    vertical-align: super;
    margin-right: 15px;
}
#drawer-content .menu-box01 .menu-list01 li a {
    font-weight: bold;
}


#drawer-checkbox:checked ~ #drawer-content {
  /*transform: translateY(94px);*/
  display: block;
}
#drawer-close {
  display: none;
  position: fixed;
  /*z-index: 39;*/
  z-index: 100;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  /*background: #000;*/
  opacity: 1;
  transition: all 0.3s ease-in-out 0s;
}
#drawer-checkbox:checked ~ #drawer-close {
  display: block;
  opacity: 1;
  margin: 0;
  background-color: #000;
  z-index: 100;
}


/* --------------------------------------------
    menu01
-------------------------------------------- */
#menu01 {
  position: fixed;
  width: 100%;
  height: auto;
  min-height: 95px;
  top: 0;
  left: 0;
  background-color: #000;
  filter: drop-shadow(0px 3px 6px rgba(112, 112, 112, 0.1));/*#707070*/
  z-index: 999;
  color: rgb(112, 112, 112);
}
.navbar-header {
  position: relative;
  top: 0;
  left: 0;
  display: inline-block;
  margin: 0;
  padding: 0;
}
.navbar-header a {
  display: block;
}
.navbar-header a h1 {
  line-height: 0;
  margin: 0;
  padding: 30px 50px;
}
.navbar-header a h1 img {
  width: 215px;
  max-width: 100%;
  height: auto;
}

/*--- .sidebtn ---*/
.sidebtn {
  position: absolute;
  top: 0;
  right: 95px;
  z-index: 50;
  height: 100%;
}
.sidebtn .sldebtn-list {
  list-style: none;
  margin: 0;
  padding: 0;
  height: 100%;
}
.sidebtn .sldebtn-list li {
  position: relative;
  display: inline-block;
  width: 95px;
  height: 100%;
  margin: 0;
  color: #fff;
  font-size: 1em;
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.1em;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  transition: all 0.5s ease;
}
.sidebtn .sldebtn-list li a {
  color: #fff;
  display: block;
  width: 100%;
  height: 100%;
  -webkit-transition: all 0.5s ease;
  -moz-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.sidebtn li.langage-btn { background-color: #3B506C; margin-right: -4px; }
.sidebtn li.langage-btn .langage-txt {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.sidebtn li.langage-btn :hover { background-color: #707070; }

.sidebtn li.mail-btn { background-color: #ADADAD; }
.sidebtn li.mail-btn img {
    width: 25px;
    object-fit: contain;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.sidebtn li.mail-btn:hover { background-color: #5F7BA0; }


/* --------------------------------------------
    header
-------------------------------------------- */
#hd01 {
    position: relative;
    width: 100%;
    margin-top: 94px;
    line-height: 0;
}
#hd01 .slider-txt01 {
    width: 60%;
    max-width: 100%;
    position: absolute;
    left: 11.5%;
    bottom: 7%;
    z-index: 10;
}
#hd01 .slider-cover {
    width: 50%;
    max-width: none;
    position: absolute;
    right: -7%;
    bottom: 7%;
    z-index: 10;
}
.slick-slider {
    width: 100%;
    height: auto;
    margin: auto;
}
.style-box img {
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
}



/* --------------------------------------------
    main-contents
-------------------------------------------- */
#content-main {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
}
#content-main::before{
  content: "";
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 100vh;
  background-image: url(../img/bg01.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.img-main01 {
  height: auto;
  margin-bottom: 80px;
  position: relative;
}
.img-main01 img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.content-wrap {
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
}
.content-wrap p {
    line-height: 1.8;
}


/*--- #sec01 ---*/
#sec01 {
    position: relative;
    padding: 25px 0 60px;
}
#sec01::before{
  content: "";
  display: inline-block;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  width: 100%;
  max-width: 50%;
  height: 100%;
  background-image: url(../img/sec01-bg01.png);
  background-position: bottom left;
  background-repeat: no-repeat;
  background-size: cover;
}
#sec01 h4 {
    color: #fff;
}

.info-wrap {
    
}
.info-box {
    background-color: #fff;
    margin: 0 auto;
    padding: 35px;
}
.info-box dl {
    position: relative;
    width: 100%;
    margin-bottom: 30px;
	border-bottom: solid 1px #ccc;
}
.info-box dl:last-child {
    margin-bottom: 0;
}
.info-box dt {
    font-weight: normal;
    display: inline-block;
    width: 120px;
    margin: 0;
    padding: 0;
}
.info-box dd {
    display: block;
    width: calc(100% - 135px);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    position: absolute;
    right: 0;
    top: 0;
    margin: 0;
    padding: 0;
}


/*---------- infoタブ ----------*/
.topinfo-wrap .flex-box { justify-content: space-between; }
.nav-tabs {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    width: 37em;
    /*
    background-color: #fff;
    -webkit-filter: drop-shadow(0px 3px 6px rgba(0,0,0,0.16));
    -moz-filter: drop-shadow(0px 3px 6px rgba(0,0,0,0.16));
    -ms-filter: drop-shadow(0px 3px 6px rgba(0,0,0,0.16));
    filter: drop-shadow(0px 3px 6px rgba(0,0,0,0.16));
    */
}
.nav-tabs > li > a {
  position: relative;
  color: #fff !important;
  font-weight: 500;
  display: block;
  width: 8.5em;
  margin: 6px;
  padding: 5px;
  text-align: center;
  background-color: #5D5D5D;
  border: none;
  /*
  border-right: 1px solid #dcdcdc;
  border-radius: 3px;
  */
}
.nav-tabs > li.active > a {
  /*
  color: #000 !important;
  */
}
.nav-tabs > li > a::before {
  /*
  content: '';
  display: block;
  width: 1px;
  height: calc(100% - 6px);
  position: absolute;
  left: calc(100% + 6px);
  top: 3px;
  background-color: #dcdcdc;
  */
}
.nav-tabs > li:last-child > a::before { display: none; }
.nav > li > a:hover, .nav > li > a:focus {
    outline: none;
    text-decoration: none;
    border: none!important;
    background-color: #707070;
}
.nav-tabs > li.active > a, .nav-tabs > li.active > a:hover, .nav-tabs > li.active > a:focus {
    color: #fff;
    border: none;
    background-color: #256AD8;
}
/* カテ分けお知らせ */
.information {
  background-color: #fff;
  margin: 0 auto;
  padding: 35px;
}
.information a {
  text-decoration: none !important;
    color: #000 !important;
}
.information dl {
  padding: 12px 0; 
  margin: 0;
  width: 100%;
  border-bottom: 1px solid #ccc;
}
/*
.information dl:first-of-type {
  border-top: 1px solid #ccc;
}
*/
.information dt, .information dd {
  display: inline-block;
  vertical-align: middle;
  margin-bottom: 0.5rem;
}
.information .data {
    font-weight: normal;
    width: 5.5em;
    margin-right: 0.5em;
    padding: 2px 0;
}
.information .icon {
    color: #fff;
    font-size: 0.8em;
    line-height: 1.3;
    display: inline-block;
    width: 7em;
    margin-right: 0.5em;
    padding: 3px;
    background-color: #ADADAD;
    text-align: center;
}
.information .icon.info {
    background-color: #3B506C;
}
.information .icon.recruit {
    background-color: #256AD8;
}
.information .icon.events {
    background-color: #707070;
}
.information .icon.no_category {
    background-color: #fff;
}

.information .txt {
    padding: 2px 0;
    overflow: hidden;
/*
    width: calc(100% - 16em);
    white-space: nowrap;
    text-overflow: ellipsis;
*/
}
/* ページネーション */
.pagenate ul {
  margin: 40px auto 0;
  padding: 20px ;
  text-align: center;
    line-height: 3;
}
.pagenate ul li {
  display: inline-block;
  padding: 0px 5px;
  margin: 0;
}
.pagenate ul li .link_page,
.pagenate ul li .current_page {
  padding: 2px 10px;
  margin: 0;
    border: solid 2px #3B506C;
    border-radius: 5px;
}
.pagenate ul li .link_page {
    background-color: #3B506C;
    color: #fff;
}

.pagenate ul li:before {
  background-color: transparent;
  display: none;
  padding: 0;
}
.pagenate  ul li span {
  padding: 0;
}


/*--- #sec02 ---*/
#sec02 {
    position: relative;
    padding: 25px 0 60px;
}
#sec02 .sec02-wrap {
    max-width: 1080px;
}
#sec02 .sec02-txt {
    max-width: 955px;
    margin: 0 auto 35px;
}
#sec02 .row {
    padding: 50px 0;
}
#sec02 .merit01-box {
    position: relative;
    display: block;
    padding: 0 25px 25px;
}
#sec02 .merit01-box .merit01-img {
    position: relative;
    z-index: 10;
    margin-bottom: 20px;
}
#sec02 .merit01-box .merit01-img::before{
  content: "";
  display: inline-block;
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: -1;
  width: 100%;
  height: 100%;
  background-color: #256AD8;
  border-radius: 35% 0 0 0;
}
#sec02 .merit01-box .merit01-img img {
    width: 100%;
    max-width: 420px;
    height: auto;
    object-fit: contain;
    margin: 0 auto;
    padding: 0;
}
#sec02 .merit01-box .merit01-tit {
    font-size: 1.4em;
    font-weight: bold;
    line-height: 1.3;
    letter-spacing: 0.2em;
}
#sec02 .merit01-box .merit01-tit .titsub {
    display: block;
    font-size: 0.7em;
    font-weight: normal;
}
#sec02 .merit01-box .merit01-txt {
    font-size: 0.95em;
    margin: 15px auto 30px;
}
#sec02 .merit01-box .btn03-wrap {
    position: absolute;
    bottom: 0;
    display: block;
}

/*--- #sec03 ---*/
#sec03 {
    color: #fff;
    position: relative;
    padding: 25px 0 80px;
}
#sec03 .sec03-wrap {
    max-width: 1035px;
}
#sec03 .sec03-txt {
    max-width: 900px;
    margin: 0 auto 35px;
}
#sec03 .sec03-box {
    margin-bottom: 60px;
}
#sec03 .sec03-box .col-sm-12 {
    text-align: center;
    margin: 60px auto 80px;
}
#sec03 .sec03-box .col-sm-12 .sec03-tit {
    font-size: 1.4em;
    font-weight: bold;
    letter-spacing: 0.1em;
    display: inline-block;
    padding: 3px;
    border-bottom: 1px solid #fff;
}

#sec03 .sec03-box .col-sm-6 {
    padding-left: 25px;
    padding-right: 25px;
}
#sec03 .sec03-box .col-sm-6:not(:last-child) img {
    max-width: 420px;
}
#sec03 .sec03-box .col-sm-6 img {
    width: 100%;
    max-width: 500px;
    height: auto;
    object-fit: contain;
    margin-bottom: 25px;
}


/*--- #sec04 ---*/
#sec04 {
    color: #fff;
    height: auto;
    display: grid;
    display: -ms-grid;
    grid-template-columns: 50% 50%;
    -ms-grid-columns: 50% 50%;
}
#sec04 h3 {
    font-size: 2.5em;
    padding: 0 0 35px;
}
#sec04 h3 span.titsub {
    font-size: 0.4em;
}
#sec04 .sec04-box {
    padding: 10%;
}
#sec04 .sec04-txt {
    line-height: 1.8;
    max-width: 400px;
    margin: 0 auto;
}
#sec04 .btn02 {
    margin-top: 50px;
    margin-bottom: 0;
}

#sec04 .sec04-left {
    width: auto;
    height: auto;
    -ms-grid-column: 1;
    
    background-image: url(../img/sec04-bg02.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
#sec04 .sec04-right {
    width: auto;
    height: auto;
    -ms-grid-column: 1;
    
    background-image: url(../img/sec04-bg01.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

/*--- #sec05 ---*/
#sec05 {
    position: relative;
    display: block;
    padding: 25px 0;
}
#sec05::before{
  content: "";
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 52%;
  z-index: 0;
  width: 50%;
  max-width: 480px;
  height: 100%;
  background-image: url(../img/sec05-img01v3.png);
  background-position: bottom left;
  background-repeat: no-repeat;
  background-size: contain;
}
#sec05 .sec05-wrap {
    padding: 50px 0;
}
#sec05 .sec05-tit {
    font-size: 1.95em;
    line-height: 1.5;
    letter-spacing: 0.2em;
}
#sec05 .btn02 { text-align: left; }



/* --------------------------------------------
    footer
-------------------------------------------- */
#ft01 {
    color: #fff;
    width: 100%;
    position: relative;
    background-image: url(../img/ft-bg01.jpg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}
#ft01 .ft01-wrap {
    width: 100%;
    height: 100%;
    position: relative;
}
#ft01 .container {
  position: relative;
  z-index: 10;
  padding: 60px 0 35px;
}
#ft01 .ft01-img img {
  width: 215px;
  object-fit: contain;
}
#ft01 .row {
  padding: 35px 0 25px;
}
#ft01 .row p {
  margin: 5px auto 0;
}
#ft01 a {
  color: #fff;
  font-size: 1em;
}
#ft01 a:hover { opacity: 0.3; }

/*左*/
#ft01 .row .ft01-tit {
  font-weight: bold;
}
#ft01 .row p {
  font-size: 0.9em;
  line-height: 1.6;
}

/*右*/
#ft01 .ft-menu {
  margin: 0 auto;
  padding: 0;
}
#ft01 .ft-menu li {
  display: inline-block;
  margin: 10px 0;
}
#ft01 .ft-menu li a {
  margin: 0 80px 0 0;
  padding-left: 10px;
  line-height: 1.3;
  letter-spacing: 0.05em;
  border-left: 6px solid #fff;
}
#ft01 .cp {
  position: relative;
  z-index: 10;
  color: #1F1F1F;
  background-color: #fff;
  font-size: 0.75em;
  letter-spacing: 2px;
  text-align: center;
  padding: 15px 0;
}


/* --------------------------------------------
    top page
-------------------------------------------- */
/*
#pagetop {
    position: fixed;
    right: 20px;
    bottom: 30px;
    cursor: pointer;
    z-index: 2;
}
#pagetop img {

}
*/


/* --------------------------------------------
    other page
-------------------------------------------- */
.circle {	
  position: relative;
	/*
  display: inline-block;
	*/
  width: 340px;
  height: 340px;
  border-radius: 50%;
  background: #000;
	color: #fff;
	box-shadow: 10px 10px #256AD8; 
	margin: 0 auto 20px;
}

.circle div {
  position: absolute;
  display: inline-block;
  left: 6%;
  top: 50%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  width :300px;
  text-align:center;
}
.bg-blue01 {
	background-color: #256AD8;
	color: #fff;
	background-image: url(../img/bg-blue01texture.png);
	background-repeat: repeat;
}
.bg-blue01 .txt-philosophy01 {
	border-bottom-color: #fff;
}
.bg-w02 {
	background-image: url(../img/bg-w02.png);
	background-repeat: no-repeat;
	background-position: center right;
}
#titbar {
    background-image: url(../img/titbar01.jpg);
    background-position: center;
    background-repeat: no-repeat;
    background-color: #000;
    background-size: cover;
    margin-top: 95px;
    height: 200px;
}
#titbar h2 {
    color: #fff;
    margin: 0;
    padding: 60px 0;
	text-shadow: #000 1px 0 10px;
}

#titbar.works { background-image: url(../img/titbar_works.jpg);}
#titbar.contact { background-image: url(../img/titbar_contact.jpg);}
#titbar.news { background-image: url(../img/titbar_contact.jpg);}
#titbar.estimate { background-image: url(../img/titbar_contact.jpg);}
#titbar.business { background-image: url(../img/titbar_business.jpg);}
#titbar.philosophy { background-image: url(../img/titbar_philosophy.jpg);}
#titbar.recruit { background-image: url(../img/titbar_recruit.jpg);}
#titbar.products  { background-image: url(../img/titbar_products.jpg);}

.txt-philosophy01 {
    font-weight: 700;
    font-style: normal;    
	font-size: 1.8em;
	border-bottom: solid 1px #000;
	display: inline-block;
}
.txt-philosophy01 span {
	font-size: 0.6em;
}
.txt-philosophy02 {
    font-weight: 500;
    font-style: normal;    
	font-size: 1em;
}

/*-- 隙間用 --*/
.t-80 { padding-top: 80px; }
.b-80 { padding-bottom: 80px; }

.img-responsive { max-width: 100%; }
/*-- 画像に青い囲み --*/
.img-box01 {
    position: relative;
    z-index: 10;
    margin-bottom: 35px;
    padding-right: 10px;
}
.img-box01::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: -1;
    width: calc(100% - 10px);
    height: 100%;
    background-color: #256AD8;
    border-radius: 35% 0 0 0;
}

.other-content {
    background-color: #fff;
}
.other-content::before{
  display: none;
  background: none;
}
.other-content section {
    padding-bottom: 100px;
}
.other-content h3 { font-size: 2.5em; }
.other-content h3 span.titsub { font-weight: bold; letter-spacing: 0.1em; padding-top: 0.8rem; }
.other-content h4 { font-size: 1.6em; font-weight: bold; letter-spacing: 0.1em; margin-bottom: 1.5rem; }
.other-content h5 { font-family: 'Noto Sans JP', sans-serif; font-size: 1.2em; font-weight: bold; letter-spacing: 0.05em; margin-bottom: 1rem; }
.other-content .content-wrap p { line-height: 2; }

/*-- table --*/
.other-content table {
    width: 100%;
    border: 1px solid #5C5C74;
    border-collapse: collapse;
    margin-bottom: 35px;
}
.other-content table tr { border-bottom: 1px solid #5C5C74; }
.other-content table tr:last-child { border-bottom: none; }
.other-content table th , .other-content table td {
    padding: 15px 25px;
    vertical-align: top;
    line-height: 1.8;
}
.other-content table th {
    color: #256AD8;
    font-size: 1.1em;
    letter-spacing: 0.05em;
    background-color: #DDE9FD;
    white-space: nowrap;
}

/*-- ol,ul list --*/
.other-content ol li, .other-content ul li {
    padding: 15px 0 0 0;
}

.privacy-content ol {
    counter-reset: li;    /* li のカウンタを 0 にセット */ 
    list-style: none;
}

.privacy-content li:before {
    color: #256AD8;
    font-weight: bold;
    counter-increment: li;   /* li の数を一つずつ増加 */
    content: counter(li) ". ";          /* 数を表示 */
}

.aform-content {
	max-width: 100%;
}
.aform-content td,
.aform-content .aform-input {
	width: 100% !important;
}

form span.aform-required {
	color: #fff;
	padding: 1px 6px 2px;
	font-size: 0.8rem;
	background-color: #256AD8;
	margin-left: 5px;
	border-radius: 5px;
}
/*
.aform-content form span.parts-9 {
    padding: 1px 6px 2px;
    margin-left: 0;
    border-radius: 0;
	
	color: #256AD8;
    background-color: #DDE9FD;
    font-size: 1.1em;
    letter-spacing: 0.05em;
    white-space: nowrap;
}
*/
.aform-content form ul.parts-9 {
	list-style: none;
}
.aform-content form ul.parts-9 li {
	padding: 0;
}
.aform-content form ul.parts-9 input {
	width: auto !important;
	margin-right: 10px ;
}


/* --------------------------------------------
    Responsive
-------------------------------------------- */
@media screen and (min-width: 768px) {
  .hidden-xs { display: block; }
  .visible-xs { display: none; }
}

@media screen and (max-width: 992px) {
  #drawer-content .menu-hd01 .menu-logo img { padding: 3px 0; }
  #drawer-content .menu-hd01 .menu-btn01 li a { font-size: 0.9em; padding: 7px 15px; }
  #hd01 .slider-txt01 { width: 70%; left: 5.5%; }
  #sec05 { padding: 0; }
  #sec05::before { left: 48%; width: 58%; max-width: 480px; }
  #sec05 .sec05-wrap { padding: 10% 0 7%; }
  #sec05 .sec05-tit { font-size: 1.8em; letter-spacing: 0.1em; }
}

@media screen and (max-width: 767px) {
  .hidden-xs { display: none;  }
  .visible-xs { display: block; }

  html, body { font-size: 18px; }
  h2 { font-size: 1.8em; }
  h2 span.titsub { font-size: 0.5em; }
  h3 { font-size: 2.25em; }
  h4 { font-size: 1.8em; letter-spacing: 0.1em; }
  h4 span.titsub { display: none; }
  .btn02 a { padding: 20px 35px; }

  #menu01 { min-height: 65px; }
  .navbar-header a h1 { padding: 20px 25px; }
  .navbar-header a h1 img { width: 160px; }
  #drawer-icon { width: 75px; padding: 18px; }
  #drawer-icon span::before { margin-top: -12px; }
  #drawer-icon span::after { margin-top: 24px; }
  .sidebtn { right: 75px; }
  .sidebtn .sldebtn-list li { width: 75px; }

  #drawer-content .menu-hd01 { padding: 30px 0 20px; }
  #drawer-content .menu-hd01 .menu-btn01 { display: block; float: none; margin-top: 25px; }
  #drawer-content .menu-box { margin: 0 auto 60px; }
  #drawer-content .menu-hd01 .menu-btn01 li.lang-btn { display: block; margin-bottom: 15px; }
  #drawer-content .menu-box01 { margin: 0; }
  #drawer-content .menu-box01:first-child { margin-top: 15px; }
  #drawer-content .menu-box01 h4 {  font-size: 1.5em; margin: 15px auto; }

  #hd01 { margin-top: 65px; }

  .info-box dt { width: 115px; }
  .info-box dd { width: calc(100% - 120px); }

  #sec02 .row { padding: 50px 0 0; }
  #sec02 .merit01-box { padding: 0 20px 25px; }
  #sec02 .merit01-box .merit01-tit { font-size: 1.2em; letter-spacing: 0.1em; }

  #sec04 {
    display: block;
    display: -ms-block;
    grid-template-columns: 100% 100%;
    -ms-grid-columns: 100% 100%;
  }
  #sec04 h3 { font-size: 2em; }

  #sec05 .sec05-wrap { padding: 50px 0 190px; }
  #sec05::before { width: 300px; left: calc(50% - 150px); height: 260px; }
  #sec05 .sec05-tit { font-size: 1.55em; letter-spacing: 0.1em; width: fit-content; margin-inline: auto; }
  #sec05 .btn02 { width: 17rem; }

  #ft01 .container { padding: 60px 25px 35px; }
  #ft01 .ft-menu li a { margin: 0 35px 0 0; }
  #ft01 .cp { letter-spacing: 0px; }

  /*-- 内部ページ --*/
  #titbar { margin-top: 65px; height: 150px; }
  #titbar h2 { padding: 42px 0; }
  .other-content .content-wrap p { line-height: 1.8; }
	
.circle {	
  width: 280px;
  height: 280px;
}

.circle div {
  left: 6%;
  width :250px;
}
.circle div h5 { font-size:1rem;}
.circle div { font-size:0.8rem;}
	
	.txt-philosophy01 { font-size: 1.3rem; }
	.txt-philosophy01 span { font-size: 0.7rem; }
	.txt-philosophy02 { font-size: 1.0rem; }

  .other-content h3 { font-size: 1.6em; padding-bottom: 35px; text-align: left; }
  .other-content h3 span.titsub { font-size: 16px; padding-top: 0.5rem; }
  .other-content h4 { font-size: 1.3em; letter-spacing: 0.05em; }
  .other-content h5 { font-size: 1.1em; }

  /* table */
  .other-content table th , .other-content table td { width: 100%!important; display: block; padding: 6px 12px; line-height: 1.6; }
  .other-content table th { font-size: 1em; padding: 6px 12px; }

  .nav-tabs { width: 18.5em; margin: 0 auto; }
  .nav-tabs > li:nth-child(even) > a::before { display: none; }
  /* カテ分けお知らせ */
  .information .data { font-size: 1em; }
  .information .icon { font-size: 0.9em; }
  .information .txt { width: 100%; padding-top: 10px; }


	.aform-content form span.parts-9 {
		font-size: 1em;
	}

}
@media screen and (max-width: 480px) {
    .sidebtn { display: none; }
}
