.home_page .key {
  position: relative;
  --height: 56vw;
  --min-height: 450px;
  --max-height: 900px;
  height: var(--height);
  min-height: var(--min-height);
  max-height: var(--max-height);
  font-size: 0.625em;
  margin: calc(var(--wrapper) - 20px) var(--px-key) 0;
  z-index: 1;
}
.home_page .key::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("../images/idx_mv.jpg") no-repeat center/cover;
}
.home_page .key::after {
  content: "";
  position: absolute;
  width: 100vw;
  height: 26.667%;
  top: 0;
  left: calc(50% - 50vw);
  background-color: #fff;
  z-index: -1;
}
.home_page .key .mv_slider:not(.slick-slider) {
  display: flex;
  overflow: hidden;
}
.home_page .key .mv_slider:not(.slick-slider) .item:not(:first-child) {
  display: none;
}
.home_page .key_text {
  position: relative;
  overflow: hidden;
  height: var(--height);
  min-height: var(--min-height);
  max-height: var(--max-height);
  display: flex;
  align-items: flex-end;
}
.home_page .key .catch {
  position: relative;
  width: 40%;
  max-width: 640px;
  background-color: #fff;
  border-top-left-radius: 4em;
  padding: 4.8em 6.8em 6.8em;
}
.home_page .key .catch::before {
  content: "";
  position: absolute;
  width: 6.4em;
  aspect-ratio: 64/68;
  top: -2.5em;
  left: 3.9em;
  background: url("../images/idx_catch_decor.png") no-repeat center/cover;
}
.home_page .key .catch h2,
.home_page .key .catch p {
  letter-spacing: 0.1em;
}
.home_page .key .catch h2 {
  font-size: 4.8em;
  font-weight: 700;
  color: var(--main-color);
  line-height: 1.4;
  margin-bottom: 0.2708em;
}
.home_page .key .catch p {
  font-size: max(13px, 2.4em);
  font-weight: 500;
  line-height: 1.75;
  padding-left: 2px;
  color: var(--clr1);
}
.home_page .key_anchor {
  position: absolute;
  left: 3em;
  bottom: -2.7em;
  display: flex;
  gap: 2px;
}
.home_page .key_anchor .item {
  --clr: #87b828;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 27.2em;
  min-height: 12em;
  z-index: 0;
}
.home_page .key_anchor .item::after {
  content: "";
  position: absolute;
  width: 100%;
  aspect-ratio: 272/27;
  bottom: 0;
  left: 0;
  --mask: url(../images/idx_key_anchor_shadow.png);
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  z-index: -1;
}
.home_page .key_anchor .item1::after {
  background-color: #647346;
}
.home_page .key_anchor .item1 .txt::before {
  background-image: -moz-linear-gradient(-45deg, rgb(135, 184, 40) 0%, rgb(255, 185, 34) 100%);
  background-image: -webkit-linear-gradient(-45deg, rgb(135, 184, 40) 0%, rgb(255, 185, 34) 100%);
  background-image: -ms-linear-gradient(-45deg, rgb(135, 184, 40) 0%, rgb(255, 185, 34) 100%);
}
.home_page .key_anchor .item2 {
  --clr: #1ca2d9;
}
.home_page .key_anchor .item2::after {
  background-color: #4b7789;
}
.home_page .key_anchor .item2 .txt::before {
  background-image: -moz-linear-gradient(-45deg, rgb(28, 162, 217) 0%, rgb(255, 185, 34) 100%);
  background-image: -webkit-linear-gradient(-45deg, rgb(28, 162, 217) 0%, rgb(255, 185, 34) 100%);
  background-image: -ms-linear-gradient(-45deg, rgb(28, 162, 217) 0%, rgb(255, 185, 34) 100%);
}
.home_page .key_anchor .item3 {
  --clr: #ea6ba3;
}
.home_page .key_anchor .item3::after {
  background-color: #7f4c63;
}
.home_page .key_anchor .item3 .txt::before {
  background-image: -moz-linear-gradient(-45deg, rgb(234, 107, 163) 0%, rgb(255, 185, 34) 100%);
  background-image: -webkit-linear-gradient(-45deg, rgb(234, 107, 163) 0%, rgb(255, 185, 34) 100%);
  background-image: -ms-linear-gradient(-45deg, rgb(234, 107, 163) 0%, rgb(255, 185, 34) 100%);
}
.home_page .key_anchor .txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 92%;
  max-width: 11.3636em;
  padding-bottom: 0.9545em;
  margin: 0 auto;
  height: 100%;
  position: relative;
  margin-bottom: 0;
  text-align: center;
  font-size: 2.2em;
  font-weight: 500;
  letter-spacing: 0.07em;
  line-height: 1;
  color: #fff;
  border-radius: 10px;
  background-color: var(--clr);
  z-index: 0;
}
.home_page .key_anchor .txt::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.4;
  z-index: -1;
  border-radius: inherit;
  transition: all 0.3s ease;
}
.home_page .key_anchor .txt::after {
  content: "";
  position: absolute;
  width: round(1em, 1px);
  aspect-ratio: 1/1;
  bottom: 0.3636em;
  left: calc(50% - 0.5em);
  background: url("../images/idx_key_ic_arrow.png") no-repeat center/cover;
}
.home_page .key_anchor .txt .en {
  display: block;
  font-size: 0.5em;
  letter-spacing: 0.1em;
  color: #e9e19a;
  text-transform: uppercase;
  margin-bottom: 1.0909em;
}
@media only screen and (min-width: 769px) {
  .home_page .key::before {
    border-radius: 2em 2em 0 2em;
  }
  .home_page .key_text {
    justify-content: flex-end;
  }
  .home_page .key_anchor .item:hover .txt::before {
    background-image: unset;
  }
}
@media only screen and (min-width: 1921px) {
  .home_page .key {
    --max-height: 32vw;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1560px) {
  .home_page .key {
    font-size: min(0.55vw, 8.75px);
  }
}
@media only screen and (max-width: 1560px) and (min-width: 769px) and (max-height: 800px) and (orientation: landscape) {
  .home_page .key {
    --max-height: calc(100vh - var(--wrapper) - 40px);
  }
  .home_page .key .catch {
    padding: 4.5em 5.5em;
  }
}
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .home_page .key {
    font-size: 4.25px;
  }
  .home_page .key .catch {
    width: 38%;
    padding: 4.5em 10px;
  }
}

