﻿@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
 */
/*
/*
/*
 * "Courgette" 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
 */

/* ############## 共通 ############## */

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: #4a4a4a;
  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: #4a4a4a;
  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: 36px;
}

h3 {
  font-size: 28px;
}

h4 {
  font-size: 22px;
}

h5 {
  font-size: 18px;
}

h6 {
  font-size: 17px;
}

.h2-common {
  position: relative;
  z-index: 2;
  font-size: clamp(24px, calc(100vw /560 * 40), 34px);
  line-height: 1.45;
  font-weight: 900;
  /* width: fit-content; */
  margin-inline: auto;
  text-align: center;
  width: calc(100% + 48px);
  margin-left: -24px;
  margin-right: -24px;
}

.h3-common {
  position: relative;
  z-index: 2;
  font-size: clamp(21px, calc(100vw /560 * 28), 26px);
  line-height: 1.45;
  font-weight: 900;
}

.sf {
  display: none !important;
}

.white {
  color: #ffffff !important;
}

.black {
  color: #4a4a4a !important;
}

.blue {
  color: #0066b3 !important;
}

.darkblue {
  color: #112369 !important;
}

.green {
  color: #14ae67 !important;
}

.lightgreen {
  color: #e9f7e1 !important;
}

.gold {
  color: #e8b909 !important;
}

.back--white {
  background-color: #ffffff !important;
}

.back--black {
  background-color: #4a4a4a !important;
}

.back--blue {
  background-color: #0066b3 !important;
}

.h3-box-left.back--blue {
  background-color: #0066b3 !important;
}

.back--darkblue {
  background-color: #112369 !important;
}

.back--green {
  background-color: #14ae67 !important;
}

.back--lightgreen {
  background-color: #e9f7e1 !important;
}

.back--gold {
  background-color: #e8b909 !important;
}

.back--bg1 {
  background-color: #fff;
  background-image: url("../image/background1.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.object--white {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 300px;
  background-color: #ffffff !important;
}

.back--bg2 {
  background-image: url("../image/background2.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}

.back--bg3 {
  background-image: url("../image/background3.jpg");
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}

.back--bg4 {
  background-image: url("../image/background4.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.back--bg5 {
  background-image: url("../image/background5.jpg");
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
}

.color-box {
  padding: 20px clamp(10px, calc(100vw /400 * 15), 15px);
  border-radius: clamp(25px, calc(100vw /560 * 50), 50px);
}

.color-box2 {
  padding: 30px clamp(10px, calc(100vw /400 * 30), 30px);
  border-radius: clamp(25px, calc(100vw /560 * 50), 50px);
}

.color-box3 {
  padding: 25px clamp(10px, calc(100vw /400 * 25), 25px);
  border-radius: clamp(25px, calc(100vw /560 * 50), 50px);
}

.color-box4 {
  padding: 30px clamp(10px, calc(100vw /400 * 30), 30px);
  border-radius: clamp(25px, calc(100vw /560 * 50), 50px);
}

.color-box .h2-common,
.color-box2 .h2-common,
.color-box4 .h3-common {
  font-weight: 700;
}

.border {
  border: 1px solid #4a4a4a;
}

.border-blue {
  border: 1px solid #0066b3;
}

.border-bottom1,
.border-bottom-black {
  border-bottom: 1px solid #4a4a4a;
}

.border-bottom-white {
  border-bottom: 1px solid #ffffff !important;
}

.border-bottom-blue {
  border-bottom: 1px solid #0066b3;
}

.border-bottom-darkblue {
  border-bottom: 1px solid #112369;
}

.border-bottom-darkblue2 {
  border-bottom: 2px solid #112369;
}

@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: "Courgette";
  font-weight: 400;
  font-style: normal;
  src: url("../font/Courgette-Regular.woff") format("woff");
  font-display: swap;
}

.courgette {
  font-family: "Courgette", sans-serif;
}

.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 #4a4a4a;
}

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;
}

.flip-horizontal {
  transform: scale(-1, 1);
}

.utikesi {
  text-decoration: line-through;
}

.ls0 {
  letter-spacing: 0;
}

.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-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-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-240 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 240px;
}

.contents-560 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 560px;
  box-shadow: 0px 0px 16px rgba(0, 0, 0, .025);
}

