/*************************************************
style.css
**************************************************/
/* フォント指定 */
@font-face {
	font-family: 'shippori';
	    font-style: normal;
	    font-weight: 400;
	    font-display: swap;
	    src: url('/bank/core2026/fonts/ShipporiGothicB2-Bold.ttf') format('truetype');
	}
body { font-family: shippori;}

/* フォントについて
Copyright 2020 The Shippori Mincho Project Authors (https://github.com/fontdasu/ShipporiMincho)

This Font Software is licensed under the SIL Open Font License, Version 1.1.
This license is copied below, and is also available with a FAQ at:
http://scripts.sil.org/OFL
*/


/* 共通スタイル */
:where(:root) {
/*
  font-family: var(--font-primary);
*/
  font-style: unset;
  font-weight: 400;
  line-height: 1.5;
  text-align: start;
  word-break: initial;
  line-break: strict;
  hyphens: auto;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  letter-spacing: var(--tracking-value-2);
}

.drawer-open {
  overflow: hidden;
}

:where(body) {
  min-block-size: 100svb;
  margin: unset;
  padding: unset;
  background: var(--white-color);
}

:where(h1, h2, h3, h4, h5, h6) {
  margin-block: unset;
  font-size: unset;
}

img {
  max-inline-size: 100%;
  vertical-align: top;
}

ul {
  margin-block: unset;
  padding-inline-start: unset;
}

ul > li {
  list-style-type: '';
}

a {
  color: var(--link-color);
}

*:focus-visible {
  /* style */
  outline: 4px solid var(--border-focus);
  outline-offset: 2px;
  /* transition */
  transition: outline 0.3s ease-in-out;
}

.word-wrap {
  display: inline-block;
}

.visually-hidden {
  position: fixed !important;
  /* keep it on viewport */
  top: 0px !important;
  left: 0px !important;
  /* give it non-zero size, VoiceOver on Safari requires at least 2 pixels
		 before allowing buttons to be activated. */
  width: 4px !important;
  height: 4px !important;
  /* visually hide it with overflow and opacity */
  opacity: 0 !important;
  overflow: hidden !important;
  /* remove any margin or padding */
  border: none !important;
  margin: 0 !important;
  padding: 0 !important;
  /* ensure no other style sets display to none */
  display: block !important;
}

.content {
  max-inline-size: var(--container-content);
  inline-size: 100%;
  margin-inline: auto;
  padding-inline: var(--space-16);
}
/***********************
header
************************/
.site-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: var(--stack-top);
  margin-inline: auto;
  background: var(--gray-color-03);
}
  .site-header__primary {
    display: flex;
    justify-content: space-between;
    gap: var(--space-24);
    align-items: center;
    position: relative;
    max-inline-size: var(--container-size-xl);
    margin-inline: auto;
    padding-block: var(--space-30);
    padding-inline: var(--space-24) calc(var(--space-40) + var(--toggle-size));
    z-index: var(--stack-head);
  }
  @media (width < 768px) {
    .site-header__primary {
      padding-block: var(--space-16);
      padding-inline: var(--space-16) calc(var(--space-16) + var(--toggle-size));
    }
  }
    .site-header__inner {
      display: flex;
      justify-content: space-between;
      align-items: center;
      max-inline-size: calc(var(--container-size-lg) + var(--space-32));
    }
      .site-header__title {
        inline-size: 60vw;
        max-inline-size: calc(388 * var(--rem));
      }
        .site-header__title a {
          /* layout */
          display: grid;
          align-items: center;
          color: currentColor;
          text-decoration: none;
        }
          .site-header__title-logo img {
            /* layout */
            display: block;
            inline-size: 100%;
            block-size: auto;
          }
      @media (width < 980px) {
        .site-header__nav-wrap {
          display: none;
        }
      }
 
.global-nav__list {
  display: flex;
  justify-content: flex-end;
  gap: var(--space-36);
}
@media (width < 1080px) {
  .global-nav__list {
    gap: var(--space-24);
  }
}
  .global-nav__item {
    a {
      display: inline-block;
      position: relative;
      padding-block: var(--space-10);
      padding-inline: var(--space-8);
      color: var(--font-color);
      font-size: var(--font-size-15);
      text-decoration: none;
      &::after {
        content: "";
        position: absolute;
        inset-block-end: 0;
        inset-inline-start: 0;
        inline-size: 100%;
        block-size: 1px;
        background-color: var(--font-color);
        opacity: 0;
        transition: var(--hover-anm);
      }
      &:hover,
      &:focus-within {
        &::after {
          opacity: 1;
        }
      }
    }
  }

  
