@charset "UTF-8";
/* common
----------------------------------*/
.img {
  width: 100%;
}

a {
  display: block;
}

.tab {
  display: none !important;
}

.sp {
  display: none !important;
}

.sp_ib {
  display: none !important;
}

.sp_min {
  display: none !important;
}

table {
  width: 100%;
  table-layout: fixed;
}

td,
th {
  font-weight: normal;
  text-align: left;
}

.noLink a,
.noLink a:hover,
.noLink a img,
.noLink a:hover img {
  opacity: 0.6 !important;
  cursor: inherit;
}

.text_wh {
  color: #fff !important;
}

@media screen and (max-width: 1000px) {
  .tab {
    display: block !important;
  }
  .tab_non {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
  .tab {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
  .sp_ib {
    display: inline-block !important;
  }
  .inner {
    max-width: 100%;
    min-height: 0;
    padding: 0 6.667vw;
  }
}
.hvUnderbar a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #fff calc(100% - 1px), #fff 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position: 100%;
  transition: 0.3s background-size;
}

.hvUnderbarBk a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #373E45 calc(100% - 1px), #373E45 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position: 100%;
  transition: 0.3s background-size;
}

.hvUnderbargrn a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #8ec31f calc(100% - 1px), #8ec31f 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  background-position: 100%;
  transition: 0.3s background-size;
}

.hvUnderbar a:hover,
.hvUnderbarBk a:hover,
.hvUnderbarGrn a:hover {
  text-decoration: none;
  background-size: 100% 100%;
  background-position: 0;
}

.hvUnderbarRev a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #fff calc(100% - 1px), #fff 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transition: 0.3s background-size;
  background-position: 0;
}

.hvUnderbarRevBk a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #373E45 calc(100% - 1px), #373E45 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transition: 0.3s background-size;
  background-position: 0;
}

.hvUnderbarRevGrn a {
  display: inline;
  line-height: 1.6;
  background: linear-gradient(transparent calc(100% - 1px), #8ec31f calc(100% - 1px), #8ec31f 100%, transparent 100%);
  background-repeat: no-repeat;
  background-size: 100% 100%;
  transition: 0.3s background-size;
  background-position: 0;
}

.hvUnderbarRev a:hover,
.hvUnderbarRevBk a:hover,
.hvUnderbarRevGrn a:hover {
  text-decoration: none;
  background-size: 0% 100%;
  background-position: 100%;
}

@media screen and (max-width: 374px) {
  .sp_min {
    display: block;
  }
}
.fadeIn {
  opacity: 0;
}
.fadeIn.onAnim {
  -webkit-animation: fadein 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) both;
          animation: fadein 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) both;
}

.upIn,
.load_upIn,
.pa_upIn {
  opacity: 0;
}
.upIn.onAnim,
.load_upIn.onAnim,
.pa_upIn.onAnim {
  -webkit-animation: upin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) both;
          animation: upin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) both;
}

.rhIn,
.load_rhIn {
  opacity: 0;
}
.rhIn.onAnim,
.load_rhIn.onAnim {
  -webkit-animation: rhin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
          animation: rhin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
}

.lhIn,
.load_lhIn {
  opacity: 0;
}
.lhIn.onAnim,
.load_lhIn.onAnim {
  -webkit-animation: lhin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
          animation: lhin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
}

.smallIn,
.load_smallIn {
  transform: scale(1.05);
  transform-origin: top center;
}
.smallIn.onAnim,
.load_smallIn.onAnim {
  -webkit-animation: smallin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
          animation: smallin 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
}

.popIn,
.load_popIn,
.pa_popIn {
  transform: scale(0.9);
  transform-origin: center center;
  opacity: 0;
}
.popIn.onAnim,
.load_popIn.onAnim,
.pa_popIn.onAnim {
  -webkit-animation: popin 0.3s 1 cubic-bezier(0.17, 0.67, 0.55, 1.45) both;
          animation: popin 0.3s 1 cubic-bezier(0.17, 0.67, 0.55, 1.45) both;
}

