@charset "UTF-8";
:root {
--ilp-txt01: #04141C;
--ilp-txt02: #616161;
--ilp-main01: #293794;
--txt-0001: #81CDE7;
--txt-0002: #CCE5EE;
--txt-0003: #04141C;
--txt-00003:#4F62DB;
--txt-00004:#81CDE7;
--l-txt0002: #09264E;
}
*,
::after,
::before {
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  color: #04141C;
  letter-spacing: 1.5px;
  font-weight: 400;
}
article,
aside,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section {
  display: block;
}
body {
  margin: 0 auto;
  line-height: 1.5;
  text-align: left;
  background: #fff;
  max-width: 768px;
}

[tabindex="-1"]:focus:not(:focus-visible) {
  outline: 0 !important;
}
hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
}
h1,
h2,
h3,
h4,
h5,
h6,
p,
li {
  margin: 0;
  padding: 0;
  line-height: 1.5;
}
abbr[data-original-title],
abbr[title] {
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  cursor: help;
  border-bottom: 0;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none;
}
address {
  font-style: normal;
  line-height: inherit;
}
dl,
ol,
ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
dd {
  margin-left: 0;
}
blockquote {
  margin: 0 0 1rem;
}
b,
strong {
  font-weight: bolder;
}
small {
  font-size: 80%;
}
sub,
sup {
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

a {
  color: #000000;
  text-decoration: none;
  background-color: transparent;
}
a:hover {
  color: #000000;
  text-decoration: none;
  opacity: 0.5;
  cursor: pointer;
}
a:not([href]):not([class]) {
  color: inherit;
  text-decoration: none;
}
a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}
*:focus {
  outline: none;
}
code,
kbd,
pre,
samp {
  font-family: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 1em;
}
pre {
  margin-top: 0;
  overflow: auto;
  -ms-overflow-style: scrollbar;
}
figure {
  margin: 0 0 1rem;
}
img {
  vertical-align: middle;
  border-style: none;
}
svg {
  overflow: hidden;
  vertical-align: middle;
}
table {
  border-collapse: collapse;
}
caption {
  padding-top: 0.75rem;
  padding-bottom: 0.75rem;
  color: #6c757d;
  text-align: left;
  caption-side: bottom;
}
th {
  text-align: inherit;
}
label {
  display: inline-block;
}
button {
  border-radius: 0;
}
button:focus {
  outline: 1px dotted;
  outline: 5px auto -webkit-focus-ring-color;
}
button,
input,
optgroup,
select,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
button,
input {
  overflow: visible;
}
button,
select {
  text-transform: none;
}
[role=button] {
  cursor: pointer;
}
select {
  word-wrap: normal;
}
[type=button],
[type=reset],
[type=submit],
button {
  -webkit-appearance: button;
}
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled),
button:not(:disabled) {
  cursor: pointer;
}
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  padding: 0;
  border-style: none;
}
input[type=checkbox],
input[type=radio] {
  box-sizing: border-box;
  padding: 0;
}
input[type="checkbox"] {
  appearance: checkbox;
  -webkit-appearance: checkbox;
  width: 16px;
  height: 16px;
  margin: 0 4px 0 0;
  vertical-align: middle;
}
textarea {
  overflow: auto;
  resize: vertical;
}
fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
legend {
  display: block;
  width: 100%;
  max-width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  font-size: 1.5rem;
  line-height: inherit;
  color: inherit;
  white-space: normal;
}
progress {
  vertical-align: baseline;
}
[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}
[type=search] {
  outline-offset: -2px;
  -webkit-appearance: none;
}
[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  font: inherit;
  -webkit-appearance: button;
}
output {
  display: inline-block;
}
summary {
  display: list-item;
  cursor: pointer;
}
template {
  display: none;
}
[hidden] {
  display: none !important;
}
img, video {
  height: auto;
  width: 100%;
  max-width: 100%;
  line-height: 0;
}
input {
  -webkit-appearance: none;
}
input[type=text] {
  margin: 0;
  padding: 0;
  background: none;
  border: none;
  border-radius: 0;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
input[type=submit],
input[type=button] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
  background: #ccc;
  color: #fff;
  transition: background 0.2s;
}
input[type=submit]::-webkit-search-decoration,
input[type=button]::-webkit-search-decoration {
  display: none;
}
input[type=submit]::focus,
input[type=button]::focus {
  outline-offset: -2px;
}
.pc {
  display: none;
}
@media screen and (min-width: 769px) {

  a[href*="tel:"] {
    /* pointer-events: none;
    cursor: default;
    text-decoration: none; */
  }
  a:hover {
    cursor: pointer !important;
  }
}
body {
  background: linear-gradient(to bottom, transparent 0%, transparent 90%, #fff 100%), url("https://www.yokoyamashikaiin.jp/wp-content/themes/yokoyama/assets/img/bg.png");
  background-repeat: repeat;
  background-position: center center;
}

/* header {
  height: 100vh;
} */
header div.menu {
  position: fixed;
  left: 0;
  right: 0;
  width: 100%;
  height: 70px;
  margin: 0 auto;
  z-index: 3;
  max-width: 768px;
}
header div.menu .ttl_area {
  display: flex;
  align-items: center;
  width: auto;
  margin: 0;
}
header div.menu .logo{
  width: 55vw;
  margin: 0;
}
@media screen and (min-width: 769px) {
  header div.menu .logo{
    width: 360px;
    margin: 0;
  }
}
header nav {
  display: none;
  background-color: #fff;
  position: absolute;
  padding: 120px 0 160px;
  text-align: center;
  z-index: 10;
  width: 100%;
  max-width: 768px;
  margin-top: -70px;
  /* height: 100vh; */
}
header nav ul.menu_area {
  position: relative;
  margin: 0 auto 50px;
}
header nav ul.menu_area li a {
  display: block;
  font-size: 1.6rem;
  white-space: nowrap;
  text-align: left;
  display: block;
  font-weight: 500;
  border-bottom: 1px solid rgba(75,74,74,0.3);
  height: 60px;
  line-height: 60px;
  padding-left: 10%;
  position: relative;
  font-family: "Zen Maru Gothic", sans-serif;
}
header nav ul.menu_area li a:after {
  content: '';
  width: 10px;
  height: 10px;
  border: 0;
  border-top: solid 2px #4B4A4A;
  border-right: solid 2px #4B4A4A;
  transform: rotate(45deg);
  position: absolute;
  top: 0;
  right: 20px;
  bottom: 0;
  margin: auto;
}

header nav .btn_area{
  height: 85px;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
}
header nav .btn_area .btn a{
  display: block;
  width: 80%;
  height: 60px;
  line-height: 58px;
  text-align: center;
  font-weight: 500;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  border-radius: 48px;
  margin:  0 auto 10px;
  color: #fff;
  font-size: 1.8rem;
}
header nav .btn_area .btn a.gr{
  background-image: linear-gradient(90deg, rgba(160, 234, 96, 1), rgba(51, 191, 43, 1));
}
header nav .btn_area .btn a.or{
  background-image: linear-gradient(90deg, rgba(249, 230, 88, 1), rgba(253, 34, 27, 1));
}
header nav .btn_area .btn a.bl{
  background-image: linear-gradient(90deg, rgba(31, 203, 226, 1), rgba(24, 125, 205, 1));
}

/* ハンバーガー */
  .btn_hum {
    display: block;
    position: absolute;
    right: 10px !important;
    z-index: 10000; /*追記：いつも一番上*/
    /* background: rgba(255, 255, 255, .8); */
    margin-top: 10px;
    width: 56px;
    height: 56px;
    top: 0;
  }
  .btn_hum:after{
    content: "";
    display: block;
    position: absolute;
    background: #187DCD;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    right: 5px;
    border: 2px solid #fff;
  }
  .bar {
    width: 25px;
    height: 2px;
    display: block;
    position: absolute;
    left: 23px;
    transform: translateX(-50%);
    background-color: #fff;
    z-index: 2;
  }
  .bar-top {
    top: 18px;
  }
  .bar-middle {
    top: 50%;
    transform: translate(-50%, -50%);
  }
  .bar-bottom {
    bottom: 18px;
  }
  .btn_hum.close .bar-top {
    transform: translate(-50%, 5px) rotate(45deg);
    transition: transform 0.3s;
    background-color: #fff;
    top: 22px;
    width: 30px;
    left: 23px;
  }
  .btn_hum.close .bar-middle {
    opacity: 0;
    transition: opacity 0.3s;
  }
  .btn_hum.close .bar-bottom {
    transform: translate(-50%, -5px) rotate(-45deg);
    transition: transform 0.3s;
    background-color: #fff;
    bottom: 21px;
    width: 30px;
    left: 23px;
  }
/* ハンバーガー */
/* ヘッダー固定 */
.is-animation {
  background-color: rgba(255, 255, 255, 1) !important;
  /* height: 70px; */
  margin-top: 0 !important;
  padding-top: 10px;
  /* transition-duration:.5s; */
  border-radius: 0 !important;
  height: 108px !important;
}

/* ヘッダー固定 */
.pagetop {
  position: fixed;
  right: 5vw;
  bottom: 45px;
  z-index: 1000;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #2C2C2C;
}
.pagetop span {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
}
.pagetop span:after {
  content: "";
  background: #ffffff;
  height: 8.6602540378px;
  width: 10px;
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: 20px;
}
main {
  background: #fff;
}
main .mv{
  position: relative;
}
main .logo{
  position: absolute;
  left: 0;
  top: 0;
}
header div.menu .logo,main .logo{
  width: 55vw;
  margin: 0;
}
@media screen and (min-width: 769px) {
  header div.menu .logo,main .mv .logo{
    width: 360px;
    margin: 0;
  }
}
main .mv .text_area{
  position: absolute;
  text-align: center;
  top: 95vw;
}
@media screen and (min-width: 769px) {
  main .mv .text_area{
    top: 720px;
  }
}
main .mv .text_area h1{
  font-family: "Inter", sans-serif;
  font-size: 4.8rem;
  /* color: #81CDE7; */
  color: var(--txt-0001);
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  main .mv .text_area h1{
    font-size: 6.8rem;
  }
}
main .mv .text_area h2{
  font-size: 2.2rem;
  color: var(--txt-0001);
  font-weight: 400;
  margin: -3px auto 15px;
}
@media screen and (min-width: 769px) {
  main .mv .text_area h2{
    font-size: 4.2rem;
  }
}
main .mv .text_area h3{
  font-size: 1.4rem;
  color: var(--txt-0002);
  font-weight: 300;
}
@media screen and (min-width: 769px) {
  main .mv .text_area h3{
    font-size: 2.7rem;
  }
}
main .mv .text_area h4{
  font-size: 1.6rem;
  color: var(--txt-0002);
  font-weight: 300;
  padding: 0 4vw;
  text-align: left;
  margin: 35px auto 35px;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  main .mv .text_area h4{
    font-size: 2.9rem;
  }
}
main .mv .text_area a{
  display: block;
  color: var(--txt-0003);
  width: 75%;
  background: #80CAE3;
  margin: auto;
  border-radius: 8px;
  padding: 12px 0;
  font-size: 1.8rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  main .mv .text_area a{
    font-size: 3.8rem;
  }
}
main .mv .text_area a span{
  color: #0A5D86;
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  main .mv .text_area a span{
    font-size: 3.2rem;
  }
}
#concept{
  padding: 0 4vw;
}
#concept h2{
  padding: 20px 0;
  text-align: center;
}
#concept h2 span{
  display: inline-block;
  color: var(--ilp-txt01);
  font-size: 2.6rem;
  font-family: "Noto Serif JP", serif;
  border-bottom: 1px solid var(--ilp-txt02);
  margin-top: 5px;
}
@media screen and (min-width: 769px) {
  #concept h2 span{
    font-size: 4.6rem;
  }
}
#concept h3{
  font-size: 1.3rem;
  font-weight: 400;
  color: #09264E;
  line-height: 1.7;
  margin: 25px auto;
  text-align: center;
  letter-spacing: 1px;
}
@media screen and (min-width: 769px) {
  #concept h3{
    font-size: 2.7rem;
  }
}
#concept .tabcontent_area {
  width: 100%;
  max-width: 1240px;
  margin: 0 auto;
  padding: 30px 0;
}
#concept .tab-container {
  display: flex;
  flex-wrap: wrap;
}
#concept .tab-container {
    /* margin: 0 0 15px; */
}
#concept .tab {
  font-weight: 500;
  text-align:center;
  width: calc(100% / 2);
  padding: 5px 10px;
  background-color: #09264E;
  cursor: pointer;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--txt-00004);
}
@media screen and (min-width: 769px) {
  #concept .tab {
    font-size: 2rem;
  }
}
#concept .tab.active {
  background-color: var(--ilp-main01);
  color: #fff;
  position: relative;
}
#concept .tab.active:after {
  position: absolute;
  content: "";
  left: 0;
  top: -10px;
  background: var(--ilp-main01);
  width: 100%;
  height: 10px;
}
#concept .tabcontent {
  display: none; /*必須*/
}
#concept .tabcontent.show {
  display: block; /*必須*/
  background: var(--ilp-main01);
  color: #fff;
  padding: 20px 0;
}
#concept .tabcontent img{
  width: 90%;
  display: block;
  margin: auto;
}

