﻿@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/variable/pretendardvariable.min.css");

:root {
  --color-primary: #1d3557;
  /*
   * 브랜딩 팔레트(수정 시 아래 두 토큰만 갱신)
   * 컬러 1: #005eff  →  var(--branding-color-1)
   * 컬러 2: #8eff00  →  var(--branding-color-2)
   */
  --branding-color-1: #005eff;
  --branding-color-2: #8eff00;

  --color-brand-theme-blue: #1e40af;
  --color-accent: #4e89ff;
  --color-background: #f7f9fc;
  --color-surface: #ffffff;
  --color-text: #222222;
  --color-text-muted: #6b7280;
  --shadow-soft: 0 10px 30px rgba(15, 23, 42, 0.08);
  --radius-md: 12px;
  --radius-lg: 20px;
  --header-height: 91.08px; 
  --header-nav-gap: 1.8rem;
  --font-sans-variable: "Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, system-ui,
    "Apple SD Gothic Neo", "Noto Sans KR", "Segoe UI", sans-serif;
  --font-pretendard-static: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, "Apple SD Gothic Neo",
    "Noto Sans KR", "Segoe UI", sans-serif;
}

@font-face {
  font-family: "NanumBrushCustom";
  src: url("../assets/fonts/1.otf") format("opentype");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "TimesNewerRomanBold";
  src: url("../assets/fonts/TimesNewerRoman-Bold.otf") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  overflow-y: auto;
  scrollbar-gutter: auto;
  font-family: var(--font-sans-variable);
}

html,
body {
  margin: 0;
  padding: 0;
  height: 100%;
}


body {
  font-family: var(--font-sans-variable);
  color: var(--color-text);
  background-color: var(--color-background);
  line-height: 1.6;
  overflow: visible;
}


.home-main {
  min-height: 0;
}


.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

img {
  max-width: 100%;
  display: block;
}

a {
  color: inherit;
  text-decoration: none;
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

button,
input,
select,
textarea {
  font-family: inherit;
}

.container {
  width: 100%;
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 1.5rem;
}

.section {
  padding: 5rem 0;
}

.section-alt {
  background-color: #ffffff;
}

.section-header {
  text-align: center;
  margin-bottom: 3rem;
}

.section-header h2 {
  font-size: 2rem;
  margin-bottom: 0.75rem;
}

.section-header p {
  color: var(--color-text-muted);
  max-width: 560px;
  margin: 0 auto;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 1.5rem;
  border-radius: 999px;
  border: none;
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease,
    box-shadow 0.2s ease, transform 0.1s ease;
}

.btn-primary {
  background: linear-gradient(135deg, var(--color-accent), #2563eb);
  color: #ffffff;
  box-shadow: var(--shadow-soft);
}

.btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 40px rgba(37, 99, 235, 0.35);
}

.btn-secondary {
  background-color: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(148, 163, 184, 0.4);
  color: var(--color-primary);
}

.btn-secondary:hover {
  background-color: rgba(148, 163, 184, 0.08);
}

.btn-outline {
  background-color: transparent;
  border: 1px solid rgba(148, 163, 184, 0.8);
  color: var(--color-primary);
}

.btn-outline:hover {
  background-color: rgba(148, 163, 184, 0.08);
}

.btn.full-width {
  width: 100%;
}



.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--header-height);
  overflow: hidden;
  background-color: #000000;
  backdrop-filter: none;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.site-header .container {
  max-width: 1120px; 
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height);
  gap: 1.5rem;
}

.logo {
  display: inline-flex;
  align-items: center;
  height: 40px;
  width: 220px;
  flex: 0 0 220px;
  margin-left: -16px;
}

.logo img {
  height: 100%;
  width: 100%;
  display: block;
  object-fit: contain;
}

.main-nav {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  margin-left: 0.25rem;
}

.nav-menu {
  display: flex;
  gap: var(--header-nav-gap);
  align-items: center;
}

.nav-menu a {
  font-size: 0.75rem;
  color: #ffffff;
  padding: 0.25rem 0;
  position: relative;
  font-weight: 600;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans KR", "Apple SD Gothic Neo", Arial, sans-serif;
}

.nav-menu a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.25rem;
  width: 0;
  height: 2px;
  background: #ffffff;
  transition: none;
}

.nav-menu a:hover {
  color: #ffffff;
  text-decoration-color: #ffffff;
}

.nav-menu a:hover::after {
  width: 100%;
}

.nav-menu a.nav-current {
  color: #ffffff;
}

.nav-menu a.nav-current::after {
  width: 100%;
  background: #ffffff;
}

@media (min-width: 769px) {
  .header-inner {
    display: grid;
    grid-template-columns: 220px minmax(0, 1fr) 320px;
    gap: 1rem;
  }

  .logo {
    margin-left: 0;
    justify-content: flex-start;
  }

  .main-nav {
    min-width: 0;
    margin-left: 0;
  }

  .nav-menu {
    justify-content: flex-start;
    gap: var(--header-nav-gap);
  }

  .nav-menu li {
    flex: 0 0 auto;
    min-width: 0;
  }

  .nav-menu a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    white-space: nowrap;
  }

  .header-actions {
    width: 320px;
    flex: 0 0 320px;
  }
}


.header-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.header-actions-top {
  display: flex;
  gap: 0.75rem;
}

.header-actions-top .pill-cta-button {
  margin-top: 0.22rem;
}

.text-link-button {
  border: none;
  background: none;
  padding: 0;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  cursor: pointer;
}

.text-link-button:hover {
  color: var(--color-primary);
}

.header-auth-button {
  min-width: 110px;
  padding: 0.3rem 0.8rem;
  border-radius: 8px;
  border: 1px solid #ffffff;
  background-color: transparent;
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 600;
  cursor: pointer;
}

.header-auth-button:hover {
  background-color: rgba(255, 255, 255, 0.12);
  color: #ffffff;
  border-color: #ffffff;
}


.site-header .header-auth-button {
  display: none;
}

.header-actions-bottom {
  display: flex;
  gap: 0.5rem;
}

.pill-cta-button {
  border: none;
  background: none;
  color: #b8bcc8;
  padding: 0;
  border-radius: 0;
  font-size: 0.65rem;
  cursor: pointer;
  white-space: nowrap;
  font-weight: 600;
}

.pill-cta-badge {
  display: inline-flex;
  align-items: flex-start;
  justify-content: center;
  margin-left: 0.25rem;
  padding: 0.02rem 0.3rem 0.08rem;
  border-radius: 999px;
  background-color: #ffffff;
  color: #000000;
  font-size: 0.55rem;
  font-weight: 700;
  position: relative;
  top: 0.5px; 
  line-height: 1; 
}


.pill-cta-button[data-header-diagnosis] {
  color: #ffffff;
}

.pill-cta-button[data-header-diagnosis] .pill-cta-badge {
  background-color: transparent;
  border: 1px solid rgba(255, 255, 255, 0.9);
  color: #ffffff;
}

.pill-cta-button:hover {
  text-decoration: underline;
}

.pill-cta-button[data-gainge-campus]:hover {
  text-decoration-color: #c4c8d0;
  color: #d1d5db;
}

.pill-cta-button[data-header-diagnosis]:hover {
  text-decoration-color: #ffffff;
  color: #ffffff;
}


.header-actions-top .pill-cta-button + .pill-cta-button::before {
  content: "|";
  color: rgba(184, 188, 200, 0.65);
  margin: 0 0.2rem 0 0;
}

.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 4px;
  width: 24px;
  height: 24px;
  padding: 0;
  border: none;
  background: none;
  cursor: pointer;
}

.nav-toggle span {
  display: block;
  height: 2px;
  border-radius: 999px;
  background-color: #ffffff;
}



.main-gradient-wrap {
  min-height: 100%;
}

.hero-section {
  padding-top: calc(var(--header-height) + 0.000375rem); 
  padding-bottom: 4.5rem; 
  background: #000000;
}

.hero-main-media-wrap {
  padding-top: 2.2rem;
}

.hero-main-media {
  position: relative;
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
  border-radius: 10px;
  overflow: hidden;
  background: #111111;
}

.hero-main-media-image {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.hero-main-play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 74px;
  height: 74px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: rgba(0, 0, 0, 0.35);
  color: #ffffff;
  font-size: 1.85rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding-left: 4px;
}

.hero-main-play-btn:hover {
  background: rgba(0, 0, 0, 0.5);
}

.main-greeting-section {
  background: #000000;
  padding: 1.6rem 0 2rem;
}

.main-greeting-text {
  margin: 0;
  color: #ffffff;
  text-align: center;
  font-size: 1.1rem;
  font-weight: 600;
  line-height: 1.5;
}

.hero-inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0;
}


.home-hero-section.hero-section {
  --home-hero-ar-h: 6.94575;
  position: relative;
  overflow: hidden;
  background: #000000;
  box-sizing: border-box;
  width: 100%;
  aspect-ratio: 16 / var(--home-hero-ar-h);
  min-height: unset;
  display: flex;
  align-items: center;
  padding-top: 0;
  padding-bottom: clamp(1rem, 2.5vw, 2rem);
}

.home-hero-backdrop {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  background-color: #0b0f17;
}

.home-hero-section .home-hero-backdrop .consulting-group-photo-bg-main {
  background-size: calc(92% * var(--home-hero-ar-h) / 6) auto;
  background-position: center top;
}

.home-hero-photo-overlay.consulting-group-photo-overlay {
  z-index: 1;
}

.home-hero-dots {
  position: relative;
  z-index: 3;
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  margin-top: clamp(0rem, 0.15vw, 0.08rem);
  margin-bottom: clamp(2.1rem, 4.5vw, 3.35rem);
  gap: 0.54rem;
}

.home-hero-dot {
  display: block;
  box-sizing: border-box;
  width: 8px;
  height: 8px;
  min-width: 8px;
  min-height: 8px;
  padding: 0;
  margin: 0;
  flex: 0 0 8px;
  border: 0;
  border-radius: 50%;
  appearance: none;
  -webkit-appearance: none;
  aspect-ratio: 1 / 1;
  background: rgba(255, 255, 255, 0.45);
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.home-hero-dot[aria-selected="true"] {
  background: #ffffff;
}

.home-hero-dot:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.home-hero-container {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: calc(var(--header-height) + 2rem);
}

.home-hero-split {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 3fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: stretch;
  padding: 2rem 0 2.5rem;
  min-height: 0;
}

.home-hero-col--text {
  color: #ffffff;
  padding-left: clamp(0.5rem, 2vw, 1.5rem);
  padding-right: clamp(0.5rem, 2vw, 1.5rem);
  padding-top: clamp(1rem, 3.5vh, 2.25rem);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-end;
  width: 100%;
  height: 100%;
  min-height: 0;
  box-sizing: border-box;
}


.home-hero-text-stack {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0;
  width: min(100%, 640px);
  margin-left: auto;
  margin-right: 0;
  --home-hero-text-fs: clamp(0.92rem, 1.85vw, 1.12rem);
  transition: transform 0.45s ease;
  transform: scale(1);
  transform-origin: center center;
}

.home-hero-text-stack:hover {
  transform: scale(1.02);
}

.home-hero-text-box {
  position: relative;
  margin: 0;
  padding: 0.75rem 1rem;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 8px;
  color: #ffffff;
  font-size: calc(1.1 * var(--home-hero-text-fs));
  font-weight: 500;
  line-height: 1.58;
  text-align: left;
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.35);
}

.home-hero-text-box + .home-hero-text-box {
  margin-top: 0.75rem;
}

.home-hero-text-box--1 {
  z-index: 1;
  font-size: calc(1.1 * 1.4 * 1.05 * var(--home-hero-text-fs));
  white-space: nowrap;
}

.home-hero-text-box--body {
  font-size: calc(0.8 * 1.5 * 1.1 * 1.05 * var(--home-hero-text-fs));
  transform: translateX(clamp(1rem, 2.4vw, 1.85rem));
}

.home-hero-emphasized-head {
  font-size: 2.5em;
  font-weight: 700;
  line-height: 1.15;
}

@media (max-width: 768px) {
  .home-hero-section.hero-section {
    --home-hero-ar-h: 3.009825;
    aspect-ratio: 4 / var(--home-hero-ar-h);
  }

  .home-hero-section .home-hero-backdrop .consulting-group-photo-bg-main {
    background-size: cover;
    background-position: center top;
  }

  .home-hero-split {
    grid-template-columns: 1fr;
    min-height: 0;
    gap: 2rem;
    padding: 1.5rem 0 2rem;
  }

  .home-hero-col--text {
    padding-left: 0;
    padding-right: 0;
    padding-top: clamp(0.75rem, 2.5vh, 1.5rem);
    justify-content: flex-start;
    align-items: flex-start;
    text-align: left;
  }

  .home-hero-text-box--1 {
    white-space: normal;
  }

  .home-hero-dots {
    margin-top: 0;
    margin-bottom: 2.2rem;
  }

  .home-hero-dot {
    width: 8px;
    height: 8px;
    min-width: 8px;
    min-height: 8px;
    flex: 0 0 8px;
  }
}


.home-copy-section {
  background: #000000;
  color: #ffffff;
  padding: 0.45rem 0 3.81672rem;
}


.home-copy-section .container {
  max-width: 1000px;
}

.home-copy-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: calc(clamp(1.5rem, 4vw, 3rem) * 1.15);
  align-items: start;
  margin-top: clamp(4.368rem, 10.08vw, 7.728rem);
}

.home-copy-col-link {
  display: block;
  min-width: 0;
  text-align: center;
  transition: transform 0.45s ease, border-color 0.3s ease;
  transform: scale(1);
  transform-origin: center center;
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  outline-offset: 4px;
  box-sizing: border-box;
  border: 1px solid transparent;
  border-radius: 14px;
  padding: clamp(1.1rem, 2.8vw, 1.65rem) clamp(1rem, 2.2vw, 1.4rem);
}

.home-copy-col-link:visited {
  color: inherit;
}

.home-copy-col-link:hover {
  transform: scale(1.02);
  border-color: transparent;
}

.home-copy-col-link:focus-visible {
  outline: 2px solid var(--branding-color-2);
  outline-offset: 4px;
}

.home-copy-text {
  margin: 0;
  font-size: calc(0.9 * clamp(1rem, 1.9vw, 1.15rem));
  font-weight: 500;
  line-height: 1.65;
  color: rgba(255, 255, 255, 0.92);
}

/* 좌측 소개문만 105% 확대 (강조 수치는 기존 시각 크기 유지) */
.home-copy-text--left-intro {
  font-size: calc(0.9 * clamp(1rem, 1.9vw, 1.15rem) * 1.05);
  line-height: calc(1.65 * 1.03);
}

.home-copy-text--left-intro .home-copy-em {
  font-size: calc(1.5em / 1.05);
}

.home-copy-text--right-outcome {
  font-size: calc(0.9 * clamp(1rem, 1.9vw, 1.15rem) * 1.05);
  line-height: calc(1.65 * 1.03);
}

.home-copy-text--right-outcome .home-copy-em {
  font-size: calc(1.5em / 1.05);
}

.home-copy-em {
  font-weight: 700;
  font-size: 1.5em;
  line-height: inherit;
  color: #ffffff;
}

.home-copy-underline {
  text-decoration: underline;
  text-underline-offset: 0.12em;
  text-decoration-thickness: 1px;
}

.home-copy-underline--brand2 {
  font-size: 1.08em;
  color: var(--branding-color-2);
  text-decoration: none;
}

.home-copy-underline--brand2:visited {
  color: var(--branding-color-2);
}

.home-copy-underline--brand2:hover,
.home-copy-underline--brand2:focus-visible {
  color: var(--branding-color-2);
  opacity: 0.92;
  text-decoration: none;
}

/* 증언 블록 전체 링크 안 마지막 문장 강조(기존 브랜드2 링크 문장과 동일 톤) */
.home-copy-accent-line {
  font-size: 1.08em;
  color: var(--branding-color-2);
}

@media (max-width: 768px) {
  .home-copy-split {
    grid-template-columns: 1fr;
  }

  .home-copy-section {
    padding: 3.5rem 0 1.68rem;
  }
}



.home-voc-section {
  background: #000000;
  color: #ffffff;
  padding: 3.5rem 0 0.3003rem;
}

/* 재생 중 영상 프레임이 섹션 좌우로 나갈 때 가로 클리핑 방지 */
.home-voc-section:has(.is-home-voc-playing) {
  overflow-x: visible;
}

.home-voc-container {
  max-width: 1000px;
}

.home-voc-logo-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(4rem, 8vw, 6rem);
  margin-bottom: calc(0.7 * clamp(4rem, 10vw, 7rem));
}

.home-voc-logo {
  width: clamp(150px, 18vw, 240px);
  height: auto;
  display: block;
  /* 로고 PNG의 좌우 투명 여백을 화면에서 잘라 시각 간격을 실제로 확보 */
  clip-path: inset(0 6% 0 6%);
}

.home-voc-logo-arrow {
  display: none;
}

.home-voc-section-title {
  margin: 0 0 clamp(1.2rem, 2.4vw, 1.8rem);
  padding-left: 0.65rem;
  text-align: left;
  color: #ffffff;
  font-size: calc(clamp(1.1rem, 1.4vw + 0.75rem, 1.45rem) * 0.82 * 1.15);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.02em;
  position: relative;
}

.home-voc-section-subtitle {
  /* 부제목과 첫 블럭(그리드) 사이: 기존 하단 마진 대비 115% */
  margin: calc(clamp(1.2rem, 2.4vw, 1.8rem) * -0.65) 0 calc(clamp(1rem, 2.1vw, 1.55rem) * 1.1 * 1.15);
  padding-left: clamp(0.45rem, 1.1vw, 0.7rem);
  text-align: left;
  color: rgba(255, 255, 255, 0.72);
  font-size: clamp(0.72rem, 1.05vw, 0.86rem);
  font-weight: 500;
  line-height: 1.3;
}

.home-voc-grid {
  --home-voc-gap: clamp(1rem, 3vw, 2rem);
  --home-voc-col: calc((100% - var(--home-voc-gap)) / 2);
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: repeat(3, minmax(140px, auto));
  column-gap: var(--home-voc-gap);
  /* 블럭 세트 간 상하 여백: 기존(row-gap × 0.975) 대비 150% */
  row-gap: calc(var(--home-voc-gap) * 0.975 * 1.5);
  align-items: stretch;
}

.home-voc-cell {
  min-width: 0;
  padding: clamp(1rem, 2.5vw, 1.5rem);
  box-sizing: border-box;
  transition: box-shadow 0.28s ease;
}

.home-voc-cell[data-home-voc-story-url] {
  cursor: pointer;
}

.home-voc-cell[data-home-voc-inline-media] {
  cursor: default;
}

.home-voc-cell[data-home-voc-story-url]:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.home-voc-cell[data-home-voc-inline-media] .home-voc-inline-play:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.home-voc-cell > * {
  transition: transform 0.36s ease;
  transform-origin: center center;
}

.home-voc-cell:hover > * {
  transform: scale(1.06);
}

.home-voc-cell:hover {
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.28);
}

.home-voc-cell--empty:hover > * {
  transform: none;
}

.home-voc-cell--image {
  padding: 0;
  overflow: hidden;
  width: 80%;
  height: 80%;
  justify-self: center;
  align-self: center;
}

.home-voc-cell--empty {
  width: 80%;
  height: 80%;
  justify-self: center;
  align-self: center;
  padding: 0;
  position: relative;
  overflow: hidden;
}

.home-voc-empty-content {
  position: absolute;
  inset: 0;
  color: #666666;
  transition: transform 0.36s ease, color 0.3s ease;
}

.home-voc-company-name {
  position: absolute;
  top: clamp(0.45rem, 1.1vw, 0.75rem);
  left: clamp(0.7rem, 1.8vw, 1.1rem);
  margin: 0;
  font-size: calc(clamp(0.9rem, 1.5vw, 1.1rem) * 0.8);
  font-weight: 700;
  line-height: 1.3;
}

.home-voc-quote {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  margin: 0;
  transform: translateY(-50%);
  padding: 0 clamp(0.07rem, 0.18vw, 0.11rem);
  text-align: justify;
  text-justify: inter-character;
  font-size: calc(clamp(0.88rem, 1.45vw, 1.05rem) * 1.07);
  line-height: 1.55;
  font-weight: 500;
  text-indent: 1em;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.home-voc-actions {
  position: absolute;
  left: 50%;
  bottom: clamp(0.2rem, 0.8vw, 0.45rem);
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  gap: clamp(0.85rem, 2vw, 1.35rem);
}

.home-voc-text-btn {
  color: inherit;
  font-size: calc(clamp(0.82rem, 1.25vw, 0.95rem) * 0.8 * 1.12);
  font-weight: 600;
  line-height: 1.2;
  text-decoration: underline;
  text-underline-offset: 0.14em;
  text-decoration-thickness: 1px;
  transition: color 0.3s ease;
}

.home-voc-cell--empty:hover .home-voc-empty-content {
  color: #ffffff;
}

.home-voc-cell--empty:hover .home-voc-text-btn {
  color: #ffffff;
  text-decoration-color: #ffffff;
}

.home-voc-grid:has(.home-voc-cell--pair1-image:hover) .home-voc-cell--pair1-text .home-voc-empty-content,
.home-voc-grid:has(.home-voc-cell--pair2-image:hover) .home-voc-cell--pair2-text .home-voc-empty-content,
.home-voc-grid:has(.home-voc-cell--pair3-image:hover) .home-voc-cell--pair3-text .home-voc-empty-content {
  color: #ffffff;
}

.home-voc-grid:has(.home-voc-cell--pair1-image:hover) .home-voc-cell--pair1-text .home-voc-text-btn,
.home-voc-grid:has(.home-voc-cell--pair2-image:hover) .home-voc-cell--pair2-text .home-voc-text-btn,
.home-voc-grid:has(.home-voc-cell--pair3-image:hover) .home-voc-cell--pair3-text .home-voc-text-btn {
  color: #ffffff;
  text-decoration-color: #ffffff;
}

.home-voc-cell--empty-bridge {
  width: calc((100% + (0.2 * var(--home-voc-col) + var(--home-voc-gap)) + 1px) * 1.05);
  justify-self: end;
  margin-left: -1px;
}

.home-voc-cell--empty-bridge-left {
  width: calc((100% + (0.2 * var(--home-voc-col) + var(--home-voc-gap)) + 1px) * 1.05);
  justify-self: start;
  margin-right: -1px;
  transform: translateY(-18%);
}

.home-voc-cell--image-left-edge {
  justify-self: start;
}

.home-voc-cell--image-right-edge {
  justify-self: end;
  transform: translateY(-18%);
}

.home-voc-cell--row3-up {
  transform: translateY(-35%);
}

/* 섹션 내 썸네일 ↔ <video> 레이어(정적 src, ended 시 썸네일 복귀 — js/main.js) */
.home-voc-media-stack {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  border-radius: inherit;
}

/* 재생 중 셀 자체 레이어는 건드리지 않고, 비디오 레이어만 오버레이로 띄움 */
.home-voc-cell--image:has(.is-home-voc-playing) {
  overflow: visible;
}

/* right-edge/row3-up 셀은 기본 transform이 있어 fixed 기준이 틀어질 수 있음.
   재생 중에는 transform을 해제해 모든 영상이 동일하게 전면 오버레이로 뜨게 한다. */
.home-voc-cell--image-right-edge:has(.is-home-voc-playing),
.home-voc-cell--row3-up:has(.is-home-voc-playing) {
  transition: none;
  transform: none;
}

/* 전 화면 투명 딤: .site-header(100) 아래, 본문 위 — 클릭 시 닫힘; 영상 셀(110)은 딤 위 */
.home-voc-dim {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: transparent;
  pointer-events: auto;
  cursor: default;
}

.home-voc-cell--image:has(.is-home-voc-playing) > .home-voc-media-stack,
.home-voc-cell--image:has(.is-home-voc-playing):hover > .home-voc-media-stack {
  transition: none;
  transform: none;
}

/* 비디오: .home-voc-inline-video-frame — 크기·비율은 CSS로 조정 */
.home-voc-media-layer--video {
  position: fixed;
  inset: 0;
  z-index: 80;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.6s ease, visibility 0s linear 0.6s, z-index 0s step-end;
  display: block;
  background: transparent;
}

.home-voc-inline-video-frame {
  position: fixed;
  left: var(--home-voc-frame-left, 50vw);
  top: var(--home-voc-frame-top, 50vh);
  transform: translate(var(--home-voc-frame-shift-x, -50%), var(--home-voc-frame-shift-y, -50%));
  box-sizing: border-box;
  width: 50.4vw;
  height: auto;
  aspect-ratio: var(--home-voc-video-ar, 16 / 9);
  max-width: none;
  max-height: none;
  min-width: 0;
  min-height: 0;
}

.home-voc-media-stack.is-home-voc-playing .home-voc-media-layer--video {
  z-index: 1200;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transition: opacity 0.6s ease, visibility 0s linear 0s, z-index 0s step-start;
}

.home-voc-inline-video-frame .home-voc-inline-video {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  background: transparent;
}

.home-voc-inline-video-frame .home-voc-inline-iframe {
  object-fit: unset;
  border: 0;
  vertical-align: top;
}

/* 영상 우측 상단: 배경 없이 × (닫기) — 프레임(실제 화면) 기준 */
.home-voc-inline-video-frame .home-voc-inline-close {
  position: absolute;
  top: 0;
  right: clamp(0.35rem, 1.1vw, 0.6rem);
  z-index: 4;
  margin: 0;
  padding: 0.12em 0.16em 0.1em 0.14em;
  border: 0;
  background: none;
  color: #ffffff;
  font-size: clamp(1.62rem, 3.84vw, 2.22rem);
  line-height: 1;
  font-weight: 300;
  font-family: system-ui, "Segoe UI", sans-serif;
  cursor: pointer;
  text-shadow: 0 0 0.15em rgba(0, 0, 0, 0.85), 0 2px 2px rgba(0, 0, 0, 0.9);
  -webkit-tap-highlight-color: transparent;
}

.home-voc-inline-video-frame .home-voc-inline-close:focus-visible {
  outline: 3px solid rgba(255, 255, 255, 0.9);
  outline-offset: 3px;
}

.home-voc-media-layer--thumb {
  position: relative;
  z-index: 1;
  width: 100%;
  height: 100%;
  transition: opacity 0.45s ease;
}

.home-voc-inline-play {
  position: absolute;
  inset: 0;
  z-index: 2;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  border-radius: inherit;
  -webkit-tap-highlight-color: transparent;
}

.home-voc-media-stack.is-home-voc-playing .home-voc-media-layer--thumb {
  opacity: 0;
  pointer-events: none;
}

.home-voc-image-wrap {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.home-voc-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* 이미지 셀: 중앙 재생(흰 원 테두리 + 흰 삼각) */
.home-voc-play-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.home-voc-play-btn__ring {
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(2.65rem, 8.5vw, 4rem);
  height: clamp(2.65rem, 8.5vw, 4rem);
  border: calc(4px * 0.8) solid #ffffff;
  border-radius: 50%;
  box-shadow: 0 2px 16px rgba(0, 0, 0, 0.4);
}

.home-voc-play-btn__tri {
  display: block;
  width: 0;
  height: 0;
  margin-left: 0.2em;
  border-style: solid;
  border-width: 0.5em 0 0.5em 0.9em;
  border-color: transparent transparent transparent #ffffff;
}

@media (max-width: 768px) {
  .home-voc-section {
    padding: 2.75rem 0 0.2457rem;
  }

  .home-voc-grid {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(6, minmax(120px, auto));
  }

  .home-voc-cell--empty-bridge {
    width: 80%;
    justify-self: center;
    margin-left: 0;
  }

  .home-voc-cell--empty-bridge-left {
    width: 80%;
    justify-self: center;
    margin-right: 0;
  }
}

.home-logo-rotation-section {
  background: #000000;
  padding: 3.1rem 0 4.5rem;
}

.home-diagnosis-section {
  background: #000000;
  color: #ffffff;
  /* 하단 여백: 5.4rem 기준 약 1.2배 → site-footer 위 간격 */
  padding: 2rem 0 calc(5.4rem * 1.2);
}

.home-diagnosis-container {
  max-width: 1000px;
}

.home-diagnosis-title {
  margin: 0;
  font-size: clamp(1.2rem, 1.8vw, 1.65rem);
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
  scroll-margin-top: calc(var(--header-height) + 1.2rem);
}

.home-diagnosis-subtitle {
  margin: 0.95rem 0 0;
  font-size: clamp(0.72rem, 1.05vw, 0.86rem);
  font-weight: 500;
  line-height: 1.35;
  text-align: center;
  color: rgba(255, 255, 255, 0.72);
}

.home-diagnosis-image-list {
  display: flex;
  flex-direction: column;
  gap: calc(1.95rem * 1.15);
  align-items: stretch;
  margin-top: calc(1.3 * 1.44 * clamp(1.35rem, 3.2vw, 2.1rem));
}

/* 진단 블록: 고정 높이·이미지 채움은 .consulting-voc-box 근처에서 정의 */

.home-logo-rotation-container {
  max-width: 1000px;
}

.home-logo-rotation-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: clamp(0.65rem, 1.7vw, 1rem);
  transform: translateY(-0.9rem);
}

.home-logo-rotation-more-wrap {
  display: flex;
  justify-content: center;
  margin-top: calc(1.2 * 1.3 * clamp(0.7rem, 1.8vw, 1.1rem));
}

.home-logo-rotation-more-btn {
  color: #ffffff;
  font-size: calc(clamp(0.8rem, 1.1vw, 0.92rem) * 0.9 * 1.1);
  font-weight: 600;
  line-height: 1.3;
  text-decoration: underline;
  text-underline-offset: 0.14em;
  text-decoration-thickness: 1px;
}

.home-logo-slot {
  position: relative;
  width: 92.4%;
  min-height: calc(clamp(78px, 8.5vw, 108px) * 0.539);
  justify-self: center;
  align-self: center;
  background: #ffffff;
  border-radius: 8px;
  overflow: hidden;
  transition: background-color 1.5s ease;
}

.home-logo-slot-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: clamp(0.45rem, 1.2vw, 0.7rem);
  opacity: 0;
  filter: brightness(1);
  transition: opacity 1.5s ease, filter 1.5s ease;
}

.home-logo-slot.is-blinking .home-logo-slot-image {
  opacity: 1;
  filter: brightness(1.12);
}

.home-logo-slot.is-logo-fading-in .home-logo-slot-image {
  opacity: 1;
  filter: brightness(1.12);
}

.home-logo-slot.is-logo-swapping .home-logo-slot-image {
  opacity: 0;
  filter: brightness(1);
  transition: opacity 1.5s ease, filter 1.5s ease;
}

