/* ＝＝＝＝＝＝＝＝＝＝ */
/*　　　 全体設定 　　　*/
/* ＝＝＝＝＝＝＝＝＝＝ */
html {
  scroll-behavior: smooth;
}

:root {
  --main-width: 100vw;
  --device-width: 750;
  margin-top: 0 !important;
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

body {
  position: relative;
  background-color: #FFF;
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-family: "Zen Maru Gothic", sans-serif;
}

a {
  text-decoration: none;
}

a:hover {
  opacity: 0.5;
  transition: 0.4s;
}

.js-fade {
  opacity: 0;
  visibility: hidden;
  transform: translateY(100px);
  transition: opacity 1s, visibility 1s, transform 1s;
}

.inview {
  opacity: 1;
  visibility: visible;
  transform: translateY(0px);
}

.spbr {
  display: block;
}

.pcbr {
  display: none;
}

.contents {
  position: relative;
  box-sizing: border-box;
}

header {
    font-family: "Noto Sans JP", sans-serif;
}

footer {
    font-family: "Noto Sans JP", sans-serif;
    z-index: 100;
}

@media screen and (min-width: 641px) {
    .menu__second-level li a {
        font-weight: 400 !important;
    }
}

@media screen and (min-width:750px) {
  :root {
    --main-width: 100vw;
    --device-width: 1280;
  }

  .spbr {
    display: none;
  }

  .pcbr {
    display: block;
  }
}

/* header */
header {
  position: relative;
  z-index: 1000;
}



@media screen and (min-width:750px) {}

/* main */
main {
  margin-top: calc(-155 / var(--device-width) * var(--main-width));
  overflow: hidden;
}

/* content01 */
#content01 {
  padding-top: 27%;
}

#content01>div {
  position: absolute;
}

#content01 .item01 {
  top: 11.2%;
  left: 0;
  right: 0;
  margin: auto;
  width: 73.2%;
  opacity: 0;
}

#content01 .item01.poyoyon2 {
  animation: poyoyon2 1s ease-in-out forwards;
  opacity: 1;
}

#content01 .item02 {
  top: 14.5%;
  left: -3%;
  right: 0;
  margin: auto;
  width: 60%;
  opacity: 0;
}

#content01 .item02.poyoyon2 {
  animation: poyoyon2 1s ease-in-out forwards;
  opacity: 1;
}

@keyframes poyoyon2 {
  0% {
    transform: scale(1.0, 1.0) translate(0, 0);
  }

  15% {
    transform: scale(0.98, 0.9) translate(0, 5px);
  }

  30% {
    transform: scale(1.02, 1.0) translate(0, 8px);
  }

  50% {
    transform: scale(0.98, 1.05) translate(0, -8px);
  }

  70% {
    transform: scale(1.0, 0.9) translate(0, 5px);
  }

  100% {
    transform: scale(1.0, 1.0) translate(0, 0);
  }

  0%, 100% {
    opacity: 1;
  }
}

#content01 .item03 {
  top: 21.4%;
  left: -33%;
  right: 0;
  margin: auto;
  width: 41.1%;
  z-index: 20;
  opacity: 0;
}

#content01 .item03.slideIn2 {
  animation: slideIn2 2s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  opacity: 1;
}

#content01 .item03_wrap {
  position: relative;
  transform: rotate(-10deg);
}

#content01 .item03_wrap::after {
  content: "";
  position: absolute;
  top: 2%;
  left: 95%;
  width: 99.4%;
  height: 40vw;
  background-image: url(../images/hukidasi01_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: rotate(9deg);
  z-index: 100;
}

#content01 .item04 {
  top: 28.6%;
  left: 0%;
  right: -38%;
  margin: auto;
  width: 54.8%;
  z-index: 10;
  opacity: 0;
}

#content01 .item04.slideIn1 {
  animation: slideIn1 2s cubic-bezier(0.25, 1, 0.5, 1) forwards;
  opacity: 1;
}

#content01 .item04_wrap {
  position: relative;
  transform: rotate(23deg);
}

#content01 .item04_wrap::after {
  content: "";
  position: absolute;
  bottom: -35.3%;
  right: 50%;
  width: 74.4%;
  height: 40vw;
  background-image: url(../images/hukidasi02_sp.png);
  background-repeat: no-repeat;
  background-size: contain;
  transform: rotate(-24deg);
  z-index: 100;
}

