@charset "utf-8";
/* Author: Hosaka */
/* ---------------------------------------------------
	top
------------------------------------------------------ */
/* ---------------------------------------------------
	mainvisual
------------------------------------------------------ */
#mainvisual {
  position: relative;
  margin-bottom: 100px;
}
#mainvisual .main-slider .slides {display: none;}
#mainvisual .main-slider .slides.slick-initialized {display: block;}
#mainvisual .main-slider .slides .slide {
  height: 100vh;
/*  min-height: 740px;*/
}
.is_tablet #mainvisual .main-slider .slides .slide {
  height: 100%;
/*  min-height: 740px;*/
}
#mainvisual .main-slider .slides .slide img {
/*  display: none;*/
}
/*#mainvisual .main-slider .slides .slide.slide01 {
  background: url(../img/home/img-main-01.jpg) no-repeat center;
  background-size: cover;
}
#mainvisual .main-slider .slides .slide.slide02 {
  background: url(../img/home/img-main-01.jpg) no-repeat center;
  background-size: cover;
}
#mainvisual .main-slider .slides .slide.slide03 {
  background: url(../img/home/img-main-01.jpg) no-repeat center;
  background-size: cover;
}*/
#mainvisual .main-tit {
  position: absolute;
  left: 5%;
  top: 54%;
  max-width: 95%;
  font-size: 70px;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: .05em;
  z-index: 100;
}
@media screen and (max-width:812px) and (orientation:landscape){
  #mainvisual .main-tit{top:36%;}
}
#mainvisual .main-box {
  position: absolute;
  right: 10%;
  bottom: -100px;
  width: 400px;
  padding: 3px 20px 20px;
  background: #F3F1E6;
  border: 10px solid #fff;
  transition: background .4s;
}
#mainvisual .main-box:hover {
  background: #fff;
}
#mainvisual .main-box:hover img {
  opacity: 1;
}
#mainvisual .main-box:hover .box-link .link-btn {
  background: none;
  color: #111;
}
#mainvisual .main-box .box-tit {
  margin-bottom: 10px;
  padding-top: 35px;
  background: url(../img/home/bg-main-01.png) no-repeat center top;
  background-size: 144px;
  font-size: 50px;
  font-weight: 400;
  letter-spacing: .05em;
  line-height: 1;
  text-align: center;
}
#mainvisual .main-box .box-link {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  text-decoration: none;
}
#mainvisual .main-box .box-link .link-eyecatch {
  width: 120px;
  margin-bottom: 10px;
}
#mainvisual .main-box .box-link .link-eyecatch + .link-tit {
  width: calc(100% - 140px);
}
#mainvisual .main-box .box-link .link-tit {
  margin-bottom: 10px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.6;
}
#mainvisual .main-box .box-link .link-txt {
  width: calc(100% - 95px);
  font-size: 18px;
  line-height: 1.8;
}
#mainvisual .main-box .box-link .link-btn {
  width: 80px;
  height: 80px;
  padding-top: 25px;
  background: #111;
  border: 1px solid #111;
  border-radius: 50%;
  color: #fff;
  font-size: 20px;
  letter-spacing: .05em;
  line-height: 1.4;
  text-align: center;
  transition: all .4s;
}
#mainvisual .main-scroll {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 70px;
  width: 100px;
  margin: 0 auto;
  line-height: 1;
  letter-spacing: .1em;
  text-align: center;
}
#mainvisual .main-scroll a {
  display: inline-block;
  color: #fff;
  text-decoration: none;
}
#mainvisual .main-scroll a:hover img {
  opacity: 1;
  transform: translateY(2px);
}
#mainvisual .main-scroll .icon {
  display: block;
  margin: 3px auto 0;
  transition: transform .4s;
}