.contents {
  padding: clamp(50px, calc(100vw /560 * 100), 100px) clamp(24px, calc(100vw /560 * 40), 56px);
}

.contents2 {
  padding: clamp(90px, calc(100vw /560 * 180), 180px) clamp(24px, calc(100vw /560 * 40), 56px);
}

.contents3 {
  padding: clamp(30px, calc(100vw /560 * 60), 60px) clamp(24px, calc(100vw /560 * 40), 56px) clamp(50px, calc(100vw /560 * 100), 100px);
}

.contents.footer {
  padding: 30px clamp(15px, calc(100vw /560 * 30), 30px) 200px;
}

.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;
}

.width-fit-content {
  width: fit-content;
}

.big120 {
  font-size: 120%;
  line-height: 1;
  vertical-align: -2px;
}

.big150 {
  font-size: 150%;
  line-height: 1;
  margin-inline: 3px;
}

.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;
}

/* アニメーション　*/
/* 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;
}

.wrapper {
  overflow: hidden;
}

.effectfade {
  opacity: 0;
  animation: EffectFade 1.0s forwards;
  will-change: transform
}

@keyframes EffectFade {

  0% {
    opacity: 0;
    transform: translate(0px, 45px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

/* lefttoright*/
.lefttoright {
  opacity: 0;
  animation: LeftToRight 1.0s forwards;
  will-change: transform
}

@keyframes LeftToRight {
  0% {
    opacity: 0;
    transform: translate(-45px, 0px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

/* righttoleft*/
.righttoleft {
  opacity: 0;
  animation: RightToLeft 1.0s forwards;
  will-change: transform
}

@keyframes RightToLeft {
  0% {
    opacity: 0;
    transform: translate(45px, 0px);
  }

  100% {
    opacity: 1;
    transform: translate(0, 0);
  }
}

/* effectfade時間差1*/
.effectfade {
  animation-delay: 0.1s;
}


.effectfade.second {
  animation-delay: 0.2s;
}

.effectfade.third {
  animation-delay: 0.1s;
}

.effectfade.fourth {
  animation-delay: 0.2s;
}

.effectfade.fifth {
  animation-delay: 0.1s;
}

.effectfade.sixth {
  animation-delay: 0.2s;
}


.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%;
}

/* ########## 共通ボタン ########## */

.sale {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  top: -65px;
  left: -5px;
  transform: rotate(-15deg);
  position: absolute;
  width: clamp(118px, calc(100vw /400 * 128), 128px);
  height: clamp(80px, calc(100vw /400 * 90), 90px);
  border-radius: 50%;
  text-align: center;
  font-weight: 400;
  font-size: clamp(15px, calc(100vw /400 * 16), 16px);
  line-height: 0.75;
  color: #ffffff !important;
  background-color: #e8b909;
  transition: all .25s ease 0s;
}

.sale::after {
  content: "";
  position: absolute;
  bottom: 12px;
  left: 75%;
  border-style: solid;
  border-width: 12px 9px 0 9px;
  border-color: #e8b909 transparent transparent;
  transform: translate(-65%, 100%) rotate(-140deg);
  z-index: 1;
}

.sale .sale-price {
  line-height: 1.75;
  font-size: clamp(21px, calc(100vw /400 * 23), 23px);
  font-weight: 700;
}

.cta-product {
  position: absolute;
  right: 0;
  top: clamp(-95px, calc(-95 * 100vw / 400), -70px);
  width: clamp(90px, calc(100vw /400 * 124), 124px);
}

.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: #4a4a4a;
  background-color: #ffffff;
  transition: all .15s ease 0s;
  box-shadow: 0 7px 0 #000018;
}

.button-common>a::before {
  content: "";
  position: absolute;
  right: 20px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #4a4a4a;
  border-top: 2px solid #4a4a4a;
  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: #0066b3;
}

.button-common.cta>a::before {
  right: 25px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

.button-common.log-in>a {
  max-width: 100%;
  color: #ffffff;
  background-color: #e8b909;
  box-shadow: 0 7px 0 #ba831f;
}

.button-common.log-in>a::before {
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

.button-common.contact>a {
  max-width: 100%;
  color: #ffffff;
  background-color: #0066b3;
}

.button-common.contact>a::before {
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

/* ########## hover active ########## */

.button-common>a:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #000018;
}

.button-common>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 #ba831f;
}

.button-common.log-in>a:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #ba831f;
  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: 45px 60px;
  right: 0;
  left: 0;
  max-width: 560px;
  margin-inline: auto;
}

.fix-cta.is-show {
  opacity: 1;
  height: 220px;
}

.side {
  width: calc((100% - 560px) / 2);
  display: flex;
  justify-content: center;
  align-items: center;
}

.contents-center {
  width: 560px;
}

.photo-position-left {
  position: absolute;
  z-index: 1;
  top: clamp(-154px, calc(100vw / 560 * -154), -77px);
  left: 0;
  width: clamp(87px, calc(100vw /560 * 174), 174px);
  height: auto;
}

.photo-position-right {
  position: absolute;
  z-index: 1;
  top: clamp(-154px, calc(100vw / 560 * -154), -77px);
  right: 0;
  width: clamp(87px, calc(100vw /560 * 174), 174px);
  height: auto;
}

.photo-position-right.catanddog {
  top: clamp(-181px, calc(100vw / 560 * -181), -88px);
}

.photo-position-center {
  position: absolute;
  z-index: 1;
  right: 0;
  left: 0;
  margin: auto;
  width: clamp(200px, calc(100vw /560 * 400), 400px);
  height: auto;
  top: clamp(-194px, calc(100vw / 560 * -194), -117px);
}

.top-separate {
  margin-bottom: -5px;
}

.bottom-separate {
  margin-top: -5px;
}

/* ########## ヘッダー1 ########## */

.header__left {
  padding: 0px 15px 0px;
}

.header__product {
  padding: 15px;
  width: 100%;
  text-align: center;
}

.header__product img {
  width: 294px;
  filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, .1));
}

