﻿@charset "UTF-8";

/* ########## A-DHA-PT  ########## */
/*
 * "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
 */
/*
/*
/*
 * "Poppins" 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) 2025 A-DHA-PT 
 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: #464646;
  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: #464646;
  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: 2;
  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;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 700;
  text-align: initial;
}

h1 {
  font-size: 36px;
}

h2 {
  font-size: 26px;
}

h3 {
  font-size: 18px;
}

h4 {
  font-size: 16px;
}

h5 {
  font-size: 15px;
}

h6 {
  font-size: 14px;
}

.h2-common {
  position: relative;
  z-index: 2;
  font-size: clamp(16px, calc(100vw /400 * 26), 26px);
  line-height: 1.35;
  font-weight: 700;
  width: fit-content;
  margin-inline: auto;
  text-align: center;
}

.h2-common.h2-common-dss {
  font-size: clamp(16px, calc(100vw /400 * 24), 24px);
}

.h2-en {
  position: absolute;
  z-index: 0;
  color: rgba(255, 255, 255, 0.175);
  font-family: "Poppins";
  font-weight: 700;
  font-size: clamp(32px, calc(100vw / 400 * 72), 72px);
  line-height: 1.25;
  letter-spacing: -1px;
  bottom: -15px;
  left: 0;
  right: 0;
  margin: auto;
  width: fit-content;
  white-space: nowrap;
}

.h2-common.how-to {
  font-size: clamp(16px, calc(100vw /560 * 26), 26px);

}

.h2-en.how-to {
  font-size: clamp(32px, calc(100vw / 560 * 72), 72px);
  line-height: 1.25;
  letter-spacing: -1px;
  bottom: -12px;
}

.h2-a-dha-pt {
  width: clamp(200px, calc(100vw / 400 * 300), 300px);
  bottom: 5px;
}

.sf {
  display: none !important;
}

.white {
  color: #ffffff !important;
}

.black {
  color: #464646 !important;
}

.green {
  color: #4dba86 !important;
}

.blue {
  color: #005cab !important;
}

.blue2 {
  color: #cce0f2 !important;
}

.blue3 {
  color: #4188ce !important;
}

.green-blue {
  color: #27acbf !important;
}

.green-blue2 {
  color: #bbe1e9 !important;
}

.lightblue {
  color: #f4fafb !important;
}

.lightblue2 {
  color: #ccdeec !important;
}

.lightblue3 {
  color: #e3edf5 !important;
}

.lightgreen-blue {
  color: #f4fafb !important;
}

.lightgray {
  color: #eaeaea !important;
}

.yellow {
  color: #ffe100 !important;
}

.back--white {
  background-color: #ffffff !important;
}

.back--black {
  background-color: #464646 !important;
}

.back--blue {
  background-color: #005cab !important;
}

.back--blueimage1 {
  background: url("../image/background-dha.png") no-repeat center / cover;

}

.back--blueimage2 {
  background: url("../image/background-dha2.png") no-repeat center / cover;
  position: relative;
  margin-top: -45px;
}

.back--green-blue {
  background-color: #27acbf !important;
}

.back--lightgreen-blue {
  background-color: #f4fafb !important;
}

.back--lightblue {
  background-color: #f4fafb !important;
}

.back--lightblue2 {
  background-color: #ccdeec !important;
}

.lightgreen-box {
  padding: 30px;
  border-radius: 10px;
  background-color: #f4fafb !important;
}

.lightgreen-box2 {
  padding: 30px;
  border-radius: 10px;
  background-color: #eff9f4 !important;
}

.white-box {
  padding: 30px;
  border-radius: 10px;
  background-color: #ffffff !important;
}

.back--lightgreen {
  background-color: #eff9f4 !important;
}

.back--yellow {
  background-color: #ffe100 !important;
}

.border {
  border: 1px solid #464646;
}

.border-blue {
  border: 1px solid #005cab;
}

.border-bottom1,
.border-bottom-black {
  border-bottom: 1px solid #464646;
}

.border-bottom-white {
  border-bottom: 1px solid #ffffff !important;
}

.border-bottom-blue {
  border-bottom: 1px solid #005cab;
}

@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: "Poppins";
  font-weight: 300;
  font-style: normal;
  src: url("../font/Poppins-Light.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 400;
  src: url("../font/Poppins-Regular.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 500;
  src: url("../font/Poppins-Medium.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 600;
  src: url("../font/Poppins-SemiBold.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 700;
  src: url("../font/Poppins-Bold.woff") format("woff");
  font-display: swap;
}

@font-face {
  font-family: "Poppins";
  font-style: normal;
  font-weight: 800;
  src: url("../font/Poppins-Black.woff") format("woff");
  font-display: swap;
}

.poppins {
  font-family: "Poppins", 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 #464646;
}

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; */
}