.home_page .topic_path {
  display: none;
}
.home_page .wrap_h3 {
  text-align: center;
}
.home_page .wrap_h3 h3 {
  position: relative;
  font-family: var(--f-jp);
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1.4;
  color: var(--main-color);
}
.home_page .wrap_h3 h3::before {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  margin: 0 auto;
  background: url("../images/idx_h3_ic.png") no-repeat center/cover;
}
.home_page .wrap_h3 .h_en {
  font-family: var(--f-en);
  font-size: calc(var(--fs-base) + 2px);
  font-weight: 400;
  letter-spacing: 0.1em;
  line-height: 1.4;
  text-transform: uppercase;
  color: var(--clr3);
}
.home_page .wrap_h3.white .h_en,
.home_page .wrap_h3.white h3 {
  color: #fff;
}
.home_page .wrap_h3.white .h_en::before,
.home_page .wrap_h3.white h3::before {
  background-image: url("../images/idx_h3_ic_white.png");
}
.home_page .wrap_h3.st2 {
  position: relative;
}
.home_page .wrap_h3.st2 .h_en {
  line-height: 1;
  letter-spacing: 0.05em;
  color: rgba(234, 107, 163, 0.1);
}
.home_page .wrap_h3.st2 h3 {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
.home_page .wrap_h3.st2 h3::before {
  margin: 0;
}
.home_page .wrap_h3.st2 h3::after {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  margin: 0;
  background: url("../images/idx_h3_ic.png") no-repeat center/cover;
}
@media only screen and (min-width: 769px) {
  .home_page .wrap_h3 h3 {
    font-size: calc(var(--ttl_size) + 14px);
    margin-bottom: 0.2381em;
  }
  .home_page .wrap_h3 h3::before {
    width: round(0.5714em, 1px);
    margin-bottom: 10px;
  }
  .home_page .wrap_h3.st2 .h_en {
    font-size: clamp(80px, 10vw, 140px);
  }
  .home_page .wrap_h3.st2 h3 {
    top: 0.8333em;
    gap: 0.619em;
  }
  .home_page .wrap_h3.st2 h3::after {
    width: 0.5714em;
  }
}

section {
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}

.idx01 {
  position: relative;
  z-index: 0;
}
.idx01::before {
  content: "";
  position: absolute;
  width: 30em;
  aspect-ratio: 300/403;
  bottom: calc(100% - 20.7em);
  left: 0px;
  background: url("../images/idx_key_decor.png") no-repeat center/cover;
  z-index: -1;
}
.idx01 .wrap {
  position: relative;
  border: 2px solid var(--main-color);
  background-color: #fff;
  overflow: hidden;
  z-index: 0;
}
.idx01 .wrap::before {
  content: "";
  position: absolute;
  width: 92.4em;
  aspect-ratio: 924/454;
  top: -2px;
  left: -2px;
  background: url("../images/idx01_decor.png") no-repeat center/cover;
  z-index: -1;
}
.idx01 .wrap_h3 .h_en {
  font-size: var(--fs-base);
  color: var(--main-color);
}
.idx01 .wrap_h3 h3 {
  color: var(--clr1);
}
.idx01 .wrap_h3 h3::before {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 27 27	' %3E%3Cpath d='M26.197,5.088 L14.100,17.143 C13.966,17.231 13.801,17.282 13.642,17.300 C12.904,17.383 11.382,17.359 10.623,17.303 C10.033,17.259 9.661,16.961 9.607,16.351 C9.545,15.652 9.534,14.152 9.609,13.465 C9.640,13.180 9.810,12.926 9.917,12.667 L21.797,0.825 C21.905,0.725 22.070,0.651 22.213,0.628 C22.506,0.579 22.756,0.625 22.999,0.796 L26.169,3.956 C26.415,4.296 26.417,4.735 26.197,5.088 ZM11.579,13.772 L11.579,15.336 L13.149,15.336 L20.971,7.544 L20.971,7.422 L19.437,5.954 L11.579,13.772 ZM22.391,3.009 L20.879,4.561 L22.436,6.068 L23.948,4.516 L22.391,3.009 ZM11.728,6.496 C10.698,6.636 9.254,6.463 8.160,6.499 C7.020,6.537 4.452,6.620 3.639,7.453 C2.810,8.302 2.829,10.381 2.779,11.505 C2.659,14.198 2.576,17.350 2.777,20.029 C2.982,22.760 3.288,23.751 6.193,24.048 C9.030,24.338 12.499,24.232 15.363,24.107 C16.577,24.053 18.891,24.096 19.671,23.002 C20.332,22.073 20.410,19.760 20.446,18.620 C20.478,17.637 20.287,15.959 20.471,15.088 C20.685,14.075 22.292,14.106 22.414,15.244 C22.582,16.804 22.446,19.794 22.220,21.371 C21.609,25.645 19.131,25.915 15.363,26.070 C12.315,26.197 7.653,26.422 4.734,25.809 C1.051,25.037 0.933,22.215 0.806,19.049 C0.688,16.130 0.584,12.679 0.868,9.785 C1.326,5.123 3.852,4.700 7.996,4.556 C8.988,4.523 10.871,4.402 11.780,4.553 C12.829,4.729 12.825,6.348 11.728,6.496 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--clr3);
  background-image: unset;
}
.idx01 .btn-group .btn-news {
  width: 14.2em;
  min-width: 14.2em;
  margin: 0 auto;
}
.idx01 .btn-group .btn-news a {
  border-radius: 0;
  border: none;
  background-color: transparent;
  color: var(--clr1);
  padding: 0;
}
.idx01 .btn-group .btn-news a::before {
  border: 1px solid var(--main-color);
}
.idx01 .TabContainer {
  width: 100%;
  max-width: 750px;
}
.idx01 .TabContainer .TabPager > div {
  position: relative;
  max-width: 160px;
  min-height: 3em;
  border-radius: 999em;
  border: 1px solid inherit;
}
.idx01 .TabContainer .TabPager > div::after {
  content: "";
  position: absolute;
  aspect-ratio: 17/10;
  top: calc(100% - 1px);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: inherit;
  opacity: 0;
  visibility: hidden;
}
.idx01 .TabContainer .TabPager > div:nth-child(1) {
  background-color: var(--main-color);
}
.idx01 .TabContainer .TabPager > div:nth-child(2) {
  background-color: var(--clr2);
}
.idx01 .TabContainer .TabPager > div:nth-child(3) {
  background-color: var(--clr3);
}
.idx01 .TabContainer .TabPager > div .tt {
  color: #fff;
}
.idx01 .TabContainer .TabPager > div.active::after {
  opacity: 1;
  visibility: visible;
}
.idx01 .news {
  position: relative;
}
.idx01 .news ul li {
  border-bottom: 1px solid #e1e5e6;
  width: auto;
}
.idx01 .news ul li a {
  position: relative;
  display: inline-flex;
  text-decoration: none;
  transition: all 0.3s;
  letter-spacing: 0.1em;
  white-space: nowrap;
  max-width: 100%;
  width: 100%;
  color: var(--clr1);
}
.idx01 .news ul li a::after {
  content: "";
  position: absolute;
  width: 1.375em;
  aspect-ratio: 22/13;
  right: 1.0625em;
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.826 L18.924,7.283 L0.000,7.283 L0.000,5.695 L18.923,5.695 L14.210,1.154 L15.256,-0.010 L22.000,6.490 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #cee4a5;
}
.idx01 .news ul li a span {
  display: inline-block;
}
.idx01 .news ul li a:hover {
  opacity: 1;
}
.idx01 .news ul li a .date {
  flex-shrink: 0;
  width: 6.75em;
}
.idx01 .news ul li a .cate {
  position: relative;
  top: -2px;
  flex-shrink: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 7.1429em;
  height: 2.1429em;
  border-radius: 999em;
  font-size: calc(var(--fs-base) - 2px);
  color: #fff;
  letter-spacing: 0.1em;
}
.idx01 .news ul li a .cate.news {
  background-color: var(--clr2);
}
.idx01 .news ul li a .cate.column {
  background-color: var(--clr3);
}
.idx01 .news ul li a .title {
  position: relative;
  padding-right: 3em;
  text-overflow: ellipsis;
  overflow: hidden;
}
@media only screen and (min-width: 769px) {
  .idx01 {
    padding: clamp(80px, 10vw, 100px) 0 80px;
  }
  .idx01::before {
    font-size: min(0.55vw, 10px);
  }
  .idx01 .wrap {
    display: grid;
    grid-template-columns: 28% 66%;
    justify-content: space-between;
    align-items: flex-start;
    gap: 0;
    border-radius: 20px;
    padding: 58px 68px 74px;
    min-height: 28.125em;
  }
  .idx01 .wrap::before {
    font-size: 10px;
  }
  .idx01 .wrap_h3 {
    padding-top: 2.125em;
  }
  .idx01 .wrap_h3 h3 {
    font-size: calc(var(--ttl_size) + 2px);
    margin-bottom: 0.3667em;
  }
  .idx01 .wrap_h3 h3::before {
    width: round(0.9em, 1px);
    margin-bottom: 0.7333em;
  }
  .idx01 .btn-group {
    margin-top: auto;
    grid-row: 3/4;
  }
  .idx01 .btn-group .btn-news a {
    min-height: 2.7778em;
    padding-left: 0.3889em;
  }
  .idx01 .TabContainer {
    grid-row: 1/span 3;
    grid-column-start: 2;
    margin-left: auto;
  }
  .idx01 .TabContainer .TabPager {
    justify-content: flex-end;
    gap: 0.625em;
    margin-bottom: 1.625em;
  }
  .idx01 .TabContainer .TabPager > div {
    width: 25%;
  }
  .idx01 .TabContainer .TabPager > div::after {
    width: 17px;
    left: calc(50% - 5px);
  }
  .idx01 .TabContainer .TabPager > div:nth-child(1):hover {
    background-color: #129042;
  }
  .idx01 .TabContainer .TabPager > div:nth-child(2):hover {
    background-color: #5c8599;
  }
  .idx01 .TabContainer .TabPager > div:nth-child(3):hover {
    background-color: #f29090;
  }
  .idx01 .news ul li a {
    padding: 1.75em 1.25em 1.3125em;
  }
  .idx01 .news ul li a::after {
    top: 2.1875em;
  }
  .idx01 .news ul li a .title {
    max-width: calc(100% - 12.8125em);
    margin-left: 0.75em;
  }
  .idx01 .news ul li a:hover {
    background-color: rgba(225, 229, 230, 0.5);
  }
  .idx01 .btn-group .btn-news a:hover {
    color: var(--main-color);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1366px) {
  .idx01 .wrap {
    grid-template-columns: 32% 65%;
    margin-left: 80px;
    margin-right: 80px;
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .idx01 .wrap_h3 h3 {
    font-size: 24px;
  }
  .idx01 .wrap {
    margin-left: 50px;
    margin-right: 50px;
    padding-left: 20px;
    padding-right: 20px;
  }
}

.idx02 {
  background-color: #fafff1;
}
.idx02 .idx_box .box_ttl {
  max-width: 1280px;
  margin: 0 auto;
}
.idx02 .idx_box .ttl {
  position: relative;
}
.idx02 .idx_box .ttl::before {
  content: "";
  aspect-ratio: 30/31;
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 31' %3E%3Cpath d='M29.899,21.695 C29.744,26.812 26.375,30.028 21.258,30.096 C17.077,30.150 12.894,30.154 8.713,30.091 C3.497,30.014 0.147,26.644 0.040,21.434 C-0.004,19.297 0.032,17.159 0.032,15.021 C0.032,12.882 -0.010,10.743 0.040,8.607 C0.156,3.575 3.457,0.251 8.473,0.179 C12.743,0.118 17.015,0.123 21.285,0.176 C26.372,0.239 29.756,3.495 29.901,8.603 C30.025,12.963 30.031,17.335 29.899,21.695 ZM27.263,8.837 C27.194,5.144 24.951,2.969 21.256,2.926 C17.117,2.879 12.975,2.881 8.835,2.924 C4.955,2.965 2.811,5.137 2.783,9.021 C2.754,13.075 2.754,17.132 2.783,21.187 C2.812,25.103 4.883,27.202 8.806,27.299 C10.853,27.350 12.902,27.308 14.950,27.308 C14.950,27.302 14.950,27.296 14.950,27.290 C17.131,27.290 19.315,27.358 21.493,27.274 C25.037,27.136 27.203,24.959 27.265,21.405 C27.338,17.217 27.342,13.026 27.263,8.837 ZM23.010,8.873 C22.044,8.928 21.185,8.073 21.256,7.116 C21.333,6.095 21.918,5.490 22.956,5.438 C23.948,5.389 24.726,6.200 24.701,7.346 C24.607,8.226 24.038,8.811 23.010,8.873 ZM15.014,22.776 C10.729,22.812 7.289,19.400 7.267,15.091 C7.245,10.813 10.689,7.357 14.970,7.360 C19.219,7.363 22.718,10.881 22.681,15.114 C22.644,19.330 19.231,22.740 15.014,22.776 ZM14.977,10.112 C12.243,10.106 9.964,12.420 10.016,15.149 C10.067,17.842 12.317,20.024 15.018,19.999 C17.721,19.975 19.904,17.754 19.894,15.040 C19.883,12.336 17.670,10.118 14.977,10.112 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--main-color);
}
.idx02 .idx_box .ttl .h_en {
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1;
  color: var(--main-color);
  text-transform: capitalize;
}
.idx02 .idx_box .ttl h3 {
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: 0;
}
.idx02 .idx_box .btn-group .btn-ins {
  width: 23em;
}
.idx02 .idx_box .btn-group .btn-ins a {
  width: 100%;
  display: flex;
  align-items: center;
  position: relative;
  font-size: 1.8em;
  font-weight: 400;
  letter-spacing: 0.1em;
  color: var(--main-color);
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding: 9px;
}
.idx02 .idx_box .btn-group .btn-ins a::after {
  content: "";
  position: absolute;
  width: 1.2222em;
  aspect-ratio: 22/14;
  top: 0.1667em;
  bottom: 0;
  right: 0.3889em;
  margin: auto 0;
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 14' %3E%3Cpath d='M15.256,13.124 L14.210,11.960 L18.923,7.419 L0.000,7.419 L0.000,5.831 L18.924,5.831 L14.210,1.289 L15.256,0.125 L22.000,6.625 L15.256,13.124 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--main-color);
}
@media only screen and (min-width: 769px) {
  .idx02 {
    padding: 80px 0 63px;
  }
  .idx02 .idx_box .box_ttl {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    padding: 0 67px 33px;
  }
  .idx02 .idx_box .box_cont {
    padding: 0 15px;
  }
  .idx02 .idx_box .ttl {
    padding-left: 2.9375em;
  }
  .idx02 .idx_box .ttl::before {
    position: absolute;
    width: 1.875em;
    top: 0.5625em;
    left: 0px;
  }
  .idx02 .idx_box .ttl .h_en {
    font-size: calc(var(--ttl_size) + 14px);
    margin-bottom: 9px;
  }
  .idx02 .idx_box .ttl h3 {
    font-size: calc(var(--fs-base) + 8px);
  }
}

