@charset "UTF-8";
/***************************************************************
 *
 * sanitize.css | CC0 Public Domain | github.com/jonathantneal/sanitize.css
 *
***************************************************************/
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap");
pre, textarea {
  overflow: auto; }

[hidden], audio:not([controls]), template {
  display: none; }

details, main, summary {
  display: block; }

input[type=number] {
  width: auto; }

input[type=search] {
  -webkit-appearance: textfield; }

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none; }

progress {
  display: inline-block; }

small {
  font-size: 75%; }

textarea {
  resize: verticlp_specialal; }

[unselectable] {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

*, ::after, ::before {
  box-sizing: inherit;
  border-style: solid;
  border-width: 0; }

* {
  position: relative;
  font-size: inherit;
  line-height: inherit;
  margin: 0;
  padding: 0; }

::after, ::before {
  text-decoration: inherit;
  vertical-align: inherit; }

:root {
  -ms-overflow-style: -ms-autohiding-scrollbar;
  overflow-y: scroll;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  box-sizing: border-box;
  cursor: default;
  font: 20px/1.5 sans-seri f;
  text-rendering: optimizeLegibility; }

a {
  text-decoration: none; }

audio, canvas, iframe, img, svg, video {
  vertical-align: middle; }

button, input, select, textarea {
  background-color: transparent;
  color: inherit;
  font-family: inherit;
  font-style: inherit;
  font-weight: inherit; }

code, kbd, pre, samp {
  font-family: monospace,monospace; }

ol, ul {
  list-style: none; }

select {
  -moz-appearance: none;
  -webkit-appearance: none; }

select::-ms-expand {
  display: none; }

select::-ms-value {
  color: currentColor; }

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

::-moz-selection {
  background-color: #B3D4FC;
  text-shadow: none; }

::selection {
  background-color: #B3D4FC;
  text-shadow: none; }

@media screen {
  [hidden~=screen] {
    display: inherit; }

  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    clip: rect(0 0 0 0) !important;
    position: absolute !important; } }
/***************************************************************
 *
 * layout and etc...
 *
***************************************************************/
img {
  max-width: 100%;
  height: auto; }

html {
  overflow: hidden; }

body {
  overflow: hidden;
  margin: 0; }

/* 
			inview (ScrollTrigger)
*********************************************/
.inview {
  transition: all 1s ease; }

.ivo {
  opacity: 0;
  -webkit-filter: blur(12px);
  filter: blur(12px); }
  .ivo.in-view {
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0); }

/* 
			Draggable
*********************************************/
.draggable_wrap,
.draggable_snap_wrap {
  overflow: hidden; }
  .draggable_wrap::after,
  .draggable_snap_wrap::after {
    z-index: 1;
    transition: 1s all ease;
    opacity: 0;
    pointer-events: none;
    content: "";
    position: absolute;
    display: block;
    width: 4em;
    height: 4em;
    top: 55%;
    left: 0;
    right: 0;
    margin: auto;
    background: url("img/084.png") no-repeat center center/auto 60% rgba(0, 0, 0, 0.6);
    border-radius: 1.5em; }
  .draggable_wrap.dragg::after,
  .draggable_snap_wrap.dragg::after {
    z-index: 10000;
    opacity: 1; }

/*
			PC通話発信無効化
*********************************************/
@media (min-width: 769px) {
  a[href^="tel:"] {
    pointer-events: none; } }
/***************************************************************
 *
 * sass media query
 *
***************************************************************/
/***************************************************************
 *
 * Stylesheet for LP
 *
***************************************************************/
/*
			Font
*********************************************/
body {
  font-size: 20px;
  line-height: 1.4em;
  color: #060606;
  font-family: "Zen Kaku Gothic New","Hiragino Kaku Gothic ProN", "Hiragino Sans", "游ゴシック", "YuGothic", "open sans",  "Noto Sans Japanese", "メイリオ", "Meiryo",system-ui, sans-serif;
  overflow: hidden;
  background: #f9f5ed; }

body a {
  color: #060606;
  text-decoration: none; }

.font_a {
  font-family: "Playfair Display","Hiragino Mincho ProN","游明朝","Yu Mincho","HGS明朝E","メイリオ","Meiryo",serif; }

#smooth-content {
  overflow: hidden;
  padding-bottom: 14em; }
  @media (max-width: 1500px) {
    #smooth-content {
      padding-bottom: 6em; } }

