@charset "UTF-8";

.wp-block-image img {
  height: auto;
  max-width: 100%;
}

/* =======================================
 news(front, archive, single共通)
======================================= */
.news {
  color: #333;
}
.news_title {
  margin-inline: auto;
  width: 255px;
}
.news_list {
  margin-inline: auto;
  margin-top: 40px;
  width: 1000px;
}
.news_article {
  border-bottom: 1px solid #f2f2f2;
  display: flex;
  gap: 25px;
  padding: 25px 0;
}
.news_article_thumb {
  height: 105px;
  margin: 0;
  width: 140px;
}
.news_article_thumb a {
  display: block;
  height: 105px;
  overflow: hidden;
}
.news_article_thumb img {
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease-in-out;
  width: 100%;
}
@media (any-hover: hover) {
  .news_article_thumb a:hover img {
    transform: scale(1.1);
  }
}
.news_article_desc {
  padding-top: 20px;
  width: 810px;
}
.news_article_date {
  display: block;
  font-size: 16px;
  letter-spacing: 0.18em;
  line-height: 1;
}
.news_article_title {
  font-size: 17px;
  letter-spacing: 0.18em;
  line-height: 1.6;
  margin-top: 10px;
}
.news_article_title a {
  text-decoration: underline;
}
@media (any-hover: hover) {
  .news_article_title a:hover {
    text-decoration: none;
  }
}

.news_button {
  margin-inline: auto;
  width: 460px;
}
.news_button a {
  align-items: center;
  background: linear-gradient(135deg, #605041 22%,#050402 100%);
  display: flex;
  height: 70px;
  justify-content: center;
  position: relative;
}
.news_button_label {
  color: #fff;
  font-size: 22px;
  letter-spacing: 0.18em;
}
.news_button_arrow {
  fill: none;
  position: absolute;
  right: 25px;
  stroke: #fff;
  stroke-miterlimit: 10;
  top: 32px;
  width: 47px;
}

@media screen and (max-width: 1100px) {
  .news_title {
    width: 23.182vw;
  }
  .news_list {
    margin-top: 3.636vw;
    width: 90.909vw;
  }
  .news_article {
    gap: 2.273vw;
    padding: 2.273vw 0;
  }
  .news_article_thumb {
    height: 9.545vw;
    width: 12.727vw;
  }
  .news_article_thumb a {
    height: 9.545vw;
  }
  .news_article_desc {
    padding-top: 1.818vw;
    width: 73.636vw;
  }
  .news_article_date {
    font-size: 1.455vw;
  }
  .news_article_title {
    font-size: 1.545vw;
    margin-top: 0.909vw;
  }

  .news_button {
    width: 41.818vw;
  }
  .news_button a {
    height: 6.364vw;
  }
  .news_button_label {
    font-size: 2vw;
  }
  .news_button_arrow {
    right: 2.273vw;
    top: 2.909vw;
    width: 4.273vw;
  }
}

/* =======================================
 front-page
======================================= */
#campaign {
  background: #fff;
  height: auto;
}
.campaign_top {
  padding: 50px 0 90px;
}

.campaign_slider.slick-dotted.slick-slider {
  margin-bottom: 0;
}
.campaign_slider .wp-block-image {
  margin: 0;
  padding: 0 24px;
}
.campaign_slider .slick-dots {
  display: block;
  list-style: none;
  margin: 30px 0 0;
  padding: 0;
  position: static;
  text-align: center;
  width: 100%;
}
.campaign_slider .slick-dots li {
  display: inline-block;
  cursor: pointer;
  height: 20px;
  margin: 0 10px;
  padding: 0;
  position: relative;
  width: 20px;
}
.campaign_slider .slick-dots li button {
  background: transparent;
  border: 0;
  color: transparent;
  cursor: pointer;
  display: block;
  font-size: 0;
  height: 20px;
  line-height: 0;
  outline: none;
  padding: 0;
  width: 20px;
}
.campaign_slider .slick-dots li button:hover,
.campaign_slider .slick-dots li button:focus {
  outline: none;
}
.campaign_slider .slick-dots li button:hover::before,
.campaign_slider .slick-dots li button:focus::before {
  opacity: 1;
}
.campaign_slider .slick-dots li button:before {
  content: "";
  background: #ccc;
  border-radius: 50%;
  height: 20px;
  inset: 0;
  opacity: 1;
  position: absolute;
  text-align: center;
  width: 20px;
}
.campaign_slider .slick-dots li.slick-active button::before {
  background: #a8906c;
}

