@charset "UTF-8";
.c-txtfig._reverse {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  gap: 2rem; /* 必要に応じて調整 */
}

#home .home-mainimg .mainimg-link { max-width: 410px; }
@media screen and (max-width: 750px) {
  #home .home-mainimg .mainimg-link {
    max-width: unset;
    width: min(550px, 80%);
    bottom: 4em;
    left: 50%;
    translate: -50% 0;
    margin: auto;
  }
}
#home .home-event .event-btn { padding-top: 50px; }

#spot ._idx .spot-results .spot-results-list ul li .genre  { margin-bottom: 15px; gap: 0; }
#spot ._idx .spot-results .spot-results-list ul li .genre li {  display: flex; align-items: center; justify-content: center;  width: 100%; margin-top: 10px; margin-left: 10px; padding: 7px 5px; background-color: #fff; font-size: 1.3rem; font-weight: 700; border-radius: 2em; line-height: 1; box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.2); }
#spot ._idx .spot-results .spot-results-list ul li .genre .ico { width: 0.65em; margin-right: 7px; }
#spot ._idx .spot-results .spot-results-list ul li .genre ._spot { max-width: 155px; color: #00adaf; }
#spot ._idx .spot-results .spot-results-list ul li .genre ._experience { max-width: 100px; color: #2980f4; }

@media screen and (max-width: 1470px) { .header .header-in { position: static; padding: 0; } }
@media screen and (max-width: 1470px) { .header .header-con { height: 100px; padding: 1em; border-radius: 0; } }
@media screen and (max-width: 1470px) { .header .header-logo { max-width: 440px; } }
@media screen and (max-width: 1470px) { .header .header-nav .header-search { width: min(65px,11dvw); } }
@media screen and (max-width: 1470px) { .header .header-nav .header-menu { display: block; width: 56px; height: 40px; margin-left: 20px; cursor: pointer; } }
@media screen and (max-width: 1470px) { .header .header-nav .gnav { display: none; } }
@media screen and (max-width: 1470px) { .pagettl-sec { padding: 20px 0 90px; } }
@media screen and (max-width: 1470px) { .pagettl-sec._subpage .topicpath { margin-bottom: 90px; } }
@media screen and (max-width: 1470px) { .pagettl-sec .topicpath { margin-bottom: 90px; } }
@media screen and (max-width: 1470px) { .topicpath { padding: 1em; } }

