/* reset */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
input, textarea, button, header {
  background: transparent;
  border: 0;
  border-radius: 0;
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  vertical-align: baseline;
  -webkit-text-size-adjust: 100%;
  max-block-size: 999999px;
  outline: none;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: none;
}

button:focus {
  outline: 0;
}

ol, ul {
  list-style: none;
}

a {
  background-color: transparent; /* 1 */
  -webkit-text-decoration-skip: objects; /* 2 */
  text-decoration: none;
  outline: none;
}

img {
  inline-size: 100%;
  block-size: auto;
  vertical-align: bottom;
}

body {
  color: rgb(51, 51, 51);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1.8;
  position: relative;
}

a {
  font-weight: 500;
  color: rgb(51, 51, 51);
}

/* header */
.c-header {
  display: block flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  inline-size: 300px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 50;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 576px) {
  .c-header {
    inline-size: 380px;
  }
  .c-header.scrolled {
    inline-size: 300px;
  }
  .c-header.scrolled .c-header__logo {
    inline-size: 250px;
    top: 1rem;
    left: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .c-header {
    inline-size: 450px;
  }
  .c-header.scrolled {
    inline-size: 350px;
  }
  .c-header.scrolled .c-header__logo {
    inline-size: 270px;
    top: 1.25rem;
    left: 2rem;
  }
}
@media screen and (min-width: 992px) {
  .c-header {
    inline-size: 550px;
  }
}
@media screen and (min-width: 1200px) {
  .c-header {
    inline-size: 800px;
  }
}

.c-header__body {
  inline-size: 100%;
}

.c-header__logo {
  inline-size: 250px;
  position: absolute;
  top: 1rem;
  left: 1rem;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  z-index: 20;
}
@media screen and (min-width: 576px) {
  .c-header__logo {
    inline-size: 340px;
  }
}
@media screen and (min-width: 768px) {
  .c-header__logo {
    inline-size: 400px;
  }
}
@media screen and (min-width: 992px) {
  .c-header__logo {
    inline-size: 500px;
    top: 1rem;
    left: 1.5rem;
  }
}
@media screen and (min-width: 1200px) {
  .c-header__logo {
    inline-size: 700px;
    top: 1.5rem;
    left: 2rem;
  }
}

.c-sec__page .c-header {
  inline-size: 300px;
}
@media screen and (min-width: 576px) {
  .c-sec__page .c-header {
    inline-size: 300px;
  }
  .c-sec__page .c-header .c-header__logo {
    inline-size: 250px;
    top: 1rem;
    left: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .c-sec__page .c-header {
    inline-size: 350px;
  }
  .c-sec__page .c-header .c-header__logo {
    inline-size: 270px;
    top: 1.25rem;
    left: 2rem;
  }
}

.c-header__logo-link {
  display: block flex;
}

.c-header__bg {
  inline-size: 100%;
  -webkit-filter: drop-shadow(0px 3px 8px rgba(0, 0, 0, 0.2));
  filter: drop-shadow(0px 3px 8px rgba(0, 0, 0, 0.2));
}

/* footer */
.c-footer {
  display: block flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 3rem;
  padding-inline: 4vw;
  background-color: rgb(13, 120, 45);
  position: relative;
}
@media screen and (min-width: 768px) {
  .c-footer {
    padding-inline: 2rem;
  }
}

.c-footer__title {
  -webkit-padding-after: 1rem;
          padding-block-end: 1rem;
  font-size: clamp(1.125rem, 0.681rem + 0.93vw, 1.375rem);
  font-weight: 500;
  color: rgb(255, 255, 255);
  text-align: center;
}

.c-footer__tel {
  -webkit-padding-after: 0.5rem;
          padding-block-end: 0.5rem;
  font-size: clamp(0.938rem, 0.604rem + 0.69vw, 1.125rem);
  font-weight: 500;
  color: rgb(255, 255, 255);
}
.c-footer__tel a {
  font-size: clamp(0.938rem, 0.604rem + 0.69vw, 1.125rem);
  font-weight: 500;
  color: rgb(255, 255, 255);
}

.c-footer__mail {
  -webkit-padding-after: 1rem;
          padding-block-end: 1rem;
  font-size: clamp(0.938rem, 0.604rem + 0.69vw, 1.125rem);
  font-weight: 500;
  color: rgb(255, 255, 255);
}
.c-footer__mail a {
  font-size: clamp(0.938rem, 0.604rem + 0.69vw, 1.125rem);
  font-weight: 500;
  color: rgb(255, 255, 255);
}

.c-footer__contact {
  inline-size: 100%;
  max-inline-size: 300px;
  -webkit-padding-after: 1rem;
          padding-block-end: 1rem;
}

.c-footer__contact-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  inline-size: 100%;
  block-size: 45px;
  border-radius: 25px;
  background-color: rgb(255, 255, 255);
  border: 2px solid rgb(255, 255, 255);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.c-footer__contact-button:hover {
  color: rgb(255, 255, 255);
  background-color: rgb(13, 120, 45);
}
@media screen and (min-width: 576px) {
  .c-footer__contact-button {
    block-size: 50px;
  }
}

.c-footer__copy {
  inline-size: 100%;
  font-size: clamp(0.75rem, 0.528rem + 0.46vw, 0.875rem);
  color: rgb(255, 255, 255);
  text-align: center;
  position: relative;
  z-index: 20;
}

.c-footer__deco01,
.c-footer__deco02 {
  inline-size: 120px;
  position: absolute;
  top: 0;
  translate: 0 -90%;
}
@media screen and (min-width: 576px) {
  .c-footer__deco01,
  .c-footer__deco02 {
    inline-size: 140px;
  }
}
@media screen and (min-width: 768px) {
  .c-footer__deco01,
  .c-footer__deco02 {
    inline-size: 200px;
  }
}

.c-footer__deco01 {
  left: 1rem;
}
@media screen and (min-width: 576px) {
  .c-footer__deco01 {
    left: 2rem;
  }
}

.c-footer__deco02 {
  right: 1rem;
}
@media screen and (min-width: 576px) {
  .c-footer__deco02 {
    right: 2rem;
  }
}

.c-contents {
  padding-inline: 5vw;
}
@media screen and (min-width: 768px) {
  .c-contents {
    padding-inline: 2rem;
  }
}

.c-innner {
  max-inline-size: 1000px;
  margin-inline: auto;
}

.c-headline {
  display: block flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
  position: relative;
}
.c-headline span {
  font-size: clamp(1.5rem, 0.389rem + 2.31vw, 2.125rem);
  letter-spacing: 0.1em;
  text-shadow: 2px 2px 14px rgb(255, 255, 255), -2px 2px 14px rgb(255, 255, 255), 2px -2px 14px rgb(255, 255, 255), -2px -2px 14px rgb(255, 255, 255);
  position: relative;
  z-index: 20;
}
.c-headline::before {
  content: "";
  inline-size: 80px;
  aspect-ratio: 1;
  background-image: url(../img/header-fig-01.png);
  background-repeat: no-repeat;
  background-size: 100%;
  position: absolute;
  top: 50%;
  left: 50%;
  translate: -50% -50%;
}
@media screen and (min-width: 768px) {
  .c-headline::before {
    inline-size: 100px;
  }
}

.c-button {
  display: block flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  inline-size: 260px;
  block-size: 45px;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(0.938rem, 0.678rem + 0.72vw, 1.125rem);
  color: rgb(255, 255, 255);
  line-height: 1.4;
  text-align: center;
  border: 2px solid rgb(0, 164, 100);
  background-color: rgb(0, 164, 100);
  border-radius: 35px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.c-button:hover {
  color: rgb(0, 164, 100);
  letter-spacing: 0.1em;
  background-color: rgb(255, 255, 255);
}
@media screen and (min-width: 476px) {
  .c-button {
    inline-size: 280px;
    block-size: 55px;
  }
}
@media screen and (min-width: 768px) {
  .c-button {
    inline-size: 320px;
    block-size: 65px;
  }
}

.c-sec__header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 6rem 3rem;
  background-image: url(../img/bg.jpg);
}
@media screen and (min-width: 768px) {
  .c-sec__header {
    padding-block: 7rem 5rem;
  }
}

.c-sec__header-title {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.611rem + 1.85vw, 2rem);
  font-weight: bold;
}

.c-sec__contents {
  container-type: inline-size;
  padding-inline: 5vw;
  padding-block: 4rem 6rem;
}
@media screen and (min-width: 768px) {
  .c-sec__contents {
    padding-inline: 2rem;
    padding-block: 6rem 9rem;
  }
}

.c-sec__contents-inner {
  max-inline-size: 900px;
  margin-inline: auto;
}

.p-hero {
  overflow-x: hidden;
}

.p-hero__slider {
  position: relative;
}

.p-hero__slider-main {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  block-size: 100vh;
}
.p-hero__slider-main .swiper {
  block-size: 100%;
  margin-inline: -3%;
}
@media screen and (min-width: 768px) {
  .p-hero__slider-main {
    block-size: 700px;
  }
}
@media screen and (min-width: 992px) {
  .p-hero__slider-main {
    block-size: 800px;
  }
}

.p-hero__slider-deco01,
.p-hero__slider-deco02 {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  inline-size: 8%;
  position: relative;
  z-index: 5;
}
.p-hero__slider-deco01 img,
.p-hero__slider-deco02 img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center right;
     object-position: center right;
  inline-size: 100%;
  block-size: 100%;
}
@media screen and (min-width: 576px) {
  .p-hero__slider-deco01,
  .p-hero__slider-deco02 {
    inline-size: 10%;
  }
}
@media screen and (min-width: 768px) {
  .p-hero__slider-deco01,
  .p-hero__slider-deco02 {
    inline-size: 13%;
  }
}

