/********** common **********/
@import url('https://fonts.googleapis.com/css2?family=Yellowtail&display=swap');

section {
  margin-bottom: 160px;
}

.text-green {
  font-weight: bold;
  color: #18904D;
}

.big-text {
  line-height: 1;
  position: absolute;
  top: -80px;
  left: calc(50% - 50vw + 10vw);
}

.big-text p {
  font-family: 'Yellowtail', cursive;
  font-size: 240px;
  opacity: 0.3;
}

.main-contents {
  position: relative;
}

#content {
  overflow: initial;
}

@media screen and (max-width: 959px) {
  .big-text {
    top: -32px;
  }
  .big-text p {
    font-size: 160px;
  }
}

@media screen and (max-width: 768px) {
  section {
    margin-bottom: 80px;
  }

  .big-text {
    top: 0;
  }

  .big-text p {
    font-size: 120px;
  }
}



/********** top **********/
.top__background {
  width: 100vw;
  position: absolute;
  top: 0;
  left: calc(50% - 50vw);
}

.top__background img {
  width: 100%;
}

.top {
  position: relative;
}

.top__text-wrap {
  position: absolute;
  bottom: -40px;
  right: 0;
  z-index: 10;
}

.top__image {
  width: 80vw;
  margin-left: calc(50% - 50vw);
}

.top__image img {
  width: 100%;
}

.top__text {
  margin-bottom: 24px;
}

.top__text--spn {
  display: none;
}

