@charset "utf-8";
/* CSS Document */

/* reset */
/* 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 {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
  display: block;
  box-sizing: border-box;
}
body {
  line-height: 1;
}
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 {
  max-width: 100%;
  height: auto;
  width: auto;
  display: block;
}
/*-----------------*/

html, body, main {
  margin: 0px;
  padding: 0px;
  width: 100%;
  height: 100%;
  scroll-behavior: smooth;
  font-size: clamp(13px,calc(26 / 750 * 100vw),26px);
  font-family: "Zen Kaku Gothic New",'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ','Mayryo','ＭＳ Ｐゴシック','MS PGothic',sans-serif;
  color:#111111;
  line-height:1.5em;
  letter-spacing: 0.12em;
}
.jost {
  font-family: "Jost", "Zen Kaku Gothic New",'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','メイリオ','Mayryo','ＭＳ Ｐゴシック','MS PGothic',sans-serif;
}
.mincho {
  font-family: "Zen Old Mincho", serif!important;
}
.spitem {
  display: block;
}
.pcitem {
  display: none;
}

@media screen and (min-width:750px){
  html, body, main {
    font-size: 18px;
  }
.spitem {
  display: none;
}
.pcitem {
  display: block;
}
}

section {
  height: 100vh;
}

.container {
}

.scroll_container {
  --totalwidth: 700;
  height: calc((var(--totalwidth) / 750) * 100vh);
}

.horizontal_scroll {
  position: absolute;
  top: 0;
  height: 100%;
  width:  calc(var(--totalwidth) / 750 * 100vw);
  will-change: transform;
  display: flex;
  justify-content: space-between;
    transform: translate3d(calc(clamp(0px,var(--percentage-val) * 1%,var(--percentage-val) * 1% - 100vw) * -1),0, 0);
  z-index: 3;
  gap:0;
}

.scroll_contents {
  --contentwidth: 750;
  height: 100%;
  width: calc(var(--contentwidth) / 750 * 100vw);
  position: relative;
  box-sizing: border-box;
  padding-bottom: clamp(90px,calc(180 / 750 * 100vw),180px);
}

.sticky_wrap {
  overflow: hidden;
  position: sticky;
  top: 0;
  height: 100vh;
}

@media screen and (min-width:750px){
  .scroll_container {
    --totalwidth-pc: 700;
    height: calc((var(--totalwidth-pc) / 1920) * 100vh);
  }

  .horizontal_scroll {
    width:  calc(var(--totalwidth-pc) / 1920 * 100vw);
  }

  .scroll_contents {
    --contentwidth-pc: 1920;
    width: calc(var(--contentwidth-pc) / 1920 * 100vw);
    padding-bottom: 110px;
  }
  .fv__section {
    height: 1000px;
  }
}




/*---- fv ---------------------*/
.fv {
  background: url(../img/webp/fv_bg_sp.webp) no-repeat 50% 50%;
  -webkit-background-size: cover;
  background-size: cover;
  position: relative;
  display: block;
  width: 100%;
  height: 100svh;
  overflow: hidden;
  z-index: 3;
}
.fv__title {
  display: block;
  width: calc(670 / 750 * 100%);
  z-index: 3;
  position: relative;
  margin: 0 auto;
  transform: translate3d(0,calc(230 / 700 * 100%),0);
}
.fv__front {
  display: block;
  position: absolute;
  width: 100%;
  bottom: -1px;
  left: 0;
  z-index: 5;
}
.fv__imgbox {
  display: block;
  position: absolute;
  width: 100%;
  bottom: 0%;
  left: 0;
  z-index: 4;
  transform: translate3d(0,2%,0);
}
.fv__img {
  display: block;
  position: relative;
  z-index: 4;
  margin: 0 auto;
}
.fv__item--01 {
  position: absolute;
  display: block;
  z-index: 2;
  width: calc(120 / 750 * 100%);
  left: calc(-10 / 750 * 100%);
  bottom: 56%;
}
.fv__item--02 {
  position: absolute;
  display: block;
  z-index: 2;
  width: calc(177 / 750 * 100%);
  right: calc(-10 / 750 * 100%);
  bottom: 46%;
}
.fv__item--03 {
  position: absolute;
  display: block;
  z-index: 2;
  width: calc(315 / 750 * 100%);
  right: calc(20 / 750 * 100%);
  bottom: 0%;
  box-sizing: border-box;
  padding-bottom: calc(424 / 750 * 100%);
}
.fv__bal {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}


@media screen and (min-width:750px){
  .fv {
    background: url(../img/webp/fv_bg_pc.webp) no-repeat 50% 50%;
    -webkit-background-size: cover;
    background-size: cover;
    height: 1000px;
  }
  .fv__title {
    width: calc(570 / 900 * 100%);
    max-width: 570px;
    transform: translate3d(9%,50%,0);
  }
  .fv__front img {
    display: block;
    margin: 0 auto;
    max-width: 100%;
    width: 100%;
  }
  .fv__imgbox {
    display: block;
    position: absolute;
    width: 140%;
    max-width: 1320px;
    margin: 0 auto;
    box-sizing: border-box;
    padding-right: clamp(0px,calc(97 / 1320 * 100%),97px);
    bottom: 0%;
    left: 50%;
    z-index: 4;
    transform: translate3d(-50%,8%,0);
  }
  .fv__img {
    display: block;
    position: relative;
    z-index: 4;
    margin: 0 auto;
  }
  .fv img {
    display: block;
    margin: 0 auto;
  }
  .fv__item--01 {
    position: absolute;
    display: block;
    z-index: 2;
    width: calc(96 / 900 * 100%);
    left: calc(50% - clamp(0px,calc(400 / 1320 * 100%),400px));
    max-width: 96px;
    bottom: calc(810 / 1080 * 100%);
  }
  .fv__item--02 {
    position: absolute;
    display: block;
    z-index: 2;
    width: calc(155 / 900 * 100%);
    max-width: 155px;
    right: calc(50% - clamp(0px,calc(400 / 1320 * 100%),400px));
    bottom: auto;
    top: 2%;
  }
  .fv__item--03 {
    position: absolute;
    display: block;
    z-index: 2;
    width: calc(297 / 900 * 100%);
    max-width: 297px;
    right: calc(50% - clamp(0px,calc(420 / 1320 * 100%),420px));
    bottom: 46%;
    box-sizing: border-box;
    padding-bottom: 0;
  }
  .fv__bal img {
    width: auto;
    height: 100vh;
    object-fit: cover;
    z-index: 1;
  }

}

/*-----------------------------------------------------------*/
.scroll_container {
  background: url(../img/webp/grass_bg.webp) repeat top center;
  -webkit-background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
  background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
}

.content01__content {
  background-image: -moz-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);  
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  flex-direction: column;
  height: 100%;
  gap: clamp(30px,calc(60 / 750 * 100vw),60px);
  z-index: 3;
}
.content01__catch {
  text-align: center;
  font-size: calc(40 / 26 * 1em);
  line-height: calc(64 / 40 * 1em);
  font-weight: 500;
}
.content01__catchimg {
  display: block;
  margin: clamp(15px,calc(30 / 750 * 100vw),30px) auto 0;
  width: calc(467 / 750 * 100%);
}

