/* 바다나무 프로그램 컬러 */

:root {
  --rhyme: linear-gradient(
    90deg,
    rgba(133, 86, 157, 1) 0%,
    rgba(143, 95, 165, 1) 100%
  );

  --genius: linear-gradient(
    90deg,
    rgba(244, 159, 48, 1) 0%,
    rgba(245, 167, 55, 1) 100%
  );

  --talk: linear-gradient(
    90deg,
    rgba(140, 182, 69, 1) 0%,
    rgba(149, 189, 77, 1) 100%
  );

  --sound: linear-gradient(
    90deg,
    rgba(65, 164, 222, 1) 0%,
    rgba(73, 172, 226, 1) 100%
  );

  --read: linear-gradient(
    90deg,
    rgba(239, 98, 94, 1) 0%,
    rgba(241, 108, 104, 1) 100%
  );
}

.rhyme-bg {
  background: var(--rhyme);
}

.genius-bg {
  background: var(--genius);
}

.talk-bg {
  background: var(--talk);
}

.sound-bg {
  background: var(--sound);
}

.read-bg {
  background: var(--read);
}

:root {
  --rhyme-color: #9666ac;
  --rhyme-intro-bg: #f8f5fa;

  --genius-color: #f6ad3c;
  --genius-intro-bg: #fff9ef;

  --talk-color: #9bc253;
  --talk-intro-bg: #f7ffe8;

  --sound-color: #4fb2e4;
  --sound-intro-bg: #f2f9fd;

  --read-color: #f2726e;
  --read-intro-bg: #fff6f6;
}

/* 캐릭터 */
.bada {
  --background: #95d2f2;
  --color: #69b3e7;
}

.jess {
  --background: #f48da1;
  --color: #e0457b;
}

.curly {
  --background: #8270b3;
  --color: #8370b3;
}

.pogo {
  --background: #0e3267;
  --color: #f26924;
}

.mimi {
  --background: #f9bac4;
  --color: #e82b42;
}

.abby {
  --background: #b9d982;
  --color: #ffce34;
}

.mat {
  --background: #faa74a;
  --color: #f26a2d;
}

.mipi {
  --background: #f598a6;
  --color: #f598a6;
}

.eccos {
  --background: #85c552;
  --color: #86c551;
}

/* product 상세페이지 css */

.progarm-tit .image {
  position: relative;
  bottom: -65px;
  width: 62%;
}

.progarm-tit .text {
  flex: 1;
}

.progarm-tit .text p {
  font-family: "pretendard", sans-serif;
  margin-top: 35px;
  letter-spacing: -0.05rem;
}

.program-intro .content-title h2 {
  font-size: var(--f90);
  line-height: 1;
}

.program-intro .content-title h3 {
  color: var(--program-color);
  margin-top: 6px;
}

.program-intro .content-title h5 {
  letter-spacing: -1.5px;
  color: var(--color-mute);
  margin: 10px 0 0 0;
}

.program-intro .pdt-list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 10px;
  row-gap: 20px;
  justify-content: center;
  margin: 40px auto 0 auto;
  max-width: 1000px;
}

.program-intro .pdt-list li {
  font-family: "vag-rundschrift-d", "gulim", "Pretendard", sans-serif;
  font-size: var(--f22);
  letter-spacing: 0.4px;
  padding: 10px 20px;
  background-color: #fff;
  border-radius: 50px;
  width: fit-content;
  color: #314650;
  line-height: 1;
}

.program-intro .pdt-list li span {
  font-size: var(--font-size-default);
}

.info-area {
  position: relative;
  margin-top: -70px;
}

.info-area .container {
  --container-width: 1200px;
}

.info-area .info-box {
  position: relative;
}

.info-box {
  background-color: #fff;
  border-radius: 30px;
  padding: 60px;
  box-shadow: 0 4px 17px 0 rgba(0, 0, 0, 0.05);
}

.info-box > div ~ div {
  margin-top: 40px;
}

.info-box .tit-label {
  font-size: var(--f20);
  font-weight: 500;
  letter-spacing: -0.8px;
  background-color: var(--program-color);
  border-radius: 50px;
  color: #fff;
  text-align: center;
  padding: 5px 25px;
  width: fit-content;
  margin-bottom: 15px;
}

.info-box h4 {
  font-family: "vag-rundschrift-d", "gulim", sans-serif;
  font-weight: 400;
  letter-spacing: 0.4px;
  color: var(--program-color);
  margin-bottom: 5px;
  padding-left: 5px;
}

.info-box h5 {
  color: var(--color-mute);
  font-size: var(--f20);
  font-weight: 400;
  padding-left: 5px;
}

.info-box ul li {
  color: var(--color-mute);
  font-size: var(--f20);
  font-weight: 400;
  line-height: 1.6;
  position: relative;
  padding-left: 12px;
}

