@charset "UTF-8";

/* Custom Dark Header for Contents List with Orange Accents */
.contents-list-header {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  background: linear-gradient(135deg, #2A2A2A 0%, #2D2620 100%);
  z-index: 1000;
  border-bottom: 2px solid rgba(255, 119, 0, 0.3);
  box-shadow: 0 2px 8px rgba(255, 119, 0, 0.1);
}

.contents-header-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 12px 15px;
  max-width: 100%;
}

.contents-logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  text-decoration: none;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}

.contents-logo:hover {
  opacity: 0.8;
}

.contents-logo-img {
  height: auto;
  max-height: 32px;
  width: auto;
  max-width: 120px;
  display: block;
}

.contents-menu-toggle {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 40px;
  height: 40px;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  padding: 8px;
  border-radius: 8px;
}

.contents-menu-toggle:hover {
  background: rgba(255, 119, 0, 0.2);
  border-color: rgba(255, 119, 0, 0.4);
  transform: scale(1.05);
}

.contents-menu-toggle svg line {
  stroke: #fff;
  transition: stroke 0.3s ease;
}

.contents-menu-toggle:hover svg line {
  stroke: #FF7700;
}

.contents-menu-toggle svg {
  width: 100%;
  height: 100%;
}

@media (max-width: 400px) {
  .contents-header-inner {
    padding: 10px 12px;
  }
  
  .contents-logo-img {
    max-height: 28px;
    max-width: 100px;
  }
  
  .contents-menu-toggle {
    width: 36px;
    height: 36px;
  }
}

/* Hide existing top_header mobile-header when custom header is present, but keep mobile-menu accessible */
body.contents-list-page .top_header .mobile-header {
  display: none !important;
}

body.contents-list-page .top_header {
  position: relative;
  z-index: 1;
  background: transparent;
  border: none;
  height: 0;
  overflow: visible;
}

/* Ensure mobile-menu is always accessible even when mobile-header is hidden */
body.contents-list-page .top_header nav.mobile-menu,
body.contents-list-page nav.mobile-menu {
  display: flex !important;
  position: fixed !important;
  z-index: 999999 !important;
  right: -100% !important; /* Start hidden */
  transition: right 0.3s ease-in-out !important;
}

/* Adjust body padding to account for fixed header */
body.contents-list-page {
  padding-top: 60px;
}

@media (max-width: 400px) {
  body.contents-list-page {
    padding-top: 56px;
  }
}

/* Adjust wrap margin when custom header is present */
body.contents-list-page {
  background: #1D1D1D;
  color: #fff;
  min-height: 100vh;
}

body.contents-list-page #wrap {
  margin-top: 0;
  max-width: 100%;
}

/* Enhanced Grid Layout for Course Cards */
.lecture {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  background: transparent;
  padding: 20px 0;
}

.course-grid-wrapper {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 20px !important;
  padding: 0 15px !important;
  visibility: visible !important;
  background: transparent;
}

@media (max-width: 480px) {
  .course-grid-wrapper {
    gap: 15px !important;
    padding: 0 10px !important;
  }
}