.p-hero__slider-deco02 img {
  -o-object-position: center left;
     object-position: center left;
}

.p-hero__slider-item {
  block-size: 100%;
  position: relative;
}

.p-hero__slider-fig {
  block-size: 100%;
}
.p-hero__slider-fig img {
  -o-object-fit: cover;
     object-fit: cover;
  inline-size: 100%;
  block-size: 100%;
}

.p-hero__slider-info {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  color: rgb(255, 255, 255);
  position: absolute;
  top: 5rem;
  right: 2rem;
}
@media screen and (min-width: 476px) {
  .p-hero__slider-info {
    right: 2rem;
  }
}
@media screen and (min-width: 576px) {
  .p-hero__slider-info {
    top: 4rem;
    right: 4rem;
  }
}
@media screen and (min-width: 768px) {
  .p-hero__slider-info {
    right: 5rem;
  }
}

.p-hero__slider-name {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(2rem, 0.222rem + 3.7vw, 3rem);
  font-weight: 600;
  letter-spacing: 0.2em;
  text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2), -2px 2px 10px rgba(0, 0, 0, 0.2), 2px -2px 10px rgba(0, 0, 0, 0.2), -2px -2px 10px rgba(0, 0, 0, 0.2);
}

.p-hero__slider-location {
  -webkit-padding-start: 6em;
          padding-inline-start: 6em;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1rem, 0.556rem + 0.93vw, 1.25rem);
  font-weight: 600;
  text-shadow: 2px 2px 10px rgba(0, 0, 0, 0.2), -2px 2px 10px rgba(0, 0, 0, 0.2), 2px -2px 10px rgba(0, 0, 0, 0.2), -2px -2px 10px rgba(0, 0, 0, 0.2);
  line-height: 1.4;
  letter-spacing: 0.2em;
  position: relative;
}
.p-hero__slider-location::before {
  content: "";
  inline-size: 5em;
  block-size: 2px;
  background-color: rgb(255, 255, 255);
  position: absolute;
  top: 0.5em;
  right: 0.6em;
}

