@charset "UTF-8";
/* Reset Style */
@import url("https://fonts.googleapis.com/css2?family=Josefin+Sans:wght@100;400;600&family=Zen+Kaku+Gothic+New:wght@400;700&display=swap");
html {
  overflow-y: scroll;
}

body {
  line-height: 1;
  color: #000;
}

/* html5doctor.com Reset Stylesheet v1.6.1
Last Updated: 2010-09-17 Author: Richard Clark - http://richclarkdesign.com Twitter: @rich_clark */
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;
  vertical-align: baseline;
  background: transparent;
}

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

ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

a {
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  background: transparent;
}

ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

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;
}

hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input, select {
  vertical-align: middle;
}

/* YUI 3.4.1 (build 4118) Copyright 2011 Yahoo! Inc. All rights reserved.
Licensed under the BSD License. http://yuilibrary.com/license/ */
body {
  font: 13px/1.231 arial, helvetica, clean, sans-serif;
  *font-size: small;
  *font: x-small;
}

select, input, button, textarea {
  font: 99% arial, helvetica, clean, sans-serif;
}

table {
  font-size: inherit;
  font: 100%;
}

pre, code, kbd, samp, tt {
  font-family: monospace;
  *font-size: 108%;
  line-height: 100%;
}

/**以下レスポンシブグリッド用**/
.mt0 {
  margin-top: 0px !important;
}

.mb0 {
  margin-bottom: 0px !important;
}

.pt0 {
  padding-top: 0px !important;
}