#about{
  padding: 40px 4vw 110px;
  background: #ECF2FF;
}
#about h2{
  color: var(--ilp-txt01);
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 8px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}
#about h2 span{
  color: var(--ilp-txt01);
  font-size: 2.6rem;
  display: block;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #about h2{
    font-size: 5.2rem;
  }
  #about h2 span{
    font-size: 4.2rem;
  }
}
#about .about1{
  margin: 20px auto 0;
}
#about h3{
  margin: 25px auto 10px;
  text-align: center;
  display: flex;
  flex-direction: column;
}
#about h3 span{
  background: var(--ilp-main01);
  font-size: 1.7rem;
  color: #fff;
  display: inline-block;
  padding: 4px 6px;
  margin: 0 auto 8px;
  text-align: center;
  border-radius: 4px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #about h3 span{
    font-size: 3.2rem;
  }
}
#about .box{
  border: 1px solid var(--ilp-txt01);
  margin: auto;
  text-align: center;
  padding: 25px 0;
  background: #fff;
}
#about h4{
  font-size: 2rem;
  color: var(--ilp-txt01);
  font-weight: 500;
  text-align: center;
  margin-bottom: 20px;
}
@media screen and (min-width: 769px) {
  #about h4{
    font-size: 4rem;
  }
}
#about .box {
  margin-bottom: 35px;
}
#about .box h4{
  margin-bottom: 20px;
}
#about .box img{
  width: 85%;
  display: block;
  margin: auto;
}
#about .text{
  font-size: 1.4rem;
  color: var(--ilp-txt02);
  line-height: 1.7;
  text-align: center;
  margin: 10px auto 0;
}
@media screen and (min-width: 769px) {
  #about .text{
    font-size: 2.7rem;
  }
}
#about .box .text{
  margin: 20px auto 0;
}
#about .box .text span.b{
  font-weight: 500;
  font-size: 1.4rem;
}
#about .box .text span.s{
  font-size: 1.3rem;
}
@media screen and (min-width: 769px) {
  #about .box h4{
    font-size: 3.8rem;
  }
  #about .box .text,#about .box .text span.s{
      font-size: 2.7rem;
  }
  #about .box .text span.b{
    font-weight: 500;
    font-size: 2.8rem;
  }
}