/* Ensure footer visibility and styling */
footer {
  display: block !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  clear: both;
  background: linear-gradient(135deg, #2A2A2A 0%, #2D2620 100%) !important;
  color: #fff !important;
  margin-top: 50px !important;
  border-top: 2px solid rgba(255, 119, 0, 0.2) !important;
}

.footer_container {
  width: 100% !important;
  max-width: 100% !important;
}

.footer_logo img {
  max-height: 40px !important;
  filter: brightness(1.2) !important;
}

.footer_menu {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 15px !important;
  margin: 20px 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.footer_menu li a {
  color: #e2e8f0 !important;
  text-decoration: none !important;
  font-size: 14px !important;
  transition: all 0.3s ease !important;
}

.footer_menu li a:hover,
.footer_menu li a.active {
  color: #FF7700 !important;
}

.footer_info,
.footer_copyright {
  text-align: center !important;
  color: #cbd5e1 !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
}

.footer_info {
  margin: 20px 0 !important;
}

.footer_copyright p {
  margin: 5px 0 !important;
  color: #94a3b8 !important;
}

.top_banner {
  padding: 50px 0 70px 0;
  text-align: center;
  color: #fff;
  background: url(../img/lecture/sub_banner_img.png) no-repeat;
  background-position-x: center;
}

@media (max-width: 700px) {
  .top_banner {
    background-size: cover;
    padding: 40px 0;
  }
}

.top_banner p {
  font-size: 24px;
  line-height: 39px;
  font-weight: 600;
}

@media (max-width: 1000px) {
  .top_banner p {
    font-size: 20px;
    line-height: 35px;
    padding: 0 10px;
  }
}

@media (max-width: 400px) {
  .top_banner p {
    font-size: 16px;
  }
}


.fc_purple {
  color: #5f42dc;
}

.fc_purple_gradient {
  font-weight: 900 !important;
  background: -webkit-gradient(linear, left top, right top, from(#5f42dc), to(#0a98a1));
  background: linear-gradient(to right, #5f42dc, #0a98a1);
  background-clip: text;
  -webkit-background-clip: text;
  color: rgba(0, 0, 0, 0);
  -webkit-text-fill-color: transparent;
  font-weight: 900;
  letter-spacing: -0.5px;
}

.content_header {
  margin: 20px 0 30px 0;
}

.content_header > form > ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}

@media (max-width: 1000px) {
  .content_header > form > ul {
    margin-top: 57px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

@media (max-width: 400px) {
  .content_header > form > ul {
    margin-top: 50px;
  }
}

.content_header > form > ul > li > ul {
  position: absolute;
  top: 70px;
  left: 10px;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  font-size: 16px;
}

@media (max-width: 638px) {
  .content_header > form > ul > li > ul {
    top: 110px;
    font-size: 14px;
  }
}

@media (max-width: 400px) {
  .content_header > form > ul > li > ul {
    top: 96px;
    font-size: 12px;
  }
}

@media (max-width: 270px) {
  .content_header > form > ul > li > ul {
    top: 128px;
  }
}

.content_header > form > ul > li > ul > li {
  display: inline;
  margin-right: 30px;
  position: relative;
}

.content_header > form > ul > li > ul > li::after {
  content: "";
  width: 1px;
  height: 14px;
  background-color: #222;
  position: absolute;
  right: -15px;
  top: 8px;
}

@media (max-width: 1000px) {
  .content_header > form > ul > li > ul > li::after {
    top: 5px;
  }
}

@media (max-width: 400px) {
  .content_header > form > ul > li > ul > li::after {
    top: 3px;
  }
}

.content_header > form > ul > li > ul > li:last-of-type::after {
  width: 0px;
}

.content_header > form > ul > li > ul > li > a {
  color: #222;
}

.content_header > form > ul > li > ul > li > a.on {
  color: #5f42dc;
}

.content_header > form > ul > li > a {
  padding: 5px 25px 7px 25px;
  border: 1px solid;
  border-radius: 25px;
  margin-right: 13px;
  margin-top: 13px;
  height: 40px;
  display: inline-block;
}

@media (max-width: 1000px) {
  .content_header > form > ul > li > a {
    height: 34px;
  }
}

@media (max-width: 400px) {
  .content_header > form > ul > li > a {
    height: 30px;
    padding: 5px 15px 7px 15px;
    margin-right: 8px;
    margin-top: 10px;
  }
}

@media (max-width: 282px) {
  .content_header > form > ul > li > a {
    margin-right: 4px;
  }
}

.content_header > form > ul > li > a.on {
  border: 2px solid #5f42dc;
  color: #5f42dc;
  font-weight: 500;
}

.content_header .search_box input {
  width: 100%;
  height: 40px;
  background-color: #f8f8f8;
  border: navajowhite;
  border-radius: 50px;
  padding: 25px 25px;
}

.content_header .search_box input::-webkit-input-placeholder {
  color: #777;
}

.content_header .search_box input:-ms-input-placeholder {
  color: #777;
}

.content_header .search_box input::-ms-input-placeholder {
  color: #777;
}

.content_header .search_box input::placeholder {
  color: #777;
}

.content_header .search_box i {
  position: absolute;
  top: 12px;
  right: 25px;
  font-size: 23px;
}

.research_box {
  border: 1px solid;
  padding: 27px;
  margin: 20px 0;
}

.research_box .question {
  font-weight: 600;
  font-size: 20px;
  margin-bottom: 25px;
  position: relative;
  display: inline-block;
}

.research_box .question span {
  color: #5f42dc;
}

.research_box .question::before {
  position: absolute;
  bottom: -7px;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #5f42dc;
  content: "";
}

.research_box ul.answer {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  width: 1000px;
  gap: 14px;
  margin-bottom: 30px;
}

.research_box ul.answer li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.research_box input {
  width: 20px;
  height: 20px;
  background-color: rgba(0, 0, 0, 0);
  border: 1px solid;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  cursor: pointer;
}

.research_box input:checked {
  -webkit-appearance: auto;
     -moz-appearance: auto;
          appearance: auto;
}

.research_box label {
  margin-left: 5px;
}

.lecture_wrap {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr 1fr 1fr;
      grid-template-columns: 1fr 1fr 1fr 1fr;
  gap: 25px;
  margin: 40px 0;
}

@media (max-width: 1300px) {
  .lecture_wrap {
    -ms-grid-columns: 1fr 1fr 1fr;
        grid-template-columns: 1fr 1fr 1fr;
  }
}

@media (max-width: 900px) {
  .lecture_wrap {
    -ms-grid-columns: 1fr 1fr;
        grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 600px) {
  .lecture_wrap {
    -ms-grid-columns: 1fr;
        grid-template-columns: 1fr;
  }
}

.swiper.hot {
  padding: 0 10px;
}

.flashArea {
  color: #fff;
}

.recommendArea {
  color: #fff;
}

@media (max-width: 1000px) {
  .recommendArea {
    display: none;
  }
}

#load {
  text-align: center;
  margin-top: 50px;
}


/*course*/
.lecture_top strong {
  margin: 30px 0;
  display: block;
  font-size: 25px;
}

.lecture_top .select-box {
  width: 120px;
  display: inline-block;
  position: relative;
  margin-right: 15px;
}

.lecture_top .select-box select {
  width: 100%;
  padding: 10px;
  font-size: 14px;
  border: 1px solid #ccc;
}

.lecture_top .select-box select:focus {
  border-color: #007bff;
  outline: none;
}

.lecture_top .select-box::after {
  /*   content: "▼"; */
  position: absolute;
  right: 12px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  pointer-events: none;
  font-size: 10px;
  color: #666;
}

.swiper-slide {
  margin-top: 0 !important;
}

.swiper-slide .more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: 250px;
  cursor: pointer;
}


.swiper-slide .more .txt {
  font-size: 20px;
  font-weight: bold;
  line-height: 30px;
  margin-top: 11px;
}

.swiper-slide .more .txt span {
  color: #7ba7d7;
}

.lecture .grid-wrapper {
  display: block;
  margin-bottom: 50px;
}

/* Course List Header with Title and Sort Buttons */
.course-list-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 20px 15px;
  margin-bottom: 20px;
}

.course-list-title {
  font-size: 20px;
  font-weight: 600;
  color: #FFFFFF;
}

.course-list-sort {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}

.sort-btn {
  padding: 8px 16px;
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.3);
  border-radius: 20px;
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  font-family: "Noto Sans KR", "Roboto", sans-serif;
}

.sort-btn:hover {
  border-color: rgba(255, 255, 255, 0.5);
  color: rgba(255, 255, 255, 0.9);
}

.sort-btn.active {
  background-color: rgba(255, 119, 0, 0.3);
  border-color: #FF7700;
  color: #FFFFFF;
  font-weight: 500;
}

/* Course Grid Wrapper - Enhanced 2 Column Layout */
.course-grid-wrapper {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 1fr 1fr;
      grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 0 15px;
  margin-bottom: 40px;
  position: relative;
}

@media (max-width: 600px) {
  .course-grid-wrapper {
    gap: 12px;
    padding: 0 10px;
  }
}

/* Course Card Item */
.course-card-item {
  width: 100%;
}

.course-card-item .edu_contents {
  width: 100%;
  background: linear-gradient(145deg, #2A2A2A 0%, #2E2E2E 100%);
  border-radius: 16px;
  overflow: hidden;
  cursor: pointer;
  -webkit-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  display: block;
  position: relative;
}

.course-card-item .edu_contents:hover {
  -webkit-transform: translateY(-4px);
      -ms-transform: translateY(-4px);
          transform: translateY(-4px);
  border-color: rgba(255, 119, 0, 0.4);
  -webkit-box-shadow: 0 8px 25px rgba(255, 119, 0, 0.2), 0 4px 8px rgba(0, 0, 0, 0.3);
          box-shadow: 0 8px 25px rgba(255, 119, 0, 0.2), 0 4px 8px rgba(0, 0, 0, 0.3);
}

.course-card-item .edu_contents::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(255, 119, 0, 0.03) 0%, transparent 50%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
}

.course-card-item .edu_contents:hover::before {
  opacity: 1;
}

.course-card-item .edu_contents .img {
  width: 100%;
  height: 120px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: block;
}

.course-card-item .edu_contents .title {
  padding: 16px;
  display: block;
  background: linear-gradient(180deg, rgba(42, 42, 42, 0.8) 0%, rgba(46, 46, 46, 0.9) 100%);
  backdrop-filter: blur(2px);
}

.course-card-item .edu_contents .title strong {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #FFFFFF;
  line-height: 1.4;
  margin-bottom: 10px;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.5);
  line-clamp: 2;
  -webkit-box-orient: vertical;
  min-height: 36px;
}

.course-card-item .edu_contents .card-meta-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 4px;
  font-size: 11px;
  color: rgba(255, 255, 255, 0.7);
  margin-bottom: 8px;
}

.course-card-item .edu_contents .card-meta-info .separator {
  color: rgba(255, 255, 255, 0.5);
  margin: 0 2px;
}

.course-card-item .edu_contents .card-tags {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.course-card-item .edu_contents .img {
    position: relative;
}

.course-card-item .edu_contents .content-type-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    padding: 4px 10px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    font-size: 11px;
    font-weight: 600;
    box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3);
    z-index: 10;
    color: white;
    white-space: nowrap;
}