.toggle {
  display: grid;
  grid-template-rows: 1fr;
  place-items: center;
  row-gap: var(--space-8);
  position: absolute;
  inset-block-start: 50%;
  inset-inline-end: var(--space-24);
  z-index: var(--stack-toggle);
  inline-size: var(--toggle-size);
  aspect-ratio: 1;
  margin: auto;
  padding-block: var(--space-6);
  padding-inline: 0;
  background-color: var(--nav-toggle-background-color);
  border: none;
  border-radius: var(--rounded-full);
  color: var(--white-color);
  cursor: pointer;
  outline: 2px transparent solid;
  transform: translateY(-50%);
  transition: outline 0.3s ease-in-out;
  &:hover,
  &:focus-within {
    outline-color: var(--font-color);
  }
}
  .toggle-icon {
    position: relative;
    display: inline-grid;
    place-items: center;
    width: var(--toggle-line-width);
    background: transparent;
    border: none;
    transition: all 0.3s ease-in-out;
    transform: translateY(calc(-1 * (var(--toggle-padding) / 2)));
    &::before,
    &::after,
    span {
      content: '';
      position: absolute;
      grid-area: 1 / 1;
      inset-block-start: 0;
      inset-inline-start: 0;
      inline-size: 100%;
      block-size: var(--toggle-line-height);
      border-radius: var(--rounded-full);
      background-color: var(--nav-toggle-color);
      transition: all 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
      transform-origin: center;
    }
    &::before {
      transform: translateY(calc(var(--toggle-padding) * -2));
    }
    &::after {
      transform: translateY(calc(var(--toggle-padding) * 2));
    }
    span {
      inline-size: 100%;
      left: 0;
    }
  }
  .toggle[aria-expanded='true'] .toggle-icon::before,
  .toggle[aria-expanded='true'] .toggle-icon::after,
  .toggle[aria-expanded='true'] .toggle-icon span {
    background: var(--nav-toggle-color);
  }
  .toggle[aria-expanded='true'] .toggle-icon {
    span {
      width: 0;
      left: 50%;
      opacity: 0;
    }
    &::before {
      transform: translateY(0) rotate(135deg);
    }
    &::after {
      transform: translateY(0) rotate(-135deg);
    }
  }




.drawer {
  --drawer-size: calc(600 * var(--rem));
  position: fixed;
  z-index: var(--stack-drawer);
  inset-block: 0;
  inset-inline-end: calc(-1 * var(--drawer-size));
  max-inline-size: var(--drawer-size);
  inline-size: 100%;
  background-color: var(--white-color);
  padding: var(--space-24);
  padding-block-start: calc(var(--toggle-size) + var(--space-24));
  transition: all .4s ease-in 0s;
  .drawer-open & {
    inset-inline-end: 0;
  }
}
@media (width >= 1400px) {
  .drawer {
    .drawer-open & {
      inset-inline-end: calc((100vw - var(--container-size-xl)) / 2);
    }
  }
}
@media (width < 768px) {
  .drawer {
    --drawer-size: 80vw;
  }
}
@media (width < 480px) {
  .drawer {
    --drawer-size: 90vw;
  }
}
  .dnav-list {
    display: grid;
    padding-inline-end: calc(var(--space-16) + var(--toggle-size));
    gap: var(--space-16);
  }
  @media (width < 768px) {
    .dnav-list {
      padding-inline-end: unset;
    }
  }
    .dnav-list__link {
      display: inline-block;
      position: relative;
      padding-block: var(--space-10);
      padding-inline: var(--space-8);
      color: var(--font-color);
      font-size: var(--font-size-15);
      text-decoration: none;
      &::after {
        content: "";
        position: absolute;
        inset-block-end: 0;
        inset-inline-start: 0;
        inline-size: 100%;
        block-size: 1px;
        background-color: var(--font-color);
        opacity: 0;
        transition: var(--hover-anm);
      }
      &:hover,
      &:focus-within {
        &::after {
          opacity: 1;
        }
      }
    }



/* search */
.blc-search {
  position: absolute;
  inset-block-end: var(--space-24);
  inline-size: calc(100% - (var(--space-24) * 2));
}
  .search-title {
    color: var(--theme-color);
    font-weight: var(--fontweight-semibold);
    font-size: var(--font-size-23);
  }
  .blc-search__inner {
    display: flex;
    gap: var(--space-10);
    inline-size: 100%;
    block-size: calc(50 * var(--rem));
    margin-block: var(--space-20) 0;
    &:hover,
    &:focus-within {
      background-color: var(--color-background-hover);
    }
  }
    .blc-search__input {
      inline-size: 100%;
      padding: var(--space-10);
      background: var(--white-color);
      border: 1px var(--gray-color-01) solid;
      border-radius: calc(10 * var(--rem));
      font-family: inherit;
      font-size: var(--font-size-18);
      &:focus-within {
        border-color: var(--font-color);
      }
    }
    .blc-search__submit {
      inline-size: auto;
      block-size: 100%;
      padding: var(--space-6);
      background: var(--theme-color);
      outline: transparent 3px solid;
      border: none;
      border-radius: var(--rounded-4);
      color: var(--white-color);
      font-size: var(--font-size-20);
      font-weight: var(--fontweight-regular);
      line-height: 1;
      letter-spacing: .5em;
      text-indent: .5em;
      cursor: pointer;
      &:hover,
      &:focus-within {
        outline-color: var(--theme-color);
        background-color: var(--white-color);
        color: var(--theme-color);
      }
    }


