@font-face {
  font-family: 'EBGaramond08-Regular';
  src: url('fonts/EBGaramond08-Regular.eot?#iefix') format('embedded-opentype'),  url('fonts/EBGaramond08-Regular.otf')  format('opentype'),
      url('fonts/EBGaramond08-Regular.woff') format('woff'), url('fonts/EBGaramond08-Regular.ttf')  format('truetype'), url('fonts/EBGaramond08-Regular.svg#EBGaramond08-Regular') format('svg');
  font-weight: normal;
  font-style: normal;
}

/*===== CSS RESET =====*/

html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,cite,code,del,dfn,img,ins,kbd,q,s,samp,strike,tt,var,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,embed,figure,figcaption,footer,header,hgroup,menu,nav,output,ruby,section,summary,time,mark,audio,video,input,textarea,select{outline:none;border:0;font-size:100%;vertical-align:baseline;margin:0;padding:0}table{border-collapse:collapse;border-spacing:0}.clear{clear:both}.clearfix:after{content:" ";display:table;clear:both}.clearfix{*zoom:1}ul,ol{list-style:none;}*,*:before,*:after{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}body *{max-height:99999em}body img{max-height:none}


/*===== BASE =====*/
*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

html, body {
  width: 100%;
  min-height: 100%;
}
body {
  background: #FFF;
  font-size: 14px;
  line-height: 1.4;
  font-family: "ヒラギノ角ゴProN", Kozuka Gothic Pro, Meiryo, YuGothic, "Hiragino Kaku Gothic ProN", sans-serif;
  -webkit-text-size-adjust: none;
  color: #161c1e;
}

ul, ol, li {
  list-style: none;
}

a {
  color: #000;
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}

.clearfix:after {
  content: " ";
  display: table;
  clear: both;
}

.container {
  width: 100%;
  max-width: 960px;
  margin: auto;
}

.btn {
  font-size: 16px;
  line-height: 1em;
  text-align: center;
  width: 204px;
  margin: 0 auto;
  display: block;
  border: 1px solid #161c1e;
  position: relative;
  padding: 11px 0;
  font-weight: 500;
  background: none;
  outline: none;
}

.btn:hover {
  background: #161c1e;
  color: #fff !important;
}

