* {
  box-sizing: border-box;
  font-family: source-han-sans-japanese, sans-serif;
}

:root {
  --theme-color: #222222;
  --waseda: #8a1a21;
  --keio: #05155b;
  --aogaku: #00462d;
  --meiji: #484d9c;
  --rikkyo: #4d1f81;
  --chuo: #cf342f;
  --hosei: #293f94;
  --gakushuin: #1c4893;
}

img {
  width: 100%;
  -o-object-fit: contain;
     object-fit: contain;
}

a {
  text-decoration: none;
}

p {
  font-style: italic;
  font-size: 3.2085561497vw;
}

@media screen and (min-width: 768px) {
  p {
    font-size: 1.3786764706vw;
  }
}
ul,
ol,
li {
  list-style: none;
  padding: 0;
}

.divider {
  margin-top: 4.2780748663vw;
  margin-bottom: 4.2780748663vw;
}

@media screen and (min-width: 768px) {
  .divider {
    margin-top: 1.8382352941vw;
  }
}
@media screen and (min-width: 768px) {
  .divider {
    margin-bottom: 1.8382352941vw;
  }
}
.vertical_centerized {
  display: flex;
  align-items: center;
}

.golden_text {
  background: linear-gradient(38.92deg, #a9a977 0.17%, #8d842f 50.11%, #e1e296 100.05%);
  color: transparent;
  background-clip: text;
  -webkit-background-clip: text;
}

.white {
  background-color: #fff;
}

.black {
  background-color: #222;
}

.gray {
  background-color: #f6f6f6;
}

.gray2 {
  background-color: #eee;
}

.container {
  padding: 6.4171122995vw;
}

@media screen and (min-width: 768px) {
  .container {
    padding: 2.7573529412vw;
  }
}
.theme-color {
  background-color: #222222;
}

.text-center {
  text-align: center;
}

.arrow_container {
  width: 100%;
  height: 0;
  position: relative;
  z-index: 10;
}
.arrow_container img {
  width: 27%;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.bubble_container {
  width: 100%;
  height: 0;
  position: relative;
  z-index: 10;
}
.bubble_container img {
  width: 34.933333%;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.button {
  background-color: #9b9364;
  height: 15.2406417112vw;
  padding: 3.2085561497vw;
  border-radius: 8.0213903743vw;
}
.button.theme-color {
  background-color: #222222;
}
.button img {
  width: auto;
  display: block;
  margin: 0 auto;
  height: 8.8235294118vw;
}

@media screen and (min-width: 768px) {
  .button {
    height: 6.5487132353vw;
    padding: 1.3786764706vw;
    border-radius: 3.4466911765vw;
  }
}
@media screen and (min-width: 768px) {
  .button img {
    height: 3.7913602941vw;
  }
}
.cv_button {
  background-color: #9b9364;
  z-index: 100;
  border-radius: 5px;
  position: relative;
  color: #fff;
  text-decoration: none;
  outline: none;
  overflow: hidden;
}
.cv_button img {
  width: auto;
  margin: 15px auto;
  height: 34px;
  display: block;
}
.cv_button.desktop {
  padding: 8px;
}
.cv_button::before {
  content: "";
  position: absolute;
  top: 0;
  left: -75%;
  width: 50%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.3) 100%);
  transform: skewX(-25deg);
  animation: 2s shine;
  animation-iteration-count: infinite;
}

.lp_desktop {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  width: 57.03125vw;
}

.lp_smartphone {
  position: relative;
  width: 100%;
  padding-top: 57px;
  background-color: #fff;
  overflow: scroll;
}
.lp_smartphone section {
  position: relative;
}
.lp_smartphone section[id]::before {
  display: block;
  height: 57px;
  margin-top: -57px;
  content: "";
}
.lp_smartphone .cv_button {
  position: fixed;
  left: 24px;
  right: 24px;
  bottom: 20px;
  height: 64px;
  filter: drop-shadow(0px 0px 10px rgba(0, 0, 0, 0.2));
}
.lp_smartphone .coach {
  padding-top: 6.4171122995vw;
  padding-left: 6.4171122995vw;
  padding-right: 6.4171122995vw;
  padding-bottom: 0vw;
}
.lp_smartphone .coach.coach_with_button {
  padding-bottom: 10.6951871658vw;
}
.lp_smartphone .coach .image-holder {
  padding-left: 8.2887700535vw;
  padding-right: 8.2887700535vw;
}
.lp_smartphone #top {
  position: relative;
  z-index: 2;
}
.lp_smartphone #top .front {
  position: absolute;
  top: calc(14.46280992% + 57px);
  left: 3.73333333%;
  width: 66.13333333%;
}
.lp_smartphone #top .online {
  position: absolute;
  top: calc(2.66666667% + 57px);
  left: 60.53333333%;
  width: 21.86666667%;
}
.lp_smartphone .top_v2 {
  margin-bottom: calc(0px - 6.9518716578vw - 57px);
}
.lp_smartphone #startdash .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #campaign .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #campaign .container .caution {
  font-size: 2.4064171123vw;
}
.lp_smartphone #campaign .container .message {
  margin: 14px 0;
}
.lp_smartphone #campaign .container .message p {
  font-size: 4.8128342246vw;
  font-weight: 700;
}
.lp_smartphone .achievement_brief_wrapper {
  margin-bottom: 13.36898396vw;
}
.lp_smartphone .achievement_brief {
  margin: 6.4171122995vw;
  margin-bottom: 0;
}
.lp_smartphone .achievement_brief .achievement_brief_card {
  display: flex;
  align-items: flex-end;
  margin-bottom: 3.2085561497vw;
  gap: 2.1390374332vw;
}
.lp_smartphone .achievement_brief .achievement_brief_card img {
  width: 25%;
  border-radius: 50%;
}
.lp_smartphone .achievement_brief .achievement_brief_card .first-line,
.lp_smartphone .achievement_brief .achievement_brief_card .second-line {
  width: -moz-fit-content;
  width: fit-content;
}
.lp_smartphone .achievement_brief .achievement_brief_card .first-line {
  background-color: #d9d6c8;
  color: #222;
  font-weight: 900;
  font-size: 3.743315508vw;
  padding: 0.8021390374vw;
  margin-bottom: 0.5347593583vw;
}
.lp_smartphone .achievement_brief .achievement_brief_card .second-line {
  background-color: #222;
  color: #fff;
  font-weight: 900;
  font-size: 4.8128342246vw;
  padding: 0.8021390374vw;
}
.lp_smartphone #worries {
  position: relative;
  z-index: 1;
}
.lp_smartphone #features .container {
  background: #fff;
  padding: 24px;
}
.lp_smartphone #features .feature {
  padding: 20px 0;
}
.lp_smartphone #achievement .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #achievement .achievement_content {
  display: flex;
  overflow-x: scroll;
}
.lp_smartphone #achievement_v1 {
  padding-bottom: 1px;
}
.lp_smartphone .achievement_horizontal_scroll .review_cards {
  display: flex;
  overflow: auto;
  gap: 4.2780748663vw;
  padding-left: 4.2780748663vw;
  padding-right: 4.2780748663vw;
}
.lp_smartphone .achievement_horizontal_scroll .review_cards .review_card {
  flex-shrink: 0;
}
.lp_smartphone .ordinary_schools_v2 {
  padding: 0;
  padding-top: 11.7647058824vw;
  background-color: #222;
}
.lp_smartphone .ordinary_schools_v2 .container {
  padding-top: 0;
  margin-bottom: -10.6951871658vw;
}
.lp_smartphone .ordinary_schools_v2 h2 {
  display: block;
  width: 48.9304812834%;
  margin: 0 auto 16px;
}
.lp_smartphone .ordinary_schools_v2 h3 {
  display: block;
  margin: 0 auto;
  width: 57%;
}
.lp_smartphone .ordinary_schools_v2 p {
  margin: 12px 0;
  text-align: center;
}
.lp_smartphone .ordinary_schools_v2 .reason {
  margin: 4.2780748663vw;
  padding: 3.2085561497vw;
  background-color: #fff;
  z-index: 3;
}
.lp_smartphone .ordinary_schools_v2 .reason img {
  padding-bottom: 3.2085561497vw;
}
.lp_smartphone .ordinary_schools_v2 .arrow_container + .reason {
  margin-top: 15.2406417112vw;
}
.lp_smartphone #counseling_voices .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #counseling_voices h2 {
  text-align: center;
  margin-bottom: 16px;
}
.lp_smartphone #counseling_voices .button {
  margin-top: 6.4171122995vw;
}
.lp_smartphone #counseling_flow .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #counseling_flow .button {
  margin-top: 6.4171122995vw;
}
.lp_smartphone #method h2 {
  display: block;
  width: 66.3101604278%;
  margin: 0 auto;
  margin-top: 14.4385026738vw;
  margin-bottom: 7.486631016vw;
}
.lp_smartphone #method .container {
  padding: 6.4171122995vw;
}
.lp_smartphone #method h3 {
  color: #fff;
  margin-bottom: 12px;
  height: 14.7058823529vw;
}
.lp_smartphone #method p {
  margin-top: 12px;
  margin-bottom: 12px;
}
.lp_smartphone #voices {
  padding-bottom: 1px;
}
.lp_smartphone #counseling .container {
  padding: 4.2780748663vw 6.4171122995vw 9.6256684492vw;
}
.lp_smartphone #counseling .arrow_container > img {
  transform: translate(-50%, -30%);
}
.lp_smartphone #counseling .present {
  padding-top: 16.0427807487vw;
}
.lp_smartphone #counseling .booking {
  padding: 6.4171122995vw;
  padding-top: 8.5561497326vw;
  padding-bottom: 8.5561497326vw;
}
.lp_smartphone #counseling .booking .caution {
  padding-top: 4.0106951872vw;
}
.lp_smartphone #counseling .booking .caution p {
  font-size: 2.1390374332vw;
}
.lp_smartphone #counseling.counseling_short .container {
  padding-top: 0;
}
.lp_smartphone #counseling_bannar .container {
  padding: 6.4171122995vw 6.4171122995vw 10.6951871658vw;
}
.lp_smartphone .medium .container {
  padding: 0;
  padding-bottom: 8.5561497326vw;
}
.lp_smartphone .medium .card {
  width: 30.4812834225vw;
  height: 16.3101604278vw;
  background-color: #f6f6f6;
  flex-shrink: 0;
  /* box-shadow: 0 0 2px 0 rgba(0, 0, 0, .1) */
}
.lp_smartphone .medium .card img {
  width: 100%;
  height: 100%;
}
.lp_smartphone .medium .folder {
  display: flex;
  gap: 1.0695187166vw;
  flex-shrink: 0;
}
.lp_smartphone .medium .slide-rl .folder {
  animation: slide 10s linear infinite;
}
.lp_smartphone .medium .slide-lr .folder {
  animation: slide 10s linear reverse infinite;
}
.lp_smartphone .medium .wrapper {
  display: flex;
  gap: 1.0695187166vw;
  overflow: hidden;
}
.lp_smartphone .medium .wrapper + .wrapper {
  margin-top: 1.0695187166vw;
}
.lp_smartphone #schooling_styles {
  padding: 6.4171122995vw;
}
.lp_smartphone #schooling_styles h2 {
  width: 57.6687116564%;
  display: block;
  margin: 0 auto 16px;
}
.lp_smartphone #schooling_styles h3 {
  width: 100%;
  background-color: #222222;
  color: #fff;
  padding-left: 5%;
  font-size: 4.8128342246vw;
  height: 14.7058823529vw;
  margin-bottom: 2.1390374332vw;
  font-style: italic;
}
.lp_smartphone #schooling_styles p {
  margin: 12px 0;
}
.lp_smartphone #line_register {
  padding: 6.4171122995vw;
}
.lp_smartphone #line_register .button {
  margin-top: 6.4171122995vw;
}
.lp_smartphone #faq .container {
  padding: 6.4171122995vw;
  padding-top: 53px;
  padding-bottom: 10px;
}
.lp_smartphone #faq .container .faq-small-heading {
  font-family: futura-pt, sans-serif;
  font-size: 12px;
  color: #8a8565;
  letter-spacing: 15%;
  font-weight: 400;
  margin-bottom: 8px;
}
.lp_smartphone #faq .container h2 {
  display: block;
  text-align: center;
  margin: 0 auto 16px;
}
.lp_smartphone #faq .qanda {
  background-color: #fff;
  margin: 8px 0px;
  position: relative;
}
.lp_smartphone #faq .qanda .question_icon {
  position: absolute;
  font-family: futura-pt, sans-serif;
  font-size: 12px;
  text-align: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  font-style: normal;
  font-weight: 500;
  color: #fff;
  background-color: #8a8565;
  top: 18px;
  left: 8px;
  line-height: 20px;
}
.lp_smartphone #faq .qanda .open_button {
  position: absolute;
  top: 25px;
  right: 12px;
  width: 12px;
}
.lp_smartphone #faq .qanda .question {
  padding: 19px 39px;
  font-size: 11px;
  font-weight: bold;
  color: #222;
  border-bottom: 1px solid #f6f6f6;
}
.lp_smartphone #faq .qanda .answer {
  position: relative;
  font-size: 10px;
  padding: 10px 10px 10px 40px;
  display: none;
  line-height: 162%;
  background-color: #fff;
  margin-top: 2px;
}
.lp_smartphone #faq .qanda .answer_icon {
  position: absolute;
  font-family: futura-pt, sans-serif;
  font-size: 12px;
  text-align: center;
  font-style: normal;
  font-weight: 500;
  color: #8a8565;
  background-color: #fff;
  top: 10px;
  left: 8px;
  line-height: 20px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
}
.lp_smartphone #faq .qanda.open .answer {
  display: block;
}
.lp_smartphone #faq .qanda.open .open_button {
  transform: rotate(180deg);
}
.lp_smartphone #faq .button {
  margin-top: 6.4171122995vw;
}
.lp_smartphone .comparative_table_index .container {
  padding: 0 24px;
  padding-bottom: 6.4171122995vw;
}
.lp_smartphone .comparative_table_index .table_wrapper {
  display: flex;
  overflow-x: scroll;
}
.lp_smartphone .comparative_table_index .table_wrapper img {
  min-width: 120%;
}
.lp_smartphone .comparative_table_v1 {
  background-color: #ebeae2;
  padding-top: 16.0427807487vw;
}
.lp_smartphone .comparative_table_v1 .table_wrapper {
  display: flex;
  overflow-x: scroll;
  padding-left: 6.4171122995vw;
  padding-right: 6.4171122995vw;
}
.lp_smartphone .comparative_table_v1 .table_wrapper img {
  min-width: 125%;
}
.lp_smartphone .comparative_table_v2 {
  z-index: 9;
  margin-bottom: calc(0px - 10.9625668449vw - 57px);
}

