@charset "UTF-8";
/* *****************************
* utility
**************************** */
.sp {
  display: none;
}
@media (max-width: 767px) {
  .sp {
    display: block;
  }
}

/* *****************************
* component
**************************** */
/* title */
.page-ss-ttl-lv01 {
  font-size: 30px;
  font-weight: bold;
  color: #1d3c7a;
  width: fit-content;
  margin: 0 auto 30px;
  padding: 0 30px;
  position: relative;
  z-index: 0;
  text-align: center;
}
.page-ss-ttl-lv01:before,
.page-ss-ttl-lv01:after {
  content: "";
  aspect-ratio: 9 / 17;
  width: 15px;
  position: absolute;
  bottom: 0;
  background: #1d3c7a;
  mask: url(../img/ss/ttl-lv01.svg) no-repeat center / contain;
}
.page-ss-ttl-lv01:before {
  left: 0;
}
.page-ss-ttl-lv01:after {
  right: 0;
  transform: scale(-1,1);
}
.page-ss-ttl-lv01 .sp {
  display: none;
}

@media (max-width: 767px) {
  .page-ss-ttl-lv01 {
    font-size: 22px;
  }
  .page-ss-ttl-lv01 .sp {
    display: block;
  }
}

.page-ss-ttl-lv02 {
  font-size: 25px;
  margin: 0 0 30px;
  font-weight: bold;
  text-align: center;
  color: #1d3c7a;
}
@media (max-width: 767px) {
  .page-ss-ttl-lv02 {
    font-size: 20px;
    margin: 0 0 20px;
  }
}

.page-ss-ttl-lv04 {
  display: flex;
  margin-bottom: 1.5rem;
  font-size: 18px;
  color: #1d3c7a;
}
.page-ss-ttl-lv04:before {
  content: "";
  width: 4px;
  background-color: #1d3c7a;
  margin-right: 0.5rem;
  flex: 0 0 auto;
}

/* button */
.page-ss-button01 {
  width: fit-content;
  height: 50px;
  border-radius: 25px;
  position: relative;
  z-index: 0;
  transition: .4s all ease;
  border: 2px solid;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 18px;
  padding: 0 60px 0 30px;
  margin: 0 auto;
  line-height: 1.25;
}
.page-ss-button01:hover {
  text-decoration: none;
}
.page-ss-button01:before,
.page-ss-button01:after {
  content: "";
  position: absolute;
  transition: .4s all ease;
}
.page-ss-button01:before {
  aspect-ratio: 1 / 1;
  width: 30px;
  border-radius: 50%;
  top: 8px;
  right: 10px;
}
.page-ss-button01:after {
  aspect-ratio: 12 / 9;
  width: 20px;
  mask: url(../img/ss/ico-arw.svg) no-repeat center / contain;
  position: absolute;
  top: 14px;
  right: 15px;
}

.page-ss-button01--ver1 {
  background: #1d3c7a;
  border-color: #1d3c7a;
  color: #fff;
}
.page-ss-button01--ver1:hover {
  background: #fff;
  color: #1d3c7a;
}
.page-ss-button01--ver1:before {
  background: #fff;
}
.page-ss-button01--ver1:hover:before {
  background: #1d3c7a;
}
.page-ss-button01:after {
  background: #1d3c7a;
}
.page-ss-button01--ver1:hover:after {
  background: #fff;
}

.page-ss-button01--ver2 {
  background: #ffa303;
  border-color: #ffa303;
  color: #fff;
}
.page-ss-button01--ver2:hover {
  background: #fff;
  color: #ffa303;
}
.page-ss-button01--ver2:before {
  background: #fff;
}
.page-ss-button01--ver2:hover:before {
  background: #ffa303;
}
.page-ss-button01--ver2:after {
  background: #ffa303;
}
.page-ss-button01--ver2:hover:after {
  background: #fff;
}

@media (max-width: 767px) {
  .page-ss-button01 {
    font-size: 16px;
  }
}