/* 
			Responsive
*********************************************/
.lg_show,
.md_show,
.sm_show,
.xs_show,
.lg_showin,
.md_showin,
.sm_showin,
.xs_showin {
  display: none; }

@media screen and (max-width: 768px) {
  .md_hide {
    display: none; }

  .md_show {
    display: block; }

  .md_showin {
    display: inline; }

  body {
    font-size: 20px;
    font-size: 2.6041666666667vw;
    line-height: 1.4em; } }
@media screen and (max-width: 600px) {
  body {
    font-size: 15.6px;
    font-size: 2.6041666666667vw;
    line-height: 1.4em; }

  .sm_hide {
    display: none; }

  .sm_show {
    display: block; }

  .sm_showin {
    display: inline; } }
@media screen and (max-width: 414px) {
  body {
    font-size: 10.76px;
    font-size: 2.6041666666667vw;
    line-height: 1.4em; }

  .xs_hide {
    display: none; }

  .xs_show {
    display: block; }

  .xs_showin {
    display: inline; } }
/***************************************************************
 *
 * 				 LP
 *
***************************************************************/
#pc_bg {
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0;
  left: 0;
  background: url("img/083.png") no-repeat center center/cover; }
  #pc_bg > h1 {
    width: 4.95em;
    height: 7.1em;
    margin: 3em 0 0 3.05em; }
    @media (max-width: 1500px) {
      #pc_bg > h1 {
        display: none; } }
  #pc_bg > div {
    position: absolute;
    display: block;
    width: 100vw;
    height: 100vh;
    top: 0;
    left: 0; }
    #pc_bg > div > span {
      position: absolute;
      top: 0;
      bottom: 0;
      left: 0;
      right: 0;
      margin: auto; }
    #pc_bg > div > span:nth-child(1) {
      width: 11em;
      height: 11em;
      transform: translate(-45vw, -30vh); }
      #pc_bg > div > span:nth-child(1) > img {
        animation: float1 10s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(2) {
      width: 5.5em;
      height: 5.5em;
      transform: translate(-50vw, -10vh); }
      #pc_bg > div > span:nth-child(2) > img {
        animation: float2 12s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(3) {
      width: 14em;
      height: 14em;
      transform: translate(-30vw, 0); }
      #pc_bg > div > span:nth-child(3) > img {
        animation: float3 14s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(4) {
      width: 9.5em;
      height: 9.5em;
      transform: translate(-35vw, 42vh); }
      #pc_bg > div > span:nth-child(4) > img {
        animation: float4 16s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(5) {
      width: 13em;
      height: 13em;
      transform: translate(25vw, -40vh); }
      #pc_bg > div > span:nth-child(5) > img {
        animation: float5 18s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(6) {
      width: 3.5em;
      height: 3.5em;
      transform: translate(45vw, -44vh); }
      #pc_bg > div > span:nth-child(6) > img {
        animation: float6 20s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(7) {
      width: 3em;
      height: 3em;
      transform: translate(40vw, -30vh); }
      #pc_bg > div > span:nth-child(7) > img {
        animation: float7 22s ease-in-out alternate infinite; }
    #pc_bg > div > span:nth-child(8) {
      width: 12em;
      height: 12em;
      transform: translate(32vw, 40vh); }
      #pc_bg > div > span:nth-child(8) > img {
        animation: float8 24s ease-in-out alternate infinite; }
@keyframes float1 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(1.5em) translateY(-2em); }
  100% {
    transform: translateX(-1.5em) translateY(-3em); } }
@keyframes float2 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(-1.5em) translateY(-2em); }
  100% {
    transform: translateX(1.5em) translateY(-3em); } }
@keyframes float3 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(1.5em) translateY(-2em); }
  100% {
    transform: translateX(-1.5em) translateY(-3em); } }
@keyframes float4 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(-1em) translateY(-1.5em); }
  100% {
    transform: translateX(1em) translateY(-3em); } }