@media screen and (max-width: 1280px) {
  #mainvisual .main-box {
    right: 6%;
    bottom: -100px;
    width: 320px;
    padding: 3px 20px 20px;
    background: #F3F1E6;
    border-width: 5px;
  }
  #mainvisual .main-box .box-tit {
    font-size: 46px;
  }
  #mainvisual .main-box .box-link .link-eyecatch {
    width: 100px;
  }
  #mainvisual .main-box .box-link .link-eyecatch + .link-tit {
    width: calc(100% - 115px);
  }
  #mainvisual .main-box .box-link .link-tit {
    margin-bottom: 10px;
    font-size: 17px;
  }
  #mainvisual .main-box .box-link .link-txt {
    width: calc(100% - 74px);
    font-size: 15px;
  }
  #mainvisual .main-box .box-link .link-btn {
    width: 64px;
    height: 64px;
    padding-top: 16px;
  }
}
@media screen and (max-width: 1024px) {
  #mainvisual .main-box {
    right: 3%;
  }
}
@media screen and (max-width: 767px) {
  #mainvisual {
    margin-bottom: 0;
  }
  #mainvisual .main-slider {
    position: relative;
  }
  #mainvisual .main-slider .slides .slide {
    height: auto;
    min-height: auto;
  }
  #mainvisual .main-slider .slides .slide img {
    display: block;
    width: 170%;
    max-width: 170%;
    max-width: 0 -35%;
  }
  #mainvisual .main-tit {
    left: 5%;
    top: 38vw;
    font-size: 8vw;
  }
  #mainvisual .main-box {
    position: relative;
    right: 0;
    left: 0;
    bottom: 0;
    width: 90%;
    margin: -50px auto 0;
    padding: 3px 20px 20px;
    border-width: 8px;
  }
  #mainvisual .main-box:hover {
    background: #F3F1E6;
  }
  #mainvisual .main-box:hover .box-link .link-btn {
    background: #111;
    color: #fff;
  }
  #mainvisual .main-box .box-tit {
    padding-top: 35px;
    background: url(../img/home/bg-main-01.png) no-repeat center top;
    background-size: 124px;
    font-size: 40px;
  }
  #mainvisual .main-box .box-link .link-eyecatch {
    width: 100px;
  }
  #mainvisual .main-box .box-link .link-eyecatch + .link-tit {
    width: calc(100% - 120px);
  }
  #mainvisual .main-box .box-link .link-tit {
    margin-bottom: 10px;
    font-size: 18px;
  }
  #mainvisual .main-scroll {
    bottom: 65px;
  }
  #mainvisual .main-scroll a:hover img {
    transform: translateY(0);
  }
}
/* ---------------------------------------------------
	sec01
------------------------------------------------------ */
#sec01 {
  padding: 140px 0 160px;
}
#sec01 h2 {
  margin-bottom: 50px;
  font-size: 40px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: .1em;
  text-align: center;
}
#sec01 h2:before, #sec01 h2:after {
  content: "";
  display: inline-block;
  width: 181px;
  height: 8px;
  background: url(../img/common/bg-tit.png) no-repeat;
  background-size: auto 8px;
  vertical-align: middle;
}
#sec01 h2 > span {
  display: inline-block;
  padding: 0 40px;
  font-size: 40px;
  font-weight: 500;
}
#sec01 .sec-list {
  width: 94%;
  max-width: 1520px;
  margin: 0 auto 60px;
}
#sec01 .sec-list .list-item {
  display: block;
  width: 350px;
  max-width: 23.03%;
  margin-right: 2.62%;
  text-decoration: none;
}
#sec01 .sec-list .list-item:nth-of-type(4), #sec01 .sec-list .list-item:last-of-type {
  margin-right: 0;
}
#sec01 .sec-list .list-item .item-pic {
  margin-bottom: 15px;
	width: 100%;
	height: 260px;
	overflow: hidden;
	position: relative;
}
#sec01 .sec-list .list-item .item-pic img {position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); transform: translate(-50%, -50%); width: auto; height: auto; min-width: 100%; min-height: 100%;}
#sec01 .sec-list .list-item .item-date {
  margin-bottom: 10px;
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
	color: #777;
}
#sec01 .sec-list .list-item .item-tit {
  line-height: 1.4;
}