.scrollicon {
  position: relative;
  display: block;
  margin: 0;
  width: calc(182 / 750 * 100%);
}
.scrollicon__img {
  display: block;
  position: relative;
  z-index: 3;
}
.scrollicon__ar {
  position: absolute;
  z-index: 2;
  width: 100%;
  top: 0;
  left: 0;
}
.scrollicon__text {
  position: absolute;
  z-index: 2;
  width: 100%;
  top: 0;
  left: 0;
}


@media screen and (min-width:750px){
  .horizontal_scroll {
  background-image: -moz-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%); 
  }
  .content01__content {
    gap: 90px;
  }
  .content01__catch {
    font-size: 32px;
    line-height: calc(50 / 32 * 1em);
  }
  .content01__catchimg {
    display: block;
    margin: 20px auto 0;
    width: 416px;
  }
  .scrollicon {
    width: 182px;
  }
}



/* ----------------- keiba */
#keiba {
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 999;
  overflow: hidden;
  width: 100%;
}
.keiba__box {
  position: relative;
  margin: 0 auto 0 0;
  overflow: hidden;
  display: block;
  width: 100%;
}
.keiba__item {
  --keiba-scroll: 0;
  position: absolute;
  bottom: 0;
  left: calc(var(--keiba-scroll) * 1%);
  width: 100vw;
}
.keiba__inner {
  position: relative;
  display: block;
  width: 100vw;
  height: 0;
  padding-bottom: clamp(185px,calc(270 / 750 * 100vw),270px);
  z-index: 2;
}
.keiba__bg {
  position: relative;
  margin: 0 auto;
  overflow: hidden;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: flex-end;
  align-items: flex-end;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: flex-end;
  flex-direction: column;
  z-index: 1;
}
.keiba__bg .keiba__fence {
  width: 100%;
  height: 0;
  padding-bottom: clamp(45px,calc(90 / 750 * 100vw),90px);
  background: url(../img/webp/fence_rp.webp) repeat-x bottom center;
  -webkit-background-size: clamp(150px,calc(300 / 750 * 100vw),300px) auto;
  background-size: clamp(150px,calc(300 / 750 * 100vw),300px) auto;
}
.keiba__bg .keiba__green {
  width: 100%;
  height: 0;
  padding-bottom: clamp(90px,calc(180 / 750 * 100vw),180px);
  background: url(../img/webp/grass_bg.webp) repeat top center;
  -webkit-background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
  background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
}

.horse {
  display: block;
  position: absolute;
  bottom: 0;
  left: calc(var(--percentage-val) * 1%);
  width: clamp(95px,calc(190 / 750 * 100vw),190px);
  z-index: 3;
  transform: translate3d(-100%,0,0);
}


#keiba__nav {
  position: absolute;
  z-index: 9999;
  bottom: 0;
  right: 0;
  width: calc(400 / 750 * 100vw);
  box-sizing: border-box;
  padding-bottom:  calc(20 / 750 * 100vw);
  padding-right:  calc(40 / 750 * 100vw);
  opacity: 1;
  transition: all .5s ease;
}
.keiba__progressbar {
  background: #fff;
  position: relative;
  width: 100%;
  box-sizing: border-box;
  display: block;
  margin: 0 0 clamp(5px,calc(10 / 750 * 100vw),10px);
}
.keiba__progressbar:after {
  content: "";
  display: block;
  width: 100%;
  bottom: 0;
  right: 0;
  background: #fff;
  height: clamp(2px,calc(4 / 750 * 100vw),4px);
  z-index: 2;
}
.keiba__progress--now {
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: calc(var(--percentage-val) * 1%);
  background: #d22515;
  height: 200%;
}
.keiba__progressnum {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: flex-end;
  width: 100%;
  gap: clamp(15px,calc(30 / 750 * 100vw),30px);
}
.keiba__progressnum__item {
  width: clamp(15px,calc(30 / 750 * 100vw),30px);
  box-sizing: border-box;
}


@media screen and (min-width:750px){
  .keiba__inner {
    padding-bottom:200px;
  }
  .keiba__bg .keiba__fence {
    padding-bottom: 90px;
    background: url(../img/webp/fence_rp.webp) repeat-x bottom center;
    -webkit-background-size: auto 50px;
    background-size: auto 50px;
  }
  .keiba__bg .keiba__green {
    padding-bottom: 100px;
    background: url(../img/webp/grass_bg.webp) repeat top center;
    -webkit-background-size: 400px auto;
    background-size: 400px auto;
  }
  .horse {
    width: 180px;
    bottom: -60px;
  }


  #keiba__nav {
    width: 390px;
    padding-bottom: 20px;
    padding-right: 30px;
  }
  .keiba__progressbar {
    margin: 0 0 10px;
  }
  .keiba__progressbar:after {
    content: "";
    display: block;
    width: 100%;
    bottom: 1px;
    right: 0;
    background: #fff;
    height: 4px;
    z-index: 2;
  }
  .keiba__progress--now {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: calc(var(--percentage-val) * 1%);
    background: #d22515;
    height: 10px;
  }
  .keiba__progressnum {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
      -ms-align-items: center;
      align-items: center;
      -webkit-box-pack: justify;
      -ms-flex-pack: justify;
      justify-content: flex-end;
    width: 100%;
    gap: clamp(15px,calc(30 / 750 * 100vw),30px);
  }
  .keiba__progressnum__item {
    width: 30px;
  }

}

/* ---------------- /keiba */

.halon {
  width: clamp(25px,calc(50 / 750 * 100vw),50px);
  position: absolute;
  bottom: 0;
  left: clamp(20px,calc(40 / 750 * 100vw),40px);
  z-index: 10;
  padding-bottom: clamp(90px,calc(180 / 750 * 100vw),180px);
}
.halon--goal {
  width: clamp(200px,calc(400 / 750 * 100vw),400px);
  position: absolute;
  bottom: 0;
  right: clamp(310px,calc(620 / 750 * 100vw),620px);
  z-index: 10;
  padding-bottom: clamp(90px,calc(180 / 750 * 100vw),180px);
}

@media screen and (min-width:750px){
  .halon {
    width: 40px;
    left: 50px;
    padding-bottom: 110px;
  }
  .halon--goal {
    width: 310px;
    right: 400px;
    padding-bottom: 110px;
  }
}
/*---------------------*/


.content02__content {
  background-image: -moz-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -webkit-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  background-image: -ms-linear-gradient( 90deg, rgb(107,184,248) 0%, rgb(214,240,255) 50%, rgb(255,255,255) 100%);
  height: 100%;
  position: relative;
  z-index: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
}
.content02__item {
  background: #fff;
  box-shadow: calc(10 / 750 * 100vw) calc(20 / 750 * 100vw) calc(30 / 750 * 100vw) 0px rgba(28, 103, 164, 0.2);
  border-radius: clamp(20px,calc(40 / 750 * 100vw),40px);
  width: calc(670 / 750 * 100%);
  overflow: hidden;
  position: relative;
  display: block;
 }