.page-cover {
  position: fixed;
  inset-block-start: 0;
  inset-inline-start: 0;
  z-index: var(--stack-cover);
  inline-size: 100%;
  block-size: 100%;
  background: #000;
  opacity: .7;
  cursor: pointer;
}


/* ===============================
Main
================================ */
#main {
  padding-block: var(--header-size) var(--space-52);
  background: var(--sub-color-02);
}
@media (width < 768px) {
  #main {
    padding-inline: var(--space-8);
  }
}


.housing-info {
  max-inline-size: var(--container-content);
  inline-size: 100%;
  margin-inline: auto;
  inline-size: 100%;
  overflow: hidden;
  margin-inline: auto;
  border: 1px var(--theme-color) solid;
  border-radius: calc(16 * var(--rem));
}
  .housing-info__ttl {
    border-block-end: 1px var(--theme-color) solid;
    background-color: var(--white-color);
    .ttl {
      padding-block: var(--space-15);
      color: var(--theme-color);
      font-weight: bold;
      font-size: var(--font-size-23);
      letter-spacing: var(--tracking-250);
      text-align: center;
    }
  }
  .housing-info__inner {
    padding-inline: var(--space-40);
  }
  @media (width < 768px) {
    .housing-info__inner {
      padding-inline: var(--space-16);
    }
  }
    .housing-search {
      display: grid;
      grid-template-columns: 1fr auto;
      align-items: center;
      gap: var(--space-24);
      padding-block: var(--space-30);
      padding-inline: var(--space-52);
    }
    @media (width < 1024px) {
      .housing-search {
        padding-inline: var(--space-24);
      }
    }
    @media (width < 980px) {
      .housing-search {
        grid-template-columns: 1fr;
      }
    }
    @media (width < 768px) {
      .housing-search {
        padding-inline: var(--space-16);
        padding-block: var(--space-24);
      }
    }
      .housing-search__list {
        display: grid;
        gap: var(--space-30);
        margin: unset;
      }
        .housing-search__item {
          display: flex;
          gap: var(--space-8) var(--space-24);
          align-items: center;
          flex-wrap: wrap;
        }
          .housing-search__term {
            inline-size: 4em;
            color: var(--theme-color);
            font-size: var(--font-size-23);
            margin-inline-end: var(--space-16);
            text-align: end;
          }
          @media (width < 768px) {
            .housing-search__term {
              inline-size: 100%;
              text-align: start;
            }
          }
          .housing-search__dscrpt {
            margin: unset;
            color: var(--theme-color);
            font-size: var(--font-size-19);
          }
            .checkbox {
              display: inline-flex;
              align-items: center;
              gap: var(--space-8);
              position: relative;
              cursor: pointer;
              --checkbox-size: calc(20 * var(--rem));
            }
              .checkbox input {
                position: absolute;
                opacity: 0;
                inline-size: var(--checkbox-size);
                block-size: var(--checkbox-size);
                margin: unset;
              }
              .checkbox__mark {
                inline-size: var(--checkbox-size);
                block-size: var(--checkbox-size);
                outline: 1px solid var(--theme-color);
                border-radius: 4px;
                display: inline-block;
                position: relative;
                box-sizing: border-box;
              }
                .checkbox__mark::after {
                  content: "";
                  position: absolute;
                  inset-inline: 0;
                  inset-block: 0;
                  inline-size: calc(6 * var(--rem));
                  block-size: calc(12 * var(--rem));
                  margin: auto;
                  border: 0 solid var(--white-color);
                  border-inline-end-width: 2px;
                  border-block-end-width: 2px;
                  transform: translate(0, -10%) rotate(45deg);
                  opacity: 0;
                }
              .checkbox input:hover + .checkbox__mark,
              .checkbox input:focus-within + .checkbox__mark {
                outline-color: var(--black-color);
                outline-width: 2px;
              }
              .checkbox input:checked + .checkbox__mark {
                background-color: var(--theme-color);
              }
              .checkbox input:checked + .checkbox__mark::after {
                opacity: 1;
              }
              .checkbox__label {
                inline-size: 3.5em;
                letter-spacing: var(--tracking-120);
              }
      .housing-search__submit {
        & .search-submit {
          display: inline-flex;
          gap: var(--space-8);
          padding-inline: var(--space-42);
          padding-block: var(--space-8);
          border: none;
          border-radius: var(--rounded-full);
          background: var(--theme-color);
          font: inherit;
          color: var(--white-color);
          font-size: var(--font-size-23);
          letter-spacing: var(--tracking-120);
          outline: 1px transparent solid;
          cursor: pointer;
          transition: var(--hover-anm);
          &::before {
            content: "";
            inline-size: calc(20 * var(--rem));
            background: url(../img/icon_glass.png) center center no-repeat;
            background-size: contain;
            filter: invert(1);
            transition: var(--hover-anm);
          }
          &:hover,
          &:focus-within {
            background: var(--white-color);
            color: var(--theme-color);
            outline-color: var(--theme-color);
            &::before {
              filter: invert(23%) sepia(98%) saturate(748%) hue-rotate(104deg) brightness(90%) contrast(101%);
            }
          }
        }
      }
      @media (width < 980px) {
        .housing-search__submit {
          text-align: center;
        }
      }

