@import url(https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300;400&family=M+PLUS+Rounded+1c:wght@100;300;400&family=Noto+Sans+JP:wght@100..900&family=Zen+Maru+Gothic:wght@300;400&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300;400&family=M+PLUS+Rounded+1c:wght@100;300;400&family=Noto+Sans+JP:wght@100..900&family=Zen+Maru+Gothic:wght@300;400&display=swap);
@import url(https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.5.1/css/all.min.css);
/* http://meyerweb.com/eric/tools/css/reset/  v2.0 | 20110126 License: none (public domain)
*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

img {
  vertical-align: bottom;
}

/******************************************************/
/* class */
/******************************************************/
.ANCHER {
  margin-top: -120px;
  padding-top: 120px;
}

.nb {
  border: none !important;
}

.center {
  text-align: center !important;
}

.right {
  text-align: right !important;
}

.left {
  text-align: left !important;
}

.mt0 {
  margin-top: 0px !important;
}

.mt1 {
  margin-top: 1px !important;
}

.mt2 {
  margin-top: 2px !important;
}

.mt3 {
  margin-top: 3px !important;
}

.mt4 {
  margin-top: 4px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mt6 {
  margin-top: 6px !important;
}

.mt7 {
  margin-top: 7px !important;
}

.mt8 {
  margin-top: 8px !important;
}

.mt9 {
  margin-top: 9px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.ml0 {
  margin-left: 0px !important;
}

.ml1 {
  margin-left: 1px !important;
}

.ml2 {
  margin-left: 2px !important;
}

.ml3 {
  margin-left: 3px !important;
}

.ml4 {
  margin-left: 4px !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml6 {
  margin-left: 6px !important;
}

.ml7 {
  margin-left: 7px !important;
}

.ml8 {
  margin-left: 8px !important;
}

.ml9 {
  margin-left: 9px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml15 {
  margin-left: 15px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml25 {
  margin-left: 25px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml35 {
  margin-left: 35px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml45 {
  margin-left: 45px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.mb1 {
  margin-bottom: 1px !important;
}

.mb2 {
  margin-bottom: 2px !important;
}

.mb3 {
  margin-bottom: 3px !important;
}

.mb4 {
  margin-bottom: 4px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb6 {
  margin-bottom: 6px !important;
}

.mb7 {
  margin-bottom: 7px !important;
}

.mb8 {
  margin-bottom: 8px !important;
}

.mb9 {
  margin-bottom: 9px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mr0 {
  margin-right: 0px !important;
}

.mr1 {
  margin-right: 1px !important;
}

.mr2 {
  margin-right: 2px !important;
}

.mr3 {
  margin-right: 3px !important;
}

.mr4 {
  margin-right: 4px !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mr6 {
  margin-right: 6px !important;
}

.mr7 {
  margin-right: 7px !important;
}

.mr8 {
  margin-right: 8px !important;
}

.mr9 {
  margin-right: 9px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr15 {
  margin-right: 15px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr25 {
  margin-right: 25px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr35 {
  margin-right: 35px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr45 {
  margin-right: 45px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mr320 {
  margin-right: 320px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pt1 {
  padding-top: 1px !important;
}

.pt2 {
  padding-top: 2px !important;
}

.pt3 {
  padding-top: 3px !important;
}

.pt4 {
  padding-top: 4px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pt6 {
  padding-top: 6px !important;
}

.pt7 {
  padding-top: 7px !important;
}

.pt8 {
  padding-top: 8px !important;
}

.pt9 {
  padding-top: 9px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pl0 {
  padding-left: 0px !important;
}

.pl1 {
  padding-left: 1px !important;
}

.pl2 {
  padding-left: 2px !important;
}

.pl3 {
  padding-left: 3px !important;
}

.pl4 {
  padding-left: 4px !important;
}

.pl5 {
  padding-left: 5px !important;
}

.pl6 {
  padding-left: 6px !important;
}

.pl7 {
  padding-left: 7px !important;
}

.pl8 {
  padding-left: 8px !important;
}

.pl9 {
  padding-left: 9px !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pl15 {
  padding-left: 15px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl25 {
  padding-left: 25px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl35 {
  padding-left: 35px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl45 {
  padding-left: 45px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.pb1 {
  padding-bottom: 1px !important;
}

.pb2 {
  padding-bottom: 2px !important;
}

.pb3 {
  padding-bottom: 3px !important;
}

.pb4 {
  padding-bottom: 4px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pb6 {
  padding-bottom: 6px !important;
}

.pb7 {
  padding-bottom: 7px !important;
}

.pb8 {
  padding-bottom: 8px !important;
}

.pb9 {
  padding-bottom: 9px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb55 {
  padding-bottom: 55px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.pb65 {
  padding-bottom: 65px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.pr0 {
  padding-right: 0px !important;
}

.pr1 {
  padding-right: 1px !important;
}

.pr2 {
  padding-right: 2px !important;
}

.pr3 {
  padding-right: 3px !important;
}

.pr4 {
  padding-right: 4px !important;
}

.pr5 {
  padding-right: 5px !important;
}

.pr6 {
  padding-right: 6px !important;
}

.pr7 {
  padding-right: 7px !important;
}

.pr8 {
  padding-right: 8px !important;
}

.pr9 {
  padding-right: 9px !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pr15 {
  padding-right: 15px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr25 {
  padding-right: 25px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr35 {
  padding-right: 35px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr45 {
  padding-right: 45px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.w10 {
  width: 10px !important;
}

.w20 {
  width: 20px !important;
}

.w30 {
  width: 30px !important;
}

.w40 {
  width: 40px !important;
}

.w50 {
  width: 50px !important;
}

.w60 {
  width: 60px !important;
}

.w70 {
  width: 70px !important;
}

.w80 {
  width: 80px !important;
}

.w90 {
  width: 90px !important;
}

.w100 {
  width: 100px !important;
}

.w110 {
  width: 110px !important;
}

.w120 {
  width: 120px !important;
}

.w130 {
  width: 130px !important;
}

.w140 {
  width: 140px !important;
}

.w150 {
  width: 150px !important;
}

.w160 {
  width: 160px !important;
}

.w170 {
  width: 170px !important;
}

.w180 {
  width: 180px !important;
}

.w190 {
  width: 190px !important;
}

.w200 {
  width: 200px !important;
}

.w210 {
  width: 210px !important;
}

.w220 {
  width: 220px !important;
}

.w230 {
  width: 230px !important;
}

.w240 {
  width: 240px !important;
}

.w250 {
  width: 250px !important;
}

.w260 {
  width: 260px !important;
}

.w270 {
  width: 270px !important;
}

.w280 {
  width: 280px !important;
}

.w290 {
  width: 290px !important;
}

.w300 {
  width: 300px !important;
}

.w310 {
  width: 310px !important;
}

.w320 {
  width: 320px !important;
}

.w330 {
  width: 330px !important;
}

.w340 {
  width: 340px !important;
}

.w350 {
  width: 350px !important;
}

.w360 {
  width: 360px !important;
}

.w370 {
  width: 370px !important;
}

.w380 {
  width: 380px !important;
}

.w390 {
  width: 390px !important;
}

.w400 {
  width: 400px !important;
}

.w410 {
  width: 410px !important;
}

.w420 {
  width: 420px !important;
}

.w430 {
  width: 430px !important;
}

.w440 {
  width: 440px !important;
}

.w450 {
  width: 450px !important;
}

.w460 {
  width: 460px !important;
}

.w470 {
  width: 470px !important;
}

.w480 {
  width: 480px !important;
}

.w490 {
  width: 490px !important;
}

.w500 {
  width: 500px !important;
}

.w510 {
  width: 510px !important;
}

.w520 {
  width: 520px !important;
}

.w530 {
  width: 530px !important;
}

.w540 {
  width: 540px !important;
}

.w550 {
  width: 550px !important;
}

.w560 {
  width: 560px !important;
}

.w570 {
  width: 570px !important;
}

.w580 {
  width: 580px !important;
}

.w590 {
  width: 590px !important;
}

.w600 {
  width: 600px !important;
}

.w610 {
  width: 610px !important;
}

.w620 {
  width: 620px !important;
}

.w630 {
  width: 630px !important;
}

.w640 {
  width: 640px !important;
}

.w650 {
  width: 650px !important;
}

.w660 {
  width: 660px !important;
}

.w670 {
  width: 670px !important;
}

.w680 {
  width: 680px !important;
}

.w690 {
  width: 690px !important;
}

.w700 {
  width: 700px !important;
}

.w710 {
  width: 710px !important;
}

.w720 {
  width: 720px !important;
}

.w730 {
  width: 730px !important;
}

.w740 {
  width: 740px !important;
}

.w750 {
  width: 750px !important;
}

.w760 {
  width: 760px !important;
}

.w770 {
  width: 770px !important;
}

.w780 {
  width: 780px !important;
}

.w790 {
  width: 790px !important;
}

.w800 {
  width: 800px !important;
}

.w810 {
  width: 810px !important;
}

.w820 {
  width: 820px !important;
}

.w830 {
  width: 830px !important;
}

.w840 {
  width: 840px !important;
}

.w850 {
  width: 850px !important;
}

.w860 {
  width: 860px !important;
}

.w870 {
  width: 870px !important;
}

.w880 {
  width: 880px !important;
}

.w890 {
  width: 890px !important;
}

.w900 {
  width: 900px !important;
}

.w910 {
  width: 910px !important;
}

.w920 {
  width: 920px !important;
}

.w930 {
  width: 930px !important;
}

.w940 {
  width: 940px !important;
}

.w950 {
  width: 950px !important;
}

.bdNone {
  border: none !important;
}

.bdtNone {
  border-top: none !important;
}

.bdrNone {
  border-right: none !important;
}

.bdbNone {
  border-bottom: none !important;
}

.bdlNone {
  border-left: none !important;
}

.bgNone {
  background: none !important;
}

.vtop {
  vertical-align: top !important;
}

.vmiddle {
  vertical-align: middle !important;
}

.vtop {
  vertical-align: top !important;
}

.vbottom {
  vertical-align: bottom !important;
}

.fnt80 {
  font-size: 80% !important;
}

.fnt85 {
  font-size: 85% !important;
}

.fnt90 {
  font-size: 90% !important;
}

.fnt95 {
  font-size: 95% !important;
}

.fnt100 {
  font-size: 100% !important;
  line-height: 100%;
}

.fnt110 {
  font-size: 110% !important;
  line-height: 110%;
}

.fnt120 {
  font-size: 120% !important;
  line-height: 120%;
}

.fnt130 {
  font-size: 130% !important;
  line-height: 140%;
}

.fnt140 {
  font-size: 140% !important;
  line-height: 140%;
}

.strong {
  font-weight: bold !important;
}

.bold {
  font-weight: bold !important;
}

.normal {
  font-weight: normal !important;
}

.floR {
  float: right !important;
}

.floL {
  float: left !important;
}

.floNone {
  float: none !important;
}

.block {
  display: block;
}

.none {
  display: none;
}

.inline {
  display: inline;
}

.marginAuto {
  margin-left: auto !important;
  margin-right: auto !important;
}

.red {
  color: #c60000 !important;
}

.last_r {
  margin-right: 0 !important;
}

.last_l {
  margin-left: 0 !important;
}

.txtgr {
  color: #007a17 !important;
}

/******************************************************/
/* clear */
/******************************************************/
.clearBoth {
  clear: both;
}

.clear {
  display: inline-block;
}

.clear:after {
  content: ".";
  display: block;
  height: 0;
  visibility: hidden;
  clear: both;
}

/* Hides MacIE5 \*/
* html .clear {
  height: 1%;
}

.clear {
  display: block;
}

/* Hides MacIE5 */
@charset "UTF-8";
.SP {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  .PC {
    display: none !important;
  }
  .SP {
    display: block !important;
  }
}
/******************************************************************
base
******************************************************************/
@media screen and (max-width: 768px) {
  body {
    font-size: 0.9rem !important;
    line-height: 3 !important;
  }
  body main {
    font-size: 0.85rem;
    line-height: 1.5;
  }
  /*Android*/
  html.android body main {
    font-size: 0.7rem;
    line-height: 1.2;
  }
}
a {
  color: #3865e0;
  text-decoration: none;
}

h1, h2 {
  line-height: 2.1;
}

h3 {
  line-height: 2.3;
}

h4 {
  line-height: 2.4;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  -webkit-backface-visibility: hidden;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #B5C1CC;
}

button, input, optgroup, select, textarea {
  color: #000;
  line-height: inherit;
}

body {
  -webkit-animation: fadein 3s forwards;
          animation: fadein 3s forwards;
  overflow-x: hidden;
  color: #1e1318;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 350;
  font-size: 1rem;
  letter-spacing: 0;
}

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

@keyframes fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
a.over {
  opacity: 1;
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease; /* アニメーション設定 */
}

a.over:hover {
  opacity: 0.6; /* マウスオーバー時に半透明に */
}

/******************************************************/
/* ローディング */
/******************************************************/
.loading {
  /*ローディング画面の縦横幅を画面いっぱいになるように指定*/
  width: 100vw;
  height: 100dvh;
  /*ローディング画面の表示位置を固定*/
  position: fixed;
  top: 0;
  left: 0;
  background: #f9f7f3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  /*ローディング画面を0.5秒かけて非表示にする*/
  -webkit-transition: all 0.5s linear;
  transition: all 0.5s linear;
  z-index: 500;
}

/*ローディング画面を非表示にする*/
.loading.loaded {
  /*0.5秒かけてopacityを0にする*/
  opacity: 0;
  visibility: hidden;
}

.loading-text {
  color: #216e92;
  font-size: 70%;
  font-weight: 700;
  text-align: center;
  letter-spacing: 0;
  margin-top: 5px;
}

.spinner {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 3px solid #b7ddee;
  border-left-color: #1381b4;
  /* アニメーションを1秒かけて実行 */
  -webkit-animation: spinner-rotation 1s linear infinite;
          animation: spinner-rotation 1s linear infinite;
}

/* アニメーションの設定 */
@-webkit-keyframes spinner-rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes spinner-rotation {
  0% {
    -webkit-transform: rotate(0);
            transform: rotate(0);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
/******************************************************************
header
******************************************************************/
header {
  z-index: 50;
  position: relative;
}

header .sns.sns_head {
  z-index: 50;
  position: fixed;
  top: 13px;
  right: 50px;
  margin: 0;
  width: 140px;
}

.sns.sns_head li img {
  width: 45%;
}

.sns.sns_head li.fb img {
  width: 30%;
}

@media only screen and (max-width: 768px) {
  header .sns.sns_head {
    top: 3px;
    right: 55px;
    width: 110px;
  }
  .sns.sns_head li img {
    width: 50%;
  }
  .sns.sns_head li.fb img {
    width: 42%;
  }
}
/******************************************************************
pagetop
******************************************************************/
#pagetop {
  width: 40px;
  position: fixed;
  bottom: 15px;
  right: 15px;
  z-index: 5;
}

/******************************************************************
main
******************************************************************/
/* tit_set */
.tit_set {
  width: 100%;
  margin: auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  z-index: 1;
}

.tit_set .tit_left {
  width: 40%;
  z-index: 5;
  text-align: center;
}

.tit_set .tit_left img {
  width: 80%;
  margin: -2vw 0 0 4vw;
}

.tr_wrapper {
  position: relative;
  width: 60%;
}

.tr_wrapper .main_cover {
  z-index: 2;
  width: 18vw;
  margin-left: -60px;
  position: absolute;
  top: 0;
}

.main_txt {
  z-index: 2;
  width: 25vw;
  position: absolute;
  bottom: 15px;
  right: 15px;
  -webkit-filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.5));
          filter: drop-shadow(1px 1px 2px rgba(0, 0, 0, 0.5));
}

.main_left {
  position: absolute;
  max-width: 93px;
  left: 0;
  top: 0;
}

.tit_set .tit_right img {
  width: 100% !important;
  position: relative;
}

@media only screen and (max-width: 768px) {
  /* tit_set */
  .tit_set {
    position: relative;
    height: 100dvh;
    display: block;
  }
  .tit_set .tit_left {
    width: 100%;
  }
  .tit_set .tit_left img {
    width: 85%;
    margin: 65px 0 0 0;
  }
  .tr_wrapper {
    position: absolute;
    bottom: 0;
    width: 100%;
  }
  .tr_wrapper .main_cover {
    display: none;
  }
  .main_left {
    max-width: 55px;
  }
  .main_txt {
    width: 180px;
    bottom: 10px;
    right: 10px;
  }
}
/******************************************************/
/* content */
/******************************************************/
.content_waeapper {
  background: url("../img/bg_blue.svg") no-repeat left 25vh;
  width: 100%;
  background-size: 100%;
  position: relative;
}

.scroll-infinity_top {
  position: absolute;
  top: 3.5vw;
}

.content {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
}

.read_set {
  max-width: 1400px;
  margin: auto;
  padding: 0 100px 50px 100px;
  width: 100%;
  margin-top: -8vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

h2.title_line {
  width: 100%;
  border-bottom: 1px solid #000;
  line-height: 300%;
}

.title_under {
  margin-left: 11.5vw;
  font-size: 140%;
  padding-top: 5px;
}

h2.title_line span {
  width: 100%;
  font-size: 200%;
  border-bottom: 3px solid #000;
  margin-left: 11.2vw;
  font-weight: 500;
  font-style: italic;
  padding-bottom: 5px;
  letter-spacing: 0.1em;
}

h2.title_line span > span {
  margin-left: 0;
  font-size: 60%;
  border-bottom: none;
}

p.rider {
  width: 30%;
}

.rider img {
  max-width: 324px;
}

.txt_set {
  margin-top: 14vw;
  width: 65%;
}

.read_set h2 {
  font-size: 280%;
  font-weight: 700;
  font-style: italic;
  line-height: 160%;
}

.read_set h2 span {
  font-size: 150%;
  display: block;
  padding-left: 20px;
  color: #72bb2a;
}

.read_set p {
  margin-top: 2vw;
  line-height: 250%;
}

/*SP*/
@media screen and (max-width: 768px) {
  .content_waeapper {
    background: url("../img/bg_blue_sp.svg") no-repeat left 12vh;
  }
  .scroll-infinity_top {
    top: 0;
  }
  .read_set {
    max-width: 100%;
    padding: 0 25px 0 25px;
    margin-top: -45px;
    display: block;
  }
  p.rider {
    width: 100%;
    text-align: center;
  }
  .rider img {
    max-width: 100px;
  }
  .txt_set {
    margin-top: 15px;
    width: 100%;
  }
  .read_set h2 {
    font-size: 180%;
    line-height: 160%;
  }
  .read_set h2 span {
    font-size: 130%;
    padding-left: 10px;
  }
  .read_set p {
    margin-top: 15px;
    line-height: 200%;
  }
  h2.title_line {
    width: 100%;
    line-height: 270%;
    margin: 15px 0 0 0;
  }
  .title_under {
    margin: -10px 0 15px 25px;
    font-size: 100%;
    padding-top: 0;
  }
  h2.title_line span {
    font-size: 140%;
    margin-left: 25px;
  }
  h2.title_line span > span {
    font-size: 70%;
  }
}
/******************************************************/
/* categorie */
/******************************************************/
.categorie {
  max-width: 1400px;
  margin: auto;
  padding: 0 100px 50px 100px;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 2.5vw;
  line-height: 180%;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.categorie .cat_title {
  width: 57%;
}

.cat_read {
  margin-bottom: 20px;
}

.categorie .cat_title dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 90%;
}

.categorie .cat_title dl dt {
  width: 120px;
}

.categorie .cat_title dl dd {
  width: 85%;
}

.categorie .cat_title img {
  width: 100%;
  border-bottom: 1px solid #000;
  margin-bottom: 15px;
  padding-bottom: 20px;
}

.categorie .ca_img {
  width: 40%;
}

.categorie .o1 {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
}

.categorie .o2 {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}

.btn_entry {
  background-size: 10px;
  display: block;
  background: #000;
  color: #fff;
  max-width: 380px;
  padding: 12px 35px 12px 25px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 120%;
  font-weight: 600;
  font-style: italic;
  text-align: center;
  clip-path: polygon(0 0, calc(100% - 30px) 0, 100% 100%, calc(100% - 30px) 100%, 0 100%);
  margin-top: 30px;
  overflow: hidden;
  position: relative;
}

a.btn_entry::before {
  content: "";
  width: 100%;
  position: absolute;
  top: -10px;
  right: -60px;
  z-index: -1;
  border-right: 80px solid transparent;
  border-bottom: 120px solid #4e9209;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
  -webkit-transition: -webkit-transform ease 0.4s;
  transition: -webkit-transform ease 0.4s;
  transition: transform ease 0.4s;
  transition: transform ease 0.4s, -webkit-transform ease 0.4s;
}

a.btn_entry:hover::before {
  -webkit-transform: translateX(0);
          transform: translateX(0);
}

.btn_entry span {
  background: url("../img/cate_icon.png") no-repeat left center;
  background-size: 30px;
  padding-left: 35px;
}

/*SP*/
@media screen and (max-width: 768px) {
  .categorie {
    max-width: 100%;
    padding: 0 25px 0 25px;
    display: block;
    margin: 0 0 40px 0;
    line-height: 140%;
  }
  .categorie.cat01 {
    background: url("../img/bg_blue01_sp.svg") no-repeat left 18vw !important;
    background-size: 150% !important;
  }
  .categorie.cat02 {
    background: url("../img/bg_blue02_sp.svg") no-repeat right 18vw !important;
    background-size: 150% !important;
  }
  .categorie.cat03 {
    background: url("../img/bg_blue03_sp.svg") no-repeat left -30vw !important;
    background-size: 250% !important;
  }
  .categorie .cat_title {
    width: 100%;
  }
  .categorie .ca_img {
    width: 70%;
    margin: 0 auto 30px auto;
  }
}
/******************************************************************
spec_box
******************************************************************/
.content_narrow {
  max-width: 1400px;
  margin: 0 auto 0 auto;
  padding: 0 100px 4vw 100px;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 2.5vw;
  line-height: 180%;
}

.spec_box {
  border: solid 1px #d1d1d1;
  padding: 12px 12px 12px 12px;
  margin-top: -30px;
}

.spec_box dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 1px;
}

.spec_box dl:nth-child(2n) dt,
.spec_box dl:nth-child(2n) dd {
  background: none;
}

.spec_box dl dt {
  padding: 10px 5px 10px 15px;
  width: 180px;
  background-color: rgba(226, 226, 226, 0.5);
}

.spec_box dl dd {
  padding: 10px 5px 10px 15px;
  width: 90%;
  background-color: rgba(236, 236, 236, 0.5);
}

.spec_box dl dd span {
  display: block;
  font-size: 80%;
}

.cap {
  display: block;
  font-size: 80%;
  padding-top: 5px;
  text-indent: -1em;
  margin-left: 1em;
  line-height: 150%;
}

/*SP*/
@media screen and (max-width: 768px) {
  .spec_box {
    padding: 5px 5px 2px 5px;
    margin-top: 0;
  }
  .content_narrow {
    max-width: 100%;
    padding: 0 25px 0 25px;
    margin-top: 0;
    line-height: 150%;
    font-size: 90%;
    margin-bottom: 30px;
  }
  .spec_box dl dt {
    padding: 7px 10px 7px 10px;
    width: 120px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .spec_box dl dd {
    padding: 7px 10px 5px 10px;
    width: 90%;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .cap {
    padding-top: 7px;
    line-height: 150%;
  }
}
/******************************************************************
others
******************************************************************/
.banenr {
  margin: auto;
}

/*SP*/
@media screen and (max-width: 768px) {
  .banenr {
    max-width: 100%;
  }
}
/******************************************************************
sponsor
******************************************************************/
.sponsor {
  width: 100%;
  text-align: center;
  margin: 100px 0 70px 0;
}

.sponsor:last-child {
  margin-bottom: 0;
}

h3.sideline {
  font-size: 1.3vw;
  color: #478807;
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; /* 垂直中心 */
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center; /* 水平中心 */
  margin-bottom: 50px;
}

h3.sideline:before, h3.sideline:after {
  border-top: 1px solid #7f7f7f;
  content: "";
  width: 40%; /* 線の長さ */
}

h3.sideline:before {
  margin-right: 1em; /* 文字の右隣 */
}

h3.sideline:after {
  margin-left: 1em; /* 文字の左隣 */
}

.sponsor ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 50%;
  margin: auto;
}

.spo01 {
  width: 40%;
}

.spo02 {
  width: 100%;
}

.spo03 {
  width: 60%;
}

/*SP*/
@media screen and (max-width: 768px) {
  .sponsor {
    margin: 20px 0 30px 0;
  }
  h3.sideline {
    font-size: 100%;
    margin-bottom: 20px;
  }
  h3.sideline:before, h3.sideline:after {
    width: 30%; /* 線の長さ */
  }
  .sponsor ul {
    width: 100%;
  }
  .spo01 {
    width: 70%;
  }
  .spo02 {
    width: 90%;
  }
  .spo03 {
    width: 50%;
  }
}
/******************************************************************
entry
******************************************************************/
.entry {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.entry li {
  width: 48%;
}

.entry_read {
  margin-bottom: 50px;
}

.notice {
  line-height: 150%;
  margin-top: 20px;
}

.notice dt {
  font-weight: 600;
  margin-bottom: 5px;
}

.notice dd {
  font-size: 80%;
  text-indent: -1em;
  margin-left: 1em;
}

/*SP*/
@media screen and (max-width: 768px) {
  .entry_read {
    margin-bottom: 20px;
  }
}
/******************************************************************
result
******************************************************************/
.result {
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

.result li {
  width: 100%;
  max-width: 275px;
}

.result a {
  display: block;
  font-weight: 600;
  font-size: min(1.3vw, 16px);
  text-align: center;
  color: #fff;
  background: #007cd3;
  padding: 20px 0 20px 0;
  letter-spacing: 0.1em;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: relative;
  clip-path: polygon(0% 0%, 95% 0%, 100% 25%, 100% 100%, 0% 100%);
}

/*SP*/
@media screen and (max-width: 768px) {
  .result {
    margin-bottom: -15px;
  }
  .result li {
    max-width: 42vw;
  }
  .result a {
    margin-bottom: 15px;
    font-size: 90%;
    padding: 10px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
}
/******************************************************************
gallery
******************************************************************/
.gallery {
  padding-bottom: 100px;
}

/*SP*/
@media screen and (max-width: 768px) {
  .gallery {
    padding-bottom: 20px;
  }
}
/******************************************************************
news_area
******************************************************************/
.news_area {
  background: #edf4f7;
  padding: 80px 0 0 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

h2.title_line.noline {
  width: 100%;
  border-bottom: none;
  line-height: 300%;
}

h2.title_line.noline span {
  display: block;
  padding-bottom: 0 !important;
  border-bottom: none;
  margin-bottom: -5px;
}

.news_area dl {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  letter-spacing: 0.1em;
  border-bottom: 1px solid #ccc;
  padding-bottom: 20px;
  margin-bottom: 20px;
}

.news_area dl:first-child {
  border-top: 1px solid #ccc;
  padding-top: 20px;
  margin-top: 70px;
}

.news_area dl dt {
  font-weight: 600;
  color: #20b1e5;
  margin-right: 30px;
}

.news_area dl dd a {
  color: #000;
}

.news_area dl dd a:hover {
  text-decoration: underline;
}

a.btn_news {
  display: block;
  width: 300px;
  margin: auto;
  text-align: center;
  background: #72bb2a;
  color: #fff;
  font-size: 110%;
  font-weight: 600;
  padding: 13px 12px 12px 12px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 60px;
}

/*SP*/
@media screen and (max-width: 768px) {
  h2.title_line.noline span {
    display: inline;
  }
  .news_area {
    padding: 10px 0 1px 0;
  }
  h2.title_line.noline {
    line-height: 160%;
  }
  .news_area dl {
    display: block;
    padding-bottom: 10px;
    margin-bottom: 10px;
  }
  .news_area dl dt {
    margin-right: 0;
    margin-bottom: 5px;
  }
  .news_area dl:first-child {
    padding-top: 10px;
    margin-top: 10px;
  }
  a.btn_news {
    display: block;
    width: 100%;
    margin-top: 25px;
  }
}
/******************************************************************
nozawa_area
******************************************************************/
.nozawa_area {
  padding: 100px 100px 100px 100px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: url("../img/nozawa_bg.jpg") no-repeat bottom center #5687de;
  background-size: 100%;
}

.na_inner {
  max-width: 1400px;
  margin: 0 auto 40vw auto;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  text-align: center;
  color: #fff;
}

.nozawa_area h2 {
  font-size: 230%;
  font-weight: 600;
  margin-bottom: 2.5vw;
}

.na_img {
  width: 100%;
}

.na_img img {
  max-width: 363.5px;
}

.na_txt {
  font-size: 110%;
  max-width: 1200px;
  line-height: 250%;
  margin: 2.5vw auto;
}

a.btn_news.bg_white {
  background: #fff;
  color: #000;
  font-weight: 400;
}

/*SP*/
@media screen and (max-width: 768px) {
  .nozawa_area {
    padding: 25px;
  }
  .na_inner {
    max-width: 100%;
  }
  .nozawa_area h2 {
    font-size: 140%;
    line-height: 140%;
    margin-bottom: 10px;
  }
  .na_img img {
    max-width: 200px;
  }
  .na_txt {
    font-size: 100%;
    max-width: 100%;
    line-height: 200%;
    margin: 10px auto;
  }
  a.btn_news.bg_white {
    padding: 0;
  }
}
/******************************************************************
event_area
******************************************************************/
.event_area {
  margin: 100px 0 100px 0;
}

.ebent_read {
  text-align: center;
  margin-bottom: 100px;
  padding: 0 10vw 0 10vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  line-height: 180%;
  font-size: 120%;
}

.event_set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  line-height: 250%;
  width: 100%;
  margin-bottom: 100px;
}

.event_set .tit_event {
  width: 50%;
  margin: 0 10vw 0 5vw;
}

.event_set .tit_event dt {
  font-weight: 500;
  font-size: 200%;
  line-height: 140%;
  padding-left: 15px;
  border-left: 6px solid #05cbbc;
  margin-bottom: 2vw;
}

a.btn_news.bg_green {
  background: #05cbbc;
  color: #fff;
  font-weight: 400;
  padding: 5px;
  margin: 2vw 0 0 0;
}

.event_set .event_img {
  width: 60%;
}

.event_set .event_img img {
  width: 100%;
}

.event_set.img_right .tit_event {
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  margin: 0 5vw 0 10vw;
}

.event_set.img_right .event_img {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}

/*SP*/
@media screen and (max-width: 768px) {
  .event_area {
    margin: 30px 0 0 0;
    padding: 0 25px 0 25px;
    -webkit-box-sizing: border-box;
            box-sizing: border-box;
  }
  .ebent_read {
    margin-bottom: 30px;
    padding: 0 0 0 0;
    font-size: 100%;
  }
  .event_set {
    display: block;
    margin-bottom: 30px;
    padding: 0 0 0 0;
  }
  .event_set .tit_event {
    width: 100%;
    margin: 0 0 0 0;
  }
  .event_set .event_img {
    width: 100%;
    margin-top: 20px;
  }
  .event_set.img_right .tit_event {
    margin: 0 0 0 0;
  }
  .event_set .tit_event dt {
    font-size: 140%;
    padding-left: 10px;
    margin: 20px 0 15px 0;
  }
  .event_set .tit_event dd.ev_txt {
    line-height: 200%;
    margin-bottom: 20px;
  }
}
/******************************************************************
scroll-infinity_bottom
******************************************************************/
.scroll-infinity_bottom {
  margin: 100px 0 100px 0;
  position: relative;
}

.rool {
  position: absolute;
  right: 10vw;
  top: -2.5vw;
  z-index: 10;
}

.rool_logo {
  position: absolute;
  right: 10vw;
  top: -2.5vw;
  z-index: 15;
}

.rool_tit {
  position: absolute;
  left: 9.5vw;
  top: 1.2vw;
  z-index: 20;
}

.rool_tit img {
  width: 20vw;
}

.rool img {
  width: 10vw;
  -webkit-animation: rotation 20s linear infinite;
          animation: rotation 20s linear infinite;
}

.rool_logo img {
  width: 10vw;
}

/* アニメーション */
@-webkit-keyframes rotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes rotation {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
/*SP*/
@media screen and (max-width: 768px) {
  .scroll-infinity_bottom {
    margin: 10px 0 0 0;
  }
  .rool {
    position: absolute;
    right: 20px;
    top: 5px;
  }
  .rool_logo {
    position: absolute;
    right: 20px;
    top: 5px;
  }
  .rool_tit {
    position: absolute;
    left: 25px;
    top: 17px;
  }
  .rool_tit img {
    width: 150px;
  }
  .rool img {
    width: 70px;
    -webkit-animation: rotation 20s linear infinite;
            animation: rotation 20s linear infinite;
  }
  .rool_logo img {
    width: 70px;
  }
}
/******************************************************************
btn_area
******************************************************************/
.btn_area {
  background: #edf4f7;
  padding: 60px 0 1px 0;
}

.btn_set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

.btn_inner {
  width: 48%;
  padding: 20px 40px 40px 40px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  background: #fff;
  text-align: center;
}

a.btn_news.bg_blue {
  background: #007cd3;
  color: #fff;
  font-weight: 400;
  margin: 20px 0 0 0;
  width: 100%;
  font-size: min(1.4vw, 17px);
}

.txt01 {
  color: #b1b1b1;
  margin-bottom: 30px;
  letter-spacing: 0.05em;
}

.btn_inner h3 {
  font-size: min(1.4vw, 20px);
  font-weight: 400;
  margin-bottom: -5px;
}

.btn_inner h3.ico01 span {
  background: url("../img/icon01.png") no-repeat left center;
  background-size: 20%;
  padding-left: 2.5vw;
}

.btn_inner h3.ico02 span {
  background: url("../img/icon02.png") no-repeat left center;
  background-size: 25%;
  padding-left: 3vw;
}

.btn_inner h3.ico03 span {
  background: url("../img/icon03.png") no-repeat left center;
  background-size: 20%;
  padding-left: 3vw;
}

/*SP*/
@media screen and (max-width: 768px) {
  .btn_area {
    padding-top: 30px;
  }
  .btn_inner h3 {
    font-size: 140%;
  }
  .btn_set {
    display: block;
  }
  .btn_inner {
    width: 100%;
    padding: 15px;
    margin-bottom: 25px;
  }
  a.btn_news.bg_blue {
    margin: 10px 0 0 0;
    font-size: 110%;
  }
  .txt01 {
    margin-bottom: 25px;
  }
  .btn_inner h3.ico01 span {
    padding-left: 32px;
  }
  .btn_inner h3.ico02 span {
    padding-left: 42px;
  }
  .btn_inner h3.ico03 span {
    padding-left: 40px;
  }
}
/******************************************************/
/* footer */
/******************************************************/
footer {
  background: url("../img/bg_foot.svg") no-repeat top center;
  background-size: 100%;
  padding: 11vw 0 7vw 0;
  text-align: center;
  letter-spacing: 0;
  font-size: 80%;
  letter-spacing: 0.1em;
  line-height: 220%;
}

footer p img {
  width: 30%;
  margin-bottom: 5vw;
}

.sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 200px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 30px auto;
}

.sns li img {
  width: 35%;
}

.sns li.fb img {
  width: 20%;
}

/*SP*/
@media screen and (max-width: 768px) {
  footer {
    padding: 60px 0 45px 0;
    font-size: 80%;
    line-height: 220%;
    letter-spacing: 0.1em;
  }
  footer p img {
    width: 50%;
    margin-bottom: 20px;
  }
  footer p img {
    width: 70%;
    margin-bottom: 30px;
  }
  .sns {
    width: 150px;
    margin: 30px auto;
  }
  .sns li img {
    width: 60%;
  }
  .sns li.fb img {
    width: 50%;
  }
}
@charset "UTF-8";
/******************************************************************
順番にふわっ
******************************************************************/
.fadeUp2 {
  -webkit-animation-name: fadeUpAnime2;
          animation-name: fadeUpAnime2;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime2 {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime2 {
  from {
    opacity: 0;
    -webkit-transform: translateY(30px);
            transform: translateY(30px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* アニメーションスタートの遅延時間を決めるCSS*/
.delay-time01 {
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}

.delay-time02 {
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}

.delay-time03 {
  -webkit-animation-delay: 0.7s;
          animation-delay: 0.7s;
}

/******************************************************************
ふわっ
******************************************************************/
/* fadeUp */
.fadeUp {
  -webkit-animation-name: fadeUpAnime;
          animation-name: fadeUpAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(25px);
            transform: translateY(25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(25px);
            transform: translateY(25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* fadeDown */
.fadeDown {
  -webkit-animation-name: fadeDownAnime;
          animation-name: fadeDownAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeDownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-25px);
            transform: translateY(-25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}

@keyframes fadeDownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-25px);
            transform: translateY(-25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/* fadeRight */
.fadeRight {
  -webkit-animation-name: fadeRightAnime;
          animation-name: fadeRightAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(25px);
            transform: translateX(25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(25px);
            transform: translateX(25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/* fadeLeft */
.fadeLeft {
  -webkit-animation-name: fadeLeftAnime;
          animation-name: fadeLeftAnime;
  -webkit-animation-duration: 1s;
          animation-duration: 1s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@-webkit-keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-25px);
            transform: translateX(-25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}

@keyframes fadeLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-25px);
            transform: translateX(-25px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeUpTrigger,
.fadeRightTrigger,
.fadeLeftTrigger {
  opacity: 0;
}

.late_00s {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}

.late_01s {
  -webkit-animation-delay: 0.1s;
          animation-delay: 0.1s;
}

.late_02s {
  -webkit-animation-delay: 0.2s;
          animation-delay: 0.2s;
}

.late_03s {
  -webkit-animation-delay: 0.3s;
          animation-delay: 0.3s;
}

.late_04s {
  -webkit-animation-delay: 0.4s;
          animation-delay: 0.4s;
}

.late_05s {
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}

.late_06s {
  -webkit-animation-delay: 0.6s;
          animation-delay: 0.6s;
}

.late_07s {
  -webkit-animation-delay: 0.7s;
          animation-delay: 0.7s;
}

.late_08s {
  -webkit-animation-delay: 0.8s;
          animation-delay: 0.8s;
}

.late_09s {
  -webkit-animation-delay: 0.9s;
          animation-delay: 0.9s;
}

.late_10s {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.late_11s {
  -webkit-animation-delay: 1.1s;
          animation-delay: 1.1s;
}

.late_12s {
  -webkit-animation-delay: 1.2s;
          animation-delay: 1.2s;
}

.late_13s {
  -webkit-animation-delay: 1.3s;
          animation-delay: 1.3s;
}

.late_14s {
  -webkit-animation-delay: 1.4s;
          animation-delay: 1.4s;
}

.late_15s {
  -webkit-animation-delay: 1.5s;
          animation-delay: 1.5s;
}

.late_16s {
  -webkit-animation-delay: 1.6s;
          animation-delay: 1.6s;
}

.late_17s {
  -webkit-animation-delay: 1.7s;
          animation-delay: 1.7s;
}

.late_18s {
  -webkit-animation-delay: 1.8s;
          animation-delay: 1.8s;
}

.late_19s {
  -webkit-animation-delay: 1.9s;
          animation-delay: 1.9s;
}

.late_20s {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}

.late_21s {
  -webkit-animation-delay: 2.1s;
          animation-delay: 2.1s;
}

.late_22s {
  -webkit-animation-delay: 2.2s;
          animation-delay: 2.2s;
}

.late_23s {
  -webkit-animation-delay: 2.3s;
          animation-delay: 2.3s;
}

.late_24s {
  -webkit-animation-delay: 2.4s;
          animation-delay: 2.4s;
}

.late_25s {
  -webkit-animation-delay: 2.5s;
          animation-delay: 2.5s;
}

.late_26s {
  -webkit-animation-delay: 2.6s;
          animation-delay: 2.6s;
}

.late_27s {
  -webkit-animation-delay: 2.7s;
          animation-delay: 2.7s;
}

.late_28s {
  -webkit-animation-delay: 2.8s;
          animation-delay: 2.8s;
}

.late_29s {
  -webkit-animation-delay: 2.9s;
          animation-delay: 2.9s;
}

.late_30s {
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
}

.late_31s {
  -webkit-animation-delay: 3.1s;
          animation-delay: 3.1s;
}

.late_32s {
  -webkit-animation-delay: 3.2s;
          animation-delay: 3.2s;
}

.late_33s {
  -webkit-animation-delay: 3.3s;
          animation-delay: 3.3s;
}

.late_34s {
  -webkit-animation-delay: 3.4s;
          animation-delay: 3.4s;
}

.late_35s {
  -webkit-animation-delay: 3.5s;
          animation-delay: 3.5s;
}

.late_37s {
  -webkit-animation-delay: 3.7s;
          animation-delay: 3.7s;
}

.late_38s {
  -webkit-animation-delay: 3.8s;
          animation-delay: 3.8s;
}

.late_39s {
  -webkit-animation-delay: 3.9s;
          animation-delay: 3.9s;
}

.late_40s {
  -webkit-animation-delay: 4s;
          animation-delay: 4s;
}

.late_41s {
  -webkit-animation-delay: 4.1s;
          animation-delay: 4.1s;
}

.late_42s {
  -webkit-animation-delay: 4.2s;
          animation-delay: 4.2s;
}

.late_43s {
  -webkit-animation-delay: 4.3s;
          animation-delay: 4.3s;
}

.late_44s {
  -webkit-animation-delay: 4.4s;
          animation-delay: 4.4s;
}

.late_45s {
  -webkit-animation-delay: 4.5s;
          animation-delay: 4.5s;
}

.late_46s {
  -webkit-animation-delay: 4.6s;
          animation-delay: 4.6s;
}

.late_47s {
  -webkit-animation-delay: 4.7s;
          animation-delay: 4.7s;
}

.late_48s {
  -webkit-animation-delay: 4.8s;
          animation-delay: 4.8s;
}

.late_49s {
  -webkit-animation-delay: 4.9s;
          animation-delay: 4.9s;
}

.late_30s {
  -webkit-animation-delay: 3s;
          animation-delay: 3s;
}

.late_50s {
  -webkit-animation-delay: 5s;
          animation-delay: 5s;
}

.late_55s {
  -webkit-animation-delay: 5.5s;
          animation-delay: 5.5s;
}

.late_60s {
  -webkit-animation-delay: 6s;
          animation-delay: 6s;
}

.late_65s {
  -webkit-animation-delay: 6.5s;
          animation-delay: 6.5s;
}

/******************************************************************
じわっ
******************************************************************/
.blur {
  -webkit-animation-name: blurAnime;
          animation-name: blurAnime;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
  overflow: hidden;
}

@-webkit-keyframes blurAnime {
  from {
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(1.02);
            transform: scale(1.02);
    opacity: 0;
  }
  to {
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}

@keyframes blurAnime {
  from {
    -webkit-filter: blur(10px);
            filter: blur(10px);
    -webkit-transform: scale(1.02);
            transform: scale(1.02);
    opacity: 0;
  }
  to {
    -webkit-filter: blur(0);
            filter: blur(0);
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
.blurTrigger {
  opacity: 0;
}

/******************************************************************
スライダー
******************************************************************/
.swiper {
  z-index: 0 !important;
}

/* スライドの動き等速 */
.swiper-wrapper {
  -webkit-transition-timing-function: linear !important;
          transition-timing-function: linear !important;
}

/* 画像のサイズ調整 */
.swiper-slide img {
  height: auto;
  width: 100%;
}

/******************************************************************
１文字づつ
******************************************************************/
.eachTextAnime span {
  opacity: 0;
}

.eachTextAnime.appeartext span {
  -webkit-animation: text_anime_on 2s ease-out forwards;
          animation: text_anime_on 2s ease-out forwards;
}

@-webkit-keyframes text_anime_on {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes text_anime_on {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
/******************************************************************
wave
******************************************************************/
.scroll-infinity_top {
  position: relative;
  margin: 0 0 0 0;
}

.kc_bottom {
  position: absolute !important;
  bottom: 0 !important;
  width: 100%;
  z-index: 10;
}

.scroll-infinity_top img {
  vertical-align: bottom;
}

@-webkit-keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

@keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
.scroll-infinity__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
}

.scroll-infinity__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  list-style: none;
  padding: 0 3vw 0 0;
}

.scroll-infinity__list--left {
  -webkit-animation: infinity-scroll-left 30s infinite linear 0.5s both;
          animation: infinity-scroll-left 30s infinite linear 0.5s both;
}

.scroll-infinity__item {
  width: 100vw;
}

.scroll-infinity__item > img {
  width: 100%;
}

@-webkit-keyframes infinity-scroll-right {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
}

@keyframes infinity-scroll-right {
  from {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
  to {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
}
.scroll-infinity__list--right {
  -webkit-animation: infinity-scroll-right 30s infinite linear 0.5s both;
          animation: infinity-scroll-right 30s infinite linear 0.5s both;
}

/* SP */
@media screen and (max-width: 736px) {
  .scroll-infinity__item {
    width: 220vw;
    margin-top: 17px;
  }
}
@charset "UTF-8";
.wrapper {
  height: 100%;
  overflow-x: hidden;
  position: relative;
}

.menu-trigger {
  display: inline-block;
  width: 28px;
  height: 22px;
  vertical-align: middle;
  cursor: pointer;
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 10;
}

.menu-trigger span {
  display: inline-block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  position: absolute;
  left: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}

.menu-trigger.active span {
  background-color: #000;
}

.menu-trigger span:nth-of-type(1) {
  top: 0;
}

.menu-trigger.active span:nth-of-type(1) {
  -webkit-transform: translateY(6px) rotate(-45deg);
          transform: translateY(6px) rotate(-45deg);
}

.menu-trigger span:nth-of-type(2) {
  width: 20px;
  bottom: 13px;
}

.menu-trigger.active span:nth-of-type(2) {
  width: 28px;
  -webkit-transform: translateY(-2px) rotate(45deg);
          transform: translateY(-2px) rotate(45deg);
}

nav {
  width: 100%;
  height: 100%;
  position: fixed;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  top: 0;
  right: 0;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
  background: #00c5ed;
  background-size: 100%;
  overflow-y: auto;
}

nav.open {
  visibility: visible;
  opacity: 1;
}

nav .nav_wrapper {
  position: relative;
  height: 100vh;
  background-size: 100%;
}

@media screen and (max-width: 768px) {
  .menu-trigger {
    top: 18px;
    right: 20px;
  }
}
/******************************************************************
展開メニュー
******************************************************************/
.accordion {
  z-index: 1000;
  width: 100%;
  max-width: 360px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  border-bottom: 1px solid #a8e1ec;
}

.accordion .link {
  cursor: pointer;
  display: block;
  padding: 15px 15px 15px 15px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  border-top: 1px solid #a8e1ec;
  position: relative;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.accordion li i {
  position: absolute;
  top: 16px;
  left: 12px;
  font-size: 18px;
  color: #fff;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.accordion li a {
  color: #fff;
  display: block;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.accordion li a:hover,
.accordion .link:hover {
  color: #fff600;
}

.accordion li i.fa-chevron-down {
  right: 12px;
  left: auto;
  font-size: 16px;
}

.accordion li.open .link {
  color: #fff600;
}

.accordion li.open i {
  color: #fff;
}

.accordion li.open i.fa-chevron-down {
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}

.accordion li.default .submenu {
  display: block;
}

/*Submenu*/
.submenu {
  display: none;
  font-size: 90%;
  padding-bottom: 20px;
}

.submenu a {
  display: block;
  text-decoration: none;
  color: #d9d9d9;
  padding: 10px;
  padding-left: 30px;
}

@media screen and (max-width: 768px) {
  .accordion {
    z-index: 1000;
    width: 100%;
    max-width: 100%;
    margin: 50px auto 30px auto;
    border-bottom: 1px solid #a8e1ec;
  }
  .accordion .link {
    cursor: pointer;
    display: block;
    padding: 5px 10px 5px 10px;
    color: #fff;
  }
  /*Submenu*/
  .submenu a {
    padding-left: 30px;
    line-height: 100%;
  }
}
@charset "UTF-8";
/* Slider */
.slick-loading .slick-list {
  background: #fff url("./ajax-loader.gif") center center no-repeat;
}

/* Icons */
@font-face {
  font-family: "slick";
  font-weight: normal;
  font-style: normal;
  src: url("./fonts/slick.eot");
  src: url("./fonts/slick.eot?#iefix") format("embedded-opentype"), url("./fonts/slick.woff") format("woff"), url("./fonts/slick.ttf") format("truetype"), url("./fonts/slick.svg#slick") format("svg");
}
/* Arrows */
.slick-prev,
.slick-next {
  font-size: 0;
  line-height: 0;
  position: absolute;
  top: 50%;
  display: block;
  width: 20px;
  height: 20px;
  padding: 0;
  -webkit-transform: translate(0, -50%);
  transform: translate(0, -50%);
  cursor: pointer;
  color: transparent;
  border: none;
  outline: none;
  background: transparent;
}

.slick-prev:hover,
.slick-prev:focus,
.slick-next:hover,
.slick-next:focus {
  color: transparent;
  outline: none;
  background: transparent;
}

.slick-prev:hover:before,
.slick-prev:focus:before,
.slick-next:hover:before,
.slick-next:focus:before {
  opacity: 1;
}

.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
  opacity: 0.25;
}

.slick-prev:before,
.slick-next:before {
  font-family: "slick";
  font-size: 20px;
  line-height: 1;
  opacity: 0.75;
  color: white;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-prev {
  left: -25px;
}

[dir=rtl] .slick-prev {
  right: -25px;
  left: auto;
}

.slick-prev:before {
  content: "←";
}

[dir=rtl] .slick-prev:before {
  content: "→";
}

.slick-next {
  right: -25px;
}

[dir=rtl] .slick-next {
  right: auto;
  left: -25px;
}

.slick-next:before {
  content: "→";
}

[dir=rtl] .slick-next:before {
  content: "←";
}

/* Dots */
.slick-dotted.slick-slider {
  margin-bottom: 0;
}

.slick-dots {
  position: absolute;
  bottom: 15px;
  display: block;
  width: 100%;
  padding: 0;
  margin: 0;
  list-style: none;
  text-align: center;
}

.slick-dots li {
  position: relative;
  display: inline-block;
  width: 20px;
  height: 20px;
  margin: 0 2px;
  padding: 0;
  cursor: pointer;
}

.slick-dots li button {
  font-size: 0;
  line-height: 0;
  display: block;
  width: 20px;
  height: 20px;
  padding: 5px;
  cursor: pointer;
  color: transparent;
  border: 0;
  outline: none;
  background: transparent;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
  outline: none;
}

.slick-dots li button:hover:before,
.slick-dots li button:focus:before {
  opacity: 1;
}

.slick-dots li button:before {
  font-family: "slick";
  font-size: 5px;
  line-height: 20px;
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  content: "•";
  text-align: center;
  opacity: 0.5;
  color: #fff;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.slick-dots li.slick-active button:before {
  opacity: 1;
  color: #fff;
}
/* Slider */
.slick-slider {
  position: relative;
  display: block;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -webkit-touch-callout: none;
  -khtml-user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.slick-list {
  position: relative;
  display: block;
  overflow: hidden;
  margin: 0;
  padding: 0;
}

.slick-list:focus {
  outline: none;
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand;
}

.slick-slider .slick-track,
.slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.slick-track {
  position: relative;
  top: 0;
  left: 0;
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.slick-track:before,
.slick-track:after {
  display: table;
  content: "";
}

.slick-track:after {
  clear: both;
}

.slick-loading .slick-track {
  visibility: hidden;
}

.slick-slide {
  display: none;
  float: left;
  height: 100%;
  min-height: 1px;
}

[dir=rtl] .slick-slide {
  float: right;
}

.slick-slide img {
  display: block;
}

.slick-slide.slick-loading img {
  display: none;
}

.slick-slide.dragging img {
  pointer-events: none;
}

.slick-initialized .slick-slide {
  display: block;
}

.slick-loading .slick-slide {
  visibility: hidden;
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid transparent;
}

.slick-arrow.slick-hidden {
  display: none;
}
@charset "UTF-8";
/******************************************************/
/* header */
/******************************************************/
.lower {
  /******************************************************/
  /* main */
  /******************************************************/
  /******************************************************/
  /* 競技内容 */
  /******************************************************/
  /******************************************************/
  /* ヒルクライムスペシャルコンテンツ */
  /******************************************************/
  /******************************************************/
  /* ヒルクライムスポンサー */
  /******************************************************/
  /******************************************************/
  /* お知らせ */
  /******************************************************/
  /* arrow */
  /* pager */
}
.lower .head_logo {
  max-width: 300px;
  position: absolute;
  left: 20px;
  top: 27px;
}
.lower .head_date {
  max-width: 250px;
  position: absolute;
  right: 225px;
  top: 30px;
}
.lower header .sns.sns_head {
  top: 33px;
}
.lower .menu-trigger {
  top: 45px;
}
@media only screen and (max-width: 768px) {
  .lower header {
    height: 55px;
    border-bottom: 5px solid #72bb2a;
  }
  .lower .head_logo {
    width: 55px;
    left: 5px;
    top: 9px;
  }
  .lower header .sns.sns_head {
    top: 4px;
    right: 50px;
  }
  .lower .menu-trigger {
    top: 24px;
    right: 15px;
  }
  .lower .head_date {
    display: none;
  }
}
.lower main {
  padding-top: 100px;
}
.lower .tr_wrapper .main_cover {
  margin-left: -30px !important;
}
.lower .tit_set {
  z-index: -1;
}
.lower .tr_wrapper {
  position: relative;
  width: 67%;
}
.lower .tr_wrapper .main_cover {
  z-index: 2;
  width: 10vw;
  margin-left: -50px;
  position: absolute;
  top: 0;
}
.lower .tit_set .tit_left {
  width: 25%;
  margin: 0 auto 0 6vw;
  text-align: center;
}
.lower .tit_set .tit_left.gravel img {
  width: 100%;
  margin: -2vw 0 0 1.5vw;
}
.lower .main_left {
  width: 7vw;
}
.lower .slick-dots {
  display: none !important;
}
@media only screen and (max-width: 768px) {
  .lower .tit_set {
    height: auto;
  }
  .lower main {
    padding-top: 0;
  }
  .lower .tr_wrapper {
    width: 100%;
  }
  .lower .tit_set .tit_left {
    width: 50%;
    margin: 0 auto 0 auto;
  }
  .lower .main_left {
    display: none;
  }
  .lower .tit_set .tit_left img,
  .lower .tit_set .tit_left.gravel img {
    margin: 30px auto 30px auto;
  }
}
.lower h3.lower_tit {
  font-weight: 600;
  font-size: 150%;
  border-bottom: 1px solid #000;
  margin: 60px 0 50px 0;
  line-height: 200%;
}
.lower .breadcrumb {
  margin-left: 11.2vw;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  margin-top: 5px;
  margin-bottom: 40px;
}
@media only screen and (max-width: 768px) {
  .lower .breadcrumb {
    margin-top: 0;
  }
}
.lower .breadcrumb ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5em;
  font-size: 80%;
  font-weight: 500;
}
.lower .breadcrumb li::after {
  content: ">";
  margin-left: 0.5em;
}
.lower .breadcrumb li:last-child::after {
  content: "";
}
.lower .lead {
  font-weight: 500;
  line-height: 260%;
  margin-bottom: 40px;
}
.lower .spec_box {
  margin-top: 0;
}
.lower .spec_box.cl01 dl {
  display: block;
}
.lower .spec_box.cl01 dl dt {
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-weight: 600;
}
.lower .spec_box.cl01 dl dd {
  background: #fff;
  border-bottom: 1px solid #ccc;
  width: 100%;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
.lower .spec_box.cl01 dl dd:last-child {
  border-bottom: none !important;
}
.lower .clm_2set,
.lower .clm_3set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.lower .clm_2set .clm01,
.lower .clm_2set .clm02 {
  width: 48%;
}
.lower .clm_3set .clm01,
.lower .clm_3set .clm02,
.lower .clm_3set .clm03 {
  width: 32%;
}
.lower .clm_2set .clm01 iframe,
.lower .clm_2set .clm02 iframe {
  width: 100%;
  aspect-ratio: 16/9;
}
.lower .ind_dl li {
  text-indent: -1em;
  margin-left: 1em;
  line-height: 200%;
}
@media only screen and (max-width: 768px) {
  .lower .breadcrumb {
    margin-left: 30px;
    margin-bottom: 15px;
  }
  .lower h3.lower_tit {
    font-size: 120%;
    margin: 20px 0 20px 0;
  }
  .lower .lead {
    line-height: 220%;
    margin-bottom: 20px;
  }
  .lower .ind_dl li {
    line-height: 180%;
  }
  .lower .clm_2set,
  .lower .clm_3set {
    display: block;
  }
  .lower .clm_2set .clm01,
  .lower .clm_2set .clm02,
  .lower .clm_3set .clm01,
  .lower .clm_3set .clm02,
  .lower .clm_3set .clm03 {
    margin-bottom: 20px;
    width: 100%;
  }
  .lower .clm_2set .clm01:last-child,
  .lower .clm_2set .clm02:last-child,
  .lower .clm_3set .clm01:last-child,
  .lower .clm_3set .clm02:last-child,
  .lower .clm_3set .clm03:last-child {
    margin-bottom: 0;
  }
}
.lower .sp_set {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  background: #f0f6fb;
  padding: 20px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.lower .sp_set .sp_right {
  width: 60%;
  padding: 50px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  line-height: 200%;
}
.lower .sp_logo {
  text-align: center;
  margin-bottom: 30px;
}
.lower .sp_set .sp_right h3 {
  font-weight: 800;
  font-size: 150%;
}
@media only screen and (max-width: 768px) {
  .lower .sp_set {
    display: block;
    padding: 15px;
  }
  .lower .sp_set .sp_right {
    width: 100%;
    padding: 0;
  }
  .lower .sp_logo {
    width: 50%;
    margin: 25px auto 25px auto;
  }
  .lower .sp_set .sp_right h3 {
    font-weight: 800;
    font-size: 140%;
    line-height: 150%;
    margin-bottom: 15px;
  }
}
.lower .spo_learge {
  margin-bottom: 20px;
}
.lower .spo_small {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  width: 100%;
}
.lower .spo_small li {
  margin: 40px 40px 0 0;
}
@media only screen and (max-width: 768px) {
  .lower .spo_learge {
    width: 40%;
    margin-bottom: 0;
  }
  .lower .spo_small li {
    width: 25%;
    margin: 20px 20px 0 0;
  }
}
.lower .news_set {
  margin-bottom: 40px;
}
.lower .news_set h2 {
  font-size: 130%;
  margin-bottom: 15px;
  font-weight: 600;
  color: #007cd3;
  border-bottom: 1px solid #000000;
}
.lower .news_set h3 {
  font-size: 125%;
  font-weight: 500;
  margin-bottom: 5px;
}
.lower .news_set p {
  margin-bottom: 10px;
}
.lower .news_set a.ns_link {
  color: #000;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: end;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
}
.lower .arrow_right {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 1px;
  margin: 0 0 0 7px;
  border-radius: 9999px;
  background-color: #72bb2a;
}
.lower .arrow_right::before {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  right: 0;
  width: 8px;
  height: 1px;
  border-radius: 9999px;
  background-color: #72bb2a;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transform-origin: calc(100% - 0.5px) 50%;
          transform-origin: calc(100% - 0.5px) 50%;
}
.lower .arrow_left {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 1px;
  margin: 0 7px 0 0;
  border-radius: 9999px;
  background-color: #72bb2a;
}
.lower .arrow_left::before {
  content: "";
  position: absolute;
  top: calc(50% - 0.5px);
  left: 0;
  width: 8px;
  height: 1px;
  border-radius: 9999px;
  background-color: #72bb2a;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
  -webkit-transform-origin: 0.5px 50%;
          transform-origin: 0.5px 50%;
}
.lower .pager {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  line-height: 100%;
}
.lower .pager .page_num {
  display: block;
  border: solid 1px #c3c3c3;
  padding: 5px 10px 7px 10px;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  color: #000;
  margin: 0 5px 0 5px;
}
.lower .pager .page_num.active,
.lower .pager .page_num:hover {
  background: #000;
  color: #fff;
}
.lower .pager .pager_next, .lower .pager .pager_prev {
  margin: 0 15px;
  font-size: 78%;
}
@media only screen and (max-width: 768px) {
  .lower .news_set {
    margin-bottom: 20px;
  }
  .lower .news_set h2 {
    font-size: 120%;
    margin-bottom: 5px;
  }
  .lower .news_set h3 {
    margin-bottom: 0;
  }
  .lower .pager .pager_next, .lower .pager .pager_prev {
    margin: 0 5px;
    font-size: 100%;
  }
  .lower .pager .page_num {
    margin: 0 3px 0 3px;
  }
}

.singleArticle p {
  line-height: 1.9;
  letter-spacing: 0.1em;
  margin-bottom: 40px;
}
.singleArticle strong {
  font-weight: bold;
}
.singleArticle .wp-block-image img {
  max-width: 1024px;
  width: 100%;
}
.singleArticle .wp-block-image.size-full {
  margin: 0 auto 40px;
}
.singleArticle .wp-block-embed-youtube.aligncenter {
  text-align: center;
}
.singleArticle .wp-block-embed-youtube.alignright {
  text-align: right;
}
.singleArticle .wp-block-table {
  margin: 30px 0;
}
.singleArticle .wp-block-table table {
  border-collapse: collapse;
}
.singleArticle .wp-block-table thead {
  border-bottom: 3px solid;
}
.singleArticle .wp-block-table th, .singleArticle .wp-block-table td {
  border: 1px solid;
  padding: 10px;
}

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