* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
}
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;
}
body {
  font-size: 16px;
  line-height: 1.5;
  color: #111;
  font-family: "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN",
    "ＭＳ Ｐゴシック", sans-serif, "Droid Sans", "Arial";
  border-top: 10px solid #c21500;
  border-image: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
  border-image-slice: 1;
  -webkit-text-size-adjust: 100%;
  margin: 0;
}
img {
  border: 0;
  vertical-align: bottom;
}
a:link {
  color: #111;
  text-decoration: underline;
  cursor: pointer;
}
a:visited {
  color: #111;
  text-decoration: none;
  cursor: pointer;
}
a:hover {
  color: #111;
  text-decoration: none;
  cursor: pointer;
}
a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha(opacity=80)";
  -moz-opacity: 0.8;
}
em {
  font-style: inherit;
}
.pc {
  display: none;
}
.sp {
  display: block;
}
.hover {
  opacity: 0.8;
  filter: alpha(opacity=80);
  -ms-filter: "alpha(opacity=80)";
  -moz-opacity: 0.8;
}
pre {
  margin: 0;
  padding: 0;
  border: 0;
}
.clearfix {
  *zoom: 1;
}
.clearfix:before,
.clearfix:after {
  display: table;
  content: "";
}
.clearfix:after {
  clear: both;
}
.listnone li {
  list-style: none;
}
.texindent {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
}
.contents {
  width: 93%;
  margin: 0 auto;
  *zoom: 1;
}
.contents:before,
.contents:after {
  display: table;
  content: "";
}
.contents:after {
  clear: both;
}
.gradation {
  background: #fff2ad;
  /* Old browsers */
  background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
  /* IE6-9 */
}
.h2-home {
  margin-bottom: 10px;
  font-size: 7.692vw;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.03em;
  text-align: center;
}
.h2-home + p {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
}
.h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
.h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
.h3 {
  background: #000;
  padding: 18px 0;
  font-size: 30px;
  line-height: 1;
  font-weight: normal;
  text-align: center;
  color: #fff;
  margin-bottom: 20px;
}
.triangle-y50 {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 40px solid transparent;
  border-left: 40px solid transparent;
  border-top: 20px solid #fff2ad;
  border-bottom: 0;
  margin: 0 auto 20px;
}
.triangle-r50 {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 40px solid transparent;
  border-left: 40px solid transparent;
  border-top: 20px solid #ffcabf;
  border-bottom: 0;
  margin: 0 auto 20px;
}
.triangle-r {
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 40px solid transparent;
  border-left: 40px solid transparent;
  border-top: 20px solid #e8383d;
  border-bottom: 0;
  margin: 0 auto 20px;
}
.button-normal {
  border: none;
  outline: none;
  margin: 0 auto 14px;
}
.button-normal a {
  display: block;
  background: #e8383d;
  padding: 16px 0;
  font-size: 5.128vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  box-shadow: 5px 5px 0 0 #000000;
}
.button-normal a:active {
  -ms-transform: translateY(2px);
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  box-shadow: none;
}
.button-normal a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -khtml-opacity: 0.7;
  -moz-opacity: 0.7;
}
.button-normal + p {
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0;
}
.glay {
  background: #eaebeb;
  padding: 40px 0;
}
header {
  margin: 0 0 20px 0;
}
.header-home .logo {
  width: 300px;
  margin: 30px auto 30px;
}
.header-home .logo a img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.header-home .mainvisual {
  width: 100%;
  height: 0;
  padding-top: 92.67%;
  margin: 0 0 30px 0;
  background-image: url("../images/mainvisual-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
.header-home .top {
  width: 85%;
  height: 0;
  padding-top: 32%;
  margin: 0 auto;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  background-image: url("../images/eyecatch-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
.header-lower .logo {
  width: 70%;
  margin: 30px 0;
}
.header-lower .logo a img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
.header-lower .balloon {
  width: 100%;
}
.header-lower .balloon img {
  position: absolute;
  top: 40px;
  right: 3%;
  width: 27%;
}
.header-lower .movie {
  background: #000;
  text-align: center;
  padding: 40px 0;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 30px;
  aspect-ratio: 1.77777778;
}
.header-lower .movie iframe {
  width: 90%;
  height: 100%;
}
.header-lower .kikoeru {
  width: 90%;
  height: 0;
  padding-top: 21%;
  margin: 0 auto;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  background-image: url("../images/howtouse1/eyecatch-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
.header-lower .kikoenai {
  width: 67%;
  height: 0;
  padding-top: 21%;
  margin: 0 auto;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  background-image: url("../images/howtouse2/eyecatch-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
.header-lower .kv {
  margin-top: 24px;
  text-align: center;
}
.header-lower .kv img {
  max-width: 100%;
}
#footer-link {
  margin: 40px 0 0 0;
}
#footer-link .contents {
  width: 100%;
}
#footer-link .contents ul {
  text-align: center;
}
#footer-link .contents ul li {
  display: inline-block;
  vertical-align: top;
  zoom: 1;
  margin-right: 0;
  font-size: 18px;
  width: 100%;
}
#footer-link .contents ul li a {
  text-decoration: none;
  padding: 10px 0;
  display: block;
  background: #84919e;
  color: #fff;
}
#footer-link .contents ul li:after {
  content: none;
  margin-left: 0;
}
#footer-link .contents ul li:first-child:before {
  content: none;
  margin-right: 0;
}
#footer-link .contents ul li:nth-child(1) {
  border-bottom: 1px solid #fff;
}
#footer-link .contents ul li:nth-child(2) {
  width: 50%;
  float: left;
  border-right: 1px solid #fff;
}
#footer-link .contents ul li:nth-child(3) {
  width: 50%;
  float: right;
}
#pagetop {
  background: #e8383d;
  text-align: center;
}
#pagetop a {
  display: block;
  padding: 10px 0;
  font-size: 16px;
  color: #fff;
  text-decoration: none;
}
#pagetop a:hover {
  text-decoration: underline;
}
#pagetop a::before {
  content: url(../images/icon-pagetop-sp.png);
  vertical-align: middle;
  padding-right: 10px;
}
footer {
  background: #fff2ad;
  /* Old browsers */
  background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
  /* IE6-9 */
  text-align: center;
  padding: 20px 0;
  font-size: 3.7vw;
  margin-bottom: 81px;
}
footer .operation hr {
  width: 40%;
  margin: 20px auto 20px;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
}
#home #nav .contents .default {
  width: 100%;
  height: auto;
  padding: 30px 10px;
  background: #fff;
}
#home #nav .contents .point {
  background: #eaebeb;
  padding: 14px 20px;
  margin: 0 0 25px 0;
  font-size: 18px;
  line-height: 1.3;
  -webkit-border-radius: 10px;
  border-radius: 10px;
}
#home #nav .contents .point p {
  height: auto;
  padding: 0 0 0 64px;
  display: table-cell;
  vertical-align: middle;
  position: relative;
}
#home #nav .contents .point p:before {
  font-family: "Font Awesome 6 Free";
  content: "\f058";
  font-weight: 900;
  font-size: 44px;
  line-height: 1;
  position: absolute;
  top: 0;
  left: 0;
}
#home #nav .contents .headline {
  float: none;
  width: 100%;
  height: auto;
  text-align: center;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: -0.04em;
  margin: 0 0 10px 0;
}
#home #nav .contents .headline br {
  display: none;
}
#home #nav .contents .headline p {
  margin: 0;
}
#home #nav .contents .app {
  float: none;
  width: 90%;
  margin: 0 auto 20px;
  *zoom: 1;
}
#home #nav .contents .app:before,
#home #nav .contents .app:after {
  display: table;
  content: "";
}
#home #nav .contents .app:after {
  clear: both;
}
#home #nav .contents .app .ios {
  width: 43.8%;
  float: left;
  text-align: center;
}
#home #nav .contents .app .ios img {
  text-align: center;
}
#home #nav .contents .app .ios a img {
  width: 135px;
}
#home #nav .contents .app .android {
  width: 51%;
  float: right;
  text-align: center;
}
#home #nav .contents .app .android img {
  text-align: center;
}
#home #nav .contents .app .android a img {
  width: 164px;
}
#home #nav .contents .illust {
  width: 100%;
  height: auto;
  display: flex;
  align-items: center;
  justify-content: center;
}
#home #nav .contents .illust img {
  width: 43%;
  margin: 0 auto;
  padding-bottom: 30px;
}
#home #nav .contents button {
  border: none;
  outline: none;
  margin: 0 auto 14px;
  width: 100%;
}
#home #nav .contents button a {
  display: block;
  background: #e8383d;
  padding: 16px 0;
  font-size: 5.128vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  box-shadow: 5px 5px 0 0 #000000;
}
#home #nav .contents button a:active {
  -ms-transform: translateY(2px);
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  box-shadow: none;
}
#home #nav .contents button a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -khtml-opacity: 0.7;
  -moz-opacity: 0.7;
}
#home #nav .contents button + p {
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0;
}
#home #nav .contents .kikoenai {
  width: 100%;
  height: auto;
  padding: 30px 10px;
  background: #fff;
  float: none;
  margin-bottom: 20px;
}
#home #nav .contents .kikoenai h2 {
  margin-bottom: 10px;
  font-size: 7.692vw;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #nav .contents .kikoenai h2 + p {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
}
#home #nav .contents .kikoeru {
  width: 100%;
  height: auto;
  padding: 30px 10px;
  background: #fff;
  float: none;
}
#home #nav .contents .kikoeru h2 {
  margin-bottom: 10px;
  font-size: 7.692vw;
  font-weight: 400;
  line-height: 1;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #nav .contents .kikoeru h2 + p {
  margin-bottom: 20px;
  font-size: 14px;
  line-height: 1.8;
  text-align: center;
}
#home #nav .contents .kikoeru h2 + p {
  margin-bottom: 0;
}
#home #about {
  padding: 30px 10px;
}
#home #about h2 {
  margin-bottom: 17px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #about h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#home #about .about-lead {
  margin-bottom: 20px;
  text-align: center;
  font-size: 5.86666667vw;
  font-weight: 600;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
#home #about .about-lead em {
  padding: 0.3em 0 0 0.3em;
  background: linear-gradient(transparent 10%, #fff2ad 10%);
}
#home #about .about-txt {
  font-size: 4.26666667vw;
  margin-bottom: 20px;
  text-align: center;
}
#home #about .about-txt span {
  background: linear-gradient(transparent 10%, #fff2ad 10%);
}
#home #about h3 {
  text-align: center;
  margin-bottom: 25px;
  font-size: 4.8vw;
  letter-spacing: 0.08em;
  font-weight: 700;
  margin-bottom: 25px;
}
#home #about .movie {
  text-align: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 32px;
  aspect-ratio: 1.77777778;
}
#home #about .movie iframe {
  width: 100%;
  height: 100%;
}
#home #about .cta-area {
  background-color: #eaebeb;
  border-radius: 30px;
  padding: 60px 20px;
  margin-bottom: 50px;
}
#home #about .cta-area .cta-area_txt {
  position: relative;
  text-align: center;
  width: max-content;
  margin-inline: auto;
  letter-spacing: 0.08em;
  font-weight: 700;
  font-size: 19px;
  padding-bottom: 40px;
  font-style: normal;
}
#home #about .cta-area .cta-area_txt .be-heard {
  background: #f1c739;
  padding: 0 5px;
  font-style: inherit;
}
#home #about .cta-area .cta-area_txt .no-be-heard {
  background: #6dc7f3;
  padding: 0 5px;
  font-style: inherit;
}
#home #about .cta-area .cta-area_ttl {
  text-align: center;
  font-size: 20px;
}
#home #about .cta-area .cta-area_logo {
  width: 155px;
  margin-inline: auto;
  margin-bottom: 28px;
}
#home #about .cta-area .cta-area_logo img {
  object-fit: contain;
  height: auto;
  max-width: 100%;
}
#home #about .cta-area .cta-area_txt02 {
  text-align: center;
  margin-bottom: 40px;
}
#home #about .cta-area .cta-area_btn {
  width: 100%;
  text-align: center;
  margin-inline: auto;
}
#home #about .cta-area .cta-area_btn + .cta-area_btn {
  margin-top: 20px;
}
#home #about .cta-area .cta-area_btn a {
  display: block;
  height: 100%;
  padding: 10px 0 10px 25px;
  text-decoration: none;
  background-color: #fff;
  border-radius: 40px;
  text-align: left;
  position: relative;
}
#home #about .cta-area .cta-area_btn a::after {
  content: "";
  display: block;
  width: 21px;
  height: 12.5px;
  background-image: url(../images/arrow.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}