.search-result {
  padding-block: var(--space-40);
  border-block-start: 1px var(--theme-color) solid;
}
  .search-result__item {
    transition: opacity 0.4s ease;
    opacity: 0;
    &[hidden] {
      display: none;
      opacity: 0;
    }
    &.is-visible {
      opacity: 1;
    }
    &.is-more {
      display: none;
      opacity: 0;
    }
  }
  .no-result {
    padding: 1em;
    border: 1px var(--theme-color) solid;
    transition: opacity 0.4s ease;
    opacity: 0;
    &[hidden] {
      display: none;
      opacity: 0;
    }
    &.is-visible {
      opacity: 1;
    }
  }
@media (width < 768px) {
  .search-result {
    padding-block: var(--space-24);
  }
}
  .search-result__list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(calc(254 * var(--rem)), 1fr));
  }
  @media (width < 768px) {
    .search-result__list {
      gap: var(--space-16) 0;
    }
  }
    .result-info {
      display: grid;
      grid-template-rows: auto;
      gap: var(--space-10);
      padding: var(--space-10);
      color: currentColor;
      text-decoration: none;
      transition: var(--hover-anm);
      &:hover,
      &:focus-within {
        background-color: var(--sub-color-03);
      }
    }
      .result-info__ttl {
        order: 2;
        position: relative;
        padding-inline-start: var(--space-10);
        font-size: var(--font-size-23);
        &::before {
          content: "";
          position: absolute;
          inset-inline-start: 0;
          inset-block: 0;
          inline-size: 4px;
          block-size: 80%;
          margin: auto;
          background-color: var(--theme-color);
        }
      }
      .result-info__img {
        order: 0;
        inline-size: 100%;
        aspect-ratio: 1.3 / 1;
        img {
          inline-size: 100%;
          block-size: 100%;
          object-fit: cover;
        }
        &.underdiscussion {
          position: relative;
          &::after {
            content: "";
            position: absolute;
            inset-inline: 0;
            inset-block: 0;
            background-color: var(--black-color);
            opacity: .5;
          }
        }
          .underdiscussion__label {
            position: absolute;
            z-index: 1;
            inset-inline-start: 0%;
            inset-block-start: 50%;
            inline-size: 100%;
            color: var(--white-color);
            font-size: var(--font-size-30);
            letter-spacing: var(--tracking-100);
            text-align: center;
            transform: translateY(-50%);
            &::before,
            &::after {
              content: "-";
            }
          }
      }
      .result-info__transactions {
        display: flex;
        gap: var(--space-10);
        order: 1;
        .transaction {
          padding-block: var(--space-2);
          padding-inline: var(--space-10);
          color: var(--white-color);
          font-size: var(--font-size-15);
          &.transaction--bas {
            background-color: #AA3030;
          }
          &.transaction--rent {
            background-color: #3030AA;
          }
        }
      }
      .info-list {
        order: 3;
        display: grid;
        gap: var(--space-8);
      }
        .info-list__item {
          display: grid;
          grid-template-columns: auto 1fr;
        }
          .info-list__dscrpt {
            margin: unset;
            padding: unset;
          }

.btn-link {
  display: block;
  inline-size: fit-content;
  margin-inline: auto;
  padding-block: var(--space-2);
  padding-inline: var(--space-40);
  border-radius: var(--rounded-full);
  background: var(--theme-color);
  outline: 1px var(--theme-color) solid;
  font-size: var(--font-size-23);
  letter-spacing: var(--tracking-120);
  color: var(--white-color);
  text-decoration: none;
  transition: var(--hover-anm);
  &:hover,
  &:focus-within {
    color: var(--theme-color);
    background-color: var(--white-color);
  }
}

/* ===============================
Footer
================================ */

.site-footer {
  padding-block: var(--space-36) 0;
  background: var(--sub-color-01);
}
  .site-footer__wrap {
    max-inline-size: var(--container-content);
    inline-size: 100%;
    margin-inline: auto;
    padding-inline: var(--space-16);
  }


/* ------- 
Footer Details
------- */
.footer-info {
  display: flex;
  flex-direction: column;
  row-gap: var(--space-20);
}

/* branding */
.site-footer__title {
  inline-size: fit-content;
  color: var(--white-color);
  font-size: var(--font-size-23);
  font-weight: 700;
  text-decoration: none;
}
@media (width < 768px) {
  .site-footer__title {
    font-size: 3.7vw;
  }
}
@media (width < 480px) {
  .site-footer__title {
    font-size: 5vw;
  }
}

.site-footer-map {
  position: relative;
  inline-size: 100%;
  max-inline-size: calc(688 * var(--rem));
  aspect-ratio: 2.5 / 1;
}
  .site-footer-map iframe {
    position: absolute;
    inset-inline-start: 0;
    inset-block-start: 0;
    inline-size: 100%;
    block-size: 100%;
  }