#theory{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 110px;
}
#theory h2{
  color: var(--ilp-txt01);
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 5px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}
#theory h2 span{
  color: var(--ilp-txt01);
  font-size: 2.6rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #theory h2{
    font-size: 5.2rem;
  }
  #theory h2 span{
    font-size: 4.2rem;
  }
}
#theory h3{
  font-size: 1.4rem;
  color: var(--ilp-txt01);
  line-height: 1.7;
  margin: 5px auto 0;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #theory h3{
    font-size: 2.7rem;
  }
}
#theory h3:first-of-type{
  margin-top: 25px;
}
#theory .img_theory{
  margin: 30px auto 0;
  display: block;
}
#theory h4 span{
  position: relative;
  font-size: 1.55rem;
  color: #141E5B;
  font-weight: 600;
  margin: 30px auto 20px;
  display: inline-block;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #theory h4 span{
    font-size: 2.8rem;
  }
}
#theory h4 span:before{
  content: "";
  position: absolute;
  left: -23px;
  bottom: 45%;
  background: #141E5B;
  width: 30px;
  height: 1px;
  transform: rotate(70deg);
}
#theory h4 span:after{
  content: "";
  position: absolute;
  right: -23px;
  bottom: 45%;
  background: #141E5B;
  width: 30px;
  height: 1px;
  transform: rotate(-70deg);
}
#theory h4 span.line2:before{
  left: -25px;
}
#theory h4 span.line2:after{
  right: -25px;
}
@media screen and (min-width: 769px) {
  #theory h4 span:before,#theory h4 span:after{
    width: 40px;
  }
  #theory h4 span:before{
      left: -35px;
   }
  #theory h4 span:before{
      right: -35px;
   }
   #theory h4 span.line2:before{
    left: -40px;
  }
  #theory h4 span.line2:after{
    right: -40px;
  }
}
#theory .text{
  line-height: 1.7;
  font-size: 1.4rem;
  font-weight: 300;
  text-align: left;
}
@media screen and (min-width: 769px) {
  #theory .text{
    font-size: 2.7rem;
  }
}

#important{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 110px;
  background: #ECF2FF;
}
#important h2{
  color: var(--ilp-txt01);
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 5px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}
#important h2 span{
  color: var(--ilp-txt01);
  font-size: 2.6rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #important h2{
    font-size: 5.2rem;
  }
  #important h2 span{
    font-size: 4.2rem;
  }
}
#important h3{
  display: flex;
  align-items: center;
  margin:25px auto 25px;
}
#important h3 img{
  width: 3px;
  height: 16px;
} 
#important h3 span{
  font-size: 2rem;
  color: #141E5B;
  padding-left: 10px;
}
@media screen and (min-width: 769px) {
  #important h3 img{
    width: 6px;
    height: 32px;
  } 
  #important h3 span{
    font-size: 3.3rem;
    padding-left: 20px;
  }
}
#important .important1{
  margin: 0 auto 20px;
  display: block;
}
#important .text{
  font-size: 1.4rem;
  font-weight: 300;
  margin-top: 10px;
  line-height: 1.7;
  text-align: left;
  color: #04141C;
}
@media screen and (min-width: 769px) {
  #important .text{
    font-size: 2.7rem;
  }
}
#important .text span{
  background: var(--ilp-main01);
  font-size: 1.4rem;
  color: #fff;
  display: inline-block;
  padding: 4px 6px;
  text-align: center;
  border-radius: 4px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #important .text span{
    font-size: 2.7rem;
  }
}
#important .text.mt5{
  margin-top: 5px;
}
#important .important_note{
  margin: 30px auto;
}
#important h4{
  color: #04141C;
  font-size: 2rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #important h4{
    font-size: 3.3rem;
  }
}
#important .important_arrow{
  width: 18vw;
  margin: 3px auto 25px;
}
#important .important_ttl{
  margin: 30px auto 15px;
}


#value{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 20px;
  background: #293794;
}
#value h2{
  color: #fff;
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 5px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}

#value h2:last-of-type{
  margin-top: 60px;
  padding-top: 40px;
}
#value h2 span{
  color: #fff;
  font-size: 2.6rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #value h2{
    font-size: 5.2rem;
  }
  #value h2 span{
    font-size: 4.2rem;
  }
}
#value .title_border_w{
  margin-bottom: 15px;
}
#value .box{
  background: #fff;
  border-radius: 8px;
  padding: 4vw;
  margin: 0 auto 15px;
}
#value .box:first-of-type{
  margin-top: 15px;
}
#value .box .point{
  width: 20vw;
}
#value .box h3{
  font-size: 2rem;
  font-weight: 500;
  margin: 5px auto 15px;
  color: #04141C;
  line-height: 1.7;
}
#value .box h3 span{
  font-size: 1.8rem;
}
#value .box h4{
  font-size: 1.4rem;
  font-weight: 500;
  margin-bottom: 5px;
  color: #04141C;
}
#value .box p{
  font-size: 1.4rem;
  font-weight: 300;
  text-align: center;
  color: #04141C;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #value .box .point{
    width: 120px;
  }
  #value .box h3{
    font-size: 3.3rem;
  }
  #value .box h3 span{
    font-size: 3.1rem;
  }
  #value .box h4,#value .box p{
    font-size: 2.7rem;
  }
}
#value .box p.text{
  font-size: 1.4rem;
  text-align: center;
  color: #616161;
  text-align: left;
  margin-top: 10px;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #value .box p.text{
    font-size: 2.7rem;
  }
}
#value .box p.text.mt15{
  margin-top: 15px;
}

#difference{
  margin: 0 auto;
  text-align: center;
  padding:  40px 4vw 40px;
  background: #ECF2FF;
}
#difference h3{
  color: #04141C;
  font-size: 2rem;
  font-weight: 500;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  #difference h3{
    font-size: 3.3rem;
  }
}
#difference p,#difference li{
  font-size: 1.4rem;
  text-align: center;
  color: #04141C;
  text-align: left;
  margin-top: 10px;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #difference p,#difference li{
    font-size: 2.7rem;
  }
}
#difference li{
  text-indent: -1em;
  padding-left: 1em;
  margin-top: 5px;
  line-height: 1.5;
}
#difference li:first-of-type{
  margin-top: 10px;
}

#case{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 30px;
  background: url(../../assets/img/lp_sync/case_bg.png) no-repeat 0 0;
  background-size: cover;
  width: 100%;
  height: 100%;
}
#case h2{
  color: #04141C;
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 5px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}
@media screen and (min-width: 769px) {
  #case h2{
      font-size: 5.2rem;  
  }
}
#case .box{
  background: #fff;
  border-radius: 8px;
  padding: 4vw;
  margin-bottom: 4vw;
}
#case .box:first-of-type{
  margin-top: 15px;
  }
