@charset "UTF-8";
html {
  font-size: 62.5%;
}

body {
  overflow: hidden;
  font-size: 1.2rem;
  line-height: 1.6;
  color: #1a1a1a;
  font-family: 'Hiragino Sans','Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'Meiryo', 'メイリオ', Osaka, 'MS PGothic',sans-serif;
  -webkit-font-feature-settings: "palt";
  font-feature-settings: "palt";
}

.mincho {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", '\5b8b\4f53',serif;
}

#side-mail {
  position: fixed;
  z-index: 100;
  right: 0;
  display: none;
  top: 200px;
}

@media screen and (max-width: 640px) {
div#book{
width:100px
margin:auto;
text-align:center;
}
div#book img{
display:block;
width:100px;
margin:auto;

}

div#book2{
width:100px
margin:auto;
text-align:center;
}
div#book2 img{
display:block;
width:100px;
padding-top:106vw;
margin:auto;

}
  #side-mail {
    top: 100px;
  }
}

@media screen and (min-width: 769px) {

div#book2{
width:80%;
margin:auto;
text-align:right;
}
	}
div#book{
width:80%;
margin:auto;
text-align:center;}

  .hidden-desktop {
    display: none;
  }
  a {
    -webkit-transition: all .3s ease-in-out;
    -o-transition: all .3s ease-in-out;
    transition: all .3s ease-in-out;
  }
  a:hover {
    opacity: .5;
    -moz-opacity: .5;
  }
}

@media screen and (min-width: 641px) and (max-width: 768px) {
div#book2{
width:80%;
margin:auto;
text-align:right;
}
  
  .hidden-tablet {
    display: none;
  }
  img {
    max-width: 100%;
  }
}

@media screen and (max-width: 640px) {
  .hidden-phone {
    display: none;
  }
  img {
    max-width: 100%;
  }
}

.w640 {
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.mb0 {
  margin-bottom: 0rem;
}

.mb5 {
  margin-bottom: 0.5rem;
}

.mb10 {
  margin-bottom: 1rem;
}

.mb15 {
  margin-bottom: 1.5rem;
}

.mb20 {
  margin-bottom: 2rem;
}

.mb25 {
  margin-bottom: 2.5rem;
}

.mb30 {
  margin-bottom: 3rem;
}

.mb35 {
  margin-bottom: 3.5rem;
}

.mb40 {
  margin-bottom: 4rem;
}

.mb45 {
  margin-bottom: 4.5rem;
}

.mb50 {
  margin-bottom: 5rem;
}

.mb55 {
  margin-bottom: 5.5rem;
}

.mb60 {
  margin-bottom: 6rem;
}

.mb65 {
  margin-bottom: 6.5rem;
}

.mb70 {
  margin-bottom: 7rem;
}

.mb75 {
  margin-bottom: 7.5rem;
}

.mb80 {
  margin-bottom: 8rem;
}

.mb85 {
  margin-bottom: 8.5rem;
}

.mb90 {
  margin-bottom: 9rem;
}

.mb95 {
  margin-bottom: 9.5rem;
}

.mb100 {
  margin-bottom: 10rem;
}

.mb105 {
  margin-bottom: 10.5rem;
}

.mb110 {
  margin-bottom: 11rem;
}

.mb115 {
  margin-bottom: 11.5rem;
}

.mb120 {
  margin-bottom: 12rem;
}

.mb125 {
  margin-bottom: 12.5rem;
}

.mb130 {
  margin-bottom: 13rem;
}

.mb135 {
  margin-bottom: 13.5rem;
}

.mb140 {
  margin-bottom: 14rem;
}

.mb145 {
  margin-bottom: 14.5rem;
}

.mb150 {
  margin-bottom: 15rem;
}

.mb1em {
  margin-bottom: 1em;
}

/* ===============================
  
  header
  
=============================== */
header {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.9);
  padding: 4rem 0;
  z-index: 100;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

header .tel {
  position: absolute;
  right: 30px;
  top: 50%;
  margin-top: -30px;
}

@media screen and (min-width: 641px) {
  header {
    height: 170px;
  }
  header h1 {
    text-align: center;
  }
}

@media screen and (max-width: 640px) {
  header {
    padding: 1.5rem;
    height: 80px;
  }
  header h1 {
    padding-left: 15px;
    width: calc(100% - 80px);
    width: -webkit-calc(100% - 80px);
  }
  header .tel {
    right: 10px;
    width: 40px;
    margin-top: -20px;
  }
}

/* ===============================
  
  main
  
=============================== */
main#key {
  background: url(../images/bg1.jpg) no-repeat center top/cover;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (min-width: 641px) {
  main#key {
    min-height: 830px;
  }
  main#key h1 {
    padding-top: 420px;
  }
  main#key #arrow {
    padding-top: 140px;
  }
}