.location-info__details {
  display: grid;
  gap: var(--space-8);
  margin: unset;
  padding: unset;
  color: var(--white-color);
}
  .location-info__item {
    display: grid;
    grid-template-columns: auto 1fr;
    margin: unset;
  }
    .location-info__term {
      margin: unset;
      padding: unset;
      font-size: var(--font-size-15);
    }
    .location-info__dscrpt {
      margin: unset;
      padding: unset;
      font-size: var(--font-size-15);
    }


/*===========================
Copyright
=============================*/

.copyright {
  --logo-size: calc(36 * var(--rem));
  position: relative;
  padding-block: var(--space-40) calc(var(--space-16) + var(--reread-link-height) + var(--reread-link-inset));
}
@media (width < 768px) {
  .copyright {
    text-align: end;
  }
}
  .site-footer-nav {
    display: flex;
    justify-content: center;
  }
    .site-footer-nav__item {
      padding-inline: var(--space-16);
    }
    .site-footer-nav__item +
    .site-footer-nav__item {
      border-inline-start: 1px var(--white-color) solid;
    }
      .site-footer-nav__link {
        color: var(--white-color);
        font-size: var(--font-size-15);
        text-decoration: none;
        &:hover,
        &:focus-within {
          text-decoration: underline;
          text-decoration-thickness: 2px;
          text-underline-offset: 0.2em;
        }
      }
  @media (width < 768px) {
    .site-footer-nav {
      display: grid;
      justify-content: normal;
      gap: var(--space-16);
      inline-size: 100%;
      margin-block-end: var(--space-16);
      padding-inline: var(--space-8);
      text-align: start;
    }
      .site-footer-nav__item {
        position: relative;
        padding-inline: var(--space-8);
        &::after {
          content: "";
          position: absolute;
          inset-block-end: calc(-1 * var(--space-8));
          inset-inline: 0;
          inline-size: 100%;
          margin-inline: auto;
          border-block-start: 1px var(--white-color) dashed;
        }
      }
      .site-footer-nav__item +
      .site-footer-nav__item {
        border: none;
      }
  }

  .copyright__container {
    display: inline-grid;
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: var(--space-8);
    position: absolute;
    inset-block-start: var(--space-32);
    inset-inline-end: var(--space-24);
    text-decoration: none;
  }
  @media (width < 768px) {
    .copyright__container {
      position: static;
    }
  }
    .copyright__logo {
      inline-size: auto;
      block-size: var(--logo-size);
      & img {
        inline-size: auto;
        block-size: 100%;
      }
    }
    .copyright__label {
      color: var(--white-color);
      font-size: var(--font-size-23);
      font-weight: bold;
    }


/*************************************************
 reread-link
**************************************************/
.reread-link {
  position: fixed;
  inset-block-end: var(--reread-link-inset);
  inset-inline-end: var(--reread-link-inset);
  inline-size: var(--reread-link-height);
  aspect-ratio: 1;
  background-color: var(--theme-color);
  border: var(--border-width-lg) solid var(--sub-color-07);
  outline: var(--border-width-lg) solid transparent;
  border-radius: var(--rounded-full);
  transition: background-color 0.3s ease, outline-color 0.3s ease;
  z-index: var(--stack-foot);
  transition: var(--hover-anm);
}
.reread-link a {
  display: grid;
  place-items: center;
  inline-size: 100%;
  block-size: 100%;
}
.reread-link img {
  inline-size: 100%;
  max-inline-size: 32px;
  block-size: auto;
  object-fit: contain;
  transition: var(--hover-anm);
}
.reread-link:hover,
.reread-link:focus-visible {
  background-color: var(--sub-color-02);
  border-color: var(--theme-color);
  outline-color: var(--border-hover-bold);
}
  .reread-link:hover img,
  .reread-link:focus-visible img {
    filter: invert(34%) sepia(85%) saturate(600%) hue-rotate(104deg) brightness(70%) contrast(110%);
  }

/*************************************************
 CMS用テンプレート  .txtbox内部
**************************************************/
.locus-container {
  display: flex;
  height: min-content;
  margin-inline: auto;
  margin-block-end: var(--space-40);
  background: var(--sub-color-07);
}

p.locus {
  margin-block: var(--space-10);
  font-weight: var(--fontweight-regular);
  line-height: 1;
  letter-spacing: var(--tracking-30);
}

.locus a {
  margin: 0 0.1em;
  color: var(--link-color);
  text-decoration: underline;
  text-underline-offset: 0.2em;
  &:hover,
  &:focus-within {
    color: var(--color-text-link-hover);
    text-decoration: none;
  }
}

.locus span {
  margin: 0 0.2em;
}

.page .contents {
  position: relative;
  overflow-x: clip;
}

.page .content-date {
  display: flex;
  justify-content: end;
  margin-block-start: unset;
}

.contents_inside {
  display: flex;
  gap: var(--space-20);
}


.contents_main {
  flex: 1; 
  min-inline-size: 0;
}


