@charset "UTF-8";
/* 
html5doctor.com Reset Stylesheet
v1.6.1
Last Updated: 2010-09-17
Author: Richard Clark - http://richclarkdesign.com 
Twitter: @rich_clark
*/
@import url("https://fonts.googleapis.com/css2?family=Petit+Formal+Script&family=Shippori+Mincho&display=swap");
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 {
  line-height: 1; }

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block; }

nav ul {
  list-style: none; }

blockquote, q {
  quotes: none; }

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none; }

a {
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent; }

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none; }

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold; }

del {
  text-decoration: line-through; }

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0; }

input, select {
  vertical-align: middle; }

a {
  color: #707070;
  text-decoration: none;
  transition: .3s; }

a:hover {
  text-decoration: none;
  transition: .3s; }

p {
  line-height: 1.8em;
  color: #707070; }

a img {
  border-style: none; }
  a img:hover {
    opacity: 0.7; }

/** float **/
.fl0 {
  float: left; }

.fl10 {
  float: left;
  margin-right: 10px; }

.fr0 {
  float: right; }

.fr10 {
  float: right;
  margin-left: 10px; }

/** padding **/
.pb10 {
  padding-bottom: 10px; }

.pb20 {
  padding-bottom: 20px; }

.pb30 {
  padding-bottom: 30px; }

.pb40 {
  padding-bottom: 40px; }

.pb50 {
  padding-bottom: 50px; }

.pb60 {
  padding-bottom: 60px; }

.pb70 {
  padding-bottom: 70px; }

/** margin **/
.mb10 {
  margin-bottom: 10px; }

.mb20 {
  margin-bottom: 20px; }

.mb30 {
  margin-bottom: 30px; }

.mb40 {
  margin-bottom: 40px; }

.mb50 {
  margin-bottom: 50px; }

.mt10 {
  margin-top: 10px; }

.mt20 {
  margin-top: 20px; }

.mt30 {
  margin-top: 30px; }

.mt40 {
  margin-top: 40px; }

.mt50 {
  margin-top: 50px; }

.ml10 {
  margin-left: 10px; }

.ml20 {
  margin-left: 20px; }

.ml30 {
  margin-left: 30px; }

.ml40 {
  margin-left: 40px; }

.ml50 {
  margin-left: 50px; }

.mr10 {
  margin-right: 10px; }

.mr20 {
  margin-right: 20px; }

.mr30 {
  margin-right: 30px; }

.mr40 {
  margin-right: 40px; }

.mr50 {
  margin-right: 50px; }

/** text **/
.tcenter {
  text-align: center; }

.tright {
  text-align: right; }

.tleft {
  text-align: left; }

/** clear **/
.clear {
  clear: both; }

.pc {
  display: block; }
  @media screen and (max-width: 767px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media screen and (max-width: 767px) {
    .sp {
      display: block; } }

.inner, .about {
  width: min(83%, 1370px);
  margin: auto;
  position: relative; }

.flb_sb, .topabout .box, .flow .list, .item .box, .item h3, .item ul li, .faq .inner, .faq .about, .about, .differnce .list, .concept .txt, .voice .inner, .voice .about {
  display: flex;
  justify-content: space-between; }

.flb_ct, .mv .txt_pc, .differnce .list .box li {
  display: flex;
  justify-content: center; }

.flb_st, footer .inner, footer .about, .concept .inner, .concept .about {
  display: flex;
  justify-content: flex-start; }

.flb_ed, header, header ul {
  display: flex;
  justify-content: flex-end; }

.fadeIn {
  opacity: 0;
  transition: 3s; }
  .fadeIn.is-show {
    opacity: 1; }

.fadeIn_up {
  opacity: 0;
  transform: translate(0, 50px);
  transition: 2s; }
  .fadeIn_up.is-show {
    transform: translate(0, 0);
    opacity: 1; }

.fadeIn_left {
  opacity: 0;
  transform: translate(-50px, 0);
  transition: 2s; }
  .fadeIn_left.is-show {
    transform: translate(0, 0);
    opacity: 1; }

.fadeIn_right {
  opacity: 0;
  transform: translate(50px, 0);
  transition: 2s; }
  .fadeIn_right.is-show {
    transform: translate(0, 0);
    opacity: 1; }

@keyframes fadein {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }
body {
  background: #fff;
  line-height: 1.7em;
  font-size: 15px;
  font-family: "Shippori Mincho", serif;
  font-weight: 400;
  color: #707070;
  -webkit-text-size-adjust: 100%; }

* {
  box-sizing: border-box; }

img {
  max-width: 100%;
  display: block; }

iframe {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9; }

/* ヘッダー */
header {
  position: sticky;
  top: 0;
  left: 0;
  width: 100%;
  align-items: center;
  background: rgba(255, 255, 255, 0.8);
  padding: 20px min(6vw, 118px);
  z-index: 999; }
  @media screen and (max-width: 999px) {
    header {
      padding: 18px 22px; } }
  header .logo {
    display: block;
    width: 200px;
    margin-right: auto; }
    @media screen and (max-width: 767px) {
      header .logo {
        /*width: 38px;*/
        width: 180px; } }
  header ul {
    align-items: center; }
    @media screen and (max-width: 767px) {
      header ul {
        display: none;
        position: absolute;
        top: 100%;
        left: 0;
        width: 100%;
        height: 100vh;
        text-align: center;
        background: rgba(255, 255, 255, 0.8);
        padding-top: 100px;
        z-index: 99; } }
    header ul li {
      display: block;
      font-size: clamp(13px, 0.9vw, 19px);
      letter-spacing: 0.05em;
      padding-left: min(2.34vw, 45px); }
      @media screen and (max-width: 767px) {
        header ul li {
          font-size: 19px;
          padding-bottom: 33px; } }
      header ul li.btn a {
        background: #B9B993;
        color: #fff;
        padding: 0 11px;
        line-height: 42px;
        display: block; }
        header ul li.btn a:hover {
          opacity: .7; }
      @media screen and (max-width: 767px) {
        header ul li.btn {
          display: none; } }
      header ul li.spbtn {
        display: none; }
        @media screen and (max-width: 767px) {
          header ul li.spbtn {
            display: block;
            width: 90%;
            position: absolute;
            left: 5%;
            top: 80%; } }
  header .menu {
    display: none; }
    @media screen and (max-width: 767px) {
      header .menu {
        display: flex;
        justify-content: space-between;
        flex-direction: column;
        width: 28px;
        height: 16px;
        position: relative;
        z-index: 5; } }
    header .menu span {
      display: block;
      width: 100%;
      height: 1px;
      background: #707070;
      transition: .3s; }
    header .menu.active span {
      transition: .3s; }
      header .menu.active span:nth-of-type(1) {
        transform: translateY(7.5px) translateX(0) rotate(-45deg); }
      header .menu.active span:nth-of-type(2) {
        opacity: 0; }
      header .menu.active span:nth-of-type(3) {
        transform: translateY(-8.5px) translateX(0) rotate(45deg); }
  header .linebtn {
    position: absolute;
    top: 100%;
    right: 0;
    width: 59px; }
    @media screen and (max-width: 767px) {
      header .linebtn {
        display: none; } }

/* フッター */
footer {
  background: #E2E2E2;
  padding-top: 78px;
  padding-bottom: 70px; }
  @media screen and (max-width: 767px) {
    footer {
      padding-top: 40px;
      padding-bottom: 50px; } }
  footer .inner, footer .about {
    position: relative; }
    @media screen and (max-width: 767px) {
      footer .inner, footer .about {
        display: block; } }
    footer .inner .logo, footer .about .logo {
      display: block;
      width: 200px;
      margin-right: 10%; }
      @media screen and (max-width: 767px) {
        footer .inner .logo, footer .about .logo {
          width: 180px;
          padding-bottom: 40px; } }
    footer .inner ul, footer .about ul {
      margin-right: 10%; }
      @media screen and (max-width: 767px) {
        footer .inner ul, footer .about ul {
          display: inline-block; } }
      footer .inner ul li, footer .about ul li {
        font-size: clamp(14px, 0.9vw, 18px);
        padding-bottom: 15px;
        list-style: none; }
        @media screen and (max-width: 767px) {
          footer .inner ul li, footer .about ul li {
            font-size: 12px;
            padding-bottom: 10px; } }
    footer .inner .copy, footer .about .copy {
      position: absolute;
      right: 0;
      bottom: 0;
      font-size: 14px;
      color: rgba(112, 112, 112, 0.5); }
      @media screen and (max-width: 767px) {
        footer .inner .copy, footer .about .copy {
          font-size: 11px;
          position: relative;
          right: auto;
          bottom: auto;
          padding-top: 20px; } }

/* コンテンツ */
.btnmore {
  display: block;
  width: 190px;
  font-size: 16px;
  font-weight: 400;
  position: relative;
  padding-bottom: 6px; }
  @media screen and (max-width: 767px) {
    .btnmore {
      margin: auto;
      text-align: center; } }
  .btnmore::before, .btnmore::after {
    content: "";
    display: block;
    position: absolute;
    background: #707070;
    transition: .3s; }
  .btnmore::before {
    width: 100%;
    height: 1px;
    left: 0;
    bottom: 0; }
  .btnmore::after {
    width: 1px;
    height: 12px;
    transform: rotate(-45deg);
    right: 3px;
    bottom: -1px; }
  .btnmore:hover {
    color: #B9B993; }
    .btnmore:hover::before, .btnmore:hover::after {
      transition: .3s; }
    .btnmore:hover::before {
      width: calc(100% + 10px); }
    .btnmore:hover::after {
      right: -7px; }

.pagettl {
  padding: 250px 0;
  font-size: clamp(20px, 1.56vw, 30px);
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.46em;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .pagettl {
      padding: 50px 0;
      font-size: 22px; } }

/* トップページ */
.topttl {
  font-size: clamp(20px, 1.56vw, 30px);
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.46em;
  text-align: center;
  margin-bottom: 100px; }
  @media screen and (max-width: 767px) {
    .topttl {
      font-size: 25px;
      margin-bottom: 50px; } }
  .topttl span {
    position: relative;
    padding-bottom: 10px; }
    .topttl span::after {
      content: "";
      display: block;
      width: 100%;
      height: 1px;
      background: #707070;
      position: absolute;
      left: 0;
      bottom: 0; }

.mv {
  padding-right: min(6vw, 118px);
  position: relative; }
  @media screen and (max-width: 999px) {
    .mv {
      padding-right: 2vw; } }
  @media screen and (max-width: 767px) {
    .mv {
      padding-right: 0; } }
  .mv .txt_pc {
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    flex-direction: column;
    padding-left: min(6vw, 118px); }
    @media screen and (max-width: 999px) {
      .mv .txt_pc {
        padding-right: 2vw; } }
    @media screen and (max-width: 767px) {
      .mv .txt_pc {
        display: none; } }
    .mv .txt_pc h1 {
      font-size: clamp(30px, 2.8vw, 55px);
      line-height: 1.8em;
      font-weight: 400;
      padding-bottom: min(2.6vw, 50px);
      letter-spacing: 0.12em; }
      .mv .txt_pc h1 span {
        display: block;
        font-size: clamp(26px, 1.8vw, 34px);
        letter-spacing: 0; }
    .mv .txt_pc p {
      font-size: clamp(16px, 1vw, 20px); }
    .mv .txt_pc a {
      width: 360px;
      margin-top: min(3.3vw, 65px); }
    .mv .txt_pc .btn {
      display: block;
      width: 410px;
      line-height: 57px;
      background: #03C755;
      color: #fff;
      text-align: center;
      border-radius: 30px;
      letter-spacing: 0.05em;
      font-size: 21px;
      box-shadow: 2px 3px 4px rgba(0, 0, 0, 0.16);
      margin-top: min(3.3vw, 65px); }
      .mv .txt_pc .btn:hover {
        opacity: .7; }
  .mv .txt_sp {
    display: none; }
    @media screen and (max-width: 767px) {
      .mv .txt_sp {
        display: block;
        width: 100%;
        padding: 0 8.5%;
        position: absolute;
        left: 0;
        bottom: 32px;
        text-align: center; } }
    .mv .txt_sp h1 {
      color: #fff;
      font-size: 20px;
      letter-spacing: -0.03em;
      font-weight: 400;
      padding-bottom: 90px; }

.topabout {
  padding-top: 115px;
  padding-bottom: 270px; }
  @media screen and (max-width: 767px) {
    .topabout {
      padding-top: 50px;
      padding-bottom: 130px; } }
  .topabout h2 {
    text-align: center;
    font-size: 55px;
    font-weight: 400;
    letter-spacing: 0.05em;
    padding-bottom: 135px; }
    @media screen and (max-width: 767px) {
      .topabout h2 {
        font-size: 33px;
        padding-bottom: 30px; } }
  .topabout .box {
    align-items: flex-end; }
    @media screen and (max-width: 767px) {
      .topabout .box {
        display: block; } }
    .topabout .box .txt {
      width: 44%; }
      @media screen and (max-width: 767px) {
        .topabout .box .txt {
          width: 100%; } }
      .topabout .box .txt img {
        margin-top: 60px;
        margin-bottom: 40px; }
        @media screen and (max-width: 767px) {
          .topabout .box .txt img {
            margin-top: 37px;
            margin-bottom: 25px; } }
    .topabout .box .img {
      width: 49%; }
      @media screen and (max-width: 767px) {
        .topabout .box .img {
          display: none; } }
  .topabout h3 {
    font-size: clamp(20px, 1.56vw, 30px);
    letter-spacing: 0.05em;
    font-weight: 400;
    padding-bottom: 30px;
    line-height: 1.6em; }
    @media screen and (max-width: 767px) {
      .topabout h3 {
        font-size: 25px;
        text-align: center; } }
  .topabout p {
    font-size: clamp(14px, 0.9vw, 18px);
    letter-spacing: 0.05em;
    line-height: 1.9em; }
    @media screen and (max-width: 767px) {
      .topabout p {
        font-size: 16px;
        line-height: 2em; } }

.topreason {
  padding-top: 150px; }
  @media screen and (max-width: 767px) {
    .topreason {
      padding-top: 50px; } }
  .topreason .inner, .topreason .about {
    width: min(88%, 1550px);
    position: relative; }
    @media screen and (max-width: 999px) {
      .topreason .inner, .topreason .about {
        width: 100%; } }
  .topreason .txt {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 46%; }
    @media screen and (max-width: 767px) {
      .topreason .txt {
        bottom: auto;
        top: 3%;
        left: 8%;
        width: auto; } }
    .topreason .txt h2 {
      font-size: clamp(20px, 1.56vw, 30px);
      font-weight: 400;
      letter-spacing: 0.05em;
      line-height: 1.1em;
      padding-bottom: 25px; }
      @media screen and (max-width: 767px) {
        .topreason .txt h2 {
          display: none; } }
    .topreason .txt ul {
      padding-bottom: 35px; }
      @media screen and (max-width: 767px) {
        .topreason .txt ul {
          display: none; } }
      .topreason .txt ul li {
        list-style: none;
        font-size: clamp(14px, 0.9vw, 18px);
        line-height: 1.9em;
        letter-spacing: 0.05em; }
    .topreason .txt p {
      font-size: 16px;
      line-height: 2em;
      display: none; }
      @media screen and (max-width: 767px) {
        .topreason .txt p {
          display: block; } }
    @media screen and (max-width: 767px) {
      .topreason .txt .btnmore {
        display: none; } }
  .topreason .sptxt {
    display: none;
    padding-top: 66px; }
    @media screen and (max-width: 767px) {
      .topreason .sptxt {
        display: block;
        width: 85%;
        margin: auto; } }
    .topreason .sptxt h2 {
      font-size: 25px;
      font-weight: 400;
      letter-spacing: 0.05em;
      line-height: 1.6em;
      padding-bottom: 50px;
      text-align: center; }
    .topreason .sptxt ul {
      padding-bottom: 50px; }
      .topreason .sptxt ul li {
        display: block;
        background: #F5F5F5;
        padding: 10px 0 15px 0;
        text-align: center;
        margin-bottom: 8px;
        font-size: 16px;
        line-height: 1.7em; }
        .topreason .sptxt ul li span {
          display: block;
          font-family: "Petit Formal Script", cursive;
          font-size: 26px;
          padding-bottom: 10px; }

.topdifference {
  background: rgba(226, 241, 248, 0.66);
  padding-top: 100px;
  padding-bottom: 130px; }
  @media screen and (max-width: 767px) {
    .topdifference {
      padding: 50px 0; } }
  .topdifference .inner, .topdifference .about {
    width: min(83%, 1170px); }
  .topdifference .video {
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
    margin-bottom: 100px; }
    @media screen and (max-width: 767px) {
      .topdifference .video {
        margin-bottom: 50px; } }
  .topdifference .btnmore {
    margin: auto; }

.flow {
  padding-top: 248px;
  padding-bottom: 130px; }
  @media screen and (max-width: 767px) {
    .flow {
      padding-top: 100px;
      padding-bottom: 0; } }
  .flow .inner, .flow .about {
    width: min(83%, 1535px); }
    @media screen and (max-width: 767px) {
      .flow .inner, .flow .about {
        width: 100%; } }
  .flow .topttl {
    margin-bottom: 150px; }
    @media screen and (max-width: 767px) {
      .flow .topttl {
        margin-bottom: 104px; } }
  @media screen and (max-width: 767px) {
    .flow .list {
      display: block; } }
  .flow .list .box {
    width: 29%;
    position: relative; }
    @media screen and (max-width: 767px) {
      .flow .list .box {
        width: 100%;
        padding-bottom: 100px; }
        .flow .list .box:nth-child(odd) {
          padding-right: 8.5%; }
          .flow .list .box:nth-child(odd) h3 {
            padding-left: 8.5%; }
          .flow .list .box:nth-child(odd) p {
            padding-left: 8.5%; }
        .flow .list .box:nth-child(even) {
          padding-left: 8.5%; }
          .flow .list .box:nth-child(even) h3 {
            padding-right: 8.5%; }
          .flow .list .box:nth-child(even) p {
            padding-right: 8.5%; } }
  .flow .list .no {
    font-family: "Petit Formal Script", cursive;
    font-size: clamp(70px, 6.4vw, 123px);
    color: #B9B993;
    position: absolute;
    top: -35px;
    left: -20px; }
    @media screen and (max-width: 767px) {
      .flow .list .no {
        font-size: 100px;
        left: 8.5%; } }
  .flow .list img {
    margin-bottom: 55px; }
    @media screen and (max-width: 767px) {
      .flow .list img {
        margin-bottom: 50px; } }
  .flow .list h3 {
    font-size: clamp(20px, 1.56vw, 30px);
    padding-bottom: 30px;
    font-weight: 400;
    line-height: 1.46em;
    letter-spacing: 0.05em; }
    @media screen and (max-width: 767px) {
      .flow .list h3 {
        font-size: 23px;
        padding-bottom: 24px; } }
  .flow .list p {
    font-size: clamp(14px, 0.9vw, 18px);
    letter-spacing: 0.05em;
    line-height: 1.9em; }
    @media screen and (max-width: 767px) {
      .flow .list p {
        font-size: 16px; } }
    .flow .list p.pb {
      padding-bottom: 45px; }

.item {
  background: #F5F5F5;
  padding: 100px 0; }
  @media screen and (max-width: 767px) {
    .item {
      padding: 50px 0; } }
  .item .box {
    background: #fff;
    align-items: center; }
    @media screen and (max-width: 767px) {
      .item .box {
        display: block; } }
  .item .img {
    width: 50%; }
    @media screen and (max-width: 767px) {
      .item .img {
        width: 100%; } }
  .item .txt {
    width: 50%;
    padding: 50px; }
    @media screen and (max-width: 767px) {
      .item .txt {
        width: 100%;
        padding: 20px 20px 40px 20px; } }
  .item h3 {
    font-size: clamp(20px, 1.56vw, 30px);
    margin-bottom: 30px;
    font-weight: 400;
    line-height: 1.46em;
    letter-spacing: 0.05em;
    border-bottom: #707070 1px solid;
    padding-bottom: 5px;
    align-items: center; }
    @media screen and (max-width: 767px) {
      .item h3 {
        font-size: 23px;
        margin-bottom: 10px;
        display: block; } }
    .item h3 b {
      font-weight: 400;
      font-size: 1.3em; }
      @media screen and (max-width: 767px) {
        .item h3 b {
          padding-top: 10px;
          display: block; } }
      .item h3 b span {
        font-size: 14px; }
  .item ol {
    padding: 10px 20px 20px 20px; }
    .item ol li {
      list-style: none;
      display: inline-block;
      margin-right: 15px;
      font-size: 13px; }
      @media screen and (max-width: 767px) {
        .item ol li {
          font-size: 12px; } }
      .item ol li:last-child {
        margin-right: 0; }
  .item ul {
    padding-bottom: 5px; }
    .item ul li {
      list-style: none;
      align-items: center;
      line-height: 2em; }
      .item ul li span {
        font-size: 1.2em; }
      .item ul li:last-child {
        padding-top: 10px;
        margin-top: 10px;
        border-top: #707070 1px solid; }
  .item p {
    font-size: 12px;
    text-align: right; }

.faq {
  padding: 245px 0; }
  @media screen and (max-width: 767px) {
    .faq {
      padding: 100px 0; } }
  @media screen and (max-width: 767px) {
    .faq .inner, .faq .about {
      display: block; } }
  .faq h2 {
    font-size: clamp(20px, 1.56vw, 30px);
    letter-spacing: 0.05em;
    font-weight: 400; }
    @media screen and (max-width: 767px) {
      .faq h2 {
        font-size: 25px; } }
  .faq dl {
    width: 55%; }
    @media screen and (max-width: 767px) {
      .faq dl {
        width: 100%; } }
    .faq dl dt {
      font-size: clamp(16px, 0.9vw, 20px);
      font-weight: 400;
      padding-bottom: 23px;
      letter-spacing: 0.05em; }
      @media screen and (max-width: 767px) {
        .faq dl dt {
          letter-spacing: -0.02em;
          font-size: 17px;
          padding-bottom: 10px; } }
    .faq dl dd {
      font-size: clamp(14px, 0.9vw, 18px);
      padding-bottom: 75px;
      letter-spacing: 0.05em;
      line-height: 1.9em; }
      @media screen and (max-width: 767px) {
        .faq dl dd {
          font-size: 16px;
          padding-bottom: 50px; } }

/* コンセプト */
.about {
  flex-direction: row-reverse;
  align-items: flex-end;
  margin-top: -130px;
  padding-bottom: 200px; }
  @media screen and (max-width: 767px) {
    .about {
      display: block;
      padding: 100px 0;
      margin-top: 0; } }
  .about h1 {
    font-size: clamp(20px, 1.56vw, 30px);
    letter-spacing: 0.05em;
    font-weight: 400;
    padding-bottom: 23px; }
    @media screen and (max-width: 767px) {
      .about h1 {
        font-size: 25px;
        text-align: center;
        padding-bottom: 50px; } }
  .about p {
    font-size: clamp(14px, 0.9vw, 18px);
    line-height: 1.9em; }
    @media screen and (max-width: 767px) {
      .about p {
        font-size: 16px; } }
  .about .txt {
    width: 40%; }
    @media screen and (max-width: 767px) {
      .about .txt {
        width: 100%;
        padding-bottom: 50px; } }
  .about .video {
    width: 57%;
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16); }
    @media screen and (max-width: 767px) {
      .about .video {
        width: 100%; } }

.differnce {
  padding: 100px 0;
  background: #F5F5F5;
  position: relative; }
  @media screen and (max-width: 767px) {
    .differnce {
      padding: 50px 0; } }
  .differnce::after {
    content: "";
    display: block;
    width: 100%;
    aspect-ratio: 1953 / 64;
    background: url("../images/concept/line.jpg") center top no-repeat;
    background-size: 100% auto;
    position: absolute;
    left: 0;
    top: 100%; }
  .differnce .list {
    align-items: flex-end;
    max-width: 1280px;
    margin: auto; }
    .differnce .list li {
      list-style: none;
      text-align: center; }
    .differnce .list h3 {
      text-align: center;
      font-size: 24px;
      font-weight: 400;
      padding-bottom: 15px;
      line-height: 1.4em; }
      @media screen and (max-width: 999px) {
        .differnce .list h3 {
          font-size: 18px; } }
      @media screen and (max-width: 767px) {
        .differnce .list h3 {
          font-size: 15px;
          padding-bottom: 10px; } }
    .differnce .list .box {
      width: 42%;
      background: #fff;
      padding: 26px 50px 30px 50px; }
      @media screen and (max-width: 999px) {
        .differnce .list .box {
          padding-left: 20px;
          padding-right: 20px; } }
      @media screen and (max-width: 767px) {
        .differnce .list .box {
          padding: 8px 0 0 0;
          width: 41%; } }
      .differnce .list .box img {
        margin-bottom: 30px; }
        @media screen and (max-width: 767px) {
          .differnce .list .box img {
            margin-bottom: 0; } }
      .differnce .list .box li {
        font-size: 18px;
        align-items: center;
        height: 86px;
        background: #f0f0f0;
        margin-bottom: 10px;
        padding: 0 10px; }
        @media screen and (max-width: 999px) {
          .differnce .list .box li {
            font-size: 16px; } }
        @media screen and (max-width: 767px) {
          .differnce .list .box li {
            font-size: 11px;
            margin-bottom: 6px;
            height: 70px;
            padding: 0;
            line-height: 1.4em; } }
        .differnce .list .box li:last-child {
          margin-bottom: 0; }
    .differnce .list .ttl {
      width: 16%;
      padding-bottom: 30px; }
      @media screen and (max-width: 767px) {
        .differnce .list .ttl {
          width: 18%;
          padding-bottom: 0; } }
      .differnce .list .ttl li {
        line-height: 86px;
        margin-bottom: 10px;
        font-size: 20px; }
        @media screen and (max-width: 767px) {
          .differnce .list .ttl li {
            font-size: 11px;
            line-height: 70px;
            margin-bottom: 6px; } }
        .differnce .list .ttl li:last-child {
          margin-bottom: 0; }

.concept {
  padding-top: 260px;
  padding-bottom: 100px; }
  @media screen and (max-width: 767px) {
    .concept {
      padding-top: 100px;
      padding-bottom: 0; } }
  .concept .inner, .concept .about {
    width: 100%; }
    @media screen and (max-width: 767px) {
      .concept .inner, .concept .about {
        display: block;
        width: 83%; } }
  .concept .img {
    width: 54%;
    margin-right: 5%; }
    @media screen and (max-width: 767px) {
      .concept .img {
        display: none; } }
    .concept .img img {
      width: 100%;
      height: 100%;
      object-fit: cover; }
  .concept .txt {
    flex-direction: column;
    width: min(35%, 500px); }
    @media screen and (max-width: 767px) {
      .concept .txt {
        display: block;
        width: 100%;
        padding-top: 50px; } }
    .concept .txt .paragraph {
      padding-bottom: 30px; }
      @media screen and (max-width: 767px) {
        .concept .txt .paragraph {
          padding-bottom: 0; } }
    @media screen and (max-width: 767px) {
      .concept .txt img {
        display: none; } }
  .concept h2 {
    font-size: clamp(20px, 1.56vw, 30px);
    letter-spacing: 0.05em;
    font-weight: 400;
    line-height: 2.1em;
    padding-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .concept h2 {
        font-size: 22px;
        line-height: 1.6em; } }
  .concept p {
    font-size: clamp(14px, 0.9vw, 18px); }
    @media screen and (max-width: 767px) {
      .concept p {
        font-size: 15px; } }

.voice {
  padding-top: 100px;
  padding-bottom: 250px; }
  .voice .inner, .voice .about {
    flex-wrap: wrap; }
    @media screen and (max-width: 767px) {
      .voice .inner, .voice .about {
        display: block; } }
    .voice .inner h2, .voice .about h2 {
      width: 100%; }
  .voice .video {
    width: 53.7%; }
    @media screen and (max-width: 767px) {
      .voice .video {
        width: 100%;
        margin-bottom: 50px; } }
  .voice .txt {
    width: 37.7%; }
    @media screen and (max-width: 767px) {
      .voice .txt {
        width: 100%; } }
  .voice h3 {
    font-size: clamp(20px, 1.56vw, 30px);
    letter-spacing: 0.05em;
    font-weight: 400;
    padding-bottom: 30px; }
    @media screen and (max-width: 767px) {
      .voice h3 {
        font-size: 23px;
        padding-bottom: 25px; } }
    .voice h3 span {
      font-size: clamp(15px, 0.9vw, 20px);
      margin-left: 10px; }
      @media screen and (max-width: 767px) {
        .voice h3 span {
          font-size: 15px; } }
  .voice ul {
    padding-bottom: 20px; }
    .voice ul li {
      list-style: none;
      font-size: clamp(14px, 0.9vw, 18px);
      line-height: 1.9em;
      letter-spacing: 0.05em; }
  .voice p {
    font-size: clamp(14px, 0.9vw, 18px);
    line-height: 1.9em;
    letter-spacing: 0.05em; }

/* 特定商取引法に基づく表記 */
.policy {
  padding-bottom: 200px; }
  @media screen and (max-width: 767px) {
    .policy {
      padding-bottom: 80px; } }
  .policy h2 {
    font-size: clamp(15px, 0.9vw, 17px);
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 1.5em;
    padding-bottom: 20px; }
    @media screen and (max-width: 767px) {
      .policy h2 {
        font-size: 13px;
        padding-bottom: 10px; } }
    .policy h2 span {
      margin-right: 10px; }
  .policy ul, .policy ol {
    padding-bottom: 40px; }
    @media screen and (max-width: 767px) {
      .policy ul, .policy ol {
        padding-bottom: 20px; } }
    .policy ul li, .policy ol li {
      list-style: none;
      font-size: clamp(15px, 0.9vw, 17px);
      font-weight: 400;
      letter-spacing: 0.01em;
      line-height: 1.8em; }
  .policy ul li {
    position: relative;
    padding-left: 15px; }
    @media screen and (max-width: 767px) {
      .policy ul li {
        font-size: 13px; } }
    .policy ul li::before {
      content: "・";
      position: absolute;
      top: 0;
      left: 0; }
  .policy ol li {
    text-indent: -0.9em;
    padding-left: 0.9em; }
    .policy ol li ol li {
      text-indent: -3em;
      padding-left: 3em; }
    .policy ol li ol.circle li {
      text-indent: -1em;
      padding-left: 1em; }
  .policy p {
    font-size: clamp(15px, 0.9vw, 17px);
    font-weight: 400;
    letter-spacing: 0.01em;
    line-height: 1.8em; }
    @media screen and (max-width: 767px) {
      .policy p {
        font-size: 13px; } }
    .policy p.pb {
      padding-bottom: 40px; }
      @media screen and (max-width: 767px) {
        .policy p.pb {
          padding-bottom: 20px; } }
    .policy p.date {
      text-align: right; }
