@font-face {
    font-family: 'Pretendard-Regular';
    src: url('https://fastly.jsdelivr.net/gh/Project-Noonnu/noonfonts_2107@1.1/Pretendard-Regular.woff') format('woff');
    font-weight: 400;
    font-style: normal;
}
@import url('/comm/css/font.css');
@import url('//fonts.googleapis.com/earlyaccess/notosanskr.css');
body {
      background-color: #fdfdfd;
      font-family: 'Pretendard';
    }
	/* ��޴� �����̳� */
#topmenu {
  background: white;
  padding: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  position: sticky;
  top: 0;
  z-index: 100;
}
.sms-row button {
    background-color: #fee500;
    border: 1px solid #d6d6d6;
    font-size: 14px;
    border-radius: 6px;
    letter-spacing: -1px;
    font-weight: 500;
}
/* ���� ����� */
.header-bar {
  background: white;
  border-bottom: 1px solid #eee;
  padding: 0.35rem 1rem;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin: auto;
  max-width: 60rem;
  position: relative;
}

/* �ΰ� */
.header-left img {
  height: 34px;
}

/* ����ũž�� ���� ��ũ */
.header-right {
  display: flex;
  align-items: center;
}
.header-right a {
  margin-left: 1rem;
  font-weight: 600;
  color: #000;
  text-decoration: none;
}

/* ����Ͽ� �ܹ��� ��� ��ư (�⺻ ����) */
.header-toggle {
  display: none;
  background: none;
  border: none;
  font-size: 1.8rem;
  cursor: pointer;
  color: #000;
}

@media (max-width: 768px) {
  /* 1) header-bar�� ���� �������� */
  .header-bar {
    flex-direction: row;
    align-items: flex-end;
    padding: 12px 21px;
    max-width: 100%;
    display: flex;
    gap: 24px;
    justify-content: flex-end;
  }

  /* 2) �ΰ� ���� �Ʒ��� ���� */
  .header-left {
    margin-bottom: 0.5rem;
  }

  /* 3) ���� �޴�(.header-right)�� ���̰�, ���� ��ũ�� */
  .header-right {
    display: flex;               /* flex row */
    flex-direction: row;
    overflow-x: auto;            /* ���� ��ũ�� ��� */
    -webkit-overflow-scrolling: touch; /* iOS ��ġ ������ ��ũ�� */
    width: 100%;
    gap: 1rem;
    padding-bottom: 0.5rem;
  }

  /* 4) ��ũ flex ����������, �ٹٲ� ���� */
  .header-right a {
    flex: 0 0 auto;
    white-space: nowrap;
    margin: 0;                   /* ������ ������ gap���� */
  }

  /* 5) ���ʿ��� ��� ��ư ����� */
  .header-toggle {
    display: none !important;
  }
}

/* ȭ�� Ȯ�� �� ����� �޴� �ڵ� ���� (JS���� ����) */

    .lecture-card {
      background: #fff;
      border-radius: 10px;
      padding: 1rem;
      border: 1px solid #ccc;
      box-shadow: 0 2px 8px rgba(0,0,0,0.05);
      min-height: 277px;
    }
    .lecture-card .lecture-img {
      background-color: #ccc;
      width: 100%;
      aspect-ratio: 16 / 9;
      border-radius: 8px;
      position: relative;
    }
    .lecture-card .lecture-img::before {
      content: '\25B6';
      font-size: 3rem;
      color: white;
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
    }