/* ===============================
TxtBox(CMS用)
================================ */
:root {
  /*----- txtbox common -----*/
  /* テキスト */
  --txtbox-font-size: var(--font-size-18);
  --txtbox-font-weight: var(--fontweight-regular);
  --txtbox-line-height: 1.7;
  /* リンク */
  --txtbox-link-color: var(--link-color);
  --txtbox-link-color-hover: var(--link-color) ;
  /* マーカー */
  --txtbox-marker-color: var(--sub-color-02);
  --txtbox-marker-size: 12px;
  /*----- heading -----*/
  /* h1 */
  --heading-h1-border-color: var(--sub-color-01);
  --heading-h1-text-color: currentColor;
  --heading-h1-font-size: var(--font-size-36);
  --heading-h1-font-weight: var(--fontweight-regular);
  --heading-h1-letter-spacing: var(--tracking-value-4);
  --heading-h1-line-height: 1.5;
  /* h2 */
  --heading-h2-bg-color: var(--sub-color-07);
  --heading-h2-border-color: transparent;
  --heading-h2-border-radius: var(--rounded-4);
  --heading-h2-text-color: currentColor;
  --heading-h2-font-size: var(--font-size-28);
  --heading-h2-font-weight: var(--fontweight-semibold);
  --heading-h2-line-height: 1.5;
  --heading-h2-letter-spacing: var(--tracking-value-5);
  /* h3 */
  --heading-h3-marker-color: var(--sub-color-01);
  --heading-h3-border-color: var(--sub-color-01);
  --heading-h3-text-color: var(--color-text-default);
  --heading-h3-font-size: var(--font-size-24);
  --heading-h3-font-weight: var(--fontweight-semibold);
  --heading-h3-line-height: 1.5;
  --heading-h3-letter-spacing: var(--tracking-value-5);
  /* h4 */
  --heading-h4-marker-color: var(--sub-color-01);
  --heading-h4-text-color: currentColor;
  --heading-h4-font-size: var(--font-size-22);
  --heading-h4-font-weight: var(--fontweight-semibold);
  --heading-h4-line-height: 1.6;
  --heading-h4-letter-spacing: var(--tracking-value-5);
  /* h5 */
  --heading-h5-marker-color: var(--sub-color-04);
  --heading-h5-border-radius: 0;
  --heading-h5-text-color: currentColor;
  --heading-h5-font-size: var(--font-size-20);
  --heading-h5-font-weight: var(--fontweight-semibold);
  --heading-h5-line-height: 1.5;
  --heading-h5-letter-spacing: var(--tracking-value-5);
  /* h6 */
  --heading-h6-marker-color: none;
  --heading-h6-text-color: currentColor;
  --heading-h6-font-size: var(--font-size-18);
  --heading-h6-font-weight: var(--fontweight-semibold);
  --heading-h6-line-height: 1.6;
  --heading-h6-letter-spacing: var(--tracking-value-6);
  /*----- table -----*/
  --table-border-color: var(--font-color);
  --table-header-bg-color: var(--sub-color-07);
  --table-cell-bg-color: var(--white-color);
  --table-text-color: currentColor;
  --table-header-text-color: currentColor;
}
.txtbox {
  /* size */
  inline-size: 100%;
  text-spacing-trim: trim-start;
}
.txtbox:not(h1, h2, h3, h4, h5, h6) {
  color: var(--color-text-default);
  font-size: var(--txtbox-font-size);
  font-weight: var(--txtbox-font-weight);
  line-height: var(--txtbox-line-height);
}
.txtbox {
  margin-block-start: var(--space-24);
}
.txtbox i,
.txtbox em {
  text-indent: 0.5em;
}
.txtbox ul {
  margin-block-end: 1.2em;
}
.txtbox ul > li {
  position: relative;
}
.txtbox ul > li:before {
  /* layout */
  content: "";
  display: block;
  /* position */
  position: absolute;
  inset-inline-start: 1em;
  inset-block-start: 0.5em;
  /* size */
  inline-size: var(--txtbox-marker-size);
  block-size: var(--txtbox-marker-size);
  /* style */
  background: var(--txtbox-marker-color);
  border-radius: var(--rounded-full);
}
ul + h2,
ol + h2 {
  margin-block-start: var(--space-32);
}
ul + img,
ol + img {
  margin-block-start: var(--space-24);
}
.txtbox table.wide_table caption,
.txtbox table.widetable caption {
  text-align: center;
}
.txtbox a {
  text-decoration: underline;
  text-underline-offset: 0.2em;
}
a.outside,
a.sizeview {
  color: var(--txtbox-link-color);
  /* transition */
  transition: color 0.3s ease;
}
.txtbox a:hover,
.txtbox a:focus-within {
  color: var(--color-text-link-hover);
  text-decoration-thickness: 3px;
}

