/* =============================================
   sub.css - 서브페이지 공통 스타일 (일반 콘텐츠)
   ============================================= */

/* ── CSS 변수 (1뎁스별 배경) ─────────────── */
body.page-bootcamp {
  --subTopBg: url('/html/assets/img/sub/bootcamp_bg.jpg');
}
body.page-oled {
  --subTopBg: url('/html/assets/img/sub/oled_bg.jpg');
}
body.page-led {
  --subTopBg: url('/html/assets/img/sub/led_bg.jpg');
}
body.page-result {
  --subTopBg: url('/html/assets/img/sub/result_bg.jpg');
}
body.page-apply {
  --subTopBg: url('/html/assets/img/sub/apply_bg.jpg');
}
body.page-etc {
  --subTopBg: url('/html/assets/img/sub/bootcamp_bg.jpg');
}

/* ── 서브 상단 공통 컴포넌트 ─────────────── */
.subTop {
  width: 100%;
  position: relative;
}

.subTop__visual {
  position: relative;
  width: 100%;
  height: clamp(200px, 35vw, 420px);
  background: var(--subTopBg, linear-gradient(135deg, rgba(20, 30, 60, 0.9), rgba(10, 10, 26, 0.95))) center / cover no-repeat;
  display: flex;
  align-items: center;
  justify-content: center;
}

.subTop__title {
  font-size: clamp(20px, 3.6vw, 56px);
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

.subTop__nav {
  width: 100%;
  background: transparent;
  display: flex;
  justify-content: center;
  position: relative;
  margin-top: -56px;
  padding: 0 clamp(20px, 2vw, 20px);
  z-index: 10;
}

.subTop__navList {
  display: flex;
  width: 100%;
  max-width: 1400px;
  background: #F8F8F8;
  border-radius: 10px 10px 0 0;
  overflow: hidden;
}

.subTop__navItem {
  flex: 1;
  position: relative;
}

.subTop__navItem:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: rgba(0, 0, 0, 0.08);
}
.intro-tab .subTop__navItem {
  width:calc(100% / 3);
}

.subTop__navLink {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  min-height: 56px;
  padding: clamp(8px, 1vw, 10px) clamp(16px, 2vw, 24px);
  font-size: clamp(15px, 1.8vw, 18px);
  font-weight: 500;
  color: #333333;
  background: #f8f8f8;
  transition: all 0.25s ease;
  text-align: center;
  line-height: 1.4;
}

.subTop__navLink:hover,
.subTop__navLink:focus {
  background: #f8f8f8;
  color: var(--color-secondary01);
}

.subTop__navLink.is-active {
  background: var(--color-secondary01);
  color: #ffffff;
  font-weight: 700;
}

.subTop__navLink.is-active:hover {
  background: var(--color-secondary01);
}

/* ── 서브탑 브레드크럼 (Home > 대분류 > 드롭다운) ─────────────────── */
.subTop__nav--breadcrumb .subTop__breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px 8px;
  width: 100%;
  max-width: 1400px;
  min-height: 56px;
  padding: 12px clamp(20px, 2vw, 24px);
  background: #f8f8f8;
  border-radius: 10px 10px 0 0;
  font-size: clamp(14px, 1.6vw, 16px);
  color: #333333;
}

.subTop__breadcrumb-link {
  color: var(--color-secondary01);
  text-decoration: none;
  font-weight: 500;
  transition: color 0.2s;
}

.subTop__breadcrumb-link:hover {
  color: var(--color-primary);
  text-decoration: underline;
}

.subTop__breadcrumb-sep {
  color: #6b7280;
  font-weight: 400;
  user-select: none;
}

.subTop__breadcrumb-section {
  font-weight: 600;
  color: #1a1a1a;
}

.subTop__breadcrumb-select {
  margin-left: 4px;
  padding: 8px 32px 8px 14px;
  font-size: inherit;
  font-family: inherit;
  color: #1a1a1a;
  background: #ffffff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%234b5563' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  min-width: 140px;
  max-width: 280px;
}

.subTop__breadcrumb-select:hover,
.subTop__breadcrumb-select:focus {
  border-color: var(--color-secondary01);
  outline: none;
}

/* ── 서브탑 드롭다운 메뉴 (PC: 기존 형태 유지) ─────────────────── */
.subTop__nav--dp .subTop__dp-inner.inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 8px;
  width: 100%;
  max-width: 1400px;
  min-height: 56px;
  padding: 0 clamp(20px, 2vw, 24px);
  background: #f8f8f8;
  border-radius: 10px 10px 0 0;
}

.subTop__nav--dp .subTop__dp-home.home {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  color: #333;
  text-decoration: none;
  font-size: 18px;
  transition: color 0.2s;
}
.subTop__nav--dp .subTop__dp-home.home:hover {
  color: var(--color-secondary01);
}

.subTop__nav--dp .dp_menu {
  position: relative;
}

.subTop__nav--dp .dp_title {
  margin: 0;
}

.subTop__nav--dp .dp_title button {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  min-height: 40px;
  font-size: clamp(14px, 1.5vw, 16px);
  font-weight: 500;
  color: #333;
  background: transparent;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.subTop__nav--dp .dp_title button:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--color-secondary01);
}
.subTop__nav--dp .dp_title button.is-active {
  font-weight: 700;
  color: var(--color-secondary01);
  background: rgba(0, 83, 162, 0.12);
}
.subTop__nav--dp .dp_title button.is-active:hover {
  background: rgba(0, 83, 162, 0.18);
  color: var(--color-secondary01);
}

/* PC: 드롭다운은 각 버튼 하단, 세로 리스트 */
.subTop__nav--dp .dp_menu .list-unstyled {
  list-style: none;
  margin: 0;
  padding: 10px 0;
  min-width: 180px;
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 20;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  display: none;
}
.subTop__nav--dp .dp_menu.is-open .list-unstyled {
  display: block;
}

.subTop__nav--dp .dp_menu .list-unstyled li {
  margin: 0;
}
.subTop__nav--dp .dp_menu .list-unstyled li a {
  display: block;
  padding: 10px 16px;
  font-size: 14px;
  color: #333;
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
}
.subTop__nav--dp .dp_menu .list-unstyled li a:hover {
  background: #f3f4f6;
  color: var(--color-secondary01);
}
.subTop__nav--dp .dp_menu .list-unstyled li.on a {
  font-weight: 700;
  color: var(--color-secondary01);
  background: rgba(0, 83, 162, 0.08);
}

/* ── 서브페이지 공통 래퍼 ─────────────────── */
.sub {
  position:relative;
  overflow:hidden;
  background: #ffffff;
}

.sub__content {
  max-width: 1460px;
  margin: 0 auto;
  padding: clamp(40px, 6vw, 80px) clamp(15px, 2vw, 30px) clamp(60px, 8vw, 120px);
}

/* ── 서브페이지 공통 컴포넌트 (재사용) ──────── */

/* 서브페이지 상단 헤더 (타이틀 + 브레드크럼) */
.sub-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: clamp(30px, 4vw, 50px);
}

.sub-header__title {
  font-size: clamp(32px, 4.2vw, 48px);
  font-weight: 900;
  color: #000000;
  line-height: 1;
  margin: 0;
  letter-spacing: -0.02em;
}

/* 브레드크럼 네비게이션 */
.breadcrumb {
  display: flex;
  align-items: center;
  gap: clamp(4px, 0.5vw, 6px);
  font-size: clamp(12px, 1.4vw, 14px);
  color: #000;
  white-space: nowrap;
}
.breadcrumb > a {
  color:#000;
}
.breadcrumb > a:first-child:before {
  content: "\e900";
  font-family: 'xeicon' !important;
  font-size: 16px;
  color: #000;
  margin-right: 6px;
}

.breadcrumb__link {
  color: #000;
  text-decoration: none;
  transition: color 0.2s;
}

.breadcrumb__separator {
  color: #000;
  font-size: clamp(11px, 1.3vw, 13px);
  margin: 0 clamp(2px, 0.3vw, 3px);
}

.breadcrumb__current {
  color: #000000;
  font-weight: 400;
}

/* 섹션 타이틀 (아이콘 + 텍스트) */
.section-title {
  display: flex;
  align-items: center;
  gap: clamp(8px, 1.2vw, 12px);
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: clamp(24px, 3vw, 36px);
  line-height: 1.3;
}

.section-title__icon {
  width: clamp(24px, 3vw, 32px);
  height: clamp(24px, 3vw, 32px);
  object-fit: contain;
  flex-shrink: 0;
}

/* ── 서브페이지 본문 타이포 (흰 배경 최적화) ── */
.sub__content h1,
.sub__content h2 {
  font-size: clamp(18px, 2.2vw, 28px);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: clamp(15px, 1.5vw, 24px);
  line-height: 1.3;
}
.sub__content h1 {
  font-size: clamp(20px, 2.4vw, 32px);
  margin-bottom:0;
}

.sub__content h3 {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 600;
  color: var(--color-secondary01);
  margin-bottom: clamp(10px, 1vw, 15px);
  line-height: 1.4;
}

.sub__content h4 {
  font-size: clamp(18px, 2.2vw, 22px);
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: clamp(10px, 1.2vw, 16px);
  line-height: 1.4;
}

.sub__content p {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
}

.sub__content a {
  color: #000;
  text-decoration: none;
  transition: color 0.2s;
}


.sub__content strong {
  font-weight: 700;
  color: #2a2a2a;
}

.sub__content em {
  font-style: italic;
  color: var(--color-secondary01);
}

.sub__content blockquote {
  border-left: 4px solid var(--color-secondary01);
  padding: clamp(12px, 2vw, 20px) clamp(16px, 2.5vw, 24px);
  background: #f9fafb;
  margin: clamp(20px, 3vw, 32px) 0;
  font-size: clamp(14px, 1.8vw, 16px);
  color: #555555;
  line-height: 1.7;
}

.sub__content hr {
  border: none;
  border-top: 1px solid #e5e7eb;
  margin: clamp(32px, 4vw, 48px) 0;
}


.section-title__wrap {
  margin-bottom: clamp(24px, 3vw, 36px);
  display:flex;
  flex-direction: column;
  gap:clamp(10px, 1.5vw, 20px);
}
.section-title__wrap .section-title {
  margin-bottom:0;
}
.section-title__wrap .section-title__descWrap {
  text-align:left;
  font-size: clamp(14px, 1.8vw, 20px);
  font-weight: 600;
  color: var(--color-secondary01);
  margin: 0;
  line-height: 1.6;
}
.section-title__wrap .section-title__desc {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.6;
  text-align:left;
}

.list__wrap {
  display: flex;
  flex-direction: column;
}
.list__wrap .list__item {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
  padding-left: clamp(20px, 2vw, 25px);
  position: relative;
}

.list__wrap .list__item::before {
  content: "\e92c";
  font-family:'xeicon';
  display:inline-block;
  position: absolute;
  left: 0;
  top: 0;
  color:var(--color-secondary01);
}

@media (max-width: 575.98px) {
	.section-title {
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
  }
}


/* ── 카드 레이아웃 (산학프로그램 등) ────── */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: clamp(20px, 3vw, 32px);
  margin-bottom: clamp(32px, 4vw, 48px);
}

.program-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  padding: clamp(24px, 3vw, 32px);
  transition: all 0.3s;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
}

.program-card:hover {
  background: #fafbfc;
  border-color: var(--color-secondary01);
  transform: translateY(-4px);
  box-shadow: 0 8px 24px rgba(0, 83, 162, 0.12);
}

.program-card__title {
  font-size: clamp(18px, 2.5vw, 22px);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom: 12px;
  line-height: 1.3;
}

.program-card__desc {
  font-size: clamp(14px, 1.8vw, 16px);
  color: #555555;
  line-height: 1.6;
  margin-bottom: 20px;
}

.program-card__meta {
  display: flex;
  flex-direction: column;
  gap: 8px;
  font-size: 14px;
  color: #666666;
  margin-bottom: 20px;
  padding: 16px;
  background: #f9fafb;
  border-radius: 8px;
}

.program-card__meta strong {
  color: #333333;
}

.program-card__btn {
  display: inline-block;
  padding: 10px 20px;
  background: var(--color-secondary01);
  border-radius: 8px;
  color: #ffffff;
  font-weight: 600;
  font-size: 14px;
  text-align: center;
  text-decoration: none;
  transition: all 0.2s;
}

.program-card__btn:hover {
  background: var(--color-primary);
  color: #ffffff;
  text-decoration: none;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 83, 162, 0.2);
}

/* ── 공통 안내박스 ───────────────────────── */
.info-box {
  padding: clamp(20px, 3vw, 28px);
  background: #f0f9ff;
  border: 1px solid #bfdbfe;
  border-left: 4px solid var(--color-secondary01);
  border-radius: 8px;
  margin: clamp(24px, 3vw, 32px) 0;
}

.info-box__title {
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: 12px;
}

.info-box__content {
  font-size: clamp(14px, 1.8vw, 16px);
  line-height: 1.7;
  color: #334155;
}

.warning-box {
  padding: clamp(20px, 3vw, 28px);
  background: #fef3c7;
  border: 1px solid #fcd34d;
  border-left: 4px solid #f59e0b;
  border-radius: 8px;
  margin: clamp(24px, 3vw, 32px) 0;
}

.warning-box__title {
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 700;
  color: #d97706;
  margin-bottom: 12px;
}

.warning-box__content {
  font-size: clamp(14px, 1.8vw, 16px);
  line-height: 1.7;
  color: #78350f;
}

/* ── 공통 버튼 ───────────────────────────── */
.btn-primary {
  display: inline-block;
  padding: clamp(12px, 1.5vw, 16px) clamp(24px, 3vw, 32px);
  background: var(--color-secondary01);
  color: #ffffff;
  font-size: clamp(15px, 1.8vw, 17px);
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s;
  border: none;
  cursor: pointer;
  font-family: 'Noto Sans KR', sans-serif;
}

.btn-primary:hover {
  background: var(--color-primary);
  color: #ffffff;
  text-decoration: none;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 83, 162, 0.25);
}

.btn-secondary {
  display: inline-block;
  padding: clamp(12px, 1.5vw, 16px) clamp(24px, 3vw, 32px);
  background: #ffffff;
  color: var(--color-secondary01);
  font-size: clamp(15px, 1.8vw, 17px);
  font-weight: 600;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s;
  border: 1px solid var(--color-secondary01);
  cursor: pointer;
  font-family: 'Noto Sans KR', sans-serif;
}

.btn-secondary:hover {
  background: var(--color-secondary01);
  color: #ffffff;
  text-decoration: none;
  transform: translateY(-2px);
}

/* ── 반응형 ─────────────────────────────── */
@media (max-width: 991.98px) {
  .subTop__visual {
    padding-top: 10px;
  }

  .subTop__nav {
    margin-top: -48px;
  }

  .subTop__navLink {
    min-height: 48px;
  }

  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
  }

  /* 공통 컴포넌트 반응형 */
  .sub-header {
    gap: clamp(5px, 1vw, 16px);
  }
  .sub__content p br {
    display:none;
  }
}