.p-hero__deco01 {
  max-width: 900px;
  position: absolute;
  right: -0.25rem;
  bottom: -0.25rem;
  z-index: 10;
}

.p-hero__deco02 {
  display: block flex;
  inline-size: 100%;
  position: absolute;
  left: -0.25rem;
  bottom: 0;
  translate: 0 50%;
  z-index: 10;
}

.p-hero__schedule {
  inline-size: 70%;
  margin-inline: auto 10%;
  -webkit-margin-before: -6rem;
          margin-block-start: -6rem;
  position: relative;
  z-index: 20;
}
@media screen and (min-width: 476px) {
  .p-hero__schedule {
    inline-size: 55%;
    margin-inline: auto 1.5rem;
    -webkit-margin-before: -6rem;
            margin-block-start: -6rem;
  }
}
@media screen and (min-width: 576px) {
  .p-hero__schedule {
    inline-size: 55%;
    margin-inline: auto 2rem;
    -webkit-margin-before: -7rem;
            margin-block-start: -7rem;
  }
}
@media screen and (min-width: 768px) {
  .p-hero__schedule {
    inline-size: 50%;
    margin-inline: auto 3rem;
    -webkit-margin-before: -8rem;
            margin-block-start: -8rem;
  }
}
@media screen and (min-width: 992px) {
  .p-hero__schedule {
    inline-size: 520px;
    -webkit-margin-before: -8rem;
            margin-block-start: -8rem;
  }
}