@media screen and (max-width: 640px) {
  main#key {
    height: 100vh;
    position: relative;
  }
  main#key h1 {
    position: absolute;
    top: 40%;
    left: 3%;
    width: 94%;
  }
  main#key #arrow {
    position: absolute;
    bottom: 30px;
    left: 0;
    width: 100%;
    text-align: center;
  }
}

/* ===============================
  
  desc
  
=============================== */
#desc {
  background-color: #39ac4a;
  color: #fff;
  font-size: 1.8rem;
  padding: 3rem 0;
}

@media screen and (max-width: 640px) {
  #desc {
    padding: 4rem 3%;
  }
}

/* ===============================
  
  sec1
  
=============================== */
#sec1 p.w640 {
  font-size: 1.6rem;
  line-height: 2.1;
  letter-spacing: 0.14em;
}

#sec1 .text1 {
  color: #39ac4a;
  font-weight: 500;
  font-size: 3.0rem;
}

#sec1 .list1 {
  text-align: center;
  letter-spacing: -0.4em;
  max-width: 960px;
  margin: 0 auto 30px;
}

#sec1 .list1 li {
  display: inline-block;
  letter-spacing: normal;
  margin: 10px;
}

@media screen and (max-width: 640px) {
  #sec1 {
    padding: 2rem 3%;
  }
  #sec1 .text1 {
    font-size: 2.6rem;
  }
}

/* ===============================
  
  sec2
  
=============================== */
#sec2 #work-slide li img {
  margin-left: auto;
  margin-right: auto;
}

#sec2 #work-slide .img {
  margin-bottom: 20px;
}

#sec2 #work-slide a {
  display: block;
  text-align: center;
}

@media screen and (max-width: 640px) {
  #sec2 {
    padding: 2rem 3%;
  }
}

/* ===============================
  
  ポップアップの中身
  
=============================== */
.window-inner {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  max-width: 1300px;
  width: 90%;
  margin: 100px auto;
  background-color: #fff;
  padding: 40px 20px 20px;
  border: 1px solid #c9caca;
  position: relative;
}

.window-inner h3 {
  text-align: center;
  color: #39ac4a;
  font-weight: 500;
  font-size: 3.0rem;
  margin-bottom: 40px;
}

.window-inner .text p {
  font-size: 1.6rem;
  line-height: 2;
}

.window-inner img {
  max-width: 100%;
}

.window-inner .mfp-close {
  width: 45px;
  height: 45px;
  position: absolute;
  top: 0px;
  left: 10px;
}

.window-inner .mfp-close:after, .window-inner .mfp-close:before {
  content: '';
  display: block;
  width: 60px;
  height: 2px;
  background-color: #000;
  position: absolute;
  left: 0;
  top: 40px;
}

.window-inner .mfp-close:before {
  -webkit-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.window-inner .mfp-close:after {
  -webkit-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  transform: rotate(45deg);
}

@media screen and (min-width: 641px) {
  .window-inner ul {
    overflow: hidden;
  }
  .window-inner ul li {
    width: 49%;
    float: left;
  }
  .window-inner ul li:nth-child(2n) {
    float: right;
  }
}

@media screen and (max-width: 640px) {
  .window-inner h3 {
    margin-top: 30px;
    font-size: 2.4rem;
  }
  .window-inner li {
    margin-bottom: 30px;
  }
}

.window-inner .img {
  position: relative;
}

.window-inner .img.bottom {
  margin-bottom: 60px;
}

.window-inner .img.bottom i {
  bottom: -50px;
}

.window-inner .img.top {
  margin-top: 60px;
}

.window-inner .img.top i {
  top: -50px;
}

.window-inner .img i {
  position: absolute;
  left: 50%;
  margin-left: -50px;
}

/* ===============================
  
  sec3
  
=============================== */
#sec3 {
  background: url(../images/bg2.jpg) no-repeat center top/cover;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

#sec3 .box {
  border: 1px solid #fff;
  padding: 20px;
  position: relative;
}