.section-works {
  padding: 71px 0 0;
  overflow: hidden;
}
.section-works .sec-title > a {
  width: 200px;
  display: block;
  margin: 0 auto 20px;
}
.section-works .sec-title > span {
  font-size: 20px;
}
.section-works .works-part {
  font-size: 22px;
  line-height: 1em;
  letter-spacing: 0.05em;
  width: 100%;
  padding: 60px 0 14px;
}
#works-full .section-works .works-part {
  font-size: 22px;
  text-align: center;
}
.section-works .works-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 30px;
  padding: 0 0 60px;
  border-bottom: 1px solid #707070;
}
.section-works .works-list#all-list {
  padding-top: 20px;
}
.section-works .works-list > li {
  display: block;
  width: 292px;
  height: auto;
  box-sizing: border-box;
}
.section-works .works-list > li:nth-child(3n):after {
  content: " ";
  display: table;
  clear: both;
}
.section-works .works-list a {
  display: block;
  width: 100%;
}
.section-works .works-list a .image {
  width: 100%;
  height: 150px;
  line-height: 0;
  box-sizing: border-box;
  border: 1px solid #707070;
  position: relative;
}
.section-works .works-list a .image img.w-img {
  width: 100%;
  line-height: 0;
}
.section-works .works-list a .image .lik {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  background: rgba(22, 28, 30, 0.8);
  opacity: 0;
}
.section-works .works-list a:hover .image .lik {
  opacity: 1;
}
.section-works .works-list a .image .lik .btn {
  width: 179px;
  left: 50%;
  top: 50%;
  height: 40px;
  border-color: #fff;
  color: #fff;
  position: absolute;
  margin: -20px 0 0 -89.5px;
}
.section-works .works-list a:hover .image .lik .btn {
  background: transparent;
}
.section-works .works-list a .info {
  width: 100%;
}
.section-works .works-list a .info .w-title {
  font-size: 16px;
  line-height: 1.5em;
  letter-spacing: 0.08em;
  font-weight: bold;
  padding: 15px 0 5px;
  margin: 0;
}
.section-works .works-list a .info .w-type {
  font-size: 12px;
  line-height: 1.5em;
  color: #999;
  margin: 0;
}
.section-works .works-viewfull {
  width: 100%;
  text-align: center;
}
.section-works .works-viewfull .w-msg {
  font-size: 16px;
  line-height: 1.5em;
  margin: 55px 0 26px;
}
.section-works .works-article {
  margin-top: 42px;
}
.section-works .works-article .row-back {
  padding: 60px 0 0;
  text-align: center;
}
.section-works .works-article .row-back a {
  display: inline-block;
  padding: 10px 20px;
  font-size: 16px;
  line-height: 1em;
  color: #fff;
  border-radius: 10px;
  background: #000;
}
.section-works .works-article .works-info {
  letter-spacing: 0.5px;
}
.section-works .works-article .works-info .w-part1 {
}
.section-works .works-article .works-info .w-part1 .w-mainimg {
  position: relative;
  width: 100%;
  height: auto;
  line-height: 0;
}
.section-works .works-article .works-info .w-part1 .w-mainimg:after {
  content: " ";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border: 1px solid #707070;
}
.section-works .works-article .works-info .w-part1 .w-mainimg img {
  width: 100%;
  height: auto;
}
.section-works .works-article .works-info .w-part1 .btn {
  position: absolute;
  right: 30px;
  bottom: -20px;
  background: #fff;
  width: auto;
  min-width: 180px;
  font-size: 16px;
  font-weight: bold;
  padding: 12px 20px;
  box-sizing: border-box;
  z-index: 1;
}
.section-works .works-article .works-info .w-part1 .btn:hover {
  background: #000;
}
.section-works .works-article .works-info .w-part1 p.btn,
.section-works .works-article .works-info .w-part1 p.btn:hover {
  font-weight: normal;
  background: #999;
  border-color: #999;
  color: #fff !important;
}
.section-works .works-article .works-info .w-part1 p.btn:before {
  display: none;
}
.section-works .works-article .works-info .w-part1 .w-set {
  display: table;
  width: 100%;
  margin: 36px 0 0;
}
.section-works .works-article .works-info .w-part1 .w-set .w-head {
  display: table-cell;
  vertical-align: top;
  width: 50%;
  padding: 0 30px;
  box-sizing: border-box;
}
.section-works .works-article .works-info .w-part1 .w-set .w-head .w-title {
  font-size: 28px;
  line-height: 1.5em;
  margin: -6px 0 0;
}
.section-works .works-article .works-info .w-part1 .w-set .w-head .w-type {
  font-size: 14px;
  line-height: 1.5em;
  padding: 4px 0 0;
  color: #7fd0dd;
  font-weight: bold;
}
.section-works .works-article .works-info .w-part1 .w-set .w-detail {
  display: table-cell;
  vertical-align: top;
  width: 50%;
  padding: 0 30px;
  box-sizing: border-box;
  border-left: 1px solid #707070;
  font-size: 14px;
  line-height: 1.87em;
}
.section-works .works-article .works-info .w-part1 .w-set .w-detail li {
  display: table;
  width: 100%;
}
.section-works .works-article .works-info .w-part1 .w-set .w-detail li .th {
  display: table-cell;
  vertical-align: top;
  width: 9em;
  font-weight: bold;
}
.section-works .works-article .works-info .w-part1 .w-set .w-detail li .td {
  display: table-cell;
  vertical-align: top;
}
.section-works .works-article .works-info .w-part2 {
  width: 100%;
  background: #e1f1f6;
  margin: 36px 0 0;
}
.section-works .works-article .works-info .w-part2 .w-detail {
  padding: 40px 30px 20px;
  margin: 0 auto;
  box-sizing: border-box;
}
.section-works .works-article .works-info .w-part2 .w-detail li {
  display: table;
  width: 100%;
  padding: 0 0 20px;
}
.section-works .works-article .works-info .w-part2 .w-detail li .th {
  display: table-cell;
  vertical-align: top;
  width: 8em;
  font-size: 16px;
  line-height: 1.6em;
  font-weight: bold;
  padding: 0;
}
.section-works .works-article .works-info .w-part2 .w-detail li .td {
  display: table-cell;
  vertical-align: top;
  width: auto;
  font-size: 16px;
  line-height: 1.6em;
}
.section-works .works-article .works-info .w-more {
}
.section-works .works-article .works-info .w-more .btn {
  width: 100%;
  font-size: 20px;
  font-weight: bold;
  padding: 15px 0;
  margin-top: 40px;
}
.section-works .works-article .works-info .w-more .btn:before {
  width: 20px;
  height: 12px;
  right: 20px;
  margin-top: -6px;
}
.section-works .works-article .works-info .w-more._open .btn:before {
  margin-top: -7px;
}
.section-works .works-article .works-info .w-more .w-imgswrap {
  display: block;
  width: 100%;
  height: auto;
  max-height: 0;
  overflow: hidden;
}
.section-works .works-article .works-info .w-more .w-imgswrap .w-imgs {
  width: 100%;
  height: auto;
}
.section-works .works-article .works-info .w-more .w-imgswrap .w-imgs div {
  position: relative;
  width: 100%;
  height: auto;
  line-height: 0;
  margin: 40px 0 0;
}
.section-works .works-article .works-info .w-more .w-imgswrap .w-imgs div:after {
  content: " ";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  border: 1px solid #707070;
}
.section-works .works-article .works-info .w-more .w-imgswrap .w-imgs img {
  width: 100%;
  height: auto;
}
.section-works .works-article .works-info .w-more .btn:hover {
  cursor: pointer;
}

