@charset "UTF-8";
/*==========================================
変数 inc.scss
===========================================*/
@media all and (-ms-high-contrast: none) {
  .editor-style {
    word-break: break-all;
  }
}
.editor-style p {
  line-height: 2;
}
.editor-style p:not(:last-child) {
  margin-bottom: 1em;
}
.editor-style p:has(img) {
  line-height: 1;
}
.editor-style a {
  color: #000;
  text-decoration: underline !important;
}
.editor-style a img {
  transition: 0.3s;
}
.editor-style a:hover {
  text-decoration: none !important;
}
.editor-style a:hover img {
  opacity: 0.8;
}
.editor-style img {
  height: auto;
}
.editor-style h2 {
  display: inline-block;
  font-size: clamp(2rem, 2vw, 2.4rem);
  font-weight: bold;
  line-height: 1.4;
  margin: 0.2em 0 1em;
}
.editor-style h3 {
  line-height: 1.4;
  font-size: clamp(1.8rem, 2vw, 2rem);
  font-weight: bold;
  margin: 0.2em 0 1em;
}
.editor-style strong {
  font-weight: bold;
}
.editor-style em {
  font-style: italic;
}
.editor-style ul {
  margin: 1em 0;
}
.editor-style ul li {
  position: relative;
  padding: 0 0 0 1em;
}
.editor-style ul li:not(:last-child) {
  margin-bottom: 0.7em;
}
.editor-style ul li::before {
  top: 0.6em;
  left: 0;
  content: "";
  display: block;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: #000;
  position: absolute;
}
.editor-style ol {
  list-style-type: decimal;
  margin: 1em 0 1em 1em;
}
.editor-style ol li {
  padding: 0;
}
.editor-style ol li:not(:last-child) {
  margin-bottom: 0.7em;
}
.editor-style .blocks-gallery-grid, .editor-style .wp-block-gallery {
  margin: 0;
}
.editor-style li.blocks-gallery-item {
  padding-left: 0;
}
.editor-style li.blocks-gallery-item::before {
  display: none;
}

/*==========================================
 　共通
===========================================*/
.bg-green {
  background: #0d9967;
  padding: 80px 0 100px;
}
@media screen and (min-width: 768px) {
  .bg-green {
    padding: 150px 0 100px;
  }
}

.works-ttl {
  margin: 0 auto 25px;
  color: #fff;
}
@media screen and (min-width: 768px) {
  .works-ttl {
    margin: 0 auto 40px;
  }
}
.works-ttl .ttl-en {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: clamp(4rem, 14vw, 14rem);
  line-height: 1;
}
.works-ttl .ttl-ja {
  font-size: clamp(1.6rem, 2vw, 2rem);
  letter-spacing: 0.2em;
  font-weight: 500;
}

/*==========================================
 　LIST
===========================================*/
.archive-works .btn-backtop {
  padding: 80px 0;
}
@media screen and (min-width: 768px) {
  .archive-works .btn-backtop {
    padding: 100px 0;
  }
}

.works-nav {
  display: flex;
  justify-content: space-between;
  max-width: 660px;
  width: 100%;
  margin: 0 auto;
}
.works-nav li {
  max-width: 200px;
  width: 31%;
}
.works-nav li a {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 2px solid #fff;
  border-radius: 50px;
  color: #fff;
  font-size: clamp(1.1rem, 3.3vw, 1.6rem);
  text-align: center;
  height: 100%;
  padding: 0.6em 0;
  position: relative;
}
.works-nav li a span {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: 2rem;
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  .works-nav li a:hover {
    background: #fff;
    color: #0d9967;
  }
}
.works-nav li .nav-narrow {
  cursor: pointer;
}
.works-nav li .nav-narrow.open {
  background: #fff;
  color: #0d9967;
}
.works-nav li .nav-narrow.open::after {
  content: "";
  position: absolute;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 28px 9px 0 9px;
  border-color: #fff transparent transparent transparent;
  bottom: -28px;
  left: calc(50% - 9px);
}