.content02__item .content02__img {
  display: block;
  margin: 0;
}
.content02__item .content02__box {
  box-sizing: border-box;
  padding: calc(40 / 670 * 100%) 0;
  text-align: center;
}
.content02__item .content02__catch {
  font-size: calc(30 / 26 * 1em);
  line-height: calc(60 / 30 * 1em);
}
.content02__item .marker--bk {
  color: #fff;
  display: inline-block;
  background: #000;
  line-height: 1.2em;
  box-sizing: border-box;
  padding: .3em .8em .1em;
  font-feature-settings: 'palt' 1;
  font-weight: 700;
}
.content02__item .text--yw {
  color: #ffe63f;
}
.content02__item .content02__text {
  font-size: calc(24 / 26 * 1em);
  font-weight: 400;
  letter-spacing: 0.12em;
  margin: 1.25em auto;
}
.content02__item .content02__text span {
  font-size: calc(34 / 24 * 1em);
  font-weight: 700;
}
.content02__item .content02__message {
  font-size: calc(34 / 24 * 1em);
  font-weight: 700;
  line-height: calc(50 / 34 * 1em);
}

@media screen and (min-width:750px){
  .content02__item {
    box-shadow: 10px 17.321px 30px 0px rgba(28, 103, 164, 0.2);
    border-radius: 40px;
    width: calc(920 / 1000 * 100%);
    max-width: 920px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: stretch;
    align-items: stretch;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
   }

  .content02__item .content02__img {
    display: block;
    margin: 0;
    width: 50%;
  }
  .content02__item .content02__box {
    box-sizing: border-box;
    padding: calc(60 / 920 * 100%) 0;
    text-align: center;
    width: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-around;
    flex-direction: column;
  }
  .content02__item .content02__catch {
    font-size: clamp(11px,calc(22 / 920 * 100vw),22px);
    line-height: calc(50 / 22 * 1em);
  }
  .content02__item .marker--bk {
    line-height: 1.1em;
    box-sizing: border-box;
    padding: .3em .7em .4em;
    font-feature-settings: 'palt' 1;
    font-weight: 700;
  }
  .content02__item .content02__text {
    font-size: calc(16 / 18 * 1em);
    margin: 1.5em auto auto;
    box-sizing: border-box;
    line-height: calc(40 / 18 * 1em);
  }
  .content02__item .content02__text span {
    font-size: calc(28 / 16 * 1em);
    line-height: 1em;
  }
  .content02__item .content02__message {
    font-size: clamp(13px,calc(26 / 920 * 100vw),26px);
    line-height: calc(40 / 26 * 1em);
    margin: auto;
  }  
}

/*---------------------*/


.content03__content {
  background-image: url(../img/webp/content03_bg_top.webp) , url(../img/webp/content03_bg_btm.webp) , url(../img/webp/content03_bg_illust.webp),-moz-linear-gradient( 90deg, rgb(255,194,62) 0%, rgb(255,230,63) 100%);
  background-image: url(../img/webp/content03_bg_top.webp) , url(../img/webp/content03_bg_btm.webp) , url(../img/webp/content03_bg_illust.webp),-webkit-linear-gradient( 90deg, rgb(255,194,62) 0%, rgb(255,230,63) 100%);
  background-image: url(../img/webp/content03_bg_top.webp) , url(../img/webp/content03_bg_btm.webp) , url(../img/webp/content03_bg_illust.webp),-ms-linear-gradient( 90deg, rgb(255,194,62) 0%, rgb(255,230,63) 100%);
  background-repeat: no-repeat;
  -webkit-background-size: clamp(230px,calc(460 / 750 * 100vw),460px) auto ,clamp(350px,calc(700 / 750 * 100vw),700px) auto ,clamp(1080px,calc(2160 / 750 * 100vw),2160px) auto , cover;
  background-size: clamp(230px,calc(460 / 750 * 100vw),460px) auto ,clamp(350px,calc(700 / 750 * 100vw),700px) auto ,clamp(1080px,calc(2160 / 750 * 100vw),2160px) auto , cover;
  background-position: top left , bottom right , bottom center , bottom center;
  height: 100%;
  position: relative;
  z-index: 3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: flex-start;
}
.content03__box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  flex-direction: column;
  width: 75%;
}
.content03__catch {
  width: 100%;
  background: url(../img/webp/content03_main_img_sp.webp) no-repeat bottom left;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  box-sizing: border-box;
  position: relative;
  height: 0;
  padding-bottom: calc(340 / 2464 * 100%);
}
.content03__catch h2 {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100vw;
  text-align: center;
  transform: translate3d(0,-50%,0);
  font-size: calc(50 / 26 * 1em);
  font-feature-settings: 'palt' 1;
  line-height: calc(74 / 50 * 1em);
  letter-spacing: 0.12em;
  font-weight: 900;
  box-sizing: border-box;
  padding-left: .5em;
}
.content03__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: flex-start;
  width: 100%;
}
.content03__listitem {
  box-sizing: border-box;
  width: 100vw;
  padding: clamp(30px,calc(60 / 750 * 100vw),60px);
}
.content03__listitem p {
  line-height: calc(50 / 26 * 1em);
  letter-spacing: 0.12em;
  text-align: justify;
}

.content03__message {
  width: 25%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  flex-direction: column;
  box-sizing: border-box;
  position: relative;
  box-sizing: border-box;
  padding-bottom: calc(60 / 750 * 100%);
}
.content03__messagetext {
  position: relative;
  display: block;
  width: calc(650 / 750 * 100%);
  margin: 0;
  box-sizing: border-box;
  padding-bottom: calc(40 / 750 * 100%);
  opacity: 1;
  transform: translate3d(0,0,0);
  transition: all 1.2s ease;
}
.content03__messagetext.hideitem {
  opacity: 0;
  transform: translate3d(0,-10%,0);
}
.content03__messagetext > span {
  display: block;
  position: relative;
  z-index: 2;
}
.content03__messagetext__text {
  position: absolute;
  top: 44.2%;
  left: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  z-index: 3;
  transform: translate3d(-50%,0,0);
  gap: .4em
}
.content03__messagetext__textitem {
  width: clamp(44px,calc(87 / 750 * 100vw),87px);
  margin: 0;
  transition: all 1.2s ease;
  transition-delay: 0.6s;
  opacity: 1;
  transform: translate3d(0,0,0);
  position: relative;
  z-index: 2;
  display: block;
}
.content03__messagetext__textitem:nth-child(2) {
  transition-delay: 1s;
}
.content03__messagetext__textitem:nth-child(3) {
  transition-delay: 1.4s;
}
.content03__messagetext__textitem:nth-child(4) {
  transition-delay: 1.8s;
}
.hideitem .content03__messagetext__textitem {
  opacity: 0;
  transform: translate3d(0,100%,0);
}
.content03__messagesign{
  position: absolute;
  bottom: 0;
  right: calc(50 / 750 * 100%);
  display: block;
  width: calc(630 / 750 * 100%);
  margin: 0;
}