/* *****************************
* MV
**************************** */
.page-ss-mv {
  aspect-ratio: 484 / 221;
  width: 100%;
  position: relative;
  z-index: 0;
}
.page-ss-mv__slider {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.page-ss-mv__slider-item {
  aspect-ratio: 484 / 221;
  width: 100%;
}
.page-ss-mv__slider-item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.page-ss-mv__inr {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-direction: column;
  width: 100%;
  height: 100%;
  padding: 15px;
  gap: 30px;
  top: 0;
  left: 0;
  position: absolute;
  z-index: 1;
}
.page-ss-mv__badge {
  width: 350px;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 30px;
}
.page-ss-mv__title {
  font-size: 35px;
  font-weight: bold;
  color: #1d3c7a;
  text-align: center;
text-shadow:
  0 0 2px #fff,
  0 0 6px #fff,
  0 0 12px #fff,
  0 0 24px #fff,
  0 0 36px #fff;
}

.page-ss-mv__title .sp {
  display: none;
}

@media screen and (max-width: 992px) {
  .page-ss-mv {
    position: relative;
    z-index: 0;
    aspect-ratio: 4 / 3;
  }
  .page-ss-mv__inr {
    padding: 6em 20px 0;
    gap: 20px;
    top: 0;
    left: 0;
    position: absolute;
    z-index: 1;
  }
  .page-ss-mv__slider-item {
    aspect-ratio: 4 / 3;
    width: 100%;
  }
  .page-ss-mv__badge {
    width: 100%;
    gap: 10px;
  }
  .page-ss-mv__title {
    font-size: 30px;
    line-height: 1.5;
  }
  .page-ss-mv__title .sp {
    display: block;
  }
}

/* *****************************
* PAGE NAV
**************************** */
.page-ss-pagenav {
  display: flex;
  justify-content: center;
  gap: 15px;
}
.page-ss-pagenav__list {
  width: 225px;
  height: 50px;
  border-radius: 25px;
  position: relative;
  z-index: 0;
  transition: .4s all ease;
  border: 2px solid #1d3c7a;
  color: #1d3c7a;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: bold;
  font-size: 18px;
  padding: 0 40px 0 0;
}
.page-ss-pagenav__list:hover {
  background: #1d3c7a;
  color: #fff;
  text-decoration: none;
}
.page-ss-pagenav__list:before,
.page-ss-pagenav__list:after {
  content: "";
  position: absolute;
  transition: .4s all ease;
}
.page-ss-pagenav__list:before {
  aspect-ratio: 1 / 1;
  width: 30px;
  border-radius: 50%;
  top: 8px;
  right: 10px;
  background: #1d3c7a;
}
.page-ss-pagenav__list:hover:before {
  background: #fff;
}
.page-ss-pagenav__list:after {
  aspect-ratio: 12 / 9;
  width: 20px;
  background: #fff;
  mask: url(../img/ss/ico-arw.svg) no-repeat center / contain;
  position: absolute;
  top: 14px;
  right: 15px;
  transform: rotate(90deg);
}
.page-ss-pagenav__list:hover:after {
  background: #1d3c7a;
}

@media (max-width: 767px) {
  .page-ss-pagenav {
    flex-wrap: wrap;
  }
  .page-ss-pagenav__list {
    width: 300px;
  }
}

/* *****************************
* PAGE
**************************** */
@media (max-width: 767px) {
  .page-ss-reason-sec__item:not(:first-child) {
    margin-top: 20px;
  }
}

.page-ss-reform-sec {
  padding: 30px;
  background: #deeef9;
}
.page-ss-reform-sec__contents {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 30px;
}
.page-ss-reform-sec__item-title {
  color: #fff;
  background: #1d3c7a;
  padding: 5px;
  text-align: center;
  font-weight: bold;
}
@media (max-width: 767px) {
  .page-ss-reform-sec {
    padding: 40px 20px;
  }
  .page-ss-reform-sec__contents {
    grid-template-columns: repeat(1,1fr);
    gap: 20px;
  }
  .page-ss-reform-sec__item-title {
    color: #fff;
    background: #1d3c7a;
    padding: 5px;
    text-align: center;
    font-weight: bold;
  }
}

.page-ss-flow-sec__title {
  width: 400px;
  margin: 0 auto 35px;
}
@media (max-width: 767px) {
  .page-ss-flow-sec__title {
    width: 90%;
    margin: 0 auto 35px;
  }
}

.page-ss-flow-sec {

  .contents {
    display: grid;
    grid-template-columns: repeat(1,1fr);
    gap: 30px;
  }

  .item:first-child {
    position: relative;
    z-index: 0;
  }

  .item:first-child:before {
    content: "";
    aspect-ratio: 1 / 1;
    width: 20px;
    background: #865e1b;
    position: absolute;
    top: 0;
    left: 140px;
    clip-path: polygon(0 0, 0% 100%, 100% 100%);
  }

  .item .inr {
    display: flex;
    align-items: flex-start;
  }

  .item .num {
    flex: 0 0 140px;
  }

  .item .content {
    display: flex;
    align-items: center;
    background: #fff5e8;
    padding: 20px 15px 20px 25px;
    gap: 25px;
    margin-top: 20px;
    min-height: 180px;
  }

  .item .icon-img {
    width: 100px;
    margin: 0 0 10px;
  }

  .item .title {
    font-weight: bold;
    line-height: 1.25;
    text-align: center;
    color: #ffa303;
  }

  .item .lead {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
    padding: 0 0 15px;
    margin: 0 0 15px;
    border-bottom: 1px dashed #5b5b5b;
  }

  .item .lists {
    display: grid;
    grid-template-columns: repeat(2,1fr);
    gap: 0 10px;
    line-height: 1.25;
  }

  .item .lists._col1 {
    grid-template-columns: repeat(1,1fr);
  }

  .item .list {
    display: flex;
  }

  .item .list:before {
    content: "・";
  }

}

@media (max-width: 767px) {
  .page-ss-flow-sec {

    .item {
      position: relative;
      z-index: 0;
    }

    .item:first-child:before {
      content: "";
      aspect-ratio: 1 / 1;
      width: 10px;
      background: #865e1b;
      position: absolute;
      top: 0;
      left: 60px;
      clip-path: polygon(0 0, 0% 100%, 100% 100%);
    }
  
    .item .inr {
      display: flex;
      align-items: flex-start;
    }
  
    .item .num {
      position: absolute;
      width: 60px;
    }
  
    .item .content {
      display: block;
      background: #fff5e8;
      padding: 20px 0 20px 0;
      gap: 25px;
      margin-top: 0;
      height: auto;
    }

    .item:first-child .content {
      margin-top: 10px;
    }

    .item .icon-box {
      display: flex;
      align-items: center;
      gap: 20px;
      padding: 0 0 20px 85px;
    }
  
    .item .icon-img {
      width: 70px;
      margin: 0 0 10px;
    }
  
    .item .title {
      font-weight: bold;
      line-height: 1.25;
      text-align: center;
      color: #ffa303;
    }
  
    .item .lead {
      font-size: 16px;
      font-weight: bold;
      line-height: 1.5;
      padding: 0 0 15px;
      margin: 0 0 15px;
      border-bottom: 1px dashed #5b5b5b;
      padding: 0 20px 15px;
    }
  
    .item .lists {
      display: grid;
      grid-template-columns: repeat(1,1fr);
      gap: 0 10px;
      line-height: 1.25;
      padding: 0 20px;
    }
  
    .item .lists._col1 {
      grid-template-columns: repeat(1,1fr);
    }
  
    .item .list {
      display: flex;
    }
  
    .item .list:before {
      content: "・";
    }
  
  }
}

.page-ss-post-mv {
  aspect-ratio: 485 / 140;
  width: 100%;
  background: url(../img/ss/post-mv.jpg) no-repeat center / cover;
  display: flex;
  align-items: center;
  justify-content: center;
  .title {
    padding: 5px 40px;
    background: #1d3c7a;
    color: #fff;
    font-size: 25px;
    font-weight: bold;
  }
}

.page-ss-post-lists {
  display: grid;
  grid-template-columns: repeat(2,1fr);
  gap: 20px;
  .thumbnail img {
    width: 100%;
    height: auto;
  }

  .list {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 2;
    background: #ececeb;
    gap: 0;
  }

  .list .content {
    padding: 10px 15px;
    background: #ececeb;
  }

  .list .title {
    font-size: 16px;
    line-height: 1.25;
    font-weight: bold;
    padding: 0 0 10px;
    margin: 0 0 10px;
    border-bottom: 1px dashed;
  }

  .list .tax-lists {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 14px;
  }

  .list .tax {
    background: #fff;
    padding: 5px 10px;
    border-radius: 5px;
    border: 1px solid #1d3c7a;
    line-height: 1.25;
    color: #1d3c7a;
    font-weight: bold;
  }
}

@media (max-width: 767px) {
  .page-ss-post-lists {
    grid-template-columns: repeat(1,1fr);
    gap: 20px;
  }
}


/* ページャー全体 */
.c_pager_num{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;            /* 数字同士の間隔 */
  margin:40px 0 0;
  font-family: inherit;
}

/* 数字（a/span 共通）を丸ボタンに */
.c_pager_num .page-numbers{
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:36px;
  height:36px;
  border-radius:50%;
  background:#163a7b;  /* 濃い青 */
  color:#fff;
  text-decoration:none;
  font-weight:700;
  line-height:1;
}

/* ホバー/フォーカス */
.c_pager_num a.page-numbers:hover,
.c_pager_num a.page-numbers:focus{
  filter:brightness(1.1);
  outline:none;
}

/* 現在ページ（色は同系で少し強めに） */
.c_pager_num .page-numbers.current{
  background:#1c4b9c;
}

/* 「…」のドットは非表示にしたい場合 */
.c_pager_num .page-numbers.dots{ display:none; }

/* 先頭/末尾（≪ ≫）はテキストのまま右側に配置 */
.c_pager_num .first,
.c_pager_num .last{
  width:auto;
  height:auto;
  border-radius:0;
  background:transparent;
  color:#163a7b;
  font-size:20px;
  font-weight:700;
  padding:0 4px;
}

/* 画像の例に合わせて < と >（prev/next）は非表示 */
.c_pager_num .prev,
.c_pager_num .next{ display:none; }

/* 数字と »» の間を少し広げる */
.c_pager_num .last{ margin-left:8px; }