.works-narrowblock {
  display: none;
  border: 3px solid #fff;
  padding: 30px 20px;
  color: #fff;
  margin-top: 40px;
}
@media screen and (min-width: 1201px) {
  .works-narrowblock {
    padding: 40px;
  }
}
.works-narrowblock .works-narrow .item:not(:last-child) {
  margin-bottom: 1em;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .works-narrow .item {
    display: flex;
    justify-content: space-between;
  }
  .works-narrowblock .works-narrow .item:not(:last-child) {
    margin-bottom: 2em;
  }
}
@media screen and (min-width: 768px) {
  .works-narrowblock .works-narrow .item dt {
    min-width: 5.5em;
    padding: 0.3em 0 0;
  }
}
.works-narrowblock .works-narrow .item dd {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .works-narrow .item dd {
    border-left: 2px solid #fff;
    padding: 0 0 0 0.5em;
  }
}
@media screen and (min-width: 1201px) {
  .works-narrowblock .works-narrow .item dd {
    padding: 0 0 0 1em;
  }
}
.works-narrowblock .works-narrow .item .item-cat {
  display: flex;
  flex-wrap: wrap;
}
.works-narrowblock .works-narrow .item .item-cat li {
  display: inline-block;
  margin: 0.1em 0.4em 0.2em 0;
}
.works-narrowblock .works-narrow .item .item-cat li a {
  display: block;
  border: 2px solid #fff;
  text-align: center;
  color: #fff;
  padding: 0.2em 1em;
  font-weight: 500;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
  border-radius: 50px;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .works-narrow .item .item-cat li a {
    padding: 0.4em 2em;
  }
}
.works-narrowblock .works-narrow .item .item-cat li a.current {
  background: #fff;
  color: #0d9967;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .works-narrow .item .item-cat li a:hover {
    background: #fff;
    color: #0d9967;
  }
}
.works-narrowblock .narrow-btn {
  display: flex;
  justify-content: space-between;
  max-width: 430px;
  width: 100%;
  margin: 40px auto 0;
}
.works-narrowblock .narrow-btn li {
  max-width: 200px;
  width: 48%;
}
.works-narrowblock .narrow-btn li a {
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  border: 2px solid #fff;
  color: #fff;
  height: 100%;
  line-height: 1;
  padding: 0.5em 0;
}
.works-narrowblock .narrow-btn li a.reset {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: 2rem;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .narrow-btn li a.reset:hover {
    background: #fff;
    color: #0d9967;
  }
}
.works-narrowblock .narrow-btn li a.submit {
  border-color: #000;
  background: #000;
}
@media screen and (min-width: 768px) {
  .works-narrowblock .narrow-btn li a.submit:hover {
    background: #00294a;
    border-color: #00294a;
  }
}

.works-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 60px;
}
@media screen and (min-width: 768px) {
  .works-list {
    margin-top: 80px;
  }
}
@media screen and (min-width: 1201px) {
  .works-list::before, .works-list::after {
    content: "";
    display: block;
    width: 24.75%;
  }
  .works-list::before {
    order: 1;
  }
}
@media screen and (max-width: 767px) {
  .works-list {
    margin-bottom: 40px;
  }
}
.works-list .works-item {
  width: 49.7%;
}
.works-list .works-item:nth-of-type(n + 5) {
  margin-top: 0.5%;
}
@media screen and (min-width: 1201px) {
  .works-list .works-item {
    width: 24.75%;
  }
}
@media screen and (max-width: 1200px) {
  .works-list .works-item:nth-of-type(n + 3) {
    margin-top: 0.6%;
  }
}
.works-list .works-item a {
  display: block;
  position: relative;
}
@media screen and (min-width: 768px) {
  .works-list .works-item a:hover .item-img img {
    transform: scale(1.1, 1.1);
  }
  .works-list .works-item a:hover .item-filter {
    opacity: 1;
  }
}
.works-list .works-item .item-img {
  font-size: 0;
  overflow: hidden;
  position: relative;
}
.works-list .works-item .item-img img {
  transition: all 0.8s ease;
  width: 100%;
  height: 68vw;
  object-fit: cover;
}
@media screen and (min-width: 1201px) {
  .works-list .works-item .item-img img {
    height: 431px;
  }
}
.works-list .works-item .new-area span {
  display: none;
  width: 40px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  background: red;
  color: #fff;
  border-radius: 50%;
  font-family: "Jost", sans-serif;
  font-weight: bold;
  font-size: clamp(1.2rem, 1.6vw, 1.6rem);
  position: absolute;
  left: 7px;
  top: 7px;
}
@media screen and (min-width: 768px) {
  .works-list .works-item .new-area span {
    width: 47px;
    height: 47px;
    line-height: 47px;
    left: 10px;
    top: 10px;
  }
}
.works-list .works-item .new-area .new {
  display: block;
}
.works-list .works-item .item-filter {
  opacity: 0;
  transition: 0.3s ease-in-out;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 52, 118, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  padding-bottom: 9vw;
}
@media screen and (min-width: 1201px) {
  .works-list .works-item .item-filter {
    padding-bottom: 100px;
  }
}
.works-list .works-item .item-filter p {
  color: #fff;
  border: 2px solid #fff;
  text-align: center;
  border-radius: 50px;
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: clamp(1.4rem, 1.8vw, 1.8rem);
  letter-spacing: 0.3em;
  width: 90%;
  padding: 0.2em 0;
}
.works-list .works-item .item-data {
  background: rgba(255, 255, 255, 0.8);
  padding: 0.8em 0.5em;
  position: absolute;
  bottom: 0;
  width: 100%;
}
.works-list .works-item .item-ttl {
  font-weight: 500;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}
