@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

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

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

main {
  display: block;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
}

a {
  color: inherit;
  text-decoration: none;
}

img {
  width: 100%;
  height: auto;
  vertical-align: middle;
}

address {
  font-style: normal;
}

sup {
  font-size: smaller;
  vertical-align: super;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

body {
  color: #292929;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
}

.l-container {
  max-width: 1032px;
  padding-left: 16px;
  padding-right: 16px;
  margin-inline: auto;
}

.l-header {
  position: sticky;
  left: 0;
  top: 0;
  z-index: 100;
  background-color: #fff;
}

.p-header {
  display: flex;
  align-items: center;
  padding: 10px 25px 10px 16px;
}
@media screen and (min-width: 768px) {
  .p-header {
    align-items: initial;
    padding: 22px 16px 17px;
  }
}

.p-header__logo img {
  max-width: 208px;
}

.p-header__nav {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  width: 80vw;
  max-width: 360px;
  padding: 72px 20px 24px;
  background: #fff;
  transform: translateX(100%);
  transition: transform 0.25s ease;
  overflow: auto;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .p-header__nav {
    position: relative;
    top: auto;
    right: auto;
    left: auto;
    width: auto;
    max-width: 100%;
    padding: 0;
    margin-left: auto;
    overflow: visible;
    transform: translateX(0%);
  }
}

.p-header__nav-list {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 768px) {
  .p-header__nav-list {
    flex-direction: row;
  }
}

.p-header__nav-item {
  position: relative;
  border-top: 1px solid #d8d8d8;
}
@media screen and (min-width: 768px) {
  .p-header__nav-item {
    border-top: none;
    border-left: 1px solid #d8d8d8;
  }
}

.p-header__nav-item + .p-header__nav-item {
  margin-top: 12px;
}
@media screen and (min-width: 768px) {
  .p-header__nav-item + .p-header__nav-item {
    margin-top: 0;
  }
}

.p-header__nav-link {
  display: flex;
  align-items: center;
  width: 100%;
  height: 100%;
  padding: 20px 12px 10px;
  color: #005583;
  font-size: 18px;
  font-weight: 400;
  text-align: center;
  line-height: 120%;
}
@media screen and (min-width: 768px) {
  .p-header__nav-link {
    justify-content: center;
    width: 168px;
    padding-top: 0;
    padding-bottom: 0;
    font-size: 16px;
  }
}

.p-header__nav-link--primary_money {
  justify-content: center;
  margin-top: 10px;
  padding: 11px 16px;
  background-color: #9d9e4b;
  color: #ffffff;
  text-align: center;
  font-family: "Zen Old Mincho";
  font-size: 15px;
  font-weight: 700;
  line-height: 110%;
}

.p-header__nav-link--primary {
  justify-content: center;
  margin-top: 10px;
  padding: 11px 16px;
  background-color: #006aa3;
  color: #ffffff;
  text-align: center;
  font-family: "Zen Old Mincho";
  font-size: 15px;
  font-weight: 700;
  line-height: 110%;
}

@media screen and (min-width: 768px) {
  .p-header__nav-link--primary_money {
    width: 208px;
    margin-top: 0;
    margin-left: 32px;
  }	
	
  .p-header__nav-link--primary {
    width: 208px;
    margin-top: 0;
    margin-left: 32px;
  }
}

.p-header__nav-icon {
  width: 10px;
  margin-left: auto;
  transform: rotate(0deg);
  transition: transform 0.2s ease;
}
@media screen and (min-width: 768px) {
  .p-header__nav-icon {
    margin-left: 9px;
  }
}

@media screen and (min-width: 768px) {
  .p-header__subnav {
    display: none;
  }
}

.p-header__subnav[hidden] {
  display: none;
  height: 0;
}

@media screen and (min-width: 768px) {
  .p-header__nav-item:hover > .p-header__subnav {
    position: absolute;
    top: 100%;
    right: 0;
    display: block;
  }
}

.p-header__subnav-link {
  display: block;
  padding: 8px 16px;
  background-color: #005583;
  color: #fff;
  font-size: 14px;
  font-weight: 400;
  line-height: 120%;
}

/* ハンバーガー */
.p-header__toggle {
  position: relative;
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-left: auto;
  border: 0;
  background: transparent;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .p-header__toggle {
    display: none;
  }
}

.p-header__toggle-bar {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 2px;
  background: #315868;
  transform: translateY(-50%);
}

.p-header__toggle-bar:first-child {
  transform: translateY(-10px);
}

.p-header__toggle-bar:last-child {
  transform: translateY(8px);
}

/* オーバーレイ（SPメニュー開時） */
.p-header__overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.35);
  z-index: 9;
}
.p-header__overlay[hidden] {
  display: none;
}

/*--------------------------------
フラグが付いたときの制御 
---------------------------------*/
/* 開状態（bodyにフラグ） */
body.is-menu-open .p-header__nav {
  transform: translateX(0);
}

body.is-menu-open .p-header__overlay {
  display: block !important;
}

/* 開いた親のアイコンを回転 */
.p-header__nav-link[aria-expanded=true] .p-header__nav-icon {
  transform: rotate(180deg);
}

/* スクロール固定（メニュー開時） */
body.is-menu-open {
  overflow: hidden;
}

* {
  box-sizing: border-box;
}

.p-footer {
  padding-top: 54px;
  padding-bottom: 24px;
  background-color: rgba(170, 206, 222, 0.6);
}
@media screen and (min-width: 768px) {
  .p-footer {
    padding-top: 72px;
  }
}

.p-footer__contents {
  display: flex;
  flex-direction: column-reverse;
}
@media screen and (min-width: 768px) {
  .p-footer__contents {
    flex-direction: row;
    margin-left: 16px;
  }
}

.p-footer__container:nth-child(1) {
  margin-top: 80px;
}
@media screen and (min-width: 768px) {
  .p-footer__container:nth-child(1) {
    margin-top: 0;
  }
}
@media screen and (min-width: 768px) {
  .p-footer__container:nth-child(2) {
    margin-left: auto;
  }
}

.p-footer__company-logo {
  max-width: 210px;
}

.p-footer__address {
  margin-top: 24px;
  color: #2c4855;
  font-family: "Zen Old Mincho";
  font-size: 14px;
  font-weight: 400;
  line-height: 180%;
}
@media screen and (min-width: 768px) {
  .p-footer__address {
    margin-top: 40px;
    font-size: 16px;
  }
}

.p-footer__school-logo {
  max-width: 264px;
}

.p-footer__link-box {
  display: flex;
  flex-direction: column;
  flex-wrap: wrap;
  gap: 12px;
  width: 100%;
  max-width: 437px;
  margin-top: 40px;
}
@media screen and (min-width: 768px) {
  .p-footer__link-box {
    flex-direction: row;
    gap: 24px 16px;
  }
}