#case .box .flex{
  display: flex;
}
#case .box .flex img{
  width: 30%;
  display: block;
  height: 100%;
}
#case .box .flex .text{
  width: 70%;
  text-align: left;
  padding-left: 4%;
}
#case .box .flex .text dt,#case .box2 dt{
  color: #293794;
  font-size: 1.6rem;
  font-weight: 500;
  margin-bottom: 3px;
}
@media screen and (min-width: 769px) {
  #case .box .flex .text dt,#case .box2 dt{
    font-size: 2.9rem;
  }
}
#case .box .flex .text dd,#case .box2 dd{
  margin-bottom: 3px;
}
#case .box .flex .text dd ,#case .box2 dd p{
  color: #04141C;
  font-size: 1.4rem;
  font-weight: 400;
  line-height: 1.7;
  text-indent: -1em;
  padding-left: 1em;
}
@media screen and (min-width: 769px) {
  #case .box .flex .text dd ,#case .box2 dd p{
    font-size: 2.7rem;
  }
}
#case .content{
  background: #ECF2FF;
  padding: 15px;
  text-align: left;
  border-radius: 8px;
  margin-bottom: 8px;
}
#case .content dt{
  font-size: 1.4rem;
  color: #04141C;
}
#case .content dd{
  font-size: 1.4rem;
  color: #616161;
}
@media screen and (min-width: 769px) {
  #case .content dt,#case .content dd{
      font-size: 2.7rem;
  }
}
#case .box2{
  background: #ECF2FF;
  padding: 15px;
  text-align: left;
  border-radius: 8px;
  margin-bottom: 8px;
}

#effect{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 0;
  background: #ECF2FF;
}
#effect h2{
  color: #04141C;
  font-size: 3.2rem;
  text-align: center;
  margin-bottom: 5px;
  font-weight: 600;
  display: block;
  font-family: "Noto Serif JP", serif;
}
#effect h2 span{
  font-size: 2.6rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #effect h2{
    font-size: 5.2rem;
  }
  #effect h2 span{
    font-size: 4.2rem;
  }
}
#effect .effect1{
  margin: 15px auto 20px;
  display: block;
}
#effect li{
  display: flex;
  align-items: center;
  background: #fff;
  margin-bottom: 8px;
  padding: 4vw;
  border-radius: 8px;
}
@media screen and (min-width: 769px) {
  #effect li{
    padding: 15px 4vw;
  }
}
#effect li img{
  width: 20px;
  height: 20px;
  display: block;
  margin-right: 4px;
}
@media screen and (min-width: 769px) {
#effect li img{
  width: 28px;
  height: 28px;
  display: block;
}
}
#effect li span{
  color: #2A2A2A;
  font-size: 1.35rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #effect li span{
    font-size: 2.7rem;
  }
}
#effect p{
  color: #2A2A2A;
  font-size: 1.1rem;
  text-align: left;
}
@media screen and (min-width: 769px) {
#effect p{
  font-size: 2.1rem;
}
}
#effect .box{
  position: relative;
  margin-top: 30px;
}
#effect .box .effect_arrow{
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  top: -10px;
  width: 40px;
}
#effect .box .effect2{
  margin: 20px auto 0;
}

#flow{
  margin: 0 auto;
  text-align: center;
  padding:  30px 4vw 40px;
  background: #F5F5F5;
}
#flow h2 {
    color: #04141C;
    font-size: 2rem;
    text-align: center;
    margin-bottom: 5px;
    font-weight: 600;
    display: block;
    font-family: "Noto Serif JP", serif;
}
@media screen and (min-width: 769px) {
  #flow h2 {
      font-size: 3.3rem;
  }
}
#flow .box{
  display: flex;
  align-items: center;
  background: #fff;
}
#flow .box:first-of-type{
  margin-top: 15px;
}
#flow .box img{
  width: 26%;
}
#flow .box dl{
  width: 74%;
  text-align: left;
  padding: 0 0 0 4%;
}
#flow .box dl dt{
  color: #293794;
  font-family: "Roboto", sans-serif;
  font-size: 1.2rem;
  font-style: italic;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #flow .box dl dt{
    font-size: 2.5rem;
  }
}
#flow .box dl dd{
  color: #04141C;
  font-size: 1.4rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #flow .box dl dd{
    font-size: 2.7rem;
  }
}
#flow .flow_arrow{
  width: 20px;
  display: block;
  margin: 10px auto 10px;
}

#contact_free{
  padding: 40px 4vw;
}
#contact_free a{
  display: block;
  color: var(--txt-0003);
  width: 75%;
  background: #80CAE3;
  margin: auto;
  border-radius: 8px;
  padding: 12px 0;
  font-size: 1.8rem;
  font-weight: 600;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #contact_free a{
    font-size: 3.8rem;
  }
}
#contact_free a span{
  color: #0A5D86;
  display: block;
  font-size: 1.2rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #contact_free a span{
    font-size: 3.2rem;
  }
}
#contact_free p{
  color: #141E5B;
  line-height: 1.7;
  font-size: 1.4rem;
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  #contact_free p{
    font-size: 2rem;
  }
}

#invisa{
  padding: 40px 4vw 40px;
  text-align: center;
  background: #293794;
}
#invisa .en{
  color: #81CDE7;
  font-family: "Roboto", sans-serif;
  font-size: 1.6rem;
  font-style: italic;
}
#invisa h2{
  color: #fff;
  font-size: 2.4rem;
  font-weight: 400;
  margin: 10px auto 30px;
}
@media screen and (min-width: 769px) {
  #invisa .en{
    font-size: 2.9rem;
  }
  #invisa h2{
    font-size: 3.7rem;
  }
}
.bg_gold{
  height: 8px;
  background-image: linear-gradient(90deg, rgba(201, 180, 105, 1), rgba(253, 231, 168, 1) 40%, rgba(201, 180, 105, 1));
}