.pb0 {
  padding-bottom: 0px !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.mt25 {
  margin-top: 25px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.mt30 {
  margin-top: 30px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.mt35 {
  margin-top: 35px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.mt45 {
  margin-top: 45px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.mt50 {
  margin-top: 50px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.mt55 {
  margin-top: 55px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.pt55 {
  padding-top: 55px !important;
}

.pb55 {
  padding-bottom: 55px !important;
}

.mt60 {
  margin-top: 60px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.pt60 {
  padding-top: 60px !important;
}

.pb60 {
  padding-bottom: 60px !important;
}

.mt65 {
  margin-top: 65px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.pt65 {
  padding-top: 65px !important;
}

.pb65 {
  padding-bottom: 65px !important;
}

.mt70 {
  margin-top: 70px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.pt70 {
  padding-top: 70px !important;
}

.pb70 {
  padding-bottom: 70px !important;
}

.mt75 {
  margin-top: 75px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.pt75 {
  padding-top: 75px !important;
}

.pb75 {
  padding-bottom: 75px !important;
}

.mt80 {
  margin-top: 80px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.pt80 {
  padding-top: 80px !important;
}

.pb80 {
  padding-bottom: 80px !important;
}

.mt85 {
  margin-top: 85px !important;
}

.mb85 {
  margin-bottom: 85px !important;
}

.pt85 {
  padding-top: 85px !important;
}

.pb85 {
  padding-bottom: 85px !important;
}

.mt90 {
  margin-top: 90px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.pt90 {
  padding-top: 90px !important;
}

.pb90 {
  padding-bottom: 90px !important;
}

.mt95 {
  margin-top: 95px !important;
}

.mb95 {
  margin-bottom: 95px !important;
}

.pt95 {
  padding-top: 95px !important;
}

.pb95 {
  padding-bottom: 95px !important;
}

.mt100 {
  margin-top: 100px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.pt100 {
  padding-top: 100px !important;
}

.pb100 {
  padding-bottom: 100px !important;
}

/*
  clamp()関数の推奨値を1次関数を用いて計算
  $property: プロパティ
  $minBp: 下限ブレークポイント
  $maxBp: 上限ブレークポイント
  $minVal: 最小値
  $maxVal: 最大値

  @include clampFunction('プロパティ', 下限ブレークポイント, 上限ブレークポイント, 最小値, 最大値);
*/
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}

.container-fluid, .container {
  margin-right: auto;
  margin-left: auto;
  padding-left: 15px;
  padding-right: 15px;
}

.row {
  box-sizing: border-box;
  display: flex;
  flex: 0 1 auto;
  flex-direction: row;
  flex-wrap: wrap;
  margin-right: -15px;
  margin-left: -15px;
}
.row.reverse {
  flex-direction: row-reverse;
}

.col.reverse {
  flex-direction: column-reverse;
}

.col-1, .col-2, .col-3, .col-4, .col-5, .col-6, .col-7, .col-8, .col-9, .col-10, .col-11, .col-12, .col, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg, .col-xl-1, .col-xl-2, .col-xl-3, .col-xl-4, .col-xl-5, .col-xl-6, .col-xl-7, .col-xl-8, .col-xl-9, .col-xl-10, .col-xl-11, .col-xl-12, .col-xl {
  width: 100%;
  position: relative;
  padding-right: 15px;
  padding-left: 15px;
}

.col-xs, .col-xs-1, .col-xs-2, .col-xs-3, .col-xs-4, .col-xs-5, .col-xs-6, .col-xs-7, .col-xs-8, .col-xs-9, .col-xs-10, .col-xs-11, .col-xs-12, .col-xs-offset-0, .col-xs-offset-1, .col-xs-offset-2, .col-xs-offset-3, .col-xs-offset-4, .col-xs-offset-5, .col-xs-offset-6, .col-xs-offset-7, .col-xs-offset-8, .col-xs-offset-9, .col-xs-offset-10, .col-xs-offset-11, .col-xs-offset-12 {
  box-sizing: border-box;
  flex: 0 0 auto;
  padding-right: 15px;
  padding-left: 15px;
}

.col-xs {
  flex-grow: 1;
  flex-basis: 0;
  max-width: 100%;
}

.col-xs-1 {
  flex-basis: 8.33333333%;
  max-width: 8.33333333%;
}

.col-xs-2 {
  flex-basis: 16.66666667%;
  max-width: 16.66666667%;
}

.col-xs-3 {
  flex-basis: 25%;
  max-width: 25%;
}

.col-xs-4 {
  flex-basis: 33.33333333%;
  max-width: 33.33333333%;
}

.col-xs-5 {
  flex-basis: 41.66666667%;
  max-width: 41.66666667%;
}

.col-xs-6 {
  flex-basis: 50%;
  max-width: 50%;
}

.col-xs-7 {
  flex-basis: 58.33333333%;
  max-width: 58.33333333%;
}

.col-xs-8 {
  flex-basis: 66.66666667%;
  max-width: 66.66666667%;
}

.col-xs-9 {
  flex-basis: 75%;
  max-width: 75%;
}

.col-xs-10 {
  flex-basis: 83.33333333%;
  max-width: 83.33333333%;
}

.col-xs-11 {
  flex-basis: 91.66666667%;
  max-width: 91.66666667%;
}

.col-xs-12 {
  flex-basis: 100%;
  max-width: 100%;
}

.col-xs-offset-0 {
  margin-left: 0;
}

.col-xs-offset-1 {
  margin-left: 8.33333333%;
}

.col-xs-offset-2 {
  margin-left: 16.66666667%;
}

.col-xs-offset-3 {
  margin-left: 25%;
}

.col-xs-offset-4 {
  margin-left: 33.33333333%;
}

.col-xs-offset-5 {
  margin-left: 41.66666667%;
}

.col-xs-offset-6 {
  margin-left: 50%;
}

.col-xs-offset-7 {
  margin-left: 58.33333333%;
}

.col-xs-offset-8 {
  margin-left: 66.66666667%;
}

.col-xs-offset-9 {
  margin-left: 75%;
}

.col-xs-offset-10 {
  margin-left: 83.33333333%;
}

.col-xs-offset-11 {
  margin-left: 91.66666667%;
}

.start-xs {
  justify-content: flex-start;
  text-align: start;
}

.center-xs {
  justify-content: center;
  text-align: center;
}

.end-xs {
  justify-content: flex-end;
  text-align: end;
}

.top-xs {
  align-items: flex-start;
}

.middle-xs {
  align-items: center;
}

.bottom-xs {
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
}

.around-xs {
  -ms-flex-pack: distribute;
  justify-content: space-around;
}

.between-xs {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}

.first-xs {
  -webkit-box-ordinal-group: 0;
  -ms-flex-order: -1;
  order: -1;
}

.last-xs {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1;
}

@media (min-width: 768px) {
  .container {
    width: 768px;
  }
  .col-sm, .col-sm-1, .col-sm-2, .col-sm-3, .col-sm-4, .col-sm-5, .col-sm-6, .col-sm-7, .col-sm-8, .col-sm-9, .col-sm-10, .col-sm-11, .col-sm-12, .col-sm-offset-0, .col-sm-offset-1, .col-sm-offset-2, .col-sm-offset-3, .col-sm-offset-4, .col-sm-offset-5, .col-sm-offset-6, .col-sm-offset-7, .col-sm-offset-8, .col-sm-offset-9, .col-sm-offset-10, .col-sm-offset-11, .col-sm-offset-12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: 15px;
    padding-left: 15px;
  }
  .col-sm {
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }
  .col-sm-1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }
  .col-sm-2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }
  .col-sm-3 {
    flex-basis: 25%;
    max-width: 25%;
  }
  .col-sm-4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }
  .col-sm-5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }
  .col-sm-6 {
    flex-basis: 50%;
    max-width: 50%;
  }
  .col-sm-7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }
  .col-sm-8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }
  .col-sm-9 {
    flex-basis: 75%;
    max-width: 75%;
  }
  .col-sm-10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }
  .col-sm-11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }
  .col-sm-12 {
    flex-basis: 100%;
    max-width: 100%;
  }
  .col-sm-offset-0 {
    margin-left: 0;
  }
  .col-sm-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-sm-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-sm-offset-3 {
    margin-left: 25%;
  }
  .col-sm-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-sm-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-sm-offset-6 {
    margin-left: 50%;
  }
  .col-sm-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-sm-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-sm-offset-9 {
    margin-left: 75%;
  }
  .col-sm-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-sm-offset-11 {
    margin-left: 91.66666667%;
  }
  .start-sm {
    justify-content: flex-start;
    text-align: start;
  }
  .center-sm {
    text-align: center;
  }
  .end-sm {
    justify-content: flex-end;
    text-align: end;
  }
  .top-sm {
    align-items: flex-start;
  }
  .middle-sm {
    align-items: center;
  }
  .bottom-sm {
    align-items: flex-end;
  }
  .around-sm {
    justify-content: space-around;
  }
  .between-sm {
    justify-content: space-between;
  }
  .first-sm {
    order: -1;
  }
  .last-sm {
    order: 1;
  }
}
@media (min-width: 992px) {
  .container {
    width: 992px;
  }
  .col-md, .col-md-1, .col-md-2, .col-md-3, .col-md-4, .col-md-5, .col-md-6, .col-md-7, .col-md-8, .col-md-9, .col-md-10, .col-md-11, .col-md-12, .col-md-offset-0, .col-md-offset-1, .col-md-offset-2, .col-md-offset-3, .col-md-offset-4, .col-md-offset-5, .col-md-offset-6, .col-md-offset-7, .col-md-offset-8, .col-md-offset-9, .col-md-offset-10, .col-md-offset-11, .col-md-offset-12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: 15px;
    padding-left: 15px;
  }
  .col-md {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }
  .col-md-1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }
  .col-md-2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }
  .col-md-3 {
    flex-basis: 25%;
    max-width: 25%;
  }
  .col-md-4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }
  .col-md-5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }
  .col-md-6 {
    flex-basis: 50%;
    max-width: 50%;
  }
  .col-md-7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }
  .col-md-8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }
  .col-md-9 {
    flex-basis: 75%;
    max-width: 75%;
  }
  .col-md-10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }
  .col-md-11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }
  .col-md-12 {
    flex-basis: 100%;
    max-width: 100%;
  }
  .col-md-offset-0 {
    margin-left: 0;
  }
  .col-md-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-md-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-md-offset-3 {
    margin-left: 25%;
  }
  .col-md-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-md-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-md-offset-6 {
    margin-left: 50%;
  }
  .col-md-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-md-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-md-offset-9 {
    margin-left: 75%;
  }
  .col-md-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-md-offset-11 {
    margin-left: 91.66666667%;
  }
  .start-md {
    justify-content: flex-start;
    text-align: start;
  }
  .center-md {
    text-align: center;
  }
  .end-md {
    justify-content: flex-end;
    text-align: end;
  }
  .top-md {
    align-items: flex-start;
  }
  .middle-md {
    align-items: center;
  }
  .bottom-md {
    align-items: flex-end;
  }
  .around-md {
    justify-content: space-around;
  }
  .between-md {
    justify-content: space-between;
  }
  .first-md {
    order: -1;
  }
  .last-md {
    order: 1;
  }
}
@media (min-width: 1300px) {
  .container {
    width: 1300px;
  }
  .col-lg, .col-lg-1, .col-lg-2, .col-lg-3, .col-lg-4, .col-lg-5, .col-lg-6, .col-lg-7, .col-lg-8, .col-lg-9, .col-lg-10, .col-lg-11, .col-lg-12, .col-lg-offset-0, .col-lg-offset-1, .col-lg-offset-2, .col-lg-offset-3, .col-lg-offset-4, .col-lg-offset-5, .col-lg-offset-6, .col-lg-offset-7, .col-lg-offset-8, .col-lg-offset-9, .col-lg-offset-10, .col-lg-offset-11, .col-lg-offset-12 {
    box-sizing: border-box;
    flex: 0 0 auto;
    padding-right: 15px;
    padding-left: 15px;
  }
  .col-lg {
    flex-grow: 1;
    flex-basis: 0;
    max-width: 100%;
  }
  .col-lg-1 {
    flex-basis: 8.33333333%;
    max-width: 8.33333333%;
  }
  .col-lg-2 {
    flex-basis: 16.66666667%;
    max-width: 16.66666667%;
  }
  .col-lg-3 {
    flex-basis: 25%;
    max-width: 25%;
  }
  .col-lg-4 {
    flex-basis: 33.33333333%;
    max-width: 33.33333333%;
  }
  .col-lg-5 {
    flex-basis: 41.66666667%;
    max-width: 41.66666667%;
  }
  .col-lg-6 {
    flex-basis: 50%;
    max-width: 50%;
  }
  .col-lg-7 {
    flex-basis: 58.33333333%;
    max-width: 58.33333333%;
  }
  .col-lg-8 {
    flex-basis: 66.66666667%;
    max-width: 66.66666667%;
  }
  .col-lg-9 {
    flex-basis: 75%;
    max-width: 75%;
  }
  .col-lg-10 {
    flex-basis: 83.33333333%;
    max-width: 83.33333333%;
  }
  .col-lg-11 {
    flex-basis: 91.66666667%;
    max-width: 91.66666667%;
  }
  .col-lg-12 {
    flex-basis: 100%;
    max-width: 100%;
  }
  .col-lg-offset-0 {
    margin-left: 0;
  }
  .col-lg-offset-1 {
    margin-left: 8.33333333%;
  }
  .col-lg-offset-2 {
    margin-left: 16.66666667%;
  }
  .col-lg-offset-3 {
    margin-left: 25%;
  }
  .col-lg-offset-4 {
    margin-left: 33.33333333%;
  }
  .col-lg-offset-5 {
    margin-left: 41.66666667%;
  }
  .col-lg-offset-6 {
    margin-left: 50%;
  }
  .col-lg-offset-7 {
    margin-left: 58.33333333%;
  }
  .col-lg-offset-8 {
    margin-left: 66.66666667%;
  }
  .col-lg-offset-9 {
    margin-left: 75%;
  }
  .col-lg-offset-10 {
    margin-left: 83.33333333%;
  }
  .col-lg-offset-11 {
    margin-left: 91.66666667%;
  }
  .start-lg {
    justify-content: flex-start;
    text-align: start;
  }
  .center-lg {
    text-align: center;
  }
  .end-lg {
    justify-content: flex-end;
    text-align: end;
  }
  .top-lg {
    align-items: flex-start;
  }
  .middle-lg {
    align-items: center;
  }
  .bottom-lg {
    align-items: flex-end;
  }
  .around-lg {
    justify-content: space-around;
  }
  .between-lg {
    justify-content: space-between;
  }
  .first-lg {
    order: -1;
  }
  .last-lg {
    order: 1;
  }
}
.visible-xs {
  display: none !important;
}

