﻿@charset "UTF-8";

/* ########## プロデン デンタルケア ########## */
/*
 * "Noto Sans JP" is lisenced under the SIL Open Font License 1.1
 * http://fonts.googleapis.com
 * https://www.google.com/fonts/attribution
 * http://scripts.sil.org/OFL
 */
/*
/*
 * "Roboto" is lisenced under the SIL Open Font License 1.1
 * http://fonts.googleapis.com
 * https://www.google.com/fonts/attribution
 * http://scripts.sil.org/OFL
 * 
 */

/* Copyright (c) 2026 ProDen
 Released under the MIT license
 https://opensource.org/licenses/mit-license.php */

/* ############## 共通 ############## */

html {
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
}

body {
  width: 100%;
  max-width: 100%;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
  font-family: "Noto Sans JP", "Meiryo", "Helvetica Neue", "Arial", "verdana", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro";
  overflow-wrap: anywhere;
  /* 収まらない場合に折り返す */
  word-break: normal;
  /* 単語の分割はデフォルトに依存 */
  line-break: strict;
  /* 禁則処理を厳格に適用 */
  color: #5d6266;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 400;
  letter-spacing: 0.35px;
}

label,
td,
th,
p,
div,
dd,
dt,
li,
a,
input,
textarea,
select,
h1,
h2,
h3,
h4,
h5,
h6 {
  color: #5d6266;
  font-size: 16px;
  line-height: 1.5;
  font-weight: 500;
  letter-spacing: 0.15px;
}

p,
li,
td,
th,
dd,
dt {
  text-align: justify;
  line-height: 1.9;
  font-weight: 400;
}

.text10 {
  font-size: 10px;
}

.text11 {
  font-size: 11px;
}

.text12 {
  font-size: 12px;
}

.text13 {
  font-size: 13px;
}

.text14 {
  font-size: 14px;
}

.text15 {
  font-size: 15px;
}

.text16 {
  font-size: 16px;
}

.text17 {
  font-size: 17px;
}

.text18 {
  font-size: 18px;
}

.text19 {
  font-size: 19px;
}

.text20 {
  font-size: 19px;
}

.text21 {
  font-size: 19px;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  text-align: initial;
}

h1 {
  font-size: 65px;
}

h2 {
  font-size: 32px;
}

h3 {
  font-size: 28px;
}

h4 {
  font-size: 22px;
}

h5 {
  font-size: 18px;
}

h6 {
  font-size: 17px;
}

.h2-common {
  display: block;
  position: relative;
  z-index: 2;
  font-size: clamp(18px, calc(100vw /560 * 32), 32px);
  line-height: 1.45;
  font-weight: 900;
  text-align: center;
  width: 100%;
}

.h2-kira img {
  width: clamp(18px, calc(100vw /560 * 44), 44px);
  vertical-align: clamp(-5px, calc(100vw /560 * -5), -1px);
}


.h2-en {
  position: absolute;
  z-index: 0;
  color: rgba(255, 255, 255, 0.35);
  font-family: "Roboto";
  font-weight: 700;
  font-size: clamp(32px, calc(100vw / 560 * 80), 80px);
  line-height: 1.25;
  bottom: 0px;
  white-space: nowrap;
}

.h2-en.line2 {
  bottom: clamp(16px, calc(100vw / 560 * 40), 40px);
}

.h2-en.line3 {
  bottom: clamp(40px, calc(100vw / 560 * 90), 90px);
}

.h2-en.left-en {
  left: 0;
}

.h2-en.right-en {
  right: 0;
}

.h2-common2 {
  position: relative;
  z-index: 2;
  font-size: clamp(23px, calc(100vw /560 * 28), 28px);
  line-height: 1.45;
  font-weight: 900;
}

.h3-common {
  position: relative;
  z-index: 2;
  font-size: clamp(21px, calc(100vw /560 * 26), 26px);
  line-height: 1.45;
  font-weight: 900;
}

.h3-product {
  color: #ffffff;
  font-size: clamp(18px, calc(100vw /560 * 24), 24px);
  line-height: 1.45;
  font-weight: 700;
  text-align: center;
  padding: 4px 5px 7px;
  border: 2px solid #ffffff;
  margin-bottom: 20px;
}


.katuko {
  display: inline-block;
  margin-left: -0.3em;
  margin-right: -0.3em;
}

.seaweed-right {
  position: absolute;
  z-index: 0;
  right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: 0;
  width: clamp(60px, calc(100vw /560 * 152), 152px);
}

.seaweed-left {
  position: absolute;
  z-index: 0;
  left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: 0;
  width: clamp(50px, calc(100vw /560 * 118), 118px);
}

.seaweed-left2 {
  position: absolute;
  z-index: 0;
  left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: 0;
  width: clamp(80px, calc(100vw /560 * 163), 163px);
}

.seaweed-left3 {
  position: absolute;
  z-index: 0;
  left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: clamp(80px, calc(100vw /560 * 163), 163px);
  width: clamp(60px, calc(100vw /560 * 127), 127px);
}

.seaweed-left4 {
  position: absolute;
  z-index: 0;
  left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: clamp(-90px, calc(-90 * 100vw / 560), -45px);
  width: clamp(60px, calc(100vw /560 * 123), 123px);
}

.seaweed-left5 {
  position: absolute;
  z-index: 0;
  left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: clamp(-90px, calc(-90 * 100vw / 560), -45px);
  width: clamp(60px, calc(100vw /560 * 127), 127px);
}

.seaweed-right2 {
  position: absolute;
  z-index: 0;
  right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: clamp(-100px, calc(-100 * 100vw / 560), -45px);
  width: clamp(60px, calc(100vw /560 * 152), 152px);
}

.seaweed-right3 {
  position: absolute;
  z-index: 0;
  right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  top: clamp(-100px, calc(-100 * 100vw / 560), -45px);
  width: clamp(60px, calc(100vw /560 * 152), 152px);
}

.sf {
  display: none !important;
}

.white {
  color: #ffffff !important;
}