#price{
  background: #ECF2FF;
  padding: 20px 4vw;
  text-align: center;
}
#price h2{
  color: #293794;
  font-size: 2rem;
  border: 1px solid #293794;
  background: #fff;
  font-weight: 500;
  padding: 5px 0;
}
@media screen and (min-width: 769px) {
  #price h2{
    font-size: 3.3rem;
  }
}
#price .box{
  background: #fff;
  padding: 40px 4vw;
  margin: 15px auto 0;
  border-radius: 4px;
}
#price .box h3{
  font-size: 1.7rem;
  color: #293794;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #price .box h3{
    font-size: 3rem;
  }
}
#price .box .s{
  font-size: 1.4rem;
  color: #293794;
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  #price .box .s{
    font-size: 2.7rem;
  }
}
#price .box .price_area{
  display: flex;
  color: #293794;
  align-items: center;
  border-bottom: 2px solid #293794;
  margin-top: -10px;
  text-align: center;
  justify-content: center;
}
#price .box .price_area .p1{
  font-size: 4.1rem;
  font-style: italic;
  font-family: "Roboto", sans-serif;
  margin-top: 12px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #price .box .price_area .p1{
    font-size: 5.4rem;
  }
}
#price .box .price_area .p2{
  font-size: 5.8rem;
  font-style: italic;
  font-family: "Roboto", sans-serif;
  margin: 0 3px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #price .box .price_area .p2{
    font-size: 6.1rem;
  }
}
#price .box .price_area .p3{
  font-size: 3.3rem;
  font-weight: 400;
  margin: 0 3px 0 0;
}
@media screen and (min-width: 769px) {
  #price .box .price_area .p3{
    font-size: 4.6rem;
  }
}
#price .box .price_area .p4{
  font-size: 1.6rem;
  margin-top: 12px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  #price .box .price_area .p4{
    font-size: 2.9rem;
  }
}
#price h4{
  border-radius: 4px;
  background: #293794;
  color: #fff;
  height: 55px;
  line-height: 55px;
  font-size: 1.6rem;
  font-weight: 400;
  margin: 15px auto;
}
#price .box2{
  background: #fff;
  border-radius: 4px;
  padding: 20px 4vw;
}
#price .box2 h5{
  font-size: 1.4rem;
  font-weight: 400;
  color: #293794;
  font-family: "Zen Kaku Gothic New", sans-serif;
  margin-bottom: 10px;
}
#price .box2 h5 span{
  font-size: 1rem;
}
#price .box2 li{
   font-family: "Zen Kaku Gothic New", sans-serif;
  color: #293794;
  font-size: 1.2rem;
  text-indent: -1em;
  padding-left: 1em;
  text-align: left;
  font-weight: 300;
  line-height: 1.7;
  margin-top: 10px;
}
@media screen and (min-width: 769px) {
  #price h4{
    font-size: 2.9rem;
  }
  #price .box2 h5{
    font-size: 2.7rem;
  }
  #price .box2 h5 span{
    font-size: 2.3rem;
  }
  #price .box2 li{
  font-size: 3.2rem;
  }
}
#pay{
  padding: 30px 4vw;
  text-align: center;
  background: #fff;
}
#pay h2{
  font-size: 2rem;
  font-weight: 500;
  color: #141E5B;
  margin-bottom: 25px;
}
#pay h3{
  font-size: 1.8rem;
  font-weight: 500;
  color: #141E5B;
  margin-top: 20px;
}
@media screen and (min-width: 769px) {
  #pay h2{
    font-size: 3.3rem;
  }
  #pay h3{
    font-size: 3.1rem;
    font-weight: 500;
    color: #141E5B;
  }
}

#intro{
  background: #ECF0FF;
  padding: 30px 4vw 90px;
}
#intro .box{
  background: #fff;
  padding: 4vw;
  margin-bottom: 4vw;
}
#intro .box h2{
  display: flex;
  align-items: center;
  padding-bottom: 3px;
  border-bottom: 1px solid #E2E2E2;
}
#intro .box h2 img{
  width: 3px;
  height: 16px;
}
@media screen and (min-width: 769px) {
  #intro .box h2 img{
    width: 6px;
    height: 32px;
  }
}
#intro .box h2 span{
  font-size: 1.8rem;
  font-weight: 400;
  color: #141E5B;
  padding-left: 10px;
}
@media screen and (min-width: 769px) {
  #intro .box h2 span{
    font-size: 3.1rem;
        padding-left: 20px;
  }
}
#intro .box h3{
  font-size: 1.6rem;
  color: #04141C;
  line-height: 1.7;
  margin: 20px auto;
}
@media screen and (min-width: 769px) {
  #intro .box h3{
    font-size: 2.9rem;
  }
}
#intro .box p,#intro .box li{
  font-size: 1.4rem;
  color: #616161;
  font-weight: 300;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #intro .box p,#intro .box li{
    font-size: 2.7rem;
  }
}
#intro .box p span{
  font-weight: 500;
}
#intro .box h4{
  font-size: 1.4rem;
  color: #04141C;
  line-height: 1.7;
  margin: 0 auto 15px;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #intro .box h4{
    font-size: 2.7rem;
  }
}
#intro .box ul{
  margin:20px auto;
}
#intro .box ul li{
  font-weight: 400;
  color: #04141C;
  text-indent: -1em;
  padding-left: 1em;
  margin-bottom: 5px;
}
#intro .box .flex{
  display: flex;
  margin: 25px auto 20px;
}
#intro .box .flex img{
  width: 30%;
}
#intro .box .flex p{
  width: 70%;
  padding-left: 4%;
  font-size: 1.55rem;
  font-weight: 500;
  color: #04141C;
}
@media screen and (min-width: 769px) {
  #intro .box .flex p{
    font-size: 2.85rem;
  }
}
#intro .box dt{
  font-size: 1.4rem;
  color: #04141C;
  font-family: "Shippori Mincho", serif;
  font-weight: 600;
  margin-bottom: 5px;
}
#intro .box dd{
  font-size: 1.4rem;
  color: #616161;
  margin-bottom: 12px;
  line-height: 1.7;
}
@media screen and (min-width: 769px) {
  #intro .box dt,#intro .box dd{
    font-size: 2.7rem;
  }
}
#intro .box a{
  display: flex;
  align-items: center;
}
#intro .box a span{
  text-decoration: underline;
  color: #04141C;
  font-size: 1.4rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #intro .box a span{
    font-size: 2.7rem;
  }
}
#intro .box a img{
  width: 16px;
  height: 16px;
  margin-left: 5px;
}

#list {
  background: #F5F5F5;
  padding: 30px 4vw;
  text-align: center;
}
#list h2{
  display: flex;
  color: #04141C;
  align-items: center;
  text-align: center;
  justify-content: center;
  font-size: 2.4rem;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #list h2{
    font-size: 3.7rem;
  }
}
#list h2 span{
  border: 1px solid #293794;
  border-right: none;
  color: #293794;
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  #list h2 span{
    width: 64px;
    height: 64px;
  }
}
#list h2 span:last-of-type{
  margin-right: 10px;
  border-right: 1px solid #293794;
}
#list h3{
  color: #04141C;
  font-size: 2rem;
  font-weight: 500;
  margin: 10px auto 20px;
  background:linear-gradient(transparent 80%, #FFDB59 80%);
  display: inline-block;
}
@media screen and (min-width: 769px) {
  #list h3{
    font-size: 3.3rem;
  }
}
#list .box{
  background: #fff;
  border-radius: 8px;
  padding: 0 4vw 4vw;
  margin-bottom: 20px;
}
#list .box h4{
  color: #293794;
  font-size: 2.4rem;
  padding: 30px 0 5px;
}
#list .box .en{
  color: #616161;
  font-size: 1.7rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #list .box h4{
    font-size: 3.7rem;
  }
  #list .box .en{
    font-size: 3rem;
  }
}
#list .box .ad{
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 20px auto 20px;
}
#list .box .ad img{
  width: 18px;
  height: 18px;
}
#list .box .ad p{
  color: #04141C;
  font-size: 1.6rem;
  text-align: left;
  width: calc( 100% - 18px);
  padding-left: 10px;
}
@media screen and (min-width: 769px) {
  #list .box .ad p{
    font-size: 2.9rem;
  }
}
#list .box a{
  display: flex;
  background: #293794;
  padding: 12px 20px;
  border-radius: 4px;
  align-items: center;
  margin-bottom: 10px;
}
#list .box a img{
  width: 32px;
  height: 32px;
}
#list .box a span{
  color: #fff;
  font-size: 2.4rem;
  display: block;
  margin-left: 20px;
}
#list .box a span.tel{
  font-family: "Roboto", sans-serif;
  font-size: 2.4rem;
}
#list .box a span.web{
  font-size: 2rem;
  margin-left: 30px;
}
@media screen and (min-width: 769px) {
  #list .box a span{
    font-size: 3.7rem;
  }
  #list .box a span.tel{
    font-size: 3.7rem;
  }
  #list .box a span.web{
    font-size: 3.3rem;
    margin-left: 33px;
  }
}