.header__logo a {
  width: 245px;
  width: 100%;
}

.header-nav-pc {
  margin-top: 30px;
  margin-left: 15px;
}

.header-nav-pc a::before {
  content: "";
  display: inline-block;
  border-top: 7px solid transparent;
  border-bottom: 7px solid transparent;
  border-left: 8px solid #002f63;
  position: absolute;
  left: -15px;
  top: 6px;
}

.header-nav-pc li a {
  display: inline;
  color: #112369;
  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(#112369, #112369);
  background-repeat: no-repeat;
  background-position: bottom right;
  background-size: 0 2px;
  transition: background-size 0.3s;
}

.header-nav-pc li:not(:last-child) {
  margin-bottom: 15px;
  line-height: 1.5;
}

/* hover */
.header-nav-pc li a:hover {
  background-position: bottom left;
  background-size: 100% 2px;
}

/* 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: 980px) {
  .container {
    display: none;
  }
}

.band-header {
  position: relative;
  top: 0;
  left: 0;
  z-index: 3;
  height: clamp(25px, calc(100vw /560 * 50), 50px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.header-logo {
  width: clamp(70px, calc(100vw /560 * 135), 135px);
  margin-top: -3px;
}

.header-logo a:hover {
  opacity: .8;
}

.header-logo a:active {
  opacity: .7;
}

/* ########## メイン ########## */

.main__title>img {
  object-position: center top;
  object-fit: cover;
  font-family: "object-fit: cover";
  width: clamp(300px, calc(100vw / 560 * 447), 447px);
  margin-inline: auto;
  display: block;
}

.main__title {
  z-index: 5;
  position: absolute;
  top: -5%;
  left: 0;
  right: 0;
  margin-inline: 35px;
}

.fv--back {
  margin-top: -2px;
  position: relative;
  z-index: 3;
}

.fv__product {
  z-index: 5;
  position: absolute;
  bottom: -7%;
  right: 0;
  width: clamp(100px, calc(100vw / 560 * 237), 237px);
}

/* ########## ディアクレイとは ########## */
.text-deer-clay {
  font-size: clamp(14px, calc(100vw / 380 * 18), 18px);
}

.text-deer-clay2 {
  font-size: clamp(12px, calc(100vw / 380 * 16), 16px);
}

/* ########## なんでクレイ（粘土）がいいの？ ########## */

/* ########## 3つのポイント ########## */

.point-number {
  width: clamp(60px, calc(100vw / 560 * 95), 95px);
  height: clamp(60px, calc(100vw / 560 * 95), 95px);
  border-radius: clamp(60px, calc(100vw / 560 * 95), 95px);
  background-color: #112369;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}

.title-point {
  color: #FFF;
  font-size: clamp(10px, calc(100vw / 560 * 16), 16px);
  line-height: 1.25;
}

.title-point-number {
  color: #FFF;
  font-family: "courgette";
  line-height: 1;
  font-size: clamp(32px, calc(100vw / 560 * 58), 58px);
  letter-spacing: -1px;
}

.h3-point {
  padding-left: clamp(7.5px, calc(100vw / 560 * 15), 15px);
  flex: 1;
  line-height: 1.75;
  font-size: clamp(20px, calc(100vw / 560 * 28), 28px);
}

.point-img {
  width: clamp(116px, calc(100vw / 560 * 232), 232px);
  margin-inline: auto;
}

/* ########## 与え方 ########## */

.flex-howto li {
  width: 31%;
}

.h3-box {
  display: flex;
  flex-wrap: wrap;
  border: 1px solid #0066b3;
}

.h3-box-left {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: clamp(18px, calc(100vw / 560 * 21), 21px);
  width: 45%;
  padding: 15px 10px;
  color: #FFF;
  background-color: #e8b909 !important;
}

.h3-box-right {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.5;
  width: 55%;
  padding: 15px 10px;
  font-size: clamp(18px, calc(100vw / 560 * 21), 21px);
  color: #112369 !important;
  background-color: #ffffff !important;
}

.h3-box-left.type2 {
  padding: 5px 15px;
}

.h3-box-right.type2 {
  padding: 5px 10px;
}

.illust-feed {
  width: clamp(100px, calc(100vw / 560 * 199), 199px);
  margin-inline: auto;
}

/* ########## 秘密 ########## */

.shot-story-photo {
  width: clamp(112.5px, calc(100vw / 560 * 225), 225px);
  max-width: 100%;
  margin-top: 15px;
  margin-inline: auto;
}

/* ########## 製品概要 ########## */

.price {
  font-size: 54px;
  font-weight: 700;
  color: #ffffff;
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  margin-top: -15px;
  margin-bottom: -15px;
  letter-spacing: -1.5px;
}

.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;
}

/* ########## よくあるご質問 ##########  */

.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;
  font-size: 18px;
  padding: 10px 55px 10px clamp(55px, calc(100vw / 560 * 75), 75px);
  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: #112369;
  transition: all .15s ease 0s;
  -webkit-box-shadow: 0 7px 0 #000018;
  box-shadow: 0 7px 0 #000018;
}