@keyframes float5 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(1.5em) translateY(-2.5em); }
  100% {
    transform: translateX(-1.5em) translateY(-3em); } }
@keyframes float6 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(-1.5em) translateY(-2.5em); }
  100% {
    transform: translateX(1.5em) translateY(-3em); } }
@keyframes float7 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(1em) translateY(-1.5em); }
  100% {
    transform: translateX(-1em) translateY(-3em); } }
@keyframes float8 {
  0% {
    transform: translateX(0) translateY(0); }
  50% {
    transform: translateX(-1em) translateY(-2em); }
  100% {
    transform: translateX(1em) translateY(-3em); } }
  #pc_bg > p {
    position: absolute;
    bottom: 0;
    left: 0;
    height: 5.5em;
    width: 100%;
    /* ビューポート全体の幅 */
    overflow: hidden;
    /* コンテナ外の内容を隠す */
    white-space: nowrap;
    /* テキストを改行しない */ }
    #pc_bg > p > span {
      display: inline-block;
      white-space: nowrap;
      animation: we_scroll 40s linear infinite; }
      #pc_bg > p > span > img {
        display: inline-block;
        max-width: none;
        width: 109em;
        height: auto; }
@keyframes we_scroll {
  0% {
    transform: translateX(0); }
  100% {
    transform: translateX(-50%); } }
h1#pc_bg_logo {
  display: none; }
  @media (max-width: 1500px) {
    h1#pc_bg_logo {
      display: block;
      width: 4.95em;
      padding: 3em 0;
      margin: auto;
      left: -15em; } }

a#pc_bg_shop {
  z-index: 10;
  display: block;
  position: fixed;
  bottom: 7em;
  right: 2em;
  max-width: 21.05em;
  height: 23.5em;
  max-height: calc( 100vh - 9em ); }
  @media (max-width: 1300px) {
    a#pc_bg_shop {
      width: calc( 100vw - 768px - 6em ); } }
  @media (max-width: 1080px) {
    a#pc_bg_shop {
      display: none; } }
  a#pc_bg_shop > img {
    height: 100%; }
    @media (max-width: 1300px) {
      a#pc_bg_shop > img {
        height: auto; } }

#leap_wrap {
  width: 768px;
  margin: 8em 0 0 10em;
  background: #dfecf5;
  border-radius: 1em;
  filter: drop-shadow(0 0 4em rgba(80, 100, 140, 0.3));
  overflow: hidden; }
  @media (max-width: 1500px) {
    #leap_wrap {
      margin: 0 0 0 2em; } }
  @media (max-width: 1080px) {
    #leap_wrap {
      margin: 0 auto 0; } }
  @media screen and (max-width: 768px) {
    #leap_wrap {
      width: 100vw; } }

#lp_header {
  background: #FFF;
  border-radius: 0 0 4em 4em;
  padding: 4em 0 10em 0; }
  #lp_header > div h2 {
    margin-bottom: 0em;
    padding: 0 0 0 3em; }
    #lp_header > div h2 > span {
      font-size: 1.7em;
      line-height: 1.6em;
      color: #1a66bb; }
  #lp_header > div h1 {
    margin-bottom: 5em;
    padding: 0 0 0 3em; }
    #lp_header > div h1 > span {
      display: block;
      font-size: 2.8em;
      line-height: 1.6em; }
  #lp_header > ul {
    width: max-content;
    display: flex;
    justify-content: center;
    left: -19.8em; }
    #lp_header > ul > li {
      width: 26em;
      height: 41em;
      border-radius: 13em;
      overflow: hidden; }
      #lp_header > ul > li > span {
        display: flex;
        width: 26em;
        height: 41em;
        justify-content: center;
        align-items: center; }
        #lp_header > ul > li > span > video {
          width: 100%;
          height: 100%;
          object-fit: cover; }
  #lp_header > span {
    display: block;
    width: 12.575em;
    height: 18.25em;
    margin: 0 1.5em -14em auto;
    top: -9em; }
  #lp_header > h3 {
    width: 27.525em;
    margin: 0 0 0 3em; }
  #lp_header > img {
    position: absolute;
    width: 4em;
    height: 4em;
    left: 7em;
    top: 55em; }