.p-footer__link {
  width: 100%;
  padding-top: 12px;
  padding-bottom: 12px;
  border: 1px solid #9d9e4b;
  background-color: #fcfbf1;
  color: #883;
  font-family: "Zen Old Mincho";
  text-align: center;
  font-size: 24px;
  font-weight: 600;
  line-height: 160%;
}
@media screen and (min-width: 768px) {
  .p-footer__link {
    width: calc(50% - 8px);
  }
}


.p-footer__link--color-secondary {
  border-color: #4f7687;
  background-color: #f2fcff;
  color: #4f7687;
}

.p-footer__entry-link {
  width: 100%;
  margin-top: 20px;
  padding-top: 16px;
  padding-bottom: 16px;
  background-color: #006aa3;
  color: #fff;
  text-align: center;
  font-family: "Zen Old Mincho";
  font-size: 28px;
  font-weight: 600;
  line-height: 160%;
}

.p-footer__entry-link_money {
  width: 100%;
  margin-top: 20px;
  padding-top: 16px;
  padding-bottom: 16px;
  background-color: #9d9e4b;
  color: #fff;
  text-align: center;
  font-family: "Zen Old Mincho";
  font-size: 28px;
  font-weight: 600;
  line-height: 160%;
}
@media screen and (min-width: 768px) {
  .p-footer__entry-link {
    margin-top: 0;
  }
}

.p-footer__copyright {
  display: block;
  width: calc(100% - 48px);
  margin-top: 56px;
  margin-inline: auto;
  padding-top: 18px;
  border-top: 1px solid #fff;
  color: #4f7687;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 160%;
}
/*--------------------------------------------------------------
# 共通コンポーネント
--------------------------------------------------------------*/
.sp-only {
  display: block;
}
@media screen and (min-width: 768px) {
  .sp-only {
    display: none;
  }
}

.p-voice {
  /*padding-top: 64px;*/
  padding-bottom: 64px;
  background-color: #65AAD8;
}
@media screen and (min-width: 768px) {
  .p-voice {
    /*padding-top: 120px;*/
    /*padding-bottom: 120px;*/
  }
}
.page-secondary .p-voice {
  background-color: #c7c35c;
}
.page-tertiary .p-voice {
  background-color: #7597a2;
}
.p-voice .splide {
  position: relative;
  margin-top: 60px;
  padding-top: 32px;
  padding-left: 16px;
  padding-right: 16px;
  padding-bottom: 30px;
  background-color: #fff;
  box-shadow: 0 12px 28px 0 rgba(67, 65, 18, 0.1);
}
@media screen and (min-width: 768px) {
  .p-voice .splide {
    margin-top: 80px;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: 40px;
  }
}
.p-voice .splide__arrows {
  position: absolute;
  top: 25%;
  left: 50%;
  display: flex;
  justify-content: space-between;
  width: 98%;
  z-index: 1;
  transform: translateX(-50%);
  pointer-events: none;
}
@media screen and (min-width: 768px) {
  .p-voice .splide__arrows {
    top: auto;
    bottom: 33.5%;
    width: 95%;
  }
}
.p-voice .splide__arrow {
  border: none;
  background-color: transparent;
  cursor: pointer;
  pointer-events: all;
}
.p-voice .splide__arrow::before {
  content: "";
  display: block;
  width: 48px;
  height: 48px;
  margin: auto;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url("../img/_common/voice/icon_arrow2.png");
}
.p-voice .splide__arrow--next::before {
  transform: rotate(180deg);
}

.p-voice__text {
  max-width: 700px;
  margin-top: 48px;
  margin-inline: auto;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
}
.page-tertiary .p-voice__text {
  color: #fff;
}
.p-voice__text--white {
  color: #fff;
}
.p-voice__text p + p {
  margin-top: 16px;
}

.p-voice__list {
  display: flex;
}
@media screen and (min-width: 768px) {
  .p-voice__list {
    gap: 32px;
  }
}

.p-voice__item {
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-voice__item {
    max-width: 348px;
  }
}

.p-voice__pic {
  position: relative;
}
.p-voice__pic::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url("../img/_common/voice/icon_arrow.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 64px;
  pointer-events: none;
}

.p-voice__author {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  padding: 18px 6px 6px;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  line-height: 160%;
  text-align: right;
}
.p-voice__author::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  display: block;
  width: 100%;
  height: 100%;
  clip-path: polygon(100% 100%, 0% 100%, 0% 51.19%, 100% 0%);
  background-color: #c7c35c;
  mix-blend-mode: multiply;
}
.page-secondary .p-voice__author::after {
  background-color: #883;
}
.page-tertiary .p-voice__author::after {
  background-color: #315868;
}

.p-voice__name {
  position: relative;
  z-index: 1;
}

.p-voice__title {
  margin-top: 24px;
  padding-left: 8px;
  padding-right: 8px;
  color: #003D5E;
  font-size: 18px;
  font-weight: 600;
  line-height: 160%;
}
.page-secondary .p-voice__title {
  color: #58561f;
}
.page-tertiary .p-voice__title {
  color: #1d353f;
}

.p-voice__list-text {
  margin-top: 16px;
  padding-left: 8px;
  padding-right: 8px;
  color: #292929;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
}
.p-voice__list-text p + p {
  margin-top: 8px;
}

/* modal */
.p-modal {
  position: fixed;
  left: 0;
  top: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100vw;
  height: 100vh;
  padding-left: 20px;
  padding-right: 20px;
  background: rgba(65, 65, 65, 0.8);
  z-index: 9999;
}

.p-modal__content {
  position: relative;
  width: 100%;
  max-width: 800px;
}

.p-modal__close {
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  padding: 0;
  margin: 0;
  margin-left: auto;
}
.p-modal__close::before, .p-modal__close::after {
  content: "";
  position: absolute;
  width: 80%;
  height: 1px;
  background-color: #fff;
}
.p-modal__close::before {
  rotate: 30deg;
}
.p-modal__close::after {
  rotate: -30deg;
}

.p-modal__iframe {
  width: 100%;
  aspect-ratio: 16/9;
}
.p-modal__iframe iframe {
  width: 100%;
  height: 100%;
}

.js-youtube-open {
  cursor: pointer;
}

#js-youtube-modal {
  display: none;
}

#js-youtube-modal.is-open {
  display: flex;
}