@media screen and (min-width: 768px) {
  .lp_smartphone {
    margin-left: 57.03125vw;
    width: 42.96875vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .cv_button {
    display: none;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach {
    padding-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach {
    padding-left: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach {
    padding-right: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach {
    padding-bottom: 0vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach.coach_with_button {
    padding-bottom: 4.5955882353vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach .image-holder {
    padding-left: 3.5615808824vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .coach .image-holder {
    padding-right: 3.5615808824vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .top_v2 {
    margin-bottom: calc(0px - 2.9871323529vw - 57px);
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #startdash .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #campaign .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #campaign .container .caution {
    font-size: 1.0340073529vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #campaign .container .message p {
    font-size: 2.0680147059vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_brief_wrapper {
    margin-bottom: 5.7444853vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_brief {
    margin: 2.7573529412vw;
    margin-bottom: 0;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_brief .achievement_brief_card {
    margin-bottom: 1.3786764706vw;
    gap: 0.9191176471vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_brief .achievement_brief_card .first-line {
    font-size: 1.6084558824vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_brief .achievement_brief_card .second-line {
    font-size: 2.0680147059vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #achievement .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_horizontal_scroll .review_cards {
    gap: 1.8382352941vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_horizontal_scroll .review_cards {
    padding-left: 1.8382352941vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .achievement_horizontal_scroll .review_cards {
    padding-right: 1.8382352941vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .ordinary_schools_v2 {
    padding-top: 5.0551470588vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .ordinary_schools_v2 .container {
    margin-bottom: -4.5955882353vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .ordinary_schools_v2 .reason {
    margin: 1.8382352941vw;
    padding: 1.3786764706vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .ordinary_schools_v2 .reason img {
    padding-bottom: 1.3786764706vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .ordinary_schools_v2 .arrow_container + .reason {
    margin-top: 6.5487132353vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling_voices .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling_voices .button {
    margin-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling_flow .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling_flow .button {
    margin-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #method h2 {
    margin-top: 6.2040441176vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #method h2 {
    margin-bottom: 3.2169117647vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #method .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #method h3 {
    height: 6.3189338235vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .container {
    padding: 1.8382352941vw 2.7573529412vw 4.1360294118vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .present {
    padding-top: 6.8933823529vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .booking {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .booking {
    padding-top: 3.6764705882vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .booking {
    padding-bottom: 3.6764705882vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .booking .caution {
    padding-top: 1.7233455882vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling .booking .caution p {
    font-size: 0.9191176471vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #counseling_bannar .container {
    padding: 2.7573529412vw 2.7573529412vw 4.5955882353vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .medium .container {
    padding-bottom: 3.6764705882vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .medium .card {
    width: 13.0974264706vw;
    height: 7.0082720588vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .medium .folder {
    gap: 0.4595588235vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .medium .wrapper {
    gap: 0.4595588235vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .medium .wrapper + .wrapper {
    margin-top: 0.4595588235vw;
  }
}
@keyframes slide {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #schooling_styles {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #schooling_styles h3 {
    font-size: 2.0680147059vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #schooling_styles h3 {
    height: 6.3189338235vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #schooling_styles h3 {
    margin-bottom: 0.9191176471vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #line_register {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #line_register .button {
    margin-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #faq .container {
    padding: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone #faq .button {
    margin-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .comparative_table_index .container {
    padding-bottom: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .comparative_table_v1 {
    padding-top: 6.8933823529vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .comparative_table_v1 .table_wrapper {
    padding-left: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .comparative_table_v1 .table_wrapper {
    padding-right: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  .lp_smartphone .comparative_table_v2 {
    margin-bottom: calc(0px - 4.7104779412vw - 57px);
  }
}
.voice_cards_wrapper {
  display: flex;
  overflow-x: scroll;
}
.voice_cards_wrapper .voice_cards_container {
  display: flex;
}
.voice_cards_wrapper .voice_card {
  position: relative;
  width: 216px;
  height: 114px;
  background-color: #fff;
  border: solid transparent 2px;
}
.voice_cards_wrapper .voice_card.selected {
  border: solid #d9d6c8 2px;
}
.voice_cards_wrapper .voice_card + .voice_card {
  margin-left: 12px;
}
.voice_cards_wrapper .voice_card img {
  position: absolute;
  top: 14px;
  left: 16px;
  width: 64px;
  height: 64px;
}
.voice_cards_wrapper .voice_card .name {
  position: absolute;
  bottom: 14px;
  left: 16px;
  width: 64px;
  font-size: 10px;
  text-align: center;
}
.voice_cards_wrapper .voice_card .change {
  position: absolute;
  top: 16px;
  left: 90px;
  font-family: futura-pt, sans-serif;
  font-style: italic;
  font-size: 18px;
  font-weight: 500;
  line-height: 26px;
  width: 100px;
}
.voice_cards_wrapper .voice_card .change span {
  font-size: 26px;
  line-height: 26px;
  width: 40px;
  font-weight: 800;
  display: inline-block;
}
.voice_cards_wrapper .voice_card .change2 {
  position: absolute;
  top: 46px;
  left: 90px;
  font-size: 10px;
  font-style: italic;
  font-weight: 600;
  width: 100px;
}
.voice_cards_wrapper .voice_card .result {
  position: absolute;
  top: 68px;
  left: 90px;
  font-size: 12px;
  font-style: italic;
  font-weight: 600;
}

.review_card {
  position: relative;
  margin: 53px auto 32px;
  padding: 24px 24px 24px;
  max-width: 326px;
  background-color: #fff;
}
.review_card img {
  display: block;
  background-color: #d9d9d9;
  width: 90px;
  height: 90px;
  margin: -53px auto 0;
  border-radius: 50%;
}
.review_card .reviewer_name {
  font-size: 10px;
  height: 10px;
  margin: 8px;
  text-align: center;
}
.review_card .review_title {
  font-family: source-han-sans-japanese, sans-serif;
  font-style: normal;
  margin-top: 20px;
  margin-bottom: 8px;
  font-weight: 800;
  font-size: 18px;
  line-height: 129%;
}
.review_card .review_content {
  font-style: normal;
  margin: 8px 0 0;
  font-weight: 400;
  font-size: 12px;
  line-height: 158%;
}
.review_card .change1 {
  font-family: futura-pt, sans-serif;
  margin: 0;
  font-style: italic;
  font-weight: 400;
  font-size: 24px;
  line-height: 100%;
  text-align: center;
}
.review_card .change1 .arrow {
  font-size: 20px;
}
.review_card .change1 .after {
  font-size: 34px;
  font-weight: 900;
  width: 60px;
  height: 34px;
  display: inline-block;
}
.review_card .change2 {
  font-weight: 900;
  margin: 4px 0 16px;
  font-size: 12px;
  line-height: 100%;
  text-align: center;
}

#counseling_messages .message,
#achievement_messages .message,
#achievement_messages_2 .message {
  margin-top: 6.4171122995vw;
  padding: 6.4171122995vw;
  background-color: #eae9e5;
  display: none;
}

@media screen and (min-width: 768px) {
  #counseling_messages .message,
  #achievement_messages .message,
  #achievement_messages_2 .message {
    margin-top: 2.7573529412vw;
  }
}
@media screen and (min-width: 768px) {
  #counseling_messages .message,
  #achievement_messages .message,
  #achievement_messages_2 .message {
    padding: 2.7573529412vw;
  }
}
#counseling_messages .message.selected,
#achievement_messages .message.selected,
#achievement_messages_2 .message.selected {
  display: block;
}

.desktop {
  display: none;
}
.desktop .cover_image {
  height: 100vh;
  -o-object-fit: cover;
  object-fit: cover;
}

@media screen and (min-width: 768px) {
  .desktop {
    display: block;
  }
}
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: 57px;
  padding: 8px 16px;
  background-color: #fff;
  color: #fff;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100;
}
.header.active {
  background-color: #222222;
}
.header .header_left {
  display: flex;
  align-items: center;
  justify-content: left;
}
.header .header_left h1 {
  font-size: 16px;
  font-style: italic;
}
.header .logo {
  max-width: 133px;
}
.header .logo.hide {
  display: none;
}
.header a {
  color: #fff;
}
.header #hamburger_button {
  width: 40px;
  height: 40px;
  background: url("/lp/images/button/header-icon.png");
  background-size: contain;
  border-radius: 50%;
  padding-top: 10px;
  visibility: visible;
  cursor: pointer;
  justify-content: flex-end;
}
.header #hamburger_button.open {
  background: url("/lp/images/button/header-icon-active.png");
  background-size: contain;
}
.header #hamburger_button .hamline1 {
  width: 16px;
  height: 0px;
  border: 0.6px solid #fff;
  margin-left: 10px;
  background: #fff;
  transform-origin: left bottom;
  transition: 0.3s;
}
.header #hamburger_button .hamline2 {
  width: 16px;
  height: 0px;
  border: 0.6px solid #fff;
  margin-left: 10px;
  margin-top: 3px;
  background: #fff;
  transform-origin: left bottom;
  transition: 0.3s;
}
.header #hamburger_button .hamchar {
  margin-top: 3px;
  font-family: var(--pt);
  font-style: normal;
  font-weight: 450;
  font-size: 8px;
  line-height: 100%;
  text-align: center;
  color: #ffffff;
}
.header #hamburger_button.open .hamline1 {
  transform: rotate(45deg);
  margin-left: 12.3px;
  margin-top: 1.5px;
}
.header #hamburger_button.open .hamline2 {
  transform: rotate(-45deg);
  margin-left: 12.3px;
  margin-top: 10.5px;
}
.header #hamburger_button.open .hamchar {
  opacity: 0;
}

@media screen and (min-width: 768px) {
  .header {
    width: 42.96875vw;
  }
}
@media screen and (min-width: 1336px) {
  .header {
    width: 100vw;
    padding-left: 50px;
  }
}
#hamburger_menu {
  width: 100%;
  height: calc(100vh - 57px);
  background: #222222;
  padding-top: 0.1px;
  text-align: center;
  z-index: 20000;
  position: fixed;
  top: 57px;
  display: none;
}
#hamburger_menu .list_wrap {
  height: calc(100% - 104px);
  position: relative;
}
#hamburger_menu .list {
  position: absolute;
  margin-top: 17%;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: -moz-fit-content;
  height: fit-content;
}
#hamburger_menu ul {
  margin: 0;
}
#hamburger_menu.open {
  display: block;
}
#hamburger_menu li {
  font-size: 14px;
  margin-bottom: 16px;
}
#hamburger_menu a {
  color: #fff;
}
#hamburger_menu .menulogo {
  width: 71.53px;
}
#hamburger_menu .menubtn {
  background: #9b9364;
  border-radius: 20px;
  margin: 32px auto 0 auto;
  width: 130px;
  padding: 12px 16px 12px 16px;
  font-family: var(--hans);
  font-style: normal;
  font-weight: 900;
  font-size: 14px;
  line-height: 100%;
  color: #ffffff;
}
#hamburger_menu .menuchar {
  margin-top: 20px;
  font-family: var(--hans);
  font-style: normal;
  font-weight: 500;
  font-size: 13px;
  line-height: 100%;
  color: #ffffff;
}

@media screen and (min-width: 768px) {
  #hamburger_menu {
    width: 42.96875%;
  }
}
.footer {
  margin-top: 12px;
  background: #222;
  color: #fff;
  padding: 33px 16px 84px;
}
.footer img {
  width: 63px;
  display: block;
  margin: 0 auto;
}
.footer ul {
  list-style: none;
  text-align: center;
  padding: 0;
}
.footer li {
  font-size: 10px;
  margin-bottom: 10px;
}
.footer a {
  color: #222;
}

@keyframes shine {
  50% {
    left: 125%;
  }
  100% {
    left: 125%;
  }
}
.list-cv {
  position: absolute;
  bottom: 25%;
  max-width: 240px;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  display: flex;
  flex-direction: column;
  row-gap: 6px;
}

@media screen and (max-width: 768px) {
  .list-cv {
    bottom: 18%;
  }
}
@media screen and (max-width: 500px) {
  .list-cv {
    bottom: 15%;
  }
}
.desktop-links {
  position: absolute;
  top: 42%;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  -moz-column-gap: 6px;
       column-gap: 6px;
  min-width: 369px;
}

@media screen and (min-width: 1025px) {
  .desktop-links {
    top: 46%;
    max-width: 476px;
  }
}
.common-mgt {
  margin-top: 12px;
}

.common-mgb {
  margin-bottom: 12px;
}

.desktop-coach {
  width: 50%;
  bottom: 12%;
}

@media screen and (max-width: 900px) {
  .desktop-coach {
    width: 100%;
    bottom: 5%;
  }
}
@media screen and (min-width: 901px) {
  .desktop-coach {
    width: 100%;
    bottom: 12%;
  }
}
.table_container {
  position: relative;
}
.table_container .comparative_table_v2 {
  position: absolute;
  top: 19.7%;
  padding-left: 16px;
  overflow-x: auto;
}
.table_container .comparative_table_v2::-webkit-scrollbar {
  display: none;
}
.table_container .comparative_table_v2 .table_wrapper img {
  min-width: 190%;
}

.footer ul li a {
  color: #fff;
}

.footer-copy {
  font-size: 10px;
  text-align: center;
  margin-top: 24px;
  font-family: futura-pt, sans-serif;
  letter-spacing: 1px;
  font-weight: 400;
  transform: scale(0.8);
}

.cv-area {
  display: flex;
  justify-content: center;
  -moz-column-gap: 3px;
       column-gap: 3px;
  position: fixed;
  bottom: 12px;
  width: 100%;
  z-index: 10000;
}
.cv-area a {
  width: 100%;
  max-width: 183px;
}

@media screen and (min-width: 768px) {
  .cv-area {
    display: none;
  }
}
.surface_white {
  background-color: #fff;
}

.voiceArea {
  position: relative;
}

.voiceItems {
  overflow-x: scroll;
  position: absolute;
  top: 36.5%;
  left: 16px;
  display: flex;
  -moz-column-gap: 12px;
       column-gap: 12px;
}
.voiceItems img {
  width: 320px;
  height: 355px;
}

.voiceItems::-webkit-scrollbar {
  display: none;
}

@media screen and (min-width: 768px) {
  .voiceItems img {
    width: auto;
    height: 400px;
  }
}
@media screen and (min-width: 1600px) {
  .voiceItems img {
    width: auto;
    height: 600px;
  }
}
.scdp {
  padding: 12px 0;
}

.header-counsering {
  display: inline-block;
  max-width: 133px;
  margin-left: auto;
  margin-right: 8px;
}

@media screen and (min-width: 768px) {
  .header-counsering {
    display: none;
  }
}
.navbottom-counsering {
  position: absolute;
  bottom: 0;
}

.popup {
  z-index: 1111111;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: rgba(34, 34, 34, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  visibility: hidden;
}

.popup.open {
  visibility: visible;
}

.popupImg {
  width: 100%;
  max-width: 336px;
}

@media screen and (min-width: 768px) {
  .popup {
    display: none;
  }
}
.common-mgb8 {
  margin-bottom: 8px;
}

.desktop_online {
  position: absolute;
  top: 57px;
  width: 97px;
  right: 64px;
}

/*# sourceMappingURL=styles.css.map */