.works-list .works-item .item-add {
  font-family: "Jost", sans-serif;
  font-weight: bold;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
}
.works-list .works-item .item-cat {
  font-size: clamp(1.1rem, 1.6vw, 1.6rem);
}

/*==========================================
 　DETAIL
===========================================*/
.single-works .single-bg {
  position: relative;
  padding: 80px 0 0;
}
@media screen and (min-width: 768px) {
  .single-works .single-bg {
    padding: 150px 0 0;
  }
}
.single-works .single-bg::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  background: #0d9967;
  width: 100%;
  height: clamp(400px, 100vw, 1013px);
  z-index: -1;
}

.article-date {
  color: #fff;
  display: flex;
  flex-wrap: wrap;
  border-left: 3px solid #fff;
  border-right: 3px solid #fff;
  margin-bottom: 25px;
}
.article-date .article-ttl {
  font-size: clamp(1.8rem, 2.2vw, 2.2rem);
  letter-spacing: 0.1em;
  width: 100%;
  padding: 0 0.5em;
  line-height: 1.2;
}
@media screen and (min-width: 577px) {
  .article-date .article-ttl {
    padding: 0 1em;
  }
}
@media screen and (min-width: 1201px) {
  .article-date .article-ttl {
    width: 50%;
  }
}
@media screen and (max-width: 1200px) {
  .article-date .article-ttl {
    margin-bottom: 0.5em;
  }
}
.article-date .article-cat {
  width: 65%;
  padding: 0 0.5em;
  display: flex;
  justify-content: center;
  flex-direction: column;
}
@media screen and (min-width: 577px) {
  .article-date .article-cat {
    padding: 0 1em;
  }
}
@media screen and (min-width: 1201px) {
  .article-date .article-cat {
    border-left: 3px solid #fff;
    width: 28%;
  }
}
.article-date .article-cat .cat-type {
  font-size: clamp(1.6rem, 1.8vw, 1.8rem);
}
.article-date .article-cat .cat-add {
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
}
.article-date .article-cat .cat-add .en {
  font-family: "Jost", sans-serif;
  font-weight: 700;
}
.article-date .article-products {
  text-align: center;
  width: 35%;
  font-size: clamp(1.6rem, 1.8vw, 1.8rem);
  border-left: 3px solid #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (min-width: 577px) {
  .article-date .article-products {
    letter-spacing: 0.2em;
  }
}
@media screen and (min-width: 1201px) {
  .article-date .article-products {
    width: 22%;
  }
}