@media (max-width: 768px) {
  .home-logo-rotation-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.hero-thumbnail {
  position: relative;
  width: 100%;
  min-height: 490px;
  margin-top: 2.75rem; 
  border-radius: 0;
  overflow: hidden;
  display: flex;
  align-items: center;
  transform: translateY(-0.75rem); 
}

.hero-thumbnail-bg {
  position: absolute;
  inset: 0;
  background: #0f172a url("../assets/images/메인페이지1.webp") center center / cover no-repeat;
}

.hero-thumbnail-overlay {
  position: absolute;
  inset: 0;
  background: rgba(2, 6, 23, 0.35);
  pointer-events: none;
}

.hero-thumbnail .hero-banner {
  position: relative;
  z-index: 1;
  min-height: 260px;
  padding: 0.75rem 0;
}

.hero-banner {
  width: 100%;
  min-height: 260px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2.5rem;
}

.hero-text-group {
  flex: 1 1 auto;
  text-align: center;
  margin-left: -15%; 
}

.hero-copy-text {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.7;
  color: #ffffff;
}

.hero-play-area {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.75rem;
  color: #ffffff;
  text-align: center;
}

.hero-play-button {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: transparent;
  color: #ffffff;
  font-size: 1.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.hero-play-caption {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.4;
}


.hero-extension {
  width: 100%;
  padding-top: 2.5rem;
  transform: translateY(0); 
}

.hero-extension-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 2rem;
  margin-bottom: 2.25rem;
  transform: translateY(-1.5rem); 
}

.hero-extension-left {
  flex: 1 1 50%;
  text-align: center;
  color: #ffffff;
}

.hero-extension-heading {
  margin: 0 0 1rem;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.35;
}

.hero-extension-desc {
  margin: 0;
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.95);
}

.hero-extension-right {
  flex: 1 1 50%;
  text-align: center;
  color: #ffffff;
}

.hero-extension-quote {
  margin: 0 0 0.5rem;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1.45;
}

.hero-extension-attribution {
  margin: 0;
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.9);
}

.hero-extension-slogan {
  margin: 0;
  text-align: center;
  font-size: 1.75rem;
  font-weight: 700;
  line-height: 1.2; 
  color: #ffffff;
}

@media (max-width: 768px) {
  .hero-extension-row {
    flex-direction: column;
    gap: 2rem;
  }
  .hero-extension-right {
    text-align: center;
  }
  .hero-extension-heading {
    font-size: 1.5rem;
  }
  .hero-extension-quote {
    font-size: 1.2rem;
  }
}


.customer-logos-section {
  padding: 2.16rem 0; 
  background-color: #ffffff;
  overflow: hidden;
}


.customer-logos-inner {
  overflow: hidden;
}

.logo-row-wrap {
  overflow: hidden;
  padding: 0.9rem 0; 
}


.logo-row-middle {
  margin-left: -8%;
}

.logo-track {
  display: flex;
  align-items: center;
  gap: 2.75rem;
  width: max-content;
  animation: logo-scroll 78.125s linear infinite; 
}

@keyframes logo-scroll {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}

.logo-item {
  flex-shrink: 0;
  width: 112px;   
  height: 45px;   
  display: flex;
  align-items: center;
  justify-content: center;
}

.logo-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #cbd5e1;
  border-radius: 6px;
}


.testimonial-section {
  background-color: #ffffff;
  padding-top: 2.56rem; 
  padding-bottom: 2.56rem; 
}

.testimonial-section .testimonial-entry {
  margin-bottom: 2.56rem; 
}

.testimonial-section .testimonial-entry:last-child {
  margin-bottom: 0;
}

.testimonial-section .testimonial-entry-inner {
  display: flex;
  align-items: stretch;
  gap: 2.4rem;
  max-width: 100%;
}


.testimonial-section .testimonial-copy {
  flex: 1 1 45%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  min-height: 0;
}

.testimonial-section .testimonial-copy-inner {
  --testimonial-copy-gap: 1.43rem;
  width: 100%;
  max-width: 100%;
  padding: 0.65rem 1.2rem 0 0;
  box-sizing: border-box;
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
  align-items: stretch;
  gap: 0;
}


.testimonial-section .testimonial-quote {
  margin: 0 0 var(--testimonial-copy-gap);
  font-size: 1.12rem;
  font-weight: 700;
  line-height: 1.45;
  color: var(--color-text);
  text-align: center;
  grid-row: 1;
}

.testimonial-section .testimonial-quote--sm {
  font-size: 1.02rem;
}


.testimonial-section .testimonial-mid-wrap {
  grid-row: 2;
  align-self: start;
  justify-self: stretch;
  width: 100%;
  min-height: 0;
}

.testimonial-section .testimonial-attribution {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.55;
  color: var(--color-text-muted);
  text-align: right;
}

.testimonial-section .testimonial-summary {
  margin: var(--testimonial-copy-gap) 0 0;
  font-size: 0.96rem;
  line-height: 1.65;
  color: var(--color-text);
  text-align: left;
}


.testimonial-section .testimonial-copy-inner .story-story-btn {
  grid-row: 3;
  align-self: end;
  margin-top: 0.65rem;
  width: 100%;
}

.testimonial-section .testimonial-tag {
  margin: 0;
  font-size: 0.76rem;
  color: var(--color-primary);
}

.testimonial-section .testimonial-media {
  flex: 0 0 50%;
  max-width: 448px;
  position: relative;
  display: block;
  border-radius: var(--radius-md);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  background-color: #e5e7eb;
}

.testimonial-section button.testimonial-media {
  appearance: none;
  border: none;
  padding: 0;
  margin: 0;
  width: 100%;
  font: inherit;
  color: inherit;
  cursor: pointer;
  text-align: left;
}

.testimonial-section .testimonial-thumb {
  display: block;
  width: 100%;
  height: 100%;
  background-color: #cbd5e1;
}

.testimonial-section .testimonial-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.testimonial-section .testimonial-play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 58px;
  height: 58px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: rgba(0, 0, 0, 0.5);
  color: #ffffff;
  font-size: 1.2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: none;
}

.testimonial-section .testimonial-media:hover .testimonial-play-btn {
  background: rgba(0, 0, 0, 0.7);
}

@media (max-width: 768px) {
  .testimonial-section .testimonial-entry-inner {
    flex-direction: column;
    gap: 1.5rem;
    align-items: stretch;
  }
  .testimonial-section .testimonial-media {
    flex: 1 1 auto;
    max-width: 100%;
  }
  .testimonial-section .testimonial-copy-inner {
    display: flex;
    flex-direction: column;
    flex: 0 1 auto;
    min-height: 0;
    gap: 0;
    padding-top: 0.65rem;
  }
  .testimonial-section .testimonial-mid-wrap {
    align-self: stretch;
  }
  .testimonial-section .testimonial-copy-inner .story-story-btn {
    margin-top: 0.65rem;
    align-self: stretch;
  }
}


.invitation-section {
  background-color: #ffffff;
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.invitation-inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  min-height: 260px;
}

.invitation-image-wrap {
  flex: 0 0 38%;
  max-width: 38%;
}

.invitation-image {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 12px;
  box-shadow: var(--shadow-soft);
  object-fit: cover;
}

.invitation-text {
  flex: 1 1 auto;
  min-width: 0;
  text-align: center;
}

.invitation-message {
  margin: 0 0 3.6rem;
  font-family: var(--font-sans-variable);
  font-size: clamp(1.5rem, 3.2vw, 2.1rem);
  font-weight: 600;
  line-height: 1.55;
  letter-spacing: -0.03em;
  color: var(--color-text);
}

.invitation-actions {
  display: flex;
  justify-content: center;
  gap: 1.7rem;
  flex-wrap: wrap;
}

.invitation-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 180px;
  padding: 0.75rem 1.35rem;
  border-radius: 14px;
  border: 2px solid transparent;
  background-color: var(--branding-color-2);
  color: #000000;
  font-size: 0.95rem;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  transform: scale(1);
  transition:
    background-color 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease,
    transform 0.22s ease;
}

.invitation-btn:hover,
.invitation-btn:focus-visible {
  background-color: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
  transform: scale(1.05);
  outline: none;
}


.company-intro-section {
  background-color: #ffffff;
  padding: 3.5rem 0 5rem;
  
}

.company-intro-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

.company-intro-row {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
}

.company-intro-box-set {
  display: flex;
  align-items: flex-start;
  gap: 2.5rem;
  margin: 0 auto;
}

.company-intro-box {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  min-width: 0;
}

.company-intro-box-set .company-intro-box {
  flex: 1 1 0;
  min-width: 14rem;
}

.company-intro-box-set .company-intro-line2 {
  white-space: nowrap;
}

.company-intro-box-center {
  text-align: center;
  align-items: center;
}

.company-intro-box-left {
  text-align: left;
  align-items: flex-start;
}

.company-intro-box-right {
  text-align: left;
  align-items: flex-start;
}

.company-intro-line1 {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--color-text);
}

.company-intro-line2 {
  margin: 0 0 0.35rem;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.5;
}


.site-footer {
  background-color: #000000;
  color: rgba(255, 255, 255, 0.78);
  padding: 1.75rem 0 2rem;
  margin-bottom: 0;
}

.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1.35rem;
}

.footer-top-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem 1.25rem;
  width: 100%;
}

.footer-logo-link {
  display: inline-flex;
  align-items: center;
  line-height: 0;
  text-decoration: none;
  margin-left: -16px;
}

.footer-main-logo {
  display: block;
  height: 40px;
  width: auto;
}

.footer-social-icons {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.65rem;
}


.footer-social-icon-link--youtube {
  order: 1;
}

.footer-social-icon-link--instagram {
  order: 2;
}

.footer-social-icon-link--blog {
  order: 3;
}

.footer-social-icon-link {
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 0;
  opacity: 0.9;
  transition: opacity 0.2s ease;
}

.footer-social-icon-link:hover {
  opacity: 1;
}

.footer-social-icon-link img {
  display: block;
  height: 30px;
  width: auto;
  max-height: 36px;
}

.footer-legal {
  width: 100%;
  font-size: 0.72rem;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.62);
}

.footer-legal-line {
  margin: 0 0 0.45rem;
}

.footer-legal a {
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.footer-legal a:hover {
  color: rgba(255, 255, 255, 0.88);
}

.footer-copyright {
  margin: 1.5rem 0 0;
  font-size: 0.7rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.48);
}

@media (max-width: 768px) {
  .company-intro-inner {
    flex-direction: column;
    gap: 1.25rem;
  }
  .company-intro-row {
    flex-direction: column;
    align-items: center;
  }
  .company-intro-box-set {
    flex-direction: column;
    align-items: center;
  }
  .company-intro-box-left,
  .company-intro-box-right {
    text-align: center;
    align-items: center;
  }
  .footer-inner {
    align-items: flex-start;
    text-align: left;
  }

  .footer-top-row {
    flex-direction: column;
    align-items: flex-start;
  }

  .footer-social-icons {
    align-self: flex-end;
    justify-content: flex-end;
    width: 100%;
  }
}



.card-grid {
  display: grid;
  gap: 1.75rem;
}

.card-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.card {
  background-color: var(--color-surface);
  border-radius: var(--radius-md);
  padding: 1.75rem 1.5rem;
  box-shadow: var(--shadow-soft);
}

.card h3 {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-size: 1.15rem;
}

.card p {
  margin-top: 0;
  margin-bottom: 0.75rem;
  color: var(--color-text-muted);
}

.card-list {
  padding-left: 1.2rem;
  margin: 0 0 0.75rem;
}

.card-list li {
  list-style: disc;
  color: var(--color-text);
  margin-bottom: 0.25rem;
}

.card-link {
  font-weight: 600;
  font-size: 0.9rem;
  color: var(--color-accent);
}

.price {
  font-weight: 700;
  color: var(--color-primary);
  margin-bottom: 0.75rem;
}

.featured {
  border: 2px solid rgba(78, 137, 255, 0.7);
  transform: translateY(-4px);
}



.process-steps {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.process-step {
  background-color: var(--color-surface);
  padding: 1.5rem 1.25rem;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.process-step h3 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-size: 1rem;
}

.process-step p {
  margin: 0;
  color: var(--color-text-muted);
}



.testimonials-slider {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1rem;
}

.testimonials-wrapper {
  overflow: hidden;
  flex: 1 1 auto;
}

.testimonial {
  display: none;
  background-color: var(--color-surface);
  padding: 2rem 1.75rem;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.testimonial.active {
  display: block;
}

.testimonial-text {
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 1rem;
}

.testimonial-meta {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-text-muted);
}

.slider-control {
  border: none;
  background-color: rgba(15, 23, 42, 0.08);
  color: #111827;
  width: 36px;
  height: 36px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}



.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.5fr);
  gap: 2rem;
  align-items: center;
}

.avatar-placeholder {
  width: 180px;
  height: 180px;
  border-radius: 999px;
  background: linear-gradient(135deg, #4e89ff, #2563eb);
  color: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 1.1rem;
  box-shadow: var(--shadow-soft);
}

.about-content p {
  color: var(--color-text-muted);
}



.resource-card {
  min-height: 200px;
}



.contact-form {
  max-width: 720px;
  margin: 0 auto;
  background-color: var(--color-surface);
  padding: 2rem 1.75rem;
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-soft);
}

.form-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
}

.form-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.form-field label {
  font-size: 0.9rem;
  font-weight: 600;
}

.form-field input,
.form-field select,
.form-field textarea {
  border-radius: 0.75rem;
  border: 1px solid rgba(148, 163, 184, 0.7);
  padding: 0.6rem 0.75rem;
  font-size: 0.95rem;
  outline: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
  border-color: var(--color-accent);
  box-shadow: 0 0 0 1px rgba(78, 137, 255, 0.5);
}

.form-actions {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.form-message {
  font-size: 0.9rem;
}

.form-message.success {
  color: #16a34a;
}

.form-message.error {
  color: #dc2626;
}



@media (max-width: 1024px) {
  .hero-inner {
    grid-template-columns: minmax(0, 1fr);
  }

  .hero-media {
    order: -1;
  }

  .process-steps {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .card-grid-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .header-inner {
    gap: 0.75rem;
  }

  .main-nav {
    justify-content: flex-end;
  }

  .nav-toggle {
    display: flex;
  }

  .nav-menu {
    position: absolute;
    top: var(--header-height);
    left: 0;
    right: 0;
    background-color: #000000;
    flex-direction: column;
    padding: 1rem 1.5rem 1.25rem;
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
    transform: translateY(-120%);
    opacity: 0;
    pointer-events: none;
    transition: transform 0.18s ease, opacity 0.18s ease;
  }

  .nav-menu.open {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
  }

  .hero-section {
    padding-top: calc(4.5rem + var(--header-height));
  }

  .home-hero-section.hero-section {
    padding-top: 0;
  }

  .home-hero-container {
    padding-top: calc(var(--header-height) + 4.5rem + 2rem);
  }

  .card-grid-3 {
    grid-template-columns: minmax(0, 1fr);
  }

  .process-steps {
    grid-template-columns: minmax(0, 1fr);
  }

  .about-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .avatar-placeholder {
    margin: 0 auto;
  }

  .form-row {
    grid-template-columns: minmax(0, 1fr);
  }

  .footer-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}


.gainge-management-main {
  padding-top: 0;
  padding-bottom: 0;
  margin: 0;
  background-color: #000000;
}

.gainge-management-main + .site-footer {
  margin-top: 0;
}


/* 인사말–비전 사이 빈 띠: rem + 소량 dvh (18vh 대비 모니터 간 편차 축소), --gainge-spacer-section-height 로 덮어쓰기 가능 */
.gainge-spacer-section {
  margin: 0;
  padding: 0;
  min-height: var(
    --gainge-spacer-section-height,
    clamp(6.5rem, 10dvh, 9.5rem)
  );
  background-color: #000000;
  border: 0;
}

.gainge-vision-section {
  margin: 0;
  padding: 0;
  background-color: #000000;
  color: #e8eaef;
}

.gainge-vision-section-inner {
  box-sizing: border-box;
}

.gainge-vision-media {
  margin: 0;
  padding: 0;
  line-height: 0;
}

.gainge-vision-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  vertical-align: top;
  filter: brightness(0.78);
  transition: filter 0.5s ease;
}

.gainge-vision-media:hover .gainge-vision-img {
  filter: brightness(1.08);
}

@media (prefers-reduced-motion: reduce) {
  .gainge-vision-img {
    transition-duration: 0.01ms;
  }
}

.gainge-vision-text-area {
  box-sizing: border-box;
  /* 상단 패딩 동일 · 하단은 열어보기 버튼 아래 여백(기존 대비 65%) */
  padding: calc(1.1 * 1.5 * 1.3 * clamp(2.5rem, 5.5vh, 4rem)) 0
    calc(0.65 * 1.1 * 1.35 * clamp(3rem, 8vh, 6rem));
}

.gainge-vision-tagline {
  margin: 0;
  font-family: var(--font-sans-variable);
  font-size: clamp(1.55rem, 4.1vw, 2.35rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.03em;
  color: var(--branding-color-2);
  text-align: center;
}

.gainge-vision-body-box {
  margin-top: calc(1.1 * 1.5 * 1.3 * clamp(1.5rem, 3.5vh, 2.25rem));
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}

.gainge-vision-body-text {
  margin: 0;
  font-family: var(--font-sans-variable);
  font-size: clamp(0.98rem, 2.1vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.78;
  letter-spacing: -0.02em;
  color: #e8eaef;
  text-align: left;
  text-indent: 1em;
}

.gainge-vision-expand {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s ease;
}

.gainge-vision-expand.is-open {
  grid-template-rows: 1fr;
}

.gainge-vision-expand-clip {
  overflow: hidden;
  min-height: 0;
}

.gainge-vision-expand-inner {
  padding-top: clamp(0.85rem, 2vh, 1.25rem);
}

.gainge-vision-expand-p {
  margin: 0;
  font-family: var(--font-sans-variable);
  font-size: clamp(0.98rem, 2.1vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.78;
  letter-spacing: -0.02em;
  color: #e8eaef;
  text-align: left;
  text-indent: 1em;
}

.gainge-vision-expand-p + .gainge-vision-expand-p {
  margin-top: 1rem;
}

.gainge-vision-expand-p strong {
  font-weight: 700;
  color: #93c5fd;
  text-shadow: 0 0 1px rgba(15, 23, 42, 0.35);
}

.gainge-vision-actions {
  margin: calc(1.2 * 2 * clamp(1.1rem, 2.5vh, 1.65rem)) 0 0;
  text-align: center;
}

.gainge-vision-toggle-btn {
  display: inline;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #e8eaef;
  font-family: inherit;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: inherit;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.28em;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-vision-toggle-btn:hover {
  color: #ffffff;
}

.gainge-vision-toggle-btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .gainge-vision-expand {
    transition-duration: 0.01ms;
  }
}


.gainge-business-section {
  margin: 0;
  padding: calc(1.45 * clamp(3rem, 8vh, 5.5rem)) 0;
  background-color: #000000;
  color: #e8eaef;
  /* 사업 소개 패널 최대 가로 · 펼침 슬롯 세로(분량과 무관하게 동일, 긴 글은 패널 안 스크롤·스크롤바 숨김) */
  --gainge-business-detail-panel-max-width: calc(48rem * 1.05);
  --gainge-business-detail-slot-height: calc(
    1.05 * 1.07 * 0.7 * 0.35 * 1.05 *
      (
        20 * 1.72 * clamp(0.97rem, 1.75vw, 1.07rem) +
          2 * clamp(1.25rem, 3vw, 1.65rem)
      )
  );
}

.gainge-business-inner {
  box-sizing: border-box;
}

.gainge-business-section-title {
  margin: clamp(-2.1rem, -4.2vh, -1.45rem) 0 0.4rem;
  font-family: var(--font-sans-variable);
  font-size: clamp(1.2rem, 2.8vw, 1.45rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.03em;
  color: #ffffff;
  text-align: center;
}

.gainge-business-section-hint {
  margin: 0 0 calc(2.3 * clamp(1.5rem, 3.5vh, 2.35rem));
  font-family: var(--font-sans-variable);
  font-size: 0.78rem;
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: rgba(232, 234, 239, 0.72);
  text-align: center;
}

.gainge-business-rows {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: calc(clamp(1.25rem, 3.2vh, 2rem) * 1.2);
  width: fit-content;
  max-width: 100%;
  margin: 0 auto;
}

.gainge-business-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: calc(clamp(1rem, 3.2vw, 2.25rem) * 1.2);
}

.gainge-business-circle {
  position: relative;
  z-index: 0;
  box-sizing: border-box;
  flex: 0 0 auto;
  width: clamp(7.25rem, 20vw, 10.5rem);
  height: clamp(7.25rem, 20vw, 10.5rem);
  margin: 0;
  padding: 0.65rem;
  border: 2px solid var(--branding-color-2);
  border-radius: 50%;
  background-color: #000000;
  color: #ffffff;
  overflow: hidden;
  isolation: isolate;
  cursor: pointer;
  font-family: var(--font-sans-variable);
  font-size: calc(1.15 * 1.1 * 0.9 * 0.8 * clamp(1.12rem, 3.05vw, 1.34rem));
  font-weight: 600;
  line-height: 1.28;
  letter-spacing: -0.03em;
  text-align: center;
  word-break: keep-all;
  transition:
    background-color 0.3s ease,
    color 0.3s ease,
    border-color 0.3s ease,
    transform 0.35s ease,
    box-shadow 0.35s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-business-circle::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--gainge-business-circle-image, none);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transition: opacity 0.3s ease;
}

.gainge-business-circle::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0.759);
  transition: opacity 0.3s ease;
}

.gainge-business-circle-label {
  position: relative;
  z-index: 2;
  display: block;
  max-width: 100%;
}

/* 동그라미별 이미지 경로를 여기에 넣어 주세요 */
.gainge-business-circle[data-gainge-business="consulting"] {
  --gainge-business-circle-image: url("../assets/사업 1.webp");
}
.gainge-business-circle[data-gainge-business="coaching"] {
  --gainge-business-circle-image: url("../assets/사업 2.webp");
}
.gainge-business-circle[data-gainge-business="edu-platform"] {
  --gainge-business-circle-image: url("../assets/사업 3.webp");
}
.gainge-business-circle[data-gainge-business="corporate-education"] {
  --gainge-business-circle-image: url("../assets/사업 4.webp");
}
.gainge-business-circle[data-gainge-business="community"] {
  --gainge-business-circle-image: url("../assets/사업 5.webp");
}
.gainge-business-circle[data-gainge-business="headhunting"] {
  --gainge-business-circle-image: url("../assets/사업 6.webp");
}
.gainge-business-circle[data-gainge-business="investment"] {
  --gainge-business-circle-image: url("../assets/사업 7.webp");
}
.gainge-business-circle[data-gainge-business="publishing"] {
  --gainge-business-circle-image: url("../assets/사업 8.webp");
}


.gainge-business-circle:hover,
.gainge-business-circle:focus-visible {
  z-index: 2;
  background-color: #000000;
  color: #ffffff;
  border: 2px solid var(--branding-color-2);
  transform: translateY(-6px) scale(1.06);
  box-shadow:
    0 4px 0 rgba(255, 255, 255, 0.12),
    0 18px 36px rgba(0, 0, 0, 0.55);
  outline: none;
}

.gainge-business-circle:hover::before,
.gainge-business-circle:focus-visible::before,
.gainge-business-circle.is-active::before {
  opacity: 0;
}

.gainge-business-circle:hover::after,
.gainge-business-circle:focus-visible::after,
.gainge-business-circle.is-active::after {
  opacity: 0;
}

.gainge-business-circle.is-active {
  z-index: 1;
  background-color: #000000;
  color: #ffffff;
  border: 2px solid var(--branding-color-1);
  transform: translateY(-4px) scale(1.04);
  box-shadow:
    0 3px 0 rgba(255, 255, 255, 0.1),
    0 14px 28px rgba(0, 0, 0, 0.45);
}

.gainge-business-circle.is-active:hover,
.gainge-business-circle.is-active:focus-visible {
  background-color: #000000;
  color: #ffffff;
  border: 2px solid var(--branding-color-1);
  transform: translateY(-6px) scale(1.06);
  box-shadow:
    0 4px 0 rgba(255, 255, 255, 0.12),
    0 18px 36px rgba(0, 0, 0, 0.55);
}

.gainge-business-detail {
  display: grid;
  grid-template-rows: 0fr;
  margin-top: -0.85rem;
  transition: grid-template-rows 0.45s ease;
}
.gainge-business-detail.is-open {
  grid-template-rows: 1fr;
}

.gainge-business-detail-clip {
  overflow: hidden;
  min-height: 0;
}

.gainge-business-detail-inner {
  padding-top: 0.02rem;
}

.gainge-business-detail.is-open .gainge-business-detail-inner {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  width: min(100%, var(--gainge-business-detail-panel-max-width));
  margin-inline: auto;
  height: var(--gainge-business-detail-slot-height);
  max-height: var(--gainge-business-detail-slot-height);
}

.gainge-business-detail.is-open .gainge-business-detail-panel {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.gainge-business-detail.is-open .gainge-business-detail-panel::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.gainge-business-detail-panel {
  width: min(100%, var(--gainge-business-detail-panel-max-width));
  max-width: 100%;
  height: auto;
  margin: 0 auto;
  padding: clamp(1.25rem, 3vw, 1.65rem);
  border-radius: 12px;
  background-color: rgba(255, 255, 255, 0.05);
  border: 1px solid transparent;
  box-sizing: border-box;
  overflow: visible;
}

.gainge-business-detail-body {
  margin: 0;
  color: #f6f8fb;
  font-size: clamp(0.97rem, 1.75vw, 1.07rem);
  font-weight: 400;
  line-height: 1.72;
  letter-spacing: -0.01em;
  white-space: normal;
  word-break: break-all;
  text-align: justify;
  text-justify: inter-character;
  text-indent: 1em;
}

.gainge-business-detail-body strong {
  font-weight: 700;
  color: #93c5fd;
  text-shadow: 0 0 1px rgba(15, 23, 42, 0.35);
}

@media (prefers-reduced-motion: reduce) {
  .gainge-business-circle {
    transition-duration: 0.01ms;
  }
  .gainge-business-detail {
    transition-duration: 0.01ms;
  }
}


.gainge-declaration-section {
  margin: 0;
  padding: clamp(3rem, 8vh, 5.5rem) 0;
  background-color: #000000;
  color: #e8eaef;
}

.gainge-declaration-inner {
  box-sizing: border-box;
}

.gainge-declaration-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  gap: clamp(1.5rem, 4vw, 2.75rem);
}

.gainge-declaration-media {
  margin: 0;
  padding: 0;
  line-height: 0;
  align-self: start;
}

.gainge-declaration-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  vertical-align: top;
  opacity: 0.86;
  filter: brightness(0.88);
  transition:
    opacity 0.5s ease,
    filter 0.5s ease;
}

.gainge-declaration-media:hover .gainge-declaration-img {
  opacity: 1;
  filter: brightness(1.06);
}

@media (prefers-reduced-motion: reduce) {
  .gainge-declaration-img {
    transition-duration: 0.01ms;
    opacity: 1;
    filter: none;
  }
}

