@media screen and (max-width: 991px) {
  html.header-scrolled header {
    background-color: #fff;
  }
}
html body header {
  -webkit-transition: 0.4s ease;
  transition: 0.4s ease;
}
@media screen and (max-width: 991px) {
  html body header {
    background-color: #fff;
  }
}
@media screen and (max-width: 991px) {
  html body header .header-inner .logo-wrapper a {
    color: #fff;
    -webkit-transition: 0.4s ease;
    transition: 0.4s ease;
  }
}
html body main .ttl-wrap h2 {
  text-align: center;
  color: #fff;
  font-size: 30px;
  font-weight: 700;
  padding: 22px 0 24px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap h2 {
    font-size: 18px;
    padding: 16px 0 17px;
  }
}
html body main .ttl-wrap h2::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 81px;
  height: 49px;
  top: 0;
  bottom: -33px;
  left: 0;
  right: 0;
  margin: auto auto 0 auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap h2::after {
    width: 31px;
    height: 52px;
    bottom: -48px;
  }
}
html body main .ttl-wrap .ttl-wrap-contents {
  padding: 100px 0 70px;
  position: relative;
  z-index: 0;
}
html body main .ttl-wrap .ttl-wrap-contents::after {
  content: "";
  position: absolute;
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 81px;
  height: 49px;
  top: 0;
  bottom: -33px;
  left: 0;
  right: 0;
  margin: auto auto 0 auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap .ttl-wrap-contents::after {
    width: 31px;
    height: 52px;
    bottom: -48px;
  }
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap .ttl-wrap-contents {
    padding: 45px 0 35px;
  }
}
html body main .ttl-wrap .ttl-wrap-contents .inner {
  max-width: calc(1000px + 2rem);
  padding: 0 1rem;
  margin: auto;
  text-align: center;
}
html body main .ttl-wrap .ttl-wrap-contents h3 {
  text-align: center;
  font-size: 30px;
  line-height: 1.5;
  margin-bottom: 30px;
  position: relative;
  display: inline-block;
  padding: 0 30px 0 40px;
}
html body main .ttl-wrap .ttl-wrap-contents h3::before, html body main .ttl-wrap .ttl-wrap-contents h3::after {
  content: "";
  position: absolute;
  top: 5%;
  display: inline-block;
  width: 4px;
  height: 100%;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap .ttl-wrap-contents h3::before, html body main .ttl-wrap .ttl-wrap-contents h3::after {
    width: 2px;
  }
}
html body main .ttl-wrap .ttl-wrap-contents h3::before {
  left: 0;
  -webkit-transform: rotate(-25deg);
          transform: rotate(-25deg);
}
html body main .ttl-wrap .ttl-wrap-contents h3::after {
  right: 0;
  -webkit-transform: rotate(25deg);
          transform: rotate(25deg);
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap .ttl-wrap-contents h3 {
    font-size: 16px;
    margin-bottom: 10px;
    padding: 0 15px;
  }
}
html body main .ttl-wrap .ttl-wrap-contents p {
  text-align: center;
  font-size: 18px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap .ttl-wrap-contents p {
    font-size: 14px;
  }
}
html body main .ttl-wrap.pink h2 {
  background-color: #E65D7A;
}
html body main .ttl-wrap.pink h2::after {
  background-image: url("../../images/index/ttl-h2-after-pink.png");
}
html body main .ttl-wrap.pink .ttl-wrap-contents {
  background-color: #FCF1F2;
}
html body main .ttl-wrap.pink .ttl-wrap-contents::after {
  background-image: url("../../images/index/ttl-after-pink.png");
}
html body main .ttl-wrap.pink .ttl-wrap-contents h3 {
  color: #E65D7A;
}
html body main .ttl-wrap.pink .ttl-wrap-contents h3::before, html body main .ttl-wrap.pink .ttl-wrap-contents h3::after {
  background-color: #E65D7A;
}
html body main .ttl-wrap.blue h2 {
  background-color: #31B2D3;
}
html body main .ttl-wrap.blue h2::after {
  background-image: url("../../images/index/ttl-h2-after-blue.png");
}
html body main .ttl-wrap.blue .ttl-wrap-contents {
  background-color: #ECF7FA;
}
html body main .ttl-wrap.blue .ttl-wrap-contents::after {
  background-image: url("../../images/index/ttl-after-blue.png");
}
html body main .ttl-wrap.blue .ttl-wrap-contents h3 {
  color: #31B2D3;
}
html body main .ttl-wrap.blue .ttl-wrap-contents h3::before, html body main .ttl-wrap.blue .ttl-wrap-contents h3::after {
  background-color: #31B2D3;
}
html body main .ttl-wrap + section {
  padding-top: 70px;
}
@media screen and (max-width: 767px) {
  html body main .ttl-wrap + section {
    padding-top: 50px;
  }
}
html body main h2.h2-ttl {
  text-align: center;
  font-size: 30px;
  font-weight: 600;
  margin-bottom: 60px;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  html body main h2.h2-ttl {
    font-size: 18px;
    margin-bottom: 30px;
  }
}
html body main h2.h2-ttl::after {
  content: "";
  position: absolute;
  width: 60px;
  height: 5px;
  top: 0;
  bottom: -20px;
  left: 0;
  right: 0;
  margin: auto auto 0 auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  html body main h2.h2-ttl::after {
    width: 30px;
    height: 3px;
    bottom: -6px;
  }
}
html body main h2.h2-ttl.pink {
  color: #E65D7A;
}
html body main h2.h2-ttl.pink::after {
  background-color: #E65D7A;
}
html body main h2.h2-ttl.blue {
  color: #31B2D3;
}
html body main h2.h2-ttl.blue::after {
  background-color: #31B2D3;
}
html body main .sec-event .contents-list-wrapper {
  display: grid;
  gap: 50px;
}
@media screen and (max-width: 575px) {
  html body main .sec-event .contents-list-wrapper .contents-list:last-child {
    width: calc(100% + 2rem);
    margin: auto -1rem;
  }
}
html body main .sec-event ul {
  border-top-style: dashed;
  border-top-width: 1px;
}
html body main .sec-event ul li {
  border-bottom-style: dashed;
  border-bottom-width: 1px;
  line-height: 1.5;
  padding: 33px 0;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li {
    padding: 17px 0 15px;
  }
}
@media screen and (min-width: 768px) {
  html body main .sec-event ul li:nth-child(2) dl dd p:first-child {
    margin-top: -11px;
  }
}
html body main .sec-event ul li dl {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 40px;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl {
    grid-template-columns: 65px 1fr;
    gap: 15px;
  }
}
html body main .sec-event ul li dl dt {
  color: #fff;
  font-size: 14px;
  font-weight: 500;
  width: 100%;
  height: 38px;
  display: grid;
  place-content: center;
}
@media screen and (min-width: 768px) {
  html body main .sec-event ul li dl dt {
    margin-top: 7px;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dt {
    height: 26px;
    font-size: 12px;
    margin-top: 3px;
  }
}
html body main .sec-event ul li dl dd {
  color: #000;
  font-size: 16px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  gap: 1em;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd {
    font-size: 13px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 0;
  }
}
html body main .sec-event ul li dl dd p {
  font-size: 26px;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd p {
    font-size: 18px;
  }
}
html body main .sec-event ul li dl dd p.bg-yellow {
  font-size: 18px;
  background-color: #F8F3D7;
  padding: 5px 10px;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd p.bg-yellow {
    font-size: 16px;
    width: calc(100% + 10px + 65px);
    margin-left: -75px;
    margin-top: 10px;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd span.sp-none {
    display: none;
  }
}
html body main .sec-event ul li dl dd span.large {
  font-size: 20px;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd span.large {
    font-size: 14px;
  }
}
html body main .sec-event ul li dl dd .dd-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 768px) {
  html body main .sec-event ul li dl dd .dd-inner {
    margin-top: 15px;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd .dd-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
html body main .sec-event ul li dl dd .soldout {
  width: 100%;
  width: calc(100% + 40px + 110px);
  margin-left: -150px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd .soldout {
    width: calc(100% + 10px + 65px);
    margin-left: -75px;
  }
}
html body main .sec-event ul li dl dd .soldout p {
  margin-top: 1rem;
  text-align: center;
  color: #E70012 !important;
  font-size: 20px;
  font-weight: 600;
}
@media screen and (max-width: 767px) {
  html body main .sec-event ul li dl dd .soldout p {
    font-size: 18px;
  }
}
html body main .sec-event.pink ul {
  border-top-color: #E65D7A;
}
html body main .sec-event.pink ul li {
  border-bottom-color: #E65D7A;
}
html body main .sec-event.pink ul li dl dt {
  background-color: #E65D7A;
}
html body main .sec-event.pink ul li dl dd p {
  color: #E65D7A;
}
html body main .sec-event.blue ul {
  border-top-color: #31B2D3;
}
html body main .sec-event.blue ul li {
  border-bottom-color: #31B2D3;
}
html body main .sec-event.blue ul li dl dt {
  background-color: #31B2D3;
}
html body main .sec-event.blue ul li dl dd p {
  color: #31B2D3;
}
html body main .btn-pink {
  max-width: 700px;
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 767px) {
  html body main .btn-pink {
    max-width: 330px;
  }
}
html body main .btn-pink a {
  width: 100%;
  height: 100px;
  display: grid;
  place-content: center;
  border-radius: 100px;
  background-color: #fff;
  border: 5px solid #E70012;
  color: #E70012;
  font-size: 28px;
  font-weight: 700;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  html body main .btn-pink a {
    border-width: 3px;
    height: 70px;
    font-size: 16px;
  }
}
html body main .btn-pink a:hover {
  background-color: #E70012;
  color: #fff;
}
html body main .btn-blue {
  max-width: 700px;
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 767px) {
  html body main .btn-blue {
    max-width: 330px;
  }
}
html body main .btn-blue a {
  width: 100%;
  height: 100px;
  display: grid;
  place-content: center;
  border-radius: 100px;
  background-color: #fff;
  border: 5px solid #31B2D3;
  color: #31B2D3;
  font-size: 28px;
  font-weight: 700;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
  text-align: center;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  html body main .btn-blue a {
    border-width: 3px;
    height: 70px;
    font-size: 16px;
  }
}
html body main .btn-blue a:hover {
  background-color: #31B2D3;
  color: #fff;
}
html body main .mainvisual .mainvisual-1 {
  background-image: url("../../images/index/mv-1-bg-pc.png");
  background-repeat: no-repeat;
  background-position: center top;
  height: 630px;
  padding-top: 150px;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-1 {
    background-image: url("../../images/index/mv-1-bg-sp.png");
    background-size: 100% auto;
    height: 801px;
    height: 106.8vw;
  }
  html body main .mainvisual .mainvisual-1 figure {
    display: none;
  }
}
html body main .mainvisual .mainvisual-2 {
  background-image: url("../../images/index/mv-2-bg-pc.png");
  background-repeat: no-repeat;
  background-position: center top;
  height: 426px;
  padding-top: 120px;
  margin-top: -77px;
  position: relative;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-2 {
    background-image: url("../../images/index/mv-2-bg-sp.png");
    background-size: 100% auto;
    height: 1399px;
    height: 186.5333333333vw;
    padding-top: 30px;
    padding-top: 8vw;
    margin-top: 0;
  }
}
html body main .mainvisual .mainvisual-2 figure {
  position: absolute;
  left: 0;
  right: -1040px;
  top: -93px;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-2 figure {
    display: none;
  }
}
html body main .mainvisual .mainvisual-2 dl {
  margin-bottom: 37px;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-2 dl {
    margin-bottom: 280px;
    margin-bottom: 75vw;
  }
}
html body main .mainvisual .mainvisual-2 dl dt,
html body main .mainvisual .mainvisual-2 dl dd {
  text-align: center;
  line-height: 1.5;
}
html body main .mainvisual .mainvisual-2 dl dt {
  color: #E5503E;
  font-size: 30px;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  html body main .mainvisual .mainvisual-2 dl dt {
    font-size: 20px;
  }
}
html body main .mainvisual .mainvisual-2 dl dd {
  font-size: 18px;
  line-height: 1.7;
}
@media screen and (max-width: 767px) {
  html body main .mainvisual .mainvisual-2 dl dd {
    font-size: 14px;
  }
}
html body main .mainvisual .mainvisual-2 .btn-wrap {
  max-width: calc(1000px + 2rem);
  padding: 0 2rem;
  margin: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-2 .btn-wrap {
    grid-template-columns: 1fr;
    gap: 12px;
  }
}
html body main .mainvisual .mainvisual-2 .btn-wrap a {
  color: #080808;
  font-size: 24px;
  font-weight: 700;
  height: 116px;
  display: grid;
  place-content: center;
  padding-bottom: 27px;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
@media screen and (max-width: 575px) {
  html body main .mainvisual .mainvisual-2 .btn-wrap a {
    height: 81px;
    height: 21.6vw;
    font-size: 16px;
    padding-bottom: 20px;
  }
}
html body main .mainvisual .mainvisual-2 .btn-wrap a:hover {
  color: #fff;
}
html body main .mainvisual .mainvisual-2 .btn-wrap a:first-child {
  background-image: url("../../images/index/mv-btn-1.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
}
html body main .mainvisual .mainvisual-2 .btn-wrap a:last-child {
  background-image: url("../../images/index/mv-btn-2.png");
  background-repeat: no-repeat;
  background-position: center top;
  background-size: 100% auto;
}
html body main .sec-1 h2 {
  text-align: center;
  font-weight: 700;
  font-size: 40px;
  margin-bottom: 50px;
  color: #000000;
}
@media screen and (max-width: 767px) {
  html body main .sec-1 h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
html body main .sec-1 .box {
  max-width: 840px;
  width: 100%;
  margin: 20px auto 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (max-width: 767px) {
  html body main .sec-1 .box {
    margin-bottom: 25px;
  }
}
@media screen and (max-width: 575px) {
  html body main .sec-1 .box {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    gap: 10px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
html body main .sec-1 .box p {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  html body main .sec-1 .box p {
    width: calc(100% - 110px);
    font-size: 14px;
  }
  html body main .sec-1 .box p br {
    display: none;
  }
}
html body main .sec-1 .btn-sec1 {
  width: 480px;
  height: 101px;
  margin: auto;
}
@media screen and (max-width: 575px) {
  html body main .sec-1 .btn-sec1 {
    width: 262px;
    height: 60px;
  }
}
html body main .sec-1 .btn-sec1 a {
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("../../images/index/sec1-btn.svg");
  background-size: 100% auto;
  background-repeat: no-repeat;
}
html body main .sec-1 .btn-sec1 a:hover {
  background-image: url("../../images/index/sec1-btn-hover.svg");
}
html body main .sec-1 .btn-sec1 a span {
  display: none;
}
html body main .sec-2 {
  background-color: #FCF1F2;
  position: relative;
  z-index: 0;
}
html body main .sec-2::before {
  content: "";
  position: absolute;
  background-image: url("../../images/index/ico-event-next.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 49px;
  height: 81px;
  top: -11px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto auto auto;
  z-index: -1;
}
html body main .sec-2 .contents-list-wrapper {
  display: grid;
  gap: 100px;
}
@media screen and (max-width: 767px) {
  html body main .sec-2 .contents-list-wrapper {
    gap: 45px;
  }
}
html body main .sec-2 .contents-list-wrapper .contents-list:first-child {
  display: grid;
  gap: 50px;
}
@media screen and (max-width: 767px) {
  html body main .sec-2 .contents-list-wrapper .contents-list:first-child {
    gap: 45px;
  }
}
html body main .sec-2 .contents-list-wrapper .contents-list:last-child p {
  text-align: center;
  font-size: 18px;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  html body main .sec-2 .contents-list-wrapper .contents-list:last-child p {
    font-size: 14px;
    margin-bottom: 13px;
  }
}
html body main .sec-3 {
  background-color: #ECF7FA;
  position: relative;
  z-index: 0;
}
html body main .sec-3::before {
  content: "";
  position: absolute;
  background-image: url("../../images/index/ico-event-next.png");
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 49px;
  height: 81px;
  top: -11px;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto auto auto;
  z-index: -1;
}
html body main .sec-3 .contents-list-wrapper {
  display: grid;
  gap: 100px;
}
@media screen and (max-width: 767px) {
  html body main .sec-3 .contents-list-wrapper {
    gap: 45px;
  }
}
html body main .sec-3 .contents-list-wrapper .contents-list:first-child {
  display: grid;
  gap: 50px;
}
@media screen and (max-width: 767px) {
  html body main .sec-3 .contents-list-wrapper .contents-list:first-child {
    gap: 45px;
  }
}
html body main .sec-3 .contents-list-wrapper .contents-list:last-child p {
  text-align: center;
  font-size: 18px;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  html body main .sec-3 .contents-list-wrapper .contents-list:last-child p {
    font-size: 14px;
    margin-bottom: 13px;
  }
}
html body main .sec-4 {
  background-image: url("../../images/index/sec4-bg.png");
  background-repeat: repeat-y;
  background-position: center top;
}
html body main .sec-4 h2 {
  text-align: center;
  font-size: 40px;
  font-weight: 700;
  color: #000;
  margin-bottom: 12px;
}
@media screen and (max-width: 767px) {
  html body main .sec-4 h2 {
    font-size: 20px;
    margin-bottom: 18px;
  }
}
html body main .sec-4 p {
  text-align: center;
  color: #0A0607;
  margin-bottom: 75px;
}
@media screen and (max-width: 767px) {
  html body main .sec-4 p {
    font-size: 14px;
    margin-bottom: 35px;
  }
}
@media screen and (min-width: 576px) {
  html body main .sec-4 .slider {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px 40px;
  }
}
@media screen and (max-width: 575px) {
  html body main .sec-4 .slider .slick-next {
    right: -10px !important;
  }
  html body main .sec-4 .slider .slick-prev {
    left: -10px !important;
  }
  html body main .sec-4 .slider .slick-next:before {
    background: url("../../images/index/slick-arw-r.png") !important;
    background-size: contain !important;
  }
  html body main .sec-4 .slider .slick-prev:before {
    background: url("../../images/index/slick-arw-l.png") !important;
    background-size: contain !important;
  }
  html body main .sec-4 .slider .slick-arrow {
    z-index: 2 !important;
    width: 27.5px !important;
    height: 49.5px !important;
  }
  html body main .sec-4 .slider .slick-arrow:before {
    content: "" !important;
    width: 100% !important;
    height: 100% !important;
    position: absolute;
    top: 0;
    left: 0;
    opacity: 1 !important;
  }
}
html body main .sec-4 .slider + p {
  margin-top: 50px;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  html body main .sec-4 .slider + p {
    margin-top: 20px;
    font-size: 12px;
  }
}
html body main .sec-5 {
  background-color: #FBFADF;
  padding: 110px 0 200px;
}
@media screen and (min-width: 768px) {
  html body main .sec-5 {
    background-image: url("../../images/index/sec5-bg.png");
    background-repeat: no-repeat;
    background-position: center bottom;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-5 {
    padding: 60px 0;
  }
}
html body main .sec-5 h2 {
  text-align: center;
  font-weight: 700;
  font-size: 30px;
  margin-bottom: 40px;
}
@media screen and (max-width: 767px) {
  html body main .sec-5 h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
html body main .sec-5 .contents-list-wrapper {
  display: grid;
  gap: 30px;
}
html body main .sec-5 .contents-list-wrapper .contents-list:nth-child(2) {
  max-width: 670px;
  width: 100%;
  margin: auto auto 30px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  html body main .sec-5 .contents-list-wrapper .contents-list:nth-child(2) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}
html body main .sec-5 .contents-list-wrapper .contents-list:nth-child(2) p {
  font-size: 18px;
}
@media screen and (max-width: 767px) {
  html body main .sec-5 .contents-list-wrapper .contents-list:nth-child(2) p {
    font-size: 14px;
    width: calc(100% - 110px);
  }
}
html body main .sec-5 .btn-sec5 {
  max-width: 480px;
  width: 100%;
  margin: auto;
}
@media screen and (max-width: 767px) {
  html body main .sec-5 .btn-sec5 {
    max-width: 330px;
  }
}
html body main .sec-5 .btn-sec5 a {
  width: 100%;
  height: 60px;
  display: grid;
  place-content: center;
  border-radius: 60px;
  background-color: #fff;
  border: 2px solid #707070;
  color: #000;
  font-size: 18px;
  font-weight: 700;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
@media screen and (max-width: 767px) {
  html body main .sec-5 .btn-sec5 a {
    height: 50px;
    font-size: 14px;
  }
}
html body main .sec-5 .btn-sec5 a:hover {
  background-color: #E5E5E5;
}
html body main .sec-faq h2 {
  text-align: center;
  color: #000;
  font-weight: 700;
  font-size: 46px;
  margin-bottom: 35px;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq h2 {
    font-size: 20px;
    margin-bottom: 20px;
  }
}
html body main .sec-faq .faq-wrap {
  display: grid;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq .faq-wrap {
    gap: 20px;
  }
}
html body main .sec-faq .faq-wrap dl {
  border: 3px solid #000;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq .faq-wrap dl {
    border-width: 2px;
  }
}
html body main .sec-faq .faq-wrap dl dt {
  padding: 30px 30px 30px 55px;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq .faq-wrap dl dt {
    padding: 1rem 10px 1rem 35px;
    font-size: 16px;
  }
}
html body main .sec-faq .faq-wrap dl dt::before {
  content: "";
  position: absolute;
  background-image: url("../../images/index/ico-faq-dt.svg");
  background-repeat: no-repeat;
  background-size: 100% auto;
  width: 17px;
  height: 28px;
  top: 31px;
  bottom: 0;
  left: 28px;
  right: 0;
  margin: 0 auto auto 0;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq .faq-wrap dl dt::before {
    width: 12px;
    height: 19px;
    top: 19px;
    left: 12px;
  }
}
html body main .sec-faq .faq-wrap dl dd {
  background-color: #F0EFEF;
  padding: 25px 30px 30px 55px;
  font-size: 18px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  html body main .sec-faq .faq-wrap dl dd {
    padding: 1rem 10px;
    font-size: 14px;
  }
}
html body main .contents-news .contents-list {
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  html body main .contents-news .contents-list {
    margin-bottom: 20px;
  }
}
html body main .contents-news .contents-list:last-child {
  margin-bottom: 0;
}
html body main .contents-news .contents-list .label-wrapper {
  display: table;
  float: left;
}
@media screen and (max-width: 767px) {
  html body main .contents-news .contents-list .label-wrapper {
    float: none;
    margin-bottom: 5px;
  }
}
html body main .contents-news .contents-list .label-wrapper .single-time {
  font-weight: bold;
  display: table-cell;
  height: 100%;
  vertical-align: middle;
}
html body main .contents-news .contents-list .label-wrapper .category-tag {
  padding: 0;
  display: table-cell;
  height: 100%;
  vertical-align: middle;
}
html body main .contents-news .contents-list .label-wrapper .category-tag li {
  list-style-type: none;
  float: left;
  padding: 0 15px;
}
@media screen and (max-width: 767px) {
  html body main .contents-news .contents-list .label-wrapper .category-tag li {
    padding: 0 5px;
  }
}
html body main .contents-news .contents-list .label-wrapper .category-tag li a {
  display: inline-block;
  color: #fff;
  font-size: 0.75rem;
  font-weight: bold;
  background-color: #333;
  padding: 5px 8px;
  line-height: 1em;
}
@media screen and (max-width: 767px) {
  html body main .contents-news .contents-list .label-wrapper .category-tag li a {
    display: block;
  }
}
html body main .contents-news .contents-list a {
  display: inline-block;
}
@media screen and (max-width: 991px) {
  html body main .contents-news .contents-list a {
    font-size: 0.875rem;
  }
}
html body main .sec-contact {
  background-color: #82BE3C;
  padding: 45px 0 30px;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact {
    padding: 40px 0 50px;
  }
}
html body main .sec-contact p {
  text-align: center;
  color: #fff;
  font-weight: 500;
  font-size: 22px;
  margin-bottom: 25px;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact p {
    font-size: 16px;
    margin-bottom: 15px;
  }
}
html body main .sec-contact dl {
  margin-bottom: 0;
}
@media screen and (min-width: 768px) {
  html body main .sec-contact dl {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl {
    margin-bottom: 20px;
  }
}
html body main .sec-contact dl dt,
html body main .sec-contact dl dd {
  color: #fff;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl dt,
  html body main .sec-contact dl dd {
    text-align: center;
  }
}
html body main .sec-contact dl dt {
  font-weight: 700;
  font-size: 30px;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl dt {
    font-size: 16px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #fff;
  }
}
html body main .sec-contact dl dd {
  font-size: 22px;
}
@media screen and (min-width: 768px) {
  html body main .sec-contact dl dd {
    border-left: 1px solid #fff;
    padding-left: 28px;
    margin-left: 28px;
  }
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl dd {
    font-size: 16px;
  }
}
html body main .sec-contact dl dd span {
  display: block;
  font-size: 18px;
  margin-top: 7px;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl dd span {
    font-size: 14px;
  }
}
html body main .sec-contact dl dd span.tel {
  font-size: 48px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  html body main .sec-contact dl dd span.tel {
    display: none;
  }
}
html body main .sec-contact .nav-cta-sp-contact {
  padding-top: 30px;
  background-color: #fff;
}
@media screen and (min-width: 768px) {
  html body main .sec-contact .nav-cta-sp-contact {
    display: none;
  }
}
html body main .sec-contact .nav-cta-sp-contact p {
  margin-bottom: 6px;
  text-align: center;
  color: #000;
  font-size: 14px;
}
html body main .sec-contact .nav-btn-tel {
  width: 100%;
  margin: auto;
}
@media screen and (min-width: 768px) {
  html body main .sec-contact .nav-btn-tel {
    display: none;
  }
}
html body main .sec-contact .nav-btn-tel a {
  width: 100%;
  height: 70px;
  display: grid;
  place-content: center;
  border-radius: 70px;
  background-color: #fff;
  color: #82BE3C;
  font-size: 28px;
  font-weight: 700;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
  position: relative;
  z-index: 0;
}
html body main .sec-contact .nav-btn-tel a::before {
  content: "";
  position: absolute;
  width: calc(100% - 12px);
  height: calc(100% - 12px);
  border-radius: 70px;
  border: 3px solid #82BE3C;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto auto auto auto;
  z-index: -1;
}
@media screen and (max-width: 767px) {
  html body main .sec-form {
    padding: 30px 0 50px;
  }
}
html body main .sec-form p {
  text-align: center;
  font-size: 18px;
  margin-bottom: 1rem;
}
@media screen and (max-width: 767px) {
  html body main .sec-form p {
    font-size: 14px;
    margin-bottom: 13px;
  }
}
html body main .sec-form .nav-btn-contact {
  max-width: 700px;
  width: 100%;
  margin: auto;
}
html body main .sec-form .nav-btn-contact a {
  width: 100%;
  height: 100px;
  display: grid;
  place-content: center;
  border-radius: 100px;
  background-color: #fff;
  border: 3px solid #E70012;
  color: #E70012;
  font-size: 29px;
  font-weight: 700;
  -webkit-transition: 0.3s all ease;
  transition: 0.3s all ease;
}
@media screen and (max-width: 767px) {
  html body main .sec-form .nav-btn-contact a {
    height: 70px;
    font-size: 16px;
  }
}
html body main .sec-form .nav-btn-contact a:hover {
  background-color: #E70012;
  color: #fff;
}/*# sourceMappingURL=index.css.map */