/* ------------------------------ */
/* Fonts */
/* ------------------------------ */
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Thin.woff") format("woff");
  font-weight: 100;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Light.woff") format("woff");
  font-weight: 300;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Regular.woff") format("woff");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Medium.woff") format("woff");
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Bold.woff") format("woff");
  font-weight: 700;
  font-display: swap;
}
@font-face {
  font-family: "Noto Sans JP";
  src: url("../fonts/NotoSansJP-Black.woff") format("woff");
  font-weight: 900;
  font-display: swap;
}
@font-face {
  font-family: "MPLUSRounded1c";
  src: url("../fonts/MPLUSRounded1c-Regular.woff") format("woff");
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: "MPLUSRounded1c";
  src: url("../fonts/MPLUSRounded1c-Medium.woff") format("woff");
  font-weight: 500;
  font-display: swap;
}
@font-face {
  font-family: "MPLUSRounded1c";
  src: url("../fonts/MPLUSRounded1c-Bold.woff") format("woff");
  font-weight: 700;
  font-display: swap;
}
:root {
  --content-width: min(100%, 750px);
  --color-txt: #4D4D4D;
  --color-white: #FFFFFF;
  --color-blue: #0068B7;
  --color-light-blue: #0099D9;
  --color-super-light-blue: #BEE3FF;
  --color-thin-blue: #E4F6FF;
  --color-yellow: #EFE300;
  --color-orange: #F78900;
  --color-light-orange: #FDE7CC;
  --color-green: #00A040;
  --color-light-green: #CCECD9;
  --color-pink: #F19CC1;
  --color-light-pink: #FBE1EC;
  --color-gray: #A9A9A9;
  --color-light-gray: #F2F2F2;
  --color-onlineshop: #f66152;
  --font-size-default: 16px;
  --font-size-xxsmall: 10px;
  --font-size-xsmall: 12px;
  --font-size-msmall: 13px;
  --font-size-small: 14px;
  --font-size-medium: 18px;
  --font-size-large: 20px;
  --font-size-xlarge: 24px;
  --font-size-xxlarge: 28px;
  --font-size-xxxlarge: 30px;
  --font-size-splarge: 40px;
  --font-noto-sans-jp: "Noto Sans JP", sans-serif;
  --font-mplus-rounded: "MPLUSRounded1c", sans-serif;
}

/* ------------------------------ */
/* Animations */
/* ------------------------------ */
.a-blur {
  opacity: 0;
}
.a-blur.is-active {
  -webkit-animation: a-blur 0.6s ease-in-out forwards;
          animation: a-blur 0.6s ease-in-out forwards;
}

.a-slide-up {
  opacity: 0;
  -webkit-transform: translateY(20px);
          transform: translateY(20px);
}
.a-slide-up.is-active {
  -webkit-animation: a-slide-up 0.6s ease-in-out forwards;
          animation: a-slide-up 0.6s ease-in-out forwards;
}

.a-slide-left {
  opacity: 0;
  -webkit-transform: translateX(-20px);
          transform: translateX(-20px);
}
.a-slide-left.is-active {
  -webkit-animation: a-slide-left 0.6s ease-in-out forwards;
          animation: a-slide-left 0.6s ease-in-out forwards;
}

.a-pop-in {
  opacity: 0;
  -webkit-transform: scale(0.8);
          transform: scale(0.8);
}
.a-pop-in.is-active {
  -webkit-animation: a-pop-in 0.4s ease-in-out forwards;
          animation: a-pop-in 0.4s ease-in-out forwards;
}

@-webkit-keyframes a-blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}