.top__text p {
  display: inline;
  padding: 16px;
  font-size: 32px;
  font-weight: bold;
  color: #ffffff;
  background: linear-gradient(to right, #60C990, #CDF169);
}

.top__figure {
  width: 45vw;
  position: absolute;
  bottom: -100px;
  right: calc(50% - 48vw);
}

@media screen and (max-width: 959px) {
  .top__image {
    width: 90vw;
  }

  .top__text p {
    font-size: 24px;
  }

  .top__figure {
    width: 40vw;
  }

  .top__text p {
    background: linear-gradient(to right, rgba(96, 201, 144, 0.8), rgba(205, 241, 105, 0.8));
  }
}

@media screen and (max-width: 768px) {
  .top__image {
    width: 100vw;
  }

  .top__text-wrap {
    right: unset;
    left: 0;
    bottom: -80px;
  }

  .top__text--pc {
    display: none;
  }

  .top__text--spn {
    display: block;
  }

  .top__text {
    margin-bottom: 12px;
  }

  .top__text p {
    padding: 8px;
    font-size: 16px;
  }

  .top__figure {
    bottom: -64px;
  }
}


/********** skill up **********/
.skill-up {
  position: relative;
}

.skill-up__bg {
  width: 90%;
  margin: 0 auto;
  padding: 5%;
  background: linear-gradient(to right, rgba(16, 98, 82, 0.3), rgba(142, 195, 31, 0.3));
}

.skill-up__content {
  padding: 10%;
  background-color: #ffffff;
  box-shadow: 0px 5px 5px 0px #859389;
}

.skill-up__title {
  margin-bottom: 64px;
}

.skill-up__title h2 {
  font-size: 24px;
}

.skill-up__title-sub {
  text-align: right;
  margin-bottom: 40px;
}

.skill-up__title-sub p {
  font-size: 18px;
  font-weight: bold;
}

.skill-up__text p {
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 40px;
}

.skill-up__text img {
  margin-bottom: 24px;
}

.skill-up__text-img--spn {
  display: none;
}

.skill-up__text span {
  font-size: 18px;
}

.skill-up__big-text p {
  color: #DBEBBA;
}

.skill-up__figure {
  position: absolute;
  bottom: 0;
  left: calc(50% - 50vw);
}

@media screen and (max-width: 959px) {
  .skill-up__title h2 {
    font-size: 32px;
  }

  .skill-up__title-sub p {
    font-size: 20px;
  }

  .skill-up__text p {
    margin-bottom: 24px;
    font-size: 16px;
    line-height: 160%;
  }

  .skill-up__text span {
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .skill-up {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-bottom: 0;
  }

  .skill-up__bg {
    width: 100%;
    padding: 5% 0;
  }

  .skill-up__content {
    padding: 5%;
  }

  .skill-up__title {
    margin-bottom: 16px;
  }

  .skill-up__title h2 {
    font-size: 16px;
  }

  .skill-up__title h2 span {
    font-size: 20px;
  }

  .skill-up__title-sub {
    margin-bottom: 16px;
  }

  .skill-up__title-sub p {
    font-size: 14px;
  }

  .skill-up__text p {
    font-size: 14px;
    line-height: 160%;
  }

  .skill-up__text-img--pc {
    display: none;
  }

  .skill-up__text-img--spn {
    display: block;
  }

  .skill-up__text span {
    font-size: 18px;
  }

  .skill-up__figure {
    display: none;
  }
}


/********** goal **********/
.goal {
  position: relative;
}

.goal__bg {
  width: 90%;
  margin: 0 auto;
  padding: 5%;
  background: linear-gradient(to right, rgba(33, 141, 167, 0.3), rgba(50, 195, 31, 0.3));
}

.goal__content {
  padding: 10%;
  background-color: #ffffff;
  box-shadow: 0px 5px 5px 0px #859389;
}

.goal__title {
  margin-bottom: 64px;
}

.goal__title h2 {
  font-size: 24px;
}

.goal__text p {
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 40px;
}

.goal__text span {
  font-size: 18px;
}

.goal__big-text {
  color: #BBDBE3;
}

.goal__figure {
  position: absolute;
  bottom: 0;
  right: calc(50% - 50vw);
}

@media screen and (max-width: 959px) {
  .goal__title h2 {
    font-size: 32px;
  }

  .goal__text p {
    margin-bottom: 24px;
    font-size: 16px;
    line-height: 160%;
  }

  .goal__text span {
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .goal {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-bottom: 0;
  }

  .goal__bg {
    width: 100%;
    padding: 0 0 5%;
  }

  .goal__content {
    padding: 5%;
  }

  .goal__title {
    margin-bottom: 16px;
  }

  .goal__title h2 {
    font-size: 16px;
  }

  .goal__text p {
    font-size: 14px;
    line-height: 160%;
  }

  .goal__text span {
    font-size: 18px;
  }

  .goal__big-text {
    top: -64px;
  }

  .goal__figure {
    display: none;
  }

}


/********** why **********/
.why {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  position: relative;
}

.why__bg {
  max-width: var(--container_size);
  margin: 0 auto;
  padding-right: var(--swl-pad_container,0);
  padding-left: var(--swl-pad_container,0);
}

.why__content {
  width: 90%;
  margin: 0 auto;
  padding: 10% 5%;
  background-color: #ffffff;
  box-shadow: 0 5px 5px #D5D5D5;
}

.why__title {
  margin-bottom: 40px;
}

.why__title h2 {
  font-weight: bold;
  font-size: 24px;
}

.why__title-sub {
  margin-bottom: 80px;
  text-align: right;
}

.why__title-sub p {
  font-weight: bold;
  font-size: 18px;
}

.why__item--first,
.why__item--second {
  padding: 10%;
  background-color: #F8F8F8;
  box-shadow: 0 5px 5px #D5D5D5;
  position: relative;
}

.why__item--first {
  margin-bottom: 120px;
}

.why__item-text p {
  font-size: 16px;
  margin-bottom: 24px;
  line-height: 40px;
}

.why__item-text span {
  font-size: 18px;
}

.why__item-img {
  position: absolute;
  top: -60px;
  left: 0;
}

.why__item-img img {
  width: 50%;
}

.why__image {
  width: 125%;
  margin-left: -12.5%;
  padding: 40px 12.5%;
  background-color: rgba(103, 105, 103, 0.3);
}

.why__big-text {
  color: #818080;
  opacity: 0.25;
}

.why__background--01,
.why__background--02 {
  height: calc(100% + 160px);
  position: absolute;
  top: -80px;
}

.why__background--01 {
  right: calc(50% - 50vw);
  z-index: -1;
}

.why__background--02 {
  width: 100vw;
  left: calc(50% - 50vw);
  transform: rotateX(180deg);
  z-index: -2;
}

.why__background--01 img,
.why__background--02 img {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 959px) {
  .why__title h2 {
    font-size: 32px;
  }

  .why__title-sub p {
    font-size: 20px;
  }

  .why__item-img {
    top: -60px;
  }

  .why__item-img img {
    width: 50%;
  }

  .why__item-text p {
    font-size: 16px;
    line-height: 160%;
  }

  .why__item-text span {
    font-size: 24px;
  }
}

@media screen and (max-width: 768px) {
  .why {
    margin-bottom: 24px;
  }

  .why__bg {
    width: 100%;
    max-width: unset;
    padding-right: 0;
    padding-left: 0;
  }

  .why__content {
    width: 100%;
    padding: 5%;
  }

  .why__title {
    margin-bottom: 16px;
  }

  .why__title h2 {
    font-size: 16px;
  }

  .why__title-sub {
    margin-bottom: 16px;
  }

  .why__title-sub p {
    font-size: 14px;
  }

  .why__item--first,
  .why__item--second {
    padding: 5%;
  }

  .why__item--first {
    margin-bottom: 40px;
  }

  .why__item-text p {
    font-size: 14px;
  }

  .why__item-text span {
    font-size: 18px;
  }

  .why__item-img {
    top: -32px;
  }

  .why__item-img img {
    width: 25%;
  }

  .why__image {
    width: 113%;
    margin-left: -6.5%;
    padding: 0;
    background-color: unset;
  }

  .why__big-text {
    top: -64px;
  }

  .why__background--01,
  .why__background--02 {
    height: 100%;
    top: 0;
  }

  .why__background--01 img,
  .why__background--02 img {
    width: 100%;
    height: 100%;
  }

}


/********** value **********/
.value {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  position: relative;
}

.value__bg {
  max-width: var(--container_size);
  margin: 0 auto;
  padding-right: var(--swl-pad_container,0);
  padding-left: var(--swl-pad_container,0);
}

.value__content {
  width: 90%;
  margin: 0 auto;
  padding: 10% 5%;
  background-color: #ffffff;
  box-shadow: 0 5px 5px #d5d5d5;
}

.value__title {
  margin-bottom: 80px;
}

.value__title h2 {
  font-weight: bold;
  font-size: 24px;
}

.value__item {
  margin-bottom: 80px;
  padding: 10%;
  background-color: #F8F8F8;
  box-shadow: 0 5px 5px #d5d5d5;
  position: relative;
}

.value__item-title {
  margin-bottom: 40px;
}

.value__item-title::before {
  display: inline-block;
  width: 5px;
  height: 80px;
  margin-bottom: -80px;
  margin-left: -16px;
  background-color: #BEBEBE;
  content: '';
}

.value__item-title::after {
  display: block;
  width: 440px;
  height: 5px;
  margin-left: -40px;
  background-color: #BEBEBE;
  content: '';
}

.value__item-title h3 {
  font-size: 18px;
  color: #18904D;
  font-weight: bold;
}

.value__item-content p {
  margin-bottom: 24px;
  font-size: 16px;
  line-height: 40px;
}

.value__item-content .text-green {
  font-size: 18px;
}

.value__item-img {
  padding: 40px;
  background-color: rgba(103, 105, 103, 0.3);
  margin-bottom: 24px;
}

.value__big-text {
  color: #818080;
  opacity: 0.25;
}

.value__background {
  height: calc(100% + 240px);
  position: absolute;
  top: -80px;
  left: calc(50% - 50vw);
  z-index: -1;
  transform: rotateZ(180deg);
}

.value__background img {
  width: 100%;
  height: 100%;
}

@media screen and (max-width: 959px) {
  .value__title h2 {
    font-size: 32px;
  }

  .value__item-title h3 {
    font-size: 24px;
  }

  .value__item-content p {
    font-size: 16px;
    line-height: 160%;
  }

  .value__item-content .text-green {
    font-size: 24px;
  }
}


@media screen and (max-width: 768px) {
  .value {
    margin-bottom: 0;
  }

  .value__bg {
    max-width: unset;
    margin: 0 auto;
    padding-right: 0;
    padding-left: 0;
  }

  .value__content {
    width: 100%;
    padding: 5%;
  }

  .value__title {
    margin-bottom: 16px;
  }

  .value__title h2 {
    font-size: 16px;
  }

  .value__item {
    margin-bottom: 40px;
    padding: 5%;
  }

  .value__item-title {
    margin-bottom: 24px;
  }

  .value__item-title::before {
    width: 2px;
    height: 28px;
    margin-bottom: -40px;
    margin-left: -8px;
  }

  .value__item-title::after {
    width: 240px;
    height: 2px;
    margin-left: -16px;
  }

  .value__item-title h3 {
    font-size: 14px;
  }

  .value__item-content p {
    font-size: 14px;
  }

  .value__item-content .text-green {
    font-size: 18px;
  }

  .value__item-img {
    padding: 0;
    background-color: unset;
  }

  .value__big-text {
    margin-top: -64px;
  }

  .value__background {
    height: 100%;
  }
}


/********** history **********/
.history {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  padding: 120px 0;
  position: relative;
  background: linear-gradient(to right, rgba(50, 195, 31, 0.3), rgba(33, 141, 167, 0.3));
}

.history__bg {
  max-width: var(--container_size);
  margin: 0 auto;
  padding-right: var(--swl-pad_container,0);
  padding-left: var(--swl-pad_container,0);
}

.history__content {
  width: 90%;
  margin: 0 auto;
  padding: 10% 5%;
  background-color: #ffffff;
  box-shadow: 0 5px 5px #d5d5d5;
}

.history__title {
  margin-bottom: 80px;
}

.history__title h2 {
  font-weight: bold;
  font-size: 24px;
}

.history__item-year {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  background: linear-gradient(to right, #BDE9B8, #B7D8E0);
  border-radius: 50%;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}

.history__item-year p {
  display: inline;
  font-size: 16px;
  font-weight: bold;
}

.history__item-detail {
  display: flex;
}

.history__item-line {
  width: 80px;
  text-align: center;
}

.history__item-line div {
  width: 8px;
  height: calc(100% + 2px);
  margin: -1px auto;
  background: linear-gradient(to right, #BDE9B8, #B7D8E0);
}

.history__item-content {
  display: grid;
  display: -ms-grid;
  grid-template-columns: 80px 1fr;
  -ms-grid-columns: 80px 1fr;
  width: calc(100% - 120px);
  margin: 16px 0;
}

.history__item-content p {
  margin-bottom: 16px;
  font-size: 16px;
  font-weight: bold;
}

.history__item-content-month {
  text-align: right;
  padding-right: 16px;
}

.history__big-text {
  color: #BEEAB8;
  top: 0;
}

@media screen and (max-width: 959px) {
  .history__item-year {
    width: 80px;
    height: 80px;
  }

  .history__item-year p {
    font-size: 20px;
  }

  .history__item-line {
    width: 80px;
  }

  .history__item-line div {
    width: 8px;
  }

  .history__item-content {
    grid-template-columns: 64px 1fr;
    -ms-grid-columns: 64px 1fr;
    width: calc(100% - 80px);
  }

  .history__item-content p {
    font-size: 16px;
  }

  .history__big-text {
    top: 64px;
  }
}

@media screen and (max-width: 768px) {
  .history {
    padding: 24px 0;
    margin-bottom: 24px;
  }

  .history__bg {
    max-width: unset;
    padding-right: 0;
    padding-left: 0;
  }

  .history__content {
    width: 100%;
    padding: 5%;
  }

  .history__title {
    margin-bottom: 16px;
  }

  .history__title h2 {
    font-size: 16px;
  }

  .history__item-year {
    width: 40px;
    height: 40px;
  }

  .history__item-year p {
    font-size: 14px;
    font-weight: normal;
  }

  .history__item-line {
    width: 40px;
  }

  .history__item-line div {
    width: 4px;
  }

  .history__item-content {
    grid-template-columns: 40px 1fr;
    -ms-grid-columns: 40px 1fr;
    width: calc(100% - 40px);
  }

  .history__item-content p {
    font-size: 14px;
    font-weight: normal;
  }

  .history__item-content-month {
    padding-right: 8px;
  }

  .history__big-text {
    color: #BEEAB8;
    top: 0;
  }
}


/********** author **********/
.author {
  position: relative;
}

.author__bg {
  width: 90%;
  margin: 0 auto;
  padding: 5%;
  background: linear-gradient(to right, rgba(91, 186, 31, 0.3), rgba(33, 167, 74, 0.3));
}

.author__content {
  margin: 0 auto;
  padding: 0 5% 10%;
  background-color: #ffffff;
  box-shadow: 0 5px 5px #d5d5d5;
  position: relative;
}

.author__img {
  text-align: right;
  position: absolute;
  top: -3%;
  right: -3%;
}

.author__img img {
  width: 90%;
}

.author__text {
  padding-top: 450px;
  margin-bottom: 80px;
}

.author__text-name {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 80px;
}

.author__text-name p:first-child {
  font-weight: bold;
  font-size: 24px;
}

.author__text-name p:last-child {
  font-weight: bold;
  font-size: 18px;
}

.author__text-title {
  margin-bottom: 80px;
}

.author__text-title p {
  font-size: 16px;
  font-weight: bold;
}

.author__button {
  text-align: center;
}

.author__button a {
  padding: 16px 40px;
  font-weight: bold;
  font-size: 16px;
  color: #EF7D2E;
  border: 2px solid #EF7D2E;
  border-radius: 12px;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}

.author__background {
  width: 100vw;
  height: 100%;
  margin-left: calc(50% - 50vw);
  position: absolute;
  top: -170px;
  z-index: -1;
  overflow: hidden;
}

.author__background img {
  width: 100%;
}

@media screen and (max-width: 959px) {
  .author__img img {
    width: 80%;
  }

  .author__text {
    padding-top: 320px;
    margin-bottom: 40px;
  }

  .author__text-name {
    margin-bottom: 40px;
  }

  .author__text-name p:first-child {
    font-size: 32px;
  }

  .author__text-name p:last-child {
    font-size: 20px;
  }

  .author__text-title {
    margin-bottom: 40px;
  }

  .author__text-title p {
    font-size: 16px;
  }

  .author__button a {
    font-size: 20px;
  }
}

@media screen and (max-width: 768px) {
  .author {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-bottom: 24px;
  }

  .author__bg {
    width: 100%;
    padding: 5%;
  }

  .author__img {
    top: -1%;
    right: -3%;
  }

  .author__img img {
    width: 80%;
  }

  .author__text {
    padding-top: 200px;
    margin-bottom: 20px;
  }

  .author__text-name {
    margin-bottom: 20px;
  }

  .author__text-name p:first-child {
    font-size: 14px;
  }

  .author__text-name p:last-child {
    font-size: 14px;
  }

  .author__text-title {
    margin-bottom: 32px;
  }

  .author__text-title p {
    font-size: 14px;
    font-weight: normal;
  }

  .author__button a {
    padding: 16px 40px;
    font-size: 14px;
  }

  .author__background {
    top: 0;
  }
}


/********** training **********/
.training {
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-bottom: -6em;
  padding: 120px;
  background-color: #ECECEC;
}

.training__content {
  display: flex;
  align-items: center;
  justify-content: space-around;
}

.training__item--left,
.training__item--right {
  padding: 40px;
  background-color: #f4f4f4;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
}

.training__item--left {
  width: 55%;
}

.training__item--right {
  width: 40%;
}

.training__item-title {
  text-align: center;
  margin-bottom: 40px;
}

.training__item-title p {
  font-size: 24px;
}

.training__item-title p:last-child {
  color: #34A853;
}

.training__item-button {
  display: flex;
  align-items: center;
  justify-content: center;
}

.training__item-button a {
  margin: 0 40px;
  padding: 16px 32px;
  color: #EF7D2E;
  font-size: 16px;
  font-weight: bold;
  border: 2px solid #EF7D2E;
  border-radius: 12px;
  background-color: #FFFFFF;
}

@media screen and (max-width: 1400px) {
  .training__item-button a {
    margin: 0 16px;
  }
}

@media screen and (max-width: 1250px) {
  .training__content {
    flex-direction: column;
  }

  .training__item--left,
  .training__item--right {
    width: 75%;
  }

  .training__item--left {
    margin-bottom: 16px;
  }

}

@media screen and (max-width: 959px) {
  .training__item--left,
  .training__item--right {
    padding: 16px;
    width: 90%;
  }

  .training__item-button a {
    padding: 16px;
  }
}

@media screen and (max-width: 768px) {
  .training {
    padding: 16px;
  }

  .training__content {
    display: block;
  }

  .training__item--left,
  .training__item--right {
    padding: 16px;
  }

  .training__item--left {
    width: 100%;
  }

  .training__item--right {
    width: 100%;
  }

  .training__item-title {
    margin-bottom: 16px;
  }

  .training__item-title p {
    font-size: 14px;
  }

  .training__item-title p:last-child {
    color: #34A853;
    font-size: 18px;
  }

  .training__item-button {
    flex-direction: column;
    gap: 16px;
  }

  .training__item-button a {
    width: 75%;
    margin: 0;
    padding: 12px 40px;
    text-align: center;
  }
}