#content01 .item09 {
  top: 57.5%;
  left: 0;
  right: 0;
  margin: auto;
  font-family: "Zen Maru Gothic", sans-serif;
}

#content01 .item09>p:first-of-type {
  color: #5A3214;
  font-size: calc(40 / var(--device-width) * var(--main-width));
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.4em;
}

#content01 .item09_inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: calc(612 / var(--device-width) * var(--main-width));
  margin: 0 auto 2.6%;
}

#content01 .item09_inner div p {
  color: #5A3214;
  font-size: calc(30 / var(--device-width) * var(--main-width));
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.5em;
}

#content01 .item09_inner .apple img {
  display: block;
  width: calc(254 / var(--device-width) * var(--main-width));
  margin: auto;
}

#content01 .item09_inner .google img {
  display: block;
  width: calc(315 / var(--device-width) * var(--main-width));
  margin: auto;
}

#content01 .item09 .attention {
  color: #5A3214;
  font-size: calc(16 / var(--device-width) * var(--main-width));
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  width: 80%;
  margin: auto;
}


#content01 .item11 {
  position: absolute;
  top: 75.9%;
  right: 0;
  left: 0;
  margin: auto;
  width: 92%;
  z-index: 10;
}

#content01 .item11.active {
  animation: poyopoyo 2s ease-out;
}

#content01 .text {
  position: absolute;
  bottom: 2%;
  left: 0;
  right: 0;
  width: 85%;
  margin: auto;
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(16 / var(--device-width) * var(--main-width));
}

#content01>.coution {
  position: absolute;
  top: 53%;
  left: 64%;
  color: #5A3214;
  font-size: calc(16 / var(--device-width) * var(--main-width));
}

@keyframes slideIn1 {
  0% {
    transform: translateX(180px);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
  }

  40%, 100% {
    opacity: 1;
  }
}

@keyframes slideIn2 {
  0% {
    transform: translateX(-180px);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
  }

  40%, 100% {
    opacity: 1;
  }
}

@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }

  50%, 70% {
    transform: scale(0.95);
  }
}


@media screen and (min-width:750px) {
  #content01 {
    z-index: 10;
    padding-top: 12%;
  }

  #content01 .item01 {
    top: 18%;
    left: 42%;
    right: 0;
    margin: auto;
    width: 38.8%;

  }

  #content01 .item02 {
    top: 23%;
    left: 40%;
    right: 0;
    margin: auto;
    width: 31.7%;

  }

  #content01 .item03 {
    top: 23%;
    left: -61.1%;
    right: 0px;
    margin: auto;
    width: 16%;
    z-index: 20;
  }

  #content01 .item03_wrap::after {
    top: calc(-113 / var(--device-width) * var(--main-width));
    left: calc(-20 / var(--device-width) * var(--main-width));
    width: calc(193 / var(--device-width) * var(--main-width));
    height: calc(157 / var(--device-width) * var(--main-width));
    bottom: initial;
    background-image: url(../images/hukidasi01_pc.png);
    transform: rotate(10deg);
  }


  #content01 .item04 {
    top: 21.9%;
    left: 6px;
    right: 32%;
    margin: auto;
    width: 22.6%;
    z-index: 10;
  }

  #content01 .item04_wrap::after {
    top: calc(-94 / var(--device-width) * var(--main-width));
    left: calc(35 / var(--device-width) * var(--main-width));
    width: calc(191 / var(--device-width) * var(--main-width));
    height: calc(156 / var(--device-width) * var(--main-width));
    background-image: url(../images/hukidasi02_pc.png);
    transform: rotate(-23deg);
  }


  #content01 .item11 {
    top: 61.8%;
    width: 47%;
  }

  #content01 .text {
    bottom: 1.6%;
    width: 73%;
  }

  #content01 .item09 {
    top: 42.2%;
    left: 39%;
  }

  #content01 .item09>p:first-of-type {
    font-size: calc(26 / var(--device-width) * var(--main-width));
    margin-bottom: 0.4em;
  }

  #content01 .item09_inner {
    width: calc(519 / var(--device-width) * var(--main-width));
    margin: 0 auto 1.9%;
  }

  #content01 .item09_inner div p {
    font-size: calc(22 / var(--device-width) * var(--main-width));
    margin-bottom: 0.5em;
  }

  #content01 .item09_inner .apple img {
    width: calc(218 / var(--device-width) * var(--main-width));
  }

  #content01 .item09_inner .google img {
    width: calc(270 / var(--device-width) * var(--main-width));
  }

  #content01 .item09 .attention {
    font-size: calc(14 / var(--device-width) * var(--main-width));
    width: 64%;
  }

  #content01>.coution {
    position: absolute;
    top: 55%;
    left: 25%;
    color: #5A3214;
    font-size: calc(16 / var(--device-width) * var(--main-width));
  }

}