@media (max-width: 767.98px) {
  .subTop__visual {
    padding-top: 60px;
  }

  .subTop__nav {
    margin-top: 0;
    display: none;
    padding:0;
  }
  .subTop__nav--breadcrumb,
  .subTop__nav--dp {
    display: flex !important;
  }
  .subTop__breadcrumb {
    min-height: 48px;
    padding: 10px 16px;
  }
  .subTop__breadcrumb-select {
    min-width: 120px;
    max-width: 100%;
    flex: 1;
  }
  /* 모바일: 홈 버튼 숨김 */
  .subTop__nav--dp .subTop__dp-home.home {
    display: none !important;
  }
  /* 모바일: dp 메뉴 25% / 33% / 50% 균등 분할 */
  .subTop__nav--dp .subTop__dp-inner.inner {
    position: relative;
    flex-wrap: nowrap;
    min-height: 48px;
    padding: 0 16px;
  }
  .subTop__nav--dp .dp_menu {
    position: static;
    flex: 1;
    min-width: 0;
  }
  /* 모바일: dp 버튼 텍스트 말줄임 (한 줄 유지, ... 표시) */
  .subTop__nav--dp .dp_menu .dp_title {
    margin: 0;
    min-width: 0;
    flex: 1;
    overflow: hidden;
  }
  .subTop__nav--dp .dp_menu .dp_title button {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    text-align: center;
    box-sizing: border-box;
  }
  /* 모바일: 드롭다운 inner 하단, li당 한 줄(세로 배치) */
  .subTop__nav--dp .dp_menu .list-unstyled {
    position: absolute;
    top: 100%;
    left: 0;
    width: 100%;
    min-width: 0;
    padding: 10px 0;
    border: 1px solid #e5e7eb;
    border-top: none;
    border-radius: 0 0 8px 8px;
    display: none;
  }
  .subTop__nav--dp .dp_menu.is-open .list-unstyled {
    display: block;
  }
  .subTop__nav--dp .dp_menu .list-unstyled li {
    display: block;
    margin: 0;
    min-width: 0;
    overflow: hidden;
  }
  .subTop__nav--dp .dp_menu .list-unstyled li a {
    display: block;
    width: 100%;
    padding: 10px 16px;
    border-radius: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-sizing: border-box;
  }
  .intro-tab {
    display:flex;
  }

  .subTop__navList {
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    border-radius: 0;
  }

  .subTop__navList::-webkit-scrollbar {
    display: none;
  }

  .subTop__navItem:not(:last-child)::after {
    display: block;
  }

  .subTop__navLink {
    white-space: nowrap;
    font-size:13px;
    min-height:44px;
  }

  .card-grid {
    grid-template-columns: 1fr;
  }

  /* 공통 컴포넌트 반응형 */
  .breadcrumb {
    flex-wrap: wrap;
  }
}

@media (max-width: 575.98px) {
  .subTop__visual {
    padding-top: 60px;
  }
  .subTop__nav {
    margin-top: -40px;
  }
  .intro-tab {
    margin-top:0;
  }
	.subTop__navLink {
    min-height:40px;
  }
}


/* =============================================
   bootcamp/intro 페이지 전용 스타일
   ============================================= */

.bootcamp-intro {
  /* 페이지 전체 래퍼 */
}

/* ── 공통 테이블 래퍼 (.tb-wrap) ────────── */
.tb-wrap {
  width: 100%;
  background: #ffffff;
  border-radius: 0;
  overflow: hidden;
}

.tb-wrap__head {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.8vw, 20px);
  padding:0 0 clamp(16px, 2.2vw, 24px) 0;
  background: #ffffff;
  border-bottom: 3px solid #0053a2;
}

.tb-wrap__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: clamp(6px, 0.8vw, 8px) clamp(15px, 2vw, 30px);
  background: #0053a2;
  color: #ffffff;
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 700;
  border-radius: 20px;
  white-space: nowrap;
  line-height: 1.2;
}

.tb-wrap__title {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.4;
  flex: 1;
}

.tb-wrap__table {
  width: 100%;
  border-collapse: collapse;
  background: #ffffff;
  border: 1px solid #d1d5db;
}

.tb-wrap__row {
  border-bottom: 1px solid #e5e7eb;
}

.tb-wrap__row:last-child {
  border-bottom: none;
}

.tb-wrap__th {
  width: clamp(120px, 15%, 160px);
  padding: clamp(10px, 1.5vw, 20px) clamp(15px, 2vw, 30px);
  background: #f0f4f8;
  color: var(--color-secondary01);
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  text-align: center;
  vertical-align: middle;
  border-right: 1px solid #e5e7eb;
  line-height: 1.5;
}

.tb-wrap__td {
  padding: clamp(10px, 1.5vw, 20px) clamp(15px, 2vw, 30px);
  background: #ffffff;
  color: #333;
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  line-height: 1.6;
  vertical-align: middle;
}
.tb-wrap__td > b {
  color: var(--color-secondary01);
}
.tb-wrap__note {
  display:block;
  font-size:clamp(12px, 1.4vw, 16px);
  color:#777;
}

/* sec02: 사업개요 표 */
.bootcamp-intro__overview {
  margin-bottom: clamp(40px, 6vw, 80px);
}

/* sec03: 프로그램 세부 내용 */
.bootcamp-intro__program-detail {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.program-boxes {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 20px);
}

.program-box {
  padding: clamp(20px, 2.5vw, 35px) clamp(2px, 20px, 40px);
  background: #F3F9FF;
  border-radius: 5px;
}

.program-box__title {
  font-size: clamp(17px, 2.2vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: clamp(10px, 1.5vw, 14px);
  line-height: 1.3;
}

.program-box__text {
  font-size: clamp(14px, 1.8vw, 16px);
  line-height: 1.75;
  color: #374151;
  margin: 0;
}

/* sec04: 교육과정 */
.bootcamp-intro__course {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.course-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(15px, 2vw, 32px);
}

.course-card {
  padding: clamp(20px, 2.5vw, 35px) clamp(2px, 20px, 40px);
  background: #F7F7F7;
  border-radius: 5px;
  transition: all 0.3s ease;
}

.course-card__title {
  font-size: clamp(20px, 2.8vw, 26px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: clamp(8px, 1.2vw, 12px);
  line-height: 1.2;
}

.bootcamp-intro__course .course-card__duration {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 600;
  color: #333;
  margin-bottom: clamp(5px, 0.5vw, 10px);
  line-height: 1.6;
}

.bootcamp-intro__course .course-card__desc {
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #777;
  margin: 0;
}

/* sec05: 참여대학 */
.bootcamp-intro__university {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.university-logos {
  display: flex;
  flex-wrap:wrap;
  gap: clamp(10px, 1.5vw, 20px);
}

.university-card {
  width:calc(25% - 15px);
  padding: clamp(10px, 1.5vw, 20px);
  background: #ffffff;
  border-radius: 5px;
  border:1px solid #ddd;
  display:flex;
  align-items:center;
  justify-content:center;
}

.university-card:hover {
  border-color: var(--color-secondary01);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
  transform: translateY(-3px);
}

.university-card__logo {
  width:100%;
  max-width: 80%;
  object-fit: contain;
}

/* sec06: 부트캠프 사업의 차별점 */
.bootcamp-intro__difference {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.difference-boxes {
  display: flex;
  flex-direction: column;
  gap: clamp(16px, 2vw, 20px);
}

.difference-box {
  padding: clamp(20px, 2.5vw, 35px) clamp(2px, 20px, 40px);
  background: #F3F9FF;
  border-radius: 5px;
}

.difference-box__title {
  font-size: clamp(17px, 2.2vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: clamp(10px, 1.5vw, 14px);
  line-height: 1.3;
}

.difference-box__text {
  font-size: clamp(14px, 1.8vw, 16px);
  line-height: 1.75;
  color: #000;
}

.difference-box__text:last-child {
  margin-bottom: 0;
}

.bootcamp-intro .difference-box__note {
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #777;
  margin-top: clamp(5px, 1vw, 5px);
}

/* sec07: 참여기업 역할 및 참여 이점 */
.bootcamp-intro__company-role {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.company-role-box {
  padding: clamp(20px, 2.5vw, 35px) clamp(2px, 20px, 40px);
  background: #F7F7F7;
  border-radius: 5px;
}

.company-role-box__subtitle {
  font-size: clamp(18px, 2.5vw, 22px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: clamp(12px, 1.8vw, 18px);
  line-height: 1.3;
}

.bootcamp-intro .company-role-box__text {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
}

.company-role-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  padding-left: 0;
  list-style: none;
  margin-top:clamp(10px, 1.5vw, 20px);
}

.company-role-list__item {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
  padding-left: 15px;
  position: relative;
}

.company-role-list__item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 12px;
  width: clamp(3px, 0.3vw, 4px);
  height: clamp(3px, 0.3vw, 4px);
  background: var(--color-secondary01);
  border-radius: 50%;
}

/* sec08: 사업 참여 이점 */
.bootcamp-intro__benefit {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.benefit-grid {
  display: flex;
  flex-wrap:wrap;
  gap:clamp(10px, 2vw, 30px);
}

.benefit-item {
  display: grid;
  grid-template-columns: 200px 60px 1fr;
  gap: 0;
  align-items: center;
  width:calc(50% - 20px);
}

.benefit-item__visual {
  display: flex;
  align-items: center;
  justify-content: center;
}

.benefit-item__circle {
  width: clamp(140px, 180px, 200px);
  height: clamp(140px, 180px, 200px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding: clamp(16px, 2.5vw, 24px);
}

.benefit-item__circle::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  padding: clamp(10px, 1.4vw, 18px);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.4));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
}

.benefit-item__circle--cyan {
  background: linear-gradient(135deg, #22d3ee 0%, #06b6d4 100%);
}

.benefit-item__circle--sky {
  background: linear-gradient(135deg, #38bdf8 0%, #0ea5e9 100%);
}

.benefit-item__circle--blue {
  background: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);
}

.benefit-item__circle--navy {
  background: linear-gradient(135deg, #1e40af 0%, #1e3a8a 100%);
}

.benefit-item__circle-text {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  line-height: 1.4;
  position: relative;
  z-index: 1;
}

.benefit-item__connector {
  width: 130%;
  height: 2px;
  background: repeating-linear-gradient(
    to right,
    #3b82f6 0,
    #3b82f6 clamp(3px, 0.5vw, 5px),
    transparent clamp(3px, 0.5vw, 5px),
    transparent clamp(8px, 1.2vw, 10px)
  );
  position: relative;
  left:-22%;
}

.benefit-item__connector::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(6px, 0.8vw, 8px);
  height: clamp(6px, 0.8vw, 8px);
  background: #3b82f6;
  border-radius: 50%;
}

.benefit-item__connector::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(5px, 0.7vw, 7px);
  height: clamp(5px, 0.7vw, 7px);
  background: #9ca3af;
  border-radius: 50%;
}

.benefit-item__content {
  padding: clamp(20px, 2.5vw, 30px) clamp(2px, 3vw, 40px);
  background: #ffffff;
  border: 1px solid #ddd;
  border-radius:5px;
  min-height: clamp(140px, 16vw, 178px);
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.benefit-item__desc {
  font-size: clamp(14px, 1.7vw, 16px);
  line-height: 1.75;
  color: #374151;
  margin: 0;
}

/* sec09: 문의처 배너 */
.contact-banner {
  display: grid;
  grid-template-columns: 240px 1fr;
  gap: clamp(40px, 6vw, 80px);
  padding: clamp(20px, 40px, 50px) 0;
  background: #106EC7;
  border-radius: 5px;
  position: relative;
}

.contact-banner__section {
  display: flex;
  flex-direction: column;
  justify-content: center;
  position:relative;
}

.contact-banner__section::after {
  content: '';
  position: absolute;
  top: 20%;
  right:0;
  height: 60%;
  width: 1px;
  background: rgba(255, 255, 255, 0.2);
}
.contact-banner__section--main::after {
  right: auto;
  left: calc(100% - auto);
  display: none;
}
.contact-banner__section--main {
  flex-direction: row;
  justify-content: flex-start;
  gap:clamp(20px, 4vw, 50px);
}
.contact-banner__section:last-child::after {
  display: none;
}

.bootcamp-intro .contact-banner__label {
  font-size: clamp(18px, 2.4vw, 28px);
  font-weight: 700;
  color: #ffffff;
  margin: 0;
  line-height: 1.3;
  text-align:center;
  position:relative;
}

.bootcamp-intro .contact-banner__title {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.6;
  text-align:left;
  margin-bottom:0;
}

.bootcamp-intro .contact-banner__subtitle {
  font-size: clamp(14px, 1.6vw, 20px);
  color: #ffffff;
  font-weight:400;
  margin: 0;
  line-height: 1.6;
  text-align:left;
}

.contact-banner__section--info {
  text-align: right;
}

.contact-banner__person,
.contact-banner__tel,
.contact-banner__email {
  font-size: clamp(13px, 1.7vw, 15px);
  color: #ffffff;
  margin: 0 0 clamp(4px, 0.6vw, 6px) 0;
  line-height: 1.5;
}

.contact-banner__person {
  font-weight: 600;
}

.contact-banner__email:last-child {
  margin-bottom: 0;
}

@media (max-width: 1199.98px) {
	.benefit-item {
    width:100%;
  }
  .benefit-item__desc br {
    display: none;
  }
}

/* ── 반응형: TABLET ────────────────────── */
@media (max-width: 991.98px) {
  .tb-wrap__th {
    width: clamp(100px, 18%, 140px);
  }

  .course-cards {
    grid-template-columns: 1fr;
  }

  .university-logos {
    grid-template-columns: repeat(2, 1fr);
  }

  .benefit-grid {
    gap: clamp(10px, 2vw, 40px) clamp(24px, 3vw, 32px);
  }

  .benefit-item {
    grid-template-columns: 180px 60px 1fr;
  }
  .contact-banner {
    grid-template-columns: 1fr;
    text-align: center;
    padding:clamp(30px, 40px, 60px) clamp(20px, 30px, 40px);
    gap:clamp(10px, 1vw, 20px);
  }
  .bootcamp-intro .contact-banner__label {
    text-align: left;
  }
  .contact-banner__section--main {
    display:flex;
    flex-direction: column;
    gap:5px;
  }

  .contact-banner__section::after {
    display: none;
  }

  .contact-banner__section--info {
    text-align: center;
  }
}

/* ── 반응형: MOBILE ────────────────────── */
@media (max-width: 767.98px) {
  .tb-wrap__head {
    flex-direction: column;
    align-items: flex-start;
    gap: clamp(8px, 1.5vw, 12px);
  }

  .tb-wrap__table,
  .tb-wrap__table tbody {
    display: block;
  }

  .tb-wrap__row {
    display: flex;
    flex-direction: column;
  }

  .tb-wrap__th {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #e5e7eb;
  }

  .tb-wrap__td {
    width: 100%;
  }

  .university-logos {
    grid-template-columns: 1fr;
  }

  .benefit-grid {
    gap: clamp(32px, 5vw, 48px);
  }

  .benefit-item__visual {
    margin: 0 auto;
  }

  .benefit-item__content {
    text-align: left;
  }
  
  .university-card {
    width:calc(33% - 0.8vw);
  }
  .company-role-list__item{
    padding-left:10px;
  }
  .company-role-list__item::before {
    top:9px;
  }
}

@media (max-width: 575.98px) {
  .breadcrumb {
    display:none;
  }
	.university-card {
    width:calc(50% - 5px);
  }
  .company-role-list__item::before {
    top:8px;
  }
  .benefit-grid {
    gap:10px;
  }
  .benefit-item {
    grid-template-columns: 1fr;
    gap:5px;
  }
  .benefit-item__visual {
    width:100%;
  }
  .benefit-item__circle {
    width: 100%;
    height: auto;
    border-radius: 10px;
  }
  .benefit-item__circle:before {
    display:none;
  }
  .benefit-item__circle-text br {
    display:none;
  }
  .benefit-item__connector {
    display: none;
  }
  .benefit-item__content {
    min-height:auto;
    padding:20px;
  }
  .contact-banner {
    padding:20px;
  }
}

/* =============================================
   bootcamp/system 페이지 전용 스타일
   ============================================= */

.bootcamp-system__org {
  margin-bottom: clamp(48px, 6vw, 72px);
}

.system-org {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
}
.system-org:before {
  content:"";
  display:block;
  width:1px;
  height:80%;
  background:#ddd;
  position:absolute;
  top:0;
  left:50%;
}

/* 상단 중앙 기관 박스 */
.system-org__top {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  gap:20px;
}

.system-org__box {
  padding: clamp(14px, 2vw, 18px) clamp(32px, 4vw, 48px);
  border-radius: 6px;
  font-size: clamp(16px, 2vw, 18px);
  font-weight: 700;
  text-align: center;
  line-height: 1.3;
  min-width: clamp(200px, 28vw, 323px);
}

.system-org__box--navy {
  background: var(--color-secondary05);
  color: #ffffff;
}

.system-org__box--blue {
  background: #2563eb;
  color: #ffffff;
}

.system-org__box--cyan {
  background: #06b6d4;
  color: #ffffff;
}

/* 중단 좌우 분기 */
.system-org__center {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1vw, 15px);
  position: relative;
}

.system-org__center::after {
  content: '';
  position: absolute;
  top: 40px;
  left: 16%;
  right: 16%;
  height: 1px;
  background: #ddd;
}

.system-org__branch--left::before,
.system-org__branch--right::before {
  content: '';
  position: absolute;
  top: 40px;
  width: 1px;
  height: 40px;
  background: #ddd;
  z-index:0;
}

.system-org__branch--left::before {
  left: 50%;
  transform: translateX(-50%);
}

.system-org__branch--right::before {
  left: 50%;
  transform: translateX(-50%);
}

.system-org__branch {
  position: relative;
  padding-top: clamp(40px, 6vw, 80px);
}

.system-org__node {
  display: flex;
  flex-direction: column;
  gap: 10px;
  position:relative;
  z-index:2;
}

.system-org__body {
  padding: clamp(20px, 2.5vw, 30px) clamp(15px, 2vw, 25px);
  background: #ffffff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  min-height: clamp(120px, 18vw, 160px);
}

.system-org__desc {
  font-size: clamp(14px, 1.7vw, 16px);
  line-height: 1.75;
  color: #374151;
  margin: 0;
  text-align: center;
}

.system-org__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(5px, 1vw, 14px);
}

.system-org__list-item {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
  padding-left: clamp(20px, 2vw, 25px);
  position: relative;
}

.system-org__list-item::before {
  content: "\e92c";
  font-family:'xeicon';
  display:inline-block;
  position: absolute;
  left: 0;
  top: 0;
  color:var(--color-secondary01);
}

/* 하단 대학 로고 */
.system-org__universities {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1vw, 15px);
  position: relative;
}

.system-org__universities::after {
  content: '';
  position: absolute;
  top: 40px;
  left: 16%;
  right: 16%;
  height: 1px;
  background: #ddd;
}
.system_org__univ_wrap {
  position:relative;
  padding-top: clamp(40px, 6vw, 80px);
  height:100%;
}
.system_org__univ_wrap::before {
  content: '';
  position: absolute;
  top: 40px;
  left:50%;
  width: 1px;
  height: 40px;
  background: #ddd;
  z-index:1;
}

.system_org__univ_wrap:nth-child(2)::before {
  display:none;
}
.system-org__univ {
  position:relative;
  padding: clamp(20px, 2vw, 30px);
  background: #ffffff;
  border: 1px solid #ddd;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index:2;
  height:100%;
}

.system-org__univ-logo {
  max-width: 80%;
  height: auto;
  object-fit: contain;
}

/* 최하단 설명 박스 */
.system-org__summary {
  padding: clamp(24px, 3.5vw, 36px);
  background: #ffffff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  margin-top:clamp(10px, 1vw, 15px);
}

.system-org__summary-grid .system-org__summary-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0 clamp(24px, 3.5vw, 40px);
}

.system-org__summary-item {
  display: flex;
  align-items: center;
  gap: clamp(10px, 1.5vw, 14px);
}

.system-org__summary-icon {
  width: clamp(6px, 0.8vw, 8px);
  height: clamp(6px, 0.8vw, 8px);
  background: #2563eb;
  border-radius: 50%;
  flex-shrink: 0;
}

.system-org__summary-text {
  font-size: clamp(14px, 1.7vw, 16px);
  font-weight: 600;
  color: #374151;
  line-height: 1.5;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .system-org__top {
    gap:10px;
  }
  .system-org__box {
    width:100%;
  }
  .system-org__branch--left::before,
  .system-org__branch--right::before,
  .system_org__univ_wrap::before {
    top:3vw;
  }
  .system-org__center::after,
  .system-org__universities::after {
    content: '';
    position: absolute;
    top: 3vw;
    left: 16.4%;
    right: 16.4%;
    height: 1px;
    background: #ddd;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .system-org:before {
    height:100%;
  }
  .system-org__node {
    width:100%;
  }
  .system-org__center {
    grid-template-columns: 1fr;
    padding-top:20px;
  }
  .system-org__body {
    min-height:auto;
  }
  .system-org__list {
    gap:5px;
  }
  .system-org__universities {
    grid-template-columns: 1fr;
    padding-top:20px;
    gap:10px;
  }
  .system_org__univ_wrap {
    padding-top:0;
  }

  .system-org__center::after {
    display: none;
  }

  .system-org__branch--left::before,
  .system-org__branch--right::before {
    display: none;
  }

  .system-org__branch {
    padding-top: 0;
  }

  .system-org__universities::before {
    display: none;
  }

  .system-org__universities::after {
    display: none;
  }

  .system-org__univ::before {
    display: none;
  }
  .system-org__summary {
    position:relative;
    background:#fff;
    z-index:2;
    padding:clamp(20px, 2.5vw, 30px) clamp(15px, 2vw, 25px);
  }
  .system-org__summary-grid .system-org__summary-list {
    grid-template-columns: 1fr;
  }
}



/* =============================================
   참여대학 탭 메뉴 공통 스타일
   ============================================= */

.university-tab {
  width: 100%;
  background: #f8f9fa;
  margin-bottom: clamp(20px, 4vw, 50px);
}

.university-tab__inner {
  max-width: 1460px;
  margin: 0 auto;
  padding: 0;
}

.university-tab__list {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
  padding: 0;
  margin: 0;
  gap: 0;
  border:1px solid #ddd;
}
.university-tab__select {
  display:none;
}

.university-tab__item {
  flex: 1;
  position: relative;
}

.university-tab__item:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 20%;
  height: 60%;
  width: 1px;
  background: #d1d5db;
}

