@charset "UTF-8";
/**
 * header
**/
.top header {
  background: var(--site-c-lighter);
}
/**
 * section element
**/
section {
  padding: 60px 0;
}
@media only screen and (max-width: 959px) {
  section {
    padding: 50px 0
  }
}
@media only screen and (max-width: 767px) {
  section {
    padding: 40px 0
  }
}
/**
 * button
**/
.top .btn {
  width: 100%;
  max-width: 460px;
  font-weight: inherit;
  position: relative;
}
.top .btn a, .top .btn input, .top .btn button, .top .btn > span {
  border-radius: 12px;
  font-size: 26px;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  width: 100%;
  height: 84px;
}
.top .btn a {
  font-family: unset;
}
.top .btn--small {
  width: 100%;
  max-width: 460px;
  font-weight: inherit;
  position: relative;
}
.top .btn--small a, .top .btn--small input, .top .btn--small button, .top .btn--small > span {
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 5px 0 0 #a6543a;
  border-radius: 12px;
  border: solid 1px var(--site-c-main);
  background: #fff;
  color: var(--site-c-main);
  font-size: 18px;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  width: 100%;
  height: 64px;
  position: relative;
  top: 0;
}
.top .btn--small a:hover, .top .btn--small input:hover, .top .btn--small button:hover, .top .btn--small > span:hover {
  box-shadow: 0 0 0 0 #a6543a;
  border-color: var(--site-c-main-active);
  background: #fff;
  color: var(--site-c-main-active);
  top: 5px;
}
@media only screen and (max-width: 959px) {
  .top .btn a, .top .btn input, .top .btn button, .top .btn > span {
    font-size: 20px;
    height: 60px;
  }
  .top .btn--small a, .top .btn--small input, .top .btn--small button, .top .btn--small > span {
    font-size: 18px;
    height: 50px;
  }
}
@media only screen and (max-width: 767px) {
  .top .btn a, .top .btn input, .top .btn button, .top .btn > span {
    font-size: 16px;
    height: 60px;
  }
  .top .btn--small a, .top .btn--small input, .top .btn--small button, .top .btn--small > span {
    font-size: 14px;
    height: 50px;
  }
}
@media only screen and (max-width: 320px) {
  .top .btn a, .top .btn input, .top .btn button, .top .btn > span {
    font-size: 16px;
    height: 60px;
  }
  .top .btn--small a, .top .btn--small input, .top .btn--small button, .top .btn--small > span {
    font-size: 12px;
    height: 50px;
  }
}
/**
 * main visual helper
 * NOTE: display: none以外の記述はしないでください
**/
@media only screen and (min-width: 401px) {
  .main-vis-max-400-disp {
    display: none;
  }
}