video {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  transform: translateZ(0);
  filter: drop-shadow(0px 0px #ffffff);
  /* 黒線がでるの消すコード */
}

.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;
}

.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-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;
}

.contents-560 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 560px;
  box-shadow: 0px 0px 16px rgba(0, 0, 0, .025);
}

.max-240 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 240px;
}

.max-320 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 320px;
}

.max-340 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 320px;
}

.max-380 {
  padding: 0px 0px;
  margin-right: auto;
  margin-left: auto;
  max-width: 380px;
}

.contents45 {
  padding: 85px 45px 75px;
}

.contents45.footer {
  padding: 60px 30px 190px;
}

.contents30 {
  padding: 85px 30px 75px;
}

.contents-main {
  padding: 15px 30px 15px;
}

.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;
}

.big150 {
  font-size: 150%;
  line-height: 1;
  margin-inline: 3px;
}


.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%;
}

/* ########## 共通ボタン ########## */

.button-common {
  position: relative;
  text-align: center;
}

.button-common>a {
  font-size: 19px;
  padding: 6px 30px 6px 15px;
  line-height: 0;
  max-width: 300px;
  width: 100%;
  height: 52px;
  border-radius: 52px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  position: relative;
  gap: 10px;
  color: #005cab;
  background-color: #cddaef;
  transition: all .25s ease 0s;
}

.button-common.cta>a {
  font-size: 26px;
  background-color: #ffe100;
  max-width: 470px;
  height: 70px;
  padding: 6px 0px 6px 35px;
}

.button-common.dha>a {
  background-color: #ffffff;
  max-width: 100%;
  height: auto;
  line-height: 1.5;
  padding: 12px 35px 12px 25px;
  border: 1px solid #ffffff;
}

.button-common.log-in>a {
  font-size: 21px;
  height: auto;
  line-height: 1.35;
  padding: 12px 40px 12px 20px;
  background-color: #ffe100;
  max-width: 380px;
}

.button-common.contact>a {
  font-size: 21px;
  color: white;
  background-color: #005cab;
  max-width: 380px;
}

.button-common.contact>a::after {
  width: 32px;
  height: 32px;
  background: #ffffff;
}

.button-common.contact>a::before {
  border-right: 2px solid #005cab;
  border-top: 2px solid #005cab;
}

.sale {
  padding-top: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  top: -50px;
  left: 0px;
  position: absolute;
  width: 105px;
  height: 105px;
  border-radius: 105px;
  text-align: center;
  color: white;
  font-weight: 500;
  font-size: 16px;
  line-height: 1.15;
  letter-spacing: 0.5px;
  background-color: #005cab;
  border: 1px solid #ffffff;
}

/* 白い線（下地） */
.sale::before {
  content: "";
  position: absolute;
  bottom: 17px;
  left: 90%;
  border-style: solid;
  border-width: 11px 8px 0 8px;
  border-color: #fff transparent transparent;
  transform: translate(-75%, 100%) rotate(-165deg);
  z-index: 0;
}

/* 本体 */
.sale::after {
  content: "";
  position: absolute;
  bottom: 18px;
  left: 89%;
  border-style: solid;
  border-width: 10px 7px 0 7px;
  border-color: #005cab transparent transparent;
  transform: translate(-75%, 100%) rotate(-165deg);
  z-index: 1;
}

.sale-price {
  font-size: 32px;
  font-weight: 600;
}

.cta-dog {
  margin-inline: auto;
  padding-left: 45px;
  width: clamp(120px, calc(100vw /420 * 210), 210px);
  margin-bottom: -2px;
}


.button-common>a::after {
  content: "";
  width: 32px;
  height: 32px;
  background: #005cab;
  border-radius: 50%;
  position: absolute;
  right: 10px;
  display: inline-block;
  transition: all .25s ease 0s;
}

.button-common>a::before {
  content: "";
  position: absolute;
  /* right: 24px; */
  right: 23px;
  width: 8px;
  height: 8px;
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
  transform: translateY(-50%) rotate(45deg);
  /* top: 51.5%; */
  top: 50%;
  z-index: 2;
  transition: all .25s ease 0s;
}