.p-outline {
  overflow-x: clip;
  -webkit-margin-before: -1rem;
          margin-block-start: -1rem;
  -webkit-padding-before: 5rem;
          padding-block-start: 5rem;
  background-image: url(../img/bg.jpg);
}
@media screen and (min-width: 768px) {
  .p-outline {
    -webkit-margin-before: -3rem;
            margin-block-start: -3rem;
    -webkit-padding-before: 3rem 6rem;
            padding-block-start: 3rem 6rem;
  }
}
@media screen and (min-width: 992px) {
  .p-outline {
    -webkit-padding-before: 6rem;
            padding-block-start: 6rem;
  }
}
@media screen and (min-width: 1200px) {
  .p-outline {
    -webkit-margin-before: -3rem;
            margin-block-start: -3rem;
    -webkit-padding-before: 8rem;
            padding-block-start: 8rem;
  }
}

.p-outline__title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.808rem + 1.92vw, 2rem);
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}
@media screen and (min-width: 476px) {
  .p-outline__title br {
    display: none;
  }
}

.p-outline__copy {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1rem, 0.481rem + 1.44vw, 1.375rem);
  font-weight: bold;
  line-height: 1.4;
  text-align: center;
}

.p-outline__detail {
  max-inline-size: 730px;
  margin-inline: auto;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.125rem, 0.903rem + 0.46vw, 1.25rem);
  font-weight: 600;
  line-height: 1.75;
}
@media screen and (min-width: 768px) {
  .p-outline__detail {
    line-height: 2;
  }
}
@media screen and (min-width: 992px) {
  .p-outline__detail {
    line-height: 2.4;
  }
}

.p-outline__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}
.p-outline__button .c-button {
  inline-size: 100%;
  max-inline-size: 350px;
  color: rgb(0, 164, 100);
  background-color: rgb(255, 255, 255);
}
.p-outline__button .c-button:hover {
  color: rgb(255, 255, 255);
  background-color: rgb(0, 164, 100);
}
@media screen and (min-width: 768px) {
  .p-outline__button {
    -webkit-margin-after: 5rem;
            margin-block-end: 5rem;
  }
}

.p-cityscape {
  block-size: 80px;
  margin-inline: calc(50% - 50cqi);
}
.p-cityscape img {
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left bottom;
     object-position: left bottom;
  inline-size: 100%;
  block-size: 100%;
}
@media screen and (min-width: 768px) {
  .p-cityscape {
    block-size: 100px;
  }
}
@media screen and (min-width: 1500px) {
  .p-cityscape {
    block-size: auto;
  }
}

.p-news {
  padding-block: 5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-news {
    padding-block: 6rem;
  }
}
@media screen and (min-width: 992px) {
  .p-news {
    padding-block: 7rem 10rem;
  }
}

.p-news__title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.808rem + 1.92vw, 2rem);
  font-weight: bold;
  text-align: center;
}

.p-news__intro {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
}