.lecture-card .lecture-img img {
    height: 126px;
    border-radius: 9px;
    object-fit: cover;
}
    .lecture-card .badge {
      position: absolute;
      top: 10px;
      left: 10px;
    }
    .lecture-card .status {
      font-weight: bold;
      font-size: 0.9rem;
      color: #555;
      margin-top: 0.5rem;
    }
    .lecture-progress {
      height: 6px;
      background-color: #eee;
      border-radius: 3px;
      overflow: hidden;
    }
    .lecture-progress .progress-bar {
      height: 100%;
      background-color: #d22b42;
    }
    .info-box {
      border-radius: 12px;
      text-align: center;
      padding: 1rem;
      font-size: 0.9rem;
      font-weight: 500;
    }
    .info-box.green {background: #e5f8e0;color: #009900;border: 1px solid #009900;}
    .info-box.purple {background: #f3f2fd;color: #5e35b1;border: 1px solid #5e35b1;}
    .info-box.blue {background: #eef7fe;color: #0077cc;border: 1px solid #0077cc;}
    .info-box.gray {background: #f7f7f7;color: #444;border: 1px solid #444;}
    .info-box.orange {background: #fff7e0;color: #f57c00;border: 1px solid #f57c00;}
    .sticky-bottom-bar {
      position: sticky;
      bottom: 0;
      background: linear-gradient(to right, #c63000, #FFEB3B);
      color: white;
      text-align: center;
      padding: 1rem;
      font-weight: bold;
      /* padding-top: 46px; */
      /* display: none; */
    }
.text-center {
    display: flex;
    align-items: center;
    justify-content: center;
}
.wi_all {
    width: 100%;
}
.bg-white {
    border: 1px solid #ababab;
    color: #000000;
}
a {
    color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));
    text-decoration: none !important;
}
.align-items-center button{
    border-radius: 8px;
    width: auto;
    background-color: #b8b8b8;
}
.align-items-center2 button {
    border-radius: 8px;
    width: auto;
    background-color: #b8b8b8;
}
.d-flex {
    background-color: #f0f0f0;
    padding: 21px;
    border-radius: 9px;
    border: 0px solid #eee;
}
.d-flex2 {
    background-color: #ffffff;
    padding: 0px 2px 17px 21px;
    border-radius: 9px;
    border: 0px solid #eee;
    display: flex !important;
}
.text-truncate {font-size:16px;}
.gap-3 {/* flex: 1; */}
.p-2 {flex: 1}
    .sticky-bottom-bar button {
      background: white;
      color: #f857a6;
      font-weight: bold;
      border: none;
      padding: 0.5rem 1rem;
      border-radius: 5px;
    }
	.lecture-row {
      display: flex;
      flex-wrap: wrap;
      gap: 12px;
      margin-top: 14px;
    }
.col-md-4 {
    padding: 10px;
    flex: 1 1 0;
    width: auto;
}
    .lecture-card.flex-equal {
      flex: 1 1 calc(33.333% - 1rem);
      min-width: 220px;
    }
    .lecture-card .badge {
      position: absolute;
      top: 12px;
      left: 12px;
      z-index: 2;
    }
 .lecture-card .badge2 {
      position: absolute;
      top: 12px;
      left: 55px;
      z-index: 2;
      --bs-badge-padding-x: 0.65em;
      --bs-badge-padding-y: 0.35em;
      --bs-badge-font-size: 0.75em;
      --bs-badge-font-weight: 700;
      --bs-badge-color: #fff;
      --bs-badge-border-radius: var(--bs-border-radius);
      display: inline-block;
      padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
      font-size: var(--bs-badge-font-size);
      font-weight: var(--bs-badge-font-weight);
      line-height: 1;
    }
	.video-header {
    background-color: #fff;
    padding: 1rem;
    border-bottom: 1px solid #eee;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .video-header .logo {
    height: 36px;
  }
  .video-header .menu a {
    margin-left: 1rem;
    text-decoration: none;
    font-weight: 500;
  }
  .video-header .menu a.text-danger {
    color: #d22b42;
  }
  .video-header .menu a.text-success {
    color: #00aa66;
  }
  .video-warning {
    background-color: #a00000;
    color: #fff;
    padding: 0.75rem;
    font-size: 0.85rem;
    text-align: center;
    font-weight: bold;
  }
  .video-container {
    display: flex;
    flex-direction: row;
    gap: 1.5rem;
    padding: 2rem 1rem;
    background-color: #f9f9f9;
  }
  .video-player {
    flex: 4;
    position: relative;
  }
  .video-player img {
    width: 100%;
    border-radius: 10px;
  }
  .video-player .play-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 4rem;
    color: white;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    width: 80px;
    height: 80px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .video-playlist {
    flex: 1.5;
    background: white;
    border-radius: 8px;
    overflow-y: auto;
    max-height: 600px;
    padding: 9px;
    border: 1px solid #dcdcdc;
  }
  .video-playlist .section-title {
    font-size: 0.85rem;
    color: #888;
    margin-bottom: 0.5rem;
  }
  .video-playlist .playlist-item {
    padding: 0.5rem 0;
    border-bottom: 1px solid #eee !important;
    font-size: 13px;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .video-playlist .playlist-item .title {
    font-size: 13px;
    letter-spacing: -1px;
}
  .video-playlist .playlist-item.active {
    color: #d22b42;
    font-weight: bold;
  }
.sec-list {
    border-bottom: 1px solid #000;
}
  .video-footer {
    background: #fff;
    padding: 2rem 1rem;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }
  .video-footer h5 {
    font-weight: bold;
    margin-bottom: 0.5rem;
  }
  .video-footer .footer-bottom {
    margin-top: 2rem;
    font-size: 0.85rem;
    color: #666;
    line-height: 1.6;
  }
  .playlist-item {
      padding: 8px 10px;
      border-radius: 6px;
      display: flex;
      justify-content: space-between;
      align-items: center;
    }
    .playlist-item.active {
      /* background-color: #f8f9fa; */
      font-weight: bold;
    }
    .playlist-item span {
      font-size: 12px;
      /* color: #888; */
    }
    .playlist-item.red span {
      color: #dc3545;
      font-weight: bold;
    }
.playlist-item .meta{
    font-size: 14px;
    letter-spacing: -1px;
}
.page-wrapper { margin: 0; font-family: 'Noto Sans KR', sans-serif; display: flex; justify-content: center; align-items: center; height: 100vh; background: #f9f9f9; }
    .signup-box { text-align: center; background: #fff; padding: 40px 20px; border-radius: 12px; box-shadow: 0 4px 10px rgba(0,0,0,0.1); width: 100%; max-width: 400px; }
    .signup-box img { width: 80px; margin-bottom: 20px; }
    .signup-box h2 { margin-bottom: 30px; }
    .btn {display: flex;align-items: center;justify-content: center;gap: 8px;width: 100%;padding: 12px;border: none;color: #fff;border-radius: 6px;cursor: pointer;font-size: 16px;margin-bottom: 10px;background-color: #838383;}
    .btn2 {
    display: flex
;
    align-items: center;
    justify-content: center;
    gap: 8px;
    width: 100%;
    padding: 12px;
    border: none;
    color: #fff;
    border-radius: 6px;
    cursor: pointer;
    font-size: 16px;
    margin-bottom: 10px;
    background-color: #838383;
}
.btn-kakao { background: #ffe812; color: #000; }
    .btn-google { background: #f5f5f5; color: #000; }
    .btn-facebook { background: #1877f2; color: #fff; }
    .btn-email { background: #fff; border: 1px solid #ddd; color: #000; }
    .btn:hover { opacity: 0.9; }
	.email-signup-box { background: #fff; padding: 40px 20px; border-radius: 12px; box-shadow: 0 4px 10px rgba(0,0,0,0.1); width: 100%; max-width: 400px; text-align: center; }

    .email-signup-box img { width: 80px; margin-bottom: 20px; }

    .email-signup-box h2 {margin-bottom: 30px;color: #000;letter-spacing: -3px;}

    .form-control { width: 100%; padding: 12px; margin-bottom: 10px; border: 1px solid #ddd; border-radius: 6px; font-size: 14px; }

    .btn-submit { background: #007bff; color: #fff; border: none; width: 100%; padding: 12px; border-radius: 6px; cursor: pointer; font-size: 16px; }

    .btn-submit:hover { opacity: 0.9; }
    @media (max-width: 768px) {
      .lecture-card.flex-equal {
        flex: 1 1 100%;
      }
    }
.col-lg-8 {
    border: 1px solid #cccccc;
    border-radius: 13px;
    padding: 5px 34px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
    background-color: #fff;
}
.mb-2 {
    margin-bottom: 0px !important;
    margin-top: 10px;
}
.gray_box {
    font-size: 0.7rem;
    color: #ffffff !important;
    background-color: #6a0000;
    padding: 10px 25px;
    border-radius: 6px;
    letter-spacing: -1px;
}


.pdp_header,
    .pdp_footer {
      background: #f5f5f5;
      padding: 20px;
      text-align: center;
    }

    .pdp_main { padding: 0; }

    /* ���� 1) ��� ��� (Slick Slider) ���� */
    .banner_section { width: 100%; overflow: hidden; }
    .main_slide .item {
      display: flex !important;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      height: 417px;
      color: #fff;
    }
    /* ���� ���� */
    .main_slide .item-01 {background: linear-gradient(to right, #383653, #383653);}
    .main_slide .item-02 {background-color: #2f2f2f;color: #1c3273;}
    .main_slide .item-03 { background-color: #daf0d9; color: #14532d; }

    .banner_section .container {
      max-width: 1300px;
      margin: 0 auto;
      padding: 0 20px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      width: 100%;
    }
    .content_box {
	flex: 1;
	display: flex;
	height: 417px;
	align-items: center;
	background: url(/img/ss01.png) top / cover no-repeat;
	background-size: cover;
	}
	 .content_box2 {
	flex: 1;
	display: flex;
	height: 417px;
	align-items: center;
	background: url(/img/ss02.png) top / cover no-repeat;
	background-size: cover;
	}
    .content p.title {
     font-size: 45px;
      line-height: 1.3;
      margin-bottom: 10px;
      font-weight: 800;
    }
    .content p.desc { font-size: 1.2rem; }

    .visual_img {
      flex: 1;
    height: 500px;
    background-size: cover;
    background-position: center;
    margin-left: 40px;
    }

    .slick-prev, .slick-next {
      position: absolute; top: 50%; transform: translateY(-50%);
      background: rgba(0,0,0,0.5); color: #fff;
      width: 40px; height: 40px; border-radius: 50%;
      border: none; z-index: 2;
    }
    .slick-prev { left: 20px; }
    .slick-next { right: 20px; }

    /* ���� 2) �ǽð� ����Ʈ (Swiper) ���� */
    .pdp_best-wrapper {
      max-width: 1300px;
      margin: 60px auto;
      padding: 0 20px;
      overflow: hidden;
    }
    .pdp_best-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      margin-bottom: 20px;
    }
    .pdp_best-header h2 {
      font-size: 1.8rem;
      color: #1c3273;
    }
    .pdp_best-controls {
      display: flex;
      align-items: center;
      gap: 12px;
    }
    .pdp_view-all {
      font-size: 1rem;
      color: #1c3273;
    }
    .pdp_best-prev,
    .pdp_best-next {
      background: none;
      border: none;
      font-size: 1.5rem;
      color: #1c3273;
      cursor: pointer;
      line-height: 1;
    }

    .pdp_best-slider {
      overflow: hidden;
    }
    .pdp_best-slider .swiper-wrapper {
      display: flex;
    }
    .pdp_best-slider .swiper-slide {
      flex-shrink: 0;
      margin-right: 20px;
    }
    .pdp_thumb {
      width: 100%;
      padding-top: 56.25%;
      background-size: cover;
      background-position: center;
      border-radius: 6px;
    }
    .pdp_video-info { margin-top: 10px; }
    .pdp_video-title { font-size: 1rem; margin-bottom: 4px; }
    .pdp_video-meta { font-size: 0.9rem; color: #666; }

    /* ���� ���� ������(CSS) ���� */
    @media (max-width: 1024px) {
      .main_slide .item { height: 350px; }
      .content p.title { font-size: 1.7rem; }
      .pdp_best-wrapper { padding: 0 15px; }
    }
    @media (max-width: 768px) {
		.video-container {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
    padding: 2rem 1rem;
    background-color: #f9f9f9;
}
      .main_slide .item {
        flex-direction: column-reverse;
        height: auto;
        padding: 40px 0; }
	  .content_box {flex: 1;display: flex;height: 500px;align-items: center;}
      .visual_img {
        width: 100%;
        height: 200px;
        margin: 20px 0 0;
      }
	  .main_slide .item {
      display: flex !important;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      height: 500px;
      color: #fff;
    }
	.content_box { flex: 1;
	display: flex;    height: 500px;    align-items: center;}
    .content p.title {
      font-size: 2rem;
      line-height: 1.3;
      margin-bottom: 10px;    }
      .content p.title { font-size: 1.5rem; }
      .pdp_best-header h2 { font-size: 1.5rem; }
    }



    @media (max-width: 576px) {
      .content p.title { font-size: 1.3rem; }
      .content p.desc { font-size: 1rem; }
      .main_slide .item { padding: 20px 0; }
      .visual_img { height: 150px; }
    
	.content_box {
    flex: 1;display: flex;
    height: 500px;
    align-items: center;}
.main_slide .item {
      display: flex !important;
      align-items: center;
      justify-content: space-between;
      width: 100%;
      height: 500px;
      color: #fff;
    }
	.content_box { flex: 1;
	display: flex;    height: 500px;    align-items: center;}
    .content p.title {
      font-size: 2rem;
      line-height: 1.3;
      margin-bottom: 10px;
    }
	}

.foot_footer {
  background-color: #f5f5f5;
  padding: 40px 20px;
}

.foot_inner {
  max-width: 1300px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
}

.foot_info {
  flex: 1 1 auto;
}

.foot_nav {
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  margin: 0 0 12px;
  padding: 0;
}

.foot_nav li a {
  font-size: 0.95rem;
  color: #333;
  transition: color 0.2s;
}

.foot_nav li a:hover {
  color: #1c3273;
}

.foot_text {
  font-size: 0.85rem;
  color: #666;
  margin: 4px 0;
}

.foot_logo img {
  max-width: 120px;
  height: auto;
}

/* ����� */
@media (max-width: 768px) {
  .foot_inner {
    flex-direction: column;
    text-align: center;
    align-items: center;
  }
  .foot_nav {
    justify-content: center;
    margin-bottom: 16px;
  }
  .foot_logo {
    margin-top: 20px;
  }
}
/* ��õ ���ᰭ�� ���� */
.pdp_free-wrapper {
  max-width: 1300px;
  margin: 60px auto;
  padding: 0 20px;
  overflow: hidden;
}

/* ��� (Ÿ��Ʋ + ��Ʈ��) */
.pdp_free-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 20px;
}

/* ���� Ÿ��Ʋ */
.pdp_free-header h2 {
  font-size: 1.8rem;
  color: #1c3273;
}

/* ���� ��κ��� + ȭ��ǥ */
.pdp_free-controls {
  display: flex;
  align-items: center;
  gap: 12px;
}

/* ��ư �� ī�� ���� ���� Ŭ���� �״�� ���� */
    .pdp_free-prev,
    .pdp_free-next {
      background: none;
      border: none;
      font-size: 1.5rem;
      color: #1c3273;
      cursor: pointer;
      line-height: 1;
    }
.container {
    /* max-width: 60rem; */
}
/* ======= ���/����/���� ��Ÿ��(����) ======= */
.pt-container {
  max-width: 60rem;
  margin: 0 auto;
  padding: 36px 18px 0 18px;
  font-family: 'Pretendard', 'Noto Sans KR', sans-serif;
}
.pt-main-row {
  display: flex; gap: 38px;
  align-items: flex-start;
  margin-bottom: 14px;
}
.pt-left {
  flex: 1.8 1 0;
    min-width: 310px;
    max-width: 700px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
}
.pt-img16 {
  position: relative;
  width: 100%; aspect-ratio: 16/9;
  background: #e3e6ed;
  border-radius: 16px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.pt-img16 img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.pt-caption {
  margin-top: 26px; font-size: 19px; color: #223d7d; text-align: left; line-height: 1.6; font-weight: 500;
}
.pt-right {
  flex: 1 1 0; width: calc(100% - 700px); background: #fff; border-radius: 13px; box-shadow: 0 1px 10px rgba(190,200,220,0.07);
  padding: 32px 22px 24px 22px; display: flex; flex-direction: column; gap: 10px; align-items: flex-start;
}
.pt-author { font-size: 14px; color: #6a7687; margin-bottom: 4px;}
.pt-title { font-size: 21px; font-weight: 700; margin-bottom: 10px; color: #172142;}
.pt-meta { font-size: 15px; color: #fcaf17;}
.pt-rating { color: #fcaf17; font-weight: 600; }
.pt-count { color: #adb4bf; font-size: 14px; }
.pt-tags { margin-bottom: 10px; }
.tag {
  display: inline-block;
  background: #ffe3b3;
  color: #ff7f00;
  border-radius: 4px;
  font-size: 13px;
  font-weight: 500;
  padding: 2px 7px;
  margin-right: 5px;
}
.pt-price { font-size: 25px; font-weight: 800; color: #3857f9; margin: 10px 0 12px 0;}
.pt-btn {
  width: 100%; padding: 13px 0;
  border-radius: 8px; font-size: 17px; font-weight: 700; margin-bottom: 9px; cursor: pointer;
  border: none; transition: background 0.15s;
}
.pt-btn.main { background: #223d7d; color: #fff;}
.pt-btn.main:hover { background: #3756a1;}
.pt-btn.sub {background: #fff;border: 1px solid #d4d9e2;color: #223d7d;display: none;}
.pt-btn.sub:hover { background: #f0f5ff;}
/* �� */
.pt-tabs {
  display: flex;
  gap: 0;
  position: sticky;
  top: 45px;
  background: #fff;
  border-bottom: 1.5px solid #e5e8ee;
  font-size: 17px;
  z-index: 9;
  margin-bottom: 0;
}
.pt-tabs .tab {
  flex: 1 1 0;
  padding: 17px 0;
  color: #61656a;
  border-bottom: 2.5px solid transparent;
  text-decoration: none;
  font-weight: 500;
  text-align: center;
  transition: color 0.15s, border 0.2s, background 0.16s;
  position: relative;
  cursor: pointer;
  background: #fff;
}
.pt-tabs .tab.active,
.pt-tabs .tab:focus,
.pt-tabs .tab:hover {
  color: #223d7d;
  border-bottom: 2.5px solid #223d7d;
  background: #f9fbfd;
}
/* ���� */
.pt-section {/* max-width: 780px; */margin: 0 auto;padding: 64px 0 44px 0;}
.pt-section h2 { font-size: 25px; color: #1b2655; margin-bottom: 24px; font-weight: 700;}
.pt-section ul {/* margin-left: 1.1em; */}
.pt-section2 ul li { font-size: 17px; margin-bottom: 8px; }
.pt-teacher-profile { display: flex;     align-items: flex-start; gap: 28px; }
.pt-teacher-profile img { width: 94px; height: 94px; object-fit: cover; border-radius: 50%; }
.pt-teacher-profile b { font-size: 20px; color: #233575;}
.review-box {
  background: #f9fbfd;
  border-radius: 14px;
  padding: 24px 24px 18px 24px;
  margin-bottom: 28px;
  box-shadow: 0 1px 8px rgba(90,110,139,0.04);
}
.review-header {
  display: flex; gap: 13px; align-items: center; margin-bottom: 6px;
  font-size: 15px; color: #495a70;
}
.review-label {
  background: #e2e5f2;
  color: #223d7d;
  font-size: 12px;
  padding: 1px 6px;
  border-radius: 7px;
  margin-left: 4px;
}
.review-rating {
  color: #fdcb18;
  font-size: 20px;
  margin-bottom: 8px;
  font-family: 'Pretendard', 'Noto Sans KR', sans-serif;
  letter-spacing: 3px;
}
.review-content {
  color: #374559;
  font-size: 16px;
  line-height: 1.7;
}

/* ======= ���ᰭ�� �˾� ======= */
.pt-modal {
  display: none;
  position: fixed;
  z-index: 10011;
  left: 0; top: 0; width: 100vw; height: 100vh;
}
.pt-modal.show { display: block; }
.pt-modal-bg {
  position: fixed;
  left: 0; top: 0; width: 100vw; height: 100vh;
  background: rgba(20,28,50,0.42);
  z-index: 1;
  cursor: pointer;
}
.pt-modal-box {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%,-50%);
  background: #fff;
  border-radius: 18px;
  max-width: 460px;
  width: 96vw;
  box-shadow: 0 2px 28px rgba(0,0,0,0.13);
  padding: 30px 22px 20px 22px;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  animation: fadeIn .26s cubic-bezier(.6,.1,.9,1);
}
@keyframes fadeIn { from { opacity:0; transform:translate(-50%,-47%);} to { opacity:1; transform:translate(-50%,-50%);} }

.pt-modal-title {
  font-size: 18px;
  font-weight: 700;
  margin-bottom: 22px;
  color: #26314a;
  text-align: center;
  word-break: keep-all;
}
.pt-modal-close {
  position: absolute;
  right: 18px; top: 14px;
  background: none;
  border: none;
  font-size: 32px;
  color: #8891ac;
  cursor: pointer;
  transition: color 0.18s;
  z-index: 10;
  line-height: 1;
}
.pt-modal-close:hover { color: #ef6d24; }
.pt-modal-video {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
  background: #eee;
  border-radius: 10px;
  overflow: hidden;
  margin-bottom: 20px;
  box-shadow: 0 1px 10px rgba(70,40,10,0.07);
  cursor: pointer;
}
.pt-modal-video img {
  width: 100%; height: 100%; object-fit: cover; display: block;
  background: #e6e6e6;
}
.pt-modal-play {
  position: absolute;
  left: 50%; top: 50%;
  transform: translate(-50%,-50%);
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: opacity 0.15s;
  z-index: 5;
}
.pt-modal-play:hover { opacity: 0.80; }
.pt-modal-desc {
  text-align: center;
  margin-bottom: 22px;
  margin-top: -7px;
}
.pt-modal-ot {
  font-size: 15px;
  color: #ff5a1f;
  font-weight: 600;
  margin-bottom: 3px;
}
.pt-modal-ot b {
  color: #26314a;
  margin-right: 3px;
  font-weight: 700;
  font-size: 17px;
}
.pt-modal-buy {
  width: 100%;
  background: #ff5a1f;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  padding: 13px 0 12px 0;
  border-radius: 10px;
  border: none;
  margin-top: 10px;
  cursor: pointer;
  transition: background 0.16s;
}
.pt-modal-buy:hover { background: #e04a07; }

/* ======= ���� �������� ��� ======= */
.pt-video-modal {
  display: none;
  position: fixed; z-index: 10222;
  left: 0; top: 0; width: 100vw; height: 100vh;
}
.pt-video-modal.show { display: block; }
.pt-video-modal-bg {
  position: fixed; left: 0; top: 0; width: 100vw; height: 100vh;
  background: rgba(0,0,0,0.5);
  z-index: 1;
}
.pt-video-modal-box {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%);
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 2px 28px rgba(0,0,0,0.22);
  width: 90vw; max-width: 620px;
  padding: 0; z-index: 2; display: flex; flex-direction: column; align-items: flex-end;
}
.pt-video-modal-close {
  background: none; border: none;
  font-size: 30px; color: #9da8c3;
  cursor: pointer; margin: 8px 16px 0 0;
  position: absolute; right: 0; top: 0; z-index: 5;
}
.pt-video-iframe-wrap {
  width: 100%; aspect-ratio: 16/9;
  background: #222;
  border-radius: 0 0 10px 10px;
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  position: relative;
}
.pt-video-iframe-wrap iframe {
  width: 100%; height: 100%; border: 0;
  display: block; background: #000;
}

/* ������ */
@media (max-width: 1100px) {
  .pt-container { max-width: 99vw; }
  .pt-main-row { flex-direction: column; gap: 28px; }
  .pt-left, .pt-right { max-width: 100%; }
}
@media (max-width: 700px) {
  .pt-container { padding:9vw 10px 0 10px;}
  .pt-section { padding: 38px 0 26px 0; }
  .pt-section h2 { font-size: 17px; margin-bottom: 15px;}
  .pt-caption { font-size: 15px; margin-top: 16px;}
  .pt-right { padding: 19px 7vw 11px 7vw; border-radius: 8px;width: 100%;}
  .pt-img16 { border-radius: 7px; }
  .pt-teacher-profile img { width: 60px; height: 60px;}
  .pt-teacher-profile b { font-size: 14px;}
  .review-box { padding: 12px 8px 11px 8px; border-radius: 8px;}
  .review-header { font-size: 12px;}
  .review-label { font-size: 11px;}
  .review-rating { font-size: 13px;}
  .review-content { font-size: 12px;}
  .pt-tabs { font-size: 13px;}
  .pt-tabs .tab { padding: 9px 0;}
  .pt-modal-box { padding: 18px 5vw 12px 5vw; border-radius: 12px; max-width: 98vw;}
  .pt-modal-title { font-size: 16px; }
  .pt-modal-ot { font-size: 13px; }
  .pt-modal-buy { font-size: 15px; padding: 11px 0; border-radius: 7px;}
  .pt-modal-video { border-radius: 7px;}
  .pt-video-modal-box { max-width: 99vw; }
}


.bb_c {color:#000}
/* ===== ī�� ===== */
    .user_card {
      background: #fff;
      border-radius: 8px;
      box-shadow: 0 4px 20px rgba(0,0,0,0.1);
      width: 100%;
      max-width: 400px;
      padding: 40px 32px;
	  margin: 50px auto;
    }
    .user_logo {
      text-align: center;
      margin-bottom: 24px;
    }
    .user_logo h1 {
      margin: 0;
      font-size: 1.5rem;
      color: #1c3273;
    }
	.user_logo img {
    width: 50%;
}
    .user_tagline {
      text-align: center;
      font-size: 1rem;
      color: #333;
      margin-bottom: 32px;
      line-height: 1.4;
    }

    /* ===== Kakao ��ư ===== */
    .user_kakao-btn {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: center;
      background: #FEE500;
      border: none;
      border-radius: 4px;
      padding: 12px 0;
      font-size: 1rem;
      font-weight: 600;
      color: #3c1e1e;
      cursor: pointer;
      margin-bottom: 24px;
    }
    .user_kakao-btn img {
      height: 20px;
      margin-right: 8px;
    }
 /* ===== �̸��� ���� ��ũ ===== */
    .user_email-signup {
      display: block;
      text-align: center;
      font-size: 0.9rem;
      color: #888;
      margin-bottom: 24px;
      text-decoration: none;
    }
    .user_email-signup:hover {
      text-decoration: underline;
    }

    /* ===== OR ���м� ===== */
    .user_divider {
      display: flex;
      align-items: center;
      text-align: center;
      margin-bottom: 24px;
    }
    .user_divider::before,
    .user_divider::after {
      content: '';
      flex: 1;
      height: 1px;
      background: #ddd;
    }
    .user_divider span {
      margin: 0 12px;
      color: #888;
      font-size: 0.9rem;
    }

    /* ===== �� ===== */
    .user_form .user_field {
      margin-bottom: 16px;
      display: flex;
      flex-direction: column;
    }
    .user_form label {
      display: block;
      font-size: 0.9rem;
      color: #444;
      margin-bottom: 6px;
    }
    .user_form input,
    .user_form select {
      width: auto;
      padding: 10px 12px;
      border: 1px solid #ccc;
      border-radius: 4px;
      font-size: 0.95rem;
      outline: none;
      transition: border-color .2s;
    }
    .user_form input:focus,
    .user_form select:focus {
      border-color: #1c3273;
    }
	.user_login-btn {
      width: 100%;
      padding: 12px;
      background: #1c3273;
      color: #fff;
      border: none;
      border-radius: 4px;
      font-size: 1rem;
      font-weight: 600;
      cursor: pointer;
      margin-top: 8px;
    }
    .user_password-group {
      position: relative;
    }
    .user_password-toggle {
      position: absolute;
      top: 50%;
      right: 12px;
      transform: translateY(-50%);
      cursor: pointer;
      font-size: 1.1rem;
      color: #888;
    }

    /* ===== �������� ===== */
    .user_phone-group {
      display: flex;
      gap: 8px;
	  flex-direction: column;
    }
    .user_phone-group input {
      flex: 1;
    }
    .user_phone-group button {
      padding: 0 12px;
      background: #1c3273;
      border: none;
      color: #fff;
      border-radius: 4px;
      cursor: pointer;
      font-size: 0.9rem;
    }

    /* ===== üũ�ڽ� ===== */
    .user_checks {
      margin: 16px 0;
      font-size: 0.85rem;
      color: #555;
      display: flex;
      flex-direction: column;
      align-items: flex-start;
    }
    .user_checks label {
      display: block;
      margin-bottom: 8px;
      cursor: pointer;
    }
    .user_checks a {
      color: #1c3273;
      text-decoration: none;
    }
    .user_checks a:hover {
      text-decoration: underline;
    }

    /* ===== ���� ��ư ===== */
    .user_submit-btn {
      width: 100%;
      padding: 12px;
      background: #1c3273;
      color: #fff;
      border: none;
      border-radius: 4px;
      font-size: 1rem;
      font-weight: 600;
      cursor: pointer;
      margin-top: 8px;
    }

    /* ===== �α��� ��ũ ===== */
    .user_login-link {
      text-align: center;
      margin-top: 24px;
      font-size: 0.9rem;
      color: #555;
    }
    .user_login-link a {
      color: #1c3273;
      text-decoration: none;
      font-weight: 600;
      margin-left: 4px;
    }

    /* ===== ���� ===== */
    .user_error {
      background: #ffe5e5;
      color: #d00;
      padding: 8px 12px;
      border-radius: 4px;
      font-size: 0.9rem;
      margin-bottom: 16px;
      display: none;
    }
    .user_error.open {
      display: block;
    }

	.phone-box {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .phone-box input {
    flex: 1;
    padding: 10px;
    border: 1px solid #ccc;
    border-radius: 4px;
  }
  .phone-box button {
    padding: 0 12px;
    background: #1c3273;
    color: #fff;
    border: none;
    border-radius: 4px;
    cursor: pointer;
  }
/* ==== �޴��� + ��ư �ڽ� ==== */
    .user_phone-group .phone-box {
      display: flex; align-items: center; gap: 8px;
    }
    .phone-box input { flex: 1; }
    .phone-box button {
      padding: 0 12px; background: #1c3273; color: #fff;
      border: none; border-radius: 4px; cursor: pointer;
      font-size: 0.9rem;
    }
  /* Ÿ�̸� */
  #timer {
    font-size: 0.9rem;
    color: #888;
    min-width: 50px;
    text-align: center;
  }

  /* �����Ϸ� ���� */
  .user_verify-btn[disabled] {
    background: #ccc;
    cursor: default;
  }
.preview_img {
    height: 214px !important;
}
   /* ==== Ÿ�̸� & ���� ==== */
    #verification-section { display: none; margin-bottom: 16px; }
    #verification-section .phone-box { gap: 8px; }
    #timer {
      min-width: 50px; text-align: center; color: #888; font-size: 0.9rem;
    }
    .user_verify-btn {
      background: #1c3273; color: #fff; border: none; border-radius: 4px;
      padding: 0 12px; cursor: pointer; font-size: 0.9rem;
    }


    /* ==== ���� ��ư ==== */
    .user_submit-btn {
      width: 100%; padding: 12px; background: #1c3273; color: #fff;
      border: none; border-radius: 4px; font-size: 1rem;
      font-weight: 600; cursor: pointer; margin-top: 8px;
    }

    /* ==== ��ũ ==== */
    .user_bottom {
      text-align: center; margin-top: 24px; font-size: 0.9rem; color: #555;
    }
    .user_bottom a {
      color: #1c3273; text-decoration: none; font-weight: 600;
      margin-left: 4px;
    }

	:root{
      --pri:#ff4d4f;
      --bd:#e1e1e1;
      --mut:#6c757d;
      --ok:#198754;
      --card-bg:#fff;
    }
    /* 컨테이너/카드 */
    .fi_wrap{max-width:560px;margin:40px auto;padding:0 16px}
    .fi_card{background:var(--card-bg);border-radius:14px;box-shadow:0 6px 24px rgba(0,0,0,.06);padding:28px}
    .fi_logo{text-align:center;margin-bottom:18px}
    .fi_logo h1{font-size:22px;margin:0}
    .fi_divider{display:flex;align-items:center;gap:12px;margin:18px 0}
    .fi_divider:before,.fi_divider:after{content:"";flex:1;height:1px;background:#eee}
    .fi_error{color:#dc3545;margin:8px 0;display:none}
    .fi_info{color:var(--mut);font-size:12px;background:#f8f9fa;border:1px solid #eee;border-radius:10px;padding:12px;margin-bottom:16px}

    /* 필드/버튼 */
    .fi_field{margin-bottom:16px}
    .fi_field label{display:block;margin:0 0 6px 2px;font-weight:600}
    .fi_input{width:100%;height:48px;border:1px solid var(--bd);border-radius:10px;padding:0 14px;outline:none}
    .fi_input:focus{border-color:var(--pri);box-shadow:0 0 0 .2rem rgba(255,77,79,.1)}
    .fi_btn{height:48px;border-radius:10px;border:0;padding:0 14px;font-weight:600}
    .fi_btn-red{background:var(--pri);color:#fff}
    .fi_btn-ghost{background:#fff;border:1px solid var(--bd)}
    .fi_btn:disabled{opacity:.6;cursor:not-allowed}

    /* SMS UI */
    .fi_grid2{display:grid;grid-template-columns:1fr 150px;gap:8px}
    .fi_grid3{display:grid;grid-template-columns:1fr 150px auto;gap:8px;align-items:center}
    .fi_hint{font-size:12px;color:var(--mut);margin-top:6px}
    .fi_badge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px;border:1px solid #e2e2e2;border-radius:999px}
    .fi_badge.ok{border-color:var(--ok);color:var(--ok)}
    .fi_timer{font-size:12px;color:var(--mut);white-space:nowrap}

    /* 결과 리스트 */
    .fi_result{background:#f8f9fa;border:1px solid #eee;border-radius:12px;padding:12px}
    .fi_result h6{margin:0 0 8px 0}
    .fi_email{display:flex;gap:8px;align-items:center;justify-content:space-between;background:#fff;border:1px solid #eee;border-radius:10px;padding:10px 12px}
    .fi_email code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
    .fi_copy{border:1px solid var(--bd);background:#fff;border-radius:8px;height:36px;padding:0 12px}

    /* 링크 */
    .fi_links{margin-top:16px;text-align:center}
    .fi_links a{color:#6c757d;text-decoration:none}
    .fi_links a:hover{text-decoration:underline}

    @media (max-width:480px){
      .fi_grid2{grid-template-columns:1fr}
      .fi_grid3{grid-template-columns:1fr 1fr}
      .fi_btn,.fi_input{height:44px}
      .fi_card{padding:20px}
    }


	/* ====== Find Password (fp_) ====== */
    .fp_wrap{max-width:560px;margin:40px auto;padding:0 16px}
    .fp_card{background:#fff;border-radius:14px;box-shadow:0 6px 24px rgba(0,0,0,.06);padding:28px}
    .fp_logo{text-align:center;margin-bottom:18px}
    .fp_logo h1{font-size:22px;margin:0}
    .fp_divider{display:flex;align-items:center;gap:12px;margin:18px 0}
    .fp_divider:before,.fp_divider:after{content:"";flex:1;height:1px;background:#eee}
    .fp_error{color:#dc3545;margin:8px 0;display:none}
    .fp_field{margin-bottom:16px}
    .fp_field label{display:block;margin:0 0 6px 2px;font-weight:600}
    .fp_input{width:100%;height:48px;border:1px solid #e1e1e1;border-radius:10px;padding:0 14px;outline:none}
    .fp_input:focus{border-color:#ff4d4f;box-shadow:0 0 0 .2rem rgba(255,77,79,.1)}
    .fp_hint{font-size:12px;color:#6c757d;margin-top:6px}
    .fp_pwgroup{position:relative}
    .fp_pwbtn{position:absolute;right:12px;top:50%;transform:translateY(-50%);cursor:pointer;user-select:none}
    .fp_flexcol{display:flex;gap:8px;flex-direction:column;align-items:stretch}
    .fp_actions{display:flex;gap:8px;align-items:center}
    .fp_btn{height:48px;border-radius:10px;border:0;padding:0 14px;font-weight:600}
    .fp_btn-red{background:#ff4d4f;color:#fff}
    .fp_btn-ghost{background:#fff;border:1px solid #e1e1e1}
    .fp_btn:disabled{opacity:.6;cursor:not-allowed}

    /* SMS */
    .fp_smsBadge{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:4px 10px;border:1px solid #e2e2e2;border-radius:999px}
    .fp_smsBadge.ok{border-color:#198754;color:#198754}
    .fp_timer{font-size:12px;color:#6c757d;white-space:nowrap}
    .fp_grid2{display:grid;grid-template-columns:1fr 150px;gap:8px}
    .fp_grid3{display:grid;grid-template-columns:1fr 150px auto;gap:8px;align-items:center}

    /* Footer links */
    .fp_links{margin-top:16px;text-align:center}
    .fp_links a{color:#6c757d;text-decoration:none}
    .fp_links a:hover{text-decoration:underline}

    /* Gray law box */
    .fp_graybox{background:#f8f9fa;border:1px solid #eee;border-radius:10px;padding:12px;margin-bottom:20px;color:#6c757d;font-size:12px}

    @media (max-width:480px){
      .fp_grid2{grid-template-columns:1fr}
      .fp_grid3{grid-template-columns:1fr 1fr;grid-auto-rows:auto}
      .fp_timer{justify-self:end}
      .fp_btn{height:44px}
      .fp_input{height:44px}
      .fp_card{padding:20px}
    }


	/* 좌/우 영상 영역 레이아웃은 기존 CSS 유지 가정 */

    /* 섹션(주차) 카드 */
    .playlist-sec{
      background:#fff;
      border:1px solid #eee;
      border-radius:10px;
      margin-bottom:12px;
      overflow:hidden;
      padding: 10px;
    }
    .playlist-sec .sec-head{
      font-size: 12px;
      color:#9aa0a6;
      padding: 0px 0;
    }
    .playlist-sec .sec-sub{
      font-size: 13px;
      color:#444;
      padding: 0;
      font-weight: 600;
      border-bottom: 1px solid #000;
    }

    /* 강의 아이템 */
    .playlist-item{padding:10px 12px;cursor:pointer;border-bottom:1px solid #f8f9fa}
    .playlist-item:last-child{border-bottom:0}
    .playlist-item.active{/* background:#fff4f0; */}
    .playlist-item .title{font-weight: 600;}
    .playlist-item .meta{font-size: 12px;/* color:#6c757d; */margin-top:2px}


	/* ====== 아이콘 전용 새 클래스 ====== */
    .sp-ico{font-size:14px;line-height:1;vertical-align:middle}
    .sp-ico+ .sp-ico{margin-left:6px}
    .sp-ico-attach{color:#e03131}
    .sp-ico-attach.dim{color:#e03131;opacity:.25}
    .sp-ico-play{color:#6c757d}

    /* 플레이리스트 메타 영역 정렬 */
    .video-playlist .playlist-item .meta{
      display:flex;align-items:center;justify-content:flex-end;gap:6px;
      font-variant-numeric:tabular-nums
    }

    /* 섹션(주차) 그룹 - 기존 레이아웃과 충돌 없는 가벼운 보조 스타일 */
    .playlist-sec{background:#fff;border-radius:8px;box-shadow:0 2px 10px rgba(0,0,0,.04);margin-bottom:12px}
    .playlist-sec .sec-list{padding: 0;}


	 /* 잠금(수강기간 아님) 오버레이 */
    .locked-item{position:relative;}
    .locked-cover{
      position:absolute; inset:0;
      background:rgba(255,255,255,.7);
      display:flex; align-items:center; justify-content:center;
      border-radius:8px; z-index:2; text-align:center;
    }
    .locked-cover .lock-msg{color:#374151; font-weight:700; font-size:.95rem; margin-top:.35rem;}

    

    /* 상단 컨트롤 아이콘 */
    .ctrl-ico{font-size:20px; line-height:1; cursor:pointer}
    .ctrl-ico.playing{color: #6c757d;}
    .ctrl-ico.paused{color: #dc3545;}
    .ctrl-ico.stopped{color:#6c757d}
    .attach-ico.disabled{opacity:.3; cursor:not-allowed}
.playlist-sec{ position:relative; } /* 필수 */
.sec-locked-cover{
  position:absolute; inset:0; z-index:5;
  display:flex; align-items:center; justify-content:center; text-align:center;
  background:rgba(255,255,255,.75);
  backdrop-filter: blur(3px);
  border-radius:8px;
}
.sec-locked-cover .msg{ margin-top:.4rem; font-weight:700; color:#374151; }

.playlist-sec{ position:relative; } /* 필수 */
.sec-locked-cover{
  position:absolute; inset:0; z-index:5;
  display:flex; align-items:center; justify-content:center; text-align:center;
  background:rgba(255,255,255,.75);
  backdrop-filter: blur(3px);
  border-radius:8px;
}
.sec-locked-cover .msg{margin-top:.4rem;font-weight:700;color:#374151;font-size: 12px;margin-top: 19px;}

/* sub.css 또는 main.css 아무데나 */
.pt-intro { white-space: pre-line; }
.pt-intro img {width:100%;}