#lp_ts {
  top: -3em; }
  #lp_ts > div > p {
    width: 15.55em;
    margin-left: 4.5em;
    z-index: 2; }
  #lp_ts > div > a {
    display: block;
    width: 19.25em;
    margin: 0 auto;
    z-index: 2; }
  #lp_ts > div > span {
    position: absolute;
    z-index: 1; }
  #lp_ts > div > span:nth-child(3) {
    width: 7.15em;
    height: 7.8em;
    top: -1.5em;
    left: 53%;
    animation: float3 8s ease-in-out alternate infinite; }
  #lp_ts > div > span:nth-child(4) {
    width: 13.75em;
    height: 14.125em;
    top: 2.5em;
    left: 19em; }
  #lp_ts > div > span:nth-child(5) {
    width: 10.075em;
    height: 9.675em;
    top: 15em;
    left: 16em; }
  #lp_ts > div > span:nth-child(6) {
    width: 3em;
    height: 3.1em;
    top: 12.2em;
    left: 3.5em;
    animation: float6 9s ease-in-out alternate infinite; }
  #lp_ts > div > span:nth-child(7) {
    width: 7.75em;
    height: 6.45em;
    top: 19.5em;
    left: 3em;
    animation: float7 10s ease-in-out alternate infinite; }
  #lp_ts > div > span:nth-child(8) {
    width: 12.325em;
    height: 12.375em;
    bottom: -5em;
    left: 23.75em;
    animation: float8 14s ease-in-out alternate infinite; }
  #lp_ts > p {
    height: 11em;
    width: 100%;
    /* ビューポート全体の幅 */
    overflow: hidden;
    /* コンテナ外の内容を隠す */
    white-space: nowrap;
    /* テキストを改行しない */ }
    #lp_ts > p > span {
      display: inline-block;
      white-space: nowrap;
      animation: we_scroll 50s linear infinite; }
      #lp_ts > p > span > img {
        display: inline-block;
        max-width: none;
        width: 218em;
        height: auto;
        opacity: 0.4; }

#lp_care {
  top: -9em;
  background: url("img/020.png") no-repeat center center/contain; }
  #lp_care > span {
    display: block;
    width: 12.5em;
    margin: 0 0 2.5em 10em;
    animation: float4 6 ease-in-out alternate infinite; }
  #lp_care > h2 {
    width: 5.725em;
    height: 22.4em;
    position: absolute;
    top: 5em;
    right: 3em; }
  #lp_care > p {
    margin: 0 0 3em 2em; }
    #lp_care > p > span, #lp_care > p > strong {
      font-size: 1.4em;
      line-height: 1.6em; }
  #lp_care > h4 {
    width: 34.35em;
    margin: 0 auto 3em; }
  #lp_care > h3 {
    width: 27.225em;
    margin: 0 0 0 2em; }

#lp_month_wrap {
  display: flex;
  align-items: center; }
  #lp_month_wrap > h4 {
    width: 8em;
    display: flex;
    align-items: center;
    justify-content: center; }
    #lp_month_wrap > h4 > img {
      width: 1.575em;
      height: 17.425em; }
  #lp_month_wrap > div {
    background: #FFF;
    border-radius: 1.5em 0 0 1.5em;
    padding: 2.5em 0 2.5em 1em;
    width: 30.4em; }
  #lp_month_wrap #lp_month > h2 {
    padding: 0 1em; }
    #lp_month_wrap #lp_month > h2 > span {
      font-size: 1.65em;
      line-height: 1.6em; }
  #lp_month_wrap #lp_month > p {
    padding: 0 1em;
    margin-bottom: 3.5em; }
    #lp_month_wrap #lp_month > p > span {
      font-size: 1.2em;
      line-height: 1.6em; }
  #lp_month_wrap #lp_month > ul {
    display: flex;
    width: max-content; }
    #lp_month_wrap #lp_month > ul > li {
      width: 22em;
      padding: 0 1em; }
      #lp_month_wrap #lp_month > ul > li > h3 {
        font-size: 1.5em;
        font-weight: 400; }
      #lp_month_wrap #lp_month > ul > li > span {
        display: block;
        border-radius: 0.5em;
        overflow: hidden;
        margin: 1.5em 0; }
      #lp_month_wrap #lp_month > ul > li > p {
        font-size: 1.2em;
        line-height: 1.6em; }