.section-works .works-list-cont,
.section-works .works-article {
  display: none;
}
.section-works .works-list-cont {
  padding-bottom: 20px;
}

.section-works .work-link {
  cursor: pointer;
}

.loading img {
  display: block;
  margin: auto;
}
.section-contact {
  background: #f5f5f5;
  padding: 77px 0 68px;
  margin-top: 60px;
  position: relative;
  z-index: 800;
}
.section-contact .sec-inner {
  width: 495px;
  margin: 0 auto;
}
.section-contact .sec-introtxt {
  width: 100%;
  margin: 0 auto 28px;
  font-size: 18px;
  line-height: 1em;
  text-align: center;
}
.section-contact .group {
  float: left;
}
.section-contact .group .title {
  font-size: 16px;
  line-height: 1.5em;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}
.section-contact .group .tell {
  font-size: 30px;
  line-height: 1em;
  letter-spacing: 0.05em;
  font-weight: 500;
}
.section-contact .group .time-open {
  font-size: 16px;
  line-height: 1.5em;
  margin-top: 4px;
  letter-spacing: 0.5px;
}
.section-contact .btn {
  float: right;
  width: 244px;
  margin-top: 2px;
  padding: 15px 0 15px 42px;
  line-height: 1.5em;
  text-align: left;
  box-sizing: border-box;
}