/* content02 */
#content02 {
  box-sizing: border-box;
}

#content02>div {
  position: absolute;
}

#content02 .item12 {
  position: absolute;
  top: 2.6%;
  right: 0;
  left: 0;
  margin: auto;
  width: 84%;
  z-index: 20;
}

#content02 .item05 {
  top: 2.9%;
  left: 0;
  right: 0%;
  margin: auto;
  width: 82.6%;
  z-index: 10;
}

#content02 .item_inner {
  position: relative;
}

#content02 .item_inner p {
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(30 / var(--device-width) * var(--main-width));
  font-weight: bold;
  line-height: 1.666;
}

#content02 .item_inner p span {
  position: relative;
  color: #D7588C;
  z-index: 20;
}

#content02 .item07 .item_inner p span {
  position: relative;
  color: #EA5504;
  z-index: 20;
}

#content02 .item_inner p span::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(13 / var(--device-width) * var(--main-width));
  background-color: #FFFB6E;
  z-index: -1;
}

#content02 .item06 {
  top: 8.5%;
  left: -41.4%;
  right: 0;
  margin: auto;
  width: 109%;
}

#content02 .item06 .item_inner p {
  position: absolute;
  top: 23%;
  right: -10%;
  font-family: "Zen Maru Gothic", sans-serif;
  text-align: center;
}

#content02 .item07 {
  top: 31.2%;
  left: 14%;
  right: 0;
  margin: auto;
  width: 98%;
}

#content02 .item07 .item_inner p {
  position: absolute;
  top: 39%;
  left: -7%;
  font-family: "Zen Maru Gothic", sans-serif;
  text-align: center;
}

#content02 .item08 {
  top: 56.6%;
  left: -38.2%;
  right: 0;
  margin: auto;
  width: 115.8%;
}

#content02 .item08 .item_inner p {
  position: absolute;
  top: 40%;
  right: -8%;
  font-family: "Zen Maru Gothic", sans-serif;
  text-align: center;
}

.fadein {
  opacity: 0;
  transform: translate(0, 0);
  transition: all 2s;

  &.fadein-left {
    transform: translate(-30px, 0);
  }

  &.fadein-right {
    transform: translate(30px, 0);
  }

  &.fadein-up {
    transform: translate(0, -30px);
  }

  &.fadein-bottom {
    transform: translate(0, 30px);
  }

  &.scrollin {
    opacity: 1 !important;
    transform: translate(0, 0) !important;
  }
}

@media screen and (min-width:750px) {

  #content02 .item_inner p {
    font-size: calc(26 / var(--device-width) * var(--main-width));
  }

  #content02 .item12 {
    top: 3.6%;
    width: 49%;
  }

  #content02 .item05 {
    top: -0.1%;
    left: 1%;
    right: 0%;
    margin: auto;
    width: 48.6%;
    z-index: 10;
  }

  #content02 .item06 {
    top: 28%;
    left: -57%;
    right: 0px;
    margin: auto;
    width: 30.1%;

  }

  #content02 .item06 .item_inner p {
    top: 13%;
    right: 11%;
  }

  #content02 .item07 {
    top: 22.2%;
    left: -1%;
    right: 0px;
    margin: auto;
    width: 27.3%;
  }

  #content02 .item07 .item_inner p {
    top: 13%;
    left: 9%;
  }

  #content02 .item08 {
    top: 28%;
    left: 58%;
    right: 0px;
    margin: auto;
    width: 28%;

  }

  #content02 .item08 .item_inner p {
    top: 13%;
    right: 9%;
  }
}

/* content03 */
#content03 {
  z-index: 30;
}

#content03 .ttl {
  position: absolute;
  top: 0.1%;
  left: 0;
  right: 0;
  margin: auto;
  width: 50%;
}

#content03 .spec p {
  position: absolute;
  left: 25%;
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(39 / var(--device-width) * var(--main-width));
  font-weight: bold;
  line-height: 1.41;
}