.info-box ul li::before {
  content: "·";
  position: absolute;
  left: 0;
}

.info-box ul li ~ li {
  margin-top: 4px;
}

.monthly-package {
  background-color: #fafafa;
}

.monthly-package .content-title h5 {
  margin-top: 10px;
  color: var(--color-mute);
  letter-spacing: -1.5px;
}

.monthly-package .monthly-list {
  display: flex;
  flex-wrap: wrap;
  column-gap: 10px;
  row-gap: 20px;
  justify-content: center;
  margin: 25px auto 0 auto;
}

.monthly-package .monthly-list li {
  font-family: "vag-rundschrift-d", "gulim", "Pretendard", sans-serif;
  font-size: var(--f22);
  letter-spacing: 0.4px;
  padding: 10px 20px;
  border-radius: 50px;
  width: fit-content;
  background-color: #fff;
  color: #314650;
  line-height: 1;
  box-shadow: 0 5px 5px 0 rgba(0, 0, 0, 0.02);
}

.monthly-package .lb-grid {
  --grid-num: 3;
  --grid-t-num: 2;
  --grid-m-num: 1;
}

.monthly-package .label-box {
  --label-height: 65px;
  --label-color: var(--program-color);
}

.monthly-package .label-box .content {
  text-align: left;
  padding: 30px 40px 40px 40px;
  height: calc(100% - 65px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  row-gap: 20px;
}

.monthly-package .label-box .content h5 {
  color: var(--program-color);
  font-size: var(--f20);
}

.monthly-package .label-box .content p {
  font-size: var(--f16);
  color: var(--color-mute);
  letter-spacing: -0.5px;
  line-height: 1.4;
  margin-top: 5px;
}

/* Desktop ( 1024px ~)*/
@media all and (min-width: 1024px) {
}

/* Laptop ( 1024px ~ 1440px)*/
@media all and (min-width: 1024px) and (max-width: 1440px) {
  .tit-banner .content {
    gap: 15px;
  }

  .progarm-tit .image {
    width: 55%;
  }

  .progarm-tit .text p br.none-L {
    display: none;
  }
}

/* Tablet ( 768px ~ 1023px)*/
@media all and (min-width: 768px) and (max-width: 1023px) {
  .progarm-tit {
    height: auto;
    padding-top: 80px;
  }

  .progarm-tit .content {
    flex-direction: column;
    gap: 0;
  }

  .progarm-tit .text * {
    text-align: center;
  }

  .progarm-tit .text h1 br {
    display: none;
  }

  .progarm-tit .image {
    width: 85%;
    margin-top: -25px;
  }

  .progarm-tit .text p {
    margin-top: 25px;
  }

  .program-intro .pdt-list {
    column-gap: 8px;
    row-gap: 12px;
  }

  .info-box {
    padding: 50px;
  }

  .monthly-package .monthly-list {
    column-gap: 8px;
    row-gap: 12px;
  }

  .monthly-package .label-box {
    --label-height: 55px;
  }

  .monthly-package .label-box .content {
    padding: 20px 30px 30px 30px;
    height: calc(100% - 55px);
  }
}

/* Mobile ( ~ 767px)*/
@media all and (max-width: 767px) {
  .progarm-tit {
    height: auto;
    padding: 0;
    padding-top: 40px;
  }

  .progarm-tit .content {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    padding: 0 10px;
  }

  .progarm-tit .text * {
    text-align: center;
  }

  .progarm-tit .text h1 br {
    display: none;
  }

  .progarm-tit .image {
    width: 100%;
    margin-top: -25px;
    bottom: -35px;
  }

  .progarm-tit .text p {
    margin-top: 25px;
  }

  .program-intro .pdt-list {
    column-gap: 6px;
    row-gap: 8px;
    margin: 30px auto 0 auto;
  }

  .program-intro .pdt-list li {
    font-size: 14px;
    padding: 8px 12px;
  }

  .info-area {
    margin-top: 0;
  }

  .info-box {
    padding: 35px;
  }

  .info-box > div ~ div {
    margin-top: 30px;
  }

  .info-box .tit-label {
    padding: 4px 16px;
    margin-bottom: 10px;
  }

  .info-box ul li {
    padding-left: 10px;
  }

  .monthly-package .monthly-list {
    column-gap: 6px;
    row-gap: 8px;
  }

  .monthly-package .monthly-list li {
    font-size: 14px;
    padding: 8px 12px;
  }

  .monthly-package .lb-grid {
    --grid-num: 3;
    --grid-t-num: 2;
    --grid-m-num: 1;
  }

  .monthly-package .label-box {
    --label-height: 50px;
  }

  .monthly-package .label-box .content {
    padding: 20px 25px 30px 25px;
    height: calc(100% - 50px);
  }
}