@-webkit-keyframes fadein {
  0% {
    opacity: 0;
  }
  100%, to {
    opacity: 1;
  }
}

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100%, to {
    opacity: 1;
  }
}
@-webkit-keyframes upin {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes upin {
  0% {
    opacity: 0;
    transform: translateY(20px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@-webkit-keyframes rhin {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes rhin {
  0% {
    opacity: 0;
    transform: translateX(20px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@-webkit-keyframes lhin {
  0% {
    opacity: 0;
    transform: translateX(-30px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes lhin {
  0% {
    opacity: 0;
    transform: translateX(-30px);
  }
  100%, to {
    opacity: 1;
    transform: translateY(0);
  }
}
@-webkit-keyframes smallin {
  0% {
    transform: scale(1.05);
  }
  100%, to {
    transform: scale(1);
  }
}
@keyframes smallin {
  0% {
    transform: scale(1.05);
  }
  100%, to {
    transform: scale(1);
  }
}
@-webkit-keyframes popin {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  100%, to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes popin {
  0% {
    opacity: 0;
    transform: scale(0.9);
  }
  100%, to {
    opacity: 1;
    transform: scale(1);
  }
}
.D01 {
  -webkit-animation-delay: 0.1s !important;
          animation-delay: 0.1s !important;
  transition-delay: 0.1s !important;
}

.D02 {
  -webkit-animation-delay: 0.2s !important;
          animation-delay: 0.2s !important;
  transition-delay: 0.2s !important;
}

.D03 {
  -webkit-animation-delay: 0.3s !important;
          animation-delay: 0.3s !important;
  transition-delay: 0.3s !important;
}

.D04 {
  -webkit-animation-delay: 0.4s !important;
          animation-delay: 0.4s !important;
  transition-delay: 0.4s !important;
}

.D05 {
  -webkit-animation-delay: 0.5s !important;
          animation-delay: 0.5s !important;
  transition-delay: 0.5s !important;
}

.D06 {
  -webkit-animation-delay: 0.6s !important;
          animation-delay: 0.6s !important;
  transition-delay: 0.6s !important;
}

.D07 {
  -webkit-animation-delay: 0.7s !important;
          animation-delay: 0.7s !important;
  transition-delay: 0.7s !important;
}

.D08 {
  -webkit-animation-delay: 0.8s !important;
          animation-delay: 0.8s !important;
  transition-delay: 0.8s !important;
}

.D09 {
  -webkit-animation-delay: 0.9s !important;
          animation-delay: 0.9s !important;
  transition-delay: 0.9s !important;
}

.D10 {
  -webkit-animation-delay: 1s !important;
          animation-delay: 1s !important;
  transition-delay: 1s !important;
}

.D11 {
  -webkit-animation-delay: 1.1s !important;
          animation-delay: 1.1s !important;
  transition-delay: 1.1s !important;
}

.D12 {
  -webkit-animation-delay: 1.2s !important;
          animation-delay: 1.2s !important;
  transition-delay: 1.2s !important;
}

.D13 {
  -webkit-animation-delay: 1.3s !important;
          animation-delay: 1.3s !important;
  transition-delay: 1.3s !important;
}

.D14 {
  -webkit-animation-delay: 1.4s !important;
          animation-delay: 1.4s !important;
  transition-delay: 1.4s !important;
}

.D15 {
  -webkit-animation-delay: 1.5s !important;
          animation-delay: 1.5s !important;
  transition-delay: 1.5s !important;
}

.D16 {
  -webkit-animation-delay: 1.6s !important;
          animation-delay: 1.6s !important;
  transition-delay: 1.6s !important;
}

.D17 {
  -webkit-animation-delay: 1.7s !important;
          animation-delay: 1.7s !important;
  transition-delay: 1.7s !important;
}

.D18 {
  -webkit-animation-delay: 1.8s !important;
          animation-delay: 1.8s !important;
  transition-delay: 1.8s !important;
}

.D19 {
  -webkit-animation-delay: 1.9s !important;
          animation-delay: 1.9s !important;
  transition-delay: 1.9s !important;
}

.D20 {
  -webkit-animation-delay: 2s !important;
          animation-delay: 2s !important;
  transition-delay: 2s !important;
}

.D21 {
  -webkit-animation-delay: 2.1s !important;
          animation-delay: 2.1s !important;
  transition-delay: 2.1s !important;
}

.D22 {
  -webkit-animation-delay: 2.2s !important;
          animation-delay: 2.2s !important;
  transition-delay: 2.2s !important;
}

.D23 {
  -webkit-animation-delay: 2.3s !important;
          animation-delay: 2.3s !important;
  transition-delay: 2.3s !important;
}

.D24 {
  -webkit-animation-delay: 2.4s !important;
          animation-delay: 2.4s !important;
  transition-delay: 2.4s !important;
}

.D25 {
  -webkit-animation-delay: 2.5s !important;
          animation-delay: 2.5s !important;
  transition-delay: 2.5s !important;
}

.D26 {
  -webkit-animation-delay: 2.6s !important;
          animation-delay: 2.6s !important;
  transition-delay: 2.6s !important;
}

.D27 {
  -webkit-animation-delay: 2.7s !important;
          animation-delay: 2.7s !important;
  transition-delay: 2.7s !important;
}

.D28 {
  -webkit-animation-delay: 2.8s !important;
          animation-delay: 2.8s !important;
  transition-delay: 2.8s !important;
}

.D29 {
  -webkit-animation-delay: 2.9s !important;
          animation-delay: 2.9s !important;
  transition-delay: 2.9s !important;
}

.D30 {
  -webkit-animation-delay: 3s !important;
          animation-delay: 3s !important;
  transition-delay: 3s !important;
}

.circleUpIn {
  transition: 1.2s all;
  -webkit-clip-path: circle(0% at 50% 50%);
          clip-path: circle(0% at 50% 50%);
  transform: translate(0, 40px);
}
.circleUpIn.onAnim {
  -webkit-clip-path: circle(80% at 50% 50%);
          clip-path: circle(80% at 50% 50%);
  transform: translate(0, 0);
}

.clipLhIn {
  transition: 0.8s -webkit-clip-path ease;
  transition: 0.8s clip-path ease;
  transition: 0.8s clip-path ease, 0.8s -webkit-clip-path ease;
  -webkit-clip-path: polygon(0 -30%, 0 -30%, 0 130%, 0 130%);
          clip-path: polygon(0 -30%, 0 -30%, 0 130%, 0 130%);
  display: block;
}
.clipLhIn.onAnim {
  -webkit-clip-path: polygon(0 -30%, 100% -30%, 130% 130%, 0% 130%);
          clip-path: polygon(0 -30%, 100% -30%, 130% 130%, 0% 130%);
}

.clipRhIn {
  transition: 0.8s -webkit-clip-path ease;
  transition: 0.8s clip-path ease;
  transition: 0.8s clip-path ease, 0.8s -webkit-clip-path ease;
  -webkit-clip-path: polygon(100% -20%, 100% -20%, 100% 120%, 100% 120%);
          clip-path: polygon(100% -20%, 100% -20%, 100% 120%, 100% 120%);
  display: block;
}
.clipRhIn.onAnim {
  -webkit-clip-path: polygon(0 -20%, 100% -20%, 120% 120%, 0% 120%);
          clip-path: polygon(0 -20%, 100% -20%, 120% 120%, 0% 120%);
}

.clipDownIn {
  transition: 0.6s -webkit-clip-path ease;
  transition: 0.6s clip-path ease;
  transition: 0.6s clip-path ease, 0.6s -webkit-clip-path ease;
  -webkit-clip-path: polygon(-100% 0, 200% 0, 200% 0, -100% 0);
          clip-path: polygon(-100% 0, 200% 0, 200% 0, -100% 0);
}
.clipDownIn.onAnim {
  -webkit-clip-path: polygon(-100% 0, 200% 0, 200% 100%, -100% 100%);
          clip-path: polygon(-100% 0, 200% 0, 200% 100%, -100% 100%);
}

/* ---------------------------
	parts
--------------------------- */
/* ---------------------------
	Loader
--------------------------- */
#loader {
  position: fixed;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 99999;
  background: #ececec;
}

@media screen and (max-width: 767px) {
  #loader img {
    width: 32vw;
  }
}
.loaderOut {
  opacity: 1;
  transform: translateX(-50vw);
}

.loaded .loaderOut {
  -webkit-animation: slideIn 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
          animation: slideIn 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
}

.active.loaded .loaderOut {
  opacity: 0;
  -webkit-animation: slideOut 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
          animation: slideOut 0.5s 1 cubic-bezier(0.37, 0.53, 0.73, 0.87) forwards;
}

@-webkit-keyframes slideIn {
  0% {
    opacity: 1;
    transform: translateX(-50vw);
  }
  100%, to {
    opacity: 0;
    transform: translateX(200vw);
  }
}

@keyframes slideIn {
  0% {
    opacity: 1;
    transform: translateX(-50vw);
  }
  100%, to {
    opacity: 0;
    transform: translateX(200vw);
  }
}
@-webkit-keyframes slideOut {
  0% {
    opacity: 0;
    transform: translateX(-200vw);
  }
  100%, to {
    opacity: 1;
    transform: translateX(-50vw);
  }
}
@keyframes slideOut {
  0% {
    opacity: 0;
    transform: translateX(-200vw);
  }
  100%, to {
    opacity: 1;
    transform: translateX(-50vw);
  }
}
/* ---------------------------
	common
--------------------------- */
main {
  max-width: min(100vw, 1400px);
  margin: 0 auto;
  position: relative;
  display: flex;
  justify-content: flex-end;
}

body {
  overflow: hidden;
}
body.loaded {
  position: relative;
}
body.loaded.open {
  position: fixed;
  z-index: 1;
}

#contFixWrap {
  width: 100%;
  min-height: calc(var(--vh) * 100);
  box-sizing: border-box;
}
#contFixWrap div.inner {
  width: min(71.429vw, 1000px);
  box-sizing: border-box;
  margin-left: auto;
  padding-right: min(3.571vw, 50px);
}

div.ttlWrap h2 {
  font-family: "Alfa Slab One", serif;
  font-weight: 400;
  font-style: normal;
  font-size: min(3.571vw, 50px);
  letter-spacing: 0.08em;
  line-height: 1;
}
div.ttlWrap h2 em {
  color: #3B82C5;
}
div.ttlWrap h2 + p {
  font-size: min(1vw, 14px);
  font-weight: 700;
  display: flex;
  align-items: center;
  line-height: 1;
  margin-top: 0.4em;
}
div.ttlWrap h2 + p::before {
  content: "";
  width: min(1.714vw, 24px);
  height: min(1.714vw, 24px);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  margin-right: 0.3em;
}

#sec01 div.ttlWrap h2 + p::before {
  background-image: url(../img/icon_about.svg);
}

#sec02 div.ttlWrap h2 + p::before {
  background-image: url(../img/icon_news.svg);
}

#sec03 div.ttlWrap h2 + p::before {
  background-image: url(../img/icon_sports.svg);
}

#sec04 div.ttlWrap h2 + p::before {
  background-image: url(../img/icon_health.svg);
}

#sec05 div.ttlWrap h2 + p::before {
  background-image: url(../img/icon_contact.svg);
}

.note em {
  color: #3B82C5;
  font-weight: 700;
}

@media screen and (max-width: 767px) {
  main {
    max-width: 100%;
  }
  #contFixWrap {
    padding-top: 24vw;
  }
  #contFixWrap div.inner {
    width: 1000%;
    padding: 0 5.333vw;
  }
  div.ttlWrap h2 {
    font-size: 12vw;
  }
  div.ttlWrap h2 + p {
    font-size: 3.733vw;
  }
  div.ttlWrap h2 + p::before {
    width: 6.4vw;
    height: 6.4vw;
  }
}
/* ---------------------------
	Header
--------------------------- */
header {
  position: fixed;
  z-index: 200;
  top: min(3.571vw, 50px);
  left: calc((var(--vw) * 100 - var(--mw)) / 2 + min(3.571vw, 50px));
  box-sizing: border-box;
  background: #fff;
  width: min(21.429vw, 300px);
  padding: min(2.857vw, 40px);
  box-shadow: min(0.286vw, 4px) min(0.286vw, 4px) min(1.786vw, 25px) 0 rgb(225, 237, 243);
  border-radius: min(0.714vw, 10px);
  letter-spacing: 0;
}
header h1 {
  width: min(15.714vw, 220px);
}
header h1 a {
  transition: 0.3s all;
}
header h1 a:hover {
  opacity: 0.7;
}
header nav {
  position: relative;
  margin-top: min(2.857vw, 40px);
}
header nav ul li {
  font-weight: 700;
  line-height: 1.8;
}
header nav ul li a {
  transition: 0.3s color;
}
@media screen and (min-width: 769px) {
  header nav ul li a:hover {
    color: #3B82C5;
  }
}
header nav ul li ~ li {
  margin-top: min(1.429vw, 20px);
}
header nav ul li:first-child a::before {
  background-image: url(../img/icon_home.svg);
}
header nav ul li:nth-child(2) a::before {
  background-image: url(../img/icon_about.svg);
}
header nav ul li:nth-child(3) a::before {
  background-image: url(../img/icon_news.svg);
}
header nav ul li:nth-child(4) a::before {
  background-image: url(../img/icon_sports.svg);
}
header nav ul li:nth-child(5) a::before {
  background-image: url(../img/icon_health.svg);
}
header nav ul li.contact {
  margin-top: min(2.143vw, 30px);
}
header nav ul li.contact a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(15.571vw, 218px);
  height: min(4.643vw, 65px);
  border-radius: min(0.214vw, 3px);
  background: #D92872;
  color: #fff;
  transition: 0.3s background;
  border: 1px solid #D92872;
}
header nav ul li.contact a::before {
  background-image: url(../img/icon_contact.svg);
  margin-right: 0.5em;
}
@media screen and (min-width: 769px) {
  header nav ul li.contact a:hover {
    background: #fff;
    color: #D92872;
  }
  header nav ul li.contact a:hover::before {
    background-image: url(../img/icon_tel.svg);
  }
}
header nav ul a {
  display: flex;
  align-items: center;
}
header nav ul a::before {
  content: "";
  width: min(1.714vw, 24px);
  height: min(1.714vw, 24px);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  margin-right: 0.3em;
}

