@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Anton+SC&family=M+PLUS+1p&family=Noto+Sans+JP:wght@100..900&display=swap");
body {
  font-family: 游ゴシック体, YuGothic, 游ゴシック, Yu Gothic, メイリオ, Meiryo, ヒラギノ角ゴ Pro W3, Hiragino Kaku Gothic ProN, sans-serif;
  overflow-x: hidden;
}

/* common */
.en {
  font-family: "Anton SC", serif;
  font-weight: 400;
}
.sec_contain {
  max-width: 1200px;
  margin: auto;
}
.sec_title {
  overflow-x: clip;
}
.sec_title h2 {
  position: relative;
  font-family: "Anton SC", serif;
  font-weight: 400;
  font-size: 52px;
  letter-spacing: 0.1em;
  text-align: left;
  color: #fff;
  display: inline-block;
}
@media screen and (max-width: 960px) {
  .sec_title h2 {
    font-size: 30px;
  }
}
.sec_title h2::after {
  position: absolute;
  content: "";
  top: 50%;
  right: calc(-3% - 1500px);
  width: 1500px;
  height: 1px;
  background-color: #fff;
}
.bk {
  color: #000 !important;
}
.wh {
  color: #fff !important;
}
.pc-only {
  display: block;
}
.sp-only {
  display: none;
}
@media (max-width: 960px) {
  .pc-only {
    display: none;
  }
  .sp-only {
    display: block;
  }
}
br.sp-only {
  display: none;
}
@media (max-width: 960px) {
  br.sp-only {
    display: block;
  }
}
@media (max-width: 960px) {
  .sp-center {
    text-align: center;
  }
}
.p-barbesec {
  position: relative;
  padding: 70px 20px;
}
@media screen and (max-width: 960px) {
  .p-barbesec {
    padding: 30px 20px;
  }
}
.p-barbesec .curriculum_img {
  max-width: 1000px;
  width: 100%;
  border-radius: 4px;
  background-color: #fffacc;
  margin: auto;
  margin-top: 50px;
}
@media screen and (max-width: 960px) {
  .p-barbesec .curriculum_img {
    margin-top: 20px;
    max-width: 100%;
  }
}
.p-studentvoice .sec_title h2 {
  color: #000;
}
.p-studentvoice .sec_title h2::after {
  background-color: #000;
}
.p-studentvoice {
  padding-bottom: 200px;
}
@media screen and (max-width: 960px) {
  .p-studentvoice {
    padding-bottom: 50px;
  }
}
.p-studentvoice_body {
  position: relative;
  margin-top: 30px;
  z-index: 1;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body {
    margin-top: 20px;
  }
}
.p-studentvoice_body .mainimg {
  position: relative;
  max-width: 900px;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .mainimg {
    max-width: 100%;
  }
}
.p-studentvoice_body .mainimg .txtimg {
  max-width: 520px;
  position: absolute;
  width: 100%;
  bottom: -100px;
  left: 80px;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .mainimg .txtimg {
    max-width: 285px;
    bottom: -65px;
    left: 30px;
  }
}
.p-studentvoice_body .maintxt {
  position: absolute;
  right: 0;
  bottom: -180px;
  z-index: 2;
  padding: 40px 30px;
  max-width: 525px;
  width: 100%;
  border-radius: 6px;
  background: #fff;
  border: 1px solid #906d26;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .maintxt {
    max-width: 100%;
    padding: 20px;
  }
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .maintxt {
    margin-top: 45px;
    position: unset;
  }
}
.p-studentvoice_body .maintxt p {
  font-weight: 400;
  font-size: 18px;
  line-height: 1.7;
  text-align: left;
  color: #000;
  margin: 0;
}
.p-studentvoice_body .maintxt p.midtxt {
  font-size: 16px;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .maintxt p {
    font-size: 14px;
  }
  .p-studentvoice_body .maintxt p.midtxt {
    font-size: 14px;
  }
}
.p-studentvoice_body .maintxt .toptxt {
  font-weight: bold;
}
.p-studentvoice_body .maintxt .midtxt {
  margin: 20px auto;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body .maintxt .midtxt {
    margin: 10px auto;
  }
}
.p-studentvoice_body .maintxt .bttxt {
  font-weight: bold;
  color: #906d26;
}
.p-studentvoice_body + .p-studentvoice_body {
  margin-top: 260px;
}
@media screen and (max-width: 960px) {
  .p-studentvoice_body + .p-studentvoice_body {
    margin-top: 40px;
  }
}
.p-workstyle {
  padding: 150px 20px 250px;
  background-image: url(../img/course/barber/academy-bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  -webkit-clip-path: polygon(0 8%, 100% 0, 100% 100%, 0 90%);
  clip-path: polygon(0 8%, 100% 0, 100% 100%, 0 90%);
}
@media screen and (max-width: 960px) {
  .p-workstyle {
    background-image: url(../img/course/barber/academy-bg-sp.png);
    background-size: cover;
    background-position: top;
    padding: 100px 20px 150px;
    -webkit-clip-path: polygon(0 0%, 100% 0, 100% 100%, 0 100%);
    clip-path: polygon(0 0%, 100% 0, 100% 100%, 0 100%);
  }
}
.p-workstyle .sec_title h2 {
  text-align: center;
}
.p-workstyle_body {
  margin-top: 50px;
}
@media screen and (max-width: 960px) {
  .p-workstyle_top {
    align-items: center;
    display: flex;
    flex-direction: column;
  }
}
.p-workstyle_top p {
  font-weight: bold;
  font-size: 20px;
  line-height: 1.5;
  text-align: left;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-workstyle_top p {
    font-size: 14px;
  }
}
.p-workstyle_top_head {
  display: inline-block;
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
  padding: 10px 25px;
}
@media screen and (max-width: 960px) {
  .p-workstyle_top_head {
    margin: auto;
    text-align: center;
    font-size: 14px;
  }
}
.p-workstyle_top_txt01 {
  width: 100%;
  margin: 20px 0;
  font-weight: bold;
}
.p-workstyle_top_txt02 {
  font-size: 16px;
}
@media screen and (max-width: 960px) {
  .p-workstyle_top_txt01 {
    font-size: 16px !important;
  }
  .p-workstyle_top_txt02 {
    font-size: 14px !important;
  }
}
.p-workstyle_phase {
  max-width: 95%;
  margin: auto;
  margin-top: 40px;
  display: grid;
  align-items: normal;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 40px;
}
@media screen and (max-width: 960px) {
  .p-workstyle_phase {
    margin-top: 20px;
    grid-template-columns: 1fr;
    grid-gap: 20px;
    max-width: 90%;
  }
}
.p-workstyle_phase_item {
  padding: 25px;
  width: 100%;
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.83);
}
@media screen and (max-width: 960px) {
  .p-workstyle_phase_item {
    padding: 20px;
    min-height: auto;
  }
}
.p-workstyle_phase_head {
  padding-bottom: 7px;
  border-bottom: 1px solid #000;
  font-weight: 400;
  font-size: 24px;
  text-align: center;
  margin-bottom: 10px;
  font-weight: bold;
}
@media screen and (max-width: 960px) {
  .p-workstyle_phase_head {
    font-size: 16px;
  }
}
.p-workstyle_phase .content p {
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 960px) {
  .p-workstyle_phase .content p {
    font-size: 14px;
  }
}
.p-workstyle_phase {
  display: flex;
}
.p-workstyle_phase_arrow {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-workstyle_phase_arrow img {
  width: 40px;
  height: auto;
}
@media screen and (max-width: 768px) {
  .p-workstyle_phase {
    flex-direction: column;
    gap: 10px;
  }
  .p-workstyle_phase_arrow {
    transform: rotate(90deg);
  }
  .p-workstyle_phase_arrow img {
    width: 20px;
  }
}
.p-workstyle_introimgs {
  margin-top: 50px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 25px;
}
.p-workstyle_introimgs img {
  border: 1px solid #ffffff;
}
@media screen and (max-width: 960px) {
  .p-workstyle_introimgs {
    flex-direction: column;
    gap: 20px;
    width: 100%;
    margin: auto;
    margin-top: 30px;
  }
  .p-workstyle_introimgs img {
    width: 100%;
  }
}
.p-obpickup {
  padding-top: 0;
  position: relative;
}
.p-obpickup::before {
  position: absolute;
  content: "";
  top: -200px;
  left: 0;
  background-color: #906d26;
  width: 100%;
  height: 200px;
  z-index: -1;
}
.p-obpickup_body {
  margin-top: 50px;
}
.p-obpickup_head {
  font-family: "M PLUS 1p", serif;
  font-weight: bold;
  font-size: 20px;
  letter-spacing: 0.1em;
  text-align: left;
  color: #fff;
  display: inline-block;
  padding: 10px 40px;
  background-color: #000;
  margin: 0;
}
@media screen and (max-width: 960px) {
  .p-obpickup_head {
    font-size: 14px;
    padding: 10px;
    width: 100%;
    text-align: center;
  }
}
.p-obpickup_head .txt01 {
  font-size: 24px;
}
@media screen and (max-width: 960px) {
  .p-obpickup_head .txt01 {
    font-size: 16px;
  }
}
.p-obpickup_box {
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box {
    margin-top: 10px;
  }
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item {
    display: flex;
    align-items: center;
    flex-direction: column;
  }
}
.p-obpickup_box_item:nth-child(1) img {
  max-width: 800px;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item:nth-child(1) img {
    max-width: 95%;
    margin: auto;
  }
}
.p-obpickup_box_item:nth-child(1) .txt, .p-obpickup_box_item:nth-child(2) .txt {
  margin-top: 60px;
  font-size: 16px;
  font-weight: bold;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item:nth-child(1) .txt {
    margin-top: 20px;
  }
  .p-obpickup_box_item:nth-child(1) .txt, .p-obpickup_box_item:nth-child(2) .txt {
    font-size: 14px;
  }
}
.p-obpickup_box_item:nth-child(2) {
  margin-top: 35px;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item:nth-child(2) {
    margin-top: 30px;
  }
}
.p-obpickup_box_item:nth-child(2) img {
  max-width: 530px;
  position: absolute;
  top: 250px;
  right: 0;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item:nth-child(2) img {
    max-width: 95%;
    margin: auto;
    position: unset;
    top: unset;
  }
}
.p-obpickup_box_item .txt {
  font-weight: 500;
  font-size: 20px;
  line-height: 1.7;
  text-align: left;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-obpickup_box_item .txt {
    margin-top: 20px;
    font-size: 14px;
  }
}
/* primebarber */
.primebarber img {
  width: 100%;
}
@media screen and (max-width: 960px) {
  .primebarber .slick-slider .slick-prev::before, .primebarber .slick-slider .slick-next::before {
    color: #fff;
  }
  .primebarber .slick-slider .slick-prev::before {
    content: "";
  }
  .primebarber .slick-slider .slick-next::before {
    content: "";
  }
  .primebarber .slick-slider .slick-dots {
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
  }
  .primebarber .slick-slider .slick-dots li {
    margin: 0;
  }
  .primebarber .slick-slider .slick-dots li button::before {
    font-size: 32px;
    color: #fff;
  }
  .primebarber .slick-slider .slick-slide {
    margin: 0 5px;
  }
  .primebarber .slick-slider .slick-list {
    margin-left: -5px;
    padding-left: 0 !important;
  }
}
.primebarber .p-workstyle {
  position: relative;
  z-index: 2;
}
.primebarber .p-workstyle_toptxt {
  font-weight: 700;
  font-size: 20px;
  color: #fff;
  margin-top: 10px;
}
@media screen and (max-width: 960px) {
  .primebarber .p-workstyle_toptxt {
    font-size: 18px;
    text-align: center;
  }
}
.primebarber .p-workstyle_introimgs {
  max-width: 100% !important;
}
@media screen and (max-width: 960px) {
  .primebarber .p-workstyle_introimgs {
    flex-direction: row;
  }
}
.primebarber .p-studentvoice {
  margin-bottom: 150px;
}
@media screen and (max-width: 960px) {
  .primebarber .p-studentvoice {
    margin-bottom: 0;
  }
}
.primebarber .p-studentvoice_body .maintxt {
  max-width: 545px;
}
.primebarber .p-obpickup {
  background: #123B82;
}
@media screen and (max-width: 960px) {
  .p-obpickup.p-barbesec {
    padding-top: 0px !important;
  }
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup {
    padding: 50px 20px;
  }
}
.primebarber .p-obpickup::before {
  height: 250px;
  top: -250px;
  background: #123B82;
  z-index: 1;
}
.primebarber .p-obpickup_body {
  margin-top: 70px;
}
.primebarber .p-obpickup_item {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 70px;
  margin-bottom: 100px;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item {
    flex-direction: column;
    gap: 20px;
    margin-bottom: 30px;
  }
}
.primebarber .p-obpickup_item.reverse {
  flex-direction: row-reverse;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item.reverse {
    flex-direction: column;
  }
}
.primebarber .p-obpickup_item:last-child {
  margin-bottom: 0;
}
.primebarber .p-obpickup_item img {
  max-width: 480px;
  border: 1px solid #FFFFFF;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item img {
    max-width: 265px;
    margin: auto;
  }
}
.primebarber .p-obpickup_item .content {
  max-width: 585px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item .content {
    max-width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
}
.primebarber .p-obpickup_item .content .head {
  display: inline-block;
  background: #906D26;
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.1em;
  color: #fff;
  padding: 10px 30px;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item .content .head {
    font-size: 18px;
    padding: 7px 25px;
  }
}
.primebarber .p-obpickup_item .content .txt {
  margin-top: 40px;
  font-weight: 500;
  font-size: 20px;
  color: #fff;
  line-height: 1.7;
  margin-top: 20px;
}
.primebarber .p-obpickup_item .content .txt:first-of-type {
  margin-top: 40px;
}
@media screen and (max-width: 960px) {
  .primebarber .p-obpickup_item .content .txt {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.7;
  }
}
.p-primebarbesec01 {
  position: relative;
  padding: 70px 20px;
  padding-bottom: 150px;
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0% 100%);
  background-color: #fff;
}
.p-primebarbesec01 .sec_title {
  margin-bottom: 25px;
}
.p-primebarbesec01 .sec_title h2::after {
  background-color: #000;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01 {
    padding-top: 40px;
    padding-bottom: 80px;
    clip-path: polygon(0 0, 100% 0, 100% 95%, 0% 100%);
  }
}
.p-primebarbesec01_body .toptxt {
  font-weight: bold;
  font-size: 18px;
  line-height: 1.7;
  text-align: left;
  color: #000;
  margin-top: 40px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01_body .toptxt {
    font-size: 14px;
  }
}
.p-primebarbesec01_body .introbox__item {
  margin-bottom: 50px;
  display: flex;
  align-items: center;
  gap: 30px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01_body .introbox__item {
    flex-direction: column;
    gap: 20px;
    margin-bottom: 25px;
  }
}
.p-primebarbesec01_body .introbox__item:last-child {
  margin-bottom: 0;
}
.p-primebarbesec01_body .introbox__item.imgbox {
  align-items: flex-start;
  gap: 90px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01_body .introbox__item.imgbox {
    align-items: center;
    gap: 20px;
  }
}
.p-primebarbesec01_body .introbox__item .head {
  min-width: 190px;
  padding: 10px 25px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01_body .introbox__item .head {
    font-size: 14px;
  }
}
.p-primebarbesec01_body .introbox__item .txt {
  margin: 0;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.4;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01_body .introbox__item .txt {
    font-size: 14px;
    line-height: 1.7;
  }
}
.p-primebarbesec01 .curriculum_img {
  width: 100%;
  margin: auto;
  margin-top: 40px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01 .curriculum_img {
    margin-top: 20px;
    width: -moz-max-content;
    width: max-content;
    overflow-x: scroll;
  }
}
.p-primebarbesec01 .curriculum_img img {
  width: 100%;
}
.p-primebarbesec01 .tabletxt {
  margin-top: 20px;
  font-weight: 500;
  font-size: 16px;
  color: #000000;
  text-align: right;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec01 .tabletxt {
    font-size: 12px;
    margin-top: -20px;
  }
}
@media screen and (max-width: 960px) {
  .toptxt-cutmans {
    text-align: center;
  }
}
.p-primebarbesec02 {
  padding: 70px 20px;
  position: relative;
  margin-top: -150px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 {
    margin-top: -100px;
  }
}
.p-primebarbesec02 .sec_title h2::after {
  background-color: #000;
}
.p-primebarbesec02 .toptxt {
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.1em;
  color: #000;
  margin-top: 40px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .toptxt {
    font-size: 18px;
    margin-top: 20px;
  }
}
.p-primebarbesec02 .introbox {
  margin-top: 30px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox {
    margin-top: 20px;
  }
}
.p-primebarbesec02 .introbox__item {
  margin-bottom: 50px;
  display: flex;
  align-items: center;
  gap: 30px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item {
    flex-direction: column;
    gap: 15px;
    margin-bottom: 20px;
  }
}
.p-primebarbesec02 .introbox__item:last-child {
  margin-bottom: 0;
}
.p-primebarbesec02 .introbox__item .head {
  min-width: 190px;
  padding: 10px 25px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 18px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item .head {
    min-width: auto;
    max-width: 100%;
    width: 100%;
    display: block;
    font-size: 16px;
  }
}
.p-primebarbesec02 .introbox__item .txt {
  margin: 0;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.4;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item .txt {
    font-size: 14px;
    line-height: 1.7;
  }
}
.p-primebarbesec02 .introbox__item_imgs {
  display: flex;
  align-items: flex-start;
  gap: 80px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item_imgs {
    flex-direction: column;
    gap: 20px;
  }
}
.p-primebarbesec02 .introbox__item_imgs_item {
  max-width: 390px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item_imgs_item {
    max-width: 100%;
    display: flex;
    align-items: flex-start;
    flex-direction: row;
  }
}
.p-primebarbesec02 .introbox__item_imgs_item img {
  max-width: 290px;
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item_imgs_item img {
    max-width: 120px;
  }
}
.p-primebarbesec02 .introbox__item_imgs_item .title {
  font-weight: 700;
  font-size: 20px;
  color: #000;
  text-align: center;
  margin: 0;
  margin-bottom: 15px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item_imgs_item .title {
    font-size: 16px;
    margin-bottom: 5px;
    text-align: left;
  }
}
.p-primebarbesec02 .introbox__item_imgs_item .txt {
  font-weight: 500;
  font-size: 16px;
  color: #000000;
  margin: 0;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02 .introbox__item_imgs_item .txt {
    font-size: 14px;
  }
}
.p-primebarbesec02_head {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 50px;
  flex-wrap: wrap;
}
.p-primebarbesec02_head p {
  font-weight: bold;
  font-size: 34px;
  letter-spacing: 0.01em;
  text-align: center;
  color: #000000;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02_head {
    margin-top: 30px;
  }
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02_head p {
    font-size: 20px !important;
  }
}
.p-primebarbesec02_head .badge-label {
  background-color: #FFE833;
  border-radius: 999px;
  padding: 8px 24px;
  font-weight: 700;
  font-size_: 16px;
  white-space: nowrap;
  width: fit-content;
  flex-basis: 100%;
  text-align: center;
  font-size: 34px;
  flex-basis: auto;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .p-primebarbesec02_head .badge-label {
    font-size: 20px;
    margin-bottom: 30px;
  }
}
.p-primebarbesec02_head_text {
  display: flex;
  align-items: flex-end;
}
.p-primebarbesec02_head_text .deco-left, .p-primebarbesec02_head_text .deco-right {
  width: 45px;
  height: 61px;
  flex-shrink: 0;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec02_head_text .deco-left, .p-primebarbesec02_head_text .deco-right {
    width: 20px;
    height: 40px;
  }
}
.p-primebarbesec03 {
  padding: 100px 20px;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03 {
    padding: 100px 15px 100px;
  }
}
.p-primebarbesec03::before {
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-image: url(../img/course/barber/classical-bg.jpg);
  background-position: top;
  background-size: 100%;
  background-repeat: no-repeat;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03::before {
    background-image: url(../img/course/barber/classical-bg-sp.jpg);
    background-size: cover;
  }
}
.p-primebarbesec03_body {
  position: relative;
  z-index: 3;
}
.p-primebarbesec03_title {
  color: #FFFFFF;
  font-family: "Anton SC", sans-serif;
  font-weight: 400;
  font-size: 52px;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_title {
    font-size: 26px;
  }
}
.p-primebarbesec03_grid01 {
  margin-top: 80px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 22px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_grid01 {
    margin-top: 25px;
    grid-gap: 10px;
    grid-template-columns: 1fr 1fr;
  }
}
.p-primebarbesec03_grid01 .item {
  padding: 15px;
  border: 1px solid #FFFFFF;
  background: rgba(236, 17, 17, 0.568627451);
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_grid01 .item {
    padding: 10px;
    min-height: 105px;
  }
}
.p-primebarbesec03_grid01 .item_title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.4;
  text-align: center;
  color: #FFFFFF;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_grid01 .item_title {
    font-size: 14px;
  }
}
.p-primebarbesec03_grid01 .item_txt {
  margin-top: 5px;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.4;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_grid01 .item_txt {
    font-size: 10px;
  }
}
.p-primebarbesec03_flex {
  display: flex;
  align-items: center;
  gap: 30px;
  margin-top: 80px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex {
    margin-top: 45px;
    gap: 0;
  }
}
.p-primebarbesec03_flex .flex_content {
  max-width: 645px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex .flex_content {
    max-width: 100%;
  }
}
.p-primebarbesec03_flex .flex_content_title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.1em;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex .flex_content_title {
    font-size: 18px;
    margin-bottom: 35px;
    text-align: center;
  }
}
.p-primebarbesec03_flex .flex_content_txt {
  margin-top: 25px;
  font-weight: 500;
  font-size: 18px;
  color: #fff;
  line-height: 1.7;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex .flex_content_txt {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.7;
  }
}
.p-primebarbesec03_flex .flex_img {
  max-width: 520px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex .flex_img {
    max-width: 100%;
  }
}
.p-primebarbesec03_specialties {
  margin-top: 150px;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_specialties {
    margin-top: 30px;
  }
}
.p-primebarbesec03_h3before {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 24px;
  letter-spacing: 0.1em;
  color: #fff;
  text-align: center;
  margin-bottom: 10px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_h3before {
    font-size: 16px;
    margin-bottom: 5px;
  }
}
.p-primebarbesec03_h3 {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 40px;
  letter-spacing: 0.1em;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_h3 {
    font-size: 20px;
  }
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_h3.mt-70 {
    margin-top: 70px;
  }
}
.p-primebarbesec03_h3::after {
  content: "";
  display: block;
  width: 110px;
  height: 3px;
  background-color: #fff;
  margin: auto;
  margin-top: 15px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_h3::after {
    margin-top: 10px;
  }
}
.p-primebarbesec03_flex02 {
  display: flex;
  align-items: stretch;
  gap: 50px 25px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 70px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 {
    display: flex;
    flex-wrap: nowrap;
    margin-top: 25px;
    margin-bottom: 0px !important;
    gap: 0;
  }
}
.p-primebarbesec03_flex02 .item {
  max-width: 280px;
  width: 100%;
  background: #AE8950;
  border: 1px solid #FFFFFF;
  padding: 15px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 .item {
    max-width: 100%;
    padding: 10px;
  }
}
.p-primebarbesec03_flex02 .item_title {
  min-height: 50px;
  display: flex;
  align-items: center;
  gap: 15px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 20px;
  line-height: 24px;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 .item_title {
    font-size: 17px;
    gap: 2px;
    justify-content: center;
  }
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 .item_title span.num {
    font-size: 20px !important;
  }
}
.p-primebarbesec03_flex02 .item_title {
  color: #fff;
}
.p-primebarbesec03_flex02 .item_title span.num {
  font-family: "Anton SC", serif;
  font-size: 36px;
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 .item_title span.num {
    font-size: 32px;
  }
}
.p-primebarbesec03_flex02 .item_txt {
  color: #fff;
  font-weight: 500;
  font-size: 18px;
  color: #fff;
  margin: 10px auto 15px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex02 .item_txt {
    font-size: 14px;
  }
}
.p-primebarbesec03_flex03 {
  margin-top: 50px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-gap: 28px;
  align-items: stretch;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex03 {
    display: block;
    margin-top: 25px;
  }
}
.p-primebarbesec03_flex03 .item {
  min-height: 200px;
  background: #3C508F;
  border: 1px solid #FFFFFF;
  padding: 20px 25px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex03 .item {
    padding: 15px;
    min-height: 200px;
  }
}
.p-primebarbesec03_flex03 .item_title {
  display: flex;
  align-items: center;
  gap: 15px;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 24px;
  letter-spacing: 0.1em;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex03 .item_title {
    font-size: 16px;
  }
}
.p-primebarbesec03_flex03 .item_title span.num {
  font-family: "Anton SC", serif;
  font-size: 40px;
  font-weight: 500;
  line-height: 1;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex03 .item_title span.num {
    font-size: 24px;
  }
}
.p-primebarbesec03_flex03 .item_txt {
  font-weight: 500;
  font-size: 18px;
  color: #fff;
  margin-top: 10px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec03_flex03 .item_txt {
    font-size: 14px;
  }
}
.p-primebarbesec04 {
  padding: 100px 20px;
  background-image: url(../img/course/barber/stress-bg.jpg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04 {
    padding: 100px 20px;
  }
}
.p-primebarbesec04_title {
  color: #FFFFFF;
  font-family: "Anton SC", sans-serif;
  font-weight: 400;
  font-size: 52px;
  letter-spacing: 0.1em;
  text-align: center;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_title {
    font-size: 26px;
  }
}
.p-primebarbesec04_grid01 {
  margin-top: 80px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-gap: 22px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_grid01 {
    margin-top: 25px;
    grid-gap: 10px;
    grid-template-columns: 1fr 1fr;
  }
}
.p-primebarbesec04_grid01 .item {
  padding: 15px;
  border: 1px solid #FFFFFF;
  background: rgba(0, 0, 0, 0.7803921569);
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_grid01 .item {
    padding: 10px;
    min-height: 105px;
  }
}
.p-primebarbesec04_grid01 .item_title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.4;
  text-align: center;
  color: #FFFFFF;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_grid01 .item_title {
    font-size: 14px;
  }
}
.p-primebarbesec04_grid01 .item_txt {
  margin-top: 5px;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.4;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_grid01 .item_txt {
    font-size: 10px;
  }
}
.p-primebarbesec04_flex {
  margin-top: 60px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex {
    margin-top: 45px;
  }
}
.p-primebarbesec04_flex .itembox {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 80px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex .itembox {
    gap: 0;
    margin-bottom: 60px;
  }
  .p-primebarbesec04_flex .itembox:last-child {
    margin-bottom: 0;
  }
}
.p-primebarbesec04_flex .itembox.reverse {
  flex-direction: row-reverse;
}
.p-primebarbesec04_flex .flex_content {
  max-width: 590px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex .flex_content {
    max-width: 100%;
  }
}
.p-primebarbesec04_flex .flex_content_title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.5;
  letter-spacing: 0.1em;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex .flex_content_title {
    font-size: 18px;
    margin-bottom: 30px;
    text-align: center;
  }
}
.p-primebarbesec04_flex .flex_content_txt {
  margin-top: 30px;
  font-weight: 600;
  font-size: 18px;
  color: #fff;
  line-height: 1.7;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex .flex_content_txt {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.7;
  }
}
.p-primebarbesec04_flex .flex_img {
  max-width: 320px;
  width: 100%;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_flex .flex_img {
    max-width: 245px;
    margin: 0 auto;
  }
}
.p-primebarbesec04_bottom {
  display: flex;
  align-items: stretch;
  gap: 20px;
  margin-top: 100px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_bottom {
    display: block;
    margin-top: 60px;
  }
}
.p-primebarbesec04_bottom .item {
  max-width: 385px;
  width: 100%;
  background: rgba(216, 94, 125, 0.7607843137);
  border: 1px solid #FFFFFF;
  padding: 25px 20px;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_bottom .item {
    padding: 15px;
    max-width: 100%;
    min-height: 200px;
  }
}
.p-primebarbesec04_bottom .item_title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.4;
  text-align: left;
  color: #FFFFFF;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_bottom .item_title {
    font-size: 18px;
  }
}
.p-primebarbesec04_bottom .item_txt {
  margin-top: 10px;
  font-weight: 600;
  font-size: 18px;
  line-height: 1.5;
  color: #fff;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec04_bottom .item_txt {
    margin-top: 20px;
    font-size: 14px;
  }
}
.p-primebarbesec05 {
  padding: 100px 20px;
  position: relative;
}
@media screen and (max-width: 960px) {
  .p-primebarbesec05 {
    padding: 70px 15px 50px;
  }
}
/* 横スクロールの外枠 */
@media screen and (max-width: 960px) {
  .scrollbox {
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }
  .scrollbox .scrollcontent {
    display: flex;
    justify-content: flex-start;
    gap: 10px;
    padding-bottom: 10px;
    scroll-snap-type: x mandatory;
  }
  .scrollbox .scrollcontent_item {
    flex: 0 0 auto;
    width: 300px;
    scroll-snap-align: start;
  }
  .scrollbox .scrollcontent_item img {
    width: 100%;
    height: auto;
    display: block;
  }
}
body .swipe-hint {
  display: none;
}
@media screen and (max-width: 960px) {
  body .swipe-hint {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    margin-top: 5px;
    letter-spacing: 0.05em;
    background-color: #e0e0e0 !important;
    color: #000 !important;
    padding: 6px 16px;
    border-radius: 999px;
    font-weight: 700;
  }
  body .swipe-hint.dark {
    background: #000 !important;
    color: #fff !important;
  }
  body .swipe-hint__arrow {
    display: inline-block;
    animation: bounceRight 1.2s ease-in-out infinite;
  }
}
@keyframes bounceRight {
  0%, 100% {
    transform: translateX(0);
  }
  50% {
    transform: translateX(5px);
  }
}
.mainView img {
  width: 100%;
}
/* ロイヤルメイクアップ */
@media screen and (max-width: 768px) {
  .course-grid + .course-grid {
    margin-top: 30px !important;
  }
}
@media screen and (max-width: 768px) {
  .course-card {
    margin-bottom: 20px;
  }
}
@media screen and (min-width: 769px) {
  .exam-required {
    padding: 25px 25px 35px;
    /* background: rgba(255, 255, 255, 0.70); */
    background: #ffffff;
    margin-bottom: 4%;
    position: relative;
    z-index: 2;
  }
  .exam-block {
    margin-bottom: 10px;
  }
  .exam-heading {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #755C9E;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title {
    background: #755C9E;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 768px) {
  .exam-required {
    padding: 15px;
    background: rgba(255, 255, 255, 0.70);
    margin-bottom: 4%;
  }
  .exam-heading {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #755C9E;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title {
    background: #755C9E;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 20px;
  }
  .sec-02 {
    padding-bottom: 10px !important;
    /* margin-bottom: -40px!important; */
  }
}
.exam-text {
  line-height: 1.8;
}
.exam-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.exam-card img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 16px;
}
.exam-card p {
  line-height: 1.5;
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .exam-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .exam-title {
    font-size: 16px;
  }
  .exam-card img {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
  }
  .wd84 img {
    width: 84% !important;
  }
}
.course-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.course-grid_02 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
}
.course-card {
  display: flex;
  flex-direction: column;
  position: relative;
}
.course-img img {
  width: 100%;
  height: auto;
  display: block;
}
.course-title {
  font-size: 16px;
  font-weight: bold;
  text-align: center;
  margin: 20px 0 15px;
  padding-bottom: 12px;
  border-bottom: 1px solid #000;
}
.course-text {
  font-size: 16px;
  line-height: 1.5;
  margin-bottom: 15px;
  /* padding-bottom: 30px; */
}
.course-text.course-text-toggle {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  line-height: 1.5em;
  height: 3em;
  -webkit-line-clamp: 2;
  transition: 0.3s;
}
.course-text.course-text02 {
  margin-top: 20px;
}
.course-card.open .course-text-toggle {
  height: auto;
  -webkit-line-clamp: unset;
}
.course-text-space {
  margin-top: 20px;
  margin-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .course-text-space {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
}
/* .course-more {
    text-align: right;
    position: absolute;
    right: 0;
    bottom: 0;
} */
.course-more {
  text-align: right;
  color: #755C9E;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
  cursor: pointer;
  text-decoration: underline;
  margin-bottom: 0;
  padding: 0;
  height: auto;
  background: transparent;
  border: none;
}
.course-more a:hover {
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .course-grid {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .course-grid_02 {
    grid-template-columns: 1fr;
    gap: 30px;
  }
  .course-title {
    font-size: 16px;
    font-weight: bold !important;
  }
  .course-more {
    margin-top: 15px;
  }
  .course-text {
    font-size: 16px;
    line-height: 1.5;
    margin-bottom: 0px;
    padding-bottom: 0px;
  }
}
/* Withビューティー */
.course-features {
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 6%;
}
.course-box p {
  font-size: 16px;
  line-height: 1.5;
}
.course-box .strong {
  font-weight: bold;
  margin-bottom: 0 !important;
}
@media screen and (min-width: 769px) {
  .course-box {
    width: 31%;
    border: 4px solid #DC76A3;
    padding: 2%;
    background: #ffffff;
    position: relative;
    text-align: left;
  }
  .course-label {
    background: #DC76A3;
    color: #ffffff;
    padding: 10px 28px;
    border-radius: 40px;
    font-weight: bold;
    font-size: 20px;
    text-align: center;
  }
  .course-box h3 {
    text-align: center;
    font-size: 20px;
    margin-bottom: 20px;
    margin-top: 10px;
    color: #333;
    font-weight: bold;
  }
}
@media screen and (max-width: 768px) {
  .course-box {
    width: 100%;
    border: 4px solid #DC76A3;
    padding: 3%;
    background: #ffffff;
    position: relative;
    text-align: left;
    z-index: 50 !important;
  }
  .course-label {
    background: #DC76A3;
    color: #ffffff;
    padding: 10px 0;
    border-radius: 40px;
    font-weight: bold;
    font-size: 16px;
    text-align: center;
  }
  .course-features {
    flex-direction: column;
    align-items: center;
  }
  .course-box h3 {
    text-align: center;
    font-size: 16px;
    margin-bottom: 20px;
    margin-top: 10px;
    color: #333;
    font-weight: bold;
  }
  .course-box p {
    font-size: 14px;
  }
}
@media screen and (min-width: 769px) {
  .relative {
    position: relative;
  }
  .relative .papet {
    position: absolute;
    right: 20px;
    top: -50px;
    width: 320px;
  }
  .relative .papet img {
    width: 100%;
  }
  .relative .papet_02 {
    position: absolute;
    right: 20px;
    top: -130px;
    width: 300px;
  }
  .relative .papet_02 img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .relative {
    position: relative;
  }
  .relative .papet {
    position: absolute;
    right: -10px;
    top: 30px;
    width: 100px;
  }
  .relative .papet img {
    width: 100%;
  }
  .relative .papet_02 {
    position: absolute;
    right: 0px;
    top: -40px;
    width: 120px;
  }
  .relative .papet_02 img {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .bc-header h3 {
    font-size: 36px;
    margin-bottom: 25px;
  }
  .bc-header .en {
    font-weight: bold;
    letter-spacing: 2px;
    margin-right: 20px;
  }
  .bc-header .jp {
    font-weight: bold;
    font-size: 24px;
  }
}
@media screen and (max-width: 768px) {
  .bc-header h3 {
    font-size: 24px;
    margin-bottom: 15px;
  }
  .bc-header .en {
    font-weight: bold;
    letter-spacing: 2px;
    margin-right: 20px;
  }
  .bc-header .jp {
    font-weight: bold;
    font-size: 18px;
  }
}
.bc-sub {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
}
.bc-sub .label {
  background: #966961;
  color: #ffffff;
  padding: 10px 20px;
  font-weight: bold;
  letter-spacing: 1px;
}
.bc-sub .title {
  color: #DF2C7B;
  font-weight: bold;
  font-size: 20px;
}
.bc-line {
  border: none;
  border-top: 2px solid #000000;
  margin-bottom: 25px;
}
.bc-description {
  font-size: 16px;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .primebarber p {
    font-size: 14px;
  }
}
.bc-images {
  display: flex;
  gap: 30px;
  justify-content: space-between;
  flex-wrap: wrap;
}
.bc-item {
  width: 23%;
  text-align: left;
}
.bc-item img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 15px;
}
.bc-career {
  border: 4px solid #e48cb3;
  padding: 25px 30px;
  margin-top: 20px;
  margin-bottom: 2%;
}
@media screen and (max-width: 768px) {
  .bc-career.mb-80 {
    margin-bottom: 80px;
  }
}
.bc-career .career-title {
  font-weight: bold;
  margin-bottom: 10px;
}
@media screen and (max-width: 768px) {
  .bc-career {
    padding: 15px 20px 5px;
  }
}
@media screen and (max-width: 768px) {
  .bc-images {
    flex-direction: column;
    gap: 25px;
  }
  .bc-item {
    width: 100%;
  }
}
/*カットマンズ*/
@media screen and (min-width: 769px) {
  .toptxt-cutmans {
    padding: 15px;
    font-weight: bold;
    font-size: 22px;
  }
}
@media screen and (max-width: 768px) {
  .toptxt-cutmans {
    padding: 15px;
    font-weight: bold;
    font-size: 16px !important;
  }
}
.mens-program {
  position: relative;
  padding: 7%;
  background: url("../img/course/cutmans/cutmans_01.jpg") no-repeat left center;
  background-size: cover;
}
.mens-content-img {
  position: absolute;
  left: 0;
  bottom: 0;
  width: 40%;
  max-width: 426px;
}
.mens-content {
  width: 65%;
  margin-left: auto;
  color: #222;
}
.mens-content h3 {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 15px;
  padding-bottom: 10px;
  border-bottom: 1px solid #333;
}
@media screen and (max-width: 768px) {
  .mens-content {
    width: 100%;
  }
  .mens-program {
    padding: 5%;
    background-position: center;
  }
}
/*  */
.p-primebarbesec02.p-royalmakeupbesec02 {
  padding-bottom: 20px;
}
.p-royalmakeupbesec03 {
  padding: 0 20px;
  background-image: url(../img/course/makeup/sec03-bg.png);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center 200px;
  position: relative;
}
.p-royalmakeupbesec03 .img01 {
  position: absolute;
  top: 10%;
  left: 5%;
  width: 300px;
  height: auto;
}
.p-royalmakeupbesec03 .img02 {
  position: absolute;
  top: 40%;
  left: 5%;
  width: 300px;
}
.p-royalmakeupbesec03 .img03 {
  position: absolute;
  top: 26%;
  right: 5%;
  width: 330px;
}
.p-royalmakeupbesec03 .img04 {
  position: absolute;
  top: 68%;
  right: 15%;
  width: 150px;
}
@media screen and (max-width: 1400px) {
  .p-royalmakeupbesec03 .img01 {
    left: -3%;
    /* width: 250px; */
  }
  .p-royalmakeupbesec03 .img02 {
    left: 0%;
  }
  .p-royalmakeupbesec03 .img03 {
    right: 0%;
  }
  .p-royalmakeupbesec03 .img04 {
    right: 5%;
  }
}
@media screen and (max-width: 768px) {
  .p-royalmakeupbesec03 .img01, .p-royalmakeupbesec03 .img02, .p-royalmakeupbesec03 .img03, .p-royalmakeupbesec03 .img04 {
    display: none;
  }
}

.bg-gradient {
  background: linear-gradient(180deg, #FFEFE2 0%, #FBE3A0 100%);
}
.p-royalmakeupbesec04 {
  background: #FAB37A;
  padding: 200px 20px 100px;
  clip-path: polygon(100% 5%, 100% 95%, 0% 100%, 0% 0%);
}
.p-royalmakeupbesec04 {
  margin-top: -150px;
}
.p-royalmakeupbesec04-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-gap: 20px;
}
.p-royalmakeupbesec04_box .midtxt01 {
  font-weight: 700;
  font-size: 18px;
  color: #000;
  line-height: 2;
}
.p-royalmakeupbesec04_box .midtxt02 {
  font-weight: 500;
  font-size: 16px;
  color: #000;
  line-height: 1.5;
  margin-bottom: 20px;
}
.p-royalmakeupbesec04_box .midtxt03 {
  font-weight: 500;
  font-size: 16px;
  color: #000;
  line-height: 1.5;
  margin-top: 20px;
  margin-bottom: 5px;
}
.p-royalmakeupbesec04_box .athuerimg {
  max-width: 70px;
  width: 100%;
  margin: 0;
}
.p-royalmakeupbesec04_box .athuerimg img {
  margin: 0;
}
.p-royalmakeupbesec04_box .p-primebarbesec02_head p {
  color: #fff;
}
.p-royalmakeupbesec04_box .p-primebarbesec02_head img {
  filter: invert(1);
}
.p-royalmakeupbesec04_box .p-primebarbesec02_head_text {
  align-items: stretch;
  gap: 10px;
}
.p-royalmakeupbesec04-link {
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-royalmakeupbesec04-link a {
  background: #C43E48;
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 15px;
  padding-right: 30px;
  border-left: 20px solid #000;
  position: relative;
}
.p-royalmakeupbesec04-link a::after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: -20px;
  width: 40px;
  height: 15px;
  background-image: url(../img/course/makeup/arrow.png);
  background-repeat: no-repeat;
  background-size: contain;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .p-royalmakeupbesec04-link a:hover::after {
    right: -30px;
  }
}
.p-royalmakeupbesec04-link a img {
  width: 60px;
}
.p-royalmakeupbesec04-link a .txt01 {
  font-weight: bold;
  font-size: 20px;
  color: #fff;
  margin-bottom: 5px;
}
.p-royalmakeupbesec04-link a .txt02 {
  font-weight: 500;
  font-size: 16px;
  color: #fff;
  margin: 0;
}
@media screen and (max-width: 768px) {
  .p-royalmakeupbesec04 {
    padding: 150px 20px 70px;
    clip-path: polygon(100% 3%, 100% 97%, 0% 100%, 0% 0%);
  }
  .p-royalmakeupbesec04-grid {
    grid-template-columns: 1fr;
    grid-gap: 10px;
  }
  .p-royalmakeupbesec04_box .midtxt01 {
    font-size: 16px;
    line-height: 1.7;
  }
  .p-royalmakeupbesec04_box .midtxt02 {
    font-size: 14px;
  }
  .p-royalmakeupbesec04_box .midtxt03 {
    font-weight: 500;
    font-size: 16px;
    color: #000;
    line-height: 1.5;
    margin-top: 20px;
    margin-bottom: 5px;
  }
  .p-royalmakeupbesec04_box .athuerimg {
    max-width: 70px;
    width: 100%;
    margin: 0;
  }
  .p-royalmakeupbesec04_box .athuerimg img {
    margin: 0;
  }
  .p-royalmakeupbesec04_box .p-primebarbesec02_head p {
    color: #fff;
  }
  .p-royalmakeupbesec04_box .p-primebarbesec02_head img {
    filter: invert(1);
  }
  .p-royalmakeupbesec04_box .p-primebarbesec02_head_text {
    align-items: stretch;
    gap: 10px;
  }
  .p-royalmakeupbesec04-link a {
    gap: 10px;
    padding: 10px;
    padding-right: 15px;
    border-left: 5px solid #000;
    position: relative;
  }
  .p-royalmakeupbesec04-link a::after {
    right: -10px !important;
    width: 25px;
    height: 10px;
  }
  .p-royalmakeupbesec04-link a img {
    width: 40px;
  }
  .p-royalmakeupbesec04-link a .txt01 {
    font-size: 13px;
  }
  .p-royalmakeupbesec04-link a .txt02 {
    font-size: 12px;
  }
  .p-royalmakeupbesec04_box .p-primebarbesec02_head_text {
    align-items: flex-end;
    gap: 0px;
  }
}
/* Cutsman */
.p-cutmansprogram02 .p-primebarbesec02_body {
  margin-top: 100px;
}
@media screen and (max-width: 768px) {
  .p-cutmansprogram02 .p-primebarbesec02_body {
    margin-top: 50px;
  }
  .mens-program {
    display: flex;
    flex-direction: column-reverse;
    align-items: center;
    gap: 30px;
    padding-bottom: 0;
    background: url(../img/course/cutmans/cursmans-bg-sp.png);
    background-position: bottom;
    background-repeat: no-repeat;
    background-size: cover;
  }
  .mens-content-img {
    position: initial;
    width: 100%;
    max-width: 100%;
  }
}
/*スペシャリスト*/
@media screen and (min-width: 769px) {
  .curriculun-under {
    line-height: 2em;
  }
  .exam-heading-specialist {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-specialist::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #4EAFB1;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title-specialist {
    background: #4EAFB1;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 768px) {
  .curriculun-under {
    line-height: 1.5em;
  }
  .curriculun-under .badge-label {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: -20px;
  }
  .exam-heading-specialist {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-specialist::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #4EAFB1;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title-specialist {
    background: #4EAFB1;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 20px;
  }
}
.relative {
  position: relative;
}
@media screen and (min-width: 769px) {
  .specialty {
    position: absolute;
    top: 0;
    right: 0;
    max-width: 380px;
    width: 40%;
  }
  .specialty img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .specialty {
    position: absolute;
    top: 15px;
    right: 0;
    max-width: 380px;
    width: 40%;
  }
  .specialty img {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .dryer {
    position: absolute;
    left: -60px;
    bottom: -40px;
    width: 10%;
    max-width: 248px;
  }
  .dryer img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .dryer {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 5%;
    max-width: 248px;
  }
  .dryer img {
    width: 100%;
  }
}
.category_buttons {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px 20px;
  list-style: none;
  padding: 0;
  margin: 4% 0 4% 0;
}
.category_buttons li a {
  display: block;
  position: relative;
  padding: 5px 40px 5px 20px;
  border-radius: 50px;
  border: 3px solid #f2578f;
  background: linear-gradient(90deg, #FEF36F 0%, #FFC9E1 100%);
  text-decoration: none;
  transition: 0.3s;
}
.category_buttons li a:hover {
  background: linear-gradient(90deg, #FFC9E1 0%, #FEF36F 100%);
}
.category_buttons .arrow {
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: #f2578f;
  border-radius: 50%;
}
.category_buttons .arrow::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 5px;
  width: 6px;
  height: 6px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: rotate(45deg);
}
@media screen and (min-width: 769px) {
  .category_buttons .title {
    display: block;
    font-size: 16px;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #f2578f;
    border-bottom: 2px solid #f2578f;
    padding-bottom: 3px;
  }
  .category_buttons .num {
    display: block;
    margin-top: 3px;
    font-size: 14px;
    color: #f2578f;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
}
@media screen and (max-width: 768px) {
  .category_buttons .title {
    display: block;
    font-size: 14px;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
    color: #f2578f;
    border-bottom: 2px solid #f2578f;
    padding-bottom: 3px;
  }
  .category_buttons .num {
    display: block;
    margin-top: 3px;
    font-size: 14px;
    color: #f2578f;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: bold;
  }
  .category_buttons {
    grid-template-columns: 1fr;
  }
}
@media screen and (min-width: 769px) {
  .acd {
    padding-top: 20px !important;
  }
}
@media screen and (max-width: 768px) {
  .acd {
    padding-top: 10px !important;
  }
}
.acd {
  margin-bottom: 20px !important;
}
.acd .acd-body {
  display: none;
}
.acd.open .acd-body {
  display: block;
}
@media screen and (min-width: 769px) {
  .acd .bc-header h3 {
    position: relative;
    cursor: pointer;
    padding-right: 40px;
  }
  .acd .bc-header h3::after {
    content: "+";
    position: absolute;
    right: 10px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 28px;
    font-weight: bold;
    color: #000;
  }
  .acd.open .bc-header h3::after {
    content: "−";
  }
}
@media screen and (max-width: 768px) {
  .acd .bc-header {
    padding-bottom: 0 !important;
  }
  .acd .bc-header h3 {
    position: relative;
    cursor: pointer;
    padding-right: 0 !important;
  }
  .acd .bc-header h3::after {
    content: "+";
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    font-size: 28px;
    font-weight: bold;
    color: #000;
  }
  .acd.open .bc-header h3::after {
    content: "−";
  }
}
.acd .course-grid {
  display: none;
}
.acd.open .course-grid {
  display: grid;
}
@media screen and (min-width: 769px) {
  .read-ph {
    border-top: 1px solid #000;
    padding-top: 15px;
    margin-top: 10px;
  }
  .course-card {
    margin-top: 30px;
  }
  .course-img {
    position: relative;
  }
  .course-img .course-card-num {
    position: absolute;
    top: -35px;
    left: 15px;
    color: #31C3C6;
    font-size: 48px;
    font-family: "Anton SC", serif;
    letter-spacing: 0.1em;
  }
}
@media screen and (max-width: 768px) {
  .read-ph {
    border-top: 1px solid #000;
    padding-top: 15px;
    margin-top: 10px;
    margin-bottom: 35px;
  }
  .bc-header h3 .jp {
    margin-top: 0 !important;
    display: block;
  }
  .course-img {
    position: relative;
  }
  .course-img .course-card-num {
    position: absolute;
    top: -25px;
    left: 15px;
    color: #31C3C6;
    font-size: 38px;
    font-family: "Anton SC", serif;
    letter-spacing: 0.1em;
  }
}
@media screen and (min-width: 769px) {
  .anchor-offset {
    display: block;
    height: 118px;
    margin-top: -118px;
  }
  .specialist-box {
    width: 92%;
    max-width: 1000px;
    margin-left: auto;
    margin-right: auto;
    border: 4px solid #fff;
    background: rgba(255, 255, 255, 0.30);
    padding: 4% 8%;
  }
}
@media screen and (max-width: 768px) {
  .anchor-offset {
    display: block;
    height: 30px;
    margin-top: -30px;
  }
  .specialist-box {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    border: 4px solid #fff;
    background: rgba(255, 255, 255, 0.30);
    padding: 2%;
  }
  .acd .bc-header h3 .en {
    font-size: 17px !important;
    display: block !important;
  }
  .acd .bc-header h3 .jp {
    font-size: 14px !important;
    display: block !important;
    margin-bottom: -5px !important;
  }
}
.specialist-box .p-royalmakeupbesec04-link a {
  width: 100% !important;
}
.specialist-box .p-royalmakeupbesec04-link {
  margin-bottom: 3%;
}
@media screen and (max-width: 768px) {
  .sp-specialist-mgt {
    margin-top: -100px;
  }
}
/*美容・理容通信コース*/
.cost-box .red {
  color: #FF2C2C;
}
.days-list {
  margin-bottom: 40px;
}
.days-list li {
  margin-bottom: 8px;
  color: #000;
  font-weight: medium !important;
}
.point-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
}
@media screen and (min-width: 769px) {
  .point-title {
    background: #FDF050;
    font-weight: bold;
    text-align: center;
    padding: 12px;
    margin-bottom: 15px;
    letter-spacing: 2px;
    font-size: 20px;
  }
}
@media screen and (max-width: 768px) {
  .point-title {
    background: #FDF050;
    font-weight: bold;
    text-align: center;
    padding: 12px;
    margin-bottom: 15px;
    letter-spacing: 2px;
    font-size: 16px;
  }
}
.point-box h3 {
  border-bottom: 1px solid #333;
  padding-bottom: 8px;
  margin-bottom: 15px;
  font-weight: bold;
  font-size: 18px;
}
@media screen and (max-width:768px) {
  .point-box h3 {
    font-size: 16px;
  }
}
.cost-box .price span {
  display: inline !important;
}
.cost-box .yen span {
  display: inline !important;
  ;
}
@media screen and (min-width: 961px) {
  .cost-boxes {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 30px;
    margin-bottom: 20px;
  }
  .cost-box {
    border: 1px solid #333;
    padding: 20px;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 10px;
  }
  .section-title {
    background: #FDF050;
    text-align: center;
    font-size: 20px;
    font-weight: bold;
    padding: 12px 10px;
    margin: 40px 0 30px;
  }
  .cost-box .period {
    font-weight: bold;
    font-size: 20px;
  }
  .cost-box .price {
    font-size: 52px;
    font-family: serif;
    line-height: 1;
  }
  .cost-box .yen {
    font-size: 20px;
    font-weight: bold;
  }
  .cost-box p {
    margin: 0;
  }
  .point-box-img {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .point-box-img img {
    width: 100%;
  }
  .pcNone {
    display: none !important;
  }
  .cprres-top {
    padding-top: 1% !important;
  }
}
@media screen and (max-width:960px) {
  .cost-boxes {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
    margin-bottom: 20px;
  }
  .cost-box {
    border: 1px solid #333;
    padding: 15px;
    text-align: center;
  }
  .section-title {
    background: #FDF050;
    text-align: center;
    font-size: 16px;
    font-weight: bold;
    padding: 12px 10px;
    margin: 40px 0 30px;
  }
  .cost-box .period {
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 10px;
  }
  .cost-box .price {
    font-size: 28px;
    font-family: serif;
    line-height: 1;
    margin: 0 0 10px;
  }
  .cost-box .yen {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 0 !important;
  }
  .point-box-img {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  .point-box-img img {
    width: 100%;
  }
  .cost-boxes {
    grid-template-columns: 1fr;
  }
  .point-grid {
    grid-template-columns: 1fr;
  }
  .spNone {
    display: none !important;
  }
  .cprres-top {
    padding-top: 20px !important;
  }
}
@media screen and (min-width: 769px) {
  .exam-required-cprres {
    padding: 25px 25px 15px;
    background: #ffffff;
    margin-bottom: 4%;
    position: relative;
    z-index: 2;
  }
}
@media screen and (max-width: 768px) {
  .exam-required-cprres {
    padding: 15px !important;
    background: rgba(255, 255, 255, 0.70);
    margin-bottom: 4%;
  }
}
/*ワーキングアカデミー*/
.working-a-bg {
  background-image: url(../img/course/workingacademy/working-a-bg.png) !important;
}
@media screen and (max-width: 960px) {
  .working-a-bg {
    background-image: url(../img/course/workingacademy/working-a-bg-sp.png) !important;
  }
}
@media screen and (max-width: 768px) {
  .working-box.pd-4 {
    padding-bottom: 30px !important;
  }
}
@media screen and (max-width: 960px) {
  .section-blue-working {
    display: none;
  }
  .pc-mgt--30 {
    background: #fff !important;
    margin-top: 0 !important;
    padding-top: 20px !important;
  }
}
@media screen and (min-width: 769px) {
  .exam-heading-working-a {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-working-a::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #DC75A3;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title-working-a {
    background: #DC75A3;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 768px) {
  .exam-heading-working-a {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-working-a::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #DC75A3;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .exam-title-working-a {
    background: #DC75A3;
    color: #fff;
    text-align: center;
    padding: 10px 25px;
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 20px;
  }
}
.service-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 60px;
  margin-top: 40px;
}
.service-item {
  text-align: center;
}
.service-img {
  width: 100%px;
  margin: 0 auto 25px;
  border-radius: 50%;
  overflow: hidden;
}
.service-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media screen and (min-width: 769px) {
  .service-title {
    font-size: 18px;
    font-weight: bold;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #333;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
@media screen and (max-width: 768px) {
  .service-title {
    font-size: 16px;
    font-weight: bold;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px solid #333;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}
.service-text {
  font-size: 16px;
  text-align: left;
  width: 100%;
  margin: 15px auto 0;
}
@media screen and (max-width:768px) {
  .service-grid {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .service-img {
    width: 90%;
  }
}
@media screen and (max-width: 768px) {
  .working-a-bg {
    padding-bottom: 30px !important;
  }
}
@media screen and (min-width:769px) {
  .support-txt {
    width: 40%;
    max-width: 330px;
    margin-left: 2%;
  }
  .support-txt img {
    width: 100%;
  }
  .pd-4 {
    padding: 4% !important;
  }
  .scissors-img {
    position: absolute;
    right: 3%;
    bottom: -6%;
    max-width: 545px;
  }
  .scissors-img img {
    width: 100%;
  }
  .ftpink {
    color: #DC75A3;
    text-align: center;
    font-weight: bold;
    font-size: 18px;
    margin-top: 4%;
    margin-bottom: 4%;
  }
}
@media screen and (max-width:768px) {
  .bg-blue-area {
    padding-top: 100px !important;
  }
  .support-txt {
    width: 40%;
    margin-left: 2%;
    padding-top: 6%;
  }
  .support-txt img {
    width: 100%;
  }
  .pd-4 {
    padding-top: 20px !important;
    padding-bottom: 110px !important;
  }
  .scissors-img {
    position: absolute;
    right: -15px;
    bottom: -15px;
    width: 60%;
  }
  .scissors-img img {
    width: 100%;
  }
  .ftpink {
    color: #DC75A3;
    text-align: center;
    font-weight: bold;
    font-size: 16px;
    margin-top: 25px;
    margin-bottom: 25px;
  }
}
.income-box {
  display: flex;
  align-items: stretch;
  gap: 6px;
  flex-wrap: nowrap;
  width: 100%;
}
.income-label, .income-item, .income-value, .income-result {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 64px;
  box-sizing: border-box;
  white-space: nowrap;
}
.income-label.black {
  background: #000;
  color: #fff;
  padding: 0 12px;
  font-weight: bold;
  font-size: 16px;
}
.income-item.blue {
  background: #8FA3B8;
  padding: 0 12px;
  font-weight: bold;
  font-size: 14px;
  text-align: center;
}
.income-value {
  border: 2px solid #8FA3B8;
  padding: 0 18px;
  font-size: 20px;
  font-weight: 600;
}
.income-symbol {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
  font-weight: bold;
  width: 26px;
}
.income-result {
  background: #F0E34A;
  padding: 0 28px;
  font-size: 34px;
  font-weight: bold;
  flex: 1;
}
@media screen and (max-width:768px) {
  .income-box {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr);
    gap: 10px;
    width: 100%;
  }
  .income-label {
    grid-column: 1 / -1;
    margin-bottom: 3%;
  }
  .income-item.blue:nth-of-type(1) {
    grid-column: 1;
  }
  .income-value:nth-of-type(1) {
    grid-column: 2;
  }
  .income-symbol.plus {
    grid-column: 1 / -1;
  }
  .income-item.blue:nth-of-type(2) {
    grid-column: 1;
  }
  .income-value:nth-of-type(2) {
    grid-column: 2;
  }
  .income-symbol.equal {
    grid-column: 1 / -1;
  }
  .income-item.blue:nth-of-type(3) {
    grid-column: 1;
  }
  .income-result {
    grid-column: 2;
    height: 65px;
  }
  .income-box *, .income-box *::before, .income-box *::after {
    box-sizing: border-box;
  }
}
@media screen and (max-width:768px) {
  .income-box {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr);
    gap: 10px;
    width: 100%;
  }
  .income-value {
    white-space: normal;
    font-size: 16px;
    line-height: 1.4;
    padding: 0 12px;
  }
  .income-symbol.plus, .income-symbol.equal {
    grid-column: 1 / -1;
    justify-self: center;
    width: auto;
  }
  .income-result {
    font-size: 20px;
  }
}
.ph-s-1 {
  max-width: 600px;
  margin-left: auto;
  margin-top: 3%;
}
.schoolcost-wrap {
  display: grid;
  grid-template-columns: 1fr 70px 1fr;
  gap: 15px;
  align-items: center;
  margin-top: 6%;
}
.schoolcost-wrap > div:first-child, .schoolcost-wrap > div:last-child {
  align-self: flex-start;
}
.schoolcost-title {
  display: inline-block;
  background: #BFD4EC;
  padding: 10px 20px;
  font-weight: bold;
  margin-bottom: 15px;
}
.schoolcost-box {
  border: 2px solid #4495D0;
}
.schoolcost-head {
  background: #FEF36D;
  padding: 12px;
  text-align: center;
  font-weight: bold;
  height: 50px;
}
.schoolcost-table {
  display: grid;
  grid-template-columns: 180px 1fr;
}
.schoolcost-cell {
  padding: 12px;
  border-top: 1px solid #4495D0;
  colro: #000;
  font-weight: bold;
}
.schoolcost-cell:nth-child(odd) {
  border-right: 1px solid #4495D0;
  text-align: center;
}
.schoolcost-price {
  text-align: right;
  font-weight: bold;
}
.schoolcost-arrow {
  text-align: center;
}
.schoolcost-arrow svg {
  width: 70px;
  height: auto;
}
@media screen and (min-width:769px) {
  .mg-t-4 {
    margin-top: 80px !important;
  }
}
@media screen and (max-width:768px) {
  .schoolcost-wrap {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .schoolcost-arrow {
    transform: rotate(90deg);
  }
}
@media screen and (max-width: 768px) {
  .schoolcost-table {
    grid-template-columns: 80px 1fr;
  }
}
.bdl-5 {
  border-left: 7px solid #FEF36D;
  padding-left: 13px;
}
.pgl-20 {
  padding-left: 20px;
  margin-top: 10px !important;
}
@media screen and (min-width: 769px) {
  .abs-top {
    position: relative !important;
    margin-left: auto !important;
    margin-top: -230px !important;
  }
  .og-voice {
    width: 50%;
    max-width: 460px;
    position: absolute;
    top: -120px;
    right: 20px;
  }
  .mainimg {
    position: relative !important;
  }
  .sisor2 {
    position: absolute !important;
    right: -360px !important;
    top: -120px !important;
    width: 450px !important;
  }
  .sisor3 {
    position: absolute !important;
    left: -360px !important;
    bottom: 0 !important;
    width: 480px !important;
  }
  .pc-mgt--30 {
    margin-top: -30px;
  }
  .pc-mgt--100 {
    margin-top: -100px;
  }
}
@media screen and (max-width: 768px) {
  .mainimg {
    position: relative !important;
  }
  .sisor2 {
    position: absolute !important;
    right: 0 !important;
    top: -50px !important;
    width: 150px !important;
  }
  .abs-top {
    position: relative !important;
    margin-top: -130px !important;
  }
  .og-voice {
    width: 80% !important;
    position: absolute;
    top: -70px;
    right: 0;
  }
  .sp-voice-area {
    margin-top: 170px !important;
  }
  .sisor3 {
    position: absolute !important;
    right: -20px !important;
    bottom: -100px !important;
    width: 230px !important;
  }
}
.section-blue {
  position: relative;
  background: #3A8AC8;
  padding: 0 0;
}
.section-blue::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -80px;
  width: 100%;
  height: 120px;
  background: #3A8AC8;
  transform: skewY(-3deg);
  transform-origin: left;
}
/*取得者コース*/
.acquiror-h5 {
  font-weight: bold;
  border-bottom: 1px solid #000;
  padding-bottom: 14px;
  margin-bottom: 16px;
  margin-top: 20px;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .acquiror-h5 {
    text-align: center;
    margin-top: 10px;
  }
}
@media screen and (min-width: 769px) {
  .exam-heading-acquiror {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-acquiror::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #FDF050;
    position: absolute;
    left: 0;
    top: 2px;
  }
  .acquiror-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }
}
@media screen and (min-width: 769px) {
  .exam-card-illust img {
    width: 70%;
  }
}
@media screen and (max-width: 768px) {
  .exam-card-illust {
    margin-left: -20px;
  }
  .exam-card-illust img {
    width: 45% !important;
  }
}
@media screen and (max-width: 768px) {
  .exam-heading-acquiror {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-acquiror::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #FDF050;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
/*ブライダルウェディング*/
.bridal-bg {
  background-image: url(../img/course/bridalwedding/bridal_06.png) !important;
}
@media screen and (min-width: 769px) {
  .exam-heading-bridal {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-bridal::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #B9435A;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
@media screen and (max-width: 768px) {
  .exam-heading-bridal {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-bridal::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #B9435A;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
.bridal-box.special {
  background: #FDF7AB;
}
.note {
  font-size: 13px;
}
@media screen and (min-width: 769px) {
  .bridal-text {
    font-size: 18px !important;
    text-align: left;
    line-height: 1.5;
  }
  .bridal-flow {
    border: 2px solid #713CC8;
    padding: 50px 40px;
    font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
    text-align: center;
    width: 100% !important;
  }
  .bridal-title {
    background: #A670A7;
    color: #fff;
    display: inline-block;
    padding: 15px 50px;
    font-weight: bold;
    margin: 0 auto 40px;
    text-align: center;
    font-size: 20px;
  }
  .bridal-top {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 30px;
    margin-bottom: 40px;
  }
  .bridal-box {
    padding: 25px 70px;
    border: 2px solid #A670A7;
    font-weight: bold;
    font-size: 20px;
  }
  .bridal-plus {
    width: 40px;
    display: flex;
  }
  .bridal-plus img {
    width: 100%;
  }
  .bridal-steps {
    display: flex;
    align-items: stretch;
    justify-content: center;
    gap: 30px;
    margin-bottom: 40px;
  }
  .step {
    background: #A670A7;
    color: #fff;
    border-radius: 8px;
    position: relative;
    flex: 1;
  }
  .step-inner {
    padding: 30px 25px 20px;
  }
  .step h4 {
    font-size: 20px;
    text-align: center;
    margin-bottom: 20px;
    line-height: 1.4;
    font-weight: bold;
  }
  .step p {
    font-size: 16px;
    line-height: 1.5;
    color: #fff;
    text-align: left;
  }
  .arrow-wedding {
    width: 35px;
    position: absolute;
    top: 50px;
    right: -30px;
  }
  .arrow-wedding img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .bridal-text {
    font-size: 16px;
    text-align: left;
    line-height: 1.5;
  }
  .bridal-flow {
    border: 2px solid #713CC8;
    padding: 4%;
    font-family: "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
    text-align: center;
  }
  .bridal-title {
    background: #A670A7;
    color: #fff;
    display: inline-block;
    padding: 15px 25px;
    font-weight: bold;
    margin: 0 auto 40px;
    text-align: center;
    font-size: 18px;
  }
  .bridal-top {
    margin-bottom: 40px;
  }
  .bridal-box {
    padding: 4% 0;
    border: 2px solid #A670A7;
    font-weight: bold;
    font-size: 17px;
    width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
  .bridal-plus {
    width: 25px;
    margin-left: auto;
    margin-right: auto;
    margin-top: 2%;
    margin-bottom: 2%;
  }
  .bridal-plus img {
    width: 100%;
  }
  .bridal-steps {}
  .step {
    background: #A670A7;
    color: #fff;
    border-radius: 8px;
    position: relative;
    width: 100%;
    margin-bottom: 40px;
  }
  .step-inner {
    padding: 15px 12.5px 10px;
  }
  .step h4 {
    font-size: 17px;
    text-align: center;
    margin-bottom: 20px;
    line-height: 1.4;
    font-weight: bold;
  }
  .step p {
    font-size: 14px !important;
    line-height: 1.5;
    color: #fff;
    text-align: left;
  }
  .arrow-wedding {
    width: 25px;
    position: absolute;
    bottom: -30px;
    left: 50%;
    transform: translateX(-50%);
  }
  .arrow-wedding img {
    width: 100%;
    transform: rotate(90deg);
  }
}
.center {
  text-align: center;
}
.flower-illust {
  width: 80%;
  max-width: 410px;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 2%;
}
.flower-illust img {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .abs-left {
    display: inline !important;
    width: 25px !important;
  }
  .abs-right {
    display: inline !important;
    width: 25px !important;
  }
}
@media screen and (max-width: 768px) {
  .abs-left {
    position: absolute;
    left: 0;
    bottom: 0;
    transform_: translateY(-50%);
    display: inline !important;
    width: 20px !important;
  }
  .abs-right {
    position: absolute;
    right: 0;
    bottom: 0;
    transform_: translateY(-50%);
    display: inline !important;
    width: 20px !important;
  }
}
.imgsize {
  max-width: 30%;
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 769px) {
  .ft22 {
    font-size: 22px;
    font-weight: bold;
  }
  .ft26 {
    font-size: 26px;
    font-weight: bold;
    color: #F32121;
  }
  .bridal-h4 {
    background: #E5CBDF;
    font-weight: bold;
    text-align: center;
    padding-top: 7px;
    padding-bottom: 7px;
    font-size: 17px;
    margin-bottom: 10px;
  }
  .special-txt {
    width: 50% !important;
  }
}
@media screen and (max-width: 768px) {
  .ft22 {
    font-size: 17px;
    font-weight: bold;
  }
  .ft26 {
    font-size: 18px;
    font-weight: bold;
    color: #F32121;
  }
  .bridal-h4 {
    background: #E5CBDF;
    font-weight: bold;
    text-align: center;
    padding-top: 7px;
    padding-bottom: 7px;
    font-size: 14px;
    margin-bottom: 10px;
  }
  .special-txt {
    width: 70% !important;
  }
}
.bridalwedding__head {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}
.bridalwedding__head p {
  font-weight: bold;
  font-size: 34px;
  letter-spacing: 0.01em;
  text-align: center;
  color: #000000;
  position: relative;
}
.bridalwedding__head .badge-label {
  background-color: #FFE833;
  border-radius: 999px;
  padding: 8px 24px;
  font-weight: 700;
  font-size_: 16px;
  white-space: nowrap;
  width: fit-content;
  flex-basis: 100%;
  text-align: center;
  font-size: 34px;
  flex-basis: auto;
  margin-bottom: 40px;
}
@media screen and (max-width: 768px) {
  .bridalwedding__head .badge-label {
    font-size: 20px;
    margin-bottom: 30px;
  }
}
.bridalwedding__head_text {
  display: flex;
  align-items: flex-end;
}
.bridalwedding__head_text .deco-left, .bridalwedding__head_text .deco-right {
  width: 45px;
  height: 61px;
  flex-shrink: 0;
}
@media screen and (max-width: 960px) {
  .bridalwedding__head_text .deco-left, .bridalwedding__head_text .deco-right {
    width: 20px;
    height: 40px;
  }
}
@media screen and (min-width: 769px) {
  .pc-mgt--100 {
    margin-top: 50px !important;
  }
}
@media screen and (max-width: 768px) {
  .bridal-voice {
    margin-top: 10px !important;
  }
}
.course-text.course-text-toggle {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  line-height: 1.5em;
  height: 3em;
  -webkit-line-clamp: 2;
  transition: 0.3s;
}
.course-text.course-text02 {
  margin-top: 20px;
}
.exam-card.open .course-text-toggle {
  height: auto;
  -webkit-line-clamp: unset;
}
/* Wedding */
.bridalwedding01 {
  padding-bottom: 100px !important;
}
.bridalwedding03 {
  padding-bottom: 50px;
  clip-path: polygon(0 0%, 100% 0, 100% 100%, 0 100%);
}
@media screen and (min-width: 769px) {
  .bridalwedding02 {
    clip-path: polygon(0 3%, 100% 0, 100% 100%, 0 97%);
    padding-top: 200px;
  }
  .mgtop {
    margin-top: -150px;
  }
}
@media screen and (max-width: 768px) {
  .bridalwedding02 {
    clip-path: polygon(0 3%, 100% 0, 100% 100%, 0 97%);
    padding-top: 50px;
    padding-bottom: 50px;
  }
  .mgtop {
    margin-top: -100px;
  }
  .mgtop-2 {
    margin-top: -70px;
  }
}
@media screen and (max-width: 768px) {
  .bridalwedding02 {
    clip-path: polygon(0 1%, 100% 0, 100% 100%, 0 99%);
    padding-top: 150px;
  }
  .bridalwedding01 {
    padding-bottom: 50px !important;
  }
  .bridalwedding01 .bridal-title {
    font-size: 16px;
  }
  .bridalwedding01 .bridal-box {
    font-size: 15px;
  }
  .bridalwedding02 .exam-card02 .bridal-h4 {
    margin-bottom: 20px;
  }
}
.wd100 {
  width: 100% !important;
}
.bridal-more {
  display: block !important;
  text-align: right !important;
  width: 100px;
  margin-left: auto;
}
/*トータルエステティック*/
.total-bg {
  background-image: url(../img/course/totalesthetic/total_09.png) !important;
}
.mgt-3 {
  margin-top: 3% !important;
}
@media screen and (min-width: 769px) {
  .mgt-150 {
    margin-top: 150px !important;
  }
  .hw_vector {
    position: absolute;
    top: -100px;
    right: -30px;
    width: 60%;
    max-width: 680px;
  }
  .hw_vector img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .mgt-150 {
    margin-top: 80px !important;
  }
  .sp-pd0 {
    padding-top: 0 !important;
    margin-top: 30px !important;
  }
  .hw_vector {
    position: absolute;
    top: -60px;
    right: 0;
    width: 90%;
    max-width: 680px;
  }
  .hw_vector img {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .exam-heading-total {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-total::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #9E6CBA;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
@media screen and (max-width: 768px) {
  .exam-heading-total {
    font-size: 18px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-total::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #9E6CBA;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
.total-h6 {
  font-weight: bold;
  margin-top: 15px;
}
.pinkline {
  border: 4px solid #E5CBDF;
  padding: 10px;
  margin-bottom: 15px;
}
@media screen and (min-width: 769px) {
  .total_r-b {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 60%;
    max-width: 300px;
  }
  .total_r-b img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .total_r-b {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
  .sp-mgt-30 {
    margin-top: 30px
  }
}
.total_r-b img {
  width: 100%;
}
.equipment {
  width: 65%;
  max-width: 420px;
  margin-left: auto;
}
.equipment img {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .esthe-p {
    font-weight: bold;
    font-size: 18px;
  }
  .realsalon {
    color: #F74F7A;
    font-size: 24px;
  }
  .flw {
    position: absolute;
    right: 80px;
    bottom: 60px;
    width: 50%;
    max-width: 600px;
  }
  .flw img {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .esthe-p {
    font-weight: bold;
    font-size: 16px;
  }
  .realsalon {
    color: #F74F7A;
    font-size: 18px;
  }
}
.total-bg {
  background-size: 100% !important;
}
/* Globalbeauty */
.course-features.global {
  background: #F5B731;
}
.course-features.global .course-box {
  border: none;
}
.course-features.global .course-label {
  background: #F5B731;
}
.course-features.global .course-box h3 {
  min-height: 2.8em;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2.5rem;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  .course-features.global .course-box {
    padding: 5%;
  }
  .course-features.global .course-label {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
  .course-features.global .course-box h3 {
    min-height: auto;
    margin-top: 1.5rem;
    margin-bottom: 1.5rem;
    font-size: 18px;
  }
}
.global-study {
  margin-top: 40px;
}
.global-study-title {
  background: #F5D735;
  display: table;
  margin: 0 auto 20px;
  padding: 8px 40px;
  border-radius: 999px;
  font-weight: bold;
  font-size: 20px;
  text-align: center;
}
.global-study-text {
  font-size: 16px;
  line-height: 1.6;
  margin-bottom: 20px;
}
.global-study-imgs {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.global-study-imgs img {
  width: 100%;
  height: auto;
}
@media screen and (max-width: 768px) {
  .global-study-title {
    font-size: 16px;
    padding: 8px 30px;
  }
  .global-study-text {
    font-size: 14px;
  }
  .global-study-imgs {
    grid-template-columns: 1fr;
    gap: 15px;
  }
}
/* bbdoubleschool */
.double-school-grid {
  grid-template-columns: repeat(3, 1fr);
}
.double-school-grid .acquiror-h5 {
  text-align: left !important;
  min-height: 3em;
}
@media screen and (min-width: 769px) {
  .double-school-grid .acquiror-h5 {
    font-size: 18px;
  }
}
@media screen and (max-width: 768px) {
  .double-school-grid {
    grid-template-columns: 1fr !important;
  }
  .double-school-grid .acquiror-h5 {
    min-height: auto;
  }
}
/*韓国ダブルライセンス*/
.dlicens-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  width: 100%;
  margin: 50px auto 0;
}
.dlicens-card {
  background: #fff;
  border: 4px solid #D42C49;
  overflow_: hidden;
  display: flex;
  flex-direction: column;
}
.dlicens-card-header {
  padding: 14px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.dlicens-badge {
  display: inline-block;
  border: 2px solid #fff;
  border-radius: 50px;
  color: #fff;
  font-size: 19px;
  font-weight: bold;
  padding: 10px 0;
  width: 100%;
  background: #D42C49;
  text-align: center;
}
.dlicens-card-body {
  padding: 22px 24px 24px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.dlicens-card-title {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.5;
  text-align: center;
  color: var(--text);
}
.dlicens-card-text {
  font-size: 16px;
}
.dlicens-card-photo {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  display: block;
  margin-bottom: 4px;
}
@media (max-width: 640px) {
  .dlicens-grid {
    grid-template-columns: 1fr;
  }
  .dlicens-card-title {
    font-size: 15.5px;
  }
}
@media screen and (min-width: 769px) {
  .pdb-100 {
    padding-bottom: 250px;
  }
}
@media screen and (max-width: 768px) {
  .pdb-100 {
    padding-bottom: 150px;
  }
}
.dl-program {
  border: 2px solid #69C545;
  padding: 2%;
}
.dl-program img {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .dl-program h3 {
    color: #69C545;
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 15px;
  }
}
@media screen and (max-width: 768px) {
  .dl-program h3 {
    color: #69C545;
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.wl-page .sec_title h2::after {
  background-color: #fff !important;
}
@media screen and (min-width: 769px) {
  .sischoolbox {
    max-width: 970px !important;
    border-radius: 0 !important;
    border: none !important;
    background: #fff;
    padding: 3%;
    margin-left: auto;
    margin-top: -150px;
    z-index: 10;
    position: relative;
  }
}
@media screen and (max-width: 768px) {
  .sischoolbox {
    width: 100% !important;
    border-radius: 0 !important;
    border: none !important;
    background: #fff;
    padding: 3%;
    margin-left: auto;
    margin-top: 90px;
    z-index: 10;
    position: relative;
  }
}
.sischoolbox p {
  font-size: 16px !important;
}
@media screen and (min-width: 769px) {
  .sischoolbox-h4 {
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 10px;
  }
}
@media screen and (max-width: 768px) {
  .sischoolbox-h4 {
    font-weight: bold;
    font-size: 16px;
    margin-bottom: 10px;
  }
}
.mgt-3 {
  margin-top: 3%;
}
.sischoolbox-msg {
  padding: 60px 0;
  background: #fff;
}
.sischoolbox-name {
  margin-top: 20px;
  text-align: right;
}
.sischoolbox-inner-02 {
  padding: 2%;
}
@media screen and (max-width: 768px) {
  .sischoolbox-inner-02 p {
    font-size: 15px !important;
  }
}
.bbs-message {
  margin-top: 3%;
}
.bbs-message__wrap {
  max-width: 1000px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 40px;
}
.bbs-message__photo {
  flex: 0 0 220px;
}
.bbs-message__photo img {
  width: 100%;
  height: auto;
  display: block;
}
.bbs-message__content {
  flex: 1;
}
.bbs-message__content p {
  font-size: 16px;
}
@media screen and (max-width: 768px) {
  .bbs-message__content p {
    margin-top: -20px;
  }
}
.bbs-message__author {
  margin-top: 20px !important;
  text-align: right;
}
@media screen and (max-width: 768px) {
  .bbs-message__wrap {
    flex-direction: column;
    align-items: flex-start;
  }
  .bbs-message__photo {
    width: 100%;
  }
  .bbs-message__author {
    text-align: left;
  }
}
@media screen and (min-width: 769px) {
  .textbbs {
    position: absolute;
    top: -130px;
    right: 0;
    width: 50%;
  }
  .textbbs img {
    width: 100%;
  }
  .flwillust {
    position: absolute;
    left: -200px;
    bottom: -70px;
    max-width: 300px;
  }
}
@media screen and (max-width: 768px) {
  .textbbs {
    position: absolute;
    top: -70px;
    right: 0;
    width: 60%;
  }
  .textbbs img {
    width: 100%;
  }
  .flwillust {
    width: 40%;
    margin-left: auto;
  }
  .flwillust img {
    width: 40%;
    margin-left: auto;
    width: 100%;
  }
}
.mgb-0 {
  margin-bottom: 0 !important;
}
@media screen and (min-width: 769px) {
  .bbs-btn-group {
    display: flex;
    gap: 48px;
    flex-wrap: wrap;
    justify-content: flex-end;
    margin-top: 40px;
    margin-right: 3%;
  }
  .bbs-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 320px;
    padding: 18px 32px;
    border: 1.5px solid #fff;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: .1em;
    text-decoration: none;
    cursor: pointer;
    background: transparent;
    transition: background .25s ease;
  }
}
@media screen and (max-width: 768px) {
  .bbs-btn-group {
    display: flex;
    gap: 24px;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 30px;
  }
  .bbs-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 90%;
    padding: 16px 16px;
    border: 1.5px solid #fff;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    letter-spacing: .1em;
    text-decoration: none;
    cursor: pointer;
    background: transparent;
    transition: background .25s ease;
  }
}
.bbs-btn:hover {
  background: rgba(255, 255, 255, .06);
}
.bbs-btn::after {
  content: '';
  position: absolute;
  right: -20px;
  top: 50%;
  transform: translateY(-50%);
  width: 40px;
  height: 1.5px;
  background: #fff;
  transition: width .3s ease, right .3s ease;
}
.bbs-btn:hover::after {
  width: 56px;
  right: -36px;
}
.under_h2 {
  color: #fff;
  font-size: 24px;
  font-weight: bold;
  margin-top: 20px;
}
@media screen and (max-width: 768px) {
  .spmgb-0 {
    margin-top: 0 !important;
  }
}
.rohan-section {
  display: flex;
  align-items: stretch;
  gap: 48px;
  width: 100%;
  margin: 0 auto;
  padding: 48px 0 0;
}
.rohan-section__img {
  flex: 0 0 55%;
  max-width: 513px;
}
.rohan-section__img img {
  width: 100%;
  display: block;
}
.rohan-section__body {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  color: #fff;
}
.rohan-section__heading {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.rohan-section__title {
  font-size: 20px !important;
  font-weight: 900;
  color: #fff;
  margin-bottom: 0;
}
.rohan-section__subtitle {
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  margin-top: 0;
}
.rohan-section__text {
  font-size: 16px;
  color: #fff;
}
@media screen and (min-width: 769px) {
  .rohan-section__btn-wrap {
    display: flex;
    justify-content: flex-end;
  }
}
@media (max-width: 768px) {
  .rohan-section__btn-wrap {
    display: flex;
    justify-content: center;
  }
  .rohan-section {
    flex-direction: column;
  }
  .rohan-section__img {
    flex: none;
    max-width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .harivi-img-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    width: 100%;
    margin: 5% auto 0;
  }
}
@media screen and (max-width: 768px) {
  .harivi-img-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 6px;
    width: 100%;
    margin: 5% auto 0;
  }
}
.harivi-img-grid__item {
  overflow: hidden;
  aspect-ratio: 4 / 3;
}
.harivi-img-grid__item img {
  width: 100%;
  display: block;
}
@media (max-width: 640px) {
  .harivi-img-grid {
    grid-template-columns: 1fr;
  }
}
.kbeauty-section {
  display: grid;
  margin: 0 auto;
  margin-top: 3%;
  padding: 4%;
  background: #fff;
}
@media screen and (min-width: 769px) {
  .kbeauty-section__text-top {
    display: flex;
    flex-direction: column;
    gap: 20px;
    border-top: 1.5px solid #222;
    padding-top: 15px;
    margin-top: -80px !important;
  }
}
@media screen and (max-width: 768px) {
  .kbeauty-section__text-top {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding-top: 15px;
  }
}
.kbeauty-section__text-bottom {
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: center;
}
.kbeauty-section__img-top img, .kbeauty-section__img-bottom img {
  width: 100%;
  display: block;
}
@media screen and (min-width: 769px) {
  .kbeauty-section__heading {
    border-bottom_: 1.5px solid #222;
    padding-bottom: 0 !important;
  }
}
@media screen and (max-width: 768px) {
  .kbeauty-section__heading {
    border-bottom: 1.5px solid #222;
    padding-bottom: 16px;
  }
}
@media screen and (min-width: 769px) {
  .kbeauty-section__title {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: .05em;
  }
}
@media screen and (max-width: 768px) {
  .kbeauty-section__title {
    font-size: 18px;
    font-weight: 700;
    letter-spacing: .05em;
  }
}
.kbeauty-section__lead {
  font-size: 16px;
  margin-bottom: 0 !important;
}
.kbeauty-section__text {
  font-size: 16px;
  margin-top: 0 !important;
}
@media screen and (min-width: 769px) {
  .kbeauty-section {
    grid-template-areas:
      "heading    img-top"
      "text-top   img-top"
      "img-bottom text-bottom";
    grid-template-columns: 1fr 1fr;
    column-gap: 40px;
    row-gap: 0;
  }
  .kbeauty-section__heading {
    grid-area: heading;
    padding-bottom_: 16px;
    margin-bottom: 20px;
  }
  .kbeauty-section__text-top {
    grid-area: text-top;
    padding-bottom: 40px;
  }
  .kbeauty-section__img-top {
    grid-area: img-top;
    width: 90%;
    margin-left: auto;
  }
  .kbeauty-section__img-bottom {
    grid-area: img-bottom;
    width: 90%;
  }
  .kbeauty-section__text-bottom {
    grid-area: text-bottom;
  }
}
@media screen and (max-width: 768px) {
  .kbeauty-section {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .kbeauty-section__heading {
    order: 1;
  }
  .kbeauty-section__img-top {
    order: 2;
    width: 100%;
  }
  .kbeauty-section__text-top {
    order: 3;
  }
  .kbeauty-section__img-bottom {
    order: 4;
    width: 100%;
  }
  .kbeauty-section__text-bottom {
    order: 5;
  }
}
@media screen and (min-width: 769px) {
  .kbeauty-section__title {
    padding-bottom: 0 !important;
  }
  .kbeauty-section__heading {
    padding-bottom: 0 !important;
  }
}
@media screen and (min-width: 769px) {
  .voice__img {
    width: 30%;
    max-width: 324px;
  }
  .voice__content {
    width: 70%;
    border: 2px solid #D42C49;
    padding: 30px;
    border-radius: 8px;
  }
}
@media screen and (max-width: 768px) {
  .voice__img {
    width: 100%;
  }
  .voice__content {
    width: 100%;
    border: 1px solid #D42C49;
    padding: 10px;
    border-radius: 8px;
  }
}
.voice__inner {
  display: flex;
  gap: 40px;
  width: 100%;
  margin: 3% auto;
  align-items: flex-start;
}
.voice__img img {
  width: 100%;
  height: auto;
  display: block;
}
@media screen and (min-width: 769px) {
  .voice__title {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 20px;
  }
}
@media screen and (max-width: 768px) {
  .voice__title {
    font-size: 15px;
    font-weight: 700;
    margin-bottom: 10px;
  }
}
.voice__name {
  color: #D42C49;
  font-weight: 700;
  font-size: 18px;
  line-height: 1.5em;
  margin-bottom: 0 !important;
}
.voice__text {
  line-height: 1.7em;
  color: #000;
}
.reverse.voice__inner {
  flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .voice__inner {
    flex-direction: column;
  }
  .voice__img, .voice__content {
    width: 100%;
  }
  .voice__content {
    padding: 20px;
  }
  .reverse.voice__inner {
    flex-direction: column;
  }
}
.mgb_pdb-0 {
  margin-bottom: 0;
  padding-bottom: 0;
}
.mgt_pdt-0 {
  margin-top: 0;
  padding-top: 0;
}
@media (max-width: 768px) {
  .sp-mgt-50 {
    margin-top: 20px !important;
  }
}
@media screen and (min-width: 769px) {
  .bg-red-area_01 {
    position: relative;
    background: #D42C49;
    padding-bottom: 150px !important;
  }
  .bg-red-area_01::before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    width: 100%;
    height: 102px;
    background: #fff;
    clip-path: polygon(0 0, 100% 80%, 100% 0, 0 0);
  }
  .bg-red-area_01::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 150px;
    background: #10628a;
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0 100%);
  }
  .bg-red-area_02 {
    position: relative;
    background: #10628a;
    padding-bottom: 150px !important;
  }
  .bg-red-area_02::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100px;
    background: #D42C49;
    clip-path: polygon(0 0, 100% 80%, 100% 100%, 0 100%);
  }
  .bg-red-area_03 {
    background: #D42C49;
  }
}
@media screen and (max-width: 768px) {
  .bg-red-area_01 {
    position: relative;
    background: #D42C49;
    padding-bottom: 50px !important;
  }
  .bg-red-area_01::before {
    content: "";
    position: absolute;
    top: -1px;
    left: 0;
    width: 100%;
    height: 50px;
    background: #fff;
    clip-path: polygon(0 0, 100% 80%, 100% 0, 0 0);
  }
  .bg-red-area_01::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50px;
    background: #10628a;
    clip-path: polygon(0 80%, 100% 0, 100% 100%, 0 100%);
  }
  .bg-red-area_02 {
    position: relative;
    background: #10628a;
    padding-bottom: 60px !important;
  }
  .bg-red-area_02::after {
    content: "";
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 100%;
    height: 50px;
    background: #D42C49;
    clip-path: polygon(0 0, 100% 80%, 100% 100%, 0 100%);
  }
  .bg-red-area_03 {
    background: #D42C49;
  }
}
.bg-red-area_01 .dl-program {
  margin-top: 40px;
}
@media screen and (max-width: 768px) {
  .dl-program {
    padding: 4%;
  }
}
@media screen and (max-width: 768px) {
  .sischoolbox .sischoolbox-inner-02 p {
    font-size: 13px !important;
  }
  .sischoolbox .exam-title-specialist {
    margin-bottom: 20px !important;
  }
}
@media screen and (max-width: 768px) {
  .kbeauty-section {
    padding: 6%;
  }
  .kbeauty-section__text-top {
    gap: 10px;
    padding-top: 10px;
  }
}
@media screen and (max-width: 768px) {
  .sischoolbox-h4:first-child {
    margin-top: 10px;
  }
  .sischoolbox-h4.mgt-3 {
    margin-top: 25px !important;
  }
}
/*理美容ダブル*/
@media screen and (min-width: 769px) {
  .exam-heading-double {
    font-size: 20px;
    font-weight: 600;
    margin-bottom: 16px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-double::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #48A8DF;
    position: absolute;
    left: 0;
    top: 2px;
  }
}
@media screen and (max-width: 768px) {
  .exam-heading-double {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 10px;
    padding-left: 14px;
    position: relative;
  }
  .exam-heading-double::before {
    content: "";
    width: 6px;
    height: 24px;
    background: #48A8DF;
    position: absolute;
    left: 0;
    top: 2px;
  }
}

.royalmakeup .p-primebarbesec03::before {
  width: 0;
  height: 0;
}