#sec3 .box i {
  position: absolute;
  top: -50px;
}

#sec3 .text {
  color: #fff;
  font-size: 1.4rem;
  line-height: 2;
}

@media screen and (min-width: 641px) {
  #sec3 {
    min-height: 740px;
    padding: 90px 0 0;
  }
  #sec3 i {
    left: -50px;
  }
  #sec3 ul {
    max-width: 940px;
    margin-left: auto;
    margin-right: auto;
  }
  #sec3 ul li {
    float: left;
    width: 49%;
    max-width: 440px;
  }
  #sec3 ul li:nth-child(2n) {
    float: right;
  }
}

@media screen and (max-width: 1000px) {
  #sec3 i {
    left: 50%;
    margin-left: -50px;
  }
}

@media screen and (max-width: 640px) {
  #sec3 {
    padding: 5rem 3%;
  }
  #sec3 li {
    margin-bottom: 50px;
  }
}

/* ===============================
  
  sec4
  
=============================== */
#sec4 {
  padding: 5rem 0;
}

#sec4 .contents {
  max-width: 1760px;
  margin-left: auto;
  margin-right: auto;
}

#sec4 img {
  max-width: 100%;
}

#sec4 .box1 {
  background: url(../images/ph1.jpg) no-repeat center center/cover;
}

#sec4 .box1 h3 {
  font-size: 2.8rem;
  margin-top: 10px;
}

#sec4 .box1 p {
  margin-top: 10px;
  font-size: 1.6rem;
  line-height: 1.8;
}

@media screen and (min-width: 641px) {
  #sec4 {
    overflow: hidden;
  }
  #sec4 .box1 {
    float: right;
    width: 66%;
    display: table;
  }
  #sec4 .box1 .inner {
    display: table-cell;
    padding: 0 0 0 50px;
    vertical-align: middle;
  }
  #sec4 .box1 .inner p {
    max-width: 500px;
  }
  #sec4 .box2 {
    float: left;
    width: 33%;
    margin-bottom: 1%;
  }
  #sec4 .box3 {
    float: left;
    width: 33%;
  }
}

@media screen and (max-width: 640px) {
  #sec4 {
    padding: 5rem 3%;
  }
  #sec4 .box1 {
    padding: 5rem 10px;
    margin-bottom: 20px;
  }
  #sec4 .box1 h3 {
    font-size: 2.4rem;
  }
  #sec4 .box2 {
    margin-bottom: 20px;
  }
}

/* ===============================
  
  sec5
  
=============================== */
#sec5 {
  background: url(../images/bg3.jpg) no-repeat center top/cover;
}

#sec5 p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 2.2;
  letter-spacing: 0.14em;
}

@media screen and (min-width: 641px) {
  #sec5 {
    min-height: 740px;
    padding: 110px 0 0;
  }
}

@media screen and (max-width: 640px) {
  #sec5 {
    padding: 5rem 3%;
  }
}

/* ===============================
  
  sec6
  
=============================== */
#sec6 {
  padding: 5rem 0;
}

#sec6 .contents {
  max-width: 1760px;
  margin-left: auto;
  margin-right: auto;
}

#sec6 img {
  max-width: 100%;
}

#sec6 .box1 {
  background: url(../images/ph4.jpg) no-repeat center center/cover;
}

#sec6 .box1 h3 {
  font-size: 2.8rem;
  margin-top: 10px;
  color: #fff;
}

#sec6 .box1 p {
  margin-top: 10px;
  font-size: 1.6rem;
  line-height: 1.8;
  color: #fff;
}

@media screen and (min-width: 641px) {
  #sec6 {
    overflow: hidden;
  }
  #sec6 .box1 {
    float: left;
    width: 66%;
    display: table;
  }
  #sec6 .box1 .inner {
    text-align: right;
    display: table-cell;
    padding: 0 0 0 calc(100% - 600px);
    padding: 0 0 0 -webkit-calc(100% - 600px);
    vertical-align: middle;
  }
  #sec6 .box1 .inner p {
    max-width: 500px;
  }
  #sec6 .box2 {
    float: right;
    width: 33%;
    margin-bottom: 1%;
  }
  #sec6 .box3 {
    float: right;
    width: 33%;
  }
}