@media screen and (min-width:750px){
  .content03__content{
    align-items: stretch;
  }
  .content03__box {
    justify-content: flex-start;
    box-sizing: border-box;
    padding-top: 80px;

  }
.content03__catch {
  background: url(../img/webp/content03_main_img_pc.webp) no-repeat bottom left;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  padding-bottom: calc(340 / 2110 * 100%);
}
  .content03__catch h2 {
    width: calc(100% / 3);
    text-align: center;
    transform: translate3d(0,-50%,0);
    font-size: clamp(25px,calc(50 / 1920 * 100vw),50px);
    font-feature-settings: 'palt' 1;
    line-height: calc(74 / 50 * 1em);
    letter-spacing: 0.12em;
    padding-left: .5em;
  }
  .content03__listitem {
    box-sizing: border-box;
    width: calc(100% / 3);
    padding: 40px 40px 80px;
  }
  .content03__listitem p {
    line-height: calc(40 / 18 * 1em);
    max-width: 550px;
    margin: 0 auto;
  }

  .content03__message {
    width: 25%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: flex-start;
    flex-direction: column;
    box-sizing: border-box;
    position: relative;
    box-sizing: border-box;
    padding-top: 80px;
    padding-bottom: 0;
    height: 100%;
  }
  .content03__messagetext {
    position: relative;
    display: block;
    width: calc(650 / 700 * 100%);
    margin: 0;
    padding-bottom: calc(40 / 750 * 100%);
    transform: translate3d(0,calc(36 / 380 * 100% * -1),0);
  }
  .content03__messagetext > span {
    display: block;
    position: relative;
    z-index: 2;
  }
  .content03__messagetext__text {
    position: absolute;
    top: 40.2%;
    left: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: center;
    z-index: 3;
    transform: translate3d(-50%,0,0);
    gap: .4em
  }
  .content03__messagetext__textitem {
    width: 20%;
    margin: 0;
    transition: all 1.2s ease;
    opacity: 1;
    transform: translate3d(0,0,0);
    position: relative;
    z-index: 2;
    display: block;
  }
  .hideitem .content03__messagetext__textitem {
    opacity: 0;
    transform: translate3d(0,100%,0);
  }
  .content03__messagesign{
    position: absolute;
    bottom: 0;
    right: 50%;
    transform: translate3d(50%,0,0);
    display: block;
    width: calc(630 / 750 * 100%);
    margin: 0 a;
  }

}
/*---------------------*/


.content04__content {
  background: transparent;
  height: 100%;
  overflow: hidden;
  position: relative;
  z-index: 3;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0% 100%);
}

.content04__message {
  position: absolute;
  top: 43%;
  left: calc(50 / 750 * 100%);
  background-color: rgba(255,255,255,0.9);
  display: block;
  box-sizing: border-box;
  width: calc(650 / 750 * 100%);
  max-width: 650px;
  border-radius: clamp(20px,calc(40 / 750 * 100vw),40px);
  margin: 0 auto;
  padding: calc(40 / 750 * 100%);
  line-height: calc(50 / 26 * 1em);
  letter-spacing: 0.12em;
  text-align: justify;
  opacity: 1;
  transition: all 1.2s ease;
  transform: translate3d(0,0%,0);
}
.content04__message.hideitem {
  opacity: 0;
  transform: translate3d(0,30%,0);
}


.clipedbg {
  position: relative;
  top: 0;
  left: calc(var(--contentinner-per) * 50%);
  width: 100%;
  height: 100vh;
}
.clipedbg__box {
  position: relative;
  overflow: hidden;
  width: 100vw;
  height: 100%;
}
.clipedbg__box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media screen and (min-width:750px) {
  .clipedbg {
    left: 0;
  }
  
.content04__message {
  top: 46%;
  left: 50%;
  background-color: rgba(255,255,255,0.9);
  display: block;
  box-sizing: border-box;
  width: calc(700 / 750 * 100%);
  max-width: 700px;
  border-radius: 40px;
  padding:30px 50px;
  line-height: calc(40 / 18 * 1em);
  transform: translate3d(-50%,0,0);
}
.content04__message.hideitem {
  opacity: 0;
  transform: translate3d(-50%,30%,0);
}

  
}

/*---------------------*/

.content05__content {
  height: 100%;
}
.content05__content .clipedbg__box {
  background: #10142c;
}
.content05__content .clipedbg__box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: 50% 40%;
}


.content05__message {
  position: absolute;
  top: 50%;
  left: calc(50 / 750 * 100%);
  background-color: rgba(255,255,255,0.9);
  display: block;
  box-sizing: border-box;
  width: calc(650 / 750 * 100%);
  max-width: 650px;
  border-radius: clamp(20px,calc(40 / 750 * 100vw),40px);
  margin: 0 auto;
  padding: calc(60 / 650 * 100%) calc(40 / 650 * 100%);
  line-height: calc(50 / 26 * 1em);
  letter-spacing: 0.12em;
  text-align: justify;
  opacity: 1;
  transition: all 1.2s ease;
  transform: translate3d(0,-50%,0);
  box-sizing: border-box;
}
.content05__message.hideitem {
  opacity: 0;
  transform: translate3d(0,-20%,0);
}
.content05__message h2 {
  background: #111111;
  color: #fff;
  font-size: calc(36 / 26 * 1em);
  font-weight: 700;
  text-align: center;
  line-height: 1.75em;
  box-sizing: border-box;
  margin-bottom: 0.8em;
}

@media screen and (min-width:750px) {

  .content05__content .clipedbg__box img {
    object-fit: cover;
    object-position: 50% 50%;
  }


  .content05__message {
    top: 60%;
    left: 50%;
    width: calc(700 / 750 * 100%);
    max-width: 700px;
    border-radius: 40px;
    margin: 0 auto;
    padding: 50px 50px;
    line-height: calc(40 / 18 * 1em);
    transform: translate3d(-50%,-50%,0);
  }
  .content05__message.hideitem {
    opacity: 0;
    transform: translate3d(-50%,-20%,0);
  }
  .content05__message h2 {
    font-size: calc(28 / 18 * 1em);
    line-height: 1.5em;
    box-sizing: border-box;
    margin-bottom: 0.4em;
  }

}


/*---------------------*/


.content06__content {
  background-image: url(../img/webp/content06_img_sp.webp);
  background-repeat: no-repeat;
  background-position: 0 0;
  -webkit-background-size: cover;
  background-size: cover;
  height: 100%;
  position: relative;
  z-index: 3;
}
.content06__area {
  position: relative;
  display: block;
  width: 100%;
  padding-left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  height: 100%;
}
.content06__item {
  display: block;
  position: relative;
  background-image: url(../img/webp/content06_item_sp.webp);
  -webkit-background-size: contain;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom left;
  width: 100vw;
  height: 100%;
  box-sizing: border-box;
}
.content06__fire {
  display: block;
  position: absolute;
  width: clamp(65px,calc(129 / 750 * 100vw),129px);
  height: clamp(65px,calc(129 / 750 * 100vw),129px);
  cursor: pointer;
  bottom: calc(710  / 750 * 100vw);
  right: 8%;
  z-index: 4;
}
.content06__firebox {
  position: absolute;
  top: 50%;
  left: calc(50 / 750 * 100vw);
  background-color: rgba(255,255,255,0.9);
  display: block;
  box-sizing: border-box;
  width: calc(650 / 750 * 100vw);
  max-width: 650px;
  border-radius: clamp(20px,calc(40 / 750 * 100vw),40px);
  margin: 0 auto;
  padding: calc(40 / 650 * 100vw) calc(40 / 650 * 100vw);
  line-height: calc(50 / 26 * 1em);
  letter-spacing: 0.12em;
  text-align: justify;
  opacity: 5;
  transition: all 1.2s ease;
  transform: translate3d(0,-50%,0);
  box-sizing: border-box;
  font-size: calc(22 / 26 * 1em);
  line-height: calc(40 / 22 * 1em);
  z-index: 5;
}
.content06__firebox.hideitem {
  opacity: 0;
  transform: translate3d(0,-20%,0);
}
.content06__firebox h2 {
  font-size: calc(28 / 22 * 1em);
  font-weight: 700;
  margin-bottom: .5em;
}
.content06__fireclose {
  text-align: center;
  margin-top: 1em;
  font-size: calc(20 / 22 * 1em);
  cursor: pointer;
}
.content06__fireclose span {
  display: inline-block;
  border: 1px solid;
  border-radius: 3em;
  padding: 0 4em;
  font-weight: 700;
}