.schedule table {
	width: 100%;
	table-layout: fixed;
}
.schedule table th {
	width: 33% !important;
}
.schedule table tr:first-child th {
	letter-spacing: 3px;
}
.schedule table tr:first-child td {
	font-weight: 500;
	color: #111;
	text-align: left;
	padding: 13px 0px;
	line-height: 1;
  text-align: center;
}
.schedule p {
	margin-left: 22px;
	margin-bottom: 2px;
}
.schedule p strong {
	color: #8D6B44;
}
.schedule p:last-child {
	margin-bottom: 0;
}
.schedule_note {
	letter-spacing: 1px;
	margin-top: 10px;
}
.schedule_note li {
	text-align: left;
	font-weight: 400;
	font-size: 1.3rem;
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .schedule_note li {
    font-size: 2.4rem;
  }
}
.schedule_note li span {
	color: #293794;
}
.schedule .tb01 td {
	padding: 22px 0;
	line-height: 1;
}
.schedule .tb01 td,
.schedule .tb01 th {
	border-bottom: 1px solid #04141C;
  font-size: 1.4rem;
  color: #293794;
  text-align: left;
  font-weight: 500;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .schedule .tb01 td,
  .schedule .tb01 th {
    font-size: 2.4rem;
  }
}
.schedule .tb01 th{
  color: #04141C;
}
.schedule .tb01 tr:first-child th {
  text-align: center;
  padding-left: 3px;
}
/* .schedule .tb01 th {
	padding-left: 14px;
} */
/* .schedule tr:last-child {
	border-bottom: 1px solid #967341;
} */

#access {
  margin: 0 auto 0;
  text-align: center;
  padding: 40px 4vw 40px;
  background: #fff;
}
#access .en{
  font-size: 1.6rem;
  font-family: "Roboto", sans-serif;
  color: #4F62DB;
  font-style: italic;
}
#access h2{
  font-size: 2.4rem;
  font-weight: 500;
  color: #141E5B;
  margin: 10px auto 30px;
}
@media screen and (min-width: 769px) {
  #access .en{
    font-size: 2.9rem;
  }
  #access h2{
    font-size: 3.7rem;
  }
}
#access iframe{
  width: 100%;
  height: 200px;
}
@media screen and (min-width: 769px) {
  #access iframe{
    width: 100%;
    height: 360px;
  }
}
#access .box{
  background: #F5F5F5;
  padding: 0 4vw 4vw;
  margin:-2px auto 20px;
}
#access .box h4{
  color: #293794;
  font-size: 2.4rem;
  padding: 30px 0 5px;
}
#access .box .en{
  color: #141E5B;
  font-size: 1.7rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  #access .box h4{
    font-size: 3.7rem;
  }
  #access .box .en{
    font-size: 3rem;
  }
}
#access .box .ad,#access .box .detail{
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 20px auto 20px;
}
#access .box .ad img{
  width: 18px;
  height: 18px;
}
#access .box .ad p{
  color: #04141C;
  font-size: 1.6rem;
  text-align: left;
  width: calc( 100% - 18px);
  padding-left: 10px;
}
@media screen and (min-width: 769px) {
  #access .box .ad p{
    font-size: 2.9rem;
  }
}
#access .box .detail{
  background: #fff;
  border-radius: 8px;
  padding: 4vw;
}
@media screen and (min-width: 769px) {
  #access .box .detail{
    padding: 2vw;
  }
}
#access .box .detail img{
  width: 18px;
  height: 18px;
}
#access .box .detail p{
  color: #141E5B;
  font-size: 1.6rem;
  text-align: left;
  width: calc( 100% - 18px);
  padding-left: 10px;
}
#access .box .detail p span{
  font-size: 2rem;
}
#access .box .detail p span.b{
  font-size: 1.6rem;
  font-weight: 600;
  display: block;
  margin-bottom: 5px;
}
@media screen and (min-width: 769px) {
  #access .box .detail p{
    font-size: 2.9rem;
  }
  #access .box .detail p span{
    font-size: 3.3rem;
  }
  #access .box .detail p span.b{
    font-size: 2.9rem;
  }
}

#sns {
  margin: 0 auto 0;
  text-align: center;
  padding: 40px 4vw 40px;
  background: #fff;
}
#sns .en{
  font-size: 1.6rem;
  font-family: "Roboto", sans-serif;
  color: #4F62DB;
  font-style: italic;
}
#sns h2{
  font-size: 2.4rem;
  font-weight: 500;
  color: #141E5B;
  margin: 10px auto 30px;
}
#sns a{
  text-align: center;
  border: 1px solid #BFBFBD;
  margin-bottom: 15px;
  height: 64px;
  line-height: 64px;
  border-radius: 32px;
  display: block;
  font-family: "Roboto", sans-serif;
  font-size: 1.6rem;
  color: #04141C;
  text-align: center;
}
@media screen and (min-width: 769px) {
  #sns .en{
    font-size: 2.9rem;
  }
  #sns h2{
    font-size: 3.7rem;
  }
  #sns a{
    font-size: 2.9rem;
  }
}
#sns a{
  background: url(../../assets/img/lp_sync/icon_insta.svg) no-repeat 35px center;
  background-size: 48px 48px;
}
#sns a.tiktok{
  background: url(../../assets/img/lp_sync/icon_tiktok.svg) no-repeat 35px center;
}
#sns a.youtube{
  background: url(../../assets/img/lp_sync/icon_youtube.svg) no-repeat 35px center;
}
#sns a.face{
  background: url(../../assets/img/lp_sync/icon_face.svg) no-repeat 35px center;
}
@media screen and (min-width: 769px) {
  #sns a{
    background-size: 72px 72px !important;
  }
}

footer{
  padding: 20px 0 80px;
  background: #050C37;
  text-align: center;
  margin: auto;
}
footer small{
  font-size: 1rem;
  color: #CCE5EE;
}
@media screen and (min-width: 769px) {
  footer small{
    font-size: 1.8rem;
  }
}