.article-slider .article-mainimg .slick-prev,
.article-slider .article-mainimg .slick-next {
  border: none;
  background: transparent;
  top: auto;
  bottom: -65px;
}
@media screen and (min-width: 768px) {
  .article-slider .article-mainimg .slick-prev,
  .article-slider .article-mainimg .slick-next {
    bottom: 57px;
  }
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .slick-prev,
  .article-slider .article-mainimg .slick-next {
    bottom: auto;
    top: 846px;
  }
}
.article-slider .article-mainimg .slick-prev::before,
.article-slider .article-mainimg .slick-next::before {
  width: 0;
  height: 0;
  border-style: solid;
  content: "";
  top: calc(50% - 14px);
}
.article-slider .article-mainimg .slick-prev {
  left: calc(50% - 50px);
}
@media screen and (min-width: 768px) {
  .article-slider .article-mainimg .slick-prev {
    left: auto;
    right: 50px;
  }
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .slick-prev {
    right: 55px;
  }
}
.article-slider .article-mainimg .slick-prev::before {
  border-width: 14px 20px 14px 0;
  border-color: transparent #0d9967 transparent transparent;
  right: calc(50% - 7px);
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .slick-prev::before {
    border-width: 18.5px 30px 18.5px 0;
  }
}
.article-slider .article-mainimg .slick-prev::after {
  content: "";
  width: 1px;
  height: 35px;
  background: #0d9967;
  display: block;
  position: absolute;
  bottom: 0;
  left: 50px;
}
@media screen and (min-width: 768px) {
  .article-slider .article-mainimg .slick-prev::after {
    left: 43px;
  }
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .slick-prev::after {
    height: 64px;
    bottom: -20px;
  }
}
.article-slider .article-mainimg .slick-next {
  right: calc(50% - 50px);
}
@media screen and (min-width: 768px) {
  .article-slider .article-mainimg .slick-next {
    right: 0;
  }
}
.article-slider .article-mainimg .slick-next::before {
  border-width: 14px 0 14px 20px;
  border-color: transparent transparent transparent #0d9967;
  left: calc(50% - 7px);
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .slick-next::before {
    border-width: 18.5px 0 18.5px 30px;
  }
}
.article-slider .article-mainimg .item .item-img {
  font-size: 0;
}
.article-slider .article-mainimg .item .item-img img {
  width: 100%;
  height: 62vw;
  object-fit: scale-down;
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .item .item-img img {
    height: 768px;
  }
}
.article-slider .article-mainimg .item .item-body {
  padding: 25px 0 0;
}
@media screen and (min-width: 1201px) {
  .article-slider .article-mainimg .item .item-body {
    padding: 40px 0 0;
  }
}
@media screen and (min-width: 768px) {
  .article-slider .article-mainimg .item .item-body {
    width: 80%;
    max-width: 725px;
    letter-spacing: 0.1em;
  }
}
.article-slider .article-mainimg .item .item-ttl {
  font-size: clamp(2rem, 2.6vw, 2.6rem);
  letter-spacing: 0.1em;
}
.article-slider .article-mainimg .item .item-txt {
  min-height: 3em;
}
.article-slider .mainimg-thum {
  margin-top: 25px;
}
.article-slider .mainimg-thum .item {
  margin: 0 2.5px;
  position: relative;
}
@media screen and (max-width: 767px) {
  .article-slider .mainimg-thum .item {
    display: none;
  }
}
.article-slider .mainimg-thum .item::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.7);
  transition: 0.3s ease-in-out;
  display: block;
}
.article-slider .mainimg-thum .item.slick-current::before {
  opacity: 0;
}
.article-slider .mainimg-thum .item img {
  width: 100%;
  height: 10vw;
  object-fit: cover;
}
@media screen and (min-width: 1201px) {
  .article-slider .mainimg-thum .item img {
    height: 125px;
  }
}

.article-point {
  margin-top: 40px;
  border-top: 4px solid #0d9967;
  border-bottom: 4px solid #0d9967;
  color: #0d9967;
  padding: 30px 0;
}
@media screen and (min-width: 768px) {
  .article-point {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 40px 0;
  }
}
@media screen and (min-width: 768px) {
  .article-point .point-head {
    text-align: center;
    min-width: 15em;
  }
}
.article-point .point-ttl {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: clamp(3rem, 4.6vw, 4.6rem);
  letter-spacing: 0.1em;
}
.article-point .point-body {
  width: 100%;
}
@media screen and (min-width: 1201px) {
  .article-point .point-body {
    padding: 0 0 0 3em;
  }
}