.gainge-declaration-copy {
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  align-self: stretch;
  min-width: 0;
  min-height: 0;
  padding-top: clamp(0.4rem, 1.1vh, 0.75rem);
  font-family: var(--font-sans-variable);
  font-size: clamp(0.98rem, 2.1vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.78;
  letter-spacing: -0.02em;
  text-align: justify;
  text-justify: inter-character;
  word-break: break-all;
  overflow-wrap: anywhere;
}


.gainge-declaration-body-box {
  width: 100%;
}

.gainge-declaration-intro-wrap {
  margin: 0;
}

.gainge-declaration-expand {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s ease;
}

.gainge-declaration-expand.is-open {
  grid-template-rows: 1fr;
}

.gainge-declaration-expand-clip {
  overflow: hidden;
  min-height: 0;
}

.gainge-declaration-expand-inner {
  padding-top: clamp(0.85rem, 2vh, 1.25rem);
}

.gainge-declaration-expand-inner .gainge-declaration-p:last-child {
  margin-bottom: 0;
}

.gainge-declaration-lead {
  margin: 0 0 calc(1.5 * 1.3 * 1.1em);
  font-size: clamp(1.2rem, 2.8vw, 1.42rem);
  line-height: 1.4;
  text-align: justify;
  text-justify: inter-character;
}

.gainge-declaration-lead strong {
  font-weight: 700;
  color: #ffffff;
}

.gainge-declaration-p {
  margin: 0 0 1.1em;
}

.gainge-declaration-p strong {
  font-weight: 700;
  color: #93c5fd;
  text-shadow: 0 0 1px rgba(15, 23, 42, 0.35);
}

.gainge-declaration-p:last-child {
  margin-bottom: 0;
}

.gainge-declaration-p--closing {
  margin-top: 0.2em;
}

.gainge-declaration-actions {
  flex: 0 0 auto;
  margin: calc(1.8 * clamp(1.1rem, 2.5vh, 1.65rem)) 0 0;
  text-align: center;
}

.gainge-declaration-toggle-btn {
  display: inline;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #e8eaef;
  font-family: inherit;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: inherit;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.28em;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-declaration-toggle-btn:hover {
  color: #ffffff;
}

.gainge-declaration-toggle-btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}


.gainge-principles-section {
  margin: 0;
  padding: calc(1.4 * 1.5 * clamp(1.4rem, 3.6vh, 2.2rem)) 0 calc(1.35 * clamp(0.9rem, 2.2vh, 1.4rem));
  background-color: #000000;
}

.gainge-principles-inner {
  box-sizing: border-box;
}

.gainge-principles-title {
  margin: 0 0 calc(2 * 1.35 * 1.3 * 1.23 * clamp(1rem, 2.4vh, 1.5rem));
  color: #ffffff;
  font-family: var(--font-sans-variable);
  font-size: clamp(1.18rem, 2.6vw, 1.5rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.02em;
  text-align: left;
}

.gainge-principles-content {
  width: 100%;
}

.gainge-principles-list {
  display: grid;
  gap: 0;
  row-gap: 0;
  column-gap: 0;
}

.gainge-principles-block {
  display: grid;
  grid-template-columns: minmax(3rem, 5.5rem) 1fr;
  align-items: stretch;
  gap: clamp(0.7rem, 1.8vw, 1.2rem);
  width: 100%;
  min-height: calc(0.8 * clamp(7.2rem, 16.2vh, 9.45rem));
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.02);
}

.gainge-principles-number {
  margin: 0;
  color: var(--branding-color-2);
  font-family: var(--font-sans-variable);
  font-size: clamp(2rem, 5vw, 2.8rem);
  font-weight: 800;
  line-height: 1;
  letter-spacing: -0.03em;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: clamp(0.1rem, 0.5vh, 0.35rem);
}

.gainge-principles-main {
  display: grid;
  grid-template-rows: auto 1fr;
  align-content: start;
  gap: clamp(0.5rem, 1.4vh, 0.8rem);
}

.gainge-principles-block-title {
  margin: 0;
  color: #ffffff;
  font-family: var(--font-sans-variable);
  font-size: clamp(1.05rem, 2.2vw, 1.35rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.gainge-principles-block-desc {
  margin: 0;
  color: #e5e7eb;
  font-family: var(--font-sans-variable);
  font-size: clamp(0.95rem, 1.8vw, 1.05rem);
  font-weight: 400;
  line-height: 1.65;
  letter-spacing: -0.01em;
}

@media (prefers-reduced-motion: reduce) {
  .gainge-declaration-expand {
    transition-duration: 0.01ms;
  }
}

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

  .gainge-principles-block {
    grid-template-columns: minmax(2.8rem, 4.2rem) 1fr;
  }
}


.gainge-mgmt-about-section {
  margin: 0;
  padding: clamp(3rem, 8vh, 5.5rem) 0;
  background-color: #000000;
  color: #e8eaef;
}

.gainge-mgmt-about-inner {
  box-sizing: border-box;
}

.gainge-mgmt-about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  gap: clamp(1.5rem, 4vw, 2.75rem);
}


.gainge-mgmt-about-media {
  margin: 0;
  padding: 0;
  line-height: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: stretch;
  min-height: 0;
}

.gainge-mgmt-about-img {
  display: block;
  width: 100%;
  height: auto;
  max-width: 100%;
  object-fit: contain;
  vertical-align: top;
}

.gainge-mgmt-about-img--logo {
  max-width: min(100%, 330px);
  margin-left: auto;
  margin-right: auto;
  transform: translateX(-0.65rem);
}

.gainge-mgmt-about-copy {
  box-sizing: border-box;
  min-width: 0;
  font-family: var(--font-sans-variable);
  font-size: clamp(0.98rem, 2.1vw, 1.0625rem);
  font-weight: 400;
  line-height: 1.78;
  letter-spacing: -0.02em;
  text-align: justify;
  text-justify: inter-character;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.gainge-mgmt-about-body-box {
  min-width: 0;
}

.gainge-mgmt-about-title {
  margin: 0 0 calc(1.25 * 1.25 * 1.1em);
  font-size: clamp(1.2rem, 2.8vw, 1.45rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.03em;
  color: #ffffff;
  text-align: justify;
  text-justify: inter-character;
}

.gainge-mgmt-about-p {
  margin: 0 0 1.1em;
}

.gainge-mgmt-about-p:last-child {
  margin-bottom: 0;
}

.gainge-mgmt-about-expand {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s ease;
}

.gainge-mgmt-about-expand.is-open {
  grid-template-rows: 1fr;
}

.gainge-mgmt-about-expand-clip {
  overflow: hidden;
  min-height: 0;
}

.gainge-mgmt-about-expand-inner {
  padding-top: clamp(0.85rem, 2vh, 1.25rem);
}

.gainge-mgmt-about-expand-p {
  margin: 0 0 1.1em;
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: inherit;
  color: #e8eaef;
  text-align: justify;
  text-justify: inter-character;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.gainge-mgmt-about-expand-p:last-child {
  margin-bottom: 0;
}

.gainge-mgmt-about-expand-p + .gainge-mgmt-about-expand-p {
  margin-top: 0;
}

/* 지식경영 문단(3번째)과 가인지 경영 문단 사이 간격만 기본(1.1em 하단) 대비 140% */
.gainge-mgmt-about-expand-inner > .gainge-mgmt-about-expand-p:nth-child(3) {
  margin-bottom: calc(1.1em * 1.4);
}

.gainge-mgmt-about-expand-p--closing {
  margin-top: 0.15em;
}

.gainge-mgmt-about-expand-p strong {
  font-weight: 700;
  color: #93c5fd;
  text-shadow: 0 0 1px rgba(15, 23, 42, 0.35);
}

.gainge-mgmt-about-actions {
  margin: clamp(1.1rem, 2.5vh, 1.65rem) 0 0;
  text-align: center;
}

.gainge-mgmt-about-toggle-btn {
  display: inline;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #e8eaef;
  font-family: inherit;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: inherit;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.28em;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-mgmt-about-toggle-btn:hover {
  color: #ffffff;
}

.gainge-mgmt-about-toggle-btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
  .gainge-mgmt-about-expand {
    transition-duration: 0.01ms;
  }
}

@media (max-width: 900px) {
  .gainge-mgmt-about-grid {
    grid-template-columns: 1fr;
  }

  .gainge-mgmt-about-img--logo {
    max-width: 277px;
    transform: translateX(-0.5rem);
  }
}


.gainge-explore-section {
  margin: 0;
  padding: calc(1.5 * clamp(2.5rem, 6vh, 4rem)) 0 calc(1.2 * clamp(3rem, 8vh, 5rem));
  background-color: #000000;
  color: #e8eaef;
}

.gainge-explore-inner {
  box-sizing: border-box;
}

.gainge-explore-title {
  margin: 0 0 calc(1.2 * 1.5 * clamp(2.9rem, 6.2vh, 3.85rem));
  font-family: var(--font-sans-variable);
  font-size: clamp(1.35rem, 3.2vw, 1.75rem);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.03em;
  text-align: center;
  color: #ffffff;
}

.gainge-youtube-banner-link {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 clamp(3.5rem, 7.5vh, 4.75rem);
  padding: clamp(0.65rem, 1.8vw, 0.9rem) clamp(1.25rem, 4vw, 1.75rem);
  min-height: 0;
  border-radius: 14px;
  border: 2px solid rgba(0, 0, 0, 0.15);
  background: var(--branding-color-2);
  text-decoration: none;
  color: #000000;
  box-sizing: border-box;
  box-shadow: 0 4px 24px rgba(15, 23, 42, 0.08);
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.gainge-youtube-banner-link:hover {
  background: var(--branding-color-1);
  border-color: var(--branding-color-1);
  box-shadow: 0 10px 32px rgba(0, 94, 255, 0.25);
  transform: translateY(-2px);
}

.gainge-youtube-banner-link:hover .gainge-youtube-banner-title,
.gainge-youtube-banner-link:hover .gainge-youtube-banner-desc {
  color: #ffffff;
}

.gainge-youtube-banner-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  text-align: center;
}

.gainge-youtube-banner-copy {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.3rem;
  text-align: center;
  min-width: 0;
}

.gainge-youtube-banner-title {
  font-size: clamp(0.98rem, 2.35vw, 1.22rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: #000000;
  transition: color 0.2s ease;
}

.gainge-youtube-banner-desc {
  font-size: clamp(0.8rem, 1.85vw, 0.9rem);
  line-height: 1.4;
  color: #000000;
  transition: color 0.2s ease;
}

.gainge-books-heading {
  margin: clamp(1.1rem, 2.4vh, 1.85rem) 0 clamp(1.75rem, 3.8vh, 2.5rem);
  font-family: var(--font-sans-variable);
  font-size: clamp(1.05rem, 2.2vw, 1.2rem);
  font-weight: 700;
  letter-spacing: -0.02em;
  text-align: center;
  color: #ffffff;
}

.gainge-books-carousel {
  max-width: 900px;
  margin: 0 auto;
}

.gainge-books-carousel-dots {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  margin: 0 0 clamp(2.35rem, 5.2vh, 3.25rem);
  padding: 0;
  list-style: none;
}

.gainge-books-dot {
  width: 10px;
  height: 10px;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.28);
  cursor: pointer;
  transition:
    background 0.2s ease,
    transform 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-books-dot:hover {
  background: rgba(255, 255, 255, 0.5);
  transform: scale(1.08);
}

.gainge-books-dot.is-active {
  background: #ffffff;
  transform: scale(1.12);
}

.gainge-books-dot:focus-visible {
  outline: 2px solid #93c5fd;
  outline-offset: 3px;
}

.gainge-books-carousel-viewport {
  position: relative;
  overflow: visible;
  margin: 0 clamp(2.25rem, 6vw, 3rem);
}

/* 트랙만 가로 오버플로 숨김 — 화살표는 뷰포트 밖으로 나가도 잘리지 않음 */
.gainge-books-carousel-mask {
  overflow: hidden;
  width: 100%;
}

.gainge-books-carousel-track {
  display: flex;
  flex-direction: row;
  width: 500%;
  transition: transform 0.45s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  will-change: transform;
}

/* 기업교육 워크샵 현장 캐러셀(.corporate-education-workshop-carousel .community-testimony-nav)과 동일 계열 */
.gainge-books-carousel-arrow {
  position: absolute;
  top: 50%;
  z-index: 3;
  margin: 0;
  padding: 0.2rem 0.45rem;
  min-width: auto;
  min-height: auto;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color: rgba(248, 250, 252, 0.5);
  font-size: clamp(2.85rem, 6.8vw, 4.15rem);
  font-weight: 700;
  line-height: 0.85;
  cursor: pointer;
  pointer-events: auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-books-carousel-arrow:hover:not(:disabled) {
  background: transparent;
  border: none;
  color: rgba(248, 250, 252, 0.78);
}

.gainge-books-carousel-arrow:focus-visible {
  outline: 2px solid rgba(248, 250, 252, 0.65);
  outline-offset: 4px;
}

.gainge-books-carousel-arrow:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.gainge-books-carousel-arrow--prev {
  left: 0;
  transform: translate(-70%, calc(-50% - 1.1rem));
}

.gainge-books-carousel-arrow--next {
  right: 0;
  transform: translate(70%, calc(-50% - 1.1rem));
}

.gainge-books-carousel-arrow--prev:hover:not(:disabled) {
  transform: translate(-70%, calc(-50% - 1.1rem));
}

.gainge-books-carousel-arrow--next:hover:not(:disabled) {
  transform: translate(70%, calc(-50% - 1.1rem));
}

.gainge-books-carousel-arrow-icon {
  display: inline-block;
  transform: scaleY(1.26);
  transform-origin: center;
}

.gainge-books-slide {
  box-sizing: border-box;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 calc(100% / 15);
  width: calc(100% / 15);
  min-width: 0;
  padding: 0 clamp(0.85rem, 2.8vw, 1.55rem);
  text-decoration: none;
  color: inherit;
}

.gainge-books-slide-frame {
  display: block;
  width: 70%;
  max-width: 70%;
  margin: 0 auto;
  border-radius: 10px;
  overflow: hidden;
  background: #1a1a1a;
  border: 1px solid rgba(255, 255, 255, 0.12);
  aspect-ratio: 2 / 3;
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.42);
}

.gainge-books-slide-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease, filter 0.3s ease;
}

.gainge-books-slide:hover .gainge-books-slide-img {
  transform: scale(1.02);
  filter: brightness(1.04);
}

@media (max-width: 600px) {
  .gainge-books-carousel-viewport {
    margin: 0 clamp(1.85rem, 5vw, 2.35rem);
  }

  .gainge-books-carousel-arrow {
    font-size: clamp(2.2rem, 9vw, 3.2rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .gainge-youtube-banner-link,
  .gainge-youtube-banner-link:hover,
  .gainge-books-dot,
  .gainge-books-slide-img,
  .gainge-books-carousel-track {
    transition-duration: 0.01ms;
  }

  .gainge-books-slide:hover .gainge-books-slide-img {
    transform: none;
  }
}


.gainge-greeting-section {
  margin: 0;
  padding: 0;
  background-color: #000000;
  /* 히어로(인사말) 블록 세로 스케일 — min-height·리듬값과 동기 (기준 1.34 × 1.07 ≒ 길이 107%) */
  --gainge-greeting-hero-size-scale: calc(1.34 * 1.07);
  --gainge-title-right: 10%;
  --gainge-title-nudge-left: clamp(2.5rem, 7.5vw, 4.75rem);

  --gainge-title-estimated-width: min(58%, 22rem);
  --gainge-title-fs: clamp(2.3rem, 9.2vw, 6.05rem);
  --gainge-body-pull-left: clamp(4.75rem, 30vw, 42rem);
  --gainge-body-inner-width-pct: 63%;
  /* 제목 ~ 스페이서: 거의 본문 상단에 붙는 느낌(아주 얇은 간격만) */
  --gainge-greeting-title-body-gap: clamp(
    calc(0.3rem * var(--gainge-greeting-hero-size-scale)),
    calc(0.65dvh * var(--gainge-greeting-hero-size-scale)),
    calc(0.55rem * var(--gainge-greeting-hero-size-scale))
  );
  /* 본문 블록 상단: 스페이서가 줄어든 경우에도 타이틀~본문 사이 최소 여백 */
  --gainge-greeting-article-margin-top: clamp(
    calc(2.275rem * var(--gainge-greeting-hero-size-scale)),
    calc(5.25dvh * var(--gainge-greeting-hero-size-scale)),
    calc(4.725rem * var(--gainge-greeting-hero-size-scale))
  );
  /* 타이틀 좌우 위치: 음수일수록 왼쪽(미세 조정은 이 값만 변경) */
  --gainge-greeting-title-shift-x: -38vw;
  /*
   * 콘텐츠 상단 패딩: 타이틀을 크게 아래로 내림 → 제목·본문 사이 플렉스 스페이서가 줄어
   * 본문 블록은 여전히 하단 정렬(거의 본문 첫 줄 바로 아래에 타이틀이 오도록).
   */
  --gainge-greeting-content-push-down: calc(
    1.15 *
      clamp(
        calc(10rem * var(--gainge-greeting-hero-size-scale)),
        calc(14dvh * var(--gainge-greeting-hero-size-scale)),
        calc(18rem * var(--gainge-greeting-hero-size-scale))
      ) +
      clamp(
        calc(5.5rem * var(--gainge-greeting-hero-size-scale)),
        calc(14dvh * var(--gainge-greeting-hero-size-scale)),
        calc(11rem * var(--gainge-greeting-hero-size-scale))
      ) +
      calc(
        0.5 *
          clamp(
            calc(5.5rem * var(--gainge-greeting-hero-size-scale)),
            calc(14dvh * var(--gainge-greeting-hero-size-scale)),
            calc(11rem * var(--gainge-greeting-hero-size-scale))
          )
      )
  );
}

.gainge-greeting-frame {
  width: 100%;
  background-color: #000000;
}


.gainge-greeting-stack {
  position: relative;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  box-sizing: border-box;
  background-color: #000000;
}

.gainge-greeting-column-wrap {
  position: relative;
  width: 100%;
  max-width: 100%;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  /* 접힘 기본: 최소 높이는 rem 하한 + dvh 상한 캡 (히어로 스케일 반영) */
  min-height: max(
    calc(34rem * var(--gainge-greeting-hero-size-scale)),
    min(
      calc(92dvh * var(--gainge-greeting-hero-size-scale)),
      calc(50rem * var(--gainge-greeting-hero-size-scale))
    )
  );
}

/* 배경만 담당 — 위치·크기는 여기서 따로 조정 가능 */
.gainge-greeting-bg {
  position: absolute;
  left: 0;
  right: 0;
  top: var(--header-height);
  bottom: 0;
  z-index: 0;
  background-color: #000000;
  background-image: url("../assets/가인지경영 인사말 섹션 배경.webp");
  background-size: 90% auto;
  background-position: center top;
  background-repeat: no-repeat;
  opacity: 0;
  animation: gainge-greeting-bg-fade-in 1.1s ease-out forwards;
  pointer-events: none;
}

.gainge-greeting-hero {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  /* 내부 .gainge-greeting-content 가 flex:1 로 채우고, 본문 블록은 margin-top:auto 로 하단 정렬 */
  justify-content: flex-start;
  align-items: stretch;
  flex: 1 1 auto;
  width: 100%;
  min-height: 0;
  box-sizing: border-box;
  padding-top: max(env(safe-area-inset-top, 0px), var(--header-height));
  /* 본문·열어보기를 히어로 바닥에 붙이는 느낌 — 아주 얇은 안전 여백 + 노치 */
  padding-bottom: max(
    env(safe-area-inset-bottom, 0px),
    clamp(
      calc(0.35rem * var(--gainge-greeting-hero-size-scale)),
      calc(0.85dvh * var(--gainge-greeting-hero-size-scale)),
      calc(0.65rem * var(--gainge-greeting-hero-size-scale))
    )
  );
}

/* 인사말 본문 펼침 시 — `is-greeting-expanded` 는 main.js에서 토글 (:has() 미지원·구형 브라우저 대응) */
.gainge-greeting-section.is-greeting-expanded .gainge-greeting-hero {
  padding-bottom: max(
    env(safe-area-inset-bottom, 0px),
    clamp(
      calc(0.3rem * var(--gainge-greeting-hero-size-scale)),
      calc(0.75dvh * var(--gainge-greeting-hero-size-scale)),
      calc(0.55rem * var(--gainge-greeting-hero-size-scale))
    )
  );
}

.gainge-greeting-section.is-greeting-expanded .gainge-greeting-column-wrap {
  min-height: max(
    calc(36rem * var(--gainge-greeting-hero-size-scale)),
    min(
      calc(96dvh * var(--gainge-greeting-hero-size-scale)),
      calc(52rem * var(--gainge-greeting-hero-size-scale))
    )
  );
}

/* 접힘: 동일하게 히어로 바닥에 가깝게 */
.gainge-greeting-section:not(.is-greeting-expanded) .gainge-greeting-hero {
  padding-bottom: max(
    env(safe-area-inset-bottom, 0px),
    clamp(
      calc(0.35rem * var(--gainge-greeting-hero-size-scale)),
      calc(0.85dvh * var(--gainge-greeting-hero-size-scale)),
      calc(0.65rem * var(--gainge-greeting-hero-size-scale))
    )
  );
}

@keyframes gainge-greeting-bg-fade-in {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.gainge-greeting-content {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  gap: 0;
  width: 100%;
  box-sizing: border-box;
  padding-top: var(--gainge-greeting-content-push-down);
  padding-right: var(--gainge-title-right);
  padding-left: max(
    0px,
    calc(
      100% - var(--gainge-title-right) - var(--gainge-title-estimated-width) - var(--gainge-title-nudge-left) - 0.5em - var(--gainge-body-pull-left)
    )
  );
}

.gainge-greeting-title {
  align-self: flex-end;
  flex-shrink: 0;
  margin: 0;
  margin-bottom: var(--gainge-greeting-title-body-gap);
  padding: 0;
  max-width: 100%;
  text-align: right;
  color: #ffffff;
  font-family: var(--font-pretendard-static);
  font-size: var(--gainge-title-fs);
  font-weight: 900;
  line-height: 1.02;
  letter-spacing: -0.055em;
  text-shadow:
    0 0 1.25rem rgba(0, 0, 0, 0.55),
    0 0.12em 0.35em rgba(0, 0, 0, 0.45);
  transform: translateX(var(--gainge-greeting-title-shift-x));
}

.gainge-greeting-title-line {
  display: block;
}

.gainge-greeting-title-line + .gainge-greeting-title-line {
  margin-top: 0.19em;
}

/* 제목과 본문 블록 사이: 접힘 시 남는 세로 공간 흡수 → 본문을 히어로 하단으로 밀어 줌 */
.gainge-greeting-flex-spacer {
  flex: 1 1 auto;
  min-height: 0;
}

/*
 * 펼침 시 main.js 가 --gainge-greeting-spacer-lock 에 접힘 상태의 스페이서 높이(px)를 넣음 →
 * 스페이서가 줄어들지 않아 본문 블록 상단이 위로 당겨지지 않고, 섹션만 아래로 길어짐.
 */
.gainge-greeting-section.is-greeting-expanded .gainge-greeting-flex-spacer {
  flex-grow: 0;
  flex-shrink: 0;
  flex-basis: auto;
  height: var(--gainge-greeting-spacer-lock, 0px);
  min-height: var(--gainge-greeting-spacer-lock, 0px);
}

@media (max-width: 768px) {
  .gainge-greeting-section {
    --gainge-title-right: 6%;
    --gainge-title-estimated-width: min(62%, 18rem);
    --gainge-title-fs: clamp(1.67rem, 8.8vw, 2.8rem);
    --gainge-body-pull-left: clamp(2rem, 18vw, 18rem);
    --gainge-greeting-title-shift-x: -32vw;
    --gainge-greeting-content-push-down: calc(
      1.15 *
        clamp(
          calc(8rem * var(--gainge-greeting-hero-size-scale)),
          calc(12dvh * var(--gainge-greeting-hero-size-scale)),
          calc(16rem * var(--gainge-greeting-hero-size-scale))
        ) +
        clamp(
          calc(4rem * var(--gainge-greeting-hero-size-scale)),
          calc(11dvh * var(--gainge-greeting-hero-size-scale)),
          calc(8.5rem * var(--gainge-greeting-hero-size-scale))
        ) +
        calc(
          0.5 *
            clamp(
              calc(4rem * var(--gainge-greeting-hero-size-scale)),
              calc(11dvh * var(--gainge-greeting-hero-size-scale)),
              calc(8.5rem * var(--gainge-greeting-hero-size-scale))
            )
        )
    );
  }

  .gainge-greeting-title {
    letter-spacing: -0.05em;
  }

  .gainge-greeting-article-inner {
    font-size: 0.92rem;
    line-height: 1.76;
  }
}


.gainge-greeting-article {
  width: 100%;
  flex-shrink: 0;
  margin-top: var(--gainge-greeting-article-margin-top);
  box-sizing: border-box;
  margin-left: 0;
  margin-right: 0;
  padding: 0;
  background-color: transparent;
  color: #e8eaef;
}

.gainge-greeting-article-inner {
  box-sizing: border-box;
  width: var(--gainge-body-inner-width-pct);
  min-width: var(--gainge-body-inner-width-pct);
  max-width: var(--gainge-body-inner-width-pct);
  height: fit-content;
  margin: 0;
  padding: 0;
  font-family: var(--font-sans-variable);
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.78;
  letter-spacing: -0.02em;
  pointer-events: auto;
  text-align: justify;
  text-justify: inter-character;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.gainge-greeting-body-p {
  margin: 0 0 1.35em;
  text-align: justify;
  text-justify: inter-character;
}

.gainge-greeting-body-p:last-child {
  margin-bottom: 0;
}

.gainge-greeting-brand2 {
  color: var(--branding-color-2);
}

.gainge-greeting-body-box {
  margin: 0;
}


.gainge-greeting-expand {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.45s ease;
}

.gainge-greeting-expand.is-open {
  grid-template-rows: 1fr;
}

.gainge-greeting-expand-clip {
  overflow: hidden;
  min-height: 0;
}

.gainge-greeting-expand-inner {
  padding-top: clamp(0.85rem, 1.25dvh, 1.25rem);
}

.gainge-greeting-expand-inner .gainge-greeting-body-p:last-child {
  margin-bottom: 0;
}

.gainge-greeting-actions {
  margin: clamp(0.7rem, 1.25dvh, 1.2rem) 0 0;
  text-align: center;
}

.gainge-greeting-toggle-btn {
  display: inline;
  padding: 0;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: #e8eaef;
  font-family: inherit;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: inherit;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.28em;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
  -webkit-appearance: none;
  appearance: none;
}

.gainge-greeting-toggle-btn:hover {
  color: #ffffff;
}

.gainge-greeting-toggle-btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

.gainge-greeting-body-p--invite {
  margin-top: 1.75em;
  margin-bottom: 1.1em;
  font-weight: 600;
  text-align: left;
  text-align-last: left;
  text-justify: auto;
  word-break: normal;
}

.gainge-greeting-body-p--signature {
  text-align: right;
  text-align-last: right;
  text-justify: auto;
  word-break: normal;
  font-weight: 600;
  margin-bottom: 0;
}

@media (prefers-reduced-motion: reduce) {
  .gainge-greeting-bg {
    animation: none;
    opacity: 1;
  }

  .gainge-greeting-expand {
    transition-duration: 0.01ms;
  }
}


.testimonials-main {
  padding-top: calc(var(--header-height) + 0.000375rem);
  min-height: 50vh;
  background-color: #000000;
}


.consulting-main {
  padding-top: calc(var(--header-height) + 0.000375rem);
  min-height: 50vh;
  background-color: #000000;
}


body.corporate-education-page {
  background-color: #000000;
}


.corporate-education-main {
  padding-top: calc(var(--header-height) + 0.000375rem);
  min-height: 50vh;
  background-color: #000000;
}




.testimonials-hero {
  margin: 0;
  padding: 0.7rem 0 0;
  background-color: #000000;
}

.testimonials-hero .container {
  padding: 0 1.5rem;
}

.testimonials-hero-wrap {
  position: relative;
  padding-bottom: 1.5rem;
}

.testimonials-stories-heading {
  margin: 1.6rem auto 3.2rem;
  max-width: 1020px;
  padding-left: 0;
  font-size: 1.15rem;
  font-weight: 800;
  line-height: 1.4;
  color: #ffffff;
  text-align: left;
}

.testimonials-hero-label {
  position: absolute;
  top: 1rem;
  left: 2.75rem;
  z-index: 3;
  font-size: 1.125rem;
  font-weight: 600;
  color: #000;
  letter-spacing: 0.05em;
}

.testimonials-hero-image {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}


.testimonials-hero-wrap .story-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  max-width: 1020px;
  margin: 0 auto 0;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.35);
  box-sizing: border-box;
}




.testimonials-search {
  padding: 3.2rem 0 3rem;
  background-color: #000000;
}

.testimonials-search-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 0.75rem;
  align-items: center;
  max-width: 760px;
  margin: 0 auto 4.3rem;
}

.testimonials-search-input {
  height: 44px;
  width: 100%;
  border: 1px solid #d1d5db;
  border-radius: 10px;
  padding: 0 1rem;
  font-size: 1rem;
  background: #ffffff;
  outline: none;
}

.testimonials-search-input:focus {
  border-color: #9ca3af;
  box-shadow: 0 0 0 3px rgba(156, 163, 175, 0.25);
}

.testimonials-search-button {
  width: 44px;
  height: 44px;
  border-radius: 6px;
  border: 1px solid #d1d5db;
  background: #f3f4f6;
  display: grid;
  place-items: center;
  cursor: pointer;
}

.testimonials-search-button:hover {
  background: #e5e7eb;
}

.testimonials-search-icon {
  position: relative;
  width: 18px;
  height: 18px;
  box-sizing: border-box;
  border: 2px solid #6b7280;
  border-radius: 50%;
}

.testimonials-search-icon::after {
  content: "";
  position: absolute;
  width: 9px;
  height: 2px;
  background: #6b7280;
  right: -7px;
  bottom: -2px;
  transform: rotate(45deg);
  border-radius: 999px;
}

.testimonials-filters {
  max-width: 980px;
  margin: 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 10px;
  overflow: hidden;
}

.testimonials-filter-row {
  display: grid;
  grid-template-columns: 140px 1fr;
  align-items: stretch;
}

.testimonials-filter-row + .testimonials-filter-row {
  border-top: 1px solid rgba(255, 255, 255, 0.18);
}

.testimonials-filter-label {
  background: #1f2937;
  font-weight: 600;
  font-size: 0.95rem;
  color: #f8fafc;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.75rem 0.75rem;
}

.testimonials-filter-body {
  background: #111827;
  padding: 0.5rem 0.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
}


.testimonials-filter-body--industry {
  flex-direction: column;
  flex-wrap: nowrap;
  align-items: stretch;
  justify-content: flex-start;
}

.testimonials-filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  justify-content: center;
  width: 100%;
}

.filter-chip {
  border: 1px solid rgba(248, 250, 252, 0.3);
  background: #1f2937;
  color: #f8fafc;
  border-radius: 6px;
  padding: 0.35rem 0.75rem;
  font-size: 0.9rem;
  cursor: pointer;
}

.filter-chip:hover,
.filter-chip:focus-visible {
  background: #374151;
  border-color: rgba(248, 250, 252, 0.55);
  outline: none;
}


.testimonials-filters .filter-chip[aria-pressed="true"] {
  background: #ffffff;
  color: #000000;
  border-color: rgba(0, 0, 0, 0.14);
}

.testimonials-filters .filter-chip[aria-pressed="true"]:hover {
  background: #ffffff;
  color: #000000;
  border-color: rgba(0, 0, 0, 0.2);
}

.testimonials-filters .filter-chip[aria-pressed="true"]:focus-visible {
  background: #ffffff;
  color: #000000;
  border-color: rgba(0, 0, 0, 0.2);
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .testimonials-search-form {
    max-width: 100%;
    margin: 0 auto 1rem;
  }
  .testimonials-filters {
    border-radius: 12px;
  }
  .testimonials-filter-row {
    grid-template-columns: 1fr;
  }
  .testimonials-filter-label {
    justify-content: flex-start;
    padding: 0.6rem 0.75rem;
  }
}


.testimonials-board {
  padding: 1.2rem 0 3rem;
}

.testimonials-board .container {
  max-width: 960px;
  margin: 0 auto;
  padding: 0 1rem;
}


.board-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  margin-bottom: 2rem;
}

.board-item {
  display: flex;
  gap: 1.1rem;
  align-items: stretch;
  padding: 0.9rem;
  min-height: 128px;
  box-sizing: border-box;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: #0b0f17;
  border-radius: 12px;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.25);
  cursor: pointer;
  transition: transform 0.24s ease, background-color 0.24s ease, border-color 0.24s ease, box-shadow 0.24s ease;
}

.board-item:hover {
  background: #ffffff;
  border-color: rgba(255, 255, 255, 0.95);
  transform: scale(1.02);
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.3);
}

.board-thumb-link {
  display: block;
  flex-shrink: 0;
  width: 168px;
  min-height: 110px;
  border-radius: 10px;
  overflow: hidden;
}

.board-thumb-image {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 110px;
  object-fit: cover;
  transition: transform 0.28s ease, filter 0.28s ease;
}

.board-item:hover .board-thumb-image {
  transform: scale(1.05);
  filter: brightness(1.08);
}

.board-meta {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 0.45rem;
  min-width: 0;
  flex: 1;
}

.board-title {
  font-weight: 600;
  color: #f8fafc;
  line-height: 1.35;
  text-align: left;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  width: 100%;
  text-decoration: none;
}

.board-title:hover {
  color: #ffffff;
  text-decoration: underline;
}

.board-item:hover .board-title,
.board-item:hover .board-title:hover {
  color: #0f172a;
}

.board-author {
  display: inline-block;
  align-self: flex-end;
  font-size: 0.92rem;
  color: #cbd5e1;
  text-decoration: none;
  width: auto;
  text-align: left;
}

.board-author:hover {
  color: #ffffff;
  text-decoration: underline;
}

.board-item:hover .board-author,
.board-item:hover .board-author:hover {
  color: #0f172a;
}


.author-posts-popup {
  background: #000;
  color: #f8fafc;
  min-height: 100vh;
  padding: 2rem 0 3rem;
}

.author-posts-popup .container {
  max-width: 900px;
}

.author-posts-popup-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
  margin-bottom: 1.2rem;
}

.author-posts-popup-title {
  margin: 0;
  font-size: clamp(1.2rem, 2.5vw, 1.55rem);
  color: #ffffff;
}

.author-posts-popup-close {
  border: 1px solid rgba(255, 255, 255, 0.75);
  background: transparent;
  color: #ffffff;
  border-radius: 999px;
  padding: 0.35rem 0.85rem;
  cursor: pointer;
}

.author-posts-popup-empty {
  margin: 1.5rem 0;
  color: #cbd5e1;
}


.board-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.5rem 0.25rem;
}

.board-page-numbers {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}

.board-page-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  padding: 0.4rem 0.5rem;
  font-size: 0.95rem;
  color: #ffffff;
  border-radius: 6px;
  text-decoration: none;
}

.board-page-num:hover {
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
}

.board-page-num.is-current {
  font-weight: 700;
  color: #ffffff;
  background: transparent;
}

.board-page-num.is-current:hover {
  color: #ffffff;
}

.board-page-next {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.4rem 0.6rem;
  font-size: 0.9rem;
  color: #ffffff;
  text-decoration: none;
  border-radius: 6px;
}

.board-page-next:hover {
  background: rgba(255, 255, 255, 0.14);
  text-decoration: underline;
}

.board-page-next span {
  font-size: 0.75rem;
}

@media (max-width: 600px) {
  .board-item {
    flex-direction: column;
    gap: 0.75rem;
    padding: 0.75rem;
    min-height: 0;
  }
  .board-thumb-link {
    width: 100%;
    min-height: 170px;
  }
  .board-thumb-image {
    min-height: 170px;
  }
}


.board-article-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.78);
  z-index: 1000;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 2rem 1rem 3rem;
  overflow-y: auto;
}

.board-article-overlay.hidden {
  display: none;
}

.board-article-modal {
  position: relative;
  width: min(90vw, 1120px);
  max-width: 1120px;
  background: var(--color-surface);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
  padding: 2.25rem 2.8rem 2.8rem;
  margin: auto;
  max-height: 94vh;
  overflow-y: auto;
}