.p-news-category {
  max-inline-size: 800px;
  margin-inline: auto;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  padding-inline: 1rem;
  padding-block: 1rem;
  background-color: rgb(214, 233, 196);
  border-radius: 20px;
}
@media screen and (min-width: 576px) {
  .p-news-category {
    padding-inline: 1.25rem;
    padding-block: 1.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-news-category {
    padding-inline: 1.5rem;
    padding-block: 1.5rem;
  }
}

.p-news-category__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
}
@media screen and (min-width: 476px) {
  .p-news-category__list {
    grid-template-columns: repeat(4, 1fr);
  }
}
@media screen and (min-width: 576px) {
  .p-news-category__list {
    -webkit-column-gap: 1rem;
       -moz-column-gap: 1rem;
            column-gap: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .p-news-category__list {
    -webkit-column-gap: 2rem;
       -moz-column-gap: 2rem;
            column-gap: 2rem;
  }
}

.p-news-category__label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  block-size: 32px;
  font-size: 0.875rem;
  color: rgb(255, 255, 255);
  border-radius: 16px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.p-news-category__label:hover {
  opacity: 0.7;
}

.p-news-list {
  display: block grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem 1.5rem;
  inline-size: 100%;
  max-inline-size: 900px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-news-list {
    grid-template-columns: repeat(3, 1fr);
    gap: 3rem 1.5rem;
  }
}
@media screen and (min-width: 992px) {
  .p-news-list {
    grid-template-columns: repeat(4, 1fr);
    gap: 3rem 2rem;
  }
}

.p-news-list__link {
  display: block flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.p-news-list__link:hover {
  opacity: 0.7;
}
.p-news-list__link:hover .p-news-list__fig img {
  scale: 1.1;
}

.p-news-list__fig {
  overflow: clip;
  border-radius: 16px;
  -webkit-margin-after: 0.5rem;
          margin-block-end: 0.5rem;
}
.p-news-list__fig img {
  -o-object-fit: cover;
     object-fit: cover;
  inline-size: 100%;
  block-size: 100%;
  scale: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.p-news-list__date {
  letter-spacing: 0.1em;
  line-height: 1.4;
  -webkit-margin-after: 0.5rem;
          margin-block-end: 0.5rem;
}

.p-news-list__category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  inline-size: 100px;
  padding-inline: 1rem;
  padding-block: 0.125rem;
  font-size: 0.875rem;
  color: rgb(255, 255, 255);
  line-height: 1.2;
  text-align: center;
  border-radius: 15px;
  position: relative;
  pointer-events: none;
}
@media screen and (min-width: 576px) {
  .p-news-list__category {
    top: 0.125rem;
  }
}

.p-news-list__title {
  -webkit-margin-after: 0.75rem;
          margin-block-end: 0.75rem;
  font-size: clamp(0.875rem, 0.446rem + 0.89vw, 1rem);
  font-weight: 600;
  line-height: 1.5;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.cat-news .p-news-category__label,
.cat-news .p-news-list__category {
  border: 2px solid rgb(13, 149, 94);
  background-color: rgb(13, 149, 94);
}

.cat-event .p-news-category__label,
.cat-event .p-news-list__category {
  border: 2px solid rgb(6, 96, 161);
  background-color: rgb(6, 96, 161);
}

.cat-tourism .p-news-category__label,
.cat-tourism .p-news-list__category {
  color: rgb(13, 149, 94);
  border: 2px solid rgb(216, 213, 96);
  background-color: rgb(216, 213, 96);
}

.cat-other .p-news-category__label,
.cat-other .p-news-list__category {
  border: 2px solid rgb(150, 150, 150);
  background-color: rgb(150, 150, 150);
}

.p-news__deco {
  inline-size: 100%;
  position: absolute;
  bottom: 0;
  left: 0;
  translate: 0 50%;
}

.p-news__button {
  display: block flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-top: 4rem;
}

.p-video {
  -webkit-padding-before: 5rem;
          padding-block-start: 5rem;
}
@media screen and (min-width: 768px) {
  .p-video {
    -webkit-padding-before: 8rem;
            padding-block-start: 8rem;
  }
}

.p-video__inner {
  -webkit-padding-after: 4rem;
          padding-block-end: 4rem;
  border-bottom: 1px solid rgba(0, 164, 100, 0.6);
}

.p-video__title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.808rem + 1.92vw, 2rem);
  font-weight: bold;
  text-align: center;
}

.p-video__main {
  inline-size: 100%;
  aspect-ratio: 16/9;
}
.p-video__main iframe {
  display: block;
  inline-size: 100%;
  block-size: 100%;
}

.p-video__link {
  display: block flex;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.p-video__link:hover {
  opacity: 0.7;
}

.p-authorized {
  padding-block: 5rem;
}
@media screen and (min-width: 768px) {
  .p-authorized {
    padding-block: 8rem;
  }
}

.p-authorized__title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.808rem + 1.92vw, 2rem);
  font-weight: bold;
  text-align: center;
}

.p-authorized-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
}
@media screen and (min-width: 768px) {
  .p-authorized-list {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1.5rem;
  }
}
@media screen and (min-width: 992px) {
  .p-authorized-list {
    gap: 2rem;
  }
}

.p-authorized-list__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border: 1px solid rgb(0, 0, 0);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.p-authorized-list__link:hover {
  opacity: 0.7;
}