.sub__content .university-tab__link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(48px, 6vw, 52px);
  padding: clamp(12px, 1.5vw, 14px) clamp(16px, 2vw, 20px);
  font-size: clamp(14px, 1.4vw, 16px);
  font-weight: 400;
  color: #9ca3af;
  text-decoration: none;
  text-align: center;z
  line-height: 1.2;
  transition: all 0.2s ease;
  position: relative;
  background: #fff;
}

.university-tab__link:hover {
  color: var(--color-secondary01);
}

.university-tab__link.is-active {
  color:var(--color-secondary01);
  font-weight: 700;
}

.university-tab__link.is-active::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--color-secondary01);
}

.university-banner {
  width:100%;
  height:auto;
  margin-bottom: clamp(30px, 4vw, 50px);
}
.university-banner img {
  width:100%;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .university-tab__link {
    min-height: clamp(46px, 5.5vw, 50px);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .university-tab__list {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }

  .university-tab__list::-webkit-scrollbar {
    display: none;
  }

  .university-tab__link {
    min-height: clamp(44px, 5.5vw, 48px);
    font-size: clamp(13px, 1.6vw, 14px);
    padding: clamp(10px, 1.5vw, 12px) clamp(12px, 2vw, 16px);
  }
}

@media (max-width: 575.98px) {
	.university-tab__list {
    display:none;
  }
  .university-tab__select {
    display:block;
    width:100%;
    min-height: clamp(44px, 5.5vw, 48px);
    font-size: clamp(13px, 1.6vw, 14px);
    padding: clamp(10px, 1.5vw, 12px) clamp(12px, 2vw, 16px);
  }
}

/* ── university01 사업소개 카드 섹션 ────────── */
.bootcamp-university .univ01__wrap {
  width: 100%;
  margin-top: clamp(40px, 5vw, 60px);
}

.bootcamp-university .univ01__cards {
  display: grid;
  grid-template-columns: 1fr 200px;
  gap: clamp(10px, 1.5vw, 30px);
  margin-top: clamp(30px, 4vw, 50px);
}
.bootcamp-university .univ01__card--inner {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 10px;
}
.bootcamp-university .univ01__card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  min-height: 200px;
}

.bootcamp-university .univ01__card--logo {
  justify-content: center;
}

.bootcamp-university .univ01__logo {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

.bootcamp-university .univ01__card--desc {
  border:0;
  background:#f5f5f5;
  text-align:left;
  justify-content: center;
  align-items: flex-start;
  padding:clamp(15px, 2vw, 30px) clamp(15px, 2vw, 30px);
  gap:10px;
}

.bootcamp-university .univ01__card--desc h3 {
  margin-bottom:0;
  color:#000;
}
.bootcamp-university .univ01__cardTitle {
  font-size: clamp(15px, 1.8vw, 18px);
  font-weight: 700;
  color: #1a1a1a;
  margin: 0;
  line-height: 1.4;
}

.bootcamp-university .univ01__desc {
  font-size: clamp(13px, 1.5vw, 15px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.5;
}
.bootcamp-university .univ01__desc > b {
  color: var(--color-secondary01);
}

.bootcamp-university .univ01__card--qr {
  justify-content: center;
  gap: 10px;
}

.bootcamp-university .univ01__qr {
  max-width: 120px;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.bootcamp-university .univ01__qrCap {
  font-size: clamp(13px, 1.5vw, 15px);
  font-weight: 500;
  color: #1a1a1a;
  margin: 0;
  line-height: 1.4;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .bootcamp-university .univ01__cards {
    grid-template-columns: 1fr;
  }

  .bootcamp-university .univ01__card--qr {
    grid-column: 1 / -1;
  }

  .bootcamp-university .univ01__desc br {
    display:block;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .univ01__cards {
    grid-template-columns: 1fr;
  }
  .bootcamp-university .univ01__card--inner {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .bootcamp-university .univ01__card {
    min-height:140px;
  }

  .bootcamp-university .univ01__card--qr {
    grid-column: auto;
  }
}


/* ── university01 교육 특화 커리큘럼 섹션 (sec02) ────────── */
.bootcamp-university .sec02 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.bootcamp-university .sec02__head {
  text-align: center;
  margin-bottom: clamp(20px, 4vw, 30px);
}

.bootcamp-university .sec02__title {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 900;
  color: #1a1a1a;
  margin: 0 0 clamp(12px, 1.5vw, 16px) 0;
  line-height: 1.3;
}

.bootcamp-university .sec02__desc {
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 400;
  color: #666;
  margin: 0;
  line-height: 1.6;
}

.bootcamp-university .sec02__topGrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 2.5vw, 30px);
  margin-bottom: clamp(30px, 4vw, 40px);
}

.bootcamp-university .sec02__topCol {
  text-align: left;
  margin-bottom:10px;
}

.bootcamp-university .sec02__topTit {
  font-size: clamp(18px, 2.2vw, 24px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom:10px;
  line-height: 1.4;
}
.bootcamp-university .sec02__topTit--sky {
  color: var(--color-secondary02);
}

.bootcamp-university .sec02__topTxt {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.6;
}

.bootcamp-university .sec02__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(30px, 4vw, 50px);
}

.bootcamp-university .sec02__col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.bootcamp-university .sec02__row {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 10px;
  align-items: stretch;
}
.bootcamp-university .sec02__row:nth-of-type(2){
  min-height:206px;
}
.bootcamp-university .sec02__row:nth-of-type(3){
  min-height:320px;
}
.bootcamp-university .sec02__row:nth-of-type(4){
  min-height:180px;
}

.bootcamp-university .sec02__label {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-secondary01);
  color: #ffffff;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 700;
  border-radius: 6px;
  padding: clamp(16px, 2vw, 20px) clamp(8px, 1vw, 12px);
  text-align: center;
  letter-spacing: 0.1em;
}

.bootcamp-university .sec02__label--sky {
  background: var(--color-secondary02);
}

.bootcamp-university .sec02__card {
  display:flex;
  flex-direction: column;
  justify-content: center;
  gap:10px;
  height:100%;
}

.bootcamp-university .sec02__card--inner {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap:10px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: clamp(15px, 2vw, 20px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  height:100%;
}

.bootcamp-university .sec02__cardTit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom:0;
  line-height: 1.4;
}

.bootcamp-university .sec02__list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.bootcamp-university .sec02__list li {
  position: relative;
  padding-left: clamp(20px, 4vw, 25px);
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  word-break: keep-all;
  letter-spacing: -0.05em;
}

.bootcamp-university .sec02__list li:last-child {
  margin-bottom: 0;
}

.bootcamp-university .sec02__list li::before {
  content: "\e92c";
  font-family:"xeicon";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-secondary01);
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .bootcamp-university .sec02__topGrid {
    grid-template-columns: 1fr;
  }

  .bootcamp-university .sec02__grid {
    grid-template-columns: 1fr;
    gap: clamp(20px, 4vw, 50px);
  }

  .bootcamp-university .sec02__row {
    grid-template-columns: clamp(70px, 10vw, 80px) 1fr;
  }
  .bootcamp-university .sec02__row:nth-of-type(2),
  .bootcamp-university .sec02__row:nth-of-type(3),
  .bootcamp-university .sec02__row:nth-of-type(4){
    min-height:auto;
  }
  .bootcamp-university .sec02__topCol {
    margin-bottom:0;
  }
  .bootcamp-university .sec02__topTit {
    margin-bottom:5px;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .sec02__row {
    grid-template-columns: 1fr;
    gap: clamp(10px, 1.5vw, 12px);
  }

  .bootcamp-university .sec02__label {
    writing-mode: horizontal-tb;
    padding: clamp(10px, 1.5vw, 12px);
  }
}


/* ── university01 산학 연계 활동 섹션 (sec03) ────────── */
.bootcamp-university .sec03 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.bootcamp-university .sec03__info-list {
  list-style: none;
  margin: 0 0 clamp(30px, 4vw, 40px) 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.bootcamp-university .sec03__info-list li {
  position: relative;
  padding-left: clamp(20px, 4vw, 25px);
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  word-break: keep-all;
}

.bootcamp-university .sec03__info-list li::before {
  content: "\e92c";
  font-family:"xeicon";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-secondary01);
}

.bootcamp-university .sec03__info-list li .highlight {
  color: var(--color-secondary01);
  font-weight: 700;
}

.bootcamp-university .sec03__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1.5vw, 20px);
}

.bootcamp-university .sec03__item {
  margin: 0;
  padding: 0;
  overflow: hidden;
  background: #f5f5f5;
  aspect-ratio: 4 / 2.4;
}

.bootcamp-university .sec03__item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}


/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .sec03__grid {
    grid-template-columns: 1fr;
  }
}


/* ── university01 배출인원 성과 섹션 (sec04) ────────── */
.bootcamp-university .sec04 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.bootcamp-university .sec04__wrap {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: clamp(30px, 4vw, 50px);
  align-items: center;
  justify-items: center;
  margin-top: clamp(20px, 3vw, 30px);
}

.bootcamp-university .sec04__card {
  background: #ffffff;
  border: 1px solid #ddd;
  border-radius: 250px;
  padding: clamp(15px, 2vw, 20px) clamp(35px, 5vw, 60px);
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.bootcamp-university .sec04__card--left {
  justify-content: flex-start;
}

.bootcamp-university .sec04__leftInner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(20px, 3vw, 30px);
  width: 100%;
}

.bootcamp-university .sec04__icon {
  width: auto;
  height: clamp(120px, 12vw, 214px);
  object-fit: contain;
  flex-shrink: 0;
}