.content06__box {
  background: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: stretch;
  align-items: stretch;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: calc(1300 / 2200 * 100%);
  margin: 0 auto 0 calc(20 / 2200 * 100%);
  position: relative;
  box-sizing: border-box;
  padding: calc(40 / 1500 * 100%);
  border-radius: clamp(20px,calc(40 / 750 * 100vw),40px);
}
.content06__ttl {
  line-height: calc(70 / 36 * 1em);
  font-size: calc(36 / 26 * 1em);
  margin-bottom: 1em;
}
.content06__ttl span {
  background: #111111;
  color: #fff;
  display: inline-block;
  font-weight: 700;
  display: inline-block;
  box-sizing: border-box;
  padding: .2em .5em;
  line-height: 1.25em;
  
}
.content06__inbox {
  width: calc(550 / 1200 * 100%);
  line-height: calc(50 / 26 * 1em);
}
.content06__image {
  max-width: 550px;
  margin: 0;
  display: block;
}
.content06__glass {
  position: absolute;
  bottom: 0;
  right: 0;
}
.content06__glassitem {
  position: absolute;
  bottom: 0;
  right: 0;
}
.content06__inbox--02 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  flex-direction: column;
}
.content06__glass {
  display: block;
  width: clamp(65px,calc(130 / 750 * 100vw),130px);
  position: absolute;
  bottom: 0;
  right: 0;
  cursor: pointer;
  transform: translate3d(70%,20%,0);
  z-index: 4;
}
.content06__glassitem {
  display: block;
  width: clamp(105px,calc(210 / 750 * 100vw),210px);
  position: absolute;
  bottom: 20%;
  right: 1%;
  cursor: pointer;
  transform: translate3d(70%,20%,0);
  z-index: 3;
  opacity: 1;
  filter: blur(0);
  transition: all 1.2s ease;
}
.content06__glassitem.hideitem {
  transform: translate3d(70%,40%,0);
  opacity: 0;
  filter: blur(1em);
}


@media screen and (min-width:750px) {
  .content06__content {
    background-color: #c58c64;
    background-image: url(../img/webp/content06_img_pc.webp);
    background-repeat: no-repeat;
    background-position: 50% 0%;
    -webkit-background-size: cover;
    background-size: cover;
  }
  .content06__area {
    box-sizing: border-box;
    margin: 0 auto;
    box-sizing: border-box;
    padding-left:0;
    justify-content: center;
  }
.content06__item {
  display: block;
  position: relative;
  background-image: url(../img/webp/content06_item_pc.webp);
  -webkit-background-size: contain;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: bottom left;
  width: 613px;
  height: 100%;
  box-sizing: border-box;
  margin-right: 30px;
}
  .content06__fire {
    display: block;
    position: absolute;
    width: clamp(0px,calc(119 / 612 * 100%),119px);
    height: clamp(0px,calc(115 / 612 * 100%),115px);
    bottom: 0;
    box-sizing: border-box;
    padding-bottom: clamp(0px,118%,85svh);
    right:  clamp(0px,calc(30 / 612 * 100%),80px);
    z-index: 4;
  }
  .content06__firebtn {
    cursor: pointer;
  }
  .content06__firebox {
    position: absolute;
    top: 50%;
    left: 50%;
    background-color: rgba(255,255,255,0.9);
    display: block;
    box-sizing: border-box;
    width: 500px;
    max-width: 500px;
    border-radius:40px;
    margin: 0;
    padding: 50px;
    line-height: calc(30 / 14 * 1em);
    letter-spacing: 0.12em;
    text-align: justify;
    opacity: 5;
    transition: all 1.2s ease;
    transform: translate3d(-125%,-50%,0);
    font-size: calc(14 / 18 * 1em);
    z-index: 5;
  }
  .content06__firebox.hideitem {
    opacity: 0;
    transform: translate3d(-125%,-20%,0);
  }
  .content06__firebox h2 {
    font-size: calc(20 / 14 * 1em);
    font-weight: 700;
    margin-bottom: .5em;
  }
  .content06__fireclose {
    text-align: center;
    margin-top: 1em;
    font-size: calc(12 / 14 * 1em);
  }
  .content06__box {
    background: #fff;
    display: block;
    width: calc(100% - 100px);
    max-width: 800px;
    margin: 0;
    position: relative;
    box-sizing: border-box;
    padding: 50px;
    border-radius: 40px;
    line-height: calc(40 / 18  * 1em);
  }
  .content06__ttl {
    line-height: calc(60 / 28 * 1em);
    font-size: calc(28 / 18 * 1em);
    margin-bottom: 0.5em;
  }
  .content06__ttl span {
    background: #111111;
    color: #fff;
    display: inline-block;
    font-weight: 700;
    display: inline-block;
    box-sizing: border-box;
    padding: .2em .8em;
    padding-right: 0.2em;
    line-height: 1.25em;
    margin-right: -1px;
    position: relative;

  }
  .content06__ttl br + span {
    padding-left: 0;
    padding-right: 0.8em;
  }
.content06__ttl h2 {
  line-height: 1em;
}
  .content06__ttl br {
    display: none;
  }
  .content06__inbox {
    width: 100%;
    line-height: calc(40 / 18 * 1em);
  }
  .content06__image {
    max-width: 700px;
    margin: 50px  auto 0;
    display: block;
  }
  .content06__glass {
    position: absolute;
    bottom: 0;
    right: 0;
  }
  .content06__glassitem {
    position: absolute;
    bottom: 0;
    right: 0;
  }
  .content06__inbox--02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -ms-align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    flex-direction: column;
  }
  .content06__glass {
    display: block;
    width: clamp(65px,calc(130 / 750 * 100vw),130px);
    position: absolute;
    bottom: 0;
    right: 0;
    cursor: pointer;
    transform: translate3d(70%,20%,0);
    z-index: 4;
  }
  .content06__glassitem {
    display: block;
    width: clamp(105px,calc(210 / 750 * 100vw),210px);
    position: absolute;
    bottom: 20%;
    right: 1%;
    cursor: pointer;
    transform: translate3d(70%,20%,0);
    z-index: 3;
    opacity: 1;
    filter: blur(0);
    transition: all 1.2s ease;
  }
  .content06__glassitem.hideitem {
    transform: translate3d(70%,40%,0);
    opacity: 0;
    filter: blur(1em);
  }
  
}
/*---------------------*/