.trigger {
  display: none;
}

.menuBox {
  display: none;
}

@media screen and (max-width: 767px) {
  header {
    width: 100%;
    height: 24vw;
    padding: 5.333vw 5.333vw 2.667vw;
    box-sizing: border-box;
    top: 0;
    left: 0;
    border-radius: 0;
    box-shadow: none;
    display: flex;
    align-items: center;
    background: rgba(236, 236, 236, 0.9);
  }
  header h1 {
    width: 67.733vw;
  }
  header nav {
    display: none;
  }
  header.active {
    box-shadow: 1.067vw 1.067vw 1.333vw 0 rgba(0, 0, 0, 0.05);
  }
  header.open {
    background: rgba(236, 236, 236, 0);
    box-shadow: 1.067vw 1.067vw 1.333vw 0 rgba(0, 0, 0, 0);
  }
  header.open h1 {
    filter: brightness(5);
  }
  .trigger {
    display: block;
    width: 16vw;
    height: 16vw;
    border-radius: 2.667vw;
    position: fixed;
    top: 5.333vw;
    right: 5.333vw;
    z-index: 1000;
    background: #fff;
  }
  .trigger span {
    display: block;
    position: absolute;
    top: 4.267vw;
    left: 4.267vw;
    z-index: 20;
    width: 7.467vw;
    height: 0.8vw;
    border-radius: 0.533vw;
    background: #3B82C5;
    transition: 0.3s all;
  }
  .trigger span:last-of-type {
    top: 6.4vw;
  }
  .trigger p {
    position: absolute;
    line-height: 1;
    width: 100%;
    top: 9.6vw;
    left: 0;
    text-align: center;
    font-size: 2.667vw;
    font-weight: 700;
    letter-spacing: 0;
  }
  .trigger p em {
    color: #3B82C5;
  }
  .trigger p._close {
    display: none;
  }
  .trigger.open span {
    transform: rotate(45deg);
    top: 5.333vw;
  }
  .trigger.open span:last-of-type {
    transform: rotate(-45deg);
    top: 5.333vw;
  }
  .trigger.open p._menu {
    display: none;
  }
  .trigger.open p._close {
    display: block;
  }
  .menuBox {
    position: fixed;
    z-index: 100;
    width: 100%;
    height: calc(var(--vh) * 100);
    background-image: url(../img/bg_footer.svg), linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
    background-position: right -1px bottom -1px, 0 0;
    background-repeat: no-repeat, no-repeat;
    background-size: 53.333vw 27.2vw, 100% 100%;
    overflow: hidden;
  }
  .menuBox nav {
    transition: 0.3s all;
    transform: translateX(-100vw);
  }
  .menuBox a {
    color: #fff;
  }
  .menuBox div.menuWrap {
    margin-top: 26.667vw;
    height: calc(var(--vh) * 100 - 26.667vw);
    overflow: auto;
  }
  .menuBox ul {
    margin-top: 13.333vw;
    padding: 0 9.333vw 8vw;
  }
  .menuBox ul li {
    font-weight: 700;
    line-height: 1.8;
  }
  .menuBox ul li a {
    transition: 0.3s color;
  }
}
@media screen and (max-width: 767px) and (min-width: 769px) {
  .menuBox ul li a:hover {
    color: #3B82C5;
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li ~ li {
    margin-top: 9.333vw;
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li:first-child a::before {
    background-image: url(../img/icon_home.svg);
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li:nth-child(2) a::before {
    background-image: url(../img/icon_about.svg);
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li:nth-child(3) a::before {
    background-image: url(../img/icon_news.svg);
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li:nth-child(4) a::before {
    background-image: url(../img/icon_sports.svg);
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li:nth-child(5) a::before {
    background-image: url(../img/icon_health.svg);
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul li.contact {
    margin-top: 10.667vw;
  }
  .menuBox ul li.contact a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 17.333vw;
    border-radius: 0.8vw;
    background: #D92872;
    border: 1px solid #D92872;
  }
  .menuBox ul li.contact a::before {
    background-image: url(../img/icon_contact.svg);
    margin-right: 0.5em;
  }
}
@media screen and (max-width: 767px) {
  .menuBox ul a {
    display: flex;
    align-items: center;
  }
  .menuBox ul a::before {
    content: "";
    width: 6.4vw;
    height: 6.4vw;
    background-position: center center;
    background-repeat: no-repeat;
    background-size: contain;
    margin-right: 0.3em;
    filter: brightness(5);
  }
}
@media screen and (max-width: 767px) {
  .menuBox.open nav {
    transform: translateX(0);
  }
}
/* ---------------------------
	kvBox
--------------------------- */
#kvBox div.inner {
  display: flex;
  justify-content: space-between;
  margin-top: min(1.429vw, 20px);
  padding-right: 0;
}
#kvBox div.inner > div {
  width: min(32.5vw, 455px);
  margin-top: min(7.5vw, 105px);
}
#kvBox .catch {
  margin-top: min(2.857vw, 40px);
  font-size: min(1.429vw, 20px);
  font-weight: 700;
  color: #fff;
}
#kvBox .catch p {
  margin-top: min(0.714vw, 10px);
}
#kvBox .catch p span {
  display: inline-flex;
  align-items: center;
  padding: 0 min(1.429vw, 20px);
  background: linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
  height: min(3.571vw, 50px);
  border-radius: min(0.286vw, 4px);
}
#kvBox figure {
  width: min(36.071vw, 505px);
  margin-right: min(2.143vw, 30px);
}