.board-article-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
  border: none;
  background: transparent;
  font-size: 1.75rem;
  line-height: 1;
  color: var(--color-text-muted);
  cursor: pointer;
  border-radius: 8px;
}

.board-article-close:hover,
.board-article-close:focus-visible {
  color: var(--color-text);
  background: #f3f4f6;
  outline: none;
}

.board-article-body {
  padding-top: 0.5rem;
}

.board-article-title {
  font-size: 1.35rem;
  font-weight: 700;
  line-height: 1.4;
  margin: 0 0 1.25rem;
  color: var(--color-primary);
}

.board-article-body p {
  margin: 0 0 1rem;
  line-height: 1.75;
  color: var(--color-text);
}

.board-article-heading {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 1.5rem 0 0.75rem;
  color: var(--color-primary);
}

.board-article-figure {
  margin: 1.25rem 0;
  text-align: center;
}

.board-article-img-placeholder {
  display: block;
  width: 100%;
  min-height: 180px;
  background: #e5e7eb;
  border-radius: 8px;
  color: var(--color-text-muted);
  font-size: 0.9rem;
  line-height: 180px;
  text-align: center;
}

.board-article-body .board-article-figure img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  border-radius: 8px;
}

.board-article-cta-wrap {
  text-align: center;
  margin: 2rem 0 0 !important;
}

.board-article-cta {
  display: inline-block;
  padding: 0.75rem 1.5rem;
  background: #f3f4f6;
  color: var(--color-text);
  font-weight: 600;
  border-radius: var(--radius-md);
  text-decoration: none;
}

.board-article-cta:hover {
  background: #e5e7eb;
  color: var(--color-primary);
}

@media (max-width: 600px) {
  .board-article-modal {
    width: calc(100vw - 1.4rem);
    max-width: calc(100vw - 1.4rem);
    padding: 1.5rem 1.25rem 2rem;
  }
  .board-article-title {
    font-size: 1.2rem;
  }
}

.story-grid-item {
  position: relative;
  overflow: visible;
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  gap: 1.8rem;
}

.story-thumb-link {
  display: block;
  text-decoration: none;
  color: inherit;
}

button.story-thumb-link {
  appearance: none;
  border: none;
  padding: 0;
  margin: 0;
  width: 100%;
  font: inherit;
  text-align: inherit;
  cursor: pointer;
  background: transparent;
}

.story-thumb-link:hover .story-play-btn {
  opacity: 1;
  transform: translate(-50%, -50%) scale(1.1);
}

.story-thumb-image-wrap {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 12px;
}

.story-grid-item img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
  object-fit: cover;
  aspect-ratio: 16 / 10;
  border-radius: 12px;
  transition: transform 0.28s ease, filter 0.28s ease;
}

.story-thumb-link:hover .story-grid-item img,
.story-thumb-link:hover img {
  transform: scale(1.06);
  filter: brightness(1.14);
}


.story-play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: transparent;
  border: calc(2px * 1.6) solid #ffffff;
  opacity: 0.9;
  transition: opacity 0.2s, transform 0.2s;
  box-sizing: border-box;
}

.story-play-btn::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-40%, -50%);
  border-style: solid;
  border-width: 9px 0 9px 15px;
  border-color: transparent transparent transparent #fff;
}


.story-thumb-caption {
  margin: 0.5rem 0 0;
  font-size: 0.9rem;
  font-weight: 500;
  color: #374151;
  text-align: center;
  line-height: 1.4;
}

.story-story-btn {
  margin: 0;
  padding: 0.52rem 0.6rem;
  font-size: 0.9rem;
  font-weight: 600;
  color: #ffffff;
  text-align: center;
  line-height: 1.4;
  display: block;
  width: 100%;
  border: 1px solid rgba(255, 255, 255, 0.9);
  background: #000000;
  cursor: pointer;
  font-family: inherit;
  border-radius: 6px;
  transform: translateY(0) scale(1);
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.story-story-btn:hover {
  background: #ffffff;
  color: #000000;
  border-color: #ffffff;
  transform: translateY(-2px) scale(1.04);
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.25);
  text-decoration: none;
}

.story-section {
  padding: 0.5rem 0 3.25rem;
  background-color: #f3f4f6;
}

.story-heading {
  margin: 0 auto;
  max-width: 1120px;
  padding: 0 1.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  color: #111827;
}

.story-background-wrap {
  background-color: #e5e7eb;
}

.story-background-inner {
  position: relative;
  max-width: 1120px;
  margin: 0 auto;
}

.story-background-image {
  display: block;
  width: 100%;
  height: auto;
}

.story-thumbs-grid {
  position: absolute;
  inset: 10% 6%;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-auto-rows: auto;
  gap: 0.9rem;
}

.story-thumb img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 0.5rem;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.18);
}


.story-thumb-1,
.story-thumb-2 {
  align-self: stretch;
}

.story-thumb-3,
.story-thumb-4 {
  margin-top: 0.2rem;
}

@media (max-width: 768px) {
  .story-section {
    padding: 0.5rem 0 2.75rem;
  }
  .story-thumbs-grid {
    position: static;
    padding: 1rem 1.25rem 1.5rem;
    grid-template-columns: 1fr;
  }
  .story-background-inner {
    padding: 0;
  }
  .story-background-image {
    display: none;
  }
}


.consulting-group-photo-section {
  margin-top: 0;
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 6;
  overflow: hidden;
  background: #000000;
}

.consulting-group-photo-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
  opacity: 0;
  /* 페이드 인·아웃 동일 시간·대칭 곡선 — 지속(ms)은 js/hero-rotation-config.js crossfadeMs 와 동기화 */
  transition: opacity var(--hero-crossfade-duration, 0.75s) ease-in-out;
  will-change: opacity;
}

.consulting-group-photo-bg-fill,
.consulting-group-photo-bg-main {
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  pointer-events: none;
}


.consulting-group-photo-bg-fill {
  display: none;
  z-index: 0;
}

.consulting-group-photo-bg--blur-fill .consulting-group-photo-bg-fill {
  display: block;
  background-position: center top;
  background-size: cover;
  transform: scale(1.08);
  filter: blur(32px);
  opacity: 0.88;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.consulting-group-photo-bg-main {
  z-index: 1;
  background-position: center top;
  background-size: 75% auto;
}

.consulting-group-photo-bg.is-active {
  opacity: 1;
}

.consulting-group-photo-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0.44);
  pointer-events: none;
}

.consulting-group-photo-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  transform: translateY(-6%);
}

.consulting-group-photo-title {
  margin: 0;
  color: #ffffff;
  font-family: "TimesNewerRomanBold", "Times New Roman", Times, serif;
  font-size: clamp(36px, 5.5vw, 72px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
}

.consulting-group-photo-dots {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  padding: 0 1rem 1rem;
  pointer-events: auto;
  box-sizing: border-box;
}

.consulting-group-photo-dot {
  flex-shrink: 0;
  box-sizing: border-box;
  width: 8px;
  height: 8px;
  padding: 0;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  background: rgba(255, 255, 255, 0.42);
  transition: background-color 0.2s ease;
}

.consulting-group-photo-dot:hover {
  background: rgba(255, 255, 255, 0.72);
}

.consulting-group-photo-dot.is-current {
  background: #ffffff;
}

.consulting-group-photo-dot:focus {
  outline: none;
}

.consulting-group-photo-dot:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

@media (max-width: 768px) {
  .consulting-group-photo-section {
    aspect-ratio: 4 / 2.6;
  }

  
  .consulting-group-photo-bg-fill,
  .consulting-group-photo-bg--blur-fill .consulting-group-photo-bg-fill {
    display: none;
  }

  .consulting-group-photo-bg-main {
    background-size: cover;
    background-position: center top;
  }

  .consulting-group-photo-dots {
    padding-bottom: 0.75rem;
    gap: 0.48rem;
  }

  .consulting-group-photo-dot {
    width: 8px;
    height: 8px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .consulting-group-photo-bg {
    transition: opacity 0.01ms;
  }
}

.consulting-main .consulting-group-photo-content {
  transform: translateY(-5%);
}

.consulting-main .consulting-group-photo-dots {
  padding: 0 1rem 0.8rem;
}

.testimonials-main .consulting-group-photo-dots {
  padding: 0 1rem 0.65rem;
}

.testimonials-main .testimonials-hero-wrap > .consulting-group-photo-dots {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  margin-top: 0.24rem;
  padding: 0 0 3.8rem;
}

@media (max-width: 768px) {
  .consulting-main .consulting-group-photo-dots {
    padding: 0 1rem 0.65rem;
  }

  .testimonials-main .consulting-group-photo-dots {
    padding: 0 1rem 0.5rem;
  }

  .testimonials-main .testimonials-hero-wrap > .consulting-group-photo-dots {
    padding: 0 0 0.7rem;
  }
}

.corporate-education-main .consulting-group-photo-dot {
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.75);
}

.corporate-education-main .consulting-group-photo-dot.is-current {
  background: #ffffff;
  border-color: #ffffff;
}

.corporate-education-hero .consulting-group-photo-bg-fill,
.corporate-education-hero .consulting-group-photo-bg--blur-fill .consulting-group-photo-bg-fill {
  display: none !important;
}

.corporate-education-hero .consulting-group-photo-bg-main {
  background-size: cover;
  background-position: center center;
}


.about-group-photo-section {
  margin-top: var(--header-height);
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 7;
  overflow: hidden;
  background: #000000 url("../assets/전체 멤버 사진 샘플.webp") center center / cover no-repeat;
  animation: community-maria-hero-fade-in 0.75s ease-out both;
}

.about-group-photo-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.52);
}

.about-group-photo-content {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  z-index: 1;
}

.about-group-photo-title {
  margin: 0;
  color: #ffffff;
  font-family: "TimesNewerRomanBold", "Times New Roman", Times, serif;
  font-size: clamp(36px, 5.5vw, 72px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  text-transform: none;
}

@media (max-width: 768px) {
  .about-group-photo-section {
    aspect-ratio: 4 / 3;
  }
}


.about-copy-section {
  background: #111111;
  padding: 3.6rem 0 4rem;
  text-align: center;
}

.about-copy-title {
  margin: 0 0 2rem;
  font-size: 2rem;
  line-height: 1.2;
  font-weight: 700;
  color: var(--color-primary);
}

.about-copy-body {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1rem, 1.66vw, 1.1rem);
  line-height: 2.18;
}

.about-copy-slogan {
  margin: 1.85rem 0 0;
  color: var(--branding-color-2);
  font-size: clamp(1.24rem, 2vw, 1.68rem);
  font-weight: 800;
  line-height: 1.45;
}


.about-map-section {
  margin-top: 2.5rem;
  padding: 0 0 3rem;
}

.about-map-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
  align-items: stretch;
}

.about-map-left {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
}

.about-contact-card {
  width: 100%;
  min-height: 560px;
  border-radius: 12px;
  border: 1px solid rgba(148, 163, 184, 0.35);
  background: #ffffff;
  padding: 2.15rem 1.75rem;
  box-sizing: border-box;
}

.about-contact-title {
  margin: 0 0 1.5rem;
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  color: #0f172a;
}

.about-contact-dl {
  margin: 0;
}

.about-contact-row {
  display: grid;
  grid-template-columns: 8.6rem 1rem 1fr;
  gap: 0.45rem;
  align-items: start;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(148, 163, 184, 0.25);
}

.about-contact-row:last-child {
  border-bottom: none;
}

.about-contact-row dt,
.about-contact-row dd {
  margin: 0;
  line-height: 1.55;
  color: #111827;
}

.about-contact-row dt {
  margin: 0;
  font-weight: 700;
}

.about-map-right {
  overflow: hidden;
  border-radius: 12px;
}

.about-map-iframe {
  display: block;
  width: 100%;
  min-height: 560px;
  height: 100%;
  border: 0;
}

.about-map-image {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

@media (max-width: 768px) {
  .about-map-grid {
    grid-template-columns: 1fr;
  }

  .about-contact-card {
    min-height: auto;
    padding: 1.5rem 1.1rem;
  }

  .about-contact-title {
    font-size: 1.36rem;
    margin-bottom: 1.25rem;
  }

  .about-contact-row {
    grid-template-columns: 6.8rem 0.8rem 1fr;
    gap: 0.35rem;
    padding: 0.78rem 0;
  }

  .about-map-iframe {
    min-height: 340px;
  }
}


.about-services-section {
  margin-top: 0;
  padding: 4.25rem 0 3.9rem;
  background-color: #000000;
}

.about-services-buttons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.15rem;
  max-width: 920px;
  margin: 0 auto;
}

.about-services-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.85rem 1rem;
  width: 100%;
}

.about-service-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 9rem;
  min-height: 2.5rem;
  padding: 0.4rem 0.55rem;
  box-sizing: border-box;
  border: 2px solid rgba(255, 255, 255, 0.95);
  border-radius: 10px;
  background-color: transparent;
  color: #ffffff;
  font-weight: 600;
  font-size: 0.82rem;
  text-decoration: none;
  text-align: center;
  line-height: 1.3;
  font-family: inherit;
  cursor: default;
  user-select: none;
  transition:
    border-color 0.22s ease,
    color 0.22s ease,
    background-color 0.22s ease,
    transform 0.22s ease,
    box-shadow 0.22s ease;
}

a.about-service-btn {
  cursor: pointer;
}


button.about-service-btn:hover {
  background-color: transparent;
  border-color: rgba(255, 255, 255, 0.95);
  color: #ffffff;
  transform: none;
  box-shadow: none;
}


a.about-service-btn:hover {
  background-color: #ffffff;
  color: #111111;
  border-color: #ffffff;
  transform: translateY(-4px);
  box-shadow: 0 8px 22px rgba(0, 0, 0, 0.38);
}


a.about-service-btn[href*="greetinghr.com/ko/home"] {
  background-color: #ffffff;
  color: #111111;
  border-color: #ffffff;
}

a.about-service-btn[href*="greetinghr.com/ko/home"]:hover {
  background-color: #000000;
  color: #ffffff;
  border-color: #ffffff;
}

@media (prefers-reduced-motion: reduce) {
  a.about-service-btn:hover {
    transform: none;
  }
}

.about-service-btn:focus {
  outline: none;
}

.about-service-btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 3px;
}

.about-services-tagline {
  margin: 2.05rem 0 0;
  padding: 0 0.5rem;
  text-align: center;
  color: #ffffff;
  font-size: 1.05rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: -0.01em;
  text-decoration: underline;
  text-decoration-color: rgba(255, 255, 255, 0.92);
  text-underline-offset: 0.22em;
  text-decoration-thickness: 1px;
}

@media (max-width: 768px) {
  .about-services-section {
    padding: 3.5rem 0 3.15rem;
  }

  .about-services-tagline {
    margin-top: 1.7rem;
    font-size: 0.95rem;
    text-underline-offset: 0.2em;
  }

  .about-services-buttons {
    gap: 0.95rem;
  }

  .about-services-row {
    flex-wrap: nowrap;
    gap: 0.65rem;
  }

  .about-service-btn {
    flex: 1 1 0;
    min-width: 0;
    width: auto;
    max-width: none;
    min-height: 2.35rem;
    font-size: clamp(0.62rem, 2.6vw, 0.78rem);
    padding: 0.35rem 0.28rem;
  }
}


.consulting-dashboard-section {
  position: relative;
  min-height: 420px;
  margin-top: -2.4rem;
  padding: 0 0 0;
  background-color: #000000;
}

.dashboard-bg {
  position: absolute;
  inset: 0;
  background: #000000;
}

.dashboard-overlay {
  position: absolute;
  inset: 0;
  background: transparent;
  pointer-events: none;
}

.dashboard-content {
  position: relative;
  z-index: 1;
  color: #ffffff;
  padding-top: 4.75rem;
  padding-bottom: 3.25rem;
}

@media (max-width: 768px) {
  .consulting-dashboard-section {
    margin-top: -1.5rem;
    padding: 2rem 0 3rem;
  }
}


.corporate-education-dashboard-section.consulting-dashboard-section {
  min-height: 0;
  margin-top: 0;
  margin-bottom: 0;
  padding: 0;
}

.corporate-education-main .corporate-education-hero-dots-section {
  margin: 0;
  padding: clamp(0.5rem, 1.2vw, 0.85rem) 0 clamp(0.75rem, 1.8vw, 1.25rem);
  background: #000000;
}

.corporate-education-main .corporate-education-hero-dots-section .consulting-group-photo-dots {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  margin: 0;
  padding: 0;
}

.corporate-education-main .corporate-education-dashboard-section.consulting-dashboard-section {
  min-height: clamp(18rem, 34.5vw, 24.75rem);
}

.corporate-education-main .corporate-education-dashboard-section.consulting-dashboard-section > .container {
  min-height: inherit;
  display: flex;
  align-items: center;
}

.corporate-education-dashboard-content.dashboard-content {
  width: 100%;
  padding-top: clamp(2rem, 3.6vw, 2.8rem);
  padding-bottom: clamp(2rem, 3.6vw, 2.8rem);
}


.corporate-education-dashboard-grid {
  --ced-label-size: clamp(0.95rem, 0.85vw + 0.75rem, 1.12rem);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: auto auto;
  column-gap: clamp(0.75rem, 2vw, 1.5rem);
  row-gap: clamp(1.25rem, 2.5vw, 2rem);
  max-width: 1100px;
  margin: 0 auto;
  text-align: center;
  font-family: var(--font-pretendard-static);
}

.corporate-education-dashboard-cell {
  color: #ffffff;
  min-width: 0;
}

.corporate-education-dashboard-cell--label {
  font-size: var(--ced-label-size);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.02em;
  padding: 0 0.35rem;
  align-self: end;
}

.corporate-education-dashboard-cell--value {
  font-size: calc(var(--ced-label-size) * 2.3);
  font-weight: 900;
  line-height: 1.12;
  letter-spacing: -0.03em;
  padding: 0 0.25rem;
  align-self: start;
}

.corporate-education-dashboard-cell--value[data-corporate-education-stat="cumulative-learners"] {
  color: var(--branding-color-2);
}

@media (max-width: 768px) {
  .corporate-education-dashboard-section.consulting-dashboard-section {
    margin-top: 0;
    margin-bottom: 0;
    min-height: clamp(16.5rem, 61.5vw, 22.5rem);
    padding: 0;
  }

  .corporate-education-main .corporate-education-hero-dots-section {
    padding: clamp(0.4rem, 1vw, 0.65rem) 0 clamp(0.55rem, 1.5vw, 0.95rem);
  }

  .corporate-education-dashboard-content.dashboard-content {
    padding-top: clamp(1.6rem, 4vw, 2.25rem);
    padding-bottom: clamp(1.6rem, 4vw, 2.25rem);
  }

  .corporate-education-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(4, auto);
    row-gap: clamp(1rem, 3vw, 1.5rem);
  }

  .corporate-education-dashboard-cell--label {
    align-self: center;
  }

  .corporate-education-dashboard-cell--value {
    align-self: center;
  }
}


.corporate-education-differentiation-section {
  margin-top: 0;
  padding-top: 0;
  background-color: #000000;
  color: #ffffff;
}

.corporate-education-differentiation-section .container {
  padding-top: 0;
  padding-bottom: clamp(2.5rem, 5vw, 4rem);
}

.corporate-education-differentiation-container {
  display: grid;
  grid-template-rows: auto auto;
  row-gap: clamp(2.4rem, 4.8vw, 3.84rem);
}

.corporate-education-differentiation-title {
  margin: 0;
  text-align: center;
  font-size: calc(clamp(1.45rem, 2.4vw, 1.95rem) * 0.75);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #ffffff;
  line-height: 1.35;
}

.corporate-education-differentiation-top {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(0.35rem, 0.75vw, 0.55rem);
}

.corporate-education-differentiation-point {
  position: relative;
  z-index: 0;
  margin: 0;
  min-height: clamp(12rem, 17vw, 15rem);
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 10px;
  display: grid;
  grid-template-rows: auto auto auto;
  align-content: center;
  justify-items: center;
  row-gap: clamp(1.25rem, 2.6vw, 1.9rem);
  text-align: center;
  padding: 0.65rem 0.5rem;
  color: #ffffff;
  font-size: calc(clamp(0.76rem, 0.65vw + 0.52rem, 0.9rem) * 1.1);
  font-weight: 600;
  line-height: 1.38;
  transform: scale(1);
  transform-origin: center;
  transition:
    transform 0.28s ease,
    background-color 0.28s ease,
    color 0.28s ease,
    border-color 0.28s ease,
    box-shadow 0.28s ease;
}

.corporate-education-differentiation-point:hover {
  z-index: 2;
  transform: scale(1.06);
  background: #ffffff;
  color: #000000;
  border-color: rgba(0, 0, 0, 0.18);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.18);
}

.corporate-education-differentiation-point:hover .corporate-education-differentiation-point-num {
  color: #ffffff;
  background: var(--branding-color-1);
  box-shadow: 0 2px 8px rgba(0, 94, 255, 0.35);
}

.corporate-education-differentiation-point:hover .corporate-education-differentiation-point-title {
  color: #000000;
}

.corporate-education-differentiation-point:hover .corporate-education-differentiation-point-body {
  color: #000000;
}

.corporate-education-differentiation-point:hover .corporate-education-differentiation-point-body-em {
  color: #000000;
}

@media (prefers-reduced-motion: reduce) {
  .corporate-education-differentiation-point {
    transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  }

  .corporate-education-differentiation-point:hover {
    transform: none;
  }
}


.corporate-education-differentiation-top .corporate-education-differentiation-point {
  padding-top: clamp(1.35rem, 2.6vw, 1.9rem);
  padding-bottom: clamp(0.25rem, 0.65vw, 0.5rem);
}

.corporate-education-differentiation-point-num {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.65rem;
  height: 1.65rem;
  padding: 0 0.28rem;
  border-radius: 7px;
  font-size: 0.72rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  line-height: 1;
  color: #000000;
  background: var(--branding-color-2);
  box-shadow: 0 2px 8px rgba(142, 255, 0, 0.35);
  justify-self: center;
  align-self: center;
}

.corporate-education-differentiation-point-title {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  font-size: calc(clamp(0.88rem, 0.75vw + 0.52rem, 1.05rem) * 1.1);
  line-height: 1.28;
  width: 100%;
}

.corporate-education-differentiation-point-body {
  display: block;
  margin: 0;
  width: 100%;
  align-self: center;
  text-align: center;
  line-height: 1.4;
}

.corporate-education-differentiation-point-body-em {
  font-weight: 800;
  color: #bfdbfe;
  letter-spacing: -0.02em;
}

.corporate-education-differentiation-bottom {
  width: 100%;
  margin-top: clamp(0.85rem, 1.8vw, 1.5rem);
}

.corporate-education-differentiation-image {
  display: block;
  width: 100%;
  height: auto;
  object-fit: cover;
  border-radius: 12px;
}

@media (max-width: 768px) {
  .corporate-education-differentiation-top {
    grid-template-columns: 1fr;
  }
}


.corporate-education-voc-section {
  background: #000000;
  color: #ffffff;
  padding: clamp(2.25rem, 4.5vw, 3.25rem) 0 clamp(3rem, 5vw, 4.2rem);
}

.corporate-education-voc-section-title {
  margin: 0 0 clamp(1.35rem, 2.8vw, 2rem);
  text-align: center;
  font-size: calc(clamp(1.45rem, 2.4vw, 1.95rem) * 0.75);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #ffffff;
  line-height: 1.35;
}

.corporate-education-voc-grid {
  --voc-card-gap: clamp(0.45rem, 1.2vw, 0.75rem);
  --voc-template-width: clamp(14.99rem, 22.68vw, 19.04rem);
  margin-top: clamp(1.95rem, 3.9vw, 2.99rem);
  overflow-x: hidden;
  overflow-y: visible;
  width: 100%;
  position: relative;
  z-index: 1;
}

.corporate-education-voc-flow-track {
  display: flex;
  gap: var(--voc-card-gap);
  width: max-content;
  animation: corporate-education-voc-flow-right 90s linear infinite;
  will-change: transform;
}

.corporate-education-voc-grid:hover .corporate-education-voc-flow-track {
  animation-play-state: paused;
}

.corporate-education-voc-flow-template-card {
  --voc-template-padding: clamp(0.72rem, 1.25vw, 0.96rem);
  --voc-template-min-height: clamp(17.8rem, 32.6vw, 23.8rem);
  --voc-template-gap: clamp(0.55rem, 1vw, 0.75rem);
  --voc-template-image-width: 91.1%;
  --voc-template-image-ratio: 16 / 8.2;
  --voc-template-image-margin-bottom: 0.715rem;
  width: var(--voc-template-width);
  min-width: var(--voc-template-width);
  max-width: var(--voc-template-width);
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 12px;
  background: #111111;
  box-sizing: border-box;
  padding: var(--voc-template-padding);
  min-height: var(--voc-template-min-height);
  display: flex;
  flex-direction: column;
  gap: var(--voc-template-gap);
  position: relative;
  z-index: 1;
  transform: translateY(0) scale(1);
  transition:
    transform 0.25s ease,
    background-color 0.25s ease,
    border-color 0.25s ease,
    box-shadow 0.25s ease;
}

.corporate-education-voc-flow-template-tag {
  margin: 0;
  color: rgba(241, 245, 249, 0.9);
  font-size: clamp(0.72rem, 0.84vw + 0.4rem, 0.9rem);
  font-weight: 600;
  line-height: 1.3;
  transition: color 0.25s ease;
}

.corporate-education-voc-flow-template-image-frame {
  width: var(--voc-template-image-width);
  margin: 0 auto var(--voc-template-image-margin-bottom);
  aspect-ratio: var(--voc-template-image-ratio);
  overflow: hidden;
  border-radius: 9px;
}

.corporate-education-voc-flow-template-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.corporate-education-voc-flow-template-text {
  margin: 0;
  width: var(--voc-template-image-width);
  margin-left: auto;
  margin-right: auto;
  flex: 1;
  display: block;
  padding-top: clamp(0.75rem, 1.4vw, 1rem);
  color: #ffffff;
  font-size: calc(clamp(0.78rem, 0.9vw + 0.36rem, 0.95rem) * 1.03);
  line-height: 1.55;
  text-align: justify;
  text-align-last: left;
  text-justify: inter-character;
  word-break: break-all;
  overflow-wrap: anywhere;
  transition: color 0.25s ease;
}

.corporate-education-voc-flow-template-card:hover {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.2);
  transform: translateY(0) scale(1);
  box-shadow: none;
}

.corporate-education-voc-flow-template-card:hover .corporate-education-voc-flow-template-tag,
.corporate-education-voc-flow-template-card:hover .corporate-education-voc-flow-template-text {
  color: #111111;
}

@keyframes corporate-education-voc-flow-right {
  from {
    transform: translateX(calc(-1 * ((12 * var(--voc-template-width)) + (12 * var(--voc-card-gap)))));
  }
  to {
    transform: translateX(0);
  }
}

.corporate-education-voc-card {
  margin: 0;
  min-height: clamp(5.8rem, 11vw, 7.2rem);
  perspective: 1200px;
}