#home #about .cta-area .cta-area_btn.be-heard_btn a {
  background-color: #6dc7f3;
}
#home #about .cta-area .cta-area_btn.no-be-heard_btn a {
  background-color: #f1c739;
}
#home #about .cta-area .cta-area_btn a em {
  display: block;
  font-weight: 600;
  font-size: 20px;
  font-style: initial;
}
#home #about .cta-area .cta-area_btn {
  width: 307px;
  max-width: 100%;
}
#home #about .app {
  width: calc(100% + 7%);
  padding: 60px 20px;
  margin-left: -3.5%;
  background: #e8383d;
  border-radius: 20px;
}
#home #about .app h2 {
  margin-bottom: 20px;
  text-align: center;
  font-size: 5.86666667vw;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.8;
  color: #fff;
}
#home #about .app img {
  max-width: 100%;
}
#home #about .app .container {
  display: flex;
  flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 20px 43px;
}
#home #about .app figure {
  flex-basis: 468px;
  margin: 0 auto;
}
#home #about .app figure div {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 22px 20px;
  background: #fff;
  border-radius: 20px;
}
#home #about .app figure img {
  width: 46.93333333vw;
  max-width: 100%;
}
#home #about .app p {
  color: #fff;
}
#home #about .app .btn-wrapper {
  max-width: 307px;
  margin: 0 auto;
}
#home #about .app .btn-container {
  display: grid;
  grid-template-columns: 133px 165px;
  gap: 0 2.66666667vw;
  padding: 0 3px 0 0;
  margin-bottom: 16px;
}
#home #about .app .btn-apple {
  max-width: 133px;
}
#home #about .app .btn-apple p,
#home #about .app .btn-google p {
  margin-bottom: 5px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
#home #about .app .btn-google {
  max-width: 165px;
}
#home #about .app .annotation {
  max-width: 307px;
  margin: 14px auto 0;
  color: #fff;
  font-size: 16px;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
#home #about .registration {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 307px;
  height: 74px;
  padding: 15px 0 8px 30px;
  margin: 0 auto;
  text-decoration: none;
  background-color: #fff;
  border-radius: 40px;
  text-align: left;
  position: relative;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.05em;
}
#home #about .registration::after {
  content: "";
  display: block;
  width: 21px;
  height: 12.5px;
  background-image: url(../images/arrow.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}

#home #case {
  padding: 30px 0;
}
#home #case h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #case h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#home #case h2 br {
  display: block;
}
#home #case h2 + p {
  font-size: 24px;
  font-weight: normal;
  text-align: center;
  margin-bottom: 20px;
}
#home #case h2 + p br {
  display: block;
}
#home #case .case-list ul li {
  list-style: none;
}
#home #case .case-list ul li {
  background: #fff;
  padding: 20px 30px;
  margin-bottom: 14px;
  *zoom: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
#home #case .case-list ul li:before,
#home #case .case-list ul li:after {
  display: table;
  content: "";
}
#home #case .case-list ul li:after {
  clear: both;
}
#home #case .case-list ul li img {
  float: none;
  margin-right: 0;
  width: 200px;
}
#home #case .case-list ul li .element {
  width: 100%;
  text-align: center;
}
#home #case .case-list ul li .element h3 {
  font-size: 6.154vw;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 4px;
}
#home #case .case-list ul li .element h3 + p {
  font-size: 4.615vw;
  line-height: 1.5;
}
#home #case .case-list ul li:nth-child(even) {
  flex-direction: column-reverse;
}
#home #case .case-list ul li:nth-child(even) img {
  float: none;
  margin-left: 40px;
}
#home #case .case-list ul li:last-of-type {
  margin-bottom: 0;
}

#home #case .transition {
  width: 90%;
  margin: 0 auto;
  *zoom: 1;
}
#home #case .transition:before,
#home #case .transition:after {
  display: table;
  content: "";
}
#home #case .transition:after {
  clear: both;
}
#home #case .transition .left {
  width: 100%;
  float: none;
}
#home #case .transition .right {
  width: 100%;
  float: none;
}
#home #case .transition button {
  border: none;
  outline: none;
  margin: 0 auto 14px;
  width: 100%;
}
#home #case .transition button a {
  display: block;
  background: #e8383d;
  padding: 16px 0;
  font-size: 5.128vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  box-shadow: 5px 5px 0 0 #000000;
}
#home #case .transition button a:active {
  -ms-transform: translateY(2px);
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  box-shadow: none;
}
#home #case .transition button a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -khtml-opacity: 0.7;
  -moz-opacity: 0.7;
}
#home #case .transition button + p {
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0;
}
#home #case .transition .none {
  display: none;
}
#home #case .transition .mgn {
  margin-bottom: 24px;
}

#home #qa {
  padding: 30px 0;
}
#home #qa h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #qa h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#home #qa .qa-list {
  margin-bottom: 50px;
}
#home #qa .qa-list ul li {
  list-style: none;
}
#home #qa .qa-list ul li {
  border-bottom: 1px dotted #8c98a4;
  margin-bottom: 24px;
}
#home #qa .qa-list ul li ul li {
  font-size: 4.615vw;
  margin-left: 3rem;
  margin-bottom: 24px;
  border: none;
}
#home #qa .qa-list ul li ul li:before {
  content: "Q.";
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1;
  margin-right: 16px;
  margin-left: -3rem;
  vertical-align: baseline;
}
#home #qa .qa-list ul li ul li:nth-child(even) {
  font-size: 4.615vw;
  margin-left: 3rem;
}
#home #qa .qa-list ul li ul li:nth-child(even):before {
  content: "A.";
  font-size: 7.692vw;
  font-weight: normal;
  color: #e8383d;
  line-height: 1;
  margin-right: 16px;
  margin-left: -3rem;
  vertical-align: baseline;
}
#home #qa .qa-list ul li:last-child {
  border: none;
}
#home #qa .link {
  text-align: center;
  position: relative;
  width: 70%;
  margin: 0 auto;
  padding: 16px 0;
}
#home #qa .link a {
  font-size: 4.348vw;
  line-height: 1;
  padding: 0 0 0 50px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#home #qa .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 39px;
  line-height: 1.2;
  position: absolute;
  top: 0;
  left: 0;
}
#home #system {
  padding: 30px 0;
}
#home #system h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#home #system h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#home #system h2 br {
  display: block;
}
#home #system .logo {
  margin: 0 auto 40px;
  width: 270px;
}
#home #system .logo img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
#home #system p {
  font-size: 4.615vw;
  line-height: 1.6;
  margin-bottom: 25px;
}
#home #system p span {
  background: linear-gradient(transparent 10%, #fff2ad 10%);
}
#home #system .visual h3 {
  font-size: 5.6vw;
  font-weight: 700;
  line-height: normal;
  text-align: center;
  letter-spacing: 0.05em;
}
#home #system .visual .item {
  position: relative;
  padding: 4vw;
  border-radius: 2.66666667vw;
  background: var(--image-bg);
  color: var(--image-color);
  text-align: center;
}

#home #system .visual .item::before {
  position: absolute;
  width: 4vw;
  height: 2.66666667vw;
  background: url(../images/visual-arrow.svg) no-repeat;
  background-size: contain;
  content: "";
}

#home #system .visual .item.red {
  --image-bg: #f3c5bd;
  --image-color: #111;
}

#home #system .visual .item.white {
  --image-bg: #f3c5bd;
  --image-color: #fff;
}

#home #system .visual .item.orange {
  --image-bg: #fff;
  --image-color: #f28e01;
}

#home #system .visual .wrapper {
  display: grid;
  grid-template-rows: auto auto auto auto;
  grid-template-columns: 1fr 32vw;
  grid-template-areas: "player01 player01" "player02 player05" "player03 player05" "player04 player04";
  margin-top: 6.4vw;
  gap: 8vw 5.33333333vw;
}

#home #system .visual .item01 {
  grid-area: player01;
}

#home #system .visual .item01::before {
  bottom: -5.33333333vw;
  left: 24.8vw;
}

#home #system .visual .item02 {
  grid-area: player02;
  padding-bottom: 1.6vw;
}

#home #system .visual .item02::before {
  bottom: -5.33333333vw;
  left: 24.8vw;
}

#home #system .visual .item03 {
  grid-area: player03;
}

#home #system .visual .item03::before {
  bottom: -5.33333333vw;
  left: 24.8vw;
}

#home #system .visual .item04 {
  grid-area: player04;
  padding: 7.46666667vw;
  background: #fff;
  border: 0.8vw solid var(--image-bg);
}

#home #system .visual .item04::before {
  display: none;
}

#home #system .visual .item04 h4 {
  font-size: 4.26666667vw;
  color: #111;
}

#home #system .visual .item05 {
  grid-area: player05;
  padding: 5.33333333vw 0 7.46666667vw 1.33333333vw;
  border: 0.8vw solid var(--image-color);
}

#home #system .visual .item05::before {
  top: 9.06666667vw;
  bottom: initial;
  left: -5.5vw;
  rotate: 90deg;
}

#home #system .visual .item05::after {
  position: absolute;
  bottom: 9.33333333vw;
  left: -5.5vw;
  width: 4vw;
  height: 2.66666667vw;
  rotate: 90deg;
  background: url(../images/visual-arrow.svg) no-repeat;
  background-size: contain;
  content: "";
}

#home #system .visual .item05 img {
  width: 16.26666667vw;
  margin: 0 auto;
}

#home #system .visual .item05 h4 {
  margin-top: 1.86666667vw;
  font-weight: 600;
  font-size: 4.26666667vw;
}

#home #system .visual .item05 p {
  padding-left: 2vw;
  margin-top: 1.06666667vw;
  line-height: 1.4;
  letter-spacing: 0;
  text-align: left;
  color: #111;
}

#home #system .visual .item h4 {
  font-weight: 600;
  font-size: 4.26666667vw;
  line-height: normal;
  letter-spacing: 0;
}

#home #system .visual .item .text {
  margin-bottom: 0;
  font-size: 3.2vw;
}