.content07__content {
  background-image: url(../img/webp/content07_screen_sp.webp),url(../img/webp/content07_img_sp.webp);
  background-repeat: no-repeat;
  background-position: bottom right , top left;
  -webkit-background-size: calc(2490 / 2700 * 100%) auto , cover;
  background-size: calc(2490 / 2700 * 100%) auto ,cover;
  height: 100%;
  position: relative;
  z-index: 3;
}
.content07__box {
  position: relative;
  width: 100vw;
  height: 100%;
  display: block;
}
.content07__copy {
  display: block;
  width: calc(600 / 750 * 100%);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%,-50%,0);
  opacity: 1;
  filter: blur(0);
  transition: all 1.2s ease;
}
.content07__copy.hideitem {
  transform: translate3d(-50%,-0%,0);
  opacity: 0;
  filter: blur(1em);
}


@media screen and (min-width:750px) {

.content07__content {
  background-image: url(../img/webp/content07_screen_pc.webp),url(../img/webp/content07_img_pc.webp);
  background-repeat: no-repeat;
  background-position: bottom right , top left;
  -webkit-background-size: calc(2140 / 2900 * 100%) auto , cover;
  background-size: calc(2140 / 2900 * 100%) auto ,cover;
  height: 100%;
  position: relative;
  z-index: 3;
}
.content07__box {
  position: relative;
  width: 800px;
  height: 100%;
  display: block;
}
.content07__copy {
  display: block;
  width: calc(538 / 800 * 100%);
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate3d(-50%,-50%,0);
  opacity: 1;
  filter: blur(0);
  transition: all 1.2s ease;
}
.content07__copy.hideitem {
  transform: translate3d(-50%,-0%,0);
  opacity: 0;
  filter: blur(1em);
}

}

/* ------------------------------------------- */
.grass {
  background: url(../img/webp/grass_bg.webp) repeat top center;
  -webkit-background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
  background-size: clamp(200px,calc(400 / 750 * 100vw),400px) auto;
  height: auto;
}
.grass__item {
  margin: 0 auto;
  box-sizing: border-box;
  padding: calc(40 / 750 * 100%) 0;
}
.grass__sttl {
  text-align: center;
}
.grass__sttl:before {
  content: "";
  display: block;
  height: clamp(35px,calc(70 / 750 * 100vw),70px);
  width: clamp(35px,calc(70 / 750 * 100vw),70px);
  background: url(../img/webp/icon_horseshoe.webp) no-repeat 50% 50%;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  margin: 0 auto;
}
.grass__sttl h2 {
  color: #fff;
  font-size: calc(40 / 26 * 1em);
  font-weight: 900;
  letter-spacing: 0.12em;
  font-feature-settings: 'palt' 1;
  margin: 0.8em auto;
}
.grass__sttl .grass__sttl--l {
  font-size: calc(60 / 40 * 1em);
  line-height: calc(96 / 60 * 1em);
  letter-spacing: 0.12em;
}
.grass__sttl .jost {
  font-weight: 600;
}
.grass__sttl .grass__sttl--l .jost {
  font-size: calc(72 / 60 * 1em);
  font-weight: 600;
  letter-spacing: 0.12em;
}
.grass__box {
  position: relative;
  width: 100%;
  margin: 0 auto;
  overflow: hidden;
}
.grass__image {
  display: block;
  position: relative;
  z-index: 3;
  margin: 0 auto;
}
.grass__image--01 {
  width: calc(720 / 750 * 100%);
  margin-bottom: clamp(-334px,calc(334 / 750 * 100% * -1),-152px);
}
.grass__image--02 {
  width: calc(720 / 750 * 100%);
  margin-bottom: clamp(-260px,calc(260 / 750 * 100% * -1),-130px);
}
.grass__image--03 {
  width: calc(990 / 750 * 100%);
  margin-left: clamp(-120px,calc(120 / 750 * 100% * -1),-60px);
  margin-right: clamp(-120px,calc(120 / 750 * 100% * -1),-60px);
}
.grass__box--03 {
  position: relative;
  z-index: 3;
  margin-bottom: clamp(-240px,calc(240 / 750 * 100% * -1),-120px);
}
.grass__textbox {
  display: block;
  background: #fff;
  position: relative;
  width: calc(670 / 750 * 100%);
  z-index: 2;
  margin: 0 auto;
  border-radius: clamp(40px,calc(80 / 750 * 100vw),80px);
  padding-top: clamp(140px,calc(280 / 750 * 100%),280px);
}
.grass__image--02 + .grass__textbox {
  padding-top: clamp(120px,calc(240 / 750 * 100%),240px);
} 
.grass__textbox--03  {
  padding-top: clamp(134px,calc(268 / 750 * 100%),268px);
} 
.grass__box .grass__catch {
  background: #f06c01;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  padding: calc(30 / 670 * 100%) 0;
}
.grass__catch h3 {
  font-size: calc(38 / 26 * 1em);
  font-weight: 900;
  line-height: calc(72 / 38 * 1em);
}
.grass__box h3 span {
  font-size: calc(76 / 38 * 1em);
  line-height: 1em;
  display: inline-block;
}
.grass__box .grass__text {
  box-sizing: border-box;
  line-height: calc(50 / 26 * 1em);
  padding: calc(30 / 670 * 100%) calc(50 / 670 * 100%) calc(50 / 670 * 100%);
}
.grass__bal {
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: 4;
  transform: translate3d(-50%,0,0);
  width: calc(550 / 730 * 100%);
} 
.grass__bal h3 {
  background: #000;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  position: relative;
  margin: 0 auto;
  z-index: 2;
  padding: calc(30 / 550 * 100%) 0;
  width: 100%;
  margin: 0 auto;
  font-size: calc(38 / 26 * 1em);
  font-weight: 900;
  line-height: calc(62 / 38 * 1em);
  border-radius: clamp(10px,calc(20 / 750 * 100vw),20px);
}
.grass__bal h3 span {
  color: #ffe63f;
  font-size: calc(46 / 38 * 1em);
}
.grass__bal:after {
  content: "";
  display: block;
  background: url(../img/bal_tsuno.svg) no-repeat top left;
  -webkit-background-size: contain;
  background-size: contain;
  height: clamp(27px,calc(54 / 750 * 100vw),54px);
  width: clamp(27px,calc(54 / 750 * 100vw),54px);
  z-index: 1;
  position: absolute;
  bottom: 0;
  left: 58%;
  transform: translate3d(0,60%,0);
}

.btn--ig {
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
  padding: calc(40 / 750 * 100%) calc(70 / 750 * 100%) calc(80 / 750 * 100%);
  
}