.bootcamp-university .sec04__k1 {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 600;
  color: #000;
  line-height: 1.4;
}

.bootcamp-university .sec04__k2 {
  font-size: clamp(16px, 2vw, 20px);
  font-weight: 600;
  color: #000;
  line-height: 1.4;
}

.bootcamp-university .sec04__num {
  font-size: clamp(24px, 3vw, 48px);
  font-weight: 700;
  color: var(--color-secondary01);
  display: inline-block;
  margin-right: clamp(4px, 0.5vw, 6px);
}

.bootcamp-university .sec04__desc {
  font-size: clamp(12px, 1.4vw, 16px);
  font-weight: 400;
  color: #000;
  line-height: 1.4;
}

.bootcamp-university .sec04__mid {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(12px, 1.5vw, 16px);
  text-align: center;
}

.bootcamp-university .sec04__arrow {
  width: clamp(60px, 10vw, 111px);
  height: auto;
  object-fit: contain;
}

.bootcamp-university .sec04__midCap {
  font-size: clamp(16px, 1.8vw, 18px);
  font-weight: 700;
  color: #000;
  margin: 0;
  line-height: 1.4;
  white-space: nowrap;
}
.bootcamp-university .sec04__rightInner {
  display: flex;
  flex-wrap:wrap;
  gap:20px 10px;
  width: 100%;
  justify-content: center;
  align-items: center;
}
.bootcamp-university .sec04__rightInner p {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 600;
  color: #000;
  margin: 0;
  line-height: 1.6;
  text-align:center;
  word-break: keep-all;
}
.bootcamp-university .sec04__logos {
  max-width: 100%;
  height: auto;
  object-fit: contain;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .bootcamp-university .sec04__wrap {
    grid-template-columns: 1fr;
    gap: clamp(30px, 4vw, 40px);
  }

  .bootcamp-university .sec04__mid {
    flex-direction: row;
    gap: clamp(15px, 2vw, 20px);
  }

  .bootcamp-university .sec04__arrow {
    transform: rotate(90deg);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .sec04__card {
    border-radius: clamp(40px, 8vw, 60px);
    padding: clamp(25px, 3.5vw, 35px) clamp(25px, 4vw, 40px);
  }

  .bootcamp-university .sec04__leftInner {
    flex-direction: column;
    text-align: center;
  }

  .bootcamp-university .sec04__txt {
    width: 100%;
  }
}


/* ── university01 참여기업 효과 섹션 (sec05) ────────── */
.bootcamp-university .sec05 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.bootcamp-university .sec05__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 2vw, 50px);
  margin-top: clamp(30px, 4vw, 40px);
}

.bootcamp-university .sec05__item {
  display: flex;
  align-items: center;
  text-align: left;
  gap: clamp(16px, 2vw, 20px);
}

.bootcamp-university .sec05__circle {
  width: clamp(100px, 16vw, 180px);
  height: clamp(100px, 16vw, 180px);
  border: 1px solid #e5e7eb;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: #ffffff;
  padding: clamp(15px, 2vw, 20px);
}

.bootcamp-university .sec05__circle img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.bootcamp-university .sec05__txt {
  flex: 1;
}

.bootcamp-university .sec05__tit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 clamp(5px, 1vw, 12px) 0;
  line-height: 1.5;
}

.bootcamp-university .sec05__desc {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.6;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .bootcamp-university .sec05__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }

  .bootcamp-university .sec05__item:nth-child(3) {
    grid-column: auto;
    max-width: 100%;
  }
  .bootcamp-university .sec05__tit br,
  .bootcamp-university .sec05__desc br {
    display:none;
  }
  .bootcamp-university .sec05__circle img {
    max-width: 60%;
    max-height: 60%;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .sec05__item:nth-child(3) {
    grid-column: auto;
    max-width: 100%;
  }
}


/* ── university01 보유 장비 및 인프라 섹션 (sec06) ────────── */
.bootcamp-university .sec06 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.bootcamp-university .sec06__wrap {
  display: flex;
  gap: clamp(10px, 2vw, 20px);
  margin-top: clamp(30px, 4vw, 40px);
}
.bootcamp-university .sec06__wrap .sec06__left,
.bootcamp-university .sec06__wrap .sec06__right {
  flex:1;
}

.bootcamp-university .sec06__leftInner {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex:1;
  height:100%;
}

.bootcamp-university .sec06__box {
  background: #f0f8ff;
  border-radius: 12px;
  padding: clamp(20px, 2.5vw, 30px) clamp(24px, 3vw, 35px);
}

.bootcamp-university .sec06__subtit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom:clamp(5px, 1vw, 10px);
  line-height: 1.4;
}

.bootcamp-university .sec06__box .company-role-list {
  margin-top: 0;
}

.bootcamp-university .sec06__rightInner {
  display: flex;
  flex:1;
  height:100%;
  background: #fafbfc;
  border-radius: 12px;
  padding: clamp(35px, 5vw, 60px) clamp(30px, 4vw, 40px);
  position:relative;
}

.bootcamp-university .sec06__contact {
  width: 100%;
  text-align: left;
}

.bootcamp-university .sec06__headline {
  font-size: clamp(22px, 3vw, 36px);
  font-weight: 700;
  color: #000;
  margin: 0 0 clamp(20px, 3vw, 40px) 0;
  line-height: 1.3;
}

.bootcamp-university .sec06__contactTit {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 700;
  color: #333;
  margin: 0 0 clamp(16px, 2vw, 20px) 0;
  line-height: 1.4;
}

.bootcamp-university .sec06__line {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
}

.bootcamp-university .sec06__ico {
  width: clamp(16px, 2vw, 20px);
  height: clamp(16px, 2vw, 20px);
  object-fit: contain;
  flex-shrink: 0;
}