#content03 .spec p::after {
  position: absolute;
  top: 0;
  left: calc(-120 / var(--device-width) * var(--main-width));
  bottom: 0;
  margin: auto;
  content: "";
  width: calc(110 / var(--device-width) * var(--main-width));
  height: calc(110 / var(--device-width) * var(--main-width));
  background-repeat: no-repeat;
  background-size: contain;
}

#content03 .spec p span {
  color: #EC6D74;
  font-size: calc(44 / var(--device-width) * var(--main-width));
}

#content03 .spec p:first-of-type {
  top: 4.5%;
}

#content03 .spec p:first-of-type::after {
  background-image: url("../images/icon_spec01_sp.png");
}

#content03 .spec p:nth-of-type(2) {
  top: 18.4%;
}

#content03 .spec p:nth-of-type(2)::after {
  background-image: url("../images/icon_spec02_sp.png");
}

#content03 .spec p:nth-of-type(3) {
  top: 32.3%;
}

#content03 .spec p:nth-of-type(3)::after {
  background-image: url("../images/icon_spec03_sp.png");
}

#content03 .spec p:nth-of-type(4) {
  top: 46.8%;
}

#content03 .spec p:nth-of-type(4)::after {
  background-image: url("../images/icon_spec04_sp.png");
}

#content03 .function {
  position: absolute;
  top: 60.2%;
  left: 0;
  right: 0;
  margin: auto;
}

#content03 .function>p {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  text-align: center;
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(32 / var(--device-width) * var(--main-width));
  font-weight: 500;
}

#content03 .function ul {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: center;
  gap: calc(25 / var(--device-width) * var(--main-width));
  position: absolute;
  top: calc(120 / var(--device-width) * var(--main-width));
  width: 100%;
}

#content03 .function ul li {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(26 / var(--device-width) * var(--main-width));
  font-weight: 500;
  letter-spacing: -0.03em;
  text-align: center;
  border-radius: calc(24 / var(--device-width) * var(--main-width));
  filter: drop-shadow(calc(6 / var(--device-width) * var(--main-width)) calc(6 / var(--device-width) * var(--main-width)) calc(5 / var(--device-width) * var(--main-width)) rgba(200, 200, 200, 0.6));
  width: calc(310 / var(--device-width) * var(--main-width));
  height: calc(186 / var(--device-width) * var(--main-width));
}

#content03 .function ul li span {
  color: #EC6D74;
  font-size: calc(30 / var(--device-width) * var(--main-width));
}

#content03 .function ul li span.small {
  color: #5A3214;
  font-size: calc(25 / var(--device-width) * var(--main-width));
  vertical-align: super;
}

#content03 .function .note {
  position: absolute;
  top: initial;
  bottom: calc(-555 / var(--device-width) * var(--main-width));
  left: initial;
  right: calc(50 / var(--device-width) * var(--main-width));
  color: #5A3214;
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(16 / var(--device-width) * var(--main-width));
  margin: 0;
}

@media screen and (min-width:750px) {
  #content03 .ttl {
    top: 5.4%;
    left: 0;
    width: 47%;
  }

  #content03 .spec {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: calc(466 / var(--device-width) * var(--main-width)) 0;
    align-items: center;
    position: absolute;
    top: 10.3%;
    left: calc(210 / var(--device-width) * var(--main-width));
    right: 0;
    width: calc(990 / var(--device-width) * var(--main-width));
    margin: auto;
  }

  #content03 .spec p {
    position: relative;
    left: initial;
    font-size: calc(24 / var(--device-width) * var(--main-width));
    font-weight: bold;
    line-height: 1.41;
    width: 45%;
  }

  #content03 .spec p::after {
    width: calc(78 / var(--device-width) * var(--main-width));
    height: calc(78 / var(--device-width) * var(--main-width));
    left: calc(-100 / var(--device-width) * var(--main-width));

  }


  #content03 .spec p span {
    font-size: calc(29 / var(--device-width) * var(--main-width));
  }

  #content03 .function {
    top: 47%;
  }

  #content03 .function>p {
    font-size: calc(24 / var(--device-width) * var(--main-width));
    letter-spacing: -0.02em;
  }

  #content03 .function ul {
    top: calc(69 / var(--device-width) * var(--main-width));
  }

  #content03 .function ul li {
    font-size: calc(20 / var(--device-width) * var(--main-width));
    text-align: center;
    line-height: 1.42;
    width: calc(262 / var(--device-width) * var(--main-width));
    height: calc(157 / var(--device-width) * var(--main-width));
  }

  #content03 .function ul li span {
    font-size: calc(23 / var(--device-width) * var(--main-width));
  }

  #content03 .function ul li span.small {
    font-size: calc(15 / var(--device-width) * var(--main-width));
  }

  #content03 .function .note {
    bottom: calc(-256 / var(--device-width) * var(--main-width));
    left: initial;
    right: calc(90 / var(--device-width) * var(--main-width));
    font-size: calc(16 / var(--device-width) * var(--main-width));
  }
}