#lp_sec {
  padding: 4.5em 0 0;
  margin-bottom: -7em;
  z-index: 2; }
  #lp_sec > p {
    width: 93%;
    margin: 0 0 3em auto;
    font-size: 1.3em;
    line-height: 1.8em; }
  #lp_sec > span {
    display: flex;
    width: 33em;
    height: 22em;
    margin: 0 auto;
    align-items: center;
    justify-content: center; }
    #lp_sec > span > video {
      width: 100%;
      height: 100%;
      object-fit: cover; }

#lp_three {
  padding: 10em 0 5em;
  background: #FFF;
  border-radius: 1.5em 1.5em 4em 4em; }
  #lp_three > h2 {
    padding: 0 0 3em 2.5em; }
    #lp_three > h2 span {
      display: block;
      font-size: 1.7em;
      line-height: 2em; }
    #lp_three > h2 strong {
      display: block;
      font-size: 2.2em;
      line-height: 1.5em; }
  #lp_three > ul {
    width: max-content;
    display: flex;
    justify-content: center;
    left: -19.8em;
    margin-bottom: 5em; }
    #lp_three > ul > li {
      width: 26em;
      height: 41em;
      border-radius: 13em;
      overflow: hidden; }
      #lp_three > ul > li > span {
        display: flex;
        width: 26em;
        height: 41em;
        justify-content: center;
        align-items: center; }
        #lp_three > ul > li > span > video {
          width: 100%;
          height: 100%;
          object-fit: cover; }
  #lp_three ol {
    width: max-content;
    display: flex; }
    #lp_three ol > li {
      width: 768px;
      text-align: center; }
      @media screen and (max-width: 768px) {
        #lp_three ol > li {
          width: 100vw; } }
      #lp_three ol > li > img {
        width: 35em; }
  #lp_three > p {
    padding: 5em 0 0; }
    #lp_three > p > a {
      display: block;
      width: 19.25em;
      margin: 0 auto; }

#lp_story {
  background: url("img/036.png") no-repeat center top/contain;
  padding: 7em 0 8em; }
  #lp_story > h2 {
    position: absolute;
    width: 5.25em;
    height: 1.175;
    top: 7em;
    left: 2.5em; }
  #lp_story > h1 {
    width: 8.825em;
    margin: 0 2em 3.5em auto; }
  #lp_story > h3 {
    width: 34.05em;
    margin: 0 auto -2em; }
  #lp_story > p {
    height: 11em;
    width: 100%;
    /* ビューポート全体の幅 */
    overflow: hidden;
    /* コンテナ外の内容を隠す */
    white-space: nowrap;
    /* テキストを改行しない */ }
    #lp_story > p > span {
      display: inline-block;
      white-space: nowrap;
      animation: we_scroll 50s linear infinite; }
      #lp_story > p > span > img {
        display: inline-block;
        max-width: none;
        width: 218em;
        height: auto;
        opacity: 0.4; }
  #lp_story > h4 {
    text-align: center;
    top: -2em; }
    #lp_story > h4 > span {
      display: block;
      font-size: 1.7em;
      line-height: 2em; }
    #lp_story > h4 > strong {
      display: block;
      font-size: 3em;
      line-height: 1.6em; }