.p-tanada {
  overflow: clip;
  padding-block: 5rem;
  background-image: url(../img/bg.jpg);
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-tanada {
    padding-block: 6rem;
  }
}
@media screen and (min-width: 992px) {
  .p-tanada {
    padding-block: 8rem;
  }
}

.p-tanada__head {
  display: block flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  row-gap: 2rem;
  -webkit-padding-after: 6rem;
          padding-block-end: 6rem;
}

.p-tanada__headline {
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(2.25rem, 1.583rem + 1.39vw, 2.625rem);
  font-weight: 600;
  letter-spacing: 0.3em;
  line-height: 1.4;
  text-align: center;
}
.p-tanada__headline span {
  font-family: "Shippori Mincho B1", serif;
  font-size: 0.9em;
}
@media screen and (min-width: 768px) {
  .p-tanada__headline br {
    display: none;
  }
}

.p-tanada__tagline {
  display: block flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 0.5rem;
     -moz-column-gap: 0.5rem;
          column-gap: 0.5rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1rem, 0.818rem + 0.91vw, 1.5rem);
  font-weight: 600;
  letter-spacing: 0.2em;
}
.p-tanada__tagline::before, .p-tanada__tagline::after {
  content: "";
  inline-size: 40px;
  block-size: 20px;
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: center bottom;
}
.p-tanada__tagline::before {
  background-image: url(../img/tanada-fig-10.png);
}
.p-tanada__tagline::after {
  background-image: url(../img/tanada-fig-11.png);
}
@media screen and (min-width: 768px) {
  .p-tanada__tagline {
    -webkit-column-gap: 1rem;
       -moz-column-gap: 1rem;
            column-gap: 1rem;
  }
  .p-tanada__tagline::before, .p-tanada__tagline::after {
    inline-size: 60px;
    block-size: 30px;
  }
}

.p-tanada__box {
  position: relative;
}
.p-tanada__box:not(:last-of-type) {
  -webkit-padding-after: 7rem;
          padding-block-end: 7rem;
}
@media screen and (min-width: 768px) {
  .p-tanada__box:not(:last-of-type) {
    -webkit-padding-after: 5rem;
            padding-block-end: 5rem;
  }
}

.p-tanada__box-inner {
  display: block grid;
  -webkit-padding-after: 2rem;
          padding-block-end: 2rem;
  row-gap: 2rem;
}
@media screen and (min-width: 768px) {
  .p-tanada__box-inner {
    grid-template-columns: repeat(2, 1fr);
  }
}
.p-tanada__left {
  position: relative;
  z-index: 10;
}

.p-tanada__title {
  -webkit-padding-after: 1rem;
          padding-block-end: 1rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.5rem, 0.611rem + 1.85vw, 2rem);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-align: center;
}

.p-tanada__location {
  display: block flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 0.5rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1rem, 0.778rem + 0.46vw, 1.125rem);
  font-weight: 600;
  background-color: rgb(250, 239, 66);
  position: relative;
}
.p-tanada__location::before, .p-tanada__location::after {
  content: "";
  inline-size: 35px;
  block-size: 2px;
  background-color: rgb(51, 51, 51);
  rotate: 45deg;
  -webkit-transform-origin: center;
          transform-origin: center;
  position: absolute;
}
.p-tanada__location::before {
  top: 12%;
  right: -2%;
}
.p-tanada__location::after {
  bottom: 12%;
  left: -2%;
}

.p-tanada__copy {
  display: block flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding-block: 2rem 1rem;
  font-size: clamp(1.25rem, 1.028rem + 0.46vw, 1.375rem);
  font-weight: 600;
  line-height: 1.4;
}

.p-tanada__detail {
  font-family: "Shippori Mincho B1", serif;
}

.p-tanada__right {
  position: relative;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .p-tanada__right {
    -webkit-padding-before: 1rem;
            padding-block-start: 1rem;
    -webkit-padding-start: 3rem;
            padding-inline-start: 3rem;
  }
}

.p-tanada__fig {
  -webkit-padding-after: 2rem;
          padding-block-end: 2rem;
}

.p-tanada__data {
  max-inline-size: 450px;
  margin-inline: auto;
}

.p-tanada__button {
  display: block grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.5rem;
  max-inline-size: 650px;
  margin-inline: auto;
  position: relative;
  z-index: 20;
}
.p-tanada__button .c-button {
  inline-size: 100%;
}
@media screen and (min-width: 476px) {
  .p-tanada__button {
    gap: 1rem;
  }
}
@media screen and (min-width: 768px) {
  .p-tanada__button {
    gap: 1.5rem;
  }
}

