@charset "UTF-8";

/* =========================================================
  Reset
========================================================= */
/*! sanitize.css | CC0 Public Domain | github.com/jonathantneal/sanitize.css */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:baseline;background:transparent;font-weight: normal;list-style-type:none;}
body {line-height:1}
pre,textarea{overflow:auto}
[hidden],audio:not([controls]),template{display:none}
details,main,summary{display:block}
input[type=number]{width:auto}
input[type=search]{-webkit-appearance:textfield}
input[type=search]::-webkit-search-cancel-button,input[type=search]::-webkit-search-decoration{-webkit-appearance:none}
progress{display:inline-block}
small{font-size:75%}
textarea{resize:vertical}
[unselectable]{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}
*,::after,::before{box-sizing:inherit;border-style:solid;border-width:0}
*{font-size:inherit;line-height:inherit;margin:0;padding:0}
::after,::before{text-decoration:inherit;vertical-align:inherit}
a{text-decoration:none}
audio,canvas,iframe,img,svg,video{vertical-align:middle}
button,input,textarea{background-color:transparent;color:inherit;font-family:inherit;font-style:inherit;font-weight:inherit;min-height:1.5em}
code,kbd,pre,samp{font-family:monospace,monospace}
nav ol,nav ul{list-style:none}
table{border-collapse:collapse;border-spacing:0}
::-moz-selection{background-color:#B3D4FC;text-shadow:none}
::selection{background-color:#B3D4FC;text-shadow:none}
@media screen{[hidden~=screen]{display:inherit}
  [hidden~=screen]:not(:active):not(:focus):not(:target){clip:rect(0 0 0 0)!important;position:absolute!important}
}

/* =========================================================
  Common
========================================================= */
* {
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
  height: 100%;
}
body {
  color: #451603;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  max-height: 999999px;
  line-height: 1.6;
  background: #f7f2e1;
}
a {
  color: #451603;
  text-decoration: none;
  transition: all .25s ease-in;
}
a:focus {
  outline: none;
}
a:hover {
  opacity: 0.6;
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}
.spOnly {
  display: none;
}
.fadein {
  opacity: 0;
  transform: translateY(30px);
  transition: all 1s ease-out;
  transition-delay: 0.5s;
}
.valueBlock .stepBlock .box.fadein:nth-of-type(2) {
  transition-delay: 1s;
}
.valueBlock .stepBlock .box.fadein:nth-of-type(3) {
  transition-delay: 1.5s;
}
.fadein.show {
  opacity: 1;
  transform: translateY(0);
}
@media only screen and (max-width:750px) {
  .pcOnly {
    display: none;
  }
  .spOnly {
    display: block;
  }
  img {
    width: 100%;
  }
}
/* =========================================================
  Header
========================================================= */
.innerHead {
  margin-bottom: -32px;
}
.innerHead.serviceHead {
  position: relative;
  z-index: 3;
}
.innerHead .headWrap {
  background: url(../img/head_bg.jpg) no-repeat top center #fff;
  background-size: auto 155px;
  padding-bottom: 80px;
}
.innerHead.serviceHead .headWrap,
.innerHead.titleHead .headWrap,
.innerHead.singleHead .headWrap {
  background: url(../img/head_bg.png) no-repeat top center;
  background-size: auto 155px;
  padding-bottom: 80px;
  position: relative;
  z-index: 3;
}
.innerHead .logo {
  padding: 20px 3% 0;
}
.innerHead .logo a {
  display: flex;
  align-items: center;
}
.innerHead .logo figure {
  max-width: 152px;
}
.innerHead .logo p {
  font-size: 1.6rem;
  font-size: clamp(1.2rem,1.25vw,1.6rem);
  font-weight: 700;
  letter-spacing: 0.64px;
  padding: 13px 0 0 3.6vw;
}
.innerHead .icon {
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.innerHead .icon figure {
  position: absolute;
  right: 25.5%;
  bottom: max(-12.2vw,-59px);
  max-width: 307px;
  width: 24%;
}
.menuTrigger {
  display: none;
}
.globalNav {
  position: absolute;
  right: 1.1%;
  top: 24px;
  display: flex;
  justify-content: flex-end;
  z-index: 2;
  width: 100%;
}
.topNav {
  display: none;
}
.globalNav li {
  margin-left: 0.6%;
}
.globalNav li img {
  width: auto;
  height: 24px;
}
.innerHead .pageTitle {
  padding: 48px 3% 180px;
  text-align: center;
  background: url(../img/title_bg.jpg) no-repeat center bottom #f7f2e1;
  background-size: auto 155px;
}
.innerHead .pageTitle h1 {
  font-size: 3.6rem;
  font-size: clamp(3.4rem,2.81vw,3.6rem);
  font-weight: 700;
  letter-spacing: 1.44px;
}
@media only screen and (max-width:750px) {
  .innerHead {
    margin-bottom: 0;
  }
  .innerHead .headWrap {
    background: url(../img/head_bg_sp.jpg) no-repeat top center #fff;
    background-size: 100%;
    padding-bottom: 22%;
  }
  .innerHead.serviceHead .headWrap,
  .innerHead.titleHead .headWrap,
  .innerHead.singleHead .headWrap {
    background: url(../img/head_bg_sp.png) no-repeat top center;
    background-size: 100%;
    padding-bottom: 22%;
  }
  .innerHead .logo {
    padding: 3.6% 0 0 5.5%;
  }
  .innerHead .logo figure {
    max-width: 30%;
  }
  .innerHead .logo p {
    font-size: 3.2vw;
    letter-spacing: 0.48px;
    padding: 1% 0 0 6.6vw;
    line-height: 1.5;
  }
  .innerHead .icon {
    display: none;
  }
  .menuTrigger {
    display: block;
    position: fixed;
    right: 4%;
    top: 3.6vw;
    width: 8.6vw;
    height: 8.6vw;
    z-index: 999;
  }
  .topPageTrigger.menuTrigger {
    opacity: 0;
    pointer-events: none;
    transition: 1s;
  }
  .topPageTrigger.menuTrigger.isShow {
    opacity: 1;
    pointer-events: all;
  }
  .menuTrigger span {
    position: absolute;
    left: 0;
    width: 100%;
    height: 6px;
    border-radius: 100px;
    background: #2f661c;
    transition: all .25s;
  }
  .menuTrigger span:nth-of-type(1) {
    top: 0;
  }
  .menuTrigger span:nth-of-type(2) {
    top: 0;
    bottom: 0;
    margin: auto;
  }
  .menuTrigger span:nth-of-type(3) {
    bottom: 0;
  }
  .menuTrigger.navOpen span:nth-of-type(1) {
    transform: translateY(3.35vw) rotate(-45deg);
  }
  .menuTrigger.navOpen span:nth-of-type(2) {
    left: 50%;
    opacity: 0;
    animation: activeBar .8s forwards;
  }
  .menuTrigger.navOpen span:nth-of-type(3) {
    transform: translateY(-3.35vw) rotate(45deg);
  }
  .globalNav {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    display: block;
    width: 50%;
    background: rgba(255, 255, 255, 1);
    height: 100%;
    overflow-y: auto;
    transition: all .5s;
    transform: translateX(100%);
    z-index: 998;
    padding: 15% 3% 0;
  }
  .globalNav.navOpen {
    transform: translateX(0);
  }
  .globalNav li {
    margin: 0;
    border-bottom: 1px solid #451603;
  }
  .globalNav li a {
    padding: 10% 5%;
  }
  .globalNav li img {
    width: auto;
    height: 8.53vw;
  }
  .innerHead .pageTitle {
    padding: 14.5% 0 29.5%;
    background: url(../img/title_bg_sp.jpg) no-repeat center bottom #f7f2e1;
    background-size: 100%;
  }
  .innerHead .pageTitle h1 {
    font-size: 6.93vw;
    letter-spacing: 1.04px;
  }
}
@media only screen and (max-width:750px) and (orientation: landscape) {
  .innerHead .menuTrigger.navOpen span:nth-of-type(1) {
    transform: translateY(3.7vw) rotate(-45deg);
  }
  .innerHead .menuTrigger.navOpen span:nth-of-type(3) {
    transform: translateY(-3.7vw) rotate(45deg);
  }
}
.headBtnLink {
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 3;
  margin-top: -11.6%;
}
.headBtnLink li {
  max-width: 160px;
  width: 100%;
  margin: 0 6px;
}
.headBtnLink li a {
  display: block;
  width: 100%;
  background: #4da500;
  border-radius: 100px;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 80px;
}
.headBtnLink li a svg {
  fill: #fff;
  max-width: 110px;
  transition: all .25s ease-in;
}
.headBtnLink li a:hover {
  background: #2f661c;
  opacity: 1;
}
.headBtnLink li a:hover svg {
  fill: #ffea06;
  max-width: 122px;
}
.topLogo {
  max-width: 370px;
  margin: 1.8% auto 48px;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width:750px) {
  .headBtnLink {
    display: none;
  }
  .topLogo {
    max-width: 87%;
    margin: -6.3% auto 10%;
  }
}
/* =========================================================
  Main Contents
========================================================= */
.mainContents {
  display: block;
  position: relative;
  z-index: 2;
}
.topPage.mainContents,
.servicePage.mainContents,
.titlePage.mainContents,
.singlePage.mainContents {
  background: url(../img/line_bg05.jpg) no-repeat center bottom #f7f2e1;
  background-size: auto 150px;
}
.innerPage.mainContents {
  padding: 0 3%;
  background: #fff;
}
.txtPage.mainContents {
  background: url(../img/line_bg06.jpg) no-repeat center bottom #fff;
  background-size: auto 150px;
}
@media only screen and (max-width:750px) {
  .topPage.mainContents,
  .servicePage.mainContents,
  .titlePage.mainContents,
  .singlePage.mainContents {
    background: url(../img/line_bg05_sp.jpg) no-repeat center bottom #f7f2e1;
    background-size: 100%;
  }
  .innerPage.mainContents {
    padding: 0 4.6%;
  }
  .txtPage.mainContents {
    background: url(../img/line_bg06_sp.jpg) no-repeat center bottom #fff;
    background-size: 100%;
  }
}
/* ---------- Common ---------- */
.mainContents .linkTxt {
  max-width: 1000px;
  margin: 0 auto;
  text-align: right;
}
.mainContents .linkTxt a {
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-weight: 700;
}
.mainContents .linkTxt a::after {
  content: "";
  display: inline-block;
  width: 26px;
  height: 26px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2026%2026%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20.st1%20%7B%20fill%3A%20%23451603%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M13%2C0h0C5.8%2C0%2C0%2C5.8%2C0%2C13h0c0%2C7.2%2C5.8%2C13%2C13%2C13h0c7.2%2C0%2C13-5.8%2C13-13h0C26%2C5.8%2C20.2%2C0%2C13%2C0Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M11%2C18.4c-.2%2C0-.5%2C0-.6-.3-.3-.3-.3-.9%2C0-1.2l4.3-4.1-4.3-4.1c-.3-.3-.4-.9%2C0-1.2.3-.3.9-.4%2C1.2%2C0l5%2C4.7c.2.2.3.4.3.6s0%2C.5-.3.6l-5%2C4.7c-.2.2-.4.2-.6.2Z%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  vertical-align: middle;
  position: relative;
  top: -1px;
  margin-left: 10px;
}
@media only screen and (max-width:750px) {
  .mainContents .linkTxt {
    max-width: 100%;
  }
  .mainContents .linkTxt a {
    font-size: 3.73vw;
  }
  .mainContents .linkTxt a::after {
    width: 6.93vw;
    height: 6.93vw;
    margin-left: 2vw;
  }
}
/* ---------- Index ---------- */
.mainContents .leadBlock {
  text-align: center;
  padding: 0 3%;
  margin: 0 0 32px;
}
.mainContents .leadBlock h2 {
  font-size: 2.8rem;
  font-weight: bold;
  letter-spacing: 1.12px;
  margin-bottom: 14px;
}
.mainContents .leadBlock .note {
  font-size: 2.4rem;
  font-size: clamp(2.2rem,1.87vw,2.4rem);
  line-height: 2;
}
@media only screen and (max-width:750px) {
  .mainContents .leadBlock {
    text-align: left;
    padding: 0;
    margin: 0 0 14.5%;
  }
  .mainContents .leadBlock h2 {
    font-size: 7.46vw;
    letter-spacing: 1px;
    margin-bottom: 6%;
    text-align: center;
  }
  .mainContents .leadBlock .note {
    font-size: 4.8vw;
    padding: 0 5%;
  }
}
.mainContents .introduction {
  padding: 0 3% 68px;
}
.mainContents .introBlock {
  max-width: 1000px;
  margin: 0 auto 22px;
  display: flex;
  justify-content: space-between;
}
.mainContents .introBlock .box {
  width: 48%;
  background: linear-gradient(to bottom,  rgba(215, 248, 185,0) 0%,rgba(215, 248, 185,0) 20%,rgba(215, 248, 185,1) 21%,rgba(215, 248, 185,1) 100%);
  border-radius: 0 0 8px 8px;
}
.mainContents .introBlock .box .txtBox {
  padding-bottom: 25px;
}
.mainContents .introBlock .box .txtBox h3 {
  margin: 0 auto 3px;
  width: 80%;
  position: relative;
  top: -12px;
}
.mainContents .introBlock .box .txtBox p {
  width: 84%;
  margin: 0 auto;
  font-size: 1.6rem;
  letter-spacing: 0.64px;
  line-height: 1.8;
}
@media only screen and (max-width:750px) {
  .mainContents .introduction {
    padding: 0 3% 12.3%;
  }
  .mainContents .introBlock {
    max-width: none;
    margin: 0 auto 7%;
    display: block;
  }
  .mainContents .introBlock .box {
    width: 100%;
    background: url(../img/introduction_bg_sp.png) no-repeat;
    background-size: 100%;
    overflow: hidden;
  }
  .mainContents .introBlock .box02 {
    background: url(../img/introduction_line_sp.png) no-repeat;
    background-size: 100%;
    padding-top: 15%;
  }
  .mainContents .introBlock .box02 figure {
    display: none;
  }
  .mainContents .introBlock .box .txtBox {
    padding: 2% 0 5%;
  }
  .mainContents .introBlock .box .txtBox h3 {
    margin: 0 auto 4%;
    width: 83%;
    top: 0;
  }
  .mainContents .introBlock .box .txtBox p {
    width: 88%;
    margin: 0 auto;
    font-size: 4.26vw;
    letter-spacing: 0.3px;
  }
}
.mainContents .foundBlock {
  padding: 0 3% 128px;
  margin: 0 auto;
  background: url(../img/line_bg01.jpg) no-repeat center bottom;
  background-size: auto 150px;
}
.mainContents .foundBlock h2 {
  max-width: 908px;
  margin: 0 auto 55px;
}
.mainContents .foundBlock ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  max-width: 775px;
  margin: 0 auto 24px;
}
.mainContents .foundBlock li {
  width: 20.8%;
  margin: 0 5.6% 24px 0;
  text-align: center;
}
.mainContents .foundBlock li:nth-of-type(4n) {
  margin-right: 0;
}
.mainContents .foundBlock li .soonB {
  display: none;
}
@media only screen and (max-width:750px) {
  .mainContents .foundBlock {
    padding: 0 0 31%;
    margin: 0 auto;
    background: url(../img/line_bg01_sp.jpg) no-repeat center bottom;
    background-size: 100%;
  }
  .mainContents .foundBlock h2 {
    max-width: 89.4%;
    margin: 0 auto 9%;
  }
  .mainContents .foundBlock ul {
    max-width: 85.4%;
    margin: 0 auto 3%;
  }
  .mainContents .foundBlock li {
    width: 22.9%;
    margin: 0 2.8% 7% 0;
  }
  .mainContents .foundBlock li:nth-of-type(4n) {
    margin-right: 0;
  }
  .mainContents .foundBlock li figcaption {
    font-size: 2.66vw;
    padding-top: 2%;
  }
  .mainContents .foundBlock .linkTxt {
    width: 90%;
  }
}
.mainContents .movieBlock {
  padding: 34px 3% 100px;
  background: url(../img/line_bg02.jpg) no-repeat center bottom #e4dcc2;
  background-size: auto 150px;
  max-width: 100%;
  overflow: hidden;
}
.mainContents .movieBlock.noVoice {
  background: url(../img/line_bg02_novoice.jpg) no-repeat center bottom #e4dcc2;
  background-size: auto 150px;
}
.mainContents .movieBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 30px;
}
.mainContents .movieBlock h2 img {
  max-width: 365px;
}
.mainContents .movieBlock h2::before,
.mainContents .movieBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.mainContents .movieBlock h2::before {
  margin-right: 20px;
}
.mainContents .movieBlock h2::after {
  margin-left: 20px;
}
.mainContents .movieBlock .movieWrap {
  max-width: 640px;
  margin: 0 auto 50px;
}
.mainContents .movieBlock .movieWrap iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.mainContents .movieBlock .movieWrap p {
  text-align: center;
  font-size: 1.6rem;
  padding-top: 12px;
}
.mainContents .movieBlock .appBlock {
  background: none;
}
.mainContents .movieBlock .appBlock .appBox {
  top: 0;
  margin-bottom: 0;
}
@media only screen and (max-width:750px) {
  .mainContents .movieBlock {
    padding: 8% 3% 26.5%;
    background: url(../img/line_bg02_sp.jpg) no-repeat center bottom #e4dcc2;
    background-size: 100%;
  }
  .mainContents .movieBlock.noVoice {
    background: url(../img/line_bg02_novoice_sp.jpg) no-repeat center bottom #e4dcc2;
    background-size: 100%;
  }
  .mainContents .movieBlock h2 {
    display: block;
    width: 80%;
    margin: 0 auto 10.5%;
  }
  .mainContents .movieBlock h2 img {
    max-width: 100%;
  }
  .mainContents .movieBlock h2::before {
    display: none;
  }
  .mainContents .movieBlock h2::after {
    width: 16vw;
    margin: 8.5% auto 0;
  }
  .mainContents .movieBlock .movieWrap {
    max-width: 97%;
    margin-bottom: 13.2%;
  }
  .mainContents .movieBlock .movieWrap p {
    font-size: 3.73vw;
    line-height: 2;
    padding-top: 2.5%;
  }
  .mainContents .movieBlock .appBlock .appBox figure {
    width: 45.6%;
  }
}
.mainContents .voiceBlock {
  padding: 20px 3% 160px;
  background: url(../img/line_bg03.jpg) no-repeat center bottom #f7f2e1;
  background-size: auto 150px;
}
.mainContents .voiceBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 52px;
}
.mainContents .voiceBlock h2 img {
  max-width: 183px;
}
.mainContents .voiceBlock h2::before,
.mainContents .voiceBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.mainContents .voiceBlock h2::before {
  margin-right: 20px;
}
.mainContents .voiceBlock h2::after {
  margin-left: 20px;
}
.mainContents .voiceBox {
  max-width: 980px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mainContents .voiceBox figure {
  width: 14.3%;
}
.mainContents .voiceBox .txtBox {
  width: 81.7%;
  border: 6px solid #ffec20;
  background: #fff;
  border-radius: 40px;
  padding: 26px 5% 27px;
}
.mainContents .voiceBox .txtBox h3 {
  font-size: 2.2rem;
  letter-spacing: 0.88px;
  margin-bottom: 15px;
}
.mainContents .voiceBox .txtBox .note {
  font-weight: 500;
  letter-spacing: 0.64px;
  font-size: 1.6rem;
  margin-bottom: 14px;
}
.mainContents .voiceBox .txtBox .name {
  text-align: right;
  font-size: 1.6rem;
  letter-spacing: 0.64px;
}
@media only screen and (max-width:750px) {
  .mainContents .voiceBlock {
    padding: 11.5% 3% 20.5%;
    background: url(../img/line_bg03_sp.jpg) no-repeat center bottom #f7f2e1;
    background-size: 100%;
  }
  .mainContents .voiceBlock h2 {
    display: block;
    width: 80%;
    margin: 0 auto 11.5%;
  }
  .mainContents .voiceBlock h2 img {
    max-width: 100%;
  }
  .mainContents .voiceBlock h2::before {
    display: none;
  }
  .mainContents .voiceBlock h2::after {
    width: 16vw;
    margin: 15.5% auto 0;
  }
  .mainContents .voiceBox {
    max-width: 100%;
    margin: 0 auto 20px;
    display: block;
  }
  .mainContents .voiceBox .txtBox {
    width: 100%;
    padding: 7.8% 4.5% 7%;
  }
  .mainContents .voiceBox .titleBox {
    display: flex;
    justify-content: space-between;
    margin-bottom: 8.5%;
  }
  .mainContents .voiceBox .titleBox figure {
    width: 29.2%;
  }
  .mainContents .voiceBox .txtBox h3 {
    font-size: 5.86vw;
    margin-bottom: 0;
    width: 65%;
  }
  .mainContents .voiceBox .txtBox .note {
    font-size: 4.26vw;
    margin-bottom: 5.5%;
  }
  .mainContents .voiceBox .txtBox .name {
    font-size: 4.26vw;
  }
}
.mainContents .infoBlock {
  padding: 20px 3% 416px;
  background: url(../img/line_bg04.jpg) no-repeat center bottom #fff;
  background-size: auto 350px;
}
.mainContents .infoBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 66px;
}
.mainContents .infoBlock h2 img {
  max-width: 433px;
}
.mainContents .infoBlock h2::before,
.mainContents .infoBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.mainContents .infoBlock h2::before {
  margin-right: 20px;
}
.mainContents .infoBlock h2::after {
  margin-left: 20px;
}
.mainContents .snsBlock {
  max-width: 955px;
  margin: 0 auto 50px;
  display: flex;
  justify-content: center;
}
.mainContents .snsBlock .xBox {
  width: 57%;
}
.mainContents .snsBlock .snsWrap {
  width: 40%;
  padding-top: 12px;
}
.mainContents .snsBlock .snsWrap .titleBlock {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 16px;
}
.mainContents .snsBlock .snsWrap .titleBlock figure {
  width: 21%;
}
.mainContents .snsBlock .snsWrap .titleBlock .txtBox {
  width: 75%;
}
.mainContents .snsBlock .snsWrap .titleBlock .txtBox h3 {
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0.64px;
}
.mainContents .snsBlock .snsWrap .titleBlock .txtBox p {
  font-size: 1.3rem;
  font-weight: 500;
  letter-spacing: 0.52px;
}
.mainContents .snsBlock .snsWrap .note {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.52px;
  margin-bottom: 55px;
}
.mainContents .snsBlock .snsWrap .btn {
  margin-bottom: 62px
}
.mainContents .snsBlock .snsWrap .btn a {
  display: flex;
  justify-content: center;
  position: relative;
  color: #fff;
  border: 1px solid #451603;
  background: #451603;
  border-radius: 100px;
  text-align: center;
  font-weight: 700;
  font-family: "M PLUS Rounded 1c", sans-serif;
  padding: 4px 3%;
}
.mainContents .snsBlock .snsWrap .btn a::after {
  content: "";
  transition: all .25s ease-in;
  mask-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2232%22%20height%3D%2232%22%20viewBox%3D%220%200%2032%2032%22%20fill%3D%22none%22%3E%20%3Cpath%20d%3D%22M14.0085%2020.5359L19.0085%2015.816L14.0085%2011.0962%22%20stroke%3D%22white%22%20stroke-width%3D%221.71037%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-position: center;
  background: #fff;
  width: 32px;
  height: 32px;
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  margin: auto;
}
.mainContents .snsBlock .snsWrap .btn a:hover {
  background: #fff;
  color: #451603;
  opacity: 1;
}
.mainContents .snsBlock .snsWrap .btn a:hover::after {
  background: #451603;
}
.mainContents .snsBlock .snsBtn {
  display: flex;
  justify-content: center;
}
.mainContents .snsBlock .snsBtn li {
  max-width: 40px;
  margin: 0 8px;
}
.mainContents .newsBlock h3 {
  max-width: 389px;
  margin: 0 auto 20px;
}
.mainContents .newsCarousel {
  position: relative;
  max-width: 1060px;
  margin: 0 auto 36px;
}
.mainContents .newsSwiper {
  overflow: hidden;
  max-width: 940px;
  margin: 0 auto;
}
.mainContents .newsSwiper.isCenter .swiper-wrapper {
  justify-content: center;
}
.mainContents .newsCarousel .swiper-slide {
  max-width: 32%;
  margin-right: 2%;
  height: auto;
}
.mainContents .newsCarousel .swiper-controller {
  display: flex;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
.mainContents .newsCarousel .swiper-button-prev,
.mainContents .newsCarousel .swiper-button-next {
  width: 40px;
  height: 40px;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2240%22%20height%3D%2240%22%20viewBox%3D%220%200%2040%2040%22%20fill%3D%22none%22%3E%20%3Ccircle%20cx%3D%2220.0001%22%20cy%3D%2220.0001%22%20r%3D%2219.7647%22%20fill%3D%22%23451603%22%2F%3E%20%3Cpath%20d%3D%22M23.0085%2015.0964L18.0085%2019.8163L23.0085%2024.5361%22%20stroke%3D%22white%22%20stroke-width%3D%221.71037%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
}
.mainContents .newsCarousel .swiper-button-prev:hover,
.mainContents .newsCarousel .swiper-button-next:hover {
  opacity: 0.6;
}
.mainContents .newsCarousel .swiper-button-prev {
  left: 0;
}
.mainContents .newsCarousel .swiper-button-next {
  right: 0;
  transform: rotate(180deg);
}
.mainContents .newsCarousel .swiper-button-prev svg,
.mainContents .newsCarousel .swiper-button-next svg {
  display: none;
}
.mainContents .newsCarousel .box {
  background: #d7f8b9;
  padding: 20px 20px 30px;
  height: 100%;
}
.mainContents .newsCarousel .box figure {
  margin-bottom: 10px;
}
.mainContents .newsCarousel .box h4 {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: 0.6px;
  margin-bottom: 10px;
}
.mainContents .newsCarousel .box time {
  display: block;
  text-align: right;
  font-size: 1.3rem;
  letter-spacing: 0.52px;
  font-weight: 500;
}
.mainContents .bnrArea {
  max-width: 940px;
  margin: 0 auto;
  display: flex;
}
.mainContents .bnrArea li {
  width: 32%;
  margin-right: 2%;
}
.mainContents .bnrArea li:last-child {
  margin-right: 0;
}
@media only screen and (max-width:750px) {
  .mainContents .infoBlock {
    padding: 12.5% 0 35.5%;
    background: url(../img/line_bg04_sp.jpg) no-repeat center bottom #fff;
    background-size: 100%;
  }
  .mainContents .infoBlock h2 {
    display: block;
    width: 90%;
    margin: 0 auto 8.5%;
  }
  .mainContents .infoBlock h2 img {
    max-width: 100%;
  }
  .mainContents .infoBlock h2::before {
    display: none;
  }
  .mainContents .infoBlock h2::after {
    width: 16vw;
    margin: 11% auto 0;
  }
  .mainContents .snsBlock {
    max-width: 100%;
    margin: 0 auto 16%;
    display: block;
  }
  .mainContents .snsBlock .xBox {
    width: 100%;
  }
  .mainContents .snsBlock .snsWrap {
    width: 94%;
    margin: 0 auto;
    padding: 6% 0 12.5%;
    border-bottom: 2px solid #451603;
  }
  .mainContents .snsBlock .snsWrap .titleBlock {
    margin: 0 7.4% 5.5%;
  }
  .mainContents .snsBlock .snsWrap .titleBlock figure {
    width: 27%;
  }
  .mainContents .snsBlock .snsWrap .titleBlock .txtBox {
    width: 68%;
  }
  .mainContents .snsBlock .snsWrap .titleBlock .txtBox h3 {
    font-size: 4.26vw;
  }
  .mainContents .snsBlock .snsWrap .titleBlock .txtBox p {
    font-size: 3.46vw;
  }
  .mainContents .snsBlock .snsWrap .note {
    font-size: 3.46vw;
    margin: 0 7.4% 13%;
  }
  .mainContents .snsBlock .snsWrap .btn {
    margin: 0 7.4% 21.5%
  }
  .mainContents .snsBlock .snsWrap .btn a {
    padding: 1.4% 3%;
    font-size: 3.73vw;
  }
  .mainContents .snsBlock .snsWrap .btn a::after {
    width: 8.53vw;
    height: 8.53vw;
  }
  .mainContents .snsBlock .snsBtn li {
    max-width: 10.66vw;
    margin: 0 2.13vw;
  }
  .mainContents .newsBlock h3 {
    max-width: 57%;
    margin: 0 auto 8%;
  }
  .mainContents .newsCarousel {
    max-width: 80%;
    margin: 0 auto 4%;
  }
  .mainContents .swiper-wrapper {
    display: block;
  }
  .mainContents .newsSwiper {
    max-width: none;
  }
  .mainContents .newsCarousel .swiper-slide {
    max-width: 100%;
    margin: 0 0 7%;
  }
  .mainContents .newsCarousel .swiper-controller {
    display: none;
  }
  .mainContents .newsCarousel .box {
    padding: 7% 7% 9.5%;
  }
  .mainContents .newsCarousel .box figure {
    margin-bottom: 4%;
  }
  .mainContents .newsCarousel .box h4 {
    font-size: 4.26vw;
    margin-bottom: 4%;
  }
  .mainContents .newsCarousel .box time {
    font-size: 3.46vw;
  }
  .mainContents .bnrArea {
    max-width: 80%;
    margin: 0 auto;
    display: block;
  }
  .mainContents .bnrArea li {
    width: 100%;
    margin: 0 0 7%;
  }
}
.mainContents .appBlock {
  padding: 0 3% 20px;
  position: relative;
  z-index: 2;
  background: #e4dcc2;
}
.mainContents.topPage .appBlock {
  padding: 0 3% 52px;
}
.mainContents .appBoxWrap {
  position: relative;
  margin: -244px auto 0;
}
.mainContents #appAbout {
  padding-top: 20px;
}
.mainContents .appBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 86px;
}
.mainContents .appBlock h2 img {
  max-width: 291px;
}
.mainContents .appBlock h2::before,
.mainContents .appBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.mainContents .appBlock h2::before {
  margin-right: 20px;
}
.mainContents .appBlock h2::after {
  margin-left: 20px;
}
.mainContents .appBlock .appBox {
  display: flex;
  justify-content: space-between;
  max-width: 562px;
  margin: 0 auto 0;
}
.mainContents .appBlock .appBox .imgBox {
  width: 28.5%;
}
.mainContents .appBlock .appBox .txtBox {
  width: 65.4%;
  position: relative;
}
.mainContents .appBlock .appBox .txtBox .appStar {
  position: absolute;
  right: -76px;
  top: -110px;
}
.mainContents .appBlock .appBox dl {
  display: flex;
  line-height: 2;
  font-size: 1.6rem;
}
.mainContents .appBlock .appBox dt {
  text-align: right;
  font-weight: 700;
  letter-spacing: 0.72px;
  min-width: 97px;
  margin-right: 25px;
}
.mainContents .appBlock .appBox dd {
  letter-spacing: 0.72px;
  white-space: nowrap;
}
.mainContents .appBlock .appBox dd span {
  font-size: 1rem;
}
.mainContents .appBlock .appBox dd .caution {
  font-size: 1.3rem;
  line-height: 1.8;
  padding-top: 5px;
}
.mainContents .appBlock .appBox ul {
  display: flex;
  margin-top: 50px;
}
.mainContents .appBlock .appBox li {
  margin-right: 20px;
}
.mainContents .appBlock .appBox li img {
  width: auto;
  height: 40px;
}
.mainContents .appBlock .btn {
  max-width: 320px;
  width: 100%;
  margin: 0 auto 34px;
  text-align: center;
  position: relative;
  z-index: 2;
}
.mainContents .appBlock .btn a {
  border-radius: 100px;
  background: #451603;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2rem;
  letter-spacing: 1.44px;
  font-weight: 600;
  border: 2px solid #451603;
  position: relative;
  display: block;
  padding: 17px 0;
}
.mainContents .appBlock .btn a::after {
  content: "";
  transition: all .25s ease-in;
  mask-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2036%2020%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M33.6%2C11.4H2.4c-.8%2C0-1.4-.6-1.4-1.4s.6-1.4%2C1.4-1.4h31.2c.8%2C0%2C1.4.6%2C1.4%2C1.4s-.6%2C1.4-1.4%2C1.4Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M25.2%2C19.4c-.4%2C0-.8-.2-1-.4-.5-.6-.5-1.5%2C0-2l7.3-6.9-7.3-6.9c-.6-.5-.6-1.5%2C0-2%2C.5-.6%2C1.5-.6%2C2%2C0l8.4%2C7.9c.3.3.4.6.4%2C1s-.2.8-.4%2C1l-8.4%2C7.9c-.3.3-.6.4-1%2C.4Z%22%2F%3E%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-position: center;
  background: #fff;
  width: 28px;
  height: 16px;
  position: absolute;
  right: 5%;
  top: 0;
  bottom: 0;
  margin: auto;
}
.mainContents .appBlock .btn a:hover {
  background: #fff;
  color: #451603;
  opacity: 1;
}
.mainContents .appBlock .btn a:hover::after {
  background: #451603;
  right: 4%;
}
@media only screen and (max-width:750px) {
  .mainContents .appBlock {
    padding: 11% 0 0;
  }
  .mainContents.topPage .appBlock {
    padding: 11% 0 11%;
  }
  .mainContents .appBoxWrap {
    margin: 0 auto;
  }
  .mainContents #appAbout {
    padding-top: 20px;
  }
  .mainContents .appBlock h2 {
    display: block;
    width: 80%;
    top: 0;
    margin: 0 auto 10%;
  }
  .mainContents .appBlock h2 img {
    max-width: 100%;
  }
  .mainContents .appBlock h2::before {
    display: none;
  }
  .mainContents .appBlock h2::after {
    width: 16vw;
    margin: 6.5% auto 0;
  }
  .mainContents .appBlock .appBox {
    display: block;
    top: 0;
    max-width: none;
    margin: 0 auto 17.5%;
  }
  .mainContents .appBlock .appBox .imgBox {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    margin-bottom: 9.6%;
  }
  .mainContents .appBlock .appBox .imgBox figure {
    width: 42.7%;
    margin: 0 2%;
  }
  .mainContents .appBlock .appBox .imgBox .appStar {
    width: 36.3%;
    margin: 0 2%;
  }
  .mainContents .appBlock .appBox .txtBox {
    width: 92.4%;
    margin: 0 auto;
  }
  .mainContents .appBlock .appBox dt {
    font-size: 4.26vw;
    font-weight: 700;
    letter-spacing: 0.64px;
    min-width: 25vw;
    margin-right: 6vw;
  }
  .mainContents .appBlock .appBox dd {
    font-size: 4.26vw;
    letter-spacing: 0.64px;
    white-space: normal;
  }
  .mainContents .appBlock .appBox dd span {
    font-size: 3.66vw;
  }
  .mainContents .appBlock .appBox dd .caution {
    font-size: 3.46vw;
    padding-top: 0;
  }
  .mainContents .appBlock .appBox ul {
    justify-content: center;
    margin: 11% 0 0;
  }
  .mainContents .appBlock .appBox li {
    margin: 0 2%;
  }
  .mainContents .appBlock .appBox li:first-child {
    width: 31%;
  }
  .mainContents .appBlock .appBox li:last-child {
    width: 38.33%;
  }
  .mainContents .appBlock .btn {
    max-width: 86%;
    margin: 0 auto 34px;
  }
  .mainContents .appBlock .btn a {
    font-size: 5.33vw;
    letter-spacing: 0.8px;
    padding: 17px 0;
  }
  .mainContents .appBlock .btn a::after {
    width: 7.46vw;
    height: 4.26vw;
    right: 7%;
  }
  .mainContents .appBlock .btn a:hover::after {
    right: 5%;
  }
}
.mainContents .fixArea {
  position: sticky;
  bottom: 0;
  z-index: 9;
  opacity: 0;
  pointer-events: none;
  transition: 1s;
}
.mainContents .fixArea.isShow {
  opacity: 1;
  pointer-events: all;
}
.mainContents .fixArea .footBtn {
  display: flex;
  justify-content: flex-end;
  text-align: right;
  padding: 0 3% 20px 0;
}
.mainContents .fixArea .footBtn li {
  margin-bottom: 10px;
}
.mainContents .fixArea .footBtn li.toPagetop {
  cursor: pointer;
  transition: all .25s ease-in;
}
.mainContents .fixArea .footBtn li.toPagetop:hover {
  opacity: 0.6;
}
.txtPage .fixArea .footBtn li:first-of-type {
  display: none;
}
@media only screen and (max-width:750px) {
  .mainContents .fixArea .footBtn {
    justify-content: center;
    padding: 0 0 3%;
  }
  .mainContents .fixArea .footBtn ul {
    width: 45.7%;
  }
  .mainContents .fixArea .footBtn li {
    margin-bottom: 6%;
  }
}
/* ---------- Line Icon ---------- */
.mainContents .lineIcon01 {
  max-width: 998px;
  margin: 0 auto;
  position: relative;
}
.mainContents .lineIcon01 figure {
  position: absolute;
  max-width: 189px;
  width: 19%;
  margin: 0;
  bottom: -132px;
  left: 3.7%;
}
.mainContents .lineIcon02 {
  max-width: calc(1140px - 10%);
  margin: 0 auto;
  position: relative;
}
.mainContents .lineIcon02 figure {
  position: absolute;
  max-width: 252px;
  width: 23%;
  margin: 0;
  bottom: -45px;
  right: -6%;
}
.mainContents .lineIcon04 {
  max-width: 1018px;
  margin: 0 auto;
  position: relative;
}
.mainContents .lineIcon04 figure {
  position: absolute;
  max-width: 186px;
  width: 25%;
  margin: 0;
  bottom: max(-18.5vw,-160px);
  right: 0;
}
@media only screen and (max-width:750px) {
  .mainContents .lineIcon01,
  .mainContents .lineIcon02,
  .mainContents .lineIcon04 {
    display: none;
  }
}
/* ---------- キノリーって？ ---------- */
.serviceHead .mv {
  position: relative;
  z-index: 2;
  margin-top: -12%;
}
.servicePage .leadBlock {
  background: url(../img/service_bg.jpg) no-repeat center 0;
  background-size: cover;
  margin: -10.5% 0 0;
  padding: 5.9% 3% clamp(110px,10%,128px);
}
.servicePage .leadBlock .serviceLogo {
  max-width: 321px;
  margin: 0 auto 23px;
}
.servicePage .introduction {
  position: relative;
  margin-top: 3.8%;
  padding-bottom: 152px;
  background: url(../img/line_bg08.jpg) no-repeat center bottom #fff;
  background-size: auto 150px;
}
.servicePage .introduction::before {
  content: "";
  width: 100%;
  height: 150px;
  position: absolute;
  left: 0;
  top: -150px;
  background: url(../img/line_bg07.png) no-repeat center bottom;
  background-size: auto 150px;
}
.servicePage .introduction .lineIcon01 figure {
  bottom: -160px;
}
.servicePage .introduction .flowBlock {
  padding: 14px 0 88px;
}
.servicePage .introduction .flowBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 64px;
}
.servicePage .introduction .flowBlock h2 img {
  max-width: 613px;
}
.servicePage .introduction .flowBlock h2::before,
.servicePage .introduction .flowBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.servicePage .introduction .flowBlock h2::before {
  margin-right: 20px;
}
.servicePage .introduction .flowBlock h2::after {
  margin-left: 20px;
}
.servicePage .introduction .flowBlock figure {
  max-width: 937px;
  margin: 0 auto;
}
.servicePage .introduction .spreadBlock h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 68px;
}
.servicePage .introduction .spreadBlock h2 img {
  max-width: 403px;
}
.servicePage .introduction .spreadBlock h2::before,
.servicePage .introduction .spreadBlock h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.servicePage .introduction .spreadBlock h2::before {
  margin-right: 20px;
}
.servicePage .introduction .spreadBlock h2::after {
  margin-left: 20px;
}
.servicePage .movieBlock {
  background: url(../img/line_bg09.jpg) no-repeat center bottom #e4dcc2;
  background-size: auto 150px;
}
.servicePage .foundBlock {
  padding-bottom: 377px;
  background: url(../img/line_bg04.jpg) no-repeat center bottom #fff;
  background-size: auto 350px;
}
.servicePage .foundBlock li .soonW {
  display: none;
}
.servicePage .foundBlock li .soonB {
  display: block;
}
@media only screen and (max-width:750px) {
  .serviceHead .mv {
    position: relative;
    z-index: 2;
    margin-top: -27vw;
  }
  .servicePage .leadBlock {
    background: url(../img/service_bg_sp.jpg) no-repeat center 0;
    background-size: 100%;
    margin: -20.5vw 0 0;
    padding: 19.9vw 0 35%;
  }
  .servicePage .leadBlock .serviceLogo {
    max-width: 91%;
    margin: 0 auto 6%;
  }
  .servicePage .introduction {
    margin-top: 3.8%;
    padding-bottom: 31%;
    background: url(../img/line_bg08_sp.jpg) no-repeat center bottom #fff;
    background-size: 100%;
  }
  .servicePage .introduction::before {
    height: 33.33vw;
    left: 0;
    top: -33.33vw;
    background: url(../img/line_bg07_sp.png) no-repeat center bottom;
    background-size: auto 33.33vw;
  }
  .servicePage .introduction .flowBlock {
    padding: 0 0 13.5%;
    position: relative;
    top: -2vw;
  }
  .servicePage .introduction .flowBlock h2 {
    display: block;
    width: 89%;
    margin: 0 auto 10%;
  }
  .servicePage .introduction .flowBlock h2 img {
    max-width: 100%;
  }
  .servicePage .introduction .flowBlock h2::before {
    display: none;
  }
  .servicePage .introduction .flowBlock h2::after {
    width: 16vw;
    margin: 10% auto 0;
  }
  .servicePage .introduction .flowBlock figure {
    max-width: 100%;
  }
  .servicePage .introduction .spreadBlock h2 {
    display: block;
    width: 56%;
    margin: 0 auto 14%;
  }
  .servicePage .introduction .spreadBlock h2 img {
    max-width: 100%;
  }
  .servicePage .introduction .spreadBlock h2::before {
    display: none;
  }
  .servicePage .introduction .spreadBlock h2::after {
    width: 16vw;
    margin: 16.5% auto 0;
  }
  .servicePage .movieBlock {
    background: url(../img/line_bg09_sp.jpg) no-repeat center bottom #e4dcc2;
    background-size: 100%;
  }
  .servicePage .foundBlock {
    padding-bottom: 36%;
    background: url(../img/line_bg04_sp.jpg) no-repeat center bottom #fff;
    background-size: 100%;
  }
}
/* ---------- タイトルのご紹介 ---------- */
.titleHead {
  position: relative;
  margin-bottom: 0;
}
.titleHead::after {
  content: "";
  width: 100%;
  height: 100px;
  position: absolute;
  z-index: 2;
  bottom: 0;
  left: 0;
  background: url(../img/titlepage_bg.png) no-repeat center bottom;
  background-size: auto 100px;
}
.titleHead .pageTitle {
  background: url(../img/titlepage_title_bg.jpg) no-repeat center top;
  background-size: cover;
  margin-top: -60px;
  padding: 108px 3%;
}
.mainContents .titleContents {
  padding: 66px 3% 365px;
  background: url(../img/line_bg10.jpg) no-repeat center bottom #fbf7ed;
  background-size: auto 350px;
}
.mainContents .titleContents h2 {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 66px;
}
.mainContents .titleContents h2 img {
  max-width: 684px;
}
.mainContents .titleContents h2::before,
.mainContents .titleContents h2::after {
  content: "";
  width: 60px;
  height: 2px;
  display: block;
  background: #451603;
}
.mainContents .titleContents h2::before {
  margin-right: 20px;
}
.mainContents .titleContents h2::after {
  margin-left: 20px;
}
.mainContents .titleContents .block {
  max-width: 980px;
  margin: 0 auto 75px;
}
.mainContents .titleContents .block h3 {
  font-size: 2.8rem;
  font-weight: 700;
  color: #fff;
  text-align: center;
  border-radius: 100px;
  line-height: 1.5;
  margin-bottom: 26px;
}
.mainContents .titleContents .block h3 span {
  font-weight: 700;
  font-size: 3.6rem;
}
.mainContents .titleContents .block.block01 h3 {
  background: #77c4e2;
}
.mainContents .titleContents .block.block02 h3 {
  background: #ff8972;
}
.mainContents .titleContents .block.block03 h3 {
  background: #40ad52;
}
.mainContents .titleContents .block.block04 h3 {
  background: #a4add6;
}
.mainContents .titleContents .block ul {
  display: flex;
  flex-wrap: wrap;
}
.mainContents .titleContents .block li {
  width: 23.5%;
  margin: 0 2% 24px 0;
}
.mainContents .titleContents .block li:nth-child(4n) {
  margin-right: 0;
}
.mainContents .titleContents .block li a {
  display: flex;
  flex-direction: column;
  background: #fff;
  padding: 20px 7% 28px;
  border-radius: 10px;
  height: 100%;
}
.mainContents .titleContents .block li figure {
  max-width: 128px;
  margin: 0 auto 10px;
}
.mainContents .titleContents .block li h4 {
  font-size: 1.6rem;
  font-size: clamp(1.4rem,1.25vw,1.6rem);
  font-weight: 700;
  margin-bottom: 12px;
}
.mainContents .titleContents .block li .txtBox {
  margin-top: auto;
}
.mainContents .titleContents .block li .note {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  font-size: 1.3rem;
  letter-spacing: 0.52px;
  line-height: 1.5;
  font-weight: 500;
  margin-bottom: 18px;
}
.mainContents .titleContents .block li .linkTxt {
  text-align: right;
}
.mainContents .titleContents .block li .linkTxt p {
  font-size: 1.3rem;
  font-weight: 500;
  display: flex;
  justify-content: flex-end;
  align-items: center;
}
.mainContents .titleContents .block li .linkTxt p::after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 24px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2026%2026%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20.st1%20%7B%20fill%3A%20%23451603%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st1%22%20d%3D%22M13%2C0h0C5.8%2C0%2C0%2C5.8%2C0%2C13h0c0%2C7.2%2C5.8%2C13%2C13%2C13h0c7.2%2C0%2C13-5.8%2C13-13h0C26%2C5.8%2C20.2%2C0%2C13%2C0Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M11%2C18.4c-.2%2C0-.5%2C0-.6-.3-.3-.3-.3-.9%2C0-1.2l4.3-4.1-4.3-4.1c-.3-.3-.4-.9%2C0-1.2.3-.3.9-.4%2C1.2%2C0l5%2C4.7c.2.2.3.4.3.6s0%2C.5-.3.6l-5%2C4.7c-.2.2-.4.2-.6.2Z%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  position: relative;
  top: -1px;
  margin-left: 8px;
}
@media only screen and (max-width:750px) {
  .titleHead::after {
    height: 7.81vw;
    z-index: 2;
    background: url(../img/titlepage_bg_sp.png) no-repeat center top;
    background-size: 100%;
  }
  .titleHead .pageTitle {
    margin-top: -13vw;
    padding: 26vw 3%;
  }
  .mainContents .titleContents {
    padding: 13% 4.6% 28%;
    background: url(../img/line_bg10_sp.jpg) no-repeat center bottom #fbf7ed;
    background-size: 100%;
  }
  .mainContents .titleContents h2 {
    display: block;
    width: 84%;
    margin: 0 auto 10.5%;
  }
  .mainContents .titleContents h2 img {
    max-width: 100%;
  }
  .mainContents .titleContents h2::before {
    display: none;
  }
  .mainContents .titleContents h2::after {
    width: 16vw;
    margin: 11% auto 0;
  }
  .mainContents .titleContents .block {
    max-width: 100%;
    margin: 0 auto 75px;
  }
  .mainContents .titleContents .block h3 {
    font-size: 7.46vw;
    border-radius: 27px;
    margin-bottom: 9%;
    padding: 0 6%;
  }
  .mainContents .titleContents .block h3 span {
    font-size: 9.6vw;
  }
  .mainContents .titleContents .block li {
    width: 100%;
    margin: 0 0 6.5%;
  }
  .mainContents .titleContents .block li a {
    display: block;
    padding: 6% 6% 8.5%;
  }
  .mainContents .titleContents .block li figure {
    max-width: 42.7%;
    margin: 0 auto 3.4%;
  }
  .mainContents .titleContents .block li h4 {
    font-size: 4.26vw;
    margin-bottom: 3.4%;
  }
  .mainContents .titleContents .block li .note {
    -webkit-line-clamp: 3;
    font-size: 3.46vw;
    margin-bottom: 5.6%;
  }
  .mainContents .titleContents .block li .linkTxt p {
    font-size: 3.46vw;
  }
  .mainContents .titleContents .block li .linkTxt p::after {
    width: 6.4vw;
    height: 6.4vw;
    top: -1px;
    margin-left: 2vw;
  }
}
/* ---------- 各タイトル詳細ページ ---------- */
.singleHead {
  position: relative;
  margin-bottom: 0;
}
.singleHead::after {
  content: "";
  width: 100%;
  height: 100px;
  position: absolute;
  z-index: 2;
  bottom: 0;
  left: 0;
  background: url(../img/titlesingle_bg.png) no-repeat center bottom;
  background-size: auto 100px;
}
.singleTitle {
  margin-top: -155px;
  padding: 168px 3% 132px;
}
.singleClrBlu .singleTitle {
  background: url(../img/app/title_bg_b.jpg) no-repeat center top;
  background-size: cover;
}
.singleClrRed .singleTitle {
  background: url(../img/app/title_bg_r.jpg) no-repeat center top;
  background-size: cover;
}
.singleClrGrn .singleTitle {
  background: url(../img/app/title_bg_g.jpg) no-repeat center top;
  background-size: cover;
}
.singleClrPur .singleTitle {
  background: url(../img/app/title_bg_p.jpg) no-repeat center top;
  background-size: cover;
}
.singleHead .singleTitleWrap {
  max-width: 1150px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
.singleHead .singleTitleWrap .txtBox {
  width: 43%;
  padding-top: 16px;
}
.singleHead .singleTitleWrap .txtBox h1 {
  margin-bottom: 40px;
}
.singleHead .singleTitleWrap .txtBox h1 img {
  width: 100%;
}
.singleHead .singleTitleWrap .txtBox .meta {
  display: flex;
  justify-content: center;
}
.singleHead .singleTitleWrap .txtBox .meta .details {
  width: 61.5%;
  margin: 0 2%;
}
.singleHead .singleTitleWrap .txtBox .meta .details dl {
  display: flex;
  font-size: 1.2rem;
  margin-bottom: 5px;
}
.singleHead .singleTitleWrap .txtBox .meta .details dt {
  text-align: center;
  width: 104px;
  background: #f7f2e1;
}
.singleHead .singleTitleWrap .txtBox .meta .details dt p {
  font-weight: 700;
  display: flex;
  align-items: center;
  height: 100%;
  justify-content: center;
}
.singleHead .singleTitleWrap .txtBox .meta .details dd {
  width: calc(100% - 104px);
  background: #fff;
  line-height: 1.8;
  padding: 4px 4%;
}
.singleHead .singleTitleWrap .txtBox .meta .appIcon {
  width: 21.3%;
  margin: 0 2%;
}
.singleHead .singleTitleWrap .imgBlock {
  width: 56.8%;
}
.singleHead .singleTitleWrap .imgWrap {
  position: relative;
}
.singleHead .singleTitleWrap .imgBlock .titleImg {
  width: 80%;
  margin: 0 auto;
  overflow: hidden;
}
.singleHead .singleTitleWrap .imgBlock .swiper-controller {
  display: flex;
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
}
.singleHead .singleTitleWrap .imgBlock .swiper-button-prev,
.singleHead .singleTitleWrap .imgBlock .swiper-button-next {
  width: 40px;
  height: 40px;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2240%22%20height%3D%2240%22%20viewBox%3D%220%200%2040%2040%22%20fill%3D%22none%22%3E%20%3Ccircle%20cx%3D%2220.0001%22%20cy%3D%2220.0001%22%20r%3D%2219.7647%22%20fill%3D%22%23451603%22%2F%3E%20%3Cpath%20d%3D%22M23.0085%2015.0964L18.0085%2019.8163L23.0085%2024.5361%22%20stroke%3D%22white%22%20stroke-width%3D%221.71037%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
}
.singleHead .singleTitleWrap .imgBlock .swiper-button-prev:hover,
.singleHead .singleTitleWrap .imgBlock .swiper-button-next:hover {
  opacity: 0.6;
}
.singleHead .singleTitleWrap .imgBlock .swiper-button-prev {
  left: 0;
}
.singleHead .singleTitleWrap .imgBlock .swiper-button-next {
  right: 0;
  transform: rotate(180deg);
}
.singleHead .singleTitleWrap .imgBlock .swiper-button-prev svg,
.singleHead .singleTitleWrap .imgBlock .swiper-button-next svg {
  display: none;
}
.singleHead .singleTitleWrap .imgBlock .swiper-pagination {
  bottom: -42px;
}
.singleHead .singleTitleWrap .imgBlock .swiper-pagination-bullet {
  background: #451603;
  opacity: 1;
  margin: 0 9px;
}
.singleHead .singleTitleWrap .imgBlock .swiper-pagination-bullet-active {
  background: #f99207;
}
.singlePage {
  padding: 0 0 5px;
}
.singlePage .singleBlock {
  padding: 28px 3% 40px;
  background: #fff;
}
.singlePage .singleBlock .lead,
.singlePage .singleBlock .leads {
  max-width: 980px;
  margin: 0 auto 44px;
  line-height: 2;
  font-size: 1.8rem;
}
.singlePage .singleBlock .leads p {
  margin-bottom: 38px;
}
.singlePage .singleBlock .leads p:last-of-type {
  margin-bottom: 0;
}
.singlePage .singleBlock .block {
  max-width: 980px;
  margin: 0 auto 36px;
}
.singlePage .singleBlock .block figure {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 8px;
}
.singlePage .singleBlock .block figure img {
  min-width: 68px;
}
.singlePage .singleBlock .block figure::before,
.singlePage .singleBlock .block figure::after {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  background: #451603;
}
.singlePage .singleBlock .block figure::before {
  margin-right: 48px;
}
.singlePage .singleBlock .block figure::after {
  margin-left: 48px;
}
.singlePage .singleBlock .block h2 {
  text-align: center;
  font-size: 2.8rem;
  font-weight: 700;
  margin-bottom: 34px;
  line-height: 1.5;
}
.singlePage .singleBlock .block .note,
.singlePage .singleBlock .block .notes {
  font-size: 1.8rem;
  line-height: 2;
}
.singlePage .singleBlock .block .notes p {
  margin-bottom: 38px;
}
.singlePage .singleBlock .block .notes p:last-of-type {
  margin-bottom: 0;
}
.singlePage .singleContents .pointBlock {
  padding: 0 3% 200px;
  background: #fff;
  background: url(../img/line_bg11.jpg) no-repeat center bottom #fff;
  background-size: auto 150px;
}
.singlePage .singleContents .pointWrap {
  max-width: 980px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2.5%;
}
.singlePage .singleContents .pointBox {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 4;
  gap: 0;
}
.singlePage .singleContents .pointBox .point {
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px
}
.singlePage .singleContents .pointBox .point span {
  font-size: 4rem;
  font-weight: 700;
  letter-spacing: -1.6px;
}
.singleClrBlu .singlePage .singleContents .pointBox .point {
  color: #63bcde;
}
.singleClrRed .singlePage .singleContents .pointBox .point {
  color: #ff8972;
}
.singleClrGrn .singlePage .singleContents .pointBox .point {
  color: #40ad52;
}
.singleClrPur .singlePage .singleContents .pointBox .point {
  color: #a4add6;
}
.singlePage .singleContents .pointDetails {
  border-radius: 10px;
  padding: 20px 20px 30px;
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 3;
  gap: 0;
}
.singleClrBlu .singlePage .singleContents .pointDetails {
  background: #d7f4ff;
}
.singleClrRed .singlePage .singleContents .pointDetails {
  background: #ffd9d2;
}
.singleClrGrn .singlePage .singleContents .pointDetails {
  background: #d6f4db;
}
.singleClrPur .singlePage .singleContents .pointDetails {
  background: #ebefff;
}
.singlePage .singleContents .pointDetails h3 {
  font-size: 1.8rem;
  font-weight: 700;
  margin-bottom: 10px;
}
.singlePage .singleContents .pointDetails figure {
  margin-bottom: 10px;
}
.singlePage .singleContents .pointDetails .note {
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1.5;
}
.singlePage .titleContents {
  padding-top: 24px;
}
.singlePage .titleContents h2 img {
  max-width: 628px;
}
@media only screen and (max-width:750px) {
  .singleHead::after {
    content: "";
    width: 100%;
    height: 100px;
    position: absolute;
    z-index: 2;
    bottom: 0;
    left: 0;
    background: url(../img/titlesingle_bg_sp.png) no-repeat center bottom;
    background-size: 100%;
  }
  .singleTitle {
    margin-top: -20vw;
    padding: 25vw 0 21.5vw;
  }
  .singleClrBlu .singleTitle {
    background: url(../img/app/title_bg_b_sp.jpg) no-repeat center top;
    background-size: cover;
  }
  .singleClrRed .singleTitle {
    background: url(../img/app/title_bg_r_sp.jpg) no-repeat center top;
    background-size: cover;
  }
  .singleClrGrn .singleTitle {
    background: url(../img/app/title_bg_g_sp.jpg) no-repeat center top;
    background-size: cover;
  }
  .singleClrPur .singleTitle {
    background: url(../img/app/title_bg_p_sp.jpg) no-repeat center top;
    background-size: cover;
  }
  .singleHead .singleTitleWrap {
    max-width: 100%;
    display: block;
  }
  .singleHead .singleTitleWrap .txtBox {
    width: 100%;
    padding: 0 0 9%;
  }
  .singleHead .singleTitleWrap .txtBox h1 {
    margin-bottom: 4.6%;
  }
  .singleHead .singleTitleWrap .txtBox .meta {
    justify-content: space-between;
    margin: 0 3%;
  }
  .singleHead .singleTitleWrap .txtBox .meta .details {
    width: 69.8%;
    margin: 0;
  }
  .singleHead .singleTitleWrap .txtBox .meta .details dl {
    font-size: 3.2vw;
    margin-bottom: 2%;
  }
  .singleHead .singleTitleWrap .txtBox .meta .details dt {
    width: 24vw;
  }
  .singleHead .singleTitleWrap .txtBox .meta .details dd {
    width: calc(100% - 24vw);
    padding: 1.7% 5%;
  }
  .singleHead .singleTitleWrap .txtBox .meta .appIcon {
    width: 22.7%;
  }
  .singleHead .singleTitleWrap .imgBlock {
    width: 94%;
    margin: 0 auto;
  }
  .singleHead .singleTitleWrap .imgBlock .titleImg {
    width: 75%;
  }
  .singleHead .singleTitleWrap .imgBlock .swiper-button-prev,
  .singleHead .singleTitleWrap .imgBlock .swiper-button-next {
    width: 10.66vw;
    height: 10.66vw;
  }
  .singleHead .singleTitleWrap .imgBlock .swiper-pagination {
    bottom: -8.5vw;
  }
  .singleHead .singleTitleWrap .imgBlock .swiper-pagination-bullet {
    margin: 0 2.5vw;
  }
  .singlePage {
    padding: 0;
  }
  .singlePage .singleBlock {
    padding: 11.2% 5% 9.5%;
  }
  .singlePage .singleBlock .lead,
  .singlePage .singleBlock .leads {
    max-width: 100%;
    margin: 0 auto 9.5%;
    font-size: 4.26vw;
  }
  .singlePage .singleBlock .leads p {
    margin-bottom: 11%;
  }
  .singlePage .singleBlock .block {
    max-width: 100%;
    margin: 0 auto 12.5%;
  }
  .singlePage .singleBlock .block figure {
    margin-bottom: 4.2%;
  }
  .singlePage .singleBlock .block figure img {
    min-width: 17.06vw;
  }
  .singlePage .singleBlock .block figure::before {
    margin-right: 4vw;
  }
  .singlePage .singleBlock .block figure::after {
    margin-left: 4vw;
  }
  .singlePage .singleBlock .block h2 {
    text-align: left;
    font-size: 5.86vw;
    margin-bottom: 9.5%;
  }
  .singlePage .singleBlock .block .note,
  .singlePage .singleBlock .block .notes {
    font-size: 4.26vw;
  }
  .singlePage .singleBlock .block .notes p {
    margin-bottom: 11%;
  }
  .singlePage .singleContents .pointBlock {
    padding: 0 4.5% 15%;
    background: url(../img/line_bg11_sp.jpg) no-repeat center bottom #fff;
    background-size: 100%;
  }
  .singlePage .singleContents .pointWrap {
    max-width: 100%;
    display: block;
    gap: 0;
  }
  .singlePage .singleContents .pointBox {
    display: block;
    margin-bottom: 11%;
  }
  .singlePage .singleContents .pointBox .point {
    text-align: center;
    font-size: 5.33vw;
    margin-bottom: 0.5%
  }
  .singlePage .singleContents .pointBox .point span {
    font-size: 10.66vw;
  }
  .singlePage .singleContents .pointDetails {
    padding: 6% 6% 9.5%;
    display: block;
  }
  .singlePage .singleContents .pointDetails h3 {
    font-size: 4.8vw;
    margin-bottom: 3%;
  }
  .singlePage .singleContents .pointDetails figure {
    margin: 0 5% 3%;
  }
  .singlePage .singleContents .pointDetails .note {
    font-size: 3.46vw;
  }
  .singlePage .titleContents {
    padding-top: 9.5%;
  }
  .singlePage .titleContents h2 img {
    max-width: 100%;
  }
}
/* ---------- 利用規約 ---------- */
.termsContents {
  max-width: 980px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.termsContents .block {
  border-bottom: 1px solid #cfcfcf;
  padding: 0 2% 42px;
  margin-bottom: 50px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.termsContents .block:last-of-type {
  border: none;
}
.termsContents .block h2 {
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 1.12px;
  margin-bottom: 30px;
}
.termsContents .block h3 {
  margin: 9px 0 7px;
}
.termsContents .block h4 {
  margin-bottom: 7px;
}
.termsContents .block p {
  margin-bottom: 8px;
}
.termsContents .block p.dots {
  text-indent: -1em;
  padding-left: 1em;
}
.termsContents .block .m {
  margin-bottom: 42px;
}
.termsContents .block span {
  font-size: 1.4rem;
  letter-spacing: 0.56px;
  display: inline-block;
  margin-top: 8px;
}
.termsContents .block dl {
  margin: 10px 0 8px;
}
.termsContents .block dl dt {
  margin-bottom: 7px;
}
.termsContents .block dl dd {
  margin: 0 0 10px 17px;
}
.termsContents .block .box {
  margin: 12px 0 13px;
}
.termsContents .block .box2 {
  margin: 46px 0 34px;
}
.termsContents .block .box2 span {
  margin-top: 0;
}
.termsContents .block .box2 span.caution {
  margin-top: 47px;
}
.termsContents .block .number li {
  text-indent: -2.1em;
  padding-left: 2.1em;
  margin-bottom: 8px;
}
.termsContents .block .subNumber li {
  text-indent: -1.6em;
  padding-left: 2.4em;
}
.termsContents .block .noNumber li {
  text-indent: 0;
  padding-left: 0.6em;
}
.termsContents .block .bracketsNumber li {
  text-indent: -1.7em;
  padding-left: 1.7em;
  margin-bottom: 8px;
}
.termsContents .block .bracketsSubNumber {
  padding: 8px 0;
}
.termsContents .block .bracketsSubNumber li {
  text-indent: -2.7em;
  padding-left: 2em;
}
.termsContents .block .cautionList {
  padding: 36px 0;
}
.termsContents .block .cautionList li {
  text-indent: -1em;
  padding-left: 1em;
  font-size: 1.4rem;
  letter-spacing: 0.56px;
}
.termsContents .block .round {
  padding: 8px 0;
}
.termsContents .block .round li {
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 8px;
}
.termsContents .days {
  text-align: right;
  font-size: 1.3rem;
  position: relative;
  margin-top: -20px;
}
@media only screen and (max-width:750px) {
  .termsContents {
    max-width: 100%;
    padding-top: 5%;
  }
  .termsContents .block {
    padding: 0 6% 12%;
    margin-bottom: 15%;
    font-size: 4.26vw;
  }
  .termsContents .block:last-of-type {
    margin-bottom: 12.5%;
  }
  .termsContents .block h2 {
    font-size: 5.86vw;
    margin-bottom: 10%;
  }
  .termsContents .block h3 {
    margin: 0 0 3%;
  }
  .termsContents .block h4 {
    margin-bottom: 2%;
  }
  .termsContents .block p {
    margin-bottom: 3%;
  }
  .termsContents .block span {
    font-size: 3.73vw;
    margin-top: 3%;
  }
  .termsContents .block dl {
    margin: 0;
  }
  .termsContents .block dl dt {
    margin-bottom: 3%;
  }
  .termsContents .block dl dd {
    margin: 0 0 3% 6%;
  }
  .termsContents .block .box {
    margin: 9.5% 0 10.5%;
  }
  .termsContents .block .box2 {
    margin: 11% 0 10%;
  }
  .termsContents .block .box2 span.caution {
    margin-top: 14%;
  }
  .termsContents .block .m {
    margin-bottom: 11%;
  }
  .termsContents .days {
    font-size: 3.46vw;
    margin-top: -8%;
  }
  .termsContents .block .cautionList {
    padding: 12.4% 0 10%;
  }
  .termsContents .block .cautionList li {
    font-size: 3.73vw;
  }
}
/* ---------- 特定商取引法における表示 ---------- */
.tokushohoContents {
  max-width: 980px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.tokushohoContents .block {
  border-bottom: 1px solid #cfcfcf;
  padding: 0 2% 42px;
  margin-bottom: 50px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.tokushohoContents .block:last-of-type {
  border: none;
}
.tokushohoContents .block h2 {
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 1.12px;
  margin-bottom: 30px;
}
.tokushohoContents .block p {
  margin-bottom: 8px;
}
.tokushohoContents .block p.tel {
  font-size: 2rem;
  letter-spacing: 0.8px;
  margin-bottom: 15px;
}
.tokushohoContents .block span {
  font-size: 1.4rem;
  letter-spacing: 0.56px;
  display: inline-block;
  margin-top: 8px;
}
.tokushohoContents .block ul {
  margin-bottom: 10px;
}
.tokushohoContents .block li {
  display: flex;
}
.tokushohoContents .block li::before {
  content: "・";
  margin-right: 5px;
}
@media only screen and (max-width:750px) {
  .tokushohoContents {
    max-width: 100%;
    padding-top: 5%;
  }
  .tokushohoContents .block {
    padding: 0 6% 12%;
    margin-bottom: 15%;
    font-size: 4.26vw;
  }
  .tokushohoContents .block:last-of-type {
    margin-bottom: 12.5%;
  }
  .tokushohoContents .block h2 {
    font-size: 5.86vw;
    margin-bottom: 10%;
  }
  .tokushohoContents .block p {
    margin-bottom: 3%;
  }
  .tokushohoContents .block p.tel {
    font-size: 5.33vw;
    margin-bottom: 4%;
  }
  .tokushohoContents .block span {
    font-size: 3.73vw;
    margin-top: 3%;
  }
  .tokushohoContents .block ul {
    margin-bottom: 4%;
  }
  .tokushohoContents .block li::before {
    margin-right: 2vw;
  }
}
/* ---------- 個人情報の取り扱いについて ---------- */
.privacyContents {
  max-width: 980px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.privacyContents .lead {
  font-size: 1.8rem;
  line-height: 2;
  letter-spacing: 0.72px;
  padding: 0 2% 35px;
  margin-bottom: 54px;
  border-bottom: double 4px #451603;
}
.privacyContents .block {
  border-bottom: 1px solid #cfcfcf;
  padding: 0 2% 42px;
  margin-bottom: 50px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.privacyContents .block.last {
  border: none;
  padding-bottom: 0;
}
.privacyContents .block h2 {
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 1.12px;
  margin-bottom: 30px;
}
.privacyContents .block p {
  text-indent: 1em;
}
.privacyContents .block p:last-of-type {
  margin-bottom: 8px;
}
.privacyContents .block p.in0 {
  text-indent: 0;
  margin-top: 8px;
}
.privacyContents .block ul {
  margin: 18px 0 20px;
}
.privacyContents .block .typeA {
  margin: 30px 0 10px;
}
.privacyContents .block li {
  display: flex;
}
.privacyContents .block li::before {
  content: "・";
  margin-right: 5px;
}
.privacyContents .block .box {
  margin-top: 26px;
}
.privacyContents .block .box ul {
  margin: 0 0 8px;
}
.privacyContents .contact {
  border: 1px solid #000;
  padding: 20px 2% 18px;
  margin-bottom: 84px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.privacyContents .contact a {
  text-decoration: underline;
}
@media only screen and (max-width:750px) {
  .innerHead .pageTitle.privacyTitle {
    padding: 14.5% 0 24.5%;
  }
  .privacyContents {
    max-width: 100%;
    padding-top: 8%;
  }
  .privacyContents .lead {
    font-size: 4.8vw;
    padding: 0 4% 12%;
    margin-bottom: 15%;
  }
  .privacyContents .block {
    padding: 0 6% 12%;
    margin-bottom: 15%;
    font-size: 4.26vw;
  }
  .privacyContents .block:last-of-type {
    margin-bottom: 12.5%;
  }
  .privacyContents .block h2 {
    font-size: 5.86vw;
    margin-bottom: 10%;
  }
  .privacyContents .block p:last-of-type {
    margin-bottom: 3%;
  }
  .privacyContents .block p.in0 {
    margin-top: 3%;
  }
  .privacyContents .block ul {
    margin: 6% 0 9%;
  }
  .privacyContents .block .typeA {
    margin: 4% 0 4.2%;
  }
  .privacyContents .block li::before {
    margin-right: 2vw;
  }
  .privacyContents .block .box {
    margin-top: 7%;
  }
  .privacyContents .block .box ul {
    margin: 0 0 2.5%;
  }
  .privacyContents .contact {
    padding: 6%;
    margin-bottom: 20%;
    font-size: 4.26vw;
  }
}
/* ---------- お問い合わせ・FAQ ---------- */
.innerHead .pageTitle.faqTitle {
  padding-bottom: 160px;
}
.innerHead .pageTitle.faqTitle .lead {
  max-width: 980px;
  margin: 0 auto;
  padding: 30px 0 18px;
  font-size: 1.8rem;
  line-height: 2;
  text-align: center;
}
.faqContents {
  max-width: 980px;
  margin: -40px auto 0;
  position: relative;
  z-index: 2;
}
.faqContents h2 {
  font-size: 2.8rem;
  text-align: center;
  font-weight: 700;
  margin-bottom: 26px;
}
.faqContents .faqList {
  padding: 12px 3.2% 38px;
  margin-bottom: 112px;
  font-size: 1.6rem;
  letter-spacing: 0.64px;
  border-bottom: 1px solid #451603;
}
.faqContents .faqList li {
  display: inline-block;
  margin: 0 14px 20px 0;
}
.faqContents .faqList li a {
  display: inline-block;
  background: #451603;
  color: #fff;
  border-radius: 100px;
  padding: 4px 20px;
  line-height: 1.3;
}
.faqContents .block {
  margin-bottom: 125px;
}
.faqContents .block h3 {
  text-align: center;
  font-weight: bold;
  font-size: 2.8rem;
  background: #f7f2e1;
  margin-bottom: 28px;
}
.faqContents .faqDetails dt {
  display: flex;
  align-items: center;
  padding: 16px 8% 16px 2%;
  position: relative;
  min-height: 72px;
  border-top: 1px solid #cfcfcf;
  cursor: pointer;
}
.faqContents .faqDetails dt::before,
.faqContents .faqDetails dt::after {
  content: "";
  position: absolute;
  width: 32px;
  height: 4px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2032%204%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23999%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M30%2C4H2C.9%2C4%2C0%2C3.1%2C0%2C2S.9%2C0%2C2%2C0h28c1.1%2C0%2C2%2C.9%2C2%2C2s-.9%2C2-2%2C2Z%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  right: 2.5%;
  top: 0;
  bottom: 0;
  margin: auto;
}
.faqContents .faqDetails dt::after {
  transform: rotate(90deg);
  transition: all .25s ease-in;
}
.faqContents .faqDetails dt.open::after {
  transform: rotate(0deg);
  transition: all .25s ease-in;
}
.faqContents .faqDetails dt:first-of-type {
  border-top: none;
}
.faqContents .faqDetails dt p {
  display: flex;
  font-size: 1.8rem;
  line-height: 1.5;
  letter-spacing: 1.12px;
}
.faqContents .faqDetails dt span {
  font-weight: 700;
  min-width: 72px;
}
.faqContents .faqDetails dd {
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
  overflow: hidden;
  height: 0;
  transition: height 0.3s ease;
}
.faqContents .faqDetails dd p {
  padding: 0 2% 50px;
  word-break: break-all;
}
.faqContents .faqDetails dd a {
  text-decoration: underline;
}
.faqContents .btn {
  max-width: 400px;
  width: 100%;
  margin: 0 auto 80px;
  text-align: center;
}
.faqContents .btn a {
  border-radius: 100px;
  background: #451603;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 1.44px;
  font-weight: 600;
  border: 2px solid #451603;
  position: relative;
  display: block;
  padding: 15px 0;
}
.faqContents .btn a::after {
  content: "";
  transition: all .25s ease-in;
  mask-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2036%2020%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M33.6%2C11.4H2.4c-.8%2C0-1.4-.6-1.4-1.4s.6-1.4%2C1.4-1.4h31.2c.8%2C0%2C1.4.6%2C1.4%2C1.4s-.6%2C1.4-1.4%2C1.4Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M25.2%2C19.4c-.4%2C0-.8-.2-1-.4-.5-.6-.5-1.5%2C0-2l7.3-6.9-7.3-6.9c-.6-.5-.6-1.5%2C0-2%2C.5-.6%2C1.5-.6%2C2%2C0l8.4%2C7.9c.3.3.4.6.4%2C1s-.2.8-.4%2C1l-8.4%2C7.9c-.3.3-.6.4-1%2C.4Z%22%2F%3E%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-position: center;
  background: #fff;
  width: 36px;
  height: 20px;
  position: absolute;
  right: 5%;
  top: 0;
  bottom: 0;
  margin: auto;
}
.faqContents .btn a:hover {
  background: #fff;
  color: #451603;
  opacity: 1;
}
.faqContents .btn a:hover::after {
  background: #451603;
  right: 4%;
}
.faqContents .btn p {
  color: #000;
  font-size: 1.3rem;
  letter-spacing: 0.053px;
  padding-top: 2.4%;
}
@media only screen and (max-width:750px) {
  .innerHead .pageTitle.faqTitle {
    padding-bottom: 23%;
  }
  .innerHead .pageTitle.faqTitle .lead {
    max-width: 90%;
    padding: 10.5% 0 1%;
    font-size: 4.8vw;
    letter-spacing: 0.72px;
    text-align: left;
  }
  .faqContents {
    max-width: 100%;
    margin: 0;
    padding-top: 10.5%;
  }
  .faqContents h2 {
    font-size: 7.46vw;
    margin-bottom: 16%;
  }
  .faqContents .faqList {
    padding: 0 0 9.2%;
    margin-bottom: 29%;
    font-size: 4.26vw;
    line-height: 1.5;
    text-align: center;
  }
  .faqContents .faqList li {
    margin: 0 2% 5.2%;
  }
  .faqContents .faqList li a {
    padding: 1% 5.5vw;
  }
  .faqContents .block {
    margin-bottom: 35.5%;
  }
  .faqContents .block h3 {
    font-size: 7.46vw;
    line-height: 1.5;
    margin-bottom: 8.5%;
  }
  .faqContents .faqDetails dt {
    padding: 6.5% 6%;
    min-height: 0;
  }
  .faqContents .faqDetails dt::before,
  .faqContents .faqDetails dt::after {
    width: 6.9vw;
    height: 1.06vw;
    right: 7%;
    top: 8.4vw;
    bottom: auto;
  }
  .faqContents .faqDetails dt p {
    display: block;
    font-size: 4.8vw;
  }
  .faqContents .faqDetails dt span {
    min-width: 0;
    display: block;
    margin-bottom: 4%;
  }
  .faqContents .faqDetails dd {
    font-size: 4.26vw;
  }
  .faqContents .faqDetails dd p {
    padding: 0 6% 10.5%;
  }
  .faqContents .btn {
    max-width: 93.5%;
    margin: 0 auto 20%;
  }
  .faqContents .btn a {
    font-size: 5.33vw;
    letter-spacing: 0.8px;
    padding: 5.5% 0;
  }
  .faqContents .btn a::after {
    width: 7.46vw;
    height: 4.26vw;
  }
  .faqContents .btn p {
    font-size: 3.46vw;
    letter-spacing: 0.06px;
    padding-top: 3.4%;
  }
}
/* ---------- アプリケーション・プライバシーポリシー ---------- */
.appGuideline {
  max-width: 980px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}
.appGuideline .block {
  border-bottom: 1px solid #cfcfcf;
  padding: 0 2% 42px;
  margin-bottom: 50px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
  word-break: break-all;
}
.appGuideline .block:last-of-type {
  border: none;
}
.appGuideline .block h2 {
  font-size: 2.2rem;
  line-height: 1.5;
  letter-spacing: 1.12px;
  margin-bottom: 30px;
}
.appGuideline .block h3 {
  margin: 15px 0 8px;
  text-indent: -2.7em;
  padding-left: 2.7em;
}
.appGuideline .block p {
  margin-bottom: 8px;
}
.appGuideline .block .indentT {
  padding-left: 2.7em;
  margin-bottom: 15px;
}
.appGuideline .block .parentheses li {
  text-indent: -2.7em;
  padding-left: 2.7em;
}
.appGuideline .block .number {
  margin: 8px 0;
}
.appGuideline .block .number.indentN {
  margin: 8px 0 8px 2.7em;
}
.appGuideline .block .number li {
  text-indent: -1em;
  padding-left: 1em;
}
.appGuideline .block .number li::before {
  display: none;
}
.appGuideline .block .number li p {
  margin: 16px 0;
}
.appGuideline .block .number .dotNumber {
  margin: 8px 0 8px 26px;
}
.appGuideline .block .dotNumber {
  margin: 8px 0 8px 1.5em;
}
.appGuideline .block .dotNumber li {
  list-style-type: disc;
  text-indent: 0;
  padding-left: 0;
}
.appGuideline .contact {
  border: 1px solid #000;
  padding: 20px 2% 18px;
  font-size: 1.6rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.appGuideline .contact a {
  text-decoration: underline;
}
@media only screen and (max-width:750px) {
  .appGuideline {
    max-width: 100%;
    padding-top: 5%;
  }
  .appGuideline .block {
    padding: 0 6% 12%;
    margin-bottom: 15%;
    font-size: 4.26vw;
  }
  .appGuideline .block h2 {
    font-size: 5.86vw;
    margin-bottom: 10%;
  }
  .appGuideline .block h3 {
    margin: 7% 0 3%;
  }
  .appGuideline .block p {
    margin-bottom: 3%;
  }
  .appGuideline .block .indentT {
    margin-bottom: 7%;
  }
  .appGuideline .block .number {
    margin: 3% 0;
  }
  .appGuideline .block .number.indentN {
    margin: 3% 0 3% 2.7em;
  }
  .appGuideline .block .number li p {
    margin: 7% 0;
  }
  .appGuideline .block .number .dotNumber {
    margin: 3% 0 3% 6.5vw;
  }
  .appGuideline .block .dotNumber {
    margin: 3% 0 3% 1.5em;
  }
  .appGuideline .contact {
    padding: 6%;
    font-size: 4.26vw;
  }
}
/* ---------- お問い合わせ ---------- */
.inquiryContents {
  max-width: 980px;
  margin: 0 auto 90px;
  position: relative;
  z-index: 2;
}
.inquiryContents .formBlock {
  max-width: 600px;
  margin: 0 auto 40px;
  font-size: 1.8rem;
}
.inquiryContents .formBlock label {
  display: flex;
  align-items: center;
  margin-bottom: 12px;
}
.inquiryContents .formBlock label span {
  font-weight: bold;
  color: #f00;
  font-size: 1.2rem;
  margin-left: 5px;
  position: relative;
  top: 1px;
}
.inquiryContents .formBlock input,
.inquiryContents .formBlock textarea {
  width: 100%;
  border: 1px solid #a7a7a7;
  background: #fff;
  display: block;
  border-radius: 6px;
  padding: 4px 10px;
  box-sizing: border-box;
}
.inquiryContents .formBlock textarea {
  min-height: 128px;
}
.inquiryContents .errorMessage {
  color: #f00;
  font-size: 1.4rem;
  margin-top: 4px;
}
.inquiryContents input.is-invalid {
  border-color: #f00;
  outline-color: #f00;
}
.inquiryContents .txtLink {
  text-align: center;
  font-size: 1.6rem;
  line-height: 2;
  margin: 40px 0;
}
.inquiryContents .txtLink a {
  text-decoration: underline;
}
.inquiryContents .agreeBlock {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  font-size: 1.8rem;
  margin-bottom: 40px
}
.inquiryContents .agreeBlock input {
  width: 20px;
  height: 20px;
  margin-right: 8px;
  position: relative;
  top: 1px;
  outline: none;
}
.inquiryContents .errorMessage {
  color: #f00;
  font-size: 1.4rem;
  margin-top: 4px;
}
.inquiryContents input.is-invalid {
  border-color: #f00;
  outline-color: #f00;
}
.inquiryContents .agreeBlock .errorMessage {
  width: 100%;
  text-align: center;
}
.inquiryContents .submitBtn {
  border-radius: 100px;
  background: #451603;
  color: #fff;
  font-family: "M PLUS Rounded 1c", sans-serif;
  font-size: 2.8rem;
  letter-spacing: 1.44px;
  font-weight: 600;
  border: 2px solid #451603;
  position: relative;
  display: block;
  padding: 15px 0;
  max-width: 400px;
  width: 100%;
  margin: 0 auto;
}
.inquiryContents .submitBtn:disabled {
  opacity: 0.5;
  pointer-events: none;
}
.inquiryContents .submitBtn::after {
  content: "";
  transition: all .25s ease-in;
  mask-image: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2036%2020%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M33.6%2C11.4H2.4c-.8%2C0-1.4-.6-1.4-1.4s.6-1.4%2C1.4-1.4h31.2c.8%2C0%2C1.4.6%2C1.4%2C1.4s-.6%2C1.4-1.4%2C1.4Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M25.2%2C19.4c-.4%2C0-.8-.2-1-.4-.5-.6-.5-1.5%2C0-2l7.3-6.9-7.3-6.9c-.6-.5-.6-1.5%2C0-2%2C.5-.6%2C1.5-.6%2C2%2C0l8.4%2C7.9c.3.3.4.6.4%2C1s-.2.8-.4%2C1l-8.4%2C7.9c-.3.3-.6.4-1%2C.4Z%22%2F%3E%3C%2Fsvg%3E');
  mask-repeat: no-repeat;
  mask-position: center;
  background: #fff;
  width: 36px;
  height: 20px;
  position: absolute;
  right: 5%;
  top: 0;
  bottom: 0;
  margin: auto;
}
.inquiryContents .submitBtn:hover {
  background: #fff;
  color: #451603;
  opacity: 1;
}
.inquiryContents .submitBtn:hover::after {
  background: #451603;
  right: 4%;
}
@media only screen and (max-width:750px) {
  .inquiryContents {
    max-width: 100%;
    margin: 0 auto;
  }
  .inquiryContents .formBlock {
    max-width: 88%;
    margin: 0 auto 12%;
    font-size: 4.8vw;
  }
  .inquiryContents .formBlock label {
    margin-bottom: 4%;
  }
  .inquiryContents .formBlock label span {
    font-size: 3.2vw;
    margin-left: 1vw;
  }
  .inquiryContents .formBlock input,
  .inquiryContents .formBlock textarea {
    padding: 1.06vw 2.13vw;
  }
  .inquiryContents .txtLink {
    font-size: 3.73vw;
    margin: 12% 0;
  }
  .inquiryContents .agreeBlock {
    font-size: 4.8vw;
    margin-bottom: 12%;
  }
  .inquiryContents .agreeBlock input {
    width: 5.33vw;
    height: 5.33vw;
    margin-right: 3vw;
    top: 1.5px;
  }
  .inquiryContents .errorMessage {
    font-size: 3.73vw;
    margin-top: 1%;
  }
  .inquiryContents .submitBtn {
    max-width: 93.5%;
    margin: 0 auto 26%;
    font-size: 5.33vw;
    letter-spacing: 0.8px;
    padding: 5.5% 0;
  }
  .inquiryContents .submitBtn::after {
    width: 7.46vw;
    height: 4.26vw;
  }
}
/* ---------- Thanks ---------- */
.thanksPage {
  max-width: 980px;
  margin: 0 auto 90px;
}
.thanksPage .lead {
  text-align: center;
  font-size: 2.4rem;
  line-height: 1.6;
  letter-spacing: 1.12px;
  margin-bottom: 30px;
}
.thanksPage ul {
  margin-bottom: 50px;
  font-size: 1.4rem;
  line-height: 1.8;
  letter-spacing: 0.64px;
}
.thanksPage li {
  text-indent: -1em;
  padding-left: 1em;
}
@media only screen and (max-width:750px) {
  .thanksPage {
    max-width: 100%;
    margin: 0 auto;
  }
  .thanksPage .lead {
    font-size: 4.6vw;
    letter-spacing: 0.5px;
    margin-bottom: 10%;
  }
  .thanksPage ul {
    margin-bottom: 15%;
    font-size: 3.73vw;
  }
}
/* ---------- TOPページに戻る ---------- */
.topReturn {
  padding-bottom: 30px;
}
.appBlock .topReturn {
  margin-top: 56px;
}
.topReturn a {
  display: block;
  max-width: 280px;
  line-height: 1;
  width: 100%;
  text-align: center;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.8px;
  font-family: "M PLUS Rounded 1c", sans-serif;
  color: #fff;
  background: #a59b97;
  border-radius: 100px;
  margin: 0 auto;
  padding: 14px 0;
  position: relative;
}
.topReturn a::before {
  content: "";
  width: 20px;
  height: 10px;
  background: url('data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20data-name%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20version%3D%221.1%22%20viewBox%3D%220%200%2020%2010%22%3E%20%3Cdefs%3E%20%3Cstyle%3E%20.st0%20%7B%20fill%3A%20%23fff%3B%20%7D%20%3C%2Fstyle%3E%20%3C%2Fdefs%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M18.3%2C5.8H1.7c-.4%2C0-.8-.3-.8-.8s.3-.8.8-.8h16.6c.4%2C0%2C.8.3.8.8s-.3.8-.8.8Z%22%2F%3E%20%3Cpath%20class%3D%22st0%22%20d%3D%22M6.2%2C10c-.2%2C0-.4%2C0-.5-.2L1.2%2C5.6c-.2-.1-.2-.3-.2-.6s0-.4.2-.6L5.6.2c.3-.3.8-.3%2C1.1%2C0%2C.3.3.3.8%2C0%2C1.1l-3.9%2C3.7%2C3.9%2C3.7c.3.3.3.8%2C0%2C1.1-.2.2-.4.2-.6.2Z%22%2F%3E%3C%2Fsvg%3E') no-repeat;
  background-size: contain;
  position: absolute;
  left: 5%;
  top: 0;
  bottom: 0;
  margin: auto;
}
@media only screen and (max-width:750px) {
  .topReturn {
    padding-bottom: 22.5%;
  }
  .appBlock .topReturn {
    margin-top: 0;
    padding-bottom: 18%;
  }
  .topReturn a {
    max-width: 82%;
    font-size: 5.33vw;
    padding: 4% 0;
  }
  .topReturn a::before {
    width: 5.33vw;
    height: 2.66vw;
    left: 5%;
  }
}
/* =========================================================
  Footer
========================================================= */
.footer {
  padding: 30px 3% 0;
  text-align: center;
  color: #fff;
  background: #2f661c;
}
.footer ul {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  max-width: 780px;
  margin: 0 auto 30px;
}
.footer li {
  margin: 0 10px 18px;
}
.footer li a {
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 0.56px;
}
.footer .logoImg {
  display: flex;
  justify-content: center;
  margin-bottom: 30px;
}
.footer .neosLogo {
  max-width: 200px;
  margin: 0 30px;
}
.footer .neosLogo figure {
  display: flex;
  height: 104.5px;
  align-items: center;
}
.footer .mark {
  margin: 0 30px;
}
.footer .mark figure {
  max-width: 210px;
  margin: 0 auto 8px;
}
.footer .mark p {
  font-size: 1.1rem;
  line-height: 1.8;
}
.footer .copyright {
  font-size: 1.1rem;
  letter-spacing: 0.56px;
}
.footer .copyright p {
  padding-bottom: 30px;
}
@media only screen and (max-width:750px) {
  .footer {
    padding: 1% 0 0;
  }
  .footer ul {
    display: block;
    margin-bottom: 8%;
  }
  .footer li {
    margin: 0 0 2.5%;
  }
  .footer li a {
    font-size: 3.73vw;
  }
  .footer .logoImg {
    display: block;
    margin-bottom: 0;
  }
  .footer .neosLogo {
    max-width: 53%;
    margin: 0 auto 8%;
  }
  .footer .mark {
    margin-bottom: 8%;
  }
  .footer .mark figure {
    max-width: 56%;
    margin: 0 auto 2%;
  }
  .footer .mark p {
    font-size: 2.93vw;
  }
  .footer .copyright {
    font-size: 2.93vw;
  }
  .footer .copyright p {
    padding-bottom: 8.5%;
  }
}