.black {
  color: #5d6266 !important;
}

.blue {
  color: #46b1e4 !important;
}

.lightblue {
  color: #e0f2fb !important;
}

.purple {
  color: #e3b7d4 !important;
}

.lightpurple {
  color: #fbf4f8 !important;
}

.green {
  color: #14ae67 !important;
}

.lightgreen {
  color: #e2f1ed !important;
}

.green-blue {
  color: #75c4b4 !important;
}

.lightgreen-blue {
  color: #e2f1ed !important;
}

.yellow {
  color: #ffdd72 !important;
}

.orange {
  color: #ec6d00 !important;
}

.lightorange {
  color: #fdebdc !important;
}

.back--white {
  background-color: #ffffff !important;
}

.back--black {
  background-color: #5d6266 !important;
}

.back--blue {
  background-color: #46b1e4 !important;
}

.back--blue2 {
  background-color: #0090da !important;
}

.back--lightblue {
  background-color: #e0f2fb !important;
}

.back--purple {
  background-color: #e3b7d4 !important;
}

.back--purple2 {
  background-color: #cd7fb3 !important;
}

.back--lightpurple {
  background-color: #fbf4f8 !important;
}

.back--green {
  background-color: #14ae67 !important;
}

.back--lightgreen {
  background-color: #e2f1ed !important;
}

.back--green-blue {
  background-color: #75c4b4 !important;
}

.back--green-blue2 {
  background-color: #3bab94 !important;
}

.back--lightgreen-blue {
  background-color: #e2f1ed !important;
}

.back--yellow {
  background-color: #ffdd72 !important;
}

.back--yellow2 {
  background-color: #ffdd72 !important;
}

.back--orange {
  background-color: #e5a140 !important;
}

.back--orange2 {
  background-color: #c65500 !important;
}

.back--fv {
  background-image: url("../image/fv.jpg");
  background-size: cover;
  background-position: bottom center;
  background-repeat: no-repeat;

}