.corporate-education-voc-card-inner {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: inherit;
  transform-style: preserve-3d;
  transform: translateY(0) scale(1) rotateY(0deg);
  transition: transform 0.8s cubic-bezier(0.22, 0.78, 0.2, 1), box-shadow 0.8s cubic-bezier(0.22, 0.78, 0.2, 1);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

.corporate-education-voc-card:hover .corporate-education-voc-card-inner {
  transform: translateY(-0.28rem) scale(1.03) rotateY(180deg);
  box-shadow: 0 0.7rem 1.5rem rgba(0, 0, 0, 0.3);
}

.corporate-education-voc-face {
  position: absolute;
  inset: 0;
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 10px;
  padding: clamp(0.65rem, 1.3vw, 0.95rem);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: clamp(0.73rem, 0.77vw + 0.41rem, 0.87rem);
  line-height: 1.4;
  word-break: break-all;
  overflow-wrap: anywhere;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.corporate-education-voc-face--front {
  background: #000000;
  color: #ffffff;
}

.corporate-education-voc-face--back {
  background: #ffffff;
  color: #111111;
  border-color: rgba(15, 23, 42, 0.25);
  transform: rotateY(180deg);
}

.corporate-education-voc-section .corporate-education-voc-photos.community-testimony-photos {
  margin-top: clamp(3.1rem, 5.6vw, 4.4rem);
}


.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section {
  margin-top: 0;
  background: #000000;
  padding-top: clamp(0.65rem, 1.4vw, 1.1rem);
  padding-bottom: clamp(3.25rem, 6vw, 4.75rem);
  transform: translateY(0) scale(1);
  transition: transform 0.42s cubic-bezier(0.22, 0.78, 0.2, 1), box-shadow 0.42s cubic-bezier(0.22, 0.78, 0.2, 1);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0);
  will-change: transform, box-shadow;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover {
  background: #ffffff;
  transform: translateY(-0.35rem) scale(1.008);
  box-shadow: 0 1rem 2rem rgba(255, 255, 255, 0.06);
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-title {
  color: #ffffff;
  opacity: 1;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-title-block {
  margin-top: 0;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-greeting,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-text,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-line,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-chunk--signature .community-maria-summary-line {
  color: #ffffff;
  opacity: 1;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-line strong {
  color: #f3f4f6;
  font-weight: 800;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-title,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-greeting,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-summary-text,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-summary-line,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-chunk--signature .community-maria-summary-line {
  color: #000000;
  opacity: 1;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section:hover .community-maria-summary-line strong {
  color: #000000;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-cell--right {
  min-width: 0;
  padding-top: clamp(2.5rem, 5vw, 3.75rem);
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-greeting--summary {
  margin-top: clamp(2.15rem, 4.2vw, 3.15rem);
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-title,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-greeting,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-text,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-chunk,
.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-line {
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-summary-text {
  overflow-x: visible;
  max-width: 100%;
}


.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-grid {
  align-items: stretch;
}

.corporate-education-main .corporate-education-greeting-section.consulting-representative-greeting.community-maria-section .community-maria-cell--left {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  align-items: center;
}


.corporate-education-intro-section {
  background: #000000;
  padding: clamp(2.5rem, 5vw, 3.75rem) 0 clamp(2rem, 4vw, 3rem);
}

.corporate-education-intro-title {
  margin: 0;
  text-align: center;
  font-size: calc(clamp(1.45rem, 2.4vw, 1.95rem) * 0.75);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #ffffff;
  line-height: 1.3;
}

.corporate-education-intro-block {
  margin-top: clamp(2.1rem, 4.4vw, 3.4rem);
}

.corporate-education-intro-block-title {
  margin: 0;
  padding-left: 0.65rem;
  text-align: left;
  color: #ffffff;
  font-size: calc(clamp(1.1rem, 1.4vw + 0.75rem, 1.45rem) * 0.82);
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.02em;
  position: relative;
}

.corporate-education-intro-block-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 3.4px;
  height: 80%;
  background: #ffffff;
  transform: translateY(-50%);
}

.corporate-education-intro-items {
  margin-top: clamp(0.8rem, 1.8vw, 1.25rem);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(0.85rem, 1.8vw, 1.4rem);
}


.corporate-education-workshop-carousel {
  position: relative;
  margin-top: clamp(0.8rem, 1.8vw, 1.25rem);
}

.corporate-education-workshop-viewport {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.corporate-education-workshop-viewport::-webkit-scrollbar {
  display: none;
}

.corporate-education-intro-items.corporate-education-intro-items--workshop {
  display: flex;
  flex-wrap: nowrap;
  align-items: stretch;
  margin-top: 0;
  gap: clamp(0.85rem, 1.8vw, 1.4rem);
  width: max-content;
  min-width: 100%;
}

.corporate-education-intro-items--workshop .corporate-education-intro-item {
  min-width: 0;
}


.corporate-education-workshop-carousel .community-testimony-nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  cursor: pointer;
  pointer-events: auto;
}

.corporate-education-workshop-carousel .community-testimony-nav:hover:not(:disabled) {
  transform: translate(-70%, calc(-50% - 1.1rem));
}

.corporate-education-workshop-carousel .community-testimony-nav:disabled {
  opacity: 0.35;
  cursor: not-allowed;
}

.corporate-education-workshop-carousel .community-testimony-nav[hidden] {
  display: none;
}

.corporate-education-workshop-carousel .community-testimony-nav--prev {
  left: 0;
  transform: translate(-70%, calc(-50% - 1.1rem));
}

.corporate-education-workshop-carousel .community-testimony-nav--next {
  right: 0;
  transform: translate(70%, calc(-50% - 1.1rem));
}

.corporate-education-workshop-carousel .community-testimony-nav--next:hover:not(:disabled) {
  transform: translate(70%, calc(-50% - 1.1rem));
}

.corporate-education-intro-item {
  margin: 0;
  min-width: 0;
}

.corporate-education-intro-media {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.28);
  background: #0f172a;
  aspect-ratio: 16 / 10;
}

.corporate-education-intro-image {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 1;
  transition: opacity 0.36s ease;
}

.corporate-education-intro-overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  padding: clamp(0.75rem, 1.6vw, 1.1rem);
  background: #000000;
  color: #ffffff;
  opacity: 0;
  transform: scale(0.96);
  transform-origin: center center;
  transition: opacity 0.36s ease, transform 0.36s ease;
}

.corporate-education-intro-overlay-content {
  width: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: auto auto auto auto;
  align-items: stretch;
  padding-top: clamp(0.28rem, 0.7vw, 0.5rem);
}

.corporate-education-intro-tags {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.corporate-education-intro-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.22rem 0.5rem;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.14);
  color: #ffffff;
  font-size: calc(0.756rem * 1.2 * 1.05);
  font-weight: 700;
  line-height: 1;
}

.corporate-education-intro-overlay-text {
  margin: 0 0 -0.08rem;
  align-self: center;
  text-align: center;
  font-size: calc(clamp(0.84rem, 0.82vw + 0.48rem, 0.97rem) * 0.9 * 1.2 * 1.05);
  font-weight: 700;
  line-height: 1.52;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.corporate-education-intro-overview-container,
.corporate-education-intro-target-container,
.corporate-education-intro-meta-container {
  width: 100%;
}

.corporate-education-intro-target-container {
  margin-top: clamp(1.4rem, 3vw, 2.2rem);
}


.corporate-education-intro-items--workshop .corporate-education-intro-item[data-admin-item-key="workshop-2"] .corporate-education-intro-target-container {
  margin-top: clamp(0.85rem, 2.2vw, 1.55rem);
}

.corporate-education-intro-overview-container {
  margin-top: clamp(1.35rem, 3.1vw, 2.1rem);
}

.corporate-education-intro-meta-container {
  margin-top: clamp(0.85rem, 1.9vw, 1.4rem);
}

.corporate-education-intro-target {
  margin: 0.02rem 0 0;
  padding-left: clamp(1.35rem, 2.5vw, 2.1rem);
  text-align: left;
  font-size: calc(clamp(0.74rem, 0.62vw + 0.42rem, 0.85rem) * 0.9 * 1.2 * 1.05);
  line-height: 1.35;
  color: #e5e7eb;
  word-break: break-all;
  overflow-wrap: anywhere;
}

.corporate-education-intro-meta {
  margin: 0.55rem 0 0;
  text-align: center;
  font-size: calc(clamp(0.72rem, 0.62vw + 0.43rem, 0.82rem) * 0.9 * 1.2 * 1.05);
  line-height: 1.35;
  color: #cbd5e1;
}

.corporate-education-intro-media:hover .corporate-education-intro-image {
  opacity: 0;
}

.corporate-education-intro-media:hover .corporate-education-intro-overlay {
  opacity: 1;
  transform: scale(1);
}

/* 교육 종료(Admin): 썸네일 위 고투명 검정 틴트(z-index 2). 상세 오버레이(3)가 호버 시 그 위로 표시됨 */
.corporate-education-intro-ended-panel {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  text-align: center;
  padding: 0.75rem;
  pointer-events: none;
  box-sizing: border-box;
}

.corporate-education-intro-ended-shade {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.48);
  border-radius: 0;
}

.corporate-education-intro-ended-text {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 12.5em;
  color: #ffffff;
  font-size: calc(clamp(0.8rem, 0.9vw + 0.4rem, 0.95rem) * 1.15);
  font-weight: 800;
  line-height: 1.4;
  letter-spacing: -0.03em;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

.corporate-education-intro-link {
  margin-top: clamp(0.95rem, 2.2vw, 1.15rem);
  display: table;
  margin-left: auto;
  margin-right: auto;
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 0.14em;
  font-size: calc(0.702rem * 1.1 * 1.05);
  font-weight: 500;
  line-height: 1;
  transition: color 0.22s ease, opacity 0.22s ease;
}

.corporate-education-intro-link:hover {
  color: #e2e8f0;
  opacity: 0.9;
}

.corporate-education-intro-cta-wrap {
  margin-top: clamp(2.4rem, 4.4vw, 3.5rem);
  display: flex;
  justify-content: center;
}

.corporate-education-intro-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: clamp(9rem, 14.4vw, 10.98rem);
  padding: 0.7rem 1.26rem;
  border-radius: 12px;
  background: var(--branding-color-2);
  color: #000000;
  text-decoration: none;
  font-size: clamp(0.828rem, 0.72vw + 0.432rem, 0.9rem);
  font-weight: 700;
  line-height: 1;
  border: 2px solid transparent;
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    opacity 0.22s ease,
    background-color 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease;
}

.corporate-education-intro-cta:hover {
  transform: translateY(-1px) scale(1.04);
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
  box-shadow: 0 8px 16px rgba(0, 94, 255, 0.28);
  opacity: 0.98;
}

.corporate-education-calendar-section {
  background: #000000;
  padding: clamp(2.2rem, 4.5vw, 3.4rem) 0 clamp(2.4rem, 5vw, 3.8rem);
}

.corporate-education-calendar-title {
  margin: 0;
  text-align: left;
  font-size: calc(clamp(1.45rem, 2.4vw, 1.95rem) * 0.75);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: #ffffff !important;
  line-height: 1.3;
  transform: translateY(-0.28rem);
}

.corporate-education-calendar-section .community-calendar-title::before {
  content: none;
}

.corporate-education-calendar-section .community-calendar-title {
  margin: 1.2rem 0 0.48rem;
  padding-left: 0.65rem;
}

.corporate-education-calendar-section .community-calendar-guide {
  margin: 0 0 2.75rem;
  padding-left: 0.65rem;
  font-size: clamp(0.78rem, 1vw, 0.9rem);
  font-weight: 500;
  line-height: 1.4;
  color: rgba(209, 213, 219, 0.92);
  letter-spacing: -0.02em;
}

/* 커뮤니티 페이지: 캘린더 부제를 제목 바로 아래에 두고 표와 간격 둠 (기업교육 캘린더와 동일) */
.community-main .community-calendar-section .community-calendar-title {
  margin: 1.2rem 0 0.48rem;
  padding-left: 0.65rem;
}

.community-main .community-calendar-section .community-calendar-guide {
  margin: 0 0 2.75rem;
  padding-left: 0.65rem;
  font-size: clamp(0.78rem, 1vw, 0.9rem);
  font-weight: 500;
  line-height: 1.4;
  color: rgba(209, 213, 219, 0.92);
  letter-spacing: -0.02em;
}

.corporate-education-calendar-section .community-calendar-cell--program {
  align-items: center;
  text-align: center;
  padding: 0.46rem 0.52rem;
}

.corporate-education-calendar-section .community-calendar-row:not(.community-calendar-row--head) {
  min-height: 54px;
}

.corporate-education-calendar-section .community-calendar-cell {
  min-height: 38px;
  padding: 0.36rem 0.24rem;
  gap: 0;
}

.corporate-education-calendar-section .community-calendar-row:not(.community-calendar-row--head) .community-calendar-cell {
  min-height: 54px;
}

.corporate-education-calendar-section .community-calendar-row--head .community-calendar-cell {
  min-height: 24px;
  padding: 0.25rem 0.2rem;
}

.corporate-education-calendar-section .community-calendar-program-title {
  font-size: 0.82rem;
  font-weight: 700;
}


.corporate-education-calendar-section .community-calendar-cell .community-calendar-pill {
  margin: 0;
}

.corporate-education-calendar-section .community-calendar-cell .community-calendar-pill + .community-calendar-pill {
  margin-top: 0;
}


.corporate-education-calendar-section .community-calendar-pill,
.corporate-education-calendar-section .community-calendar-pill--btn {
  background: transparent;
  border: 0;
  border-color: transparent;
  border-radius: 0;
  min-width: 0;
  padding: 0;
  color: #dbeafe;
  line-height: 1;
}

.corporate-education-calendar-section .community-calendar-pill--btn:hover {
  background: transparent;
  border-color: transparent;
  color: #dbeafe;
}

.corporate-education-calendar-image {
  display: block;
  margin: clamp(1.7rem, 3.2vw, 2.6rem) auto 0;
  width: min(100%, 78rem);
  height: auto;
  border-radius: 12px;
}

@media (max-width: 900px) {
  .corporate-education-intro-items:not(.corporate-education-intro-items--workshop) {
    grid-template-columns: 1fr;
  }

}



.consulting-bu-leader-section {
  margin-top: 3.5rem;
  padding: 3rem 0 5rem;
  background: #000000;
  overflow-x: clip;
}

.consulting-bu-leader-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 440px);
  gap: 3.5rem 3.5rem;
  align-items: stretch;
  padding: 1rem 0 0;
  transition: transform 0.45s cubic-bezier(0.22, 0.78, 0.2, 1);
  transform-origin: center center;
}

.consulting-bu-leader-text {
  min-width: 0;
  text-align: left;
  padding: 0.75rem 1.5rem 0.75rem 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: clamp(3.5rem, 8vh, 5.5rem);
  min-height: 100%;
}

.consulting-bu-leader-title {
  margin: clamp(-0.55rem, -1vw, -0.25rem) 0 0;
  font-size: calc(clamp(1.75rem, 2.8vw, 2.35rem) * 0.9);
  font-weight: 700;
  color: #ffffff;
  line-height: 1.28;
  letter-spacing: -0.035em;
}

.consulting-bu-leader-points {
  display: flex;
  flex-direction: column;
  gap: clamp(1.45rem, 3.4vh, 2.15rem);
}

.consulting-bu-leader-block {
  margin: 0;
}

.consulting-bu-leader-subtitle {
  margin: 0 0 0.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem 0.65rem;
  font-size: 1.125rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.4;
  letter-spacing: -0.02em;
}

.consulting-bu-leader-num {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.875rem;
  height: 1.875rem;
  padding: 0 0.35rem;
  border-radius: 8px;
  font-size: 0.8125rem;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
  color: #000000;
  background: var(--branding-color-2);
  box-shadow: 0 2px 8px rgba(142, 255, 0, 0.35);
  transform: translateY(-0.18rem);
  transition:
    background-color 0.45s cubic-bezier(0.22, 0.78, 0.2, 1),
    color 0.45s cubic-bezier(0.22, 0.78, 0.2, 1),
    box-shadow 0.45s cubic-bezier(0.22, 0.78, 0.2, 1);
}

.consulting-bu-leader-subtitle-label {
  flex: 1 1 auto;
  min-width: 0;
  text-align: center;
}

.consulting-bu-leader-desc {
  margin: 0;
  padding-left: 0.34rem;
  font-size: 1.0625rem;
  line-height: 1.72;
  color: #e5e7eb;
  letter-spacing: -0.015em;
  text-align: justify;
  text-align-last: left;
  text-indent: 1em;
  word-break: break-all;
}

.consulting-bu-leader-divider {
  margin: 0;
  border: none;
  border-top: 1px solid rgba(255, 255, 255, 0.28);
}

.consulting-bu-leader-image-wrap {
  min-width: 0;
  position: relative;
  border-radius: 0;
  overflow: hidden;
  background: transparent;
  box-shadow: none;
  display: flex;
  align-items: center;
  justify-content: center;
}


.consulting-bu-leader-image-wrap::after {
  content: none;
}

.consulting-bu-leader-image {
  position: relative;
  z-index: 0;
  display: block;
  width: 100%;
  max-width: 440px;
  height: auto;
  object-fit: contain;
  object-position: center center;
  vertical-align: top;
}


@media (hover: hover) and (pointer: fine) {
  .consulting-bu-leader-section:hover .consulting-bu-leader-panel {
    transform: scale(1.025);
  }

  /* 섹션 줌인과 함께: 숫자 박스 브랜드 1 · 숫자 흰색 */
  .consulting-bu-leader-section:hover .consulting-bu-leader-num {
    color: #ffffff;
    background-color: var(--branding-color-1);
    box-shadow: 0 2px 8px rgba(0, 94, 255, 0.35);
  }
}

@media (prefers-reduced-motion: reduce) {
  .consulting-bu-leader-panel {
    transition: none;
  }

  .consulting-bu-leader-section:hover .consulting-bu-leader-panel {
    transform: none;
  }

  .consulting-bu-leader-num {
    transition: none;
  }

  @media (hover: hover) and (pointer: fine) {
    .consulting-bu-leader-section:hover .consulting-bu-leader-num {
      color: #000000;
      background-color: var(--branding-color-2);
      box-shadow: 0 2px 8px rgba(142, 255, 0, 0.35);
    }
  }
}

@media (max-width: 900px) {
  .consulting-bu-leader-panel {
    grid-template-columns: 1fr;
    gap: 2rem;
    padding-top: 0;
  }

  .consulting-bu-leader-text {
    order: 2;
    padding: 0;
    min-height: 0;
    justify-content: flex-start;
    gap: 1.5rem;
  }

  .consulting-bu-leader-title {
    font-size: 1.625rem;
  }

  .consulting-bu-leader-points {
    gap: 1.25rem;
  }

  .consulting-bu-leader-image-wrap {
    order: 1;
    width: 100%;
    max-width: none;
    border-radius: 16px;
  }

  .consulting-bu-leader-image {
    position: relative;
    width: 100%;
    max-width: 100%;
    height: auto;
    object-fit: contain;
  }
}


.consulting-solution-box-section {
  margin-top: 3rem;
  padding: 0 0 clamp(3.75rem, 7vw, 5.25rem);
  background: #000000;
}


.consulting-extra-section {
  padding: 1.9rem 0 4.1rem;
  background: #000000;
}

.consulting-extra-inner {
  min-height: 0;
}

.industry-section-header {
  margin-bottom: 3.465rem;
}

.industry-section-title {
  margin: 0 0 0.6rem;
  font-size: 1.44rem;
  font-weight: 700;
  line-height: 1.35;
  color: #ffffff;
  scroll-margin-top: calc(var(--header-height) + 1.25rem);
}

.industry-section-desc {
  margin: 0;
  font-size: 1rem;
  line-height: 1.65;
  color: #d1d5db;
}

.industry-section-desc strong {
  color: #ffffff;
  font-weight: 700;
}

.industry-section-meta {
  margin: 0.65rem 0 0;
  font-size: 0.9rem;
  color: #6b7280;
}

.industry-grid-empty {
  margin: 0 0 1rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: #9ca3af;
  text-align: center;
}

.industry-select-prompt {
  margin: 0 0 1.15rem;
  font-size: 0.95rem;
  line-height: 1.5;
  color: #9ca3af;
  text-align: center;
}

.industry-section-header .industry-select-prompt {
  margin: 0;
  max-width: 40rem;
  text-align: left;
  font-weight: 400;
  color: #d1d5db;
}

.industry-select-prompt[hidden] {
  display: none;
}

@keyframes industryLogoCardIn {
  from {
    opacity: 0;
    transform: translateY(12px) scale(0.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}


@keyframes industryLogoCardAppear {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.consulting-extra-section .industry-logo-card.industry-logo-card--in {
  animation: industryLogoCardIn 0.42s ease backwards;
}

.consulting-extra-section .industry-logo-card.industry-logo-card--appear {
  animation: industryLogoCardAppear 0.4s ease backwards;
}

@media (prefers-reduced-motion: reduce) {
  .consulting-extra-section .industry-logo-card.industry-logo-card--in,
  .consulting-extra-section .industry-logo-card.industry-logo-card--appear {
    animation: none;
    opacity: 1;
  }
}

.industry-filter-wrap {
  margin-bottom: 1.25rem;
}

.consulting-extra-section .industry-filter-wrap {
  margin-bottom: 2.7225rem;
}


.industry-filter {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(10.75rem, 1fr));
  column-gap: 0.55rem;
  row-gap: 0.715rem;
  width: 100%;
  margin-bottom: 0;
  min-width: 0;
}

.industry-chip {
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  background: #ffffff;
  color: #334155;
  font-size: 0.88rem;
  font-weight: 600;
  padding: 0.45rem 0.9rem;
  white-space: nowrap;
  cursor: pointer;
  transition: all 0.2s ease;
}

.industry-chip:not(.industry-chip--close) {
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 0;
  max-width: none;
  padding: 0.45rem 0.75rem;
  text-align: center;
  line-height: 1.25;
}

.industry-filter .industry-chip.industry-chip--category,
.industry-filter .industry-chip.industry-chip--all {
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  white-space: nowrap;
  padding: 0.42rem 0.6rem;
  font-size: 0.8rem;
  line-height: 1.35;
  justify-content: center;
  background-color: #000000;
  border-color: transparent;
  color: #ffffff;
}

.industry-filter .industry-chip.industry-chip--category {
  transition:
    transform 0.22s ease,
    background-color 0.2s ease,
    border-color 0.2s ease,
    color 0.2s ease;
}

.industry-filter .industry-chip.industry-chip--all {
  font-size: 0.84rem;
}

.consulting-extra-section .industry-filter .industry-chip.industry-chip--category {
  font-size: calc(0.8rem * 1.15 * 1.03);
}

.consulting-extra-section .industry-filter .industry-chip.industry-chip--all {
  font-size: calc(0.84rem * 1.15 * 1.03);
}

.industry-filter .industry-chip.industry-chip--category:hover {
  background-color: #ffffff;
  border-color: #000000;
  color: #000000;
  transform: scale(1.06);
  position: relative;
  z-index: 1;
}

.industry-filter .industry-chip.industry-chip--category.is-active:hover {
  background-color: #ffffff;
  border-color: #000000;
  color: #000000;
}

.industry-filter .industry-chip.industry-chip--category:focus-visible {
  outline: 2px solid var(--color-brand-theme-blue);
  outline-offset: 2px;
}

.industry-chip:not(:disabled):hover {
  border-color: var(--color-brand-theme-blue);
  color: var(--color-brand-theme-blue);
}


.industry-filter .industry-chip.industry-chip--all:not(.is-active) {
  background: #000000;
  border-color: transparent;
  color: #ffffff;
}

.industry-filter .industry-chip.industry-chip--all:not(.is-active):hover {
  background-color: #ffffff;
  border-color: #000000;
  color: #000000;
  transform: none;
}

.industry-filter .industry-chip.industry-chip--all.is-active:hover {
  background: #ffffff;
  border-color: transparent;
  color: #000000;
  transform: none;
}

.industry-chip.is-active {
  background: #ffffff;
  border-color: transparent;
  color: #000000;
}

.industry-filter .industry-chip.industry-chip--category.is-active,
.industry-filter .industry-chip.industry-chip--all.is-active {
  background: #ffffff;
  border-color: transparent;
  color: #000000;
}

.industry-chip--close {
  cursor: pointer;
  background-color: #000000;
  color: #ffffff;
  border: 1px solid #000000;
  border-radius: 6px;
  font-weight: 600;
  letter-spacing: normal;
}

.industry-chip.industry-chip--close:hover,
.industry-chip.industry-chip--close:focus-visible {
  background-color: #1a1a1a;
  border-color: #1a1a1a;
  color: #ffffff;
}

.industry-logo-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  column-gap: 0.75rem;
  row-gap: 1.2rem;
}

.industry-logo-grid--collapsed {
  display: none;
}

.industry-logo-card {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  min-height: 120px;
  padding: 0.85rem 0.7rem 0.65rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.04);
}

.industry-logo-mark {
  width: 100%;
  box-sizing: border-box;
  flex: 0 0 64px;
  height: 64px;
  min-height: 64px;
  max-height: 64px;
  border-radius: 6px;
  background: linear-gradient(160deg, #f8fafc 0%, #f1f5f9 100%);
  border: 1px solid #cfd8e3;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.88rem;
  font-weight: 700;
  color: #334155;
  line-height: 1.25;
  padding: 0.35rem 0.55rem;
  text-align: center;
  overflow: hidden;
}

.industry-logo-name {
  margin: 0.55rem 0 0;
  font-size: 0.85rem;
  font-weight: 600;
  line-height: 1.35;
  color: #4b5563;
}


.consulting-extra-section .industry-logo-card {
  position: relative;
  z-index: 0;
  min-height: 136px;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  color: #000000;
  justify-content: flex-start;
  padding: 0.65rem 0.7rem 0.55rem;
  transform: translateY(0) scale(1);
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    z-index 0s linear 0.28s;
}

.consulting-extra-section .industry-logo-card:hover,
.consulting-extra-section .industry-logo-card:focus-within {
  z-index: 3;
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    z-index 0s;
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 14px 32px rgba(15, 23, 42, 0.14),
    0 6px 14px rgba(59, 130, 246, 0.18);
}

@media (prefers-reduced-motion: reduce) {
  .consulting-extra-section .industry-logo-card {
    transition: box-shadow 0.2s ease;
  }

  .consulting-extra-section .industry-logo-card:hover,
  .consulting-extra-section .industry-logo-card:focus-within {
    transform: none;
  }
}

.consulting-extra-section .industry-logo-card:has(.industry-logo-mark--brand) {
  padding-top: 1.35rem;
}


.consulting-extra-section .industry-logo-card[data-industry-all-showcase="1"] {
  min-height: 136px;
}

.consulting-extra-section .industry-logo-card[data-industry-all-showcase="1"]:has(.industry-logo-mark--brand) {
  padding-top: 1.18rem;
}

.consulting-extra-section .industry-logo-card[data-industry-all-showcase="1"] .industry-logo-name {
  margin-top: 0.72rem;
}

.consulting-extra-section .industry-logo-card--all-rest[data-industry-all-showcase="1"] {
  padding: 1.08rem 1rem;
}

.consulting-extra-section .industry-logo-name {
  flex: 0 0 auto;
  margin-top: 0.85rem;
  font-size: 0.93rem;
  color: #000000;
}

.consulting-extra-section .industry-logo-mark--brand {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 90%;
  min-height: 59px;
  height: 59px;
  max-height: 59px;
  box-sizing: border-box;
  margin-inline: auto;
  background: #ffffff;
  border: 1px solid #ffffff;
}

.consulting-extra-section .industry-logo-placeholder {
  font-size: 0.75rem;
  font-weight: 600;
  color: #9ca3af;
}

.consulting-extra-section .industry-logo-mark--brand img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
}

.consulting-extra-section .industry-logo-mark--brand:has(img) .industry-logo-placeholder {
  display: none;
}


.consulting-extra-section .industry-logo-card--ellipsis {
  justify-content: center;
  padding: 1rem 0.7rem;
}

.consulting-extra-section .industry-logo-card--ellipsis .industry-logo-ellipsis-char {
  font-size: 2.85rem;
  font-weight: 700;
  color: #000000;
  letter-spacing: 0.22em;
  line-height: 1;
  display: block;
  transform: translateX(5px);
}


.consulting-extra-section .industry-logo-card--all-rest {
  background: #e0f2fe;
  border-color: #7dd3fc;
  justify-content: center;
  padding: 1.25rem 1rem;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
}

.consulting-extra-section .industry-logo-card--all-rest:hover,
.consulting-extra-section .industry-logo-card--all-rest:focus-within {
  background: #e0f2fe;
  border-color: #7dd3fc;
}

.consulting-extra-section .industry-logo-card--all-rest .consulting-solution-highlight-text {
  font-size: 1rem;
  font-weight: 700;
  color: #000000;
  line-height: 1.85;
  text-align: center;
}

.consulting-extra-section .industry-logo-card--all-rest .consulting-solution-highlight-stat {
  margin: 0.2em 0;
  line-height: 1.2;
}


.industry-logo-card--sample-last {
  background: #ffffff;
  border-color: #e5e7eb;
  box-shadow: 0 1px 4px rgba(15, 23, 42, 0.04);
  justify-content: center;
  padding: 0.85rem 0.7rem;
}

.industry-logo-card--sample-last .industry-logo-sample-dots-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  flex: 1;
  min-height: 88px;
}

.industry-logo-sample-dots-text {
  color: #4b5563;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  line-height: 1;
}

.industry-logo-card--more {
  border-style: dashed;
  background: linear-gradient(165deg, #f8fafc 0%, #f1f5f9 55%, #eef2ff 100%);
  box-shadow: none;
  justify-content: center;
}

.industry-logo-card--more .industry-logo-more-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 72px;
  padding: 0.25rem 0.2rem;
}

.industry-logo-more-caption {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  line-height: 1.4;
  color: #475569;
  text-align: center;
}

@media (max-width: 1080px) {
  .industry-logo-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .industry-section-title {
    font-size: 1.35rem;
  }

  .industry-filter-wrap {
    flex-direction: column;
    align-items: stretch;
  }

  .industry-filter {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 0.1rem;
    gap: 0.55rem;
  }

  .industry-filter .industry-chip.industry-chip--category,
  .industry-filter .industry-chip.industry-chip--all {
    width: auto;
    flex: 0 0 auto;
    min-width: 10.5rem;
    max-width: none;
  }

  .industry-chip--close {
    align-self: flex-end;
  }

  .industry-filter::-webkit-scrollbar {
    height: 6px;
  }

  .industry-filter::-webkit-scrollbar-thumb {
    background: #cbd5e1;
    border-radius: 999px;
  }

  .industry-logo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 520px) {
  .industry-logo-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


.consulting-extra-section + .invitation-section {
  padding-top: 0;
  padding-bottom: 0;
  background-color: #000000;
  transform: translateY(0) scale(1);
  transition: transform 0.42s cubic-bezier(0.22, 0.78, 0.2, 1), background-color 0.42s cubic-bezier(0.22, 0.78, 0.2, 1), box-shadow 0.42s cubic-bezier(0.22, 0.78, 0.2, 1);
  box-shadow: 0 0 0 rgba(255, 255, 255, 0);
}

.consulting-extra-section + .invitation-section:hover {
  background-color: #ffffff;
  transform: translateY(-0.35rem) scale(1.01);
  box-shadow: 0 1rem 2rem rgba(255, 255, 255, 0.08);
}

.consulting-extra-section + .invitation-section .invitation-message {
  color: #ffffff;
  transition: color 0.35s ease;
}

.consulting-extra-section + .invitation-section:hover .invitation-message {
  color: #000000;
}

.consulting-extra-section + .invitation-section .invitation-image {
  border-radius: 0;
  box-shadow: none;
  width: 110%;
  max-width: none;
  height: 100%;
  object-fit: cover;
}

.consulting-extra-section + .invitation-section .invitation-inner {
  align-items: stretch;
}

.consulting-extra-section + .invitation-section .invitation-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  transform: translateY(clamp(-0.3rem, 0.2vw, 0.2rem));
}

.consulting-extra-section + .invitation-section .invitation-image-wrap {
  display: flex;
  align-items: stretch;
  overflow: hidden;
}

.consulting-extra-section + .invitation-section .invitation-btn {
  width: 162px;
  height: 43px;
  min-width: 162px;
  padding: 0.675rem 1.215rem;
  font-size: 0.855rem;
}

/* 초청 섹션 호버: 두 버튼 — 브랜드 1 배경 · 흰 글자 */
.consulting-extra-section + .invitation-section:hover .invitation-btn {
  background-color: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
}

/* 버튼에 직접 호버/포커스 시(섹션 호버 중에도) — 브랜드 2 · 검정 글자 */
.consulting-extra-section + .invitation-section:hover .invitation-btn:hover,
.consulting-extra-section + .invitation-section:hover .invitation-btn:focus-visible {
  background-color: var(--branding-color-2);
  color: #000000;
  border-color: transparent;
}

.consulting-solution-section-heading {
  margin: 0 0 0.55rem;
  text-align: left;
  font-size: 1.44rem;
  font-weight: 700;
  color: #ffffff;
  line-height: 1.4;
  letter-spacing: -0.02em;
  border-left: none;
  padding-left: 0;
}

.consulting-solution-section-desc {
  margin: 0 0 2.1rem;
  max-width: 36rem;
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.55;
  color: #d1d5db;
  letter-spacing: -0.02em;
}

.consulting-solution-grid-wrap {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: repeat(3, auto);
  gap: 0.75rem;
  align-items: stretch;
}

.consulting-solution-arrow-corner {
  grid-column: 1;
  grid-row: 1;
  min-height: 1.75rem;
  position: relative;
}

.consulting-solution-arrow-corner::after {
  content: "";
  position: absolute;
  right: 7px;
  bottom: 7px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ffffff;
}

.consulting-solution-arrow-h {
  grid-column: 2 / -1;
  grid-row: 1;
  display: flex;
  align-items: center;
  min-height: 1.75rem;
  padding-bottom: 0.15rem;
}

.consulting-solution-arrow-h-inner {
  display: flex;
  align-items: center;
  width: 100%;
}

.consulting-solution-arrow-h-line {
  flex: 1;
  height: 2px;
  background: #ffffff;
  border-radius: 1px;
}

.consulting-solution-arrow-h-head {
  width: 0;
  height: 0;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 11px solid #ffffff;
  flex-shrink: 0;
  margin-left: -1px;
}

.consulting-solution-arrow-v {
  grid-column: 1;
  grid-row: 2 / 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  min-height: 0;
}

.consulting-solution-arrow-v-line {
  flex: 1;
  width: 2px;
  min-height: 3rem;
  background: #ffffff;
  border-radius: 1px;
}

.consulting-solution-arrow-v-head {
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 11px solid #ffffff;
  flex-shrink: 0;
  margin-top: -1px;
}

.consulting-solution-grid {
  grid-column: 1 / -1;
  grid-row: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.1rem;
}

.consulting-solution-box {
  position: relative;
  z-index: 0;
  background: #ffffff;
  border: 0.8px solid rgba(107, 114, 128, 0.95);
  border-radius: 8px;
  padding: 1.25rem 1rem;
  text-align: center;
  min-height: calc(128px * 1.2 * 1.05 * 0.9);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
  transform: translateY(0) scale(1);
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    z-index 0s;
}

.consulting-solution-box:not(.consulting-solution-box--highlight) {
  background: #000000;
  border: 0.8px solid transparent;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.22);
}

.consulting-solution-box:hover,
.consulting-solution-box:focus-within {
  z-index: 3;
  transition:
    transform 0.28s ease,
    box-shadow 0.28s ease,
    z-index 0s;
  transform: translateY(-6px) scale(1.03);
  box-shadow:
    0 14px 32px rgba(15, 23, 42, 0.14),
    0 6px 14px rgba(59, 130, 246, 0.18);
  border-color: #000000;
}

.consulting-solution-box:not(.consulting-solution-box--highlight):hover,
.consulting-solution-box:not(.consulting-solution-box--highlight):focus-within {
  background: #ffffff;
  border-color: transparent;
}

.consulting-solution-num {
  display: block;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-brand-theme-blue);
  margin-bottom: 0.5rem;
}

.consulting-solution-box:not(.consulting-solution-box--highlight) .consulting-solution-num {
  color: #ffffff;
}

.consulting-solution-title {
  margin: 0 0 0.6rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #111827;
  line-height: 1.3;
}

.consulting-solution-box:not(.consulting-solution-box--highlight) .consulting-solution-title {
  color: #ffffff;
}

.consulting-solution-summary {
  margin: 0;
  font-size: 0.85rem;
  line-height: 1.5;
  color: #4b5563;
  text-align: center;
}

.consulting-solution-box:not(.consulting-solution-box--highlight) .consulting-solution-summary {
  color: rgba(255, 255, 255, 0.88);
}

.consulting-solution-box:not(.consulting-solution-box--highlight):hover .consulting-solution-num,
.consulting-solution-box:not(.consulting-solution-box--highlight):focus-within .consulting-solution-num {
  color: var(--color-brand-theme-blue);
}

.consulting-solution-box:not(.consulting-solution-box--highlight):hover .consulting-solution-title,
.consulting-solution-box:not(.consulting-solution-box--highlight):focus-within .consulting-solution-title {
  color: #111827;
}

.consulting-solution-box:not(.consulting-solution-box--highlight):hover .consulting-solution-summary,
.consulting-solution-box:not(.consulting-solution-box--highlight):focus-within .consulting-solution-summary {
  color: #4b5563;
}

/* 1~11번: 기본은 번호·제목만, 호버 시 줌·흰 배경 유지 + 설명으로 교체 (카드 높이 유지) */
.consulting-solution-box--swap {
  justify-content: stretch;
}

.consulting-solution-swap {
  position: relative;
  width: 100%;
  flex: 1 1 auto;
  align-self: stretch;
  min-height: 7.75rem;
}

/* swap 카드 얼굴(번호·제목): 기본 상태 유지 (뒷면이 위에서 바로 덮어씀) */
.consulting-solution-box--swap .consulting-solution-face {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 0.2rem;
  opacity: 1;
  visibility: visible;
  transition: none;
}

.consulting-solution-box--swap .consulting-solution-face .consulting-solution-title {
  margin: 0;
}

.consulting-solution-box--swap .consulting-solution-summary {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0 0.4rem;
  background: #ffffff;
  border-radius: 8px;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: none;
}

.consulting-solution-box.consulting-solution-box--swap:not(.consulting-solution-box--highlight):hover .consulting-solution-summary,
.consulting-solution-box.consulting-solution-box--swap:not(.consulting-solution-box--highlight):focus-within .consulting-solution-summary {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  font-family: var(--font-pretendard-static);
  font-size: calc(1.1rem * 0.9);
  font-weight: 500;
  line-height: calc(1.45 * 1.25 * 0.85);
  letter-spacing: -0.025em;
  color: #111827;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: geometricPrecision;
  transition: none;
}

/* 호버 해제 시 빠르게 원복(z-index 지연 제거·배경 짧게) — 빠른 마우스 이동 시 검정 칸이 겹쳐 보이지 않게 함 */
.consulting-solution-box.consulting-solution-box--swap:not(.consulting-solution-box--highlight) {
  transform: translateY(0) scale(1);
  transition: none;
}

.consulting-solution-box.consulting-solution-box--swap:not(.consulting-solution-box--highlight):hover,
.consulting-solution-box.consulting-solution-box--swap:not(.consulting-solution-box--highlight):focus-within {
  transform: translateY(0) scale(1);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.22);
  transition: none;
}

.consulting-solution-box--highlight {
  background: #ffffff;
  border: 0.8px solid rgba(107, 114, 128, 0.95);
  justify-content: center;
  transform: translateY(0) scale(0.9);
  transform-origin: center center;
}

.consulting-solution-box.consulting-solution-box--highlight {
  border-color: rgba(107, 114, 128, 0.95);
}

.consulting-solution-box.consulting-solution-box--highlight:hover,
.consulting-solution-box.consulting-solution-box--highlight:focus-within {
  background: #ffffff;
  border-color: #000000;
  transform: translateY(-6px) scale(0.927);
}

.consulting-solution-highlight-text {
  font-size: 1rem;
  font-weight: 700;
  color: #000000;
  line-height: 1.575;
  text-align: center;
}

.consulting-solution-highlight-stat {
  display: inline-block;
  font-size: calc(2em * 0.8);
  line-height: 1.208;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: #000000;
}

.consulting-solution-box--highlight .consulting-solution-highlight-text {
  font-size: calc(1rem * 1.1);
  line-height: calc(1.575 * 1.15);
}

.consulting-solution-box--highlight .consulting-solution-highlight-stat {
  font-size: calc(2em * 0.8 * 1.1);
  color: var(--color-brand-theme-blue);
  line-height: calc(1.208 * 1.15);
}

.consulting-solution-cta-wrap {
  margin-top: clamp(4.485rem, 7.8vh, 5.33rem);
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.75rem;
  flex-wrap: wrap;
}

.consulting-solution-roadmap-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.474rem 1.65rem;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #000000;
  background: var(--branding-color-2);
  border: 2px solid transparent;
  border-radius: 0.5rem;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
  transform: scale(1);
  transform-origin: center;
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.25s ease;
}