.visible-sm {
  display: none !important;
}

.visible-md {
  display: none !important;
}

.visible-lg {
  display: none !important;
}

.visible-xs-block,
.visible-xs-inline,
.visible-xs-inline-block,
.visible-sm-block,
.visible-sm-inline,
.visible-sm-inline-block,
.visible-md-block,
.visible-md-inline,
.visible-md-inline-block,
.visible-lg-block,
.visible-lg-inline,
.visible-lg-inline-block {
  display: none !important;
}

@media (max-width: 767px) {
  .visible-xs {
    display: block !important;
  }
  table.visible-xs {
    display: table !important;
  }
  tr.visible-xs {
    display: table-row !important;
  }
  th.visible-xs,
  td.visible-xs {
    display: table-cell !important;
  }
}
@media (max-width: 767px) {
  .visible-xs-block {
    display: block !important;
  }
}

@media (max-width: 767px) {
  .visible-xs-inline {
    display: inline !important;
  }
}

@media (max-width: 767px) {
  .visible-xs-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm {
    display: block !important;
  }
  table.visible-sm {
    display: table !important;
  }
  tr.visible-sm {
    display: table-row !important;
  }
  th.visible-sm,
  td.visible-sm {
    display: table-cell !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-block {
    display: block !important;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline {
    display: inline !important;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .visible-sm-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 992px) and (max-width: 1299px) {
  .visible-md {
    display: block !important;
  }
  table.visible-md {
    display: table !important;
  }
  tr.visible-md {
    display: table-row !important;
  }
  th.visible-md,
  td.visible-md {
    display: table-cell !important;
  }
}
@media (min-width: 992px) and (max-width: 1299px) {
  .visible-md-block {
    display: block !important;
  }
}

@media (min-width: 992px) and (max-width: 1299px) {
  .visible-md-inline {
    display: inline !important;
  }
}

@media (min-width: 992px) and (max-width: 1299px) {
  .visible-md-inline-block {
    display: inline-block !important;
  }
}

@media (min-width: 1300px) {
  .visible-lg {
    display: block !important;
  }
  table.visible-lg {
    display: table !important;
  }
  tr.visible-lg {
    display: table-row !important;
  }
  th.visible-lg,
  td.visible-lg {
    display: table-cell !important;
  }
}
@media (min-width: 1300px) {
  .visible-lg-block {
    display: block !important;
  }
}

@media (min-width: 1300px) {
  .visible-lg-inline {
    display: inline !important;
  }
}

@media (min-width: 1300px) {
  .visible-lg-inline-block {
    display: inline-block !important;
  }
}

@media (max-width: 767px) {
  .hidden-xs {
    display: none !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .hidden-sm {
    display: none !important;
  }
}
@media (min-width: 992px) and (max-width: 1299px) {
  .hidden-md {
    display: none !important;
  }
}
@media (min-width: 1300px) {
  .hidden-lg {
    display: none !important;
  }
}
@media (max-width: 767px) {
  .xs-center {
    text-align: center !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .sm-center {
    text-align: center !important;
  }
}
@media (min-width: 992px) and (max-width: 1299px) {
  .md-center {
    text-align: center !important;
  }
}
@media (min-width: 1300px) {
  .lg-center {
    text-align: center !important;
  }
}
@media (max-width: 767px) {
  .xs-right {
    text-align: right !important;
  }
}
@media (min-width: 768px) and (max-width: 991px) {
  .sm-right {
    text-align: right !important;
  }
}
@media (min-width: 992px) and (max-width: 1299px) {
  .md-right {
    text-align: right !important;
  }
}
@media (min-width: 1300px) {
  .lg-right {
    text-align: right !important;
  }
}
:root {
  font-size: 62.5%;
  letter-spacing: 1px;
}

body {
  background: #fff;
  color: #332d2b;
  font-family: "游ゴシック", YuGothic, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Verdana, sans-serif;
  -webkit-text-size-adjust: 100%;
  font-feature-settings: "palt";
}

#page {
  position: relative;
  font-size: 1.6rem;
  overflow: hidden;
  font-weight: 400;
}

#page {
  min-width: 1100px;
}

.container {
  width: 1100px;
}

a:link {
  color: #00f;
  text-decoration: none;
}
a:visited {
  color: #00f;
}
a:hover {
  color: #00f;
}
a:active {
  color: #00f;
}

img {
  line-height: 1;
  font-size: 0;
  vertical-align: top;
  height: auto;
  max-width: 100%;
}

table {
  width: 100%;
  margin: 0 auto 20px;
  border-collapse: collapse;
}

th,
td {
  padding: 10px;
  border: 1px solid #ccc;
  vertical-align: top;
}

/* スマホ
-------------------------------------------------- */
@media only screen and (max-width: 767px) {
  #page {
    min-width: 100%;
    font-size: 1.5rem;
  }
  .container {
    width: 100%;
  }
  .row {
    margin-left: -5px;
    margin-right: -5px;
  }
  .col,
  .col-1,
  .col-10,
  .col-11,
  .col-12,
  .col-2,
  .col-3,
  .col-4,
  .col-5,
  .col-6,
  .col-7,
  .col-8,
  .col-9,
  .col-lg,
  .col-lg-1,
  .col-lg-10,
  .col-lg-11,
  .col-lg-12,
  .col-lg-2,
  .col-lg-3,
  .col-lg-4,
  .col-lg-5,
  .col-lg-6,
  .col-lg-7,
  .col-lg-8,
  .col-lg-9,
  .col-md,
  .col-md-1,
  .col-md-10,
  .col-md-11,
  .col-md-12,
  .col-md-2,
  .col-md-3,
  .col-md-4,
  .col-md-5,
  .col-md-6,
  .col-md-7,
  .col-md-8,
  .col-md-9,
  .col-sm,
  .col-sm-1,
  .col-sm-10,
  .col-sm-11,
  .col-sm-12,
  .col-sm-2,
  .col-sm-3,
  .col-sm-4,
  .col-sm-5,
  .col-sm-6,
  .col-sm-7,
  .col-sm-8,
  .col-sm-9,
  .col-xl,
  .col-xl-1,
  .col-xl-10,
  .col-xl-11,
  .col-xl-12,
  .col-xl-2,
  .col-xl-3,
  .col-xl-4,
  .col-xl-5,
  .col-xl-6,
  .col-xl-7,
  .col-xl-8,
  .col-xl-9 {
    padding-left: 5px;
    padding-right: 5px;
  }
  input,
  textarea,
  select {
    font-size: 1.6rem;
    transform: scale(0.9);
  }
}
/* タブレット
-------------------------------------------------- */
/* PC(small)
-------------------------------------------------- */
/* PC(large)
-------------------------------------------------- */
/**/
.visible-xxs {
  display: none !important;
}

@media only screen and (max-width: 480px) {
  .visible-xxs {
    display: block !important;
  }
}
.txt_yellow {
  color: #f5cd1d;
}

.txt_color01 {
  color: #009fe8;
}

.txt_color02 {
  color: #ea6048;
}

.txt_color03 {
  color: #00ada4;
}

.sup {
  font-size: 0.8em;
  vertical-align: top;
}

.annotation {
  color: #666;
  font-size: clamp(9px, calc(0vw + 9px), 12px);
  padding-top: 1rem;
  letter-spacing: -0.08em;
}
@supports not (font-size: clamp(9px, calc(0vw + 9px), 12px)) {
  .annotation {
    font-size: max(9px, min(calc(0vw + 9px), 12px));
  }
}
.annotation p {
  padding-bottom: 0.5rem;
}

.c-cta_block {
  padding: clamp(25px, calc(2vw + 18px), 40px);
  background: url(https://lp.box-salon.com/wp-content/themes/box_salon_lp/assets/img/cta_bg_pc@2x.jpg) center/cover no-repeat;
  position: relative;
}
@supports not (padding: clamp(25px, calc(2vw + 18px), 40px)) {
  .c-cta_block {
    padding: max(25px, min(calc(2vw + 18px), 40px));
  }
}
.c-cta_block .ttl {
  text-align: center;
  font-size: clamp(20px, calc(1vw + 16px), 28px);
  padding-bottom: 1rem;
  position: relative;
}
@supports not (font-size: clamp(20px, calc(1vw + 16px), 28px)) {
  .c-cta_block .ttl {
    font-size: max(20px, min(calc(1vw + 16px), 28px));
  }
}
.c-cta_block .ttl::before {
  content: "";
  width: 100px;
  height: 2px;
  background: #f5cd1d;
  display: inline-block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .c-cta_block .ttl::before {
    content: none;
  }
}
.c-cta_block .ttl::after {
  content: "";
  width: 100px;
  height: 2px;
  background: #f5cd1d;
  display: inline-block;
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .c-cta_block .ttl::after {
    content: none;
  }
}
.c-cta_block__backtxt {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  margin: auto;
  font-size: clamp(65px, calc(8vw + 35px), 130px);
  letter-spacing: 0;
  font-family: "Josefin Sans", sans-serif;
  font-weight: 100;
  white-space: nowrap;
  color: rgba(237, 233, 232, 0.5);
}
@supports not (font-size: clamp(65px, calc(8vw + 35px), 130px)) {
  .c-cta_block__backtxt {
    font-size: max(65px, min(calc(8vw + 35px), 130px));
  }
}
@media screen and (max-width: 767px) {
  .c-cta_block__backtxt {
    width: 100%;
  }
}
.c-cta_block .box_wrapper {
  width: 670px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .c-cta_block .box_wrapper {
    display: block;
    width: 100%;
    max-width: 320px;
  }
}
.c-cta_block .box_inner {
  width: 200px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .c-cta_block .box_inner {
    flex-direction: row;
    align-items: flex-end;
    width: 100%;
  }
}
.c-cta_block .box_inner > span {
  display: block;
  min-height: 180px;
  margin: 0 auto 2rem auto;
}
@media screen and (max-width: 767px) {
  .c-cta_block .box_inner > span {
    min-height: 85px;
    width: 75px;
    margin: 0;
    text-align: left;
  }
}
.c-cta_block .box_inner a {
  display: block;
}
@media screen and (max-width: 767px) {
  .c-cta_block .box_inner a {
    width: 180px;
    flex-shrink: 0;
  }
}
.c-cta_block .box_inner a .visible-xs img {
  width: 180px;
  height: 50px;
}
.c-cta_block .img01 {
  padding-left: 18px;
}
@media screen and (max-width: 767px) {
  .c-cta_block .img01 {
    padding-left: 0;
  }
}
.c-cta_block .img01 img {
  width: 164px;
  height: 180px;
}
@media screen and (max-width: 767px) {
  .c-cta_block .img01 img {
    width: auto;
    height: 83px;
  }
}
.c-cta_block .img02 img {
  width: 139px;
  height: 178px;
}
@media screen and (max-width: 767px) {
  .c-cta_block .img02 img {
    width: auto;
    height: 84px;
  }
}
.c-cta_block .img03 {
  padding-top: 9px;
  padding-left: 22px;
}
@media screen and (max-width: 767px) {
  .c-cta_block .img03 {
    padding-left: 0;
    padding-top: 5px;
  }
}
.c-cta_block .img03 img {
  width: 160px;
  height: 171px;
}
@media screen and (max-width: 767px) {
  .c-cta_block .img03 img {
    width: auto;
    height: 79px;
  }
}
.c-cta_block__box {
  width: 820px;
  margin: auto;
  padding: 4rem;
  background-color: rgba(255, 255, 255, 0.85);
  text-align: center;
  border-radius: 20px;
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .c-cta_block__box {
    width: 96%;
    padding: 2rem;
  }
}
.c-cta_block__box::before, .c-cta_block__box::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  z-index: -1;
}
.c-cta_block__box::before {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  border-top: 2px dotted #f5cd1d;
  border-bottom: 2px dotted #f5cd1d;
  transform: rotate(-2.8deg);
}
.c-cta_block__box::after {
  width: 100%;
  height: 100%;
  border-radius: 20px;
  border-left: 2px dotted #f5cd1d;
  border-right: 2px dotted #f5cd1d;
  transform: rotate(-2.8deg);
}

.c-ttl01 {
  text-align: center;
  padding-bottom: clamp(30px, calc(8vw + 0px), 70px);
}
@supports not (padding-bottom: clamp(30px, calc(8vw + 0px), 70px)) {
  .c-ttl01 {
    padding-bottom: max(30px, min(calc(8vw + 0px), 70px));
  }
}
@media screen and (max-width: 767px) {
  .c-ttl01 {
    padding-left: 15px;
    padding-right: 15px;
  }
}
.c-ttl01 h2 {
  font-size: clamp(30px, calc(2vw + 23px), 50px);
  display: inline-block;
  border-bottom: 4px solid #ffcc00;
  padding-bottom: 1rem;
}
@supports not (font-size: clamp(30px, calc(2vw + 23px), 50px)) {
  .c-ttl01 h2 {
    font-size: max(30px, min(calc(2vw + 23px), 50px));
  }
}

a:hover {
  filter: brightness(80%);
  transition: 0.5s all;
}

/*----------------------------------------------------
	pagesに入れるまでもないページのスタイル
----------------------------------------------------*/
.hamburger {
  width: 70px;
  height: 50px;
  position: absolute;
  right: 10px;
  cursor: pointer;
  margin-right: -5px;
  margin-left: auto;
  z-index: 100;
}
.hamburger span {
  width: 50%;
  position: absolute;
  left: 50%;
  top: 51%;
}
.hamburger span::before {
  content: "";
  position: absolute;
  left: 50%;
  width: 80%;
  height: 2px;
  background-color: #f7f3ed;
}
.hamburger::before, .hamburger::after {
  content: "";
  height: 2px;
  width: 50%;
  position: absolute;
  left: 50%;
  margin-left: -25%;
  background-color: #f7f3ed;
  transition: all 0.6s ease;
}
.hamburger::before {
  top: 40%;
}
.hamburger::after {
  bottom: 30%;
}
.hamburger.is-act {
  color: #f7f3ed;
}
.hamburger.is-act:before {
  transform: rotate(45deg);
  top: 50%;
  background: #f7f3ed;
}
.hamburger.is-act:after {
  transform: rotate(-45deg);
  top: 50%;
  background: #f7f3ed;
}

/* 404 notfound */
.p-notfound .body {
  padding: 0 30px 30px;
}

.p-kv {
  padding-top: 100px;
  padding-bottom: 12rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .p-kv {
	    padding-top: 0;
    padding-bottom: 1rem;
  }
}
.p-kv__inner {
  width: 96vw;
  max-width: 1200px;
  margin: auto;
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-kv__inner {
    flex-wrap: wrap;
    width: 100%;
    padding: 0 30px;
    flex-direction: column-reverse;
    height: auto;
  }
}
.p-kv__txts {
  max-width: 610px;
  margin-right: auto;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .p-kv__txts {
    width: 100%;
    padding-bottom: 3rem;
  }
}
.p-kv__fukidashi {
  font-size: 2.3rem;
  font-weight: 700;
  background: #f5cd1d;
  display: inline-block;
  padding: 1rem 1.6rem;
  border-radius: 25px;
  position: relative;
  margin-bottom: 3rem;
}
@media screen and (max-width: 767px) {
  .p-kv__fukidashi {
    font-size: 1.8rem;
    text-align: center;
  }
}
.p-kv__fukidashi:after {
  border-top: 14px solid #f5cd1d;
  border-right: 12px solid transparent;
  border-left: 12px solid transparent;
  content: "";
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
}
.p-kv__copy {
  font-size: clamp(30px, calc(4vw + 15px), 60px);
  font-weight: 700;
  margin-bottom: 4rem;
  position: relative;
}
@supports not (font-size: clamp(30px, calc(4vw + 15px), 60px)) {
  .p-kv__copy {
    font-size: max(30px, min(calc(4vw + 15px), 60px));
  }
}
@media screen and (max-width: 767px) {
  .p-kv__copy {
    margin-bottom: 2rem;
  }
}
.p-kv__txt {
  color: #666;
  line-height: 1.6;
}
.p-kv__txt p {
  margin-bottom: 2rem;
}
.p-kv__pic {
  width: 48%;
  position: relative;
  padding-top: 3rem;
}
@media screen and (max-width: 767px) {
  .p-kv__pic {
    width: 100%;
    padding-bottom: 3rem;
	    padding-top: 2rem;
    text-align: center;
  }
}
.p-kv__backtxt {
  position: absolute;
  bottom: -48px;
  right: 0;
  font-size: clamp(100px, calc(11vw + 59px), 190px);
  font-family: "Josefin Sans", sans-serif;
  font-weight: 100;
  white-space: nowrap;
  color: #f7f3ed;
  z-index: -1;
  line-height: 1;
}
@supports not (font-size: clamp(100px, calc(11vw + 59px), 190px)) {
  .p-kv__backtxt {
    font-size: max(100px, min(calc(11vw + 59px), 190px));
  }
}
@media screen and (max-width: 767px) {
  .p-kv__backtxt {
    transform: rotate(-90deg);
    transform-origin: bottom left;
    bottom: 0;
    left: 107%;
  }
}

.p-index_about .container {
  padding-top: 4rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .p-index_about .container {
    padding-bottom: 4rem;
  }
}
.p-index_about h2 {
  font-size: clamp(34px, calc(0vw + 34px), 36px);
  margin-bottom: 3rem;
}
@supports not (font-size: clamp(34px, calc(0vw + 34px), 36px)) {
  .p-index_about h2 {
    font-size: max(34px, min(calc(0vw + 34px), 36px));
  }
}
@media screen and (max-width: 767px) {
  .p-index_about h2 {
    margin-bottom: 0;
  }
}
.p-index_about__body {
  display: flex;
  justify-content: space-between;
}
.p-index_about__body .txts {
  max-width: 550px;
  margin-right: auto;
  padding-top: 8rem;
}
@media screen and (max-width: 767px) {
  .p-index_about__body .txts {
    padding-top: 3rem;
  }
}
.p-index_about__body .txts .copy {
  font-size: 2.2rem;
  line-height: 1.6;
  margin-bottom: 24px;
}
.p-index_about__body .txts .copy span {
  color: #009fe8;
}
.p-index_about__body .imgs {
  position: relative;
}
.p-index_about .txt {
  color: #666;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-index_about .txt {
    letter-spacing: -0.01em;
  }
}
.p-index_about .btn {
  display: inline-block;
  position: absolute;
  right: 3rem;
  bottom: 3rem;
}
.p-index_about .btn img {
  width: 200px;
  height: 50px;
}
@media screen and (max-width: 767px) {
  .p-index_about .btn {
    display: block;
    position: relative;
    left: 0;
    bottom: 0;
    margin-top: 2rem;
    text-align: center;
  }
  .p-index_about .btn img {
    width: 310px;
    height: 50px;
  }
}
.p-index_about .about_datsumou {
  background: #f7f3ed;
}
.p-index_about .about_datsumou .container {
  padding-bottom: 4rem;
}
.p-index_about .about_datsumou h2,
.p-index_about .about_datsumou .copy span {
  color: #009fe8;
}
.p-index_about .about_datsumou .xs_inner .imgs {
  position: relative;
}
.p-index_about .about_datsumou .xs_inner .imgs .img01 img {
  width: 100%;
  display: block;
}
.p-index_about .about_datsumou .xs_inner .imgs .img02 {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_datsumou .xs_inner .imgs .img02 {
    width: 18%;
    bottom: -240px;
    right: 30px;
  }
}
@media screen and (max-width: 480px) {
  .p-index_about .about_datsumou .xs_inner .imgs .img02 {
    width: 30%;
    bottom: -200px;
    right: 15px;
  }
}
.p-index_about .about_esthetic h2,
.p-index_about .about_esthetic .copy span {
  color: #ea6048;
}
.p-index_about .about_esthetic .container {
  padding-top: 5rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_esthetic .container {
    padding-bottom: 4rem;
  }
}
.p-index_about .about_esthetic .hidden-xs .p-index_about__body {
  flex-flow: row-reverse;
}
.p-index_about .about_esthetic .hidden-xs .txts {
  margin-left: auto;
  margin-right: 0;
}
.p-index_about .about_esthetic .hidden-xs .btn {
  bottom: -2rem;
}
.p-index_about .about_esthetic .xs_inner .imgs {
  position: relative;
}
.p-index_about .about_esthetic .xs_inner .imgs .img01 img {
  width: 100%;
  display: block;
}
.p-index_about .about_esthetic .xs_inner .imgs .img02 {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_esthetic .xs_inner .imgs .img02 {
    width: 18%;
    bottom: -260px;
    right: 30px;
  }
}
@media screen and (max-width: 480px) {
  .p-index_about .about_esthetic .xs_inner .imgs .img02 {
    width: 30%;
    bottom: -220px;
    right: 15px;
  }
}
.p-index_about .about_whitening {
  background: #f7f3ed;
}
.p-index_about .about_whitening .container {
  padding-bottom: 4.5rem;
}
.p-index_about .about_whitening h2,
.p-index_about .about_whitening .copy span {
  color: #00ada4;
}
.p-index_about .about_whitening .xs_inner .imgs {
  position: relative;
}
.p-index_about .about_whitening .xs_inner .imgs .img01 img {
  width: 100%;
  display: block;
}
.p-index_about .about_whitening .xs_inner .imgs .img02 {
  position: absolute;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_whitening .xs_inner .imgs .img02 {
    width: 18%;
    bottom: -280px;
    right: 30px;
  }
}
@media screen and (max-width: 480px) {
  .p-index_about .about_whitening .xs_inner .imgs .img02 {
    width: 28%;
    bottom: -200px;
    right: -5px;
  }
}
.p-index_about .about_message {
  background: #f5cd1d;
}
.p-index_about .about_message .container {
  padding: 7% 3%;
  font-size: clamp(34px, calc(3vw + 23px), 60px);
  font-weight: 700;
  text-align: center;
  position: relative;
}
@supports not (font-size: clamp(34px, calc(3vw + 23px), 60px)) {
  .p-index_about .about_message .container {
    font-size: max(34px, min(calc(3vw + 23px), 60px));
  }
}
@media screen and (max-width: 767px) {
  .p-index_about .about_message .container {
    padding: 14% 7%;
  }
}
.p-index_about .about_message .container:before {
  content: "";
  background: url(https://lp.box-salon.com/wp-content/themes/box_salon_lp/assets/img/cat_icon.svg) no-repeat;
  width: clamp(60px, calc(7vw + 34px), 120px);
  height: clamp(30px, calc(4vw + 15px), 60px);
  position: absolute;
  bottom: -6px;
  left: 0;
}
@supports not (width: clamp(60px, calc(7vw + 34px), 120px)) {
  .p-index_about .about_message .container:before {
    width: max(60px, min(calc(7vw + 34px), 120px));
  }
}
@supports not (height: clamp(30px, calc(4vw + 15px), 60px)) {
  .p-index_about .about_message .container:before {
    height: max(30px, min(calc(4vw + 15px), 60px));
  }
}
@media screen and (max-width: 767px) {
  .p-index_about .about_message .container:before {
    bottom: -3px;
  }
}
.p-index_about .about_message .container:after {
  content: "";
  width: 40px;
  height: 40px;
  background: #f5cd1d;
  border: 5px solid #f5cd1d;
  border-radius: 5px;
  position: absolute;
  bottom: -45px;
  bottom: clamp(-16px, calc(-4vw + -1px), -45px);
  left: 50%;
  transform: translateX(-50%) rotate(45deg);
  z-index: -1;
}
@supports not (bottom: clamp(-16px, calc(-4vw + -1px), -45px)) {
  .p-index_about .about_message .container:after {
    bottom: max(-16px, min(calc(-4vw + -1px), -45px));
  }
}
.p-index_about .about_message span {
  color: white;
}
.p-index_about .about_introduction .ttl {
  font-size: clamp(23px, calc(2vw + 16px), 36px);
  padding-top: clamp(35px, calc(4vw + 20px), 70px);
  padding-bottom: clamp(35px, calc(4vw + 20px), 70px);
  text-align: center;
}
@supports not (font-size: clamp(23px, calc(2vw + 16px), 36px)) {
  .p-index_about .about_introduction .ttl {
    font-size: max(23px, min(calc(2vw + 16px), 36px));
  }
}
@supports not (padding-top: clamp(35px, calc(4vw + 20px), 70px)) {
  .p-index_about .about_introduction .ttl {
    padding-top: max(35px, min(calc(4vw + 20px), 70px));
  }
}
@supports not (padding-bottom: clamp(35px, calc(4vw + 20px), 70px)) {
  .p-index_about .about_introduction .ttl {
    padding-bottom: max(35px, min(calc(4vw + 20px), 70px));
  }
}
.p-index_about .about_introduction .lists {
  display: flex;
  justify-content: space-between;
}
.p-index_about .about_introduction .lists img {
  width: 100%;
}
.p-index_about .about_introduction .lists li {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  border-radius: 20px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .lists li {
    margin-bottom: 25px;
  }
}
.p-index_about .about_introduction .lists .caption {
  height: 100%;
  min-height: 88px;
  padding: 20px 0;
  background-color: #f7f3ed;
  font-size: 1.7rem;
  text-align: center;
  margin-bottom: 0;
  font-weight: 700;
  line-height: 1.4;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-index_about .about_introduction .lists .caption span {
  color: #f0b90a;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .lists {
    display: block;
    padding: 0 15px;
  }
}
.p-index_about .about_introduction .other {
  display: flex;
  align-items: center;
  border-radius: 15px;
  border: 2px dashed #f5cd1d;
  font-weight: 700;
  margin: 40px 0;
  padding: 3rem;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .other {
    margin: 20px 15px;
    padding: 1.8rem;
  }
}
.p-index_about .about_introduction .other .ttl {
  color: #f0b90a;
  font-size: 2rem;
  white-space: nowrap;
  padding: 15px 30px 15px 0;
  border-right: 2px solid #f7f3ed;
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .other .ttl {
    border-right: none;
    margin-right: 0;
    padding-right: 0;
  }
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .other {
    display: block;
  }
}
.p-index_about .about_introduction .other_lists ul {
  display: flex;
  flex-wrap: wrap;
}
.p-index_about .about_introduction .other_lists ul li {
  margin-right: 15px;
  padding-left: 10px;
  line-height: 1.8;
  position: relative;
}
.p-index_about .about_introduction .other_lists ul li:before {
  content: "";
  position: absolute;
  top: calc(50% - 2.5px);
  left: 0;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background-color: #f5cd1d;
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .other_lists ul li:before {
    top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .p-index_about .about_introduction .other_lists ul {
    padding: 0 1rem;
  }
}
.p-index_about .about_introduction .closing_txt {
  font-size: clamp(20px, calc(0vw + 20px), 24px);
  text-align: center;
  font-weight: 700;
}
@supports not (font-size: clamp(20px, calc(0vw + 20px), 24px)) {
  .p-index_about .about_introduction .closing_txt {
    font-size: max(20px, min(calc(0vw + 20px), 24px));
  }
}
.p-index_about .xs_inner {
  padding-left: 15px;
}

.p-index_feature {
  background: #f7f3ed;
  padding-top: clamp(30px, calc(8vw + 0px), 100px);
  position: relative;
}
@supports not (padding-top: clamp(30px, calc(8vw + 0px), 100px)) {
  .p-index_feature {
    padding-top: max(30px, min(calc(8vw + 0px), 100px));
  }
}
.p-index_feature .lists {
  padding-bottom: clamp(50px, calc(1vw + 46px), 60px);
}
@supports not (padding-bottom: clamp(50px, calc(1vw + 46px), 60px)) {
  .p-index_feature .lists {
    padding-bottom: max(50px, min(calc(1vw + 46px), 60px));
  }
}
@media screen and (max-width: 767px) {
  .p-index_feature .lists {
    padding-right: 15px;
    padding-left: 15px;
  }
}
.p-index_feature .lists img {
  width: 100%;
}
.p-index_feature .lists > li {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 767px) {
  .p-index_feature .lists > li {
    display: block;
  }
}
.p-index_feature .ttl {
  font-size: clamp(25px, calc(1vw + 21px), 34px);
  padding-bottom: clamp(20px, calc(1vw + 16px), 30px);
  color: #f0b90a;
}
@supports not (font-size: clamp(25px, calc(1vw + 21px), 34px)) {
  .p-index_feature .ttl {
    font-size: max(25px, min(calc(1vw + 21px), 34px));
  }
}
@supports not (padding-bottom: clamp(20px, calc(1vw + 16px), 30px)) {
  .p-index_feature .ttl {
    padding-bottom: max(20px, min(calc(1vw + 16px), 30px));
  }
}
.p-index_feature .img {
  padding-bottom: clamp(25px, calc(4vw + 10px), 60px);
}
@supports not (padding-bottom: clamp(25px, calc(4vw + 10px), 60px)) {
  .p-index_feature .img {
    padding-bottom: max(25px, min(calc(4vw + 10px), 60px));
  }
}
.p-index_feature .img img {
  border-radius: 15px;
}
.p-index_feature .txt {
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .p-index_feature .txt {
    letter-spacing: -0.02em;
  }
}
.p-index_feature .txt .lead {
  font-weight: 700;
  font-size: clamp(20px, calc(0vw + 20px), 24px);
  padding-bottom: 1.5rem;
}
@supports not (font-size: clamp(20px, calc(0vw + 20px), 24px)) {
  .p-index_feature .txt .lead {
    font-size: max(20px, min(calc(0vw + 20px), 24px));
  }
}
.p-index_feature .txt ul {
  padding-bottom: 3rem;
}
.p-index_feature .txt li {
  position: relative;
  padding-left: 2.4rem;
  font-weight: 700;
}
.p-index_feature .txt li:before {
  content: "";
  position: absolute;
  top: calc(50% - 9px);
  left: 0;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background-color: #f5cd1d;
}
.p-index_feature .backtxt {
  position: absolute;
  bottom: -48px;
  left: 0;
  font-size: clamp(100px, calc(11vw + 59px), 190px);
  font-family: "Josefin Sans", sans-serif;
  font-weight: 100;
  white-space: nowrap;
  color: #fff;
  line-height: 1;
  z-index: 1;
}
@supports not (font-size: clamp(100px, calc(11vw + 59px), 190px)) {
  .p-index_feature .backtxt {
    font-size: max(100px, min(calc(11vw + 59px), 190px));
  }
}
@media screen and (max-width: 767px) {
  .p-index_feature .backtxt {
    transform: rotate(-90deg);
    transform-origin: bottom left;
    bottom: 0;
    left: 107%;
  }
}

.p-index__merit01 {
  padding-top: clamp(50px, calc(6vw + 28px), 100px);
  position: relative;
}
@supports not (padding-top: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index__merit01 {
    padding-top: max(50px, min(calc(6vw + 28px), 100px));
  }
}
.p-index__merit01 .lists {
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  padding-bottom: clamp(60px, calc(5vw + 41px), 100px);
}
@supports not (padding-bottom: clamp(60px, calc(5vw + 41px), 100px)) {
  .p-index__merit01 .lists {
    padding-bottom: max(60px, min(calc(5vw + 41px), 100px));
  }
}
@media screen and (max-width: 767px) {
  .p-index__merit01 .lists {
    display: block;
  }
}
.p-index__merit01 li {
  width: 30%;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-index__merit01 li {
    width: 76%;
    margin: 0 auto;
    padding-bottom: 2rem;
  }
}
.p-index__merit01 li .txt {
  text-align: center;
  padding-top: clamp(20px, calc(2vw + 13px), 40px);
  padding-bottom: clamp(20px, calc(2vw + 13px), 40px);
}
@supports not (padding-top: clamp(20px, calc(2vw + 13px), 40px)) {
  .p-index__merit01 li .txt {
    padding-top: max(20px, min(calc(2vw + 13px), 40px));
  }
}
@supports not (padding-bottom: clamp(20px, calc(2vw + 13px), 40px)) {
  .p-index__merit01 li .txt {
    padding-bottom: max(20px, min(calc(2vw + 13px), 40px));
  }
}
.p-index__merit01 .backtxt {
  position: absolute;
  bottom: -48px;
  right: 0;
  font-size: clamp(100px, calc(11vw + 59px), 190px);
  font-family: "Josefin Sans", sans-serif;
  font-weight: 100;
  white-space: nowrap;
  color: #f7f3ed;
  line-height: 1;
  z-index: 1;
}
@supports not (font-size: clamp(100px, calc(11vw + 59px), 190px)) {
  .p-index__merit01 .backtxt {
    font-size: max(100px, min(calc(11vw + 59px), 190px));
  }
}
@media screen and (max-width: 767px) {
  .p-index__merit01 .backtxt {
    transform: rotate(-90deg);
    transform-origin: bottom left;
    bottom: 0;
    left: 107%;
  }
}

.p-index__merit02 {
  background: #f7f3ed;
  padding-top: clamp(50px, calc(6vw + 28px), 100px);
  padding-bottom: clamp(50px, calc(18vw + -18px), 200px);
}
@supports not (padding-top: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index__merit02 {
    padding-top: max(50px, min(calc(6vw + 28px), 100px));
  }
}
@supports not (padding-bottom: clamp(50px, calc(18vw + -18px), 200px)) {
  .p-index__merit02 {
    padding-bottom: max(50px, min(calc(18vw + -18px), 200px));
  }
}
.p-index__merit02 .box {
  text-align: center;
  position: relative;
  padding-top: clamp(50px, calc(6vw + 28px), 100px);
  padding-bottom: clamp(50px, calc(6vw + 28px), 100px);
  margin-bottom: clamp(50px, calc(6vw + 28px), 100px);
}
@supports not (padding-top: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index__merit02 .box {
    padding-top: max(50px, min(calc(6vw + 28px), 100px));
  }
}
@supports not (padding-bottom: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index__merit02 .box {
    padding-bottom: max(50px, min(calc(6vw + 28px), 100px));
  }
}
@supports not (margin-bottom: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index__merit02 .box {
    margin-bottom: max(50px, min(calc(6vw + 28px), 100px));
  }
}
.p-index__merit02 .box:before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 95%;
  height: 100%;
  background-color: white;
  border-radius: 20px 0 0 20px;
}
.p-index__merit02 .box .container {
  position: relative;
  max-width: 1100px;
  z-index: 1;
}
@media screen and (max-width: 1200px) {
  .p-index__merit02 .box .container {
    width: 85%;
    margin-right: 0;
  }
}
@media screen and (max-width: 480px) {
  .p-index__merit02 .box .container {
    width: 94%;
  }
}
.p-index__merit02 .box .ttl h3 {
  text-align: center;
  font-size: clamp(22px, calc(2vw + 15px), 36px);
  padding-bottom: 1rem;
  line-height: 1.5;
}
@supports not (font-size: clamp(22px, calc(2vw + 15px), 36px)) {
  .p-index__merit02 .box .ttl h3 {
    font-size: max(22px, min(calc(2vw + 15px), 36px));
  }
}
.p-index__merit02 .box .ttl img {
  width: 165px;
  height: 52px;
  display: block;
  margin: 0 auto 1rem auto;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .box .ttl img {
    width: 103px;
    height: 32px;
  }
}
.p-index__merit02 .box .ttl .txt {
  padding-bottom: clamp(40px, calc(2vw + 33px), 60px);
  line-height: 1.7;
}
@supports not (padding-bottom: clamp(40px, calc(2vw + 33px), 60px)) {
  .p-index__merit02 .box .ttl .txt {
    padding-bottom: max(40px, min(calc(2vw + 33px), 60px));
  }
}
.p-index__merit02 .lists {
  display: flex;
  justify-content: space-between;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .lists {
    display: block;
    padding-right: 10px;
  }
}
.p-index__merit02 .lists li {
  width: 32%;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .lists li {
    width: 100%;
    padding-bottom: 4rem;
  }
}
.p-index__merit02 .lists li h4 {
  font-size: clamp(24px, calc(1vw + 20px), 30px);
  padding: 2rem 0;
}
@supports not (font-size: clamp(24px, calc(1vw + 20px), 30px)) {
  .p-index__merit02 .lists li h4 {
    font-size: max(24px, min(calc(1vw + 20px), 30px));
  }
}
.p-index__merit02 .lists li .txt p {
  line-height: 1.7;
  font-size: 15px;
  letter-spacing: -0.03em;
}
@media screen and (max-width: 1200px) {
  .p-index__merit02 .box_reverse .container {
    width: 85%;
    margin-left: 15px;
    padding-right: 0;
  }
}
.p-index__merit02 .box_reverse:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 95%;
  height: 100%;
  background-color: white;
  border-radius: 0 20px 20px 0;
}
.p-index__merit02 .box_reverse .lists {
  width: 930px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-around;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .box_reverse .lists {
    width: 100%;
    padding-left: 0;
    padding-right: 0;
  }
  .p-index__merit02 .box_reverse .lists li {
    width: 47%;
    padding-bottom: 1rem;
  }
}
.p-index__merit02 .box_merit03 {
  margin-bottom: 0;
}
.p-index__merit02 .box_merit03 .lists {
  display: block;
}
.p-index__merit02 .box_merit03 .lists li {
  width: 100%;
}
.p-index__merit02 .box_merit03 .lists li:last-child {
  padding-bottom: 0;
}
.p-index__merit02 .box_merit03 .lead {
  font-size: clamp(18px, calc(1vw + 14px), 24px);
  padding-top: clamp(30px, calc(1vw + 26px), 40px);
  padding-bottom: clamp(20px, calc(1vw + 16px), 30px);
  font-weight: 700;
  position: relative;
}
@supports not (font-size: clamp(18px, calc(1vw + 14px), 24px)) {
  .p-index__merit02 .box_merit03 .lead {
    font-size: max(18px, min(calc(1vw + 14px), 24px));
  }
}
@supports not (padding-top: clamp(30px, calc(1vw + 26px), 40px)) {
  .p-index__merit02 .box_merit03 .lead {
    padding-top: max(30px, min(calc(1vw + 26px), 40px));
  }
}
@supports not (padding-bottom: clamp(20px, calc(1vw + 16px), 30px)) {
  .p-index__merit02 .box_merit03 .lead {
    padding-bottom: max(20px, min(calc(1vw + 16px), 30px));
  }
}
.p-index__merit02 .box_merit03 .lead:before {
  content: "";
  width: 2px;
  height: 22px;
  background: #f5cd1d;
  display: inline-block;
  transform: rotate(-36deg);
  margin-right: 2rem;
}
.p-index__merit02 .box_merit03 .lead:after {
  content: "";
  width: 2px;
  height: 22px;
  background: #f5cd1d;
  display: inline-block;
  transform: rotate(36deg);
  margin-left: 2rem;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .box_merit03 .lead {
    padding-top: 0;
  }
}
.p-index__merit02 .box_merit03 .lists_media {
  max-width: 900px;
  margin: 0 auto;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .box_merit03 .lists_media {
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 480px) {
  .p-index__merit02 .box_merit03 .lists_media {
    justify-content: space-between;
  }
}
.p-index__merit02 .box_merit03 .lists_media .img {
  padding-right: 1.5rem;
}
.p-index__merit02 .box_merit03 .lists_media .img:last-child {
  padding-right: 0;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .box_merit03 .lists_media .img {
    padding-bottom: 1.5rem;
  }
  .p-index__merit02 .box_merit03 .lists_media .img:nth-child(even) {
    padding-right: 0;
  }
}
@media screen and (max-width: 480px) {
  .p-index__merit02 .box_merit03 .lists_media .img {
    width: 49%;
    padding-bottom: 1rem;
    padding-right: 0;
  }
}
.p-index__merit02 .annotation {
  padding-top: 3rem;
}
@media screen and (max-width: 767px) {
  .p-index__merit02 .annotation {
    padding-left: 20px;
    padding-top: 0;
  }
}

.p-index_company {
  padding-top: clamp(50px, calc(6vw + 28px), 100px);
  padding-bottom: clamp(40px, calc(7vw + 14px), 100px);
}
@supports not (padding-top: clamp(50px, calc(6vw + 28px), 100px)) {
  .p-index_company {
    padding-top: max(50px, min(calc(6vw + 28px), 100px));
  }
}
@supports not (padding-bottom: clamp(40px, calc(7vw + 14px), 100px)) {
  .p-index_company {
    padding-bottom: max(40px, min(calc(7vw + 14px), 100px));
  }
}
.p-index_company__content {
  display: flex;
}
@media screen and (max-width: 767px) {
  .p-index_company__content {
    display: block;
    padding-left: 15px;
    padding-right: 15px;
  }
}
.p-index_company .img {
  flex-shrink: 0;
}
.p-index_company .img img {
  display: block;
  margin: 0 auto;
}
.p-index_company .info {
  padding-left: 5rem;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .p-index_company .info {
    padding-left: 0;
    padding-top: 5rem;
  }
}
.p-index_company .info dt {
  width: 60px;
  color: #f0b90a;
  font-weight: 700;
  text-align-last: justify;
  letter-spacing: -0.1em;
  margin-right: 3rem;
  padding-top: 5px;
}
@media screen and (max-width: 767px) {
  .p-index_company .info dt {
    padding-bottom: 1.5rem;
  }
}
.p-index_company .info dd {
  width: calc(100% - 100px);
  flex-grow: 1;
  letter-spacing: -0.001em;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .p-index_company .info dd {
    padding-bottom: 1.5rem;
    letter-spacing: -0.08em;
  }
}
	
	/* header */
	
#wrapper-navbar {
	padding: 15px 40px;
	border-bottom: 1px solid #ddd;
}

	@media screen and (max-width: 767px) {
		#wrapper-navbar  {
    padding: 10px 0 10px 15px;
}
}

	#wrapper-navbar img {
    width: 400px;
}
	
	@media screen and (max-width: 767px) {
	#wrapper-navbar img {
    width: 180px;
}
	}


/* 202307 */

.p-index_company .info {
    max-width: 400px;
    margin: 0 auto;
	padding-left: 0;
}

.p-index_company .info dt {
    padding: 1.5rem 0;
    line-height: 1;
}

.p-index_company .info dd {
    padding: 1.5rem 0;
    line-height: 1;
}