@media (max-width: 767px) {
  .c-modal__close {
    width: 40px;
    height: 40px;
  }
}
/*--------------------------------------------------------------
# トップページ
--------------------------------------------------------------*/
.p-top__header {
  text-align: center;
  color: #003D5E;
  line-height: 1.4;
  margin-bottom: 3rem;
}
@media screen and (min-width: 768px) {
  .p-top__header {
    margin-bottom: 4rem;
  }
}
.p-top__subheading {
  font-family: "EB Garamond", serif;
  font-weight: 400;
  font-size: 20px;
  display: block;
  margin-bottom: 1.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top__subheading {
    font-size: 2rem;
  }
}
.p-top__subheading::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  background-color: #94C7EA;
  border-radius: 100%;
  position: absolute;
  top: calc(50% - 4px);
  margin-left: calc((8px + 1rem) * -1);
}
.p-top__heading {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 32px;
}
@media screen and (min-width: 768px) {
  .p-top__heading {
    font-size: 3rem;
  }
}
.p-top__heading::before, .p-top__heading::after {
  content: "";
  display: block;
  width: 204px;
  height: 1px;
  background: linear-gradient(90deg, rgba(0, 106, 163, 0.2) 0%, #006AA3 49.52%, rgba(0, 106, 163, 0.2) 100%);
  margin: 0.75rem auto;
}
@media screen and (min-width: 768px) {
  .p-top__heading::before, .p-top__heading::after {
    margin: 1rem auto;
  }
}
@media screen and (min-width: 768px) {
  .p-top__heading--reason::before, .p-top__heading--reason::after {
    width: 580px;
  }
}
.p-top__lead {
  width: 100%;
  max-width: 700px;
  margin: 0 auto 4.5rem;
}
@media screen and (min-width: 768px) {
  .p-top__lead {
    margin: 0 auto 5rem;
  }
}
.p-top__lead > p {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  margin-bottom: 1em;
}
.p-top__lead > p:last-of-type {
  margin-bottom: 0;
}

.p-banner {
  position: fixed;
  right: 0;
  bottom: 0;
  background: #41414180;
  padding: 1rem 1.5rem;
  border-top-left-radius: 8px;
  visibility: hidden;
  opacity: 0;
  transition: opacity 0.5s ease, visibility 0.5s ease;
}
.p-banner__text {
  font-family: "Noto Sans JP";
  font-weight: 600;
  font-size: 1.125rem;
  line-height: 1.2;
  color: #fff;
  margin-bottom: 1rem;
  text-align: center;
}
.p-banner__link {
  font-family: "Zen Old Mincho";
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.6;
  color: #fff;
  display: flex;
  align-items: center;
  background-color: #006AA3;
  width: fit-content;
  padding: 0.5rem 2.5rem;
}
.p-banner__link-icon {
  width: 30px;
  height: 25px;
  margin-left: 8px;
  vertical-align: middle;
}
.p-banner.is-active {
  visibility: visible;
  opacity: 1;
}

.p-top-slide {
  position: relative;
  overflow: hidden;
}
.p-top-slide__list {
  display: flex;
}
.p-top-slide__item {
  position: relative;
  display: flex;
  width: 100%;
  border-bottom: 8px solid #005583;
  box-sizing: border-box;
  flex-shrink: 0;
}
@media screen and (min-width: 768px) {
  .p-top-slide__item {
    display: block;
  }
}
.p-top-slide__item picture {
  display: flex;
  width: 100%;
  max-height: 100vh;
}
.p-top-slide__item picture img {
  object-fit: cover;
}
.p-top-slide__image {
  display: block;
  width: 100%;
  height: auto;
}
.p-top-slide__dots {
  display: flex;
  position: absolute;
  left: 50%;
  bottom: 34px;
  transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .p-top-slide__dots {
    left: auto;
    right: 2.5rem;
    bottom: 2.5rem;
    transform: translateX(0%);
  }
}
.p-top-slide__dots-item {
  padding: 10px;
  cursor: pointer;
}
.p-top-slide__dot {
  width: 10px;
  height: 10px;
  background-color: #E6F1F8;
  border: 1px solid #94C7EA;
  border-radius: 100%;
  cursor: pointer;
}
@media screen and (min-width: 768px) {
  .p-top-slide__dot {
    width: 12px;
    height: 12px;
  }
}
.p-top-slide__dot.is-active {
  background-color: #0097F9;
  border-color: #2D89C5;
}
.p-top-slide__textbox {
  position: absolute;
  left: 20px;
  bottom: 70px;
}
@media screen and (min-width: 768px) {
  .p-top-slide__textbox {
    left: 70px;
    bottom: 80px;
  }
}
.p-top-slide__title {
  color: #FFF;
  font-family: "Zen Old Mincho";
  font-size: 28px;
  font-weight: 400;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .p-top-slide__title {
    font-size: 64px;
  }
}
.p-top-slide__text {
  display: inline-block;
  margin-top: 14px;
  padding-top: 7px;
  border-top: 2px solid #0096E7;
  color: #FFF;
  font-family: "Zen Old Mincho";
  font-size: 18px;
  font-weight: 400;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .p-top-slide__text {
    margin-top: 32px;
    padding-top: 0px;
    border-top: none;
    border-bottom: 2px solid #0096E7;
    font-size: 28px;
    text-align: center;
  }
}
.p-top-slide__nav {
  position: absolute;
  top: 40%;
  transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
  .p-top-slide__nav {
    top: 50%;
  }
}
.p-top-slide__nav::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 20px;
  margin-left: 18px;
  margin-top: 8px;
  padding: 10px;
  border: solid #fff;
  border-width: 0 4px 4px 0;
  background: none;
}
@media screen and (min-width: 768px) {
  .p-top-slide__nav::before {
    width: 30px;
    height: 30px;
  }
}
.p-top-slide__nav--prev {
  left: 15px;
  transform: rotate(135deg);
}
@media screen and (min-width: 768px) {
  .p-top-slide__nav--prev {
    left: 30px;
  }
}
.p-top-slide__nav--next {
  right: 15px;
  transform: rotate(-45deg);
}
@media screen and (min-width: 768px) {
  .p-top-slide__nav--next {
    right: 30px;
  }
}