/* content03 .login */
#content03 .login {
  font-family: "Noto Sans JP", sans-serif;
}

#content03 .login .item13 {
  position: absolute;
  top: 74.6%;
  right: 0;
  left: 0;
  margin: auto;
  width: 92%;
  z-index: 10;
}

#content03 .login .item13.active {
  animation: poyopoyo 2s ease-out;
}

#content03 .login .text {
  position: absolute;
  top: 82.6%;
  left: 0;
  right: 0;
  width: 85%;
  margin: auto;
  color: #5A3214;
  font-size: calc(16 / var(--device-width) * var(--main-width));
}

#content03 .login .coution01 {
  position: absolute;
  top: 85.4%;
  left: 0;
  right: 0;
  width: 100%;
  margin: auto;
  color: #5A3214;
  font-weight: bold;
  font-size: calc(41 / var(--device-width) * var(--main-width));
  line-height: 2;
  text-align: center;
}

#content03 .login .coution01 .underline {
  position: relative;
  z-index: 20;
}

#content03 .login .coution01 .underline::after {
  content: "";
  z-index: -1;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: calc(13 / var(--device-width) * var(--main-width));
  background-color: #FFFB6E;
}

#content03 .login .coution01 .efriends {
  display: inline-block;
  width: calc(178 / var(--device-width) * var(--main-width));
  vertical-align: text-bottom;
}

#content03 .login .coution02 {
  position: absolute;
  top: 90.2%;
  left: 0;
  right: 0;
  width: 85%;
  margin: auto;
  color: #5A3214;
  font-weight: 500;
  font-size: calc(30 / var(--device-width) * var(--main-width));
  line-height: 1.75;
  text-align: center;
}

#content03 .login .flex {
  position: absolute;
  justify-content: flex-start;
  align-items: center;
  top: 92.7%;
  left: 0;
  right: 0;
  display: flex;
  color: #5A3214;
  font-size: calc(25 / var(--device-width) * var(--main-width));
  width: calc(641 / var(--device-width) * var(--main-width));
  border-radius: calc(20 / var(--device-width) * var(--main-width));
  border: solid 2px #D85728;
  margin: auto;
  padding: 2.9% 0;
}

#content03 .login .flex .need {
  position: relative;
  color: #D85728;
  width: 29%;
  text-align: center;
}

#content03 .login .flex .need::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: 4%;
  width: 2px;
  height: calc(78 / var(--device-width) * var(--main-width));
  background-color: #D85728;
}

#content03 .login .flex .list span {
  letter-spacing: -0.08em;
}

#content03 .login ul {
  position: absolute;
  display: flex;
  flex-direction: column;
  gap: 2em;
  align-items: center;
  justify-content: center;
  top: 96%;
  margin: auto;
  width: 100%;
}

#content03 .login ul a {
  position: relative;
  font-size: calc(30 / var(--device-width) * var(--main-width));
  font-weight: 500;
  color: #2B66CF;
  text-decoration: underline;
  text-align: center;
  padding-right: 1.5em;
}

#content03 .login ul a::after {
  position: absolute;
  content: "＞";
  top: 0;
  right: 0.5em;
}