.button-common.white-btn>a {
  color: #005cab;
  background-color: #ffffff;
  border: #ffffff 2px solid;
}

.button-common.white-btn>a::after {
  background: #005cab;
}

.button-common.white-btn>a::before {
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

.sale {
  border-right: 2px solid #ffffff;
  border-top: 2px solid #ffffff;
}

/* ########## hover ########## */

.button-common>a:active {
  transform: scale(0.99);
  /* 少し縮む */
  /* 濃い色で押した感 */
  background-color: rgb(205, 105, 5);
  box-shadow: 0 2px 6px rgb(210, 105, 0) inset;
  /* 内側影 */
  outline: 2px solid #fb850f;
}

.button-common>a:hover {
  color: #ffffff;
  background-color: #fb850f;
  filter: drop-shadow(2px 2px 1.5px rgba(0, 0, 0, 0.25));
}

.button-common>a:hover::after {
  background: #ffffff;
}

.button-common>a:hover::before {
  border-right: 2px solid #fb850f;
  border-top: 2px solid #fb850f;
}

.container {
  display: flex;
  height: 100vh;
  height: 100dvh;
}

.button-common.cta .sale:hover {
  transform: translateY(-15%);
  transition: all .25s ease 0s;
}

.button-common.cta:hover .sale {
  transform: translateY(-15%);
  transition: all .25s ease 0s;
}

@media (max-width: 980px) {
  .container {
    display: none;
  }
}

.side {
  width: calc((100% - 560px) / 2);
  display: flex;
  justify-content: center;
  align-items: center;
}

.contents-center {
  width: 560px;
}

.header__left {
  padding: 30px;
}

.header__product {
  padding: 30px;
  width: 100%;
  text-align: center;
}

.header__product img {
  width: 275px;
  filter: drop-shadow(0px 0px 4px rgba(0, 0, 0, .1));
}

.header__logo a {
  width: 245px;
  width: 100%;
}

.header-nav-pc {
  margin-top: 30px;
}

.header-nav-pc li a {
  color: #005cab;
  padding: 0 3px 2px;
  font-weight: bold;
  position: relative;
  background-color: #fff;
  overflow: hidden;
  z-index: 0;
  transition: color 0.3s, transform 0.1s, box-shadow 0.1s;
}

.header-nav-pc li a::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 0;
  height: 100%;
  content: "";
  background-color: #005cab;
  transition: width 0.3s;
  z-index: -1;
}

/* hover */
.header-nav-pc li a:hover {
  color: #fff;
}

.header-nav-pc li a:hover::before {
  width: 100%;
}

/* active（クリック中） */
.header-nav-pc li a:active {
  transform: translateY(1px);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.25);
}

.header-nav-pc li a:active::before {
  background-color: #004a8a;
}

#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 ##########  */
.band-header {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
}

.header-logo {
  width: clamp(100px, calc(100vw / 560 * 176), 176px);
  position: absolute;
  top: 25%;
  transform: translateY(-25%);
  right: 0;
  left: 0;
  margin: auto;
  z-index: 99;
}
.header-logo a:hover {
  opacity: .8;
}
.header-logo a:active {
  opacity: .7;
}


.fix-cta {
  height: 0;
  overflow: hidden;
  transition: height 1.0s ease;
  position: fixed;
  z-index: 5;
  bottom: 0px;
  padding: 30px;
  right: 0;
  left: 0;
  margin-bottom: -30px;
  max-width: 560px;
  margin-inline: auto;
}

.fix-cta.is-show {
  height: 220px;
}

/* ########## メイン ########## */
.illust-position-fv {
  position: absolute;
  z-index: 3;
  top: 20px;
  right: 18%;
  width: clamp(100px, calc(100vw / 560 * 164), 164px);
}

.main__title img {
  object-position: center top;
  object-fit: cover;
  font-family: "object-fit: cover";
  width: 100%;
  height: clamp(300px, calc(100vw / 480 * 500), 500px);
  margin-top: clamp(0px, calc(100vw / 480 * 30), 30px);
}

.fv-image {
  margin-top: -40px;
}

/* ########## エーダプトとは ########## */
.back-a-dha-pt {
  position: absolute;
  bottom: -37px;
  z-index: 0;
}

