@charset "UTF-8";

@import "settings.css";

/*============================================================================================
			General
=============================================================================================*/
/*    Fonts
=====================================================*/
.g_serif {
  font-family: "GenEiKoburiMin-R", serif; /* 第2フォントに日本語フォントを指定 */
}

/*    Hamburger Menu
=====================================================*/
/*-- Initial --*/
.g_hamb {
  display: none;
}
@media (max-width: 896px) {
  .g_hamb {
    display: flex;
    flex-wrap: wrap;
    align-items: center !important;
    justify-content: center !important;
  }
  .g_hamb_inr {
    position: relative;
    width: 18px;
    height: 15px;
  }
  .g_hamb_inr div {
    position: absolute;
    display: block;
    width: inherit;
    height: 1px;
    top: 0;
    bottom: 0;
    margin: auto;
    background-color: var(--color-main);
    transition: top 0.2s, bottom 0.2s, -webkit-transform 0.2s;
    transition: transform 0.2s, top 0.2s, bottom 0.2s;
    transition: transform 0.2s, top 0.2s, bottom 0.2s, -webkit-transform 0.2s;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  .g_hamb .g_hamb_inr_top {
    bottom: auto;
  }
  .g_hamb .g_hamb_inr_btm {
    top: auto;
  }

  /*-- Opened --*/
  .g_hamb.js_open .g_hamb_inr_mdl {
    opacity: 0;
  }
  .g_hamb.js_open .g_hamb_inr_top {
    bottom: 0;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  .g_hamb.js_open .g_hamb_inr_btm {
    top: 0;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
}

/*    Slider
=====================================================*/
/*-- Default Custom --*/
.g_slider.slick-slider {
  width: 100%;
  height: auto;
  min-height: auto;
  margin: auto;
  padding-bottom: 30px; /* dots用 */
}
.g_slider.slick-slider .slick-list,
.g_slider.slick-slider .slick-track {
  height: inherit;
}
.g_slider.slick-dotted.slick-slider {
  margin-bottom: 0;
}
.g_slider .slick-dots {
  height: auto;
  bottom: 0;
  right: 0;
  left: 0;
  padding-top: 0;
  text-align: center;
}
.g_slider .slick-dots li {
  width: 10px;
  height: 10px;
  margin: 0 3px;
  overflow: visible;
}
.g_slider .slick-dots li button {
  overflow: visible;
}
.g_slider .slick-dots li button::before {
  background-color: var(--color-border);
  border-radius: 50%;
}
.g_slider .slick-dots li.slick-active button::before {
  background-color: var(--color-main);
}

.g_slider .slick-prev,
.g_slider .slick-next {
  width: 40px;
  height: 40px;
  top: 0;
}
.g_slider .slick-prev:before {
  background-image: url(../img/slider/ic_prev1.png);
}
.g_slider .slick-next:before {
  background-image: url(../img/slider/ic_next1.png);
}

.g_slider .slick-prev {
  left: 0;
}
.g_slider .slick-next {
  right: 0;
}
[dir="rtl"] .g_slider .slick-prev {
  right: 0;
}
[dir="rtl"] .g_slider .slick-next {
  left: 0;
}

/*-- Original --*/
.g_slider_itm.slick-slide {
  position: relative;
  width: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
}
.g_slider_itm.slick-slide img {
  width: 100%;
}
.g_slider_itm[data-slick-index="-2"] {
}
.g_slider_itm[data-slick-index="-1"] {
}
.g_slider_itm[data-slick-index="0"] {
}
.g_slider_itm[data-slick-index="1"] {
}
.g_slider_itm[data-slick-index="2"] {
}
.g_slider_itm[data-slick-index="3"] {
}
.g_slider_itm[data-slick-index="4"] {
}
@media (max-width: 896px) {
}
@media (max-width: 576px) {
}

/*    Section
=====================================================*/
.g_sec {
  padding-top: 80px;
}
.g_sec__last {
  padding-top: 80px;
  padding-bottom: 120px;
}
.g_sec__bg {
  margin-top: 80px;
  padding-top: 80px;
  padding-bottom: 80px;
  background-color: var(--color-sub);
}
@media (max-width: 896px) {
  .g_sec {
    padding-top: 60px;
  }
  .g_sec__last {
    padding-top: 60px;
    padding-bottom: 100px;
  }
  .g_sec__bg {
    margin-top: 60px;
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
@media (max-width: 576px) {
  .g_sec {
    padding-top: 16vw;
  }
  .g_sec__last {
    padding-top: 16vw;
    padding-bottom: 26vw;
  }
  .g_sec__bg {
    margin-top: 16vw;
    padding-top: 16vw;
    padding-bottom: 16vw;
  }
}

/*    Heading
=====================================================*/
.g_pgHd {
  padding: 100px 5vw;
}
.g_pgHd_inr {
  max-width: 1525px;
}
@media (max-width: 896px) {
  .g_pgHd {
    padding: 60px 5vw 0;
  }
}
@media (max-width: 576px) {
  .g_pgHd {
    padding: 8vw 5vw 0;
  }
}

/*    Color Text
=====================================================*/
.g_c_wh {
  color: var(--color-reverse);
}
.g_c_red {
  color: #f00;
}

/*    Button - basic -
=====================================================*/
.g_btn {
  position: relative;
  display: block;
  width: 100%;
  max-width: 340px;
  color: var(--color-reverse);
  background-color: var(--color-text);
  border-radius: 4px;
  transition: color 0.2s, background 0.2s;
}
.g_btn > * {
  width: 100%;
  height: 80px;
  padding: 0 40px 0 26px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: start;
  font-size: 1.6rem;
}
.g_btn::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.3);
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  transition: all 0.2s cubic-bezier(0.19, 1, 0.22, 1);
}
.g_btn.u_ic::after {
  width: 9px;
  height: 9px;
  top: 0;
  bottom: 0;
  right: 20px;
  border-top: 1px solid var(--color-reverse);
  border-right: 1px solid var(--color-reverse);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media (any-hover: hover) {
  .g_btn:hover::before {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    transition: all 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  }
}
@media (max-width: 576px) {
  .g_btn {
    max-width: 100%;
  }
  .g_btn > * {
    max-height: 70px;
    height: 18.6vw;
    padding: 0 10.6vw 0 6.6vw;
    font-size: 1.4rem;
  }
  .g_btn.u_ic::after {
    width: 2.6vw;
    height: 2.6vw;
    right: 5.3vw;
  }
}

/*大きめボタン*/
.g_btn__lg {
  max-width: 450px;
}

/*戻るボタン*/
.g_btn.g_btn_back::after {
  right: auto;
  left: 20px;
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
}

/*外部リンク付きボタン*/
.g_btn .g_tab {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 20px;
  margin: auto;
  padding-right: 0;
}
.g_btn .g_tab::before {
  background-image: url(../img/common/ico_tab_wh.svg);
}
@media (any-hover: hover) {
  .g_btn:hover .g_tab::before {
    background-image: url(../img/common/ico_tab.svg);
  }
}

@media (max-width: 896px) {
  .g_btn .g_tab {
    right: 2.2vw;
  }
}
@media (max-width: 576px) {
  .g_btn .g_tab {
    right: 5.3vw;
  }
}

/*    link - Text -
=====================================================*/
/* underline */
.g_link {
  color: var(--color-text);
  text-decoration: underline;
  background: linear-gradient(to bottom, rgba(237, 178, 20, 0) 50%, rgba(237, 178, 20, 1) 50%);
  background-position: 0 0;
  background-size: auto 200%;
  transition: all 0.2s ease-out;
}

@media (any-hover: hover) {
  .g_link:hover {
    background-position: 0 60%;
    text-decoration: none;
  }
}

/* hover transparent */
.g_link_transp {
  transition: opacity var(--transition);
}
@media (any-hover: hover) {
  .g_link_transp:hover {
    opacity: var(--opacity);
  }
}

/* 外部リンクアイコン */
.g_tab {
  position: relative;
}
.g_tab::after {
  content: "";
  position: relative;
  display: inline-block;
  width: 1em;
  height: 1em;
  top: 0.1em;
  margin-left: 0.3em;
  background-size: 100% auto;
  background-repeat: no-repeat;
  background-position: left bottom;
  background-image: url(../img/ico_outside.svg);
}

/*    Decoration
=====================================================*/
.g_underline {
  text-decoration: underline;
}


/* 枠線 */
.g_bd {
  border: 1px solid var(--color-border);
}
.g_bd__p {
  padding: 25px;
  border: 1px solid var(--color-border);
}
@media (max-width: 576px) {
  .g_bd__p {
    padding: 5.3vw;
  }
}

/* 見出し装飾 - 下線 */
.g_decoHd_bb {
  position: relative;
}
.g_decoHd_bb::after {
  content: "";
  display: block;
  width: 60px;
  height: 1px;
  margin-top: 20px;
  background: linear-gradient(to right, rgba(223, 95, 78, 1) 0, rgba(223, 95, 78, 1) 4px, rgba(223, 95, 78, 0) 4px);
  background-repeat: repeat-x;
  background-position: left top;
  background-size: 7px 1px;
}

/* 見出し装飾 - 左線 */
.g_decoHd_bl {
  position: relative;
  width: 360px;
  padding-right: 60px;
  letter-spacing: 0.1em;
  line-height: 1.6;
}
.g_decoHd_bl::before {
  content: "";
  display: block;
  position: absolute;
  top: 30px;
  right: -180px;
  width: 180px;
  height: 1px;
  background: linear-gradient(to right, rgb(239, 0, 18) 0, rgb(239, 0, 18) 2px, var(--color-reverse) 2px, var(--color-reverse) 5px, rgb(239, 0, 18) 5px, rgb(239, 0, 18) 8px, var(--color-reverse) 8px, var(--color-reverse) 11px, rgb(239, 0, 18) 11px, rgb(239, 0, 18) 16px, var(--color-reverse) 16px, var(--color-reverse) 19px, rgb(239, 0, 18) 19px, rgb(239, 0, 18) 100%);
  z-index: 1;
}
.g_decoHd_bl__cont {
  padding-top: 110px;
}
.g_decoHd_bl__cont::after {
  content: "";
  display: block;
  position: absolute;
  top: 30px;
  right: 0;
  left: 0;
  height: 1px;
  background: linear-gradient(to right, var(--color-text) 0, var(--color-text) 2px, var(--color-reverse) 2px, var(--color-reverse) 5px, var(--color-text) 5px, var(--color-text) 8px, var(--color-reverse) 8px, var(--color-reverse) 11px, var(--color-text) 11px, var(--color-text) 16px, var(--color-reverse) 16px, var(--color-reverse) 19px, var(--color-text) 19px, var(--color-text) 100%);
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
  z-index: 0;
}
.g_decoHd_bl__cont p {
  letter-spacing: 0.18em;
  line-height: 1.9;
}

@media (max-width: 896px) {
  .g_decoHd_bl {
    width: 100%;
    padding-top: 50px;
    padding-right: 0;
  }
  .g_decoHd_bl::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 180px;
    height: 1px;
    background: linear-gradient(to right, rgb(239, 0, 18) 0, rgb(239, 0, 18) 2px, var(--color-reverse) 2px, var(--color-reverse) 5px, rgb(239, 0, 18) 5px, rgb(239, 0, 18) 8px, var(--color-reverse) 8px, var(--color-reverse) 11px, rgb(239, 0, 18) 11px, rgb(239, 0, 18) 16px, var(--color-reverse) 16px, var(--color-reverse) 19px, rgb(239, 0, 18) 19px, rgb(239, 0, 18) 100%);
    z-index: 1;
  }
  .g_decoHd_bl::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    height: 1px;
    background: linear-gradient(to right, var(--color-text) 0, var(--color-text) 2px, var(--color-reverse) 2px, var(--color-reverse) 5px, var(--color-text) 5px, var(--color-text) 8px, var(--color-reverse) 8px, var(--color-reverse) 11px, var(--color-text) 11px, var(--color-text) 16px, var(--color-reverse) 16px, var(--color-reverse) 19px, var(--color-text) 19px, var(--color-text) 100%);
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
    z-index: 0;
  }
  .g_decoHd_bl__cont {
    padding-top: 40px;
  }
  .g_decoHd_bl__cont::after {
    display: none;
  }
}
@media (max-width: 576px) {
  .g_decoHd_bl {
    padding-top: 13.3vw;
  }
  .g_decoHd_bl__cont {
    padding-top: 5.3vw;
  }
}

/*    List number
=====================================================*/
.g_incr {
  counter-reset: item;
  padding-left: 2em;
}
.g_incr_itm {
  font-size: inherit;
  list-style-type: none;
  position: relative;
}
.g_incr_itm::before {
  font-size: inherit;
  line-height: inherit;
  content: counter(item);
  counter-increment: item;
  top: 0;
  left: -2em;
  width: 2em;
  position: absolute;
  display: inline-block;
  margin: auto;
}

/*    Pagetop
=====================================================*/
/*    追従
--------------------------- */
.g_pagetop_fixed {
  position: fixed;
  width: 40px;
  height: 40px;
  bottom: 40px;
  right: 30px;
  transition: opacity 0.2s, visibility 0s, ease 0.2s;
  opacity: 0;
  visibility: hidden;
  z-index: 200;
}
.g_pagetop_fixed img {
  width: 100%;
  transition: opacity 0.2s;
}
.g_pagetop_fixed.js_show {
  opacity: 1;
  visibility: visible;
}
.g_pagetop_fixed.js_stc {
  position: absolute;
  top: -25px;
}
@media (any-hover: hover) {
  .g_pagetop_fixed:hover img {
    opacity: 0.5;
  }
}

/*    フッター固定
--------------------------- */
.g_pagetop {
  padding: 20px 0 10px;
  color: var(--color-main);
  font-size: 1rem;
  font-weight: 500;
  background-color: var(--color-sub);
  text-align: center;
  line-height: 1;
}
.g_pagetop a {
  padding: 10px;
  display: inline-block;
  transition: color 0.2s;
}
.g_pagetop a:before {
  top: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 5px;
  height: 5px;
  border-top: 1px solid var(--color-main);
  border-right: 1px solid var(--color-main);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  transition: linear 0.2s;
}
@media (any-hover: hover) {
  .g_pagetop a:hover {
    color: var(--color-hover);
  }
  .g_pagetop a:hover:before {
    border-top: 1px solid var(--color-hover);
    border-right: 1px solid var(--color-hover);
  }
}

/*    Breadcrumb
=====================================================*/
.g_breadcrumb_lst {
  padding: 10px 0;
}
.g_breadcrumb_lst_line {
  border-bottom: 1px solid var(--color-border);
}
.g_breadcrumb_lst_li {
  position: relative;
  font-size: 1rem;
  line-height: 1.5;
}
.g_breadcrumb_lst_li + .g_breadcrumb_lst_li {
  padding-left: 20px;
}
.g_breadcrumb_lst_li + .g_breadcrumb_lst_li::before {
  content: "";
  position: absolute;
  margin: auto;
  width: 3px;
  height: 3px;
  top: 0.6em;
  left: 0.75em;
  border-top: 1px solid var(--color-main);
  border-right: 1px solid var(--color-main);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
@media (any-hover: hover) {
  .g_breadcrumb_lst_li a:hover {
    color: var(--color-main);
  }
}

@media (max-width: 896px) {
  .g_breadcrumb_lst {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
  }
  .g_breadcrumb_lst_li {
    display: inline-block;
    white-space: nowrap;
  }
}
@media (max-width: 576px) {
}

/*    GDPR
=====================================================*/
.g_gdpr {
  width: 100%;
  background-color: rgba(255, 255, 255, 0.95);
  padding: 30px 0 30px;
  box-shadow: 0px -4px 12px rgba(0, 0, 0, 0.1);
  position: fixed;
  left: 0;
  bottom: 0;
  display: none;
  z-index: 500;
}
.g_gdpr_wrp {
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.g_gdpr_txt {
  font-size: 1.4rem;
  line-height: 1.6;
  width: 80%;
  color: var(--color-main);
}
.g_gdpr_txt a {
  font-weight: bold;
  text-decoration: underline;
}
.g_gdpr_btn {
  font-size: 1.4rem;
  font-weight: 500;
  width: 255px;
  height: 50px;
  color: var(--color-reverse);
  border: 2px solid var(--color-main);
  background-color: var(--color-main);
  display: flex;
  justify-content: center;
  align-items: center;
  transition: background 0.3s;
  cursor: pointer;
  border-radius: 5px;
}
@media (any-hover: hover) {
  .g_gdpr_txt a:hover {
    color: var(--color-text);
    text-decoration: none;
    transition: color 0.3s;
  }
  .g_gdpr_btn:hover {
    color: var(--color-main);
    background-color: var(--color-reverse);
  }
}

@media (max-width: 1024px) {
  .g_gdpr {
    padding-left: 0;
  }
  .g_gdpr_wrp {
    width: 80%;
  }
}
@media (max-width: 896px) {
  .g_gdpr_wrp {
    display: block;
  }
  .g_gdpr_txt {
    width: 100%;
  }
  .g_gdpr_btn {
    width: 130px;
    margin: 15px 0 0 auto;
  }
}
@media (max-width: 576px) {
  .g_gdpr {
    padding: 3.5vw 0;
    /* bottom: 8vh; */
  }
  .g_gdpr_wrp {
    width: 86vw;
  }
  .g_gdpr_btn {
    width: 30vw;
    height: 9vw;
    margin: 4vw 0 0 auto;
  }
}

/*    Loading
=====================================================*/
.js_loading {
  width: 100vw;
  height: 100vh;
  background-color: var(--color-reverse);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999999;
}
.js_loading.js_loading__page {
  background-color: var(--color-reverse);
}
.loader {
  border-radius: 50%;
  width: 5em;
  height: 5em;
  margin: auto;
  font-size: 10px;
  border-top: 5px solid rgba(22, 22, 22, 0.2);
  border-right: 5px solid rgba(22, 22, 22, 0.2);
  border-bottom: 5px solid rgba(22, 22, 22, 0.2);
  border-left: 5px solid var(--color-main);
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  -webkit-animation: loader 1.1s infinite linear;
  animation: loader 1.1s infinite linear;
}
@-webkit-keyframes loader {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}
@keyframes loader {
  0% {
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
    transform: rotate(360deg);
  }
}

html.js_notmove {
  overflow: hidden;
}

/*    FadeIn
=====================================================*/
.js_fadeIn {
  position: relative;
  opacity: 0;
  -webkit-transform: translate3d(0, 50px, 0);
  transform: translate3d(0, 50px, 0);
  transition: opacity 0.7s, -webkit-transform 0.7s;
  transition: transform 0.7s, opacity 0.7s;
  transition: transform 0.7s, opacity 0.7s, -webkit-transform 0.7s;
  z-index: 2;
}
.js_fadeIn.delay {
  transition: opacity 0.7s 0.2s, -webkit-transform 0.7s 0.2s;
  transition: transform 0.7s 0.2s, opacity 0.7s 0.2s;
  transition: transform 0.7s 0.2s, opacity 0.7s 0.2s, -webkit-transform 0.7s 0.2s;
}
.js_fadeIn.active {
  opacity: 1;
  -webkit-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0);
}

.js_hide {
  display: none;
}

/*    Modal
=====================================================*/
.g_modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
}
.g_modal_bg {
  background-color: rgba(0, 0, 0, 0.8);
  height: 100vh;
  position: absolute;
  width: 100%;
}
.g_modal_content {
  background-color: var(--color-reverse);
  left: 50%;
  padding: 40px;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 60%;
}

/*    Table Parts
=====================================================*/
/*    definition list
---------------------------- */
.g_dl > div {
  padding: 15px 0;
  border-bottom: 1px solid var(--color-border);
}
.g_dl > div:first-child {
  border-top: 1px solid var(--color-border);
}
.g_dl dt {
  width: 15%;
  margin-right: 5%;
}
.g_dl dd {
  width: 80%;
}

@media (max-width: 896px) {
  .g_dl dt {
    width: 100%;
    margin-right: 0;
  }
  .g_dl dd {
    width: 100%;
    margin-top: 5px;
  }
}

/*    Table
---------------------------- */
.g_table {
  width: 100%;
  border: 1px solid var(--color-border);
}
.g_table tr {
  border-bottom: 1px solid var(--color-border);
}
.g_table tr:last-child {
  border-bottom: none;
}
.g_table tr th,
.g_table tr td {
  padding: 10px;
  vertical-align: middle;
}
.g_table tr th {
  background-color: var(--color-sub);
  border-right: 1px solid var(--color-border);
}
.g_table tr td {
  border-right: 1px solid var(--color-border);
}

.g_table.g_table__common thead tr th {
  background-color: #f4b084;
}
.g_table.g_table__common tr th {
  background-color: #fff2cc;
}

.g_table.g_table__teachers thead tr th {
  background-color: #9bc2e6;
}
.g_table.g_table__teachers tr th {
  background-color: #ddebf7;
}

@media (max-width: 576px) {
  .g_table_wrap {
    overflow-x: scroll;
  }
  .g_table_wrap > .g_table {
    width: 700px;
  }
  .g_table_wrap > .g_table.g_table__common,
  .g_table_wrap > .g_table.g_table__teachers {
    width: 500px;
  }
}

/*    Tel
=====================================================*/
@media (min-width: 577px) {
  .g_tel {
    pointer-events: none;
  }
}
@media (max-width: 576px) {
  .g_tel {
    text-decoration: underline;
  }
}