@media screen and (max-width: 767px) {
  #kvBox div.inner {
    flex-direction: column-reverse;
    margin-top: 0vw;
    padding: 0 5.333vw;
  }
  #kvBox div.inner > div {
    width: 100%;
    margin-top: 2.667vw;
  }
  #kvBox .catch {
    margin-top: 4vw;
    font-size: 4.267vw;
    letter-spacing: 0.02em;
  }
  #kvBox .catch p {
    margin-top: 1.333vw;
  }
  #kvBox .catch p span {
    padding: 0 4vw;
    height: 10.133vw;
    border-radius: 1.067vw;
  }
  #kvBox figure {
    width: 72vw;
    margin: 0 auto;
  }
}
/* ---------------------------
	about us ~ News
--------------------------- */
div.sectionWrap {
  display: flex;
  justify-content: space-between;
  margin-top: min(2.857vw, 40px);
}

#sec01 {
  width: min(43.571vw, 610px);
}
#sec01 #fbH_base {
  margin-top: min(2.143vw, 30px);
}
#sec01 ul {
  display: flex;
  justify-content: space-between;
  margin-top: min(2.143vw, 30px);
}
#sec01 ul li {
  width: min(20.429vw, 286px);
  border: min(0.143vw, 2px) solid #373E45;
  border-radius: min(0.714vw, 10px);
  overflow: hidden;
  letter-spacing: 0.12em;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
#sec01 ul li > div {
  padding: min(2.143vw, 30px) min(2.143vw, 30px) min(1.786vw, 25px);
}
#sec01 ul li figure {
  margin-bottom: min(1.786vw, 25px);
  border-radius: min(0.357vw, 5px);
  overflow: hidden;
}
#sec01 ul li .aboutLink {
  background: #373E45;
}
#sec01 ul li .aboutLink a {
  color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  height: min(4.286vw, 60px);
  gap: 0.4em;
  transition: 0.3s all;
  transition: 0.3s color;
}
#sec01 ul li .aboutLink a::before, #sec01 ul li .aboutLink a::after {
  content: "";
  width: min(1.714vw, 24px);
  height: min(1.714vw, 24px);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
#sec01 ul li .aboutLink a::before {
  background-image: url(../img/icon_sp-support.svg);
}
#sec01 ul li .aboutLink a::after {
  background-image: url(../img/icon_arr-down.svg);
  transition: 0.3s all;
}
#sec01 ul li .aboutLink a span {
  width: 12.8em;
}
@media screen and (min-width: 769px) {
  #sec01 ul li .aboutLink a:hover {
    color: #3B82C5;
  }
  #sec01 ul li .aboutLink a:hover::after {
    transform: translateY(min(0.357vw, 5px));
  }
}
#sec01 ul li:last-child .aboutLink a::before {
  background-image: url(../img/icon_ht-support.svg);
}
#sec01 ul li:last-child .aboutLink a span {
  width: 11.8em;
}

#sec02 {
  width: min(21.429vw, 300px);
}
#sec02 #fbCont {
  margin: min(2.143vw, 30px) auto 0;
}

div.greetingBox {
  margin-top: min(3.571vw, 50px);
}
div.greetingBox h3 {
  background: linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
  font-size: min(1.429vw, 20px);
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  padding: 0 1em;
  height: min(4.286vw, 60px);
  border-radius: min(0.286vw, 4px);
}
div.greetingBox div.inner > div {
  display: flex;
  justify-content: space-between;
  margin-top: min(2.143vw, 30px);
}
div.greetingBox div.inner > div figure {
  width: min(18.571vw, 260px);
  border-radius: min(0.714vw, 10px);
  overflow: hidden;
}
div.greetingBox div.inner > div > div {
  width: min(46.429vw, 650px);
}
div.greetingBox div.noteBox {
  background: url(../img/bg_greeting.svg) center bottom no-repeat;
  background-size: min(17.857vw, 250px) auto;
}
div.greetingBox div.noteBox p ~ p {
  margin-top: 1em;
}
div.greetingBox div.noteBox em {
  font-weight: 700;
  color: #3B82C5;
}
div.greetingBox div.noteBox .ceo {
  font-weight: 700;
  display: flex;
  flex-direction: column;
  line-height: 1.4;
}
div.greetingBox div.noteBox .ceo span {
  font-size: min(1vw, 14px);
}
div.greetingBox div.noteBox .ceo b {
  font-size: min(1.429vw, 20px);
}