#lp_wave {
  z-index: 1;
  background: #FFF;
  border-radius: 4em;
  padding-bottom: 6em; }
  #lp_wave > span {
    top: -7em;
    display: block;
    width: 33em;
    margin: 0 auto -3em; }
  #lp_wave > p {
    padding: 0 0 0 2.5em;
    margin-bottom: 4em; }
    #lp_wave > p > span {
      font-size: 1.5em;
      line-height: 2em; }
  #lp_wave > h2 {
    padding: 0 0 0 2.5em;
    margin-bottom: 2em; }
    #lp_wave > h2 > span {
      display: block;
      font-size: 2.1em;
      line-height: 1.8em; }
  #lp_wave > strong {
    display: block;
    width: 33em;
    margin: 0 auto 1em; }
  #lp_wave > h4 {
    text-align: center;
    margin-bottom: 7.5em; }
    #lp_wave > h4 > span {
      font-size: 1.5em; }
  #lp_wave > div {
    width: 34.15em;
    margin: 0 auto 6em; }
  #lp_wave > h3 {
    text-align: center; }
    #lp_wave > h3 > span {
      display: block;
      font-size: 2.6em;
      line-height: 1.6em; }

#lp_mov {
  z-index: 0;
  top: -4em;
  margin-bottom: -4em;
  width: 100%;
  height: 40em;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  justify-content: center; }
  #lp_mov > video {
    width: 100%;
    height: 100%;
    object-fit: cover; }

#lp_when {
  border-top: 1px solid #85b7dd;
  padding-bottom: 8em; }
  #lp_when > h4 {
    width: 10.275em;
    margin: -1em auto 1em; }
  #lp_when h2 {
    text-align: center;
    margin-bottom: 1em; }
    #lp_when h2 > span {
      display: block;
      font-size: 2.35em;
      line-height: 1.8em; }
  #lp_when h3 {
    text-align: center;
    margin-bottom: 4em; }
    #lp_when h3 > span {
      font-size: 1.5em; }
  #lp_when ul {
    width: max-content;
    display: flex; }
    #lp_when ul > li {
      width: 768px;
      text-align: center; }
      @media screen and (max-width: 768px) {
        #lp_when ul > li {
          width: 100vw; } }
      #lp_when ul > li > img {
        width: 34.1em; }

#lp_voice > span {
  width: 100%;
  height: 20em;
  overflow: hidden;
  display: flex;
  align-items: flex-start;
  justify-content: center; }
  #lp_voice > span > video {
    width: 100%;
    height: 100%;
    object-fit: cover; }
#lp_voice > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5em 0 4em;
  top: -8em;
  margin-bottom: -3em; }
  #lp_voice > div > h1 {
    width: 5.125em; }
  #lp_voice > div > h2 {
    width: 5.625em; }
#lp_voice > p {
  width: 35.7em;
  margin: 0 auto 3em; }
#lp_voice > strong {
  display: block;
  padding: 0 0 0 3em;
  margin-bottom: 6em;
  font-weight: 400; }
#lp_voice > h3 {
  width: 11.275em;
  margin: 0 auto 2em; }
#lp_voice > h2 {
  text-align: center;
  margin-bottom: 4em; }
  #lp_voice > h2 > span {
    font-size: 2.35em; }

#lp_base {
  padding: 0 4em; }
  #lp_base > div {
    background: #FFF;
    border-radius: 1.5em;
    padding: 2em;
    width: max-content; }
    #lp_base > div > h2 {
      padding: 0 1em; }
      #lp_base > div > h2 > span {
        font-size: 1.65em;
        line-height: 1.6em;
        margin-bottom: 1em; }
    #lp_base > div > p {
      padding: 0 1em;
      margin-bottom: 3em; }
    #lp_base > div > ul {
      width: max-content;
      display: flex; }
      #lp_base > div > ul > li {
        padding: 0 1em;
        width: 22em; }
        #lp_base > div > ul > li > h3 {
          font-size: 1.5em;
          font-weight: 400; }
        #lp_base > div > ul > li > span {
          display: block;
          border-radius: 0.5em;
          overflow: hidden;
          margin: 1.5em 0; }
        #lp_base > div > ul > li > p {
          font-size: 1.2em;
          line-height: 1.6em; }

#lp_why {
  padding: 5em 0; }
  #lp_why > h2 {
    padding: 0 0 4em 3em; }
    #lp_why > h2 > span {
      font-size: 2.3em; }
  #lp_why > p {
    padding: 0 0 0 8%;
    font-size: 1.4em;
    line-height: 1.6em;
    margin-bottom: 3em; }
  #lp_why > span {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 33em;
    margin: 0 auto 1em;
    overflow: hidden; }
    #lp_why > span > video {
      width: 100%;
      height: 100%;
      object-fit: cover; }