.p-top-reason {
  padding: 4rem 0;
}
@media screen and (min-width: 768px) {
  .p-top-reason {
    padding: 7.5rem 0;
  }
}
.p-top-reason__pic {
  margin-top: 16px;
  margin-bottom: 60px;
  overflow: scroll;
}
@media screen and (min-width: 768px) {
  .p-top-reason__pic {
    margin-bottom: 4rem;
    overflow: auto;
  }
}
.p-top-reason__pic img {
  min-width: 900px;
}
@media screen and (min-width: 768px) {
  .p-top-reason__pic img {
    min-width: auto;
    overflow: auto;
  }
}
.p-top-reason__image {
  display: block;
}
@media screen and (min-width: 768px) {
  .p-top-reason__image {
    width: 100%;
  }
}
.p-top-reason__scroll {
  position: relative;
  display: flex;
  width: fit-content;
  margin-top: 58px;
  color: #58561f;
  font-family: "EB Garamond";
  font-size: 20px;
  font-weight: 400;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .p-top-reason__scroll {
    display: none;
  }
}
.p-top-reason__scroll::before {
  content: "";
  position: absolute;
  top: 12px;
  right: 0;
  display: block;
  width: 10px;
  height: 1px;
  background-color: #003D5E;
  transform: rotate(50deg);
}
.p-top-reason__scroll::after {
  content: "";
  display: block;
  width: 101px;
  height: 1px;
  margin-top: 17px;
  margin-left: 6px;
  background-color: #003D5E;
}
.p-top-reason__about {
  margin: 0 auto 80px;
}
@media screen and (min-width: 768px) {
  .p-top-reason__about {
    width: 700px;
    margin: 0 auto 3.25rem;
  }
}
.p-top-reason__about-title {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.4;
  text-align: center;
  color: #002A40;
  position: relative;
  margin-bottom: 46px;
}
@media screen and (min-width: 768px) {
  .p-top-reason__about-title {
    margin-bottom: 2.5rem;
    font-size: 2.3rem;
  }
}
.p-top-reason__about-title::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: #2D89C5;
  border-radius: 100%;
  position: absolute;
  top: 14px;
  margin-left: calc((12px + 1rem) * -1);
}
@media screen and (min-width: 768px) {
  .p-top-reason__about-title::before {
    top: calc(50% - 6px);
  }
}
.p-top-reason__about-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  margin-bottom: 1em;
}
.p-top-reason__points {
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 1.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-reason__points {
    flex-direction: row;
  }
}
.p-top-reason__point {
  border: 1px solid #006AA3;
  width: 100%;
  padding: 3.25rem 2rem 1.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-reason__point {
    width: calc((100% - 1.5rem) / 2);
  }
}
.p-top-reason__point-label {
  display: block;
  width: 128px;
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: url("../img/top/bg-label.svg") no-repeat 0 0;
  background-size: contain;
  color: #fff;
  text-align: center;
  font-family: "EB Garamond";
  font-size: 1rem;
  font-style: normal;
  font-weight: 600;
  line-height: 1.5;
  padding: 3px 0;
}
.p-top-reason__point-title {
  margin-top: 24px;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.5;
  text-align: center;
  color: #003D5E;
  display: block;
  margin-bottom: 1.5rem;
}
.p-top-reason__point-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  margin-bottom: 10px;
}
@media screen and (min-width: 768px) {
  .p-top-reason__point-text {
    margin-bottom: 0.75em;
  }
}
.p-top-reason__point-text:last-of-type {
  margin-bottom: 0;
}
.p-top-reason__point-pic {
  display: block;
  max-width: 144px;
  margin-inline: auto;
}

.p-top-courses {
  padding: 4rem 0;
  background-color: #E6F1F8;
}
@media screen and (min-width: 768px) {
  .p-top-courses {
    padding: 7.5rem 0;
  }
}
.p-top-courses__columns {
  display: flex;
  flex-direction: column;
  margin: 0 auto;
  flex-wrap: wrap;
  gap: 3.5rem;
}
@media screen and (min-width: 768px) {
  .p-top-courses__columns {
    flex-direction: row;
    gap: 2.5rem;
  }
}
.p-top-courses__column {
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-top-courses__column {
    width: calc((100% - 2.5rem) / 2);
  }
}
.p-top-courses__column-title {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.5;
  text-align: center;
  color: #003D5E;
  display: block;
  border: 1px solid #006AA3;
  border-width: 1px 0;
  padding: 0.375rem 0;
  margin-bottom: 1.5rem;
}
.p-top-courses__column-thumb {
  display: block;
  width: 100%;
  height: auto;
  margin-bottom: 1.5rem;
}
.p-top-courses__column-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  margin-bottom: 1em;
}
@media screen and (min-width: 768px) {
  .p-top-courses__column-text {
    margin-bottom: 0.6em;
  }
}
.p-top-courses__column-link {
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: center;
  display: block;
  margin-top: 1em;
  padding: 1rem 0;
}
.p-top-courses__column-link--money {
  background-color: #9D9E4B;
}
.p-top-courses__column-link--business {
  background-color: #4F7687;
}

.p-voice__result-heading {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.4;
  text-align: center;
  color: #fff;
  margin-top: 70px;
  margin-bottom: 46px;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-voice__result-heading {
    margin-top: 6rem;
    margin-bottom: 3rem;
    font-size: 2rem;
  }
}
.p-voice__result-heading::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: #fff;
  border-radius: 100%;
  position: absolute;
  top: calc(50% - 6px);
  margin-left: -22px;
}
@media screen and (min-width: 768px) {
  .p-voice__result-heading::before {
    margin-left: calc((12px + 1rem) * -1);
  }
}
.p-voice__result-texts {
  margin: 0 auto 3rem;
}
@media screen and (min-width: 768px) {
  .p-voice__result-texts {
    width: 700px;
    margin: 0 auto 5rem;
  }
}
.p-voice__result-texts > p {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #fff;
  margin-bottom: 1em;
}
.p-voice__result-texts > p:last-of-type {
  margin-bottom: 0;
}
.p-voice__result-image {
  display: block;
  margin: 0 auto;
  height: auto;
}
@media screen and (min-width: 768px) {
  .p-voice__result-image {
    max-width: 1000px;
  }
}

.p-top-coaches {
  padding: 4rem 0;
  background-color: #F6FBFF;
}
@media screen and (min-width: 768px) {
  .p-top-coaches {
    padding: 7.5rem 0;
  }
}
.p-top-coaches__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 3rem;
	margin-top: 20px;
}
.p-top-coaches__info {
  width: calc((992px - 2.5rem) / 2);
}
.p-top-coaches__info-header {
  margin-bottom: 1rem;
}
.p-top-coaches__info-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  margin-bottom: 0.5em;
}
.p-top-coaches__info-text:last-of-type {
  margin-bottom: 0;
}
.p-top-coaches__picture {
  margin-bottom: 1.5rem;
}
.p-top-coaches__name {
  font-family: "Zen Old Mincho";
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.6;
  color: #003D5E;
}
.p-top-coaches__name-ruby {
  font-size: 1rem;
}