@media screen and (max-width: 767px) {
  div.sectionWrap {
    flex-direction: column;
    margin-top: 16vw;
  }
  #sec01 {
    width: 100%;
  }
  #sec01 #fbH_base {
    margin-top: 8vw;
  }
  #sec01 ul {
    flex-direction: column;
    margin-top: 8vw;
    gap: 5.333vw;
  }
  #sec01 ul li {
    width: 100%;
    border: 0.533vw solid #373E45;
    border-radius: 2.667vw;
  }
  #sec01 ul li > div {
    padding: 8vw 8vw 6.667vw;
  }
  #sec01 ul li figure {
    margin-bottom: 5.333vw;
    border-radius: 1.333vw;
  }
  #sec01 ul li .aboutLink a {
    height: 16vw;
  }
  #sec01 ul li .aboutLink a::before, #sec01 ul li .aboutLink a::after {
    width: 6.4vw;
    height: 6.4vw;
  }
  #sec02 {
    width: 100%;
    margin-top: 21.333vw;
  }
  #sec02 #fbCont {
    max-width: 500px;
    margin-top: 8vw;
  }
  div.greetingBox {
    margin-top: 16vw;
  }
  div.greetingBox div.inner {
    padding: 0 !important;
  }
  div.greetingBox h3 {
    font-size: 5.333vw;
    padding: 0 1em;
    height: 16vw;
    border-radius: 1.067vw;
  }
  div.greetingBox div.inner > div {
    flex-direction: column;
    margin-top: 8vw;
  }
  div.greetingBox div.inner > div figure {
    width: 69.333vw;
    border-radius: 2.667vw;
    margin: 0 auto;
  }
  div.greetingBox div.inner > div > div {
    width: 100%;
    margin-top: 8vw;
  }
  div.greetingBox div.noteBox {
    background: url(../img/bg_greeting.svg) center center no-repeat;
    background-size: 66.667vw auto;
  }
  div.greetingBox div.noteBox .ceo span {
    font-size: 3.733vw;
  }
  div.greetingBox div.noteBox .ceo b {
    font-size: 5.333vw;
  }
}
/* ---------------------------
	Active Title
--------------------------- */
#activTtl {
  height: min(23.571vw, 330px);
  width: calc(var(--vw) * 100);
  overflow: hidden;
  position: relative;
  margin-left: calc((var(--mw) - var(--vw) * 100) / 2);
  display: flex;
  justify-content: center;
}
#activTtl > div {
  position: relative;
  z-index: 20;
  width: min(71.429vw, 1000px);
  box-sizing: border-box;
  margin-left: auto;
  padding-right: min(3.571vw, 50px);
  margin-left: min(28.571vw, 400px);
}
#activTtl h2 {
  font-size: min(2.857vw, 40px);
  text-align: center;
  font-weight: 700;
  line-height: 1;
  margin-top: min(12.857vw, 180px);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: min(2.143vw, 30px);
}
#activTtl h2::after {
  content: "";
  width: min(3.571vw, 50px);
  height: min(0.214vw, 3px);
  background: #3B82C5;
}
#activTtl .scrollTxt {
  font-family: "Alfa Slab One", serif;
  font-weight: 400;
  font-style: normal;
  font-size: min(7.143vw, 100px);
  line-height: 1;
  position: absolute;
  top: calc(50% - min(3.571vw, 50px));
  left: 0;
  z-index: 10;
  width: 400vw;
}
#activTtl .scrollTxt span {
  display: inline-block;
  -webkit-animation: loop-list 15s linear infinite;
          animation: loop-list 15s linear infinite;
  padding-right: 0.3em;
  color: #fff;
}

@-webkit-keyframes loop-list {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}

@keyframes loop-list {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}
@media screen and (max-width: 767px) {
  #activTtl {
    height: 61.333vw;
    width: 100vw;
    margin-left: 0;
  }
  #activTtl > div {
    width: 100%;
    padding-right: 0;
    margin-left: 0;
  }
  #activTtl h2 {
    font-size: 6.4vw;
    margin-top: 32vw;
    gap: 8vw;
  }
  #activTtl h2::after {
    width: 13.333vw;
    height: 0.8vw;
  }
  #activTtl .scrollTxt {
    font-size: 18.667vw;
    top: calc(50% - 9.333vw);
    width: 2666.4vw;
  }
}
/* ---------------------------
	Sports
--------------------------- */
#sec03 div.slideWrap, #sec04 div.slideWrap {
  position: relative;
}
#sec03 div.infoBox, #sec04 div.infoBox {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  min-width: min(21.429vw, 300px);
}
#sec03 div.infoBox .ribbon, #sec04 div.infoBox .ribbon {
  display: flex;
  justify-content: center;
  align-items: center;
  width: min(19.286vw, 270px);
  height: min(3.214vw, 45px);
  background: #fff;
  border: 2px solid #3B82C5;
  color: #3B82C5;
  font-weight: 700;
  border-radius: min(0.286vw, 4px) min(0.286vw, 4px) min(0.286vw, 4px) 0;
  margin-top: min(3.571vw, 50px);
  position: relative;
}
#sec03 div.infoBox .ribbon::after, #sec04 div.infoBox .ribbon::after {
  content: "";
  width: 0;
  height: 0;
  border: min(0.429vw, 6px) solid transparent;
  border-bottom-color: #3B82C5;
  border-right-color: #3B82C5;
  display: block;
  position: absolute;
  bottom: -2px;
  left: -2px;
  z-index: 10;
  transform: scaleY(-1);
  transform-origin: left bottom;
}
#sec03 div.infoBox .catch, #sec04 div.infoBox .catch {
  margin-top: min(1.429vw, 20px);
  font-size: min(2.143vw, 30px);
  font-weight: 700;
  color: #fff;
}
#sec03 div.infoBox .catch p, #sec04 div.infoBox .catch p {
  margin-top: min(0.714vw, 10px);
}
#sec03 div.infoBox .catch p span, #sec04 div.infoBox .catch p span {
  display: inline-flex;
  align-items: center;
  padding: 0 min(1.786vw, 25px);
  background: linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
  height: min(4.286vw, 60px);
  border-radius: min(0.286vw, 4px);
}
#sec03 div.slideBox, #sec04 div.slideBox {
  width: min(44.286vw, 620px);
  margin-bottom: min(2.143vw, 30px);
  margin-left: auto;
  overflow: hidden;
}
#sec03 div.slideBox li, #sec04 div.slideBox li {
  position: relative;
}
#sec03 div.slideBox li figure, #sec04 div.slideBox li figure {
  padding-bottom: min(1.429vw, 20px);
}
#sec03 div.slideBox li figure img, #sec04 div.slideBox li figure img {
  display: block;
  border-radius: min(0.714vw, 10px);
  overflow: hidden;
  width: min(42.857vw, 600px);
  position: relative;
  z-index: 10;
}
#sec03 div.slideBox li figure::after, #sec04 div.slideBox li figure::after {
  content: "";
  width: min(42.857vw, 600px);
  aspect-ratio: 600/360;
  display: block;
  border-radius: min(0.714vw, 10px);
  overflow: hidden;
  background: linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
  opacity: 0.1;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 5;
}
#sec03 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec03 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal, #sec04 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec04 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal {
  width: auto;
}
#sec03 div.slideBox .swiper-pagination-bullet, #sec04 div.slideBox .swiper-pagination-bullet {
  background: #3B82C5;
  opacity: 0.15;
  transition: 0.3s all;
  width: min(0.714vw, 10px);
  height: min(0.714vw, 10px);
}
#sec03 div.slideBox .swiper-pagination-bullet-active, #sec04 div.slideBox .swiper-pagination-bullet-active {
  opacity: 1;
}
#sec03 ul.kindList, #sec04 ul.kindList {
  margin-top: min(4.286vw, 60px);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(1.786vw, 25px);
  position: relative;
}
#sec03 ul.kindList li.box, #sec04 ul.kindList li.box {
  width: min(21.429vw, 300px);
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  background: #fff;
  padding: 0 min(2.857vw, 40px) min(1.429vw, 20px);
  box-shadow: min(0.286vw, 4px) min(0.286vw, 4px) min(1.786vw, 25px) 0 rgb(225, 237, 243);
  border-radius: min(0.714vw, 10px);
  text-align: center;
  box-sizing: border-box;
}
#sec03 ul.kindList li.notice, #sec04 ul.kindList li.notice {
  order: 4;
  width: calc(min(21.429vw, 300px) - 1em);
  height: auto;
  margin-left: 1em;
  text-indent: -1em;
  font-size: min(1vw, 14px);
  line-height: 1.5;
  margin-top: max(-1.429vw, -20px);
}
#sec03 ul.kindList figure, #sec04 ul.kindList figure {
  width: min(5.714vw, 80px);
  margin-top: max(-2.143vw, -30px);
  margin-bottom: min(0.357vw, 5px);
}
#sec03 ul.kindList h4, #sec04 ul.kindList h4 {
  font-weight: 700;
  font-size: min(1.429vw, 20px);
  margin-bottom: min(0.571vw, 8px);
}