.consulting-solution-roadmap-btn:hover {
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
  transform: scale(1.06);
}

.consulting-solution-roadmap-btn:focus {
  outline: none;
}

.consulting-solution-roadmap-btn:focus-visible {
  outline: 2px solid var(--branding-color-2);
  outline-offset: 3px;
}

.consulting-solution-roadmap-btn:hover:focus-visible {
  outline-color: #ffffff;
}

.consulting-solution-inquiry-btn {
  min-width: 11.8rem;
}

.consulting-solution-roadmap-btn--fixed {
  width: 11.8rem;
  height: 2.35rem;
  padding: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.consulting-roadmap-panel {
  position: relative;
  margin: 0;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 8px;
  background: #ffffff;
  overflow: hidden;
}

.consulting-roadmap-close-btn {
  position: absolute;
  top: 0.55rem;
  right: 0.55rem;
  z-index: 2;
  width: 1.9rem;
  height: 1.9rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.62);
  color: #ffffff;
  font-size: 1rem;
  line-height: 1;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.consulting-roadmap-close-btn:hover {
  background: #ffffff;
  border-color: #000000;
  color: #000000;
}

.consulting-roadmap-frame {
  display: block;
  width: 100%;
  height: var(--consulting-roadmap-frame-height, clamp(520px, 78vh, 980px));
  border: 0;
  background: #ffffff;
}

.consulting-roadmap-empty {
  margin: 0;
  padding: 1.2rem 1rem;
  text-align: center;
  font-size: 0.9rem;
  color: rgba(255, 255, 255, 0.82);
}

.consulting-solution-grid-wrap {
  position: relative;
}

.consulting-solution-grid-wrap .consulting-roadmap-panel {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 6;
}

@media (prefers-reduced-motion: reduce) {
  .consulting-solution-roadmap-btn {
    transition:
      background-color 0.2s ease,
      color 0.2s ease,
      border-color 0.2s ease;
  }

  .consulting-solution-roadmap-btn:hover {
    transform: none;
  }
}

@media (max-width: 900px) {
  .consulting-solution-grid-wrap {
    display: block;
  }

  .consulting-solution-arrow-corner,
  .consulting-solution-arrow-h,
  .consulting-solution-arrow-v {
    display: none;
  }

  .consulting-solution-grid {
    grid-column: auto;
    grid-row: auto;
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 480px) {
  .consulting-solution-grid {
    grid-template-columns: 1fr;
  }
}

@media (prefers-reduced-motion: reduce) {
  .consulting-solution-box {
    transition: none;
    transform: none;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
  }

  .consulting-solution-box:hover,
  .consulting-solution-box:focus-within {
    transform: none;
    box-shadow: 0 1px 3px rgba(15, 23, 42, 0.07);
    z-index: 0;
  }

  .consulting-solution-box.consulting-solution-box--highlight,
  .consulting-solution-box.consulting-solution-box--highlight:hover,
  .consulting-solution-box.consulting-solution-box--highlight:focus-within {
    transform: translateY(0) scale(0.9);
  }

  .consulting-solution-face,
  .consulting-solution-box--swap .consulting-solution-summary {
    transition: none;
  }
}


.consulting-process-section {
  padding: 1rem 0 4rem;
  background: #ffffff;
}

.consulting-process-header {
  position: relative;
  margin-bottom: 1.5rem;
}

.consulting-process-arrow-wrap {
  display: flex;
  align-items: center;
  width: 100%;
  max-width: 100%;
}

.consulting-process-arrow-line {
  flex: 1;
  height: 3px;
  background: var(--color-brand-theme-blue);
  display: block;
}

.consulting-process-arrow-head {
  width: 0;
  height: 0;
  border-top: 8px solid transparent;
  border-bottom: 8px solid transparent;
  border-left: 14px solid var(--color-brand-theme-blue);
  flex-shrink: 0;
  margin-left: -1px;
}

.consulting-process-duration {
  position: absolute;
  top: -1.5rem;
  right: 0;
  margin: 0;
  font-size: 0.9rem;
  color: #4b5563;
  font-weight: 500;
}

.consulting-process-boxes {
  display: grid;
  grid-template-columns: repeat(5, 18%);
  gap: 2.5%;
  justify-content: center;
}

.consulting-process-box {
  min-height: 324px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem 1rem;
  border-radius: 8px;
}

.consulting-process-box-text {
  font-size: 1rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.35;
}


.consulting-process-box--1 { background: #dbeafe; }
.consulting-process-box--1 .consulting-process-box-text { color: #1e3a8a; }

.consulting-process-box--2 { background: #93c5fd; }
.consulting-process-box--2 .consulting-process-box-text { color: #1e3a8a; }

.consulting-process-box--3 { background: #60a5fa; }
.consulting-process-box--3 .consulting-process-box-text { color: #111827; }

.consulting-process-box--4 { background: #1d4ed8; }
.consulting-process-box--4 .consulting-process-box-text { color: #ffffff; }

.consulting-process-box--5 { background: #dbeafe; }
.consulting-process-box--5 .consulting-process-box-text { color: #111827; }

@media (max-width: 768px) {
  .consulting-process-boxes {
    grid-template-columns: 1fr;
  }
  .consulting-process-box {
    min-height: 64px;
  }
}


.consulting-stats-dashboard {
  --csd-label-size: calc(clamp(0.95rem, 0.85vw + 0.75rem, 1.12rem) * 1.2 * 0.95);
  background: #000000;
  color: #ffffff;
  padding: calc(clamp(5rem, 9vw, 7rem) * 1.05 - clamp(0.25rem, 0.7vw, 0.45rem)) 0 calc(clamp(3.75rem, 6.5vw, 5.5rem) * 1.05);
  font-family: var(--font-pretendard-static);
}

.consulting-main .consulting-stats-dashboard {
  padding-top: 0.48rem;
}

.consulting-main .consulting-stats-dashboard > .consulting-group-photo-dots {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  margin-top: 0.22rem;
  margin-bottom: 0;
  padding: 0 0 0.18rem;
}

.consulting-main .consulting-stats-dashboard > .container {
  padding-top: calc(clamp(5rem, 9vw, 7rem) * 1.05 - clamp(0.25rem, 0.7vw, 0.45rem));
}

.consulting-stats-dashboard-inner {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: calc(clamp(3rem, 6.5vw, 4.75rem) * 1.05);
  max-width: 1100px;
  margin: 0 auto;
}

.consulting-stats-dashboard-row--triple {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.75rem, 2vw, 1.5rem);
}

.consulting-stats-dashboard-pair {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: calc(clamp(1.65rem, 3.2vw, 2.5rem) * 0.9);
  min-width: 0;
}

.consulting-stats-dashboard-row--single {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: calc(clamp(1.65rem, 3.2vw, 2.5rem) * 0.9);
}

.consulting-stats-dashboard-cell {
  margin: 0;
  width: 100%;
}

.consulting-stats-dashboard-cell--label {
  font-size: var(--csd-label-size);
  font-weight: 700;
  line-height: 1.35;
  letter-spacing: -0.02em;
}

.consulting-stats-dashboard-row--single .consulting-stats-dashboard-cell--label {
  color: #ffffff;
}

.consulting-stats-dashboard-row--single .consulting-stats-dashboard-cell--value {
  color: var(--branding-color-2);
}

.consulting-stats-dashboard-cell--value {
  font-size: calc(var(--csd-label-size) * 2.3);
  font-weight: 900;
  line-height: 1.12;
  letter-spacing: -0.03em;
}

@media (max-width: 640px) {
  .consulting-stats-dashboard-row--triple {
    grid-template-columns: 1fr;
    gap: clamp(1.5rem, 4vw, 2.25rem);
  }
}


.consulting-voc-section {
  margin-top: 1.5rem;
  padding: 0 0 2rem;
}


.consulting-main .consulting-voc-section {
  margin-top: clamp(1.5rem, 3.5vw, 2.5rem);
}

.consulting-voc-list {
  display: flex;
  flex-direction: column;
  gap: 1.95rem;
  align-items: stretch;
}

.consulting-voc-item {
  display: block;
  width: 100%;
}


.consulting-voc-above-title {
  margin: 0 0 2.34rem;
  padding: 0;
  font-size: calc(clamp(1.22rem, 2vw, 1.42rem) * 0.9);
  font-weight: 700;
  line-height: 1.35;
  color: #ffffff;
  letter-spacing: -0.02em;
  text-align: left;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
}

.consulting-voc-box {
  position: relative;
  width: 100%;
  min-width: 0;
  min-height: 11.5rem;
  overflow: hidden;
  border-radius: 10px;
  padding: 2.5rem 1.75rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  text-align: left;
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
  background-color: #e5e7eb;
  background-image: linear-gradient(135deg, #f3f4f6 0%, #e5e7eb 100%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1);
  transition: transform 0.24s ease;
}

.consulting-voc-box[data-consulting-voc-story-url] {
  cursor: pointer;
}

.consulting-voc-box:hover {
  transform: scale(1.03);
}

/* 메인 진단 섹션: 카드 높이 고정(이미지 비율과 무관), img는 영역에 맞춤 */
.home-diagnosis-section .consulting-voc-box.home-diagnosis-image-slot {
  position: relative;
  display: block;
  height: 11.5rem;
  min-height: 11.5rem;
  max-height: 11.5rem;
  padding: 0;
  overflow: hidden;
  background-image: none;
  background-color: #111827;
  cursor: pointer;
}

/* 카드 전체 클릭 시 진단 페이지 열기 (히어로·텍스트·‘진단 시작하기’ 동일 동작) */
.home-diagnosis-slot-link {
  display: block;
  position: relative;
  height: 100%;
  min-height: 100%;
  margin: 0;
  padding: 0;
  border: none;
  color: inherit;
  text-decoration: none;
  cursor: pointer;
}

.home-diagnosis-slot-link:focus {
  outline: none;
}

.home-diagnosis-slot-link:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.85);
  outline-offset: 2px;
}

.home-diagnosis-section .consulting-voc-box.home-diagnosis-image-slot .home-diagnosis-slot-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* 진단 블록: 이미지 위 반투명 검정 — 위에 올릴 텍스트 가독성 확보 */
.home-diagnosis-slot-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: rgba(0, 0, 0, 0.48);
  pointer-events: none;
}

.home-diagnosis-slot-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: stretch;
  min-height: 0;
  padding: clamp(0.85rem, 2.2vw, 1.35rem) clamp(1rem, 2.8vw, 1.75rem);
  color: #ffffff;
  text-align: left;
}

.home-diagnosis-slot-text {
  flex: 1 1 auto;
  min-height: 0;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

/* 설명 ↔ 버튼 간격: 기존 대비 약 80% 수준(명시적 margin) */
.home-diagnosis-slot-actions {
  flex-shrink: 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  margin-top: clamp(0.44rem, 1.1vw, 0.72rem);
}

.home-diagnosis-slot-btn {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.4rem 0;
  border: none;
  border-radius: 0;
  background: transparent;
  color: #ffffff;
  font-family:
    "Pretendard",
    -apple-system,
    BlinkMacSystemFont,
    system-ui,
    "Apple SD Gothic Neo",
    "Noto Sans KR",
    sans-serif;
  font-size: clamp(0.792rem, 1.485vw, 0.9rem);
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.3;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.45);
  transition: color 0.2s ease, opacity 0.2s ease;
}

.home-diagnosis-slot-link:hover .home-diagnosis-slot-btn {
  color: rgba(255, 255, 255, 0.88);
  opacity: 0.95;
}

.home-diagnosis-slot-title {
  margin: 0;
  font-family:
    "Pretendard",
    -apple-system,
    BlinkMacSystemFont,
    system-ui,
    "Apple SD Gothic Neo",
    "Noto Sans KR",
    sans-serif;
  font-weight: 700;
  line-height: 1.3;
  letter-spacing: -0.03em;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

/* 제목 본문: 이전 대비 1.15배 */
.home-diagnosis-slot-title-text {
  font-size: clamp(1.2075rem, 2.875vw, 1.5525rem);
  font-weight: 700;
}

/* (약식): 설명과 동일 크기 */
.home-diagnosis-slot-title-note {
  font-size: clamp(0.9936rem, 1.863vw, 1.1316rem);
  font-weight: 400;
  letter-spacing: -0.02em;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

.home-diagnosis-slot-desc {
  margin: 0.55rem 0 0;
  font-family:
    "Pretendard",
    -apple-system,
    BlinkMacSystemFont,
    system-ui,
    "Apple SD Gothic Neo",
    "Noto Sans KR",
    sans-serif;
  font-size: clamp(0.9936rem, 1.863vw, 1.1316rem);
  font-weight: 400;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: rgba(255, 255, 255, 0.92);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.4);
}

/* 진단 전용 새 창 페이지 */
.diagnosis-standalone-body {
  margin: 0;
  min-height: 100vh;
  box-sizing: border-box;
  background: #000000;
  color: #f3f4f6;
  font-family:
    "Pretendard",
    -apple-system,
    BlinkMacSystemFont,
    system-ui,
    "Apple SD Gothic Neo",
    "Noto Sans KR",
    sans-serif;
}

.diagnosis-standalone-main {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  max-width: 44rem;
  margin: 0 auto;
  padding: calc(2 * clamp(1.75rem, 4vw, 2.5rem)) clamp(1.1rem, 3vw, 1.5rem) 3rem;
}

.diagnosis-standalone-title {
  box-sizing: border-box;
  width: 90%;
  margin: 0 auto;
  padding: 0.85rem 1.2rem;
  font-size: clamp(1.2rem, 2.6vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  line-height: 1.35;
  text-align: center;
  color: #ffffff;
  /* 기존 4px의 80% */
  border: 3.2px solid var(--branding-color-2);
  border-radius: 14px;
  background: transparent;
}

.diagnosis-standalone-lead {
  margin: 1rem 0 0;
  font-size: clamp(0.88rem, 1.65vw, 1rem);
  line-height: 1.65;
  color: rgba(243, 244, 246, 0.88);
}

#diagnosis-app {
  margin-top: calc(1.3 * 1.2rem * 1.1);
}

/* `.diagnosis-intro { display:flex }`가 네이티브 [hidden]보다 우선되어 인트로가 남는 문제 방지 */
#diagnosis-intro-panel[hidden] {
  display: none !important;
}

/* 결과 단계에서만 페이지 상단 제목·리드를 숨겨 결과 영역만 보이게 함 */
body.diagnosis-result-phase .diagnosis-standalone-title,
body.diagnosis-result-phase .diagnosis-standalone-lead {
  display: none !important;
}

body.diagnosis-result-phase #diagnosis-app {
  margin-top: 0;
}

body.diagnosis-result-phase .diagnosis-standalone-main {
  justify-content: flex-start;
}

/* 세 진단 페이지(diagnosis-*.html) 인트로 공통 — 동일 클래스·동일 수치 유지 */
.diagnosis-intro {
  display: flex;
  flex-direction: column;
  gap: calc(1.18 * 1.1rem * 1.5 * 1.1);
}

.diagnosis-intro-placeholder {
  box-sizing: border-box;
  min-height: 9rem;
  margin: 0;
  padding: 1rem 1.05rem;
  border: 1px solid transparent;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.04);
  font-size: 0.88rem;
  line-height: 1.6;
  color: rgba(243, 244, 246, 0.55);
}

/* 진단 안내 본문: 양쪽 정렬·마지막 줄 왼쪽·글자 단위 줄바꿈·문단 첫 줄 들여쓰기 */
.diagnosis-intro-placeholder.diagnosis-intro-copy {
  width: 90%;
  margin-left: auto;
  margin-right: auto;
  min-height: 0;
  font-size: calc(0.88rem * 1.1 * 1.05 * 1.1);
  line-height: calc(1.6 * 1.2 * 0.95);
  color: rgba(243, 244, 246, 0.88);
  text-align: justify;
  text-align-last: left;
  word-break: break-all;
}

.diagnosis-intro-placeholder.diagnosis-intro-copy p {
  margin: 0;
  text-indent: 1em;
}

.diagnosis-intro-placeholder.diagnosis-intro-copy p + p {
  margin-top: 0.85rem;
}

/* 진단 안내 강조 — 가인지 비전 본문 strong과 동일 톤(옅은 하늘색) */
.diagnosis-intro-placeholder.diagnosis-intro-copy strong {
  font-weight: 700;
  color: #93c5fd;
  text-shadow: 0 0 1px rgba(15, 23, 42, 0.35);
}

.diagnosis-start-btn {
  align-self: center;
  margin: 0;
  padding: 0.55rem 1.15rem;
  border: 2px solid transparent;
  border-radius: 10px;
  background: var(--branding-color-2);
  color: #000000;
  font-size: 0.9rem;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  transform: scale(1);
  transition:
    background 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease;
}

.diagnosis-start-btn:hover,
.diagnosis-start-btn:focus-visible {
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
  transform: scale(1.04);
}

.diagnosis-start-btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.85);
  outline-offset: 2px;
}

.diagnosis-loading-msg {
  margin: 0;
  padding: 1rem 0;
  font-size: 0.85rem;
  color: rgba(243, 244, 246, 0.85);
  text-align: center;
}

.diagnosis-ui {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}

.diagnosis-ui-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.8rem;
  font-size: 0.8rem;
  color: rgba(243, 244, 246, 0.78);
}

.diagnosis-ui-progress,
.diagnosis-ui-page {
  margin: 0;
}

.diagnosis-question-list {
  display: flex;
  flex-direction: column;
  gap: calc(0.7rem * 1.3 * 1.2 * 1.4);
}

/* 문항 목록 ↔ 안내 문구 ↔ 네비 버튼: 문항–버튼 간 여백 기존(진단 UI gap) 대비 1.5배에 맞춤 */
.diagnosis-ui-after-questions {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: calc(0.95rem * 1.5);
  margin-top: calc(0.95rem * 0.5);
}

.diagnosis-question-card {
  border: 1px solid rgba(0, 0, 0, 0.12);
  background: #ffffff;
  border-radius: 10px;
  padding: 0.85rem 0.95rem;
  transition:
    background 0.15s ease,
    color 0.15s ease,
    border-color 0.15s ease;
}

.diagnosis-question-text {
  margin: 0;
  font-size: calc(0.9rem * 1.1 * 1.05);
  color: #000000;
  line-height: 1.5;
}

.diagnosis-option-row {
  margin-top: calc(0.72rem * 1.1);
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}

.diagnosis-option {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.28rem 0.42rem;
  border: 1px solid transparent;
  border-radius: 999px;
  background: #ffffff;
  font-size: 0.76rem;
  color: #000000;
}

.diagnosis-option input {
  margin: 0;
  /* 선택 시 라디오 내부 ● — 브랜드 컬러 */
  accent-color: var(--color-accent);
}

.diagnosis-question-card--answered {
  background: #000000;
  border-color: #000000;
}

.diagnosis-question-card--answered .diagnosis-question-text {
  color: #ffffff;
}

.diagnosis-question-card--answered .diagnosis-option {
  border-color: transparent;
  background: transparent;
  color: #ffffff;
}

.diagnosis-question-card--answered .diagnosis-option input {
  accent-color: var(--color-accent);
}

.diagnosis-ui-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0.55rem;
}

.diagnosis-nav-btn {
  margin: 0;
  border-radius: 10px;
  padding: 0.5rem 0.9rem;
  font-size: 0.84rem;
  font-weight: 600;
  font-family: inherit;
}

.diagnosis-nav-btn--prev {
  border: 1px solid #ffffff;
  background: #ffffff;
  color: #000000;
  cursor: pointer;
}

.diagnosis-nav-btn--prev:hover:not(:disabled),
.diagnosis-nav-btn--prev:focus-visible:not(:disabled) {
  background: rgba(255, 255, 255, 0.92);
}

.diagnosis-nav-btn--prev:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.diagnosis-nav-btn--next {
  border: 1px solid #000000;
  background: #000000;
  color: #ffffff;
  cursor: default;
}

.diagnosis-nav-btn--next:disabled {
  opacity: 1;
  cursor: default;
}

.diagnosis-nav-btn--next:not(:disabled) {
  border: 1px solid #ffffff;
  background: #ffffff;
  color: #000000;
  cursor: pointer;
}

.diagnosis-nav-btn--next:not(:disabled):hover,
.diagnosis-nav-btn--next:not(:disabled):focus-visible {
  background: rgba(255, 255, 255, 0.92);
}

.diagnosis-result-btn {
  border: 1px solid #ffffff;
  background: #ffffff;
  color: #111827;
  border-radius: 10px;
  padding: 0.5rem 0.9rem;
  font-size: 0.84rem;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
}

.diagnosis-result-btn:disabled {
  opacity: 0.42;
  cursor: not-allowed;
}

.diagnosis-validation-msg {
  margin: 0;
  font-size: 0.8rem;
  color: #ffffff;
  text-align: center;
}

.diagnosis-result-screen {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1.25rem;
  min-height: calc(100vh - var(--header-height, 0px));
}

/* 보완점 카드 밖: 문의하기(같은 창 → story-inquiry-popup.html) */
.diagnosis-result-screen-actions {
  display: flex;
  justify-content: center;
  margin-top: 0.25rem;
}

.diagnosis-result-consult-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.55rem 1.35rem;
  border: 2px solid rgba(0, 0, 0, 0.15);
  border-radius: 12px;
  background: var(--branding-color-2);
  color: #000000;
  font-size: 0.9rem;
  font-weight: 600;
  font-family: inherit;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition:
    background 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease,
    transform 0.22s ease;
}

.diagnosis-result-consult-btn:hover,
.diagnosis-result-consult-btn:focus-visible {
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: var(--branding-color-1);
  transform: scale(1.05);
}

.diagnosis-result-consult-btn:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.9);
  outline-offset: 3px;
}

.diagnosis-result-block {
  margin-top: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* 제목(진단 결과)↔강점 박스: 이전 flex gap(0.75rem)의 2.5배 */
.diagnosis-result-heading {
  margin: 0 0 1.875rem;
  font-size: 1.3rem;
  font-weight: 700;
  color: #ffffff;
}

.diagnosis-result-card + .diagnosis-result-card {
  margin-top: 0.75rem;
}

.diagnosis-result-card {
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 10px;
  background: rgba(17, 24, 39, 0.66);
  padding: 0.8rem 0.9rem 0.9rem;
}

.diagnosis-result-card-title {
  margin: 0;
  font-size: 0.74rem;
  color: rgba(255, 255, 255, 0.72);
}

.diagnosis-result-card-label {
  margin: 0.35rem 0 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--branding-color-2);
}

.diagnosis-result-card-score {
  margin: 0.35rem 0 0.6rem;
  font-size: 0.8rem;
  color: rgba(243, 244, 246, 0.9);
}

.diagnosis-result-text-block {
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  background: #ffffff;
  padding: 1.5rem 0.9rem;
}

.diagnosis-result-text {
  margin: 0;
  font-size: 1.092rem;
  line-height: 1.84;
  color: #000000;
  white-space: pre-line;
  text-align: justify;
  text-align-last: left;
}

.diagnosis-result-subheading,
.diagnosis-result-subtopic {
  color: #000000;
  font-weight: 700;
}

.diagnosis-result-body-copy {
  display: inline-block;
  text-indent: 1.2em;
}

.diagnosis-result-signature {
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  text-align: left;
  color: var(--branding-color-1);
  font-weight: 700;
}

/* 블록 전체는 부모의 text-align: justify 영향 밖에서 가운데 정렬 */
.diagnosis-result-signature-wrap {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  max-width: 100%;
  margin: 0.3rem 0 0;
  box-sizing: border-box;
}

.diagnosis-load-error {
  margin: 0;
  font-size: 0.9rem;
  color: #fca5a5;
}

.diagnosis-load-error-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.diagnosis-load-error-detail {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.45;
  color: rgba(252, 165, 165, 0.9);
  word-break: break-all;
}