.accordion {
  position: relative;
}
/* ボタン */
.accordion-btn {
  background-color: #fff;
  bottom: 10px;
  color: #04141C;
  cursor: pointer;
  display: inline-block;
  font-size: 1.8rem;
  font-weight: 500;
  left: 0;
  margin: auto;
  /* position: absolute;
  position: relative; */
  right: 0;
  text-align: center;
  transition: all .2s;
  width: auto;
  /* width: fit-content; */
  z-index: 1;
  position: absolute;
}
/* 続きを読むボタンの表記 */
.accordion-btn::after {
  display: block;
  /* transform: scale(.4); */
  margin: auto;
  text-align: center;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  width: 323px;
  height: 64px;
}
.accordion-btn1::after {
  background: url(../../assets/img/lp_sync/btn1.png);
  background-size: 323px 64px;
}
.accordion-btn2::after {
  background: url(../../assets/img/lp_sync/btn2.png);
  background-size: 323px 64px;
}
.accordion-btn3::after {
  background: url(../../assets/img/lp_sync/btn3.png);
  background-size: 323px 64px;
}
.accordion-btn4::after {
  background: url(../../assets/img/lp_sync/btn4.png);
  background-size: 323px 64px;
}
.accordion-btn5::after {
  background: url(../../assets/img/lp_sync/btn5.png);
  background-size: 323px 64px;
}
.accordion-btn6::after {
  background: url(../../assets/img/lp_sync/btn6.png);
  background-size: 323px 64px;
}
.accordion-btn.is-show ::after {
	display: none;
}
/* ボタンhover時のスタイル */
/* .accordion-btn:hover {
  background-color: #fff;
  color: #6495ed;
} */
.accordion-text {
  overflow: hidden; /* テキストを隠す */
  position: relative;
}
/* 最初に見えてるテキストエリアの高さ */
.accordion-text.is-hide {
  height: 100px;
}
/* テキストをグラデーションで隠す */
.accordion-text::before {
  background: -webkit-linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,.9) 50%, rgba(255,255,255,.9) 50%, #fff 100%);
  background:         linear-gradient(top, rgba(255,255,255,0) 0%, rgba(255,255,255,.9) 50%, rgba(255,255,255,.9) 50%, #fff 100%);
  bottom: 0;
  content: "";
  height: 60px; /* グラデーションで隠す高さ */
  position: absolute;
  width: 100%;
  left: 0;
  right: 0;
  margin: auto;
}
/* 閉じるボタンの位置 */
.accordion-btn.is-show {
  bottom: -3em;
}
/* 閉じるボタンの表記 */
.accordion-btn.is-show::after {
  content:"";
  width: 323px;
  height: 64px;
  left: 0;
  margin: auto;
  text-align: center;
  position: absolute;
  top: -40px;
  bottom: auto;
  margin: auto;
}
.accordion-btn1.is-show::after {
  background: url(../../assets/img/lp_sync/btn1cl.png);
  background-size: 323px 64px;
}
.accordion-btn2.is-show::after {
  background: url(../../assets/img/lp_sync/btn2cl.png);
  background-size: 323px 64px;
}
.accordion-btn3.is-show::after {
  background: url(../../assets/img/lp_sync/btn3cl.png);
  background-size: 323px 64px;
}
.accordion-btn4.is-show::after {
  background: url(../../assets/img/lp_sync/btn4cl.png);
  background-size: 323px 64px;
}
.accordion-btn5.is-show::after {
  background: url(../../assets/img/lp_sync/btn5cl.png);
  background-size: 323px 64px;
}
.accordion-btn6.is-show::after {
  background: url(../../assets/img/lp_sync/btn6cl.png);
  background-size: 323px 64px;
}
/* 続きを見るボタンをクリックしたらテキストを隠しているグラデーションを消す */
.accordion-btn.is-show + .accordion-text::before {
  display: none;
}
/* レイアウトの為のスタイル */
.accordion {
  margin-left: auto;
  margin-right: auto;
  margin-top: 20px;
  width: 100%;
}
.accordion:not(:first-of-type) {
  margin-bottom: 100px;
  margin-top: 100px;
}
.accordion.mt {
  margin-top: 10px;
}
.accordion-text p {
  line-height: 1.3;
}


#bottom_fix{
  display: flex;
  margin-top: 1px;
  position: fixed;
  bottom: -10px;
  z-index: 3;
  width: 100%;
  max-width: 768px;
}
#bottom_fix a{
  width: 50%;
  display: block;
  height: 60px;
  line-height: 58px;
  text-align: center;
  font-weight: 500;
  border: none;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  margin: 0 auto 10px;
  color: #fff;
  font-size: 1.4rem;
  letter-spacing: 1px;
}
#bottom_fix a.or{
  background-image: linear-gradient(90deg, rgba(249, 230, 88, 1), rgba(253, 34, 27, 1));
}
#bottom_fix a.bl{
  background-image: linear-gradient(90deg, rgba(31, 203, 226, 1), rgba(24, 125, 205, 1));
}



/* お問い合せフォーム用スタイル */
.contact-form {
  margin: 0 auto;
  padding: 0 2vw;
}
@media screen and (min-width: 769px) {
  .contact-form {
    padding: 50px 0;
  }
}
.contact-form .en{
    font-size: 1.6rem;
    font-family: "Roboto", sans-serif;
    color: #4F62DB;
    font-style: italic;
    text-align: center;
}
@media screen and (min-width: 769px) {
  .contact-form .en{
    font-size: 2.9rem;
  }
}
.contact-form h2 {
    font-size: 2.4rem;
    font-weight: 500;
    color: #141E5B;
    margin: 10px auto 30px;
}
@media screen and (min-width: 769px) {
    .contact-form h2 {
        font-size: 3.7rem;
    }
}


.contact-form .logo{
  display: block;
  width: 90vw;
  margin: auto;
}
@media screen and (min-width: 769px) {
  .contact-form .logo{
    width: 18%;
  }
}
.contact-form h2 {
  font-size: 3.6rem;
  text-align: center;
  margin: 10px auto 20px;
}
@media screen and (min-width: 769px) {
  .contact-form h2 {
    font-size: 4.5rem;
  }
}
.contact-form .roadmap_circle{
  width: 15vw;
  display: block;
  margin: auto;
}
@media screen and (min-width:769px){
  .contact-form .roadmap_circle{
    width: 60px;
  }
}
.contact-form .box{
  border: 1px solid #F29805;
  border-radius: 20px;
  margin: 25px auto 25px;
  width: 92vw;
  text-align: center;
  padding: 20px 10px;
}

@media screen and (min-width:769px){
  .contact-form .box{
    max-width: 980px;
    padding: 20px;
    width: auto;
    margin: 40px auto 40px;
  }
}
.contact-form .box h3{
  color: #F29805;
  font-size: 2.5rem;
  margin-bottom: 5px;
}
@media screen and (min-width:769px){
  .contact-form .box h3{
    font-size: 3.6rem;
  }
}
.contact-form .box h4{
  font-size: 1.6rem;
  font-weight: 400;
}
@media screen and (min-width:769px){
  .contact-form .box h4{
    font-size: 2rem;
  }
}
.contact-form .cap{
  font-size: 1.4rem;
  width: 92vw;
  margin: 0 auto 30px;
  text-align: center;
  line-height: 1.7;
}
@media screen and (min-width:769px){
  .contact-form .cap{
    max-width: 980px;
    width: auto;
    font-size: 1.8rem;
  }
}
.contact-form .cap span{
  color: #F29805;
  font-size: 1.8rem;
}
@media screen and (min-width:769px){
  .contact-form .cap span{
    font-size: 2.2rem;
  }
}
.contact-form form{
  width: 92vw;
  margin: auto;
  background: #fff;
  padding: 5vw 4vw;
}
@media screen and (min-width: 769px) {
  .contact-form form{
    max-width: 85%;
    padding: 40px;
  }
}
.contact-form .form-group {
  padding-top: 15px;
  padding-bottom: 10px;
  margin: 0 auto 10px;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group {
    margin: 30px auto;
    padding: 0;
  }
}
.contact-form .form-group.no {
  border-top: none;
  padding-top: 0;
}

.contact-form .ttl{
  font-size: 1.4rem;
  font-weight: 500;
  color: #141E5B;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  .contact-form .ttl{
    font-size: 1.7rem;
  }
}
.contact-form .ttl span{
  background: #293794;
  color: #fff;
  font-size: 1.2rem;
  display: inline-block;
  padding: 2px 5px;
  vertical-align: 1px;
  margin-left: 8px;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .contact-form .ttl span{
    font-size: 1.2rem;
  }
}
.contact-form .text{
  font-size: 1.4rem;
  text-align: left;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  .contact-form .text{
    font-size: 1.6rem;
  }
}
.contact-form .form-group label {
  font-size: 1.4rem;
  text-align: left;
  margin-bottom: 8px;
  margin-right: 16px;
  display: inline-block;
}