@media screen and (max-width: 767px) {
  #sec03 div.infoBox, #sec04 div.infoBox {
    position: static;
    min-width: 0;
    width: 100%;
  }
  #sec03 div.infoBox .ribbon, #sec04 div.infoBox .ribbon {
    width: 72vw;
    height: 9.333vw;
    border-radius: 1.067vw 1.067vw 1.067vw 0;
    margin-top: 8vw;
    font-size: 3.733vw;
  }
  #sec03 div.infoBox .ribbon::after, #sec04 div.infoBox .ribbon::after {
    border: 1.6vw solid transparent;
    border-bottom-color: #3B82C5;
    border-right-color: #3B82C5;
  }
  #sec03 div.infoBox .catch, #sec04 div.infoBox .catch {
    margin-top: 5.333vw;
    font-size: 6.4vw;
  }
  #sec03 div.infoBox .catch p, #sec04 div.infoBox .catch p {
    margin-top: 2.667vw;
  }
  #sec03 div.infoBox .catch p span, #sec04 div.infoBox .catch p span {
    padding: 0 6.667vw;
    height: 12.8vw;
    border-radius: 1.067vw;
  }
  #sec03 div.slideBox, #sec04 div.slideBox {
    width: calc(100% + 10.667vw);
    margin: 5.333vw -5.333vw 13.333vw;
  }
  #sec03 div.slideBox li, #sec04 div.slideBox li {
    position: relative;
  }
  #sec03 div.slideBox li figure, #sec04 div.slideBox li figure {
    padding-bottom: 5.333vw;
  }
  #sec03 div.slideBox li figure img, #sec04 div.slideBox li figure img {
    border-radius: 0;
    width: 100%;
  }
  #sec03 div.slideBox li figure::after, #sec04 div.slideBox li figure::after {
    display: none;
  }
  #sec03 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec03 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal, #sec04 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec04 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal {
    width: 100%;
    bottom: -4vw;
  }
  #sec03 div.slideBox .swiper-pagination-bullet, #sec04 div.slideBox .swiper-pagination-bullet {
    width: 2.667vw;
    height: 2.667vw;
  }
  #sec03 ul.kindList, #sec04 ul.kindList {
    margin-top: 8vw;
    display: flex;
    flex-direction: column;
    gap: 5.333vw;
  }
  #sec03 ul.kindList li.box, #sec04 ul.kindList li.box {
    width: 100%;
    padding: 5.333vw;
    box-shadow: 1.067vw 1.067vw 6.667vw 0 rgb(225, 237, 243);
    border-radius: 2.667vw;
    text-align: left;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
  #sec03 ul.kindList li.box > div, #sec04 ul.kindList li.box > div {
    width: 58.667vw;
  }
  #sec03 ul.kindList li.notice, #sec04 ul.kindList li.notice {
    order: 0;
    width: calc(100% - 1em);
    font-size: 3.733vw;
    line-height: 1.3;
    margin-top: -1.333vw;
    letter-spacing: 0.1em;
  }
  #sec03 ul.kindList figure, #sec04 ul.kindList figure {
    width: 14.933vw;
    margin: 0;
  }
  #sec03 ul.kindList h4, #sec04 ul.kindList h4 {
    font-size: 5.333vw;
    margin-bottom: 0vw;
  }
}
#sec04 {
  margin-top: min(5.714vw, 80px);
}
#sec04 div.infoBox {
  left: auto;
  right: 0;
}
#sec04 div.slideBox {
  margin-left: 0;
}
#sec04 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec04 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal {
  left: min(46.429vw, 650px);
}
#sec04 div.introBox {
  margin-top: min(7.143vw, 100px);
}
#sec04 div.introBox h3 {
  background: linear-gradient(to right, #5848ae 0%, #3f92d3 100%);
  font-size: min(1.429vw, 20px);
  font-weight: 700;
  color: #fff;
  display: flex;
  align-items: center;
  padding: 0 1em;
  height: min(4.286vw, 60px);
  border-radius: min(0.286vw, 4px);
}
#sec04 div.introBox div.facilityList {
  display: flex;
  justify-content: space-between;
  margin-top: min(2.143vw, 30px);
}
#sec04 div.introBox div.facilityList > div {
  width: min(32.857vw, 460px);
}
#sec04 div.introBox figure {
  border-radius: min(0.714vw, 10px);
  overflow: hidden;
  position: relative;
  margin-bottom: min(1.429vw, 20px);
}
#sec04 div.introBox figure figcaption {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #3B82C5;
  color: #fff;
  width: min(10.714vw, 150px);
  height: min(3.214vw, 45px);
  font-weight: 700;
  border-radius: 0 min(0.714vw, 10px) 0 0;
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 10;
  font-size: min(1.429vw, 20px);
}
#sec04 div.introBox ul {
  margin-top: 0.75em;
  padding-top: 1em;
  border-top: 1px dashed #3B82C5;
}
#sec04 div.introBox ul li {
  display: flex;
  align-items: center;
}
#sec04 div.introBox ul li::before {
  content: "";
  width: min(0.857vw, 12px);
  height: min(0.857vw, 12px);
  background: url(../img/check.svg) 0 0 no-repeat;
  background-size: contain;
  margin-right: 0.3em;
}
#sec04 div.introBox ul li ~ li {
  margin-top: 0.3em;
}
#sec04 div.introBox ul li.sale::after {
  content: "発売中";
  width: min(2.857vw, 40px);
  height: min(1.429vw, 20px);
  display: flex;
  justify-content: center;
  align-items: center;
  background: #D92872;
  color: #fff;
  font-size: min(0.714vw, 10px);
  border-radius: min(0.214vw, 3px);
  line-height: 1;
  margin-left: 0.5em;
}
#sec04 .otherBox {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: min(2.5vw, 35px);
  height: min(4.286vw, 60px);
  border-radius: min(0.714vw, 10px);
  background: #fff;
  box-shadow: min(0.286vw, 4px) min(0.286vw, 4px) min(1.786vw, 25px) 0 rgb(225, 237, 243);
}