@media screen and (max-width: 1100px) {
  .campaign_top {
    padding: 4.545vw 0 8.182vw;
  }

  .campaign_slider .wp-block-image {
    padding: 0 2.182vw;
  }
  .campaign_slider .slick-dots {
    margin: 2.727vw 0 0;
  }
  .campaign_slider .slick-dots li {
    height: 1.818vw;
    margin: 0 0.909vw;
    width: 1.818vw;
  }
  .campaign_slider .slick-dots li button {
    height: 1.818vw;
    width: 1.818vw;
  }
  .campaign_slider .slick-dots li button:before {
    height: 1.818vw;
    width: 1.818vw;
  }
}

.news--front-page {
  padding: 50px 0 90px;
}
.news_button--front-page {
  margin-top: 55px;
}

@media screen and (max-width: 1100px) {
  .news--front-page {
    padding: 4.545vw 0 8.182vw;
  }
  .news_button--front-page {
    margin-top: 5vw;
  }
}

/* =======================================
 archive
======================================= */
.blog .footer,
.archive .footer,
.single .footer,
.error404 .footer,
.search .footer {
  margin-bottom: 0;
  padding: 0;
}

.news--archive {
  padding: 210px 0 130px;
}
.news_button--archive {
  margin-top: 70px;
}

.news_archive_title {
  font-weight: 400;
  margin-top: 1em;
}

.pagination {
  margin-top: 50px;
}
.pagination .screen-reader-text {
  display: none;
}
.pagination .navigation_links {
  display: flex;
  gap: 10px;
  justify-content: center;
}
.pagination .page-numbers {
  align-items: center;
  border: 1px solid #e6e6e6;
  color: #666;
  font-size: 14px;
  display: flex;
  height: 30px;
  justify-content: center;
  text-decoration: none;
  width: 30px;
}
.pagination .page-numbers.prev,
.pagination .page-numbers.next {
  background: #a8906c;
  border-color: #a8906c;
  color: #fff;
  font-family: "Manrope", sans-serif;
  font-size: 130%;
}
.pagination .page-numbers.current {
  background: #efebe5;
  font-weight: 700;
}
.pagination .page-numbers.dots {
  border: none;
  width: auto;
}
@media (any-hover: hover) {
  .pagination a.page-numbers:hover {
    background: #efebe5;
  }
  .pagination a.page-numbers.prev:hover,
  .pagination a.page-numbers.next:hover {
    background: #a8906c;
  }
}

@media screen and (max-width: 1100px) {
  .news--archive {
    padding: 19.091vw 0 11.818vw;
  }
  .news_button--archive {
    margin-top: 6.364vw;
  }

  .pagination {
    margin-top: 4.545vw;
  }
  .navigation_links {
    gap: 0.909vw;
  }
  .navigation_links .page-numbers {
    font-size: 1.273vw;
    height: 2.727vw;
    width: 2.727vw;
  }
}

/* =======================================
 single
======================================= */
.news--single {
  padding: 210px 0 130px;
}

.news_post {
  margin-inline: auto;
  margin-top: 110px;
  width: 690px;
}
.news_post_date {
  display: block;
  font-size: 14px;
  letter-spacing: 0.18em;
  line-height: 1;
}
.news_post_title {
  border-bottom: 1px solid #ccc;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.18em;
  line-height: 1.6;
  margin-top: 10px;
  padding-bottom: 25px;
}
.news_post_eyecatch {
  margin-inline: 0;
  margin-block-end: 30px;
  margin-block-start: 30px;
  width: 100%;
}

.news_post_content {
  font-size: 17px;
  margin-block-start: 30px;
}
.news_post_content .wp-block-heading {
  margin-block-start: 0.83em;
  margin-block-end: 0.83em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
}
.news_post_content p {
  line-height: 2.2;
  margin-block-end: 30px;
  margin-block-start: 30px;
}
.news_post_content p a {
  color: #2271b1;
  text-decoration: underline;
}
@media (any-hover: hover) {
  .news_post_content p a:hover {
    text-decoration: none;
  }
}
.news_post_content .wp-block-image {
  margin-block: 50px;
  margin-inline: 50px;
}
.news_post_content .wp-block-image figure {
  margin-block: 0;
  margin-inline: 0;
}

