/* common class */
* {
  margin: 0px;
  padding: 0px;
}

body {
  font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", YuGothic, sans-serif;
  color: var(--black-2);
}

@media screen and (max-width: 767px) {
  .pc {
    display: none !important;
  }
}
@media screen and (min-width: 768px) {
  .sp {
    display: none !important;
  }
}

.flex-box {
  display: flex;
}

.flex-box-center {
  display: flex;
  align-items: center;
}

.flex-box-center-middle {
  display: flex;
  align-items: center;
  justify-content: center;
}

.width-fill-image {
  width: 100%;
  height: auto;
}

.inline-block {
  display: inline-block;
}

.text-align-center {
  text-align: center;
}

.overflow-hidden {
  overflow: hidden;
}

.top-layer {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0px;
  left: 0px;
}

/* partner-company-list */
#contents > div:nth-child(n + 2):nth-child(-n + 8) {
  margin-top: var(--space-20x);
}
/* counseling */
#contents > div:nth-child(9) {
  margin-top: var(--space-20x);
}
/* comparison */
#contents > div:nth-child(n + 7):nth-child(-n + 14) {
  margin-top: var(--space-20x);
}
/* concept */
#contents > div:nth-child(12) {
  margin-top: calc(12 * var(--space-unit));
}
/* counseling */
#contents > div:nth-child(13) {
  margin-top: 0;
}
@media screen and (min-width: 768px) {
  /* merit */
  #contents > div:nth-child(n + 3):nth-child(-n + 8) {
    margin-top: calc(28.5 * var(--space-unit));
  }
  /* counseling */
  #contents > div:nth-child(9) {
    margin-top: var(--space-20x);
  }
  /* comparison */
  #contents > div:nth-child(n + 7):nth-child(-n + 14) {
    margin-top: calc(28.5 * var(--space-unit));
  }
  /* concept */
  #contents > div:nth-child(12) {
    margin-top: var(--space-20x);
  }
  /* counseling */
  #contents > div:nth-child(13) {
    margin-top: 0;
  }
}

/* contents-caption */
.contents-caption {
  display: flex;
  align-items: start;
  margin-left: var(--space-4x);
  margin-right: var(--space-4x);
}
@media screen and (min-width: 768px) {
  .contents-caption {
    margin-left: var(--space-h-pc);
    margin-right: var(--space-h-pc);
  }
}

.contents-caption .sub-caption {
  writing-mode: vertical-rl;
  text-orientation: mixed;
  color: var(--purple-5);
  font-family: Lato;
  font-weight: bold;
  font-size: var(--font-3xh);
  line-height: 100%;
  letter-spacing: 0.22em;
}

.contents-caption .main-captions {
  margin-left: var(--space-4x);
}

.contents-caption .main-caption {
  font-weight: bold;
  font-size: var(--font-6x);
  line-height: 140%;
  letter-spacing: 0.1em;
  color: var(--black);
}
@media screen and (min-width: 768px) {
  .contents-caption .main-caption {
    font-size: var(--font-9x);
  }
}

.contents-caption > .main-caption {
  margin-left: var(--space-4x);
}

.contents-caption > .main-caption-section {
  margin-left: var(--space-4x);
}

.contents-caption .annotation {
  margin-top: var(--space-2x);
  font-weight: 500;
  font-size: var(--font-3xh);
  line-height: 140%;
  color: var(--black-2);
}

.contents-caption .explanation {
  margin-top: var(--space-4x);
  font-size: calc(3.75 * var(--font-unit));
  line-height: 160%;
  color: var(--black-2);
}

/* button */
.primary-button {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 56px;
  width: 327px;
  border-radius: 28px;
  text-align: center;
  text-decoration: none;
  color: var(--white);
}

.lesson-button {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 56px;
  width: 327px;
  border-radius: 28px;
  text-align: center;
  text-decoration: none;
  color: var(--white);
}

@media screen and (min-width: 768px) {
  .primary-button {
    height: 72px;
    width: 400px;
    border-radius: 36px;
  }

  .lesson-button {
    height: 72px;
    width: 400px;
    border-radius: 36px;
  }
}

.primary-button .icon-next,
.secondary-button .icon-next {
  position: absolute;
  right: 16px;
  margin-top: auto;
  margin-bottom: auto;
}

.lesson-button .icon-next,
.secondary-button .icon-next {
  position: absolute;
  right: 16px;
  margin-top: auto;
  margin-bottom: auto;
}

