/* ==========================
カラー
========================== */
:root {
  --color-blue: #4481eb;
  --color-black: #535353;
  --color-white: #fff;
}

/* ==========================
共通
========================== */
body.is-modal-open {
  overflow: hidden;
}
/* ==========================
Smart Boardingで学べるコンテンツ
========================== */
.eLearningAbout {
  background-color: #edf4ff;
  position: relative;
}

.eLearningAbout::before {
  content: "";
  width: 100%;
  max-width: 1000px;
  height: 380px;
  position: absolute;
  top: 0;
  left: 0;
  background-position: top;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/eLearningAbout-bg.webp);
  z-index: 0;
  pointer-events: none;
}

.eLearningAbout::after {
  content: "";
  width: 100%;
  max-width: 1000px;
  height: 380px;
  position: absolute;
  background-position: top;
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(../img/eLearningAbout-bg.webp);
  transform: rotate(180deg);
  z-index: 0;
  right: 0;
  bottom: 0;
  pointer-events: none;
}

.eLearningAboutInner {
  padding-block: 80px 121px;
  position: relative;
}

@media screen and (max-width: 840px) {
  .eLearningAboutInner {
    padding-block: 80px 53px;
  }
}

.eLearningAboutTitle {
  color: var(--color-black);
  font-size: clamp(20px, calc(0.77vw + 17.23px), 32px);
  font-weight: 600;
  text-align: center;
  margin-block-end: 56px;
}

.eLearningAboutLead {
  color: var(--color-black);
  font-size: 22px;
  font-weight: 600;
  text-align: center;
  line-height: 1.7;
}
.searchInputLead {
  background-color: var(--color-white);
  color: var(--color-blue);
  font-size: clamp(11.98px, calc(0.39vw + 10.45px), 18px);
  letter-spacing: 0.05rem;
  font-weight: 600;
  outline: solid 2px var(--color-blue);
  padding-block: 10px;
  position: relative;
  padding-inline: 45px;
  border-radius: 100vw;
  display: block;
  width: max-content;
  margin-block-start: 25px;
}
@media screen and (max-width: 840px) {
  .searchInputLead {
    width: auto;
    text-align: center;
    line-height: 1.5;
  }
}

.searchInput {
  display: flex;
  align-items: center;
  gap: 26px;
  box-shadow: 0px 0px 7px rgba(0, 0, 0, 0.25);
  background-color: #fff;
  padding: 7px 16px;
  border-radius: 10px;
}
.searchInput input {
  width: 91%;
  font-size: clamp(16px, calc(0.13vw + 15.49px), 18px);
  border: none;
  line-height: 1;
}

.searchButton {
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: #4485eb;
  border-radius: 10px;
  flex-shrink: 0;
  padding: 10px 24px;
  transition: all 0.1s 0s linear;
}

.search-icon {
  max-width: clamp(
    24px,
    calc(24px + (30 - 24) * ((100vw - 390px) / (1440 - 390))),
    30px
  );
}

.eLearningAboutButton {
  margin-block-start: 25px;
  color: var(--color-blue);
  background-color: var(--color-white);
  box-shadow: 0px 0px 7.72438px #417edf;
  border-radius: 100vw;
  padding-block: 11px;
  padding-inline: 73px;
  display: inline-block;
}
.eLearningAboutButton .text {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 600;
}

.eLearningAboutButton .text .small {
  display: inline-block;
  font-size: 13px;
  line-height: 1.5;
}

.eLearningCategory {
  margin-block-start: 88px;
  position: relative;
  padding-block-end: 125px;
}
@media screen and (max-width: 840px) {
  .eLearningCategory {
    margin-block-start: 72px;
    padding-block-end: 73px;
  }
}