#home #system .visual .item .annotation {
  position: absolute;
  margin: 0;
  bottom: -6.93333333vw;
  left: 1.6vw;
  font-size: 3.46666667vw;
  font-weight: 700;
  color: #111;
  letter-spacing: 0.05em;
}
#contact {
  padding: 30px 0 0 0;
}
#contact h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#contact h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#contact h3 {
  font-size: 32px;
  line-height: 1.3;
  font-weight: normal;
  margin-bottom: 26px;
  text-align: center;
}
#contact h3 span {
  display: block;
  font-size: 18px;
  margin: 0;
}
#contact h3 + p {
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 24px;
  text-align: center;
}
#contact h3 + p span {
  display: block;
  margin: 0;
}
#contact .tel {
  margin-bottom: 40px;
}
#contact .tel ul {
  background: #fff2ad;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  display: block;
  justify-content: center;
  text-align: center;
  padding: 30px 0;
}
#contact .tel ul li {
  list-style: none;
}
#contact .tel ul li {
  width: 100%;
  font-size: 7.246vw;
  line-height: 1.3;
}
#contact .tel ul li a {
  text-decoration: none;
}
#contact .other table {
  width: 88%;
  margin: 0 auto 20px;
  border-spacing: 0;
}
#contact .other table tr {
  height: auto;
}
#contact .other table th,
#contact .other table td {
  display: block;
  width: 100%;
}
#contact .other table th {
  width: 100%;
  height: 60px;
  font-size: 24px;
  line-height: 1.3;
  font-weight: normal;
  border-left: 5px solid #000;
  border-right: none;
  padding: 0 0 0 20px;
  text-align: left;
  display: flex;
  align-items: center;
}
#contact .other table td {
  font-size: 16px;
  height: auto;
  line-height: 1.3;
  padding: 10px 0 20px 0;
  text-align: left;
}
#contact .form {
  background: #ffcabf;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  padding: 30px 20px;
  *zoom: 1;
  position: relative;
  text-align: center;
}
#contact .form:before,
#contact .form:after {
  display: table;
  content: "";
}
#contact .form:after {
  clear: both;
}
#contact .form h3 {
  font-size: 30px;
  line-height: 1.2;
  font-weight: normal;
  text-align: center;
  margin-bottom: 14px;
}
#contact .form h3 span {
  font-size: 24px;
}
#contact .form h3 + a {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.03em;
  display: block;
  margin-bottom: 30px;
}
#contact .form img {
  position: initial;
  top: 20px;
  right: 80px;
}
#contact-headline {
  padding: 30px 0 30px 0;
}
#contact-headline h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
  margin-bottom: 0;
}
#contact-headline h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#contact-kikoenai {
  padding: 30px 0 0 0;
}
#contact-kikoenai h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#contact-kikoenai h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#contact-kikoenai h3 {
  font-size: 32px;
  line-height: 1.3;
  font-weight: normal;
  margin-bottom: 26px;
  text-align: center;
}
#contact-kikoenai h3 span {
  display: block;
  font-size: 18px;
  margin: 0;
}
#contact-kikoenai h3 + p {
  font-size: 18px;
  line-height: 1.3;
  margin-bottom: 24px;
  text-align: center;
}
#contact-kikoenai h3 + p span {
  display: block;
  margin: 0;
}
#contact-kikoenai .tel ul {
  -webkit-border-radius: 10px;
  border-radius: 10px;
  display: block;
  justify-content: center;
  text-align: center;
  padding: 0;
}
#contact-kikoenai .tel ul li {
  list-style: none;
}
#contact-kikoenai .tel ul li {
  width: 100%;
  font-size: 7.246vw;
  line-height: 1.3;
}
#contact-kikoenai .tel ul li a {
  text-decoration: none;
}
#contact-kikoenai .other table {
  width: 100%;
  margin: 0 auto 10px;
  border-spacing: 20px;
  background: #fff2ad;
  -webkit-border-radius: 10px;
  border-radius: 10px;
}
#contact-kikoenai .other table tr {
  height: auto;
}
#contact-kikoenai .other table th,
#contact-kikoenai .other table td {
  display: block;
  width: 100%;
}
#contact-kikoenai .other table th {
  width: 100%;
  height: 60px;
  font-size: 24px;
  line-height: 1.3;
  font-weight: normal;
  border-left: 5px solid #000;
  border-right: none;
  padding: 0 0 0 20px;
  text-align: left;
  display: flex;
  align-items: center;
}
#contact-kikoenai .other table td {
  font-size: 16px;
  height: auto;
  line-height: 1.3;
  padding: 10px 0 0 0;
  text-align: left;
}
#contact-kikoenai .form {
  -webkit-border-radius: 10px;
  border-radius: 10px;
  padding: 30px 20px;
  *zoom: 1;
  position: relative;
  text-align: center;
}
#contact-kikoenai .form:before,
#contact-kikoenai .form:after {
  display: table;
  content: "";
}
#contact-kikoenai .form:after {
  clear: both;
}
#contact-kikoenai .form h3 {
  font-size: 30px;
  line-height: 1.2;
  font-weight: normal;
  text-align: center;
  margin-bottom: 14px;
}
#contact-kikoenai .form h3 span {
  font-size: 24px;
}
#contact-kikoenai .form h3 + a {
  font-size: 16px;
  line-height: 1;
  letter-spacing: 0.03em;
  display: block;
  margin-bottom: 30px;
}
#contact-kikoenai .form img {
  position: initial;
  top: 20px;
  right: 80px;
}
#kikoeru #what {
  padding: 30px 0;
  margin-top: 50px;
}
#kikoeru #what h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoeru #what h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoeru #what h2 + p {
  margin-bottom: 20px;
  font-size: 18px;
  line-height: 1.5;
  text-align: center;
}
#kikoeru #what .visual {
  margin-bottom: 30px;
}
#kikoeru #what .visual img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
#kikoeru #what button {
  width: 100%;
  border: none;
  outline: none;
  margin: 0 auto 14px;
  display: block;
  background: #e8383d;
  padding: 25px 0;
  font-size: 4.615vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  -webkit-border-radius: 10px;
  border-radius: 10px;
}
#kikoeru #what button span {
  font-size: 6.154vw;
  line-height: 1;
  color: #fff2ad;
}
#kikoeru #know {
  padding: 30px 0;
}
#kikoeru #know h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoeru #know h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoeru #know .logo {
  margin: 0 auto 30px;
  width: 90%;
}
#kikoeru #know .logo img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
#kikoeru #know table {
  width: 100%;
  border-collapse: collapse;
  margin-bottom: 30px;
  background: #fff2ad;
  /* Old browsers */
  background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
  /* IE6-9 */
  text-align: center;
}
#kikoeru #know table tr {
  border-bottom: 14px solid #fff;
}
#kikoeru #know table th,
#kikoeru #know table td {
  display: block;
}
#kikoeru #know table th {
  width: 100%;
  font-size: 12.308vw;
  line-height: 1;
  font-weight: normal;
  text-align: center;
  padding: 30px 20px 10px 20px;
  vertical-align: middle;
}
#kikoeru #know table td {
  text-align: center;
  font-size: 4.615vw;
  line-height: 1.3;
  font-weight: normal;
  padding: 0 20px 30px 20px;
  vertical-align: middle;
}
#kikoeru #know .movie {
  text-align: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 30px;
  aspect-ratio: 1.77777778;
}
#kikoeru #know .movie iframe {
  width: 100%;
  height: 100%;
}
#kikoeru #know h3 {
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  height: 206px;
  margin-bottom: 10px;
  background-image: url("../images/howtouse1/illust-relay-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 247px auto;
  -moz-background-size: 247px auto;
}
#kikoeru #know .link {
  text-align: center;
  position: relative;
  width: 86%;
  margin: 0 auto;
  padding: 16px 0;
}
#kikoeru #know .link a {
  font-size: 4vw;
  line-height: 1;
  padding: 0 0 0 43px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#kikoeru #know .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 33px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoeru #put {
  padding: 30px 0;
}
#kikoeru #put h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoeru #put h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoeru #put h2 + p {
  font-size: 18px;
  margin-bottom: 20px;
  text-align: center;
}
#kikoeru #put img {
  width: 100%;
  max-width: 100%;
  height: auto;
  margin-bottom: 20px;
}
#kikoeru #put button {
  border: none;
  outline: none;
  margin: 0 auto 14px;
  width: 100%;
}
#kikoeru #put button a {
  display: block;
  background: #e8383d;
  padding: 16px 0;
  font-size: 5.128vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  box-shadow: 5px 5px 0 0 #000000;
}
#kikoeru #put button a:active {
  -ms-transform: translateY(2px);
  -webkit-transform: translateY(2px);
  transform: translateY(2px);
  box-shadow: none;
}
#kikoeru #put button a:hover {
  opacity: 0.7;
  filter: alpha(opacity=70);
  -ms-filter: "alpha(opacity=70)";
  -khtml-opacity: 0.7;
  -moz-opacity: 0.7;
}
#kikoeru #put button + p {
  text-align: center;
  text-decoration: none;
  font-size: 14px;
  letter-spacing: 0.04em;
  margin: 0;
}
#kikoeru #note {
  padding: 30px 0;
}
#kikoeru #note h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoeru #note h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoeru #note ul li {
  list-style: none;
}
#kikoeru #note ul li {
  font-size: 4.8vw;
  line-height: 1.3;
  padding: 0 0 0 50px;
  margin: 0 0 16px 0;
  vertical-align: middle;
  position: relative;
}
#kikoeru #note ul li:before {
  font-family: "Font Awesome 6 Free";
  content: "\f05a";
  color: #84919e;
  font-weight: 900;
  font-size: 39px;
  line-height: 1;
  position: absolute;
  top: 2%;
  left: 0;
}
#kikoeru #note ul li ul {
  margin-top: 6px;
}
#kikoeru #note ul li ul li {
  list-style: disc;
  font-size: 3.8vw;
  line-height: 1.2;
  padding: 0;
  margin: 0 0 4px 20px;
  vertical-align: middle;
  position: static;
}
#kikoeru #note ul li ul li:before {
  content: none;
}
#kikoeru #note .link {
  text-align: center;
  position: relative;
  width: 56%;
  margin: 0 auto;
  padding: 16px 0;
}
#kikoeru #note .link a {
  font-size: 4vw;
  line-height: 1;
  padding: 0 0 0 43px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#kikoeru #note .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 33px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoenai .appdl {
  padding: 0 0 30px 0;
}
#kikoenai .appdl .contents {
  background: #e8383d;
  text-align: center;
  padding: 30px 30px;
  color: #fff;
}
#kikoenai .appdl .contents .mark {
  margin-bottom: 34px;
}
#kikoenai .appdl .contents .mark img {
  width: 37%;
}
#kikoenai .appdl .contents .headline {
  margin-bottom: 40px;
}
#kikoenai .appdl .contents .headline h3 {
  font-size: 7.692vw;
  line-height: 1;
  font-weight: normal;
  margin-bottom: 10px;
}
#kikoenai .appdl .contents .headline h3 + p {
  font-size: 4.359vw;
  line-height: 1.3;
}
#kikoenai .appdl .contents .headline h3 + p a {
  color: #fff;
}
#kikoenai .appdl .contents h4 {
  font-size: 18px;
  line-height: 1;
  padding: 0 0 0 26px;
  margin-bottom: 10px;
  position: relative;
}
#kikoenai .appdl .contents h4:before {
  content: "";
  position: absolute;
  top: 40%;
  left: 0;
  transform: translateY(-50%);
  border: 10px solid transparent;
  border-left: 17px solid #fff;
}
#kikoenai .appdl .contents .dl {
  width: 60%;
}
#kikoenai .appdl .contents .ios {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: left;
  margin-bottom: 36px;
}
#kikoenai .appdl .contents .android {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: left;
}
#kikoenai #idea h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoenai #idea .idea-list ul {
  display: block;
  margin-bottom: 110px;
}
#kikoenai #idea .idea-list ul li {
  width: 100%;
  list-style: none;
  background-color: #fff;
  border-radius: 30px;
  padding-top: 30px;
  overflow: hidden;
}
#kikoenai #idea .idea-list ul li + li {
  margin-top: 87.5px;
}
#kikoenai #idea .idea-list ul li img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
#kikoenai #idea .idea-list {
}
#kikoenai #idea .idea-list .idea-content {
  display: none;
}
#kikoenai #idea .idea-list .idea-list-ttl {
  text-align: center;
  color: #222;
  background-color: #6dc7f3;
  padding: 2px 5px;
  letter-spacing: 0.08em;
  width: max-content;
  margin-inline: auto;
  font-size: 19px;
  margin-bottom: 10px;
}
#kikoenai #idea .idea-list .idea-list-txt {
  font-weight: 700;
  text-align: center;
  font-size: 20px;
  letter-spacing: 0.08em;
}
#kikoenai #idea .idea-list-txt_movie iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 347 / 196;
  margin-bottom: 25px;
}
#kikoenai #idea .idea-list-txt02 {
  text-align: center;
  letter-spacing: 0.08em;
  margin-bottom: 27.5px;
}
#kikoenai #idea .idea-list-desc {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  padding: 0 20px;
  margin-bottom: 39px;
}
#kikoenai #idea .idea-content {
  padding: 11px 20px 60px;
}
#kikoenai #idea .idea-content-txt {
  margin-bottom: 25px;
}
#kikoenai #idea .idea-content-txt-block {
  display: block;
  margin-top: 25px;
}
#kikoenai #idea dt {
  font-weight: 700;
  margin-bottom: 30px;
}
#kikoenai #idea dl div + div {
  margin-top: 22.5px;
}
#kikoenai #idea .idea-list-more {
  background-color: #6dc7f3;
  text-align: center;
  padding: 22.5px 0;
  line-height: 1;
  letter-spacing: 0.12em;
  position: relative;
  margin-bottom: 0;
  cursor: pointer;
}
#kikoenai #idea .idea-list-more::before,
#kikoenai #idea .idea-list-more::after {
  content: "";
  display: block;
  width: 20px;
  height: 3px;
  background-color: #222;
  position: absolute;
  right: 20px;
  top: 50%;
  translate: 0 -50%;
  transition: translate 0.3s ease;
}
#kikoenai #idea .idea-list-more::before {
  transform: rotate(90deg);
}
#kikoenai #idea .idea-list-more.is-open::before {
  transform: rotate(0);
}
#kikoenai #idea .idea-list-more button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  font-weight: 700;
  position: relative;
  color: currentColor;
  font-size: 16px;
}
#kikoenai #idea .idea-list-more button::before {
  content: "";
  display: block;
  width: 16px;
  height: 21px;
  background-image: url(../images/icon-text.svg);
  background-position: center;
  background-size: contain;
  background-repeat: no-repeat;
  position: absolute;
  left: -5px;
  top: 50%;
  transform: translate(-100%, -50%);
}
#kikoenai #useful {
  padding: 30px 0;
}
#kikoenai #useful h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoenai #useful h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoenai #useful .case-list {
  margin-bottom: 40px;
}
#kikoenai #useful .case-list ul li {
  list-style: none;
}
#kikoenai #useful .case-list ul li {
  background: #fff;
  padding: 20px 30px;
  margin-bottom: 14px;
  *zoom: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