@media screen and (min-width:750px){
.grass__item {
  margin: 0 auto;
  box-sizing: border-box;
  padding: 20px 0 60px;
}
.grass__sttl:before {
  content: "";
  height: 50px;
  width: 50px;
}
.grass__sttl h2 {
  color: #fff;
  font-size: calc(32 / 18 * 1em);
  font-weight: 900;
  letter-spacing: 0.12em;
  font-feature-settings: 'palt' 1;
  margin: 0.8em auto;
}
  .grass__sttl--pcspacer {
    margin-top: .3em;
    display: inline-block;
  }
.grass__sttl .grass__sttl--l {
  font-size: calc(52 / 32 * 1em);
  line-height: calc(86 / 52 * 1em);
  letter-spacing: 0.12em;
}
.grass__sttl .jost {
  font-weight: 600;
}
.grass__sttl .grass__sttl--l .jost {
  font-size: calc(64 / 52 * 1em);
  font-weight: 600;
  letter-spacing: 0.12em;
}
.grass__box {
  position: relative;
  width: calc(100% - 20px);
  max-width: 950px;
  margin: 0 auto;
  overflow: hidden;
}
.grass__image {
  display: block;
  position: relative;
  z-index: 3;
  margin: 0 auto;
}
.grass__image--01 {
  width: calc(720 / 950 * 100%);
  margin-bottom: clamp(-300px,calc(300 / 950 * 100% * -1),-150px);
}
.grass__image--02 {
  width: calc(720 / 950 * 100%);
  margin-bottom: clamp(-260px,calc(260 / 950 * 100% * -1),-130px);
}
.grass__image--03 {
  width: calc(990 / 950 * 100%);
  margin-left: clamp(-20px,calc(20 / 950 * 100% * -1),-10px);
  margin-right: clamp(-20px,calc(20 / 950 * 100% * -1),-10px);
}
  .grass img {
    margin-left: auto;
    margin-right: auto;
}
.grass__box--03 {
  position: relative;
  z-index: 3;
  margin-bottom: clamp(-240px,calc(240 / 950 * 100% * -1),-120px);
}
.grass__textbox {
  display: block;
  background: #fff;
  position: relative;
  width: 100%;
  z-index: 2;
  margin: 0 auto;
  border-radius: 80px;
  padding-top: clamp(130px,calc(260 / 950 * 100%),260px);
}
.grass__image--02 + .grass__textbox {
  padding-top: clamp(120px,calc(240 / 950 * 100%),240px);
} 
.grass__textbox--03  {
  padding-top: clamp(134px,calc(268 / 950 * 100%),268px);
} 
.grass__box .grass__catch {
  background: #f06c01;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  padding: 25px 0;
}
.grass__catch h3 {
  font-size: calc(30 / 18 * 1em);
  font-weight: 900;
  line-height: calc(62 / 30 * 1em);
}
.grass__box h3 span {
  font-size: calc(62 / 30 * 1em);
  line-height: 1em;
  display: inline-block;
}
.grass__box .grass__text {
  box-sizing: border-box;
  line-height: calc(40 / 18 * 1em);
  padding: 30px 50px 80px;
}
.grass__bal {
  position: absolute;
  bottom: 0;
  left: 50%;
  z-index: 4;
  transform: translate3d(-50%,0,0);
  width: calc(550 / 730 * 100%);
} 
.grass__bal h3 {
  background: #000;
  color: #fff;
  text-align: center;
  box-sizing: border-box;
  position: relative;
  margin: 0 auto;
  z-index: 2;
  padding: 30px 0;
  width: 100%;
  margin: 0 auto;
  font-size: calc(30 / 18 * 1em);
  font-weight: 900;
  line-height: calc(62 / 38 * 1em);
  border-radius: 20px;
}
.grass__bal h3 span {
  color: #ffe63f;
  font-size: calc(38 / 30 * 1em);
}
.grass__bal:after {
  content: "";
  display: block;
  background: url(../img/bal_tsuno.svg) no-repeat top left;
  -webkit-background-size: contain;
  background-size: contain;
  height: clamp(27px,calc(54 / 750 * 100vw),54px);
  width: clamp(27px,calc(54 / 750 * 100vw),54px);
  z-index: 1;
  position: absolute;
  bottom: 0;
  left: 58%;
  transform: translate3d(0,60%,0);
}

.btn--ig {
  display: block;
  margin: 0 auto;
  box-sizing: border-box;
  padding: 0 0 100px;
  width: 500px;
  
}

  
}



/* ----------------------------- */
.cl {
  position: relative;
}
.cl .container {
  position: relative;
  z-index: 3;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  -ms-align-items: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  flex-direction: column;
}
.cl__item {
  position: relative;
  display: block;
  margin: 0 auto;
}
.cl__img {
  position: relative;
  display: block;
  margin: 0 auto;
  z-index: 2;
  box-sizing: border-box;
  padding-bottom: calc(50 / 750 * 100%)
}
.cl__btn {
  box-sizing: border-box;
  width: calc(640 / 750 * 100%);
  position: absolute;
  bottom: 0;
  z-index: 5;
  left: 50%;
  transform: translate3d(-50%,0,0);  
}
#copyright {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  color: #fff;
  font-size: clamp(8px,calc(16 / 750 * 100vw),16px);
  text-align: center;
  padding: .5em 0;
  box-sizing: border-box;
  z-index: 2;
}
.moviebg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.moviebg:before {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(0,0,0,0.5);
  z-index: 2;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
}
.moviebg video {
  position: absolute;
  top: -1px;
  left: -1px;
  right: -1px;
  bottom: -1px;
  z-index: 1;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  object-fit: cover;
  z-index: 1;
}


@media screen and (min-width:750px){
.cl__img {
  position: relative;
  display: block;
  margin: 0 auto;
  z-index: 2;
  box-sizing: border-box;
  padding-bottom: 200px;
  width: 709px;
}
.cl__btn {
  width: 540px;
}
#copyright {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  color: #fff;
  font-size: 12px;
  text-align: center;
  padding: 1em 0;
  box-sizing: border-box;
  z-index: 2;
}
  
}






/* animation ------------------------------------------------------------------*/


.fv__title span{
  display: block;
  -webkit-animation-name: expand;
  -moz-animation-name: expand;
  -o-animation-name: expand;
  animation-name: expand;
  -webkit-animation-duration: 2.2s;
  -moz-animation-duration: 2.2s;
  -o-animation-duration: 2.2s;
  animation-duration: 2.2s;
  -webkit-animation-timing-function: ease-in-out;
  -moz-animation-timing-function: ease-in-out;
  -o-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}
@-webkit-keyframes expand {
  from, 0% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    -o-transform: scale(1.05);
    transform: scale(1.05);
  }
  to, 100% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes expand {
  from, 0% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
  50% {
    -webkit-transform: scale(1.05);
    -ms-transform: scale(1.05);
    -o-transform: scale(1.05);
    transform: scale(1.05);
  }
  to, 100% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1);
  }
}



.fv__item--01 img {
  display: block;
  -webkit-animation-name: fvitem--01;
  -moz-animation-name: fvitem--01;
  -o-animation-name: fvitem--01;
  animation-name: fvitem--01;
  -webkit-animation-duration: 3.2s;
  -moz-animation-duration: 3.2s;
  -o-animation-duration: 3.2s;
  animation-duration: 3.2s;
  -webkit-animation-timing-function: ease-in-out;
  -moz-animation-timing-function: ease-in-out;
  -o-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: top right;
}

@keyframes fvitem--01 {
  from, 0% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
  50% {
    transform: translate3d(0,-3%,0) rotate(8deg);
  }
  to, 100% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
}
.fv__item--02 img {
  display: block;
  -webkit-animation-name: fvitem--02;
  -moz-animation-name: fvitem--02;
  -o-animation-name: fvitem--02;
  animation-name: fvitem--02;
  -webkit-animation-duration: 3.2s;
  -moz-animation-duration: 3.2s;
  -o-animation-duration: 3.2s;
  animation-duration: 3.2s;
  -webkit-animation-timing-function: ease-in-out;
  -moz-animation-timing-function: ease-in-out;
  -o-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: 80% 0%;
}