.faqtable th:hover {
  transform: translate(0, 3px);
  box-shadow: 0 4px 0 #000018;
}

.faqtable th:active {
  transform: translate(0, 7px);
  box-shadow: 0 0px 0 #000018;
  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: 2px;
  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(35px, calc(100vw / 560 * 46), 46px);
  height: clamp(35px, calc(100vw / 560 * 46), 46px);
  background: url(../image/icon-q.svg) no-repeat center/contain;
  pointer-events: none;
}

.faqtable .abox-contents2 {
  position: relative;
  color: #112369;
  padding: 15px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.9;
}

/* ########## アニマートとは？ ########### */

.animato_logo img {
  width: clamp(88px, calc(100vw /560 * 136), 136px);
}

/* ########## フッター ########### */

.footer__title {
  font-size: clamp(12px, calc(100vw /560 * 20), 20px);
  line-height: 1.5;
}

.footer__logo {
  width: clamp(70px, calc(100vw /460 * 106), 106px);
  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 * 13), 13px);
  font-weight: 300;
  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: 300;
  color: #ffffff;
  text-align: center;
}

@media (max-width: 479px) {
  .pc {
    display: none;
  }

  .sf {
    display: block !important;
  }

  .contents45 {
    padding: 60px 45px;
  }

  .fix-cta {
    padding: 45px 45px;
  }

  /* ########## アニマートとは？ ########### */

  .animato_logo {
    width: clamp(260px, calc(100vw /560 * 320), 320px);
    margin: auto;
  }

  /* ########## 与え方 ########### */
  .h3-box-left {
    width: 100%;
    padding: 10px 10px;
  }

  .h3-box-right {
    width: 100%;
    padding: 10px 10px;
  }
}