.course-card-item .edu_contents .content-type-badge.ctype-elearning {
    background: linear-gradient(135deg, #FF7700 0%, #FF7200 100%);
    box-shadow: 0 2px 8px rgba(255, 119, 0, 0.3);
}

.course-card-item .edu_contents .content-type-badge.ctype-microlearning {
    background: linear-gradient(135deg, #10b981 0%, #059669 100%);
}

.course-card-item .edu_contents .content-type-badge.ctype-shortform {
    background: linear-gradient(135deg, #f59e0b 0%, #d97706 100%);
}

.course-card-item .edu_contents .card-tags .tag {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(255, 119, 0, 0.1);
  border: 1px solid rgba(255, 119, 0, 0.3);
  border-radius: 12px;
  font-size: 10px;
  color: #FFFFFF;
  font-weight: 500;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.course-card-item .edu_contents:hover .card-tags .tag {
  background: rgba(255, 119, 0, 0.2);
  border-color: rgba(255, 119, 0, 0.5);
  color: #FF7700;
}

/* Empty State */
.empty-state {
  grid-column: 1 / -1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 60px 20px;
  text-align: center;
  min-height: 300px;
}

.empty-state-icon {
  margin-bottom: 20px;
  opacity: 0.5;
}

.empty-state-message {
  color: rgba(255, 255, 255, 0.7);
}

.empty-state-title {
  font-size: 18px;
  font-weight: 600;
  color: #FFFFFF;
  margin-bottom: 12px;
  font-family: "Noto Sans KR", "Roboto", sans-serif;
}

.empty-state-description {
  font-size: 14px;
  line-height: 1.6;
  color: rgba(255, 255, 255, 0.6);
  font-family: "Noto Sans KR", "Roboto", sans-serif;
}

@media (max-width: 400px) {
  .course-list-header {
    padding: 15px 10px;
    margin-bottom: 15px;
  }
  
  .course-list-title {
    font-size: 18px;
  }
  
  .sort-btn {
    padding: 6px 12px;
    font-size: 12px;
  }
  
  .course-card-item .edu_contents .img {
    height: 100px;
  }
  
  .course-card-item .edu_contents .title {
    padding: 10px;
  }
  
  .course-card-item .edu_contents .title strong {
    font-size: 12px;
    min-height: 32px;
  }
  
  .course-card-item .edu_contents .card-meta-info {
    font-size: 10px;
  }
  
  .course-card-item .edu_contents .card-tags .tag {
    font-size: 9px;
    padding: 3px 8px;
  }
  
  .empty-state {
    padding: 40px 15px;
    min-height: 250px;
  }
  
  .empty-state-icon {
    margin-bottom: 15px;
  }
  
  .empty-state-icon i {
    font-size: 40px !important;
  }
  
  .empty-state-title {
    font-size: 16px;
    margin-bottom: 10px;
  }
  
  .empty-state-description {
    font-size: 12px;
  }
}

/* Course Pagination */
.course-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 40px 0 60px 0;
  padding: 0 15px;
  width: 100%;
  overflow: visible;
  position: relative !important;
  clear: both;
}

/* Grid Nav Container - from blockList() - Override absolute positioning */
.course-pagination .grid-nav,
.course-pagination .grid-nav.swiper-nav {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  width: auto !important;
  margin: 0 auto;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  position: relative !important;
  bottom: auto !important;
  left: auto !important;
  -webkit-transform: none !important;
          transform: none !important;
  top: auto !important;
  z-index: 1 !important;
}

/* Arrow Buttons */
.course-pagination .circleprev,
.course-pagination .circlenext {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 36px;
  height: 36px;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border-radius: 8px;
  color: rgba(255, 255, 255, 0.7);
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
}

.course-pagination .circleprev:hover,
.course-pagination .circlenext:hover {
  background-color: rgba(255, 255, 255, 0.1);
  color: #FFFFFF;
}

.course-pagination .circleprev a,
.course-pagination .circlenext a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

.course-pagination .circleprev i,
.course-pagination .circlenext i {
  font-size: 18px;
}

/* Pagination Numbers Container */
.course-pagination .grid-pagination,
.course-pagination .grid-pagination.swiper-pagination {
  display: -webkit-box !important;
  display: -ms-flexbox !important;
  display: flex !important;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  -ms-flex-wrap: nowrap;
      flex-wrap: nowrap;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
}

/* Ellipsis styling */
.course-pagination .grid-pagination .pagination-ellipsis {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: auto;
  height: 36px;
  color: rgba(255, 255, 255, 0.7);
  font-size: 14px;
  font-weight: 500;
  padding: 0 4px;
  cursor: default;
  background-color: transparent;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}

.course-pagination .grid-pagination span:not(.pagination-ellipsis) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: 36px;
  height: 36px;
  text-align: center;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 500;
  color: #FFFFFF;
  font-family: "Noto Sans KR", "Roboto", sans-serif;
  -webkit-flex-shrink: 0;
      -ms-flex-negative: 0;
          flex-shrink: 0;
  background-color: transparent;
}

.course-pagination .grid-pagination span:hover {
  background-color: rgba(255, 255, 255, 0.1);
}

.course-pagination .grid-pagination span.on {
  background-color: #FF7700;
  color: #FFFFFF;
  font-weight: 600;
}

.course-pagination .grid-pagination span.on a {
  color: #FFFFFF;
}

.course-pagination .grid-pagination span a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  color: #FFFFFF;
  text-decoration: none;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

@media (max-width: 400px) {
  .course-pagination {
    margin: 30px 0 50px 0;
    padding: 0 10px;
  }
  
  .course-pagination .circleprev,
  .course-pagination .circlenext {
    width: 32px;
    height: 32px;
  }
  
  .course-pagination .circleprev i,
  .course-pagination .circlenext i {
    font-size: 16px;
  }
  
  .course-pagination .grid-pagination span:not(.pagination-ellipsis) {
    min-width: 32px;
    height: 32px;
    font-size: 12px;
  }
  
  .course-pagination .grid-pagination {
    gap: 6px;
  }
  
  .course-pagination .grid-pagination .pagination-ellipsis {
    height: 32px;
    font-size: 12px;
    padding: 0 2px;
  }
}

.grid-pagination {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
}

.grid-pagination span {
  cursor: pointer;
  margin: 0 2px;
}

.grid-pagination span a {
  color: #999;
}

.grid-pagination span.on a {
  color: #333;
}

/* Content Type Filter Cards with Orange Accents */
.content-type-filter {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  margin: 20px 0 25px 0;
  padding: 0 15px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  background-color: transparent;
}

.content-type-card {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  background-color: #3A3A3A;
  border-radius: 12px;
  padding: 20px 12px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
  border: 2px solid transparent;
  min-height: 120px;
  position: relative;
  max-width: calc(33.333% - 8px);
}

.content-type-card:hover {
  background-color: #444444;
  border-color: rgba(255, 119, 0, 0.3);
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 4px 12px rgba(255, 119, 0, 0.2);
          box-shadow: 0 4px 12px rgba(255, 119, 0, 0.2);
}

.content-type-card.active {
  background: linear-gradient(135deg, #FF7700 0%, #FF7200 100%);
  border-color: #FF7700;
  color: #FFFFFF;
  -webkit-transform: translateY(-2px);
          transform: translateY(-2px);
  -webkit-box-shadow: 0 8px 25px rgba(255, 119, 0, 0.4);
          box-shadow: 0 8px 25px rgba(255, 119, 0, 0.4);
}

.content-type-card.active .content-type-icon {
  background-color: rgba(255, 255, 255, 0.2);
  transform: scale(1.05);
}

.content-type-card.active .content-type-label {
  font-weight: 700;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
}

.content-type-icon {
  width: 43px;
  height: 43px;
  background-color: #2A2A2A;
  border: 1px solid rgba(255, 119, 0, 0.2);
  border-radius: 8px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 12px;
  transition: all 0.3s ease;
}

.content-type-card:hover .content-type-icon {
  background-color: #3A3A3A;
  border-color: rgba(255, 119, 0, 0.4);
  transform: scale(1.02);
}

.content-type-icon img {
  width: 33px;
  height: 27px;
  aspect-ratio: 47/38;
  -o-object-fit: contain;
     object-fit: contain;
}

.content-type-icon.all-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.content-type-label {
  color: #FFFFFF;
  font-size: 14px;
  font-weight: 500;
  text-align: center;
  font-family: "Noto Sans KR", "Roboto", sans-serif;
  letter-spacing: -0.2px;
}

@media (max-width: 400px) {
  .content-type-filter {
    gap: 8px;
    margin: 15px 0 25px 0;
    padding: 0 10px;
  }
  
  .content-type-card {
    padding: 16px 8px;
    min-height: 100px;
    border-radius: 10px;
    max-width: calc(33.333% - 7px);
  }
  
  .content-type-icon {
    width: 36px;
    height: 36px;
    border-radius: 6px;
    margin-bottom: 10px;
  }
  
  .content-type-icon img {
    width: 27px;
    height: 22px;
    aspect-ratio: 47/38;
  }
  
  .content-type-label {
    font-size: 12px;
  }
}
/*# sourceMappingURL=content.css.map */