#lp_spec {
  background: #FFF;
  border-radius: 384px 384px 0 0;
  padding: 12em 0 0; }
  #lp_spec > h2 {
    width: 23.925em;
    margin: 0 auto 2em; }
  #lp_spec > span {
    display: block;
    width: 37.325em;
    margin: 0 auto; }
  #lp_spec > h3 {
    width: 22.175em;
    margin: 0 auto 3em; }
  #lp_spec > div {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding-top: 6em; }
    #lp_spec > div > span {
      display: flex;
      justify-content: center;
      align-items: center;
      width: 15em;
      height: 27em;
      overflow: hidden;
      left: -0.5em; }
      #lp_spec > div > span > video {
        width: 100%;
        height: 100%;
        object-fit: cover; }
      #lp_spec > div > span:first-child {
        top: -6em;
        left: 0.5em; }
    #lp_spec > div > img {
      position: absolute;
      width: 9em;
      height: 9em;
      right: 4em;
      top: 1em; }
  #lp_spec > p {
    padding: 5em 3em; }
    #lp_spec > p > span {
      font-size: 1.4em;
      line-height: 1.8em;
      color: #1a66bb; }

#lp_special {
  background: #FFF;
  border-radius: 0 0 384px 384px;
  padding: 4em 0 12em;
  color: #1a66bb; }
  #lp_special > h1 {
    text-align: center;
    margin-bottom: 3em; }
    #lp_special > h1 > span {
      display: block;
      font-size: 1.4em;
      margin-bottom: 1em; }
    #lp_special > h1 > strong {
      display: block;
      font-size: 2.1em;
      line-height: 1.6em; }
  #lp_special > h4 {
    width: 34.9em;
    margin: 0 auto 4em; }
  #lp_special > h5 {
    width: 36.3em;
    margin: 0 auto 4em; }
  #lp_special > p {
    padding: 0 3em; }
    #lp_special > p > span {
      font-size: 1.4em;
      line-height: 1.6em;
      margin-bottom: 3em; }
  #lp_special > h3 {
    width: 33.7em;
    margin: 0 auto 6em; }
  #lp_special > h2 {
    text-align: center;
    margin-bottom: 3em; }
    #lp_special > h2 > strong {
      display: block;
      font-size: 2.1em;
      line-height: 1.6em; }
  #lp_special > span {
    display: block;
    width: 33.55em;
    margin: 0 auto 3em; }

#lp_free {
  padding: 8em 0; }
  #lp_free > div {
    display: flex;
    padding: 0 2em 0 3em;
    justify-content: space-between; }
    #lp_free > div > h3 {
      width: 13.825em; }
    #lp_free > div > h2 {
      width: 6.1em; }
  #lp_free > h1 {
    padding: 0 0 2em 3em; }
    #lp_free > h1 > span {
      color: #1a66bb;
      font-size: 1.2em; }
  #lp_free > ul {
    padding: 0 3em;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin-bottom: 4em; }
    #lp_free > ul > li {
      width: 23.5%;
      height: 2.4em;
      border: 1px solid #1a66bb;
      background: #FFF;
      border-radius: 1.2em / 50%;
      display: flex;
      justify-content: center;
      align-items: center;
      text-align: center;
      margin-bottom: 1em; }
      #lp_free > ul > li > span {
        color: #1a66bb;
        line-height: 0.9em; }
  #lp_free > p {
    padding: 0 3em; }
    #lp_free > p > span {
      font-size: 1.4em;
      line-height: 1.8em; }

#lp_ingre {
  padding-bottom: 8em; }
  #lp_ingre > h2 {
    width: 8.425em;
    margin: 0 auto 2em; }
  #lp_ingre > div {
    width: 90%;
    margin: 0 auto;
    border-radius: 0.5em;
    border: 1px solid #1a66bb;
    padding: 2em 2em 1em; }
    #lp_ingre > div > p {
      color: #1a66bb;
      font-size: 1.1em;
      line-height: 1.4em;
      margin-bottom: 1em; }

