@charset "UTF-8";
/*!
	Theme Name: muruudul-japan
*/
/**/
/*!
	Theme Name: muruudul-japan
*/
/*
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;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

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

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

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

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

del {
  text-decoration: line-through;
}

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

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

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

input, select {
  vertical-align: middle;
}

/*===================================
breakpoints
===================================*/
/*===================================
長いテキストに省略記号
===================================*/
/*===================================
animation
===================================*/
@-webkit-keyframes UpAnime {
  from {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
}
@keyframes UpAnime {
  from {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  to {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
}
@-webkit-keyframes DownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes DownAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(-100px);
            transform: translateY(-100px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes fadeAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeAnime {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@-webkit-keyframes scrolldown {
  0% {
    bottom: 55px;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    bottom: -5px;
    opacity: 0;
  }
}
@keyframes scrolldown {
  0% {
    bottom: 55px;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    bottom: -5px;
    opacity: 0;
  }
}
@-webkit-keyframes scrolldownsp {
  0% {
    bottom: 35px;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    bottom: -5px;
    opacity: 0;
  }
}
@keyframes scrolldownsp {
  0% {
    bottom: 35px;
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 0.9;
  }
  100% {
    bottom: -5px;
    opacity: 0;
  }
}
@-webkit-keyframes delayAnime {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes delayAnime {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes bgextendAnimeBase {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@-webkit-keyframes bgextendAnimeSecond {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@keyframes bgextendAnimeSecond {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
@keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}
/*===================================
foundation
===================================*/
html {
  font-size: 62.5%;
}
html, body {
  width: 100%;
  height: 100%;
}
* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
ul {
  margin: 0;
  padding: 0;
  list-style: none;
}
li {
  list-style-type: none;
}
a {
  color: #333;
  text-decoration: none;
  outline: none;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}
a:hover {
  opacity: 0.7;
}
img {
  border-style: none;
  width: 100%;
  height: auto;
  vertical-align: top;
  display: block;
}
p a {
  color: #dcc13f;
  text-decoration: underline;
}
p a:hover {
  text-decoration: none;
}
p:not(:last-child) {
  margin-bottom: 40px;
}
@media screen and (max-width: 1279px) {
  p {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 768px) {
  p {
    font-size: 2.5vw;
  }
  p:not(:last-child) {
    margin-bottom: 30px;
  }
}
@media screen and (max-width: 480px) {
  p {
    font-size: 3vw;
  }
}

/*===================================
font
===================================*/
body {
  color: #111;
  font-size: 2rem;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
  font-family: 'Noto Sans JP',"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
}
@media screen and (max-width: 1023px) {
  body {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  body {
    font-size: 1.5rem;
  }
}
.wrapper-common {
  max-width: 1080px;
  margin: 0 auto;
  padding: 0 2em;
}
.wrapper-common02 {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 2em;
}
p:not(:last-child),
.wp-block-image:not(:last-child) {
  margin-bottom: 1em;
}
a {
  transition: all 0.3s;
}
a:hover {
  opacity: 0.7;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 600;
}
.font-en {
  font-family: Helvetica, sans-serif;
}
.f-bold {
  font-weight: 600;
}
.note li {
  text-indent: -1em;
  padding-left: 1em;
}


/*===================================
switch
===================================*/
.pc-block {
  display: block;
}
@media screen and (max-width: 1600px) {
  .pc-block {
    display: none;
  }
}

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

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

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

.md-only {
  display: none;
}
@media screen and (max-width: 1023px) {
  .md-only {
    display: block;
  }
}

.md-block {
  display: none;
}
@media screen and (max-width: 1023px) {
  .md-block {
    display: block;
  }
}
@media screen and (max-width: 768px) {
  .md-block {
    display: none;
  }
}

.md-none {
  display: inline-block;
}
@media screen and (max-width: 1023px) {
  .md-none {
    display: none;
  }
}

.sm-only {
  display: none;
}
@media screen and (max-width: 768px) {
  .sm-only {
    display: block;
  }
}

.sm-none {
  display: inline-block;
}
@media screen and (max-width: 768px) {
  .sm-none {
    display: none;
  }
}

.xs-only {
  display: none;
}
@media screen and (max-width: 575px) {
  .xs-only {
    display: block;
  }
}

.xs-none {
  display: inline-block;
}
@media screen and (max-width: 575px) {
  .xs-none {
    display: none;
  }
}

/*----------------------------
fadeup animation
===================================*/
.fadeUp {
  -webkit-animation: fadeUpAnime 0.8s forwards ease-in-out;
  animation: fadeUpAnime 0.8s forwards ease-in-out;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  opacity: 0;
}
.fadeUp.dl-5 {
  -webkit-animation-delay: 0.5s;
          animation-delay: 0.5s;
}
.fadeUp.dl-10 {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}
@media screen and (max-width: 768px) {
  .fadeUp.dl-5 {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
  .fadeUp.dl-10 {
    -webkit-animation-delay: 0s;
            animation-delay: 0s;
  }
}
@keyframes fadeUpAnime {
  from {
    opacity: 0;
    -webkit-transform: translateY(50px);
            transform: translateY(50px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
/*----------------------------
fadeLeft
----------------------------*/
.fadefromLeft {
  -webkit-animation-name: fadefromLeftAnime;
          animation-name: fadefromLeftAnime;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadefromLeftAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(-80px);
            transform: translateX(-80px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/*----------------------------
fadeRight
----------------------------*/
.fadeRight {
  -webkit-animation-name: fadeRightAnime;
          animation-name: fadeRightAnime;
  -webkit-animation-duration: 0.8s;
          animation-duration: 0.8s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  opacity: 0;
}

@keyframes fadeRightAnime {
  from {
    opacity: 0;
    -webkit-transform: translateX(80px);
            transform: translateX(80px);
  }
  to {
    opacity: 1;
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
}
/*----------------------------
bgLRextend
----------------------------*/
.bgLRextend::before {
  -webkit-animation: bgLRextendAnime;
  animation: bgLRextendAnime;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s;
          animation-duration: 1.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 3;
}
@keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
  50% {
    -webkit-transform-origin: left;
            transform-origin: left;
    -webkit-transform: scaleX(1);
            transform: scaleX(1);
  }
  50.001% {
    -webkit-transform-origin: right;
            transform-origin: right;
  }
  100% {
    -webkit-transform-origin: right;
            transform-origin: right;
    -webkit-transform: scaleX(0);
            transform: scaleX(0);
  }
}

/*===================================
text color
===================================*/
.cl-theme {
  color: #dcc13f !important;
}

/*===================================
text align
===================================*/
.txtL {
  text-align: left !important;
}

.txtC {
  text-align: center !important;
}

.txtR {
  text-align: right !important;
}

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

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

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

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

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

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

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

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

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

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

/*===================================
grid
===================================*/
.grid {
  display: -ms-grid;
  display: grid;
}
.grid.col2 {
  -ms-grid-columns: (1fr)[2];
  grid-template-columns: repeat(2, 1fr);
}
.grid.col3 {
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
}
.grid.col4 {
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
}
.grid.g60 {
  grid-gap: 60px;
}
.grid.g50 {
  grid-gap: 50px;
}
.grid.g25 {
  grid-gap: 25px;
}
.grid.g10 {
  grid-gap: 10px;
}

.reverse {
  grid-auto-flow: column dense;
}
.reverse.col2 .grid__item:nth-child(odd) {
  -ms-grid-column: 2;
  -ms-grid-column-span: 1;
  grid-column: 2/3;
}

@media screen and (max-width: 1279px) {
  .g60 {
    grid-gap: 30px;
  }
  .grid.col3.g60 {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 1023px) {
  .grid.col3.g50 {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 768px) {
  .g60 {
    grid-gap: 30px;
  }
  .g50 {
    grid-gap: 25px;
  }
  .grid.col2,
  .grid.col3,
  .grid.col3.g50,
  .grid.col3.g60,
  .grid.col4 {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
  .reverse {
    grid-auto-flow: unset;
  }
  .reverse.col2 .grid__item:nth-child(odd) {
    grid-column: unset;
  }
  .grid.col3.g25,
  .grid.col4.g25 {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 575px) {
  .grid.col3.g25 {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}
/*===================================
spTel
===================================*/
.spTel {
  pointer-events: none;
}

@media screen and (max-width: 1023px) {
  a.spTel {
    pointer-events: auto;
  }
}

/* ----------------------------------
breadcrumb
/--------------------------------- */
.breadcrumb {
  margin-bottom: 5em;
  font-size: 1.6rem;
}
.breadcrumb .wrapper {
  width: 96%;
  margin: 0 auto;
  padding: 0 2%;
}
.breadcrumb a {
  color: #dcc13f;
  text-decoration: underline;
}
.breadcrumb a:hover {
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .breadcrumb {
    font-size: 1.4rem;
    margin-bottom: 3em;
  }
}
@media screen and (max-width: 480px) {
  .breadcrumb {
    font-size: 1.2rem;
  }
}

/* ----------------------------------
.anchor-link
/--------------------------------- */
.anchor-link {
  display: block;
  padding-top: 100px;
  margin-top: -100px;
}

/* ----------------------------------
sec
/--------------------------------- */
.sec {
  margin-bottom: 5em;
}
@media screen and (max-width: 768px) {
  .sec {
    margin-bottom: 3em;
  }
}

/*----------------------------
タイトル
----------------------------*/
.title-gold {
  color: #dcc13f;
  font-size: 3.3vw;
  margin-bottom: 1em;
}
.title-gold-middle {
  color: #dcc13f;
  font-size: 3.2rem;
  margin-bottom: 1em;
}
.title-white {
  color: #fff;
  font-size: 3.3vw;
  margin-bottom: 1em;
}
.title-white-middle {
  font-size: 3.2rem;
  color: #fff;
  margin-bottom: 1em;
}
.title-black {
  color: #111;
  font-size: 3.3vw;
  margin-bottom: 1em;
}
.title-black-middle {
  color: #111;
  font-size: 3.2rem;
  margin-bottom: 0.75em;
}
.title-line, .wp-block-heading {
  font-size: 3.2rem;
  border-bottom: 1px solid #b5b5b5;
  padding-bottom: 0.25em;
  margin-bottom: 0.5em;
}
.title-ballon {
  text-align: center;
  font-size: 3vw;
  margin-bottom: 1em;
}
.title-ballon .ttl-bl-wrap {
  display: inline-block;
  border-bottom: 1px solid #111;
  position: relative;
  z-index: 1;
}
.title-ballon .ttl-bl-wrap::after {
  position: absolute;
  bottom: -17px;
  left: 0;
  right: 0;
  margin: auto;
  content: "";
  width: 30px;
  height: 30px;
  border: 1px solid;
  border-color:  transparent transparent #111 #111;
  transform: rotate(-45deg);
  background-color: #fff;
  z-index: -1;
}
@media screen and (max-width: 1279px) {
  .title-white-middle,
  .title-line,
  .wp-block-heading {
    font-size: 2.5vw;
    margin-bottom: 0.5em;
  }
}
@media screen and (max-width: 1023px) {
  .title-black-middle,
  .title-gold-middle {
    font-size: 4.5vw;
  }
}
@media screen and (max-width: 768px) {
  .title-gold,
  .title-white,
  .title-black {
    font-size: 5.5vw;
    margin-bottom: 4vw;
  }
  .title-black-middle,
  .title-gold-middle {
    font-size: 5.5vw;
  }
  .title-white-middle,
  .title-line,
  .wp-block-heading {
    font-size: 3vw;
  }
  .title-ballon {
    font-size: 3.2vw;
    margin-bottom: 2em;
  }
}
@media screen and (max-width: 480px) {
  .title-gold,
  .title-white,
  .title-black {
    font-size: 5.2vw;
  }
  .title-white-middle,
  .title-line,
  .wp-block-heading {
    font-size: 4vw;
  }
}
.title-en {
  font-size: 8vw;
  opacity: 0.4;
  font-family: Helvetica,sans-serif;
  font-weight: 600;
  line-height: 1;
}
.title-en.opa-ttl {
  color: rgb(17 17 17 / 20%);
}
.title-en.opa-ttl-yl {
  color: rgb(246 220 96 / 40%);
}
@media screen and (max-width:768px) {
  .title-en {
    font-size: 10vw;
  }
}

/*----------------------------
ボタン
----------------------------*/
.button a {
  max-width: 300px;
  text-align: center;
  color: #fff;
  background-color: #111;
  border: 1px solid #fff;
  font-size: 2.4rem;
  padding: 1em;
  border-radius: 50px;
  font-weight: 600;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  transition: 0.3s ease-in-out;
}
.button a:after {
  content: '';
  position: absolute;
  top: 50%;
  right: -1em;
  transform: translateY(-50%);
  width: 60px;
  height: 2px;
  background-color: #f8f8f8;
  transition: 0.3s;
}
.button a:hover:after {
    right: -2em;
}
.button a:hover {
    background: #ccc;
    color: #111;
    opacity: 1;
}
.button-line {
  width: 240px;
}
.button-line a {
  display: block;
}
.button-yellow a {
  max-width: 400px;
  text-align: center;
  color: #fff;
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  border: 1px solid #fff;
  font-size: 2.4rem;
  padding: 1em;
  border-radius: 50px;
  font-weight: 600;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  transition: 0.3s ease-in-out;
}
.button-yellow a:after {
    content: '';
    position: absolute;
    top: 50%;
    right: -1em;
    transform: translateY(-50%);
    width: 60px;
    height: 2px;
    background-color: #f8f8f8;
    transition: 0.3s;
}
.button-yellow a:hover:after {
    right: -2em;
}
.button-yellow a:hover {
    background: #FAE684;
    background: linear-gradient(90deg, rgba(198, 171, 40, 1) 0%, rgba(250, 230, 132, 1) 100%);
    opacity: 1;
}
@media screen and (max-width:768px) {
  .button a,.button-yellow a {
    font-size: 2.5vw;
    padding: 0.5em;
  }
}
@media screen and (max-width:480px) {
  .button a,.button-yellow a {
    font-size: 3.5vw;
  }
  .button a:after,
  .button-yellow a:after {
    width: 20px;
    right: -0.6em;
  }
  .button a:hover:after,
  .button-yellow a:hover:after {
      right: -0.9em;
  }
}

/* ----------------------------------
.wpcf7-submit
/--------------------------------- */
.wpcf7-submit {
  width: 300px;
  text-align: center;
  color: #fff;
  background-color: #111;
  border: 1px solid #fff;
  font-size: 2.4rem;
  padding: 1em;
  border-radius: 50px;
  font-weight: 600;
  position: relative;
  display: flex;
  justify-content: space-around;
  align-items: center;
  transition: 0.3s ease-in-out;
  cursor: pointer;
  display: block;
  margin: 0 auto;
}
.wpcf7-submit:hover {
    background: #ccc;
    color: #111;
    opacity: 1;
}
@media screen and (max-width:480px) {
  .wpcf7-submit {
    width: 100%;
  }
}

/* ----------------------------------
contact-box
/--------------------------------- */
.contact-box {
  padding: 0 2em;
  margin-bottom: 5em;
}
.contact-box .wrapper-common02 {
  background: url(img/common/bg-contact02.jpg) no-repeat center;
  background-size: cover;
  border-radius: 50px;
  padding: 3em;
}
.contact-box .button-yellow a {
  margin: 0 auto;
}
@media screen and (max-width:768px) {
  .contact-box {
    margin-bottom: 3em;
  }
}

/* ----------------------------------
flex-box
/--------------------------------- */
.flex-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  /*align-items: center;*/
}
.flex-box:not(:last-child) {
  margin-bottom: 80px;
}
.flex-box.border-box {
  border: 1px solid #999;
  padding: 60px;
}
.flex-box .text-box {
  width: 55%;
}
.flex-box .pict-box {
  width: 40%;
}
@media screen and (min-width: 1024px) {
  .flex-box .first-cont {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .flex-box .second-cont {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}
@media screen and (max-width: 1023px) {
  .flex-box {
    display: block;
  }
  .flex-box:not(:last-child) {
    margin-bottom: 60px;
  }
  .flex-box .text-box {
    width: 80%;
    margin: 0 auto 40px;
  }
  .flex-box .pict-box {
    width: 80%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .flex-box.border-box {
    padding: 40px;
  }
  .flex-box .text-box {
    width: 90%;
    margin-bottom: 2em;
  }
}
@media screen and (max-width: 575px) {
  .flex-box .pict-box {
    width: 90%;
  }
}

/* ----------------------------------
flex-box-two-rows
/--------------------------------- */
.flex-box-two-rows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.flex-box-two-rows:not(:last-child) {
  margin-bottom: 60px;
}
.flex-box-two-rows .box-item {
  width: 48%;
  margin-bottom: 0;
}
@media screen and (max-width: 768px) {
  .flex-box-two-rows {
    display: block;
  }
  .flex-box-two-rows:not(:last-child) {
    margin-bottom: 40px;
  }
  .flex-box-two-rows .box-item {
    width: 100%;
    margin: 0 auto 20px;
  }
  .flex-box-two-rows .box-item:last-child {
    margin-bottom: 0;
  }
}

/* ----------------------------------
flex-box-tree-rows
/--------------------------------- */
.flex-box-tree-rows {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.flex-box-tree-rows .box-item {
  width: 32%;
}
.flex-box-tree-rows .box-item figure {
  margin-bottom: 20px;
}
@media screen and (max-width: 1023px) {
  .flex-box-tree-rows .box-item {
    width: 48%;
  }
}
@media screen and (max-width: 768px) {
  .flex-box-tree-rows {
    display: block;
  }
  .flex-box-tree-rows .box-item {
    width: 80%;
    margin: 0 auto 40px;
  }
  .flex-box-tree-rows .box-item figure {
    margin-bottom: 10px;
  }
  .flex-box-tree-rows .box-item:last-child {
    margin-bottom: 0;
  }
}
@media screen and (max-width: 575px) {
  .flex-box-tree-rows .box-item {
    width: 90%;
  }
}

/* ----------------------------------
table-01
/--------------------------------- */
.table-01 {
  max-width: 1080px;
  margin: 0 auto;
}
.table-01 th {
  width: 13em;
  text-align: left;
  font-weight: 600;
  padding: 2em 0;
  color: #999;
}
.table-01 tr:first-child th {
  border-top: 1px solid #b5b5b5;
}
.table-01 td {
  padding: 2em 0;
  border-bottom: 1px solid #b5b5b5;
}
.table-01 td p {
  font-weight: 600;
}
.table-01 td .linklogo_group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.table-01 td .linklogo_group:not(:last-child){
  margin-bottom: 1em;
}
.table-01 td .linklogo_group .linklogo_img {
  width: 100px;
  margin-right: 1em;
}

@media screen and (min-width: 769px) {
  .table-01 {
    padding: 0 2em;
  }
  .table-01 th {
    border-bottom: 1px solid #b5b5b5;
  }
  .table-01 tr:first-child td {
    border-top: 1px solid #b5b5b5;
  }
}

@media screen and (max-width: 768px) {
  .table-01,
  .table-01 tbody,
  .table-01 tr,
  .table-01 th,
  .table-01 td {
    display: block;
  }
  .table-01 th,
  .table-01 td {
    width: 100%;
  }
  .table-01 th {
    padding-bottom: 0;
  }
}

/* ----------------------------------
table-form
/--------------------------------- */
.table-form {
  width: 100%;
  margin-bottom: 2em;
}
.table-form th {
  width: 13em;
  text-align: left;
  font-weight: 600;
  padding: 2em 0;
  color: #999;
  vertical-align: middle;
}
.table-form tr:first-child th {
  border-top: 1px solid #b5b5b5;
}
.table-form td {
  padding: 2em 0;
  border-bottom: 1px solid #b5b5b5;
}
.table-form td input {
  width: 100%;
  height: 50px;
  line-height: 2;
  font-size: 1.8rem;
  border: 1px solid #ccc;
  padding: 0.5em;
}
.table-form td input.inp-age {
  width: 6em;
  margin-right: 0.5em;
}
.table-form td textarea {
  width: 100%;
  font-size: 1.8rem;
  border: 1px solid #ccc;
  padding: 0.5em;
}
.table-form td select {
  font-size: 2.4rem;
  width: 5em;
}
@media screen and (min-width: 769px) {
  .table-form {
    padding: 0 2em;
  }
  .table-form th {
    border-bottom: 1px solid #b5b5b5;
  }
  .table-form tr:first-child td {
    border-top: 1px solid #b5b5b5;
  }
}

@media screen and (max-width: 768px) {
  .table-form,
  .table-form tbody,
  .table-form tr,
  .table-form th,
  .table-form td {
    display: block;
  }
  .table-form th,
  .table-form td {
    width: 100%;
  }
  .table-form th {
    padding-bottom: 0;
  }
  .table-form td {
    padding-top: 1em;
  }
  .table-form td input,
  .table-form td textarea {
    font-size: 1.6rem;
  }
}

/* ----------------------------------
wp-block-list
/--------------------------------- */
.wp-block-list {
  padding-left: 1.3em;
  margin-bottom: 2em;
}
.wp-block-list li {
  list-style: disc;
}
@media screen and (max-width: 1279px) {
  .wp-block-list li {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 768px) {
  .wp-block-list li {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 480px) {
  .wp-block-list li {
    font-size: 3vw;
  }
}

/* ----------------------------------
dl-list
/--------------------------------- */
.dl-list {
  margin-bottom: 1em;
  padding: 1.5em;
  border: 3px solid #dcc13f;
  border-radius: 50px;
}
.dl-list dt {
  font-weight: 600;
  border-bottom: 1px solid #b5b5b5;
  margin-bottom: 0.25em;
}
.dl-list dd:not(:last-child) {
  margin-bottom: 0.5em;
}
@media screen and (max-width: 1279px) {
  .dl-list {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 768px) {
  .dl-list {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 480px) {
  .dl-list {
    font-size: 3vw;
  }
}
/* ----------------------------------
point-list
/--------------------------------- */
.point-list dl {
  background: #fff;
  border: 10px solid #dcc13f;
  padding: 2em 1em;
  text-align: center;
  position: relative;
  border-radius: 50px;
}
.point-list dl dt {
  background-color: #dcc13f;
  color: #fff;
  text-align: center;
  font-size: 2vw;
  font-weight: 600;
  border-radius: 30px;
  padding: 0 0.5em;
  position: absolute;
  top: -1em;
  left: -1em;
  font-family: Helvetica,sans-serif;
}
.point-list dl dd {
  font-size: 2vw;
  line-height: 1.5;
}
.point-list dl dd span {
  color: #dcc13f;
  font-size: 4vw;
  font-weight: 600;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .point-list {
    justify-content: center;
    display: flex;
  }
  .point-list dl {
    width: 48%;
  }
  .point-list dl:not(:last-child) {
    margin-right: 4%;
  }
}
@media screen and (max-width: 1279px) {
  .point-list dl {
    padding: 1em;
  }
}
@media screen and (max-width: 768px) {
  .point-list dl {
    border-width: 5px;
  }
  .point-list dl:not(:last-child) {
    margin-bottom: 2em;
  }
  .point-list dl dt {
    font-size: 3vw;
  }
  .point-list dl dd {
    font-size: 3vw;
  }
  .point-list dl dd span {
    font-size: 5vw;
  }
}

/* ----------------------------------
anchor-list
/--------------------------------- */
.anchor-list {
  margin-bottom: 100px;
}
.anchor-list ul {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1em 1fr 1em 1fr 1em 1fr 1em 1fr;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  gap: 1em;
}
.anchor-list.anchor-three-column ul {
  -ms-grid-columns: 1fr 1fr 1fr;
  grid-template-columns: 1fr 1fr 1fr;
}
.anchor-list li a {
  padding-top: 10px;
  height: 80px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: #fde2fa;
  border: solid 1px #c347b5;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  position: relative;
}
.anchor-list li a::after {
  content: "↓";
  width: 20px;
  height: 20px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 20px;
  margin: auto;
}
@media screen and (max-width: 1023px) {
  .anchor-list {
    margin-bottom: 60px;
  }
}
@media screen and (max-width: 768px) {
  .anchor-list ul {
    -ms-grid-columns: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr;
  }
  .anchor-list li a {
    height: 60px;
    padding-top: 5px;
  }
  .anchor-list li a:after {
    bottom: 13px;
  }
}
@media screen and (max-width: 575px) {
  .anchor-list ul {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
  .anchor-list.anchor-three-column ul {
    -ms-grid-columns: 1fr 1fr;
    grid-template-columns: 1fr 1fr;
  }
}

/* ----------------------------------
news-list
/--------------------------------- */
.news-list li {
  padding: 2em 0;
  border-bottom: 1px solid #ccc;
}
.news-list li:first-child {
  border-top: 1px solid #ccc;
}
.news-list li a {
  display: flex;
  align-items: center;
}
.news-list li a .date {
  font-size: 1.6rem;
  display: inline-block;
  margin-right: 2em;
  color: #999;
}
@media screen and (max-width: 575px) {
  .news-list li {
    padding: 1em 0;
  }
  .news-list li a {
    display: block;
  }
}

/* ----------------------------------
.pagination
/--------------------------------- */
.pagination {
  text-align: center;
  margin-top: 2em;
}
.pagination span {
  display: inline-block;
  padding: 3px 8px;
  font-weight: bold;
}
.pagination span.current {
  color: #dcc13f;
}
.pagination span.extend {
  border: 1px solid #dcc13f;
  background-color: #fff;
}
.pagination a {
  display: inline-block;
  padding: 3px 8px;
}
.pagination .page-numbers {
  color: #999;
  font-family: Helvetica,sans-serif;
  font-weight: 600;
}
.pagination a.prev, .pagination a.next {
  color: #fff;
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  border-radius: 50%;
}
.pagination a.prev, .pagination a.next {
  width: 46px;
}
@media screen and (max-width: 1023px) {
  .pagination a.prev, .pagination a.next {
    width: 38px;
  }
}
@media screen and (max-width: 768px) {
  .pagination a, .pagination span {
    font-size: 3vw;
  }
}

/*----------------------------
ローディング画面
----------------------------*/
.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}
.loading-text {
  font-family: Helvetica,sans-serif;
}
.pulse-container {
  display: flex;
  justify-content: space-between;
  width: 100px;
}
.pulse-bubble {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background-color: #dcc13f;
}
.pulse-bubble-1 {
  animation: pulse 0.4s ease 0s infinite alternate;
}
.pulse-bubble-2 {
  animation: pulse 0.4s ease 0.2s infinite alternate;
}
.pulse-bubble-3 {
  animation: pulse 0.4s ease 0.4s infinite alternate;
}
@keyframes pulse {
    from {
      opacity: 1;
      transform: scale(1);
    }
    to {
      opacity: 0.25;
      transform: scale(0.75);
    }
}
.content {
  display: none;
}
.show {
  display: block;
  animation: loadingContent 1s;
}
@keyframes loadingContent {
	0% {opacity: 0;}
	100% {opacity: 1;}
}

.visual-wrapper {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  background: #ffffff;
  margin-bottom: 3em;
}
#catchcopy {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 2%;
  margin: auto;
  z-index: 1;
  height: 20vw;
}
@font-face {
  font-family: season font;
  src: url('font/season.ttf') format("truetype");
  font-display: swap;
}
#catchcopy span {
  display:inline-block;
  transform: translateX(-100px); /* 左にオフセット */
  animation: fadeInLeft 1.5s forwards; /* アニメーションを適用 */
  white-space:nowrap;
  opacity: 0;
}
#catchcopy .copy-jp {
  text-align: left;
  font-size: 6rem;
  white-space: nowrap;
  line-height: 1.25;
  letter-spacing: 0.1em;
  font-family: season font;
  font-weight: bold;
  font-style: italic;
  margin-bottom: 0.5em;
}
#catchcopy .copy-en {
  font-family: Helvetica,sans-serif;
  font-weight: 600;
  line-height: 1.5;
}
#catchcopy .copy-jp .line02 {
  animation-delay: 0.5s;
}
#catchcopy .copy-jp .line03 {
  animation-delay: 1s;
}
#catchcopy .copy-en .line04 {
  animation-delay: 2s;
}
#catchcopy .copy-en .line05 {
  animation-delay: 2.25s;
}
#catchcopy .copy-en .line06 {
  animation-delay: 2.5s;
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(-100px);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}
.wave {
  position: absolute;
  width: 150%;
  height: 100%;
  animation-timing-function: ease-in-out;
}
.wave1 {
  top: 0;
  animation: waveMove1 38s ease-in-out infinite alternate,
              waveFloat1 6s ease-in-out infinite;
}
.wave2 {
  top: 5vh;
  animation: waveMove2 45s ease-in-out infinite alternate,
              waveFloat2 7s ease-in-out infinite;
}
.wave3 {
  top: 10vh;
  animation: waveMove3 50s ease-in-out infinite alternate,
              waveFloat3 5.5s ease-in-out infinite;
}
.wave4 {
  top: 15vh;
  animation: waveMove4 41s ease-in-out infinite alternate,
              waveFloat4 6.5s ease-in-out infinite;
}
.wave5 {
  top: 50vh;
  animation: waveMove5 60s ease-in-out infinite alternate,
              waveFloat5 7.5s ease-in-out infinite;
}
.wave6 {
  top: 50vh;
  animation: waveMove6 65s ease-in-out infinite alternate,
              waveFloat6 8.5s ease-in-out infinite;
}
@keyframes waveMove1 {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-40%); }
}
@keyframes waveMove2 {
  0%   { transform: translateX(-5%); }
  100% { transform: translateX(-35%); }
}
@keyframes waveMove3 {
  0%   { transform: translateX(-10%); }
  100% { transform: translateX(-30%); }
}
@keyframes waveMove4 {
  0%   { transform: translateX(-2%); }
  100% { transform: translateX(-50%); }
}
@keyframes waveMove5 {
  0%   { transform: translateX(-20%); }
  100% { transform: translateX(-60%); }
}
@keyframes waveMove6 {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-40%); }
}

@keyframes waveFloat1 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}
@keyframes waveFloat2 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-30px); }
}
@keyframes waveFloat3 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-25px); }
}
@keyframes waveFloat4 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-18px); }
}
@keyframes waveFloat5 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-22px); }
}
@keyframes waveFloat6 {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-30px); }
}
@media screen and (max-width: 1279px) {
  .visual-wrapper {
    margin-bottom: 0;
  }
  #catchcopy .copy-jp {
    font-size: 4.25vw;
  }
  #catchcopy .copy-en {
    font-size: 1.5vw;
  }
}
@media screen and (max-width: 1023px) {
  #catchcopy {
    height: 65vw;
  }
  #catchcopy .copy-jp {
    font-size: 6.25vw;
  }
  #catchcopy .copy-jp span:not(:last-child) {
    margin-bottom: 0.5em;
  }
  #catchcopy .copy-en {
    font-size: 2vw;
  }
}
@media screen and (max-width: 768px) {
  #catchcopy {
    left: 5%;
    height: 85vw;
  }
  #catchcopy .copy-jp {
    font-size: 7vw;
    margin-bottom: 1em;
  }
  #catchcopy .copy-en {
    font-size: 3vw;
  }
}