@media screen and (min-width:750px) {
  #content03 .login {
    padding-bottom: 0;
  }


  #content03 .login .item13 {
    top: 58.9%;
    width: 47%;
  }

  #content03 .login .text {
    top: 72.3%;
    width: 73%;
  }

  #content03 .login .coution01 {
    top: 77.9%;
    font-size: calc(41 / var(--device-width) * var(--main-width));
    line-height: 1.6;
  }

  #content03 .login .content_inner {
    position: absolute;
    top: 83.7%;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    width: 75.6%;
    margin: auto;
  }

  #content03 .login .coution02 {
    position: initial;
    font-size: calc(23 / var(--device-width) * var(--main-width));
    font-weight: 500;
    letter-spacing: -0.05em;
    width: 50%;
    text-align: left;
  }


  #content03 .login .flex {
    position: initial;
    justify-content: space-around;
    font-size: calc(20 / var(--device-width) * var(--main-width));
    font-weight: 400;
    width: calc(567 / var(--device-width) * var(--main-width));
    padding: 2.2% 1%;

  }

  #content03 .login .flex .need {
    width: 25%;
  }

  #content03 .login .flex .need::after {
    right: -4%;
    height: calc(62 / var(--device-width) * var(--main-width));
  }

  #content03 .login ul {
    flex-direction: row;
    top: 88.7%;
  }

  #content03 .login ul a {
    font-size: calc(22 / var(--device-width) * var(--main-width));
  }

}

/* #content04 */
#content04 {
  z-index: 20;
}

#content04 .inner {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  padding: 27% 0;
}

#content04 .ttl {
  position: relative;
  background-color: #D7588C;
  border-radius: calc(30 / var(--device-width) * var(--main-width));
  color: #fff;
  font-size: calc(45 / var(--device-width) * var(--main-width));
  font-weight: bold;
  text-align: center;
  width: 86%;
  margin: 0 auto 1.4em;
  padding: 1.6% 0;
}

#content04 .ttl::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  border-style: solid;
  border-width: calc(20 / var(--device-width) * var(--main-width)) calc(10 / var(--device-width) * var(--main-width)) 0 calc(10 / var(--device-width) * var(--main-width));
  border-color: #D7588C transparent transparent;
  translate: -50% 100%;
}

#content04 .ttl span {
  letter-spacing: -0.1em;
}

#content04 .list {
  font-family: "Noto Sans JP", sans-serif;
  font-size: calc(36 / var(--device-width) * var(--main-width));
  padding-left: calc(130 / var(--device-width) * var(--main-width));
  padding-right: calc(50 / var(--device-width) * var(--main-width));
  margin-bottom: 5%;
}

#content04 .list p {
  position: relative;
}

#content04 .list p::before {
  position: absolute;
  top: 0;
  left: calc(-80 / var(--device-width) * var(--main-width));
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  width: calc(69 / var(--device-width) * var(--main-width));
  height: calc(69 / var(--device-width) * var(--main-width));
}

#content04 .list p:first-of-type {
  margin-bottom: 1em;
}

#content04 .list p:first-of-type::before {
  background-image: url(../images/icon_faq01.png);
}

#content04 .list p:last-of-type {
  font-size: calc(27 / var(--device-width) * var(--main-width));
}

#content04 .list p:last-of-type::before {
  background-image: url(../images/icon_faq02.png);
}

#content04 .app {
  display: flex;
  flex-direction: column;
  gap: calc(30 / var(--device-width) * var(--main-width));
  font-family: "Noto Sans JP", sans-serif;
  width: 79%;
  margin: 0 auto 9%;
}

#content04 .app>div {
  display: flex;
  width: 100%;
}

#content04 .app>div img {
  display: block;
  width: calc(178 / var(--device-width) * var(--main-width));
}

#content04 .app>div.calculator img {
  padding-left: 7%;
  box-sizing: border-box;
}

#content04 .app>div p:first-of-type {
  display: inline-block;
  position: relative;
  font-size: calc(33 / var(--device-width) * var(--main-width));
  font-weight: 500;
  padding-top: 0.3em;
}

#content04 .app>div p:first-of-type::after {
  display: block;
  content: ">";
  color: #D7588C;
  position: absolute;
  top: 0.3em;
  bottom: 0;
  right: -1em;
  margin: auto;
}


#content04 .app>div p:last-of-type {
  font-size: calc(27 / var(--device-width) * var(--main-width));
  font-weight: 500;
}

#content04 .btn a {
  position: relative;
  display: block;
  font-size: calc(35 / var(--device-width) * var(--main-width));
  font-weight: 500;
  text-align: center;
  background-color: #fff;
  color: #D7588C;
  border-radius: calc(100 / var(--device-width) * var(--main-width));
  border: solid 2px #D7588C;
  width: 86%;
  padding: 2% 0 2% 9%;
  margin: AUTO;
  box-sizing: border-box;
}