@media screen and (max-width: 767px) {
  #sec04 {
    margin-top: 21.333vw;
  }
  #sec04 div.slideBox {
    margin: 5.333vw -5.333vw 13.333vw;
  }
  #sec04 div.slideBox .swiper-horizontal > .swiper-pagination-bullets, #sec04 div.slideBox .swiper-pagination-bullets.swiper-pagination-horizontal {
    left: 0;
  }
  #sec04 div.introBox {
    margin-top: 16vw;
  }
  #sec04 div.introBox h3 {
    font-size: 5.333vw;
    height: 16vw;
    border-radius: 1.067vw;
  }
  #sec04 div.introBox div.facilityList {
    flex-direction: column;
    gap: 8vw;
    margin-top: 8vw;
  }
  #sec04 div.introBox div.facilityList > div {
    width: 100%;
  }
  #sec04 div.introBox figure {
    border-radius: 2.667vw;
    margin-bottom: 5.333vw;
  }
  #sec04 div.introBox figure figcaption {
    width: 40vw;
    height: 12vw;
    border-radius: 0 2.667vw 0 0;
    font-size: 5.333vw;
  }
  #sec04 div.introBox ul {
    margin-top: 0.75em;
    padding-top: 1em;
    border-top: 1px dashed #3B82C5;
  }
  #sec04 div.introBox ul li {
    display: flex;
    align-items: center;
  }
  #sec04 div.introBox ul li::before {
    content: "";
    width: 3.2vw;
    height: 3.2vw;
    background: url(../img/check.svg) 0 0 no-repeat;
    background-size: contain;
    margin-right: 0.3em;
  }
  #sec04 div.introBox ul li ~ li {
    margin-top: 0.3em;
  }
  #sec04 div.introBox ul li.sale::after {
    content: "発売中";
    width: 10.667vw;
    height: 5.333vw;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #D92872;
    color: #fff;
    font-size: 2.667vw;
    border-radius: 0.8vw;
    line-height: 1;
    margin-left: 0.5em;
  }
  #sec04 .otherBox {
    margin-top: 9.333vw;
    height: 16vw;
    border-radius: 2.667vw;
    box-shadow: 1.067vw 1.067vw 6.667vw 0 rgb(225, 237, 243);
  }
}
/* ---------------------------
	Contact
--------------------------- */
#sec05 {
  margin-top: min(9.286vw, 130px);
  color: #fff;
  background: #D92872 url(../img/bg_contact.svg) 0 bottom no-repeat;
  background-size: min(35.714vw, 500px) auto;
  width: calc(var(--vw) * 100);
  margin-left: calc((var(--mw) - var(--vw) * 100) / 2);
}
#sec05 div.inner {
  margin-left: calc(min(28.571vw, 400px) - (var(--mw) - var(--vw) * 100) / 2);
  padding: min(7.143vw, 100px) min(3.571vw, 50px) min(7.143vw, 100px) 0;
  position: relative;
}
#sec05 div.inner::after {
  content: "";
  width: min(17.5vw, 245px);
  height: min(13.929vw, 195px);
  background: url(../img/img_contact.png) 0 0 no-repeat;
  background-size: contain;
  position: absolute;
  bottom: max(-1.429vw, -20px);
  left: 0;
  z-index: 10;
}
#sec05 div.contactWrap {
  display: flex;
  justify-content: space-between;
}
#sec05 div.contactWrap ul {
  width: min(42.857vw, 600px);
}
#sec05 div.contactWrap ul li ~ li {
  margin-top: min(2.857vw, 40px);
}
#sec05 h3 {
  display: flex;
  align-items: center;
  background: #fff;
  height: min(4.286vw, 60px);
  color: #D92872;
  border-radius: min(0.286vw, 4px);
  color: #D92872;
  padding: 0 min(1.786vw, 25px);
  font-size: min(1.429vw, 20px);
  font-weight: 700;
  box-sizing: border-box;
}
#sec05 h3::before {
  content: "";
  width: min(1.714vw, 24px);
  height: min(1.714vw, 24px);
  background-image: url(../img/icon_tel.svg);
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 0.5em;
}
#sec05 h3.mail::before {
  background-image: url(../img/icon_mail.svg);
}
#sec05 .telLink {
  font-family: "Alfa Slab One", serif;
  font-weight: 400;
  font-style: normal;
  font-size: min(3.286vw, 46px);
  letter-spacing: 0.08em;
  line-height: 1.8;
}
#sec05 .telLink a {
  color: #fff;
  pointer-events: none;
}
#sec05 .info {
  display: flex;
  margin-top: -0.3em;
}
#sec05 .info .center {
  font-weight: 700;
}
#sec05 .info .center a {
  display: inline-flex;
  color: #fff;
  pointer-events: none;
}
#sec05 .info .bis {
  margin-left: 1em;
}
#sec05 .info .bis span {
  display: inline-flex;
  align-items: center;
  border: 1px solid #fff;
  border-radius: min(0.214vw, 3px);
  font-size: min(1vw, 14px);
  font-weight: 700;
  margin-right: 0.5em;
  height: min(1.571vw, 22px);
  padding: 0 min(0.571vw, 8px);
}
#sec05 .mailLink {
  font-family: "Alfa Slab One", serif;
  font-weight: 400;
  font-style: normal;
  font-size: min(2vw, 28px);
  letter-spacing: 0.08em;
  line-height: 1.8;
  margin-top: min(0.714vw, 10px);
}
#sec05 .mailLink a {
  color: #fff;
  display: inline-flex;
  align-items: center;
  position: relative;
}
#sec05 .mailLink a::before {
  content: "";
  width: 100%;
  height: min(0.143vw, 2px);
  background: #fff;
  position: absolute;
  bottom: max(-0.143vw, -2px);
  left: 0;
  z-index: 10;
  transition: 0.3s all;
}
#sec05 .mailLink a::after {
  content: "";
  width: min(1.714vw, 24px);
  height: min(1.714vw, 24px);
  background: url(../img/icon_newwin.svg) center center no-repeat;
  background-size: contain;
  margin-left: 0.3em;
  transition: 0.3s all;
}
@media screen and (min-width: 769px) {
  #sec05 .mailLink a:hover::before {
    width: 0;
    left: 100%;
  }
  #sec05 .mailLink a:hover::after {
    transform: translate(2px, -2px);
  }
}