/* ########## DHAとは ########## */
.illust-position-dha-left {
  position: absolute;
  z-index: 3;
  top: -15px;
  left: 35px;
  width: clamp(60px, calc(100vw / 460 * 90), 90px);
}

.illust-position-dha-right {
  position: absolute;
  z-index: 4;
  top: -35px;
  right: 35px;
  width: clamp(100px, calc(100vw / 460 * 184), 184px);
}

/* ########## おすすめポイント ########## */

.illust-position-point-left {
  position: absolute;
  z-index: 4;
  top: 15px;
  left: 10px;
  width: clamp(60px, calc(100vw / 460 * 103), 103px);
}

.illust-position-point-right {
  position: absolute;
  z-index: 4;
  top: -65px;
  right: 30px;
  width: clamp(60px, calc(100vw / 460 * 103), 103px);
}

.back-point {
  position: absolute;
  bottom: -10px;
  z-index: 1;
}

.point-wrapper>li:nth-child(n + 2) {
  margin-top: 35px;
}

.point-wrapper>li {
  position: relative;
  padding: 45px 0;
}

.point-wrapper>li p {
  margin-top: 15px;
  margin-bottom: 15px;
  padding: 0 45px;
  display: flex;
  justify-content: center;
}

.point-wrapper>li h3 {
  padding: 0 45px;
  font-size: 22px;
}

.point-number {
  position: absolute;
  width: 95px;
  height: 95px;
  top: -23.75px;
  left: -23.75px;
}

.point-number-text {
  text-align: center;
  position: absolute;
  z-index: 2;
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  left: 0;
  width: fit-content;
  margin: auto;
}

.title-point {
  color: #FFF;
  font-size: 17px;
  line-height: 1.25;
}

.title-point-number {
  color: #FFF;
  font-family: "Poppins";
  line-height: 1;
  font-size: 58px;
  font-weight: 600;
  letter-spacing: -1px;
}

/* ########## 与え方 ########## */

.illust-position-how-left {
  position: absolute;
  z-index: 4;
  top: -85px;
  left: 17%;
  width: clamp(60px, calc(100vw / 460 * 103), 68px);
}

.flex-howto li {
  width: 31%;
}

.h3-box {
  display: flex;
  border: 1px solid #005cab;
}

.h3-box-left {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 50%;
  padding: 15px;
  color: #FFF;
  background-color: #005cab !important;
}

.h3-box-right {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 1.5;
  width: 50%;
  padding: 15px 10px;
  color: #005cab !important;
  background-color: #ffffff !important;
}

.h3-box-left.type2 {
  padding: 5px 15px;
}

.h3-box-right.type2 {
  padding: 5px 10px;
}

/* ########## DHA小話 ########## */

.illust-position-ss-right {
  position: absolute;
  z-index: 4;
  top: -55px;
  right: 7%;
  width: clamp(90px, calc(100vw / 460 * 122), 122px);
}

.triangle {
  margin-inline: auto;
  margin-block: 20px;
  width: 35px;
  height: 20px;
  background: #ffe100;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}

.shot-story-photo {
  width: 135px;
  max-width: 100%;
}

.shot-story-text {
  flex: 1;
}

.p-l {
  padding-left: 15px;
}

.p-r {
  padding-right: 15px;
}

.h2-en.h2-common-dss {
  bottom: 25px;
}

/* ########## 製品概要 ########## */

.illust-position-product-left {
  position: absolute;
  z-index: 4;
  top: -55px;
  left: 15%;
  width: clamp(90px, calc(100vw / 460 * 122), 122px);
}

.price {
  font-size: 54px;
  font-family: "Poppins";
  font-weight: 700;
  color: #005cab !important;
  display: flex;
  flex-wrap: wrap;
  align-content: center;
  justify-content: center;
  margin-top: -15px;
  margin-bottom: -15px;
  letter-spacing: -1.5px;
}

.zeikomi {
  margin-left: 5px;
  display: block;
  padding-top: 12px;
  font-size: 14px;
  writing-mode: vertical-rl;
  letter-spacing: 0.5px;
}

.product-left {
  flex: 1;
  padding-right: 30px;
}

.product-right {
  width: 110px;
}

/* ########## よくある質問 ##########  */

.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 {
  display: block;
  cursor: pointer;
  position: relative;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 500;
  padding: 18px 55px 18px 75px;
  border-radius: 10px;
  color: rgb(255, 255, 255);
  background-color: #005cab;
  border: #005cab 1px solid;
}

.faqtable th:hover {
  background-color: #005197;
}

.faqtable th:active {
  transform: scale(0.99);
  /* 少し縮む */
  background-color: #005197;
  /* 濃い色で押した感 */
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) inset;
  /* 内側影 */
  outline: 2px solid #005197;
}