.bootcamp-university .sec06__link {
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 400;
  color: #000;
  text-decoration: none;
  line-height: 1.6;
  transition: color 0.2s;
}
.bootcamp-university .sec06__contactImg {
  position: absolute;
  bottom: -30px;
  right: -30px;
  object-fit: contain;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .bootcamp-university .sec06__contactImg {
    width: 90%;
    right:-20px;
    bottom:-20px;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .bootcamp-university .sec06__wrap {
    flex-direction: column;
  }
  .bootcamp-university .sec06__box {
    padding: clamp(18px, 2.5vw, 25px) clamp(20px, 3vw, 28px);
  }
  .bootcamp-university .sec06__rightInner {
    padding: clamp(18px, 2.5vw, 25px) clamp(20px, 3vw, 28px);
  }
  .bootcamp-university .sec06__contactImg {
    position:relative;
    width: 100%;
    right:auto;
    bottom:auto;
    top:20px;
  }
  .bootcamp-university .sec06__contactTit {
    margin-bottom:5px;
  }
  .bootcamp-university .sec06__headline {
    font-size:18px;
    margin-bottom:10px;
  }
  .bootcamp-university .sec06__headline br {
    display:none;
  }
}


/* ── university02 (순천향대) 교육 특화 커리큘럼 섹션 (sec02) ────────── */
.sch-university .sec02 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
  --sec02-basic: var(--color-secondary02, #00b6d7);
  --sec02-mid: var(--color-secondary01, #0053a2);
  --sec02-adv: var(--color-primary, #6c26e0);
  --sec02-dark: #1a1a1a;
}

.sch-university .sec02__head {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
  gap: 0;
  margin-bottom: clamp(30px, 4vw, 40px);
}

.sch-university .section-title__wrap {
  margin-bottom:0;
}
.sch-university .sec02__titleWrap {
  flex: 1;
  margin-bottom:0;
}

.sch-university .sec02__levelTabs {
  display: flex;
  width:100%;
  justify-content: flex-end;
  gap: 4px;
  flex-shrink: 0;
}

.sch-university .sec02__tab {
  padding: clamp(4px, 0.6vw, 6px) clamp(15px, 2vw, 20px);
  font-size: clamp(12px, 1.4vw, 14px);
  font-weight: 500;
  border-radius: 6px;
  color: #fff;
  border:0;
}

.sch-university .is-basic {
  background: var(--sec02-basic);
}
.sch-university .is-mid {
  background: var(--sec02-mid);
}
.sch-university .is-adv {
  background: var(--sec02-adv);
}

.sch-university .sec02__tracks {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(30px, 4vw, 50px);
}

.sch-university .sec02__track {
  width: 100%;
}

.sch-university .sec02__trackTitle {
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin: 0 0 clamp(10px, 1.5vw, 15px) 0;
  line-height: 1.4;
}

.sch-university .sec02__grid {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.sch-university .sec02__gridRow {
  width:100%;
  flex:1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
}
.sec02__item_row {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sch-university .sec02__item {
  padding: clamp(10px, 1vw, 14px) clamp(5px, 0.5vw, 12px);
  font-size: clamp(12px, 1.4vw, 14px);
  font-weight: 400;
  text-align: center;
  border-radius: 6px;
  line-height: 1.4;
  display: flex;
  align-items: center;
  justify-content: center;
  word-break: break-all;
}

.sch-university .sec02__item.is-dark {
  background: var(--sec02-dark);
  color: #ffffff;
  font-weight: 700;
  min-height: clamp(35px, 4.5vw, 45px);
}

.sch-university .sec02__item.is-basic {
  background: var(--sec02-basic);
  color: #ffffff;
}

.sch-university .sec02__item.is-mid {
  background: var(--sec02-mid);
  color: #ffffff;
}

.sch-university .sec02__item.is-adv {
  background: var(--sec02-adv);
  color: #ffffff;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .sch-university .sec02__head {
    flex-direction: column;
    align-items: stretch;
  }

  .sch-university .sec02__levelTabs {
    justify-content: flex-start;
    margin-top: clamp(12px, 2vw, 16px);
  }

  .sch-university .sec02__tracks {
    grid-template-columns: 1fr;
    gap: clamp(30px, 4vw, 50px);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .sch-university .sec02__grid {
    gap:2px;
  }
  .sch-university .sec02__gridRow {
    gap:2px;
  }
  .sec02__item_row {
    gap:2px;
  }

  .sch-university .sec02__levelTabs {
    flex-wrap: wrap;
  }

  .sch-university .sec02__item {
    font-size: clamp(11px, 1.4vw, 13px);
    padding: 4px;
    min-height: clamp(38px, 5vw, 48px);
  }
}

.sch-university .sec03 .section-title__wrap {
  margin-bottom:clamp(10px, 2vw, 20px);
}


/* ── university02 (순천향대) 참여기업 효과 섹션 (sec05) ────────── */
.sch-university .sec05 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
  --sec05-navy: var(--color-secondary05, #002C78);
  --sec05-cyan: var(--color-secondary02, #00b6d7);
}

.sch-university .sec05__grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: clamp(10px, 1.5vw, 15px);
  margin-top: clamp(30px, 4vw, 40px);
}

.sch-university .sec05__card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: clamp(20px, 3vw, 30px) clamp(20px, 3vw, 30px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.sch-university .sec05__cardTit {
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 0 clamp(20px, 2.5vw, 26px) 0;
  line-height: 1.4;
}

.sch-university .sec05__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1vw, 10px);
}

.sch-university .sec05__list--twoCol {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(8px, 1vw, 10px);
}

.sch-university .sec05__item {
  display: flex;
  align-items: flex-start;
  gap: clamp(10px, 1.2vw, 12px);
}

.sch-university .sec05__badge {
  width: clamp(24px, 3vw, 28px);
  height: clamp(24px, 3vw, 28px);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(12px, 1.4vw, 14px);
  font-weight: 700;
  color: #ffffff;
  flex-shrink: 0;
  line-height: 1;
}

.sch-university .sec05__badge--navy {
  background: var(--sec05-navy);
}

.sch-university .sec05__badge--cyan {
  background: var(--sec05-cyan);
}

.sch-university .sec05__txt {
  flex: 1;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  word-break: keep-all;
  letter-spacing: -0.05em;
}

.sch-university .sec06__wrap {
  flex-direction: column;
}
.sch-university .sec06__leftInner {
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap:clamp(10px, 1.5vw, 15px);
}

.sch-university .sec06__contactImg {
  bottom:auto;
  top:20px;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .sch-university .sec05__grid {
    grid-template-columns: 1fr;
  }

  .sch-university .sec05__list--twoCol {
    grid-template-columns: 1fr;
  }
  .sch-university .sec06__contactImg {
    width:50%;
  } 
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .sch-university .sec05__card {
    padding: clamp(25px, 3.5vw, 35px) clamp(22px, 3vw, 30px);
  }

  .sch-university .sec05__list--twoCol {
    grid-template-columns: 1fr;
  }
  .sch-university .sec06__leftInner {
    grid-template-columns: 1fr;
  }
  .sch-university .sec06__contactImg {
    width:100%;
  } 
}


/* ── university03 (한양대) 교육 커리큘럼 그리드 ────────── */
.hanyang-university .u03-curri {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(4px, 6vw, 6px);
  width: 100%;
  margin-top:clamp(10px, 1.5vw, 20px);
}

.hanyang-university .u03-curri__levels {
  display: grid;
  grid-template-columns: 20% 1fr;
  gap: clamp(4px, 6vw, 6px);
}

.hanyang-university .u03-curri__level {
  background: var(--color-secondary01, #0053a2);
  border-radius: 12px;
  padding: 15px 10px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.hanyang-university .u03-curri__level--basic {
  background: var(--color-secondary02, #00b6d7);
}

.hanyang-university .u03-curri__level--adv {
  background: var(--color-primary, #6c26e0);
}

.hanyang-university .u03-curri__tag {
  font-size: clamp(13px, 1.5vw, 15px);
  font-weight: 700;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.3;
}

.hanyang-university .u03-curri__levelTit {
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.5;
  word-break: keep-all;
}

.hanyang-university .u03-curri__tiles {
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 2.5vw, 28px);
}

.hanyang-university .u03-curri__block {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(4px, 6vw, 6px);
}

.hanyang-university .u03-curri__block--basic {
  --u03-accent: var(--color-secondary02, #00b6d7);
}

.hanyang-university .u03-curri__block--mid {
  --u03-accent: var(--color-secondary01, #0053a2);
}

.hanyang-university .u03-curri__block--adv {
  --u03-accent: var(--color-primary, #6c26e0);
}

.hanyang-university .u03-curri__tile {
  background: #ffffff;
  border: 1px solid var(--u03-accent);
  border-radius: 8px;
  padding: 15px 10px;
  font-size: clamp(13px, 1.5vw, 15px);
  font-weight: 500;
  color: var(--u03-accent);
  text-align: center;
  line-height: 1.5;
  display: flex;
  align-items: center;
  justify-content: center;
  word-break: keep-all;
  transition: all 0.2s;
}

.hanyang-university .u03-curri__tile:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .hanyang-university .u03-curri {
    grid-template-columns: 1fr;
  }

  .hanyang-university .u03-curri__levels {
    flex-direction: row;
    justify-content: stretch;
  }

  .hanyang-university .u03-curri__level {
    flex: 1;
  }

  .hanyang-university .u03-curri__block {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .hanyang-university .u03-curri__levels {
    grid-template-columns: 1fr;
  }

  .hanyang-university .u03-curri__block {
    grid-template-columns: repeat(2, 1fr);
  }
  .hanyang-university .u03-curri__levelTit br {
    display:none;
  }
  .hanyang-university .u03-curri__tile {
    font-size: clamp(12px, 1.5vw, 14px);
    min-height: clamp(48px, 6vw, 60px);
  }
}


/* ── university03 (한양대) 교육 커리큘럼 요약 카드 ────────── */
.hanyang-university .sec02__tracks .sec02__benefits {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1vw, 15px);
}

.hanyang-university .sec02__tracks .sec02__benefit {
  background: #f7f9fb;
  border-radius: 6px;
  padding: clamp(20px, 3vw, 30px) clamp(20px, 2.5vw, 25px);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}

.hanyang-university .sec02__tracks .sec02__benefitTit {
  font-size: clamp(16px, 1.8vw, 20x);
  font-weight: 700;
  color: var(--color-secondary01, #0053a2);
  margin: 0;
  line-height: 1.5;
  word-break: keep-all;
}

.hanyang-university .sec02__tracks .sec02__benefitDesc {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.6;
  word-break: keep-all;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .hanyang-university .sec02__tracks .sec02__benefits {
    grid-template-columns: 1fr;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .hanyang-university .sec02__tracks .sec02__benefits {
    grid-template-columns: 1fr;
  }

  .hanyang-university .sec02__tracks .sec02__benefit:nth-child(3) {
    grid-column: auto;
    max-width: 100%;
  }
}


/* ── university03 (한양대) sec02 하단 Venn + Process ────────── */
.hanyang-university .sec02 .sec02__last {
  display: grid;
  grid-template-columns: 0.6fr 1fr;
  gap: clamp(40px, 5vw, 60px);
  margin-top: clamp(50px, 6vw, 70px);
}

.hanyang-university .sec02 .sec02__lastCol {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(20px, 2vw, 30px);
}

.hanyang-university .sec02 .sec02__pillTit {
  background: #1a1a1a;
  color: #ffffff;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 700;
  padding: clamp(10px, 1.2vw, 12px) clamp(24px, 3vw, 32px);
  border-radius: 30px;
  text-align: center;
  line-height: 1.4;
  align-self: flex-start;
}

/* Venn Diagram */
.hanyang-university .sec02 .sec02__venn {
  display: grid;  
  grid-template-columns:repeat(3, 1fr);
  align-items: center;
  justify-content: center;
  position: relative;
  width: 100%;
}

.hanyang-university .sec02 .sec02__vennCircle {
  width: 100%;
  padding-bottom:100%;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position:relative;
}
.hanyang-university .sec02 .sec02__vennCircle p {
  position:absolute;
  left:0;
  top:0;
  width:100%;
  height:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 500;
  color: #ffffff;
  text-align: center;
  line-height: 1.4;
  word-break: keep-all;
}

.hanyang-university .sec02 .sec02__vennCircle--c1 {
  background: rgba(0,180,229,0.6);
}

.hanyang-university .sec02 .sec02__vennCircle--c2 {
  background: rgba(19,118,212,0.6);
}

.hanyang-university .sec02 .sec02__vennCircle--c3 {
  background: rgba(0,44,120,0.6);
}

.hanyang-university .sec02 .sec02__vennCap {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 600;
  color: #000;
  margin: 0;
  text-align: center;
  line-height: 1.4;
}

/* Process */
.hanyang-university .sec02 .sec02__process {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  align-items: center;
  width:100%;
}

.hanyang-university .sec02 .sec02__processItem {
  width:100%;
  padding-bottom:100%;
  background:rgba(221,221,221,0.3);
  border:1px solid #eee;
  border-radius:50%;
  position:relative;
}
.hanyang-university .sec02 .sec02__processItemInner {
  position:absolute;
  width:100%;
  height:100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap:10px;
}
.hanyang-university .sec02 .sec02__processIcon {
  widht:30%;
  height:30%;
  object-fit:contain;
}

.hanyang-university .sec02 .sec02__processTxt {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 500;
  color: #000;
  margin: 0;
  text-align: center;
  line-height: 1.2;
  word-break: break-all;
}
.hanyang-university .sec02__process .sec02__processItem:first-child {
  background:#f8f8f8 url('../img/sub/sch_univ03_sec02_arrow_down.png') no-repeat center center;
  background-size: 3rem;
  left:0;
  z-index:1;
}
.hanyang-university .sec02__process .sec02__processItem:last-child {
  background:#f8f8f8 url('../img/sub/sch_univ03_sec02_arrow_up.png') no-repeat center center;
  background-size: 3rem;
  z-index:1;
}
/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .hanyang-university .sec02 .sec02__last {
    grid-template-columns: 1fr;
  }

  .hanyang-university .sec02 .sec02__pillTit {
    align-self: center;
  }

  .hanyang-university .sec02 .sec02__venn {
    width: 60%;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .hanyang-university .sec02 .sec02__venn {
    display: flex;  
    width: 100%;
  }
  .hanyang-university .sec02 .sec02__vennCircle {
    width: 33.33%;
    padding-bottom:33.33%;
  }
  .hanyang-university .sec02 .sec02__process {
    display: flex;
    flex-wrap:wrap;
    justify-content: center;
    width: 100%;
  }
  .hanyang-university .sec02 .sec02__processItem {
    width:33.33%;
    padding-bottom:33.33%;
  }
  .hanyang-university .sec02 .sec02__processItemInner {
    padding:10px;
    gap:5px;
  }
  .hanyang-university .sec02__process .sec02__processItem:first-child,
  .hanyang-university .sec02__process .sec02__processItem:last-child {
    background-size: 4rem;
  }
}

@media (max-width: 575.98px) {
	.hanyang-university .sec02__process .sec02__processItem:first-child,
  .hanyang-university .sec02__process .sec02__processItem:last-child {
    background-size: 2rem;
  }
}


.hanyang-university .sec02__tracks {
  display:flex;
  flex-direction: column;
  gap: clamp(20px, 3vw, 40px);
}
.hanyang-university .sec02 .section-title__txt {
  text-align:left;
  font-size: clamp(18px, 2vw, 24px);
  font-weight: 700;
  color:#000;
  line-height:1.4;
}
.hanyang-university .sec02__trackTitle {
  margin-bottom:5px;
}
.hanyang-university .sec02__trackDesc {
  margin-bottom:10px;
}

.hanyang-university .sec03__grid {
  grid-template-columns: repeat(4, 1fr);
}

.hanyang-university .sec03 .section-title__wrap {
  margin-bottom:clamp(15px, 1.5vw, 20px);
}
.hanyang-university .sec03__info-list {
  margin-bottom:clamp(15px, 1.5vw, 20px);
}
.hanyang-university .sec03__dlWrap {
  display:flex;
  flex-direction: column;
  gap: 10px;
  margin:0 0 clamp(30px, 4vw, 40px) 0;
}
.hanyang-university .sec03__dlWrap .sec03__dl {
  display:flex;
  gap:10px;
}

.hanyang-university .sec03__dlWrap .sec03__dl .sec03__dt {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 700;
  color: #000;
  line-height: 1.4;
  word-break: keep-all;
}
.hanyang-university .sec03__dlWrap .sec03__dl .sec03__dd {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  line-height: 1.4;
  word-break: keep-all;
}
@media (max-width: 767.98px) {
	.hanyang-university .sec03__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 575.98px) {
	.hanyang-university .sec03__dlWrap .sec03__dl {
    flex-direction: column;
    gap:5px;
  }
}

.sec03__grid_wrap {
  margin-top:clamp(30px, 4vw, 40px);
}
.sec03__grid_wrap .sec03__pillTit {
  display:inline-block;
  background: #1a1a1a;
  color: #ffffff;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 700;
  padding: clamp(10px, 1.2vw, 12px) clamp(24px, 3vw, 32px);
  border-radius: 30px;
  text-align: center;
  line-height: 1.4;
  align-self: flex-start;
  margin-bottom:clamp(15px, 1.5vw, 20px);
}
.sec03__grid_wrap .sec03__grid {
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 1.5vw, 20px);
 
}
.sec03__grid_wrap .sec03__grid .sec03__item {
  aspect-ratio:unset;
  padding:clamp(20px, 3.5vw, 40px) clamp(20px, 2.5vw, 30px);
  border-radius:6px;
}
.sec03__grid_wrap .sec03__grid .sec03__item .sec03__itemTit {
  margin-bottom:clamp(5px, 1vw, 10px);
}

@media (max-width: 767.98px) {
	.sec03__grid_wrap .sec03__grid {
    grid-template-columns: 1fr;
  }
}


/* ── university03 (한양대) 참여기업 효과 섹션 (sec05) ────────── */
.hanyang-university .sec05 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.hanyang-university .sec05__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(10px, 1vw, 15px);
  margin-top: clamp(30px, 4vw, 40px);
}

.hanyang-university .sec05__card {
  position: relative;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: clamp(20px, 3vw, 40px) clamp(20px, 3vw, 40px);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.hanyang-university .sec05__badge {
  position: absolute;
  top: 0;
  right: clamp(20px, 2.5vw, 30px);
  background: var(--color-secondary05, #002C78);
  color: #ffffff;
  font-size: clamp(12px, 1.4vw, 16px);
  font-weight: 700;
  padding: clamp(10px, 1.5vw, 20px) clamp(10px, 1.5vw, 20px);
  letter-spacing: 0.1em;
  line-height: 1;
  min-height:clamp(68px, 88vw, 98px);
  display:flex;
  align-items:center;
  justify-content:center;
}

.hanyang-university .sec05__badge--cyan {
  background: var(--color-secondary02, #00b6d7);
}

.hanyang-university .sec05__cardTit {
  font-size: clamp(18px, 2vw, 20px);
  font-weight: 700;
  color: #1a1a1a;
  margin-bottom:clamp(10px, 1.5vw, 20px);
  line-height: 1.4;
}

.hanyang-university .sec05 .system-org__list {
  gap: 5px;
}

.hanyang-university .sec05__subTxt {
  font-size: clamp(12px, 1.4vw, 16px);
  font-weight: 400;
  color: #777;
  line-height: 1.6;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .hanyang-university .sec05__grid {
    grid-template-columns: 1fr;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .hanyang-university .sec05__card {
    padding: clamp(25px, 3.5vw, 35px) clamp(22px, 3vw, 30px);
  }

  .hanyang-university .sec05__badge {
    right: clamp(15px, 2vw, 20px);
    min-height:48px;
  }
}


/* ── university03 (한양대) 보유 장비 및 인프라 섹션 (sec06) ────────── */
.hanyang-university .sec06 {
  width: 100%;
  margin-top: clamp(50px, 6vw, 80px);
}

.hanyang-university .sec06 .system-org__list {
  margin-top: clamp(10px, 2.5vw, 30px);
  margin-bottom: clamp(20px, 3vw, 40px);
  gap:0;
}
.hanyang-university .sec06 .system-org__list-item strong {
  color:var(--color-secondary01, #0053a2);
}

.hanyang-university .sec06__wrap {
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(10px, 1.5vw, 20px);
  margin-top: clamp(20px, 5vw, 60px);
}

.hanyang-university .sec06__left {
  display: flex;
  flex-direction: column;
}

.hanyang-university .sec06__leftInner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(20px, 3.5vw, 45px) clamp(10px, 1vw, 15px);
}

.hanyang-university .sec06__box {
  position: relative;
  background: #f0f8ff;
  border-radius: 12px;
  padding: clamp(30px, 4vw, 60px) clamp(24px, 3vw, 35px) clamp(20px, 2.5vw, 30px);
}

.hanyang-university .sec06__num {
  position: absolute;
  top: -30px;
  left: clamp(16px, 2vw, 20px);
  width: clamp(40px, 5vw, 60px);
  height: clamp(40px, 5vw, 60px);
  background: var(--color-secondary01, #0053a2);
  color: #ffffff;
  font-size: clamp(16px, 1.8vw, 18px);
  font-weight: 700;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

.hanyang-university .sec06__subtit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01, #0053a2);
  margin-bottom:clamp(5px, 1vw, 10px);
  line-height: 1.4;
}

.hanyang-university .sec06__box .system-org__list {
  margin-top: 0;
  margin-bottom: 0;
}

.hanyang-university .sec06__box .system-org__list-item {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
}

.hanyang-university .sec06__right {
  display: flex;
  flex-direction: column;
}

.hanyang-university .sec06__rightInner {
  padding-bottom:clamp(60px, 6vw, 120px);
}
.hanyang-university .sec06__contactImg {
  top:20px;
  right:20px;
  margin-top: auto;
}
.hanyang-university .sec06__contactImg img {
  width:100%;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .hanyang-university .sec06__wrap {
    grid-template-columns: 1fr;
  }

  .hanyang-university .sec06__leftInner {
    grid-template-columns: 1fr;
  }
  .hanyang-university .sec06__num {
    top: -25px;
  }
  .hanyang-university .sec06__contactImg {
    width:50%;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .hanyang-university .sec06__box {
    padding: clamp(20px, 2.5vw, 28px) clamp(16px, 2vw, 24px);
  }

  .hanyang-university .sec06__num {
    position:relative;
    top: 0;
    left: 0;
  }

  .hanyang-university .sec06__subtit {
    margin-top: 10px;
  }
  .hanyang-university .sec06__contactImg {
    right:auto;
    width:100%;
  }
  .hanyang-university .sec06__rightInner {
    padding-bottom:18px;
  }
}


/* BUILD_STAMP: 2026-03-05T22:00:00+09:00 */


/* ══════════════════════════════════════════════════════════════════════════
   oled-intro 페이지 sec03: 사업목표 및 추진방향
   ══════════════════════════════════════════════════════════════════════════ */

.oled-intro .sec03 {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.oled-intro .sec03__top {
  display: flex;
  flex-direction: column;
  gap: clamp(15px, 2vw, 30px);
  margin-bottom: clamp(15px, 2vw, 30px);
}

.oled-intro .sec03__k {
  display: flex;
  flex-direction: column;
  gap: clamp(5px, 1vw, 10px);
}

.oled-intro .sec03__kTit {
  font-size: clamp(16px, 2vw, 22px);
  font-weight: 700;
  color: var(--color-secondary01);
  line-height: 1.4;
  margin: 0;
}

.oled-intro .sec03__kTxt {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  margin: 0;
}

.oled-intro .sec03__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(16px, 2vw, 24px);
}

.oled-intro .sec03__card {
  background: #F7F7F7;
  border-radius: 8px;
  overflow: hidden;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.oled-intro .sec03__cardTit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 500;
  color: #fff;
  background: var(--color-secondary01);
  padding: clamp(12px, 1.5vw, 18px) clamp(16px, 2vw, 24px);
  margin: 0;
  line-height: 1.4;
}

.oled-intro .sec03__card .company-role-list {
  padding: clamp(16px, 2vw, 24px);
  margin: 0;
  flex: 1;
}

.oled-intro .sec03__card .company-role-list__item {
  ont-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
  padding-left: clamp(20px, 2vw, 25px);
  position: relative;
}
.oled-intro .sec03__card .company-role-list__item::before {
  content: "\e92c";
  font-family:'xeicon';
  display:inline-block;
  position: absolute;
  left: 0;
  top: 0;
  color:var(--color-secondary01);
  width:auto;
  height:auto;
  background:none;
}

@media (max-width: 991.98px) {
  .oled-intro .sec03__grid {
    gap: clamp(14px, 1.8vw, 20px);
  }
}

@media (max-width: 767.98px) {
  .oled-intro .sec03__grid {
    grid-template-columns: 1fr;
    gap: clamp(12px, 1.5vw, 16px);
  }
  
  .oled-intro .sec03__top {
    gap: clamp(16px, 2vw, 20px);
    margin-bottom: clamp(24px, 3vw, 32px);
  }
}


/* ══════════════════════════════════════════════════════════════════════════
   oled-intro 페이지 sec04: 사업의 특징
   ══════════════════════════════════════════════════════════════════════════ */

.oled-intro .sec04 {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.oled-intro .sec04 .section-title {
  margin-bottom:0;
}
.oled-intro .sec04 .sec04__title {
  font-size: clamp(20px, 2.4vw, 32px);
  margin-bottom:clamp(20px, 4vw, 50px);
}
.oled-intro .sec04__content {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.5vw, 20px);
}

.oled-intro .sec04__pointTit {
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 700;
  color: #000;
  line-height: 1.4;
  margin: 0;
  padding-left: clamp(18px, 2vw, 24px);
  position: relative;
}

.oled-intro .sec04__pointTit::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: clamp(8px, 1vw, 12px);
  height: clamp(8px, 1vw, 12px);
  background: var(--color-secondary01);
  border-radius: 50%;
}

.oled-intro .sec04__section {
  display: flex;
  flex-direction: column;
  gap: clamp(10px, 1.2vw, 14px);
}

.oled-intro .sec04__subTit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01);
  line-height: 1.4;
  margin: 0;
}

.oled-intro .sec04__desc {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  line-height: 1.6;
  margin: 0;
}

.oled-intro .sec04__diagram {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: clamp(20px, 4vw, 60px) 0;
}

.oled-intro .sec04__diagramImg {
  width: 100%;
  max-width: clamp(600px, 80vw, 1000px);
  height: auto;
  object-fit: contain;
}

.oled-intro .sec04__foot {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.oled-intro .sec04__footItem {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(6px, 0.8vw, 10px);
  align-items: baseline;
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
}

.oled-intro .sec04__footLabel {
  font-weight: 700;
  color: #000;
  flex-shrink: 0;
}

.oled-intro .sec04__footText {
  font-weight: 400;
  color: #000;
  flex: 1;
}

@media (max-width: 991.98px) {
  .oled-intro .sec04__diagram {
    padding: clamp(16px, 2.5vw, 32px) 0;
  }
}

@media (max-width: 767.98px) {
  .oled-intro .sec04__content {
    gap: clamp(15px, 2vw, 28px);
  }
  
  .oled-intro .sec04__diagram {
    padding: clamp(12px, 2vw, 24px) 0;
  }
  
  .oled-intro .sec04__diagramImg {
    max-width: 100%;
  }
  
  .oled-intro .sec04__footItem {
    flex-direction: column;
    gap: clamp(4px, 0.6vw, 6px);
  }
}

.oled-intro .sec08 .benefit-grid {
  margin-top:clamp(20px, 4vw, 60px);
  flex-direction: column;
}
.oled-intro .sec08 .benefit-item {
  width:100%;
}
.oled-intro .sec08 .benefit-item__title {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #000;
  line-height: 1.4;
  margin-bottom: clamp(5px, 1vw, 10px);
}
.oled-intro .sec08 .benefit-item__circle-text {
  display:flex;
  align-items: center;
  justify-content: center;
}
.oled-intro .benefit-item__circle-text img {
  width:70%;
  height:auto;
  object-fit: contain;
}
@media (max-width: 575.98px) {
  .oled-intro .sec08 .benefit-grid {
    gap:15px;
  }
  .oled-intro .sec08 .benefit-item {
    gap:10px;
  }
	.oled-intro .benefit-item__circle {
    width:clamp(100px, 16vw, 180px);
    height:clamp(100px, 16vw, 180px);
    border-radius:50%;
  }
  .oled-intro .benefit-item__circle::before {
    display:block;
  }
}


/* ══════════════════════════════════════════════════════════════════════════
   oled-system 페이지: OLED 조직도
   ══════════════════════════════════════════════════════════════════════════ */

.oled-system .sec02 {
  padding: clamp(40px, 5vw, 60px) 0;
}

.oled-system .orgChart {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* 상단: 주관기관 + 총괄운영위원회 */
.oled-system .orgChart__top {
  display: flex;
  flex-direction: column;
  gap: clamp(5px, 1vw, 10px);
  align-items: center;
  margin-bottom: clamp(30px, 6vw, 80px);
  position:relative;
  z-index:10;
}

.oled-system .orgChart__node {
  width: 100%;
  max-width: clamp(120px, 28vw, 378px);
  background: #fff;
  border: 1px solid var(--color-secondary05);
  border-radius: 8px;
  overflow: hidden;
}

.oled-system .orgChart__nodeHead {
  padding: clamp(12px, 1.5vw, 16px) clamp(16px, 2vw, 24px);
  text-align: center;
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
}

.oled-system .orgChart__nodeHead.is-navy {
  background: var(--color-secondary05);
}

.oled-system .orgChart__nodeBody {
  padding: clamp(15px, 2vw, 30px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.oled-system .orgChart__nodeBody--center {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 600;
  color: #000;
  text-align: center;
  line-height: 1.4;
}

.oled-system .orgChart__kdiaLogo {
  max-width: clamp(180px, 25vw, 280px);
  height: auto;
  object-fit: contain;
}

/* 하단 트랙 영역 */
.oled-system .orgChart__tree {
  position: relative;
}

.oled-system .orgChart__branch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  position: relative;
}

/* 상단 분기 연결선 */
.oled-system .orgChart__branch::before {
  content: '';
  position: absolute;
  top: -40px;
  left: 15.7%;
  right:15.7%;
  height: 1px;
  background: #d1d5db;
}

/* 트랙 */
.oled-system .orgChart__track {
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.5vw, 16px);
  position:relative;
}

.oled-system .orgChart__trackHead {
  padding: clamp(12px, 1.5vw, 16px) clamp(16px, 2vw, 20px);
  text-align: center;
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #fff;
  border-radius: 6px;
  margin: 0;
  line-height: 1.4;
  position:relative;
  z-index:10;
}

.oled-system .orgChart__track.is-blue .orgChart__trackHead {
  background: var(--color-secondary01);
}

.oled-system .orgChart__track.is-cyan .orgChart__trackHead {
  background: var(--color-secondary02);
}

.oled-system .orgChart__track.is-purple .orgChart__trackHead {
  background: var(--color-primary);
}

.oled-system .orgChart__track.is-blue::before,
.oled-system .orgChart__track.is-cyan::before,
.oled-system .orgChart__track.is-purple::before {
  content: '';
  position: absolute;
  top: -40px;
  left: 50%;
  width:1px;
  height: 100%;
  background: #d1d5db;
}
.oled-system .orgChart__track.is-cyan::before {
  top:-80px;
}
.oled-system .orgChart__track.is-purple::before {
  height:60%;
}

/* 조직 카드 */
.oled-system .orgCard {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 6px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  position:relative;
  z-index:10;
}

.oled-system .orgCard__logo {
  padding: clamp(20px, 2.5vw, 32px) clamp(16px, 2vw, 20px);
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: clamp(80px, 10vw, 120px);
}

.oled-system .orgCard__logo img {
  max-width: 100%;
  max-height: clamp(40px, 6vw, 90px);
  width: auto;
  height: auto;
  object-fit: contain;
}
.oled-system .orgCard__logo .logo_sch {
  max-height:clamp(30px, 3vw, 40px);
}

.oled-system .orgCard__name {
  padding: clamp(10px, 1.2vw, 14px) clamp(12px, 1.5vw, 16px);
  text-align: center;
  font-size: clamp(14px, 1.6vw, 17px);
  font-weight: 600;
  color: #fff;
  line-height: 1.4;
}

.oled-system .orgChart__track.is-blue .orgCard__name {
  background: var(--color-secondary01);
}

.oled-system .orgChart__track.is-cyan .orgCard__name {
  background: var(--color-secondary02);
}

.oled-system .orgChart__track.is-purple .orgCard__name {
  background: var(--color-primary);
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .oled-system .orgChart__branch::before {
    top: -3vw;
  }
  .oled-system .orgChart__track.is-blue::before,
  .oled-system .orgChart__track.is-cyan::before,
  .oled-system .orgChart__track.is-purple::before {
    top: -3vw;
  }
  .oled-system .orgChart__track.is-cyan::before {
    top:-6vw;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .oled-system .sec02 {
    padding: 0;
  }
  .oled-system .orgChart__branch {
    grid-template-columns: 1fr;
    gap: clamp(20px, 2.5vw, 28px);
  }
  
  .oled-system .orgChart__track:last-child {
    max-width: 100%;
  }
  .oled-system .orgChart__node {
    max-width:100%;
  }
  .oled-system .orgChart__top {
    margin-bottom:20px;
  }
  
  .oled-system .orgChart__branch::before {
    display: none;
  }
  .oled-system .orgChart__track.is-blue::before,
  .oled-system .orgChart__track.is-cyan::before,
  .oled-system .orgChart__track.is-purple::before {
    top: -20px;
    height:100%;
  }
  .oled-system .orgChart__track.is-cyan::before {
    top:-6vw;
  }
  .oled-system .orgCard__logo {
    padding:15px;
  }
}



.univ-wrap .university-tab__item {
  width:calc(100% / 4);
  flex:none;
  border-bottom:1px solid #ddd;
}
.univ-wrap .university-tab__item:nth-child(4n):after{
  display:none;
}
.univ-wrap .university-tab__item:nth-child(n+5) {
  border-bottom:0;
}

/* ===================================
   책임교수 섹션 (공통 컴포넌트)
   =================================== */
.univ-wrap .univ-prof {
  margin-top: clamp(40px, 6vw, 80px);
  margin-bottom: clamp(40px, 6vw, 80px);
}

.univ-wrap .section-title {
  margin-bottom: clamp(20px, 3vw, 40px);
}

.univ-wrap .univ-prof__grid {
  display: grid;
  grid-template-columns: clamp(200px, 20vw, 300px) 1fr;
  gap: clamp(30px, 4vw, 60px);
  align-items: start;
}

.univ-wrap .univ-prof__photo {
  width: 100%;
  background: #f8f9fa;
  border-radius: clamp(12px, 1.5vw, 20px);
  overflow: hidden;
}

.univ-wrap .univ-prof__img {
  width: 100%;
  height: auto;
  display: block;
  object-fit: cover;
  aspect-ratio: 3/4;
}

.univ-wrap .univ-prof__content {
  position: relative;
  padding:clamp(20px, 2.5vw, 30px) clamp(15px, 2vw, 20px) 0;
  border-top:2px solid var(--color-secondary01);
}

.univ-wrap .univ-prof__h3 {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #000;
  margin-bottom: clamp(10px, 1.5vw, 20px);
  line-height: 1.4;
}

.univ-wrap .univ-prof__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.univ-wrap .univ-prof__item {
  position: relative;
  padding-left: clamp(15px, 2vw, 20px);
  margin-bottom:5px;
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
}

.univ-wrap .univ-prof__item::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0;
  color: #000;
  font-weight: 700;
  font-size: clamp(12px, 1.4vw, 16px);
}

.univ-wrap .univ-prof__item:last-child {
  margin-bottom: 0;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .univ-wrap .univ-prof__grid {
    grid-template-columns: clamp(180px, 22vw, 240px) 1fr;
    gap: clamp(24px, 3.5vw, 40px);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .univ-wrap .univ-prof__grid {
    grid-template-columns: 1fr;
  }
  .univ-wrap .univ-prof__photo {
    max-width: 280px;
    margin: 0 auto;
  }
}

@media (max-width: 575.98px) {
	.univ-wrap .univ-prof__photo {
    max-width: 160px;
  }
  .univ-wrap .univ-prof__content {
    padding:20px 0 0;
  }
  .univ-wrap .univ-prof__item {
    margin-bottom:0;
  }
}

/* ===================================
   책임교수 인사말 섹션 (공통 컴포넌트)
   =================================== */
.univ-wrap .sec02 {
  padding: clamp(40px, 6vw, 80px) 0;
  position:relative;
}
.univ-wrap .sec02:before {
  content:"";
  display:block;
  position:absolute;
  width:200%;
  height:100%;
  left:50%;
  transform:translateX(-50%);
  top:0;
  background:#f8f8f8;
}
.univ-wrap .univ-greet {
  position:relative;
  z-index:1;
}
.univ-wrap .univ-greet .section-title {
  margin-bottom:clamp(15px, 2vw, 30px);
}

.univ-wrap .univ-greet__body {
  margin: 0 auto;
}

.univ-wrap .univ-greet__p {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.8;
  color: #000;
  margin-bottom: clamp(15px, 2vw, 30px);
  word-break: keep-all;
  text-align: justify;
}

.univ-wrap .univ-greet__p:last-child {
  margin-bottom: 0;
}

.univ-wrap .univ-greet__title {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01, #0053a2);
  margin-bottom: clamp(5px, 1vw, 10px);
}
.univ-wrap .univ-greet__list {
  list-style: none;
  padding: 0;
  margin: 0;
  gap:5px;
  display:flex;
  flex-direction: column;
}
.univ-wrap .univ-greet__item {
  position: relative;
  padding-left: clamp(20px, 2vw, 25px);
  line-height: 1.6;
  color: #000;
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 400;
}
.univ-wrap .univ-greet__item::before {
  content: "\e92c";
  font-family: 'xeicon';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-secondary01);
}

.oled-univ .sec04 .univ-greet__p,
.oled-univ .sec06 .univ-greet__p {
  margin-bottom:5px;
}

.oled-univ .sec06 .univ-greet__desc {
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #777;
  margin-bottom: 0;
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .univ-wrap .univ-greet__p {
    line-height: 1.6;
    text-align: left;
  }
}

/* ===================================
   커리큘럼 맵 섹션 (OLED 전용)
   =================================== */
.oled-univ .sec03 {
  margin-top: clamp(40px, 6vw, 80px);
  margin-bottom: clamp(40px, 6vw, 80px);
}

.oled-univ .oled-map__head {
  margin-bottom: clamp(10px, 1.5vw, 20px);
}

.oled-univ .oled-map__titleWrap {
  margin-bottom: clamp(20px, 3vw, 30px);
}

.oled-univ .oled-map__subtit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: var(--color-secondary01, #0053a2);
  margin-bottom: clamp(5px, 1vw, 10px);
}

.oled-univ .system-org__list {
  gap:5px;
}

.oled-univ .oled-map__legend {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.oled-univ .oled-map__legendItem {
  display: inline-block;
  padding: clamp(4px, 0.6vw, 6px) clamp(15px, 2vw, 20px);
  border-radius: 6px;
  font-size: clamp(12px, 1.4vw, 14px);
  font-weight: 600;
  color: #fff;
}

.oled-univ .oled-map__legendItem.is-normal {
  background: #ddd;
  color:#000;
}

.oled-univ .oled-map__legendItem.is-new {
  background: var(--color-secondary02);
}

.oled-univ .oled-map__legendItem.is-improve {
  background: var(--color-secondary04);
}

.oled-univ .oled-map__legendItem.is-fusion {
  background: var(--color-primary);
}

.oled-univ .oled-map__scroll {
  -webkit-overflow-scrolling: touch;
}

.oled-univ .oled-map__table {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  gap:6px;
}

.oled-univ .oled-map__topHead {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap:6px;
}
.oled-univ .oled-map__body {
  display: grid;
  grid-template-columns: 1fr 100px;
  gap:6px;
}
.oled-univ .oled-map__bodyContent {
  display: grid;
  gap:6px;
}
.oled-univ .oled-map__row {
  display: grid;
  grid-template-columns: 180px 1fr;
  gap:6px;
}

.oled-univ .oled-map__col--main {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap:6px;
}
.oled-univ .oled-grid-1 {
  grid-template-columns: repeat(1, 1fr);
}
.oled-univ .oled-map__col--left,
.oled-univ .oled-map__col--right {
  background: var(--color-secondary01);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(12px, 1.3vw, 15px);
  font-weight: 400;
  text-align: center;
  padding: clamp(10px, 1.5vw, 15px) 10px;
  line-height: 1.4;
  border-radius: 6px;
  height:100%;
}

.oled-univ .oled-map__chip {
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: clamp(12px, 1.3vw, 15px);
  font-weight: 400;
  text-align: center;
  padding: clamp(10px, 1.5vw, 15px) 10px;
  line-height: 1.4;
  border-radius: 6px;
  height:100%;
  word-break: break-all;
}
.oled-univ .oled-map__body .oled-map__chip {
  font-size: clamp(12px, 1.3vw, 15px);
  font-weight:400;
}

.oled-univ .is-black {
  background: #000;
  color: #fff;
}

.oled-univ .is-normal {
  background: #ddd;
  color:#000;
}

.oled-univ .is-new {
  background: var(--color-secondary02);
}

.oled-univ .is-improve {
  background: var(--color-secondary04);
}

.oled-univ .is-fusion {
  background: var(--color-primary);
}

.oled-univ .is-navy {
  background: var(--color-secondary05);
  color: #fff;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .oled-univ .oled-map__table {
    display:grid;
    grid-template-columns: 80px 1fr;
    gap:6px;
  }
  .oled-univ .oled-map__topHead,
  .oled-univ .oled-map__row {
    grid-template-columns: 1fr;
    grid-template-rows: 40px 1fr;
  }
  .oled-univ .oled-map__body {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr 40px;
  }
  .oled-univ .oled-map__col--main {
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-univ .oled-grid-1 {
    grid-template-columns: repeat(1, 1fr);
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .oled-univ .oled-map__legend {
    justify-content: flex-start;
  }
  .oled-univ .oled-map__table {
    grid-template-columns: 60px 1fr;
    gap:4px;
  }
  .oled-univ .oled-map__topHead,
  .oled-univ .oled-map__row {
    grid-template-rows: 30px 1fr;
    gap:4px;
  }
  .oled-univ .oled-map__body {
    grid-template-rows: 1fr 30px;
    gap:4px;
  }
  .oled-univ .oled-map__bodyContent {
    gap:4px;
  }
  .oled-univ .oled-map__col--main {
    grid-template-columns: repeat(2, 1fr);
    gap:4px;
  }
  .oled-univ .oled-grid-1 {
    grid-template-columns: repeat(1, 1fr);
  }
}

/* ===================================
   연구실 소개 섹션 (OLED 전용, table 기반)
   =================================== */
.oled-univ .sec04,
.oled-univ .sec05,
.oled-univ .sec06 {
  margin-bottom: clamp(40px, 6vw, 80px);
}

.oled-univ .oled-lab__table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #ddd;
  border-top:2px solid var(--color-secondary01);
}

.oled-univ .oled-lab__table th,
.oled-univ .oled-lab__table td {
  border: 1px solid #e8e8e8;
  vertical-align: middle;
}

.oled-univ .oled-lab__table tr.bg-gray th,
.oled-univ .oled-lab__table tr.bg-gray td {
  background: #f8f8f8;
}

.oled-univ .oled-lab__num {
  width: clamp(80px, 10vw, 120px);
  min-width: 80px;
  font-size: clamp(1.4px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  padding: clamp(20px, 2.5vw, 30px);
  text-align: center;
  border-right: 1px solid #ddd;
}

.oled-univ .oled-lab__th {
  width: clamp(100px, 12vw, 140px);
  min-width: 100px;
  font-size: clamp(1.4px, 1.6vw, 18px);
  font-weight: 400;
  color: #000;
  padding: clamp(10px, 1.5vw, 24px) clamp(15px, 2vw, 30px);
  text-align: center;
  line-height: 1.4;
  border-right: 1px solid #e8e8e8;
}

.oled-univ .oled-lab__td {
  padding: clamp(10px, 1.5vw, 24px) clamp(15px, 2vw, 30px);
  font-size: clamp(1.4px, 1.6vw, 18px);
  line-height: 1.7;
  color: #000;
}

.oled-univ .oled-lab__key {
  font-size: clamp(1.4px, 1.6vw, 18px);
  font-weight: 700;
  color: var(--color-secondary01, #0053a2);
  margin-bottom: 5px;
}

.oled-univ .oled-lab__bullets {
  list-style: none;
  padding: 0;
  margin: 0;
}

.oled-univ .oled-lab__bullets li {
  position: relative;
  padding-left: clamp(16px, 2vw, 20px);
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #000;
}

.oled-univ .oled-lab__bullets li::before {
  content: '•';
  position: absolute;
  left: 0;
  top: 0;
  color: #666;
  font-weight: 700;
}

.oled-univ .oled-lab__bullets li:last-child {
  margin-bottom: 0;
}

.oled-univ .oled-lab__bullets ol {
  margin:5px 0 10px;
}
.oled-univ .oled-lab__bullets ol >li {
  position: relative;
  padding-left: clamp(16px, 2vw, 20px);
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #000;
}

.oled-univ .oled-lab__bullets ol > li::before {
  content: "\e92c";
  font-family: 'xeicon';
  position: absolute;
  left: 0;
  top: 0;
  color: var(--color-secondary01);
  font-weight: 400;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .oled-univ .oled-lab__key,
  .oled-univ .oled-lab__num,
  .oled-univ .oled-lab__th,
  .oled-univ .oled-lab__td {
    font-size: 14px;
  }
  .oled-univ .oled-lab__bullets li {
    font-size: 14px;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .oled-univ .oled-lab__table,
  .oled-univ .oled-lab__table tbody,
  .oled-univ .oled-lab__table tr,
  .oled-univ .oled-lab__table th,
  .oled-univ .oled-lab__table td {
    display:block;
    width:100%;
  }
  .oled-univ .oled-lab__table th,
  .oled-univ .oled-lab__table td {
    border:0;
    border-bottom:1px solid #ddd;
    text-align:left;
  }
  .oled-univ .oled-lab__table th {
    font-weight:700;
  }
  .oled-univ .oled-lab__table .oled-lab__num {
    display:none;
  }
}

/* ===================================
   주요 협업기업 섹션 (OLED 전용)
   =================================== */
.oled-univ .sec07 .coop__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.oled-univ .sec07 .coop__card {
  background: #fff;
  border: 1px solid #e8e8e8;
  border-radius: 10px;
  padding: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap:5px;
}

.oled-univ .sec07 .coop__logo {
  max-width: 80%;
  width: auto;
  height: auto;
  max-height: clamp(60px, 8vw, 90px);
  object-fit: contain;
}

.oled-univ .sec07 .coop__name {
  font-size: clamp(14px, 1.4vw, 16px);
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.4;
}

.oled-univ .sec07 .coop__etc {
  font-size: clamp(14px, 1.4vw, 16px);
  font-weight: 400;
  color: #000;
  line-height: 1.4;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .oled-univ .sec07 .coop__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 6px;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .oled-univ .sec07 .coop__grid {
    grid-template-columns: 1fr;
  }

  .oled-univ .sec07 .coop__card {
    padding:15px;
    min-height: clamp(80px, 10vw, 120px);
  }
  .oled-univ .sec07 .coop__logo {
    max-width: 60%;
  }
}



/* ===================================
   (무기발광 전용)
   =================================== */

/* 섹션 전체 레이아웃 */
.led-intro .sec08 {
  margin-bottom:clamp(40px, 6vw, 80px);
}

.led-intro .sec08 .section-title {
  margin-bottom: clamp(20px, 3vw, 40px);
}

/* 그리드 컨테이너 */
.led-intro .sec08__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(15px, 2vw, 30px);
  margin: 0 auto;
}

/* 카드 아이템 */
.led-intro .sec08__item {
  background: #f7f7f7;
  padding: clamp(30px, 4vw, 40px) clamp(20px, 3vw, 30px);
  text-align: center;
  position: relative;
  border-radius: 8px;
  min-height: 500px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* 아이콘 영역 */
.led-intro .sec08__iconWrap {
  margin-bottom: 30px;
}

.led-intro .sec08__iconRing {
  width: clamp(140px, 16vw, 200px);
  height: clamp(140px, 16vw, 200px);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative;
  box-shadow: 0 0 0 8px rgba(255, 255, 255, 0.3);
}
.led-intro .sec08__iconRing:before {
  content: '';
  position: absolute;
  inset:0;
  border-radius: 50%;
  background:linear-gradient(135deg, rgba(255, 255, 255, 0.4), rgba(255, 255, 255, 0.4));
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  padding: clamp(10px, 1.4vw, 16px);
}
/* 각 카드별 아이콘 배경 색상 */
.led-intro .sec08__item:nth-child(1) .sec08__iconRing {
  background: var(--color-secondary01);
}

.led-intro .sec08__item:nth-child(2) .sec08__iconRing {
  background: var(--color-secondary02);
}

.led-intro .sec08__item:nth-child(3) .sec08__iconRing {
  background: var(--color-primary);
}

/* 아이콘 placeholder */
.led-intro .sec08__icon {
  width: clamp(20px, 3vw, 40px);
  height: clamp(20px, 3vw, 40px);
  margin-bottom: 10px;
  opacity: 0.9;
}

/* 원형 내부 텍스트 */
.led-intro .sec08__iconTxt {
  color: #fff;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 700;
  line-height: 1.3;
  margin: 0;
}

.led-intro .sec08__content {
  width:100%;
}
/* 제목 */
.led-intro .sec08__tit {
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #000;
  margin-bottom: clamp(10px, 1.5vw, 24px);
  line-height: 1.4;
}

/* 리스트 */
.led-intro .sec08__list {
  list-style: none;
  padding: 0;
  margin: 0;
  text-align: left;
  width: 100%;
}

.led-intro .sec08__list li {
  position: relative;
  padding-left: clamp(14px, 1.6vw, 18px);
  margin-bottom: clamp(10px, 1.4vw, 12px);
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
}

.led-intro .sec08__list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: #000;
  font-weight: 700;
}

.led-intro .sec08__list li:last-child {
  margin-bottom: 0;
}

/* 강조 텍스트 (파란색 화살표 라인) */
.led-intro .sec08__em {
  color: #000;
  font-weight: 700;
}

.led-intro .sec08__em::before {
  color: #000;
}

/* 반응형: 태블릿 (991.98px 이하) */
@media (max-width: 991.98px) {
  .led-intro .sec08__grid {
    grid-template-columns: 1fr;
  }
  .led-intro .sec08__item {
    flex-direction: row;
    padding: 30px 20px;
    min-height: auto;
    gap:20px;
  }
  .led-intro .sec08__iconWrap {
    margin-bottom:0;
  }
  .led-intro .sec08__tit {
    text-align: left;
  }
  .led-intro .sec08__list li {
    margin-bottom:0;
  }
  
  .led-intro .sec08__list li br {
    display: none;
  }
}

/* 반응형: 모바일 (767.98px 이하) */
@media (max-width: 575.98px) {
  .led-intro .sec08__grid {
    gap:10px;
  }
  .led-intro .sec08__item {
    flex-direction: column;
    padding: 30px 20px;
  }
  .led-intro .sec08__iconRing {
    width:120px;
    height:120px;
  }
  .led-intro .sec08__tit {
    text-align: center;
  }
}

.led-intro .sec10 {
  margin-bottom:0;
}
.led-intro .sec10__list {
  position:relative;
  width:100%;
  max-width:1050px;
  margin:clamp(20px, 3vw, 40px) auto 0;
}
.led-intro .sec10__list li {
  position:relative;
  padding-left: clamp(14px, 1.6vw, 18px);
  margin-bottom: clamp(10px, 1.4vw, 12px);
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.6;
  color: #000;
}
.led-intro .sec10__list li::before {
  content: '•';
  position: absolute;
  left: 0;
  color: #000;
  font-weight: 700;
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.4;
}

/* ========================================
   SEC10: 대학 리스트
   ======================================== */
.led-intro .sec10__univList {
  margin-top: clamp(2px, 2vw, 30px);
  max-width: 1050px;
  margin-left: auto;
  margin-right: auto;
}

.led-intro .sec10__univItem {
  display: flex;
  align-items: flex-start;
  gap: clamp(24px, 3vw, 40px);
  padding: clamp(20px, 3vw, 30px) 0;
  border-top: 1px solid #E5E5E5;
}

.led-intro .sec10__univItem:first-child {
  border-top: none;
  padding-top: 0;
}

.led-intro .sec10__logoBox {
  flex-shrink: 0;
  width: clamp(180px, 22vw, 260px);
  height: clamp(68px, 16vw, 88px);
  background: #fff;
  border: 1px solid #E5E5E5;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

.led-intro .sec10__logoImg {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.led-intro .sec10__info {
  flex: 1;
  min-width: 0;
}

.led-intro .sec10__name {
  font-size: clamp(16px, 1.8vw, 18px);
  font-weight: 700;
  color: var(--color-secondary01);
  margin-bottom: 5px;
  line-height: 1.4;
}

.led-intro .sec10__desc {
  font-size: clamp(14px, 1.6vw, 16px);
  line-height: 1.4;
  color: #000;
  margin: 0;
}

/* 반응형: 모바일 (767.98px 이하) */
@media (max-width: 575.98px) {
  .led-intro .sec10__univItem {
    flex-direction: column;
    gap:10px;
  }
  .led-intro .sec10__logoBox {
    width:100%;
    height:auto;
  }
}

/* ========================================
   LED SYSTEM SEC02: 추진체계 조직도
   ======================================== */
.led-system .sec02 {
  padding: clamp(40px, 5vw, 60px) 0;
}

.led-system .orgChart {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}

/* 상단: 주관기관 + 총괄운영위원회 + 평가위원회 */
.led-system .orgChart__top {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1.2vw, 12px);
  align-items: center;
  margin-bottom: clamp(30px, 6vw, 80px);
  position: relative;
  z-index: 10;
}

.led-system .orgChart__node {
  width: 100%;
  max-width: clamp(120px, 28vw, 378px);
  background: #fff;
  border: 1px solid var(--color-secondary05);
  border-radius: 8px;
  overflow: hidden;
}

.led-system .orgChart__nodeHead {
  padding: clamp(12px, 1.5vw, 16px) clamp(16px, 2vw, 24px);
  text-align: center;
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
}

.led-system .orgChart__nodeHead.is-navy {
  background: var(--color-secondary05);
}

.led-system .orgChart__nodeBody {
  padding: clamp(15px, 2vw, 30px);
  display: flex;
  align-items: center;
  justify-content: center;
}

.led-system .orgChart__nodeBody--center {
  font-size: clamp(14px, 1.6vw, 18px);
  font-weight: 600;
  color: #000;
  text-align: center;
  line-height: 1.5;
}

.led-system .orgChart__kdiaLogo {
  max-width: clamp(180px, 25vw, 280px);
  height: auto;
  object-fit: contain;
}

/* 하단 트랙 영역 */
.led-system .orgChart__tree {
  position: relative;
}

.led-system .orgChart__branch {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(20px, 2.5vw, 32px);
  position: relative;
}

/* 트랙 */
.led-system .orgChart__track {
  display: flex;
  flex-direction: column;
  gap: clamp(8px, 1vw, 10px);
  position: relative;
  height:100%;
}

.led-system .orgChart__trackHead {
  padding: clamp(12px, 1.5vw, 16px) clamp(16px, 2vw, 20px);
  text-align: center;
  font-size: clamp(16px, 1.8vw, 20px);
  font-weight: 700;
  color: #fff;
  border-radius: 8px;
  line-height: 1.4;
  position: relative;
  z-index: 10;
  margin-bottom:0;
}

.led-system .orgChart__track.is-blue .orgChart__trackHead {
  background: var(--color-secondary01);
}

.led-system .orgChart__track.is-cyan .orgChart__trackHead {
  background: var(--color-secondary02);
}

.led-system .orgChart__track.is-purple .orgChart__trackHead {
  background: var(--color-primary);
}

/* 참여대학 카드 */
.led-system .orgCard {
  background: #fff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  overflow: hidden;
  position:relative;
  z-index:10;
}

.led-system .orgCard--univ {
  display: flex;
  flex-direction: column;
}

.led-system .orgCard__head {
  padding: clamp(10px, 1.2vw, 14px) clamp(14px, 1.8vw, 18px);
  text-align: center;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 600;
  color: #fff;
  line-height: 1.4;
}

.led-system .orgChart__track.is-blue .orgCard__head {
  background: var(--color-secondary01);
}

.led-system .orgChart__track.is-cyan .orgCard__head {
  background: var(--color-secondary02);
}

.led-system .orgChart__track.is-purple .orgCard__head {
  background: var(--color-primary);
}

.led-system .orgCard__logo {
  padding: clamp(20px, 2.5vw, 30px);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  min-height: clamp(100px, 12vw, 140px);
}

.led-system .orgCard__logo img {
  max-width: clamp(120px, 16vw, 180px);
  height: auto;
  object-fit: contain;
}

/* 위원회/기업 박스 */
.led-system .orgBox {
  background: #fff;
  border: 1px solid #d1d5db;
  border-radius: 8px;
  padding: clamp(14px, 1.8vw, 20px) clamp(16px, 2vw, 24px);
  text-align: center;
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  color: #000;
  position:relative;
  z-index:10;
}

.led-system .orgBox--committee {
  font-weight: 600;
}

.led-system .orgBox--companies {
  padding: 0;
}

.led-system .orgBox__head {
  padding: clamp(10px, 1.2vw, 14px) clamp(14px, 1.8vw, 18px);
  text-align: center;
  font-size: clamp(14px, 1.6vw, 16px);
  font-weight: 600;
  color: #fff;
  border-radius: 8px 8px 0 0;
}

.led-system .orgChart__track.is-blue .orgBox__head {
  background: var(--color-secondary01);
}

.led-system .orgChart__track.is-cyan .orgBox__head {
  background: var(--color-secondary02);
}

.led-system .orgChart__track.is-purple .orgBox__head {
  background: var(--color-primary);
}

.led-system .orgBox__body {
  padding: clamp(14px, 1.8vw, 20px) clamp(16px, 2vw, 24px);
  font-size: clamp(12px, 1.4vw, 16px);
  line-height: 1.7;
  color: #333;
  text-align: center;
  height:clamp(140px, 1.4vw, 140px);
}
.led-system .orgChart__branch::before {
  content: '';
  position: absolute;
  top: -40px;
  left: 15.7%;
  right:15.7%;
  height: 1px;
  background: #d1d5db;
}
.led-system .orgChart__track.is-blue::before,
.led-system .orgChart__track.is-cyan::before,
.led-system .orgChart__track.is-purple::before {
  content: '';
  position: absolute;
  top: -40px;
  left: 50%;
  width:1px;
  height: 100%;
  background: #d1d5db;
}
.led-system .orgChart__track.is-cyan::before {
  top:-80px;
}

/* 반응형: TABLET */
@media (max-width: 991.98px) {
  .led-system .orgBox__body {
    height:auto;
  }
  .led-system .orgChart__branch::before {
    top: -3vw;
  }
  .led-system .orgChart__track.is-blue::before,
  .led-system .orgChart__track.is-cyan::before,
  .led-system .orgChart__track.is-purple::before {
    top: -3vw;
  }
  .led-system .orgChart__track.is-cyan::before {
    top:-6vw;
  }
}

/* 반응형: MOBILE */
@media (max-width: 767.98px) {
  .led-system .sec02 {
    padding: 30px 0;
  }

  .led-system .orgChart__branch {
    grid-template-columns: 1fr;
    gap: clamp(20px, 2.5vw, 28px);
  }

  .led-system .orgChart__track:last-child {
    max-width: 100%;
  }

  .led-system .orgChart__node {
    max-width: 100%;
  }

  .led-system .orgChart__top {
    margin-bottom: 20px;
  }
  .led-system .orgBox__body {
    height:auto;
  }
  .led-system .orgChart__branch::before {
    display: none;
  }
  .led-system .orgChart__track.is-blue::before,
  .led-system .orgChart__track.is-cyan::before,
  .led-system .orgChart__track.is-purple::before {
    top: -40px;
    height:100%;
  }
  .led-system .orgChart__track.is-cyan::before {
    top:-6vw;
  }
}


/* ========================================
   LED UNIV SEC01: 참여대학
   ======================================== */
.led-univ .university-tab__item {
  width:calc(100% / 3);
  border-bottom:0;
}



/* ========================================
   LED UNIV SEC01: 참여대학
   ======================================== */

.led-erica .oled-map__chip.is-title {
  background: #fff;
  color: #000;
  font-weight:700;
}
.led-erica .oled-map__col--group {
  padding:6px;
  border:1px solid #ccc;
  border-radius: 6px;
}
.led-erica .oled-map__col--rowWrap {
  display: flex;
  flex-direction: column;
  gap:6px;
}
@media (max-width: 991.98px) {
	.led-erica .oled-map__col--group {
    padding:4px;
    grid-template-columns: repeat(5, 1fr);
  }
  .led-erica .oled-map__col--rowWrap {
    gap:4px;
  }
}
@media (max-width: 575.98px) {
	.led-erica .oled-map__col--group {
    grid-template-columns: 1fr;
  }
}



/* LED 중앙대학교 */
.led-cau .oled-map__col--main {
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 991.98px) {
  .led-cau .oled-map__col--main {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767.98px) {
  .led-cau .oled-map__col--main {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* LED 고려대학교 */
.led-korea .oled-map__col--main {
  grid-template-columns: repeat(4, 1fr);
}
.led-korea .oled-map__chip.is-title {
  background: #fff;
  color: #000;
  font-weight:700;
}
.led-korea .oled-map__col--group {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 50px 1fr;
  padding:6px;
  border:1px solid #ccc;
  border-radius: 6px;
}
.led-korea .oled-map__col--rowWrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap:6px;
}

@media (max-width: 991.98px) {
  .led-korea .oled-map__col--main {
    grid-template-columns: repeat(3, 1fr);
  }
  .led-korea .oled-map__col--group {
    grid-template-columns: 1fr;
    grid-template-rows: 40px 1fr;
  }
}
@media (max-width: 767.98px) {
  .led-korea .oled-map__col--main {
    grid-template-columns: repeat(2, 1fr);
  }
  .led-korea .oled-map__col--rowWrap {
    grid-template-columns: 1fr;
  }
  .led-korea .oled-map__col--rowWrap > .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .led-korea .oled-map__col--group > .oled-map__col--rowWrap {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* OLED 순향대학교 */
.oled-sch .oled-map__col--main {
  grid-template-columns: repeat(2, 1fr);
}
.oled-sch .oled-map__col--main > .oled-map__col--group {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap:6px;
}
.oled-sch .oled-map__col--main > .oled-map__col--row-9 {
  grid-template-rows: repeat(3, 1fr);
}
.oled-sch .oled-map__col--main > .oled-map__col--row-12 {
  grid-template-rows: repeat(4, 1fr);
}
@media (max-width: 991.98px) {
  .oled-sch .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .oled-sch .oled-map__col--main > .oled-map__col--group {
    gap:4px;
  }
  .oled-sch .oled-map__col--main > .oled-map__col--row-9,
  .oled-sch .oled-map__col--main > .oled-map__col--row-12 {
    grid-template-rows: 1fr;
  }
}
@media (max-width: 767.98px) {
	.oled-sch .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .oled-sch .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(2, 1fr);
    gap:4px;
  }
  .oled-sch .oled-map__col--main > .oled-map__col--row-9,
  .oled-sch .oled-map__col--main > .oled-map__col--row-12 {
    grid-template-rows: 1fr;
  }
}



/* OLED 한양대학교 */
.oled-hanyang .oled-map__col--main {
  grid-template-columns: repeat(2, 1fr);
}
.oled-hanyang .oled-map__col--main-col-1{
  grid-template-columns: 1fr;
}
.oled-hanyang .oled-map__col--main > .oled-map__col--group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap:6px;
}
.oled-hanyang .oled-map__col--main > .oled-map__col--row-9 {
  grid-template-rows: repeat(3, 1fr);
}
.oled-hanyang .oled-map__col--main > .oled-map__col--row-12 {
  grid-template-rows: repeat(4, 1fr);
}
@media (max-width: 991.98px) {
  .oled-hanyang .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .oled-hanyang .oled-map__col--main > .oled-map__col--group {
    gap:4px;
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-hanyang .oled-map__col--main > .oled-map__col--row-9,
  .oled-hanyang .oled-map__col--main > .oled-map__col--row-12 {
    grid-template-rows: 1fr;
  }
}
@media (max-width: 767.98px) {
  .oled-hanyang .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(2, 1fr);
    gap:4px;
  }
  .oled-hanyang .oled-map__col--main > .oled-map__col--row-9,
  .oled-hanyang .oled-map__col--main > .oled-map__col--row-12 {
    grid-template-rows: 1fr;
  }
}



/* OLED 단국대학교 */

.oled-dku .oled-map__col--main {
  grid-template-columns: repeat(4, 1fr);
}
.oled-dku .oled-map__col--main-col-1{
  grid-template-columns: 1fr;
}
.oled-dku .oled-map__col--main > .oled-map__col--group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap:6px;
}
.oled-dku .oled-map__col--main > .oled-map__col--row-12 {
  grid-template-rows: repeat(4, 1fr);
}
.oled-dku .oled-map__col--main > .oled-map__col--row-6 {
  grid-template-rows: repeat(2, 1fr);
}
.oled-dku .oled-map__body .oled-map__chip {
  font-size:clamp(12px, 1.3vw, 14px);
}
@media (max-width: 991.98px) {
  .oled-dku  .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .oled-dku .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-dku .oled-map__col--main > .oled-map__col--row-12,
  .oled-dku .oled-map__col--main > .oled-map__col--row-6 {
    grid-template-rows: 1fr;
  }
}
@media (max-width: 767.98px) {
  .oled-dku .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(2, 1fr);
    gap:4px;
  }
}


/* OLED 호서대학교 */
.oled-hoseo .oled-map__col--main {
  grid-template-columns: 1fr 1fr 1.5fr;
}
.oled-hoseo .oled-map__col--main-col-1{
  grid-template-columns: 1fr;
}
.oled-hoseo .oled-map__body .oled-map__chip {
  flex-direction: column;
  font-size:clamp(12px, 1.3vw, 14px);
}
.oled-hoseo .oled-map__col--main > .oled-map__col--group {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap:6px;
}
.oled-hoseo .oled-map__col--main > .oled-map__col-6 {
  grid-template-columns: repeat(3, 1fr);
}
.oled-hoseo .oled-map__col--main > .oled-map__col--row-4 {
  grid-template-rows: repeat(4, 1fr);
}

@media (max-width: 991.98px) {
	.oled-hoseo .oled-map__col--main {
    grid-template-columns: 1fr;
  }
  .oled-hoseo .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-hoseo .oled-map__col--main > .oled-map__col-6 {
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-hoseo .oled-map__col--main > .oled-map__col--row-4 {
    grid-template-rows: 1fr;
  }
  .oled-hoseo .oled-map__row-mo-12 .oled-map__col--group {
    grid-template-columns: 1fr;
  }
  .oled-hoseo .oled-map__body .oled-map__chip > br {
    display: none;
  }
}
@media (max-width: 767.98px) {
  .oled-hoseo .oled-map__col--main > .oled-map__col--group {
    grid-template-columns: repeat(2, 1fr);
    gap:4px;
  }
  .oled-hoseo .oled-map__col--main > .oled-map__col-6 {
    grid-template-columns: repeat(2, 1fr);
  }
  .oled-hoseo .oled-map__row-mo-12 .oled-map__col--group {
    grid-template-columns: 1fr;
  }
}


/* OLED 연세대학교 */
.oled-yousei .oled-map__row {
  grid-template-columns: 180px 1fr 1fr;
}
.oled-yousei .oled-map__col--main {
  grid-template-columns: repeat(2, 1fr);
}
.oled-yousei .oled-map__col--main-col-1{
  grid-template-columns: 1fr;
}
@media (max-width: 991.98px) {
	.oled-yousei .oled-map__row {
    grid-template-columns: 1fr;
  }
  .oled-yousei .oled-map__col--main {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (max-width: 767.98px) {
  .oled-yousei .oled-map__col--main {
    grid-template-columns: repeat(2, 1fr);
  }
}


/* OLED 한양대학교 ERICA */
.oled-erica .oled-map__row {
  grid-template-columns: 180px 1fr 1fr;
}
.oled-erica .oled-map__col--main {
  grid-template-columns: repeat(2, 1fr);
}
.oled-erica .oled-map__col--main-col-1{
  grid-template-columns: 1fr;
}
@media (max-width: 991.98px) {
	.oled-erica .oled-map__row {
    grid-template-columns: 1fr;
  }
  .oled-erica .oled-map__col--main {
    grid-template-columns: repeat(3, 1fr);
  }
  .oled-erica .oled-map__col--main-col-1{
    grid-template-columns: 1fr;
  }
}
@media (max-width: 767.98px) {
  .oled-erica .oled-map__col--main {
    grid-template-columns: repeat(2, 1fr);
  }
  .oled-erica .oled-map__col--main-col-1{
    grid-template-columns: 1fr;
  }
}



/*개인정보 처리방침 && 이용약관 && 이메일무단수집거부*/
#user_guide_sec .block_area{ margin-bottom:40px;}
#user_guide_sec .block_area:last-child{ margin-bottom:0;}
#user_guide_sec .block_area *,
#user_guide_sec *{ font-size:16px; font-weight:300; color:#444; }
#user_guide_sec b,
#user_guide_sec b > span,
#user_guide_sec .block_area strong { font-size:18px; font-weight:700; color:#000; display:block; margin:5px 0;}
#user_guide_sec .block_area ol{}
#user_guide_sec .block_area ol li{}
#user_guide_sec .block_area .tit{ display:block; margin-bottom:10px;  font-size:20px;  font-weight:600; color:#000;}
#user_guide_sec .block_area .tit2{ display:block; margin:10px 0; font-weight:600;}
#user_guide_sec .block_area .dep1{ counter-reset:dep1;}
#user_guide_sec .block_area .dep1 > li{ position:relative; padding-left:20px; }
#user_guide_sec .block_area .dep1 > li:before{ content:counter(dep1)". "; counter-increment:dep1; position:absolute; top:0; left:0;}
#user_guide_sec .block_area .dep2{ margin:5px 0; counter-reset:dep2;}
#user_guide_sec .block_area .dep2 > li{ position:relative; padding-left:20px; }
#user_guide_sec .block_area .dep2 > li:before{ content:counter(dep2)") "; counter-increment:dep2; position:absolute; top:0; left:0;}
#user_guide_sec .block_area .dep1 > li,
#user_guide_sec .block_area .dep2 > li{ margin-bottom:5px;}
#user_guide_sec .block_area .dep1 > li:last-child,
#user_guide_sec .block_area .dep2 > li:last-child{ margin-bottom:0;}
#user_guide_sec .block_area .table_area table{ margin:10px 0; width:100%; border-top:2px solid #000; border-left:1px solid #ddd; }
#user_guide_sec .block_area .table_area table th,
#user_guide_sec .block_area .table_area table td{ padding:15px; text-align: center; border-right:1px solid #ddd; border-bottom:1px solid #ddd;}
#user_guide_sec .block_area .table_area table th{ background:#f7f7f7; font-weight:700;}

@media all and (max-width:991.98px) {
  #user_guide_sec .block_area *, #user_guide_sec *{ font-size:14px;}
  #user_guide_sec .block_area{ margin-bottom:20px;}
	#user_guide_sec .block_area strong { font-size:14px;}
  #user_guide_sec .block_area .tit{ font-size:16px;}
  #user_guide_sec .block_area .tit2{ margin:5px 0;}
  #user_guide_sec br {display:block;}
}