.consulting-voc-box[data-consulting-voc-bg="1"] {
  background-image: url("../assets/가로형 임시 1.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.consulting-voc-box[data-consulting-voc-bg="2"] {
  background-image: url("../assets/가로형 임시 2.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.consulting-voc-box[data-consulting-voc-bg="3"] {
  background-image: url("../assets/가로형 임시 3.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.consulting-voc-actions {
  position: static;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-start;
  gap: 0.45rem;
  margin-left: 0;
  padding-left: 0;
  transform: translateX(2.2rem);
  max-width: none;
}

.consulting-voc-video-btn {
  margin: 0;
  padding: 0.28rem 0.5rem;
  font-family: var(--font-sans-variable);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: #000000;
  background: transparent;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
  transition: color 0.2s ease, background-color 0.2s ease;
}

a.consulting-voc-video-btn.consulting-voc-story-link {
  display: inline-block;
  box-sizing: border-box;
}

.consulting-voc-video-btn:hover {
  color: #000000;
  background: rgba(255, 255, 255, 0.5);
}

.consulting-voc-video-btn:focus {
  outline: none;
}

.consulting-voc-video-btn:focus-visible {
  outline: 2px solid #111111;
  outline-offset: 2px;
}

.consulting-voc-quote {
  margin: 0;
  padding: 0;
  width: 100%;
  max-width: none;
  transform: translateY(0.2rem);
}

.consulting-voc-quote-body {
  margin: 0;
  font-family: var(--font-sans-variable);
  font-size: 1.155rem;
  line-height: 1.75;
  color: #000000;
  font-weight: 500;
  letter-spacing: -0.01em;
  text-align: left;
}

.consulting-voc-attribution {
  display: block;
  margin: 0;
  padding: 0;
  border: none;
  font-family: var(--font-sans-variable);
  font-size: 0.95rem;
  font-weight: 700;
  font-style: normal;
  color: #000000;
  text-align: left;
  letter-spacing: 0.02em;
}

.consulting-voc-meta-row {
  margin-top: 1.05rem;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.35rem;
  width: 100%;
}


.community-main {
  padding-top: calc(var(--header-height) + 0.000375rem);
  min-height: 50vh;
  background: #000000;
}


.community-main > .consulting-group-photo-section .consulting-group-photo-overlay {
  background: rgba(0, 0, 0, 0.36);
}

.community-main .community-hero-dots-section {
  margin: 0;
  padding: 0.32rem 0 0.2rem;
  background: #000000;
}

.community-main .community-hero-dots-section .container {
  min-height: 1.1rem;
  display: flex;
  align-items: center;
  justify-content: center;
}

.community-main .community-hero-dots-section .consulting-group-photo-dots {
  position: static;
  left: auto;
  right: auto;
  bottom: auto;
  z-index: auto;
  margin: 0;
  padding: 0;
}

.community-main .community-hero-dots-section .consulting-group-photo-dot {
  width: 8px;
  height: 8px;
}

.community-maria-section {
  margin-top: 0;
  padding: 0 0 calc(2rem + 1.4rem);
  background: #ffffff;
  animation: community-maria-hero-fade-in 0.75s ease-out both;
}


.community-main > .community-maria-section {
  margin-top: 2rem;
  padding: 1.1rem 0 calc(2rem + 1.4rem - 0.6rem);
}


.community-main > .community-maria-section {
  background: #000000;
  transition: background-color 0.25s ease, color 0.25s ease;
}


.community-main > .community-maria-section .community-maria-cell--left {
  overflow: hidden;
}

.community-main > .community-maria-section .community-maria-image {
  transition: transform 0.45s ease, filter 0.45s ease;
  transform: scale(1);
  filter: brightness(1);
}

.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-image {
  transform: scale(1.02);
  filter: brightness(1.08);
}

.community-main > .community-maria-section .community-maria-cell--right {
  transition: transform 0.45s ease;
  transform: scale(1);
  transform-origin: center center;
}

.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-cell--right {
  transform: scale(1.02);
}

.community-main > .community-maria-section .community-maria-greeting--summary {
  margin-top: calc(1.65rem + clamp(1.25rem, 3.2vh, 2.4rem));
  font-size: 1.1rem;
  line-height: 1.48;
}

.community-main > .community-maria-section .community-maria-summary-line {
  line-height: 1.38;
}

.community-main > .community-maria-section.is-expanded {
  background: #000000;
}

.community-main > .community-maria-section .community-maria-greeting,
.community-main > .community-maria-section .community-maria-title,
.community-main > .community-maria-section .community-maria-summary-text,
.community-main > .community-maria-section .community-maria-summary-line,
.community-main > .community-maria-section .community-maria-signature,
.community-main > .community-maria-section .community-maria-chunk--signature .community-maria-summary-line,
.community-main > .community-maria-section .community-maria-summary-line strong,
.community-main > .community-maria-section .community-maria-toggle-btn,
.community-main > .community-maria-section .community-maria-modal-chunk p {
  color: #ffffff;
  opacity: 0.9;
  transition: color 0.25s ease, opacity 0.35s ease;
}

.community-main > .community-maria-section .community-maria-toggle-btn:hover {
  color: #ffffff;
}


.community-main > .community-maria-section:hover:not(.is-expanded) {
  background: #ffffff;
}

.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-greeting,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-title,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-summary-text,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-summary-line,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-signature,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-chunk--signature .community-maria-summary-line,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-summary-line strong,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-toggle-btn,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-toggle-btn:hover,
.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-modal-chunk p {
  color: #000000;
  opacity: 1;
}

.community-maria-expand {
  margin-top: 1rem;
}

.community-maria-expand-inner {
  border-top: 1px solid rgba(255, 255, 255, 0.24);
  padding-top: 1rem;
}

.community-maria-expand .community-maria-modal-chunk p {
  word-break: break-all;
  overflow-wrap: anywhere;
}

.community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-expand-inner {
  border-top-color: rgba(0, 0, 0, 0.2);
}

@keyframes community-maria-hero-fade-in {
  from {
    opacity: 0;
    filter: brightness(0.76);
  }
  to {
    opacity: 1;
    filter: brightness(1);
  }
}

@media (prefers-reduced-motion: reduce) {
  .community-maria-section {
    animation: none;
    opacity: 1;
    filter: none;
  }

  .community-main > .community-maria-section .community-maria-image {
    transition: none;
  }

  .community-main > .community-maria-section:hover:not(.is-expanded) .community-maria-image {
    transform: none;
    filter: none;
  }

  .about-group-photo-section {
    animation: none;
    opacity: 1;
    filter: none;
  }
}


.consulting-representative-greeting.community-maria-section {
  margin-top: 2.5rem;
  padding: 3.5rem 0 3rem;
  background: #000000;
}

.consulting-representative-greeting.community-maria-section .community-maria-greeting,
.consulting-representative-greeting.community-maria-section .community-maria-title,
.consulting-representative-greeting.community-maria-section .community-maria-summary-text,
.consulting-representative-greeting.community-maria-section .community-maria-summary-line,
.consulting-representative-greeting.community-maria-section .community-maria-signature,
.consulting-representative-greeting.community-maria-section .community-maria-chunk--signature .community-maria-summary-line,
.consulting-representative-greeting.community-maria-section .community-maria-summary-line strong,
.consulting-representative-greeting.community-maria-section .community-maria-toggle-btn {
  color: #ffffff;
}

.consulting-representative-greeting.community-maria-section .community-maria-toggle-btn:hover {
  color: #ffffff;
}


.consulting-representative-greeting.community-maria-section .community-maria-title,
.consulting-representative-greeting.community-maria-section .community-maria-greeting,
.consulting-representative-greeting.community-maria-section .community-maria-summary-text,
.consulting-representative-greeting.community-maria-section .community-maria-summary-line,
.consulting-representative-greeting.community-maria-section .community-maria-signature,
.consulting-representative-greeting.community-maria-section .community-maria-toggle-btn {
  opacity: 0.86;
  transition: opacity 0.35s ease;
}

.consulting-representative-greeting.community-maria-section:hover .community-maria-title,
.consulting-representative-greeting.community-maria-section:hover .community-maria-greeting,
.consulting-representative-greeting.community-maria-section:hover .community-maria-summary-text,
.consulting-representative-greeting.community-maria-section:hover .community-maria-summary-line,
.consulting-representative-greeting.community-maria-section:hover .community-maria-signature,
.consulting-representative-greeting.community-maria-section:hover .community-maria-toggle-btn {
  opacity: 1;
}


.consulting-representative-greeting .community-maria-cell--left {
  padding-top: 0.5rem;
  overflow: hidden;
}

.consulting-representative-greeting .community-maria-image {
  width: 81%;
  margin: 0 auto;
  transition: transform 0.45s ease, filter 0.45s ease;
  transform: scale(1);
  filter: brightness(1);
}

.consulting-representative-greeting.community-maria-section:hover .community-maria-image {
  transform: scale(1.02);
  filter: brightness(1.08);
}


.consulting-representative-greeting + .consulting-bu-leader-section {
  margin-top: 0;
}


.consulting-representative-greeting .community-maria-cell--right {
  padding-top: 1rem;
}

.consulting-representative-greeting .community-maria-title-block {
  margin-top: -0.4rem;
}


.consulting-representative-greeting .community-maria-greeting--summary {
  margin-top: 3.95rem;
}


.consulting-representative-greeting .community-maria-chunk + .community-maria-chunk--signature {
  margin-top: 4.35rem;
}

@media (max-width: 768px) {
  .consulting-representative-greeting .community-maria-cell--right {
    padding-top: 0.85rem;
  }
}

.community-maria-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 2rem 2.5rem;
  align-items: start;
}

.community-maria-cell {
  overflow: hidden;
  min-width: 0;
}

.community-maria-cell--left {
  max-width: none;
}

.community-maria-cell--right {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  padding-top: 2.95rem;
  box-sizing: border-box;
}

.community-maria-image {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: top;
}

.community-maria-greeting {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.75;
  color: #374151;
}

.community-maria-greeting > p {
  margin: 0;
}

.community-maria-title-block {
  margin: -0.55rem 0 0;
  padding: 0;
}

.community-maria-title {
  margin: 0;
  font-size: clamp(1.65rem, 3.6vw, 2.35rem);
  font-weight: 800;
  line-height: 1.28;
  letter-spacing: -0.03em;
  color: #000000;
}

.community-maria-greeting--summary {
  margin-top: 3.05rem;
}

.community-maria-summary-text {
  margin: 0;
  max-width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  line-height: 1.34;
  color: #6b7280;
}

.community-maria-chunk {
  margin: 0;
}

.community-maria-chunk + .community-maria-chunk {
  margin-top: 1.42rem;
}

.community-maria-chunk + .community-maria-chunk--signature {
  margin-top: 2rem;
}

.community-maria-chunk--signature {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
}

.community-maria-chunk--signature .community-maria-summary-line {
  font-weight: 600;
  color: #1f2937;
}

.community-maria-signature-img {
  display: block;
  margin-top: 0.55rem;
  margin-left: auto;
  max-width: 12.5rem;
  width: auto;
  height: auto;
}

.community-maria-summary-line {
  display: block;
  white-space: nowrap;
  line-height: 1.34;
}

.community-maria-chunk .community-maria-summary-line + .community-maria-summary-line {
  margin-top: 0.12rem;
}

.community-maria-summary-line strong {
  font-weight: 700;
  color: #000000;
}

@media (max-width: 640px) {
  .community-maria-summary-line {
    white-space: normal;
    word-break: keep-all;
    overflow-wrap: break-word;
  }
}

.community-maria-signature {
  margin-top: 1.35rem !important;
  font-weight: 600;
  color: #1f2937;
}

.community-maria-toggle-btn {
  align-self: flex-start;
  margin-top: 1.5rem;
  padding: 0.35rem 0;
  font-size: 0.88rem;
  font-weight: 500;
  color: #525252;
  background: transparent;
  border: none;
  border-radius: 0;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 0.2em;
  transition: color 0.15s ease;
}

.community-maria-toggle-btn:hover {
  color: #1a1a1a;
  background: transparent;
}


.community-maria-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  box-sizing: border-box;
}

.community-maria-modal[hidden] {
  display: none;
}

.community-maria-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  cursor: pointer;
}

.community-maria-modal-panel {
  position: relative;
  z-index: 1;
  width: min(100%, 40rem);
  max-height: min(88vh, 780px);
  background: #ffffff;
  border-radius: 12px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
}

.community-maria-modal-scroll {
  overflow-y: auto;
  padding: 2.4rem 1.75rem 2.25rem;
  padding-right: 2.75rem;
  -webkit-overflow-scrolling: touch;
}

.community-maria-modal-title {
  margin: 0 0 1.85rem;
  padding-right: 2rem;
  font-size: clamp(1.2rem, 2.8vw, 1.45rem);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: #000000;
}

.community-maria-modal-body {
  margin: 0;
}

.community-maria-modal-chunk + .community-maria-modal-chunk {
  margin-top: 1.35rem;
}

.community-maria-modal-chunk p {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.75;
  color: #374151;
}

.community-maria-modal-chunk p + p {
  margin-top: 0.65rem;
}

.community-maria-modal-chunk--signature {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  text-align: right;
  margin-bottom: 0.35rem;
}

.community-maria-modal-chunk--signature p {
  font-weight: 600;
  color: #1f2937;
  text-align: right;
  max-width: 100%;
}

.community-maria-modal-signature {
  margin-top: 0 !important;
}

.community-maria-modal-close {
  position: absolute;
  top: 0.6rem;
  right: 0.6rem;
  z-index: 2;
  width: 2.25rem;
  height: 2.25rem;
  border: none;
  border-radius: 8px;
  background: transparent;
  color: #64748b;
  font-size: 1.75rem;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color 0.15s ease, color 0.15s ease;
}

.community-maria-modal-close:hover {
  background: #f1f5f9;
  color: #0f172a;
}

@media (max-width: 768px) {
  .community-maria-grid {
    grid-template-columns: 1fr;
  }

  .community-maria-cell--left {
    max-width: 280px;
    margin: 0 auto;
  }

  .community-maria-cell--right {
    padding-top: 1.95rem;
  }

  .community-maria-title {
    text-align: center;
  }

  .community-maria-greeting--summary {
    margin-top: 2.65rem;
  }

  .community-main > .community-maria-section .community-maria-greeting--summary {
    margin-top: calc(1.25rem + clamp(0.95rem, 2.5vh, 1.85rem));
  }

  .community-maria-toggle-btn {
    align-self: center;
    text-align: center;
  }
}


.community-intro-section {
  margin-top: 0;
  padding: 3.8rem 0 3.5rem;
  background: #000000;
}

.community-intro-section .community-intro-container {
  max-width: min(1240px, 100%);
  padding-left: clamp(1rem, 3vw, 2rem);
  padding-right: clamp(1rem, 3vw, 2rem);
}


.community-intro-top-col-wrap {
  position: relative;
  min-width: 0;
}

.community-intro-section .community-intro-top-col-wrap .community-intro-top-col,
.community-intro-section .community-intro-top-col-wrap .community-intro-curtain-panel {
  transform: translateY(0.32rem);
}

.community-intro-curtain-panel {
  position: absolute;
  top: clamp(2.2rem, 3.8vw, 2.8rem);
  bottom: -2.0rem;
  left: calc(var(--community-intro-col-gap, 1.5rem) / -2);
  width: calc(100% + var(--community-intro-col-gap, 1.5rem));
  right: auto;
  z-index: 2;
  margin: 0;
  padding: 0;
  overflow: hidden;
  border-radius: 0;
  pointer-events: none;
}

.community-intro-curtain-img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center;
  vertical-align: top;
  transition:
    filter 0.2s ease,
    opacity 0.35s ease;
}

.community-intro-curtain-word {
  position: absolute;
  inset: 0;
  z-index: 3;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: clamp(2rem, 6vw, 4rem);
  color: #ffffff;
  font-family: "TimesNewerRomanBold", "Times New Roman", Times, serif;
  font-size: clamp(18px, 2.75vw, 36px);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  opacity: 1;
  transition: opacity 0.35s ease;
  pointer-events: none;
}

.community-intro-top-col-wrap:hover .community-intro-curtain-img {
  filter: brightness(1.22);
  opacity: 0;
}

.community-intro-top-col-wrap:hover .community-intro-curtain-word {
  opacity: 0;
}

.community-intro-top-col-wrap:hover .community-intro-curtain-panel {
  pointer-events: none;
}

@media (prefers-reduced-motion: reduce) {
  .community-intro-curtain-img {
    transition:
      filter 0.12s ease,
      opacity 0.18s ease;
  }

  .community-intro-curtain-word {
    transition: opacity 0.18s ease;
  }
}

@media (hover: none) {
  .community-intro-curtain-panel {
    display: none;
  }
}

.community-intro-heading {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.3rem 0.75rem;
  margin: clamp(1.5rem, 3.2vw, 2.35rem) 0 clamp(5.72rem, 10.296vw, 8.228rem);
}

.community-intro-title {
  margin: 0;
  padding-left: 0.65rem;
  font-size: clamp(1.144rem, 1.969vw, 1.397rem);
  font-weight: 800;
  line-height: 1.35;
  color: #ffffff;
  text-align: left;
  position: relative;
  flex: 0 1 auto;
}

.community-intro-subtitle {
  margin: 0;
  padding-left: 0;
  font-size: clamp(0.74rem, 1.15vw, 0.86rem);
  font-weight: 500;
  line-height: 1.4;
  color: rgba(255, 255, 255, 0.72);
  text-align: left;
  flex: 0 1 auto;
}


.community-intro-top-grid {
  --community-intro-col-gap: clamp(1.25rem, 2.5vw, 2.25rem);
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--community-intro-col-gap);
  width: min(100%, 1120px);
  margin-left: auto;
  margin-right: auto;
  margin-top: clamp(1.4rem, 3.2vw, 2.65rem);
  margin-bottom: clamp(2.25rem, 4vw, 3.35rem);
}

.community-intro-top-col {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: clamp(1rem, 2vw, 1.5rem);
  min-width: 0;
}

.community-intro-top-col-title {
  margin: 0;
  text-align: center;
  color: #ffffff;
  font-size: clamp(1.05rem, 1.5vw, 1.28rem);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
  word-break: keep-all;
}

.community-intro-slogan {
  margin: 0;
  text-align: center;
  color: #e2e8f0;
  font-size: clamp(0.95rem, 1.35vw, 1.1rem);
  font-weight: 500;
  line-height: 1.65;
  letter-spacing: -0.02em;
  word-break: keep-all;
}

.community-intro-slogan-em {
  font-weight: 800;
  color: #93c5fd;
}


.community-intro-top-hashtags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
  align-items: center;
  gap: 0.45rem 0.65rem;
  margin: 0;
  padding: 0;
  text-align: center;
  color: #ffffff;
  font-size: clamp(0.8rem, 1.05vw, 0.92rem);
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: -0.02em;
  word-break: keep-all;
}

.community-intro-top-hashtag {
  color: #ffffff;
}

.community-intro-top-note {
  margin: -0.2rem 0 0;
  text-align: center;
  color: rgba(226, 232, 240, 0.78);
  font-size: clamp(0.72rem, 0.9vw, 0.8rem);
  font-weight: 400;
  line-height: 1.45;
  letter-spacing: -0.01em;
  word-break: keep-all;
}


.community-intro-voc-rotator {
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
}

.community-intro-voc-card {
  width: 100%;
  aspect-ratio: 16 / 10;
  box-sizing: border-box;
  border: 1px solid #000000;
  border-radius: 0.5rem;
  background: #ffffff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(0.65rem, 1.5vw, 1rem) clamp(0.75rem, 1.8vw, 1.1rem);
  overflow: hidden;
  filter: brightness(1);
}

.community-intro-voc-card:hover,
.community-intro-voc-card:focus-within {
  background: #000000;
}

.community-intro-voc-card.is-voc-flashing {
  animation: communityIntroVocFlash 0.62s ease;
}

@keyframes communityIntroVocFlash {
  0% {
    filter: brightness(1);
  }
  38% {
    filter: brightness(1.12);
  }
  100% {
    filter: brightness(1);
  }
}

.community-intro-voc-text {
  margin: 0;
  width: 100%;
  max-height: 100%;
  overflow: auto;
  text-align: center;
  color: #000000;
  font-size: clamp(0.984rem, 1.2915vw, 1.1685rem);
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  word-break: keep-all;
  overflow-wrap: break-word;
}

.community-intro-voc-card:hover .community-intro-voc-text,
.community-intro-voc-card:focus-within .community-intro-voc-text {
  color: #ffffff;
}

.community-intro-voc-dots {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.58rem;
  margin: 1.15rem 0 0;
  padding: 0;
  width: 100%;
  position: relative;
  z-index: 3;
}

.community-intro-voc-dot {
  width: 8.5px;
  height: 8.5px;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.45);
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}

.community-intro-voc-dot:hover,
.community-intro-voc-dot:focus-visible {
  background: rgba(226, 232, 240, 0.85);
  outline: none;
}

.community-intro-voc-dot.is-active {
  background: #e2e8f0;
  transform: scale(1.15);
}


.community-intro-details-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(1.25rem, 2.5vw, 2.25rem);
  width: min(100%, 1120px);
  margin-left: auto;
  margin-right: auto;
  align-items: start;
}

.community-intro-detail-slot {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  min-width: 0;
}

.community-intro-more-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  box-sizing: border-box;
  padding: 0;
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: #ffffff;
  background: transparent;
  border-radius: 0;
  text-decoration: none;
  text-align: center;
  border: none;
  cursor: pointer;
  transition:
    color 0.22s ease,
    opacity 0.22s ease,
    text-decoration-color 0.22s ease;
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-decoration-color: rgba(255, 255, 255, 0.7);
  text-underline-offset: 0.22em;
}

.community-intro-more-btn:hover {
  color: #ffffff;
  opacity: 0.82;
  text-decoration-color: #ffffff;
}

.community-intro-more-btn:focus-visible {
  outline: 2px solid var(--color-brand-theme-blue);
  outline-offset: 2px;
}

@media (prefers-reduced-motion: reduce) {
  .community-intro-more-btn {
    transition: color 0.2s ease, opacity 0.2s ease, text-decoration-color 0.2s ease;
  }

  .community-intro-more-btn:hover {
    opacity: 0.9;
  }
}

.community-intro-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.45rem;
  align-items: start;
}

.community-intro-set {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  gap: 0.85rem;
}

.community-intro-cell {
  display: grid;
  grid-template-columns: minmax(320px, 430px) minmax(0, 1fr);
  column-gap: 1.95rem;
  row-gap: 0.9rem;
  position: relative;
  align-items: start;
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  min-width: 0;
  padding: 0.62rem 0.68rem;
  border-radius: 0.72rem;
  overflow: visible;
  background: #ffffff;
  border: none;
}


.community-intro-cell--details {
  grid-template-columns: 1fr;
  max-width: none;
  margin-left: 0;
  margin-right: 0;
}

.community-intro-cell--details .community-intro-keyword-block {
  grid-column: 1;
  grid-row: 1;
  width: 100%;
}

.community-intro-top-col .community-intro-image-frame {
  width: 100%;
}

.community-intro-cell::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  overflow: hidden;
  pointer-events: none;
  background: #ffffff;
  z-index: 0;
}

.community-intro-cell > * {
  position: relative;
  z-index: 1;
}

.community-intro-cell > .community-intro-keyword-block {
  z-index: 3;
}


.community-intro-cell:not(.community-intro-cell--details) .community-intro-image-frame {
  grid-column: 1;
  grid-row: 1;
}

.community-intro-image-frame {
  position: relative;
  z-index: 1;
  width: 100%;
  border-radius: 0.5rem;
  transition: box-shadow 0.28s ease, transform 0.28s ease;
  box-shadow: 0 2px 12px rgba(15, 23, 42, 0.06);
}

.community-intro-image-frame:hover {
  z-index: 2;
  transform: translateY(-6px) scale(1.02);
  box-shadow:
    0 18px 36px rgba(15, 23, 42, 0.2),
    0 8px 16px rgba(15, 23, 42, 0.1),
    0 2px 6px rgba(15, 23, 42, 0.06);
}

@media (prefers-reduced-motion: reduce) {
  .community-intro-image-frame {
    transition: none;
  }

  .community-intro-image-frame:hover {
    transform: none;
    box-shadow: 0 6px 20px rgba(15, 23, 42, 0.12);
  }

  .community-intro-play-btn {
    transition: none;
  }

  .community-intro-play-btn:hover {
    transform: translate(-50%, -50%);
  }

  .community-intro-flip-inner {
    transition: none;
  }
}

.community-intro-image-slot {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: 0.5rem;
  overflow: hidden;
  background: #e8edf3;
  box-sizing: border-box;
}

.community-intro-image-slot .community-intro-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.community-intro-play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 68px;
  height: 68px;
  border: 3px solid #ffffff;
  border-radius: 50%;
  background: transparent;
  box-shadow: 0 4px 18px rgba(15, 23, 42, 0.35), 0 2px 6px rgba(15, 23, 42, 0.2);
  cursor: pointer;
  padding: 0;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
  z-index: 2;
}

.community-intro-play-btn::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-38%, -50%);
  border-style: solid;
  border-width: 12px 0 12px 20px;
  border-color: transparent transparent transparent #ffffff;
}

.community-intro-play-btn:hover {
  border-color: #ffffff;
  box-shadow: 0 6px 22px rgba(15, 23, 42, 0.42), 0 3px 8px rgba(15, 23, 42, 0.25);
  transform: translate(-50%, -50%) scale(1.04);
}

.community-intro-cell:not(.community-intro-cell--details) .community-intro-keyword-block {
  grid-column: 2;
  grid-row: 1;
}

.community-intro-keyword-block {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  width: 100%;
  gap: 0.9rem;
  margin-top: 0;
  margin-bottom: 0;
  min-height: 100%;
}

.community-intro-head-row {
  display: flex;
  align-items: center;
  gap: 0.88rem;
  width: 100%;
  flex-wrap: wrap;
}

.community-intro-heading {
  margin: 0;
  width: auto;
  flex: 0 0 auto;
  font-size: 1.0625rem;
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: #0f172a;
  text-align: left;
  word-break: keep-all;
}

.community-intro-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.22rem 0.2rem;
  align-items: center;
  justify-content: flex-end;
  align-content: center;
  width: auto;
  min-height: 0;
  margin-left: auto;
  flex: 1 1 auto;
}


.community-intro-flip {
  width: 100%;
  margin-top: calc(2.18rem - 0.55rem + 1.4rem);
  perspective: 1200px;
  perspective-origin: 50% 50%;
}

.community-intro-flip-inner {
  position: relative;
  width: 100%;
  transform-style: preserve-3d;
  transition: transform 1.05s cubic-bezier(0.4, 0, 0.2, 1);
  transform: rotateY(0deg);
}

.community-intro-flip-inner.is-flipped {
  transform: rotateY(180deg);
}

.community-intro-flip-face {
  width: 100%;
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

.community-intro-flip-face--front {
  position: relative;
  z-index: 2;
  transform: rotateY(0deg);
}

.community-intro-flip-face--back {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  min-height: 100%;
  transform: rotateY(180deg);
  display: flex;
  flex-direction: column;
  overflow: visible;
}

.community-intro-flip-face--back .community-intro-copy {
  flex: 1 1 auto;
  min-height: 100%;
  transform: translateY(-1.05rem);
}

.community-intro-voc {
  margin: 0 auto;
  width: 92%;
  box-sizing: border-box;
  padding: 0.92rem 0.95rem;
  border-radius: 0.6rem;
  background: #000000;
  color: #ffffff;
  font-size: 0.92rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: -0.01em;
  text-align: center;
  word-break: keep-all;
  overflow-wrap: break-word;
}

.community-intro-voc strong {
  font-weight: 700;
  color: #ffffff;
}

.community-intro-copy-toggle {
  margin-top: 2.35rem;
  align-self: center;
}

.community-intro-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-top: 2.65rem;
}

.community-intro-actions .community-intro-copy-toggle {
  margin-top: 0;
  align-self: auto;
}

.community-intro-copy-toggle,
a.community-intro-more-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.18rem 0;
  font-size: 0.8rem;
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.01em;
  color: #334155;
  background: transparent;
  border: none;
  border-radius: 0;
  cursor: pointer;
  text-decoration: underline;
  text-decoration-color: rgba(170, 180, 196, 0.45);
  text-underline-offset: 0.2em;
  transition: color 0.2s ease, text-decoration-color 0.2s ease;
}

.community-intro-copy-toggle:hover,
a.community-intro-more-link:hover {
  color: #1e293b;
  text-decoration-color: rgba(30, 41, 59, 0.48);
}

.community-intro-copy {
  margin: 0;
  width: 100%;
  box-sizing: border-box;
  padding: 1rem 1.15rem;
  font-size: 1.02rem;
  line-height: 1.75;
  color: #ffffff;
  font-weight: 400;
  letter-spacing: -0.02em;
  text-align: justify;
  text-align-last: left;
  text-justify: inter-word;
  text-indent: 1.25ch;
  word-break: keep-all;
  overflow-wrap: break-word;
  background: #1f2329;
  border-radius: 0.75rem;
  overflow: hidden;
}

.community-intro-copy strong {
  color: #ffffff;
  font-weight: 700;
}

.community-intro-copy--conference {
  word-break: normal;
  overflow-wrap: anywhere;
}

.community-intro-copy--ccClass {
  word-break: normal;
  overflow-wrap: anywhere;
}

.community-intro-tag {
  display: inline-block;
  padding: 0.28rem 0.55rem;
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.3;
  color: var(--color-brand-theme-blue);
  background: #ffffff;
  border-radius: 999px;
  letter-spacing: -0.02em;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease,
    box-shadow 0.2s ease;
}

.community-intro-tag:hover {
  background: #f8fafc;
  color: var(--color-brand-theme-blue);
  transform: translateY(-1px);
  box-shadow: 0 2px 10px rgba(15, 23, 42, 0.12);
}

@media (prefers-reduced-motion: reduce) {
  .community-intro-tag {
    transition: none;
  }

  .community-intro-tag:hover {
    transform: none;
  }
}


.community-intro-text-link {
  grid-column: 2;
  grid-row: 2;
  margin-top: 0.15rem;
  justify-self: start;
  align-self: start;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.1rem 0;
  font-size: 0.78rem;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.01em;
  color: #9ca3af;
  text-decoration: none;
  background: transparent;
  border: none;
  border-radius: 0;
  opacity: 0.88;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.community-intro-text-link:hover {
  color: #d1d5db;
  opacity: 1;
  background: transparent;
}

@media (max-width: 768px) {
  .community-intro-top-grid,
  .community-intro-details-grid {
    grid-template-columns: 1fr;
  }

  .community-intro-grid {
    grid-template-columns: 1fr;
  }

  .community-intro-cell {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .community-intro-cell:not(.community-intro-cell--details) .community-intro-image-frame,
  .community-intro-cell:not(.community-intro-cell--details) .community-intro-keyword-block,
  .community-intro-text-link {
    grid-column: auto;
    grid-row: auto;
  }

  .community-intro-keyword-block {
    margin-top: 0.25rem;
    min-height: 0;
  }

  .community-intro-text-link {
    justify-self: auto;
    align-self: center;
  }

  .community-intro-tags {
    justify-content: flex-end;
    gap: 0.24rem 0.22rem;
  }
}


.community-calendar-section {
  margin-top: 5.1rem;
  padding: 0 0 6.25rem;
}

.community-calendar-title {
  margin: 1.2rem 0 2.8rem;
  padding-left: 0.65rem;
  text-align: left;
  color: #ffffff;
  font-size: clamp(1.04rem, 1.79vw, 1.27rem);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
  position: relative;
}

.community-calendar-guide {
  margin: -1.2rem 0 1rem;
  text-align: left;
  color: rgba(209, 213, 219, 0.86);
  font-size: clamp(0.72rem, 0.95vw, 0.82rem);
  font-weight: 500;
  line-height: 1.45;
  letter-spacing: -0.01em;
}

.community-calendar-grid {
  width: 100%;
  margin-top: 0;
  border: 1px solid rgba(255, 255, 255, 0.09);
  background: #111318;
  overflow-x: auto;
}

.community-calendar-row {
  display: grid;
  grid-template-columns: 154px repeat(12, minmax(70px, 1fr));
  border-top: 1px solid rgba(255, 255, 255, 0.07);
}

.community-calendar-row:first-child {
  border-top: none;
}

.community-calendar-row:not(.community-calendar-row--head) {
  min-height: 108px;
}

.community-calendar-cell {
  min-height: 76px;
  padding: 0.72rem 0.3rem;
  border-left: 1px solid rgba(255, 255, 255, 0.06);
  color: #d1d5db;
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.35;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 0.28rem;
  white-space: nowrap;
}

.community-calendar-row:not(.community-calendar-row--head) .community-calendar-cell {
  min-height: 108px;
}

.community-calendar-cell:first-child {
  border-left: none;
}

.community-calendar-row--head .community-calendar-cell {
  min-height: 48px;
  padding: 0.5rem 0.28rem;
  color: #9ca3af;
  font-size: 0.82rem;
  font-weight: 700;
  background: #151922;
}

.community-calendar-row--head .community-calendar-cell--program {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.community-calendar-cell--program {
  align-items: flex-start;
  justify-content: center;
  text-align: left;
  padding: 0.92rem 0.95rem;
  background: #181b22;
}

.community-calendar-program-title {
  color: #d1d5db;
  font-size: 0.98rem;
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -0.01em;
}

.community-calendar-program-meta {
  margin-top: 0.28rem;
  color: #9ca3af;
  font-size: 0.75rem;
  font-weight: 600;
}

.community-calendar-program-place {
  margin-top: 0.62rem;
  color: #d1d5db;
  font-size: 0.8rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.community-calendar-program-place em {
  font-style: normal;
  color: #cbd5e1;
  font-size: 0.68rem;
  font-weight: 700;
  border: 1px solid rgba(148, 163, 184, 0.5);
  border-radius: 0.3rem;
  padding: 0.1rem 0.34rem;
  line-height: 1.2;
}

.community-calendar-pill {
  min-width: 2.83rem;
  padding: 0.28rem 0.58rem;
  border-radius: 999px;
  background: #071a3a;
  border: 1px solid rgba(21, 46, 82, 0.82);
  color: #dbeafe;
  font-size: 0.74rem;
  font-weight: 700;
  line-height: 1.05;
  text-align: center;
}

.community-calendar-pill--btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}

.community-calendar-pill--btn:hover {
  background: #ffffff;
  color: #071a3a;
  border-color: #ffffff;
}

.community-calendar-pill--btn:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.community-calendar-note {
  color: #6b7280;
  font-size: 0.72rem;
  font-weight: 600;
  line-height: 1.25;
}

.community-calendar-dash {
  color: #3f4652;
  font-size: 1rem;
  font-weight: 700;
}

@media (max-width: 1200px) {
  .community-calendar-grid {
    overflow-x: auto;
  }

  .community-calendar-row {
    min-width: 1080px;
  }
}

.community-calendar-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 1.8rem 3.78rem;
  margin-top: 1.82rem;
}

.community-calendar-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.585rem 1.1rem;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: #000000;
  background: var(--branding-color-2);
  border: 2px solid transparent;
  border-radius: 0.5rem;
  text-decoration: none;
  cursor: pointer;
  box-sizing: border-box;
  transform: translateY(0) scale(1);
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease,
    box-shadow 0.2s ease;
}

.community-calendar-cta:hover {
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: transparent;
  transform: translateY(-2px) scale(1.06);
  box-shadow: 0 8px 18px rgba(0, 94, 255, 0.32);
}

.community-calendar-cta:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}