.p-top-prices {
  padding: 4rem 0;
}
@media screen and (min-width: 768px) {
  .p-top-prices {
    padding: 7.5rem 0;
  }
}
.p-top-prices__table {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.6;
  text-align: center;
  color: #292929;
  margin-bottom: 3rem;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table {
    margin-bottom: 5rem;
  }
}
.p-top-prices__table--sp {
  display: table;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table--sp {
    display: none;
  }
}
.p-top-prices__table--pc {
  display: none;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table--pc {
    display: table;
  }
}
.p-top-prices__table-head {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.5rem;
  color: #003D5E;
}
.p-top-prices__table-header:not(:first-of-type) {
  padding: 1rem;
}
.p-top-prices__table-header:not(:first-of-type) div {
  border: 1px solid #2D89C5;
  border-width: 1px 0;
  padding: 0.375rem 0;
}
.p-top-prices__table-title {
  border: 1px solid #2D89C5;
  border-width: 1px 0;
  margin-bottom: 15px;
  padding: 0.375rem 0;
}
.p-top-prices__table-data {
  padding: 1.25rem 0;
  vertical-align: middle;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-data {
    width: 370px;
  }
}
.p-top-prices__table-data:first-of-type {
  font-weight: 400;
  font-size: 1rem;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-data:first-of-type {
    width: 260px;
  }
}
.p-top-prices__table-data:nth-of-type(2) {
  background-color: #F6FBFF;
}
.p-top-prices__table-data:first-of-type > .p-top-prices__table-data-ruby {
  font-size: 0.875rem;
}
.p-top-prices__table-data-ruby {
  font-size: 1rem;
  color: #626262;
  display: block;
  font-weight: 400;
}
.p-top-prices__table-data--total {
  font-weight: 600;
  font-size: 1.375rem;
}
.p-top-prices__table-data--total:nth-child(2), .p-top-prices__table-data--total:nth-child(3) {
  color: #003D5E;
}
.p-top-prices__table-row + .p-top-prices__table-row {
  border-top: 1px solid #E6F1F8;
}
.p-top-prices__table-row > .p-top-prices__table-data:nth-child(2) {
  background-color: #F6FBFF;
}
.p-top-prices__table-row:nth-child(2) {
  border-top: none;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-row:nth-child(2) {
    border-top: 1px solid #E6F1F8;
  }
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-row:first-of-type > td:nth-of-type(2) {
    border-top-left-radius: 24px;
    border-top-right-radius: 24px;
  }
  .p-top-prices__table-row:last-of-type > td:nth-of-type(2) {
    border-bottom-left-radius: 24px;
    border-bottom-right-radius: 24px;
  }
}
.p-top-prices__table-row:first-child td {
  padding-bottom: 0;
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  background-color: #F6FBFF;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-row:first-child td {
    padding-bottom: 0.75em;
    border-top-left-radius: 0;
    border-top-right-radius: 0;
    background-color: transparent;
  }
}
.p-top-prices__table-row:last-child td {
  border-bottom-left-radius: 24px;
  border-bottom-right-radius: 24px;
  background-color: #F6FBFF;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-row:last-child td {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    background-color: transparent;
  }
}
.p-top-prices__table-row td {
  background-color: #F6FBFF;
}
@media screen and (min-width: 768px) {
  .p-top-prices__table-row td {
    background-color: transparent;
  }
}
.p-top-prices__plan-image {
  display: block;
  margin: 0 auto;
  height: auto;
  width: 100%;
  max-width: 300px;
}
@media screen and (min-width: 768px) {
  .p-top-prices__plan-image {
    width: 288px;
  }
}
.p-top-prices__link {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 1.6;
  text-align: center;
  color: #fff;
  background-color: #006AA3;
  display: block;
  padding: 1rem 0;
  margin: 0 auto;
}
@media screen and (min-width: 768px) {
  .p-top-prices__link {
    width: 480px;
  }
}

.p-top-flow {
  padding: 4rem 0;
  background-color: #CBE6F8;
}
@media screen and (min-width: 768px) {
  .p-top-flow {
    padding: 7.5rem 0;
  }
}
.p-top-flow__steps {
  display: flex;
  flex-direction: column;
  gap: 15px;
}
@media screen and (min-width: 768px) {
  .p-top-flow__steps {
    flex-direction: row;
    gap: 0px;
  }
}
.p-top-flow__step {
  width: 100%;
  border: 1px solid #006AA3;
  background-color: #fff;
  padding: 3.25rem 1rem 1.5rem;
  position: relative;
}
@media screen and (min-width: 768px) {
  .p-top-flow__step {
    width: 25%;
  }
}
@media screen and (min-width: 768px) {
  .p-top-flow__step + .p-top-flow__step {
    border-left: none;
  }
}
.p-top-flow__step-label {
  display: block;
  width: 128px;
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: url("../img/top/bg-label.svg") no-repeat 0 0;
  background-size: contain;
  color: #fff;
  text-align: center;
  font-family: EB Garamond;
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.5;
  padding: 3px 0;
}
.p-top-flow__step-title {
  font-family: "Zen Old Mincho";
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.5;
  text-align: center;
  color: #003D5E;
  margin-bottom: 1.5rem;
  display: block;
}
@media screen and (min-width: 768px) {
  .p-top-flow__step-title {
    position: relative;
  }
}
.p-top-flow__step:not(:first-of-type) .p-top-flow__step-title::before {
  content: "";
  display: block;
  width: 13px;
  height: 26px;
  background: url("../img/top/icon-triangle.svg") no-repeat 0 0;
  background-size: contain;
  position: absolute;
  top: calc(50% - 13px);
  top: -24px;
  left: calc(50% - 6.5px);
  transform: rotate(90deg);
}
@media screen and (min-width: 768px) {
  .p-top-flow__step:not(:first-of-type) .p-top-flow__step-title::before {
    top: calc(50% - 13px);
    left: calc((1rem + 1px) * -1);
    transform: rotate(0deg);
  }
}
.p-top-flow__step-text {
  font-family: "Noto Sans JP";
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
}

.p-top-faq {
  padding: 4rem 0;
  background-color: #F8F8FB;
}
@media screen and (min-width: 768px) {
  .p-top-faq {
    padding: 7.5rem 0;
  }
}
.p-top-faq__detailsWrapper {
  max-width: 700px;
  margin: 0 auto;
}
.p-top-faq__question {
  font-family: "Zen Old Mincho";
  font-weight: 700;
  font-size: 1.25rem;
  line-height: 1.4;
  color: #003D5E;
  cursor: pointer;
  padding: 1rem 2rem;
  border: 1px solid #006AA3;
  border-width: 1px 0;
  display: flex;
  align-items: center;
  background-color: #fff;
  margin-top: -1px;
}
.p-top-faq__question-label {
  font-family: "EB Garamond";
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.4;
  vertical-align: middle;
  color: #006AA3;
  margin-right: 1.5rem;
}
.p-top-faq__answer {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
  padding: 1rem 2rem;
  border-bottom: 1px solid #006AA3;
  display: flex;
  align-items: center;
}
.p-top-faq__answer-label {
  font-family: "EB Garamond";
  font-weight: 600;
  font-size: 1.5rem;
  line-height: 1.4;
  vertical-align: middle;
  color: #292929;
  margin-right: 1.5rem;
}
.p-top-faq__detail .p-top-faq__icon {
  width: 55px;
  height: 15px;
  margin-left: auto;
  padding-left: 40px;
}
@media screen and (min-width: 768px) {
  .p-top-faq__detail .p-top-faq__icon {
    width: 15px;
    padding-left: 0;
  }
}
.p-top-faq__detail .p-top-faq__icon--close {
  display: none;
}
.p-top-faq__detail[open] .p-top-faq__icon--open {
  display: none;
}
.p-top-faq__detail[open] .p-top-faq__icon--close {
  display: block;
}