@media screen and (max-width: 640px) {
  #sec6 {
    padding: 5rem 3%;
  }
  #sec6 .box1 {
    padding: 5rem 10px;
    margin-bottom: 20px;
  }
  #sec6 .box1 h3 {
    font-size: 2.4rem;
  }
  #sec6 .box2 {
    margin-bottom: 20px;
  }
}

/* ===============================
  
  sec7
  
=============================== */
#sec7 {
  background: url(../images/bg4.jpg) no-repeat center top/cover;
  padding-bottom: 5rem;
}

#sec7 p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 2.3;
  letter-spacing: 0.14em;
  text-align: center;
}

#sec7 #photo-list {
  background-color: #fff;
  overflow: hidden;
}

#sec7 #photo-list li {
  float: left;
}

#sec7 #photo-list li a {
  display: block;
  line-height: 1;
}

#sec7 #photo-list li img {
  max-width: 100%;
}

#sec7 #photo-list li.first {
  width: 16.8%;
  max-width: 153px;
  margin: 0.5%;
}

#sec7 #photo-list li.second {
  width: 64%;
  max-width: 582px;
  margin: 0.5% 0.5% 0.5% 0;
}

#sec7 #photo-list li.third {
  width: 16.8%;
  max-width: 153px;
  margin: 0.5% 0;
}

#sec7 #photo-list li .l-box1 {
  width: 39.6%;
  margin: 0 1% 1% 0;
}

#sec7 #photo-list li .l-box2 {
  width: 40.5%;
  margin: 0 1% 1% 0;
}

#sec7 #photo-list li .l-box3 {
  width: 17.8%;
  margin: 0 0 1% 0;
}

#sec7 #photo-list li .l-box4 {
  width: 22%;
  margin: 0 1% 0 0;
}

#sec7 #photo-list li .l-box5 {
  width: 28.3%;
  margin: 0 1% 1% 0;
}

#sec7 #photo-list li .l-box6 {
  width: 28.3%;
  margin: 0 1% 1% 0;
}

#sec7 #photo-list li .l-box7 {
  width: 76.8%;
}

#sec7 #photo-list li .mb {
  margin-bottom: 3%;
}

#sec7 .koumu-list {
  max-width: 930px;
  margin: 0 auto;
  overflow: hidden;
}

#sec7 .koumu-list li {
  float: left;
  width: 300px;
  margin: 5px;
}

#sec7 .koumu-list li a {
  display: block;
  text-align: center;
  background-color: #fff;
  padding: 10px 0;
  font-size: 1.6rem;
}

@media screen and (min-width: 641px) {
  #sec7 {
    min-height: 800px!important;
    padding: 50px 0 0;
  }
  #sec7 #photo-list {
    max-width: 908px;
    margin: 0 auto 50px;
  }
}

@media screen and (max-width: 929px) {
  #sec7 .koumu-list {
    max-width: 620px;
  }
}

@media screen and (max-width: 619px) {
  #sec7 .koumu-list {
    max-width: 300px;
  }
}

@media screen and (max-width: 640px) {
  #sec7 {
    padding: 5rem 3%;
  }
  #sec7 #photo-list {
    margin-bottom: 30px;
  }
  #sec7 h2 {
    font-size: 2.8rem;
  }
  #sec7 p {
    font-size: 1.4rem;
  }
}

/* ===============================
  
  sec8
  
=============================== */
#sec8 {
  background: url(../images/bg5.jpg) no-repeat center top/cover;
}

#sec8 h2 {
  color: #fff;
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 30px;
}

#sec8 p {
  color: #fff;
  font-size: 1.6rem;
  line-height: 2.3;
  letter-spacing: 0.14em;
  text-align: center;
}

@media screen and (min-width: 641px) {
  #sec8 {
    min-height: 650px;
    padding: 110px 0 0;
  }
}

@media screen and (max-width: 640px) {
  #sec8 {
    padding: 5rem 3%;
  }
  #sec8 h2 {
    font-size: 2.8rem;
  }
  #sec8 p {
    font-size: 1.4rem;
  }
}