/* heading h1 */
h1.page-title {
  /* layout */
  position: relative;
  display: block;
  inline-size: 100%;
  margin-block-start: 0;
  padding-block-end: var(--space-8);
  padding-inline: var(--space-8);
  /* style */
  color: var(--heading-h1-text-color);
  /* typography */
  font-size: var(--heading-h1-font-size);
  font-weight: var(--heading-h1-font-weight);
  line-height: var(--heading-h1-line-height);
  letter-spacing: var(--heading-h1-letter-spacing);
}
h1.page-title::after {
  /* layout */
  content: "";
  /* position */
  position: absolute;
  inset-block-end: calc(-1 * var(--space-8));
  inset-inline-start: 0;
  /* size */
  inline-size: 100%;
  block-size: 3px;
  /* style */
  background: var(--heading-h1-border-color);
  border-radius: none;
}
/* heading h2 */
.txtbox h2 {
  /* layout */
  position: relative;
  inline-size: 100%;
  margin-block-end: var(--space-16);
  padding-inline: var(--space-16);
  padding-block: var(--space-12);
  /* style */
  background: var(--heading-h2-bg-color);
  border: 1px solid var(--heading-h2-border-color);
  border-radius: var(--heading-h2-border-radius);
  color: var(--heading-h2-text-color);
  /* typography */
  font-size: var(--heading-h2-font-size);
  font-weight: var(--heading-h2-font-weight);
  line-height: var(--heading-h2-line-height);
  letter-spacing: var(--heading-h2-letter-spacing);
}
/* heading h3 */
.txtbox h3 {
  /* layout */
  position: relative;
  margin-block-end: var(--space-16);
  padding-block-start: var(--space-8);
  padding-block-end: var(--space-8);
  padding-inline-start: calc(5px + var(--space-12));
  border-bottom: 1px dashed var(--border-default);
  /* style */
  color: var(--heading-h3-text-color);
  /* typography */
  font-size: var(--heading-h3-font-size);
  font-weight: var(--heading-h3-font-weight);
  line-height: var(--heading-h3-line-height);
  letter-spacing: var(--heading-h3-letter-spacing);
}
.txtbox h3::before {
  content: "";
  display: block;
  position: absolute;
  inset-block-start: 5%;
  inset-inline-start: 0;
  inline-size: 4px;
  block-size: 90%;
  background: var(--heading-h3-marker-color);
}
/* heading h4 */
.txtbox h4 {
  /* layout */
  position: relative;
  padding-inline-start: calc(23px + var(--space-8));
  /* style */
  color: var(--heading-h4-text-color);
  font-size: var(--heading-h4-font-size);
  font-weight: var(--heading-h4-font-weight);
  line-height: var(--heading-h4-line-height);
  letter-spacing: var(--heading-h4-letter-spacing);
}
.txtbox h4::before {
  content: "";
  position: absolute;
  inset-inline-start: 0;
  inset-block-start: 50%;
  transform: translateY(-50%);
  inline-size: calc(24 / 16 * 1rem);
  block-size: calc(24 / 16 * 1rem);
  background: none;
  border-radius: var(--rounded-full);
  box-shadow: inset 0 0 0 calc(5 / 16 * 1rem) var(--heading-h4-marker-color);
}
/* heading h5 */
.txtbox h5 {
  /* layout */
  position: relative;
  padding-inline-start: calc(13px + var(--space-16));
  /* sytle */
  color: var(--heading-h5-text-color);
  font-size: var(--heading-h5-font-size);
  font-weight: var(--heading-h5-font-weight);
  letter-spacing: var(--heading-h5-letter-spacing);
}
.txtbox h5::before {
  content: "";
  position: absolute;
  inset-inline-start: 0.4em;
  inset-block-start: 50%;
  transform: translateY(-50%);
  inline-size: 13px;
  block-size: 12px;
  background: var(--heading-h5-marker-color);
}
/* heading h6 */
.txtbox h6 {
  position: relative;
  padding-inline-start: calc(0 + var(--space-6));
  font-size: var(--heading-h6-font-size);
  font-weight: var(--heading-h6-font-weight);
  letter-spacing: var(--heading-h6-letter-spacing);
}
/* table */
.txtbox table th {
  border: 1px solid var(--table-border-color);
}
.txtbox table td {
  border: 1px solid var(--table-border-color);
}
.txtbox table th {
  color: var(--table-header-text-color);
  background: var(--table-header-bg-color);
}
.txtbox table th[scope="col"] {
  background: var(--table-header-bg-color);
}
.txtbox table th[scope="row"] {
  background: var(--table-header-bg-color);
  border: 1px solid var(--table-border-color);
}
.txtbox table td {
  background: var(--table-cell-bg-color);
}
@media (width < 768px) {
  h1.page-title {
    padding-block-end: var(--space-8);
    /* typography */
    font-size: calc(var(--heading-h1-font-size) * 0.88);
  }
  h1.page-title::after {
    inset-block-end: calc(-1 * var(--space-4));
  }
  .txtbox h2 {
    font-size: calc(var(--heading-h2-font-size) * 0.8);
  }
  .txtbox h3 {
    font-size: calc(var(--heading-h3-font-size) * 0.85);
  }
  .txtbox h4 {
    font-size: calc(var(--heading-h4-font-size) * 0.85);
  }
  .txtbox h5 {
    font-size: calc(var(--heading-h5-font-size) * 0.88);
  }
  .txtbox h6 {
    font-size: calc(var(--heading-h6-font-size) * 0.9);
  }
  .txtbox:not(h1, h2, h3, h4, h5, h6) {
    font-size: calc(var(--txtbox-font-size) * 0.89);
  }
}