@media (max-width: 750px) {
  .section-works {
    padding: 3.45em 0 0;
  }
  .section-works .sec-title {
    padding-bottom: 0.77em;
  }
  .section-works .works-part {
    font-size: 1.6em;
    padding: 2em 0 1.5em;
  }
  #works-full .section-works .works-part {
    font-size: 1.75em;
  }
  .section-works .works-list {
    margin: 0;
    padding: 0;
  }
  .section-works .works-list#all-list {
    padding-top: 2em;
  }
  .section-works .works-list > li {
    float: none;
    width: 100%;
    margin: 0 0 3em;
  }
  .section-works .works-list a {
    display: block;
  }
  .section-works .works-list a .image {
    border-color: #999999;
    height: auto;
  }
  .section-works .works-list a .image .lik {
    display: none;
  }
  .section-works .works-list a .info .w-title {
    font-size: 1.25em;
    line-height: 1.533333333333333em;
    letter-spacing: 0.05em;
    padding: 1em 0 0.5em;
    margin: 0;
  }
  .section-works .works-list a .info .w-type {
    font-size: 1.1em;
    margin: 0;
  }
  .section-works .works-viewfull .w-msg {
    font-size: 1.25em;
    line-height: 1.5em;
    margin: 2.5em 0 1.5em;
  }
  .section-works .works-article {
    margin-top: 5.333333333333333%;
  }
  .section-works .works-article .row-back {
    padding: 2em 2.083333333333333em 0;
  }
  .section-works .works-article .row-back a {
    background-size: 0.4583333333333333em auto;
    padding-left: 1em;
    font-size: 1em;
    white-space: nowrap;
  }
  .section-works .works-article .works-info {
    letter-spacing: 0.05em;
  }
  .section-works .works-article .works-info .w-part1 .w-mainimg:after {
    border-color: #999;
  }
  .section-works .works-article .works-info .w-part1 .btn {
    position: relative;
    right: auto;
    bottom: auto;
    background: #000;
    width: 100%;
    min-width: 0;
    font-size: 1.25em;
    padding: 1em 0;
  }
  .section-works .works-article .works-info .w-part1 .w-set {
    margin: 1.5em 0 0;
  }
  .section-works .works-article .works-info .w-part1 .w-set .w-head {
    display: table;
    width: 100%;
    padding: 0;
  }
  .section-works .works-article .works-info .w-part1 .w-set .w-head .w-title {
    font-size: 1.5em;
    margin: 0;
  }
  .section-works .works-article .works-info .w-part1 .w-set .w-head .w-type {
    font-size: 1.1em;
    line-height: 1.6em;
    padding: 0.6em 0 1.5em;
  }
  .section-works .works-article .works-info .w-part1 .w-set .w-detail {
    display: table;
    width: 100%;
    padding: 0 0 0 1em;
    font-size: 1.1em;
    line-height: 1.6em;
  }
  .section-works .works-article .works-info .w-part1 .w-set .w-detail li .th {
    width: 8em;
  }
  .section-works .works-article .works-info .w-part2 {
    margin: 2em 0 0;
  }
  .section-works .works-article .works-info .w-part2 .w-detail {
    padding: 2em 0 0;
    margin: 0 2.083333333333333em;
  }
  .section-works .works-article .works-info .w-part2 .w-detail li {
    padding: 0 0 2em;
  }
  .section-works .works-article .works-info .w-part2 .w-detail li .th {
    display: table;
    width: 100%;
    font-size: 1.1em;
    padding: 0 0 0.5em;
  }
  .section-works .works-article .works-info .w-part2 .w-detail li .td {
    display: table;
    width: 100%;
    font-size: 1.25em;
    letter-spacing: 0;
  }
  .section-works .works-article .works-info .w-more .btn {
    font-size: 1.5em;
    padding: 0.89em 0;
    margin-top: 2em;
  }
  .section-works .works-article .works-info .w-more .btn:before {
    background-size: 100% 100%;
    width: 1.055555555555556em;
    height: 0.6111111111111111em;
    right: 1em;
    margin-top: -0.3055555555555556em;
  }
  .section-works .works-article .works-info .w-more._open .btn:before {
    margin-top: -0.3055555555555556em;
  }
  .section-works .works-article .works-info .w-more .w-imgswrap .w-imgs div {
    margin: 2em 0 0;
  }
  .section-works .works-article .works-info .w-more .w-imgswrap .w-imgs div:after {
    border-color: #999;
  }
  .section-works .works-list-cont,
  .section-works .works-article {
    display: none;
  }
  .section-works .works-list-cont {
    padding-bottom: 2.166666666666667em;
  }
  .section-works .work-link {
    cursor: pointer;
  }

  .loading img {
    display: block;
    margin: auto;
  }
  .section-contact {
    padding: 3.166666666666667em 0 3.1em;
    margin-top: 2em;
    z-index: 802;
  }
  .section-contact .sec-inner {
    width: auto;
    padding: 0.9em 2.083333333333333em 1em;
  }
  .section-contact .sec-introtxt {
    width: auto;
    margin: 0 auto 1.3em;
    font-size: 1.25em;
    line-height: 1.6em;
  }
  .section-contact .group {
    float: none;
  }
  .section-contact .group .title {
    font-size: 1em;
    letter-spacing: 0.01em;
    margin-bottom: 0.35em;
    text-align: center;
  }
  .section-contact .group .tell {
    font-size: 1.8em;
    font-weight: bold;
    text-align: center;
  }
  .section-contact .group .time-open {
    font-size: 1em;
    line-height: 1.5em;
    margin-top: 0.35em;
    letter-spacing: 0.01em;
    text-align: center;
  }
  .section-contact .btn {
    float: none;
    width: 77.23076923076923%;
    margin-top: 1.46em;
    padding: 0.6em 0 0.6em 1em;
  }
}