.p-top-contact {
  padding: 4rem 0;
  background-color: #E6F1F8;
}
@media screen and (min-width: 768px) {
  .p-top-contact {
    padding: 7.5rem 0;
  }
}
.p-top-contact__inner {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: center;
}
@media screen and (min-width: 768px) {
  .p-top-contact__inner {
    flex-direction: row;
  }
}
.p-top-contact__bg {
  display: block;
  max-width: 300px;
}
@media screen and (min-width: 768px) {
  .p-top-contact__bg {
    width: 398px;
    max-width: 100%;
    height: 398px;
  }
}
.p-top-contact__text {
  font-family: "Noto Sans JP";
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  margin-bottom: 1em;
  color: #292929;
}
@media screen and (min-width: 768px) {
  .p-top-contact__text-wrapper {
    width: 506px;
  }
}
.p-top-contact__link {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-size: 1.75rem;
  line-height: 1.6;
  text-align: center;
  color: #fff;
  background-color: #006AA3;
  display: block;
  width: 100%;
  padding: 1rem 0;
  margin-top: 3.5rem;
}
.p-top-contact__mail-magazine img {
  display: block;
  margin: 3.5rem auto;
}
@media screen and (min-width: 768px) {
  .p-top-contact__mail-magazine img {
    width: 800px;
    height: 240px;
    margin: 5rem auto;
  }
}
.p-top-contact__sns-heading {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-size: 2rem;
  line-height: 1.4;
  text-align: center;
  color: #002A40;
  margin-bottom: 2rem;
}
.p-top-contact__sns {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 25px;
}
@media screen and (min-width: 768px) {
  .p-top-contact__sns {
    flex-direction: row;
    gap: 0;
  }
}
.p-top-contact__sns-link {
  background-color: #fff;
  padding: 2rem 2.5rem;
  position: relative;
  box-shadow: 0 12px 28px 0 #001D5D1A;
  overflow: hidden;
}
@media screen and (min-width: 768px) {
  .p-top-contact__sns-link {
    width: 476px;
  }
}
.p-top-contact__sns-link-icon {
  width: 28px;
  height: 28px;
  position: absolute;
  bottom: 1rem;
  right: 1rem;
}
.p-top-contact__sns-logo {
  display: block;
  margin-bottom: 1.5rem;
}
.p-top-contact__sns-logo--line {
  max-width: 231px;
}
.p-top-contact__sns-logo--facebook {
  width: 400px;
}
@media screen and (min-width: 768px) {
  .p-top-contact__sns-logo--facebook {
    width: 420px;
  }
}
.p-top-contact__sns-text {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  font-size: 1rem;
  line-height: 1.6;
  color: #292929;
}