.idx03 .content {
  position: relative;
  max-width: 1490px;
  background-color: #fff;
  box-shadow: -7.071px -7.071px 40px 0px rgba(0, 0, 0, 0.15);
}
.idx03 .content::before {
  content: "";
  position: absolute;
  width: 19em;
  aspect-ratio: 1/1;
  background: url("../images/idx03_decor01.svg") no-repeat center/cover;
}
.idx03 .wrap {
  max-width: 1280px;
}
.idx03 .txt_en {
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
  color: rgba(220, 217, 136, 0.2);
}
.idx03 .idx_logo {
  display: table;
  width: 75%;
  max-width: 283px;
  margin: 0 auto;
}
.idx03 .idx_logo a:hover {
  opacity: 1;
}
.idx03 .idx_info dl {
  display: flex;
}
.idx03 .idx_info dl:not(:last-child) {
  border-bottom: 1px solid #e1e1e1;
}
.idx03 .idx_info dl:has(.tel_num) {
  align-items: baseline;
}
.idx03 .idx_info dl dt,
.idx03 .idx_info dl dd {
  line-height: 2.25;
  letter-spacing: 0.1em;
}
.idx03 .idx_info dl dt {
  text-align: center;
  width: var(--w);
}
.idx03 .idx_info dl dd {
  width: calc(100% - var(--w));
}
.idx03 .idx_info dl dd.tel_num {
  color: var(--main-color);
  letter-spacing: 0.1em;
  line-height: 1.5;
}
.idx03 .idx_map {
  overflow: hidden;
  border-radius: 10px;
}
.idx03 .idx_map iframe {
  height: 100%;
}
.idx03 .btn-group {
  --size-mg: 1em;
}
@media only screen and (min-width: 769px) {
  .idx03 {
    padding: clamp(80px, 10vw, 119px) 0 clamp(80px, 10vw, 90px);
    background-image: url(../images/idx03_bg.jpg);
    background-position: top center;
    background-size: 100% auto;
  }
  .idx03 .wrap_h3 {
    margin-bottom: clamp(60px, 8vw, 114px);
  }
  .idx03 .content {
    margin-left: auto;
    border-radius: 20px 80px 20px 20px;
    padding: 29px 60px 30px 0;
    display: flex;
    justify-content: space-between;
  }
  .idx03 .content::before {
    font-size: 10px;
    top: -10.6em;
    left: -9.4em;
  }
  .idx03 .wrap {
    width: 90%;
    padding: 38px 0;
  }
  .idx03 .idx_box {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
  }
  .idx03 .idx_box .box01, .idx03 .idx_box .box02 {
    width: 50%;
    max-width: 640px;
  }
  .idx03 .idx_box .box01 {
    padding-left: 90px;
    padding-top: 22px;
  }
  .idx03 .idx_box .box02 {
    padding: 0 45px;
  }
  .idx03 .txt_en {
    font-size: clamp(80px, 10vw, 120px);
    line-height: 0.64;
    white-space: nowrap;
    -webkit-writing-mode: vertical-rl;
    -moz-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    -webkit-text-orientation: mixed;
    -moz-text-orientation: mixed;
    -ms-text-orientation: mixed;
    text-orientation: mixed;
  }
  .idx03 .idx_logo {
    margin-bottom: 37px;
  }
  .idx03 .time_sheet table {
    font-size: min(0.635vw, 10px);
  }
  .idx03 .idx_map {
    height: 299px;
  }
  .idx03 .idx_info {
    margin-bottom: 4px;
  }
  .idx03 .idx_info dl {
    --w: 5.5em;
    padding: 0.9375em 0 1.0625em;
  }
  .idx03 .idx_info dl dd {
    padding: 0 10px 0 25px;
  }
  .idx03 .idx_info dl dd.tel_num {
    font-size: 1.5em;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1560px) {
  .idx03 .wrap {
    width: 95%;
  }
  .idx03 .content {
    margin: 0 5vw;
    padding-right: max(20px, 2.5vw);
  }
  .idx03 .content::before {
    font-size: min(0.525vw, 8.75px);
  }
  .idx03 .idx_box .box01 {
    padding-left: max(20px, 2.5vw);
  }
  .idx03 .idx_box .box02 {
    padding: 0 max(20px, 2.5vw);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1366px) {
  .idx03 .content {
    border-top-right-radius: 40px;
  }
  .idx03 .btn-group {
    --size-mg: 5px;
    padding: 0 20px;
  }
}
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .idx03 {
    background-size: auto 320px;
  }
  .idx03 .content {
    margin: 0 20px;
  }
  .idx03 .time_sheet table {
    font-size: 5px;
  }
  .idx03 .idx_info dl {
    font-size: 12px;
  }
  .idx03 .idx_info dl dt {
    --w: 6em;
  }
  .idx03 .idx_info dl dd {
    padding: 0 5px;
  }
  .idx03 .idx_map {
    height: 199px;
  }
  .idx03 .btn-group {
    font-size: 7.5px;
  }
}

.idx04 {
  background-image: url(../images/idx04_bg.jpg);
}
.idx04 .idx_flow {
  counter-reset: step;
  position: relative;
  display: flex;
  z-index: 0;
}
.idx04 .idx_flow .item {
  counter-increment: step;
  width: 30.3em;
}
.idx04 .idx_flow .item .ttl {
  width: 100%;
  aspect-ratio: 303/292;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  text-align: center;
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
  margin-bottom: 0.4em;
  padding-top: 2.8em;
}
.idx04 .idx_flow .item .ttl .num {
  position: relative;
  font-size: max(8px, 1em);
  letter-spacing: 0.1em;
  color: var(--clr3);
  text-transform: uppercase;
  margin-bottom: 0.5em;
}
.idx04 .idx_flow .item .ttl .num::after {
  content: counter(step, decimal-leading-zero);
  font-size: 1.8em;
  line-height: 1;
  letter-spacing: 0.1em;
  margin-left: 0.2222em;
}
.idx04 .idx_flow .item .ttl h4 {
  position: relative;
  font-size: 2.2em;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.idx04 .idx_flow .item .ttl h4::after {
  content: "";
  display: block;
  aspect-ratio: 133/150;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.idx04 .idx_flow .item .txt {
  font-size: var(--fs-base);
  letter-spacing: 0.08em;
  color: #fff;
  max-width: 15em;
  margin: 0 auto;
}
.idx04 .idx_flow .item1 .ttl {
  --mask: url(../images/idx04_item1_bg.png);
}
.idx04 .idx_flow .item1 .ttl h4::after {
  background-image: url(../images/idx04_item1.png);
}
.idx04 .idx_flow .item2 .ttl {
  --mask: url(../images/idx04_item2_bg.png);
}
.idx04 .idx_flow .item2 .ttl h4::after {
  background-image: url(../images/idx04_item2.png);
}
.idx04 .idx_flow .item3 .ttl {
  --mask: url(../images/idx04_item3_bg.png);
}
.idx04 .idx_flow .item3 .ttl h4::after {
  background-image: url(../images/idx04_item3.png);
}
.idx04 .idx_flow .item4 .ttl {
  --mask: url(../images/idx04_item4_bg.png);
}
.idx04 .idx_flow .item4 .ttl h4::after {
  background-image: url(../images/idx04_item4.png);
}
@media only screen and (min-width: 769px) {
  .idx04 {
    padding: 70px 0 89px;
  }
  .idx04 .wrap_h3 {
    margin-bottom: 43px;
  }
  .idx04 .idx_flow {
    font-size: min(0.65vw, 10px);
    justify-content: space-between;
    margin-bottom: 4.8em;
    width: 128em;
    margin-left: auto;
    margin-right: auto;
  }
  .idx04 .idx_flow::after {
    content: "";
    position: absolute;
    width: 143.8em;
    aspect-ratio: 1438/106;
    top: 8.9em;
    left: calc(50% - 71.9em);
    background: url("../images/idx04_line.png") no-repeat center/cover;
    z-index: -1;
  }
  .idx04 .idx_flow .item .ttl h4::after {
    width: 6.0455em;
    margin-top: 0.3636em;
  }
  .idx04 .idx_flow .item1 {
    margin-left: -2.1em;
  }
  .idx04 .idx_flow .item1 h4::after {
    position: relative;
    top: 0.2727em;
    right: -0.0909em;
  }
  .idx04 .idx_flow .item2 {
    margin-left: -3.3em;
  }
  .idx04 .idx_flow .item2 h4::after {
    position: relative;
    right: -0.5455em;
  }
  .idx04 .idx_flow .item3 {
    margin-left: -2.1em;
  }
  .idx04 .idx_flow .item3 h4::after {
    position: relative;
    top: 0.0455em;
    right: -0.5909em;
  }
  .idx04 .idx_flow .item4 h4::after {
    position: relative;
    right: 0.2273em;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .idx04 .idx_flow .item .txt {
    font-size: 12px;
  }
}

.idx05 {
  background-image: url(../images/idx05_bg.png);
  background-position: top center;
  background-size: 100% auto;
}
.idx05 .idx_list .item {
  --clr: var(--main-color);
  position: relative;
  overflow: hidden;
  max-width: 540px;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  transition: all 0.3s ease;
}
.idx05 .idx_list .item .ttl {
  flex-shrink: 0;
  min-height: 200px;
  position: relative;
}
.idx05 .idx_list .item .ttl picture {
  overflow: hidden;
}
.idx05 .idx_list .item .ttl picture img {
  min-height: 200px;
  object-fit: cover;
  transition: all 0.3s ease;
}
.idx05 .idx_list .item .ttl .wrap_h4 {
  position: absolute;
  inset: 0;
  top: 3px;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
  z-index: 1;
}
.idx05 .idx_list .item .ttl .wrap_h4 h4 {
  font-size: 3.6em;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #fff;
  margin-bottom: 0.3333em;
}
.idx05 .idx_list .item .ttl .wrap_h4 .h_en {
  display: block;
  font-size: 1.6em;
  font-weight: 400;
  color: #dcd988;
  text-transform: uppercase;
  margin-bottom: 0;
}
.idx05 .idx_list .item .txt {
  flex-grow: 1;
  display: flex;
  flex-direction: column;
  background-color: var(--clr);
}
.idx05 .idx_list .item .txt .desc {
  font-size: var(--fs-base);
  flex-grow: 1;
  color: #fff;
  letter-spacing: 0.065em;
  margin-bottom: 1.625em;
}
.idx05 .idx_list .item .txt .btn-link {
  font-size: 1em;
  flex-shrink: 0;
  width: fit-content;
  margin-left: auto;
}
.idx05 .idx_list .item .txt .btn-link > span {
  display: flex;
  align-items: center;
  text-align: left;
  position: relative;
  min-height: 2.7778em;
  font-size: 1.8em;
  line-height: 1.4;
  font-weight: 500;
  color: #fff;
  letter-spacing: 0.1em;
  padding-right: 3.8333em;
}
.idx05 .idx_list .item .txt .btn-link > span::before, .idx05 .idx_list .item .txt .btn-link > span::after {
  content: "";
  position: absolute;
  width: round(2.7778em, 1px);
  height: round(2.7778em, 1px);
  border-radius: 50%;
  transition: all 0.3s ease;
  top: 0;
  bottom: 0;
  right: 0;
}
.idx05 .idx_list .item .txt .btn-link > span::before {
  background-color: #fff;
}
.idx05 .idx_list .item .txt .btn-link > span::after {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.825 L18.923,7.284 L-0.000,7.284 L-0.000,5.696 L18.924,5.696 L14.210,1.153 L15.256,-0.010 L21.1000,6.489 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  -webkit-mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--clr);
}
.idx05 .idx_list .item .txt .btn-link > span::before, .idx05 .idx_list .item .txt .btn-link > span::after {
  margin: auto 0;
}
.idx05 .idx_list .item2 {
  --clr: var(--clr2);
}
.idx05 .idx_list .item3 {
  --clr: var(--clr3);
}
@media only screen and (min-width: 769px) {
  .idx05 {
    padding: clamp(80px, 10vw, 150px) 0 clamp(80px, 10vw, 98px);
  }
  .idx05 .wrap_h3 {
    margin-bottom: 46px;
  }
  .idx05 .idx_list {
    font-size: min(0.78vw, 10px);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2.2em;
  }
  .idx05 .idx_list .txt {
    padding: 2.7em 7em 3.3em;
  }
  .idx05 .idx_list .txt .btn-link {
    margin-right: -3.4em;
  }
  .idx05 .idx_list .item:hover {
    --clr: #129042;
  }
  .idx05 .idx_list .item:hover picture img {
    transform: scale(1.2);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1366px) {
  .idx05 .idx_list .item .txt {
    padding: 2.5em 2.5em 3em;
  }
  .idx05 .idx_list .item .txt .btn-link {
    margin-right: 0;
  }
}

.idx06 {
  background: url(../images/idx06_bg.jpg) no-repeat top center/100% auto #faf8d0;
}
.idx06 .idx_box .box_img {
  flex-shrink: 0;
}
.idx06 .idx_box .box_img picture img {
  border-radius: 10px;
}
.idx06 .idx_box.st1 {
  align-items: center;
}
.idx06 .idx_box.st1 .box_cont > p {
  font-size: calc(var(--fs-base) + 2px);
  line-height: 2.3333333333;
  letter-spacing: 0.1em;
}
.idx06 .TabContainer {
  position: relative;
  z-index: 0;
}
.idx06 .TabContainer::before {
  content: "";
  position: absolute;
  width: 21.2em;
  aspect-ratio: 212/172;
  top: calc(100% - 5.3em);
  background: url("../images/idx06_decor.png") no-repeat center/cover;
}
.idx06 .TabContainer::after {
  content: "";
  position: absolute;
  max-width: 1440px;
  height: 100%;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  margin: auto;
  border-radius: 20px;
  background-color: #fff;
  z-index: -1;
}
.idx06 .TabContainer .TabPager > div {
  max-width: 220px;
  background-color: #dbebbb;
  border-radius: 10px;
}
.idx06 .TabContainer .TabPager > div::after {
  content: "";
  position: absolute;
  aspect-ratio: 28/16;
  top: calc(100% - 1px);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: inherit;
  opacity: 0;
  visibility: hidden;
}
.idx06 .TabContainer .TabPager > div .tt {
  font-weight: 500;
  line-height: 1.6666666667;
  letter-spacing: 0.1em;
  transition: all 0.3s ease;
}
.idx06 .TabContainer .TabPager > div.active {
  background-color: var(--main-color);
}
.idx06 .TabContainer .TabPager > div.active::after {
  opacity: 1;
  visibility: visible;
}
.idx06 .TabContainer .TabPager > div.active .tt {
  color: #fff;
}
@media only screen and (min-width: 769px) {
  .idx06 {
    padding: clamp(80px, 10vw, 91px) 0 clamp(80px, 10vw, 100px);
  }
  .idx06 .wrap_h3 {
    margin-bottom: 49px;
  }
  .idx06 .idx_box.st1 {
    margin-bottom: 67px;
  }
  .idx06 .idx_box.st1 .box_cont .btn-group {
    margin-top: 40px;
  }
  .idx06 .idx_box.st2 .box_cont .btn-group {
    margin-top: 37px;
  }
  .idx06 .TabContainer {
    padding: 80px 82px 90px;
  }
  .idx06 .TabContainer::before {
    font-size: 10px;
    right: calc(100% - 6.2em);
  }
  .idx06 .TabContainer::after {
    width: calc(100vw - 100px);
  }
  .idx06 .TabContainer .TabPager {
    gap: 4px;
    margin-bottom: 51px;
  }
  .idx06 .TabContainer .TabPager > div {
    width: calc(20% - 2px);
    min-height: 100px;
  }
  .idx06 .TabContainer .TabPager > div::after {
    width: 28px;
    left: calc(50% - 14px);
  }
  .idx06 .TabContainer .TabPager > div .tt {
    font-size: calc(var(--fs-base) + 2px);
  }
  .idx06 .TabContainer .TabPager > div:hover {
    background-color: #129042;
  }
  .idx06 .TabContainer .TabPager > div:hover .tt {
    color: #fff;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1560px) {
  .idx06 .TabContainer::before {
    font-size: 8.75px;
    right: calc(100% - 10em);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1440px) {
  .idx06 .idx_box.st1 {
    padding: 0 60px;
  }
  .idx06 .TabContainer::before {
    right: calc(100% - 22em);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .idx06 .idx_box.st1 {
    align-items: flex-start;
  }
  .idx06 .TabContainer {
    padding-left: 60px;
    padding-right: 60px;
  }
}
@media only screen and (min-width: 993px) {
  .idx06 .idx_box {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
  }
  .idx06 .idx_box.st1 {
    padding-left: 64px;
  }
  .idx06 .idx_box.st1 .box_img {
    width: 55%;
    max-width: 640px;
  }
  .idx06 .idx_box.st1 .box_cont {
    width: 40%;
    max-width: 476px;
    padding-bottom: 14px;
  }
  .idx06 .idx_box.st2 .box_img, .idx06 .idx_box.st2 .box_cont {
    width: 48%;
    max-width: 525px;
  }
  .idx06 .idx_box.st2 .box_img {
    padding-top: 13px;
  }
}
@media only screen and (max-width: 992px) {
  .idx06 .idx_box .box_img {
    margin-bottom: 25px;
  }
  .idx06 .idx_box .box_img img {
    margin: 0 auto;
  }
  .idx06 .idx_box .btn-group .btn {
    margin-left: auto;
    margin-right: auto;
  }
}

.idx07 {
  background-image: url(../images/idx07_bg.jpg);
  background-position: top center;
}
.idx07 .TabContainer .TabPager {
  position: relative;
  z-index: 5;
}
.idx07 .TabContainer .TabPager > div {
  width: 50%;
  max-width: 640px;
  min-height: 5.625em;
  background-color: #c0d893;
}
.idx07 .TabContainer .TabPager > div:first-child {
  border-top-left-radius: 10px;
}
.idx07 .TabContainer .TabPager > div:last-child {
  border-top-right-radius: 10px;
}
.idx07 .TabContainer .TabPager > div::after {
  content: "";
  position: absolute;
  aspect-ratio: 28/16;
  top: calc(100% - 1px);
  clip-path: polygon(50% 100%, 0 0, 100% 0);
  background-color: #f29090;
  opacity: 0;
  visibility: hidden;
}
.idx07 .TabContainer .TabPager > div .tt {
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.05em;
  color: #fff;
}
.idx07 .TabContainer .TabPager > div .tt .jp {
  position: relative;
}
.idx07 .TabContainer .TabPager > div .tt .jp::after {
  content: "";
  position: absolute;
  background-color: currentColor;
}
.idx07 .TabContainer .TabPager > div .tt .en {
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.idx07 .TabContainer .TabPager > div.active {
  background: url(../images/idx07_tab_bg.jpg) no-repeat center/cover;
}
.idx07 .TabContainer .TabPager > div.active::after {
  opacity: 1;
  visibility: visible;
}
.idx07 .TabContainer .TabContent {
  overflow: visible;
}
.idx07 .TabContainer .TabContent .content > div {
  background-color: #fff;
  border-radius: 0 0 10px 10px;
  box-shadow: -7.071px -7.071px 40px 0px rgba(0, 0, 0, 0.05);
}
.idx07 .idx_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: var(--gap);
}
.idx07 .idx_list .item {
  max-width: 360px;
  min-height: 9em;
  margin-bottom: 0;
}
.idx07 .idx_list .item.w-50 {
  width: calc((100% - var(--gap)) / 2);
  max-width: 560px;
}
.idx07 .idx_list .item a {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  background-color: #ffeff6;
  text-decoration: none;
  color: var(--clr1);
  font-size: 1.8em;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: 0;
}
.idx07 .idx_list .item a::before, .idx07 .idx_list .item a:after {
  content: "";
}
.idx07 .idx_list .item a::before {
  width: 2.7778em;
  aspect-ratio: 50/51;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.idx07 .idx_list .item a::after {
  width: round(1.3333em, 1px);
  aspect-ratio: 1/1;
  background: url(../images/idx07_ic_arrow01.png) no-repeat center/cover;
}
.idx07 .idx_list .item1 a::before {
  background-image: url(../images/idx07_item1.png);
}
.idx07 .idx_list .item2 a::before {
  background-image: url(../images/idx07_item2.png);
}
.idx07 .idx_list .item3 a::before {
  background-image: url(../images/idx07_item3.png);
}
.idx07 .idx_list .item4 a::before {
  background-image: url(../images/idx07_item4.png);
}
.idx07 .idx_list .item5 a::before {
  background-image: url(../images/idx07_item5.png);
}
.idx07 .idx_list .item6 a::before {
  background-image: url(../images/idx07_item6.png);
}
.idx07 .idx_list .item7 a::before {
  background-image: url(../images/idx07_item7.png);
}
.idx07 .idx_list .item8 a::before {
  background-image: url(../images/idx07_item8.png);
}
.idx07 .idx_list .item9 a::before {
  background-image: url(../images/idx07_item9.png);
}
.idx07 .idx_list .item10 a::before {
  background-image: url(../images/idx07_item10.png);
}
.idx07 .idx_list .item11 a::before {
  background-image: url(../images/idx07_item11.png);
}
.idx07 .idx_list .item12 a::before {
  background-image: url(../images/idx07_item12.png);
}
.idx07 .idx_list .item13 a::before {
  background-image: url(../images/idx07_item13.png);
}
.idx07 .idx_list .item14 a::before {
  background-image: url(../images/idx07_item14.png);
}
.idx07 .idx_list .item15 a::before {
  background-image: url(../images/idx07_item15.png);
}
.idx07 .idx_list .item16 a::before {
  background-image: url(../images/idx07_item16.png);
}
@media only screen and (min-width: 769px) {
  .idx07 {
    padding: 71px 0 clamp(80px, 10vw, 100px);
  }
  .idx07 .wrap_h3 {
    margin-bottom: 48px;
  }
  .idx07 .TabContainer .TabPager > div::after {
    width: 28px;
    left: calc(50% - 14px);
  }
  .idx07 .TabContainer .TabPager > div .tt {
    font-size: 30px;
  }
  .idx07 .TabContainer .TabPager > div .tt .jp {
    margin-right: 0.3667em;
    padding-right: 0.5333em;
  }
  .idx07 .TabContainer .TabPager > div .tt .jp::after {
    width: 1px;
    height: 1.7333em;
    rotate: 45deg;
    top: calc(50% - 0.8333em);
    right: 0;
  }
  .idx07 .TabContainer .TabPager > div .tt .en {
    font-size: 0.5333em;
  }
  .idx07 .TabContainer .TabPager > div:hover {
    background-color: var(--clr3);
  }
  .idx07 .TabContainer .TabContent .content > div {
    padding: 60px 84px 79px;
  }
  .idx07 .idx_list {
    font-size: min(0.7vw, 10px);
    --gap: 1.6em;
  }
  .idx07 .idx_list .item {
    width: calc((100% - var(--gap) * 2) / 3);
  }
  .idx07 .idx_list .item a {
    padding: 0.5556em 2.4444em 0.5556em 4.8889em;
    border-radius: 999em;
  }
  .idx07 .idx_list .item a::before, .idx07 .idx_list .item a::after {
    position: absolute;
  }
  .idx07 .idx_list .item a::before {
    top: calc(50% - 1.3889em);
    left: 1.4444em;
  }
  .idx07 .idx_list .item a::after {
    top: calc(50% - 0.6667em);
    right: 0.8889em;
  }
  .idx07 .idx_list .item a:hover {
    opacity: 1;
    background-color: #ea6ba3;
    color: #fff;
  }
  .idx07 .idx_list .item a:hover::before {
    filter: brightness(0) invert(1);
  }
}
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .idx07 .TabContainer .TabPager > div .tt {
    font-size: 24px;
  }
  .idx07 .TabContainer .TabContent .content > div {
    padding: 60px;
  }
  .idx07 .idx_list {
    font-size: 7.5px;
  }
  .idx07 .idx_list .item {
    width: calc((100% - var(--gap)) / 2);
  }
}

.idx08 .swiper {
  position: relative;
}
.idx08 .swiper-wrapper {
  display: flex;
}
.idx08 .swiper-wrapper .item {
  position: relative;
  width: var(--size-item);
  margin: 0 min(2.5vw, 40px);
  z-index: 0;
}
.idx08 .swiper-wrapper .item::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  background: linear-gradient(0, rgb(255, 255, 255) 20%, rgb(255, 255, 255) 60%);
  z-index: -1;
}
.idx08 .swiper-wrapper .item picture img {
  border-radius: 10px;
}
.idx08 .swiper-wrapper .item .ttl {
  position: relative;
  font-weight: 500;
  letter-spacing: 0;
  line-height: 1.4;
  text-align: center;
}
.idx08 .swiper-wrapper .item .ttl::before, .idx08 .swiper-wrapper .item .ttl::after {
  content: "";
  display: block;
  margin: 0 auto;
  background-color: #129042;
}
.idx08 .swiper-wrapper .item .ttl::before {
  aspect-ratio: 1/1;
  --mask: url("../images/ic_plus.svg");
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  margin-bottom: 0.2667em;
}
.idx08 .swiper-wrapper .item .ttl::after {
  width: 3em;
  height: 2px;
  margin-top: 0.4667em;
}
.idx08 .swiper-wrapper .item .desc {
  text-align: center;
}
.idx08 .swiper-navigation {
  position: absolute;
  inset: 0;
  width: var(--size-item);
  height: calc(var(--size-item) * 0.6);
  margin: 0 auto;
}
.idx08 .swiper-btn {
  position: absolute;
  width: 8em;
  aspect-ratio: 1/1;
  border-radius: 50%;
  border: 1px solid var(--main-color);
  background-color: #fff;
  top: calc(50% - 4em);
  z-index: 1;
  cursor: pointer;
}
.idx08 .swiper-btn::before {
  content: "";
  position: absolute;
  width: 2.2em;
  aspect-ratio: 22/13;
  top: calc(50% - 0.6em);
  left: calc(50% - 1.1em);
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.825 L18.922,7.284 L0.000,7.284 L0.000,5.694 L18.923,5.694 L14.210,1.153 L15.256,-0.011 L22.000,6.489 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--main-color);
}
.idx08 .swiper-btn-prev {
  left: -4em;
}
.idx08 .swiper-btn-prev::before {
  rotate: 180deg;
}
.idx08 .swiper-btn-next {
  right: -4em;
}
.idx08 .swiper-slide-prev.item::before {
  z-index: 1;
  opacity: 1;
  visibility: visible;
  transform-origin: left center;
  background: linear-gradient(-90deg, rgba(255, 255, 255, 0.5) 20%, rgb(255, 255, 255) 60%);
}
.idx08 .swiper-slide-next.item::before {
  z-index: 1;
  opacity: 1;
  visibility: visible;
  transform-origin: right center;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0.5) 20%, rgb(255, 255, 255) 60%);
}
@media only screen and (min-width: 769px) {
  .idx08 {
    padding: 82px 0 0;
  }
  .idx08 .wrap_h3 {
    margin-bottom: 54px;
  }
  .idx08 .swiper {
    --size-item: min(42vw, 800px);
  }
  .idx08 .swiper-wrapper .item .txt {
    padding: 36px 12.5% 89px;
  }
  .idx08 .swiper-wrapper .item .ttl {
    font-size: calc(var(--ttl_size) + 2px);
    margin-bottom: 0.5333em;
  }
  .idx08 .swiper-wrapper .item .ttl::before {
    width: 0.8667em;
  }
  .idx08 .swiper-wrapper .item .desc {
    margin-bottom: 37px;
  }
  .idx08 .swiper-btn {
    font-size: min(0.65vw, 10px);
  }
  .idx08 .swiper-btn:hover {
    background-color: var(--main-color);
  }
  .idx08 .swiper-btn:hover::before {
    background-color: #fff;
  }
}
@media only screen and (min-width: 1921px) {
  .idx08 {
    max-width: 1920px;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1440px) {
  .idx08 .swiper-wrapper .item .txt {
    padding-left: clamp(20px, 2.5vw, 40px);
    padding-right: clamp(20px, 2.5vw, 40px);
  }
}

.idx09 {
  background: url("../images/idx09_bg.png") no-repeat top center/100% auto #fffef2;
}
.idx09 .wrap_h3 {
  position: relative;
  display: table;
  margin: 0 auto;
}
.idx09 .wrap_h3::before, .idx09 .wrap_h3::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  z-index: 2;
}
.idx09 .wrap_h3::before {
  width: 12.3em;
  aspect-ratio: 246/258;
  background-image: url(../images/idx09_decor1.png);
}
.idx09 .wrap_h3::after {
  width: 12.6em;
  aspect-ratio: 252/330;
  background-image: url(../images/idx09_decor2.png);
}
.idx09 .idx_list {
  display: grid;
}
.idx09 .idx_list .item {
  --border-clr-sm: #f4d1c3;
  --item-clr: #eda2b6;
  max-width: 40em;
  position: relative;
  background-color: #fff;
  border: 1px solid var(--border-clr-sm);
  border-radius: 25em;
}
.idx09 .idx_list .item::before {
  content: "";
  width: calc(100% + 2px);
  aspect-ratio: 400/58;
  top: -1px;
  left: -1px;
  position: absolute;
  --mask: url("../images/idx09_item_decor.png");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: var(--item-clr);
}
.idx09 .idx_list .item .ttl {
  position: relative;
  font-weight: 700;
  letter-spacing: 0;
  text-align: center;
}
.idx09 .idx_list .item .ttl::before {
  content: "";
  display: block;
  aspect-ratio: 1/1;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.idx09 .idx_list .item ul {
  background-color: #f8f8f8;
}
.idx09 .idx_list .item ul li {
  position: relative;
  font-weight: 500;
  letter-spacing: 0;
  line-height: var(--lh-base);
  padding-left: 2.4375em;
}
.idx09 .idx_list .item ul li:not(:last-child) {
  margin-bottom: 0.5625em;
}
.idx09 .idx_list .item ul li::before, .idx09 .idx_list .item ul li::after {
  content: "";
  position: absolute;
  width: round(1.625em, 1px);
  aspect-ratio: 1/1;
  top: 0.3125em;
  left: 0em;
}
.idx09 .idx_list .item ul li::before {
  border-radius: 50%;
  background-color: var(--item-clr);
}
.idx09 .idx_list .item ul li::after {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 12' %3E%3Cpath d='M4.900,8.947 C5.197,8.568 5.475,8.193 5.773,7.834 C6.911,6.464 8.153,5.189 9.452,3.968 C10.746,2.751 12.093,1.599 13.566,0.596 C13.584,0.584 13.603,0.572 13.621,0.559 C13.704,0.498 13.793,0.445 13.878,0.545 C13.964,0.644 13.892,0.721 13.822,0.794 C11.950,2.744 10.110,4.721 8.389,6.802 C7.196,8.244 6.059,9.728 5.085,11.326 C4.983,11.492 4.868,11.492 4.768,11.322 C4.341,10.601 3.925,9.873 3.492,9.156 C3.107,8.518 2.667,7.919 2.087,7.435 C1.794,7.189 1.473,6.988 1.116,6.847 C1.031,6.813 0.945,6.780 0.956,6.667 C0.968,6.553 1.062,6.540 1.150,6.522 C1.916,6.356 2.578,6.569 3.166,7.057 C3.621,7.435 3.990,7.890 4.371,8.335 C4.545,8.539 4.722,8.740 4.900,8.947 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 0.875em 0.75em;
  -webkit-mask-size: 0.875em 0.75em;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
}
.idx09 .idx_list .item .ic-arr {
  position: relative;
  width: 5em;
  height: 5em;
  margin: 0 auto;
}
.idx09 .idx_list .item .ic-arr::before, .idx09 .idx_list .item .ic-arr::after {
  content: "";
  position: absolute;
  width: round(100%, 1px);
  height: round(100%, 1px);
  border-radius: 50%;
  transition: all 0.3s ease;
  top: 0;
  bottom: 0;
}
.idx09 .idx_list .item .ic-arr::before {
  background-color: var(--item-clr);
}
.idx09 .idx_list .item .ic-arr::after {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.825 L18.923,7.284 L-0.000,7.284 L-0.000,5.696 L18.924,5.696 L14.210,1.153 L15.256,-0.010 L21.1000,6.489 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  -webkit-mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
}
.idx09 .idx_list .item .ic-arr::before, .idx09 .idx_list .item .ic-arr::after {
  margin: auto 0;
}
.idx09 .idx_list .item1 .ttl::before {
  background-image: url(../images/idx09_item1.png);
}
.idx09 .idx_list .item2 .ttl::before {
  background-image: url(../images/idx09_item2.png);
}
.idx09 .idx_list .item3 .ttl::before {
  background-image: url(../images/idx09_item3.png);
}
.idx09 .idx_list .item4 .ttl::before {
  background-image: url(../images/idx09_item4.png);
}
.idx09 .idx_list .item5 .ttl::before {
  background-image: url(../images/idx09_item5.png);
}
.idx09 .idx_list .item6 .ttl::before {
  background-image: url(../images/idx09_item6.png);
}
.idx09 .idx_list .item2 {
  --border-clr-sm: #cedeb1;
  --item-clr: var(--main-color);
}
.idx09 .idx_list .item3 {
  --border-clr-sm: #cde6f0;
  --item-clr: var(--clr2);
}
.idx09 .idx_list .item4 {
  --border-clr-sm: #bae2ef;
  --item-clr: #5c8599;
}
.idx09 .idx_list .item5 {
  --border-clr-sm: #dfd6c1;
  --item-clr: #edb83b;
}
.idx09 .idx_list .item6 {
  --border-clr-sm: #c4b8b5;
  --item-clr: #a2918d;
}
@media only screen and (min-width: 769px) {
  .idx09 {
    padding: clamp(60px, 7.5vw, 100px) 0 clamp(60px, 7.5vw, 98px);
  }
  .idx09 .wrap_h3 {
    margin-bottom: 42px;
  }
  .idx09 .wrap_h3::before, .idx09 .wrap_h3::after {
    font-size: min(0.715vw, 10px);
  }
  .idx09 .wrap_h3::before {
    bottom: 100%;
    left: -18.9em;
  }
  .idx09 .wrap_h3::after {
    top: -1.8em;
    left: calc(100% + 10.6em);
  }
  .idx09 .idx_list {
    grid-template-columns: repeat(3, 1fr);
    font-size: 10px;
    gap: 3.5em 4em;
  }
  .idx09 .idx_list .item {
    padding: 5.8em 5.9em 3.8em;
    min-height: 62em;
  }
  .idx09 .idx_list .item .ttl {
    font-size: 2.6em;
    margin-bottom: 0.8462em;
  }
  .idx09 .idx_list .item .ttl::before {
    width: 8.4615em;
    margin-bottom: 0.7692em;
  }
  .idx09 .idx_list .item ul {
    padding: 2em 3em 1.9em;
    margin-bottom: 5.1em;
    border-radius: 1em;
  }
  .idx09 .idx_list .item ul li {
    font-size: 1.6em;
  }
  .idx09 .idx_list .item:hover {
    background-color: var(--border-clr-sm);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1440px) {
  .idx09 .idx_list {
    font-size: clamp(7.75px, 0.75vw, 9px);
    padding: 0 60px;
    gap: 3em 2em;
  }
  .idx09 .idx_list .item {
    padding-left: 3.5em;
    padding-right: 3.5em;
  }
}
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .idx09 {
    background-size: auto 250px;
  }
  .idx09 .idx_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 3em;
  }
}

.idx10 {
  position: relative;
  background-image: url(../images/idx10_bg.jpg);
}
.idx10::before, .idx10::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.idx10::before {
  width: 22.3em;
  aspect-ratio: 223/243;
  top: 5.5em;
  right: 12.3em;
  background-image: url(../images/idx10_decor1.png);
}
.idx10::after {
  width: 13.6em;
  aspect-ratio: 1/1;
  bottom: -2.7em;
  right: 3.5em;
  background-image: url(../images/idx10_decor2.png);
}
.idx10 .desc p {
  line-height: 2.3333333333;
  letter-spacing: 0.1em;
}
.idx10 .box_info {
  position: relative;
  grid-row: 1/span 4;
  grid-column-start: 1;
  max-width: 702px;
  height: fit-content;
}
.idx10 picture img {
  mask-position: center center;
  mask-size: 100% 100%;
  mask-repeat: no-repeat;
  mask-image: url(../images/idx10_doctor_mask.png);
  -webkit-mask-image: url(../images/idx10_doctor_mask.png);
}
.idx10 .doctor_name {
  position: absolute;
  width: 31.6em;
  aspect-ratio: 316/281;
  background: url("../images/idx10_doctor_name.png") no-repeat center/cover;
}
.idx10 .doctor_name .txt {
  position: relative;
  width: 51%;
  max-width: 16em;
  margin-top: 3.6em;
  margin-left: 2.5em;
  text-align: center;
  color: #fff;
}
.idx10 .doctor_name .txt::before {
  content: "";
  display: block;
  margin: 0 auto;
  width: 2em;
  aspect-ratio: 1/1;
  --mask: url("../images/ic_plus.svg");
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: currentColor;
  margin-bottom: 0.8em;
}
.idx10 .doctor_name .txt .pos {
  font-size: 1.8em;
  line-height: 1.7777777778;
  letter-spacing: 0.1em;
  border-bottom: 1px solid currentColor;
  padding-bottom: 0.7222em;
  margin-bottom: 0.3333em;
}
.idx10 .doctor_name .txt .name {
  font-size: 3.2em;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
.idx10 .doctor_name .txt .name .jp {
  display: block;
  margin-bottom: -0.2813em;
}
.idx10 .doctor_name .txt .name .en {
  font-size: 0.4375em;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.idx10 .btn-group {
  font-size: 0.625em;
}
.idx10 .btn-group .btn2 {
  width: fit-content;
  margin-left: auto;
}
.idx10 .btn-group .btn2:not(:last-child) {
  margin-bottom: 10px;
}
.idx10 .btn-group .btn2 a {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 2.7778em;
  font-size: 1.8em;
  letter-spacing: 0.1em;
  font-weight: 500;
  text-decoration: none;
  color: var(--clr1);
  padding-right: 3.8889em;
  transition: all 0.3s ease;
}
.idx10 .btn-group .btn2 a::before, .idx10 .btn-group .btn2 a::after {
  content: "";
  position: absolute;
  width: round(2.7778em, 1px);
  height: round(2.7778em, 1px);
  border-radius: 50%;
  transition: all 0.3s ease;
  top: 0;
  bottom: 0;
  right: 0;
}
.idx10 .btn-group .btn2 a::before {
  background-color: #87b828;
}
.idx10 .btn-group .btn2 a::after {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.825 L18.923,7.284 L-0.000,7.284 L-0.000,5.696 L18.924,5.696 L14.210,1.153 L15.256,-0.010 L21.1000,6.489 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  -webkit-mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
}
.idx10 .btn-group .btn2 a::before, .idx10 .btn-group .btn2 a::after {
  margin: auto 0;
}
.idx10 .btn-group .btn2 a::before {
  border: 1px solid var(--main-color);
}
@media only screen and (min-width: 769px) {
  .idx10 {
    padding: 86px 0 clamp(80px, 10vw, 107px);
  }
  .idx10::before, .idx10::after {
    font-size: min(0.6vw, 10px);
  }
  .idx10 .wrap_h3 {
    margin-bottom: 40px;
  }
  .idx10 .desc {
    margin-bottom: 31px;
  }
  .idx10 .wrap {
    margin-left: -4.85%;
  }
  .idx10 .doctor_name {
    font-size: min(0.68vw, 10px);
    left: 4.8em;
    bottom: -5.5em;
  }
  .idx10 .btn-group {
    margin-right: 55px;
  }
  .idx10 .btn-group .btn2 a:hover {
    color: var(--main-color);
  }
  .idx10 .btn-group .btn2 a:hover::before {
    background-color: #fff;
  }
  .idx10 .btn-group .btn2 a:hover::after {
    background-color: var(--main-color);
  }
}
@media only screen and (min-width: 993px) {
  .idx10 .wrap_h3 {
    display: flex;
    align-items: flex-end;
    padding-top: 31px;
  }
  .idx10 .wrap_h3 h3 {
    margin-bottom: 0;
    margin-right: 22px;
  }
  .idx10 .wrap_h3 h3::before {
    position: absolute;
    margin-bottom: 0;
    top: 23px;
    left: -51px;
  }
  .idx10 .wrap_h3 .h_en {
    margin-bottom: 3px;
  }
  .idx10 .wrap {
    display: grid;
    justify-content: space-between;
    grid-template-columns: 53% 41%;
  }
  .idx10 .desc {
    max-width: 510px;
  }
}
@media only screen and (min-width: 769px) and (max-width: 1440px) {
  .idx10 .wrap {
    margin-left: 0;
    padding: 0 60px;
  }
}
@media only screen and (max-width: 992px) {
  .idx10 picture {
    max-width: 500px;
    margin: 0 auto;
  }
  .idx10 .box_info {
    padding-bottom: 4em;
    margin-bottom: 20px;
  }
  .idx10 .doctor_name {
    font-size: 7.5px;
    bottom: 0;
  }
  .idx10 .desc {
    margin-bottom: 30px;
  }
  .idx10 .btn-group {
    margin: 0 auto;
  }
  .idx10 .btn-group .btn2 {
    margin-left: auto;
    margin-right: auto;
  }
}

.idx11 {
  background-image: url("../images/idx11_bg.jpg");
}
.idx11 .idx_box {
  position: relative;
  display: flex;
  max-width: 1720px;
}
.idx11 .idx_box::before {
  content: "";
  width: 46.1em;
  aspect-ratio: 461/141;
  background: url("../images/idx11_logo.png") no-repeat center/cover;
}
.idx11 .idx_box .box_cont {
  overflow: hidden;
}
.idx11 .wrap_h3 {
  margin-bottom: 33px;
}
.idx11 .desc {
  color: #fff;
  text-align: center;
  margin-bottom: 40px;
}
.idx11 .desc p {
  letter-spacing: 0.05em;
}
.idx11 .swiper {
  --size-item: 37.5em;
  position: relative;
  overflow: visible;
}
.idx11 .swiper-wrapper {
  counter-reset: item;
}
.idx11 .swiper-slide {
  box-sizing: border-box;
  flex-shrink: 0;
  counter-increment: item;
  width: calc(var(--size-item) * 0.8);
}
.idx11 .swiper-slide.swiper-slide-active .item {
  transform: scale(1);
}
.idx11 .swiper .item {
  background-color: #fff;
  transform: scale(0.8);
  transform-origin: 100% 50%;
  width: var(--size-item);
  border-radius: 10px;
  transition: all 0.3s ease;
  opacity: 1;
}
.idx11 .swiper .item .num {
  position: absolute;
  top: -0.4667em;
  left: 0.5333em;
  font-size: 6em;
  line-height: 1;
  font-weight: 300;
  letter-spacing: -0.05em;
  color: var(--clr3);
  margin-bottom: 0;
}
.idx11 .swiper .item picture img {
  border-radius: 10px 10px 0 0;
}
.idx11 .swiper .item .txt {
  margin-top: -1.2em;
  padding: 0em 4em 2.2em;
}
.idx11 .swiper .item .ttl {
  position: relative;
  font-size: 2em;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.04em;
  color: var(--main-color);
  text-align: center;
  margin-bottom: 0.8em;
}
.idx11 .swiper .item .ttl::after {
  content: "";
  display: block;
  width: 4.5em;
  height: 1px;
  margin: 0 auto;
  margin-top: 0.6em;
  background-color: currentColor;
}
.idx11 .swiper .item .desc {
  font-size: 1.6em;
  color: var(--clr1);
  letter-spacing: 0.03em;
  line-height: 1.875;
  text-align: left;
  margin-bottom: 0;
}
.idx11 .swiper-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
  z-index: 2;
  gap: 3em;
}
.idx11 .swiper-pagination {
  position: relative;
  display: flex;
  align-items: center;
  width: fit-content;
  font-size: max(10px, 1.6em);
  letter-spacing: 0;
  color: #fff;
  gap: 0.9375em;
  inset: 0 !important;
}
.idx11 .swiper-pagination .swiper-pagination-current,
.idx11 .swiper-pagination .swiper-pagination-total {
  position: relative;
  bottom: 0.1875em;
}
.idx11 .swiper-pagination .progress {
  --progress: 0;
  position: relative;
  display: block;
  width: 7.5em;
  height: 2px;
  background-color: #fff;
}
.idx11 .swiper-pagination .progress::before {
  content: "";
  position: absolute;
  width: calc(100% * var(--progress));
  height: 2px;
  top: 0;
  left: 0;
  background-color: var(--clr2);
}
.idx11 .swiper-navigation {
  position: relative;
  display: flex;
  gap: 0.8em;
}
.idx11 .swiper-navigation .swiper-btn {
  position: relative;
  width: 6em;
  height: 6em;
  border-radius: 50%;
  background-color: var(--clr2);
  cursor: pointer;
}
.idx11 .swiper-navigation .swiper-btn::before {
  content: "";
  position: absolute;
  width: 2.2em;
  aspect-ratio: 22/13;
  inset: 0;
  margin: auto;
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M21.1000,7.285 L3.079,7.285 L7.790,11.825 L6.744,12.989 L-0.000,6.488 L6.744,-0.011 L7.790,1.153 L3.076,5.695 L21.1000,5.695 L21.1000,7.285 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: 100% auto;
  -webkit-mask-size: 100% auto;
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
}
.idx11 .swiper-navigation .swiper-btn-next::before {
  rotate: 180deg;
}
@media only screen and (min-width: 1921px) {
  .idx11 .idx_box {
    margin-right: auto;
  }
}
@media only screen and (min-width: 993px) {
  .idx11 .idx_box {
    justify-content: space-between;
    padding: 0 0 0 20px;
    margin-left: auto;
  }
  .idx11 .idx_box::before {
    position: absolute;
    font-size: min(0.6vw, 10px);
    bottom: calc(100% - 2.5em);
    right: 24em;
  }
  .idx11 .idx_box .box_ttl {
    width: 30%;
    max-width: 486px;
  }
  .idx11 .idx_box .box_cont {
    width: 67%;
    max-width: 1127px;
  }
  .idx11 .swiper {
    font-size: min(0.68vw, 10px);
    margin-left: 0;
    width: 86%;
  }
  .idx11 .swiper-wrapper {
    width: 200%;
    padding-top: 45px;
    padding-left: calc(var(--size-item) * 0.2);
    padding-bottom: 40px;
  }
  .idx11 .swiper-slide {
    min-height: calc(var(--size-item) * 4.25 / 3);
  }
  .idx11 .swiper-slide.swiper-slide-prev .item {
    opacity: 0;
  }
  .idx11 .swiper .item {
    position: absolute;
    top: 0;
    right: 0;
    height: 100%;
  }
  .idx11 .swiper-group {
    position: absolute;
    bottom: 0;
    right: 3.5em;
  }
}
@media only screen and (min-width: 769px) {
  .idx11 {
    padding: clamp(80px, 10vw, 177px) 0 clamp(80px, 10vw, 138px);
  }
  .idx11 .swiper-navigation .swiper-btn:hover {
    background-color: var(--clr3);
  }
}
@media only screen and (min-width: 769px) and (max-width: 1024px) {
  .idx11 .wrap_h3 h3 {
    font-size: 36px;
  }
}
@media only screen and (max-width: 992px) {
  .idx11 .idx_box {
    flex-direction: column;
  }
  .idx11 .idx_box::before {
    font-size: 6px;
    display: block;
    margin: 0 auto;
    margin-bottom: 30px;
  }
  .idx11 .idx_box .box_ttl {
    display: contents;
  }
  .idx11 .idx_box .box_cont {
    order: 3;
    margin-bottom: 30px;
  }
  .idx11 .wrap_h3 {
    order: 1;
  }
  .idx11 .desc {
    max-width: 550px;
    order: 2;
    margin-left: auto;
    margin-right: auto;
  }
  .idx11 .btn-group {
    order: 4;
  }
  .idx11 .swiper {
    font-size: 8.75px;
    --size-item: 300px;
    width: 50%;
    margin: 0 auto;
  }
  .idx11 .swiper .item {
    min-height: 475px;
  }
  .idx11 .swiper-wrapper {
    padding-top: 20px;
    margin-bottom: 30px;
    margin-left: calc(var(--size-item) * 0.2 * -1 / 2 + 10px);
  }
  .idx11 .swiper-slide.swiper-slide-prev {
    margin-right: calc(var(--size-item) * 0.2 + 10px) !important;
  }
  .idx11 .swiper-group {
    margin: 0 auto;
    width: fit-content;
  }
}

.idx12 .wrap_h3 h3 {
  letter-spacing: 0.1em;
}
.idx12 .wrap_h3 h3::before {
  content: none;
}
.idx12 .desc {
  color: #fff;
}
.idx12 .wrap {
  position: relative;
  max-width: 1103px;
  margin: 0 auto;
  z-index: 0;
  display: flex;
}
.idx12 .wrap::before {
  content: "";
  border-radius: inherit;
  background: url("../images/idx12_bg.jpg") no-repeat right center/cover;
}
.idx12 .wrap::after {
  content: "";
  position: absolute;
  width: 22.3em;
  aspect-ratio: 223/243;
  background: url("../images/idx12_decor02.png") no-repeat center/cover;
  z-index: -1;
}
.idx12 .content {
  position: relative;
}
.idx12 .content::before, .idx12 .content::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
}
.idx12 .content::before {
  width: 2.4em;
  aspect-ratio: 1/1;
  background-image: url(../images/idx12_decor01.png);
  z-index: 1;
}
.idx12 .content::after {
  width: 7.4em;
  aspect-ratio: 74/101;
  background-image: url(../images/idx12_decor03.png);
}
.idx12 .txt {
  width: 100%;
  height: 100%;
}
.idx12 .ic-arr {
  position: absolute;
  width: 5em;
  aspect-ratio: 1/1;
}
.idx12 .ic-arr::before, .idx12 .ic-arr::after {
  content: "";
  position: absolute;
  width: round(100%, 1px);
  height: round(100%, 1px);
  border-radius: 50%;
  transition: all 0.3s ease;
  top: 0;
  bottom: 0;
}
.idx12 .ic-arr::before {
  background-color: #87b828;
}
.idx12 .ic-arr::after {
  --mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 22 13' %3E%3Cpath d='M15.256,12.989 L14.210,11.825 L18.923,7.284 L-0.000,7.284 L-0.000,5.696 L18.924,5.696 L14.210,1.153 L15.256,-0.010 L21.1000,6.489 L15.256,12.989 Z'/%3E%3C/svg%3E");
  mask-image: var(--mask);
  -webkit-mask-image: var(--mask);
  mask-repeat: no-repeat;
  -webkit-mask-repeat: no-repeat;
  mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  -webkit-mask-size: round(min(44%, 22px), 1px) round(min(26%, 13px), 1px);
  mask-position: center;
  -webkit-mask-position: center;
  background-color: #fff;
}
.idx12 .ic-arr::before, .idx12 .ic-arr::after {
  margin: auto 0;
}
@media only screen and (min-width: 769px) {
  .idx12 {
    padding: 79px 0 67px;
  }
  .idx12 .wrap_h3 {
    text-align: left;
    margin-bottom: 15px;
  }
  .idx12 .wrap_h3 h3 {
    font-size: calc(var(--ttl_size) + 8px);
    margin-bottom: 2px;
  }
  .idx12 .wrap {
    border-radius: 60px;
    align-items: flex-end;
  }
  .idx12 .wrap::before {
    position: absolute;
    top: 0;
    max-width: 920px;
    margin: auto;
    width: 85%;
    height: 90%;
    right: 78px;
  }
  .idx12 .wrap::after {
    font-size: 10px;
    bottom: 0px;
    right: 0px;
  }
  .idx12 .wrap:hover {
    opacity: 0.8;
  }
  .idx12 .content {
    width: 50%;
    max-width: 479px;
    aspect-ratio: 479/314;
    margin-bottom: 11px;
    margin-left: -2px;
  }
  .idx12 .content::before, .idx12 .content::after {
    font-size: 10px;
  }
  .idx12 .content::before {
    top: 3em;
    left: calc(50% - 2.5em);
  }
  .idx12 .content::after {
    bottom: 0.1em;
    left: -0.2em;
  }
  .idx12 .txt {
    padding: 67px 125px 67px 76px;
    mask-position: center center;
    mask-size: 100% 100%;
    mask-repeat: no-repeat;
    mask-image: url(../images/idx12_shape.png);
    -webkit-mask-image: url(../images/idx12_shape.png);
    background: url("../images/idx12_shape.png") no-repeat center/cover;
  }
  .idx12 .ic-arr {
    font-size: 10px;
    right: 15.5em;
    bottom: 6.7em;
  }
}
@media only screen and (min-width: 993px) {
  .idx12 .wrap {
    min-height: 400px;
  }
  .idx12 .wrap::before {
    left: 0;
  }
}
@media only screen and (min-width: 769px) and (max-width: 992px) {
  .idx12 .wrap {
    border-radius: 40px;
    padding-top: 80px;
  }
  .idx12 .wrap::before {
    right: 50px;
  }
  .idx12 .wrap::after {
    bottom: -3em;
    font-size: 8.75px;
  }
  .idx12 .content {
    width: 55%;
  }
  .idx12 .content::before, .idx12 .content::after {
    font-size: 8.75px;
  }
  .idx12 .content::before {
    top: 3em;
  }
  .idx12 .content::after {
    bottom: -4em;
    left: 0;
  }
  .idx12 .txt {
    padding: 50px 100px 50px 30px;
  }
  .idx12 .ic-arr {
    font-size: 8.75px;
    right: 8em;
  }
}

/*# sourceMappingURL=index_pc.css.map */