@media screen and (max-width: 767px) {
  #sec01 {
    padding: 60px 0 60px;
  }
  #sec01 h2 {
    margin-bottom: 30px;
    font-size: 40px;
  }
  #sec01 h2:before, #sec01 h2:after {
    width: 72px;
  }
  #sec01 h2 > span {
    padding: 0 20px;
    font-size: 36px;
  }
  #sec01 .sec-list {
    width: 90%;
    margin-bottom: 10px;
    justify-content: space-between;
  }
  #sec01 .sec-list .list-item {
    width: 48%;
    max-width: 48%;
    margin-right: 0;
    margin-bottom: 30px;
  }
  #sec01 .sec-list .list-item .item-pic {
    margin-bottom: 15px;
	width: 100%;
	  height: 130px;
  }
  #sec01 .sec-list .list-item .item-date {
    margin-bottom: 10px;
    font-size: 14px;
  }
  #sec01 .sec-list .list-item .item-tit {
    line-height: 1.4;
  }
  #sec01 .sec-btn {
    width: 90%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 568px) {
/*  #sec01 .sec-list .list-item {
    width: 100%;
    max-width: 100%;
  }*/
}
@media screen and (max-width: 844px) and (orientation:landscape) {
  #sec01 .sec-list .list-item .item-pic {
	height: 260px;
  }
}
/* ---------------------------------------------------
	sec02
------------------------------------------------------ */
#sec02 h2 {
  margin: 0 0 20px;
  font-weight: normal;
  font-size: 17px;
  line-height: 1.4;
  letter-spacing: .3em;
}
#sec02 h2 .en {
  display: block;
  margin-top: 15px;
  font-size: 50px;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.1;
}
#sec02 .btn-link {
  min-width: 0;
  width: 80px;
  height: 80px;
  padding: 25px 0 0;
  border-radius: 50%;
}
#sec02 .sec-row01 {
  background: #F3F1E6;
  text-align: center;
}
#sec02 .sec-row01 .row-pic {
  width: 50%;
}
#sec02 .sec-row01 .row-pic img {
  width: 100%;
}
#sec02 .sec-row01 .row-txt {
  width: 50%;
  padding: 30px 20px;
}
#sec02 .sec-row01 .row-txt h2 {
  margin-bottom: 10px;
}
#sec02 .sec-row01 .row-txt p {
  line-height: 2.2;
}
#sec02 .sec-row01 .row-txt .txt-labels {
  margin-bottom: 30px;
  font-size: 15px;
  line-height: 1.5;
}
#sec02 .sec-row01 .row-txt .txt-labels > span {
  display: inline-block;
  margin: 0 5px;
  padding: 2px 15px;
  border: 1px solid #111;
  font-weight: 600;
  vertical-align: middle;
}
#sec02 .sec-row01 .row-txt .txt-btn {
  margin-top: 50px;
}
#sec02 .sec-row02 .row-col {
  width: 50%;
  background: #F3F1E6;
  text-align: center;
}
#sec02 .sec-row02 .row-col:nth-of-type(2) {
  background: #A8A595;
}
#sec02 .sec-row02 .row-col .col-pic {
  width: 50%;
}
#sec02 .sec-row02 .row-col .col-pic img {
  width: 100%;
}
#sec02 .sec-row02 .row-col .col-txt {
  width: 50%;
  padding: 30px 20px;
}
#sec02 .sec-row02 .row-col .col-txt p {
  line-height: 2.2;
}
#sec02 .sec-row02 .row-col .col-txt .txt-btn {
  margin-top: 40px;
}

@media screen and (max-width: 1440px) {
  #sec02 h2 {
    margin-bottom: 15px;
  }
  #sec02 .sec-row01 .row-txt p {
    line-height: 2;
  }
  #sec02 .sec-row01 .row-txt .txt-btn {
    margin-top: 20px;
  }
  #sec02 .sec-row02 .row-col .col-pic {
    overflow: hidden;
  }
  #sec02 .sec-row02 .row-col .col-pic img {
    width: 122%;
    max-width: 122%;
    margin: 0 -11%;
  }
  #sec02 .sec-row02 .row-col .col-txt p {
    line-height: 2;
  }
  #sec02 .sec-row02 .row-col .col-txt .txt-btn {
    margin-top: 20px;
  }
}
@media screen and (max-width: 1280px) {
  #sec02 h2 {
    margin-bottom: 15px;
  }
  #sec02 .sec-row01 .row-pic {
    overflow: hidden;
  }
  #sec02 .sec-row01 .row-pic img {
    width: 120%;
    max-width: 120%;
    margin: 0 -10%;
  }
  #sec02 .sec-row01 .row-txt p {
    line-height: 2;
  }
  #sec02 .sec-row01 .row-txt .txt-btn {
    margin-top: 20px;
  }
  #sec02 .sec-row02 .row-col .col-pic {
    width: 100%;
  }
  #sec02 .sec-row02 .row-col .col-pic img {
    width: 100%;
    max-width: 100%;
    margin: -30% 0;
  }
  #sec02 .sec-row02 .row-col .col-txt {
    width: 100%;
    padding: 40px 20px 50px;
  }
  #sec02 .sec-row02 .row-col .col-txt p {
    line-height: 2;
  }
  #sec02 .sec-row02 .row-col .col-txt .txt-btn {
    margin-top: 20px;
  }
}
@media screen and (max-width: 1024px) {
  #sec02 .sec-row01 .row-pic {
    width: 100%;
  }
  #sec02 .sec-row01 .row-pic img {
    width: 100%;
    max-width: 100%;
    margin: 0 0 -30%;
  }
  #sec02 .sec-row01 .row-txt {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  #sec02 h2 .en {
    margin-top: 10px;
    font-size: 40px;
  }
}
@media screen and (max-width: 568px) {
  #sec02 .sec-row01 .row-pic img {
    margin: 0 0 -10%;
  }
  #sec02 .sec-row02 .row-col {
    width: 100%;
  }
  #sec02 .sec-row02 .row-col .col-txt {
    padding: 30px 20px;
  }
}
/* ---------------------------------------------------
	sec03
------------------------------------------------------ */
#sec03 {
  padding: 140px 0 160px;
  background: url(../img/home/bg-sec03-01.jpg) center top;
}
#sec03 h2 {
  margin-bottom: 50px;
  font-size: 40px;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: .1em;
  text-align: center;
}
#sec03 h2:before, #sec03 h2:after {
  content: "";
  display: inline-block;
  width: 181px;
  height: 8px;
  background: url(../img/common/bg-tit.png) no-repeat;
  background-size: auto 8px;
  vertical-align: middle;
}
#sec03 h2 > span {
  display: inline-block;
  padding: 0 40px;
  font-size: 40px;
  font-weight: 500;
}
#sec03 h3 {
  margin: 0 0 20px;
  font-weight: normal;
  font-size: 17px;
  line-height: 1.4;
  letter-spacing: .3em;
}
#sec03 h3 .en {
  display: block;
  margin-top: 5px;
  font-size: 50px;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.1;
}
#sec03 .sec-row {
  position: relative;
  width: 94%;
  max-width: 1520px;
  margin: 0 auto;
  background: url(../img/home/bg-sec03-02.png) repeat-y center top;
}
#sec03 .sec-row .row-col {
  width: 680px;
  max-width: 44.8%;
}
#sec03 .sec-row .row-col .col-txt {
  padding: 30px 20px 0;
}
#sec03 .sec-row .row-col .col-txt p {
  float: left;
  width: calc(100% - 100px);
}
#sec03 .sec-row .row-col .col-txt .btn-link {
  float: right;
  min-width: 0;
  width: 80px;
  height: 80px;
  padding: 25px 0 0;
  border-radius: 50%;
}