@media screen and (max-width: 767px) {
  #sec05 {
    margin: 21.333vw 0 0;
    background: #D92872 url(../img/bg_contact_sp.svg) right top no-repeat;
    background-size: 74.667vw auto;
    width: 100vw;
  }
  #sec05 div.inner {
    margin-left: 0;
    padding: 21.333vw 5.333vw 50.667vw;
    position: relative;
  }
  #sec05 div.inner::after {
    width: 65.333vw;
    height: 52vw;
    bottom: -5.333vw;
    left: calc(50% - 32.667vw);
  }
  #sec05 div.contactWrap {
    flex-direction: column;
  }
  #sec05 div.contactWrap div.ttlWrap {
    text-align: center;
  }
  #sec05 div.contactWrap div.ttlWrap p {
    justify-content: center;
  }
  #sec05 div.contactWrap ul {
    width: 100%;
    margin-top: 8vw;
  }
  #sec05 div.contactWrap ul li ~ li {
    margin-top: 8vw;
  }
  #sec05 h3 {
    justify-content: center;
    height: 16vw;
    border-radius: 1.067vw;
    padding: 0 6.667vw;
    font-size: 5.333vw;
  }
  #sec05 h3::before {
    width: 6.4vw;
    height: 6.4vw;
  }
  #sec05 .telLink {
    font-size: 8vw;
    text-align: center;
    line-height: 1.1;
    margin-top: 5.333vw;
  }
  #sec05 .telLink a {
    display: inline-block;
    position: relative;
    pointer-events: all;
  }
  #sec05 .telLink a::before {
    content: "";
    width: 100%;
    height: 0.533vw;
    background: #fff;
    position: absolute;
    bottom: -0.533vw;
    left: 0;
    z-index: 10;
    transition: 0.3s all;
  }
  #sec05 .info {
    flex-direction: column;
    text-align: center;
    margin-top: 4vw;
  }
  #sec05 .info .center a {
    display: inline-flex;
    color: #fff;
    pointer-events: all;
    position: relative;
  }
  #sec05 .info .center a::before {
    content: "";
    width: 100%;
    height: 0.267vw;
    background: #fff;
    position: absolute;
    bottom: 0.533vw;
    left: 0;
    z-index: 10;
    transition: 0.3s all;
  }
  #sec05 .info .bis {
    margin: 2.133vw 0 0;
  }
  #sec05 .info .bis span {
    border-radius: 0.8vw;
    font-size: 3.733vw;
    height: 5.867vw;
    padding: 0 2.133vw;
  }
  #sec05 .mailLink {
    font-size: 4.72vw;
    margin-top: 2.667vw;
  }
  #sec05 .mailLink a::before {
    height: 0.533vw;
    bottom: max(-0.143vw, -2px);
  }
  #sec05 .mailLink a::after {
    width: 6.4vw;
    height: 6.4vw;
  }
}
/* ---------------------------
	Footer
--------------------------- */
footer {
  padding: min(7.143vw, 100px) 0;
}
footer div.upper {
  display: flex;
  align-items: center;
  position: relative;
}
footer div.upper .logo {
  width: min(15vw, 210px);
  margin-right: min(3.214vw, 45px);
}
footer div.upper > div h3 {
  font-size: min(1.429vw, 20px);
  font-weight: 700;
  color: #3B82C5;
  line-height: 1;
}
footer div.upper > div h3 + p {
  font-size: min(0.714vw, 10px);
  margin-top: min(1.429vw, 20px);
}
footer div.upper #pageTop {
  width: min(4.143vw, 58px);
  height: min(4.143vw, 58px);
  display: flex;
  justify-content: center;
  align-items: center;
  background: #3B82C5;
  border: 1px solid #3B82C5;
  border-radius: min(0.357vw, 5px);
  margin-left: auto;
  transition: 0.3s all;
  cursor: pointer;
}
footer div.upper #pageTop span {
  width: 0;
  height: 0;
  border: min(0.571vw, 8px) solid transparent;
  border-bottom-color: #fff;
  transform: translateY(max(-0.286vw, -4px));
  transition: 0.3s all;
}
@media screen and (min-width: 769px) {
  footer div.upper #pageTop:hover {
    background: #fff;
  }
  footer div.upper #pageTop:hover span {
    border-bottom-color: #3B82C5;
  }
}
footer div.footerInfo {
  margin-top: min(4.286vw, 60px);
  padding-top: min(4.286vw, 60px);
  border-top: 1px solid #3B82C5;
  display: flex;
  justify-content: space-between;
  background-size: min(10.357vw, 145px) auto;
}
footer div.footerInfo > div {
  width: min(30.714vw, 430px);
}
footer div.footerInfo > div:last-of-type {
  width: min(32.857vw, 460px);
}
footer div.footerInfo dl ~ dl {
  margin-top: min(2.143vw, 30px);
}
footer div.footerInfo dt {
  font-weight: 700;
}
footer div.footerInfo dd {
  margin-top: 0.3em;
}
footer div.footerInfo dd span {
  display: inline-block;
}
footer div.footerInfo dd a {
  pointer-events: none;
  display: inline;
}

@media screen and (max-width: 767px) {
  footer {
    padding: 18.667vw 0 13.333vw;
    background: url(../img/bg_footer.svg) right -1px bottom -1px no-repeat;
    background-size: 145px auto;
  }
  footer div.inner {
    display: flex;
    flex-direction: column-reverse;
  }
  footer div.upper {
    position: relative;
    flex-direction: column;
    align-items: flex-start;
  }
  footer div.upper .logo {
    width: 67.733vw;
    margin-right: 0;
  }
  footer div.upper > div h3 {
    display: none;
  }
  footer div.upper > div h3 + p {
    font-size: 2.667vw;
    margin-top: 2.667vw;
  }
  footer div.upper #pageTop {
    position: absolute;
    width: 12.8vw;
    height: 12.8vw;
    border-radius: 1.333vw;
    top: 0;
    right: 0;
    z-index: 10;
  }
  footer div.upper #pageTop span {
    border: 1.6vw solid transparent;
    border-bottom-color: #fff;
    transform: translateY(-0.8vw);
  }
  footer div.footerInfo {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    margin-bottom: 10.667vw;
    padding-bottom: 10.667vw;
    border-bottom: 1px solid #3B82C5;
    flex-direction: column;
  }
  footer div.footerInfo > div {
    width: 100%;
  }
  footer div.footerInfo > div:last-of-type {
    width: 100%;
    margin-top: 8vw;
  }
  footer div.footerInfo dl ~ dl {
    margin-top: 8vw;
  }
  footer div.footerInfo dd a {
    pointer-events: all;
    text-decoration: underline;
  }
}
/*# sourceMappingURL=layout.css.map */