/*===================================
.header
===================================*/
.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-width: 320px;
  z-index: 101;
  padding: 1em 0;
  transition: all 0.5s;
}
.header .wrapper {
  width: 96%;
  margin: 0 auto;
}
.header .logo {
  max-width: 110px;
  transition: all 0.5s;
}
.header .logo a {
  display: block;
  max-width: 110px;
  width: 110px;
}
.header .logo img {
  width: 100%;
}
.header .logo .logo-img-sp {
  vertical-align: sub;
  display: none;
}
.header .nav li a {
  position: relative;
}
.header .menu-trigger {
  transition: all 0.5s;
}
.header.scroll {
  box-shadow: 0 0 4px #ccc;
  padding: 0.5em 0;
  background: #fff;
}
.header.scroll .logo {
  max-width: 80px;
}
.header.scroll .logo a {
  max-width: 80px;
  width: 80px;
}
.header.scroll .menu-trigger {
  top: 32px;
}
@media screen and (min-width: 1280px) {
  .header .wrapper {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .header .menu-trigger, .header .overlay {
    display: none;
  }
  .header .nav {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
    width: calc(100% - 140px);
    transition: all 0.5s;
  }
  .header .nav ul {
    margin-right: 20px;
  }
  .header .nav li {
    display: inline-block;
    margin-right: 10px;
    position: relative;
  }
  .header .nav li:last-child {
    margin-right: 0;
  }
  .header .nav li a {
    font-size: 1.6rem;
  }
  .header .nav li:not(.button) a::after {
    position: absolute;
    bottom: -4px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #fff;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform 0.3s;
  }
  .header .nav li:not(.button) a:hover::after {
    transform-origin: left top;
    transform: scale(1, 1);
    background: #111;
  }
  .header .nav li.button a {
    width: 270px;
  }
  .header .nav li.button a:after {
    width: 40px;
  }
  .header .nav li.button a:hover:after {
    right: -1.5em;
  }
  .header.scroll .nav {
    width: calc(100% - 110px);
  }
  .header.scroll .nav li a {
    font-size: 1.4rem;
  }
  .header.scroll .nav li.button a {
    width: 240px;
  }
}
@media screen and (max-width: 1279px) {
  .header .wrapper {
    display: flex;
    align-items: center;
  }
  .header .hd-lg-btn {
    margin-left: 1em;
  }
  .header .hd-lg-btn a {
    font-size: 1.6rem;
    padding: 0.5em 1em;
  }
  .header .hd-lg-btn a::after {
    width: 30px;
  }
  .header .hd-lg-btn a:hover:after {
    right: -1.25em;
  }
  .header .menu-trigger {
    display: inline-block;
    width: 36px;
    height: 28px;
    vertical-align: middle;
    cursor: pointer;
    position: fixed;
    top: 53px;
    right: 20px;
    z-index: 100;
  }
  .header .menu-trigger span {
    display: inline-block;
    box-sizing: border-box;
    position: absolute;
    left: 0;
    width: 100%;
    height: 2px;
    background-color: #111;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
  }
  .header .menu-trigger span:nth-of-type(1) {
    top: 0;
  }
  .header .menu-trigger span:nth-of-type(2) {
    top: 13px;
  }
  .header .menu-trigger span:nth-of-type(3) {
    bottom: 0;
  }
  .header .menu-trigger.active span {
    background-color: #111;
  }
  .header .menu-trigger.active span:nth-of-type(1) {
    -webkit-transform: translateY(13px) rotate(-45deg);
            transform: translateY(13px) rotate(-45deg);
  }
  .header .menu-trigger.active span:nth-of-type(2) {
    opacity: 0;
  }
  .header .menu-trigger.active span:nth-of-type(3) {
    -webkit-transform: translateY(-13px) rotate(45deg);
            transform: translateY(-13px) rotate(45deg);
  }
  .header nav {
    width: 100%;
    height: 100vh;
    padding: 80px 20px 0;
    background-color: rgba(255, 255, 255, 0.9);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    overflow-y: scroll;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    display: none;
  }
  .header nav.open {
    display: block;
  }
  .header nav ul li {
    border-bottom: 1px solid #666;
  }
  .header nav ul li a {
    display: block;
    padding: 0.5em 0 0.5em 1em;
    position: relative;
  }
  .header nav ul li:not(.button) a::before {
    content: "";
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 5px; /* くの字を山なりに見た時、左側の長さ */
    height: 5px; /* くの字を山なりに見た時、右側の長さ */
    border-top: 2px solid #111; /* くの字を山なりに見た時、左側の太さと色 */
    border-right: 2px solid #111; /* くの字を山なりに見た時、右側の太さと色 */
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg); /* くの字の向き */
  }
  .header nav ul li.button {
    border-bottom: none;
  }
  .header nav ul li.button a {
    max-width: 430px;
    padding: 1em;
    margin: 1em auto 0;
  }
}
@media screen and (max-width: 575px) {
  .header {
    padding: 0.5em 0;
  }
  .header .logo {
    max-width: 80px;
  }
  .header .logo a {
    max-width: 80px;
    width: 80px;
  }
  .header .menu-trigger {
    top: 30px;
  }
  .header.scroll .logo {
    max-width: 60px;
  }
  .header.scroll .logo a {
    max-width: 60px;
    width: 60px;
  }
  .header.scroll .menu-trigger {
    top: 23px;
  }
  .header .hd-lg-btn {
    margin-left: 0.5em;
  }
  .header .hd-lg-btn a {
    font-size: 1.3rem;
  }
  .header .hd-lg-btn a::after {
    width: 20px;
  }
}
/*----------------------------
.thought
----------------------------*/
.home .thought {
  position: relative;
  padding: 6em 0 10em;
  background: url(img/common/bg-yellow-rightup.png) no-repeat bottom center;
  background-size: 120%;
}
.home .thought .title-en {
  position: absolute;
  top: 0;
  left: 0;
  color: rgb(246 220 96 / 40%);
}
@media screen and (max-width:1279px) {
  .home .thought {
    padding-bottom: 6em;
  }
}
@media screen and (min-width:769px) {
  .home .thought {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .home .thought .text-box {
    width: 45%;
    padding-left: 2%;
  }
  .home .thought .pict-box {
    width: 50%;
  }  
}
@media screen and (max-width:768px) {
  .home .thought {
    padding-top: 10vw;
    padding-bottom: 8em;
  }
  .home .thought .text-box {
    width: 85%;
    margin: 0 auto 3em;
  }
  .home .thought .pict-box {
    margin-left: 8%;
  }
}

/*----------------------------
.philosophy
----------------------------*/
.home .philosophy {
  position: relative;
  margin-bottom: 10em;
}
.home .philosophy .title-en {
  position: absolute;
  top: -1em;
  left: 0;
  color: rgb(246 220 96 / 40%);
}
.home .philosophy .text-box {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  padding: 5em 5em 5em 8em;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
}
.home .philosophy .text-box {
  width: 52%;
  margin-left: auto;
}
.home .philosophy .text-box p {
  color: #fff;
}
.home .philosophy .pict-box {
    position: relative;
}
@media screen and (max-width: 1279px) {
  .home .philosophy {
    margin-bottom: 6em;
  }
  .home .philosophy .text-box {
    padding: 5vw 2vw 5vw 10vw;
    width: 55%;
  }
}
@media screen and (min-width:769px) {
  .home .philosophy .text-box {
    margin-left: auto;
  }
  .home .philosophy .pict-box {
    width: 52%;
  }  
}
@media screen and (max-width: 768px) {
  .home .philosophy {
    margin-bottom: 5em;
  }
  .home .philosophy .title-en {
    left: auto;
    right: 0;
  }
  .home .philosophy .text-box {
    margin-left: auto;
    width: 80%;
    padding: 5vw 5vw 13vw 9vw;
  }
  .home .philosophy .pict-box {
    top: -4em;
    width: 80%;
  }
}
@media screen and (max-width: 575px) {
  .home .philosophy .text-box {
    width: 90%;
    padding-top: 8vw;
  }
  .home .philosophy .pict-box {
    top: -2em;
  }
}

/*----------------------------
.gallery-slider
----------------------------*/
.home .gallery-slider {
  display: flex;
  overflow: hidden;
  margin-bottom: 10em;
}
.home .gallery-slider .d-demo__wrap {
  display: flex;
  overflow: hidden;
}
.home .gallery-slider .d-demo__list {
  display: flex;
  list-style: none;
}
.home .gallery-slider .d-demo__list--left {
  animation: infinity-scroll-left 50s infinite linear 0.5s both;
}
.home .gallery-slider .d-demo__item {
  width: 20vw;
  margin: 0 0.5em;
}
.home .gallery-slider .d-demo__item > img {
  width: 100%;
}
@media screen and (max-width: 1279px) {
  .home .gallery-slider {
    margin-bottom: 6em;
  }
}
@media screen and (max-width: 768px) {
  .home .gallery-slider {
    margin-bottom: 5em;
  }
  .home .gallery-slider .d-demo__item {
    width: 50vw;
  }
}
@keyframes infinity-scroll-left {
  from {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}

/*----------------------------
.guidlines
----------------------------*/
.guidlines {
  width: 92%;
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  padding: 5em;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  position: relative;
  margin-bottom: 10em;
}
.guidlines .title-en {
  position: absolute;
  top: 0;
  right: 0;
  color: rgb(255 255 255 / 40%);
}
.guidlines .gl-list li {
  background-color: #fff;
  border-radius: 50px;
  padding: 2em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
}
.guidlines .gl-list li:not(:last-child) {
  margin-bottom: 2em;
}
.guidlines .gl-list li .num {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  color: #fff;
  border-radius: 50%;
  text-align: center;
  font-family: Helvetica,sans-serif;
  font-size: 2.8rem;
  font-weight: 600;
  font-style: normal;
  width: 100px;
  line-height: 100px;
}
.guidlines .gl-list li .gl-title {
  color: #dcc13f;
  font-size: 3.2rem;
  margin-bottom: 0.5em;
  line-height: 1.5;
}
.guidlines .gl-list li .gl-title .gl-title-en {
  font-size: 2.4rem;
  margin-top: 0.5em;
  display: block;
}
.guidlines .gl-list li .ico {
  width: 100px;
}
.guidlines .gl-list li .text-box {
  width: calc(100% - 280px);
}
@media screen and (max-width: 1279px) {
  .guidlines {
    padding: 3em;
    margin-bottom: 6em;
  }
  .guidlines .gl-list li:not(:last-child) {
    margin-bottom: 1em;
  }
  .guidlines .gl-list li .num {
    width: 80px;
    line-height: 80px;
    font-size: 2.4rem;
  }
  .guidlines .gl-list li .ico {
    width: 80px;
  }
  .guidlines .gl-list li .text-box {
    width: calc(100% - 200px);
  }
  .guidlines .gl-list li .gl-title {
    font-size: 2.5vw;
  }
  .guidlines .gl-list li .gl-title .gl-title-en {
    font-size: 2vw;
  }
}
@media screen and (min-width:769px) {
  .guidlines .gl-list li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: flex-start;
  }
}
@media screen and (max-width:768px) {
  .guidlines {
    margin-bottom: 5em;
    padding: 2em;
  }
  .guidlines .title-en {
    font-size: 8vw;
  }
  .guidlines .gl-list li {
    padding: 4vw;
  }
  .guidlines .gl-list li .num {
    display: block;
    margin: 0 auto 0.5em;
  }
  .guidlines .gl-list li .ico {
    width: 140px;
    margin: 0 auto 1em;
  }
  .guidlines .gl-list li .text-box {
    width: 100%;
    text-align: center;
  }
  .guidlines .gl-list li .gl-title {
    font-size: 4vw;
  }
  .guidlines .gl-list li .gl-title .gl-title-en {
    font-size: 3vw;
  }
}
@media screen and (max-width:768px) {
  .guidlines .gl-list li .ico {
    width: 40%;
  }
}

/*----------------------------
.message
----------------------------*/
.message {
  background: url(img/common/bg-yellow-rightup.png) no-repeat bottom center;
  background-size: 120%;
  padding-bottom: 10em;
}
.message .title-black {
  line-height: 1.5;
}
.message .title-en {
  color: rgb(246 220 96 / 40%);
  text-align: right;
}
.message .name {
  max-width: 370px;
  margin-top: 2em;
}
.message .ms-box {
  position: relative;
  padding-top: 15em;
}
.message .ms-box::before {
  content: url(img/top/img-message.png);
  border-top-left-radius: 50px;
  position: absolute;
  top: 0;
  right: 0;
}
.message .ms-box:after {
  content: "";
  clear: both;
  display: block;
}
.message .text-box {
  width: 52%;
  background-color: #fff;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  padding: 5em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
  position: relative;
}
@media screen and (max-width: 1279px) {
  .message {
    padding-bottom: 6em; 
  }
  .message .ms-box {
    padding-top: 35em;
  }
  .message .ms-box::before {
    content: "";
    background: url(img/top/img-message-tab.png) no-repeat top center;
    background-size: contain;
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100vw;
  }
  .message .text-box {
    width: 90%;
    padding: 5vw;
  }
}
@media screen and (max-width: 1023px) {
  .message .text-box {
    width: 90%;
  }
}
@media screen and (max-width:768px) {
  .message .ms-box {
    padding-top: 70%;
  }
}

/*----------------------------
.business
----------------------------*/
.home .business {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  padding: 3em;
  position: relative;
  margin-bottom: 10em;
}
.home .business .title-en {
  color: rgb(255 255 255 / 40%);
  position: absolute;
  top: 0;
  right: 0;
}
.home .business .bsn-list {
  width: 94%;
  margin: 0 auto;
}
.home .business .bsn-list li:not(:last-child) {
  margin-bottom: 3em;
}
.home .business .bsn-list li .text-box {
  color: #fff;
}
.home .business .bsn-list li .text-box .num {
  font-size: 7.2rem;
  font-style: normal;
  font-weight: bold;
  font-family: Helvetica, sans-serif;
  line-height: 1;
  border-bottom: 1px solid #fff;
  padding-bottom: 0.2em;
  margin-bottom: 0.2em;
  display: inline-block;
}
@media screen and (max-width: 1279px) {
  .home .business {
    margin-bottom: 7em;
  }
  .home .business .bsn-list li .text-box .num {
    font-size: 5vw;
  }
}
@media screen and (min-width:769px) {
  .home .business .bsn-list li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .home .business .bsn-list li .text-box {
    width: 50%;
  }
  .home .business .bsn-list li .pict-box {
    width: 48%;
  }
  .home .business .bsn-list li:nth-child(even) .text-box {
    order: 1;
  }
  .home .business .bsn-list li:nth-child(even) .pict-box {
    order: 2;
  }
}
@media screen and (max-width:768px) {
  .home .business {
    padding: 2em;
    margin-bottom: 5em;
  }
  .home .business .bsn-list li .pict-box {
    margin-bottom: 1em;
  }
}

/*----------------------------
.jobsearch
----------------------------*/
.jobsearch {
  position: relative;
  padding-top: 7em;
  background: url(img/common/bg-yellow-leftup.png) no-repeat bottom center;
  background-size: 120%;
}
.jobsearch .title-en {
  position: absolute;
  top: 0;
  left: 0;
  color: rgb(246 220 96 / 40%);
}
.jobsearch .text-box {
  background-color: #111;
  padding: 5em;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  width: 50%;
}
.jobsearch .text-box p {
  color: #fff;
}
.jobsearch .pict-box {
  position: relative;
  top: -25em;
  width: 57%;
  margin-left: auto;
  margin-right: 5em;
}
@media screen and (max-width: 1279px) {
  .jobsearch {
    padding-top: 5em;
  }
  .jobsearch .text-box {
    width: 90%;
  }
  .jobsearch .pict-box {
    top: -4em;
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  .jobsearch {
    margin-bottom: 3em;
  }
  .jobsearch .text-box {
    padding: 3em;
  }
  .jobsearch .pict-box {
    top: -2em;
  }
}

/*----------------------------
.recruit
----------------------------*/
.recruit .pict-box {
  width: 92%;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
.recruit .pict-box img {
  width: 100%;
}
.recruit .text-box {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  padding: 10em 5em 5em;
  position: relative;
  z-index: 0;
  top: -7em;
  width: 92%;
  margin-left: auto;
}
.recruit .text-box .title-en {
  position: absolute;
  top: 1.2em;
  right: 3%;
  color: #fff;
}
.recruit .text-box .text-box-wrap .tx-bx-l .title-white {
  font-size: 3.2rem;
}
.recruit .text-box .text-box-wrap .tx-bx-r {
  color: #fff;
}
@media screen and (min-width:1280px) {
  .recruit .text-box .text-box-wrap {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .recruit .text-box .text-box-wrap .tx-bx-l {
    width: 45%;
  }
  .recruit .text-box .text-box-wrap .tx-bx-r {
    width: 55%;
  }
}
@media screen and (max-width: 1279px) {
  .recruit .text-box {
    top: -4em;
    padding: 7em 3em 3em;
  }
}
@media screen and (max-width: 768px) {
  .recruit .text-box {
    top: -2em;
    padding-top: 5em;
  }
  .recruit .text-box .title-en {
    top: 8%;
  }
  .recruit .text-box .text-box-wrap .tx-bx-l .title-white {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 568px) {
  .recruit .text-box .text-box-wrap .tx-bx-l .title-white {
    font-size: 3.5vw;
  }
}

/*----------------------------
.sns-sec
----------------------------*/
.sns-sec .title-black {
  line-height: 1;
}
.sns-sec .title-black .fa-brands {
  font-size: 80%;
  color: #dcc13f;
}

/*----------------------------
.news
----------------------------*/
.news {
  background-color: #f8f8f8;
  padding: 5em;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  width: 92%;
  position: relative;
  margin-bottom: 10em;
}
.news .title-en {
  position: absolute;
  bottom: 0;
  left: 4%;
  line-height: 96px;
}
.news .news-box {
  background-color: #fff;
  border-radius: 50px;
  padding: 5em;
}
.news .news-box li {
  border-top: 1px solid #999;
  padding: 2em 0;
}
.news .news-box li:last-child {
  border-bottom: 1px solid #999;
}
.news .news-box li a {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.news .news-box li a .news-date {
  color: #999;
  font-size: 1.6rem;
}
@media screen and (min-width:1280px) {
  .news {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .news .text-box {
    width: 23%;
  }
  .news .news-box {
    width: 70%;
  }
  .news .news-box li a .news-date {
    width: 10em;
  }
  .news .news-box li a .news-title {
    width: calc(100% - 10em);
  }
}
@media screen and (max-width:1279px) {
  .news {
    margin-bottom: 7em;
    padding: 3em 3em 7em;
  }
  .news .title-en {
    line-height: 1;
  }
  .news .news-box {
    padding: 3em;
  }
  .news .text-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 2em;
  }
  .news .text-box .title-black {
    margin-bottom: 0;
  }
  .news .text-box .button {
    width: 40%;
  }
}
@media screen and (max-width:768px) {
  .news {
    padding: 2em 2em 5em;
    margin-bottom: 5em;
  }
  .news .news-box {
    padding: 2em;
  }
  .news .news-box li {
    padding: 1em 0;
  }
  .news .news-box li a {
    display: block;
  }
  .news .news-box li a .news-date {
    display: block;
  }
  .news .text-box {
    display: block;
  }
  .news .text-box .title-black {
    margin-bottom: 2vw;
    text-align: center;
  }
  .news .text-box .button {
    width: 100%;
  }
  .news .text-box .button a {
    margin: 0 auto;
  }
}

/*----------------------------
#contact
----------------------------*/
#contact {
  background: url(img/common/bg-contact.jpg) no-repeat center;
  background-size: cover;
  text-align: center;
  color: #fff;
  padding: 5em 0;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
}
#contact .wrapper {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 2em;
}
#contact .tel-num {
  font-family: Helvetica,sans-serif;
  font-size: 7.2rem;
  font-weight: 600;
  line-height: 1.5;
}
#contact .tel-num a {
  color: #fff;
}
#contact .button-box {
  max-width: 1040px;
  margin: 0 auto;
}
#contact .button-box .button {
  width: 47%;
}
#contact .button-box .button a {
  max-width: none;
}
@media screen and (min-width:1024px) {
  #contact .button-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (max-width:1023px) {
  #contact .button-box {
    margin-top: 3em;
  }
  #contact .button-box .button {
    width: 80%;
    margin: 0 auto;
  }
  #contact .button-box .button:not(:last-child) {
    margin-bottom: 1em;
  }
}
@media screen and (max-width:768px) {
  #contact {
    padding: 3em 0;
  }
  #contact .tel-num {
    font-size: 9vw;
  }
}
/*----------------------------
.footer
----------------------------*/
.footer .wrapper {
  width: 94%;
  margin: 0 auto;
  padding: 4em 0;
}
.footer .wrapper .left-box .foot-logo {
  width: 170px;
}
.footer .wrapper .left-box .adress {
  font-size: 1.6rem;
}
.footer .wrapper .left-box .adress .sns-link {
  display: flex;
  gap: 1em;
}
.footer .wrapper .left-box .adress .sns-link li a {
  font-size: 3rem;
  line-height: 1;
}
.footer .copyright {
  border-top: 1px solid #111;
  padding: 1em 0;
}
.footer .copyright p {
  text-align: center;
  margin: 0;
}
.footer .wrapper .right-box ul li a {
  font-size: 1.6rem;
  position: relative;
}
@media screen and (min-width:1280px) {
  .footer .copyright p {
    font-size: 1.4rem;
  }
}
@media screen and (max-width:1279px) {
  .footer .wrapper .right-box ul li a {
    font-size: 1.7vw;
  }
}
@media screen and (min-width:1024px) {
  .footer .wrapper {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .footer .wrapper .left-box {
    width: 50%;
  }
  .footer .wrapper .left-box .adress {
    width: calc(100% - 200px);
  }
  .footer .wrapper .right-box {
    width: 45%;
  }
  .footer .wrapper .right-box ul {
    margin-bottom: 1em;
  }
}
@media screen and (max-width:1023px) {
  .footer .wrapper .left-box {
    margin-bottom: 2em;
  }
  .footer .wrapper .left-box .foot-logo {
    margin-right: 1em;
  }
}
@media screen and (min-width:769px) {
  .footer .wrapper .left-box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .footer .wrapper .right-box {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .footer .wrapper .right-box ul li a::after {
    position: absolute;
    bottom: -4px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: transparent;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform 0.3s;
  }
  .footer .wrapper .right-box ul li a:hover::after {
    transform-origin: left top;
    transform: scale(1, 1);
    background: #111;
  }
}
@media screen and (min-width:769px) and (max-width:1023px) {
  .footer .wrapper .left-box {
    justify-content: center;
  }
  .footer .wrapper .right-box ul {
    width: 25%;
  }
  .footer .wrapper .right-box ul li {
    margin: 0 0.5em;
  }
}
@media screen and (max-width:768px) {
  .footer .wrapper .left-box .foot-logo {
    margin: 0 auto 1em;
  }
  .footer .wrapper .left-box .adress {
    text-align: center;
  }
  .footer .wrapper .left-box .adress .sns-link {
    justify-content: center;
  }
  .footer .wrapper .right-box ul li {
    border-bottom: 1px solid #b5b5b5;
  }
  .footer .wrapper .right-box ul li a {
    display: block;
    padding: 0.5em 0 0.5em 1em;
    font-size: 2.5vw;
  }
  .footer .wrapper .right-box ul li a::before {
    content: "";
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 5px;
    height: 5px;
    border-top: 2px solid #111;
    border-right: 2px solid #111;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
}
@media screen and (max-width:480px) {
  .footer .wrapper .left-box .foot-logo {
    width: 120px;
  }
  .footer .wrapper .right-box ul li a {
    font-size: 3vw;
  }
}

/*----------------------------
.main-visual-title
----------------------------*/
.main-visual-title {
  position: relative;
  padding: 5em 0;
  margin-top: 142px;
  margin-bottom: 5em;
  overflow: hidden;
}
.main-visual-title .mv-ttl {
  text-align: center;
  z-index: 1;
  position: relative;
  font-size: 4vw;
  font-weight: 600;
}
.main-visual-title .mv-ttl .mv-ttl-en {
  font-size: 2vw;
  font-family: Helvetica,sans-serif;
  font-weight: 600;
  color: #dcc13f;
  display: block;
  line-height: 1;
}
@media screen and (max-width:768px) {
  .main-visual-title {
    margin-top: 112px;
    margin-bottom: 3em;
    padding: 4em 0;
  }
  .main-visual-title .mv-ttl {
    font-size: 7vw;
  }
  .main-visual-title .mv-ttl .mv-ttl-en {
    font-size: 3.5vw;
  }
}
@media screen and (max-width:575px) { 
  .main-visual-title {
    margin-top: 80px;
  }
}

/*----------------------------
.faq-list
----------------------------*/
.faq-list {
  width: 92%;
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  padding: 3em;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  position: relative;
  margin-bottom: 5em;
}
.faq-list .title-en {
  position: absolute;
  top: 0;
  right: 1%;
  color: rgb(255 255 255 / 40%);
}
.faq-box {
  padding: 2em;
  background-color: #fff;
  border-radius: 50px;
  box-shadow: 0 0 5px #ccc;
}
.faq-box:not(:last-child) {
  margin-bottom: 2em;
}
.faq-box dt {
  cursor: pointer;
  font-size: 3rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  position: relative;
  line-height: 1.5;
}
.faq-box dt::before {
  content: "Q.";
  color: #dcc13f;
  margin-right: 0.1em;
  font-family: Helvetica, sans-serif;
}
.faq-box dt::after {
  content: "＋";
  font-weight: 900;
  position: absolute;
  top: 0px;
  bottom: 0px;
  right: 0;
  width: 30px;
  line-height: 50px;
  margin: auto;
  font-weight: 400;
  text-align: center;
}
.faq-box dt.open::after {
  content: "ー";
}
.faq-box dd {
  display: none;
  margin-top: 0.5em;
  padding-top: 1em;
  padding-left: 2.2em;
  position: relative;
  border-top: 1px solid #b5b5b5;
}
.faq-box dd::before {
  content: "A.";
  position: absolute;
  top: 0.9em;
  left: 0;
  line-height: 1;
  font-size: 3rem;
  font-weight: 600;
  font-family: Helvetica, sans-serif;
}
.faq-box dd a {
  text-decoration: underline;
}
.faq-box dd a:hover {
  text-decoration: none;
}
@media screen and (max-width: 1023px) {
  .faq-box {
    padding: 1em 2em;
  }
  .faq-box dt,
  .faq-box dd::before {
    font-size: 2.5vw;
  }
  .faq-box dt::after {
    line-height: 45px;
  }
  .faq-box dd {
    font-size: 1.7vw;
  }
}
@media screen and (max-width: 768px) {
  .faq-list {
    padding: 2em;
    margin-bottom: 3em;
  }
  .faq-list .title-en {
    right: 5%;
  }
  .faq-box {
    padding: 1em;
  }
  .faq-box:not(:last-child) {
    margin-bottom: 1em;
  }
  .faq-box dt,
  .faq-box dd::before {
    font-size: 3vw;
  }
  .faq-box dt {
    padding-right: 1.5em;
  }
  .faq-box dt::after {
    line-height: 35px;
  }
  .faq-box dd {
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 480px) {
  .faq-list .title-en {
    top: 2%;
  }
  .faq-box dt,
  .faq-box dd::before {
    font-size: 4vw;
  }
  .faq-box dd {
    font-size: 3vw;
  }
}

/*----------------------------
.service
----------------------------*/
/* .about-muruudul */
.service .about-muruudul {
  margin-bottom: 8em;
}
.service .about-muruudul .lead {
  padding-bottom: 12em;
  background: url(img/common/bg-yellow-rightup.png) no-repeat top;
  background-size: 100%;
}
.service .about-muruudul .service-item .pict-box img {
  width: 100%;
}
.service .about-muruudul .service-item {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  width: 100%;
  padding: 3em 3em 3em 0;
}
.service .about-muruudul .service-item:not(:last-child) {
  margin-bottom: 8em;
}
.service .about-muruudul .service-item:nth-child(odd) {
  padding: 3em 0 3em 3em;
}
.service .about-muruudul .service-item .text-box p {
  color: #fff;
  margin-bottom: 1em;
}
@media screen and (min-width:1024px) {
  .service .about-muruudul .service-item .pict-box {
    margin-top: -8em;
  }
}
@media screen and (max-width:1023px) {
  .service .about-muruudul .lead {
    padding-bottom: 6em;
  }
  .service .about-muruudul .service-item:not(:last-child) {
    margin-bottom: 5em;
  }
  .service .about-muruudul .service-item .pict-box {
    margin: 0 0 2em 0;
    width: 100%;
  }
  .service .about-muruudul .service-item .text-box {
    width: 90%;
    margin-bottom: 0;
  }
  .service .about-muruudul .service-item .text-box p {
    margin-bottom: 2em;
  }
}
@media screen and (max-width:568px) {
}

/* .service-flow */
.service-flow {
  background-color: #f8f8f8;
  padding: 4em 0 4em 4em;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  width: 92%;
  position: relative;
  margin-left: auto;
  margin-bottom: 5em;
}
.service-flow .title-en {
  position: absolute;
  top: 0.5em;
  right: 0;
  line-height: 96px;
}
.service-flow .flow-list {
  margin-left: 2em;
}
.service-flow .flow-list li {
  padding: 2em 2em 2em 6em;
  background-color: #fff;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  position: relative;
  box-shadow: 0 0 5px #ccc;
}
.service .service-flow .flow-list li.step01 {
  background-image: url(img/service/img-flow01.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step02 {
  background-image: url(img/service/img-flow02.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step03 {
  background-image: url(img/service/img-flow03.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step04 {
  background-image: url(img/service/img-flow04.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step05 {
  background-image: url(img/service/img-flow05.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step06 {
  background-image: url(img/service/img-flow06.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service .service-flow .flow-list li.step07 {
  background-image: url(img/service/img-flow07.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow.sf-common .flow-list li.step01 {
  background-image: url(img/common/bg-service-flow01.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow.sf-common .flow-list li.step02 {
  background-image: url(img/common/bg-service-flow02.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow.sf-common .flow-list li.step03 {
  background-image: url(img/common/bg-service-flow03.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow.sf-common .flow-list li.step04 {
  background-image: url(img/common/bg-service-flow04.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow.sf-common .flow-list li.step05 {
  background-image: url(img/common/bg-service-flow05.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.service-flow .flow-list li:not(:last-child) {
  margin-bottom: 4em;
}
.service-flow .flow-list li .step-num {
  background-color: #111;
  color: #fff;
  text-align: center;
  width: 120px;
  height: 120px;
  padding-top: 22px;
  position: absolute;
  top: -1em;
  left: -1em;
  font-weight: 600;
}
.service-flow .flow-list li .step-num small {
  font-size: 2.4rem;
  display: block;
  line-height: 1;
}
.service-flow .flow-list li .step-num span {
  font-size: 6rem;
  line-height: 1;
}
@media screen and (min-width:769px) {
  .service-flow .flow-list li .btn-area {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .service-flow .flow-list li .btn-area .button-line {
    margin-right: 1em;
  }
  .service-flow .flow-list li .button {
    width: 400px;
  }
  .service-flow .flow-list li .button a {
    max-width: 360px;
  }
}
@media screen and (max-width:1023px) {
  .service-flow {
    width: 100%;
    padding: 3em 0 3em 3em;
  }
  .service-flow .flow-list {
    margin-left: 0;
  }
  .service-flow .flow-list li {
    padding: 2em 2em 2em 11%;
  }
  .service-flow .flow-list li .step-num {
    width: 11%;
  }
  .service-flow .flow-list li .step-num small {
    font-size: 2vw;
  }
  .service-flow .flow-list li .step-num span {
    font-size: 5.5vw;
  }
}
@media screen and (max-width:768px) {
  .service-flow {
    margin-bottom: 3em;
  }
  .service-flow .title-en {
    line-height: 1;
    top: 0;
  }
  .service-flow .flow-list li {
    padding: 0 0 2em;
  }
  .service-flow .flow-list li:not(:last-child) {
    margin-bottom: 3em;
  }
  .service-flow .flow-list li .step-num {
    position: static;
    width: 100%;
    height: auto;
    display: flex;
    justify-content: center;
    align-items: center;
    border-top-left-radius: 50px;
    padding: 0.5em 0;
  }
  .service-flow .flow-list li .step-num small {
    font-size: 2.5vw;
    margin-right: 0.25em;
  }
  .service-flow .flow-list li .text-box {
    padding: 1em 2em 0;
  }
  .service-flow .flow-list li .btn-area .button-line {
    margin: 0 auto 1em;
  }
  .service-flow .flow-list li .btn-area .button a {
    margin: 0 auto;
  }
}

/*----------------------------
.young_talent
----------------------------*/
/* .about-youngtalent */
.young_talent .about-youngtalent {
  padding-bottom: 12em;
  background: url(img/common/bg-yellow-leftup.png) no-repeat bottom;
  background-size: 100%;
}
.young_talent .about-youngtalent .lead {
  margin-bottom: 5em;
}
.young_talent .about-youngtalent .lead .logo-tc {
  max-width: 280px;
  margin: 0 auto 3em;
}
@media screen and (max-width:1023px) {
  .young_talent .about-youngtalent {
    padding-bottom: 6em;
  }
}
@media screen and (max-width:768px) {
  .young_talent .about-youngtalent .lead {
    margin-bottom: 3em;
  }
  .young_talent .about-youngtalent .lead .logo-tc {
    max-width: 210px;
  }
}

/* .tarecari */
.young_talent .tarecari {
  background-color: #f8f8f8;
  padding: 7em 3em 3em;
  border-radius: 50px;
  position: relative;
  margin-bottom: 5em;
}
.young_talent .tarecari .title-en {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 100%;
  text-align: center;
}
.young_talent .tarecari .text-box .title-black-middle {
  line-height: 1;
}
.young_talent .tarecari .text-box .title-black-middle small {
  font-size: 2vw;
}
.young_talent .tarecari .text-box .button a {
  max-width: 440px;
}
@media screen and (min-width:1024px) {
  .young_talent .tarecari .flex-box {
    align-items: center;
  }
  .young_talent .tarecari .text-box,
  .young_talent .tarecari .flex-box .pict-box {
    width: 50%;
  }
}
@media screen and (max-width:1023px) {
  .young_talent .tarecari {
    padding: 5em 3em 3em;
  }
  .young_talent .tarecari .text-box .title-black-middle small {
    font-size: 2.5vw;
  }
  .young_talent .tarecari .flex-box .text-box {
    text-align: center;
  }
  .young_talent .tarecari .text-box .title-black-middle {
    text-align: center;
  }
  .young_talent .tarecari .text-box .button a {
    margin: 0 auto;
  }
}
@media screen and (max-width:768px) {
  .young_talent .tarecari {
    padding: 3em 2em 2em;
  }
  .young_talent .tarecari .text-box .title-black-middle small {
    font-size: 3.5vw;
  }
}

/* .recruit-support */
.recruit-support {
  background-color: #f8f8f8;
  padding: 8em 0 5em 5em;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  width: 92%;
  position: relative;
  margin-left: auto;
  margin-bottom: 5em;
}
.recruit-support .title-en {
  position: absolute;
  top: 0;
  right: 0;
}
.recruit-support .rec-box {  
  background-color: #fff;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  position: relative;
  box-shadow: 0 0 5px #ccc;
  padding: 4em;
}
.recruit-support .rec-number {
  margin-top: 1em;
}
.recruit-support .rec-number li {
  border: 5px solid #dcc13f;
  background-color: #fff;
  border-radius: 50px;
  text-align: center;
}
.recruit-support .rec-number li p {
  font-size: 3rem;
  line-height: 1.5;
  display: flex;
  align-items: center;
  justify-content: center;
}
.recruit-support .rec-number li p .num {
  color: #dcc13f;
  font-weight: 600;
  font-size: 7.2rem;
  margin-left: 0.1em;
}
.recruit-support .rec-number li p .num small {
  font-size: 4.8rem;
}
@media screen and (max-width: 1279px) {
  .recruit-support .rec-number li p {
    font-size: 2vw;
  }
  .recruit-support .rec-number li p .num {
    font-size: 6vw;
  }
  .recruit-support .rec-number li p .num small {
    font-size: 3vw;
  }
}
@media screen and (max-width: 1023px) {
  .recruit-support {
    width: 100%;
    padding: 5em 0 3em 3em;
  }
  .recruit-support .rec-box {
    padding: 3em;
  }
}
@media screen and (min-width:769px) {
  .recruit-support .rec-number {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    align-items: center;
  }
  .recruit-support .rec-number li {
    width: 32%;
  }
}
@media screen and (max-width:768px) {
  .recruit-support {
    margin-bottom: 3em;
  }
  .recruit-support .rec-number li {
    border-width: 3px;
  }
  .recruit-support .rec-number li:not(:last-child) {
    margin-bottom: 1em;
  }
  .recruit-support .rec-box {
    padding: 2em 1em;
  }
  .recruit-support .rec-number li p {
    font-size: 3vw;
  }
  .recruit-support .rec-number li p .num {
    font-size: 7vw;
  }
}

/*----------------------------
.foreign_talent
----------------------------*/
/*.lead*/
.foreign_talent .lead {
  background: url(img/common/bg-yellow-rightup.png) no-repeat top,url(img/common/bg-yellow-leftup.png) no-repeat bottom;
  background-size: 100%,100%;
}
@media screen and (min-width:1023px) {
  .foreign_talent .lead .flex-box {
    align-items: center;
  }
  .foreign_talent .lead .flex-box .text-box {
    padding-right: 3em;
  }
  .foreign_talent .lead .flex-box .text-box.first-cont {
    padding-left: 3em;
    padding-right: 0;
  }
}
@media screen and (max-width:1023px) {
  .foreign_talent .lead {
    background-position: center 20%,center 95%;
  }
  .foreign_talent .lead .flex-box .pict-box {
    width: 90%;
    margin: 0 0 2em;
  }
  .foreign_talent .lead .flex-box .pict-box.second-cont {
    width: 90%;
    margin: 0 0 2em auto;
  }
  .foreign_talent .lead .flex-box .text-box {
    width: 90%;
  }
}

/*----------------------------
.online_school
----------------------------*/
/*.main-visual-onlineschool*/
.online_school .main-visual-onlineschool {
  background-color: #fbf1c9;
  background-image: url(img/service/online_school/mv-bg.png);
  background-position: bottom right;
  background-repeat: no-repeat;
  background-size: contain;
  padding: 5em 0;
  margin-bottom: 5em;
}
.online_school .main-visual-onlineschool .wrapper {
  padding: 0 2em;
}
.online_school .main-visual-onlineschool .text-box .catchcopy {
  font-weight: 600;
}
.online_school .main-visual-onlineschool .text-box .mv-title span {
  display: inline-block;
  color: #fff;
  background-color: #111;
  font-style: italic;
  font-size: 4.8rem;
  line-height: 1.5;
  margin-bottom: 0.2em;
  position: relative;
}
/*.online_school .main-visual-onlineschool .text-box .mv-title span::before,
.online_school .main-visual-onlineschool .text-box .mv-title span::after {
  content: "";
  position: absolute;
  top: 0;
  width: 12px;
  height: 100%;
}
.online_school .main-visual-onlineschool .text-box .mv-title span::before {
  background: url(img/service/online_school/mv-tr-left.png) no-repeat center;
  background-size: contain;
  left: -10px;
}
.online_school .main-visual-onlineschool .text-box .mv-title span::after {
  background: url(img/service/online_school/mv-tr-right.png) no-repeat center;
  background-size: contain;
  right: -10px;
}*/
.online_school .main-visual-onlineschool .text-box .mv-title span ruby rt {
  font-size: 1.4rem;
}
.online_school .main-visual-onlineschool .text-box .button {
  margin-top: 1em;
}
.online_school .main-visual-onlineschool .text-box .button a {
  max-width: 400px;
}
@media screen and (max-width:1279px) {
  .online_school .main-visual-onlineschool .text-box .mv-title span {
    font-size: 4rem;
  }
  .online_school .main-visual-onlineschool .text-box .mv-title span ruby rt {
    font-size: 1.2rem;
  }
}
@media screen and (min-width:1024px) {
  .online_school .main-visual-onlineschool .flex-box {
    align-items: center;
  }
}
@media screen and (max-width:1023px) {
  .online_school .main-visual-onlineschool {
    background-size: 200%;
    padding: 8em 0 3em;
    margin-bottom: 3em;
  }
  .online_school .main-visual-onlineschool .text-box {
    text-align: center;
  }
  .online_school .main-visual-onlineschool .text-box .button a {
    margin: 0 auto;
  }
}
@media screen and (max-width:768px) {
  .online_school .main-visual-onlineschool .text-box .mv-title span {
    font-size: 5.5vw;
  }
  /*.online_school .main-visual-onlineschool .text-box .mv-title span::before {
    left: -8px;
  }
  .online_school .main-visual-onlineschool .text-box .mv-title span::after {
    right: -8px;
  }*/
  .online_school .main-visual-onlineschool .text-box .mv-title span ruby rt {
    font-size: 1.7vw;
  }
}
/*@media screen and (max-width:480px) {
  .online_school .main-visual-onlineschool .text-box .mv-title span::before {
    left: -7px;
  }
  .online_school .main-visual-onlineschool .text-box .mv-title span::after {
    right: -7px;
  }
}*/

/* .lead */
.online_school .lead {
  position: relative;
  background: url(img/common/bg-yellow-leftup.png) no-repeat center;
  padding-bottom: 10em;
}
.online_school .lead .title-en {
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (min-width:1280px) {
  .online_school .lead .flex-box .pict-box {
    padding-top: 8em;
  }
}
@media screen and (min-width:1024px) {
  .online_school .lead .flex-box .pict-box {
    width: 45%;
  }
  .online_school .lead .flex-box .text-box {
    padding-left: 5em;
    width: 50%;
  }
}
@media screen and (max-width:1279px) {
  .online_school .lead .flex-box .pict-box {
    padding-top: 5em;
  }
}
@media screen and (max-width:1023px) {
  .online_school .lead {
    padding-bottom: 6em;
  }
  .online_school .lead .flex-box .text-box {
    width: 90%;
  }
  .online_school .lead .flex-box .pict-box {
    margin: 0 0 0 auto;
    padding-top: 0;
  }
}
@media screen and (max-width:768px) {
  .online_school .lead {
    background-position: 10% center;
    padding-bottom: 5em;
  }
}

/* .target */
.online_school .target {
  background-color: #f8f8f8;
  padding: 5em 0 5em 3em;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  width: 92%;
  position: relative;
  margin-left: auto;
  margin-bottom: 5em;
}
.online_school .target .title-en {
  position: absolute;
  top: 0.5em;
  right: 0;
  line-height: 96px;
}
.online_school .target .target-list {
  padding: 3em;
  background-color: #fff;
  border-top-left-radius: 50px;
  border-bottom-left-radius: 50px;
  box-shadow: 0 0 5px #ccc;
}
.online_school .target .target-list li figure {
  margin-bottom: 0.5em;
}
.online_school .target .target-list li p {
  text-align: center;
  font-size: 1.5vw;
}
@media screen and (min-width:1024px) {
  .online_school .target .target-list {
    justify-content: center;
  }
  .online_school .target .target-list li {
    width: 31%;
  }
}
@media screen and (min-width:769px) and (max-width:1023px) {
  .online_school .target .target-list {
    justify-content: space-between;
  }
  .online_school .target .target-list li {
    width: 48%;
  }
  .online_school .target .target-list li p {
    font-size: 2vw;
  }
}
@media screen and (min-width:769px) {
  .online_school .target .target-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
  }
}
@media screen and (max-width:768px) {
  .online_school .target {
    padding: 3em 0 3em 3em;
    margin-bottom: 3em;
  }
  .online_school .target .target-list {
    padding: 2em;
  }
  .online_school .target .target-list li {
    margin-bottom: 2em;
  }
  .online_school .target .target-list li p {
    font-size: 3vw;
  }
}

/* .guidlines-wide */
.online_school .guidlines-wide {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  padding: 5em;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  position: relative;
  margin-bottom: 10em;  
}
.online_school .guidlines-wide .title-en {
  position: absolute;
  top: 0;
  right: 0;
  color: rgb(255 255 255 / 40%);
}
.online_school .guidlines-wide .gl-list {
  display: grid;
  gap: 2em;
}
.online_school .guidlines-wide .gl-list li {
  background-color: #fff;
  padding: 2em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
  border-radius: 50px;
}
.online_school .guidlines-wide .gl-list li .ico {
  width: 90px;
}
.online_school .guidlines-wide .gl-list li .text-box .gl-title {
  color: #dcc13f;
  font-size: 3.2rem;
  margin-bottom: 0.5em;
  line-height: 1.5;
}
@media screen and (max-width: 1279px) {
  .online_school .guidlines-wide .gl-list li .text-box .gl-title {
    font-size: 2.5vw;
  }
}
@media screen and (min-width:1024px) {
  .online_school .guidlines-wide .gl-list {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 1023px) {
  .online_school .guidlines-wide {
    padding: 3em;
    margin-bottom: 6em;
  }
  .online_school .guidlines-wide .gl-list {
    grid-template-columns: 1fr;
  }
}
@media screen and (min-width:769px) {
  .online_school .guidlines-wide .gl-list li {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
  .online_school .guidlines-wide .gl-list li .text-box {
    width: calc(100% - 120px);
  }
}
@media screen and (max-width: 768px) {
  .online_school .guidlines-wide {
    margin-bottom: 5em;
    padding: 2em;
  }
  .online_school .guidlines-wide .gl-list li .ico {
    margin: 0 auto 1em;
  }
  .online_school .guidlines-wide .gl-list li .text-box .gl-title {
    font-size: 3.5vw;
    text-align: center;
  }
  .online_school .guidlines-wide .gl-list li .text-box p {
    text-align: center;
  }
}

/* .reason */
.online_school .reason {
  background-color: #f8f8f8;
  padding: 5em 3em 5em 0;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  width: 92%;
  position: relative;
  margin-bottom: 7em;
}
.online_school .reason .title-en {
  position: absolute;
  top: 0.5em;
  right: 0;
  line-height: 96px;
}
.online_school .reason .reason-list li {
  padding: 2em 2em 2em 8em;
  background-color: #fff;
  border-top-right-radius: 50px;
  border-bottom-right-radius: 50px;
  position: relative;
  box-shadow: 0 0 5px #ccc;
}
.online_school .reason .reason-list li.reason01 {
  background-image: url(img/service/online_school/img-reason01.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.online_school .reason .reason-list li.reason02 {
  background-image: url(img/service/online_school/img-reason02.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.online_school .reason .reason-list li.reason03 {
  background-image: url(img/service/online_school/img-reason03.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.online_school .reason .reason-list li.reason04 {
  background-image: url(img/service/online_school/img-reason04.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.online_school .reason .reason-list li.reason05 {
  background-image: url(img/service/online_school/img-reason05.png);
  background-repeat: no-repeat;
  background-position: right center;
  background-size: contain;
}
.online_school .reason .reason-list li:not(:last-child) {
  margin-bottom: 5em;
}
.online_school .reason .reason-list li .reason-num {
  background-color: #111;
  color: #fff;
  text-align: center;
  width: 120px;
  line-height: 120px;
  position: absolute;
  top: 0;
  left: 0;
  font-size: 6rem;
  font-weight: 600;
}
.online_school .reason .reason-list li .reason-num small {
  font-size: 2.4rem;
  display: block;
  line-height: 1;
}
.online_school .reason .reason-list li .reason-num span {
  font-size: 6rem;
  line-height: 1;
}
@media screen and (min-width:769px) {
  .online_school .reason .reason-list li .btn-area {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
  }
  .online_school .reason .reason-list li .btn-area .button-line {
    margin-right: 1em;
  }
  .online_school .reason .reason-list li .button {
    width: 400px;
  }
  .online_school .reason .reason-list li .button a {
    max-width: 360px;
  }
}
@media screen and (max-width:1023px) {
  .online_school .reason {
    width: 100%;
    padding: 3em 3em 3em 0;
    margin-bottom: 6em;
  }
  .online_school .reason .reason-list {
    margin-left: 0;
  }
  .online_school .reason .reason-list li .reason-num {
    width: 11%;
    font-size: 5.5vw;
  }
}
@media screen and (max-width:768px) {
  .online_school .reason {
    margin-bottom: 5em;
  }
  .online_school .reason .title-en {
    line-height: 1;
    top: 0;
  }
  .online_school .reason .reason-list li {
    padding: 0 0 2em;
  }
  .online_school .reason .reason-list li:not(:last-child) {
    margin-bottom: 3em;
  }
  .online_school .reason .reason-list li .reason-num {
    position: static;
    width: 100%;
    height: auto;
    line-height: 3;
    display: flex;
    justify-content: center;
    align-items: center;
    border-top-right-radius: 50px;
    font-size: 2.5vw;
    margin-right: 0.25em;
  }
  .online_school .reason .reason-list li .text-box {
    padding: 1em 2em 0;
  }
  .online_school .reason .reason-list li .btn-area .button-line {
    margin: 0 auto 1em;
  }
  .online_school .reason .reason-list li .btn-area .button a {
    margin: 0 auto;
  }
}
/* .message */
.online_school .message .ms-box::before {
  content: url(img/service/online_school/img-message.png);
  border-top-left-radius: 50px;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width:1279px) {
  .online_school .message .ms-box::before {
    content: "";
    background: url(img/service/online_school/img-message-tab.png) no-repeat top center;
    background-size: contain;
  }
}

/*----------------------------
.midcareer_recruit
----------------------------*/
/*.main-visual-midcareer*/
.midcareer_recruit .main-visual-midcareer {
  background: url(img/midcareer_recruit/mv-bg.jpg) top center no-repeat;
  background-size: cover;
  margin-bottom: 3em;
}
.midcareer_recruit .main-visual-midcareer .wrapper {
  padding-left: 2em;
}
.midcareer_recruit .main-visual-midcareer .flex-box .text-box {
  padding-top: 3em;
}
.midcareer_recruit .main-visual-midcareer .text-box .to-company,
.midcareer_recruit .main-visual-midcareer .text-box .catchcopy {
  font-weight: 600;
}
.midcareer_recruit .main-visual-midcareer .text-box .mv-title {
  font-size: 5rem;
  line-height: 1.25;
  margin-bottom: 0.1em;
}
.midcareer_recruit .main-visual-midcareer .text-box .mv-title span {
  color: #dcc13f;
}
.midcareer_recruit .main-visual-midcareer .text-box .catchcopy {
  background: linear-gradient(transparent 70%, #dcc13f 70%);
  display: inline-block;
  line-height: 1.5;
  text-shadow: 2px 2px 2px #fff;
  letter-spacing: 0.25em;
}
.midcareer_recruit .main-visual-midcareer .text-box .button {
  margin-top: 1em;
}
.midcareer_recruit .main-visual-midcareer .text-box .button a {
  max-width: 400px;
}
.midcareer_recruit .main-visual-midcareer .flex-box .pict-box {
  display: block;
}
@media screen and (max-width:1279px) {
  .midcareer_recruit .main-visual-midcareer .text-box .mv-title {
    font-size: 4vw;
  }
  .midcareer_recruit .main-visual-midcareer .flex-box .text-box {
    padding-top: 1em;
  }
}
@media screen and (min-width:1024px) {
  .midcareer_recruit .main-visual-midcareer {
    margin-top: 5.5em;
  }
  .midcareer_recruit .main-visual-midcareer .flex-box .text-box {
    width: 48%;
  }
  .midcareer_recruit .main-visual-midcareer .flex-box .pict-box {
    width: 52%;
  }
}
@media screen and (max-width:1023px) {
  .midcareer_recruit .main-visual-midcareer {
    padding: 5em 0 3em;
  }
  .midcareer_recruit .main-visual-midcareer .wrapper {
    padding-left: 0;
  }
  .midcareer_recruit .main-visual-midcareer .text-box {
    text-align: center;
  }
  .midcareer_recruit .main-visual-midcareer .text-box .mv-title {
    font-size: 6vw;
  }
  .midcareer_recruit .main-visual-midcareer .text-box .to-company,
  .midcareer_recruit .main-visual-midcareer .text-box .catchcopy {
    font-size: 3vw;
  }
  .midcareer_recruit .main-visual-midcareer .text-box .button a {
    margin: 0 auto;
  }
  .midcareer_recruit .main-visual-midcareer .flex-box .pict-box {
    width: 100%;
  }
}

/*.feature*/
.midcareer_recruit .feature {
  padding: 0 5em;
  margin-bottom: 5em;
  position: relative;
  background: url(img/common/bg-yellow-rightup.png) no-repeat center;
  background-size: 100%;
}
.midcareer_recruit .feature .point-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3em;
  margin-top: 4em;
}
.midcareer_recruit .feature .title-en {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  text-align: center;
  z-index: -1;
}
.midcareer_recruit .feature .point-list dl {
  padding: 3em 2em;
  text-align: left;
}
.midcareer_recruit .feature .point-list dl dd {
  font-size: initial;
}
.midcareer_recruit .feature .point-list dl dd h3 {
  margin-bottom: 0.5em;
  font-size: 3rem;
  text-align: center;
}
.midcareer_recruit .feature .point-list dl dd figure {
  max-width: 120px;
  margin: 0 auto 0.5em;
}
@media screen and (max-width:1024px) {
  .midcareer_recruit .feature{
    padding: 0 3em;
  }
}
@media screen and (min-width:769px) {
  .midcareer_recruit .feature .point-list dl {
    width: auto;
  }
  .midcareer_recruit .feature .point-list dl:not(:last-child) {
    margin: 0;
  }
}
@media screen and (max-width:768px) {
  .midcareer_recruit .feature {
    margin-bottom: 3em;
  }
  .midcareer_recruit .feature .point-list {
    grid-template-columns: 1fr;
    gap: 0;
  }
  .midcareer_recruit .feature .point-list dl dd h3 {
    font-size: 2.4rem;
  }
}
@media screen and (max-width:568px) {
  .midcareer_recruit .feature .point-list dl dd h3 {
    font-size: 4vw;
  }
}

/*----------------------------
.foreigntalent_recruit
----------------------------*/
/*.main-visual-foreigntalent*/
.foreigntalent_recruit .main-visual-foreigntalent {
  margin-bottom: 3em;
  background: url(img/foreigntalent_recruit/mv.jpg) no-repeat right center;
  background-size: 65%;
  padding: 5em 0;
}
.foreigntalent_recruit .main-visual-foreigntalent .wrapper {
  padding-left: 2em;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .to-company {
  font-weight: 600;
  background-color: #fff;
  display: inline-block;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .mv-title {
  font-size: 5rem;
  line-height: 1.25;
  margin-bottom: 0.1em;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .mv-title .bg-white {
  background-color: #fff;
  display: inline-block;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .mv-title .color-yl {
  color: #dcc13f;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .button {
  margin-top: 1em;
}
.foreigntalent_recruit .main-visual-foreigntalent .text-box .button a {
  max-width: 400px;
}
.foreigntalent_recruit .main-visual-foreigntalent .flex-box .pict-box {
  display: block;
}
@media screen and (max-width:1279px) {
  .foreigntalent_recruit .main-visual-foreigntalent {
    padding: 3em 0;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .text-box .mv-title {
    font-size: 4vw;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .flex-box .text-box {
  }
}
@media screen and (min-width:1024px) {
  .foreigntalent_recruit .main-visual-foreigntalent {
    margin-top: 5.5em;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .flex-box .text-box {
    width: 55%;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .flex-box .pict-box {
    display: none;
  }
}
@media screen and (max-width:1023px) {
  .foreigntalent_recruit .main-visual-foreigntalent {
    padding: 5em 0 3em;
    background: none;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .wrapper {
    padding-left: 0;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .text-box {
    text-align: center;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .text-box .mv-title {
    font-size: 6vw;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .text-box .to-company {
    font-size: 3vw;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .text-box .button a {
    margin: 0 auto;
  }
  .foreigntalent_recruit .main-visual-foreigntalent .flex-box .pict-box {
    width: 100%;
  }
}

/*.feature*/
.foreigntalent_recruit .feature {
  padding: 0 5em;
  margin-bottom: 5em;
  position: relative;
  background: url(img/common/bg-yellow-rightup.png) no-repeat bottom;
}
.foreigntalent_recruit .feature .point-list {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3em;
  margin-top: 4em;
}
.foreigntalent_recruit .feature .title-en {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  text-align: center;
  z-index: -1;
}
.foreigntalent_recruit .feature .title-gold-middle {
  line-height: 1.5;
}
.foreigntalent_recruit .feature .point-list dl {
  padding: 3em 2em;
  text-align: left;
}
.foreigntalent_recruit .feature .point-list dl dd {
  font-size: initial;
}
.foreigntalent_recruit .feature .point-list dl dd h3 {
  margin-bottom: 0.5em;
  font-size: 3rem;
  text-align: center;
}
.foreigntalent_recruit .feature .point-list dl dd figure {
  max-width: 120px;
  margin: 0 auto 0.5em;
}
@media screen and (max-width:1024px) {
  .foreigntalent_recruit .feature {
    padding: 0 3em;
  }
}
@media screen and (min-width:769px) {
  .foreigntalent_recruit .feature .point-list dl {
    width: auto;
  }
  .foreigntalent_recruit .feature .point-list dl:not(:last-child) {
    margin: 0;
  }
}
@media screen and (max-width:768px) {
  .foreigntalent_recruit .feature {
    margin-bottom: 3em;
  }
  .foreigntalent_recruit .feature .point-list {
    grid-template-columns: 1fr;
    gap: 0;
    margin-top: 3em;
  }
  .foreigntalent_recruit .feature .point-list dl {
    padding: 2em 1em;
  }
  .foreigntalent_recruit .feature .point-list dl dd h3 {
    font-size: 4vw;
  }
}

/*----------------------------
.news-content
----------------------------*/
.news-content {
  width: 96%;
  margin: 0 auto;
  background-color: #f8f8f8;
  border-radius: 50px;
  padding: 5em;
  margin-bottom: 5em;
}
.news-content .wrapper-common02 {
  padding: 0;
}
.news-content .main-area {
  background-color: #fff;
  border-radius: 50px;
  padding: 5em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
}
.news-content article .date {
  font-size: 1.8rem;
  color: #999;
}
.news-content .article-ttl {
  font-size: 3rem;
  border-bottom: 1px solid #b5b5b5;
  margin-bottom: 1em;
  padding-bottom: 0.5em;
  line-height: 1.5;
}
.news-content .button a {
  margin: 2em auto 0;
}
@media screen and (max-width:1279px) {
  .news-content {
    padding: 3em;
  }
  .news-content .main-area {
    padding: 3em;
  }
}
@media screen and (max-width:768px) {
  .news-content {
    margin-bottom: 3em;
    padding: 2em;
  }
  .news-content .main-area {
    padding: 2em;
  }
  .news-content article .date {
    font-size: 1.6rem;
  }
  .news-content .article-ttl {
    font-size: 2rem;
  }
}

/*----------------------------
.voice-company
----------------------------*/
.voice-company {
  background: #FAE684;
  background: linear-gradient(90deg, rgba(250, 230, 132, 1) 0%, rgba(198, 171, 40, 1) 100%);
  padding: 5em 0;
  border-top-left-radius: 50px;
  border-top-right-radius: 50px;
  position: relative;
  margin-bottom: 10em;  
}
.voice-company .title-en {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  color: rgb(255 255 255 / 40%);
  text-align: center;
}
.voice-company .slick-slider-voice .sl-voice {
  background-color: #fff;
  padding: 3em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
  border-radius: 50px;
  margin: 0 3em;
}
.voice-company .slick-slider-voice .com-info {
  color: #999;
  font-size: 1.8rem;
}
.voice-company .slick-slider-voice h3 {
  font-size: 2.4rem;
  border-bottom: 1px solid #b5b5b5;
  padding-bottom: 0.5em;
  margin-bottom: 0.5em;
}
.voice-company .slick-slider-voice .voice-occupation {
  font-size: 1.8rem;
  margin-bottom: 1em;
}
.voice-company .slick-slider-voice .voice-occupation .vc-title {
  text-align: center;
  border-radius: 20px;
  color: #dcc13f;
  border: 1px solid #dcc13f;
  margin-right: 0.5em;
  padding: 0 0.7em;
}
.voice-company .slick-slider-voice .slick-dots {
  bottom: -40px;
}
.voice-company .slick-slider-voice .slick-dots li button:before {
  font-size: 14px;
}
.voice-company .slick-slider-voice .slick-prev {
  left: 90px;
  z-index: 1;
}
.voice-company .slick-slider-voice .slick-next {
  right: 130px;
}
.voice-company .slick-slider-voice .slick-prev::before,
.voice-company .slick-slider-voice .slick-next::before {
  font-size: 6rem;
  opacity: 1;
  color: #111;
}

/*----------------------------
.voice-seekers
----------------------------*/
.voice-seekers {
  background: url(img/common/bg-yellow-rightup.png) center no-repeat;
  background-size: cover;
  padding: 5em 0 0;
  position: relative;
  margin-bottom: 10em;  
}
.voice-seekers .title-en {
  position: absolute;
  top: 0.5em;
  left: 0;
  right: 0;
  width: 100%;
  text-align: center;
  z-index: -1;
}
.voice-seekers .slick-slider-voice-seekers .slick-list{
  padding-bottom: 1em !important;
}
.voice-seekers .slick-slider-voice-seekers .sl-voice {
  background-color: #fff;
  padding: 3em;
  box-shadow: 5px 5px 10px rgba(44, 44, 44, 0.1);
  border-radius: 50px;
  margin: 0 1em;
}
.voice-seekers .slick-slider-voice-seekers .com-info {
  color: #999;
  font-size: 1.8rem;
}
.voice-seekers .slick-slider-voice-seekers .thumbnail {
  margin-bottom: 1em;
}
.voice-seekers .slick-slider-voice-seekers .thumbnail img {
  height: 330px;
  object-fit: cover;
  border-radius: 50px;
}
.voice-seekers .slick-slider-voice-seekers h3 {
  font-size: 2.4rem;
  line-height: 1.5;
}
.voice-seekers .slick-slider-voice-seekers .voice-occupation {
  font-size: 1.8rem;
  margin-bottom: 1em;
}
.voice-seekers .slick-slider-voice-seekers .voice-occupation .vc-title {
  text-align: center;
  border-radius: 20px;
  color: #dcc13f;
  border: 1px solid #dcc13f;
  margin-right: 0.5em;
  padding: 0 0.7em;
}
.voice-seekers .slick-slider-voice-seekers .slick-dots {
  bottom: -40px;
}
.voice-seekers .slick-slider-voice-seekers .slick-dots li button:before {
  font-size: 14px;
}
.voice-seekers .slick-slider-voice-seekers .slick-prev {
  left: 20px;
  z-index: 1;
}
.voice-seekers .slick-slider-voice-seekers .slick-next {
  right: 60px;
}
.voice-seekers .slick-slider-voice-seekers .slick-prev::before,
.voice-seekers .slick-slider-voice-seekers .slick-next::before {
  font-size: 6rem;
  opacity: 1;
  color: #111;
}
.voice-seekers .slick-dotted.slick-slider {
  margin-bottom: 3em;
}
.voice-seekers .button a {
  margin: 0 auto;
}
@media screen and (max-width:1279px) {
  .voice-seekers {
    margin-bottom: 7em;
  }
  .voice-seekers .slick-slider-voice-seekers .sl-voice {
    padding: 2em;
  }
  .voice-seekers .slick-slider-voice-seekers .thumbnail img {
    height: 250px;
  }
  .voice-seekers .slick-slider-voice-seekers h3 {
    font-size: 2vw;
  }
  .voice-seekers .slick-slider-voice-seekers .seeker-info {
    font-size: 1.5vw;
  }
}
@media screen and (max-width:1023px) {
  .voice-seekers {
    margin-bottom: 5em;
  }
  .voice-seekers .slick-slider-voice-seekers .thumbnail img {
    height: 200px;
  }
  .voice-seekers .slick-dotted.slick-slider {
    margin-bottom: 4em;
  }
}
@media screen and (max-width:768px) {
  .voice-seekers {
    margin-bottom: 3em;
  }
  .voice-seekers .slick-slider-voice-seekers .sl-voice {
    padding: 1.5em;
  }
  .voice-seekers .slick-slider-voice-seekers .thumbnail img {
    height: 310px;
  }
  .voice-seekers .slick-slider-voice-seekers h3 {
    font-size: 3vw;
  }
  .voice-seekers .slick-slider-voice-seekers .seeker-info {
    font-size: 2vw;
  }
  .voice-seekers .slick-dotted.slick-slider {
    margin-bottom: 5em;
  }
}
@media screen and (max-width:568px) {
  .voice-seekers .slick-slider-voice-seekers .thumbnail img {
    height: 200px;
  }
}
@media screen and (max-width:480px) {
  .voice-seekers .slick-slider-voice-seekers h3 {
    font-size: 3.5vw;
  }
  .voice-seekers .slick-slider-voice-seekers .seeker-info {
    font-size: 2.5vw;
  }
}

/*----------------------------
.voice-list-archive
----------------------------*/
.voice-list-archive {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2em;
}
.voice-list-archive li {
  background-color: #fff;
  border-radius: 50px;
  box-shadow: 0 0 5px #ccc;
}
.voice-list-archive li a {
  display: block;
  padding: 2em;
}
.voice-list-archive li .thumbnail {
  margin-bottom: 1em;
}
.voice-list-archive li .thumbnail img {
  border-radius: 50px;
}
.voice-list-archive li p {
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1.5;
}
@media screen and (max-width:1279px) {
  .voice-list-archive li p {
    font-size: 2vw;
  }
  .voice-list-archive .seeker-info {
    font-size: 1.5vw;
  }
}
@media screen and (max-width:768px) {
  .voice-list-archive {
    grid-template-columns: 1fr;
  }
  .voice-list-archive li p {
    font-size: 3vw;
  }
  .voice-list-archive .seeker-info {
    font-size: 2vw;
  }
}
@media screen and (max-width:480px) {
  .voice-list-archive li a {
    padding: 1.5em;
  }
  .voice-list-archive li p {
    font-size: 3.5vw;
  }
  .voice-list-archive .seeker-info {
    font-size: 2.5vw;
  }
}

/*----------------------------
.seeker-info
----------------------------*/
.seeker-info {
  color: #999;
  margin-bottom: 0.5em;
}
.seeker-info .seeker-occupation {
  display: inline-block;
  margin-left: 0.5em;
}
.seeker-info .seeker-occupation .so-title {
  color: #dcc13f;
  border: 1px solid #dcc13f;
  text-align: center;
  padding: 0 0.5em;
  margin-right: 0.2em;
  border-radius: 50px;
}
.seeker-info .seeker-occupation .so-txt {
  color: #111;
}
/*----------------------------
.voice-list-single
----------------------------*/
.voice-list-single .voice-title {
  font-size: 3.6rem;
  margin-bottom: 1em;
  line-height: 1.5;
}
.voice-list-single .thumbnail,
.voice-list-single .wp-block-image {
  margin-bottom: 2em;
}
.voice-list-single .thumbnail img {
  border-radius: 50px;
}
.voice-list-single h2.wp-block-heading {
  font-size: 3rem;
  border-bottom: 1px solid #b5b5b5;
  padding-bottom: 0.2em;
  margin-bottom: 1em;
  line-height: 1.5;
}
.voice-list-single h2.wp-block-heading:before {
  content: "Q. ";
  font-family: Helvetica, sans-serif;
  color: #dcc13f;
}
.voice-list-single p:not(:last-child) {
  margin-bottom: 2em;
}
.voice-list-single p {
  padding-left: 2.5em;
  position: relative;
}
.voice-list-single h2.wp-block-heading + p::before {
  content: "A.";
  font-family: Helvetica, sans-serif;
  font-weight: 600;
  font-size: 3rem;
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1.5;
}
.voice-list-single .adviser-comment {
  border-radius: 50px;
  padding: 5em;
  background-color: #f8f8f8;
}
.voice-list-single .adviser-comment figure {
  margin-bottom: 2em;
}
.voice-list-single .adviser-comment .text-block {
  background-color: #fff;
  border-radius: 50px;
  padding: 2em;
}
.voice-list-single .adviser-comment .text-block h2 {
  font-size: 3rem;
  border-bottom: 1px solid #b5b5b5;
  padding-bottom: 0.2em;
  margin-bottom: 1em;
  line-height: 1.5;
}
.voice-list-single .adviser-comment .text-block p {
  padding-left: 0;
}
@media screen and (max-width:768px) {
  .voice-list-single .voice-title {
    font-size: 2.4rem;
  }
  .voice-list-single h2.wp-block-heading,
  .voice-list-single .adviser-comment .text-block h2,
  .voice-list-single h2.wp-block-heading + p::before {
    font-size: 2rem;
  }
  .voice-list-single p {
    padding-left: 2em;
  }
  .voice-list-single .adviser-comment {
    padding: 3em;
  }
}
@media screen and (max-width:568px) {
  .voice-list-single .adviser-comment {
    padding: 2em;
  }
  .voice-list-single .adviser-comment figure {
    margin-bottom: 1em;
  }
  .voice-list-single .adviser-comment .text-block {
    padding: 2em 1em;
  }
  .voice-list-single .adviser-comment .text-block h2 {
    font-size: 1.8rem;
  }
}

/*----------------------------
privacy-policy
----------------------------*/
.privacy-policy .sec p:not(:last-child){
  margin-bottom: 2em;
}

/*----------------------------
error404
----------------------------*/
.error404 .sec .button a {
  margin: 0 auto;
}