.recommend-block {
  background: #0d9967;
  margin-top: 100px;
  padding: 60px 0;
}
@media screen and (min-width: 768px) {
  .recommend-block {
    padding: 80px;
  }
}
@media screen and (min-width: 1201px) {
  .recommend-block {
    padding: 100px;
  }
}
.recommend-block .recommend-ttl {
  color: #fff;
}
@media screen and (min-width: 577px) {
  .recommend-block .recommend-ttl {
    display: flex;
    align-items: flex-end;
  }
}
.recommend-block .recommend-ttl .ttl-en {
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: clamp(4rem, 6vw, 6rem);
  letter-spacing: 0.05em;
  line-height: 1;
}
.recommend-block .recommend-ttl .ttl-ja {
  font-size: clamp(1.6rem, 1.8vw, 1.8rem);
  font-weight: 500;
  letter-spacing: 0.2em;
}
@media screen and (min-width: 577px) {
  .recommend-block .recommend-ttl .ttl-ja {
    padding-left: 1em;
  }
}
.recommend-block .btn01 {
  background-color: #fff;
  margin-top: 60px;
}
@media screen and (min-width: 769px) {
  .recommend-block .btn01 {
    margin-top: 70px;
  }
}
.recommend-block .btn01:hover {
  color: #0d9967;
  opacity: 0.7;
}

.recommend-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin-top: 25px;
}
@media screen and (min-width: 768px) {
  .recommend-list {
    margin-top: 40px;
  }
}
@media screen and (min-width: 1201px) {
  .recommend-list::before, .recommend-list::after {
    content: "";
    display: block;
    width: 24.75%;
  }
  .recommend-list::before {
    order: 1;
  }
}
@media screen and (max-width: 767px) {
  .recommend-list {
    margin-bottom: 40px;
  }
}
.recommend-list .works-item {
  width: 49.7%;
}
.recommend-list .works-item:nth-of-type(n + 5) {
  margin-top: 0.5%;
}
@media screen and (min-width: 1201px) {
  .recommend-list .works-item {
    width: 24.75%;
  }
}
@media screen and (max-width: 1200px) {
  .recommend-list .works-item:nth-of-type(n + 3) {
    margin-top: 0.6%;
  }
}
.recommend-list .works-item a {
  display: block;
  position: relative;
}
@media screen and (min-width: 768px) {
  .recommend-list .works-item a:hover .item-img img {
    transform: scale(1.1, 1.1);
  }
  .recommend-list .works-item a:hover .item-filter {
    opacity: 1;
  }
}
.recommend-list .works-item .item-img {
  font-size: 0;
  overflow: hidden;
  position: relative;
}
.recommend-list .works-item .item-img img {
  transition: all 0.8s ease;
  width: 100%;
  height: 68vw;
  object-fit: cover;
}
@media screen and (min-width: 1201px) {
  .recommend-list .works-item .item-img img {
    height: 431px;
  }
}
.recommend-list .works-item .item-filter {
  opacity: 0;
  transition: 0.3s ease-in-out;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 52, 118, 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  padding-bottom: 9vw;
}
@media screen and (min-width: 1201px) {
  .recommend-list .works-item .item-filter {
    padding-bottom: 100px;
  }
}
.recommend-list .works-item .item-filter p {
  color: #fff;
  border: 2px solid #fff;
  text-align: center;
  border-radius: 50px;
  font-family: "Jost", sans-serif;
  font-weight: 700;
  font-size: clamp(1.4rem, 1.8vw, 1.8rem);
  letter-spacing: 0.3em;
  width: 90%;
  padding: 0.2em 0;
}
.recommend-list .works-item .item-data {
  background: rgba(255, 255, 255, 0.8);
  padding: 0.8em 0.5em;
  position: absolute;
  bottom: 0;
  width: 100%;
}
.recommend-list .works-item .item-ttl {
  font-weight: 500;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
}
.recommend-list .works-item .item-add {
  font-family: "Jost", sans-serif;
  font-size: clamp(1.4rem, 1.6vw, 1.6rem);
}
.recommend-list .works-item .item-cat {
  font-size: clamp(1.1rem, 1.6vw, 1.6rem);
}/*# sourceMappingURL=works.css.map */