.eLearningCategoryPlus {
  display: block;
  width: 50px;
  height: 50px;
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.eLearningCategoryTitle {
  color: var(--color-blue);
  font-size: clamp(23px, calc(0.59vw + 20.71px), 32px);
  font-weight: 600;
  text-align: center;
  position: relative;
  padding-inline: 40px;
  display: inline-block;
}

.eLearningCategoryTitle::before,
.eLearningCategoryTitle::after {
  content: "";
  width: 24px;
  height: 1px;
  background-color: var(--color-blue);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
}

.eLearningCategoryTitle::before {
  left: 0;
}
.eLearningCategoryTitle::after {
  right: 0;
}
.eLearningCategoryList {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: center;
  gap: 33px 18px;
  margin-block-start: 27px;
}

@media screen and (max-width: 840px) {
  .eLearningCategoryList {
    gap: 30px 12px;
    margin-block-start: 33px;
  }
}

.eLearningCategoryItem {
  width: calc(100% / 4 - 14px);
  padding: 28px 11px;
  border-radius: 8px;
  background: #ffffff;
  box-shadow: 0px 0px 5.35011px rgba(0, 0, 0, 0.25);
  transition: 0.3s ease;
}

@media screen and (max-width: 840px) {
  .eLearningCategoryItem {
    width: calc(100% / 2 - 6px);
    padding: 18px 7px;
  }
}
.eLearningCategoryItem:hover {
  background: linear-gradient(180deg, #04befe 0%, #4481eb 100%);
}

.eLearningCategoryItem:hover .eLearningCategoryItemTitle,
.eLearningCategoryItem:hover .eLearningCategoryItemText {
  color: var(--color-white);
}
.eLearningCategoryItemBody {
  text-align: center;
  margin-block-start: 10px;
}

@media screen and (max-width: 840px) {
  .eLearningCategoryItemBody {
    margin-block-start: 4px;
  }
}
.eLearningCategoryItemTitle {
  font-size: clamp(10px, calc(0.33vw + 8.73px), 15px);
  line-height: 2;
  color: var(--color-black);
  transition: 0.3s ease;
  text-align: center;
  font-weight: 600;
  position: relative;
  padding-inline-end: 22px;
  display: inline-block;
}

.eLearningCategoryItemTitle:after {
  content: "";
  position: absolute;
  right: 1%;
  top: 50%;
  display: block;
  width: 9px;
  height: 9px;
  border-top: 2px solid var(--color-blue);
  border-right: 2px solid var(--color-blue);
  transform: translateY(-50%) rotate(45deg);
  z-index: 2;
}
.eLearningCategoryItem:hover .eLearningCategoryItemTitle::after {
  border-top: 2px solid var(--color-white);
  border-right: 2px solid var(--color-white);
}

.eLearningCategoryItemText {
  font-size: clamp(9px, calc(0.39vw + 7.47px), 15px);
  line-height: 1.5;
  color: var(--color-black);
  text-align: center;
  font-weight: 600;
  margin-block-start: 10px;
  transition: 0.3s ease;
}

/* ==========================
自社コンテンツ
========================== */
.originalContents {
  margin-block-start: 8px;
}
@media screen and (max-width: 840px) {
  .originalContents {
    margin-block-start: 15px;
  }
}
.originalContents__lead {
  letter-spacing: 0.05rem;
  font-weight: 600;
  text-align: center;
  color: var(--color-blue);
  font-size: clamp(16px, calc(0.19vw + 15.33px), 18px);
}
.originalContentsCard {
  margin-block-start: 75px;
  border-radius: 8px;
  background-color: var(--color-white);
  box-shadow: 0px 0px 5.67182px rgba(0, 0, 0, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 62px;
}
@media screen and (max-width: 840px) {
  .originalContentsCard {
    flex-direction: column-reverse;
    margin-block-start: 27px;
    gap: 36px;
  }
}
.originalContentsCardBody {
  padding-inline-start: 53px;
}
@media screen and (max-width: 840px) {
  .originalContentsCardBody {
    padding-inline: 25px;
  }
}

.originalContentsCardLead {
  font-size: clamp(14px, calc(0.39vw + 12.47px), 20px);
  color: var(--color-blue);
  font-weight: 600;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 840px) {
  .originalContentsCardLead {
    text-align: center;
  }
}
.originalContentsCardTitle {
  font-size: clamp(20px, calc(1.11vw + 16px), 32px);
  margin-block-start: 10px;
  color: var(--color-blue);
  font-weight: 600;
  letter-spacing: 0.05rem;
}
@media screen and (max-width: 840px) {
  .originalContentsCardTitle {
    text-align: center;
    margin-block-start: 0;
  }
}
.originalContentsCardText {
  margin-block-start: 25px;
  line-height: 1.8;
  font-weight: 500;
  font-size: clamp(14px, calc(0.19vw + 13.33px), 16px);
}
@media screen and (max-width: 840px) {
  .originalContentsCardText {
    margin-block-start: 14px;
    line-height: 1.5;
    padding-block-end: 35px;
  }
}
.originalContentsCardImage {
  text-align: center;
  max-width: 530px;
  flex-shrink: 0;
}

/* ==========================
階層別研修プログラム例
========================== */

.levelProgram {
  padding-block: 90px 32px;
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 840px) {
  .levelProgram {
    padding-block: 82px 32px;
  }
}

.levelProgramTitle {
  color: var(--color-blue);
  font-size: clamp(20px, calc(0.77vw + 17.23px), 32px);
  font-weight: 600;
  text-align: center;
  position: relative;
  padding-inline: 40px;
  display: inline-block;
}

.levelProgramTitle::before,
.levelProgramTitle::after {
  content: "";
  width: 24px;
  height: 1px;
  background-color: var(--color-blue);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  display: block;
}

.levelProgramTitle::before {
  left: 0;
}
.levelProgramTitle::after {
  right: 0;
}

.levelProgramList {
  display: flex;
  flex-wrap: wrap;
  column-gap: 16px;
  row-gap: 13px;
  margin-block-start: 34px;
}

@media screen and (max-width: 840px) {
  .levelProgramList {
    padding-inline: 16px;
    row-gap: 16px;
  }
}
.levelProgramItem {
  cursor: pointer;
  border-radius: 7px;
  background-color: var(--color-white);
  box-shadow: 0px 0px 5.40618px rgba(0, 0, 0, 0.25);
  background-color: var(--color-white);
  width: calc(100% / 4 - 12px);
  transition: 0.3s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 840px) {
  .levelProgramItem {
    width: calc(100% / 2 - 10px);
    padding-block: 23px;
    padding-inline: 5px;
    font-feature-settings: "palt";
  }
}

.levelProgramItem:hover a {
  color: var(--color-blue);
}

.levelProgramItem a {
  display: block;
  padding-block: 28px;

  font-size: clamp(14px, calc(0.2vw + 13.24px), 17px);
  color: var(--color-black);
  line-height: 1.7;
  position: relative;
  font-weight: 600;
  padding-inline-end: 22px;
  text-align: center;
}

@media screen and (max-width: 840px) {
  .levelProgramItem a {
    white-space: nowrap;
  }
}

.levelProgramItem a::after {
  content: "";
  position: absolute;
  right: 1%;
  top: 50%;
  display: block;
  width: 9px;
  height: 9px;
  border-top: 2px solid var(--color-blue);
  border-right: 2px solid var(--color-blue);
  transform: translateY(-50%) rotate(45deg);
  z-index: 2;
}

.levelProgramText {
  font-size: clamp(18px, calc(0.26vw + 16.98px), 22px);
  line-height: 1.8;
  color: var(--color-black);
  text-align: center;
  font-weight: 600;
  margin-block-start: 40px;
}

@media screen and (max-width: 840px) {
  .levelProgramText {
    margin-block-start: 13px;
    line-height: 1.5;
  }
}
/* ==========================
eラーニングは動画視聴だけでは終わらない。
========================== */
.eLearningPoint {
  padding-block: 160px 146px;
}

@media screen and (max-width: 840px) {
  .eLearningPoint {
    padding-block: 60px 79px;
  }
}

.eLearningPointLead {
  color: var(--color-white);
  font-size: clamp(18px, calc(0.46vw + 16.22px), 25px);
  text-align: center;
  font-weight: 600;
  display: inline-block;
  padding-inline: 54px;
  padding-block: 10px;
  background: linear-gradient(90deg, #79b7ed 0%, #2c77c8 86%);
  box-shadow: 0px 4.17507px 35.4881px rgba(0, 82, 103, 0.18);
  border-radius: 50px;
}
@media screen and (max-width: 840px) {
  .eLearningPointLead {
    padding-inline: 22px;
  }
}

.eLearningPointTitle {
  font-size: clamp(25px, calc(0.98vw + 21.18px), 40px);
  font-weight: 600;
  line-height: 1.5;
  text-align: center;
  background: linear-gradient(90deg, #79b7ed 0%, #2c77c8 86%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  margin-block-start: 28px;
}

@media screen and (max-width: 840px) {
  .eLearningPointTitle {
    margin-block-start: 20px;
  }
}
.eLearningPointText {
  margin-block-start: 45px;
  text-align: center;
  font-size: clamp(16px, calc(0.39vw + 14.47px), 22px);
  line-height: 2;
  color: var(--color-black);
  font-weight: 500;
}

@media screen and (max-width: 840px) {
  .eLearningPointText {
    text-align: left;
    margin-block-start: 33px;
    line-height: 1.8;
  }
}

.eLearningPointList {
  display: flex;
  gap: 40px;
  margin-block: 100px 99px;
}
@media screen and (max-width: 840px) {
  .eLearningPointList {
    flex-direction: column;
    margin-block: 66px 34px;
  }
}
.eLearningPointItemBody {
  display: flex;
  flex-direction: column;
  margin-block-start: 40px;
}

@media screen and (max-width: 840px) {
  .eLearningPointItemBody {
    margin-block-start: 22px;
  }
}

.eLearningPointItem {
  width: calc(100% / 3 - 10px);
}

@media screen and (max-width: 840px) {
  .eLearningPointItem {
    width: 100%;
    max-width: 500px;
  }
}
.eLearningPointItemTitle {
  color: #2285ff;
  font-weight: 600;
  font-size: clamp(18px, calc(0.46vw + 16.33px), 23px);
  text-align: center;
  flex-grow: 1;
}

.eLearningPointItemText {
  color: var(--color-black);
  font-weight: 500;
  margin-block-start: 18px;
  font-size: clamp(13px, calc(0.2vw + 12.24px), 16px);
}

.eLearningPointFlowText {
  margin-block-start: 20px;
  font-size: clamp(20px, calc(0.46vw + 18.33px), 25px);
  color: var(--color-black);
  font-weight: 600;
  text-align: center;
  line-height: 1.5;
}

@media screen and (max-width: 840px) {
  .eLearningPointFlowText {
    margin-block-start: 47px;
  }
}
.eLearningPointFlowText .color {
  color: var(--color-blue);
  font-size: clamp(24px, calc(0.56vw + 22px), 30px);
}

/* ==========================
CV
========================== */
.eLearningCta {
  background-color: var(--color-blue);
}
.eLearningCtaInner {
  padding-block: 85px;
}
@media screen and (max-width: 840px) {
  .eLearningCtaInner {
    padding-block: 65px;
    padding-inline: 16px;
  }
}
.eLearningCtaTitle {
  font-size: clamp(23px, calc(0.59vw + 20.71px), 32px);
  text-align: center;
  font-weight: bold;
  margin-block-end: 48px;
  color: var(--color-white);
}
@media screen and (max-width: 840px) {
  .eLearningCtaTitle {
    line-height: 1.5;
  }
}
.eLearningCtaButton {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
  border-radius: 100vw;
  width: 100%;
  max-width: 440px;
  padding-block: 20px;
  display: inline-block;
  text-align: center;
  transition: 0.3s ease;
  box-shadow: 0px 0px 20px rgba(0, 0, 0, 0.15);
}

.eLearningCtaButton:hover {
  transform: translateY(-10px);
}

.eLearningCtaButton .small {
  font-size: 16px;
  text-align: center;
  line-height: 1.4;
}

.eLearningCtaButtonWhite {
  background-color: var(--color-white);
  color: var(--color-blue);
  outline: solid 5px var(--color-blue);
  margin-right: 30px;
}

@media screen and (max-width: 840px) {
  .eLearningCtaButtonWhite {
    margin-right: 0;
    margin-block-end: 30px;
  }
}

.eLearningCtaButtonWhite:hover {
  background-color: var(--color-blue);
  outline: solid 5px var(--color-white);
  color: var(--color-white);
}

.eLearningCtaButtonOrange {
  background-color: #ec7730;
  color: var(--color-white);
  outline: solid 5px var(--color-white);
}

.eLearningCtaButtonOrange:hover {
  background-color: var(--color-white);
  outline: solid 5px #ec7730;
  color: #ec7730;
}

/* ==========================
カテゴリー別コンテンツ - 共通
========================== */

/* 動画 */
.contents.js-dialog {
  align-items: center;
  margin: auto;
  margin-inline: auto;
  border-radius: 10px;
  border: none;
  max-width: 960px;
}

@media screen and (max-width: 430px) {
  .contents.js-dialog {
    margin-inline: 16px;
  }
}

.js-dialog-close:before,
.js-dialog-close:after {
  display: none;
}
.contents.js-dialog .dialog_inner {
  min-width: auto;
  padding-top: 50px;
}
.courseContentsSlideItem {
  cursor: pointer !important;
}
.courseContentsSlideItemImage {
  position: relative;
}
.js-movie-trigger {
  padding: 10px;
  cursor: pointer;
  max-width: 74px;
  display: inline-block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
/* 動画 */
/* Swiper */
.swiper-button-prev,
.swiper-button-next {
  width: 25px;
  height: 41px;
  position: absolute;
  cursor: pointer;
  top: 50%;
  z-index: 2;
  transform: translateY(-50%);
}
.swiper-button-course-next:before {
  content: "";
  width: 25px;
  height: 41px;
  background-image: url(../img/course/swiper-button-course.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  right: 20px;
}
.swiper-button-course-prev:before {
  content: "";
  width: 25px;
  height: 41px;
  background-image: url(../img/course/swiper-button-course.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 0;
  left: -40px;
  transform: rotate(180deg);
}
@media screen and (max-width: 390px) {
  .swiper-button-course-prev:before {
    left: 0;
  }
}
.courseContentsSlideList {
  position: relative;
  margin-inline-start: clamp(1px, calc(50.73vw + -557.05px), 417px);
}

.courseContentsSlideItem {
  display: flex;
  flex-direction: column;
  transition: opacity 0.3s;
  height: auto !important;
  align-items: flex-start !important;
}
.is-dim {
  opacity: 0.3;
}

.courseContentsSlideItemBody {
  display: flex;
  height: 100%;
  flex-direction: column;
}
.courseContentsSlideItemTitle {
  font-size: clamp(14px, calc(0.13vw + 13.49px), 16px);
  color: var(--color-black);
  line-height: 1.5;
  font-weight: 600;
  flex-grow: 1;
  padding-block: 17px;
}

.courseContentsSlideLabels {
  display: flex;
  gap: 13px 5px;
  flex-wrap: wrap;
}

.courseContentsSlideLabel {
  background-color: var(--color-blue);
  border-radius: 4px;
  color: var(--color-white);
  font-size: 10px;
  text-align: center;
  font-weight: 500;
  line-height: 1.5;
  padding: 3px 8px;
}

/* Swiper */

.courseContentsHead {
  background: linear-gradient(90deg, #ffffff 0%, #edf4ff 100%);
}
.courseContentsHeadInner {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-block: 60px;
  gap: 120px;
}
@media screen and (max-width: 840px) {
  .courseContentsHeadInner {
    flex-direction: column;
    padding-block: 23px;
    gap: 34px;
  }
}
.courseContentsHeadTitle {
  position: relative;
  padding-inline-start: 35px;
  font-size: 25px;
  color: var(--color-black);
  font-weight: 600;
}

.courseContentsHeadTitle:before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 30px;
  background-color: var(--color-blue);
}

.courseContentsHeadDetail {
  font-weight: 500;
  font-size: 17px;
  color: #333;
  margin-block-start: 35px;
}
@media screen and (max-width: 840px) {
  .courseContentsHeadDetail {
    margin-block-start: 27px;
  }
}
.courseContentsHeadImage {
  max-width: 360px;
}
.courseContentsAboutList {
  display: flex;
  flex-direction: column;
  gap: 93px;
  padding-block: 26px 160px;
  max-width: 1100px;
  margin-inline: auto;
}

@media screen and (max-width: 840px) {
  .courseContentsAboutList {
    padding-block: 36px 107px;
    gap: 68px;
  }
}
.courseContentsAboutItem ul li {
  padding-inline-start: 25px;
  position: relative;
}

.courseContentsAboutItem ul li:before {
  content: "●";
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  color: var(--color-blue);
}

.courseContentsAboutTitle {
  font-size: 20px;
  color: #535353;
  font-weight: 600;
  padding-block-end: 25px;
  border-bottom: solid 2px var(--color-blue);
  margin-bottom: 16px;
}
@media screen and (max-width: 840px) {
  .courseContentsAboutTitle {
    font-size: 25px;
    padding-block-end: 11px;

    margin-bottom: 26px;
    line-height: 1.5;
    display: flex;
  }
}
.courseContentsAboutText {
  font-size: 16px;
}
.courseContentsAboutTitle .number {
  color: var(--color-blue);
  display: inline-block;
  padding-inline-end: 15px;
}
.courseContentsAboutItemMerit .courseContentsAboutText {
  font-size: 16px;
  color: var(--color-blue);
  font-weight: 600;
  line-height: 1.5;
}
.courseContentsAboutItemAll .courseContentsAboutText {
  font-size: 16px;
  line-height: 1.6;
  font-weight: 500;
}

/* ==========================
検索結果
========================== */
.resultCourseHead {
  background-color: #edf4ff;
  position: relative;
}
.resultCourseHead::before {
}

.resultCourseHeadInner {
  padding-block: 100px;
}
.resultCourseHeadTitle {
  font-size: clamp(20px, calc(0.78vw + 17.09px), 32px);
  font-weight: 600;
  color: var(--color-black);
  text-align: center;
}

.resultCourseHeadTitle .color {
  color: var(--color-blue);
}

.resultCourseHeadLead {
  margin-block-start: 25px;
  font-size: clamp(18px, calc(0.26vw + 17.03px), 22px);
  font-weight: 600;
  color: var(--color-black);
  line-height: 1.5;
  text-align: center;
}

/* .resultCourse {
  margin-inline-start: clamp(1px, calc(50.73vw + -557.05px), 417px);
}
.resultCourseInner {
  max-width: 1500px;
  margin-left: auto;
} */

.resultCourseList {
  display: flex;
  flex-direction: column;
  gap: 100px;
  padding-block: 40px;
}

.resultCourseTitle {
  font-size: clamp(19.98px, calc(0.26vw + 18.96px), 24px);
  font-weight: 600;
  color: var(--color-black);
  position: relative;
  padding-left: 30px;
}
.resultCourseTitle::before {
  content: "●";
  font-size: clamp(19.98px, calc(0.26vw + 18.96px), 24px);
  color: var(--color-blue);
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
}

@media screen and (max-width: 1500px) {
  .resultCourse {
    padding-inline: 40px;
    margin-left: 0;
    overflow: hidden;
  }
}
@media screen and (max-width: 840px) {
  .resultCourse {
    padding-inline: 16px;
  }
}

.resultCourseSliderWrap {
  margin-block-start: 30px;
}
.coursePicker {
  display: grid;
  grid-template-columns: 405px 1fr;
  gap: 24px;
  align-items: center;
  position: relative;
}

@media screen and (max-width: 500px) {
  .coursePicker {
    grid-template-columns: 278px 1fr;
    align-items: flex-start;
  }
}

.coursePickerFeatured {
  min-height: 320px;
}

.coursePickerFeaturedCard {
  display: block;
}
.coursePickerFeaturedImage {
  position: relative;
}

/* @media screen and (max-width: 840px) {
  .coursePickerFeaturedImage {
    max-width: 278px;
  }
} */

.coursePickerFeaturedCard img {
  display: block;
  width: 100%;
  height: auto;
}

.coursePickerFeaturedCard h2 {
  margin: 12px 0 8px;
}

.coursePickerFeaturedLabels {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.coursePickerSide {
  position: relative;
}

.coursePickerViewport {
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: 8px 40px;
  max-width: clamp(597px, calc(55.83vw + -6px), 1066px);
}

.coursePickerViewport::-webkit-scrollbar {
  display: none;
}

.coursePickerList {
  display: flex;
  gap: 24px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.coursePickerItem {
  flex: 0 0 auto;
  width: 270px;
  opacity: 0.45;
  transition: opacity 0.3s;
}

.coursePickerItem.is-active {
  opacity: 1;
}

.coursePickerCard {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: none;
  text-align: left;
  cursor: pointer;
}

.coursePickerCard img {
  display: block;
  width: 100%;
  height: auto;
}

.coursePickerNav {
  width: 25px;
  height: 41px;
  background-image: url(../img/course/swiper-button-course.svg);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
}

.coursePickerPrev {
  left: 0;
  transform: translateY(-50%) scale(-1, 1);
}
@media screen and (max-width: 500px) {
  .coursePickerPrev {
    left: -329px;
    display: block;
    transform: translateY(-50%) scale(-1, 1);
  }
}

.coursePickerNext {
  right: 0;
}

@media screen and (max-width: 500px) {
  .coursePickerNext {
    left: 0;
  }
}

.coursePickerNav[disabled] {
  opacity: 0.3;
  cursor: default;
}
/* ==========================
カテゴリー別コンテンツ - マネジメント
========================== */