.button-title {
  color: var(--white);
  font-weight: bold;
  font-size: var(--font-4xh);
  line-height: 100%;
  display: flex;
  align-items: center;
  height: 100%;
}

.button-title img {
  margin-right: 20px; /* 画像の右側にマージンを適用 */
}

.secondary-button {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 56px;
  width: 327px;
  border-radius: 28px;
  text-align: center;
  text-decoration: none;
  color: var(--primary-color);
  border: 2px solid var(--primary-color);
}

.marker-yellow {
  background: linear-gradient(transparent 0%, #fff38a 0%);
}

#contents .partner-company {
  margin-top: var(--space-20x);
  margin-bottom: var(--space-4x);
  text-align: center;
  font-weight: bold;
  font-size: var(--font-4xh);
  line-height: 160%;
  color: var(--black-2);
}
@media screen and (min-width: 768px) {
  #contents .partner-company {
    margin-top: var(--space-20x);
    margin-bottom: var(--space-4x);
    font-size: var(--font-8x);
  }
}

#contents .partner-company-list {
  margin-top: var(--space-4x);
  margin-bottom: var(--space-20x);
  text-align: center;
}
#contents .partner-company-list img {
  width: 80%;
  max-width: 900;
}

@media screen and (min-width: 768px) {
  #contents .partner-company-list {
    margin-top: var(--space-4x);
    margin-bottom: var(--space-20x);
    text-align: center;
  }
}

.program_contents{
  margin-top: var(--space-8x);
  display: flex;
  -webkit-flex-wrap: wrap;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  justify-content: center;
  overflow: hidden;
}

.program_content{
  width: 31%;
  margin: 1rem;
  box-sizing: border-box;
}


.program_contents .program_content:nth-child(1) .program_content_titleBlock{
  background: var(--Secondary, #30349B);
}

.program_contents .program_content:nth-child(2) .program_content_titleBlock{
  background: var(--Primary, #6121A1);
}

.program_contents .program_content:nth-child(3) .program_content_titleBlock{
  border-radius: 3px;
  background: var(--Accent, #FF550D); 
}

.program_content_titleBlock{
  border-radius: 4px;
  align-items: center;
  color: #fff;
}

.program_content_title{
  width: 500px;
  padding: 0.5rem;
}

.program_content_titleBlock img{
  width: 30%;
  padding: 1rem;
}

.program_content_captionBlock{
  display: flex;
  margin-left: auto;
  padding: 1rem;
}

.program_content_caption{
  margin: 1rem 0;
}

.program_content_skil{
  margin-bottom: 1rem ;
  font-weight: bold;
}

.program_content_skil span{
  font-size: 1.1rem;
  padding-left: 1.5rem;
  position: relative;
}

.program_content_skil span::before{
  content: "";
  position: absolute;
  top: 0 ;
  left: 0;
  background: url(../images/menu-board.svg);
  width: 16px;
  height: 16.485px;
}

.program_img{
  width: 100%;
  margin-top: 1rem;
}

@media screen and (min-width: 768px) {
  .program_contents{
    max-width: 1500px;
    margin-left: auto;
    margin-right: auto;
  }
  .program_content_titleBlock{
    height: 102px;
    border-radius: 2px 2px 0px 0px!important;
  }

  .program_contents .program_content:nth-child(1){
    position: relative;
    border-radius: 4px;
    border: 1px solid #30349B;
  }

  .program_contents .program_content:nth-child(2){
    position: relative;
    border-radius: 4px;
    border: 1px solid #6121A1;
  }

  .program_contents .program_content:nth-child(3){
    border-radius: 4px;
    width: 3%;
  }
  .program_contents .program_content:nth-child(3) .program_content_title{
    width: 100%;
  }
  .program_contents .program_content:nth-child(3) .program_content_titleBlock{
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
  

.program_contents .program_content:nth-child(1)::after,
.program_contents .program_content:nth-child(2)::after{
  content: "";
  position: absolute;
  background: url(../images/program_polygon.svg);
  width: 12px;
  height: 28px;
  top: 0;
  bottom: 0;
  right: -20px;
  margin: auto 0;
}
  .program_content svg{
    display: none;
  }
  .program_content_caption{
    height: 100px;
  }
}

@media screen and (max-width: 767px) {
  .program_contents{
    display: block;
  }
  .program_content{
    width: 98%;
    margin: 1rem 0.25rem;
  }
  .program_content_captionBlock{
    padding: 0;
  }
  .program_content_captionBlock svg{
    height: 100%;
  }
  .program_captionBlock_inner{
    margin: 0 1rem;
    font-size: 14px
  }
  
}