/* ------------------------
    page：コース申込
------------------------ */
:is(body[class~="course-entry"]) {
  --sectionColor: #599ed5;
  --sectionBgColor: #ebf4fa;
}
:is(body[class~="course-entry"]) .heading {
  color: var(--sectionColor);
}

.entry {
  padding: 60px 0 70px;
}
.entry-01 {
  padding: 0 0 70px;
}
.entry-02 {
  background: var(--sectionBgColor);
}
.entry-03 .entryTop_ttl {
  margin-bottom: 0.8em;
}

.entryTop {
  --sectionColor: #599ed5;
  padding-bottom: 45px;
}
.entryTop_subTtl {
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--sectionColor);
  margin-bottom: 1.5em;
}
.entryTop_ttl {
  font-size: clamp(1.313rem, 0.825rem + 2.08vw, 2.125rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.3823529412;
  color: var(--sectionColor);
}
.entryTop_txt .emphasis {
  color: var(--sectionColor);
}

.entryProcess {
  padding: 50px min(50px, 5%);
  background: var(--sectionBgColor);
}
.entryProcess_item:not(:last-of-type):after {
  content: "";
  display: block;
  width: 150px;
  aspect-ratio: 6/1;
  -webkit-clip-path: polygon(50% 100%, 100% 0, 0 0);
  clip-path: polygon(50% 100%, 100% 0, 0 0);
  background: var(--sectionColor);
  margin: 0 auto 20px;
}
.entryProcess_ttl {
  font-size: clamp(1.125rem, 0.975rem + 0.64vw, 1.375rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: var(--sectionColor);
  background: #fff;
  border-radius: 5px;
  padding: 5px max(1em, 3.3333333333%);
  margin-bottom: 0.5em;
}
.entryProcess_txtWrap {
  padding: 0 max(1em, 3.3333333333%);
  padding-bottom: 1em;
}
.entryProcess_txtWrap .emphasis {
  font-weight: 700;
}

.entryInfo {
  padding: 50px min(50px, 5%) 0;
}
.entryInfo_ttl {
  position: relative;
  font-family: "Oswald", sans-serif;
  line-height: 1.5;
  letter-spacing: 0.02em;
  padding: 0 1em;
  color: #fff;
  background: var(--sectionColor);
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 1em;
}
.entryInfo_ttl::after {
  content: "";
  display: block;
  position: absolute;
  background: var(--sectionColor);
  width: 8px;
  aspect-ratio: 1/0.8660254038;
  -webkit-clip-path: polygon(100% 100%, 100% 0, 0 0);
  clip-path: polygon(100% 100%, 100% 0, 0 0);
  top: 100%;
  left: 1em;
}
.entryInfo_tel {
  font-size: 28px;
}
.entryInfo_tel .emphasis {
  color: var(--sectionColor);
  font-size: 0.5357142857em;
  font-weight: 700;
}

.lineup {
  margin-bottom: 45px;
}
.lineup_ttl {
  position: relative;
  font-size: clamp(1.125rem, 0.975rem + 0.64vw, 1.375rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  text-align: center;
  margin-bottom: 1em;
  color: var(--sectionColor);
  background: #fff;
  margin-bottom: 2em;
}
.lineup_ttl::after {
  content: "";
  display: block;
  position: absolute;
  background: #fff;
  width: 20px;
  aspect-ratio: 1/0.8660254038;
  -webkit-clip-path: polygon(50% 100%, 100% 0, 0 0);
  clip-path: polygon(50% 100%, 100% 0, 0 0);
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}

.lineupItem_headingWrap {
  background: var(--sectionColor);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 10px 15px;
  gap: 10px;
}
.lineupItem_headingMain {
  display: grid;
  grid-template-columns: 70px 1fr;
  gap: 10px;
}
.lineupItem_number {
  aspect-ratio: 1;
  font-size: 0.75rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.2;
  color: var(--sectionColor);
  background: #fff;
  place-content: center;
  display: grid;
}
.lineupItem_number .emphasis {
  font-family: "Oswald", sans-serif;
  font-size: 2.3333333333em;
  font-weight: 400;
  display: block;
}
.lineupItem_heading {
  font-size: clamp(1.313rem, 0.975rem + 1.44vw, 1.875rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.3;
  color: #fff;
  align-self: center;
}
.lineupItem_headingInfo {
  line-height: 1.5;
  color: #fff;
  font-weight: 500;
}
.lineupItem_headingInfoRow + .lineupItem_headingInfoRow {
  margin-top: 5px;
}
.lineupItem_style {
  font-size: 0.875rem;
  display: inline-block;
  color: var(--sectionColor);
  background: #fff;
  padding: 2px 0.5em;
  border-radius: 5px;
}
.lineupItem_state {
  font-size: 0.875rem;
  display: inline-block;
  color: #fff;
  background: #e57887;
  padding: 2px 0.5em;
  border-radius: 5px;
}
.lineupItem_state + .lineupItem_state {
  margin-left: 5px;
}
.lineupItem_state-pale.active {
  background: #eb939f;
}

.lineupItem_state-pale.few {
  background: #ff9600;
}

.lineupItem_state-pale.full {
  background: #ba0707;
}

.lineupItem_body {
  background: #fff;
  padding: 1em 1.7em 30px;
}
.lineupItem_ttl {
  color: var(--sectionColor);
}
.lineupItem_txt {
  text-align: justify;
  margin-bottom: 1em;
}
.lineupItem .btn-shadow,
.lineupItem .formCont .smf-button-control__control,
.formCont .lineupItem .smf-button-control__control {
  /*   filter: drop-shadow(6px 6px rgba(89, 158, 213, 0.3)); */
  flex: 1;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  padding: 20px;
  background: #fff;
  border: 2px solid #cf001c;
  font-size: 1.8rem;
  position: relative;
  line-height: 1.4;
  color: #cf001c;
  border-radius: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lineupItem .btn-shadow:where(:hover, :focus),
.lineupItem .formCont .smf-button-control__control:where(:hover, :focus),
.formCont .lineupItem .smf-button-control__control:where(:hover, :focus) {
  filter: drop-shadow(2px 2px rgba(89, 158, 213, 0.3));
}

.remodal-overlay {
  background: #fff;
}

.remodal-wrapper {
  padding: 0;
  text-align: unset;
}

.remodal {
  max-width: unset;
  padding: 50px 0 200px;
  margin-bottom: 0;
}

.modal {
  --sectionColor: #599ed5;
  --sectionBgColor: #ebf4fa;
  color: #333;
}

.modal-colose {
  color: var(--sectionColor);
  display: block;
  margin-left: auto;
  font-size: 30px;
  line-height: 1;
  margin-bottom: 0.5em;
}

.modal .lineupItem_headingWrap {
  margin-bottom: 1em;
}
.modal .lineupItem_curriculumHeading {
  color: var(--sectionColor);
}
.modal .lineupItem_curriculum {
  border: 1px solid var(--sectionColor);
  border-radius: 8px;
  overflow: hidden;
}
.modal .lineupItem_curriculum + .lineupItem_curriculum {
  margin-top: 18px;
}
.modal .lineupItem_curriculum-green {
  --sectionColor: #47ae35;
  --sectionBgColor: #e8f1e4;
}
.modal .lineupItem_curriculumTtlWrap {
  background: var(--sectionBgColor);
  padding: 5px 8px 5px 0.8em;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
.modal .lineupItem_curriculumTtlWrap .lineupItem_style {
  font-size: 0.75rem;
  line-height: 1.2;
  border-radius: 0;
  border: 1px solid var(--sectionColor);
}
.modal .lineupItem_curriculumTtlWrap .lineupItem_style:not(:first-child) {
  margin-left: 5px;
}
.modal .lineupItem_curriculumTtlWrap .lineupItem_state {
  font-size: 0.75rem;
  line-height: 1.2;
  border-radius: 0;
  border: 1px solid #e57887;
}
.modal .lineupItem_curriculumTtlWrap .lineupItem_state-aqua {
  background: #599ed5;
  border-color: #599ed5;
}
.modal .lineupItem_curriculumTtl {
  font-size: 1.1176470588em;
  font-weight: 500;
  color: var(--sectionColor);
}
.modal .lineupItem_curriculumBody {
  font-size: 0.8823529412em;
  padding: 0.5em 1em 1em;
}
.modal .lineupItem_curriculumListTtl {
  font-weight: 500;
}
.modal .lineupItem_curriculumList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px 1em;
  padding-left: 0.5em;
}
.modal .lineupItem_curriculumList:not(:last-child) {
  padding-bottom: 0.5em;
  border-bottom: 1px solid;
  margin-bottom: 0.3em;
}
.modal .lineupItem_curriculumList li {
  text-indent: -0.5em;
  line-height: 1.3333333333;
}
.modal .lineupItem_curriculumList li::before {
  content: "・";
  color: var(--sectionColor);
}
.modal .lineupItem_curriculumTableWrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-bottom: 60px;
}
.modal .lineupItem_curriculumTable {
  width: 100%;
  line-height: 1.5;
  border: 1px solid #cbcbcb;
}
.modal .lineupItem_curriculumTable + .lineupItem_curriculumTable {
  margin-top: 15px;
}
.modal .lineupItem_curriculumTable-center td {
  text-align: center;
}
.modal .lineupItem_curriculumTable tr:not(:last-of-type) {
  border-bottom: 1px solid #cbcbcb;
}
.modal .lineupItem_curriculumTable th {
  font-size: 0.8125rem;
  white-space: nowrap;
  width: 7.6em;
  vertical-align: middle;
  color: var(--sectionColor);
  background: var(--sectionBgColor);
  padding: 0 0.5em;
}
.modal .lineupItem_curriculumTable td {
  font-size: 0.875rem;
  vertical-align: middle;
  border-left: 1px solid #cbcbcb;
  padding: 0.3em 0.5em;
}
.modal .lineupItem_curriculumTable ul {
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  gap: 0 1em;
}
.modal .lineupItem_curriculumTable ul li::before {
  content: "・";
  color: #231815;
}
.modal .lineupItem .note {
  font-size: 0.8823529412em;
  margin-top: 5px;
  margin-bottom: 1em;
}

.courseChoice .is-frame {
  font-size: 1.2941176471em;
  color: var(--sectionColor);
  margin-bottom: 1.4em;
}

.courseChoiceItem {
  background: #fff;
  padding: 20px;
}
.courseChoiceItem:not(:last-child) {
  margin-bottom: 40px;
}
.courseChoiceItem_headingWrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 5px;
}
.courseChoiceItem_headingWrap .lineupItem_state {
  line-height: 1.5;
  align-self: center;
  margin-left: auto;
}
.courseChoiceItem_heading {
  font-size: clamp(1.125rem, 0.975rem + 0.64vw, 1.375rem);
  font-weight: 500;
  color: var(--sectionColor);
}
.courseChoiceItem .btn-shadow,
.courseChoiceItem .formCont .smf-button-control__control,
.formCont .courseChoiceItem .smf-button-control__control {
  --sectionColor: #e57887;
  filter: drop-shadow(6px 6px rgba(229, 120, 135, 0.3));
}
.courseChoiceItem .btn-shadow:where(:hover, :focus),
.courseChoiceItem .formCont .smf-button-control__control:where(:hover, :focus),
.formCont .courseChoiceItem .smf-button-control__control:where(:hover, :focus) {
  filter: drop-shadow(2px 2px rgba(229, 120, 135, 0.3));
}
.courseChoiceItem_tableWrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 15px;
  align-items: flex-start;
  margin-bottom: 18px;
}
.courseChoiceItem_summaryTable {
  font-size: 1.5rem;
  line-height: 1.5;
  border: 1px solid #cbcbcb;
  background-color: #fff;
}
.courseChoiceItem_summaryTable tr:not(:last-of-type) {
  border-bottom: 1px solid #cbcbcb;
}
.courseChoiceItem_summaryTable th {
  white-space: nowrap;
  vertical-align: middle;
  color: #cf001c;
  background: #f9e1d6;
  border-right: 1px solid #cbcbcb;
  padding: 0.5em 1em 0.5em 0.5em;
  font-size: 1.5rem;
}
.courseChoiceItem_summaryTable td {
  font-size: 1em;
  vertical-align: middle;
  padding: 0.3em 0.7em;
}
.courseChoiceItem_dateTable {
  font-size: 0.75rem;
  text-align: center;
  color: var(--sectionColor);
}
.courseChoiceItem_dateTable td {
  border: 1px solid;
}
.courseChoiceItem_dateTable .schedule {
  background: var(--sectionBgColor);
}
.courseChoiceItem_dateTable .schedule td {
  border-color: #fff;
  border-bottom-color: #f1f1f1;
}
.courseChoiceItem_dateTable tr:not([class]) td {
  border-color: #f1f1f1;
}

@media (max-width: 767px) {
  .courseChoiceItem_tableWrap {
    grid-template-columns: 1fr;
    margin-bottom: 20px;
  }
  .courseChoiceItem_dateTable {
    font-size: 0.6875rem;
  }
  .lineupItem_headingMain {
    grid-template-columns: 50px 1fr;
    gap: 10px;
  }
  .lineupItem_number {
    font-size: 0.625rem;
  }
  .lineupItem_headingInfo {
    line-height: 1.7;
  }
  .lineupItem_style {
    font-size: 0.6875rem;
  }
  .lineupItem_state {
    font-size: 0.6875rem;
  }
  .modal .lineupItem_curriculumList {
    grid-template-columns: 1fr;
  }
  .modal .lineupItem_curriculumTableWrap {
    grid-template-columns: 1fr;
    margin-bottom: 40px;
  }
  /*スタイルを展開したいところに記述する*/
}

/* ------------------------
      page：コースの内容
  ------------------------ */
:is(body[class~="course_guide"]) {
  --sectionColor: #599ed5;
}
:is(body[class~="course_guide"]) .heading {
  color: var(--sectionColor);
}

.curriculum {
  --sectionColor: #599ed5;
}
.curriculum_ttl {
  word-break: auto-phrase;
  font-size: clamp(1.25rem, 0.988rem + 1.12vw, 1.688rem);
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  color: #fff;
  background: var(--sectionColor);
  padding: 0.25em 1em;
  margin-bottom: 1em;
}
.curriculum_ttl .detail {
  font-size: 0.7407407407em;
  letter-spacing: 0.02em;
  display: inline-block;
  color: var(--sectionColor);
  background: #fff;
  padding: 0 0.6em;
  border-radius: 7px;
  margin-left: 0.8em;
}
.curriculum_ttl .detail + .detail {
  margin-left: 0.5em;
}

.curriculumTop {
  padding-bottom: 50px;
}
.curriculumTop_subTtl {
  font-family: "Oswald", sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  color: var(--sectionColor);
  margin-bottom: 1.7em;
}
.curriculumTop_ttl {
  font-size: clamp(1.313rem, 0.825rem + 2.08vw, 2.125rem);
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.3823529412;
  color: var(--sectionColor);
  margin-bottom: 0.7em;
}

.curriculumCont {
  margin-bottom: 50px;
}
.curriculumCont_ttl {
  font-size: clamp(1.25rem, 0.988rem + 1.12vw, 1.688rem);
  letter-spacing: 0.03em;
  line-height: 1.5;
  color: var(--sectionColor);
  margin-bottom: 0.5em;
}
.curriculumCont_ttlSub {
  color: var(--sectionColor);
}
.curriculumCont_txt {
  text-align: justify;
}
.curriculumCont_box {
  background: #fff;
  padding-top: 28px;
}
.curriculumCont_boxTtl {
  font-size: 1.2941176471em;
  color: var(--sectionColor);
  margin: 0 2em;
}
.curriculumCont_frameBox {
  text-align: center;
  color: var(--sectionColor);
  border: 1px solid var(--sectionColor);
  border-radius: 10px;
  padding: 0.5em;
}
.curriculumCont .note {
  font-size: 0.8823529412em;
}
.curriculumCont .is-frame {
  font-size: 1.2941176471em;
  font-weight: 500;
  color: var(--sectionColor);
  margin-bottom: 1.5em;
}
.curriculumCont .curriculumCont_List {
  --sectionColor: #599ed5;
  margin-bottom: 15px;
}
.curriculumCont-02 .curriculumCont_ListTtl {
  color: var(--sectionColor);
}
.curriculumCont-02 .card02_ttl {
  min-height: 8em;
}
.curriculumCont-02 .card02_ttl .eng {
  font-family: "Oswald", sans-serif;
  font-size: 0.6818181818em;
  font-weight: 400;
  color: #fff;
  background: var(--sectionColor);
  padding: 0 1em;
  margin-left: 1em;
}
.curriculumCont-05 .cards02 {
  --sectionColor: #47ae35;
  margin-bottom: 30px;
}
.curriculumCont-05 .card02_ttl {
  font-size: 1.375rem;
  color: var(--sectionColor);
  min-height: unset;
}
.curriculumCont-05 .card02_img {
  max-width: 330px;
  margin-right: auto;
  margin-left: auto;
}
.curriculumCont-06 {
  position: relative;
  --sectionColor: #47ae35;
  --sectionBgColor: #e8f1e4;
  background: var(--sectionBgColor);
  padding: 50px min(50px, 5%) 0;
  margin-bottom: 0;
}
.curriculumCont-06::before {
  content: "";
  display: block;
  position: absolute;
  width: 28px;
  aspect-ratio: 1.2/1;
  -webkit-clip-path: polygon(0% 100%, 50% 0, 100% 100%);
  clip-path: polygon(0% 100%, 50% 0, 100% 100%);
  background: var(--sectionBgColor);
  bottom: 100%;
  left: 50%;
  transform: translateX();
}
.curriculumCont-06 .is-frame {
  font-size: 1em;
}
.curriculumCont-07 {
  --sectionColor: #47ae35;
  --sectionBgColor: #e8f1e4;
  background: var(--sectionBgColor);
  padding: 50px min(50px, 5%) 35px;
}
.curriculumCont-07 .cards02 {
  --sectionColor: #47ae35;
  --sectionContBgColor: #fff;
  gap: 40px;
}
.curriculumCont-07 .card02_ttl {
  min-height: 8em;
}
.curriculumCont-07 .card02_ttl .emphasis {
  color: var(--sectionColor);
}
.curriculumCont-07 .card02_img {
  max-width: 300px;
  margin-right: auto;
  margin-left: auto;
}

.courseCont {
  padding: 70px 0;
  background: var(--sectionBgColor);
}
.courseCont-01 {
  --sectionColor: #599ed5;
  --sectionBgColor: #ebf4fa;
}
.courseCont-02 {
  --sectionColor: #47ae35;
  --sectionBgColor: #fff;
}

.coursePic {
  --sectionBgColor: #ebf4fa;
  background: var(--sectionBgColor);
  padding: 70px 0;
}
.coursePic_ttl {
  font-family: "Oswald", sans-serif;
  font-size: 2.5rem;
  letter-spacing: 0.02em;
  text-align: center;
  color: #cf001c;
  margin-bottom: 0.8em;
  display: flex;
  justify-content: center;
  align-items: center;
}
.coursePic_ttl::before,
.coursePic_ttl::after {
  display: inline-block;
  content: "";
  width: 9px;
  aspect-ratio: 1/4.5;
  -webkit-clip-path: polygon(50% 100%, 100% 0, 0 0);
  clip-path: polygon(50% 100%, 100% 0, 0 0);
  background: currentColor;
}
.coursePic_ttl::before {
  transform: skew(35deg, 0deg);
  margin-right: 0.7em;
}
.coursePic_ttl::after {
  transform: skew(-35deg, 0deg);
  margin-left: 0.7em;
}

.coursePicCont {
  padding: 50px;
  background: #fff;
}
.coursePicCont .is-frame {
  font-size: 1.375rem;
  font-weight: 500;
  color: var(--sectionColor);
  margin-bottom: 1.5em;
}
.coursePicCont:not(:last-child) {
  margin-bottom: 40px;
}
.coursePicCont-01 {
  --sectionColor: #cf001c;
}
.coursePicCont-02 {
  --sectionColor: #599ed5;
}
.coursePicCont-02 .note {
  font-size: 0.8823529412em;
}

.programFlow {
  margin-top: 20px;
}
.programFlow_number {
  font-family: "Oswald", sans-serif;
  text-align: center;
  line-height: 1.1;
  letter-spacing: 0.03em;
  color: var(--sectionColor);
  background: var(--sectionBgColor);
  display: grid;
  place-content: center;
  padding: 1em;
}
.programFlow_number .emphasis {
  font-size: 3.1764705882em;
  display: block;
}
.programFlow_item {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 27.2222222222%;
  gap: 1em;
  padding: 28px 0;
}
.programFlow_item:not(:last-of-type) {
  border-bottom: 1px dashed #cbcbcb;
}
.programFlow_item:not(:last-of-type)::after {
  content: "";
  display: block;
  position: absolute;
  width: 100px;
  height: 24px;
  top: 100%;
  left: 0;
  transform: translateY(-50%);
  background: url(../img/course/course_guide/doubleArrow.svg) no-repeat
      center/24px,
    #fff;
}
.programFlow_item:last-of-type {
  padding: 28px 0 10px;
}
.programFlow_body {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 1em;
}
.programFlow_name {
  font-size: 0.8823529412em;
  font-weight: 500;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
  background: var(--sectionColor);
  border-radius: 5px;
  line-height: 1.5;
  padding: 0 0.7em;
  margin-bottom: 0.9em;
}
.programFlow_ttl {
  font-size: 1.375rem;
  font-weight: 500;
  line-height: 1.5;
  color: var(--sectionColor);
  margin-bottom: 0.35em;
}

@media (max-width: 1024px) {
  .programFlow_item {
    grid-template-columns: 1fr;
    gap: 35px;
  }
  .programFlow_item:not(:last-of-type)::after {
    width: 100px;
    height: 24px;
    left: 50%;
    transform: translate(-50%, -50%);
  }
  .programFlow_img {
    max-width: 350px;
    margin: auto;
  }
  /*スタイルを展開したいところに記述する*/
}
@media (max-width: 767px) {
  .courseCont {
    padding: 30px 0;
  }
  .coursePic {
    padding: 30px 0;
  }
  .coursePic_ttl {
    font-size: 1.6875rem;
    margin-bottom: 0.3em;
  }
  .coursePic_ttl::before,
  .coursePic_ttl::after {
    width: 5px;
  }
  .coursePicCont {
    padding: 30px 5%;
  }
  .coursePicCont .is-frame {
    font-size: 1.1875rem;
    margin-bottom: 0.8em;
  }
  .programFlow {
    line-height: 1.2;
    padding: 0.3em 0.7em;
  }
  .programFlow_body {
    grid-template-columns: min(100px, 20%) 1fr;
  }
  .curriculum_ttl .detail {
    font-size: 0.65em;
  }
  .curriculumCont-02 .card02_ttl {
    min-height: unset;
  }
  .curriculumCont-06 {
    padding: 25px min(50px, 5%) 0;
  }
  .curriculumCont-07 .cards02 {
    gap: 25px;
  }
  .curriculumCont-07 .cards02_ttl {
    min-height: unset;
  }
  /*スタイルを展開したいところに記述する*/
}
/* ------------------------
      page：セミナー/説明会
  ------------------------ */
:is(body[class~="seminar"]) {
  --sectionColor: #cf001c;
}
:is(body[class~="seminar"]) .sec02List_ttl {
  font-weight: 500;
  font-size: large;
  text-align: center;
  color: #fff;
  background: var(--sectionColor);
  margin-bottom: 0.5em;
  margin-top: 3em;
  padding: 6px;
}
:is(body[class~="seminar"]) .sec02List {
  margin-top: 20px;
  margin-bottom: 40px;
}

.seminarCoupon {
  width: 80%;
  max-width: 550px;
  margin: 0 auto 75px;
}

.seminarCategoryList {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.seminarCategory {
  display: block;
  width: 20%;
  margin-right: 2%;
}

.seminarCategory > button {
  width: 100%;
  padding: 5px 0;
  text-align: center;
  font-weight: 500;
  line-height: 1.5;
  border: 2px solid currentColor;
  border-radius: 5px;
  transition: 0.2s ease;
}
.seminarCategory > button:is(:hover, :focus) {
  color: #fff;
}
.seminarCategory-all > button {
  color: #666;
}
.seminarCategory-all > button:where(:hover, :focus) {
  background: #666;
}
.seminarCategory-school > button {
  color: #cf001c;
}
.seminarCategory-school > button:where(:hover, :focus) {
  background: #cf001c;
}
.seminarCategory-online > button {
  color: #e57887;
}
.seminarCategory-online > button:where(:hover, :focus) {
  background: #e57887;
}

.seminarContWrap-school {
  --sectionColor: #e57887;
}
.seminarContWrap-online {
  --sectionColor: #ef8200;
}
.seminarContWrap + .seminarContWrap {
  margin-top: 20px;
}
.seminarContWrap.hidden {
  display: none;
}

.seminarCont {
  padding: 20px 20px 20px;
  border: 3px solid #cf001c;
  min-height: 480px;
}

.seminarCont.detail {
  min-height: 0;
}

.seminarCont .seminarCatch {
  text-align: center;
  color: #cf001c;
  font-size: large;
}

.seminarCont .is-frame {
  font-size: 1.2941176471em;
  color: #333;
  text-align: center;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0.03em;
  border-top: none;
  border-bottom: 1px solid currentColor;
  padding: 0.2em 0 1em 0;
}

.smf-action .smf-button-control__control {
  width: 240px;
  margin: 0 auto;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 700;
  padding: 12px;
  background: #fff;
  border: 2px solid #cf001c;
  font-size: 1.8rem;
  position: relative;
  line-height: 1.4;
  color: #cf001c;
  border-radius: 33px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.smf-action .smf-button-control__control:hover {
  background-color: #cf001c;
  border-color: #cf001c;
  color: #fff;
  transition: all 0.3s;
}

.seminarCont .btn-shadow::before,
.seminarCont .formCont .smf-button-control__control::before,
.formCont .seminarCont .smf-button-control__control::before {
  -webkit-mask-image: url(../img/common/icon/arrow-circle.svg);
  mask-image: url(../img/common/icon/arrow-circle.svg);
}
.seminarCont .btn-shadow:where(:hover, :focus),
.seminarCont .formCont .smf-button-control__control:where(:hover, :focus),
.formCont .seminarCont .smf-button-control__control:where(:hover, :focus) {
  color: #e57887;
  background: #fff;
  filter: drop-shadow(4px 4px rgba(99, 99, 99, 0.3));
}

.seminarCont_inner {
  padding: 20px 0 0;
  /* 		display: flex;
      flex-wrap: wrap;	*/
}

.seminarCont_place {
  color: #fff;
  background: #cf001c;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 25%;
  text-align: center;
  padding: 0 0.5em;
  font-size: medium;
  position: relative;
  top: 20px;
  height: 34px;
  line-height: 1.8;
}

.seminarCont_info {
  /* 
    display: flex;
    align-items: flex-start;
    gap: 5px 30px;
      */
  margin-bottom: 1em;
  width: 100%;
}

.seminarCont_date {
  background: #f1f1f1;
  padding: 1em 2em;
}

.seminarCont_date p {
  display: inline;
}

.seminarCont_day {
  font-size: 2rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.1;
  margin: 10px 0;
}

.seminarCont_time > :first-child {
  margin-right: 0.5em;
  margin-left: 0.5em;
}
.seminarCont_time .emphasis {
  font-weight: 500;
  color: #dd0000;
  background-color: none;
  display: inline-block;
  font-size: 1.5rem;
  border-radius: 4px;
  padding: 0;
}

.seminarCont_subinfo {
  display: flex;
  justify-content: space-between;
}

.seminarCont_subinfo dt,
dd {
  font-size: medium;
  /*font-weight: bold;*/
}

.seminarCont_detail {
  line-height: 1.8;
  font-size: medium;
  margin-top: 10px;
}

.seminarCont_flexContainer {
  display: flex;
  justify-content: space-between;
  gap: 32px;
}

.seminarCont_imgWrapper {
  min-width: 250px;
  min-height: 150px;
  max-width: 250px;
  max-height: 150px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* .seminar_apply_btn {
    display: none;
    margin-top: 30px;
    opacity: 0;
    transform: translateY(10px);
    transition: opacity 0.2s ease-in-out, transform 0.4s ease-in-out;
  } */

.seminar_apply_btn {
  display: flex;
  opacity: 0;
  transform: translateY(10px);
  height: 0;
  overflow: hidden;
  transition: opacity 0.3s ease, transform 0.3s ease, height 0.4s ease;
  justify-content:center;
}

.seminarCont_detail.p-expanded .seminar_apply_btn {
  opacity: 1;
  transform: translateY(0);
  height: 60px;
}

/* .seminar_apply_btn .btn {
    padding: 0.2em 1em;
    min-width: 200px;
    width: 200px;
  } */

.seminarCont_time span {
  font-size: 1.5rem;
}

.seminarCont_dataList {
  margin-right: 4em;
  display: flex;
  gap: 2em;
  text-wrap: nowrap;
}

.seminarCont_dataListRow {
  font-size: 0.8823529412em;
  line-height: 1.8;
  display: flex;
  gap: 1em;
  margin-top: 0em;
}
.seminarCont_dataListRow dt,
dd {
  background: none;
  font-size: 1em;
}

.seminarCont_dataListRow > a {
  text-decoration: underline;
  color: #5656a2;
}

.seminarBranch {
  color: #cf001c;
  font-weight: 500;
}

.seminarCont_dataListRow > a:hover {
  opacity: 0.7;
}

@media (max-width: 767px) {
  :is(body[class~="seminar"]) .sec02List {
    margin-top: 20px;
    margin-bottom: 20px;
  }

  :is(body[class~="seminar"]) .sec02ListItem_img {
    width: 30%;
    height: 100px;
  }

  :is(body[class~="seminar"]) .sec02ListItem_ttlandtxt {
    width: 70%;
  }

  :is(body[class~="seminar"]) .sec02ListItem_ttl {
    text-align: left;
  }

  :is(body[class~="seminar"]) .sec02ListItem_txt {
    padding-left: 10px;
  }

  :is(body[class~="seminar"]) .sec02ListItem {
    display: flex;
    flex-direction: row;
  }
  :is(body[class~="seminar"]) .sec02ListItem div {
    display: flex;
    flex-direction: column;
  }

  .seminarCoupon {
    width: 90%;
    margin: 0 auto 40px;
  }
  .seminarCont {
    padding: 20px 15px 30px;
    border-width: 3px;
  }
  .seminarCont_inner {
    padding: 10px 0 0;
  }
  .seminarCont_info {
  }
  .seminarCont_date {
    padding: 1em;
  }
  .seminarCont_day {
    font-size: 1.4rem;
  }
  .seminarCont_detail {
    margin-top: 10px;
  }

  .seminarCatch {
    margin-top: 10px;
  }

  .seminarCategoryList {
    justify-content: space-between;
  }

  .seminarCont_imgWrapper {
    max-width: 100%;
    max-height: 100%;
	align-items: center;
  }

  .seminarCategory {
    width: 32%;
    margin-right: 0;
  }

  .seminarCont_place {
    line-height: 2;
  }

  .seminarCont_dataList {
    flex-direction: column;
    gap: 0;
  }

  .seminarCont_flexContainer {
    flex-direction: column-reverse;
    gap: 30px;
  }

  /*スタイルを展開したいところに記述する*/
}
/* ------------------------
      page：セミナー/説明会
  ------------------------ */
:is(body[class~="seminar-form"]) {
  --sectionColor: #cf001c;
}
:is(body[class~="seminar-form"]) .seminarContWrap {
  margin-bottom: 60px;
}
:is(body[class~="seminar-form"]) .seminarCont {
  padding: 27px 30px 10px;
}
:is(body[class~="seminar-form"]) .seminarCont_inner {
  padding: 25px 5.4347826087% 0;
}

@media (max-width: 767px) {
  :is(body[class~="seminar-form"]) .seminarContWrap {
    margin-bottom: 40px;
  }
  :is(body[class~="seminar-form"]) .seminarCont {
    padding: 20px 15px 10px;
  }
  :is(body[class~="seminar-form"]) .seminarCont_inner {
    padding: 15px 3% 0;
  }
  /*スタイルを展開したいところに記述する*/
}
/* ------------------------
      page：資料請求
  ------------------------ */
:is(body[class~="pamphlet"]) {
  --sectionColor: #cf001c;
}
:is(body[class~="pamphlet"]) .heading {
  color: var(--sectionColor);
}

.contactTel {
  text-align: center;
  line-height: 1.5;
  display: block;
  max-width: 610px;
  padding: 25px;
  margin: 45px auto 20px;
  background: #f9e1d6;
  transition: 0.4s;
  font-size: 2.1875rem;
}
.contactTel:where(:hover, :focus) {
  opacity: 0.8;
}
.contactTel_ttl {
  font-size: 1.375rem;
  font-weight: 500;
  color: #cf001c;
}
.contactTel_number {
  font-family: "Oswald", sans-serif;
}
.contactTel_number::before {
  content: "";
  display: inline-block;
  width: 0.701754386em;
  aspect-ratio: 40/44;
  background: url(../img/common/icon/tel.svg) no-repeat center/contain;
  margin-right: 5px;
}
.contactTel_info {
  font-size: 0.8125rem;
}

/* ------------------------
      page：個別ガイダンス
  ------------------------ */
:is(body[class~="guidance"]) {
  --sectionColor: #cf001c;
}
:is(body[class~="guidance"]) .seminarCoupon {
  margin-top: 70px;
}

@media (max-width: 767px) {
  :is(body[class~="guidance"]) .seminarCoupon {
    margin-top: 40px;
  }
  /*スタイルを展開したいところに記述する*/
}
/* ------------------------
      page：コース申込フォーム EAPメンタルヘルスカウンセラー養成コース（14日間）/(18日間)
  ------------------------ */
:is(body[class~="class-form"]),
:is(body[class~="course-form"]) {
  --sectionColor: #599ed5;
  --sectionBgColor: #ebf4fa;
}
:is(body[class~="class-form"]) .lineup,
:is(body[class~="course-form"]) .lineup {
  margin: 20px 0 80px;
}
:is(body[class~="class-form"]) .lineupItem_headingWrap,
:is(body[class~="course-form"]) .lineupItem_headingWrap {
  margin-bottom: 17px;
}
:is(body[class~="class-form"]) .courseChoiceItem_summaryTable,
:is(body[class~="course-form"]) .courseChoiceItem_summaryTable {
  font-size: inherit;
  width: 100%;
}
:is(body[class~="class-form"]) .courseChoiceItem_summaryTable th,
:is(body[class~="course-form"]) .courseChoiceItem_summaryTable th {
  font-size: 0.8823529412em;
}
:is(body[class~="class-form"]) .total,
:is(body[class~="course-form"]) .total {
  font-size: 1.1764705882em;
  font-weight: 700;
  padding: 1em 0em 0.8em;
  margin-top: 0.7em;
  border-top: 1px solid #cbcbcb;
}

/* ------------------------
      page：セミナー/説明会
  ------------------------ */
:is(body[class~="seminar"]) {
  --sectionColor: #cf001c;
}
:is(body[class~="seminar"]) .heading {
  color: var(--sectionColor);
}

/* ------------------------
      フォーム
  ------------------------ */
.formCont {
  --sectionColor: #cf001c;
  max-width: 1000px !important;
  padding: 50px max(20px, 5%);
  box-shadow: 0px 0px 20px 0px #00000040;
  border-radius: 20px;
}
.formCont_txt {
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
}
.formCont_headingWrap {
  text-align: center;
}
.formCont_headingWrap .linkWrap {
  margin-top: 70px;
}
.formCont_headingWrap .linkWrap .btn {
  color: #fff;
  background: #cf001c;
  padding: 15px 40px;
  border-radius: 5px;
}
.formCont_heading {
  font-family: "Zen Maru Gothic", sans-serif;
  /*   font-size: clamp(1.688rem, 0.975rem + 3.04vw, 2.875rem); */
  font-size: 48px;
  font-weight: 500;
  letter-spacing: 0.03em;
  /*   color: #CF001C; */
  color: #1a2c61;
  margin-bottom: 0.5em;
  padding-top: 40px;
  text-align: center;
}

@media (max-width: 768px) {
  .formCont_heading {
    font-size: 28px;
  }
}

.formCont_protection {
  font-size: 1.4rem;
  line-height: 1.5;
  color: #333;
  background: #eeeeee;
  padding: 1.5em 1em;
  height: 200px;
  overflow-y: auto;
}
.formCont_protection dt {
  font-weight: 700;
}
.formCont_protection dd + dt {
  margin-top: 1em;
}
.formCont a {
  color: var(--sectionColor);
  text-decoration: underline;
}
.formCont .note {
  font-size: 0.9em;
  line-height: 1.6666666667;
}
.formCont .smf-item__label__text {
  line-height: 1.4705882353;
}
.formCont .smf-item:not(.any) .smf-item__label__text {
  color: #cf001c;
  font-family: "Zen Maru Gothic", sans-serif;
  font-weight: 500;
}
.formCont .smf-item__controls {
  display: grid;
  gap: 20px;
}
.formCont .smf-form .smf-item .smf-text-control__control,
.formCont .smf-form .smf-item .smf-textarea-control__control {
  font-size: 0.9em;
  width: 100%;
  background-color: #eeeeee;
  border-radius: 0;
  border-width: 0;
  box-shadow: none;
  padding: 10px;
}
.formCont .smf-form .smf-item .smf-text-control__control.postal-code {
  width: auto;
}
.formCont .smf-error-messages {
  font-size: 0.8em;
}
@supports (
    (-webkit-appearance: none) or (-moz-appearance: none) or (appearance: none)
  )
  or (-moz-appearance: none) {
  .formCont .smf-form .smf-item .smf-select-control__control {
    color: #333;
    font-size: 0.9em;
    background-color: #eeeeee;
    border-radius: 0;
    border-width: 0;
/*     min-width: 8.5em; */
    min-width: 4.5em;
  }
}
@supports (
    (-webkit-appearance: none) or (-moz-appearance: none) or (appearance: none)
  )
  or (-moz-appearance: none) {
  .formCont .smf-form .smf-item .smf-select-control__toggle {
    color: #333;
    background-color: unset;
    z-index: 1;
    pointer-events: none;
  }
}
.formCont .smf-form .smf-item .smf-radio-button-control {
  align-items: center;
}
.formCont .smf-form .smf-item .smf-radio-button-control__control {
  margin-top: 0;
}
.formCont .smf-form--simple-table .smf-item.required .smf-item__label,
.formCont .smf-form--simple-table .smf-item.any .smf-item__label {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

.formCont .smf-form--simple-table .smf-item.required.hybrid {
  display: none;
}

.formCont .smf-form--simple-table .smf-item.required .smf-item__label::after,
.formCont .smf-form--simple-table .smf-item.any .smf-item__label::after {
  font-size: 1.1rem;
  white-space: nowrap;
  line-height: 1;
  margin-left: auto;
  display: inline-block;
  padding: 4px 0.6em;
  transform: translateY(25%);
}
.formCont .smf-form--simple-table .smf-item.required .smf-item__label::after {
  content: "必須";
  color: #fff;
  background: #cf001c;
}
.formCont .smf-form--simple-table .smf-item.any .smf-item__label::after {
  content: "任意";
  border: 1px solid;
  padding: 2px calc(0.6em - 1px);
}
.formCont .smf-form .smf-item .smf-checkbox-control {
  color: #333;
  align-items: center;
}
.formCont .smf-form .smf-item .smf-checkbox-control__control {
  border-radius: 0;
  border-color: inherit;
}
.formCont .smf-button-control__control {
  filter: drop-shadow(6px 6px #ddd);
}
.formCont .smf-button-control__control:where(:hover, :focus) {
  filter: drop-shadow(2px 2px #ddd);
}
.formCont .smf-action {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 15px;
}
.formCont .smf-action .smf-button-control + .smf-button-control {
  margin-left: 0;
}
.formCont .smf-form--simple-table .smf-item:not(:last-child) {
  border-bottom: 1px solid #f4f8ff;
}
.formCont .birthDate .smf-item__controls {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.formCont .birthDate .smf-placeholder[data-name="year"] {
  margin-top: 0;
}
@supports (
    (-webkit-appearance: none) or (-moz-appearance: none) or (appearance: none)
  )
  or (-moz-appearance: none) {
  .formCont .birthDate.smf-item .smf-select-control__control {
    min-width: unset;
  }
}
.formCont .birthDate_item {
  display: flex;
  gap: 7px;
  align-items: baseline;
}
.formCont .emergency .emergency-group {
  display: flex;
  align-items: baseline;
  gap: 7px;
}
.formCont .emergency .emergency-group > * {
  margin: 0 !important;
}
.formCont .emergency .emergency-group .smf-placeholder {
  flex: 1;
}
@supports (
    (-webkit-appearance: none) or (-moz-appearance: none) or (appearance: none)
  )
  or (-moz-appearance: none) {
  .formCont .emergency.smf-item .smf-select-control__control {
    min-width: unset;
  }
}
.formCont .entryCheck.smf-item .smf-checkbox-control {
  color: inherit;
}
.formCont .smf-item:not(.any) .inputTxt {
  color: #cf001c;
}

@media (min-width: 640px) {
  .formCont {
    padding: 50px max(20px, 5%);
  }
  .smf-form--simple-table .smf-item__col--label {
    flex: 0 0 19em;
    max-width: 19em;
  }
  .smf-form--simple-table .smf-item__col--controls {
    flex: 1 1 calc(100% - 19em);
    max-width: calc(100% - 19em);
  }
}

/* ------------------------
     セミナー詳細に「続きを見る」機能を付ける
  ------------------------ */
.seminarCont_detail p {
  max-height: 150px; /* 初期状態の最大高さ（PC） */
  overflow: hidden; /* 内容が隠れる */
  position: relative; /* 擬似要素の配置のためにrelativeを指定 */
  transition: max-height 1s ease-out, filter 1s ease, opacity 1s ease; /* max-height, opacityを同じ時間でアニメーション */
}

/* スマホ用の高さ設定 */
@media (max-width: 768px) {
  .seminarCont_detail p {
    max-height: 65px; /* スマホでは少し低めに設定 */
  }
}

/* 文章の境界部分にぼかしを追加 */
.seminarCont_detail p::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 35px; /* ぼかしの高さ */
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0),
    rgba(255, 255, 255, 1)
  ); /* ぼかしのグラデーション */
  pointer-events: none; /* 擬似要素がクリックされないようにする */
  opacity: 1; /* 初期状態ではぼかしが表示 */
  transition: opacity 1s ease; /* ぼかしのアニメーションも1秒に変更 */
}

.seminarCont_detail.is-fully-visible p::after {
    opacity: 0;
}

/* ぼかしを非表示にするためのクラス */
.seminarCont_detail.p-expanded p::after {
  opacity: 0; /* 完全に非表示に */
}

/* ボタンをセンターに配置 */
.seminarCont_detail .button-container {
  text-align: center;
  margin-top: 20px;
}

/* 「続きを読む」と「閉じる」のスタイル */
.seminar_detail_readmore_open,
.seminar_detail_readmore_close {
  color: #cf001c; /* 文字色を指定 */
  font-weight: 500; /* ボールド属性を追加 */
  cursor: pointer; /* クリックできることを示す */
  text-decoration: none; /* リンクの下線を削除 */
  font-size: 16px; /* 文字サイズを少し大きく */
}

/* iframeのYouTubeをレスポンシブにする */
.iframe-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
}

.iframe-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.smf-form .smf-item .smf-checkbox-control__control {
  position: relative;
  background-color: #fff;
  transition: border-color 0.2s ease;
}

.smf-form .smf-item .smf-checkbox-control__control:checked {
  border-color: #cf001c;
  background-color: #fff;
}

.smf-form .smf-item .smf-checkbox-control__control:checked:before {
  content: "";
  display: block;
  position: absolute;

  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);

  width: 10px;
  height: 10px;

  background-color: #cf001c;
  border: none;
  visibility: visible;
}

.smf-item__description {
  font-size: 14px;
  font-weight: 500;
  font-family: "Zen Maru Gothic", sans-serif;
  color: #1a1a1a;
}