#kikoenai #useful .case-list ul li:before,
#kikoenai #useful .case-list ul li:after {
  display: table;
  content: "";
}
#kikoenai #useful .case-list ul li:after {
  clear: both;
}
#kikoenai #useful .case-list ul li img {
  float: none;
  margin-right: 0;
  width: 200px;
}
#kikoenai #useful .case-list ul li .element {
  width: 100%;
  text-align: center;
}
#kikoenai #useful .case-list ul li .element h3 {
  font-size: 6.154vw;
  line-height: 1.4;
  font-weight: normal;
  margin-bottom: 4px;
}
#kikoenai #useful .case-list ul li .element h3 + p {
  font-size: 4.615vw;
  line-height: 1.5;
}
#kikoenai #useful .case-list ul li:nth-child(even) {
  flex-direction: column-reverse;
}
#kikoenai #useful .case-list ul li:nth-child(even) img {
  float: none;
  margin-left: 40px;
}
#kikoenai #use {
  padding: 30px 0;
}
#kikoenai #use h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoenai #use h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoenai #use .movie {
  text-align: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 30px;
  aspect-ratio: 1.77777778;
}
#kikoenai #use .movie iframe {
  width: 100%;
  height: 100%;
}
#kikoenai #use h3 {
  width: 100%;
  margin: 0 auto 14px;
  display: block;
  background: #e8383d;
  padding: 40px 0 30px 0;
  font-size: 4.615vw;
  line-height: 1;
  font-weight: normal;
  color: #fff;
  text-align: center;
  text-decoration: none;
  -webkit-border-radius: 10px;
  border-radius: 10px;
}
#kikoenai #use h3 span {
  font-size: 9.231vw;
  line-height: 1.5;
  color: #fff2ad;
  padding-top: 10px;
}
#kikoenai #use .step3 {
  width: 100%;
  height: 0;
  padding-top: 420%;
  margin: 0 auto 40px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  background-image: url("../images/howtouse2/figure-3step-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
#kikoenai #use .easy {
  width: 335px;
  height: 0;
  padding-top: 82%;
  margin: 0 auto 16px;
  text-indent: 100%;
  white-space: nowrap;
  overflow: hidden;
  display: block;
  background-image: url("../images/howtouse2/figure-easy-sp.png");
  background-repeat: no-repeat;
  background-position: top center;
  background-size: 100% auto;
  -moz-background-size: 100% auto;
}
#kikoenai #use .read {
  width: 87%;
  margin: 0 auto 20px;
  font-size: 4.615vw;
  line-height: 1.3;
  text-align: center;
}
#kikoenai #use .read p {
  padding-top: 14px;
  font-size: 3.59vw;
  line-height: 1.3;
}
#kikoenai #use .manual {
  background: #fff;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  border: 10px solid #eaebeb;
  padding: 30px 20px;
}
#kikoenai #use .manual h4 {
  font-size: 24px;
  line-height: 1.3;
  font-weight: normal;
  text-align: center;
  margin-bottom: 30px;
}
#kikoenai #use .manual ul li {
  list-style: none;
}
#kikoenai #use .manual ul li {
  width: 100%;
  font-size: 4vw;
  line-height: 1.3;
  padding: 0 0 0 46px;
  position: relative;
  margin-bottom: 20px;
}
#kikoenai #use .manual ul li:before {
  font-family: "Font Awesome 6 Free";
  content: "\f1c1";
  font-size: 36px;
  line-height: 1;
  font-weight: 400;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoenai #use .manual ul li span {
  font-size: 14px;
}
#kikoenai #use .manual ul li:last-child {
  margin-bottom: 0;
}
#kikoenai #use .manual .link {
  text-align: center;
  position: relative;
  width: 86%;
  margin: 0 auto;
  padding: 16px 0;
}
#kikoenai #use .manual .link a {
  font-size: 4vw;
  line-height: 1;
  padding: 0 0 0 43px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#kikoenai #use .manual .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 33px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoenai #price {
  padding: 30px 0;
}
#kikoenai #price h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
  margin-bottom: 10px;
}
#kikoenai #price h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoenai #price h2 + p {
  margin-bottom: 20px;
  font-size: 18px;
  line-height: 1.5;
  text-align: center;
}
#kikoenai #price .area {
  *zoom: 1;
  margin-bottom: 20px;
}
#kikoenai #price .area:before,
#kikoenai #price .area:after {
  display: table;
  content: "";
}
#kikoenai #price .area:after {
  clear: both;
}
#kikoenai #price .area .left {
  float: none;
  width: 100%;
  background: #fff;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  padding: 40px 20px 20px 20px;
  margin-bottom: 10px;
}
#kikoenai #price .area .left h3 {
  text-align: center;
  font-size: 24px;
  line-height: 1;
  font-weight: normal;
  -webkit-border-radius: 30px;
  border-radius: 30px;
  padding: 14px 0;
  /*margin-bottom: 50px;*/
  margin-bottom: 30px;
  background: #fff2ad;
}
#kikoenai #price .area .right {
  float: none;
  width: 100%;
  background: #fff;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  padding: 40px 20px 20px 20px;
}
#kikoenai #price .area .right h3 {
  text-align: center;
  font-size: 24px;
  line-height: 1;
  font-weight: normal;
  -webkit-border-radius: 30px;
  border-radius: 30px;
  padding: 14px 0;
  /*margin-bottom: 50px;*/
  margin-bottom: 30px;
  background: #ffcabf;
}
#kikoenai #price .area .default {
  width: 100%;
  background: #fff;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  padding: 40px 20px;
}
#kikoenai #price .area .h3 {
  text-align: center;
  font-size: 24px;
  line-height: 1;
  font-weight: normal;
  -webkit-border-radius: 30px;
  border-radius: 30px;
  padding: 14px 0;
  margin-bottom: 50px;
}
#kikoenai #price .area ul li {
  list-style: none;
}
#kikoenai #price .area ul li {
  /*font-size: 18px;*/
  font-size: 16px;
  line-height: 1;
  margin-bottom: 16px;
}
#kikoenai #price .area ul li span {
  /*font-size: 24px;*/
  font-size: 22px;
  margin-left: 20px;
}
#kikoenai #price .area ul li:nth-child(4n) {
  color: #e8383d;
}
#kikoenai #price .link {
  text-align: center;
  position: relative;
  width: 56%;
  margin: 0 auto 20px;
  padding: 16px 0;
}
#kikoenai #price .link a {
  font-size: 4vw;
  line-height: 1;
  padding: 0 0 0 43px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#kikoenai #price .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 33px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoenai #price .appdl {
  padding: 0;
}
#kikoenai #price .appdl .contents {
  width: 100%;
}
#kikoenai #register {
  padding: 30px 0;
}
#kikoenai #register h2 {
  margin-bottom: 30px;
  font-size: 7.692vw;
  font-weight: normal;
  line-height: 1.2;
  letter-spacing: 0.03em;
  text-align: center;
}
#kikoenai #register h2 .icon {
  padding: 0 0 0 88px;
  background-repeat: no-repeat;
  background-position: 0 35%;
  background-size: 78px auto;
  -moz-background-size: 78px auto;
}
#kikoenai #register .movie {
  text-align: center;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  margin-bottom: 30px;
  aspect-ratio: 1.77777778;
}
#kikoenai #register .movie iframe {
  width: 100%;
  height: 100%;
}
#kikoenai #register .manual ul li {
  list-style: none;
}
#kikoenai #register .manual ul li {
  width: 100%;
  font-size: 4vw;
  line-height: 1.3;
  padding: 0 0 0 60px;
  position: relative;
  margin-bottom: 40px;
}
#kikoenai #register .manual ul li:before {
  font-family: "Font Awesome 6 Free";
  content: "\f772";
  font-size: 43px;
  line-height: 1;
  font-weight: 900;
  position: absolute;
  top: -55%;
  left: 0;
}
#kikoenai #register .manual ul li span {
  font-size: 14px;
}
#kikoenai #register .manual ul li:last-child {
  margin-bottom: 0;
}
#kikoenai #register .manual ul li:last-child:before {
  content: "\f1c1";
  font-weight: 400;
  top: -10%;
  left: 2%;
}
#kikoenai #register .manual .link {
  text-align: center;
  position: relative;
  width: 86%;
  margin: 0 auto;
  padding: 16px 0;
}
#kikoenai #register .manual .link a {
  font-size: 4vw;
  line-height: 1;
  padding: 0 0 0 43px;
  display: table-cell;
  vertical-align: middle;
  white-space: nowrap;
}
#kikoenai #register .manual .link a:before {
  font-family: "Font Awesome 6 Free";
  content: "\f059";
  font-weight: 900;
  font-size: 33px;
  line-height: 1.4;
  position: absolute;
  top: 0;
  left: 0;
}
#kikoenai .movie iframe,
#kikoeru .movie iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 375 / 209;
}
#kikoenai h2,
#kikoeru h2 {
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 20px;
  margin-top: 40px;
  letter-spacing: 0.08em;
}
#kikoenai .mobie-ttl,
#kikoeru .mobie-ttl,
#home #about .mobie-ttl {
  font-size: 20px;
  margin-bottom: 30px;
  font-weight: 700;
}
#kikoenai .mobie-ttl em,
#kikoeru .mobie-ttl em,
#home #about .mobie-ttl {
  display: block;
  font-size: 22px;
  margin-top: 10px;
  font-style: inherit;
}
#kikoenai .description,
#kikoeru .description {
  text-align: center;
  margin-bottom: 70px;
  line-height: 2;
}
#kikoenai .description span,
#kikoeru .description span {
  background: linear-gradient(transparent 10%, #fff2ad 10%);
}
#kikoenai .application_download_annotation {
  margin-bottom: 30px;
  text-align: center;
}
.adulation {
  position: fixed;
  z-index: 10;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
  width: 100%;
  text-align: center;
  color: #111;
  font-weight: 700;
  transition: height 0.3s ease, padding 0.3s ease;
  background: #eaebeb;
  padding: 32.5px 14px;
}
.adulation::before {
  content: "";
  display: block;
  width: 100%;
  height: 81px;
  background: #e8383d;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.adulation_logo {
  content: "";
  width: 44px;
  aspect-ratio: 1;
  background-color: #fff;
  border-radius: 5px;
  position: absolute;
  top: 18px;
  left: 14px;
  transition: opacity 0.3s ease;
  display: grid;
  place-items: center;
}
.adulation_logo img {
  width: 28px;
  height: 22.5px;
  transition: opacity 0.3s ease;
}
.adulation img {
  max-width: 100%;
}
.adulation_content {
  display: none;
  padding: 32.5px 14px;
}
.adulation_btn {
  position: absolute;
  top: 30px;
  right: 13.5px;
  width: 20px;
  aspect-ratio: 1;
  transition: opacity 0.3s ease;
  background-color: transparent;
  border: none;
}
.adulation_btn::before,
.adulation_btn::after {
  content: "";
  display: block;
  width: 20px;
  height: 3px;
  background-color: #fff;
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  transition: transform 0.3s ease;
}
.adulation_btn::after {
  transform: rotate(90deg);
}
.adulation_desc {
  border-radius: 20px;
  overflow: hidden;
  margin-bottom: 40px;
  background-color: #fff;
  padding: 30px 40px;
}
.adulation_btn_close {
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
  position: absolute;
  top: 0px;
  left: 50%;
  width: 60px;
  transform: translateX(-50%);
  aspect-ratio: 1;
  border-radius: 50%;
  background-color: #fff;
  transition: background 0.3s ease;
  border: none;
}
.adulation_btn_close::before,
.adulation_btn_close::after {
  content: "";
  display: block;
  width: 30px;
  height: 6px;
  background-color: #111;
  position: absolute;
  left: 50%;
  top: 50%;
  translate: -50% -50%;
  transition: transform 0.3s ease;
}
.adulation_btn_close::before {
  transform: rotate(45deg);
}
.adulation_btn_close::after {
  transform: rotate(-45deg);
}
.adulation_download {
  transition: opacity 0.3s ease;
  line-height: 1;
  letter-spacing: 0.04em;
  color: #fff;
}
.adulation_txt {
  font-size: 24px;
  font-weight: 700;
  margin-bottom: 10px;
  position: relative;
  text-align: center;
  width: max-content;
  max-width: 100%;
  margin-inline: auto;
}
.adulation_txt::before {
  content: "";
  display: block;
  width: 55.5px;
  height: 40px;
  background-image: url(../images/icon_check.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  top: -10px;
  transform: translateX(-60%);
}
.adulation_annotation {
  font-weight: 400;
  margin-bottom: 37px;
}
.adulation_logo02 {
  width: 125px;
  margin-inline: auto;
  background-color: #fff;
  border-radius: 10px;
  padding: 15px 12.5px;
  margin-bottom: 35px;
}
.adulation_right_img {
  width: 246.5px;
  margin-inline: auto;
}
.adulation_right_img img {
  width: 100%;
}
.adulation_right_img + .adulation_right_img {
  margin-top: 20px;
}
.adulation.is-open::before {
  display: none;
}
.adulation.is-open .adulation_btn {
  opacity: 0;
}
.adulation.is-open .adulation_btn_close {
  opacity: 1;
  visibility: visible;
}
.adulation.is-open .adulation_download {
  display: none;
}
.adulation.is-open .adulation_logo {
  opacity: 0;
}
.adulation.is-open {
  overflow: auto;
  max-height: 100%;
  padding-top: 80px;
  background: linear-gradient(180deg, transparent 2%, #eaebeb 2%);
}
.adulation.is-open :where(a, .adulation_btn_close) {
  pointer-events: visible;
}
.application_download {
  background-color: #e8383d;
  padding: 60px 0 40px;
}

.application_download_inner {
  width: 93%;
  margin-inline: auto;
}

.application_download_desc {
  background-color: #fff;
  border-radius: 20px;
  padding: 35px 0;
  margin-bottom: 40px;
}

.application_download_desc img {
  width: 70.67%;
  margin-inline: auto;
  display: block;
}

.application_download_txt {
  color: #fff;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  position: relative;
  margin-bottom: 15px;
  width: max-content;
  margin-inline: auto;
}

.application_download_txt::before {
  content: "";
  display: block;
  content: "";
  display: block;
  width: 55.5px;
  height: 40px;
  background-image: url(../images/icon_check.png);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  left: 0;
  top: -10px;
  transform: translateX(-60%);
}

.application_download_annotation {
  color: #fff;
  font-size: 14px;
  padding-left: 20px;
  margin-bottom: 35px;
}

.application_download_logo02 {
  width: 125px;
  margin-inline: auto;
  background-color: #fff;
  border-radius: 10px;
  padding: 15px 12.5px;
  margin-bottom: 32px;
}

.application_download_right_img {
  width: 246.5px;
  margin-inline: auto;
}

.application_download_right_img img {
  width: 100%;
}

.application_download_right_img + .application_download_right_img {
  margin-top: 20px;
}

.application_download_flex {
  margin-bottom: 40px;
}

.application_download_link {
  color: #fff;
  text-align: center;
}

.application_download_link a {
  color: currentColor;
  padding-bottom: 20px;
  text-decoration: none;
  border-bottom: 2px solid #fff;
  padding-right: 30px;
  letter-spacing: 0.12em;
  font-weight: 700;
  position: relative;
}

.application_download_link a::after {
  content: "";
  display: block;
  width: 15px;
  height: 8.5px;
  background-image: url(../images/arrow_wh.svg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  position: absolute;
  right: 0;
  top: 7px;
}

.application_download_img {
  width: 246.5px;
  margin-inline: auto;
}

.application_download_img + .application_download_img {
  margin-top: 20px;
}

.application_download_img_app {
  margin-bottom: 35px;
}

.btn {
  width: 100%;
  text-align: center;
  margin-inline: auto;
}

.btn a {
  display: block;
  height: 100%;
  padding: 10px 0;
  text-decoration: none;
  background-color: #fff;
  border-radius: 40px;
  text-align: left;
  position: relative;
  text-align: center;
}

.btn a em {
  display: block;
  font-weight: 700;
  font-size: 20px;
  font-style: initial;
}

.btn a::after {
  content: "";
  display: block;
  width: 14px;
  height: 17px;
  background-image: url(../images/icon-blank.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
  position: absolute;
  top: 50%;
  right: 24px;
  transform: translateY(-50%);
}

.btn.idea-list-blank a {
  background-color: #6dc7f3;
}

#kikoenai .movie {
  margin-bottom: 50px;
}

.about-img {
  padding-bottom: 40px;
}

.about-img img {
  max-width: 100%;
}

.reference-mark {
  display: block;
  width: 100%;
  text-align: left;
  font-size: 3.8vw;
  display: flex;
}

@media screen and (min-width: 600px) {
  .contents {
    width: 93%;
    margin: 0 auto;
    *zoom: 1;
  }
  .contents:before,
  .contents:after {
    display: table;
    content: "";
  }
  .contents:after {
    clear: both;
  }
  footer {
    font-size: 2.7vw;
    margin-bottom: 0;
  }
  header .top {
    width: 70%;
    height: 0;
    padding-top: 27%;
    margin: 0 auto;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/eyecatch-sp.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  #home #nav .contents .point {
    background: #eaebeb;
    padding: 14px 20px;
    margin: 0 0 25px 0;
    font-size: 18px;
    line-height: 1.3;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #home #nav .contents .point p {
    height: auto;
    padding: 0 0 0 44px;
    display: table-cell;
    vertical-align: middle;
    position: relative;
  }
  #home #nav .contents .point p:before {
    font-family: "Font Awesome 6 Free";
    content: "\f058";
    font-weight: 900;
    font-size: 24px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #home #nav .contents .headline {
    float: none;
    width: 100%;
    height: auto;
    text-align: center;
    font-size: 18px;
    line-height: 1.2;
    letter-spacing: -0.04em;
    margin: 0 0 10px 0;
  }
  #home #nav .contents .headline br {
    display: none;
  }
  #home #nav .contents .headline p {
    margin: 0;
  }
  #home #nav .contents .app {
    float: none;
    width: 57%;
    margin: 0 auto 20px;
    *zoom: 1;
  }
  #home #nav .contents .app:before,
  #home #nav .contents .app:after {
    display: table;
    content: "";
  }
  #home #nav .contents .app:after {
    clear: both;
  }
  #home #nav .contents .app .android {
    width: 51%;
    float: right;
    text-align: center;
  }
  #home #nav .contents .app .android img {
    text-align: center;
  }
  #home #nav .contents .app .android a img {
    width: 164px;
  }
  #home #nav .contents .illust {
    width: 100%;
    height: auto;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #home #nav .contents .illust img {
    width: 43%;
    margin: 0 auto;
    padding-bottom: 30px;
  }
  #home #nav .contents button {
    border: none;
    outline: none;
    margin: 0 auto 14px;
    width: 100%;
  }
  #home #nav .contents button a {
    display: block;
    background: #e8383d;
    padding: 16px 0;
    font-size: 5.128vw;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    box-shadow: 5px 5px 0 0 #000000;
  }
  #home #nav .contents button a:active {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: none;
  }
  #home #nav .contents button a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
    -khtml-opacity: 0.7;
    -moz-opacity: 0.7;
  }
  #home #nav .contents button + p {
    text-align: center;
    text-decoration: none;
    font-size: 14px;
    letter-spacing: 0.04em;
    margin: 0;
  }
  #home #nav .contents .kikoenai {
    float: none;
    margin-bottom: 20px;
  }
  #home #nav .contents .kikoenai h2 {
    margin-bottom: 10px;
    font-size: 7.692vw;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.03em;
    text-align: center;
  }
  #home #nav .contents .kikoenai h2 + p {
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.8;
    text-align: center;
  }
  #home #nav .contents .kikoeru {
    float: none;
  }
  #home #nav .contents .kikoeru h2 {
    margin-bottom: 10px;
    font-size: 7.692vw;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.03em;
    text-align: center;
  }
  #home #nav .contents .kikoeru h2 + p {
    margin-bottom: 20px;
    font-size: 14px;
    line-height: 1.8;
    text-align: center;
  }
  #home #nav .contents .kikoeru h2 + p {
    margin-bottom: 0;
  }
  #contact .tel ul {
    background: #fff2ad;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    display: block;
    justify-content: center;
    text-align: center;
    padding: 30px 0;
  }
  #contact .tel ul li {
    list-style: none;
  }
  #contact .tel ul li {
    width: 100%;
    font-size: 6vw;
    line-height: 1.3;
  }
  #contact .tel ul li a {
    text-decoration: none;
  }
  #kikoenai #use .easy {
    width: 335px;
    height: 0;
    padding-top: 32%;
    margin: 0 auto 16px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse2/figure-easy-sp.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  #kikoenai .appdl .contents .ios {
    width: 45%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: left;
    margin: 0 auto 36px;
  }
  #kikoenai .appdl .contents .android {
    width: 45%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: left;
    margin: 0 auto;
  }
}
@media screen and (min-width: 1025px) {
  * {
    margin: 0;
    padding: 0;
  }
  body {
    border-top: 20px solid #c21500;
  }
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  .contents {
    width: 1095px;
    margin: 0 auto;
    *zoom: 1;
    position: relative;
  }
  .contents:before,
  .contents:after {
    display: table;
    content: "";
  }
  .contents:after {
    clear: both;
  }
  .gradation {
    background: #fff2ad;
    /* Old browsers */
    background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
    /* IE6-9 */
  }
  .h2-home {
    margin-bottom: 10px;
    font-size: 48px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  .h2-home + p {
    margin-bottom: 17px;
    font-size: 16px;
    line-height: 1.8;
    text-align: center;
  }
  .h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  .h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  .h3 {
    background: #000;
    padding: 18px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    text-align: center;
    color: #fff;
    margin-bottom: 20px;
  }
  .triangle-y50 {
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 71px solid transparent;
    border-left: 71px solid transparent;
    border-top: 38px solid #fff2ad;
    border-bottom: 0;
    margin: 0 auto 23px;
  }
  .triangle-r50 {
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 71px solid transparent;
    border-left: 71px solid transparent;
    border-top: 38px solid #ffcabf;
    border-bottom: 0;
    margin: 0 auto 23px;
  }
  .triangle-r {
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 71px solid transparent;
    border-left: 71px solid transparent;
    border-top: 38px solid #e8383d;
    border-bottom: 0;
    margin: 0 auto 34px;
  }
  .button-normal {
    border: none;
    outline: none;
    margin: 0 auto 20px;
  }
  .button-normal a {
    display: block;
    background: #e8383d;
    padding: 22px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    box-shadow: 8px 8px 0 0 #000000;
  }
  .button-normal a:active {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: none;
  }
  .button-normal a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
    -khtml-opacity: 0.7;
    -moz-opacity: 0.7;
  }
  .button-normal + p {
    text-align: center;
    text-decoration: none;
    font-size: 18px;
    letter-spacing: 0.04em;
  }
  .glay {
    background: #eaebeb;
    padding: 40px 0;
  }
  header {
    margin: 0 0 30px 0;
  }
  .header-home .logo {
    /*width: 678px;*/
    width: 500px;
    margin: 30px auto 30px;
  }
  .header-home .logo a img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  .header-home .mainvisual {
    width: 100%;
    height: 0;
    padding-top: 37.63%;
    margin: 0 0 0px 0;
    background-image: url("../images/mainvisual.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-home .top {
    /*width: 80%;*/
    width: 60%;
    height: 0;
    /*padding: 11.5% 0 0 0;*/
    padding: 8.8% 0 0 0;
    margin: 0 auto;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/eyecatch.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-home .kikoeru {
    width: 839px;
    height: 66px;
    margin: 0 auto;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse1/eyecatch.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-lower .logo {
    /*width: 678px;*/
    width: 500px;
    margin: 30px auto 30px;
  }
  .header-lower .logo a img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  .header-lower .mainvisual {
    width: 100%;
    height: 0;
    padding-top: 33.8%;
    margin: 0 0 30px 0;
    background-image: url("../images/mainvisual.jpg");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-lower .kikoeru {
    /*width: 839px;*/
    width: 700px;
    height: 66px;
    /*margin: 0 auto 50px;*/
    margin: 0 auto 10px;
    padding: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse1/eyecatch.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-lower .kikoenai {
    /*width: 839px;*/
    width: 700px;
    height: 66px;
    /*margin: 0 auto 30px;*/
    margin: 0 auto 10px;
    padding: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse2/eyecatch.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  .header-lower .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    width: 100%;
    /*margin: 0 auto 60px;*/
    margin: 0 auto 40px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  .header-lower .movie iframe {
    width: 740px;
    height: 414px;
  }
  .header-lower .balloon {
    width: calc(100% + -950px);
  }
  .header-lower .balloon img {
    position: absolute;
    top: 60px;
    right: -65px;
    width: 208px;
  }
  #footer-link {
    margin: 80px 0 12px 0;
  }
  #footer-link .contents ul {
    text-align: center;
  }
  #footer-link .contents ul li {
    display: inline;
    vertical-align: top;
    zoom: 1;
    margin-right: 24px;
    font-size: 18px;
    text-decoration: none;
  }
  #footer-link .contents ul li a {
    text-decoration: none;
    padding: 0;
    display: inline;
    background: none;
    color: #000;
  }
  #footer-link .contents ul li:after {
    content: "|";
    margin-left: 24px;
  }
  #footer-link .contents ul li:first-child:before {
    content: "|";
    margin-right: 24px;
  }
  #footer-link .contents ul li:nth-child(1) {
    border: none;
  }
  #footer-link .contents ul li:nth-child(2) {
    width: auto;
    float: none;
    border: none;
  }
  #footer-link .contents ul li:nth-child(3) {
    width: auto;
    float: none;
  }
  #pagetop {
    background: #e8383d;
    text-align: center;
  }
  #pagetop a {
    display: block;
    padding: 10px 0;
    font-size: 18px;
    color: #fff;
    text-decoration: none;
  }
  #pagetop a:hover {
    text-decoration: underline;
  }
  #pagetop a::before {
    content: url(../images/icon-pagetop.png);
    vertical-align: middle;
    padding-right: 10px;
  }
  footer {
    background: #fff2ad;
    /* Old browsers */
    background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
    /* IE6-9 */
    text-align: center;
    padding: 30px 0;
    font-size: 18px;
  }
  footer .operation hr {
    width: 14%;
    margin: 20px auto 20px;
    border-top: 1px solid #fff;
    border-bottom: 1px solid #fff;
  }
  #home #nav .contents .default {
    width: 49.4%;
    height: auto;
    padding: 40px 35px;
    background: #fff;
  }
  #home #nav .contents .point {
    background: #eaebeb;
    padding: 16px 30px;
    margin: 0 0 25px 0;
    font-size: 22px;
    line-height: 1.3;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #home #nav .contents .point p {
    height: 57px;
    padding: 0 0 0 76px;
    display: table-cell;
    vertical-align: middle;
    position: relative;
  }
  #home #nav .contents .point p:before {
    font-family: "Font Awesome 6 Free";
    content: "\f058";
    font-weight: 900;
    font-size: 56px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #home #nav .contents .headline {
    float: left;
    width: 160px;
    height: 170px;
    text-align: center;
    font-size: 18px;
    line-height: 1.2;
    letter-spacing: -0.04em;
  }
  #home #nav .contents .headline p {
    padding: 4px 0 0 0;
  }
  #home #nav .contents .app {
    float: right;
    width: 300px;
  }
  #home #nav .contents .app .ios {
    width: 135px;
    float: left;
    text-align: center;
  }
  #home #nav .contents .app .ios img {
    text-align: center;
  }
  #home #nav .contents .app .android {
    width: 157px;
    float: right;
    text-align: center;
  }
  #home #nav .contents .app .android img {
    text-align: center;
  }
  #home #nav .contents .illust {
    width: 100%;
    height: 193px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  #home #nav .contents .illust img {
    width: 52%;
    margin: 0 auto;
    padding-bottom: 20px;
  }
  #home #nav .contents button {
    border: none;
    outline: none;
    margin: 0 auto 20px;
    width: 100%;
  }
  #home #nav .contents button a {
    display: block;
    background: #e8383d;
    padding: 22px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    box-shadow: 8px 8px 0 0 #000000;
  }
  #home #nav .contents button a:active {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: none;
  }
  #home #nav .contents button a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
    -khtml-opacity: 0.7;
    -moz-opacity: 0.7;
  }
  #home #nav .contents button + p {
    text-align: center;
    text-decoration: none;
    font-size: 18px;
    letter-spacing: 0.04em;
  }
  #home #nav .contents .kikoenai {
    width: 49.4%;
    height: auto;
    padding: 40px 35px;
    background: #fff;
    float: left;
  }
  #home #nav .contents .kikoenai h2 {
    margin-bottom: 10px;
    font-size: 48px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #nav .contents .kikoenai h2 + p {
    margin-bottom: 17px;
    font-size: 16px;
    line-height: 1.8;
    text-align: center;
  }
  #home #nav .contents .kikoeru {
    width: 49.4%;
    height: auto;
    padding: 40px 35px;
    background: #fff;
    float: right;
  }
  #home #nav .contents .kikoeru h2 {
    margin-bottom: 10px;
    font-size: 48px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #nav .contents .kikoeru h2 + p {
    margin-bottom: 17px;
    font-size: 16px;
    line-height: 1.8;
    text-align: center;
  }
  #home #about {
    padding: 50px 0;
  }
  #home #about .about-lead {
    margin-bottom: 36px;
    font-size: 30px;
  }
  #home #about .about-txt {
    font-size: 16px;
  }
  #home #about h3 {
    font-size: 18px;
  }
  #home #about h2 {
    margin-bottom: 24px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #about h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #home #about .about-txt {
    font-size: 24px;
    margin-bottom: 40px;
  }
  #home #about .about-txt span {
    background: linear-gradient(transparent 10%, #fff2ad 10%);
  }
  #home #about .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    width: 100%;
    margin: 0 auto 53px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #home #about .movie iframe {
    width: 740px;
    height: 414px;
  }
  #home #about .cta-area .cta-area_logo {
    width: 173px;
    margin-bottom: 20px;
    margin-left: auto;
    margin-inline: 0;
  }
  #home #about .cta-area .cta-area_txt02 {
    font-size: 11.575px;
    margin-bottom: 0;
  }
  #home #about .cta-area .cta-area_txt {
    font-size: 32px;
  }
  .cta-area_flex {
    display: flex;
    justify-content: center;
    gap: 20px;
  }
  #home #about .app {
    width: 100%;
    padding: 43px 50px 39px;
    margin-left: inherit;
  }
  #home #about .app h2 {
    margin-bottom: 18px;
    font-size: 30px;
  }
  #home #about .app figure {
    margin: inherit;
  }
  #home #about .app figure div {
    height: 207px;
  }
  #home #about .app figure img {
    max-width: 312px;
  }
  #home #about .app .btn-wrapper {
    max-width: none;
    margin: inherit;
  }
  #home #about .app .btn-container {
    grid-template-columns: auto auto;
    gap: 0 32px;
  }
  #home #about .app .btn-apple {
    max-width: 201px;
  }
  #home #about .app .btn-google {
    max-width: 246px;
  }
  #home #about .app .btn-apple p,
  #home #about .app .btn-google p {
    font-size: 18px;
  }
  #home #about .registration {
    width: 307px;
    height: 74px;
    padding: 15px 0 8px 30px;
    font-size: 20px;
    margin: 0 auto 0 0;
  }
  #home #about .app .annotation {
    max-width: none;
    font-size: 18px;
  }
  #home #case {
    padding: 50px 0;
  }
  #home #case h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #case h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #home #case h2 br {
    display: none;
  }
  #home #case h2 + p {
    font-size: 35px;
    font-weight: normal;
    text-align: center;
    margin-bottom: 60px;
  }
  #home #case h2 + p br {
    display: none;
  }
  #home #case .case-list ul li {
    list-style: none;
  }
  #home #case .case-list ul li {
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 14px 50px;
    margin-bottom: 14px;
    *zoom: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
  }
  #home #case .case-list ul li:before,
  #home #case .case-list ul li:after {
    display: table;
    content: "";
  }
  #home #case .case-list ul li:after {
    clear: both;
  }
  #home #case .case-list ul li img {
    float: left;
    margin-right: 40px;
    width: 270px;
  }
  #home #case .case-list ul li .element {
    width: 700px;
    text-align: left;
  }
  #home #case .case-list ul li .element h3 {
    font-size: 35px;
    line-height: 1.4;
    font-weight: normal;
    margin-bottom: 12px;
  }
  #home #case .case-list ul li .element h3 + p {
    font-size: 24px;
    line-height: 1.5;
  }
  #home #case .case-list ul li:nth-child(even) {
    flex-direction: row;
  }
  #home #case .case-list ul li:nth-child(even) img {
    width: 240px;
    float: right;
    margin-left: 20px;
    margin-right: 0;
  }
  #home #case .case-list ul li:last-of-type {
    margin-bottom: 0;
  }
  #home #case .transition {
    width: 90%;
    margin: 0 auto;
    *zoom: 1;
  }
  #home #case .transition:before,
  #home #case .transition:after {
    display: table;
    content: "";
  }
  #home #case .transition:after {
    clear: both;
  }
  #home #case .transition .left {
    width: 47.5%;
    float: left;
  }
  #home #case .transition .right {
    width: 47.5%;
    float: right;
  }
  #home #case .transition button {
    border: none;
    outline: none;
    margin: 0 auto 20px;
    width: 100%;
  }
  #home #case .transition button a {
    display: block;
    background: #e8383d;
    padding: 22px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    box-shadow: 8px 8px 0 0 #000000;
  }
  #home #case .transition button a:active {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: none;
  }
  #home #case .transition button a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
    -khtml-opacity: 0.7;
    -moz-opacity: 0.7;
  }
  #home #case .transition button + p {
    text-align: center;
    text-decoration: none;
    font-size: 18px;
    letter-spacing: 0.04em;
  }
  #home #case .transition .none {
    display: block;
  }
  #home #case .transition .mgn {
    margin-bottom: 24px;
  }
  #home #qa {
    padding: 50px 0;
  }
  #home #qa h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #qa h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #home #qa .qa-list {
    margin-bottom: 50px;
  }
  #home #qa .qa-list ul li {
    list-style: none;
  }
  #home #qa .qa-list ul li {
    border-bottom: 1px dotted #8c98a4;
    margin-bottom: 24px;
  }
  #home #qa .qa-list ul li ul li {
    font-size: 36px;
    margin-left: 5rem;
    margin-bottom: 24px;
    border: none;
  }
  #home #qa .qa-list ul li ul li:before {
    content: "Q.";
    font-size: 48px;
    font-weight: normal;
    line-height: 1;
    margin-right: 30px;
    margin-left: -5rem;
  }
  #home #qa .qa-list ul li ul li:nth-child(even) {
    font-size: 24px;
    margin-left: 5rem;
  }
  #home #qa .qa-list ul li ul li:nth-child(even):before {
    content: "A.";
    font-size: 48px;
    font-weight: normal;
    color: #e8383d;
    line-height: 1;
    margin-right: 30px;
    margin-left: -5rem;
    vertical-align: middle;
  }
  #home #qa .qa-list ul li:last-child {
    border: none;
  }
  #home #qa .link {
    text-align: center;
    position: relative;
    width: 31%;
    margin: 0 auto;
    padding: 16px 30px;
  }
  #home #qa .link a {
    font-size: 24px;
    line-height: 1;
    padding: 0 0 0 48px;
    display: table-cell;
    vertical-align: middle;
  }
  #home #qa .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 56px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #home #system {
    padding: 50px 0;
  }
  #home #system h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #home #system h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #home #system h2 br {
    display: none;
  }
  #home #system .logo {
    margin: 0 auto 50px;
    width: 450px;
  }
  #home #system .logo img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  #home #system p {
    font-size: 24px;
    line-height: 1.6;
    margin-bottom: 43px;
  }
  #home #system p span {
    background: linear-gradient(transparent 10%, #fff2ad 10%);
  }
  #home #system .visual h3 {
    font-size: 30px;
    font-weight: 700;
    line-height: normal;
    text-align: center;
    letter-spacing: 0.03em;
  }
  #home #system .visual .wrapper {
    display: grid;
    grid-template-rows: auto auto;
    grid-template-columns: repeat(4, 1fr);
    grid-template-areas:
      "item01 item02 item03 item04"
      ". item05 item05 .";
    margin-top: 10px;
    gap: 45px;
  }
  #home #system .visual .white {
    border: 6px solid var(--image-bg);
  }
  #home #system .visual .orange {
    border: 6px solid #f28e00;
  }
  #home #system .visual .item {
    position: relative;
    min-height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 20px;
    border-radius: 10px;
    text-align: center;
  }
  #home #system .visual .item01 {
    grid-area: item01;
  }
  #home #system .visual .item02 {
    grid-area: item02;
  }
  #home #system .visual .item03 {
    grid-area: item03;
  }
  #home #system .visual .item04 {
    grid-area: item04;
  }
  #home #system .visual .item05 {
    grid-area: item05;
  }
  #home #system .visual .item h4 {
    font-size: 22px;
  }
  #home #system .visual .item .text {
    margin: 0;
    font-size: 16px;
    line-height: 1.4;
  }
  #home #system .visual .item .annotation {
    position: absolute;
    margin: 0;
    font-size: 17px;
    font-weight: 700;
    writing-mode: vertical-rl;
    color: #111;
    letter-spacing: 0.2em;
  }
  #home #system .visual .item01::before,
  #home #system .visual .item02::before,
  #home #system .visual .item03::before {
    position: absolute;
    top: 31px;
    right: -37px;
    bottom: initial;
    left: initial;
    content: "";
    width: 25px;
    height: 17px;
    background: url(../images/visual-arrow.svg) no-repeat;
    rotate: -90deg;
  }
  #home #system .visual .item01 .annotation,
  #home #system .visual .item02 .annotation {
    top: 60px;
    right: -35px;
    bottom: initial;
    left: initial;
  }
  #home #system .visual .item .annotation #contact {
    padding: 30px 0 0 0;
  }
  #home #system .visual .item05 {
    position: relative;
    min-height: auto;
  }
  #home #system .visual .item05::before,
  #home #system .visual .item05::after {
    content: "";
    position: absolute;
    top: -35px;
    left: initial;
    width: 25px;
    height: 17px;
    background: url(../images/visual-arrow.svg) no-repeat;
    rotate: 180deg;
  }
  #home #system .visual .item02 .text {
    padding: 0;
  }
  #home #system .visual .item03 .text {
    padding: 0;
  }
  #home #system .visual .item05::before {
    left: 101px;
  }
  #home #system .visual .item05::after {
    right: 102px;
  }
  #home #system .visual .item .item-inner {
    display: grid;
    grid-template-rows: auto 1fr;
    grid-template-columns: auto 1fr;
    grid-template-areas:
      "img title"
      "img text";
    gap: 0 23px;
  }
  #home #system .visual .item05 img {
    width: 52px;
    grid-area: img;
  }
  #home #system .visual .item05 h4 {
    grid-area: title;
    margin-top: 0;
    color: #f28e01;
    text-align: left;
    font-size: 28px;
    font-weight: 700;
    line-height: normal;
  }
  #home #system .visual .item05 .text {
    padding: 0;
    grid-area: text;
    color: #111;
    text-align: left;
  }
  #contact {
    padding: 50px 0 0 0;
  }
  #contact h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #contact h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #contact h3 {
    font-size: 48px;
    line-height: 1;
    font-weight: normal;
    margin-bottom: 26px;
    text-align: center;
  }
  #contact h3 span {
    display: inline;
    font-size: 48px;
    margin-right: 20px;
  }
  #contact h3 + p {
    font-size: 30px;
    line-height: 1;
    margin-bottom: 60px;
    text-align: center;
  }
  #contact h3 + p span {
    display: inline;
    margin-right: 20px;
  }
  #contact .tel {
    margin-bottom: 40px;
  }
  #contact .tel ul {
    background: #fff2ad;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    text-align: center;
    padding: 40px 0;
  }
  #contact .tel ul li {
    list-style: none;
  }
  #contact .tel ul li {
    width: 43%;
    font-size: 46px;
    line-height: 1;
  }
  #contact .tel ul li a {
    text-decoration: none;
  }
  #contact .other table {
    width: 1000px;
    margin: 0 auto 50px;
    border-spacing: 0 20px;
  }
  #contact .other table tr {
    height: auto;
  }
  #contact .other table th,
  #contact .other table td {
    width: auto;
    vertical-align: middle;
    display: flex;
    align-items: center;
  }
  #contact .other table th {
    width: 360px;
    height: 80px;
    font-size: 30px;
    line-height: 1.3;
    font-weight: normal;
    border-left: none;
    border-right: 5px solid #000;
    padding: 0 20px 0 0;
    text-align: right;
    float: left;
  }
  #contact .other table td {
    width: 600px;
    font-size: 20px;
    height: 80px;
    float: left;
    line-height: 1.3;
    padding: 0 0 0 20px;
    text-align: left;
  }
  #contact .form {
    background: #ffcabf;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 40px 80px;
    *zoom: 1;
    position: relative;
    text-align: left;
  }
  #contact .form:before,
  #contact .form:after {
    display: table;
    content: "";
  }
  #contact .form:after {
    clear: both;
  }
  #contact .form h3 {
    font-size: 40px;
    line-height: 1.2;
    font-weight: normal;
    text-align: left;
    margin-bottom: 14px;
  }
  #contact .form h3 span {
    font-size: 40px;
  }
  #contact .form h3 + a {
    font-size: 24px;
    line-height: 1;
    letter-spacing: 0.03em;
    display: block;
    margin-bottom: 0;
  }
  #contact .form img {
    position: absolute;
    top: 30px;
    right: 80px;
  }
  #contact-headline {
    padding: 50px 0;
  }
  #contact-headline h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-bottom: 0;
  }
  #contact-headline h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #contact-kikoenai {
    padding: 70px 0 0 0;
  }
  #contact-kikoenai h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #contact-kikoenai h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #contact-kikoenai h3 {
    font-size: 48px;
    line-height: 1;
    font-weight: normal;
    margin-bottom: 26px;
    text-align: center;
  }
  #contact-kikoenai h3 span {
    display: inline;
    font-size: 48px;
    margin-right: 20px;
  }
  #contact-kikoenai h3 + p {
    font-size: 30px;
    line-height: 1;
    margin-bottom: 60px;
    text-align: center;
  }
  #contact-kikoenai h3 + p span {
    display: inline;
    margin-right: 20px;
  }
  #contact-kikoenai .tel {
    margin-bottom: 40px;
  }
  #contact-kikoenai .tel ul {
    -webkit-border-radius: 10px;
    border-radius: 10px;
    display: flex;
    justify-content: center;
    text-align: center;
  }
  #contact-kikoenai .tel ul li {
    list-style: none;
  }
  #contact-kikoenai .tel ul li {
    width: 46%;
    font-size: 46px;
    line-height: 1;
  }
  #contact-kikoenai .tel ul li a {
    text-decoration: none;
  }
  #contact-kikoenai .other table {
    width: 1095px;
    margin: 0 auto 10px;
    background: #fff2ad;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #contact-kikoenai .other table tr {
    height: auto;
  }
  #contact-kikoenai .other table th,
  #contact-kikoenai .other table td {
    width: auto;
    vertical-align: middle;
    display: flex;
    align-items: center;
  }
  #contact-kikoenai .other table th {
    width: 380px;
    height: 80px;
    font-size: 30px;
    line-height: 1.3;
    font-weight: normal;
    border-left: none;
    border-right: 5px solid #000;
    padding: 24px 20px 24px 20px;
    text-align: right;
    display: flex;
    align-items: center;
    float: left;
  }
  #contact-kikoenai .other table td {
    width: 663px;
    font-size: 20px;
    height: 80px;
    float: left;
    line-height: 1.3;
    padding: 0 0 0 20px;
    text-align: left;
  }
  #contact-kikoenai .form {
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 40px 80px;
    *zoom: 1;
    position: relative;
    text-align: left;
  }
  #contact-kikoenai .form:before,
  #contact-kikoenai .form:after {
    display: table;
    content: "";
  }
  #contact-kikoenai .form:after {
    clear: both;
  }
  #contact-kikoenai .form h3 {
    font-size: 40px;
    line-height: 1.2;
    font-weight: normal;
    text-align: left;
    margin-bottom: 14px;
  }
  #contact-kikoenai .form h3 span {
    font-size: 40px;
  }
  #contact-kikoenai .form h3 + a {
    font-size: 24px;
    line-height: 1;
    letter-spacing: 0.03em;
    display: block;
    margin-bottom: 0;
  }
  #contact-kikoenai .form img {
    position: absolute;
    top: 30px;
    right: 80px;
  }
  #kikoeru #what {
    padding: 50px 0;
  }
  #kikoeru #what h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-bottom: 40px;
  }
  #kikoeru #what h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoeru #what h2 + p {
    margin-bottom: 30px;
    font-size: 30px;
    line-height: 1.5;
    text-align: center;
  }
  #kikoeru #what .visual {
    margin-bottom: 30px;
    text-align: center;
  }
  #kikoeru #what .visual img {
    width: 934px;
    max-width: 934px;
  }
  #kikoeru #what button {
    width: 100%;
    border: none;
    outline: none;
    margin: 0 auto 14px;
    background: none;
    width: 850px;
    margin: 0 auto;
    display: block;
    background: #e8383d;
    padding: 14px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #kikoeru #what button span {
    font-size: 48px;
    line-height: 1;
    color: #fff2ad;
  }
  #kikoeru #know {
    padding: 50px 0;
  }
  #kikoeru #know h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #kikoeru #know h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoeru #know h2 br {
    display: none;
  }
  #kikoeru #know .logo {
    margin: 0 auto 60px;
    width: 100%;
    text-align: center;
  }
  #kikoeru #know .logo img {
    width: 377px;
    max-width: 377px;
    height: 122px;
  }
  #kikoeru #know table {
    width: 100%;
    border-collapse: collapse;
    margin-bottom: 50px;
    background: #fff2ad;
    /* Old browsers */
    background: -moz-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* FF3.6-15 */
    background: -webkit-linear-gradient(left, #fff2ad 0%, #ffcabf 100%);
    /* Chrome10-25,Safari5.1-6 */
    background: linear-gradient(to right, #fff2ad 0%, #ffcabf 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#fff2ad', endColorstr='#ffcabf', GradientType=1);
    /* IE6-9 */
    text-align: left;
  }
  #kikoeru #know table tr {
    border-bottom: 14px solid #fff;
  }
  #kikoeru #know table th,
  #kikoeru #know table td {
    display: inline-block;
  }
  #kikoeru #know table th {
    width: 11%;
    font-size: 60px;
    line-height: 1;
    font-weight: normal;
    text-align: left;
    padding: 28px 44px;
    vertical-align: middle;
  }
  #kikoeru #know table td {
    width: 88%;
    text-align: left;
    font-size: 40px;
    line-height: 1.2;
    font-weight: normal;
    padding: 28px 50px 28px 0;
    vertical-align: middle;
  }
  #kikoeru #know .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    width: 100%;
    margin: 0 auto 60px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #kikoeru #know .movie iframe {
    width: 740px;
    height: 414px;
  }
  #kikoeru #know h3 {
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    height: 120px;
    margin-bottom: 20px;
    background-image: url("../images/howtouse1/illust-relay.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 725px auto;
    -moz-background-size: 725px auto;
  }
  #kikoeru #know .link {
    text-align: center;
    position: relative;
    width: 45%;
    margin: 0 auto;
    padding: 16px 30px;
  }
  #kikoeru #know .link a {
    font-size: 24px;
    line-height: 1;
    padding: 0 0 0 48px;
    display: table-cell;
    vertical-align: middle;
  }
  #kikoeru #know .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 56px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoeru #put {
    padding: 50px 0;
  }
  #kikoeru #put h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-bottom: 40px;
  }
  #kikoeru #put h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoeru #put h2 + p {
    font-size: 30px;
    margin-bottom: 20px;
    text-align: center;
  }
  #kikoeru #put h2 br {
    display: none;
  }
  #kikoeru #put .visual {
    text-align: center;
  }
  #kikoeru #put .visual img {
    width: 651px;
    max-width: 651px;
    height: 453px;
    margin: 0 auto 40px;
  }
  #kikoeru #put button {
    border: none;
    outline: none;
    margin: 0 auto 20px;
    width: 100%;
    text-align: center;
    background: none;
  }
  #kikoeru #put button a {
    display: block;
    background: #e8383d;
    padding: 22px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    box-shadow: 8px 8px 0 0 #000000;
  }
  #kikoeru #put button a:active {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: none;
  }
  #kikoeru #put button a:hover {
    opacity: 0.7;
    filter: alpha(opacity=70);
    -ms-filter: "alpha(opacity=70)";
    -khtml-opacity: 0.7;
    -moz-opacity: 0.7;
  }
  #kikoeru #put button + p {
    text-align: center;
    text-decoration: none;
    font-size: 18px;
    letter-spacing: 0.04em;
  }
  #kikoeru #put button a {
    width: 44%;
    margin: 0 auto;
  }
  #kikoeru #note {
    padding: 50px 0;
  }
  #kikoeru #note h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-bottom: 40px;
  }
  #kikoeru #note h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoeru #note h2 br {
    display: none;
  }
  #kikoeru #note ul li {
    list-style: none;
  }
  #kikoeru #note ul li {
    font-size: 40px;
    line-height: 1.3;
    padding: 10px 0 10px 94px;
    margin: 0 0 34px 0;
    vertical-align: middle;
    position: relative;
  }
  #kikoeru #note ul li:before {
    font-family: "Font Awesome 6 Free";
    content: "\f05a";
    color: #84919e;
    font-weight: 900;
    font-size: 70px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoeru #note ul li ul {
    margin-top: 30px;
  }
  #kikoeru #note ul li ul li {
    list-style: disc;
    font-size: 30px;
    line-height: 1.2;
    padding: 0;
    margin: 0 0 4px 50px;
    vertical-align: middle;
    position: static;
  }
  #kikoeru #note ul li ul li:before {
    content: none;
  }
  #kikoeru #note .link {
    text-align: center;
    position: relative;
    width: 33%;
    margin: 0 auto;
    padding: 16px 30px;
  }
  #kikoeru #note .link a {
    font-size: 30px;
    line-height: 1;
    padding: 0 0 0 48px;
    display: table-cell;
    vertical-align: middle;
  }
  #kikoeru #note .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 56px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoenai .appdl {
    padding: 0 0 80px 0;
  }
  #kikoenai .appdl .contents {
    height: 304px;
    background: #e8383d;
    text-align: left;
    padding: 45px 90px;
    color: #fff;
  }
  #kikoenai .appdl .contents .mark {
    float: left;
    margin-right: 45px;
  }
  #kikoenai .appdl .contents .mark img {
    width: 214px;
  }
  #kikoenai .appdl .contents .headline {
    margin-bottom: 18px;
    float: left;
  }
  #kikoenai .appdl .contents .headline h3 {
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    margin-bottom: 6px;
    padding-top: 16px;
  }
  #kikoenai .appdl .contents .headline h3 + p {
    font-size: 17px;
    line-height: 1.3;
  }
  #kikoenai .appdl .contents .headline h3 + p a {
    color: #fff;
  }
  #kikoenai .appdl .contents h4 {
    font-size: 18px;
    line-height: 1;
    padding: 0 0 0 26px;
    margin-bottom: 10px;
    position: relative;
  }
  #kikoenai .appdl .contents h4:before {
    content: "";
    position: absolute;
    top: 40%;
    left: 0;
    transform: translateY(-50%);
    border: 10px solid transparent;
    border-left: 17px solid #fff;
  }
  #kikoenai .appdl .contents .dl {
    width: 60%;
  }
  #kikoenai .appdl .contents .qr img {
    width: 118px;
  }
  #kikoenai .appdl .contents .ios {
    width: 31%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: left;
    margin: 0 70px 0 0;
    float: left;
  }
  #kikoenai .appdl .contents .android {
    width: 31%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: left;
    float: left;
  }
  #kikoenai #idea h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1.2;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #kikoenai #idea .idea-list ul {
  }
  #kikoenai #idea .idea-list ul li {
  }
  #kikoenai #idea .idea-list ul li img {
    width: 100%;
    max-width: 100%;
    height: auto;
  }
  #kikoenai #useful {
    padding: 50px 0;
  }
  #kikoenai #useful h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #kikoenai #useful h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoenai #useful h2 br {
    display: none;
  }
  #kikoenai #useful .case-list {
    margin-bottom: 40px;
  }
  #kikoenai #useful .case-list ul li {
    list-style: none;
  }
  #kikoenai #useful .case-list ul li {
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 14px 30px;
    margin-bottom: 14px;
    *zoom: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
  }
  #kikoenai #useful .case-list ul li:before,
  #kikoenai #useful .case-list ul li:after {
    display: table;
    content: "";
  }
  #kikoenai #useful .case-list ul li:after {
    clear: both;
  }
  #kikoenai #useful .case-list ul li img {
    float: left;
    margin-right: 40px;
    width: 270px;
  }
  #kikoenai #useful .case-list ul li .element {
    width: 700px;
    text-align: left;
  }
  #kikoenai #useful .case-list ul li .element h3 {
    font-size: 35px;
    line-height: 1.4;
    font-weight: normal;
    margin-bottom: 12px;
  }
  #kikoenai #useful .case-list ul li .element h3 + p {
    font-size: 24px;
    line-height: 1.5;
  }
  #kikoenai #useful .case-list ul li:nth-child(even) {
    flex-direction: row;
  }
  #kikoenai #useful .case-list ul li:nth-child(even) img {
    width: 240px;
    float: right;
    margin-left: 20px;
    margin-right: 0;
  }
  #kikoenai #use {
    padding: 50px 0;
  }
  #kikoenai #use h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #kikoenai #use h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoenai #use .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    width: 100%;
    margin: 0 auto 60px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #kikoenai #use .movie iframe {
    width: 740px;
    height: 414px;
  }
  #kikoenai #use h3 {
    width: 100%;
    margin: 0 auto 34px;
    display: block;
    background: #e8383d;
    padding: 12px 0;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    color: #fff;
    text-align: center;
    text-decoration: none;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #kikoenai #use h3 span {
    font-size: 48px;
    line-height: 1;
    color: #fff2ad;
    padding-top: 10px;
  }
  #kikoenai #use h3 br {
    display: none;
  }
  #kikoenai #use .step3 {
    width: 100%;
    height: 0;
    padding-top: 83%;
    margin: 0 auto 40px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse2/figure-3step.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  #kikoenai #use .easy {
    width: 439px;
    height: 292px;
    padding-top: 0;
    margin: 0 auto 20px;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    background-image: url("../images/howtouse2/figure-easy.png");
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100% auto;
    -moz-background-size: 100% auto;
  }
  #kikoenai #use .read {
    width: 100%;
    margin: 0 auto 60px;
    font-size: 24px;
    line-height: 1.1;
    text-align: center;
  }
  #kikoenai #use .read p {
    padding-top: 4px;
    font-size: 16px;
    line-height: 1.1;
  }
  #kikoenai #use .manual {
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    border: 10px solid #eaebeb;
    padding: 40px 60px;
  }
  #kikoenai #use .manual h4 {
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    text-align: center;
    margin-bottom: 44px;
  }
  #kikoenai #use .manual ul {
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  #kikoenai #use .manual ul li {
    list-style: none;
  }
  #kikoenai #use .manual ul li {
    width: 420px;
    font-size: 18px;
    line-height: 1.3;
    padding: 0 0 0 60px;
    position: relative;
    margin: 0 140px 0 0;
  }
  #kikoenai #use .manual ul li:last-child {
    margin: 0;
  }
  #kikoenai #use .manual ul li:before {
    font-family: "Font Awesome 6 Free";
    content: "\f1c1";
    font-size: 46px;
    line-height: 1;
    font-weight: 400;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoenai #use .manual ul li span {
    font-size: 14px;
  }
  #kikoenai #use .manual ul li:last-child {
    margin-bottom: 0;
  }
  #kikoenai #use .manual ul li:last-child:before {
    top: -10px;
    left: 0;
  }
  #kikoenai #use .manual .link {
    text-align: center;
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding: 16px 0;
  }
  #kikoenai #use .manual .link a {
    font-size: 4vw;
    line-height: 1;
    padding: 0 0 0 43px;
    display: table-cell;
    vertical-align: middle;
    white-space: nowrap;
  }
  #kikoenai #use .manual .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 33px;
    line-height: 1.4;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoenai #price {
    /*padding: 30px 0;*/
    padding: 30px 0 80px 0;
  }
  #kikoenai #price h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
    margin-bottom: 46px;
  }
  #kikoenai #price h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoenai #price h2 + p {
    margin-bottom: 30px;
    font-size: 30px;
    line-height: 1.5;
    text-align: center;
  }
  #kikoenai #price .area {
    *zoom: 1;
    margin-bottom: 30px;
  }
  #kikoenai #price .area:before,
  #kikoenai #price .area:after {
    display: table;
    content: "";
  }
  #kikoenai #price .area:after {
    clear: both;
  }
  #kikoenai #price .area .left {
    float: left;
    width: 49.1%;
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 60px;
    margin-bottom: 10px;
  }
  #kikoenai #price .area .left h3 {
    text-align: center;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    -webkit-border-radius: 30px;
    border-radius: 30px;
    padding: 11px 0;
    margin-bottom: 40px;
    background: #fff2ad;
  }
  #kikoenai #price .area .right {
    float: right;
    width: 49.1%;
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 60px;
  }
  #kikoenai #price .area .right h3 {
    text-align: center;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    -webkit-border-radius: 30px;
    border-radius: 30px;
    padding: 11px 0;
    margin-bottom: 40px;
    background: #ffcabf;
  }
  #kikoenai #price .area .default {
    width: 49.1%;
    background: #fff;
    -webkit-border-radius: 10px;
    border-radius: 10px;
    padding: 60px;
  }
  #kikoenai #price .area .h3 {
    text-align: center;
    font-size: 30px;
    line-height: 1;
    font-weight: normal;
    -webkit-border-radius: 30px;
    border-radius: 30px;
    padding: 11px 0;
    margin-bottom: 40px;
  }
  #kikoenai #price .area ul li {
    list-style: none;
  }
  #kikoenai #price .area ul li {
    font-size: 24px;
    line-height: 1;
    margin-bottom: 32px;
  }
  #kikoenai #price .area ul li span {
    font-size: 30px;
    margin-left: 20px;
  }
  #kikoenai #price .area ul li:nth-child(4n) {
    color: #e8383d;
  }
  #kikoenai #price .area ul li:last-child {
    margin: 0;
  }
  #kikoenai #price .link {
    text-align: center;
    position: relative;
    width: 31%;
    margin: 0 auto 40px;
    padding: 16px 30px;
  }
  #kikoenai #price .link a {
    font-size: 24px;
    line-height: 1;
    padding: 0 0 0 48px;
    display: table-cell;
    vertical-align: middle;
  }
  #kikoenai #price .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 56px;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kikoenai #price .appdl {
    padding: 0;
  }
  #kikoenai #price .appdl .contents {
    width: 100%;
  }
  #kikoenai #register {
    padding: 50px 0;
  }
  #kikoenai #register h2 {
    margin-bottom: 60px;
    font-size: 60px;
    font-weight: normal;
    line-height: 1;
    letter-spacing: 0.04em;
    text-align: center;
  }
  #kikoenai #register h2 .icon {
    padding: 0 0 0 88px;
    background-repeat: no-repeat;
    background-position: 0 35%;
    background-size: 78px auto;
    -moz-background-size: 78px auto;
  }
  #kikoenai #register .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    width: 100%;
    margin: 0 auto 60px;
    -webkit-border-radius: 10px;
    border-radius: 10px;
  }
  #kikoenai #register .movie iframe {
    width: 740px;
    height: 414px;
  }
  #kikoenai #register .manual ul {
    width: 70%;
    margin: 0 auto;
    display: flex;
  }
  #kikoenai #register .manual ul li {
    list-style: none;
  }
  #kikoenai #register .manual ul li {
    width: 420px;
    font-size: 18px;
    line-height: 1.3;
    padding: 0 0 0 60px;
    position: relative;
    margin-bottom: 40px;
  }
  #kikoenai #register .manual ul li a {
    white-space: nowrap;
  }
  #kikoenai #register .manual ul li:before {
    font-family: "Font Awesome 6 Free";
    content: "\f772";
    font-size: 52px;
    line-height: 1;
    font-weight: 900;
    position: absolute;
    top: -55%;
    left: -3%;
  }
  #kikoenai #register .manual ul li span {
    font-size: 14px;
  }
  #kikoenai #register .manual ul li:last-child {
    margin-bottom: 0;
  }
  #kikoenai #register .manual ul li:last-child:before {
    content: "\f1c1";
    font-size: 48px;
    font-weight: 400;
    top: -18%;
    left: 2%;
  }
  #kikoenai #register .manual .link {
    text-align: center;
    position: relative;
    width: 86%;
    margin: 0 auto;
    padding: 16px 0;
  }
  #kikoenai #register .manual .link a {
    font-size: 4vw;
    line-height: 1;
    padding: 0 0 0 43px;
    display: table-cell;
    vertical-align: middle;
    white-space: nowrap;
  }
  #kikoenai #register .manual .link a:before {
    font-family: "Font Awesome 6 Free";
    content: "\f059";
    font-weight: 900;
    font-size: 33px;
    line-height: 1.4;
    position: absolute;
    top: 0;
    left: 0;
  }

  .btn {
    max-width: 307px;
  }
  .btn a::after {
    width: 30px;
    height: 20px;
  }
  .adulation {
    display: none;
  }
  #kikoenai .application_download {
    width: 1095px;
    margin-inline: auto;
    padding: 40px 0;
  }
  #kikoenai .application_download_txt {
    padding-left: 0;
    font-size: 24px;
  }
  #kikoenai .application_download_annotation {
    padding-left: 0;
    text-align: left;
    font-size: 14px;
  }
  #kikoenai .application_download_flex {
    display: flex;
    justify-content: center;
    gap: 20px;
  }
  #kikoenai .application_download_logo02 {
    height: max-content;
    margin: 0;
  }
  #kikoenai .application_download_annotation {
    margin-bottom: 20px;
    text-align: left;
  }
  #kikoenai .application_download_link a {
    font-size: 16.2px;
    padding-bottom: 0;
  }
  #kikoenai .application_download_link a::after {
    top: 3px;
  }
  .application_download_flex {
    margin-bottom: 0;
  }

  .adulation_flex {
    display: flex;
    justify-content: center;
    gap: 20px;
  }
  .adulation_logo02 {
    margin: 0;
    height: max-content;
  }
  .adulation_txt {
    width: max-content;
    margin-inline: auto;
    padding-left: 5%;
  }
  #about h3 {
    text-align: center;
    font-size: 32px;
    font-weight: 700;
    margin-bottom: 25px;
  }

  #kikoenai #idea .idea-list .idea-list-ttl {
    font-size: 38px;
  }
  #kikoenai #idea .idea-list .idea-list-txt {
    font-size: 30px;
    margin-bottom: 35px;
  }
  #kikoenai #idea .idea-list-txt02 {
    font-size: 24px;
  }
  #kikoenai #idea .idea-list-desc,
  #kikoenai #idea .idea-content-txt {
    font-size: 20px;
  }
  #kikoenai #idea dt,
  #kikoenai #idea dd {
    font-size: 18px;
  }
  #kikoenai #idea .idea-list-more {
    font-size: 22px;
  }
  .pc-none {
    display: none;
  }
  #kikoenai .movie {
    margin-bottom: 50px;
  }
  #kikoenai .movie,
  #kikoeru .movie {
    background: #000;
    text-align: center;
    padding: 40px 0;
    aspect-ratio: unset;
    margin: 0 auto 40px;
    border-radius: 10px;
    width: 1095px;
    max-width: 100%;
    margin-inline: auto;
  }
  #kikoenai .movie iframe,
  #kikoeru .movie iframe {
    width: 740px;
    height: 414px;
  }
  #kikoenai h2,
  #kikoeru h2 {
    font-size: 32px;
  }
  #kikoenai p,
  #kikoeru p {
    font-size: 20px;
  }
  .application_download_txt {
    font-size: 28px;
  }
  .application_download_link {
    font-size: 24px;
    text-align: left;
  }
  .application_download_link a::after {
    width: 20px;
    height: 12px;
    top: 10px;
  }
  .application_download_content {
    display: flex;
    justify-content: center;
    gap: 60px;
  }
  .application_download_desc {
    height: max-content;
    margin-bottom: 0;
  }
  .application_download_desc {
    width: 367.5px;
    padding: 66px 0;
  }
  .application_download_img_app {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
  }
  .application_download_img img {
    display: block;
    height: 62.5px;
  }
  .application_download_img + .application_download_img {
    margin-top: 0;
  }
  .application_download_img {
    width: auto;
  }
  .pc-mb-40 {
    margin-bottom: 40px;
  }
  .pc-mt-40 {
    margin-top: 40px;
  }
  .reference-mark {
    font-size: 30px;
  }
  #kikoenai .mobie-ttl,
  #kikoeru .mobie-ttl,
  #home #about .mobie-ttl {
    font-size: 28px;
  }
  #kikoenai .mobie-ttl em,
  #kikoeru .mobie-ttl em,
  #home #about .mobie-ttl em {
    font-size: 30px;
  }
}