.p-tanada__bg {
  inline-size: 150%;
  max-inline-size: 1100px;
  position: absolute;
  top: -2rem;
  left: 50%;
  translate: -50% 0;
}
@media screen and (min-width: 768px) {
  .p-tanada__bg {
    inline-size: 140%;
  }
}
@media screen and (min-width: 1200px) {
  .p-tanada__bg {
    inline-size: 120%;
  }
}

.p-tanada__deco01 {
  inline-size: 100%;
  position: absolute;
  top: 0;
  left: 0;
  translate: 0 -50%;
}

.p-pagenation {
  -webkit-padding-before: 4rem;
          padding-block-start: 4rem;
}
.p-pagenation .pagenumber ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-column-gap: 1rem;
     -moz-column-gap: 1rem;
          column-gap: 1rem;
}
.p-pagenation .pagenumber ul li {
  inline-size: 40px;
  aspect-ratio: 1;
}
.p-pagenation .pagenumber ul .current .page_link {
  color: rgb(255, 255, 255);
  background-color: rgb(51, 51, 51);
}
.p-pagenation .pagenumber ul .page_link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  inline-size: 100%;
  block-size: 100%;
  border-radius: 50%;
  border: 1px solid rgb(51, 51, 51);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.p-pagenation .pagenumber ul .page_link:hover {
  color: rgb(255, 255, 255);
  background-color: rgb(51, 51, 51);
}

.p-news-detail__head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
@media screen and (min-width: 768px) {
  .p-news-detail__head {
    -webkit-margin-after: 4rem;
            margin-block-end: 4rem;
  }
}

.p-news-detail__date {
  font-size: clamp(1rem, 0.778rem + 0.46vw, 1.125rem);
  -webkit-margin-after: 0.75rem;
          margin-block-end: 0.75rem;
}

.p-news-detail__title {
  -webkit-margin-after: 1.25rem;
          margin-block-end: 1.25rem;
  font-size: clamp(1.5rem, 0.167rem + 2.78vw, 2.25rem);
  font-weight: 600;
  line-height: 1.6;
  text-align: center;
}

.p-news-detail__category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  inline-size: 150px;
  padding-block: 0.25rem;
  font-weight: 0.875rem;
  color: rgb(255, 255, 255);
  line-height: 1.4;
  border-radius: 20px;
}

.cat-news .p-news-detail__category {
  background-color: rgb(13, 149, 94);
}

.cat-event .p-news-detail__category {
  background-color: rgb(6, 96, 161);
}

.cat-tourism .p-news-detail__category {
  color: rgb(13, 149, 94);
  background-color: rgb(216, 213, 96);
}

.cat-other .p-news-detail__category {
  background-color: rgb(150, 150, 150);
}

.p-news-detail__thumbnail {
  overflow: clip;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-inline: calc(50% - 50cqi);
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
.p-news-detail__thumbnail img {
  max-inline-size: 1300px;
  margin-inline: auto;
  border-radius: 20px;
}
@media screen and (min-width: 768px) {
  .p-news-detail__thumbnail {
    -webkit-margin-after: 4rem;
            margin-block-end: 4rem;
  }
}

.p-news-detail__contents {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .p-news-detail__contents {
    -webkit-margin-after: 4rem;
            margin-block-end: 4rem;
  }
}

.p-news-detail__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-margin-after: 5rem;
          margin-block-end: 5rem;
}
.p-news-detail__button .c-button {
  color: rgb(51, 51, 51);
  border: 2px solid rgb(172, 172, 172);
  background-color: rgb(255, 255, 255);
}

.p-news-detail__categorylist-title {
  -webkit-margin-after: 1rem;
          margin-block-end: 1rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.25rem, 0.806rem + 0.93vw, 1.5rem);
  font-weight: bold;
  text-align: center;
}

.p-news-detail__categorylist-block {
  max-inline-size: 900px;
  margin-inline: auto;
  padding-inline: 1rem;
  padding-block: 1rem;
  border-radius: 20px;
  background-color: rgb(214, 233, 196);
}
@media screen and (min-width: 576px) {
  .p-news-detail__categorylist-block {
    padding-inline: 1.25rem;
    padding-block: 1.25rem;
  }
}
@media screen and (min-width: 768px) {
  .p-news-detail__categorylist-block {
    padding-inline: 1.5rem;
    padding-block: 1.5rem;
  }
}