#lp_dev > div > h2 {
  text-align: center; }
  #lp_dev > div > h2 > span {
    display: block;
    font-size: 1.2em;
    margin-bottom: 2em;
    font-weight: 400; }
#lp_dev > div > h1 {
  text-align: center;
  margin-bottom: 3em; }
  #lp_dev > div > h1 > strong {
    display: block;
    font-size: 2.4em;
    line-height: 1.4em; }
#lp_dev #lp_dev_slide {
  width: max-content;
  display: flex;
  padding: 0 1em;
  align-items: flex-start; }
  #lp_dev #lp_dev_slide > li {
    width: 34.4em;
    padding: 0 1em;
    margin: 0 1em;
    border: 1px solid #1a66bb;
    background: #FFF;
    padding: 3em 1.5em;
    border-radius: 0.5em; }
    #lp_dev #lp_dev_slide > li > span {
      display: block;
      margin-bottom: 3em; }
    #lp_dev #lp_dev_slide > li > p {
      font-size: 1.2em;
      line-height: 1.4em;
      margin-bottom: 2em; }
#lp_dev > h3 {
  padding: 4em 0;
  width: 32.175em;
  margin: 0 auto; }

#lp_bshop {
  padding: 8em 0 5em; }
  #lp_bshop > div {
    background: #FFF;
    border-radius: 0.5em;
    padding: 3em;
    margin-bottom: 8em; }
    #lp_bshop > div > div > h4 {
      padding-left: 0.5em; }
      #lp_bshop > div > div > h4 > span {
        font-size: 1.7em;
        line-height: 1.6em;
        margin-bottom: 2em; }
    #lp_bshop > div > div > h1 {
      margin-bottom: 3em; }
      #lp_bshop > div > div > h1 > span {
        display: block;
        font-size: 2.5em;
        line-height: 1.6em; }
    #lp_bshop > div > span {
      display: block;
      width: 23.9em;
      margin: 0 auto 1.5em; }
    #lp_bshop > div > a {
      display: block;
      width: 19.25em;
      margin: 0 auto; }
  #lp_bshop > span {
    display: block;
    width: 32.275em;
    margin: 0 auto 2em; }
  #lp_bshop > a {
    display: block;
    width: 19.25em;
    margin: 0 auto 5em; }
  #lp_bshop > p {
    width: 80%;
    margin: 0 auto; }

#lp_cir {
  width: 30.75em;
  height: 30.75em;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center; }
  #lp_cir > span {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    animation: rotation 30s linear infinite; }
@keyframes rotation {
  0% {
    transform: rotate(0); }
  100% {
    transform: rotate(-360deg); } }
  #lp_cir > h2 {
    text-align: center; }
    #lp_cir > h2 > strong {
      display: block;
      font-size: 2.3em;
      line-height: 2em; }

#lp_footer {
  top: -8em; }
  #lp_footer > ul {
    width: max-content;
    display: flex;
    justify-content: center;
    left: -19.8em;
    margin-bottom: 10em; }
    #lp_footer > ul > li {
      width: 26em;
      height: 41em;
      border-radius: 13em;
      overflow: hidden; }
      #lp_footer > ul > li > span {
        display: flex;
        width: 26em;
        height: 41em;
        justify-content: center;
        align-items: center; }
        #lp_footer > ul > li > span > video {
          width: 100%;
          height: 100%;
          object-fit: cover; }
  #lp_footer > a {
    display: block;
    width: 34.1em;
    margin: 0 auto 8em; }
  #lp_footer > p {
    width: 19.3em;
    margin: 0 auto 8em; }
  #lp_footer > h1 {
    width: 6.45em;
    margin: 0 auto; }

#sm_toshop {
  display: none; }
  @media screen and (max-width: 768px) {
    #sm_toshop {
      position: fixed;
      bottom: -5em;
      left: 0;
      display: flex;
      justify-content: center;
      align-items: center;
      width: 100vw;
      height: 5em;
      background: #1a66bb;
      transition: all 1s ease; }
      #sm_toshop > span {
        color: #FFF;
        font-size: 2em; }
      #sm_toshop.shopon {
        transform: translateY(-5em); } }