@keyframes a-blur {
  0% {
    opacity: 0;
    -webkit-filter: blur(10px);
            filter: blur(10px);
  }
  100% {
    opacity: 1;
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@-webkit-keyframes a-slide-up {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes a-slide-up {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
            transform: translateY(20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes a-slide-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-20px);
            transform: translateX(-20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@keyframes a-slide-left {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-20px);
            transform: translateX(-20px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
@-webkit-keyframes a-pop-in {
  0% {
    opacity: 0;
    -webkit-transform: scaleX(0.8) scaleY(0.8);
            transform: scaleX(0.8) scaleY(0.8);
  }
  50% {
    opacity: 1;
    -webkit-transform: scaleX(1.05) scaleY(1.2);
            transform: scaleX(1.05) scaleY(1.2);
  }
  60% {
    opacity: 1;
    -webkit-transform: scaleX(0.98) scaleY(0.98);
            transform: scaleX(0.98) scaleY(0.98);
  }
  80% {
    opacity: 1;
    -webkit-transform: scaleX(1.02) scaleY(1.02);
            transform: scaleX(1.02) scaleY(1.02);
  }
  100% {
    opacity: 1;
    -webkit-transform: scaleX(1) scaleY(1);
            transform: scaleX(1) scaleY(1);
  }
}
@keyframes a-pop-in {
  0% {
    opacity: 0;
    -webkit-transform: scaleX(0.8) scaleY(0.8);
            transform: scaleX(0.8) scaleY(0.8);
  }
  50% {
    opacity: 1;
    -webkit-transform: scaleX(1.05) scaleY(1.2);
            transform: scaleX(1.05) scaleY(1.2);
  }
  60% {
    opacity: 1;
    -webkit-transform: scaleX(0.98) scaleY(0.98);
            transform: scaleX(0.98) scaleY(0.98);
  }
  80% {
    opacity: 1;
    -webkit-transform: scaleX(1.02) scaleY(1.02);
            transform: scaleX(1.02) scaleY(1.02);
  }
  100% {
    opacity: 1;
    -webkit-transform: scaleX(1) scaleY(1);
            transform: scaleX(1) scaleY(1);
  }
}
@-webkit-keyframes a-shake {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  20% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  40% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  60% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  80% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
@keyframes a-shake {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  20% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  40% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  60% {
    -webkit-transform: rotate(5deg);
            transform: rotate(5deg);
  }
  80% {
    -webkit-transform: rotate(-5deg);
            transform: rotate(-5deg);
  }
  100% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
}
#contents {
  /* ------------------------------ */
  /* Main */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Main Header */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Top Lead */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Product */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Howto */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Faq */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Knowledge */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Online Shop Banner */
  /* ------------------------------ */
  /* ------------------------------ */
  /* Utility */
  /* ------------------------------ */
  /* display */
  /* border-radius */
  /* margin */
  /* text-style */
  /* color */
}
#contents .b-main {
  font-family: "Noto Sans JP", sans-serif;
  color: var(--color-txt);
  line-height: 1.4;
  background-color: var(--color-light-gray);
}
#contents .b-main img {
  max-width: 100%;
}
#contents .b-main__inner {
  background-color: #fff;
}
@media screen and ( min-width: 768px ) {
  #contents .b-main__inner {
    width: 768px;
    margin: 0 auto;
  }
}
#contents .b-main-header {
  padding: 5.3333333333vw 0px;
  background-image: url("/sc_rsc/babyteeth/fusso/images/header-bg.jpg");
  background-size: cover;
}
#contents .b-main-header__content {
  position: relative;
  background-image: url("/sc_rsc/babyteeth/fusso/images/header-content-bg.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  background-position: center;
  width: 85.3333333333vw;
  height: 52vw;
  margin: 0px auto 4vw;
  padding: 5.3333333333vw 0px 0px;
}
#contents .b-main-header__content__title {
  margin: 0px auto 1.6vw;
}
#contents .b-main-header__content__title__logo {
  width: 17.8666666667vw;
  margin: 0px auto;
}
#contents .b-main-header__content__title__txt {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0px auto;
  font-family: "MPLUSRounded1c", sans-serif;
  font-size: 6.4vw;
  font-weight: 700;
  color: var(--color-blue);
  border-bottom: 0.5333333333vw dashed var(--color-yellow);
}
#contents .b-main-header__content__lead {
  display: block;
  font-size: 3.2vw;
  font-weight: 700;
  text-align: center;
  line-height: 1.8 !important;
}
#contents .b-main-header__content::before {
  content: "";
  display: block;
  position: absolute;
  top: 1.6vw;
  left: 1.8666666667vw;
  width: 12.8vw;
  height: 13.3333333333vw;
  background-image: url("/sc_rsc/babyteeth/fusso/images/chara-teeth.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
#contents .b-main-header__img {
  display: block;
  width: 66.6666666667vw;
  margin: 0px auto;
}
@media screen and ( min-width: 768px ) {
  #contents .b-main-header {
    padding: 40px 0px;
  }
  #contents .b-main-header__content {
    width: 600px;
    height: 365px;
    margin: 0px auto 30px;
    padding: 36px 0px 0px;
  }
  #contents .b-main-header__content__title {
    margin: 0px auto 20px;
  }
  #contents .b-main-header__content__title__logo {
    width: 120px;
  }
  #contents .b-main-header__content__title__txt {
    font-size: 40px;
    border-width: 3px;
  }
  #contents .b-main-header__content__lead {
    font-size: 22px;
  }
  #contents .b-main-header__content::before {
    top: 10px;
    left: 15px;
    width: 80px;
    height: 80px;
  }
  #contents .b-main-header__img {
    width: 320px;
  }
}
#contents .b-top-lead {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0px 2.6666666667vw;
  width: 89.3333333333vw;
  margin: 5.3333333333vw auto;
  font-size: 4.2666666667vw;
  color: var(--color-blue);
  line-height: 1.8;
  padding: 2.6666666667vw 5.3333333333vw;
  border: 0.5333333333vw solid var(--color-blue);
  border-radius: 2.6666666667vw;
}
#contents .b-top-lead__main {
  width: 100%;
}
#contents .b-top-lead__main b {
  font-weight: 700;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(70%, transparent), color-stop(0%, var(--color-yellow)));
  background: linear-gradient(transparent 70%, var(--color-yellow) 0%);
}
#contents .b-top-lead__sub {
  width: calc(100% - 28vw);
}
#contents .b-top-lead__img {
  width: 25.3333333333vw;
}
@media screen and ( min-width: 768px ) {
  #contents .b-top-lead {
    gap: 0px 20px;
    width: 580px;
    font-size: 22px;
    margin: 40px auto;
    padding: 20px 40px;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    border-width: 4px;
    border-radius: 20px;
  }
  #contents .b-top-lead__sub {
    width: calc(100% - 160px);
  }
  #contents .b-top-lead__img {
    width: 140px;
  }
}
#contents .b-product__header {
  padding: 10.6666666667vw 5.3333333333vw;
  background-image: url("/sc_rsc/babyteeth/fusso/images/bg-stripe.jpg");
  background-size: cover;
  background-position: center;
}
#contents .b-product__header__title {
  background-color: transparent;
  margin: 0px auto 5.3333333333vw;
  padding: 0px;
}
#contents .b-product__header__subtitle {
  width: 74.6666666667vw;
  margin: 0px auto 2.6666666667vw;
}
#contents .b-product__header__lead {
  margin: 0px auto 2.6666666667vw;
  font-size: 4.2666666667vw;
  font-weight: 700;
  line-height: 1.8;
}
#contents .b-product__header__list-contains, #contents .b-product__header__list-no-contains {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
#contents .b-product__header__list-contains li, #contents .b-product__header__list-no-contains li {
  font-family: var(--font-mplus-rounded);
  width: 100%;
  text-align: center;
  font-weight: 700;
  color: var(--color-white);
  border-radius: 1.3333333333vw;
}
#contents .b-product__header__list-contains {
  gap: 4vw;
  margin: 0px 0px 2.6666666667vw;
}
#contents .b-product__header__list-contains li {
  padding: 2.6666666667vw 0px;
  font-size: 3.7333333333vw;
  background-color: var(--color-light-blue);
}
#contents .b-product__header__list-contains--3col {
  gap: 1.0666666667vw;
}
#contents .b-product__header__list-no-contains {
  gap: 1.0666666667vw;
}
#contents .b-product__header__list-no-contains li {
  padding: 2.1333333333vw 0px;
  font-size: 3.2vw;
  background-color: var(--color-gray);
  background-image: url("/sc_rsc/babyteeth/fusso/images/mark-x.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
#contents .b-product__list {
  --base-color: var(--color-blue);
  padding: 10.6666666667vw 5.3333333333vw;
  background-color: var(--color-super-light-blue);
}
#contents .b-product__list__item {
  background-color: var(--color-white);
  font-family: var(--font-mplus-rounded);
  border: 1.3333333333vw solid var(--base-color);
  margin: -1.3333333333vw 0px 0px;
  padding: 0px 0px 5.3333333333vw;
}
#contents .b-product__list__item__title {
  margin: 0px 0px 3.7333333333vw;
}
#contents .b-product__list__item__title__period {
  position: relative;
  display: block;
  font-size: 5.3333333333vw;
  font-weight: 700;
  text-align: center;
  color: var(--color-white);
  margin: 0px 0px 9.0666666667vw;
  padding: 6.6666666667vw 0px 2.6666666667vw;
  background-color: var(--base-color);
}
#contents .b-product__list__item__title__period::after {
  content: "";
  position: absolute;
  top: 100%;
  display: block;
  width: 0px;
  height: 0px;
  border-top: 4.2666666667vw solid var(--base-color);
  border-left: 43.3333333333vw solid transparent;
  border-right: 43.3333333333vw solid transparent;
}
#contents .b-product__list__item__title__name {
  display: block;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  font-size: 4.2666666667vw;
  font-weight: 700;
  color: var(--base-color);
  text-align: center;
  margin: 0px auto;
  padding: 0px 2.6666666667vw;
  border-bottom: 0.5333333333vw solid var(--base-color);
}
#contents .b-product__list__item__img {
  display: block;
  width: 78.6666666667vw;
  margin: 0px auto 3.7333333333vw;
}
#contents .b-product__list__item__link {
  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;
  height: 10.6666666667vw;
  width: 78.6666666667vw;
  margin: 2.6666666667vw auto 0px;
  font-weight: 700;
  color: var(--color-txt);
  border: 0.2666666667vw solid var(--color-txt);
  border-radius: 5.3333333333vw;
}
#contents .b-product__list__item__link--shop {
  border-color: var(--color-onlineshop);
  background-color: var(--color-onlineshop);
  color: var(--color-white);
}
#contents .b-product__list__item--orange {
  --base-color: var(--color-orange);
}
#contents .b-product__list__item--green {
  --base-color: var(--color-green);
}
@media screen and ( min-width: 768px ) {
  #contents .b-product__header {
    padding: 60px 120px;
  }
  #contents .b-product__header__title {
    margin: 0px auto 30px;
  }
  #contents .b-product__header__subtitle {
    width: 480px;
    margin: 0px auto 20px;
  }
  #contents .b-product__header__lead {
    font-size: 20px;
    margin: 0px auto 20px;
  }
  #contents .b-product__header__list-contains {
    gap: 20px;
    margin: 0px 0px 20px;
  }
  #contents .b-product__header__list-contains li {
    padding: 14px 0px;
    font-size: 16px;
    border-radius: 5px;
  }
  #contents .b-product__header__list-contains--3col {
    gap: 8px;
  }
  #contents .b-product__header__list-no-contains {
    gap: 8px;
  }
  #contents .b-product__header__list-no-contains li {
    padding: 12px 0px;
    font-size: 14px;
    border-radius: 5px;
  }
  #contents .b-product__list {
    padding: 60px 160px;
  }
  #contents .b-product__list__item {
    margin: -5px 0px 0px;
    padding: 0px 0px 40px;
    border-width: 5px;
  }
  #contents .b-product__list__item__title {
    margin: 0px 0px 20px;
  }
  #contents .b-product__list__item__title__period {
    font-size: 24px;
    margin: 0px 0px 50px;
    padding: 30px 0px 15px;
  }
  #contents .b-product__list__item__title__period::after {
    border-top-width: 20px;
    border-left-width: 219px;
    border-right-width: 219px;
  }
  #contents .b-product__list__item__title__name {
    font-size: 20px;
    padding: 0px 20px;
    border-bottom-width: 3px;
  }
  #contents .b-product__list__item__img {
    width: 300px;
    margin: 0px auto 20px;
  }
  #contents .b-product__list__item__link {
    width: 360px;
    height: 50px;
    margin: 20px auto 0px;
    font-size: 16px;
    border-width: 2px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  #contents .b-product__list__item__link:hover, #contents .b-product__list__item__link:focus {
    background-color: var(--color-txt);
    color: var(--color-white);
  }
}
#contents .b-howto {
  padding: 10.6666666667vw 5.3333333333vw;
  font-family: var(--font-mplus-rounded);
  background-image: url("/sc_rsc/babyteeth/fusso/images/bg-stripe.jpg");
  background-size: contain;
  background-position: top center;
}
#contents .b-howto__title {
  background-color: transparent;
  margin: 0px auto 5.3333333333vw;
  padding: 0px;
}
#contents .b-howto__title__img {
  width: 40vw;
  margin: 0px auto;
}
#contents .b-howto__title__txt {
  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;
  width: 73.0666666667vw;
  height: 10.6666666667vw;
  margin: 0px auto;
  font-size: 5.3333333333vw;
  font-weight: 700;
  color: var(--color-white);
  background-color: var(--color-light-blue);
  border-radius: 5.3333333333vw;
}
#contents .b-howto__nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 2.6666666667vw 4.2666666667vw;
  margin: 0px 0px 5.3333333333vw;
}
#contents .b-howto__nav__item {
  width: calc(50% - 2.1333333333vw);
}
#contents .b-howto__nav__item__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 12vw;
  padding: 0px 5.3333333333vw;
  color: var(--color-white);
  background-color: var(--color-blue);
  border-radius: 1.3333333333vw;
}
#contents .b-howto__nav__item__link__txt {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  font-size: 3.7333333333vw;
  font-weight: 700;
}
#contents .b-howto__nav__item__link__txt__sub {
  font-size: 2.6666666667vw;
  font-weight: 700;
  letter-spacing: -0.01em;
}
#contents .b-howto__nav__item__link::after {
  content: "";
  -ms-flex-negative: 0;
      flex-shrink: 0;
  display: block;
  width: 4vw;
  height: 4vw;
  background-image: url("/sc_rsc/babyteeth/fusso/images/icon-arrow-w.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
#contents .b-howto__nav__item__link--orange {
  background-color: var(--color-orange);
  border-color: var(--color-orange);
}
#contents .b-howto__nav__item__link--green {
  background-color: var(--color-green);
  border-color: var(--color-green);
}
#contents .b-howto__nav__item__link--pink {
  background-color: var(--color-pink);
  border-color: var(--color-pink);
}
#contents .b-howto__guide {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2.6666666667vw;
  margin: 0px 0px 2.6666666667vw;
}
#contents .b-howto__guide__item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.3333333333vw;
}
#contents .b-howto__guide__item__img {
  width: 6.4vw;
  height: 6.4vw;
}
#contents .b-howto__guide__item__txt {
  font-size: 3.2vw;
  font-weight: 700;
  color: var(--color-blue);
}
#contents .b-howto__section {
  --base-color: var(--color-blue);
  --sub-color: var(--color-super-light-blue);
  border-radius: 1.3333333333vw;
  overflow: hidden;
  margin: 0px 0px 5.3333333333vw;
}
#contents .b-howto__section__title {
  text-align: center;
  font-weight: 700;
  color: var(--color-white);
  margin: 0px;
  padding: 2.6666666667vw;
  background-color: var(--base-color);
}
#contents .b-howto__section__title__main {
  font-size: 4.2666666667vw;
  font-weight: 700;
}
#contents .b-howto__section__title__sub {
  font-size: 2.6666666667vw;
  font-weight: 700;
}
#contents .b-howto__section__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 2.6666666667vw;
  padding: 2.6666666667vw;
  background-color: var(--sub-color);
}
#contents .b-howto__section__list__item {
  background-color: var(--color-white);
  border-radius: 1.3333333333vw;
  padding: 5.3333333333vw 0px;
}
#contents .b-howto__section__list__item__title {
  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;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 7.4666666667vw;
  font-size: 3.2vw;
  font-weight: 700;
  margin: 0px auto 2.6666666667vw;
  padding: 0px 2.6666666667vw;
  color: var(--color-white);
  background-color: var(--base-color);
  border-radius: 3.7333333333vw;
}
#contents .b-howto__section__list__item__title span {
  font-size: 2.6666666667vw;
  font-weight: 700;
}
#contents .b-howto__section__list__item__img {
  display: block;
  width: 32vw;
  margin: 0px auto 2.6666666667vw;
}
#contents .b-howto__section__list__item__data {
  padding: 0px 4vw;
}
#contents .b-howto__section__list__item__data dt {
  font-size: 3.2vw;
  font-weight: 700;
  text-align: center;
  border-bottom: 0.2666666667vw solid var(--color-txt);
  margin: 0px 0px 1.3333333333vw;
}
#contents .b-howto__section__list__item__data dd {
  text-align: center;
}
#contents .b-howto__section__list__item__data dd img {
  border-radius: 1.3333333333vw;
  margin: 0px 0px 1.3333333333vw;
}
#contents .b-howto__section__list__item__data dd span {
  font-size: 3.2vw;
  font-weight: 700;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(60%, transparent), color-stop(60%, var(--sub-color)));
  background: linear-gradient(transparent 60%, var(--sub-color) 60%);
}
#contents .b-howto__section--orange {
  --base-color: var(--color-orange);
  --sub-color: var(--color-light-orange);
}
#contents .b-howto__section--green {
  --base-color: var(--color-green);
  --sub-color: var(--color-light-green);
}
#contents .b-howto__section--pink {
  --base-color: var(--color-pink);
  --sub-color: var(--color-light-pink);
}
@media screen and ( min-width: 768px ) {
  #contents .b-howto {
    padding: 40px 120px;
  }
  #contents .b-howto__title {
    margin: 0px auto 40px;
  }
  #contents .b-howto__title__img {
    width: 140px;
  }
  #contents .b-howto__title__txt {
    width: 400px;
    height: 50px;
    font-size: 24px;
  }
  #contents .b-howto__nav {
    gap: 20px;
    margin: 40px auto;
  }
  #contents .b-howto__nav__item {
    width: calc(50% - 10px);
  }
  #contents .b-howto__nav__item__link {
    height: 64px;
    padding: 0px 40px;
    font-size: 18px;
    border-width: 2px;
    border-style: solid;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
  }
  #contents .b-howto__nav__item__link__txt {
    font-size: 18px;
  }
  #contents .b-howto__nav__item__link__txt__sub {
    font-size: 14px;
  }
  #contents .b-howto__nav__item__link::after {
    width: 20px;
    height: 20px;
  }
  #contents .b-howto__nav__item__link:hover, #contents .b-howto__nav__item__link:focus {
    background-color: var(--color-txt);
  }
  #contents .b-howto__guide {
    gap: 20px;
    margin: 0px 0px 20px;
  }
  #contents .b-howto__guide__item__img {
    width: 32px;
    height: 32px;
  }
  #contents .b-howto__guide__item__txt {
    font-size: 18px;
    font-weight: 700;
  }
  #contents .b-howto__section {
    margin: 0px 0px 40px;
  }
  #contents .b-howto__section__title {
    font-size: 24px;
    padding: 20px;
  }
  #contents .b-howto__section__title__main {
    font-size: 20px;
  }
  #contents .b-howto__section__title__sub {
    font-size: 14px;
  }
  #contents .b-howto__section__list {
    gap: 20px;
    padding: 30px 40px;
  }
  #contents .b-howto__section__list__item {
    padding: 30px 0px;
  }
  #contents .b-howto__section__list__item__title {
    height: 40px;
    font-size: 16px;
    margin: 0px auto 20px;
    padding: 0px 12px;
    border-radius: 20px;
  }
  #contents .b-howto__section__list__item__title span {
    font-size: 14px;
  }
  #contents .b-howto__section__list__item__img {
    width: 140px;
    margin: 0px auto 20px;
  }
  #contents .b-howto__section__list__item__data {
    padding: 0px 24px;
  }
  #contents .b-howto__section__list__item__data dt {
    font-size: 14px;
    border-width: 2px;
    margin: 0px 0px 10px;
  }
  #contents .b-howto__section__list__item__data dd img {
    margin: 0px 0px 10px;
    border-radius: 10px;
  }
  #contents .b-howto__section__list__item__data dd span {
    font-size: 14px;
  }
}
#contents .b-faq {
  padding: 10.6666666667vw 5.3333333333vw 5.3333333333vw;
  background-image: url("/sc_rsc/babyteeth/fusso/images/bg-dots.jpg");
  background-size: cover;
}
#contents .b-faq__title {
  margin: 0px auto 5.3333333333vw;
  padding: 0px;
  background-color: transparent;
}
#contents .b-faq__list__question, #contents .b-faq__list__answer {
  background-color: var(--color-thin-blue);
  border-radius: 1.3333333333vw;
}
#contents .b-faq__list__question {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 1.3333333333vw;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0px 0px 2.6666666667vw;
  padding: 2.6666666667vw;
}
#contents .b-faq__list__question__icon {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  width: 13.3333333333vw;
}
#contents .b-faq__list__question__txt {
  font-size: 4.2666666667vw;
  font-weight: 700;
  color: var(--color-blue);
}
#contents .b-faq__list__answer {
  margin: 0px 0px 5.3333333333vw;
  padding: 2.6666666667vw 5.3333333333vw;
  font-size: 4.2666666667vw;
  line-height: 1.8;
}
@media screen and ( min-width: 768px ) {
  #contents .b-faq {
    padding: 40px 120px 20px;
  }
  #contents .b-faq__title {
    margin: 0px auto 30px;
  }
  #contents .b-faq__list__question {
    margin: 0px 0px 10px;
    padding: 20px;
  }
  #contents .b-faq__list__question__icon {
    width: 60px;
  }
  #contents .b-faq__list__question__txt {
    font-size: 20px;
  }
  #contents .b-faq__list__answer {
    margin: 0px 0px 20px;
    padding: 20px 40px;
    font-size: 18px;
  }
}
#contents .b-knowledge {
  background-image: url("/sc_rsc/babyteeth/fusso/images/bg-stripe-blue.jpg");
  background-size: cover;
  padding: 0px 0px 2.6666666667vw;
}
#contents .b-knowledge__title {
  position: relative;
  margin: 0px 0px 5.3333333333vw;
  padding: 3.7333333333vw 0px;
  background-color: transparent;
  background-image: url("/sc_rsc/babyteeth/fusso/images/knowledge-title-bg.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
  font-family: var(--font-mplus-rounded);
  text-align: center;
}
#contents .b-knowledge__title__sub, #contents .b-knowledge__title__main {
  display: block;
  font-weight: 700;
  color: var(--color-white);
}
#contents .b-knowledge__title__sub {
  font-size: 4.2666666667vw;
}
#contents .b-knowledge__title__main {
  font-size: 6.4vw;
}
#contents .b-knowledge__title::before, #contents .b-knowledge__title::after {
  content: "";
  position: absolute;
  display: block;
  width: 7.4666666667vw;
  height: 13.3333333333vw;
  background-image: url("/sc_rsc/babyteeth/fusso/images/effect-lines.svg");
  background-size: 100% 100%;
  background-repeat: no-repeat;
}
#contents .b-knowledge__title::before {
  left: 4.5333333333vw;
  top: 5.0666666667vw;
}
#contents .b-knowledge__title::after {
  right: 4.5333333333vw;
  top: 5.0666666667vw;
  -webkit-transform: scaleX(-1);
          transform: scaleX(-1);
}
#contents .b-knowledge__section {
  width: 89.3333333333vw;
  margin: 0px auto 5.3333333333vw;
  padding: 5.3333333333vw;
  background-color: var(--color-white);
  border-radius: 1.3333333333vw;
}
#contents .b-knowledge__section__title {
  margin: 0px 0px 2.6666666667vw;
  padding: 1.3333333333vw 0px;
  font-family: var(--font-mplus-rounded);
  font-size: 4.2666666667vw;
  font-weight: 700;
  color: var(--color-white);
  text-align: center;
  background-color: var(--color-blue);
  border-radius: 8vw;
}
#contents .b-knowledge__section__txt {
  font-size: 4.2666666667vw;
  line-height: 1.8;
}
@media screen and ( min-width: 768px ) {
  #contents .b-knowledge {
    padding: 0px 0px 20px;
  }
  #contents .b-knowledge__title {
    margin: 0px auto 30px;
    padding: 30px 0px;
  }
  #contents .b-knowledge__title__sub {
    font-size: 20px;
  }
  #contents .b-knowledge__title__main {
    font-size: 28px;
  }
  #contents .b-knowledge__title::before, #contents .b-knowledge__title::after {
    width: 50px;
    height: 90px;
  }
  #contents .b-knowledge__title::before {
    left: 80px;
    top: 24px;
  }
  #contents .b-knowledge__title::after {
    right: 80px;
    top: 24px;
  }
  #contents .b-knowledge__section {
    width: 528px;
    margin: 0px auto 40px;
    padding: 40px;
  }
  #contents .b-knowledge__section__title {
    margin: 0px 0px 20px;
    padding: 10px 0px;
    font-size: 20px;
  }
  #contents .b-knowledge__section__txt {
    font-size: 18px;
  }
}
#contents .cb-fixed-onlineshop-banner {
  position: fixed;
  bottom: 20px;
  right: 20px;
  display: block;
  color: #fff !important;
  text-align: center;
  font-weight: bold;
  background: #f66152;
  padding: 16px 14px;
  font-size: 16px;
  z-index: 20;
}
#contents .cb-fixed-onlineshop-banner__left {
  right: initial;
  left: 20px;
}
#contents .u-display--md-down {
  display: none;
}
@media screen and ( max-width: 767px ) {
  #contents .u-display--md-down {
    display: block;
  }
}
#contents .u-display--sm-down {
  display: none;
}
@media screen and ( max-width: 413px ) {
  #contents .u-display--sm-down {
    display: block;
  }
}
#contents .u-display--md-up {
  display: none;
}
@media screen and ( min-width: 768px ) {
  #contents .u-display--md-up {
    display: block;
  }
}
#contents .u-display--sm-up {
  display: none;
}
@media screen and ( min-width: 414px ) {
  #contents .u-display--sm-up {
    display: block;
  }
}
#contents .u-border-radius--10 {
  border-radius: 10px;
}
#contents .u-margin--top--0 {
  margin-top: 0px !important;
}
#contents .u-margin--top--10 {
  margin-top: 10px;
}
#contents .u-margin--top--20 {
  margin-top: 20px;
}
#contents .u-margin--top--30 {
  margin-top: 30px;
}
#contents .u-margin--top--40 {
  margin-top: 40px;
}
#contents .u-margin--bottom--10 {
  margin-bottom: 10px;
}
#contents .u-margin--bottom--20 {
  margin-bottom: 20px;
}
#contents .u-margin--bottom--30 {
  margin-bottom: 30px;
}
#contents .u-margin--bottom--40 {
  margin-bottom: 40px;
}
#contents .u-text-bold {
  font-weight: bold;
}
#contents .u-text-underline {
  text-decoration: underline;
}