/**
 * main visual
**/
.main-vis {
  --main-vis-font-copy: 36px;
  display: block;
  background: var(--site-c-lighter);
  width: 100%;
  height: 768px;
  min-height: 768px;
  padding: var(--main-vis-font-copy) 0;
  position: relative;
}
@media only screen and (max-width: 959px) {
  .main-vis {
    --main-vis-font-copy: 22px;
    height: auto;
    min-height: 0;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis {
    --main-vis-font-copy: 20px;
    /*height: calc(100svh - var(--header-height));*/
    min-height: 0;
  }
}
/*
@media only screen and (max-height: 768px) {
  .main-vis {
    --main-vis-font-copy: 3.6666svh;
    height: calc(100svh - var(--header-height));
    min-height: 0;
  }
}
*/

.main-vis__inner.l-container, .main-vis__inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: stretch;
  text-align: center;
  height: 100%;
}
@media (min-width: 768px) {
  .main-vis__inner.l-container, .main-vis__inner {
    padding: 0;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis__inner.l-container, .main-vis__inner {
    justify-content: center;
  }
}
@media only screen and (max-height: 768px) {
  .main-vis__inner.l-container, .main-vis__inner {
    justify-content: flex-start;
  }
}
.main-vis__txt {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  font-size: var(--main-vis-font-copy);
  text-align: center;
}
.main-vis__txt::after {
  content: '';
  display: block;
  background-image: url("../images/bg-mv.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: contain;
  width: calc(var(--main-vis-font-copy)*17.5);
  aspect-ratio: 2 / 1;/* blue type */
  aspect-ratio: 20 / 9;/* yellow type */
  order: 10;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 767px) {
  .main-vis__txt::after {
    width: 100%;
  }
}
@media only screen and (max-height: 768px) {
  .main-vis__txt::after {
    max-width: 100%;
    width: calc(var(--main-vis-font-copy)*12.5);
  }
}

.main-vis__logo {
  width: 8.5em;
  margin: 0;
  order: 10;
}
@media only screen and (max-width: 767px) {
  .main-vis__logo {
    width: 11.25em;
    margin: calc(var(--main-vis-font-copy)*0.5) 0;
  }
}
@media only screen and (max-height: 768px) {
  .main-vis__logo {
    width: 11.25em;
    margin: calc(var(--main-vis-font-copy)*0.5) 0;
  }
}

.main-vis__txt .copy {
  color: var(--site-c-main);
  font-size: 1em;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  line-height: 1.2;
  letter-spacing: 0.15ex;
  margin: 0 0 calc(var(--main-vis-font-copy)*0.5);
  order: 0;
}
.main-vis__txt .maincopy {
  color: var(--site-c-main);
  font-size: 1.5em;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  line-height: 1.2;
  letter-spacing: 0.15ex;
  margin: 0 0 calc(var(--main-vis-font-copy)*0.25);
  order: 1;
}
@media only screen and (max-width: 767px) {
  .main-vis__txt .copy {
    white-space: nowrap;
    line-height: 1.3333;
  }
  .main-vis__txt .maincopy {
    white-space: nowrap;
    line-height: 1.3333;
  }
  .main-vis__txt .copy .item--yakumono {
    display: inline-block;
    text-indent: -0.25ex;
    margin-right: -1.6666ex;
  }
  .main-vis__txt .maincopy .item--yakumono {
    display: inline-block;
    text-indent: -0.25ex;
    margin-right: -1.6666ex;
  }
}
@media only screen and (max-height: 768px) {
  .main-vis__txt .copy {
    white-space: nowrap;
    line-height: 1.3333;
  }
  .main-vis__txt .maincopy {
    white-space: nowrap;
    line-height: 1.3333;
  }
  .main-vis__txt .copy .item--yakumono {
    display: inline-block;
    text-indent: -0.25ex;
    margin-right: -1.6666ex;
  }
  .main-vis__txt .maincopy .item--yakumono {
    display: inline-block;
    text-indent: -0.25ex;
    margin-right: -1.6666ex;
  }
}


.main-vis__lead {
  color: var(--site-c-dark);
  font-size: 18px;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.15ex;
  text-align: center;
  padding: 0;
  order: 0;
}
@media only screen and (max-width: 959px) {
  .main-vis__lead {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis__lead {
    font-size: 11px;
  }
}


.main-vis__pr {
  border-radius: 20px;
  border: solid 2px #fee77a;
  background: #fff;
  color: var(--site-c-dark);
  max-width: 640px;
  width: 100%;
  margin: 0 auto calc(var(--main-vis-font-copy)*0.25);
  padding: 20px;
  order: 20;
  position: relative;
  z-index: 10;
}
*+.main-vis__pr {
  margin-top: -20px;
}
.main-vis__pr-em {
  color: var(--site-c-dark);
  font-size: 22px;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  line-height: 1.5;
  letter-spacing: 0.15ex;
  text-align: center;
}
.main-vis__pr-notes {
  color: var(--site-c-dark);
  font-size: 14px;
  font-weight: 400;
  font-feature-settings: 'palt';
  line-height: 1.2;
  letter-spacing: 0.15ex;
  text-align: center;
}
*+.main-vis__pr-notes {
  margin-top: 1em;
}
@media only screen and (max-width: 959px) {
  .main-vis__pr {
    border-radius: 20px;
    padding: 20px;
  }
  *+.main-vis__pr {
    margin-top: -20px;
  }
  .main-vis__pr-em {
    font-size: 20px;
  }
  .main-vis__pr-notes {
    font-size: 13px;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis__pr {
    border-radius: 20px;
    padding: 20px;
  }
  *+.main-vis__pr {
    margin-top: -12px;
  }
  .main-vis__pr-em {
    font-size: 18px;
  }
  .main-vis__pr-notes {
    font-size: 13px;
  }
}



.main-vis__notes {
  color: var(--site-c-dark);
  font-size: 12px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0.15ex;
  text-align: center;
  padding: 2em 0;
}
*+.main-vis__notes {
  margin-top: 0;
}
@media only screen and (max-width: 959px) {
  .main-vis__notes {
    font-size: 10px;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis__notes {
    font-size: 10px;
  }
}

.main-vis .button-group {
  display: flex;
  flex-wrap: nowrap;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  text-align: center;
  max-width: 472px;
  margin: 0 auto;
  gap: 12px;
}
*+.main-vis .button-group {
  margin-top: 1em;
}

.main-vis .btn-over-txt {
  color: var(--site-c-main);
  font-size: 18px;
  font-weight: 700; /* maruは 700のみ対応（他ウェイトはhead.htmlにて要読み込み） */
  font-family: var(--site-font-family-maru);
  line-height: 1.2;
  letter-spacing: 0.15ex;
  text-align: center;
}
@media only screen and (max-width: 959px) {
  .main-vis .btn-over-txt {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis .btn-over-txt {
    font-size: 14px;
  }
}

.main-vis .btn {
  max-width: none;
}
.main-vis .btn--small {
  max-width: none;
}
@media only screen and (max-width: 959px) {
  .main-vis .button-group {
    gap: 12px;
  }
}
@media only screen and (max-width: 767px) {
  .main-vis .button-group {
    margin: var(--main-vis-font-copy) 0 0;
    gap: 12px;
  }
}
#top .solve {
  padding-top: 0
}
.feature {}
.feature__ttl {
  font-size: 52px;
  font-weight: 700;
  letter-spacing: 0.05ex;
}
.feature__ttl span {
  font-size: 62px;
}
.feature__txt {
  margin-top: 30px;
  font-size: 18px
}
.feature__list {
  --feature-list-gap: 40px;
  --feature-list-item-padding: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: stretch;
  align-items: stretch;
  gap: var(--feature-list-gap);
  margin-top: 50px;
}
.feature__item {
  box-shadow: 0 0 var(--feature-list-gap) 0 rgba(0, 0, 0, 0.13);
  width: calc((100% - var(--feature-list-gap) * 2) / 3);
  padding: 0 20px 20px;
}
.feature__img {
  margin: 0 calc(var(--feature-list-item-padding)*-1);
}
.feature__img img {
  width: 100%;
  height: auto;
  aspect-ratio: 67 / 50;
  object-fit: contain;
}
.feature__item-ttl {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1ex;
  line-height: 1.5;
  text-align: center;
  margin: 0.5em 0 0;
  padding: 0;
}
.feature__item-txt {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.1ex;
  line-height: 1.25;
  text-align: left;
  margin: 1em 0 0;
  padding: 0;
}
.feature__bottom {
  margin-top: 80px;
}
.feature__bottom .btn {
  margin: 50px auto 0
}
@media screen and (max-width: 767px) {
  .feature {
  }
  .feature__list {
    gap: 10px;
  }
  .feature__item {
    width: 100%
  }
  .feature__ttl {
    font-size: 28px;
    text-align: center
  }
  .feature__ttl span {
    font-size: 28px;
  }
  .feature__txt {
    font-size: 16px
  }
  .feature__bottom {
    margin-top: 40px
  }
}
/**
 * メリット
**/
.merit {}
.merit__ttl {
  color: var(--site-c-dark);
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.05ex;
  line-height: 1.25;
  text-align: center;
}
.merit__txt {
  margin-top: 30px;
  font-size: 18px
}
.merit__list {
  --merit-list-gap: 40px;
  --merit-list-item-padding: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: stretch;
  align-items: stretch;
  gap: var(--merit-list-gap);
  margin-top: 50px;
}
.merit__item {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-content: stretch;
  align-items: stretch;
  border: solid 1px var(--site-c-dark);
  background: #fff;
  width: calc((100% - var(--merit-list-gap) * 2) / 3);
  padding: 0 20px 20px;
}
.merit__item:has(.merit__item-body) {
  border: none;
  background: transparent;
  padding: 0;
}
.merit__item:has(.merit__item-body)::before {
  content: '';
  display: block;
  /*background-image: url(/common/images/bg-dos.png);*/
  background-image: url(/common/images/bg-dots-fill.png);
  background-repeat: no-repeat;
  background-position: right 0px top 0px;
  background-size: auto 100%;
  width: calc(100% - 1px);
  height: calc(100% - 5px);
  position: absolute;
  left: 16px;
  top: 20px;
  z-index: 1;
  opacity: 0.4;
}
.merit__item-body {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-content: stretch;
  align-items: stretch;
  border: solid 1px var(--site-c-dark);
  background: #fff;
  height: 100%;
  padding: 0 20px 20px;
  position: relative;
  z-index: 10;
}
.merit__img {
  margin: 0 calc(var(--merit-list-item-padding)*-1);
  padding: var(--merit-list-item-padding) var(--merit-list-item-padding) 0;
  /*order: 10;*/
}
.merit__img img {
  width: 100%;
  height: auto;
  aspect-ratio: 67 / 50; /* 画像本来のアスペクト比 */
  aspect-ratio: 2 / 1;
  object-fit: contain;
}
.merit__item-ttl {
  color: var(--site-c-dark);
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1ex;
  line-height: 1.5;
  text-align: center;
  margin: 0;
  padding: 0;
  /*order: 0;*/
}
.merit__item-ttl i {
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(135deg, rgba(37,71,110,1) 0%, rgba(37,71,110,1) 50%, rgba(37,71,110,0) 50%, rgba(37,71,110,0) 100%);
  color: #fff;
  font-family: 'Urbanist', sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 48px;
  text-align: center;
  width: 2em;
  height: 2em;
  padding: 0 0.75em 0.75em 0;
  aspect-ratio: 1 / 1;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
}
.merit__item-txt {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.1ex;
  line-height: 1.25;
  text-align: left;
  margin: 1em 0 0;
  padding: 0;
  /*order: 20;*/
}
.merit__item-txt b, .merit__item-txt strong {
  font-weight: 700;
}
.merit__bottom {
  margin-top: 80px;
}
.merit__bottom .btn {
  margin: 50px auto 0
}
@media screen and (max-width: 767px) {
  .merit {
    padding-top: 0
  }
  .merit__list {
    gap: 10px;
  }
  .merit__item {
    width: 100%;
  }
  .merit__ttl {
    font-size: 28px;
    text-align: center
  }
  .merit__ttl span {
    font-size: 28px;
  }
  .merit__img {
    padding: 16px 72px 0;
  }
  .merit__txt {
    font-size: 16px
  }
  .merit__bottom {
    margin-top: 40px
  }
}

/**
 * 機能（トップページ）
**/
.top-ability {}
.top-ability .l-container {
  max-width: 1760px;
}
@media screen and (max-width: 767px) {
  .top-ability {}
}

.top-ability__ttl {
  color: var(--site-c-dark);
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.05ex;
  line-height: 1.25;
  text-align: center;
}
.top-ability__txt {
  margin-top: 30px;
  font-size: 18px
}

.top-ability__list {
  --top-ability-list-gap: 40px;
  --top-ability-list-item-padding: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: stretch;
  align-items: stretch;
  gap: var(--top-ability-list-gap);
  margin-top: 50px;
}
@media screen and (max-width: 1600px) {
  .top-ability__list {
    --top-ability-list-gap: 32px;
    --top-ability-list-item-padding: 20px;
    gap: var(--top-ability-list-gap);
  }
}
@media screen and (max-width: 767px) {
  .top-ability__list {
    --top-ability-list-gap: 12px;
    --top-ability-list-item-padding: 20px;
    gap: var(--top-ability-list-gap);
  }
}
.top-ability__item {
  box-shadow: 0 0 var(--top-ability-list-gap) 0 rgba(0, 0, 0, 0.13);
  background: #fff;
  width: calc((100% - var(--top-ability-list-gap) * 4) / 5);
  padding: 0 var(--top-ability-list-item-padding) var(--top-ability-list-item-padding);
  position: relative;
}
@media screen and (max-width: 1300px) {
  .top-ability__item {
    width: calc((100% - var(--top-ability-list-gap) * 2) / 3);
  }
}
@media screen and (max-width: 767px) {
  .top-ability__item {
    width: 100%;
  }
}

.top-ability__img {
  margin: 0 calc(var(--top-ability-list-item-padding)*-1);
  padding: 0 var(--top-ability-list-item-padding);
}
.top-ability__img img {
  width: 100%;
  height: auto;
  aspect-ratio: 67 / 50;
  object-fit: contain;
}
.top-ability__item-ttl {
  font-size: 18px;
  font-weight: 700;
  font-feature-settings: 'palt';
  letter-spacing: 0.1ex;
  line-height: 1.5;
  text-align: center;
  margin: 0.5em 0 0;
  padding: 0;
}
.top-ability__item-ttl i {
  display: flex;
  justify-content: center;
  align-items: center;
  background: linear-gradient(135deg, rgba(243,137,104,1) 0%, rgba(243,137,104,1) 50%, rgba(243,137,104,0) 50%, rgba(243,137,104,0) 100%);
  color: #fff;
  font-family: 'Urbanist', sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-size: 48px;
  text-align: center;
  width: 2em;
  height: 2em;
  padding: 0 0.75em 0.75em 0;
  aspect-ratio: 1 / 1;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
}

@media screen and (max-width: 1600px) {
  .top-ability__item-ttl i {
    font-size: 28px;
  }
}
@media screen and (max-width: 1300px) {
  .top-ability__item-ttl i {
    font-size: 48px;
  }
}
@media screen and (max-width: 767px) {
  .top-ability__ttl {
    font-size: 28px;
    text-align: center
  }
  .top-ability__ttl span {
    font-size: 28px;
  }
}

.top-ability__item-txt {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.1ex;
  line-height: 1.25;
  text-align: left;
  margin: 1em 0 0;
  padding: 0;
}
.top-ability__item-txt b, .top-ability__item-txt strong {
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .top-ability__txt {
    font-size: 16px
  }
}

.top-ability__bottom {
  margin-top: 80px;
}
.top-ability__bottom .btn {
  margin: 50px auto 0
}
@media screen and (max-width: 767px) {
  .top-ability__bottom {
    margin-top: 40px
  }
}
/**
 * フロー（トップページ）
**/
.top-flow {}
.top-flow__ttl {
  color: var(--site-c-dark);
  font-size: 48px;
  font-weight: 700;
  letter-spacing: 0.05ex;
  line-height: 1.25;
  text-align: center;
}
.top-flow__txt {
  margin-top: 30px;
  font-size: 18px
}
.top-flow__list {
  --top-flow-list-gap: 40px;
  --top-flow-list-item-padding: 20px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: stretch;
  align-items: stretch;
  gap: var(--top-flow-list-gap);
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .top-flow__list {
    --top-flow-list-gap: 12px;
    --top-flow-list-item-padding: 20px;
    gap: var(--top-flow-list-gap);
  }
}

.top-flow__item {
  box-shadow: 0 0 var(--top-flow-list-gap) 0 rgba(0, 0, 0, 0.13);
  background: #fff;
  width: calc((100% - var(--top-flow-list-gap) * 2) / 3);
  padding: 0 20px 20px;
  position: relative;
}
* + .top-flow__item::before {
  content: '';
  display: block;
  background-image: url('/common/images/icon-top-flow-arrow.png');
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center center;
  width: 72px;
  height: auto;
  aspect-ratio: 3 / 2;
  position: absolute;
  left: 0;
  top: 50%;
  z-index: 10;
  transform: translate(-75%, 0);
}
@media screen and (max-width: 767px) {
  .top-flow__item {
    width: 100%;
  }
  * + .top-flow__item::before {
    width: 56px;
    position: absolute;
    top: 0;
    left: 50%;
    z-index: 10;
    transform: translate(-50%, -25%) rotate(90deg);
  }
}

.top-flow__img {
  margin: 0 calc(var(--top-flow-list-item-padding)*-1);
  padding: 0 var(--top-flow-list-item-padding);
}
.top-flow__img img {
  width: 100%;
  height: auto;
  aspect-ratio: 67 / 50;
  object-fit: contain;
}
.top-flow__item-ttl {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.1ex;
  line-height: 1.5;
  text-align: center;
  margin: 0.5em 0 0;
  padding: 0;
}
.top-flow__item-txt {
  font-size: 14px;
  font-weight: 400;
  letter-spacing: 0.1ex;
  line-height: 1.25;
  text-align: left;
  margin: 1em 0 0;
  padding: 0;
}
.top-flow__item-txt b, .top-flow__item-txt strong {
  font-weight: 700;
}
.top-flow__bottom {
  margin-top: 80px;
}
.top-flow__bottom .btn {
  margin: 50px auto 0
}
@media screen and (max-width: 767px) {
  .top-flow__ttl {
    font-size: 28px;
    text-align: center
  }
  .top-flow__ttl span {
    font-size: 28px;
  }
  .top-flow__txt {
    font-size: 16px
  }
  .top-flow__bottom {
    margin-top: 40px
  }
}
/**
 * お知らせ
**/
.top-news {display: none !important}
@media only screen and (max-width: 767px) {
  .top-news {}
}
.top-news .c-head__ttl {
  border: none;
  color: var(--site-c-dark);
  font-size: 48px;
  font-weight: 700;
  margin-bottom: 40px;
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .top-news .c-head__ttl {
    font-size: 28px;
    margin-bottom: 20px;
  }
}
.top-news .btn {
  margin-inline: auto;
}
.top-news * + .btn {
  margin-top: 30px;
}
.top-news__list {
  font-size: 18px;
}
.top-news__list > li, .top-news__list > li > a {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  color: inherit;
  width: 100%;
  gap: 20px;
}
.top-news__list > li {
  padding: 1em 2em;
  position: relative;
}
.top-news__list > li::before {
  content: '';
  display: block;
  border-top: solid 1px;
  border-right: none;
  border-bottom: solid 1px;
  border-left: none;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  opacity: 0.2;
  pointer-events: none;
}
.top-news__list > li + li::before {
  border-top: 0;
}
.top-news__list > li time {
  display: block;
  color: inherit;
  font-family: Arial, Helvetica, "sans-serif";
  font-weight: 400;
  font-size: inherit;
  width: 96px;
}
.top-news__list > li p {
  color: inherit;
  font-weight: 700;
  font-size: inherit;
  white-space: nowrap;
  text-overflow: ellipsis;
  width: 100%;
  padding: 0;
  overflow: hidden;
}
@media only screen and (max-width: 767px) {
  .top-news__list {
    font-size: 16px;
  }
  .top-news__list > li {
    padding: 1em;
  }
}
/**
 * 動画
**/
.top-movie {
  text-align: center;
}
.top-movie__ttl {
  font-size: 48px;
  font-weight: 700;
  line-height: 1.25;
  margin: 0 0 1em;
  padding: 0;
}
.top-movie__ttl small {
  display: block;
  font-size: 28px;
  line-height: inherit;
}
.top-movie__ttl span {
  display: block;
  font-size: inherit;
  line-height: inherit;
}
@media only screen and (max-width: 959px) {
  .top-movie__ttl {
    font-size: 40px;
  }
  .top-movie__ttl small {
    font-size: 24px;
  }
}
@media screen and (max-width: 767px) {
  .top-movie__ttl {
    font-size: 28px;
  }
  .top-movie__ttl small {
    font-size: 16px;
  }
}
.top-movie__video {
  margin-inline: auto;
  display: flex;
  gap: 20px;
}
.top-movie__video video, .top-movie__video iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
}
.top-movie .btn {
  margin-inline: auto;
}
.top-movie * + .btn {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .top-movie__video {
    flex-wrap: wrap
  }
}
/**
 * faq
 * NOTE: 本体はstyle.cssを編集、参照してください。
**/
.top .faq .c-head__ttl {
  border: none;
  color: var(--site-c-dark);
  font-size: 48px;
  font-weight: 700;
  margin-bottom: 40px;
  padding: 0;
}
@media only screen and (max-width: 767px) {
  .top .faq .c-head__ttl {
    font-size: 28px;
    margin-bottom: 20px;
  }
}
.top .faq * + .btn {
  margin-top: 30px;
}
/**
 * お悩み
**/
.nayami {
  text-align: center
}
.nayami__ttl {
  font-size: 50px;
  font-weight: 700
}
.nayami__ttl small {
  font-size: 40px
}
.nayami__img {
  width: 1070px;
  max-width: 100%;
  margin: 70px auto 0
}
@media only screen and (max-width: 959px) {
  .nayami__ttl {
    font-size: 40px;
  }
  .nayami__ttl small {
    font-size: 30px
  }
  .nayami__img {
    margin-top: 20px
  }
}
@media screen and (max-width: 767px) {
  .nayami__ttl {
    font-size: 28px
  }
  .nayami__ttl small {
    font-size: 20px;
  }
}