.p-about-logo {
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
}
@media screen and (min-width: 768px) {
  .p-about-logo {
    -webkit-margin-after: 5rem;
            margin-block-end: 5rem;
  }
}

.p-about-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  max-inline-size: 630px;
  margin-inline: auto;
  -webkit-margin-after: 1rem;
          margin-block-end: 1rem;
  -webkit-padding-after: 0.5rem;
          padding-block-end: 0.5rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.375rem, 0.856rem + 1.44vw, 1.75rem);
  font-weight: 500;
  border-bottom: 2px dashed rgb(0, 0, 0);
}

.p-about-detail {
  -webkit-margin-after: 3rem;
          margin-block-end: 3rem;
  font-size: clamp(1rem, 0.827rem + 0.48vw, 1.125rem);
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .p-about-detail {
    -webkit-margin-after: 4rem;
            margin-block-end: 4rem;
  }
}

.p-about-map {
  max-inline-size: 340px;
  margin-inline: auto;
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}

.p-about-gallery {
  display: grid;
  row-gap: 1.5rem;
  margin-inline: calc(50% - 50cqi - 4vw);
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}
@media screen and (min-width: 576px) {
  .p-about-gallery {
    grid-template-columns: repeat(3, 1fr);
    -webkit-column-gap: 0.25rem;
       -moz-column-gap: 0.25rem;
            column-gap: 0.25rem;
    -webkit-margin-after: 5rem;
            margin-block-end: 5rem;
  }
}
@media screen and (min-width: 768px) {
  .p-about-gallery {
    margin-inline: calc(50% - 50cqi - 32px);
  }
}

.p-about-gallery__box-fig {
  -webkit-margin-after: 0.5rem;
          margin-block-end: 0.5rem;
}

.p-about-gallery__box-summary {
  font-size: 0.875rem;
  text-align: center;
}

.p-about__deco {
  margin-inline: calc(50% - 50cqi - 32px);
  -webkit-margin-after: 5rem;
          margin-block-end: 5rem;
}

.p-about-outline {
  margin-inline: calc(50% - 50cqi);
  -webkit-margin-after: 5rem;
          margin-block-end: 5rem;
}
@media screen and (min-width: 768px) {
  .p-about-outline {
    -webkit-margin-after: 7rem;
            margin-block-end: 7rem;
  }
}

.p-about-outline__title {
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
  font-family: "Shippori Mincho B1", serif;
  font-size: clamp(1.375rem, 0.856rem + 1.44vw, 1.75rem);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-about-outline__title {
    -webkit-margin-after: 3rem;
            margin-block-end: 3rem;
  }
}

.p-about-outline__list {
  max-inline-size: 1300px;
  margin-inline: auto;
}

.p-about-outline__list-item {
  padding-block: 0.75rem;
  padding-inline: 4vw;
}
.p-about-outline__list-item:nth-of-type(odd) {
  background-color: rgb(223, 237, 221);
}
@media screen and (min-width: 768px) {
  .p-about-outline__list-item {
    padding-block: 1.25rem;
    padding-inline: 2rem;
  }
}

.p-about-outline__list-item-inner {
  display: grid;
  max-inline-size: 1000px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-about-outline__list-item-inner {
    grid-template-columns: 90px 1fr;
  }
}

.p-about-outline__list-head {
  font-size: clamp(1rem, 0.827rem + 0.48vw, 1.125rem);
  font-weight: bold;
  line-height: 2;
}
@media screen and (min-width: 768px) {
  .p-about-outline__list-head {
    font-weight: 500;
  }
}

.p-about-outline__list-body {
  font-size: clamp(1rem, 0.827rem + 0.48vw, 1.125rem);
  font-weight: 500;
  line-height: 2;
}

.p-about-access__map {
  max-inline-size: 960px;
  margin-inline: auto;
  -webkit-margin-after: 2rem;
          margin-block-end: 2rem;
}
.p-about-access__map:first-of-type {
  -webkit-margin-after: 4rem;
          margin-block-end: 4rem;
}
@media screen and (min-width: 768px) {
  .p-about-access__map:first-of-type {
    -webkit-margin-after: 5rem;
            margin-block-end: 5rem;
  }
}