.community-vision-section {
  margin-top: 0;
  padding: 3.8rem 0 3.5rem;
  background: #ffffff;
}

.community-vision-section > .container {
  opacity: 1;
  transform: none;
}

.community-vision-section .community-maria-title {
  font-size: clamp(1.32rem, 2.88vw, 1.88rem);
}

.community-vision-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.15fr);
  gap: 2.25rem 2.75rem;
  align-items: stretch;
}

.community-vision-cell {
  min-width: 0;
}

.community-vision-cell--photo {
  position: relative;
  display: flex;
  align-items: flex-start;
}

.community-vision-cell--text {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  align-self: stretch;
  padding-top: 0;
  box-sizing: border-box;
  min-height: 0;
}

.community-vision-text-body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.community-vision-section .community-maria-greeting--summary {
  margin-top: 2.5rem;
}

.community-vision-cell--text > .community-maria-chunk--signature.community-vision-signature {
  margin-top: auto;
  flex-shrink: 0;
}

.community-vision-image {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: top;
  border-radius: 12px;
  box-shadow: 0 10px 36px rgba(15, 23, 42, 0.12);
}

.community-vision-section .community-maria-summary-text .community-maria-summary-line {
  white-space: normal;
}

@media (max-width: 768px) {
  .community-vision-section {
    padding: 2.75rem 0 2.75rem;
  }

  .community-vision-grid {
    grid-template-columns: 1fr;
    gap: 1.75rem;
    align-items: start;
  }

  .community-vision-cell--text {
    padding-top: 1.95rem;
    height: auto;
  }

  .community-vision-text-body {
    flex: none;
    overflow-y: visible;
    min-height: 0;
  }

  .community-vision-cell--text > .community-maria-chunk--signature.community-vision-signature {
    margin-top: 2rem;
  }

  .community-vision-section .community-maria-greeting--summary {
    margin-top: 2.65rem;
  }
}


.community-testimony-section {
  margin-top: 2rem;
  padding: 0 0 2rem;
}

.community-testimony-title {
  margin: 1.2rem 0 2.904rem;
  padding-left: 0.65rem;
  text-align: left;
  color: #ffffff;
  font-size: clamp(1.04rem, 1.79vw, 1.27rem);
  font-weight: 800;
  line-height: 1.35;
  letter-spacing: -0.02em;
  position: relative;
}

.community-testimony-category-tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 2.79rem;
  margin: 0 0 2.1384rem;
  padding-left: 0.65rem;
}

.community-testimony-category-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 9.35rem;
  padding: 0.423rem 1.27rem;
  border: 2px solid transparent;
  border-radius: 0.5rem;
  background: #ffffff;
  color: #000000;
  font-size: 0.97rem;
  font-weight: 600;
  line-height: 1.35;
  cursor: pointer;
  transform: scale(1);
  transition:
    background-color 0.2s ease,
    color 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s ease;
}

.community-testimony-category-btn:hover,
.community-testimony-category-btn:focus-visible {
  background: var(--branding-color-2);
  color: #000000;
  border-color: transparent;
  transform: scale(1.04);
  outline: none;
}

.community-testimony-category-btn.is-current {
  background: var(--branding-color-2);
  color: #000000;
  border-color: transparent;
}

.community-intro-title::before,
.community-calendar-title::before,
.community-testimony-title::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 3.4px;
  height: 80%;
  background: #ffffff;
  transform: translateY(-50%);
}

.community-main .community-intro-title::before,
.community-main .community-calendar-title::before,
.community-main .community-testimony-title::before {
  content: none;
}


.community-testimony-photos {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
}

.community-testimony-photo-stage {
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: 12px;
  background: #111827;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}


.community-main .community-testimony-section .community-testimony-photo-stage {
  overflow: visible;
}

.community-main .community-testimony-section .community-testimony-photo-track {
  overflow: hidden;
  border-radius: 12px;
}


.community-main .community-testimony-section .community-testimony-nav--community {
  display: inline-flex;
  z-index: 3;
  padding: 0.21rem 0.49rem;
  min-width: auto;
  min-height: auto;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color: rgba(248, 250, 252, 0.42);
  font-size: clamp(3.85rem, 10.5vw, 5.95rem);
  font-weight: 700;
  line-height: 0.85;
  transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.community-main .community-testimony-section .community-testimony-nav--community:hover {
  background: transparent;
  border: none;
  color: rgba(248, 250, 252, 0.72);
}

.community-main .community-testimony-section .community-testimony-nav--community:focus-visible {
  outline: 2px solid rgba(248, 250, 252, 0.45);
  outline-offset: 4px;
}

.community-main .community-testimony-section .community-testimony-nav--community.community-testimony-nav--prev {
  left: 0;
  transform: translate(-50%, -50%);
}

.community-main .community-testimony-section .community-testimony-nav--community.community-testimony-nav--next {
  right: 0;
  transform: translate(50%, -50%);
}

.community-testimony-nav {
  position: absolute;
  top: 50%;
  z-index: 2;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin: 0;
  padding: 0.35rem 0.55rem;
  min-width: 2.25rem;
  min-height: 2.75rem;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.42);
  color: #f8fafc;
  font-size: clamp(1.15rem, 2.2vw, 1.45rem);
  font-weight: 700;
  line-height: 1;
  cursor: pointer;
  transition: background 0.2s ease, border-color 0.2s ease, transform 0.2s ease;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

.community-testimony-nav:hover {
  background: rgba(15, 23, 42, 0.58);
  border-color: rgba(255, 255, 255, 0.5);
}

.community-testimony-nav:focus-visible {
  outline: 2px solid rgba(226, 232, 240, 0.95);
  outline-offset: 2px;
}

.community-testimony-nav--prev {
  left: clamp(0.35rem, 1.5vw, 0.75rem);
}

.community-testimony-nav--next {
  right: clamp(0.35rem, 1.5vw, 0.75rem);
}


.corporate-education-voc-section .community-testimony-nav,
.corporate-education-workshop-carousel .community-testimony-nav {
  padding: 0.2rem 0.45rem;
  min-width: auto;
  min-height: auto;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  color: rgba(248, 250, 252, 0.5);
  font-size: clamp(2.85rem, 6.8vw, 4.15rem);
  font-weight: 700;
  line-height: 0.85;
  transition: color 0.2s ease, opacity 0.2s ease, transform 0.2s ease;
}

.corporate-education-voc-section .community-testimony-nav:hover,
.corporate-education-workshop-carousel .community-testimony-nav:hover {
  background: transparent;
  border: none;
  color: rgba(248, 250, 252, 0.78);
}

.corporate-education-voc-section .community-testimony-nav:focus-visible,
.corporate-education-workshop-carousel .community-testimony-nav:focus-visible {
  outline: 2px solid rgba(248, 250, 252, 0.65);
  outline-offset: 4px;
}


.corporate-education-main .corporate-education-voc-section .community-testimony-nav > span,
.corporate-education-main .corporate-education-workshop-carousel .community-testimony-nav > span {
  display: inline-block;
  transform: scaleY(1.26);
  transform-origin: center;
}


.corporate-education-voc-section .community-testimony-photo-stage {
  overflow: visible;
}

.corporate-education-voc-section .community-testimony-photo-track {
  overflow: hidden;
  border-radius: 12px;
}

.corporate-education-voc-section .community-testimony-nav {
  padding: clamp(1.05rem, 3vw, 1.85rem) 0.45rem;
}

.corporate-education-voc-section .community-testimony-nav--prev {
  left: 0;
  transform: translate(-50%, -50%);
}

.corporate-education-voc-section .community-testimony-nav--next {
  right: 0;
  transform: translate(50%, -50%);
}

.community-testimony-photo-track {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
}

.community-testimony-photo-img {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0;
  transition: opacity 1s ease;
  pointer-events: none;
}

.community-testimony-photo-img.is-active {
  opacity: 1;
}

@media (prefers-reduced-motion: reduce) {
  .community-testimony-photo-img {
    transition: opacity 0.01ms;
  }
}

.community-testimony-photo-dots {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  margin: 1.15rem 0 0;
  padding: 0;
}

.community-testimony-dot {
  width: 0.45rem;
  height: 0.45rem;
  padding: 0;
  border: none;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.45);
  cursor: pointer;
  transition: background 0.2s ease, transform 0.2s ease;
}

.community-testimony-dot:hover,
.community-testimony-dot:focus-visible {
  background: rgba(226, 232, 240, 0.85);
  outline: none;
}

.community-testimony-dot.is-current {
  background: #e2e8f0;
  transform: scale(1.15);
}


.community-invitation-section {
  margin-top: 3rem;
  padding: 0 0 0;
}

.community-invitation-section .container {
  display: flex;
  flex-direction: column;
  gap: 2.8rem;
  width: 100%;
}

.community-invitation-gallery {
  display: flex;
  flex-direction: column;
  gap: clamp(0.85rem, 2vw, 1.35rem);
  width: 100%;
  margin-top: 2.3rem;
}

.community-invitation-section .community-invitation-gallery {
  margin-top: 0;
}

.community-invitation-hero {
  width: 100%;
  overflow: hidden;
  border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.45);
}

.community-invitation-thumbs {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.65rem, 2vw, 1.1rem);
  align-items: start;
}

.community-invitation-thumbs li {
  margin: 0;
}

.community-invitation-thumb {
  margin: 0;
  height: 100%;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 8px 28px rgba(0, 0, 0, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.community-invitation-hero,
.community-invitation-thumb {
  transition:
    opacity 0.48s ease,
    transform 0.48s ease;
}

@media (hover: hover) and (pointer: fine) {
  .community-invitation-hero,
  .community-invitation-thumb {
    opacity: 0.72;
    transform: translateY(0.35rem);
  }

  .community-invitation-hero:hover,
  .community-invitation-thumb:hover {
    opacity: 1;
    transform: translateY(0);
  }
}

.community-invitation-image--hero {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: top;
  display: block;
}

.community-invitation-image--thumb {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  vertical-align: top;
}

@media (min-width: 769px) {
  .community-invitation-thumbs li:nth-child(2) .community-invitation-image--thumb {
    transform: translateY(-0.35rem);
  }

  .community-invitation-thumbs li:nth-child(3) .community-invitation-image--thumb {
    transform: translateY(0.2rem);
  }
}

@media (prefers-reduced-motion: reduce) {
  .community-invitation-thumbs li:nth-child(2) .community-invitation-image--thumb,
  .community-invitation-thumbs li:nth-child(3) .community-invitation-image--thumb {
    transform: none;
  }

  .community-invitation-hero,
  .community-invitation-thumb {
    transition: none;
    opacity: 1;
    transform: none;
  }
}

.community-invitation-text-block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.85rem;
}

.community-invitation-message {
  margin: 0;
  text-align: center;
  font-size: 1.95rem;
  line-height: 1.35;
  font-weight: 600;
  color: #ffffff;
  font-family: var(--font-sans-variable);
  letter-spacing: -0.03em;
}

.community-invitation-hint {
  margin: 0;
  max-width: 28rem;
  text-align: center;
  font-size: 0.9rem;
  font-weight: 500;
  line-height: 1.55;
  letter-spacing: -0.02em;
  color: #ffffff;
  font-family: var(--font-sans-variable);
}

.community-invitation-image {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: top;
}

@media (max-width: 600px) {
  .community-invitation-thumbs {
    grid-template-columns: 1fr;
    gap: 0.7rem;
  }

  .community-invitation-thumbs li:nth-child(2) .community-invitation-image--thumb,
  .community-invitation-thumbs li:nth-child(3) .community-invitation-image--thumb {
    transform: none;
  }

  .community-invitation-image--thumb {
    aspect-ratio: 16 / 9;
  }
}

@media (max-width: 768px) {
  .community-invitation-message {
    font-size: 1.72rem;
  }

  .community-invitation-hint {
    font-size: 0.84rem;
  }
}


.community-video-section {
  margin-top: 1.6rem;
  padding: 0 0 2rem;
}

.community-video-title {
  margin: 0 0 1.7rem;
  padding-left: 0.65rem;
  border-left: 4px solid var(--color-brand-theme-blue);
  font-size: 1.15rem;
  font-weight: 800;
  line-height: 1.4;
  color: #111827;
  text-align: left;
}

.community-video-list {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.community-video-block {
  display: flex;
  flex-direction: row;
  align-items: stretch;
  gap: 1rem;
}

.community-video-block--left {
  flex-direction: row;
}

.community-video-block--right {
  flex-direction: row;
}

.community-video-thumb-wrap {
  position: relative;
  flex: 1 1 auto;
  max-width: 65%;
  max-height: 280px;
  aspect-ratio: 21 / 9;
  overflow: hidden;
  border-radius: 8px;
}

.community-video-thumb {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.community-video-play-btn {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 56px;
  height: 56px;
  border: none;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer;
  padding: 0;
  transition: background 0.2s;
}

.community-video-play-btn::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-40%, -50%);
  border-style: solid;
  border-width: 10px 0 10px 18px;
  border-color: transparent transparent transparent #fff;
}

.community-video-play-btn:hover {
  background: rgba(0, 0, 0, 0.8);
}

.community-video-text {
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  padding: 1rem;
  background: #f3f4f6;
  border-radius: 8px;
  color: #6b7280;
  font-size: 0.95rem;
}


.community-video-popup {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.community-video-popup[hidden] {
  display: none;
}

.community-video-popup-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  cursor: pointer;
}

.community-video-popup-inner {
  position: relative;
  width: 90%;
  max-width: 900px;
  aspect-ratio: 16 / 9;
  background: #000;
  border-radius: 8px;
  overflow: hidden;
}

#consulting-voc-video-popup .community-video-popup-inner {
  width: 90%;
  max-width: 900px;
}

.community-video-popup-close {
  position: absolute;
  top: 0.5rem;
  right: 0.5rem;
  width: 36px;
  height: 36px;
  border: none;
  border-radius: 999px;
  background: transparent;
  color: #ffffff;
  font-size: 2rem;
  line-height: 1;
  cursor: pointer;
  z-index: 5;
  padding: 0;
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.65);
}

.community-video-popup-close:hover,
.community-video-popup-close:focus-visible {
  background: transparent;
  color: #f3f4f6;
}

.community-video-popup-close:focus {
  outline: none;
}

.community-video-popup-close:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.85);
  outline-offset: 2px;
}

.community-video-popup-body {
  position: absolute;
  inset: 0;
}

.community-video-popup-iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}


#home-testimonial-video-popup .testimonial-popup-video-native,
#testimonials-page-video-popup .testimonial-popup-video-native,
#consulting-voc-video-popup .consulting-voc-video-native {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #0f172a;
}

#consulting-voc-video-popup .home-testimonial-video-placeholder {
  z-index: 1;
}

#home-testimonial-video-popup .home-testimonial-video-placeholder,
#testimonials-page-video-popup .home-testimonial-video-placeholder {
  z-index: 1;
}


.home-testimonial-video-placeholder {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0f172a;
  color: #e5e7eb;
  text-align: center;
  padding: 1.5rem;
}

/* display:flex가 [hidden]의 display:none을 덮어써 플레이스홀더가 iframe 위에 남던 문제 (VOC 영상 팝업) */
.home-testimonial-video-placeholder[hidden] {
  display: none !important;
}

.home-testimonial-video-placeholder p {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.6;
}


#testimonials-story-page-popup .testimonials-story-popup-inner,
#home-story-page-popup .testimonials-story-popup-inner {
  aspect-ratio: auto;
  min-height: min(75vh, 720px);
  width: min(1000px, 92vw);
  max-width: 1000px;
  background: #ffffff;
}


#testimonials-story-page-popup .community-video-popup-close,
#home-story-page-popup .community-video-popup-close {
  top: 0.5rem;
  right: 0.5rem;
  color: #374151;
  background: transparent;
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.95);
  border-radius: 8px;
  width: 2.25rem;
  height: 2.25rem;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

#testimonials-story-page-popup .community-video-popup-close:hover,
#home-story-page-popup .community-video-popup-close:hover,
#testimonials-story-page-popup .community-video-popup-close:focus-visible,
#home-story-page-popup .community-video-popup-close:focus-visible {
  background: transparent;
  color: #111827;
}

#testimonials-story-page-popup .community-video-popup-close:focus-visible,
#home-story-page-popup .community-video-popup-close:focus-visible {
  outline: 2px solid rgba(55, 65, 81, 0.5);
  outline-offset: 2px;
}

@media (max-width: 768px) {
  .community-video-block,
  .community-video-block--right {
    flex-direction: column;
  }
  .community-video-thumb-wrap {
    flex: 0 0 auto;
    width: 100%;
  }
}


.story-page-main {
  padding-top: calc(var(--header-height) + 1rem);
  padding-bottom: 3rem;
  min-height: 50vh;
  background-color: #000000;
}


.story-popup-body {
  margin: 0;
  min-height: 100vh;
  background-color: #000000;
}

.story-popup-body .story-page-main {
  padding-top: 1.5rem;
  padding-bottom: 2.5rem;
}

.story-page-container {
  max-width: 880px;
}

.story-page-header--intro {
  margin-bottom: 2rem;
}

.story-page-hero-quote {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 700;
  line-height: 1.45;
  color: #ffffff;
  text-align: center;
}

.story-page-hero-attribution {
  margin: 1.43rem 0 0;
  font-size: 0.82rem;
  line-height: 1.55;
  color: #ffffff;
  text-align: right;
}

.story-page-section {
  margin-bottom: 2.25rem;
}

.story-page-voc-inner {
  background: transparent;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  border: none;
}

.story-page-voc--gratitude .story-page-voc-inner {
  border: none;
  background: transparent;
}

.story-page-voc-label {
  margin: 0 0 0.35rem;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  color: #ffffff;
}

.story-page-section-heading {
  margin: 0 0 0.85rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #ffffff;
}

.story-page-voc-body {
  font-size: 0.98rem;
  line-height: 1.75;
  color: #ffffff;
}

.story-page-voc-body p {
  margin: 0;
}

.story-page-video-section {
  margin-bottom: 2.25rem;
}

.story-page-video-wrap {
  position: relative;
  width: 100%;
  border-radius: var(--radius-md, 10px);
  overflow: hidden;
  background: #e2e8f0;
  aspect-ratio: 16 / 9;
  max-height: 420px;
  margin: 0 auto;
  isolation: isolate;
}

.story-page-video-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.story-page-video-overlay[hidden] {
  display: none !important;
}

.story-page-video-poster {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.story-page-video-play {
  position: relative;
  z-index: 2;
  width: 64px;
  height: 64px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  background: rgba(0, 0, 0, 0.55);
  color: #ffffff;
  font-size: 1.35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0 0 0 4px;
  transition: background 0.2s;
}

.story-page-video-play:hover {
  background: rgba(0, 0, 0, 0.75);
}

.story-page-video-element {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #000;
}

.story-page-video-note {
  margin: 0.65rem 0 0;
  font-size: 0.82rem;
  color: #ffffff;
  text-align: center;
}


.story-page-detail {
  margin-top: 2.5rem;
  padding-top: 2rem;
  border-top: 1px solid rgba(255, 255, 255, 0.24);
}

.story-page-detail-intro {
  margin: 0 0 2rem;
  font-size: 0.92rem;
  line-height: 1.65;
  color: #ffffff;
  text-align: center;
}

.story-page-block-heading {
  margin: 0 0 1.25rem;
  font-size: 1.2rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: -0.02em;
}

.story-page-block-split {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.1fr);
  gap: 1.35rem 1.75rem;
  align-items: start;
}

.story-page-block--reverse .story-page-block-split {
  direction: rtl;
}

.story-page-block--reverse .story-page-block-figure,
.story-page-block--reverse .story-page-block-text {
  direction: ltr;
}

.story-page-block-figure {
  margin: 0;
  border-radius: var(--radius-md, 10px);
  overflow: hidden;
  background: #e2e8f0;
  aspect-ratio: 16 / 10;
}

.story-page-block-figure img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.story-page-block-text {
  font-size: 0.96rem;
  line-height: 1.75;
  color: #ffffff;
}

.story-page-block-text p {
  margin: 0 0 1rem;
}

.story-page-block-text p:last-child {
  margin-bottom: 0;
}


.story-page-principles-lead {
  margin: 0 0 1.25rem;
  font-size: 0.92rem;
  line-height: 1.6;
  color: #ffffff;
}

.story-page-principles-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

.story-page-principle-card {
  margin: 0;
  padding: 1.15rem 1.1rem;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: var(--radius-md, 10px);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.story-page-principle-title {
  margin: 0 0 0.6rem;
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.4;
  color: var(--color-primary, #1e3a8a);
}

.story-page-principle-body {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.65;
  color: var(--color-text, #475569);
}

.story-page-cta-wrap {
  margin-top: 2.25rem;
  text-align: center;
}

.story-page-cta {
  display: inline-block;
  padding: 0.85rem 1.85rem;
  font-size: 0.98rem;
  font-weight: 600;
  color: #ffffff;
  background: var(--color-primary, #1e3a8a);
  border-radius: var(--radius-md, 10px);
  text-decoration: none;
  transition: background 0.2s;
}

.story-page-cta:hover {
  background: #172554;
  color: #ffffff;
}


.story-inquiry-main {
  display: flex;
  align-items: flex-start;
  background-color: #000000;
}

.story-popup-body .story-inquiry-main {
  background-color: #000000;
}

.story-popup-body .story-inquiry-main.story-page-main {
  background-color: #000000;
}

.story-inquiry-card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: var(--radius-md, 10px);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
  padding: 1.35rem;
}

.story-inquiry-hero-image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-md, 10px);
  margin-bottom: 1rem;
}

.story-inquiry-title {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--color-text, #0f172a);
}

.story-inquiry-desc {
  margin: 0.5rem 0 1.15rem;
  font-size: 0.92rem;
  color: var(--color-text-muted, #64748b);
}

.story-inquiry-form {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}

.story-inquiry-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.story-inquiry-field span {
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--color-text, #334155);
}

.story-inquiry-field input,
.story-inquiry-field textarea {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 0.7rem 0.8rem;
  font: inherit;
  color: var(--color-text, #0f172a);
  background: #ffffff;
}

.story-inquiry-field textarea {
  resize: vertical;
  min-height: 110px;
}

.story-inquiry-actions {
  display: flex;
  gap: 0.6rem;
  margin-top: 0.24rem;
  justify-content: center;
}

.story-inquiry-main #story-inquiry-submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: clamp(9rem, 14.4vw, 10.98rem);
  padding: 0.7rem 1.26rem;
  border-radius: 12px;
  background: var(--branding-color-2);
  color: #000000;
  text-decoration: none;
  font-size: clamp(0.828rem, 0.72vw + 0.432rem, 0.9rem);
  font-weight: 700;
  line-height: 1;
  border: 2px solid transparent;
  transform: scale(1);
  cursor: pointer;
  transition:
    transform 0.22s ease,
    box-shadow 0.22s ease,
    opacity 0.22s ease,
    background-color 0.22s ease,
    color 0.22s ease,
    border-color 0.22s ease;
}

.story-inquiry-main #story-inquiry-submit:hover,
.story-inquiry-main #story-inquiry-submit:focus-visible {
  transform: translateY(-1px) scale(1.04);
  background: var(--branding-color-1);
  color: #ffffff;
  border-color: var(--branding-color-1);
  box-shadow: 0 8px 16px rgba(0, 94, 255, 0.28);
  opacity: 0.98;
}

.story-inquiry-status {
  margin: 0.15rem 0 0;
  min-height: 0.72rem;
  font-size: 0.86rem;
  text-align: center;
  color: #475569;
}

.story-inquiry-status.is-error {
  color: #dc2626;
}

.story-inquiry-status.is-success {
  color: #047857;
}

.story-inquiry-close {
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  background: #ffffff;
  color: var(--color-text, #334155);
  padding: 0.85rem 1.15rem;
  font-size: 0.95rem;
  font-weight: 600;
  cursor: pointer;
}

.story-page-cta:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.story-admin-main .story-page-container {
  max-width: 1100px;
}

.story-admin-card {
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: var(--radius-md, 10px);
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.08);
  padding: 1.2rem;
}

.story-admin-title {
  margin: 0;
  font-size: 1.25rem;
}

.story-admin-desc {
  margin: 0.45rem 0 1rem;
  color: #64748b;
  font-size: 0.9rem;
}

.story-admin-actions {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.8rem;
}

.story-admin-table-wrap {
  overflow: auto;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}

.story-admin-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 920px;
  font-size: 0.85rem;
}

.story-admin-table th,
.story-admin-table td {
  border-bottom: 1px solid #e2e8f0;
  padding: 0.6rem 0.55rem;
  text-align: left;
  vertical-align: top;
}

.story-admin-table th {
  background: #f8fafc;
  font-weight: 700;
}

.story-admin-message {
  white-space: pre-wrap;
  min-width: 220px;
}

.story-admin-empty {
  text-align: center !important;
  color: #64748b;
}


.login-popup-main {
  padding-top: 1rem;
  padding-bottom: 3rem;
  background-color: #f8fafc;
}

.login-popup-container {
  max-width: 920px;
}

.login-popup-panel,
.login-popup-card,
.login-popup-panel * {
  box-sizing: border-box;
}

.login-popup-panel {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 1.6rem 2rem;
}


.login-popup-main {
  background-image: none;
  background-size: cover;
  background-position: center;
}

.login-popup-hero-image {
  width: 100%;
  height: auto;
  display: block;
  border-radius: var(--radius-md, 14px);
  margin-bottom: 0.65rem;
}

.login-popup-brand {
  margin-bottom: 1.4rem;
}

.login-popup-slogan {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--color-text, #0f172a);
  text-align: left;
}

.login-popup-welcome {
  margin: 0.35rem 0 0;
  font-size: 0.98rem;
  font-weight: 600;
  color: var(--color-text-muted, #64748b);
}

.login-popup-form {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
  max-width: 420px;
}

.login-popup-login-grid {
  display: flex;
  gap: 2.5rem;
  align-items: center;
}

.login-popup-left {
  width: 420px;
  max-width: 100%;
}

.login-popup-right-logo {
  flex: 1;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  transform: translateY(-3.2rem);
}

.login-popup-side-logo {
  max-width: 94px; 
  width: 100%;
  height: auto;
  display: block;
}

.login-popup-field input {
  width: 100%;
  border: none;
  outline: none;
  border-bottom: 2px solid #dbeafe;
  font: inherit;
  color: var(--color-text, #0f172a);
  padding: 0.65rem 0.15rem 0.55rem;
  background: transparent;
  font-size: 1rem;
}

.login-popup-field input:focus {
  border-bottom-color: var(--color-primary, #1e3a8a);
}

.login-popup-links {
  margin-top: 1.55rem;
  display: flex;
  flex-direction: row;
  gap: 1.4rem;
  align-items: center;
  justify-content: center;
  max-width: 420px;
  width: 100%;
  transform: none;
}

.login-popup-primary-btn {
  width: 100%;
  border: none;
  background: var(--color-primary);
  color: #ffffff;
  padding: 0.85rem 1rem;
  border-radius: 10px;
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
}

.login-popup-primary-btn:hover {
  background: #0f2a4d;
}

.login-popup-text-btn {
  border: none;
  background: transparent;
  padding: 0;
  margin: 0;
  font: inherit;
  color: var(--color-primary, #1e3a8a);
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  font-size: 0.8em; 
}

.login-popup-text-btn:hover {
  color: #172554;
}


.signup-popup-main {
  padding-top: 0.5rem;
  padding-bottom: 2.5rem;
  background-color: #f8fafc;
}

.signup-popup-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 420px;
  margin: 0 auto;
}

.signup-field {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.signup-label {
  font-size: 0.86rem;
  font-weight: 700;
  color: var(--color-text, #0f172a);
}

.signup-field input {
  width: 100%;
  box-sizing: border-box;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 0.75rem 0.85rem;
  font: inherit;
  color: var(--color-text, #0f172a);
  background: #ffffff;
}

.signup-id-row {
  display: flex;
  gap: 0.65rem;
  align-items: center;
  width: 100%;
}

.signup-id-row input {
  width: auto;
  flex: 1;
}

.signup-dup-btn {
  border: none;
  background: var(--color-primary, #1e3a8a);
  color: #ffffff;
  font-weight: 700;
  border-radius: 10px;
  padding: 0.75rem 1rem;
  cursor: pointer;
  white-space: nowrap;
}

.signup-dup-btn:hover {
  background: #172554;
}

.signup-status {
  margin: 0.25rem 0 0;
  font-size: 0.86rem;
  color: var(--color-text-muted, #64748b);
  min-height: 1.2rem;
}

.signup-status.is-error {
  color: #dc2626;
}

.signup-status.is-success {
  color: #047857;
}

.login-popup-bottom-text {
  margin: 1.5rem 0 1.75rem;
  text-align: center;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-text, #0f172a);
}

@media (max-width: 768px) {
  .login-popup-panel {
    padding: 1.5rem 1.1rem;
    border-radius: 12px;
  }

  .login-popup-form {
    max-width: 100%;
  }

  .login-popup-login-grid {
    flex-direction: column;
    gap: 1.25rem;
    align-items: stretch;
  }

  .login-popup-left {
    width: 100%;
  }

  .login-popup-right-logo {
    display: none;
  }

  .login-popup-links {
    flex-direction: column;
    gap: 0.55rem;
    transform: none;
  }
}