.back--bg1 {
  background-color: #e0f2fb;
  background-image: url("../image/background1.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: 0 clamp(100px, calc(100vw / 560 * 280), 280px) 0 0;
  overflow: hidden;
}

.back--bg2 {
  background-color: #ffffff;
  border-radius: clamp(100px, calc(100vw / 560 * 280), 280px) 0 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
  overflow: hidden;
}

.back--bg3 {
  background-color: #46b1e4;
  background-image: url("../image/background2.jpg");
  background-size: contain;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: 0 clamp(100px, calc(100vw / 560 * 280), 280px) 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
  overflow: hidden;
}

.back--bg4 {
  background-image: url("../image/background3.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: clamp(100px, calc(100vw / 560 * 280), 280px) 0 0 0;
  margin-top: clamp(-310px, calc(-310 * 100vw / 560), -130px);
  overflow: hidden;
}

.back--bg5 {
  background-image: url("../image/background4.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: 0 clamp(100px, calc(100vw / 560 * 280), 280px) 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
  overflow: hidden;
}

.back--bg6 {
  background-color: #ffffff;
  border-radius: clamp(100px, calc(100vw / 560 * 280), 280px) 0 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
  overflow: hidden;
}

.back--bg7 {
  background-image: url("../image/background5.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
  border-radius: 0 clamp(100px, calc(100vw / 560 * 280), 280px) 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
}

.back--bg8 {
  background-color: #ffffff;
  border-radius: clamp(100px, calc(100vw / 560 * 280), 280px) 0 0 0;
  margin-top: clamp(-280px, calc(-280 * 100vw / 560), -100px);
}

.back--bg9 {
  background-image: url("../image/background6.jpg");
  background-size: cover;
  background-position: bottom center;
  background-repeat: no-repeat;
  border-radius: 0 clamp(100px, calc(100vw / 560 * 280), 280px) 0 0;
  position: relative;
  z-index: 2;
}

.border {
  border: 1px solid #5d6266;
}

.border-blue {
  border: 1px solid #46b1e4;
}

.border-bottom1,
.border-bottom-black {
  border-bottom: 1px solid #5d6266;
}

.border-bottom-white {
  border-bottom: 1px solid #ffffff !important;
}

.border-bottom-orange2 {
  border-bottom: 2px solid #ec6d00;
}

.border-bottom-blue {
  border-bottom: 1px solid #46b1e4;
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 300;
  src: url("../font/NotoSansJP-Light.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 400;
  src: url("../font/NotoSansJP-Regular.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 500;
  src: url("../font/NotoSansJP-Medium.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 700;
  src: url("../font/NotoSansJP-Bold.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Noto Sans JP";
  font-style: normal;
  font-weight: 900;
  src: url("../font/NotoSansJP-Black.woff") format("woff");
  font-display: swap;
}

.Noto-Sans-JP {
  font-family: "Noto Sans JP", "Helvetica Neue", "Arial", "verdana", "メイリオ", "Meiryo", "ヒラギノ角ゴ ProN W3", "HiraKakuProN-W3", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro";
}

.sans {
  font-family: "Noto Sans JP", "メイリオ", "Meiryo", "HiraKakuProN-W3", "Hiragino Kaku Gothic Pro", sans-serif;
}


@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 700;
  src: url("../font/Roboto-Bold.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Roboto";
  font-style: normal;
  font-weight: 900;
  src: url("../font/Roboto-Black.woff") format("woff");
  font-display: swap;
}

.roboto {
  font-family: "Roboto";
}


.cta-text {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.text-stroke {
  -webkit-text-stroke: 0.5px #ffffff;
}

.box-shadow {
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5), 0 2px 2px;
}

.drop-shadow {
  filter: drop-shadow(2px 2px 1.5px rgba(0, 0, 0, 0.25));
}

.fuchidori {
  text-shadow: 1px 1px 0 #FFF, -1px -1px 0 #FFF,
    -1px 1px 0 #FFF, 1px -1px 0 #FFF,
    0px 1px 0 #FFF, 0 -1px 0 #FFF,
    -1px 0 0 #FFF, 1px 0 0 #FFF;
}

.drop-shadow2 {
  filter: drop-shadow(1.5px 1.5px 0.5px rgba(0, 0, 0, 0.35));
}

.marker1 {
  background: linear-gradient(transparent 75%, rgb(252, 199, 0) 75% 95%, transparent 95%);
}

.pretty {
  text-wrap: pretty !important;
}

.balance {
  text-wrap: balance !important;
}

input,
select,
textarea {
  outline: none;
  border: 1px solid #5d6266;
}

button,
optgroup,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

#main {
  position: relative;
}

ul,
li {
  list-style: none;
}

a {
  text-decoration: none;
  display: inline-block;
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  /* pointer-events: none; */
  /* image-rendering: -webkit-optimize-contrast; */
}

.nowrap {
  white-space: nowrap;
}

.ws-wrap {
  white-space: wrap !important;
}

.hidden {
  overflow: hidden;
}

.hidden-x {
  overflow-x: hidden;
}

.hidden-y {
  overflow-y: hidden;
}

.flip-horizontal {
  transform: scale(-1, 1);
}

.utikesi {
  text-decoration: line-through;
}

.ls0 {
  letter-spacing: 0;
}

.ls-h2 {
  letter-spacing: -1px;
}

.line-height1 {
  line-height: 1 !important;
}


.line-height15 {
  line-height: 1.5 !important;
}

.line-height175 {
  line-height: 1.75 !important;
}


.line-height2 {
  line-height: 2 !important;
}


.margin-block1 {
  margin-block: 1em !important;
}

.margin-top025 {
  margin-top: 0.25em !important;
}

.margin-top05 {
  margin-top: 0.5em !important;
}

.margin-top075 {
  margin-top: 0.75em !important;
}

.margin-top1 {
  margin-top: 1em !important;
}

.margin-top10 {
  margin-top: 1em !important;
}

.margin-top15 {
  margin-top: 1.5em !important;
}

.margin-top2 {
  margin-top: 2em !important;
}

.margin-top3 {
  margin-top: 3em !important;
}

.margin-top-5 {
  margin-top: -5px !important;
}

.margin-top5 {
  margin-top: 5px !important;
}

.margin-top10 {
  margin-top: 10px !important;
}

.margin-top15 {
  margin-top: 15px !important;
}

.margin-top20 {
  margin-top: 20px !important;
}

.margin-top30 {
  margin-top: 30px !important;
}

.margin-top35 {
  margin-top: 35px !important;
}

.margin-top45 {
  margin-top: 45px !important;
}

.margin-top50 {
  margin-top: 50px !important;
}

.margin-top60 {
  margin-top: 60px !important;
}

.margin-top90 {
  margin-top: 90px !important;
}

.margin-top120 {
  margin-top: 120px !important;
}

.margin-top130 {
  margin-top: 130px !important;
}

.margin-bottom025 {
  margin-bottom: 0.25em !important;
}

.margin-bottom035 {
  margin-bottom: 0.35em !important;
}

.margin-bottom05 {
  margin-bottom: 0.5em !important;
}

.margin-bottom1 {
  margin-bottom: 1em !important;
}

.margin-bottom2 {
  margin-bottom: 2em !important;
}

.margin-bottom3 {
  margin-bottom: 3em !important;
}

.margin-bottom10 {
  margin-bottom: 10px !important;
}

.margin-bottom15 {
  margin-bottom: 15px !important;
}

.margin-bottom20 {
  margin-bottom: 20px !important;
}

.margin-bottom25 {
  margin-bottom: 25px !important;
}

.margin-bottom30 {
  margin-bottom: 30px !important;
}

.margin-bottom45 {
  margin-bottom: 45px !important;
}

.margin-bottom60 {
  margin-bottom: 60px !important;
}

.margin-bottom90 {
  margin-bottom: 90px !important;
}

.margin-block15 {
  margin-block: 15px !important;
}

.margin-block30 {
  margin-block: 30px !important;
}

.margin-fit-content-auto {
  margin-inline: auto;
  width: fit-content;
}

.margin-top-auto {
  margin-top: auto;
}

.margin-inline-auto {
  margin-inline: auto;
}

.margin-left0 {
  margin-left: 0 !important;
}

.margin-left1 {
  margin-left: 1em !important;
}

.margin-right0 {
  margin-right: 0 !important;
}

.margin-right1 {
  margin-right: 1em !important;
}

.padding-top0 {
  padding-top: 0 !important;
}

.padding-top05 {
  padding-top: 0.5em !important;
}

.padding-top1 {
  padding-top: 1em !important;
}

.padding-top2 {
  padding-top: 2em !important;
}

.padding-top3 {
  padding-top: 3em !important;
}

.padding-top15 {
  padding-top: 15px !important;
}

.padding-top30 {
  padding-top: 30px !important;
}

.padding-bottom025 {
  padding-bottom: 0.25em !important;
}

.padding-bottom05 {
  padding-bottom: 0.5em !important;
}

.padding-bottom1 {
  padding-bottom: 1em !important;
}

.padding-bottom2 {
  padding-bottom: 2em !important;
}

.padding-bottom3 {
  padding-bottom: 3em !important;
}

.padding-bottom15 {
  padding-bottom: 15px !important;
}

.padding-bottom30 {
  padding-bottom: 30px !important;
}

.padding-inline10 {
  padding-inline: 10px !important;
}

.padding-inline15 {
  padding-inline: 15px !important;
}

.padding-inline30 {
  padding-inline: 30px !important;
}

.contents-560 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 560px;
  box-shadow: 0px 0px 16px rgba(0, 0, 0, .025);
  overflow-x: hidden;
}

.contents0 {
  position: relative;
  z-index: 2;
  padding: 0 clamp(15px, calc(100vw /560 * 30), 30px);
}

.contents {
  position: relative;
  z-index: 2;
  padding: clamp(50px, calc(100vw /560 * 100), 100px) clamp(15px, calc(100vw /560 * 30), 30px) clamp(150px, calc(100vw /560 * 360), 360px);
}

.contents2 {
  position: relative;
  z-index: 2;
  padding: clamp(100px, calc(100vw /560 * 200), 200px) clamp(15px, calc(100vw /560 * 30), 30px) clamp(150px, calc(100vw /560 * 360), 360px);
}

.contents.footer {
  padding: clamp(35px, calc(100vw /560 * 75), 75px) clamp(15px, calc(100vw /560 * 30), 30px) 200px;
}

.contents.bottom0,
.contents2.bottom0 {
  padding-bottom: 0;
}

.max-420 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 420px;
}

.max-320 {
  padding: 0px clamp(15px, calc(100vw /560 * 30), 30px);
  margin-right: auto;
  margin-left: auto;
  max-width: 420px;
}

.normal {
  font-weight: normal;
}

.weight300 {
  font-weight: 300 !important;
}

.weight400 {
  font-weight: 400 !important;
}

.weight500 {
  font-weight: 500 !important;
}

.weight600 {
  font-weight: 600 !important;
}

.weight700 {
  font-weight: 700 !important;
}

.weight800 {
  font-weight: 800 !important;
}

.weight900 {
  font-weight: 900 !important;
}

.bold {
  font-weight: 700;
}

.italic {
  font-style: italic;
}

.width-fit-content {
  width: fit-content;
}

.big {
  font-size: 120%;
  line-height: 1;
}

.big120 {
  font-size: 120%;
  line-height: 1;
}

.big150 {
  font-size: 150%;
  line-height: 1;
}

.small50 {
  font-size: 50%;
}

.small80 {
  font-size: 80%;
}

.small85 {
  font-size: 85%;
}

.asterisk {
  font-size: 70%;
  vertical-align: 5px;
}

.initial {
  text-align: initial;
}

.center {
  text-align: center;
}

.justify {
  text-align: justify;
}

.right {
  text-align: right;
}

.left {
  text-align: left;
}

.float-left {
  float: left;
}

.float-right {
  float: right;
}

.absolute {
  position: absolute;
}

.relative {
  position: relative;
}

.z-index-2 {
  z-index: -2;
}

.z-index-1 {
  z-index: -1 !important;
}

.z-index0 {
  z-index: 0;
}

.z-index1 {
  z-index: 1;
}

.z-index2 {
  z-index: 2;
}

.z-index3 {
  z-index: 3;
}

.z-index4 {
  z-index: 4;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.fontsize0 {
  font-size: 0;
}

.inline {
  display: inline !important;
}

.inline-block {
  display: inline-block !important;
}

.inline-flex {
  display: inline-flex;
}

.none {
  display: none;
}

.block {
  display: block;
}

.text-indent1 {
  padding-left: 1.05em;
  text-indent: -1.05em;
}

.opacity1 {
  opacity: 0.85;
}

.multiply {
  mix-blend-mode: multiply;
}

/* アニメーション　*/
/* Animation */
.floating {
  animation: floating-y 3.0s ease-in-out infinite alternate-reverse;
}

@keyframes floating-y {
  0% {
    transform: translateY(6%) translateX(0%);
  }

  100% {
    transform: translateY(-6%) translateX(-2%) rotate(-5deg);
  }
}

.floating2 {
  animation: floating-y2 3.0s ease-in-out infinite alternate-reverse;
}

@keyframes floating-y2 {
  0% {
    transform: translateY(-6%) translateX(-2%) rotate(-5deg);
  }

  100% {
    transform: translateY(6%) translateX(0%);
  }
}

/* fade-top*/
.fade-top {
  opacity: 0;
  animation: FadeTop 1.5s forwards;
  will-change: transform;
  animation-delay: 0.85s;
}

@keyframes FadeTop {
  30% {
    opacity: 0;
    transform: translate(0px, 0px) scale(1);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0) scale(1);
  }
}

/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
.fadeUpTrigger {
  opacity: 0;
}

.fadeUpTrigger2 {
  opacity: 0;
}

.fadeUpTrigger3 {
  opacity: 0;
}

.fadeUpTrigger4 {
  opacity: 0;
}

.wrapper {
  overflow: hidden;
}

.effectfade {
  opacity: 0;
  animation: EffectFade 0.75s forwards;
  will-change: transform;
}

@keyframes EffectFade {

  0% {
    opacity: 0;
    transform: translate(0px, 75px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

.effectfade2 {
  opacity: 0;
  animation: EffectFade2 0.65s forwards;
  will-change: transform
}

@keyframes EffectFade2 {



  0% {
    opacity: 0;
    transform: translate(0, 0) scale(0.6);
  }

  50% {
    opacity: 1;
    transform: translate(0, 0) scale(1.1);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0) scale(1);
  }
}

/* lefttoright*/
.lefttoright {
  opacity: 0;
  animation: LeftToRight 0.75s forwards;
  will-change: transform
}

@keyframes LeftToRight {
  0% {
    opacity: 0;
    transform: translate(-75px, 0px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

/* righttoleft*/
.righttoleft {
  opacity: 0;
  animation: RightToLeft 0.75s forwards;
  will-change: transform
}

@keyframes RightToLeft {
  0% {
    opacity: 0;
    transform: translate(75px, 0px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

/* effectfade時間差1*/
.effectfade {
  animation-delay: 0.2s;
}


.effectfade.second {
  animation-delay: 0.6s;
}

.effectfade.third {
  animation-delay: 1.0s;
}

.effectfade.fourth {
  animation-delay: 1.4s;
}

.effectfade.fifth {
  animation-delay: 1.8s;
}

.effectfade2 {
  animation-delay: 0.2s;
}

.effectfade2.second {
  animation-delay: 0.6s;
}

.effectfade2.third {
  animation-delay: 1.0s;
}

.effectfade2.fourth {
  animation-delay: 1.4s;
}

.effectfade2.fifth {
  animation-delay: 1.8s;
}

.righttoleft {
  animation-delay: 0.2s;
}

.lefttoright {
  animation-delay: 0.2s;
}

.righttoleft.second {
  animation-delay: 0.6s;
}

.lefttoright.second {
  animation-delay: 0.6s;
}

.righttoleft.third {
  animation-delay: 1.0s;
}

.lefttoright.third {
  animation-delay: 1.0s;
}

.righttoleft.fourth {
  animation-delay: 1.4s;
}

.lefttoright.fourth {
  animation-delay: 1.4s;
}

.fadeUpTrigger5 {
  overflow: hidden;
}

.fadeUpTrigger5 span {
  display: inline-block;
  opacity: 0;
  transform: translateY(120%);
}

.fadeUpTrigger5.is-show span {
  animation: textUp 0.9s forwards;
}

@keyframes textUp {

  0% {
    opacity: 0;
    transform: translateY(120%);
  }

  60% {
    opacity: 1;
    transform: translateY(0%);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }

}

.flex {
  display: flex;
}

.flex-w {
  flex-wrap: wrap;
}

.flex-fw {
  display: flex;
  flex-wrap: wrap;
}

.flex-ac {
  display: flex;
  align-items: center;
}

.flex-ac-jc {
  display: flex;
  align-items: center;
  justify-content: center;
}

.flex-ac-js {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.flex-fw-ac {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}

.flex-fw-jc {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.flex-fw-jfe {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.flex-fw-js {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.flex-fw-ac-js {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
}

.flex-fw-ac-jc {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.flex-fw-afs-js {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
}

.flex-fw-ast-js {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
}

.flex-fw-ac-fdc {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex-direction: column;
}

.flex-fw-fdc {
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
}

.flex-1 {
  flex: 1;
}

.column {
  flex-direction: column;
}

table {
  border-collapse: collapse;
  table-layout: fixed;
  width: 100%;
  max-width: 100%;
}

/* ########## 共通ボタン ########## */

.cta-product {
  position: absolute;
  right: 0;
  top: clamp(-85px, calc(-85 * 100vw / 560), -50px);
  width: clamp(90px, calc(100vw /560 * 150), 150px);
}

.button-common {
  position: relative;
  text-align: center;
}

.button-common>a {
  font-size: clamp(16px, calc(100vw /400 * 18), 18px);
  padding: 5px 15px 7px;
  line-height: 0;
  max-width: 300px;
  width: 100%;
  height: clamp(46px, calc(100vw /400 * 58), 58px);
  border-radius: 58px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  color: #5d6266;
  background-color: #ffffff;
  transition: all .15s ease 0s;
  box-shadow: 0 7px 0 #a6a6a6;
}

.button-common>a::before {
  content: "";
  position: absolute;
  right: 20px;
  width: 12px;
  height: 12px;
  border-right: 4px solid #a6a6a6;
  border-top: 4px solid #a6a6a6;
  transform: translateY(-50%) rotate(45deg);
  top: 50%;
  z-index: 2;
  transition: all .25s ease 0s;
}

.button-common.cta>a {
  font-size: clamp(20px, calc(100vw /400 * 26), 26px);
  padding: 5px 15px 7px;
  max-width: 100%;
  margin-top: 90px;
  height: clamp(60px, calc(100vw /400 * 75), 75px);
  border-radius: 75px;
  color: #ffffff;
  background-color: #ec6d00;
  box-shadow: 0 7px 0 #c65500;
}

.button-common.cta>a::before,
.button-common.blue-btn>a::before,
.button-common.purple-btn>a::before {
  right: 25px;
  width: 12px;
  height: 12px;
  border-right: 4px solid #ffffff;
  border-top: 4px solid #ffffff;
}

.button-common.log-in>a {
  max-width: 100%;
  color: #5d6266;
  font-weight: 900;
  background-color: #ffdd72;
  box-shadow: 0 7px 0 #e5a140;
}

.button-common.blue-btn>a {
  max-width: 100%;
  width: 92.5%;
  color: #ffffff;
  font-weight: 700;
  background-color: #46b1e4;
  box-shadow: 0 7px 0 #0090da;
  line-height: 1.35;
  padding-right: 35px;
}


.button-common.purple-btn>a {
  max-width: 100%;
  width: 92.5%;
  color: #ffffff;
  font-weight: 700;
  background-color: #e3b7d4;
  box-shadow: 0 7px 0 #cd7fb3;
  line-height: 1.35;
  padding-right: 35px;
}

.button-common.log-in>a::before {
  border-right: 4px solid #5d6266;
  border-top: 4px solid #5d6266;
}

.button-common.contact>a {
  max-width: 100%;
  color: #ffffff;
  font-weight: 900;
  background-color: #ec6d00;
  box-shadow: 0 7px 0 #c65500;
}

.button-common.contact>a::before {
  border-right: 4px solid #ffffff;
  border-top: 4px solid #ffffff;
}


/* ########## hover active ########## */

.button-common>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #a6a6a6;
}

.button-common.cta>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #c65500;
}

.button-common>a:active,
.button-common.cta>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #000018;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

.button-common.log-in>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #e5a140;
}

.button-common.contact>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #c65500;
}

.button-common.blue-btn>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #0090da;
}

.button-common.purple-btn>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #cd7fb3;
}

.button-common.log-in>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #e5a140;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

.button-common.contact>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #e5a140;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

.button-common.blue-btn>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #0090da;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

.button-common.purple-btn>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #cd7fb3;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

/*  hover activeここまで  */

/* ########## 共通アイテム ########## */
.fix-cta {
  opacity: 0;
  height: 0;
  transition: all 1.0s ease;
  position: fixed;
  z-index: 5;
  bottom: 20px;
  padding: 0 clamp(15px, calc(100vw /560 * 30), 30px) 0;
  right: 0;
  left: 0;
  max-width: 560px;
  margin-inline: auto;
  pointer-events: none;
}

.fix-cta.is-show {
  opacity: 1;
  height: 175px;
  pointer-events: auto;
}

.side {
  width: calc((100% - 560px) / 2);
  display: flex;
  justify-content: center;
  align-items: center;
}

.contents-center {
  width: 560px;
}

/* ########## メイン ########## */


.contents-center {
  width: 560px;
}

.main__title {
  display: flex;
  align-items: center;
  gap: clamp(5px, calc(100vw /560 * 15), 15px);
}

.circle {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  transform: rotate(-30deg);
  width: clamp(50px, calc(100vw /560 * 95), 95px);
  height: clamp(50px, calc(100vw /560 * 95), 95px);
  border-radius: 50%;
  text-align: center;
  font-weight: 700;
  line-height: 1.15;
  font-size: clamp(12px, calc(100vw /560 * 23), 23px);
  background-color: #ffdd72;
  transition: all .25s ease 0s;
}

.circle::after {
  content: "";
  position: absolute;
  bottom: 12px;
  left: 75%;
  border-style: solid;
  border-width: 12px 9px 0 9px;
  border-color: #ffdd72 transparent transparent;
  transform: translate(-65%, 100%) rotate(-140deg);
  z-index: 1;
}

.main__text {
  color: #ec6d00;
  font-weight: 900;
  font-size: clamp(18px, calc(100vw /560 * 32), 32px);
  line-height: 1.5;
  letter-spacing: -0.5px;
}

.main__text img {
  vertical-align: -4px;
  width: clamp(30px, calc(100vw /560 * 44), 44px);
}

.spoon {
  text-align: right;
  margin-bottom: clamp(-65px, calc(-65 * 100vw / 560), -20px);
  padding-right: clamp(30px, calc(100vw /560 * 75), 75px);
}

.spoon img {
  width: clamp(30px, calc(100vw /560 * 111), 111px);
}

.fv__photo {
  display: flex;
  align-items: center;
  gap: clamp(5px, calc(100vw /560 * 15), 15px);
  margin-right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  position: relative;
  z-index: 4;
}

.fv__product {
  width: 35%;
}

.fv__animal {
  width: 65%;
  margin-bottom: clamp(-75px, calc(-75 * 100vw / 560), -20px);
}

/* ########## ヘッダー1 ########## */

.header__logo {
  max-width: 300px;
}

.header__logo .main__title {
  gap: clamp(2.5px, calc(100vw /1260 * 7.5), 7.5px);
}

.header__logo .circle {
  width: clamp(25px, calc(100vw /1260 * 65), 65px);
  height: clamp(25px, calc(100vw /1260 * 65), 65px);
  font-size: clamp(6px, calc(100vw /1260 * 14), 14px);
}

.header__logo .circle::after {
  bottom: 6px;
  left: 75%;
  border-width: 6px 4px 0 4px;
}

.header__logo .main__text {
  font-size: clamp(10px, calc(100vw /1260 * 19), 19px);
}

.header__logo .main__text img {
  vertical-align: -2px;
  width: clamp(15px, calc(100vw /1260 * 22), 22px);
}

.header__logo .spoon {
  text-align: right;
  margin-bottom: clamp(-35px, calc(-35 * 100vw / 1260), -10px);
  padding-right: clamp(15px, calc(100vw /1360 * 35), 35px);
}

.header__logo .spoon img {
  width: 60px;
}

.header__left {
  padding: 0px 15px 0px;
}

.header__product {
  padding: 15px;
  width: 100%;
  text-align: center;
}

.header__product img {
  width: 350px;
  filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, .1));
}

.header-nav-pc {
  margin-top: 30px;
  margin-left: 15px;
}

.header-nav-pc a::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 14px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #5d6266;
  border-right: 1px solid #5d6266;
  transform: translateY(-50%) rotate(45deg);
}

.header-nav-pc li {
  margin-left: 15px;
}

.header-nav-pc li a {
  display: inline;
  color: #5d6266;
  font-weight: bold;
  position: relative;
  overflow: hidden;
  line-height: 1.25;
  z-index: 0;
  transition: color 0.3s, transform 0.1s, box-shadow 0.1s;
  background-image: linear-gradient(#46b1e4, #46b1e4);
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: 0 1px;
  transition: background-size 0.1s;
}

.header-nav-pc li:not(:last-child) {
  margin-bottom: 15px;
  line-height: 1.5;
}

/* hover */
.header-nav-pc li a:hover {
  color: #46b1e4;
  background-position: bottom left;
  background-size: 100% 1px;
}

.header-nav-pc a:hover::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 14px;
  width: 8px;
  height: 8px;
  border-top: 1px solid #46b1e4;
  border-right: 1px solid #46b1e4;
  transform: translateY(-50%) rotate(45deg);
}

/* active（クリック中） */
.header-nav-pc li:active {
  display: block;
  transform: translateY(2px);
}

#header {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
}

#bg {
  width: 100%;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -4;
  background-image: url("../image/bg.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

/* ########## ヘッダー2 ##########  */
.container {
  display: flex;
  height: 100vh;
  height: 100dvh;
}

@media (max-width: 1160px) {
  .container {
    display: none;
  }
}

.band-header {
  position: relative;
  top: 0;
  left: 0;
  z-index: 3;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.header-logo {
  width: clamp(70px, calc(100vw /400 * 135), 135px);
  margin-top: 5px;
}

.header-logo a:hover {
  opacity: .8;
}

.header-logo a:active {
  opacity: .7;
}

/* ########## プロデン デンタルケアとは… ########## */

.text-proden {
  font-size: clamp(16px, calc(100vw /400 * 18), 18px);
}

/* ########## こんなお悩みありませんか？ ########## */
.onayami__photo {
  width: clamp(100px, calc(100vw /560 * 183), 183px);
  position: absolute;
  top: clamp(80px, calc(100vw /560 * 140), 140px);
  left: 0
}

.onayami-wrapper {
  margin-right: auto;
  margin-left: auto;
  max-width: 460px;
  margin-top: clamp(-30px, calc(-30 * 100vw / 560), -15px);
}

.onayami-wrapper li {
  position: relative;
  width: fit-content;
  text-align: center;
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, .1));
}

.onayami-wrapper li img {
  width: clamp(210px, calc(100vw /460 * 257), 257px);
}

.onayami-wrapper li:nth-child(odd) {
  margin-left: auto;
}

.onayami-wrapper li:nth-child(n+2) {
  margin-top: clamp(-80px, calc(-80 * 100vw / 560), -45px);
}

.onayami-wrapper li:nth-child(2) {
  margin-top: clamp(-80px, calc(-80 * 100vw / 560), -65px);
  margin-left: 45px;
}

.onayami-wrapper li:nth-child(3) {
  margin-top: clamp(-50px, calc(-50 * 100vw / 560), -15px);
}

.onayami-wrapper li:nth-child(4) {
  margin-top: clamp(-65px, calc(-65 * 100vw / 560), 0px);
}

.onayami-text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.5;
  position: absolute;
  place-self: center;
  inset: 0;
}

.triangle {
  position: absolute;
  z-index: 2;
  top: -30px;
  left: 0;
  right: 0;
  margin-inline: auto;
  width: 140px;
  height: 60px;
  background: #ec6d00;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  margin-top: clamp(-310px, calc(-310 * 100vw / 560), -130px);
}

/* ########## 解決 ########## */

/* ########## 3つのポイント ########## */

.point-number {
  width: clamp(60px, calc(100vw / 560 * 115), 115px);
  height: clamp(70px, calc(100vw / 560 * 140), 140px);
  background: url(../image/icon-point.png) no-repeat center/contain;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  margin-top: clamp(-41px, calc(-41 * 100vw / 560), -23px);
}

.title-point {
  margin-top: clamp(20px, calc(100vw / 560 * 35), 35px);
  color: #ec6d00;
  font-family: "Roboto";
  font-size: clamp(10px, calc(100vw / 560 * 16), 16px);
  line-height: 1;
}

.title-point-number {
  color: #ec6d00;
  font-family: "Roboto";
  line-height: 0.75;
  font-size: clamp(22px, calc(100vw / 560 * 44), 44px);
  letter-spacing: -1px;
}

.point-text {
  flex: 1;
  padding-left: 10px;
}

.h3-point {
  font-size: clamp(20px, calc(100vw / 560 * 28), 28px);
  line-height: 1.35;
}

.point-img {
  margin-inline: auto;
  width: calc(100% + clamp(15px, calc(100vw / 560 * 30), 30px));
}

.point-img img {
  width: 100% !important;
}

.point-img.left-img {
  margin-left: clamp(-30px, calc(-30 * 100vw / 560), -15px);
}

.point-img.left-img img {
  border-radius: 0 135px 135px 0;
}

.point-img.right-img {
  margin-right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
}

.point-img.right-img img {
  border-radius: 135px 0 0 135px;
}

/* ########## 愛犬・愛猫の歯石にお悩みの方へ ########## */
.tartar-box {
  margin-right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  padding: clamp(15px, calc(100vw /560 * 30), 30px) clamp(15px, calc(100vw /560 * 30), 30px);
  background-color: #e0f2fb !important;
  border-radius: clamp(60px, calc(100vw / 560 * 240), 240px) 0 0 clamp(60px, calc(100vw / 560 * 240), 240px);
  overflow: hidden;
}

/* ########## 与え方 ########## */
.pet-dose {
  display: grid;
  align-items: stretch;
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 8px;
}

.pet-dose__item {
  display: flex;
  flex-direction: column;
}

.pet-dose__img {
  display: block;
  width: clamp(135px, calc(100vw / 420 * 165), 165px);
  height: clamp(135px, calc(100vw / 420 * 165), 165px);
  margin: 0 auto 10px;
}

.pet-dose__head {
  padding: 5px 10px;
  margin-bottom: 8px;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: clamp(18px, calc(100vw / 560 * 21), 21px);
  font-weight: 700;
}

.pet-dose__body {
  flex: 1;
  padding: 10px clamp(5px, calc(100vw / 560 * 15), 15px) 15px;
}

.pet-dose__body p {
  font-size: clamp(16px, calc(100vw / 560 * 18), 18px);
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: -0.25px;
  text-align: initial;
}

.pet-dose__body p:not(:first-child) {
  margin-top: 7.5px;
}

.pet-dose__item--dog .pet-dose__head {
  background: #46b1e4;
}

.pet-dose__item--dog .pet-dose__body {
  background: #e0f2fb;
}

.pet-dose__item--cat .pet-dose__head {
  background: #e3b7d4;
}

.pet-dose__item--cat .pet-dose__body {
  background: #fbf4f8;
}

.spoon2 {
  text-align: center;
}

.spoon2 img {
  width: clamp(180px, calc(100vw /560 * 200), 200px);
}

/* ########## 安心の高品質の理由 ########## */
.reason-box {
  margin-top: clamp(-60px, calc(-60 * 100vw / 560), -30px);
  margin-right: clamp(-30px, calc(-30 * 100vw / 560), -15px);
  padding: clamp(30px, calc(100vw /560 * 45), 45px) clamp(15px, calc(100vw /560 * 30), 30px);
  background-color: #e2f1ed !important;
  border-radius: clamp(90px, calc(100vw / 560 * 180), 180px) 0 0 clamp(90px, calc(100vw / 560 * 180), 180px);
  overflow: hidden;
}

.vohc-box {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(5px, calc(100vw / 560 * 20), 20px);
  margin-top: 45px;
}

.vohc-left {
  width: clamp(40px, calc(100vw / 560 * 100), 100px);
}

.vohc-right {
  width: 100%;
  flex: 1;
}

.vohc-right p {
  line-height: 1.5;
}

.h3-vohc {
  display: inline;
  border-bottom: 1px solid #5d6266;
  margin-bottom: 3px;
  padding-bottom: 3px;
  font-size: clamp(13px, calc(100vw / 560 * 21), 21px);
  line-height: 1.75;
  font-weight: 700;
}

.text16-vohc {
  font-size: clamp(13px, calc(100vw / 560 * 16), 16px);
}

.text13-vohc {
  font-size: clamp(11px, calc(100vw / 560 * 13), 13px);
}

.reason-box>p {
  letter-spacing: -0.25px;
  position: relative;
  z-index: 3;
}

/* ########## 製品概要 ########## */

.price {
  margin-top: -15px;
  font-size: 48px;
  font-weight: 700;
  color: #ffffff;
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
}

.gram {
  margin-top: -15px;
  font-size: 40px;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
}

.price span {
  font-family: "Arial";
}

.zeikomi {
  margin-left: 5px;
  display: block;
  padding-top: 15px;
  font-size: 14px;
  writing-mode: vertical-rl;
  letter-spacing: 0.5px;
}

.text-18-16 {
  font-size: clamp(16px, calc(100vw /400 * 18), 18px);
}

/* ########## よくあるご質問 ##########  */

.illust-position-faq-right {
  position: absolute;
  z-index: 4;
  top: -55px;
  right: 7%;
  width: clamp(90px, calc(100vw / 460 * 159), 159px);
}

.faqtable tr:not(:first-child) {
  margin: 30px 0 0 0;
}

.faqtable tr {
  position: relative;
  display: block;
}

.faqtable th {
  cursor: pointer;
  position: relative;
  text-align: initial;
  font-size: 18px;
  padding: 20px 55px 20px clamp(65px, calc(100vw / 560 * 80), 80px);
  line-height: 1.45;
  width: 100%;
  min-height: 58px;
  border-radius: 58px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  position: relative;
  color: #ffffff;
  background-color: #75c4b4;
  transition: all .15s ease 0s;
  -webkit-box-shadow: 0 7px 0 #3bab94;
  box-shadow: 0 7px 0 #3bab94;
}

.faqtable th:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #3bab94;
}

.faqtable th:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #3bab94;
  box-shadow: 0 2px 3px rgba(0, 0, 0, .3);
}

.abox-contents {
  display: none;
}

.faqtable td {
  display: block;
  position: relative;
  transition: 0.5s;
  padding-top: 8px;
}

.faqtable th.selected::after {
  transform: rotate(0);
  transition: 0.5s;
}

.faqtable th::before,
.faqtable th::after {
  content: '';
  display: block;
  position: absolute;
  transform: translateY(-50%);
  top: 50%;
  right: 15px;
  width: 25px;
  height: 3px;
  background-color: rgb(255, 255, 255);
}

.faqtable th::after {
  transform: translateY(-50%) rotate(90deg);
  transition: 0.5s;
  background-color: rgb(255, 255, 255);
}

.faqtable th span::before {
  content: "";
  position: absolute;
  z-index: 1;
  display: inline-block;
  left: 7px;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(49px, calc(100vw / 560 * 64), 64px);
  height: clamp(46px, calc(100vw / 560 * 59), 59px);
  background: url(../image/icon-faq.png) no-repeat center/contain;
  pointer-events: none;
}

.faqtable .abox-contents2 {
  position: relative;
  padding: 15px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.9;
}

/* ########## アニマートとは？購入方法 ########### */

.animato_logo img {
  width: clamp(88px, calc(100vw /560 * 136), 136px);
}

.animato-box {
  margin-left: clamp(15px, calc(100vw /560 * 30), 30px);
  padding: clamp(30px, calc(100vw /560 * 45), 45px) clamp(15px, calc(100vw /560 * 30), 30px) clamp(30px, calc(100vw /560 * 45), 45px) clamp(30px, calc(100vw /560 * 30), 30px);
  background-color: #e2f1ed !important;
  border-radius: clamp(90px, calc(100vw / 560 * 180), 180px) 0 0 clamp(90px, calc(100vw / 560 * 180), 180px);
  overflow: hidden;
}

.purchase-box {
  margin-left: clamp(15px, calc(100vw /560 * 30), 30px);
  padding: clamp(30px, calc(100vw /560 * 45), 45px) clamp(15px, calc(100vw /560 * 30), 30px) clamp(30px, calc(100vw /560 * 45), 45px) clamp(30px, calc(100vw /560 * 30), 30px);
  background-color: #e0f2fb !important;
  border-radius: clamp(90px, calc(100vw / 560 * 180), 180px) 0 0 clamp(90px, calc(100vw / 560 * 180), 180px);
  overflow: hidden;
}

/* ########## フッター ########### */

.footer-photo {
  padding-right: 15px;
  width: clamp(250px, calc(100vw /560 * 330), 330px);
  margin-inline: auto;
  margin-top: 45px;
  margin-bottom: -40px;
  position: relative;
  z-index: 0;
}

.footer__title {
  font-size: clamp(12px, calc(100vw /560 * 20), 20px);
  line-height: 1.5;
}

.footer__logo {
  width: clamp(70px, calc(100vw /460 * 95), 95px);
  margin: 0 auto 15px;
}

.footer__logo a:hover {
  opacity: .7;
}

.footer__logo a:active {
  opacity: .6;
}

.footer__nav {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}

.footer__nav li a {
  color: #ffffff;
  font-size: clamp(10px, calc(100vw /560 * 16), 16px);
  font-weight: 500;
  cursor: pointer;
  display: inline-block;
}

.footer__nav li a:hover {
  opacity: .7;
}

.footer__nav li a:active {
  opacity: .6;
}

.footer__nav li {
  line-height: 2;
}

.footer__nav li:not(:first-child):before {
  content: "/";
  font-size: clamp(10px, calc(100vw /560 * 16), 16px);
  display: inline-block;
  margin-right: clamp(5px, calc(100vw /560 * 10), 10px);
  margin-left: clamp(5px, calc(100vw /560 * 10), 10px);
  color: #ffffff;
}

.footer__copy {
  margin-top: 15px;
  font-size: 11px;
  font-weight: 500;
  color: #ffffff;
  text-align: center;
  letter-spacing: 0.5px;
}

@media (max-width: 479px) {
  .pc {
    display: none;
  }

  .sf {
    display: block !important;
  }

  .onayami-wrapper li:nth-child(2) {
    margin-left: 0px;
  }
}