@media screen and (max-width: 767px) {
  #sec03 {
    padding: 60px 0 30px;
  }
  #sec03 h2 {
    margin-bottom: 0;
    font-size: 40px;
  }
  #sec03 h2:before, #sec03 h2:after {
    width: 72px;
  }
  #sec03 h2 > span {
    padding: 0 20px;
    font-size: 36px;
  }
  #sec03 h3 {
    margin-bottom: 15px;
  }
  #sec03 h3 .en {
    font-size: 40px;
  }
  #sec03 .sec-row {
    width: 90%;
    background: none;
  }
  #sec03 .sec-row .row-col {
    width: 100%;
    max-width: 100%;
    padding: 30px 0;
  }
  #sec03 .sec-row .row-col + .row-col {
    border-top: 1px solid #777;
  }
  #sec03 .sec-row .row-col .col-txt {
    padding: 30px 15px 0;
  }
  #sec03 .sec-row .row-col .col-txt p {
    float: left;
    width: calc(100% - 100px);
  }
  #sec03 .sec-row .row-col .col-txt .btn-link {
    float: right;
    min-width: 0;
    width: 80px;
    height: 80px;
    padding: 25px 0 0;
    border-radius: 50%;
  }
}
/* ---------------------------------------------------
	sec04
------------------------------------------------------ */
#sec04 {
  padding: 90px 0 90px;
}
#sec04 .sec-bnr01 {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 7px;
  border: 3px solid #111;
  text-decoration: none;
}
#sec04 .sec-bnr01:hover {
  background: #F3F1E6;
}
#sec04 .sec-bnr01:hover img {
  opacity: 1;
}
#sec04 .sec-bnr01:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 40px;
  height: 40px;
  background: url(../img/common/bg-btn.svg) no-repeat right bottom;
  background-size: 100%;
}
#sec04 .sec-bnr01 .bnr-tit {
  width: calc(100% - 382px);
  margin: 0;
  padding: 0 15px;
  font-size: 28px;
  font-weight: normal;
  letter-spacing: .15em;
  line-height: 1.4;
  text-align: center;
}
#sec04 .sec-bnr01 .bnr-tit .icon {
  margin-left: 7px;
}
#sec04 .sec-bnr01 .bnr-pic {
  width: 382px;
}
#sec04 .sec-bnr02 {
  position: relative;
  display: block;
  margin-top: 100px;
  height: 340px;
  background: url(../img/home/bg-sec04-01.jpg) no-repeat center;
  background-size: cover;
  text-decoration: none;
}
#sec04 .sec-bnr02:hover {
  opacity: .7;
}
#sec04 .sec-bnr02 .bnr-tit {
  position: absolute;
  right: 16%;
  top: 50%;
  margin: -40px 0 0;
  padding: 0;
  font-weight: normal;
  font-size: 17px;
  line-height: 1.4;
  letter-spacing: .3em;
  text-align: left;
}
#sec04 .sec-bnr02 .bnr-tit .en {
  display: block;
  margin-top: 5px;
  font-size: 50px;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.1;
}
#sec04 .sec-bnr03 {
  position: relative;
  display: block;
  margin-top: 100px;
  height: 340px;
  background: url(../img/home/bg-sec04-02.jpg) no-repeat center;
  background-size: cover;
  text-decoration: none;
}
#sec04 .sec-bnr03:hover {
  opacity: .7;
}
#sec04 .sec-bnr03 .bnr-tit {
  position: absolute;
  right: 16%;
  top: 50%;
  margin: -40px 0 0;
  padding: 0;
  font-weight: normal;
  font-size: 17px;
  line-height: 1.4;
  letter-spacing: .3em;
  text-align: left;
}
#sec04 .sec-bnr03 .bnr-tit .en {
  display: block;
  margin-top: 5px;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.1;
}
#sec04 .sec-bnr04 {
  position: relative;
  display: block;
  margin-top: 100px;
  height: 340px;
  background: url(../img/home/bg-sec04-03.jpg) no-repeat center;
  background-size: cover;
  text-decoration: none;
}
#sec04 .sec-bnr04:hover {
  opacity: .7;
}
#sec04 .sec-bnr04 .bnr-tit {
  position: absolute;
  right: 16%;
  top: 50%;
  margin: -40px 0 0;
  padding: 0;
  font-weight: normal;
  font-size: 17px;
  line-height: 1.4;
  letter-spacing: .3em;
  text-align: left;
}
#sec04 .sec-bnr04 .bnr-tit .en {
  display: block;
  margin-top: 5px;
  font-size: 30px;
  font-weight: 500;
  letter-spacing: .05em;
  line-height: 1.1;
}
@media screen and (max-width: 767px) {
  #sec04 {
    padding: 60px 0 80px;
  }
  #sec04 .sec-bnr01 {
    display: block;
  }
  #sec04 .sec-bnr01:hover {
    background: none;
  }
  #sec04 .sec-bnr01 .bnr-tit {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 15px 30px;
    font-size: 24px;
  }
  #sec04 .sec-bnr01 .bnr-tit .icon {
    position: absolute;
    right: 10px;
    top: 0;
    bottom: 0;
    margin: auto 0;
  }
  #sec04 .sec-bnr01 .bnr-pic {
    width: 100%;
  }
  #sec04 .sec-bnr01 .bnr-pic img {
    width: 100%;
  }
  #sec04 .sec-bnr02 {
    margin-top: 40px;
    height: 180px;
    background: url(../img/home/bg-sec04-01.jpg) no-repeat center;
    background-size: cover;
  }
  #sec04 .sec-bnr02:hover {
    opacity: 1;
  }
  #sec04 .sec-bnr02 .bnr-tit {
    right: 10%;
    top: 50%;
    margin: -35px 0 0;
  }
  #sec04 .sec-bnr02 .bnr-tit .en {
    font-size: 40px;
  }
  #sec04 .sec-bnr03 {
    margin-top: 40px;
    height: 180px;
    background: url(../img/home/bg-sec04-02.jpg) no-repeat center;
    background-size: cover;
  }
  #sec04 .sec-bnr03:hover {
    opacity: 1;
  }
  #sec04 .sec-bnr03 .bnr-tit {
    right: 10%;
    top: 50%;
    margin: -20px 0 0;
        font-size: 10px;
  }
  #sec04 .sec-bnr03 .bnr-tit .en {
    font-size: 25px;
  }
  #sec04 .sec-bnr04 {
    margin-top: 40px;
    height: 180px;
    background: url(../img/home/bg-sec04-03.jpg) no-repeat center;
    background-size: cover;
  }
  #sec04 .sec-bnr04:hover {
    opacity: 1;
  }
  #sec04 .sec-bnr04 .bnr-tit {
    right: 10%;
    top: 50%;
    margin: -35px 0 0;
        font-size: 8px;
  }
  #sec04 .sec-bnr04 .bnr-tit .en {
    font-size: 22px;
  }
}
/*-------------------------------------------*/
/*
/*　　IE用cssハック
/*
/*-------------------------------------------*/
@media all and (-ms-high-contrast: none) {
  #sec02 .sec-row01 .row-txt .txt-labels > span {
    padding-top: 8px;
  }
}
/*-------------------------------------------*/
/*
/*　　print
/*
/*-------------------------------------------*/