.pagination {
  margin-block: var(--space-24);
}

.pagination__list {
  display: flex;
  justify-content: space-between;
  gap: var(--space-32);
}

.pagination__link {
  /* layout */
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: var(--space-8);
  padding-block: var(--space-12);
  padding-inline: var(--space-24);
  /* style */
  color: var(--color-text-bold);
  background: var(--color-background-default);
  border: 1px solid var(--border-accent);
  border-radius: var(--rounded-full);
  text-decoration: none;
  /* typography */
  font-size: var(--font-size-16);
  font-weight: var(--fontweight-regular);
  line-height: 1;
  letter-spacing: var(--tracking-50);
  /* transition */
  transition: background-color 0.3s ease-in-out;
  text-underline-offset: 2px;
}

.pagination__link:hover,
.pagination__link:focus-within {
  background-color: var(--color-background-hover);
}

/* 前へボタン */
.pagination__link--prev::before {
  content: '';
  inline-size: 16px;
  block-size: 16px;
  background: url(../img/icon-arrow-right.png) no-repeat center center / contain;
  transform: rotate(180deg);
}

/* 次へボタン */
.pagination__link--next::after {
  content: '';
  inline-size: 16px;
  block-size: 16px;
  background: url(../img/icon-arrow-right.png) no-repeat center center / contain;
}

.modal-cover {
  display: none;
  position: fixed;
  inset: 0;
  z-index: var(--stack-top, 300);
  inline-size: 100%;
  block-size: 100%;
  background: rgba(0, 0, 0, .8);
  cursor: pointer;
}



@media (width < 768px) {
  .content {
    padding-inline: var(--space-8);
  }
  
  p.locus {
    margin-block: .4em;
    font-size: var(--font-size-16);
  }
    .locus a {
      margin-inline: unset;
    }
    
  
  .news-list__list {
    padding-inline: 0;
  }
    .news-list__meta {
      gap: var(--space-6)
    }
      .news-list__date {
        padding-inline-end: var(--space-4);
      }
      .news-list__lib {
        max-inline-size: calc(60 * var(--rem));
      }
      .news-list__category {
        font-size: var(--font-size-10);
      }
}

@media (width < 576px) {

  h1.content-title {
    margin-block-end: calc(var(--space-32) * 0.8);
    font-size: calc(var(--heading--font-size-h1) * 0.8);
  }
  h1.content-title + * {
    padding-block-start: var(--space-24);
  }
  h1.content-title::after {
    inset-block-end: calc(-0.7 * var(--space-32));
  }

  .txtbox h2 {
    font-size: calc(var(--heading--font-size-h2) * 0.84);
  }
  .txtbox h3 {
    font-size: calc(var(--heading--font-size-h3) * 0.84);
  }

  .txtbox h4 {
    font-size: calc(var(--heading--font-size-h4) * 0.84);
  }
  .txtbox h5 {
    font-size: calc(var(--heading--font-size-h5) * 0.84);
  }
  .txtbox h6 {
    font-size: calc(var(--heading--font-size-h6) * 0.84);
  }

  article p,
  .txtbox :is(p, table, dl) {
    font-size: calc(var(--txtbox--font-size) * 0.84);
  }

  /* 第一階層のリストアイテムのフォントサイズ設定 */
  .txtbox > :is(ul, ol) > li {
    font-size: calc(var(--txtbox--font-size) * 0.84);
  }

  /* 入れ子要素のフォントサイズ設定 */
  .txtbox :is(table p, :is(ul, ol) :is(ul, ol) > li) {
    font-size: 1em;
  }
  .pagination__link {
    padding-block: var(--space-8);
    padding-inline: var(--space-16);
    font-size: var(--font-size-15);
  }
}

@media (width < 480px) {
  .news-list__meta {
    flex-wrap: wrap;
  }
    .news-list__date {
      inline-size: 100%;
    }
      .news-list__link {
        font-size: var(--font-size-14);
      }
}

/* 固定お問い合わせボタン */
.btn_fix_contact {
  position: fixed; top: calc(50% - 4.5em + (118px / 2)); right: 0px; height: 9em; font-size:var(--font-size-20);
  transition-duration: .3s; z-index: 10;
}
.btn_fix_contact a {
  display: flex;
  justify-content: cener;
  align-items: center;
  width: 2.5em;
  height: 100%;
  padding:.3em;
  background: var(--theme-color);
  outline: 2px solid var(--theme-color);
  color: var(--white-color);
  text-decoration: none;
  line-height: 1.2;
  text-align: center;
  border-radius: .6em 0 0 .6em;
  transition-duration: .3s;
}
.btn_fix_contact a:hover,
.btn_fix_contact a:focus {
  color: var(--theme-color);
  background: var(--white-color);
}

@media (width < 768px) {
  .btn_fix_contact {
    top: calc(50% - 4.5em + 1vh);
    font-size:var(--font-size-16);}
}

@media (width < 480px) {
  .btn_fix_contact a {
    width: 2em;
  }
}