/*--------------------------------------------------------------
# ページ共通パーツ
--------------------------------------------------------------*/
.c-page-heading {
  color: #58561f;
  font-family: "Zen Old Mincho";
  font-size: 32px;
  font-weight: 600;
  text-align: center;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .c-page-heading {
    font-size: 48px;
  }
}
.page-tertiary .c-page-heading {
  color: #1d353f;
}
.c-page-heading::before, .c-page-heading::after {
  content: "";
  display: block;
  width: 176px;
  height: 1px;
  margin-inline: auto;
  background: linear-gradient(to left, rgba(157, 158, 75, 0.2), #9d9e4b, rgba(157, 158, 75, 0.2));
}
.page-tertiary .c-page-heading::before, .page-tertiary .c-page-heading::after {
  background: linear-gradient(to left, rgba(79, 118, 135, 0.2), #4f7687, rgba(79, 118, 135, 0.2));
}
.c-page-heading::before {
  margin-bottom: 14px;
}
.c-page-heading::after {
  margin-top: 18px;
}
.c-page-en + .c-page-heading {
  margin-top: 24px;
}

.c-page-heading--white {
  color: #fff;
}
.page-tertiary .c-page-heading--white {
  color: #fff;
}
.c-page-heading--white::before, .c-page-heading--white::after {
  background: linear-gradient(to left, rgba(255, 255, 255, 0.2), #fff, rgba(255, 255, 255, 0.2));
}
.page-tertiary .c-page-heading--white::before, .page-tertiary .c-page-heading--white::after {
  background: linear-gradient(to left, rgba(255, 255, 255, 0.2), #fff, rgba(255, 255, 255, 0.2));
}

.c-page-en {
  color: #58561f;
  font-family: "EB Garamond";
  font-size: 20px;
  font-weight: 400;
  text-align: center;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .c-page-en {
    font-size: 32px;
  }
}
.page-tertiary .c-page-en {
  color: #1d353f;
}
.page-tertiary .c-page-en::before {
  background-color: #7597a2;
}
.c-page-en::before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  margin-bottom: 4px;
  margin-right: 16px;
  border-radius: 50%;
  background-color: #dad27d;
}
@media screen and (min-width: 768px) {
  .c-page-en::before {
    margin-bottom: 6px;
  }
}

.c-page-en--thin::before {
  background-color: #f3f1db;
}

.c-page-en--white {
  color: #fff;

}
.page-tertiary .c-page-en--white {
  color: #fff;
}
.c-page-en--white::before {
  background-color: #fff;
}
.page-tertiary .c-page-en--white::before {
  background-color: #fff;
}

.c-page-title {
  display: flex;
  align-items: center;
  justify-self: center;
  color: #434112;
  font-family: "Zen Old Mincho";
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  line-height: 130%;
}
@media screen and (min-width: 768px) {
  .c-page-title {
    font-size: 32px;
    line-height: 140%;
  }
}
.page-tertiary .c-page-title {
  color: #172a32;
}
.c-page-title::before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  margin-right: 16px;
  border-radius: 50%;
  background-color: #9d9e4b;
}
.page-tertiary .c-page-title::before {
  background-color: #4f7687;
}

.c-page-title__center {
  display: inline-block;
  text-align: center;
}

/* p-page-kv */
.p-page-kv {
  border-bottom: 8px solid #716f2f;
}
.page-tertiary .p-page-kv {
  border-color: #2c4855;
}
.p-page-kv img {
  max-height: 424px;
  object-fit: cover;
}

/* p-image-text */
.p-image-text {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
@media screen and (min-width: 768px) {
  .p-image-text {
    gap: 42px;
  }
}

.p-image-text__container {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
@media screen and (min-width: 768px) {
  .p-image-text__container {
    flex-direction: row;
    gap: 80px;
    padding-left: 8px;
    padding-top: 8px;
  }
}

.p-image-text__pic {
  position: relative;
  max-width: 450px;
  flex-shrink: 0;
}
.p-image-text__pic::before {
  content: "";
  position: absolute;
  top: -8px;
  left: -8px;
  display: block;
  width: 100%;
  height: 100%;
  border: 1px solid #883;
}
.page-tertiary .p-image-text__pic::before {
  border-color: #315868;
}

.p-image-text__title {
  color: #58561f;
  font-family: "Zen Old Mincho";
  font-size: 24px;
  font-weight: 600;
  text-align: center;
  line-height: 150%;
}
@media screen and (min-width: 768px) {
  .p-image-text__title {
    font-size: 32px;
    text-align: left;
  }
}
.page-tertiary .p-image-text__title {
  color: #1d353f;
}

.p-image-text__text {
  margin-top: 20px;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
}
@media screen and (min-width: 768px) {
  .p-image-text__text {
    margin-top: 24px;
  }
}
.p-image-text__text p + p {
  margin-top: 8px;
}

/* p-entry */
.p-entry {
  padding-top: 80px;
  padding-bottom: 80px;
}

.p-entry__button-box {
  display: flex;
  flex-direction: column;
  gap: 40px;
  max-width: 480px;
  margin-inline: auto;
}

.p-entry__button {
  padding: 12px 8px;
  border: 1px solid #9d9e4b;
  color: #883;
  font-family: "Zen Old Mincho";
  font-size: 24px;
  font-weight: 600;
  line-height: 160%;
  text-align: center;
}
.page-tertiary .p-entry__button {
  color: #315868;
  border-color: #315868;
}

.p-entry__button--fill {
  padding: 16px 8px;
  color: #fff;
  background-color: #883;
  font-size: 28px;
}
.page-tertiary .p-entry__button--fill {
  color: #fff;
  background-color: #315868;
}

/*--------------------------------------------------------------
# course.html
--------------------------------------------------------------*/
.p-course-about {
  padding: 64px 0 64px;
  background-color: #f3f1db;
}
@media screen and (min-width: 768px) {
  .p-course-about {
    padding: 120px 0 120px;
  }
}
.page-tertiary .p-course-about {
  background-color: #d5ebf5;
}

.p-course-about__text {
  max-width: 700px;
  margin-top: 46px;
  margin-inline: auto;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
}

.p-course-about__text p + p {
  margin-top: 16px;
}

.p-course-about__title {
  margin-top: 72px;
}
@media screen and (min-width: 768px) {
  .p-course-about__title {
    margin-top: 96px;
  }
}

.p-course-about__column {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 32px;
  max-width: 400px;
  margin-top: 46px;
  margin-inline: auto;
}
@media screen and (min-width: 768px) {
  .p-course-about__column {
    flex-direction: row;
    max-width: 100%;
    margin-top: 50px;
  }
}

.p-course-about__column-pic {
  max-width: 216px;
}
@media screen and (min-width: 768px) {
  .p-course-about__column-pic {
    /*max-width: 344px;*/
  }
}
.p-course-about__column-pic img {
  border-radius: 50%;
}
.p-course-about__column-pic figcaption {
  margin-top: 8px;
  color: #58561f;
  text-align: center;
  font-size: 18px;
  font-weight: 600;
  line-height: 160%;
}
@media screen and (min-width: 768px) {
  .p-course-about__column-pic figcaption {
    margin-top: 16px;
  }
}
.page-tertiary .p-course-about__column-pic figcaption {
  color: #1d353f;
}
.p-course-about__column-pic:nth-child(1) figcaption {
  margin-left: 20px;
  text-align: left;
}
@media screen and (min-width: 768px) {
  .p-course-about__column-pic:nth-child(1) figcaption {
    margin-left: 0;
    text-align: center;
  }
}
.p-course-about__column-pic:nth-child(2) {
  margin-top: -72px;
  /*margin-left: auto;*/
}


@media screen and (max-width: 480px) {
.p-course-about__column-pic:nth-child(2) {
  margin-top: -72px;
  margin-left: auto;
}
}

@media screen and (min-width: 768px) {
  .p-course-about__column-pic:nth-child(2) {
    margin-top: 0;
  }
}
.p-course-about__column-pic:nth-child(2) figcaption {
  margin-right: 30px;
  text-align: right;
}
@media screen and (min-width: 768px) {
  .p-course-about__column-pic:nth-child(2) figcaption {
    margin-right: 0px;
    text-align: center;
  }
}
.p-course-about__column-pic:nth-child(3) {
  margin-top: -72px;
}
@media screen and (min-width: 768px) {
  .p-course-about__column-pic:nth-child(3) {
    margin-top: 0;
  }
}

.p-course-about__image-text {
  margin-top: 58px;
}
@media screen and (min-width: 768px) {
  .p-course-about__image-text {
    margin-top: 80px;
  }
}

.p-load {
  /*padding-top: 64px;*/
  padding-bottom: 64px;
}
@media screen and (min-width: 768px) {
  .p-load {
    /*padding-top: 120px;*/
    padding-bottom: 120px;
  }
}

.p-load__text {
  max-width: 700px;
  margin-top: 48px;
  margin-inline: auto;
  font-size: 16px;
  font-weight: 400;
  line-height: 160%;
}
.p-load__text p + p {
  margin-top: 16px;
}

.p-load__subtitle {
  max-width: 763px;
  margin-inline: auto;
  margin-top: 16px;
  padding-top: 5px;
  padding-bottom: 5px;
  border-top: 1px solid #883;
  border-bottom: 1px solid #883;
  color: #58561f;
  font-family: "Zen Old Mincho";
  font-size: 24px;
  font-weight: 600;
  text-align: center;
  line-height: 160%;
}
@media screen and (min-width: 768px) {
  .p-load__subtitle {
    margin-top: 80px;
  }
}
.page-tertiary .p-load__subtitle {
  color: #003d5e;
  border-color: #006aa3;
}

.p-load__pic {
　margin: 16px auto;
  max-width: 763px;
  margin-inline: auto;
  /*margin-top: 16px;*/
  overflow: scroll;
}
@media screen and (min-width: 768px) {
  .p-load__pic {
    min-width: auto;
    overflow: auto;
  }
}
.p-load__pic img {
  min-width: 800px;
}
@media screen and (min-width: 768px) {
  .p-load__pic img {
    min-width: auto;
  }
}

.p-load__scroll {
  position: relative;
  display: flex;
  width: fit-content;
  margin-top: 58px;
  color: #58561f;
  font-family: "EB Garamond";
  font-size: 20px;
  font-weight: 400;
  line-height: 140%;
}
@media screen and (min-width: 768px) {
  .p-load__scroll {
    display: none;
  }
}
.page-tertiary .p-load__scroll {
  color: #1d353f;
}
.p-load__scroll::before {
  content: "";
  position: absolute;
  top: 12px;
  right: 0;
  display: block;
  width: 10px;
  height: 1px;
  background-color: #883;
  transform: rotate(50deg);
}
.page-tertiary .p-load__scroll::before {
  background-color: #1d353f;
}
.p-load__scroll::after {
  content: "";
  display: block;
  width: 101px;
  height: 1px;
  margin-top: 17px;
  margin-left: 6px;
  background-color: #883;
}
.page-tertiary .p-load__scroll::after {
  background-color: #1d353f;
}

/* common */
/* top */
/* page */

/* 20250922追加 */

/* ヘッダー全体を横並びに */
.p-header {
  display: flex;
  align-items: center;      /* 縦位置を中央揃え */
  justify-content: space-between; /* 左：ロゴ、右：メニュー */
}

/* ロゴはそのまま左 */
.p-header__heading {
  margin: 0; /* 念のため余白をリセット */
}

/* ナビゲーションを右寄せ */
.p-header__nav {
  margin-left: auto; /* ロゴとの間を自動で押し広げて右に寄せる */
}

/* ナビゲーションリストを横並び（必要なら） */
.p-header__nav-list {
  display: flex;
  gap: 2rem; /* メニュー間の余白は調整してください */
  margin: 0;
  padding: 0;
  list-style: none;
}



/* 20250925追加 */
.mb30{
	margin-bottom: 30px;
}
.mb40{
	margin-bottom: 40px;
}

.mb50{
	margin-bottom: 50px;
}


.mt30{
	margin-top: 30px;
}
.mt40{
	margin-top: 40px;
}

.mt50{
	margin-top: 50px;
}

		/*h3 {
			  /*線の種類（実線） 太さ 色*/
			  /*border-bottom: solid 3px black;
			  font-size: 1.5em;
			  font-weight: bold;
			}*/

			.frm4 label{
			 display: inline-block;
			 width: 140px;
			 padding: 10px;
			}

			.frm4 #name4{
			 width: 300px;
			 padding: 10px;
			}
			.frm4 #email4{
			 width: 300px;
			 padding: 10px;
			}
			.frm4 input[type=button]{
			 margin: 20px 0 0 0;
			 font-size: 18px;
			 padding: 5px;
			}

			.frm4_message{
			 color: #ff0000;
			 font-weight: bold;

			}
			.frm4 .error-message{
			 color: #ff0000;
			 padding: 0 0 0 10px;
			}

			.cp_iptxt {
			 position: relative;
			 width: 80%;
			 margin: 40px 5%;
			}
			.cp_iptxt input[type='text'] {
			 font: 15px/24px sans-serif;
			 box-sizing: border-box;
			 width: 70%;
			 padding: 0.3em;
			 transition: 0.3s;
			 letter-spacing: 1px;
			 color: #aaaaaa;
			 border: 1px solid #ffffff;
			 box-shadow: 1px 1px 2px 0 #707070 inset;
			 border-radius: 4px;
			}
			.ef input[type='text']:focus {
			 outline: none;
			 box-shadow: inset 1px 1px 2px 0 #c9c9c9;
			}


				.cta_mail{
					font-size:1.8em;
					background: #FFFFFF;
					margin-top: 30px;
				}

				.cta_mail label{
					font-weight: bold;
				}

				.cta_mail input{
					font-size: 0.7em;
					padding: 8px;
					width: 100%;
				}

			@media screen and (max-width:767px){
				.cta_mail input{
					font-size: 0.7em;
					padding: 8px;
					width: 100%;
				}
				}


			.btn,
			a.btn,
			button.btn {
			  width: 800px;
			  font-size: 0.8rem;
			  border-radius: 0.5rem;
			}

			.btn {
				cursor: pointer;
				text-align: center;
				transition: border .5s;
				width: 100%;
				border: 0;
				white-space: normal;
				display: table-cell;
				vertical-align: middle;
				padding: 0;
				line-height: 120%;
			}

			a.btn-c {
			  font-size: 1.2rem;

			  position: relative;

			  padding: 1.5rem 2rem 1.5rem 2rem;

			  -webkit-transition: all 0.3s;

			  transition: all 0.3s;
			  text-align: center;
			  color: #fff;
			  /* border-radius: 100vh; */
			  background-image: -webkit-linear-gradient(left, #4169e1 0%, #4169e1 100%);
			  background-image: linear-gradient(to right, #4169e1 0%, #4169e1 100%);
			  -webkit-box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			}

			a.btn-c:before {
			  font-family: "Font Awesome 5 Free";
			  font-size: 1.6rem;
			  line-height: 1;

			  position: absolute;
			  top: calc(50% - 0.8rem);
			  right: 1rem;

			  margin: 0;
			  padding: 0;

			  /* content: ">"; */

			}

			a.btn-c:hover {
			  -webkit-transform: scale(1.1);
			  transform: scale(1.1);

			  color: #fff;
			}

			a.btn-b {
			  font-size: 2rem;
			  font-weight: bold;
			  position: relative;

			  padding: 1.5rem 2rem 1.5rem 2rem;

			  -webkit-transition: all 0.3s;

			  transition: all 0.3s;
			  text-align: center;
			  color: #fff;
			  /* border-radius: 100vh; */
			  background-image: -webkit-linear-gradient(left, #dc143c 0%, #dc143c 100%);
			  background-image: linear-gradient(to right, #cc3755 0%, #cc3755 100%);
			  -webkit-box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			}


			@media screen and (max-width:767px){
			a.btn-b {
			  font-size: 1.2rem;

			  position: relative;

			  padding: 1.5rem 2rem 1.5rem 2rem;

			  -webkit-transition: all 0.3s;

			  transition: all 0.3s;
			  text-align: center;
			  color: #fff;
			  /* border-radius: 100vh; */
			  background-image: -webkit-linear-gradient(left, #dc143c 0%, #dc143c 100%);
			  background-image: linear-gradient(to right, #dc143c 0%, #dc143c 100%);
			  -webkit-box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			  box-shadow: 0 5px 5px rgba(0, 0, 0, 0.2);
			}

			}

			a.btn-b:before {
			  font-family: "Font Awesome 5 Free";
			  font-size: 1.6rem;
			  line-height: 1;

			  position: absolute;
			  top: calc(50% - 0.8rem);
			  right: 1rem;

			  margin: 0;
			  padding: 0;

			  /* content: ">"; */

			}

			a.btn-b:hover {
			  -webkit-transform: scale(1.1);
			  transform: scale(1.1);

			  color: #fff;
			}

			.merumaga-wrap{
				width: 95%;
				max-width: 800px;
				margin: 50px auto;
			}

			html {
			  scroll-behavior: smooth;
			}


			/* 20251006追加 */

			.youtube-modal {
			  position: fixed;
			  inset: 0;
			  z-index: 9999;
			  justify-content: center;
			  align-items: center;
			}

			.youtube-modal__overlay {
			  position: absolute;
			  inset: 0;
			  background: rgba(0, 0, 0, 0.6);
			}

			.youtube-modal__content {
			  position: relative;
			  z-index: 10;
			  width: 90%;
			  max-width: 800px;
			  aspect-ratio: 16 / 9;
			  background: #000;
			}

			#youtube-iframe {
			  width: 100%;
			  height: 100%;
			}

			.youtube-modal__close {
			  position: absolute;
			  top: -40px;
			  right: 0;
			  color: #fff;
			  background: none;
			  border: none;
			  font-size: 32px;
			  cursor: pointer;
			}

/* 1枚ぶんを表示する枠 */
#js-top-slide-viewport{
  position: relative;
  overflow: hidden;      /* ← はみ出しを見せない */
}

/* スライド列 */
#js-top-slide{
  display: flex;         /* 横並び */
  margin: 0;
  padding: 0;
  gap: 0;                /* ← 余白を出さない */
  will-change: transform;
}

/* 各スライド（li/div どちらでもOK） */
#js-top-slide > *{
  flex: 0 0 100%;        /* ← 1枚＝常に100%幅 */
  max-width: 100%;
  box-sizing: border-box;/* padding を入れても総幅100%を維持 */
  margin: 0;             /* 念のため */
  padding: 0;            /* 念のため */
}

/* 画像の行間余白を消す */
#js-top-slide img{
  display: block;        /* ← inline の行間余白を防ぐ */
  width: 100%;
  height: auto;
}


			/* 20251007追加 */
			@media screen and (max-width:480px){
			.br_sp{
				display:block;
			}
			}

			@media screen and (min-width:481px){
			.br_sp{
				display:none;
			}
			}


			/* ==========

             マネークラス

             ==========*/
			.money_font_red{
				color: #E71317;
			}


			.money_movie_contents li{
				list-style-type:disc;	
			}