.post-navigation {
  margin-inline: auto;
  margin-top: 60px;
  width: 460px;
}
.post-navigation .screen-reader-text {
  display: none;
}
.post-navigation .nav-links {
  display: flex;
  justify-content: space-between;
}
.post-navigation .nav-previous,
.post-navigation .nav-next {
  width: 90px;
}
.post-navigation .nav-previous a,
.post-navigation .nav-next a {
  align-items: center;
  border: 1px solid #e6e6e6;
  border-radius: 15px;
  color: #666;
  font-size: 14px;
  letter-spacing: 0.18em;
  display: flex;
  gap: 6px;
  height: 30px;
  justify-content: center;
  text-decoration: none;
  width: 90px;
}
@media (any-hover: hover) {
  .post-navigation .nav-previous a:hover,
  .post-navigation .nav-next a:hover {
    background: #efebe5;
  }
}
.post-navigation .nav-previous a::before,
.post-navigation .nav-next a::after {
  color: #b3b3b3;
  font-family: "Manrope", sans-serif;
  font-size: 160%;
}
.post-navigation .nav-previous a::before {
  content: "<";
}
.post-navigation .nav-next a::after {
  content: ">";
}
.nav-blog a {
  align-items: center;
  background: #a8906c;
  border-color: #a8906c;
  border-radius: 15px;
  color: #fff;
  display: flex;
  font-size: 14px;
  letter-spacing: 0.18em;
  height: 30px;
  justify-content: center;
  width: 200px;
}
@media (any-hover: hover) {
  .nav-blog a:hover {
    background: #a8906c;
  }
}

.news_button--single {
  margin-top: 70px;
}

@media screen and (max-width: 1100px) {
  .news--single {
    padding: 19.091vw 0 11.818vw;
  }

  .news_post {
    margin-top: 10vw;
    width: 62.727vw;
  }
  .news_post_date {
    font-size: 1.273vw;
  }
  .news_post_title {
    font-size: 1.818vw;
    margin-top: 0.909vw;
    padding-bottom: 2.273vw;
  }
  .news_post_eyecatch {
    margin-block-end: 2.727vw;
    margin-block-start: 2.727vw;
  }

  .news_post_content {
    font-size: 1.545vw;
    margin-block-start: 2.727vw;
  }
  .news_post_content p {
    line-height: 2.2;
    margin-block-end: 2.727vw;
    margin-block-start: 2.727vw;
  }
  .news_post_content .wp-block-image {
    margin-block: 4.545vw;
    margin-inline: 4.545vw;
  }

  .post-navigation {
    margin-top: 5.455vw;
    width: 41.818vw;
  }
  .post-navigation .nav-previous,
  .post-navigation .nav-next {
    width: 8.182vw;
  }
  .post-navigation .nav-previous a,
  .post-navigation .nav-next a {
    border-radius: 1.364vw;
    font-size: 1.273vw;
    gap: 0.545vw;
    height: 2.727vw;
    width: 8.182vw;
  }
  .nav-blog a {
    border-radius: 1.364vw;
    font-size: 1.273vw;
    height: 2.727vw;
    width: 18.182vw;
  }

  .news_button--single {
    margin-top: 6.364vw;
  }
}

.news_post_content iframe {
  aspect-ratio: 16 / 9;
  display: block;
  height: auto !important;
  margin-block-end: 1.6em;
  margin-block-start: 1.6em;
  max-width: 100%;
}

/* =======================================
 404
======================================= */
.not-found {
  padding: 210px 0 130px;
}

.not-found_title {
  color: #a8906c;
  font-size: 50px;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
  text-align: center;
}
.not-found_lead {
  color: #a8906c;
  font-size: 20px;
  letter-spacing: 0.2em;
  line-height: 1;
  margin-top: 24px;
  text-align: center;
}
.not-found_text  {
  color: #333;
  font-size: 17px;
  line-height: 2.2;
  margin-inline: auto;
  margin-block-start: 60px;
  width: 690px;
}

.news_button--error404 {
  margin-top: 70px;
}

@media screen and (max-width: 1100px) {
  .not-found {
    padding: 19.091vw 0 11.818vw;
  }

  .not-found_title {
    font-size: 4.545vw;
  }
  .not-found_lead {
    font-size: 1.818vw;
    margin-top: 2.182vw;
  }
  .not-found_text  {
    font-size: 1.545vw;
    margin-block-start: 5.455vw;
    width: 62.727vw;
  }

  .news_button--error404 {
    margin-top: 6.364vw;
  }
}

/* =======================================
 page
======================================= */
.page-wrap {
  padding: 150px 0 110px;
}
.page-title {
  color: #1a1a1a;
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
.page-content {
  margin-top: 30px;
}
:where(.page-content > p) {
  letter-spacing: 0.06em;
  line-height: 1.66;
}

@media screen and (max-width: 1100px) {
  .page-wrap {
    padding: 13.636vw 0 10vw;
  }
  .page-title {
    font-size: 2.909vw;
  }
  .page-content {
    margin-top: 2.727vw;
  }
  :where(.page-content > p) {
    letter-spacing: 0.06em;
    line-height: 1.66;
  }
}