.abox-contents {
  display: none;
}

.faqtable td {
  display: block;
  position: relative;
  transition: 0.5s;
}

.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: 15px;
  top: 50%;
  transform: translateY(-50%);
  width: 46px;
  height: 46px;
  background: url(../image/icon-q.svg) no-repeat center/contain;
  pointer-events: none;
}

.faqtable .abox-contents2 {
  position: relative;
  padding: 15px;
  font-size: 16px;
  font-weight: 500;
  line-height: 2;
}

/* ########## アニマートとは？ ########### */

.illust-position-animato-left {
  position: absolute;
  z-index: 4;
  top: -65px;
  left: 7%;
  width: clamp(60px, calc(100vw / 460 * 82), 82px);
}

.back-abouto-animato {
  position: absolute;
  bottom: 100px;
  z-index: 0;
}

/* ########## フッター ########### */

.footer__title {
  font-size: clamp(12px, calc(100vw /560 * 20), 20px);
  line-height: 1.5;
}

.footer__logo {
  width: 60px;
  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), 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: 12px;
  font-weight: 300;
  color: #ffffff;
  text-align: center;
}

.event-none {
  pointer-events: none;
  margin-bottom: 0.75em;
}

@media (max-width: 479px) {
  .pc {
    display: none;
  }

  .sf {
    display: block !important;
  }

  /* 白い線（下地） */
  .sale::before {
    bottom: 15px;
    left: 90%;
  }

  /* 本体 */
  .sale::after {
    bottom: 16px;
    left: 89%;
  }

  .button-common.cta a {
    height: 55px;
    font-size: clamp(19px, calc(100vw /420 * 24), 24px);
  }

  .contents45 {
    padding: 75px 30px 65px;
  }

  .contents45.footer {
    padding: 45px 15px 160px;
  }

  .contents30 {
    padding: 75px 15px 65px;
  }

  .contents-main {
    padding: 15px 15px 15px;
  }

  .wave-bottom {
    margin-top: -3px;
  }

  .fix-cta {
    margin-bottom: -45px;
  }

  /* ########## おすすめポイント ########## */

  .lightgreen-box {
    padding: 20px;
  }

  .lightgreen-box2 {
    padding: 20px;
  }

  .white-box {
    padding: 20px;
  }

  .point-wrapper>li:nth-child(n + 2) {
    margin-top: 35px;
  }

  .point-wrapper>li {
    position: relative;
    padding: 45px 0 25px;
  }

  .point-wrapper>li p {
    padding: 0 20px;
  }

  .point-wrapper>li h3 {
    padding: 0 45px;
  }

  .point-number {
    position: absolute;
    width: 75px;
    height: 75px;
    top: -23.75px;
    left: -23.75px;
  }

  .title-point {
    font-size: 14px;
    line-height: 1;
  }

  .title-point-number {
    font-size: 40px;
    line-height: 0.9;
    padding-right: 2px;
  }

  .point-number-text {
    margin-top: -5px;
  }

  .point-img {
    width: clamp(135px, calc(100vw /560 * 150), 150px);
    margin-inline: auto;
  }

  .sale {
    padding-top: 7px;
    top: -50px;
    width: 95px;
    height: 95px;
    border-radius: 95px;
    font-size: 14px;
  }

  .sale-price {
    font-size: 26px;
  }

  /* ########## DHA小話 ########## */

  .shot-story-photo {
    width: 100%;
    text-align: center;
    order: 2;
    margin-top: 20px;
  }

  .shot-story-text {
    width: 100%;
    order: 1;
  }

  .p-l {
    padding-left: 0px;
  }

  .p-r {
    padding-right: 0px;
  }

  .h2-en.h2-common-dss {
    bottom: 50px;
  }

  .margin-dss-sf {
    margin-top: 60px;
  }

  /* ########## 製品概要 ########## */

  .product-left {
    width: 100%;
    padding-right: 0px;
  }

  .product-right {
    width: 100%;
    margin-top: 30px;
    text-align: center;
  }

  /* ########## アニマートとは？ ########### */

  .animato_logo {
    width: clamp(260px, calc(100vw /560 * 320), 320px);
    margin: auto;
  }

}