@charset "UTF-8";
/* cms.css
----------------------------------------------------------------- */
@layer pages {
  /* ============================================================
  News（お知らせ一覧）
  ============================================================ */
  .newsCont {
    padding-block: clamp(30px, 4.6296296296vw, 50px);
  }
  @media screen and (max-width: 768px) {
    .newsCont {
      padding-block: clamp(30px, 4.6296296296vw, 50px) 22px;
    }
  }
  .newsCont__card {
    background: #fff;
    border-radius: 15px;
    box-shadow: 6px 0 21px rgba(75, 75, 75, 0.15);
    padding-block: clamp(39px, 3.7962962963vw, 41px) 41px;
    padding-inline: clamp(24px, 3.7425149701vw, 50px);
  }
  @media screen and (max-width: 768px) {
    .newsCont__card {
      padding-block: clamp(39px, 3.7962962963vw, 41px) 66px;
    }
  }
  .newsCont__catArea {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: 16px;
    flex-wrap: wrap;
    padding-bottom: clamp(34px, 3.8888888889vw, 42px);
    border-bottom: 1px solid #e4e5e5;
  }
  @media (max-width: 768px) {
    .newsCont__catArea {
      flex-direction: column;
      align-items: flex-start;
      gap: 14px;
    }
  }
  .newsCont__catLabel {
    font-size: clamp(16px, 1.7964071856vw, 24px);
    font-weight: 500;
    white-space: nowrap;
  }
  .newsCont__catBtns {
    flex: 1;
    display: flex;
    align-items: center;
    gap: clamp(12px, 1.8518518519vw, 20px);
    flex-wrap: wrap;
  }
  @media screen and (max-width: 768px) {
    .newsCont__catBtns {
      width: 100%;
    }
  }
  .newsCont__catBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: 150px;
    width: 100%;
    padding-block: 8px;
    padding-inline: 1em;
    border: 1px solid #686868;
    border-radius: 3px;
    font-size: clamp(12px, 1.0479041916vw, 14px);
    font-weight: 500;
    letter-spacing: 0.05em;
    text-decoration: none;
    transition: all 0.25s ease-in-out;
    white-space: nowrap;
    background: #fff;
    color: #686868;
  }
  @media screen and (max-width: 768px) {
    .newsCont__catBtn {
      border-radius: 5px;
      max-width: 95px;
      padding-inline: 0.5em;
    }
  }
  .newsCont__catBtn.is-active {
    background: #686868;
    color: #fff;
  }
  .newsCont__list {
    list-style: none;
  }
  .newsCont__item {
    border-bottom: 1px solid #e4e5e5;
  }
  .newsCont__item:first-child .newsCont__link {
    padding-top: clamp(35px, 3.7425149701vw, 50px);
  }
  .newsCont__link {
    display: flex;
    align-items: center;
    gap: 3%;
    padding-block: clamp(35px, 3.7425149701vw, 50px);
    text-decoration: none;
    color: inherit;
  }
  @media (max-width: 768px) {
    .newsCont__link {
      flex-wrap: wrap;
      gap: 10px;
      padding-block: clamp(35px, 3.7425149701vw, 50px) clamp(32px, 3.7425149701vw, 50px);
    }
  }
  @media (min-width: 767px) {
    .newsCont__link:hover .newsCont__ico {
      transform: translateX(5px);
    }
  }
  .newsCont__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
  }
  .newsCont__meta {
    display: flex;
    align-items: center;
    gap: clamp(10px, 1.497005988vw, 20px);
  }
  .newsCont__date {
    font-size: clamp(12px, 1.0479041916vw, 14px);
    font-weight: 500;
    color: #9e9e9f;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .newsCont__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }
  .newsCont__cat {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #686868;
    color: #fff;
    font-size: clamp(10px, 0.8982035928vw, 12px);
    font-weight: 500;
    border-radius: 3px;
    padding-block: 3px 5px;
    padding-inline: 12px;
    white-space: nowrap;
  }
  .newsCont__title {
    font-size: clamp(12px, 1.3473053892vw, 18px);
    line-height: 1.7;
    color: #000;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .newsCont__ico {
    width: clamp(34px, 2.8443113772vw, 38px);
    flex-shrink: 0;
    transition: transform 0.25s ease-in-out;
  }
  .newsCont__pager {
    margin-top: clamp(56px, 4.4161676647vw, 59px);
    display: flex;
    flex-direction: column;
    gap: 48px;
  }
  @media screen and (max-width: 768px) {
    .newsCont__pager {
      gap: 34px;
    }
  }
  .newsCont__pagerBtns {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 37px;
  }
  @media screen and (max-width: 768px) {
    .newsCont__pagerBtns {
      gap: 20px;
    }
  }
  .newsCont__pagerBtn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #9e9e9f;
    border-radius: 100px;
    max-width: 215px;
    width: 100%;
    font-size: clamp(12px, 1.1976047904vw, 16px);
    font-weight: 500;
    color: #000;
    text-decoration: none;
    transition: background-color 0.25s, color 0.25s;
    white-space: nowrap;
    padding-block: 15px;
    padding-inline: 28px;
  }
  @media (max-width: 768px) {
    .newsCont__pagerBtn {
      padding-inline: 18px;
      font-size: 12px;
    }
  }
  @media (min-width: 767px) {
    .newsCont__pagerBtn:hover {
      background: #686868;
      border-color: #686868;
      color: #fff;
    }
  }
  .newsCont__pagerBtn.is-disabled {
    opacity: 0.3;
    pointer-events: none;
  }
  .newsCont__pagerNums {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 21px;
    list-style: none;
  }
  .newsCont__pagerNum a,
  .newsCont__pagerNum span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 35px;
    height: 35px;
    border-radius: 50%;
    border: 1px solid #9e9e9f;
    font-size: clamp(12px, 1.0479041916vw, 14px);
    font-weight: 500;
    color: #000;
    text-decoration: none;
    transition: background-color 0.25s, color 0.25s, border-color 0.25s;
  }
  @media (max-width: 768px) {
    .newsCont__pagerNum a,
    .newsCont__pagerNum span {
      width: 35px;
      height: 35px;
    }
  }
  @media (min-width: 767px) {
    .newsCont__pagerNum a:hover {
      background: #686868;
      border-color: #686868;
      color: #fff;
    }
  }
  .newsCont__pagerNum.is-active span {
    background: #686868;
    border-color: #686868;
    color: #fff;
  }
  .newsCont__pagerNum--ellipsis span {
    border: none;
    font-size: clamp(14px, 1.1976047904vw, 16px);
    letter-spacing: 0.05em;
  }
  /* ============================================================
  newsSingle（お知らせ詳細）
  ============================================================ */
  .newsSingle {
    padding-block: 54px 100px;
  }
  @media (max-width: 768px) {
    .newsSingle {
      padding-block: 20px 25px;
    }
  }
  .newsSingle__card {
    background: #fff;
    border-radius: 15px;
    box-shadow: 6px 0 21px rgba(75, 75, 75, 0.15);
    padding-top: clamp(30px, 5.3703703704vw, 58px);
    padding-bottom: clamp(74px, 10.0925925926vw, 109px);
    padding-inline: clamp(30px, 4.4910179641vw, 60px);
  }
  @media (max-width: 768px) {
    .newsSingle__card {
      padding-bottom: 50px;
    }
  }
  .newsSingle__head {
    padding-bottom: clamp(16px, 1.8518518519vw, 20px);
    border-bottom: 1px solid #e4e5e5;
  }
  .newsSingle__meta {
    display: flex;
    align-items: center;
    gap: clamp(12px, 1.7964071856vw, 24px);
  }
  .newsSingle__date {
    font-size: clamp(14px, 1.1976047904vw, 16px);
    font-weight: 600;
    color: #9e9e9f;
    letter-spacing: 0.05em;
    white-space: nowrap;
  }
  .newsSingle__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }
  .newsSingle__cat {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #686868;
    color: #fff;
    font-size: clamp(10px, 0.8982035928vw, 12px);
    font-weight: 500;
    border-radius: 3px;
    padding-block: 2px 4px;
    padding-inline: 28px;
    white-space: nowrap;
  }
  @media screen and (max-width: 768px) {
    .newsSingle__cat {
      padding-inline: 20px;
      padding-block: 3px 5px;
    }
  }
  .newsSingle__ttl {
    margin-top: clamp(4px, 0.7407407407vw, 8px);
    font-size: clamp(26px, 2.245508982vw, 30px);
    font-weight: 500;
    line-height: 1.5;
    color: #000;
  }
  .cmsBody {
    margin-top: clamp(26px, 4.6296296296vw, 50px);
  }
  .cmsBody h2 {
    font-size: clamp(21px, 2.0958083832vw, 28px);
    font-weight: 500;
    line-height: 1.5;
    border-left: 5px solid #de0515;
    padding-left: 22px;
    padding-bottom: 7px;
  }
  @media screen and (max-width: 768px) {
    .cmsBody h2 {
      padding-left: 17.5px;
      padding-bottom: 0;
    }
  }
  .cmsBody h3 {
    display: inline-block;
    font-size: clamp(20px, 1.7964071856vw, 24px);
    font-weight: 500;
    line-height: 1.5;
    border-bottom: 2px solid #000;
    padding-bottom: 4px;
    margin-block: 44px 16px;
  }
  @media screen and (max-width: 768px) {
    .cmsBody h3 {
      margin-block: 44px 11px;
    }
  }
  .cmsBody p {
    font-size: 18px;
    line-height: 2;
    color: #000;
    margin-top: 24px;
  }
  @media screen and (max-width: 768px) {
    .cmsBody p {
      margin-top: 20px;
    }
  }
  .cmsBody p > img {
    width: auto;
  }
  .cmsBody p > iframe {
    width: 100%;
    aspect-ratio: 16/9;
  }
  /* ============================================================
  columnCont（コラム一覧）
  ============================================================ */
  .columnCont {
    padding-block: clamp(25px, 6.0185185185vw, 65px);
  }
  .columnCont__card {
    background: #fff;
    border-radius: 15px;
    box-shadow: 6px 0 21px rgba(75, 75, 75, 0.15);
    padding-top: clamp(40px, 4.2592592593vw, 46px);
    padding-bottom: 73px;
    padding-inline: clamp(30px, 5.5555555556vw, 60px);
  }
  @media (max-width: 768px) {
    .columnCont__card {
      padding-bottom: 42px;
    }
  }
  .columnCont__item {
    border-bottom: 1px solid #e4e5e5;
  }
  .columnCont__link {
    display: flex;
    align-items: flex-start;
    gap: clamp(20px, 3.3682634731vw, 45px);
    padding-block: clamp(35px, 3.7425149701vw, 50px);
    text-decoration: none;
    color: inherit;
  }
  @media (max-width: 768px) {
    .columnCont__link {
      flex-direction: column;
      gap: 14px;
    }
  }
  @media (min-width: 767px) {
    .columnCont__link:hover .columnCont__moreIco {
      transform: translate(3px, -50%);
    }
  }
  .columnCont__imgWrap {
    width: clamp(186px, 20.9580838323vw, 280px);
    aspect-ratio: 280/170;
    flex-shrink: 0;
    overflow: hidden;
  }
  @media screen and (max-width: 768px) {
    .columnCont__imgWrap {
      width: 100%;
    }
  }
  .columnCont__imgWrap img {
    border-radius: 13px;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
  }
  .columnCont__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
  }
  @media screen and (max-width: 768px) {
    .columnCont__body {
      width: 100%;
    }
  }
  .columnCont__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }
  .columnCont__cat {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    align-self: flex-start;
    background: #686868;
    color: #fff;
    font-size: clamp(10px, 0.8982035928vw, 12px);
    border-radius: 3px;
    padding-block: 3px 4px;
    padding-inline: 12px;
    white-space: nowrap;
  }
  @media screen and (max-width: 768px) {
    .columnCont__cat {
      padding-inline: 8px;
    }
  }
  .columnCont__title {
    font-size: clamp(16px, 1.3473053892vw, 18px);
    font-weight: 500;
    line-height: 1.5;
    color: #000;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .columnCont__txt {
    font-size: 12px;
    line-height: 1.8;
    color: #000;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .columnCont__more {
    margin-top: 4px;
  }
  @media screen and (max-width: 768px) {
    .columnCont__more {
      margin-top: 14px;
    }
  }
  .columnCont__moreBtn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    border: 1px solid #de0515;
    border-radius: 100px;
    max-width: 122px;
    width: 100%;
    color: #de0515;
    font-size: 12px;
    font-weight: 500;
    padding-block: 11.5px;
    padding-inline: 10px 21px;
  }
  @media screen and (max-width: 768px) {
    .columnCont__moreBtn {
      max-width: unset;
      display: flex;
      width: 75%;
      margin-inline: auto;
      font-size: 16px;
      padding-block: 20px;
      padding-inline: 10px;
    }
  }
  .columnCont__moreIco {
    position: absolute;
    top: 50%;
    transform: translate(0, -50%);
    right: 13px;
    width: 15px;
    transition: transform 0.25s ease-in-out;
  }
  @media screen and (max-width: 768px) {
    .columnCont__moreIco {
      right: 21px;
      width: 13px;
    }
  }
  /* ============================================================
  columnSingle（コラム詳細）
  ============================================================ */
  .columnSingle {
    padding-block: 54px 100px;
  }
  @media (max-width: 768px) {
    .columnSingle {
      padding-block: 20px 25px;
    }
  }
  .columnSingle__card {
    background: #fff;
    border-radius: 15px;
    box-shadow: 6px 0 21px rgba(75, 75, 75, 0.15);
    padding-top: clamp(30px, 5.3703703704vw, 58px);
    padding-bottom: clamp(74px, 10.0925925926vw, 109px);
    padding-inline: clamp(30px, 4.4910179641vw, 60px);
  }
  @media (max-width: 768px) {
    .columnSingle__card {
      padding-bottom: 50px;
    }
  }
  .columnSingle__head {
    padding-bottom: clamp(16px, 1.8518518519vw, 20px);
    border-bottom: 1px solid #e4e5e5;
  }
  .columnSingle__cats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5em;
  }
  .columnSingle__cat {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #686868;
    color: #fff;
    font-size: clamp(10px, 0.8982035928vw, 12px);
    border-radius: 3px;
    padding-block: 2px 4px;
    padding-inline: 8px;
    white-space: nowrap;
  }
  @media (max-width: 768px) {
    .columnSingle__cat {
      padding-inline: 20px;
      padding-block: 3px 5px;
    }
  }
  .columnSingle__ttl {
    margin-top: clamp(4px, 0.7407407407vw, 8px);
    font-size: clamp(26px, 2.245508982vw, 30px);
    font-weight: 500;
    line-height: 1.5;
    color: #000;
  }
  .columnSingle__thum {
    width: 100%;
    aspect-ratio: 1030/626;
    margin-top: clamp(25px, 4.6296296296vw, 50px);
  }
  @media screen and (max-width: 768px) {
    .columnSingle__thum {
      aspect-ratio: unset;
    }
  }
  .columnSingle__thum img {
    border-radius: 15px;
    width: auto;
    height: 100%;
    object-fit: cover;
    object-position: center top;
  }
  @media screen and (max-width: 768px) {
    .columnSingle__thum img {
      width: 100%;
    }
  }
  /* ============================================================
  cmsNoPosts（記事なし）
  ============================================================ */
  .cmsNoPosts {
    margin-top: 3em;
  }
  /* ============================================================
  cmsMoreBtn（ショートコード: more_btn）
  ============================================================ */
  .cmsMoreBtn {
    display: flex;
    align-items: center;
    width: fit-content;
    color: #de0515;
    border-bottom: 2px solid #de0515;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.5;
    text-decoration: none;
    margin-top: 24px;
    padding-bottom: 4px;
  }
  @media screen and (max-width: 768px) {
    .cmsMoreBtn {
      font-size: 18px;
    }
  }
  @media (min-width: 767px) {
    .cmsMoreBtn:hover::before {
      transform: translateX(5px);
    }
  }
  .cmsMoreBtn::before {
    content: "▶︎";
    display: inline-block;
    color: #de0515;
    margin-right: 18px;
    transition: all 0.25s ease-in-out;
  }
}