/* CSS Document */
/*
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com
Twitter: @rich_clark
*/
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	-webkit-text-size-adjust: 100%;/*smartphone*/
}
html {
	font-size: 62.5%;
}
body {
	line-height: 1.5;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
blockquote, q {
	quotes: none;
}
ul {
	list-style: none;
}
address, dl, dt, dd {
	font-style: normal;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}
a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
	text-decoration: none;
}
/* change colours to suit your needs */
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}
/* change colours to suit your needs */
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}
del {
	text-decoration: line-through;
}
abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/* change border colour to suit your needs */
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #cccccc;
	margin: 1em 0;
	padding: 0;
}
input, select {
	vertical-align: middle;
}
a img {
	border: none;
}
img {
	vertical-align: bottom
}
ol {
	padding-left: 2em;
}
#main section, #main aside {
	margin-bottom: 20px;
}
article,
aside,
footer,
header,
nav,
section,
main {
    display: block;
}

* {
    box-sizing: border-box;
}

*:before,
*:after {
    box-sizing: inherit;
}

@media screen and (min-width: 1080px) {
    .pc-none:not(:root) {
      display: none;
    }
  }
  
  @media screen and (max-width: 1079px) {
    .sp-none:not(:root) {
      display: none;
    }
  }
  
  @media (hover: hover) {
    .fv__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #333;
      transition: all 0.3s;
    }
    .fv__button:hover .feature__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .feature__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #fff;
      transition: all 0.3s;
    }
    .feature__button:hover .feature__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .companies__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #2D96DC;
      transition: all 0.3s;
    }
    .companies__button:hover .columns__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .flow__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #fff;
      transition: all 0.3s;
    }
    .flow__button:hover .feature__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .voices__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #fff;
      transition: all 0.3s;
    }
    .columns__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #2D96DC;
      transition: all 0.3s;
    }
    .columns__button:hover .columns__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .events__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #fff;
      transition: all 0.3s;
    }
    .events__button:hover .columns__icon {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .registration__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #fff;
      transition: all 0.3s;
    }
    .registration__button:hover .footer__img01 {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .footer__button:hover {
      box-shadow: 0 5px 8px 2px rgba(0, 0, 0, 0.14);
      transform: translateY(-2px);
      filter: brightness(110%);
      text-decoration: none;
      color: #2D96DC;
      transition: all 0.3s;
    }
    .footer__button:hover .footer__img01 {
      transition: all 0.3s;
      transform: translateX(3px);
    }
    .header__button01:hover {
      color: #2D96DC;
    }
    .header__button02:hover {
      background-color: #2D96DC;
      filter: brightness(110%);
      color: #fff;
    }
    .header__button03:hover {
      background-color: #fff;
      filter: brightness(110%);
      color: #2D96DC;
    }
  }
  .underline::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 46%;
  }
  @media screen and (min-width: 1080px) {
    .underline::after {
      width: 200px;
    }
  }
  
  .underline01::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 64%;
  }
  @media screen and (min-width: 1080px) {
    .underline01::after {
      width: 280px;
    }
  }
  
  .underline02::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 69%;
  }
  @media screen and (min-width: 1080px) {
    .underline02::after {
      width: 320px;
    }
  }
  
  .underline03-1::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 82%;
  }
  @media screen and (min-width: 1080px) {
    .underline03-1::after {
      width: 410px;
    }
  }
  
  .underline03::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 73%;
  }
  @media screen and (min-width: 1080px) {
    .underline03::after {
      width: 320px;
    }
  }
  
  .underline04::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 41%;
  }
  @media screen and (min-width: 1080px) {
    .underline04::after {
      width: 280px;
    }
  }
  
  .underline05::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 75%;
  }
  @media screen and (min-width: 1080px) {
    .underline05::after {
      width: 360px;
    }
  }
  
  .underline06::after {
    position: absolute;
    bottom: -21%;
    left: 50%;
    transform: translateX(-50%);
    content: "";
    display: block;
    background-color: #2D96DC;
    height: 5px;
    width: 60%;
  }
  @media screen and (min-width: 1080px) {
    .underline06::after {
      width: 230px;
    }
  }
  
  .header {
    padding: 5% 4% 4%;
    display: flex;
    justify-content: space-between;
  }
  @media screen and (min-width: 1080px) {
    .header {
      padding: 1.6% 9.4%;
      position: fixed;
      top: 0;
      left: auto;
      width: 100%;
      z-index: 10;
      background-color: #fff;
      z-index: 100;
    }
  }
  
  .header__group01 {
    width: 50%;
    
  }
  @media screen and (min-width: 1080px) {
    .header__group01 {
      cursor: pointer;
      width: 16%;
      white-space: nowrap;
    }
  }
  
  .header__group02 {
    width: 29%;
  }
  @media screen and (min-width: 1080px) {
    .header__group02 {
      display: flex;
      justify-content: space-between;
      align-items: center;
      width: 38.2%;
    }
  }
  
  @media screen and (min-width: 1080px) and (max-width: 1300px) {
    .header__group02 {
      width: 50%;
    }
  }
  .header__button01 {
    display: block;
    padding: 1% 1% 1%;
    font-size: 4.2666666667vw;
    font-weight: bold;
    color: #2D96DC;
    text-align: center;
  }
  @media screen and (min-width: 1080px) {
    .header__button01 {
      font-size: 16px;
    }
  }
  
  .header__button02 {
    transition: all 0.3s;
    display: block;
    border: 3px solid #2D96DC;
    border-radius: 5px;
    padding: 1% 1% 1%;
    font-size: 4.2666666667vw;
    font-weight: bold;
    color: #2D96DC;
    text-align: center;
  }
  @media screen and (min-width: 1080px) {
    .header__button02 {
      font-size: 16px;
      width: 28%;
    }
  }
  
  .header__button03 {
    transition: all 0.3s;
    display: block;
    border: 3px solid #2D96DC;
    background-color: #2D96DC;
    border-radius: 5px;
    padding: 1% 1% 1%;
    font-size: 4.2666666667vw;
    font-weight: bold;
    color: #fff;
    text-align: center;
  }
  @media screen and (min-width: 1080px) {
    .header__button03 {
      font-size: 16px;
      width: 28%;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .header__text01 {
      margin-top: 2%;
      font-size: 10px;
    }
  }
  
  .header__note {
    display: none;
    position: absolute;
    top: 0%;
    line-height: 1.2;
    left: 100%;
    padding: 4px;
    font-size: clamp(10px, 1vw, 10px);
    font-weight: bold;
    color: #2D96DC;
    border: 2px solid #2D96DC;
  }
  
  @media screen and (min-width: 1080px) and (max-width: 1366px) {
    .header__note {
      top: 0%;
      left: 110%;
    }
  }
  
  @media screen and (min-width: 1080px) {
  .header__group01:hover .header__note {
    display: block;
  }
  }
  
  @media screen and (max-width: 1079px) {
  .header__group01:hover .header__note {
    display: none;
  }
  }
  
  .fv {
    overflow: hidden;
  }
  
  .fv__inner {
    padding-top: 199%;
    background: #fff url(/images/top/fv_bg.png) no-repeat left 100%/100% 59%;
  }
  @media screen and (min-width: 1080px) {
    .fv__inner {
      padding-top: 668px;
      background: #fff url(/images/top/main_bg.png) no-repeat left 100%/100% 115%;
    }
  }
  
  .fv__title01 {
    font-size: 13.2vw;
    line-height: 1.2;
    font-weight: bold;
    color: #2D96DC;
    text-align: center;
    font-feature-settings: "palt";
    letter-spacing: 0.04em;
    position: absolute;
    top: 0.4%;
    left: 50%;
    width: 90%;
    z-index: 1;
  }
  @media screen and (max-width: 1079px) {
    .fv__title01 {
      transform: translate(-50%);
    }
  }
  @media screen and (min-width: 1080px) {
    .fv__title01 {
      font-size: 102px;
      top: 4.4%;
      left: 9.9%;
      width: auto;
    }
  }
  
  .fv__text01 {
    font-size: 3.2vw;
    font-feature-settings: "palt";
    letter-spacing: 0.01em;
    text-align: center;
    font-weight: bold;
    color: #fff;
    background-color: #2D96DC;
    padding: 1% 1% 1% 1%;
    width: 95%;
    position: absolute;
    top: 16.2%;
    left: 50%;
  }
  @media screen and (max-width: 1079px) {
    .fv__text01 {
      transform: translate(-50%);
    }
  }
  @media screen and (min-width: 1080px) {
    .fv__text01 {
      font-size: 20px;
      top: 40.2%;
      left: 9.9%;
      width: 570px;
      z-index: 1;
      padding: 12px 0 9px;
    }
  }
  
  .fv__text02 {
    font-size: 4vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .fv__text02 {
      font-size: 25px;
    }
  }
  
  .fv__text03 {
    width: 78%;
    position: absolute;
    top: 21.1%;
    left: 5%;
  }
  @media screen and (min-width: 1080px) {
    .fv__text03 {
      top: 62.1%;
      left: 9.9%;
      z-index: 1;
      width: auto;
    }
  }
  
  .fv__text04 {
    width: 40%;
    position: absolute;
    top: 69.9%;
    left: 4.7%;
  }
  @media screen and (min-width: 1080px) {
    .fv__text04 {
      top: 88.9%;
      left: 47.7%;
    }
  }
  
  .fv__text05 {
    width: 75%;
    position: absolute;
    top: 86.6%;
    left: 4.7%;
  }
  @media screen and (min-width: 1080px) {
    .fv__text05 {
      top: 95.6%;
      left: 67.2%;
      width: auto;
    }
  }
  
  .fv__img {
    position: absolute;
    top: 26%;
    right: 0%;
    width: 150%;
  }
  @media screen and (min-width: 1080px) {
    .fv__img {
      top: 0%;
      right: 2.9%;
      width: 60%;
      min-width: 813px;
    }
  }
  
  .fv__button {
    font-weight: bold;
    transition: all 0.3s;
    width: 100%;
    position: absolute;
    bottom: 0%;
    left: 0%;
    background-color: #FFFD45;
    padding: 5% 14% 6%;
    font-size: 5.3333333333vw;
    text-align: center;
    color: #333;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 8px;
  }
  @media screen and (min-width: 1080px) {
    .fv__button {
      font-size: 20px;
      width: 537px;
      border-radius: 14px;
      padding: 27px 132px 27px;
      bottom: 15.7%;
      left: 9.9%;
      background-color: #FFFD45;
    }
  }
  
  .fv__button.red {
    background-color: #E20B17;
    color: #fff;
  }
  
  @media screen and (min-width: 1080px) {
    .fv__img01 {
      width: 543px;
      height: 47px;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .fv__img02 {
      width: 279px;
      height: 38px;
    }
  }
  
  .floating {
    position: fixed;
    bottom: 0;
    left: auto;
    width: 100%;
    z-index: 10;
    background-color: #fff;
  }
  
  .spacer {
    padding-top: 90px;
  }
  
  .about {
    padding-top: 40px;
    padding-bottom: 8%;
    font-feature-settings: "palt";
    letter-spacing: 0.04em;
  }
  @media screen and (min-width: 1080px) {
    .about {
      padding: 100px 0 100px;
    }
  }
  
  .about__title01 {
    text-align: center;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .about__title01 {
      font-size: 40px;
    }
  }
  
  .about__text01 {
    text-align: center;
    font-weight: bold;
    font-size: 5.8666666667vw;
    margin-top: 46px;
    line-height: 1.4;
  }
  @media screen and (min-width: 1080px) {
    .about__text01 {
      font-size: 29px;
      margin-top: 42px;
    }
  }
  
  .about__text02 {
    font-size: 8.5333333333vw;
  }
  @media screen and (min-width: 1080px) {
    .about__text02 {
      font-size: 40px;
    }
  }
  
  .about__text03 {
    font-size: 8.5333333333vw;
    color: #E20000;
  }
  @media screen and (min-width: 1080px) {
    .about__text03 {
      font-size: 40px;
    }
  }
  
  .about__text04 {
    font-size: 1.1em;
    color: #E20000;
  }
  
  .about__text05 {
    font-size: 8.5333333333vw;
  }
  @media screen and (min-width: 1080px) {
    .about__text05 {
      font-size: 30px;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .about__text06 {
      font-size: 40px;
    }
  }
  
  .about__img01 {
    width: 87%;
    margin: 20px auto 0;
    display: block;
  }
  @media screen and (min-width: 1080px) {
    .about__img01 {
      width: 380px;
      margin: 0;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .about__inner {
      display: flex;
      justify-content: space-between;
      width: 1000px;
      margin: 35px auto 0;
    }
  }
  
  .about__inner01 {
    width: 91%;
    margin: 0 auto 0;
    border-radius: 30px;
    border: 5px solid #E3F3FE;
    padding: 5% 0% 5%;
  }
  @media screen and (min-width: 1080px) {
    .about__inner01 {
      width: 1000px;
      padding: 20px 0 18px;
    }
  }
  
  .about__title02 {
    text-align: center;
    font-size: 4.2666666667vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .about__title02 {
      font-size: 24px;
    }
  }
  
  .about__lists {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  @media screen and (min-width: 1080px) {
    .about__lists {
      margin-top: 28px;
    }
  }
  
  .about__list {
    width: 33.3333333333%;
    height: 62px;
    display: flex;
    justify-content: center;
  }
  @media screen and (min-width: 1080px) {
    .about__list {
      width: 16.6666666667%;
    }
  }
  
  .about__list img {
    align-items: center;
    -o-object-fit: contain;
       object-fit: contain;
  }
  
  .feature {
    padding: 8% 0 7.8%;
    background-color: #E3F3FF;
  }
  @media screen and (min-width: 1080px) {
    .feature {
      padding: 96px 0 100px;
    }
  }
  
  .feature__title01 {
    text-align: center;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .feature__title01 {
      font-size: 40px;
    }
  }
  
  .feature__title02 {
    text-align: center;
    font-size: 5.3333333333vw;
    font-weight: bold;
    color: #2E96DD;
    margin-top: 18px;
  }
  @media screen and (min-width: 1080px) {
    .feature__title02 {
      font-size: 20px;
    }
  }
  
  .feature__title03 {
    font-size: 16px;
    color: #2D96DC;
    text-align: center;
    font-weight: bold;
  }
  
  .feature__text01 {
    text-align: center;
    font-size: 3.7333333333vw;
    font-weight: bold;
    line-height: 1.4;
    margin-top: 38px;
  }
  @media screen and (min-width: 1080px) {
    .feature__text01 {
      font-size: 18px;
    }
  }
  
  .feature__text02 {
    font-size: 4vw;
    line-height: 1.5;
    margin-top: 24px;
  }
  @media screen and (min-width: 1080px) {
    .feature__text02 {
      font-size: 15px;
    }
  }
  
  .feature__lists {
    width: 100%;
  }
  @media screen and (min-width: 1080px) {
    .feature__lists {
      width: 1100px;
      margin: 42px auto 0;
      display: flex;
      justify-content: space-between;
    }
  }
  
  .feature__list {
    width: 81%;
    padding: 7% 6% 6%;
    background-color: #fff;
    border-radius: 16px;
  }
  @media screen and (max-width: 1079px) {
    .feature__list {
      margin: 8% auto 0;
    }
  }
  @media screen and (min-width: 1080px) {
    .feature__list {
      width: 344px;
      padding: 30px;
    }
  }
  
  .feature__img01 {
    width: 80%;
    margin: 0% auto 0;
    display: block;
  }
  
  .feature__img02 {
    width: 80%;
    margin: 0% auto 0;
    display: block;
  }
  
  .feature__img03 {
    width: 60%;
    margin: 0% auto 0;
    display: block;
  }
  
  .feature__box {
    margin: 40px auto 0;
    width: 344px;
    text-align: center;
  }
  
  .feature__button {
    font-weight: bold;
    transition: all 0.3s;
    background-color: #E20000;
    padding: 26px 28px 22px;
    font-size: 20px;
    text-align: center;
    color: #fff;
    border-radius: 14px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 8px;
  }
  
  .feature__icon {
    transition: all 0.3s;
  }
  @media screen and (min-width: 1080px) {
    .feature__icon {
      width: 13px;
    }
  }
  
  .companies {
    padding: 10% 0 6.4%;
    overflow: hidden;
  }
  @media screen and (min-width: 1080px) {
    .companies {
      padding: 95px 0 100px;
    }
  }
  
  .companies__title01 {
    text-align: center;
  }
  
  .companies__title02 {
    display: block;
    font-size: 4.2666666667vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .companies__title02 {
      font-size: 16px;
    }
  }
  
  .companies__title03 {
    display: block;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .companies__title03 {
      font-size: 40px;
    }
  }
  
  .companies__title04 {
    font-size: 3.7333333333vw;
    font-weight: bold;
    margin-top: 2%;
  }
  @media screen and (min-width: 1080px) {
    .companies__title04 {
      font-size: 14px;
    }
  }
  
  .companies__text01 {
    font-size: 2.6666666667vw;
    color: #2D96DC;
    margin-top: 16%;
  }
  @media screen and (min-width: 1080px) {
    .companies__text01 {
      font-size: 14px;
    }
  }
  
  @media screen and (max-width: 1079px) {
    .companies__lists {
      margin-top: 60px;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .companies__inner01 {
      width: 1100px;
      margin: 62px auto 0;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .company-slider {
      width: 1100px;
      margin: 62px auto 0;
      overflow: hidden;
    }
  }
  
  .companies__list {
    border: 4px solid #ddd;
    padding: 5% 5% 2%;
    border-radius: 10px;
    min-height: 90vw;
  
  }
  @media screen and (min-width: 1080px) {
    .companies__list {
      padding: 20px;
      min-height: 368px;
    }
  }
  
  .companies__img01 {
    width: 100%;
  }
  
  .companies__button {
    font-weight: bold;
    transition: all 0.3s;
    border-radius: 40px;
    border: 3px solid #2D96DC;
    font-size: 5.3333333333vw;
    font-weight: bold;
    padding: 2% 7%;
    margin: 28px auto 0;
    display: block;
    width: 52%;
    text-align: center;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  @media screen and (min-width: 1080px) {
    .companies__button {
      font-size: 22px;
      width: 234px;
      padding: 9px 47px;
      margin: 46px auto 0;
    }
  }
  
  .sharp-img-box {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 51vw;
  }
  @media screen and (min-width: 1080px) {
  .sharp-img-box {
    height: 203px;
  }
  }
  
  .flow {
    padding: 10% 0 14%;
    background-color: #E3F3FF;
  }
  @media screen and (min-width: 1080px) {
    .flow {
      padding: 103px 0 103px;
    }
  }
  
  .flow__title01 {
    text-align: center;
    font-size: 6.9333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .flow__title01 {
      font-size: 36px;
    }
  }
  
  .flow__title02 {
    font-size: 8.5333333333vw;
  }
  @media screen and (min-width: 1080px) {
    .flow__title02 {
      font-size: 40px;
    }
  }
  
  .flow__title03 {
    text-align: center;
    font-size: 8vw;
    font-weight: bold;
    color: #2E96DD;
    margin-top: 6%;
  }
  @media screen and (min-width: 1080px) {
    .flow__title03 {
      font-size: 30px;
      margin-top: 3%;
    }
  }
  
  .flow__title04 {
    font-size: 16px;
    color: #2D96DC;
    text-align: center;
    font-weight: bold;
  }
  
  .flow__text01 {
    font-size: 3.6vw;
    margin-top: 6%;
  }
  @media screen and (min-width: 1080px) {
    .flow__text01 {
      font-size: 15px;
    }
  }
  
  .flow__lists {
    width: 80%;
    margin: 13% auto 0;
    display: flex;
    justify-content: space-between;
    flex-direction: column;
  }
  @media screen and (max-width: 1079px) {
    .flow__lists {
      height: 296vw;
    }
  }
  @media screen and (min-width: 1080px) {
    .flow__lists {
      width: 1100px;
      flex-direction: row;
      align-items: center;
      margin-top: 66px;
    }
  }
  
  .flow__list {
    padding: 3% 9%;
    background-color: #fff;
  }
  @media screen and (min-width: 1080px) {
    .flow__list {
      width: 330px;
      padding: 11px 23px 0;
      min-height: 410px;
    }
  }
  
  .flow__list.arrow {
    background-color: transparent;
  }
  @media screen and (min-width: 1080px) {
    .flow__list.arrow {
      width: 26px;
      padding: 0;
    }
  }
  
  .flow__img01 {
    width: 17%;
    display: block;
    margin: 0 auto;
  }
  
  .flow__img02 {
    width: 100%;
    display: block;
    margin: 4% auto 0;
  }
  @media screen and (min-width: 1080px) {
    .flow__img02 {
      margin: 0;
    }
  }
  
  .flow__img03 {
    width: 17%;
    display: block;
    margin: 0 auto;
  }
  @media screen and (min-width: 1080px) {
    .flow__img03 {
      width: 100%;
      margin-top: 190px;
    }
  }
  
  .flow__img04 {
    width: 85%;
    display: block;
    margin: 4% auto 0;
  }
  @media screen and (min-width: 1080px) {
    .flow__img04 {
      width: 83%;
      margin: 0% auto 0;
    }
  }
  
  .flow__button {
    font-weight: bold;
    transition: all 0.3s;
    background-color: #E20000;
    padding: 30px 0 28px;
    font-size: 22px;
    text-align: center;
    color: #fff;
    border-radius: 14px;
    display: block;
    margin: 14px auto 0;
    width: 334px;
    padding: 26px 28px 22px;
    font-size: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .flow__box {
    margin: 40px auto 0;
    width: 344px;
    text-align: center;
  }
  
  .voices {
    padding: 8% 0 8%;
  }
  @media screen and (min-width: 1080px) {
    .voices {
      padding: 103px 0 121px;
    }
  }
  
  .voices__title01 {
    text-align: center;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .voices__title01 {
      font-size: 40px;
    }
  }
  
  .voices__title02 {
    font-size: 4.2666666667vw;
    font-weight: bold;
    color: #2E96DD;
    line-height: 1.4;
  }
  @media screen and (min-width: 1080px) {
    .voices__title02 {
      font-size: 18px;
    }
  }
  
  .voices__title03 {
    text-align: center;
    font-size: 3.7333333333vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .voices__title03 {
      font-size: 16px;
    }
  }
  
  .voices__text01 {
    font-size: 3.7333333333vw;
    margin-top: 3%;
    line-height: 1.6;
  }
  @media screen and (min-width: 1080px) {
    .voices__text01 {
      font-size: 16px;
    }
  }
  
  .voices__text02 {
    text-align: center;
    font-size: 2.6666666667vw;
    margin-top: 3%;
  }
  @media screen and (min-width: 1080px) {
    .voices__text02 {
      font-size: 11px;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .voices__inner {
      width: 1000px;
      margin: 60px auto 0;
    }
  }
  
  .voices__group01 {
    display: flex;
    justify-content: space-between;
    width: 90%;
  }
  @media screen and (max-width: 1079px) {
    .voices__group01 {
      margin: 60px auto 0;
    }
  }
  @media screen and (min-width: 1080px) {
    .voices__group01 {
      width: 100%;
    }
  }
  
  .voices__group01 + .voices__group01 {
    margin-top: 21px;
  }
  @media screen and (min-width: 1080px) {
    .voices__group01 + .voices__group01 {
      margin-top: 48px;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .voices__group01:last-of-type {
      margin-top: 50px;
    }
  }
  
  .voices__group01.reverse {
    flex-direction: row-reverse;
  }
  
  .voices__inner01 {
    position: relative;
    width: 74%;
    border-radius: 25px;
    border: 3px solid #CCEEF7;
    padding: 4%;
  }
  @media screen and (min-width: 1080px) {
    .voices__inner01 {
      width: 772px;
      padding: 26px 38px 26px;
    }
  }
  
  .voices__inner01.yellow {
    border: 3px solid #F0F097;
  }
  
  .voices__inner01.red {
    border: 3px solid #F7CCDD;
  }
  
  .voices__inner02 {
    width: 22%;
  }
  @media screen and (max-width: 1079px) {
    .voices__inner02 {
      margin-top: 5%;
    }
  }
  @media screen and (min-width: 1080px) {
    .voices__inner02 {
      width: 150px;
    }
  }
  
  .voices__img01 {
    display: block;
    margin: 0 auto;
    width: 100%;
  }
  
  .voices__img02 {
    position: absolute;
    top: 10%;
    left: 100%;
    width: 7%;
  }
  @media screen and (min-width: 1080px) {
    .voices__img02 {
      top: 40%;
    }
  }
  
  .voices__img03 {
    position: absolute;
    top: 10%;
    right: 100%;
    width: 7%;
  }
  @media screen and (min-width: 1080px) {
    .voices__img03 {
      top: 40%;
    }
  }
  
  .voices__img05 {
    position: absolute;
    top: 10%;
    left: 100%;
    width: 7%;
  }
  @media screen and (min-width: 1080px) {
    .voices__img05 {
      top: 40%;
    }
  }
  
  .events {
    overflow: hidden;
    padding: 8% 0 8%;
    background-color: #E3F3FE;
  }
  @media screen and (min-width: 1080px) {
    .events {
      padding: 103px 0 98px;
    }
  }
  
  .events__title01 {
    text-align: center;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .events__title01 {
      font-size: 32px;
    }
  }
  
  .events__title02 {
    font-size: 3.2vw;
    font-weight: bold;
    margin-top: 2%;
  }
  @media screen and (min-width: 1080px) {
    .events__title02 {
      font-size: 12px;
    }
  }
  
  .events__text01 {
    font-size: 2.6666666667vw;
    margin-top: 30px;
  }
  @media screen and (min-width: 1080px) {
    .events__text01 {
      font-size: 10px;
    }
  }
  
  .events__button {
    font-weight: bold;
    transition: all 0.3s;
    display: block;
    background-color: #F58448;
    padding: 30px 0 30px;
    color: #fff;
    text-align: center;
    margin: 40px auto 0;
    width: 80%;
    font-size: 5.3333333333vw;
    border-radius: 14px;
  }
  @media screen and (min-width: 1080px) {
    .events__button {
      width: 344px;
      font-size: 22px;
    }
  }
  
  .events__inner01 {
    padding: 5% 0 96px;
    background-color: #fff;
    width: 90%;
    margin: 7% auto 0;
  }
  @media screen and (min-width: 1080px) {
    .events__inner01 {
      width: 1100px;
      margin: 62px auto 0;
      padding: 37px 0 96px;
    }
  }
  
  .events__list {
    border: 4px solid #ddd;
    padding: 5%;
    border-radius: 10px;
  }
  @media screen and (min-width: 1080px) {
    .events__list {
      padding: 20px;
    }
  }
  
  .events__img01 {
    width: 100%;
  }
  
  @media screen and (min-width: 1080px) {
    .event-slider {
      width: 1100px;
      overflow: hidden;
    }
  }
  
  .swiper-button-next, .swiper-button-prev {
    top: 115% !important;
  }
  
  @media screen and (min-width: 768px) {
    .swiper-button-next, .swiper-button-prev {
      top: 112% !important;
    }
  }
  @media screen and (min-width: 1080px) {
    .swiper-button-next, .swiper-button-prev {
      top: 122% !important;
    }
  }
  .swiper-button-next.abc {
    right: 0 !important;
  }
  
  .swiper-button-prev.abc {
    left: 0 !important;
  }
  
  .swiper-button-next.abc, .swiper-button-prev.abc {
    top: 81% !important;
  }
  @media screen and (min-width: 768px) {
    .swiper-button-next.abc, .swiper-button-prev.abc {
      top: 90% !important;
    }
  
  .swiper-button-next.abc {
    right: 54px !important;
  }
  
  .swiper-button-prev.abc {
    left: 54px !important;
  }
  
  }
  @media screen and (min-width: 1080px) {
    .swiper-button-next.abc, .swiper-button-prev.abc {
      top: 86% !important;
    }
  }
  
  .swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
    bottom: 40px !important;
  }
  
  .swiper-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet, .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 10px !important;
  }
  
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
      left: 50% !important;
      width: 90% !important;
      transform: translateX(-50%) !important;
  }
  @media screen and (min-width: 375px) {
  .swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
      left: 50% !important;
      width: 84% !important;
      transform: translateX(-50%) !important;
  }
  }
  
  .swiper-pagination-bullet-active {
    width: 16px !important;
    height: 16px !important;
    background-color: #2E96DD !important;
    border: 3px solid #2E96DD !important;
  }
  
  .swiper-pagination-bullet:not(:root) {
    width: 16px !important;
    height: 16px !important;
    border: 3px solid #2E96DD;
    background-color: #fff;
    opacity: 1;
  }
  
  .columns {
    padding: 7% 0 9.7%;
    overflow: hidden;
  }
  @media screen and (min-width: 1080px) {
    .columns {
      padding: 103px 0 102px;
    }
  }
  
  .columns__title01 {
    text-align: center;
  }
  
  .columns__title02 {
    display: block;
    font-size: 4.2666666667vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .columns__title02 {
      font-size: 16px;
    }
  }
  
  .columns__title03 {
    display: block;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (max-width: 1079px) {
    .columns__title03 {
      margin-top: 3%;
    }
  }
  @media screen and (min-width: 1080px) {
    .columns__title03 {
      font-size: 40px;
    }
  }
  
  .columns__title04 {
    display: block;
    font-size: 3.2vw;
    margin-top: 12px;
  }
  @media screen and (min-width: 1080px) {
    .columns__title04 {
      font-size: 12px;
    }
  }
  
  .columns__inner01 {
    background-color: #E3F3FE;
    padding: 4% 5% 8%;
    width: 90%;
    margin: 46px auto 0;
  }
  @media screen and (min-width: 1080px) {
    .columns__inner01 {
      width: 1100px;
      padding: 29px 25px 47px;
      margin-top: 57px;
    }
  }
  
  .columns__lists {
    display: flex;
    justify-content: space-between;
  }
  @media screen and (max-width: 1079px) {
    .columns__lists {
      flex-wrap: wrap;
    }
  }
  
  .columns__list {
    background-color: #fff;
    padding: 1%;
    width: calc(50% - 12px);
    min-height: 40vw;
  }
  @media screen and (min-width: 1080px) {
    .columns__list {
      width: calc(25% - 18px);
      min-height: 230px;
      padding: 19px 15px 0;
    }
  }
  
  @media screen and (max-width: 1079px) {
    .columns__list:nth-of-type(n+3) {
      margin-top: 12px;
    }
  }
  
  .columns__img01 {
    width: 100%;
  }
  
  .columns__title02 {
    font-size: 3.7333333333vw;
  }
  @media screen and (max-width: 1079px) {
    .columns__title02 {
      margin-top: 1%;
    }
  }
  @media screen and (min-width: 1080px) {
    .columns__title02 {
      font-size: 16px;
    }
  }
  
  .columns__button {
    font-weight: bold;
    transition: all 0.3s;
    background-color: #fff;
    border-radius: 40px;
    border: 3px solid #2D96DC;
    font-size: 5.3333333333vw;
    font-weight: bold;
    padding: 2% 12%;
    margin: 28px auto 0;
    display: block;
    width: 71%;
    text-align: center;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  @media screen and (min-width: 1080px) {
    .columns__button {
      font-size: 22px;
      width: 234px;
      margin-top: 32px;
      padding: 9px 47px;
    }
  }
  
  .columns__icon {
    width: 7%;
    transition: all 0.3s;
  }
  
  .faq {
    padding: 8% 0 9.3%;
    background-color: #E3F3FF;
  }
  @media screen and (min-width: 1080px) {
    .faq {
      padding: 103px 0 102px;
    }
  }
  
  .faq__title01 {
    text-align: center;
    font-size: 8.5333333333vw;
    font-weight: bold;
    color: #2E96DD;
  }
  @media screen and (min-width: 1080px) {
    .faq__title01 {
      font-size: 32px;
    }
  }
  
  .faq__title02 {
    padding-left: 1em;
    text-indent: -1em;
    font-size: 3.4666666667vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .faq__title02 {
      font-size: 18px;
    }
  }
  
  .faq__text01 {
    padding-left: 1em;
    text-indent: -1em;
    font-size: 3.7333333333vw;
    margin-top: 28px;
  }
  @media screen and (min-width: 1080px) {
    .faq__text01 {
      font-size: 16px;
    }
  }
  
  .faq__lists {
    width: 90%;
    margin: 60px auto 0;
  }
  @media screen and (min-width: 1080px) {
    .faq__lists {
      width: 1100px;
      margin-top: 56px;
    }
  }
  
  .faq__inner01 {
    background-color: #fff;
    padding: 5% 13% 5% 5%;
  }
  @media screen and (min-width: 1080px) {
    .faq__inner01 {
      cursor: pointer;
      padding: 17px 17px 17px 50px;
    }
  }
  
  .faq__inner01 + .faq__inner01 {
    margin-top: 8px;
  }
  @media screen and (min-width: 1080px) {
    .faq__inner01 + .faq__inner01 {
      margin-top: 10px;
    }
  }
  
  .faq__img01 {
    position: absolute;
    top: 32%;
    right: -9%;
    transition: all 0.3s;
  }
  @media screen and (min-width: 1080px) {
    .faq__img01 {
      top: 29%;
      right: 3.2%;
    }
  }
  
  .faq__img01.open {
    transform: rotate(-180deg);
    transition: all 0.3s;
  }
  
  .registration {
    padding: 12% 0 11.5%;
    background: #fff url("/images/top/registration_bg01.png") no-repeat left top/cover;
  }
  @media screen and (min-width: 1080px) {
    .registration {
      padding: 103px 0 103px;
    }
  }
  
  .registration__title01 {
    text-align: center;
    font-size: 9.6vw;
    font-weight: bold;
  }
  @media screen and (min-width: 1080px) {
    .registration__title01 {
      font-size: 40px;
    }
  }
  
  .registration__button {
    font-weight: bold;
    transition: all 0.3s;
    background-color: #E20000;
    padding: 30px 34px 28px;
    font-size: 22px;
    text-align: center;
    color: #fff;
    border-radius: 14px;
    display: block;
    margin: 22px auto 0;
    width: 344px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  
  .footer {
    background-color: #F5F5F5;
    padding: 8% 0% 0%;
  }
  @media screen and (min-width: 1080px) {
    .footer {
      padding: 41px 0 0;
    }
  }
  
  .footer__inner {
    width: 90%;
    margin: 0 auto;
  }
  @media screen and (min-width: 1080px) {
    .footer__inner {
      display: flex;
      justify-content: space-between;
    }
  }
  
  .footer__bold {
    font-weight: bold;
  }
  
  .footer__list {
    font-size: 3.2vw;
  }
  @media screen and (min-width: 1080px) {
    .footer__list {
      font-size: 13px;
    }
  }
  
  .footer__list.btn {
    width: 100%;
    margin-bottom: 14px;
  }
  
  .footer__list.sns {
    width: 33%;
  }
  
  .footer__list + .footer__list {
    margin-top: 15px;
  }
  
  @media screen and (min-width: 1080px) {
    .footer__list.copy + .footer__list.copy {
      margin-top: 0;
      margin-left: 20px;
    }
  }
  
  @media screen and (max-width: 1079px) {
    .footer__lists + .footer__lists {
      margin-top: 38px;
    }
  }
  
  .footer__button {
    transition: all 0.3s;
    font-weight: bold;
    background-color: #fff;
    padding: 5% 14% 6%;
    font-size: 4.2666666667vw;
    color: #2D96DC;
    width: 87%;
    margin: 0 auto;
    display: block;
    text-align: center;
    border-radius: 24px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  @media screen and (min-width: 1080px) {
    .footer__button {
      font-size: 16px;
      padding: 5% 22% 6%;
    }
  }
  
  .footer__sns {
    font-size: 3.7333333333vw;
    font-weight: bold;
    display: block;
    margin-bottom: 15px;
  }
  @media screen and (min-width: 1080px) {
    .footer__sns {
      font-size: 14px;
    }
  }
  
  .footer__lists.copyright {
    background-color: #464646;
    margin-top: 30px;
    padding: 8% 4% 8%;
    color: #fff;
    margin-bottom: 0;
    font-weight: bold;
    font-size: 2.6666666667vw;
  }
  @media screen and (min-width: 1080px) {
    .footer__lists.copyright {
      font-size: 12px;
      padding: 27px 0 21px;
    }
  }
  
  .footer__list.text {
    margin-top: 32px;
    text-align: center;
  }
  @media screen and (min-width: 1080px) {
    .footer__list.text {
      margin-top: 0;
      text-align: left;
      margin-left: auto;
    }
  }
  
  @media screen and (min-width: 1080px) {
    .footer__inner01 {
      width: 1100px;
      margin: 0 auto;
      display: flex;
      align-items: center;
    }
  }
  
  .footer__img {
    width: 40%;
  }
  
  .footer__img01 {
    width: 4%;
    transition: all 0.3s;
  }
  
  @media screen and (min-width: 1080px) {
    .footer__inner .footer__lists:last-of-type {
      width: 461px;
    }
  }
  
  .floating__button {
    font-weight: bold;
    transition: all 0.3s;
    width: 100%;
    position: absolute;
    bottom: 0%;
    left: 0%;
    background-color: #E20B17;
    padding: 4% 25% 4%;
    font-size: 3.733333vw;
    text-align: center;
    color: #fff;
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 8px;
  }
  
  .floating__icon {
    width: 67%;
  }
  
  @media screen and (min-width: 768px) and (max-width: 1079px) {
    .floating__icon {
      width: 100%;
    }
  }
  body {
  position: relative;
  margin: 0;
  background: #ffffff;
}

a {
  text-decoration: none;
  transition: all 0.3s ease;
  cursor: pointer;
}

#wrapper {
  overflow: hidden;
}

img {
  max-width: 100%;
  height: auto;
}

.bold {
  font-weight: 600;
}

h2,
h3,
h4 {
  line-height: 1.4;
  font-weight: 600;
}

.spbr {
  display: none !important;
}

.pcbr {
  display: block;
}

/* animation
----------------------------------*/
@-webkit-keyframes view-zoomin {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes view-zoomin {
  0% {
    opacity: 0;
    transform: scale(0.95);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}
@-webkit-keyframes view-slideup {
  0% {
    opacity: 0;
    transform: translate(0, 35px);
  }
  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}
@keyframes view-slideup {
  0% {
    opacity: 0;
    transform: translate(0, 35px);
  }
  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}
.animation {
  opacity: 0;
}

.slideup.on {
  opacity: 1;
  -webkit-animation: view-slideup 0.65s cubic-bezier(0.2, 1, 0.2, 1);
          animation: view-slideup 0.65s cubic-bezier(0.2, 1, 0.2, 1);
}

.zoomin.on {
  opacity: 1;
  -webkit-animation: view-zoomin 0.65s cubic-bezier(0.2, 1, 0.2, 1);
          animation: view-zoomin 0.65s cubic-bezier(0.2, 1, 0.2, 1);
}

.loader {
  align-items: center;
  background: #fdfdfd;
  bottom: 0;
  display: flex;
  justify-content: center;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 9999;
}
.loader::after {
  -webkit-animation: loader 0.5s linear infinite;
          animation: loader 0.5s linear infinite;
  border: 1px solid #2d96dc;
  border-radius: 50%;
  border-right: 1px solid rgba(45, 150, 220, 0.2);
  border-top: 1px solid rgba(45, 150, 220, 0.2);
  content: "";
  height: 70px;
  width: 70px;
}
.loader.off {
  display: none;
}

@-webkit-keyframes loader {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}

@keyframes loader {
  0% {
    transform: rotate(0);
  }
  100% {
    transform: rotate(360deg);
  }
}
/* top
----------------------------------*/
.catch {
  width: 100%;
  height: auto;
  background: rgb(0, 141, 208);
  background: linear-gradient(90deg, rgb(0, 141, 208) 0%, rgb(0, 153, 226) 43%, rgba(13, 179, 227, 0.8856136204) 100%);
  margin-top: 0;
  margin-bottom: 10px;
  padding-bottom: 10px;
}

.catch_area {
  margin: 0px auto;
  padding: 1.4% 9.4% 1.1%;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-end;
  border-bottom: 1px solid #fff;
}
.catch_area .catch_l {
  text-align: left;
  width: 75.8%;
  margin-right: 3.2%;
}
.catch_area .catch_r {
  text-align: right;
  width: 21%;
}
.catch_area .catch_r img {
  max-width: 160px;
}
@media all and (max-width: 1079px) {
  .catch_area {
    padding: 20px 0px 10px;
  }
  .catch_area .catch_l {
    width: 100%;
    margin: 0 auto;
    text-align: center;
  }
}
@media all and (max-width: 1079px) {
  .catch_area {
    padding: 20px 10px 10px;
  }
}
@media all and (min-width: 1600px) {
  .catch_area {
    padding: 2.5% 9.4% 1%;
  }
}

/* contents
----------------------------------*/
.single {
  max-width: 1218px;
  margin: 0 auto;
  padding: 80px 0 160px;
  position: relative;
  margin-top: 115px;
  background-color: #ebebeb;
}

@media all and (min-width: 1080px) {
  .single {
  padding: 40px 32px 0;
  }
}

.single2 {
  max-width: 1218px;
  margin: 0 auto;
  padding: 100px 12px 40px;
  position: relative;
}

@media all and (min-width: 1080px) {
  .single2 {
    padding: 140px 0 80px 48px;
  }
}

.single3 {
  max-width: 1218px;
  margin: -70px auto 0;
  padding: 40px 0 100px;
  position: relative;
  background: #fff;
  border-radius: 50px;
}

.bg-01 {
  margin-top: -100px;
}

@media all and (max-width: 1079px) {
  .single {
    width: calc(100% - 40px);
    margin: 0 auto;
    padding: 60px 0 0;
    position: relative;
  }
  .single2 {
    width: calc(100% - 40px);
    margin: 0 auto;
    padding: 100px 0 40px;
    position: relative;
  }
  .single3 {
    width: calc(100% - 40px);
    margin: -40px auto 0;
    padding: 25px 0 60px;
    border-radius: 30px;
  }
  .bg-01 {
    background: #ebebeb;
    margin-top: -80px;
  }
}
@media all and (max-width: 1079px) {
  .single {
    width: calc(100% - 20px);
    margin: 0 auto;
    padding: 60px 0 0;
    position: relative;
  }
  .single2 {
    width: calc(100% - 20px);
    margin: 0 auto;
    padding: 100px 0 40px;
    position: relative;
  }
  .single3 {
    width: calc(100% - 20px);
    margin: -40px auto 0;
    padding: 25px 0 60px;
    border-radius: 30px;
  }
  .bg-01 {
    background: #ebebeb;
    margin-top: -80px;
  }
}
.search_area {
  width: 100%;
  height: 100%;
  margin: 20px auto 0;
  padding-bottom: 10px;
  display: flex;
  flex-wrap: wrap;
}
.search_area .search_title {
  position: relative;
  width: 25%;
  margin-bottom: 10px;
  padding-left: 10px;
}
.search_area .search_title:before {
  content: "";
  background-color: #232323;
  width: 15px;
  height: 2px;
  position: absolute;
  top: 0.6em;
  left: 0;
}
.search_area .search_title .s_title {
  padding-left: 25px;
  color: #232323;
}
.search_area .search_title .s_title:before {
  font-family: "Font Awesome 5 Free";
  content: "\f002";
  font-weight: 900;
  font-weight: 900;
  padding-right: 5px;
}
.search_area ul.search_key {
  width: 75%;
  display: flex;
  flex-wrap: wrap;
  gap: 15px 20px;
}
.search_area ul.search_key li {
  padding: 5px 10px;
  border-radius: 8px;
  white-space: nowrap;
}
.search_area ul.search_key li.selected_key {
  background: #232323;
  color: #fff;
}
.search_area ul.search_key li.key {
  background: #fff;
  color: #232323;
}
.search_area ul.search_key li:hover {
  opacity: 0.7;
  cursor: pointer;
}
@media all and (max-width: 1079px) {
  .search_area {
    display: block;
    margin: 0 auto 20px;
  }
  .search_area .search_title {
    width: 100%;
    font-size: 3.2vw;
    margin-bottom: 20px;
  }
  .search_area .search_title .s_title {
    padding-left: 15px;
  }
  .search_area ul.search_key {
    width: 100%;
    gap: 20px 20px;
  }
  .search_area ul.search_key li {
    font-size: 3.2vw;
    padding: 10px 15px;
    border-radius: 30px;
  }
}
@media all and (max-width: 1079px) {
  .search_area {
    display: block;
    margin: 0 auto 15px;
  }
  .search_area .search_title {
    width: 100%;
    font-size: 4.2666666667vw;
    margin-bottom: 10px;
  }
  .search_area .search_title:before {
    width: 12px;
  }
  .search_area .search_title .s_title {
    padding-left: 10px;
  }
  .search_area ul.search_key {
    gap: 15px 10px;
  }
  .search_area ul.search_key li {
    font-size: 3.7333333333vw;
    padding: 6px 12px;
    border-radius: 16px;
  }
}

.event-list {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  height: auto;
  box-sizing: border-box;
}
.event-list .child {
  width: 31%;
  margin: 10px auto 40px;
  height: auto;
  background: #fff;
  box-shadow: 0 6px 6px rgba(72, 56, 44, 0.06);
  border-radius: 8px;
  display: flex;
  flex-direction: column;
  box-sizing: border-box;
  transition: 0.3s all ease-in-out;
}
.event-list .child a {
  display: block;
  position: relative;
  padding: 0;
  color: #232323;
}
.event-list .child a ul.event_label {
  margin: 0 10px 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 0px;
  justify-content: flex-start;
}
.event-list .child a ul.event_label li {
  background: #2d96dc;
  padding: 2px 8px 5px;
  margin-right: 8px;
  border-radius: 0 0 4px 4px;
}
.event-list .child a ul.event_label li span {
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.2;
}
@media all and (max-width: 1079px) {
  .event-list .child a ul.event_label li {
    padding: 10px 12px;
    margin-right: 12px;
    border-radius: 0 0 8px 8px;
  }
  .event-list .child a ul.event_label li span {
    font-size: 1.4rem;
  }
}
@media all and (max-width: 1079px) {
  .event-list .child a ul.event_label li {
    padding: 2px 8px 5px;
    margin-right: 8px;
    border-radius: 0 0 4px 4px;
  }
  .event-list .child a ul.event_label li span {
    font-size: 12px;
  }
}
.event-list .child a figure {
  width: 100%;
  height: auto;
  overflow: hidden;
  padding: 0 10px;
  margin: 0 !important;
}
.event-list .child a img {
  width: 100%;
  height: auto;
  -o-object-fit: contain;
     object-fit: contain;
  font-family: "object-fit: cover;";
  transition: 0.2s all ease-in;
}
.event-list .child:hover {
  box-shadow: 0px 18px 20px -5px rgb(72 56 44 / 26%);
  transform: translateY(-5px);
  transition: 0.3s all ease-in-out;
}
@media all and (max-width: 1079px) {
  .event-list .child {
    width: 100%;
  }
  .event-list .child:not(:last-of-type) {
    margin-bottom: 30px;
  }
  .event-list .child a figure {
    height: auto;
  }
}
.event-list .event-title {
  position: relative;
  width: 100%;
  margin: 10px auto;
  padding: 0 10px;
  color: #232323;
  font-weight: 600;
  text-align: left;
  font-size: 1.15rem;
  line-height: 1.3;
  height: 72px;
  overflow: hidden;
}
@media all and (max-width: 1079px) {
  .event-list .event-title {
    font-size: 3.7333333333vw;
    height: auto;
  }
}
@media all and (max-width: 1079px) {
  .event-list .event-title {
    font-size: 4.2666666667vw;
  }
}
.event-list .event-com {
  width: calc(100% - 20px);
  padding: 10px 0;
  margin: 0 10px;
  border-top: 1px solid #ddd;
  min-height: 138px;
  text-align: center;
}
.event-list .event-com span {
  display: block;
  font-size: 12px;
}
.event-list .event-com ul {
  width: 100%;
  align-items: center;
  margin: 0 auto;
  padding: 0 5px;
}
.event-list .event-com ul li {
  width: 32%;
  display: inline-block;
  text-align: center;
}
.event-list .event-com ul li img {
  width: 78%;
  height: auto;
  margin: 0 auto;
}
@media all and (max-width: 1079px) {
  .event-list .event-com {
    min-height: auto;
  }
  .event-list .event-com span {
    font-size: 1.4rem;
  }
}
@media all and (max-width: 1079px) {
  .event-list .event-com span {
    font-size: 12px;
  }
}
.event-list .event-date {
  width: 100%;
  background: #f4f5ec;
  padding: 15px 0;
  text-align: center;
  min-height: 111px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  box-sizing: border-box;
}
.event-list .event-date .e_date {
  font-size: 1.35rem;
  font-weight: 600;
  color: #232323;
}
.event-list .event-date .e_date span {
  font-size: 16px;
}
.event-list .event-date ul {
  display: flex;
  justify-content: center;
  margin-top: 5px;
}
.event-list .event-date ul li {
  margin-right: 8px;
  padding: 0px 8px 4px;
  line-height: 1;
  background: #fff;
  border: 1px solid #a0a0a0;
}
.event-list .event-date ul li:last-child {
  margin-right: 0;
}
.event-list .event-date ul li span {
  font-size: 12px;
  color: #a0a0a0;
  vertical-align: middle;
}
.event-list .event-date .property-label {
    margin-left: 8px;
    padding: 4px 8px 4px;
    line-height: 1;
    background: #fff;
    border: 1px solid #a0a0a0;
    font-size: 12px;
    color: #a0a0a0;
    vertical-align: middle;
    display: inline-block;
}
.event-list .event-date .property-label:first-child {
    margin-left: 0;
}
@media all and (max-width: 1079px) {
  .event-list .event-date ul li {
    padding: 8px 10px;
  }
  .event-list .event-date ul li span {
    font-size: 1.4rem;
  }
  .event-list .event-date .e_date {
    font-size: 4.2666666667vw;
  }
  .event-list .event-date .e_date span {
    font-size: 1.6rem;
  }
}
@media all and (max-width: 1079px) {
  .event-list .event-date ul li {
    padding: 0px 8px 4px;
  }
  .event-list .event-date ul li span {
    font-size: 12px;
  }
  .event-list .event-date .e_date {
    font-size: 1.35rem;
  }
  .event-list .event-date .e_date span {
    font-size: 16px;
  }
}
.event-list .event_btn {
  width: 100%;
  padding: 10px 10px 0;
  margin-bottom: 10px;
  text-align: right;
}
.event-list .event_btn .btn1 {
  background: #ffd304;
  text-align: center;
  margin: 0 0 0 auto;
  width: 160px;
  color: #232323;
  display: block;
  padding: 8px 10px;
  font-weight: 600;
  border-radius: 25px;
  transition: 0.2s all ease-in;
}
.event-list .child a:hover .btn1 {
    opacity: 0.7;
    cursor: pointer;
}
.event-list .event_btn .btn1:hover {
  opacity: 0.7;
  cursor: pointer;
}
.event-list .event_btn .btn1:before {
  content: "";
  display: inline-block;
  width: 25px;
  height: 25px;
  background: url('/images/dashboard/check.svg') no-repeat center/contain;
  vertical-align: bottom;
}
.event-list .event_btn .btn2 {
  background: #ebebeb;
  text-align: center;
  margin: 0 0 0 auto;
  width: 160px;
  color: #232323;
  display: block;
  padding: 8px 10px;
  font-weight: 600;
  border-radius: 25px;
}
@media all and (max-width: 1079px) {
  .event-list .event_btn {
    font-size: 3.7333333333vw;
    height: auto;
    text-align: center;
    padding: 20px 20px 0;
    margin-bottom: 20px;
  }
  .event-list .event_btn .btn1 {
    width: 100%;
    margin: 0 auto;
  }
  .event-list .event_btn .btn2 {
    width: 100%;
    margin: 0 auto;
  }
}
@media all and (max-width: 1079px) {
  .event-list .event_btn {
    font-size: 4.2666666667vw;
    padding: 10px 10px 0;
    margin-bottom: 10px;
  }
}

.sign_area {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  width: 90%;
}
.sign_area .child_ttl {
  width: 38%;
  margin-right: 4%;
  font-family: "Zen Kaku Gothic New", sans-serif;
  font-weight: 500;
  font-size: 1.4rem;
  color: #232323;
  letter-spacing: 0.2rem;
}
.sign_area .child_btn {
  width: 58%;
  margin: 0;
}
.sign_area .child_btn ul.contact_btn {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.sign_area .child_btn ul.contact_btn > li {
  margin-bottom: 10px;
  width: 48%;
  margin-right: 4%;
}
.sign_area .child_btn ul.contact_btn > li:last-child {
  margin-right: 0;
}
@media all and (max-width: 1079px) {
  .sign_area .child_btn ul.contact_btn > li {
    width: 100%;
    margin: 0 auto 15px;
  }
  .sign_area .child_btn ul.contact_btn > li:last-child {
    margin-right: auto;
  }
}
.sign_area .child_btn ul.contact_btn > li .btn_sign {
  background: #2d96dc;
  border: 2px solid #2d96dc;
}
.sign_area .child_btn ul.contact_btn > li .btn_sign:hover {
  color: #1657c4;
  background: #fff;
  border: 2px solid #1657c4;
}
.sign_area .child_btn ul.contact_btn > li .btn_login {
  background: #38cde0;
  border: 2px solid #38cde0;
}
.sign_area .child_btn ul.contact_btn > li .btn_login:hover {
  color: #1657c4;
  background: #fff;
  border: 2px solid #1657c4;
}
.sign_area .child_btn ul.contact_btn > li a {
  width: 100%;
  display: block;
  border-radius: 50px;
  color: #fff;
  text-align: center;
  padding: 10px 0px;
  font-weight: 600;
  transition: all 0.2s ease-in;
  margin-left: auto;
  font-size: 1rem;
  letter-spacing: 0.12rem;
}
@media all and (max-width: 1079px) {
  .sign_area .child_btn ul.contact_btn > li a {
    width: 100%;
    font-size: 3.7333333333vw;
  }
}
@media all and (max-width: 1079px) {
  .sign_area .child_btn ul.contact_btn > li a {
    font-size: 4.2666666667vw;
  }
}
@media all and (max-width: 1079px) {
  .sign_area {
    display: block;
  }
  .sign_area .child_ttl {
    width: 100%;
    margin-right: 0;
    font-size: 3.7333333333vw;
    letter-spacing: 0.1rem;
    margin-bottom: 30px;
    text-align: center;
  }
  .sign_area .child_btn {
    width: 100%;
  }
}
@media all and (max-width: 1079px) {
  .sign_area {
    display: block;
  }
  .sign_area .child_ttl {
    font-size: 4.2666666667vw;
    margin-bottom: 20px;
  }
}
/*# sourceMappingURL=basis.css.map */
.none {
  display: none;
}

.block {
  display: block;
}

.clear {
  clear: both;
}

.clearfix {
  _display: inline-block;
}
.clearfix:after {
  content: ".";
  display: block;
  height: 0px;
  clear: both;
  visibility: hidden;
}

.fleft0 {
  float: left;
  display: inline;
  text-align: center;
}

.fleft1 {
  float: left;
  display: inline;
  margin-right: 10px;
  margin-bottom: 10px;
  text-align: center;
}

.fleft2 {
  float: left;
  display: inline;
  margin-right: 30px;
  margin-bottom: 20px;
  text-align: center;
}

.fright0 {
  float: right;
  display: inline;
  text-align: center;
}

.fright1 {
  float: right;
  display: inline;
  margin-left: 10px;
  margin-bottom: 10px;
  text-align: center;
}

.fright2 {
  float: right;
  display: inline;
  margin-left: 30px;
  text-align: center;
}

.m5 {
  margin: 5px;
}

.m10 {
  margin: 10px;
}

.m15 {
  margin: 15px;
}

.m20 {
  margin: 20px;
}

.m30 {
  margin: 30px;
}

.m40 {
  margin: 40px;
}

.m50 {
  margin: 50px;
}

.m75 {
  margin: 75px;
}

.m100 {
  margin: 100px;
}

.t-m5 {
  margin-top: 5px;
}

.t-m10 {
  margin-top: 10px;
}

.t-m15 {
  margin-top: 15px;
}

.t-m20 {
  margin-top: 20px;
}

.t-m30 {
  margin-top: 30px;
}

.t-m40 {
  margin-top: 40px;
}

.t-m50 {
  margin-top: 50px;
}

.t-m75 {
  margin-top: 75px;
}

.t-m100 {
  margin-top: 100px;
}

.b-m5 {
  margin-bottom: 5px;
}

.b-m10 {
  margin-bottom: 10px;
}

.b-m15 {
  margin-bottom: 15px;
}

.b-m20 {
  margin-bottom: 20px;
}

.b-m30 {
  margin-bottom: 30px;
}

.b-m40 {
  margin-bottom: 40px;
}

.b-m50 {
  margin-bottom: 50px;
}

.b-m75 {
  margin-bottom: 75px;
}

.b-m100 {
  margin-bottom: 100px;
}

.l-m5 {
  margin-left: 5px;
}

.l-m10 {
  margin-left: 10px;
}

.l-m15 {
  margin-left: 15px;
}

.l-m20 {
  margin-left: 20px;
}

.l-m30 {
  margin-left: 30px;
}

.l-m40 {
  margin-left: 40px;
}

.l-m50 {
  margin-left: 50px;
}

.l-m70 {
  margin-left: 70px;
}

.l-m75 {
  margin-left: 75px;
}

.l-m100 {
  margin-left: 100px;
}

.r-m5 {
  margin-right: 5px;
}

.r-m10 {
  margin-right: 10px;
}

.r-m15 {
  margin-right: 15px;
}

.r-m20 {
  margin-right: 20px;
}

.r-m30 {
  margin-right: 30px;
}

.r-m40 {
  margin-right: 40px;
}

.r-m50 {
  margin-right: 50px;
}

.r-m75 {
  margin-right: 75px;
}

.r-m100 {
  margin-right: 100px;
}

.h-m5 {
  margin-top: 5px;
  margin-bottom: 5px;
}

.h-m10 {
  margin-top: 10px;
  margin-bottom: 10px;
}

.h-m15 {
  margin-top: 15px;
  margin-bottom: 15px;
}

.h-m20 {
  margin-top: 20px;
  margin-bottom: 20px;
}

.h-m30 {
  margin-top: 30px;
  margin-bottom: 30px;
}

.h-m40 {
  margin-top: 40px;
  margin-bottom: 40px;
}

.h-m50 {
  margin-top: 50px;
  margin-bottom: 50px;
}

.w-m5 {
  margin-left: 5px;
  margin-right: 5px;
}

.w-m10 {
  margin-left: 10px;
  margin-right: 10px;
}

.w-m15 {
  margin-left: 15px;
  margin-right: 15px;
}

.w-m20 {
  margin-left: 20px;
  margin-right: 20px;
}

.w-m30 {
  margin-left: 30px;
  margin-right: 30px;
}

.w-m40 {
  margin-left: 40px;
  margin-right: 40px;
}

.w-m50 {
  margin-left: 50px;
  margin-right: 50px;
}

.p5 {
  padding: 5px;
}

.p10 {
  padding: 10px;
}

.p15 {
  padding: 15px;
}

.p20 {
  padding: 20px;
}

.p30 {
  padding: 30px;
}

.p40 {
  padding: 40px;
}

.p50 {
  padding: 50px;
}

.p75 {
  padding: 75px;
}

.p100 {
  padding: 100px;
}

.t-p5 {
  padding-top: 5px;
}

.t-p10 {
  padding-top: 10px;
}

.t-p15 {
  padding-top: 15px;
}

.t-p20 {
  padding-top: 20px;
}

.t-p30 {
  padding-top: 30px;
}

.t-p40 {
  padding-top: 40px;
}

.t-p50 {
  padding-top: 50px;
}

.t-p75 {
  padding-top: 75px;
}

.t-p100 {
  padding-top: 100px;
}

.b-p5 {
  padding-bottom: 5px;
}

.b-p10 {
  padding-bottom: 10px;
}

.b-p15 {
  padding-bottom: 15px;
}

.b-p20 {
  padding-bottom: 20px;
}

.b-p30 {
  padding-bottom: 30px;
}

.b-p40 {
  padding-bottom: 40px;
}

.b-p50 {
  padding-bottom: 50px;
}

.b-p75 {
  padding-bottom: 75px;
}

.b-p100 {
  padding-bottom: 100px;
}

.l-p5 {
  padding-left: 5px;
}

.l-p10 {
  padding-left: 10px;
}

.l-p15 {
  padding-left: 15px;
}

.l-p20 {
  padding-left: 20px;
}

.l-p30 {
  padding-left: 30px;
}

.l-p40 {
  padding-left: 40px;
}

.l-p50 {
  padding-left: 50px;
}

.l-p60 {
  padding-left: 60px;
}

.l-p65 {
  padding-left: 65px;
}

.l-p70 {
  padding-left: 70px;
}

.l-p75 {
  padding-left: 75px;
}

.l-p100 {
  padding-left: 100px;
}

.r-p5 {
  padding-right: 5px;
}

.r-p10 {
  padding-right: 10px;
}

.r-p15 {
  padding-right: 15px;
}

.r-p20 {
  padding-right: 20px;
}

.r-p30 {
  padding-right: 30px;
}

.r-p40 {
  padding-right: 40px;
}

.r-p50 {
  padding-right: 50px;
}

.r-p75 {
  padding-right: 75px;
}

.r-p100 {
  padding-right: 100px;
}

.h-p5 {
  padding-top: 5px;
  padding-bottom: 5px;
}

.h-p10 {
  padding-top: 10px;
  padding-bottom: 10px;
}

.h-p15 {
  padding-top: 15px;
  padding-bottom: 15px;
}

.h-p20 {
  padding-top: 20px;
  padding-bottom: 20px;
}

.h-p30 {
  padding-top: 30px;
  padding-bottom: 30px;
}

.h-p40 {
  padding-top: 40px;
  padding-bottom: 40px;
}

.h-p50 {
  padding-top: 50px;
  padding-bottom: 50px;
}

.h-p75 {
  padding-top: 75px;
  padding-bottom: 75px;
}

.h-p100 {
  padding-top: 100px;
  padding-bottom: 100px;
}

.w-p5 {
  padding-left: 5px;
  padding-right: 5px;
}

.w-p10 {
  padding-left: 10px;
  padding-right: 10px;
}

.w-p15 {
  padding-left: 15px;
  padding-right: 15px;
}

.w-p20 {
  padding-left: 20px;
  padding-right: 20px;
}

.w-p30 {
  padding-left: 30px;
  padding-right: 30px;
}

.w-p40 {
  padding-left: 40px;
  padding-right: 40px;
}

.w-p50 {
  padding-left: 50px;
  padding-right: 50px;
}

.w-p75 {
  padding-left: 75px;
  padding-right: 75px;
}

.w-p100 {
  padding-left: 100px;
  padding-right: 100px;
}

.tcenter {
  text-align: center;
}

.tright {
  text-align: right;
}

.tleft {
  text-align: left;
}

.ttext {
  text-indent: 1em;
  text-align: justify;
}

.tkome {
  padding-left: 1em;
  text-indent: -1em;
}

.tinline {
  display: inline-block;
}

.toverflow {
  overflow: hidden;
  zoom: 1;
}

.scroll {
  height: 250px;
  overflow-y: scroll;
}

.orange {
  color: #ff6600;
}

.red {
  color: #ff0000;
}

.blue {
  color: #0068b7;
}

.green {
  color: #448f42;
}

.green2 {
  color: #80c269;
}

.skyblue {
  color: #029fe6;
}

.magenta {
  color: #663366;
}

.white {
  color: #fff;
}

.pink {
  color: #ff8ec0;
}

.darkpink {
  color: #9e005d;
}

.black {
  color: #000000;
}

.yellow {
  color: #fff45c;
}

.f-s8 {
  font-size: 8px;
}

.f-s10 {
  font-size: 10px;
}

.f-s11 {
  font-size: 11px;
}

.f-s12 {
  font-size: 12px;
}

.f-s13 {
  font-size: 13px;
}

.f-s14 {
  font-size: 14px;
}

.f-s15 {
  font-size: 15px;
}

.f-s16 {
  font-size: 16px;
}

.f-s18 {
  font-size: 18px;
}

.f-s20 {
  font-size: 20px;
}

.f-s22 {
  font-size: 22px;
}

.f-s24 {
  font-size: 24px;
}

/* marker */
.marker-c {
  background: linear-gradient(transparent 70%, #a8d8fa 0%);
  z-index: 0;
}

.marker-m {
  background: linear-gradient(transparent 70%, #ff7c81 0%);
  z-index: 0;
}

.marker-y {
  background: linear-gradient(transparent 10%, #fef36c 0%);
  z-index: 0;
}

.marker-k {
  background: linear-gradient(transparent 70%, #cccccc 0%);
  z-index: 0;
}

.marker-p {
  background: linear-gradient(transparent 70%, #ffd0e1 0%);
  z-index: 0;
}

.marker-w {
  background: linear-gradient(transparent 5%, #fff 0%);
  z-index: 0;
}

/* background color */
.bg-orange {
  background-color: #ffefd6;
}

.bg-red {
  background-color: #ff0000;
}

.bg-blue {
  background-color: #0068b7;
}

.bg-green {
  background-color: rgba(53, 88, 20, 0.5);
}

.bg-skyblue {
  background-color: #029fe6;
}

.bg-magenta {
  background-color: #663366;
}

.bg-yellow {
  background-color: #fffdde;
}

.bg-white {
  background-color: #fff;
}

.bg-pink {
  background-color: #ff8ec0;
}

.bg-darkpink {
  background-color: #9e005d;
}

.bg-black {
  background-color: #000000;
}

.bg-111 {
  background-color: #111;
}

.bg-222 {
  background-color: #222;
}

.bg-333 {
  background-color: #333;
}

.bg-aaa {
  background-color: #aaa;
}

.bg-bbb {
  background-color: #bbb;
}

.bg-ccc {
  background-color: #ccc;
}

.bg-ddd {
  background-color: #ddd;
}

.bg-eee {
  background-color: #eee;
}

/* link */
.link li {
  margin-bottom: 10px;
}
.link li img {
  width: 100%;
  height: auto;
}

/* flink */
.flink0,
.flink1,
.flink2 {
  width: 100%;
  margin: 10px 0;
}

.flink0 ul {
  margin-right: -11px;
}

.flink1 ul {
  margin-right: -11px;
  margin-bottom: -10px;
}

.flink2 ul {
  margin-right: -21px;
  margin-bottom: -20px;
}

.flink0 li {
  float: left;
}

.flink1 li {
  float: left;
  margin-right: 10px;
  margin-bottom: 10px;
}

.flink2 li {
  float: left;
  margin-right: 20px;
  margin-bottom: 20px;
}

/* img */
.img-r {
  border-radius: 10px;
}

.img-maru {
  border-radius: 1000px;
}

.img-b {
  border: 3px solid #f6f4eb;
}

.img-sd {
  border: 3px solid #fff;
  box-shadow: rgba(0, 0, 0, 0.1) 1px 1px 3px 0;
}

.img-frame {
  position: relative;
  z-index: 0;
}
.img-frame:after {
  position: absolute;
  display: block;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
  transform: rotate(3deg);
  background: #fff;
  z-index: -1;
}

/* 点滅 */
.blinking {
  -webkit-animation: blink 1.5s ease-in-out infinite alternate;
  animation: blink 1.5s ease-in-out infinite alternate;
}

@-webkit-keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes blink {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/*ヘアライン*/
hr {
  clear: both;
  border: 0;
  height: 0;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
  border-bottom: 1px solid rgba(255, 255, 255, 0.3);
}

.hr-gd {
  border: 0;
  height: 1px;
  background-image: -o-linear-gradient(left, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.75), rgba(0, 0, 0, 0));
}

.hr-shadow {
  height: 12px;
  border: 0;
  box-shadow: inset 0 12px 12px -12px rgba(0, 0, 0, 0.5);
}

/*  FontAwesome  */
.fontAwesome {
  font-family: "FontAwesome";
}

.a000:before {
  font-family: "FontAwesome";
  content: "\f0a9";
}

.scrollbar {
  min-height: 100px;
  max-height: 360px;
  overflow-y: scroll;
  overflow-x: hidden;
}
.scrollbar.policy-box {
  max-height: 300px;
}
.scrollbar::-webkit-scrollbar {
  overflow: hidden;
  width: 1px;
  background: #fafafa;
}
.scrollbar::-webkit-scrollbar:horizontal {
  height: 1px;
}
.scrollbar::-webkit-scrollbar-button {
  display: none;
}
.scrollbar::-webkit-scrollbar-piece {
  background: #eee;
}
.scrollbar::-webkit-scrollbar-piece:start {
  background: #eee;
}
.scrollbar::-webkit-scrollbar-thumb, .scrollbar::-webkit-scrollbar-corner {
  background: #333;
}
/*# sourceMappingURL=common.css.map */
/* slick
----------------------------------*/
/*------ スライダーの横幅 ------*/
.slider{
    width:80%;
    max-width: 1080px;
    margin:0 auto;
}

/*------ スライダー画像 ------*/
.slider img{
    width:100%;
}

/*-------- 高さ調整 ----------*/
.slider .slick-slide{
    height:auto !important;
}

/*---------- 矢印 ----------*/
.slider .slick-next{
    right: -80px !important;
}
.slider .slick-prev{
    left: -80px !important;
}
.slider .slick-arrow{
    width: initial !important;
    height: initial !important;
    z-index:2 !important;
}
.slider .slick-arrow:before{
    font-size: 3rem !important;
    color:#4e4e4e !important;
}
.slick-dots li:last-of-type {
    margin-right: 12px !important;
}

@media screen and (max-width: 1079px) {
    .slider{
        width: calc(100% - 20px);
        margin:0 auto;
    }
}
@media all and (max-width: 1079px) {
  .spbr {
    display: block !important;
  }
  .pcbr {
    display: none;
  }
}
@media all and (max-width: 1079px) {
  html {
    font-size: 3.125vw;
  }
  .spbr {
    display: block;
  }
  .pcbr {
    display: none;
  }
  #wrapper {
    overflow-y: hidden;
  }
}

@media all and (min-width: 1080px) {
    .contents-inner {
        display: flex;
    }

    .contents-inner>div {
        width: 80%;
    }

    #wrapper {
        width: 90%;
        margin: 0 auto;
    }
    body {
        background: #f6f6f6;
    }
}

/*================================================
イベシスログイン後画面でのみサイドバーのCSS上書き
================================================*/
.acw-header:not(:root) {
    padding: 10px;
}

.uk-offcanvas-bar:not(:root) {
    background-color: #fff;
    color: #333;
}

.uk-offcanvas-bar a:not(:root) {
    color: #333;
}

.uk-offcanvas-bar .uk-close:not(:root) {
    color: #333;
}

.contents-inner .pc_only {
    width: 20% !important;
    max-width: 240px;
}

.pc_only .acw-side-navi {
    width: 100% !important;
}

.uk-breadcrumb>:nth-child(n+2):not(.uk-first-column)::before{
    content: ">" !important;
    margin: 0 0.25em !important;
}

.acw-wrapper-PC .uk-navbar-left {
    gap: 0;
}
.e_date_caption {
  font-size: 12px;
  line-height: 1.2;
  font-weight: normal;
  color: #232323;
  inline-size: fit-content;
  margin-inline: auto;
  padding: 0 4px;
}