@keyframes fvitem--02 {
  from, 0% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
  50% {
    transform: translate3d(0,-3%,0) rotate(0deg);
  }
  to, 100% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
}


.scrollicon__ar {
  display: block;
  -webkit-animation-name: scrar;
  -moz-animation-name: scrar;
  -o-animation-name: scrar;
  animation-name: scrar;
  -webkit-animation-duration: 1.8s;
  -moz-animation-duration: 1.8s;
  -o-animation-duration: 1.8s;
  animation-duration: 1.8s;
  -webkit-animation-timing-function: ease;
  -moz-animation-timing-function: ease;
  -o-animation-timing-function: ease;
  animation-timing-function: ease;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: 50% 50%;
}

@keyframes scrar {
  from, 0% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
  50% {
    transform: translate3d(0,3%,0) rotate(0deg);
  }
  to, 100% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
}
.scrollicon__text {
  display: block;
  -webkit-animation-name: roll;
  -moz-animation-name: roll;
  -o-animation-name: roll;
  animation-name: roll;
  -webkit-animation-duration: 20s;
  -moz-animation-duration: 20s;
  -o-animation-duration: 20s;
  animation-duration: 20s;
  -webkit-animation-timing-function: linear;
  -moz-animation-timing-function: linear;
  -o-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: 50% 50%;
}

@keyframes roll {
  from, 0% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
  to, 100% {
    transform: translate3d(0,0%,0) rotate(360deg);
  }
}

/* 馬全体*/
.horse {
  transform: translate3d(-110%,0,0);
  left: calc(var(--percentage-val2) * (var(--percentage-val2) * 0.5)  * var(--keiba-run) * 1%);
}


/* 馬まばらに移動 */
.keiba__start .horse {
  -webkit-animation-name: horse;
  -moz-animation-name: horse;
  -o-animation-name: horse;
  animation-name: horse;
  -webkit-animation-duration: 10s;
  -moz-animation-duration: 10s;
  -o-animation-duration: 10s;
  animation-duration: 10s;
  -webkit-animation-timing-function: linear;
  -moz-animation-timing-function: linear;
  -o-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: 50% 50%;
  z-index: 3;
}

@keyframes horse {
  from, 0% {
    transform: translate3d(-100%,-70%,0);
  }
  30% {
    transform: translate3d(0%,-80%,0);
  }
  60% {
    transform: translate3d(-10%,-60%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-70%,0);
  }
}


.keiba__start .horse--02 {
  -webkit-animation-name: horse02;
  -moz-animation-name: horse02;
  -o-animation-name: horse02;
  animation-name: horse02;
  -webkit-animation-duration: 15s;
  -moz-animation-duration: 15s;
  -o-animation-duration: 15s;
  animation-duration: 15s;
  z-index: 1;
}

@keyframes horse02 {
  from, 0% {
    transform: translate3d(-100%,-110%,0);
  }
  30% {
    transform: translate3d(-50%,-100%,0);
  }
  40% {
    transform: translate3d(-10%,-120%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-110%,0);
  }
}



.keiba__start .horse--03 {
  -webkit-animation-name: horse03;
  -moz-animation-name: horse03;
  -o-animation-name: horse03;
  animation-name: horse03;
  -webkit-animation-duration: 20s;
  -moz-animation-duration: 20s;
  -o-animation-duration: 20s;
  animation-duration: 20s;
  z-index: 3;
}

@keyframes horse03 {
  from, 0% {
    transform: translate3d(-100%,-65%,0);
  }
  20% {
    transform: translate3d(-120%,-50%,0);
  }
  80% {
    transform: translate3d(-20%,-60%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-65%,0);
  }
}

.keiba__start .horse--04 {
  -webkit-animation-name: horse04;
  -moz-animation-name: horse04;
  -o-animation-name: horse04;
  animation-name: horse04;
  -webkit-animation-duration: 10s;
  -moz-animation-duration: 10s;
  -o-animation-duration: 10s;
  animation-duration: 10s;
  z-index:3 ;
}

@keyframes horse04 {
  from, 0% {
    transform: translate3d(-100%,-70%,0);
  }
  30% {
    transform: translate3d(-0%,-60%,0);
  }
  70% {
    transform: translate3d(-150%,-70%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-70%,0);
  }
}


.keiba__start .horse--05 {
  -webkit-animation-name: horse04;
  -moz-animation-name: horse04;
  -o-animation-name: horse04;
  animation-name: horse04;
  -webkit-animation-duration: 20s;
  -moz-animation-duration: 20s;
  -o-animation-duration: 20s;
  animation-duration: 20s;
  animation-delay: 6s;
  z-index:3;
 transform: translate3d(-100%,-70%,0);
}

.keiba__start .horse--06 {
  -webkit-animation-name: horse06;
  -moz-animation-name: horse06;
  -o-animation-name: horse06;
  animation-name: horse06;
  -webkit-animation-duration: 10s;
  -moz-animation-duration: 10s;
  -o-animation-duration: 10s;
  animation-duration: 10s;
  animation-delay: 3s;
  z-index:2;
  transform: translate3d(-100%,-110%,0);
}

@keyframes horse06 {
  from, 0% {
    transform: translate3d(-100%,-110%,0);
  }
  30% {
    transform: translate3d(-50%,-110%,0);
  }
  40% {
    transform: translate3d(-10%,-120%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-110%,0);
  }
}


.keiba__start .horse--07 {
  -webkit-animation-name: horse07;
  -moz-animation-name: horse07;
  -o-animation-name: horse07;
  animation-name: horse07;
  -webkit-animation-duration: 15s;
  -moz-animation-duration: 15s;
  -o-animation-duration: 15s;
  animation-duration: 15s;
  z-index: 4;
  left: calc(var(--percentage-val2) * (var(--percentage-val2) * 0.5) * (var(--keiba-accerarate) * 0.3) * var(--keiba-run) * 1% );
}

@keyframes horse07 {
  from, 0% {
    transform: translate3d(-100%,-50%,0);
  }
  20% {
    transform: translate3d(-130%,-45%,0);
  }
  80% {
    transform: translate3d(-40%,-40%,0);
  }
  to, 100% {
    transform: translate3d(-100%,-50%,0);
  }
}




.content06__fire img {
  display: block;
  -webkit-animation-name: fire;
  -moz-animation-name: fire;
  -o-animation-name: fire;
  animation-name: fire;
  -webkit-animation-duration: 3.2s;
  -moz-animation-duration: 3.2s;
  -o-animation-duration: 3.2s;
  animation-duration: 3.2s;
  -webkit-animation-timing-function: ease-in-out;
  -moz-animation-timing-function: ease-in-out;
  -o-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
  -webkit-animation-iteration-count: infinite;
  -o-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
  transform-origin: 80% 0%;
}

@keyframes fire {
  from, 0% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
  50% {
    transform: translate3d(0,-10%,0) rotate(0deg);
  }
  to, 100% {
    transform: translate3d(0,0%,0) rotate(0deg);
  }
}