.c-blue-in-wbox { margin-inline: -40px; padding: 40px; background-color: #eff8fd; border-radius: 20px; }
@media screen and (max-width: 750px) { .c-blue-in-wbox { margin-inline: -30px; padding: 30px; } }

.content_movie .c-youtube {
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
  aspect-ratio: 16 / 9;
}

.content_movie .c-youtube iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

@media screen and (max-width: 750px) {
  .content_movie .c-youtube {
    max-width: 100%;
  }
}

.c-newslist li a .news-cate._cate04 { border: 1px solid #e88400; }
.c-newslist li a .news-cate._cate05 { border: 1px solid #2d8c3c; }
.c-newslist li a .news-cate._cate06 { border: 1px solid #c0392b; }

.home-mainimg .mainimg-link a { display: block; text-decoration: none; padding: 15px 30px; background: #fff no-repeat center; background-size: 28px auto; font-size: 1.4rem; font-weight: 700; text-align: center; border-radius: 50vw; line-height: 1.4; }

.header-search-modal {
  z-index: 100000;
  display: none;
  position: fixed;
  inset: 0;
  padding: 40px 20px;
  background: rgba(0, 53, 71, 0.55);
}

.header-search-modal .header-search-panel {
  position: relative;
  width: min(760px, 100%);
  margin: 55px auto 0;
  padding: 36px 40px;
  background: linear-gradient(145deg, #ffffff 0%, #f2fbfb 100%);
  border: 1px solid #d5ecef;
  border-radius: 24px;
  box-shadow: 0 18px 40px rgba(0, 70, 89, 0.2);
}

.header-search-modal .header-search-close {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 38px;
  height: 38px;
  border: 1px solid #99c8cc;
  border-radius: 50%;
  background: #fff;
  color: #00656f;
  font-size: 2.2rem;
  line-height: 1;
  cursor: pointer;
}

.header-search-modal .header-search-title {
  margin-bottom: 16px;
  color: #005c6d;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.2;
}

.header-search-modal .header-search-label {
  display: block;
  margin-bottom: 10px;
  font-size: 1.4rem;
  font-weight: 500;
}

.header-search-modal .header-search-row {
  display: flex;
  align-items: center;
  gap: 12px;
}

.header-search-modal .header-search-input {
  flex: 1;
  width: 100%;
  height: 56px;
  padding: 0 18px;
  border: 1px solid #9dd4d8;
  border-radius: 999px;
  background: #fff;
  font-size: 1.6rem;
}

.header-search-modal .header-search-input:focus {
  outline: 2px solid #00adaf;
  outline-offset: 2px;
}

.header-search-modal .header-search-submit {
  min-width: 120px;
  height: 56px;
  padding: 0 20px;
  border-radius: 999px;
  background: #00adaf;
  color: #fff;
  font-size: 1.6rem;
  font-weight: 700;
  transition: opacity .2s;
}

.header-search-modal .header-search-submit:hover {
  opacity: .85;
}

.js-searchopen {
  overflow: hidden;
}

.js-searchopen .header-search-modal {
  display: block;
}

@media screen and (max-width: 750px) {
  .header-search-modal {
    padding: 20px 4%;
  }

  .header-search-modal .header-search-panel {
    margin-top: 20px;
    padding: 22px 20px 24px;
    border-radius: 16px;
  }

  .header-search-modal .header-search-close {
    top: 10px;
    right: 10px;
    width: 34px;
    height: 34px;
    font-size: 2rem;
  }

  .header-search-modal .header-search-title {
    margin-right: 34px;
    margin-bottom: 12px;
    font-size: 2rem;
  }

  .header-search-modal .header-search-label {
    margin-bottom: 8px;
    font-size: 1.3rem;
  }

  .header-search-modal .header-search-row {
    flex-direction: column;
    align-items: stretch;
    gap: 10px;
  }

  .header-search-modal .header-search-input {
    height: 64px;
    padding-inline: 20px;
    font-size: 1.7rem;
  }

  .header-search-modal .header-search-submit {
    height: 35px;
    min-width: 96px;
    padding: 0 16px;
    font-size: 1.4rem;
  }
}
/* spot-slider */
.c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-main .swiper-slide {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  background: #edf3fc;
  border-radius: 1em;
  overflow: hidden;
}
@media screen and (max-width: 750px) {
  .c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-main .swiper-slide {
    border-radius: .5em;
  }
}
.c-detail .detail-top .detail-mainfig-swiper .swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.mainfig-swiper-sub-wrap {
  position: relative;
  padding-inline: 5em;
}
@media screen and (max-width: 750px) {
  .mainfig-swiper-sub-wrap {
    padding-inline: 3.5em;
  }
}
.c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper {
    height: auto;
    align-items: center;
}
.c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper .swiper-slide {
    width: 100%;
    height: auto;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: .5em;
    background: #edf3fc;  
    border: 1px solid #cbcbcb;
}
@media screen and (max-width: 750px) {
  .c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper .swiper-slide {
    border-radius: .25em;
  }
}
.c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper .swiper-slide img {
  border-radius: .5em;
}
@media screen and (max-width: 750px) {
  .c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper .swiper-slide img  {
    border-radius: .25em;
  }
}
.c-detail .detail-top .detail-mainfig-swiper .mainfig-swiper-sub .swiper-wrapper .swiper-slide.swiper-slide-thumb-active {
  border: 2px solid #00adaf;
}
.c-detail .detail-top .detail-mainfig-swiper .slide-btn {
  top: 50%;
  translate: 0 -50%;
  width: min(56px, 9dvw);
  height: min(56px, 9dvw);
  aspect-ratio: 1;
  margin: 0;
}
@media screen and (max-width: 750px) {
  .c-detail .detail-top .detail-mainfig-swiper .slide-btn {
    width: min(46px, 10dvw);
    height: min(46px, 10dvw);
  }
}
._idx .spot-results .spot-results-list ul li figure {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}
._idx .spot-results .spot-results-list ul li figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* event */
._idx .event-results .event-results-list ul {
  display: flex;
  flex-wrap: wrap;
}
._idx .event-results .event-results-list ul li figure {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 1em;
}
@media screen and (max-width: 750px) {
  ._idx .event-results .event-results-list ul li figure {
    border-radius: .5em;
  }
}
._idx .event-results .event-results-list ul li figure img {
  width: 100%;  
  height: 100%;
  object-fit: cover;
}
/* feature */
.c-morelist li figure {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 1em;
}
@media screen and (max-width: 750px) {
  .c-morelist li figure {
    border-radius: .5em;
  }
}
.c-morelist li figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* detail */
.c-detail .detail-wrap {
  justify-content: center;
}
.c-detail .detail-main {
  max-width: 880px;
}
@media screen and (max-width: 980px) {
  .c-detail .detail-side {
    display: none;
  }
  .c-spot .spot-tool .spot-tool-in {
    margin-bottom: 1em;
  }
}
/* footer  */
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-nav .footer-nav-link {
    width: 100%;
    flex-direction: column;
    align-items: center;
    gap: 1em;
  }
  .footer .footer-main .footer-nav .footer-nav-link li {
    border: none;
    padding: 0;
    margin: 0;
  }
}
.footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  justify-items: center;
  gap: 1.2em .5em;
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap {
    gap: .8em;
  }
}
.footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap :where(p[class*="footer-icon-"]) {
  padding-inline: .3em;
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap :where(p[class*="footer-icon-"]) {
    padding-inline: 0;
  }
}
.footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap .footer-icon-x {
  padding-inline: .4em;
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap .footer-icon-x {
    padding-inline: .15em;
  }
}
.footer .footer-main .footer-box .footer-sns dd p:last-child {
  width: fit-content;
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd p:last-child {
    width: min(70px, 11dvw);
  }
}
.footer .footer-main .footer-box .footer-sns dd .footer-sns-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd p {
    width: min(60px, 10dvw);
  }
}
@media screen and (max-width: 750px) {
  .footer .footer-main .footer-box .footer-sns dd p img {
    width: 100% !important;
  }
}
/* common */
@media screen and (max-width: 980px) {
  .c-spot .spot-tool {
    margin-top: 1em;
  }
}
@media screen and (max-width: 750px) {
  .c-spot .spot-tool .swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 6px !important;
  }
  .c-spot .spot-tool .spot-btn button {
    width: min(50px, 10dvw);
  }
}
.c-spot .spot-main figure figcaption {
  line-height: 1.4;
}
@media screen and (max-width: 750px) {
  .c-back {
    max-width: fit-content;
  }
  .c-back a {
    padding: 1em 2em;
  }
}
.nav-menu {
  top: 100px;
  width: min(500px, 84%);
  height: calc(100% - 100px);
}
@media screen and (max-width: 750px) {
  .nav-menu {
    top: 60px;
    height: calc(100% - 60px);
  }
}
@media screen and (max-width: 750px) {
  .header .header-logo {
    max-width: 380px;
    margin-right: 2em;
  }
  .header .header-nav .header-search {
    width: min(45px, 11dvw);
  }
  .header .header-nav .header-menu {
    width: 35px;
    margin-left: 1em;
  }
  .header .header-con {
    height: 60px;
    padding: .3em 1em .3em .5em;
  }
}
/* anime */
.js-anime-fadein {
  animation-delay: .3s;
  animation-duration: .6s;
}
.js-anime-slide {
  animation-delay: .3s;
  animation-duration: .6s;
}

/* TOP */
.home-modelcourse .modelcourse-main ul li .modelcourse-box .modelcourse-item {
  flex-wrap: wrap;
  gap: 1em 0;
}
.home-modelcourse .modelcourse-main ul li .modelcourse-box .modelcourse-item dl {
  min-width: 150px;
}
.home-modelcourse .modelcourse-main ul li .modelcourse-box .modelcourse-item dl dt {
  min-width: 6em;
}
.home-modelcourse .modelcourse-main ul li .modelcourse-box .modelcourse-item dl dd {
  word-break: keep-all;
}
.home-spot .spot-rank a figure {
  position: relative;
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  border-radius: .5em;
}
.home-spot .spot-rank a figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-feature .feature-main ul li .feature-heading {
  line-height: 1.4;
}
.home-search .search-swiper .swiper-slide figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-search .search-swiper .swiper-slide figure {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  border-radius: .5em;
  overflow: hidden;
}
.home-information .information-link ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.home-information .information-link ul li {
  width: auto;
}
.home-information .information-link ul li a figure {
  width: 100%;
}
.home-information .information-link ul li a figure figcaption {
  margin-top: 1em;
}
@media screen and (max-width: 750px) {
  .home-mainimg .mainimg-ttl {
    top: 42%;
    margin: 0;
    translate: -50% -50%;
  }
  .home-mainimg .mainimg-tool .swiper-pagination-fraction {
    font-size: 2.695rem;
    margin: 0 0 2em 1em;
  }
  .home-about .about-main .about-box p {
    line-height: 2;
  }
  .home-nav .nav-list {
    margin-bottom: 3em;
  }
  .home-heading {
    font-size: 3.144rem;
  }
  .c-newslist li a .news-cate {
    font-size: 1.235rem;
  }
  .c-btn span {
    font-size: 1.796rem;
  }
  .home-modelcourse {
    padding: 17.3333333333% 0 17%;
  }
  .home-spot {
    padding: 17.3333333333% 0 4em;
  }
  .home-spot .home-heading {
    text-align: center;
    margin-bottom: 1em;
  }
  .home-spot .spot-rank._sub {
    gap: 3em 1.5em;
  }
  .nav-menu .nav-menu-list > li > a {
    font-size: 1.796rem;
  }
  .nav-menu .nav-menu-list > li ul li a {
    font-size: 1.796rem;
  }
  .home-nav .nav-list li a figure figcaption span {
    font-size: 2.021rem;
    line-height: 1.4;
  }
  .home-nav .nav-list li a figure figcaption p {
    font-size: 4.716rem;
  }
  .home-modelcourse .modelcourse-tool .swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 6px !important;
  }
  .home-modelcourse .modelcourse-main {
    margin: 0 auto 2em;
  }
  .home-modelcourse .modelcourse-main ul li .modelcourse-box .modelcourse-heading {
    font-size: 2.246rem;
    margin-bottom: 1em;
  }
  .home-feature .feature-tool .swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 6px !important;
  }
  .home-event .event-tool .swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 6px !important;
  }
  .home-search .search-main .search-btn a {
    background-size: 1.4em;
    padding: 1em;
  }
  .home-search .search-main {
    padding: 17.3333333333% 0 2em;
  }
  .home-information .information-top .information-heading {
    font-size: 3.144rem;
    margin-bottom: .5em;
  }
  .home-information .information-link ul li {
    width: auto;
  }
  .home-information .information-link ul li a {
    padding: 1.5em .5em;
  }
  .home-information .information-link ul li a figure figcaption {
    font-size: 1.347rem;
    margin-top: 1em;
  }
  .home-sponsor .sponsor-tool .swiper-pagination-bullet {
    width: 6px !important;
    height: 6px !important;
    margin: 0 6px !important;
  }
  .home-modelcourse .modelcourse-tool .slide-btn {
    width: auto;
    gap: .5em;
  }
  .home-modelcourse .modelcourse-tool .slide-btn button {
    width: min(50px, 11dvw);
  }
  .home-feature .feature-tool .slide-btn {
    width: auto;
    gap: .5em;
  }
  .home-feature .feature-tool .slide-btn button {
    width: min(50px, 11dvw);
  }
  .home-event .event-tool .slide-btn {
    width: auto;  
    gap: .5em;
  }
  .home-event .event-tool .slide-btn button {
    width: min(50px, 11dvw);
  }
  .home-sponsor .sponsor-tool .slide-btn {
    width: auto;
    gap: .5em;
  }
  .home-sponsor .sponsor-tool .slide-btn button {
    width: min(50px, 11dvw);
  }
}
/* policy */
._privacy .privacy-box {
  margin-bottom: 3em;
}
._privacy .privacy-box dl {
  margin-bottom: 20px;
}
.privacy-box dl dd ul {
  margin-top: 1em;
  padding-left: 1em;
}
._privacy .privacy-txt {
  margin-bottom: min(70px, 5em);
}
._privacy .c-lineheading {
  color: #fff;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1.3;
  background-color: #00adaf;
  border-radius: 5px;
  padding: .4em 1em;
  margin-bottom: .8em;
}
@media screen and (max-width: 750px) {
  ._privacy .c-lineheading {
    font-size: 1.8rem;
  }
}
._privacy dt {
  font-weight: 600;
  margin-bottom: .3em;
}
._privacy :where(p,dt,dd) {
  line-height: 1.8;
}

/* contact */
#contact .contact-privacy {
  margin-top: 24px;
  margin-bottom: 18px;
  padding-left: calc(20em + 30px);
  text-align: left;
}

#contact .contact-privacy-label {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  font-size: 1.6rem;
  line-height: 1.6;
}

#contact .contact-privacy-label input[type="checkbox"] {
  width: 18px;
  height: 18px;
}

#contact .contact-privacy-label a {
  text-decoration: underline;
}

@media screen and (max-width: 750px) {
  #contact .contact-privacy {
    padding-left: 0;
  }

  #contact .contact-privacy-label {
    align-items: center;
    font-size: 1.4rem;
  }

  #contact .contact-privacy-label input[type="checkbox"] {
    margin-top: 0;
  }
}