#content04 .btn a::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 14%;
  background-image: url(../images/icon_faq03.png);
  background-repeat: no-repeat;
  background-size: contain;
  width: calc(44 / var(--device-width) * var(--main-width));
  height: calc(44 / var(--device-width) * var(--main-width));
  margin: auto;
}

@media screen and (min-width:750px) {
  #content04 .inner {
    padding: 0;
  }

  #content04 .ttl {
    font-size: calc(36 / var(--device-width) * var(--main-width));
    width: 44%;
    margin: 0 auto 1.4em;
    padding: 1% 0;
  }

  #content04 .ttl span {
    letter-spacing: -0.1em;
  }

  #content04 .list {
    font-size: calc(31 / var(--device-width) * var(--main-width));
    padding-left: calc(130 / var(--device-width) * var(--main-width));
    padding-right: calc(50 / var(--device-width) * var(--main-width));
    width: 80%;
    margin: 0 auto 2%;
  }

  #content04 .list p::before {
    width: calc(59 / var(--device-width) * var(--main-width));
    height: calc(59 / var(--device-width) * var(--main-width));
  }

  #content04 .list p:last-of-type {
    font-size: calc(23 / var(--device-width) * var(--main-width));
  }

  #content04 .app {
    display: flex;
    flex-direction: row;
    gap: calc(0 / var(--device-width) * var(--main-width));
    font-family: "Noto Sans JP", sans-serif;
    width: 73%;
    margin: 0 auto 5% 18.6%;
  }

  #content04 .app>div img {
    display: block;
    width: calc(133 / var(--device-width) * var(--main-width));
  }

  #content04 .app>div p:first-of-type {
    font-size: calc(24 / var(--device-width) * var(--main-width));
    padding-top: 0.3em;
  }

  #content04 .app>div p:last-of-type {
    font-size: calc(20 / var(--device-width) * var(--main-width));
  }

  #content04 .btn a {
    font-size: calc(28 / var(--device-width) * var(--main-width));
    width: 44.5%;
    padding: 1.3% 0 1.3% 3%;
  }

  #content04 .btn a::after {
    left: 13%;
    width: calc(41 / var(--device-width) * var(--main-width));
    height: calc(41 / var(--device-width) * var(--main-width));
  }
}

/* #content05 */
#content05 {
  z-index: 10;
}
#content05 .item14 {
  position: absolute;
  top: -0.5%;
  left: 0;
  right: 0;
  margin: auto;
  font-family: "Zen Maru Gothic", sans-serif;
}

#content05 .item14>p:first-of-type {
  color: #5A3214;
  font-size: calc(40 / var(--device-width) * var(--main-width));
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.4em;
}

#content05 .item14_inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  width: calc(612 / var(--device-width) * var(--main-width));
  margin: 0 auto 2.6%;
}

#content05 .item14_inner div p {
  color: #5A3214;
  font-size: calc(30 / var(--device-width) * var(--main-width));
  font-weight: bold;
  text-align: center;
  margin-bottom: 0.5em;
}

#content05 .item14_inner .apple img {
  display: block;
  width: calc(254 / var(--device-width) * var(--main-width));
  margin: auto;
}

#content05 .item14_inner .google img {
  display: block;
  width: calc(315 / var(--device-width) * var(--main-width));
  margin: auto;
}

#content05 .item14 .attention {
  color: #5A3214;
  font-size: calc(16 / var(--device-width) * var(--main-width));
  font-weight: 400;
  font-family: "Noto Sans JP", sans-serif;
  width: 80%;
  margin: auto;
}

@media screen and (min-width:750px) {

  #content05 .item14 {
    top: 34.2%;
    left: 0;
  }

  #content05 .item14>p:first-of-type {
    font-size: calc(26 / var(--device-width) * var(--main-width));
    margin-bottom: 0.4em;
  }

  #content05 .item14_inner {
    width: calc(519 / var(--device-width) * var(--main-width));
    margin: 0 auto 1.9%;
  }

  #content05 .item14_inner div p {
    font-size: calc(22 / var(--device-width) * var(--main-width));
    margin-bottom: 0.5em;
  }

  #content05 .item14_inner .apple img {
    width: calc(218 / var(--device-width) * var(--main-width));
  }

  #content05 .item14_inner .google img {
    width: calc(270 / var(--device-width) * var(--main-width));
  }

  #content05 .item14 .attention {
    font-size: calc(14 / var(--device-width) * var(--main-width));
    width: 39.7%
  }
}