@media screen and (min-width: 769px) {
  .contact-form .form-group label {
    font-size: 1.6rem;
  }
}
.contact-form .form-group label input[type="radio"] {
  display: inline-block;
  margin-right: 8px;
}
.contact-form .form-group .text_s{
  font-size: 1.4rem;
  font-weight: 400;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group .text_s{
    font-size: 1.6rem;
  }
}
.contact-form .form-group .birth{
  display: flex;
  align-items: center;
  margin-top: 5px;
}
.contact-form .form-group .birth p{
  color: #141E5B;
  font-size: 1.2rem;
  margin: 0 2%;
}
.contact-form .form-group .birth p:first-child{
  margin: 0 2% 0 0;
}
.contact-form .form-group .birth input{
  width: 21%;
}
.contact-form .text_s span{
  font-size: 1.3rem;
  display: block;
  margin: 2px auto 10px;
}
@media screen and (min-width: 769px) {
  .contact-form .text_s span{
    font-size: 1.5rem;
    margin: 5px auto 10px;
  }
}
.contact-form input[type="text"],
.contact-form input[type="tel"],
.contact-form input[type="date"],
.contact-form input[type="email"],
.contact-form select {
  width: 100%;
  padding: 10px 12px;
  font-size: 1.4rem;
  border: 1px solid #293794;
  border-radius: 6px;
  background: #ECF2FF;
  margin-top: 4px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  display: block;
}
.contact-form input[type="radio"] {
  /* margin-right: 8px; */
}
.contact-form input[type="radio"] {
  appearance: auto !important;
  -webkit-appearance: radio !important;
  -moz-appearance: radio !important;
}
.contact-form button[type="submit"] {
  width: 100%;
  background:#293794;
  color: #fff;
  font-size: 1.8rem;
  border: none;
  border-radius: 30px;
  cursor: pointer;
  transition: background 0.2s;
  margin: auto;
  display: block;
  height: 60px;
  line-height: 60px;
  position: relative;
}
@media screen and (min-width: 769px) {
  .contact-form button[type="submit"] {
    width: 60%;
    height: 80px;
    border-radius: 40px;
    line-height: 80px;
    font-size: 2rem;
  }
}
.contact-form button[type="submit"]:hover {
  opacity: .5;
}
.contact-form button[type="submit"]:before {
  position: absolute;
  content: "";
  background: url(../../assets/img/lp_sync/icon_arrow.png) no-repeat 0 0;
  background-size: 40px 40px;
  width: 40px;
  height: 40px;
  top: 10px;
  right: 20px
}
@media screen and (min-width: 769px) {
  .contact-form button[type="submit"]:before {
    top: 20px;
    right: 30px
  }
}


.contact-form ::placeholder{
    font-size: 1.3rem;
    color: rgba(51,51,51,0.5);
}
@media screen and (min-width: 769px) {
  .contact-form ::placeholder{
    font-size: 1.5rem;
  }
}
.contact-form textarea {
  width: 100%;
  padding: 10px 12px;
  font-size: 1.4rem;
  border: 1px solid #293794;
  border-radius: 6px;
  background: #ECF2FF;
  margin: 5px auto 0;
  resize: vertical;
  box-sizing: border-box;
  height: 120px;
}
@media screen and (min-width: 769px) {
  .contact-form textarea {
    height: 150px;
    margin: 0 auto 5px;
  }
}
.contact-form select {
  background-image: url('data:image/svg+xml;utf8,<svg fill="%23999" height="20" viewBox="0 0 20 20" width="20" xmlns="http://www.w3.org/2000/svg"><path d="M7.293 8.293a1 1 0 011.414 0L10 9.586l1.293-1.293a1 1 0 111.414 1.414l-2 2a1 1 0 01-1.414 0l-2-2a1 1 0 010-1.414z"/></svg>') !important;
  background-repeat: no-repeat !important;
  background-position: right 12px center !important;
  background-size: 20px 20px !important;
  padding-right: 36px !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
}
/* IE用: デフォルトの矢印を消す */
.contact-form select::-ms-expand {
  display: none;
}
@media screen and (min-width: 769px) {
  .contact-form input[type="date"],#company,#zipcode,#email,#tel{
    width: 45%;
  }
}
#prefecture,#position{
  width: 40%;
}
@media screen and (min-width: 769px) {
  #prefecture,#employees,#position{
    width: 30%;
  }
}
.contact-form .name-row {
  display: flex;
  gap: 12px;
}
@media screen and (min-width: 769px) {
  .contact-form .name-row {
  
  }
}
@media screen and (min-width: 769px) {
  .contact-form .name-col {
    min-width: 100px;
  }
}
.contact-form .form-group .privacy{
  text-align: center;
  margin: auto;
  display: block;
  font-size: 1.3rem;
}
@media screen and (min-width: 769px) {
  .contact-form .form-group .privacy{
    font-size: 1.4rem;
  }
}
.privacy_text{
  color: #141E5B;
  font-size: 1.4rem;
  text-align: center;
  line-height: 1.7;
}
.privacy_text a{
  color: #141E5B;
  font-size: 1.4rem;
  font-weight: 600;
  text-decoration: underline;
} 
@media screen and (min-width: 769px) {
  .privacy_text,.privacy_text a{
    font-size: 1.8rem;
  }
}
.privacy_text img{
  width: 15px;
  display: inline-block;
  margin-left: 8px;
}
.privacy{
  text-align: center;
  margin: 10px auto 30px;
  display: block;
  color: #141E5B;
  font-size: 1.3rem;
}
@media screen and (min-width: 769px) {
  .privacy{
    font-size: 1.6rem;
  }
}
.contact-form .flex{
  display: flex;
  align-items: center;
}
.contact-form .flex p{
  position: relative;
  background: #ECF2FF;
  border: 1px solid #141E5B;
  border-radius: 6px;
  padding: 10px;
}
.contact-form .flex p:first-child{
  margin-right: 20px;
}
.contact-form .flex p label{
  margin: 0;
}

.bottom_fixed{
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 10;
  margin: auto;
  display: flex;
}
.bottom_fixed > div{
  display: flex;
  height: 75px;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .bottom_fixed{
    width: 769px;
  }
  .bottom_fixed > div{
    height: 105px;
  }
}
.bottom_fixed > div ul{
  width: 50%;
  display: flex;
  align-items: center;
  text-align: center;
  position: relative;
}

.bottom_fixed > div .tokyo{
  background: #293794;
}
.bottom_fixed > div .tokyo:after{
  content: "東京院";
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  color: #293794;
  font-size: 1.6rem;
  top: -14px;
  background: #fff;
  height: 28px;
  line-height: 25px;
  border-radius: 14px;
  width: 60%;
  border: 1px solid #293794;
}

.bottom_fixed > div .yokohama{
  background: #295894;
}
.bottom_fixed > div .yokohama:after{
  content: "横浜院";
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  color: #295894;
  font-size: 1.6rem;
  top: -14px;
  background: #fff;
  height: 28px;
  line-height: 25px;
  border-radius: 14px;
  width: 60%;
  border: 1px solid #293794;
}
.bottom_fixed > div li{
  width: 50%;
  height: 100%;
}
.bottom_fixed > div li a{
  font-size: 1.5rem;
  color: #fff;
  margin: auto;
  text-align: center;
  display: block;
  height: 100%;
}
.bottom_fixed > div .tokyo li:first-child{
  border-right: 1px solid #1A2679;
}
.bottom_fixed > div .yokohama li:first-child{
  border-right: 1px solid #1A3F6D;
}
.bottom_fixed > div li img{
  width: 28%;
  display: block;
  text-align: center;
  margin: 18px auto 3px;
}


