/* ===================================================================
   크레센영어교습소 — 메인 스타일 v3
   브랜드: 네이비 + 골드 + 크림 / 베이스 18px / 모바일 우선
   =================================================================== */

:root {
  /* 컬러 시스템 (로고 기반) */
  --c-navy:        #1e3a8a;
  --c-navy-dark:   #172554;
  --c-navy-light:  #3b82f6;
  --c-gold:        #d4a017;
  --c-gold-soft:   #fbbf24;
  --c-cream:       #fdfbf7;
  --c-bg:          #ffffff;
  --c-bg-soft:     #f8fafc;
  --c-bg-warm:     #fef9e7;
  --c-text:        #0f172a;
  --c-text-soft:   #475569;
  --c-muted:       #94a3b8;
  --c-line:        #e2e8f0;
  --c-line-strong: #cbd5e1;

  /* 그림자 */
  --shadow-sm: 0 1px 3px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --shadow-md: 0 10px 25px rgba(15,23,42,.08), 0 3px 8px rgba(15,23,42,.05);
  --shadow-lg: 0 20px 50px rgba(15,23,42,.15), 0 10px 20px rgba(15,23,42,.08);
  --shadow-gold: 0 8px 24px rgba(212,160,23,.25);

  /* 모양 */
  --radius:    14px;
  --radius-sm: 8px;
  --radius-lg: 24px;

  /* 헤더 */
  --header-h: 76px;

  /* 전환 */
  --t-fast: 0.15s cubic-bezier(.4,0,.2,1);
  --t-base: 0.3s cubic-bezier(.4,0,.2,1);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
html, body { margin: 0; padding: 0; }

body {
  font-family: "Pretendard", "Poppins", system-ui, -apple-system, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  font-size: 18px;            /* 사용자 요구 — 베이스 18px */
  line-height: 1.65;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  font-feature-settings: 'kern', 'liga', 'palt';
}

/* 언어별 폰트 */
body.lang-jp { font-family: "Noto Sans JP", "Pretendard", system-ui, sans-serif; }
body.lang-cn { font-family: "Noto Sans SC", "Pretendard", system-ui, sans-serif; }
body.lang-th { font-family: "Noto Sans Thai", "Pretendard", system-ui, sans-serif; }
body.lang-ru, body.lang-vi { font-family: "Pretendard", "Inter", system-ui, sans-serif; }
body.lang-fr, body.lang-de, body.lang-es, body.lang-en {
  font-family: "Pretendard", "Poppins", system-ui, sans-serif;
}

/* 한글-영문 혼용 가독성 */
::selection { background: var(--c-gold); color: var(--c-navy-dark); }

img, video { max-width: 100%; height: auto; display: block; }

a { color: var(--c-navy); text-decoration: none; transition: color var(--t-fast); }
a:hover { color: var(--c-navy-light); }

/* 타이포 — 헤딩은 Playfair Display(세리프) + Pretendard 혼용으로 클래식+모던 */
h1, h2, h3, h4, h5 {
  margin: 0 0 .5em;
  line-height: 1.2;
  letter-spacing: -.02em;
  color: var(--c-navy-dark);
  font-weight: 700;
}
h1 { font-size: clamp(32px, 5.5vw, 56px); font-weight: 800; letter-spacing: -.035em; }
h2 { font-size: clamp(26px, 4.2vw, 42px); font-weight: 700; }
h3 { font-size: clamp(20px, 2.8vw, 26px); font-weight: 700; }
h4 { font-size: 20px; font-weight: 600; }

h1 em, h2 em {
  font-style: normal;
  background: linear-gradient(120deg, var(--c-gold) 0%, var(--c-gold-soft) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 800;
}

p { margin: 0 0 1em; }
small, .small, .footer-bottom { font-size: 16px; }   /* 작은 폰트는 16px (사용자 요구) */
.muted { color: var(--c-text-soft); }

/* 컨테이너 — 좌우 15% 여백 (사용자 요구) */
.container {
  width: 70%;
  max-width: 1600px;
  margin: 0 auto;
  padding: 0 16px;
}
@media (max-width: 1280px) { .container { width: 80%; } }
@media (max-width: 1024px) { .container { width: 90%; } }
@media (max-width: 640px)  { .container { width: 95%; padding: 0 12px; } }

/* eyebrow — 섹션 라벨 */
.eyebrow {
  display: inline-block;
  font-size: 16px;
  font-weight: 700;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--c-gold);
  margin-bottom: 12px;
  position: relative;
  padding-left: 32px;
}
.eyebrow::before {
  content: '';
  position: absolute;
  left: 0; top: 50%;
  width: 24px; height: 2px;
  background: var(--c-gold);
  transform: translateY(-50%);
}

/* ================== HEADER ================== */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(255,255,255,.96);
  backdrop-filter: saturate(180%) blur(16px);
  -webkit-backdrop-filter: saturate(180%) blur(16px);
  border-bottom: 1px solid var(--c-line);
  transition: box-shadow var(--t-base);
}
.site-header.scrolled { box-shadow: var(--shadow-sm); }
.header-inner {
  height: var(--header-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}

/* 로고 */
.logo-block {
  display: flex;
  align-items: center;
  gap: 10px;
  text-decoration: none;
  flex-shrink: 0;
}
.logo-img {
  height: 52px;
  width: auto;
  transition: transform var(--t-fast);
}
.logo-block:hover .logo-img { transform: scale(1.05); }
.logo-text-mobile {
  display: none;
  font-weight: 800;
  font-size: 18px;
  color: var(--c-navy);
  letter-spacing: -.03em;
}
.logo-text-mobile small { display: block; font-size: 16px; font-weight: 600; color: var(--c-text-soft); }

/* 메뉴 */
.primary-nav {
  display: flex;
  gap: 28px;
  margin: 0 auto;
}
.primary-nav .nav-link {
  color: var(--c-text);
  font-weight: 600;
  font-size: 18px;
  padding: 6px 0;
  position: relative;
  transition: color var(--t-fast);
}
.primary-nav .nav-link::after {
  content: '';
  position: absolute;
  left: 50%; bottom: -4px;
  width: 0; height: 3px;
  background: var(--c-gold);
  transition: width var(--t-fast), left var(--t-fast);
  border-radius: 2px;
}
.primary-nav .nav-link:hover { color: var(--c-navy); text-decoration: none; }
.primary-nav .nav-link:hover::after { width: 100%; left: 0; }

.header-actions { display: flex; align-items: center; gap: 12px; }

/* 언어 스위처 (국기 + 코드) */
.lang-switcher-flags {
  display: flex; flex-wrap: nowrap; gap: 3px;
}
.lang-switcher-flags .lang-flag-item {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: 4px 6px 3px;
  border-radius: 6px;
  background: #fff;
  border: 1px solid var(--c-line);
  color: var(--c-text-soft);
  font-weight: 600;
  transition: all var(--t-fast);
  min-width: 38px;
  text-decoration: none;
}
.lang-switcher-flags .lang-flag-item:hover {
  background: var(--c-bg-soft);
  transform: translateY(-2px);
  box-shadow: var(--shadow-sm);
  text-decoration: none;
}
.lang-switcher-flags .lang-flag-item.active {
  background: var(--c-navy-dark);
  border-color: var(--c-navy-dark);
  color: #fff;
}
.lang-switcher-flags .lang-flag-item img {
  width: 26px; height: 19px;
  object-fit: cover;
  border-radius: 2px;
  border: 1px solid rgba(0,0,0,.06);
}
.lang-switcher-flags .lang-flag-item span {
  font-size: 16px; line-height: 1;
  margin-top: 3px; letter-spacing: .5px;
}

/* 햄버거 (모바일) */
.nav-toggle {
  display: none;
  background: transparent; border: 0;
  width: 44px; height: 44px;
  cursor: pointer; padding: 10px;
}
.nav-toggle span {
  display: block; width: 100%; height: 3px;
  background: var(--c-navy-dark);
  border-radius: 2px;
  margin: 4px 0;
  transition: transform var(--t-base), opacity var(--t-base);
}
body.nav-open .nav-toggle span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
body.nav-open .nav-toggle span:nth-child(2) { opacity: 0; }
body.nav-open .nav-toggle span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ================== HERO ================== */
.hero {
  position: relative;
  min-height: clamp(520px, 80vh, 720px);
  overflow: hidden;
  display: flex;
  align-items: center;
  color: #fff;
}
.hero-bg {
  position: absolute; inset: 0;
  z-index: 0;
}
.hero-img {
  width: 100%; height: 100%; object-fit: cover;
  filter: brightness(.7);
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(30,58,138,.85) 0%, rgba(23,37,84,.7) 50%, rgba(15,23,42,.85) 100%);
}
.hero-content {
  position: relative; z-index: 1;
  padding: 80px 16px;
}
.hero-eyebrow {
  display: inline-block;
  padding: 6px 16px;
  background: rgba(212,160,23,.2);
  border: 1px solid rgba(212,160,23,.5);
  color: var(--c-gold-soft);
  font-size: 16px;
  font-weight: 600;
  letter-spacing: .05em;
  border-radius: 50px;
  margin-bottom: 24px;
  backdrop-filter: blur(4px);
}
.hero-title {
  color: #fff;
  font-size: clamp(32px, 6vw, 64px);
  font-weight: 800;
  line-height: 1.15;
  letter-spacing: -.035em;
  margin-bottom: 24px;
}
.hero-line-1 { display: block; font-weight: 500; font-size: .65em; color: rgba(255,255,255,.85); margin-bottom: 8px; }
.hero-line-2 { display: block; }
.hero-line-2 em {
  font-style: normal;
  color: var(--c-gold-soft);
  font-weight: 800;
}
.hero-sub {
  font-size: clamp(18px, 2.2vw, 22px);
  color: rgba(255,255,255,.92);
  margin-bottom: 36px;
  max-width: 600px;
  line-height: 1.55;
}
.hero-buttons {
  display: flex; gap: 12px; flex-wrap: wrap;
  margin-bottom: 48px;
}
.hero-stats {
  display: flex; gap: 40px; flex-wrap: wrap;
  border-top: 1px solid rgba(255,255,255,.2);
  padding-top: 32px;
  max-width: 700px;
}
.hero-stat {
  display: flex; flex-direction: column;
}
.hero-stat strong {
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 800;
  color: var(--c-gold-soft);
  line-height: 1;
  margin-bottom: 6px;
}
.hero-stat span {
  font-size: 16px;
  color: rgba(255,255,255,.8);
  font-weight: 500;
}

/* ================== BUTTONS ================== */
.btn {
  display: inline-flex;
  align-items: center; justify-content: center; gap: 8px;
  padding: 14px 28px;
  border-radius: 50px;
  font-size: 16px;
  font-weight: 600;
  text-decoration: none;
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--t-base);
  white-space: nowrap;
  min-height: 48px;
}
.btn:hover { text-decoration: none; transform: translateY(-2px); }
.btn-lg { padding: 16px 32px; font-size: 18px; min-height: 54px; }
.btn-primary {
  background: var(--c-gold);
  color: var(--c-navy-dark) !important;
  box-shadow: var(--shadow-gold);
}
.btn-primary:hover {
  background: var(--c-gold-soft);
  box-shadow: 0 12px 30px rgba(212,160,23,.4);
}
.btn-outline-light {
  background: transparent;
  border-color: rgba(255,255,255,.6);
  color: #fff !important;
}
.btn-outline-light:hover {
  background: rgba(255,255,255,.15);
  border-color: #fff;
}
.btn-text {
  background: transparent;
  color: var(--c-navy) !important;
  padding: 8px 0;
  border-radius: 0;
  border-bottom: 2px solid var(--c-gold);
  border-width: 0 0 2px 0 !important;
  min-height: 0;
}
.btn-text:hover {
  color: var(--c-gold) !important;
  transform: translateX(4px);
}

/* ================== 섹션 공통 ================== */
.section {
  padding: clamp(60px, 8vw, 100px) 0;
  position: relative;
}
.section-head {
  text-align: center;
  margin-bottom: clamp(40px, 6vw, 72px);
}
.section-title {
  font-size: clamp(28px, 4.5vw, 46px);
  margin-bottom: 16px;
}
.section-sub {
  font-size: 18px;
  color: var(--c-text-soft);
  max-width: 640px;
  margin: 0 auto;
}

/* ================== 5대 약속 ================== */
.section-promises {
  background: var(--c-bg-soft);
}
.promises-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
}
.promise-card {
  background: #fff;
  padding: 36px 28px;
  border-radius: var(--radius);
  border: 1px solid var(--c-line);
  position: relative;
  transition: all var(--t-base);
  overflow: hidden;
}
.promise-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 4px; height: 100%;
  background: linear-gradient(180deg, var(--c-gold), var(--c-navy));
  transform: scaleY(0); transform-origin: top;
  transition: transform var(--t-base);
}
.promise-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
  border-color: transparent;
}
.promise-card:hover::before { transform: scaleY(1); }
.promise-num {
  font-family: "Playfair Display", Georgia, serif;
  font-size: 56px;
  font-weight: 700;
  color: var(--c-gold);
  line-height: 1;
  margin-bottom: 16px;
  letter-spacing: -.03em;
}
.promise-card h3 {
  font-size: 22px;
  margin-bottom: 12px;
  color: var(--c-navy-dark);
}
.promise-card p {
  font-size: 17px;
  color: var(--c-text-soft);
  line-height: 1.65;
  margin: 0;
}

/* ================== 수업 5단계 ================== */
.section-flow {
  background: linear-gradient(135deg, var(--c-cream) 0%, #fff 100%);
}
.flow-steps {
  display: flex;
  align-items: stretch;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 40px;
}
.flow-step {
  flex: 1 1 160px;
  background: #fff;
  border: 2px solid var(--c-line);
  border-radius: var(--radius);
  padding: 24px 18px;
  text-align: center;
  position: relative;
  transition: all var(--t-base);
}
.flow-step:hover {
  border-color: var(--c-gold);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.flow-num {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 44px; height: 44px;
  background: var(--c-navy);
  color: #fff;
  font-family: "Playfair Display", Georgia, serif;
  font-size: 22px;
  font-weight: 700;
  border-radius: 50%;
  margin-bottom: 14px;
}
.flow-label {
  font-size: 20px;
  font-weight: 700;
  color: var(--c-navy-dark);
  margin-bottom: 6px;
}
.flow-desc {
  font-size: 16px;
  color: var(--c-text-soft);
  line-height: 1.5;
}
.flow-arrow {
  display: flex;
  align-items: center;
  font-size: 28px;
  color: var(--c-gold);
  font-weight: 700;
}
.flow-note {
  background: linear-gradient(135deg, var(--c-navy-dark) 0%, var(--c-navy) 100%);
  color: #fff;
  padding: 24px 32px;
  border-radius: var(--radius);
  font-size: 18px;
  text-align: center;
  box-shadow: var(--shadow-md);
}

/* ================== 갤러리 ================== */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: 320px 320px;
  gap: 16px;
}
.gallery-feature {
  grid-column: span 2;
  grid-row: span 2;
}
.gallery-item {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius);
  display: block;
  background: var(--c-bg-soft);
}
.gallery-item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform var(--t-base);
}
.gallery-item:hover img { transform: scale(1.08); }
.gallery-caption {
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 16px 20px;
  background: linear-gradient(180deg, transparent 0%, rgba(15,23,42,.92) 100%);
  color: #fff;
  font-weight: 600;
  font-size: 16px;
  transform: translateY(100%);
  transition: transform var(--t-base);
}
.gallery-item:hover .gallery-caption { transform: translateY(0); }

/* ================== 원장 소개 ================== */
.section-director {
  background: var(--c-bg-soft);
}
.director-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 60px;
  align-items: center;
}
.director-image {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 4/5;
}
.director-image img {
  width: 100%; height: 100%; object-fit: cover;
}
.director-text h2 {
  margin-top: 12px;
  margin-bottom: 24px;
}
.director-text p {
  font-size: 18px;
  line-height: 1.7;
  color: var(--c-text-soft);
  margin-bottom: 16px;
}
.director-text strong { color: var(--c-navy-dark); }

/* ================== 오시는 길 (v30 — 지도 확대 + 박스선) ================== */
.section-location { background: #fff; }
.location-grid {
  display: grid;
  grid-template-columns: 2fr 1fr;   /* 지도 ⅔ · 정보 ⅓ — 우측 여백 축소 */
  gap: 36px;
  align-items: start;
}
/* 지도 박스 — iframe + quick-links 한 카드로 묶음 */
.location-map {
  border: 1px solid var(--c-line);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 10px 30px rgba(15,23,42,.10), 0 2px 6px rgba(15,23,42,.06);
  background: #fff;
}
.location-map iframe {
  display: block;
  width: 100%;
  border: 0;
  border-radius: 0 !important;     /* inline border-radius 무력화 — 박스가 처리 */
}
.location-map .map-quick-links {
  margin-top: 0;
  padding: 12px;
  background: #fafbfc;
  border-top: 1px solid var(--c-line);
}
.location-info h3 {
  font-size: 18px;
  color: var(--c-navy);
  margin: 20px 0 6px;
}
.location-info h3:first-child { margin-top: 0; }
.location-info p { font-size: 17px; color: var(--c-text-soft); }
@media (max-width: 860px) {
  .location-grid { grid-template-columns: 1fr; gap: 24px; }
}

/* ================== 푸터 CTA (v31 — 사진 배경 + 어두운 오버레이) ================== */
.footer-cta {
  /* 어두운 그라데이션 오버레이 위에 사진 배경 (오버레이가 위 레이어) */
  background:
    linear-gradient(135deg, rgba(15,23,42,.78) 0%, rgba(30,58,138,.72) 55%, rgba(15,23,42,.85) 100%),
    url("/data/uploads/branding/cta-bg.jpg") center center / cover no-repeat;
  background-attachment: scroll;  /* 모바일 호환 */
  color: #fff;
  padding: clamp(80px, 10vw, 140px) 0;
  position: relative;
  overflow: hidden;
}
/* 우상단 골드 글로우 (사진 위 액센트) */
.footer-cta::before {
  content: '';
  position: absolute;
  width: 700px; height: 700px;
  background: radial-gradient(circle, rgba(212,160,23,.28) 0%, transparent 70%);
  top: -350px; right: -200px;
  pointer-events: none;
  z-index: 0;
}
/* 좌하단 비네팅 (텍스트 가독성 향상) */
.footer-cta::after {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at center, transparent 30%, rgba(0,0,0,.35) 100%);
  pointer-events: none;
  z-index: 0;
}
.fcta-inner {
  text-align: center;
  position: relative; z-index: 1;
}
.fcta-title {
  color: #fff;
  font-size: clamp(30px, 4.4vw, 50px);
  margin-bottom: 18px;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 20px rgba(0,0,0,.3);
}
.fcta-sub {
  font-size: 19px;
  color: rgba(255,255,255,.88);
  margin-bottom: 44px;
}
.fcta-buttons {
  display: flex; gap: 20px; justify-content: center; flex-wrap: wrap;
}
/* === CTA 전화번호 버튼 — 훨씬 크게 (요청) === */
.fcta-buttons .btn {
  font-size: clamp(22px, 2.4vw, 32px) !important;
  font-weight: 800 !important;
  padding: 22px 48px !important;
  letter-spacing: 0.01em;
  min-width: 320px;
  border-radius: 60px !important;
  box-shadow: 0 12px 40px rgba(0,0,0,.35);
  transition: transform .25s ease, box-shadow .25s ease;
}
.fcta-buttons .btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
}
.fcta-buttons .btn-primary {
  background: linear-gradient(135deg, var(--c-gold) 0%, #e8b835 100%);
  border-color: transparent;
  color: #1a2540;
}
.fcta-buttons .btn-outline-light {
  border: 2.5px solid rgba(255,255,255,.85);
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
}

/* ================== 푸터 (v30 — 4영역 한 줄 정렬) ================== */
.site-footer {
  background: #0a1530;
  color: rgba(255,255,255,.7);
  padding: 60px 0 30px;
  font-size: 16px;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.4fr 2.2fr 1.8fr 1.6fr;  /* 로고 | 학원정보 | 연락처 | 운영시간 */
  gap: 36px;
  margin-bottom: 40px;
  align-items: start;
}
.footer-brand .footer-logo {
  width: 72px;
  margin-bottom: 14px;
  /* 로고 원본 그대로 유지 (요청) — invert 필터 제거 */
  opacity: 1;
}
.footer-tag {
  font-size: 16px;
  color: var(--c-gold-soft);
  font-weight: 600;
  margin: 0;
}
.footer-col h4 {
  color: #fff;
  font-size: 16px;
  margin-bottom: 14px;
  font-weight: 700;
  letter-spacing: .02em;
}
.footer-col p {
  font-size: 16px;
  margin: 0 0 8px;
  line-height: 1.65;
}
.footer-col a { color: rgba(255,255,255,.85); }
.footer-col a:hover { color: var(--c-gold-soft); }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 24px;
  text-align: center;
  font-size: 16px;
}
/* 태블릿 이하에서는 2x2 로 자연 wrap */
@media (max-width: 980px) {
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 30px; }
}
@media (max-width: 560px) {
  .footer-grid { grid-template-columns: 1fr; gap: 26px; }
  .fcta-buttons .btn { min-width: 0; width: 100%; font-size: 22px !important; padding: 18px 24px !important; }
}

/* ================== 모바일 하단 CTA 바 (기본 숨김) ================== */
.mobile-cta-bar { display: none; }

/* 게시판 등 일반 페이지 보조 */
.site-main { min-height: 60vh; }
.post-view, .post-write { max-width: none; width: 100%; }

/* ===================================================================
   사용자 요청 v2 — 상단 헤더 좌·우 10% (본문은 15% 유지), 로고 확대, 학원명 표시
   =================================================================== */

/* 헤더만 더 넓게 (좌·우 10% — 컨테이너 80%) */
.site-header .container {
    width: 90% !important;
    max-width: 1900px !important;
}
@media (max-width: 1280px) { .site-header .container { width: 94% !important; } }
@media (max-width: 1024px) { .site-header .container { width: 95% !important; } }

/* 헤더 자체 더 두껍게 (로고 키우니까) */
.site-header { --header-h: 92px; }
.header-inner { gap: 24px; }

/* 로고 크게 — 52px → 76px */
.logo-img {
    height: 76px !important;
    width: auto;
    transition: transform var(--t-fast);
    filter: drop-shadow(0 2px 8px rgba(30,58,138,.15));
}
.logo-block:hover .logo-img { transform: scale(1.05) rotate(-2deg); }

/* 로고 옆 학원명 — 굵고 잘 보이게 (PC + 모바일 모두 표시) */
.logo-text {
    display: flex !important;
    flex-direction: column;
    font-family: 'Pretendard', 'Poppins', system-ui, sans-serif;
    font-weight: 900;
    font-size: 26px;
    color: var(--c-navy-dark);
    letter-spacing: -.03em;
    line-height: 1.05;
    margin-left: 2px;
}
.logo-text small {
    display: block;
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 16px;
    font-weight: 600;
    font-style: italic;
    color: var(--c-gold);
    margin-top: 4px;
    letter-spacing: .02em;
}

/* 호버시 학원명에 미세 효과 */
.logo-block:hover .logo-text {
    color: var(--c-navy);
}

/* 본문·푸터 컨테이너는 기존 70% 유지 — 명시적 override 방지 */
.site-main .container,
.footer-cta .container,
.site-footer .container {
    width: 70%;
    max-width: 1600px;
}
@media (max-width: 1280px) {
    .site-main .container,
    .footer-cta .container,
    .site-footer .container { width: 80%; }
}
@media (max-width: 1024px) {
    .site-main .container,
    .footer-cta .container,
    .site-footer .container { width: 90%; }
}

/* === 드롭다운 메뉴 (공지&소식) === */
.nav-dropdown {
    position: relative;
    display: inline-block;
}
.nav-link-has-sub {
    cursor: pointer;
    user-select: none;
}
.nav-caret {
    display: inline-block;
    font-size: 16px;
    margin-left: 3px;
    transition: transform var(--t-base);
    color: var(--c-gold);
}
.nav-dropdown:hover .nav-caret {
    transform: rotate(180deg);
}

.nav-sub {
    position: absolute;
    top: calc(100% + 14px);
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    background: #fff;
    min-width: 200px;
    padding: 10px 0;
    border-radius: 12px;
    box-shadow: 0 12px 32px rgba(15,23,42,.18), 0 4px 12px rgba(15,23,42,.08);
    border: 1px solid var(--c-line);
    list-style: none;
    margin: 0;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: opacity var(--t-base), transform var(--t-base), visibility 0s linear var(--t-base);
    z-index: 200;
}
.nav-sub::before {
    content: '';
    position: absolute;
    top: -7px;
    left: 50%;
    transform: translateX(-50%) rotate(45deg);
    width: 14px; height: 14px;
    background: #fff;
    border-left: 1px solid var(--c-line);
    border-top: 1px solid var(--c-line);
}
/* hover와 호버 영역 사이의 간격 보강 (마우스 이동 시 드롭다운 안 닫히도록) */
.nav-sub::after {
    content: '';
    position: absolute;
    top: -14px; left: 0; right: 0;
    height: 14px;
}
.nav-dropdown:hover .nav-sub,
.nav-dropdown:focus-within .nav-sub {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    transition-delay: 0s;
}

.nav-sub li {
    margin: 0; padding: 0;
}
.nav-sub a {
    display: block;
    padding: 11px 22px;
    color: var(--c-text);
    font-size: 17px;
    font-weight: 600;
    transition: all var(--t-fast);
    white-space: nowrap;
    text-decoration: none;
}
.nav-sub a:hover {
    background: linear-gradient(90deg, var(--c-bg-warm) 0%, transparent 100%);
    color: var(--c-navy);
    padding-left: 28px;
}

/* === 메뉴 정렬 fix — 드롭다운 항목 다른 메뉴와 baseline 맞춤 === */
.primary-nav {
    align-items: center !important;
    display: flex;
}
.nav-dropdown {
    display: inline-flex !important;
    align-items: center;
    line-height: 1;
}
.primary-nav .nav-link,
.primary-nav .nav-link-has-sub {
    display: inline-flex !important;
    align-items: center;
    height: 100%;
    line-height: 1;
    padding-top: 6px !important;
    padding-bottom: 6px !important;
}

/* === 5대 약속 v2 — 비대칭 그리드 + 컬러풀 + 모던 인터랙션 === */
.section-promises-v2 {
    background: linear-gradient(180deg, #fdfbf7 0%, #ffffff 100%);
    padding: clamp(70px, 9vw, 110px) 0;
    position: relative;
    overflow: hidden;
}
.section-promises-v2::before {
    content: '';
    position: absolute;
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(212,160,23,0.08) 0%, transparent 70%);
    top: -200px; left: -200px;
    pointer-events: none;
}
.section-promises-v2::after {
    content: '';
    position: absolute;
    width: 800px; height: 800px;
    background: radial-gradient(circle, rgba(30,58,138,0.05) 0%, transparent 70%);
    bottom: -300px; right: -300px;
    pointer-events: none;
}

.promises-v2-grid {
    display: grid;
    grid-template-columns: 4fr 6fr;
    grid-template-rows: auto auto;
    gap: 20px;
    position: relative;
    z-index: 1;
}

/* 카드 기본 */
.promise-v2 {
    --accent: #d4a017;
    background: #fff;
    padding: 36px 32px;
    border-radius: 24px;
    position: relative;
    overflow: hidden;
    border: 1px solid #f1f5f9;
    box-shadow: 0 2px 8px rgba(15,23,42,.04);
    transition: all 0.4s cubic-bezier(.2, .8, .2, 1);
    cursor: default;
}
.promise-v2:hover {
    transform: translateY(-8px);
    box-shadow: 0 25px 50px rgba(15,23,42,.12);
    border-color: var(--accent);
}

/* 배경 색상 블롭 (호버시 확대) */
.promise-v2::before {
    content: '';
    position: absolute;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: var(--accent);
    opacity: 0.08;
    top: -60px; right: -60px;
    transition: transform 0.5s cubic-bezier(.2, .8, .2, 1);
    z-index: 0;
}
.promise-v2:hover::before {
    transform: scale(1.6);
    opacity: 0.12;
}

/* 모든 자식 z-index 1로 (블롭 위로) */
.promise-v2 > * { position: relative; z-index: 1; }

/* 번호 */
.promise-v2-num {
    font-family: "Playfair Display", Georgia, serif;
    font-size: 22px;
    font-weight: 700;
    color: var(--accent);
    letter-spacing: .05em;
    margin-bottom: 14px;
    line-height: 1;
}
.promise-v2-num::before {
    content: '';
    display: inline-block;
    width: 28px; height: 2px;
    background: var(--accent);
    vertical-align: middle;
    margin-right: 10px;
    transition: width 0.4s;
}
.promise-v2:hover .promise-v2-num::before { width: 48px; }

/* 아이콘 */
.promise-v2-icon {
    width: 64px; height: 64px;
    border-radius: 18px;
    background: linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 60%, #fbbf24));
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 32px;
    margin-bottom: 20px;
    box-shadow: 0 8px 20px color-mix(in srgb, var(--accent) 35%, transparent);
    transition: transform 0.4s cubic-bezier(.2, .8, .2, 1);
}
.promise-v2:hover .promise-v2-icon {
    transform: scale(1.1) rotate(-6deg);
}

.promise-v2 h3 {
    font-size: 22px;
    font-weight: 800;
    color: var(--c-navy-dark);
    margin: 0 0 12px;
    letter-spacing: -.02em;
}
.promise-v2 p {
    font-size: 17px;
    color: var(--c-text-soft);
    line-height: 1.65;
    margin: 0;
}
.promise-v2 strong {
    color: var(--c-navy-dark);
    font-weight: 700;
}

/* 카드별 액센트 컬러 */
.promise-v2-hero { --accent: #d4a017; }   /* 골드 */
.promise-v2-c2   { --accent: #2563eb; }   /* 블루 */
.promise-v2-c3   { --accent: #10b981; }   /* 그린 */
.promise-v2-c4   { --accent: #ef4444; }   /* 레드 */
.promise-v2-c5   { --accent: #8b5cf6; }   /* 퍼플 */

/* === 첫 번째 카드 (Hero) — 큰 카드, 어두운 배경, 골드 강조 === */
.promise-v2-hero {
    grid-row: span 2;
    background: linear-gradient(135deg, #0f172a 0%, #1e3a8a 60%, #1e40af 100%);
    color: #fff;
    padding: 48px 44px;
    border: none;
}
.promise-v2-hero::before {
    background: #d4a017;
    opacity: 0.15;
    width: 300px; height: 300px;
    top: -100px; right: -100px;
}
.promise-v2-hero:hover {
    box-shadow: 0 30px 60px rgba(15,23,42,.3);
    border-color: transparent;
}
.promise-v2-hero .promise-v2-num {
    color: #fbbf24;
    font-size: 28px;
}
.promise-v2-hero .promise-v2-num::before {
    background: #fbbf24;
}
.promise-v2-hero .promise-v2-icon {
    width: 88px; height: 88px;
    border-radius: 24px;
    font-size: 44px;
    background: linear-gradient(135deg, #d4a017, #fbbf24);
    box-shadow: 0 12px 30px rgba(212,160,23,.5);
    margin-bottom: 28px;
}
.promise-v2-hero h3 {
    color: #fff;
    font-size: 32px;
    margin-bottom: 18px;
    line-height: 1.2;
}
.promise-v2-hero p {
    color: rgba(255,255,255,.85);
    font-size: 17px;
    line-height: 1.75;
    margin-bottom: 24px;
}
.promise-v2-hero strong {
    color: #fbbf24;
    background: linear-gradient(180deg, transparent 60%, rgba(212,160,23,0.25) 60%);
    padding: 0 4px;
}

/* 태그 (가장 큰 차별점) */
.promise-v2-tag {
    display: inline-block;
    padding: 6px 14px;
    background: rgba(212,160,23,0.15);
    color: #fbbf24;
    border: 1px solid rgba(212,160,23,0.4);
    border-radius: 50px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .03em;
    margin-top: 8px;
}

/* 모바일 반응형 */
@media (max-width: 1024px) {
    .promises-v2-grid {
        grid-template-columns: 1fr 1fr;
        grid-template-rows: auto;
    }
    .promise-v2-hero { grid-row: span 1; grid-column: span 2; }
}
@media (max-width: 640px) {
    .promises-v2-grid {
        grid-template-columns: 1fr;
    }
    .promise-v2-hero { grid-column: span 1; }
    .promise-v2 { padding: 28px 24px; }
    .promise-v2-hero { padding: 36px 28px; }
    .promise-v2-hero h3 { font-size: 26px; }
    .promise-v2-icon { width: 56px; height: 56px; font-size: 28px; }
    .promise-v2-hero .promise-v2-icon { width: 72px; height: 72px; font-size: 36px; }
}

/* === Hero 카드 v3 — SVG 일러스트 + 큰 타이틀 + 불릿 === */
.promise-v2-hero { padding: 36px 36px 40px; }

.promise-v2-svg {
    width: 100%;
    max-width: 320px;
    height: auto;
    display: block;
    margin: -8px auto 24px;
    filter: drop-shadow(0 8px 24px rgba(212,160,23,0.25));
    animation: heroSvgFloat 4s ease-in-out infinite;
}
@keyframes heroSvgFloat {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}

.promise-v2-title-hero {
    color: #fff !important;
    font-size: clamp(36px, 4.2vw, 52px) !important;
    font-weight: 900 !important;
    line-height: 1.05 !important;
    letter-spacing: -.04em !important;
    margin: 0 0 14px !important;
    background: linear-gradient(135deg, #fff 0%, #fbbf24 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
}

.promise-v2-tagline {
    color: rgba(255,255,255,0.92) !important;
    font-size: 17px !important;
    font-weight: 500 !important;
    line-height: 1.5 !important;
    margin: 0 0 24px !important;
    font-style: italic;
    padding-left: 14px;
    border-left: 3px solid #fbbf24;
}
.promise-v2-tagline em {
    font-style: normal;
    color: #fbbf24 !important;
    font-weight: 800;
    background: linear-gradient(180deg, transparent 60%, rgba(212,160,23,0.3) 60%);
    padding: 0 4px;
}

.promise-v2-bullets {
    list-style: none;
    padding: 0;
    margin: 0 0 24px;
    display: flex;
    flex-direction: column;
    gap: 12px;
}
.promise-v2-bullets li {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    padding: 12px 14px;
    background: rgba(255,255,255,0.06);
    border-radius: 12px;
    border: 1px solid rgba(255,255,255,0.08);
    transition: all 0.3s;
}
.promise-v2-bullets li:hover {
    background: rgba(255,255,255,0.1);
    transform: translateX(4px);
    border-color: rgba(251,191,36,0.4);
}
.bul-icon {
    flex-shrink: 0;
    width: 36px; height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, rgba(251,191,36,0.2), rgba(212,160,23,0.3));
    border-radius: 10px;
    font-size: 18px;
    border: 1px solid rgba(251,191,36,0.3);
}
.promise-v2-bullets li > span:last-child {
    color: rgba(255,255,255,0.92);
    font-size: 17px;
    font-weight: 600;
    line-height: 1.4;
}

.promise-v2-tag {
    display: inline-block;
    padding: 8px 18px;
    background: linear-gradient(135deg, #d4a017, #fbbf24);
    color: #0f172a !important;
    border: none !important;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: .03em;
    margin-top: 4px;
    box-shadow: 0 8px 20px rgba(212,160,23,0.35);
}

/* hero 카드의 promise-v2-num 위치 조정 (SVG와 안 겹치게) */
.promise-v2-hero .promise-v2-num {
    margin-bottom: 4px;
}

/* 모바일 */
@media (max-width: 640px) {
    .promise-v2-svg { max-width: 240px; margin: 0 auto 16px; }
    .promise-v2-title-hero { font-size: 32px !important; }
    .promise-v2-bullets li { padding: 10px 12px; }
    .bul-icon { width: 32px; height: 32px; font-size: 16px; }
    .promise-v2-bullets li > span:last-child { font-size: 16px; }
}

/* === 5대 약속 v2 그리드 v4 — 1열 hero + 4개 가로 카드 (높이 동일) === */
.promises-v2-grid {
    grid-template-columns: 4fr 6fr !important;
    grid-template-rows: repeat(4, 1fr) !important;
    gap: 16px !important;
    align-items: stretch;
}
.promise-v2-hero {
    grid-row: 1 / span 4 !important;
    grid-column: 1 !important;
}
.promise-v2-c2, .promise-v2-c3, .promise-v2-c4, .promise-v2-c5 {
    grid-column: 2 !important;
}

/* 02~05 카드 — 아이콘 + 타이틀 한 줄 */
.promise-v2:not(.promise-v2-hero) {
    padding: 24px 28px !important;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.promise-v2:not(.promise-v2-hero) .promise-v2-num {
    margin-bottom: 8px !important;
    font-size: 16px;
}
.promise-v2:not(.promise-v2-hero) .promise-v2-num::before {
    width: 20px;
    margin-right: 8px;
}

.promise-v2-row {
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 10px;
}
.promise-v2-row .promise-v2-icon {
    width: 52px !important;
    height: 52px !important;
    font-size: 26px !important;
    margin: 0 !important;
    border-radius: 14px;
    flex-shrink: 0;
}
.promise-v2-row h3 {
    margin: 0 !important;
    font-size: 20px !important;
    flex: 1;
    line-height: 1.25;
}
.promise-v2:not(.promise-v2-hero) p {
    font-size: 17px !important;
    margin: 0 !important;
    color: var(--c-text-soft);
    line-height: 1.55;
}

/* 호버시 아이콘만 회전 */
.promise-v2:not(.promise-v2-hero):hover .promise-v2-row .promise-v2-icon {
    transform: scale(1.1) rotate(-6deg);
}

/* 모바일 — hero는 위, 4개는 아래 1열 stack */
@media (max-width: 1024px) {
    .promises-v2-grid {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto !important;
    }
    .promise-v2-hero {
        grid-row: auto !important;
        grid-column: 1 !important;
    }
}
@media (max-width: 640px) {
    .promise-v2:not(.promise-v2-hero) { padding: 20px 22px !important; }
    .promise-v2-row .promise-v2-icon { width: 44px !important; height: 44px !important; font-size: 22px !important; }
    .promise-v2-row h3 { font-size: 18px !important; }
}

/* === Bullets v5 — 큰 폰트 + 한 줄 강제 === */
.promise-v2-bullets li > span:last-child {
    font-size: 17px !important;
    font-weight: 600;
    line-height: 1.4;
    white-space: nowrap;
    overflow: visible;
}
@media (max-width: 1280px) {
    .promise-v2-bullets li > span:last-child {
        font-size: 16px !important;
        white-space: normal;  /* 좁은 화면에서는 줄바꿈 허용 */
    }
}
@media (max-width: 640px) {
    .promise-v2-bullets li > span:last-child {
        font-size: 16px !important;
    }
}

/* === 본문 설명 폰트 17px 통일 (사용자 요청) === */
.promise-v2 p,
.promise-v2:not(.promise-v2-hero) p,
.section-sub,
.fcta-sub,
.location-info p,
.director-text p {
    font-size: 17px !important;
    line-height: 1.65 !important;
}
.flow-desc { font-size: 16px !important; }  /* 흐름 단계 작은 설명만 유지 */

/* === 그리드 비율 4:6 (좌측 약속 카드 작게, 우측 4개 카드 넓게) === */
.promises-v2-grid {
    grid-template-columns: 4fr 6fr !important;
    gap: 18px !important;
}
@media (max-width: 1024px) {
    .promises-v2-grid {
        grid-template-columns: 1fr !important;
    }
}

/* === 5대 약속 높이 축소 (사용자 요청) === */
.section-promises-v2 {
    padding: clamp(40px, 5vw, 70px) 0 !important;
}
.promises-v2-grid {
    gap: 12px !important;
}

/* 우측 작은 카드 4개 — 패딩·내부 간격 축소 */
.promise-v2:not(.promise-v2-hero) {
    padding: 18px 24px !important;
}
.promise-v2:not(.promise-v2-hero) .promise-v2-num {
    margin-bottom: 4px !important;
    font-size: 16px !important;
}
.promise-v2-row {
    margin-bottom: 6px !important;
    gap: 12px !important;
}
.promise-v2-row .promise-v2-icon {
    width: 44px !important;
    height: 44px !important;
    font-size: 22px !important;
}
.promise-v2-row h3 {
    font-size: 24px !important;
    line-height: 1.2 !important;
}
.promise-v2:not(.promise-v2-hero) p {
    font-size: 16px !important;
    line-height: 1.55 !important;
    color: var(--c-text-soft);
    margin: 0 !important;
}

/* 좌측 hero 카드 — 패딩·간격 축소 */
.promise-v2-hero {
    padding: 28px 32px 32px !important;
}
.promise-v2-svg {
    margin: -4px auto 16px !important;
    max-width: 260px !important;
}
.promise-v2-title-hero {
    font-size: clamp(30px, 3.5vw, 44px) !important;
    margin-bottom: 10px !important;
}
.promise-v2-tagline {
    font-size: 16px !important;
    margin-bottom: 16px !important;
}
.promise-v2-bullets {
    margin-bottom: 16px !important;
    gap: 8px !important;
}
.promise-v2-bullets li {
    padding: 9px 12px !important;
}
.bul-icon {
    width: 32px !important;
    height: 32px !important;
    font-size: 16px !important;
}
.promise-v2-bullets li > span:last-child {
    font-size: 16px !important;
}
.promise-v2-tag {
    padding: 6px 16px !important;
    font-size: 16px !important;
}
.promise-v2-hero .promise-v2-num {
    font-size: 18px !important;
    margin-bottom: 0 !important;
}

/* === 작은 카드 타이틀 24px (사용자 요청) === */
.promise-v2:not(.promise-v2-hero) .promise-v2-row h3 {
    font-size: 24px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
    letter-spacing: -.02em !important;
}
/* 모바일에서는 가독성·공간 위해 살짝 작게 */
@media (max-width: 768px) {
    .promise-v2:not(.promise-v2-hero) .promise-v2-row h3 {
        font-size: 20px !important;
    }
}

/* === 수업 5단계 v2 — 다크 배경 + 애니메이션 + 컬러풀 === */
.section-flow-v2 {
    position: relative;
    background: linear-gradient(180deg, rgba(8,12,28,0.92) 0%, rgba(15,23,42,0.88) 50%, rgba(19,27,58,0.93) 100%), url(/data/uploads/branding/flow-bg-teach.jpg);
    color: #fff;
    padding: clamp(70px, 9vw, 110px) 0;
    overflow: hidden;
    isolation: isolate;
}

/* 애니메이션 배경 레이어 */
.flow-bg-layer {
    position: absolute; inset: 0; z-index: 0;
    overflow: hidden;
    pointer-events: none;
}

/* 그라데이션 글로우 orb 3개 */
.flow-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.5;
    animation: orbFloat 20s ease-in-out infinite;
}
.flow-orb-1 {
    width: 500px; height: 500px;
    background: radial-gradient(circle, #d4a017 0%, transparent 70%);
    top: -150px; left: -100px;
}
.flow-orb-2 {
    width: 600px; height: 600px;
    background: radial-gradient(circle, #3b82f6 0%, transparent 70%);
    bottom: -200px; right: -150px;
    animation-delay: -7s;
}
.flow-orb-3 {
    width: 400px; height: 400px;
    background: radial-gradient(circle, #ec4899 0%, transparent 70%);
    top: 40%; left: 45%;
    opacity: 0.3;
    animation-delay: -14s;
}
@keyframes orbFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    33%      { transform: translate(80px, -50px) scale(1.15); }
    66%      { transform: translate(-60px, 70px) scale(0.85); }
}

/* 그리드 패턴 (전체) */
.flow-bg-grid {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    opacity: 0.5;
}

/* 떠다니는 점 (파티클) */
.flow-particle {
    position: absolute;
    border-radius: 50%;
    background: rgba(255,255,255,0.6);
    box-shadow: 0 0 12px rgba(255,255,255,0.8);
    animation: particleFloat linear infinite;
}
.flow-particle.p1 { width: 3px; height: 3px; left: 10%; animation-duration: 18s; animation-delay: 0s; }
.flow-particle.p2 { width: 4px; height: 4px; left: 25%; animation-duration: 22s; animation-delay: -3s; background: rgba(251,191,36,0.7); box-shadow: 0 0 14px rgba(251,191,36,0.8); }
.flow-particle.p3 { width: 2px; height: 2px; left: 45%; animation-duration: 16s; animation-delay: -8s; }
.flow-particle.p4 { width: 5px; height: 5px; left: 65%; animation-duration: 20s; animation-delay: -5s; background: rgba(6,182,212,0.7); box-shadow: 0 0 16px rgba(6,182,212,0.8); }
.flow-particle.p5 { width: 3px; height: 3px; left: 80%; animation-duration: 24s; animation-delay: -10s; }
.flow-particle.p6 { width: 4px; height: 4px; left: 92%; animation-duration: 19s; animation-delay: -6s; background: rgba(167,139,250,0.7); box-shadow: 0 0 14px rgba(167,139,250,0.8); }

@keyframes particleFloat {
    0%   { bottom: -10px;   opacity: 0; }
    10%  { opacity: 1; }
    90%  { opacity: 1; }
    100% { bottom: 110%;    opacity: 0; }
}

/* 컨테이너는 위에 */
.section-flow-v2 > .container { position: relative; z-index: 1; }

/* 헤딩 라이트 버전 */
.section-head-light .eyebrow-light {
    color: #fbbf24 !important;
}
.section-head-light .eyebrow-light::before {
    background: #fbbf24 !important;
}
.section-title-light {
    color: #fff !important;
}
.section-sub-light {
    color: rgba(255,255,255,0.7) !important;
}

/* 5단계 카드 그리드 */
.flow-v2-grid {
    display: flex;
    align-items: stretch;
    justify-content: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 40px;
}

/* 화살표 */
.flow-arrow-v2 {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    width: 40px;
    animation: arrowPulse 2s ease-in-out infinite;
}
@keyframes arrowPulse {
    0%, 100% { opacity: 0.5; transform: translateX(0); }
    50%      { opacity: 1; transform: translateX(4px); }
}

/* 카드 */
.flow-card-v2 {
    flex: 1 1 160px;
    max-width: 200px;
    min-width: 150px;
    background: rgba(255,255,255,0.04);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border: 1px solid rgba(255,255,255,0.1);
    border-radius: 22px;
    padding: 28px 18px 24px;
    text-align: center;
    position: relative;
    transition: all 0.4s cubic-bezier(.2,.8,.2,1);
    color: var(--accent);
}
.flow-card-v2::before {
    content: '';
    position: absolute;
    inset: -1px;
    border-radius: 22px;
    padding: 1px;
    background: linear-gradient(135deg, var(--accent), transparent 50%, var(--accent));
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite: xor;
    mask-composite: exclude;
    opacity: 0;
    transition: opacity 0.4s;
}
.flow-card-v2:hover {
    transform: translateY(-12px);
    background: rgba(255,255,255,0.07);
    box-shadow: 0 25px 60px var(--glow), 0 0 0 1px var(--accent);
}
.flow-card-v2:hover::before { opacity: 1; }

/* 카드 번호 */
.flow-card-num {
    position: absolute;
    top: 12px; left: 14px;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 16px;
    font-weight: 700;
    color: var(--accent);
    opacity: 0.7;
    letter-spacing: .05em;
}

/* 아이콘 컨테이너 */
.flow-card-icon {
    width: 72px; height: 72px;
    margin: 6px auto 18px;
    border-radius: 20px;
    background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 25%, transparent), color-mix(in srgb, var(--accent-d) 20%, transparent));
    border: 1px solid var(--accent);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--accent);
    box-shadow: inset 0 0 20px color-mix(in srgb, var(--accent) 15%, transparent), 0 8px 24px var(--glow);
    transition: all 0.4s cubic-bezier(.2,.8,.2,1);
    position: relative;
}
.flow-card-icon::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: 20px;
    background: radial-gradient(circle at 30% 30%, rgba(255,255,255,0.3), transparent 60%);
    pointer-events: none;
}
.flow-card-icon svg {
    width: 40px; height: 40px;
}
.flow-card-v2:hover .flow-card-icon {
    transform: scale(1.1) rotate(-6deg);
    box-shadow: inset 0 0 30px color-mix(in srgb, var(--accent) 25%, transparent), 0 12px 40px var(--glow);
}

/* 타이틀 */
.flow-card-v2 h3 {
    color: #fff !important;
    font-size: 20px !important;
    font-weight: 800 !important;
    margin: 0 0 8px !important;
    letter-spacing: -.02em;
}

/* 설명 */
.flow-card-v2 p {
    color: rgba(255,255,255,0.7) !important;
    font-size: 16px !important;
    margin: 0 !important;
    line-height: 1.5 !important;
    font-weight: 500;
}

/* 내신 대비 강조 배너 */
.flow-note-v2 {
    display: flex;
    align-items: center;
    gap: 20px;
    background: linear-gradient(135deg, rgba(212,160,23,0.15), rgba(59,130,246,0.15));
    border: 1px solid rgba(251,191,36,0.3);
    border-radius: 20px;
    padding: 22px 28px;
    margin-top: 24px;
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    position: relative;
    overflow: hidden;
}
.flow-note-v2::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(251,191,36,0.1), transparent);
    transform: translateX(-100%);
    animation: noteShimmer 3s ease-in-out infinite;
}
@keyframes noteShimmer {
    0%, 100% { transform: translateX(-100%); }
    50%      { transform: translateX(100%); }
}
.flow-note-icon {
    flex-shrink: 0;
    font-size: 36px;
    filter: drop-shadow(0 0 16px rgba(251,191,36,0.5));
}
.flow-note-text {
    display: flex;
    flex-direction: column;
    gap: 4px;
    position: relative; z-index: 1;
}
.flow-note-text strong {
    color: #fbbf24;
    font-size: 17px;
    font-weight: 800;
}
.flow-note-text span {
    color: rgba(255,255,255,0.85);
    font-size: 16px;
    line-height: 1.55;
}

/* 모바일 */
@media (max-width: 1024px) {
    .flow-v2-grid { gap: 12px; }
    .flow-card-v2 { flex: 1 1 calc(33% - 12px); max-width: none; }
    .flow-arrow-v2 { display: none; }
}
@media (max-width: 640px) {
    .flow-v2-grid {
        flex-direction: column;
        gap: 14px;
    }
    .flow-card-v2 { max-width: none; padding: 22px 18px; }
    .flow-card-icon { width: 60px; height: 60px; }
    .flow-card-icon svg { width: 34px; height: 34px; }
    .flow-card-v2 h3 { font-size: 18px !important; }
    .flow-note-v2 {
        flex-direction: column;
        align-items: flex-start;
        padding: 20px;
        gap: 12px;
    }
    .flow-note-icon { font-size: 28px; }
    .flow-note-text strong { font-size: 16px; }
    .flow-note-text span { font-size: 16px; }
}

/* === 라이트박스 (갤러리 큰화면 + Prev/Next + 닫기) === */
.lb-overlay {
    position: fixed;
    inset: 0;
    background: rgba(8, 12, 28, 0.96);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    z-index: 99998;
    display: none;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: opacity 0.25s ease;
}
.lb-overlay.lb-active {
    display: flex;
    opacity: 1;
}

.lb-stage {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 80px 80px 100px;
    cursor: zoom-out;
}

.lb-img {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain;
    border-radius: 12px;
    box-shadow: 0 30px 80px rgba(0,0,0,0.5);
    animation: lbFadeIn 0.3s cubic-bezier(.2,.8,.2,1);
    cursor: default;
}
@keyframes lbFadeIn {
    from { opacity: 0; transform: scale(0.95); }
    to   { opacity: 1; transform: scale(1); }
}

.lb-btn {
    position: absolute;
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: rgba(255,255,255,0.12);
    color: #fff;
    border: 1px solid rgba(255,255,255,0.2);
    cursor: pointer;
    font-size: 28px;
    font-weight: 300;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    z-index: 1;
    line-height: 1;
    padding: 0;
    font-family: inherit;
}
.lb-btn:hover {
    background: rgba(251,191,36,0.3);
    border-color: #fbbf24;
    transform: scale(1.1);
}
.lb-btn:active { transform: scale(0.95); }

.lb-close { top: 24px; right: 24px; font-size: 30px; }
.lb-prev  { left: 24px; top: 50%; transform: translateY(-50%); font-size: 36px; }
.lb-next  { right: 24px; top: 50%; transform: translateY(-50%); font-size: 36px; }
.lb-prev:hover, .lb-next:hover {
    transform: translateY(-50%) scale(1.1);
}
.lb-prev:active, .lb-next:active {
    transform: translateY(-50%) scale(0.95);
}

.lb-info {
    position: absolute;
    bottom: 24px;
    left: 50%;
    transform: translateX(-50%);
    text-align: center;
    color: #fff;
    pointer-events: none;
    max-width: 90vw;
}
.lb-caption {
    font-size: 17px;
    font-weight: 600;
    margin-bottom: 4px;
    text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.lb-counter {
    font-size: 16px;
    color: rgba(255,255,255,0.6);
    font-family: "Playfair Display", Georgia, serif;
    letter-spacing: .1em;
}

/* 갤러리 이미지 호버시 줌 커서 (클릭 가능 표시) */
.gallery-item { cursor: zoom-in; }

/* 모바일 — 버튼 작게, 여백 줄임 */
@media (max-width: 768px) {
    .lb-stage { padding: 60px 12px 80px; }
    .lb-btn { width: 44px; height: 44px; font-size: 24px; }
    .lb-close { top: 12px; right: 12px; }
    .lb-prev  { left: 8px; }
    .lb-next  { right: 8px; }
    .lb-caption { font-size: 16px; }
    .lb-counter { font-size: 16px; }
}

/* === 원장 소개 v2 — 가로 사진 + 떠다니는 배지 + 인용 + 미니카드 === */
.section-director-v2 {
    background: linear-gradient(180deg, #fff 0%, var(--c-cream) 100%);
    padding: clamp(70px, 9vw, 110px) 0;
    position: relative;
    overflow: hidden;
}
.section-director-v2::before {
    content: '';
    position: absolute;
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(212,160,23,0.08) 0%, transparent 70%);
    top: -100px; right: -100px;
    pointer-events: none;
}

.director-v2-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    align-items: center;
    position: relative;
    z-index: 1;
}

/* 좌측 사진 */
.director-v2-photo {
    position: relative;
}
.director-v2-photo-wrap {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    aspect-ratio: 4 / 3;
    box-shadow: 0 20px 50px rgba(15,23,42,.15), 0 5px 15px rgba(15,23,42,.08);
    transition: transform 0.5s cubic-bezier(.2,.8,.2,1);
}
.director-v2-photo-wrap:hover {
    transform: translateY(-4px);
}
.director-v2-photo-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.director-v2-photo-wrap::before {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, transparent 60%, rgba(212,160,23,0.15) 100%);
    z-index: 1;
    pointer-events: none;
}

/* 떠다니는 배지 3개 */
.director-badge {
    position: absolute;
    background: #fff;
    border-radius: 16px;
    padding: 12px 16px;
    box-shadow: 0 10px 30px rgba(15,23,42,.18), 0 4px 10px rgba(15,23,42,.08);
    display: flex;
    align-items: center;
    gap: 10px;
    z-index: 2;
    border: 1px solid rgba(212,160,23,0.2);
    animation: badgeFloat 4s ease-in-out infinite;
    transition: transform 0.3s;
}
.director-badge:hover {
    transform: scale(1.08);
    box-shadow: 0 16px 40px rgba(212,160,23,0.25);
}
.badge-tl { top: 14px; left: -20px; animation-delay: 0s; }
.badge-tr { top: 32px; right: -20px; animation-delay: -1.5s; }
.badge-bl { bottom: 24px; left: -28px; animation-delay: -3s; }

@keyframes badgeFloat {
    0%, 100% { transform: translateY(0); }
    50%      { transform: translateY(-6px); }
}

.badge-icon {
    font-size: 26px;
    filter: drop-shadow(0 2px 4px rgba(0,0,0,0.1));
}
.badge-text {
    font-size: 16px;
    font-weight: 700;
    color: var(--c-navy-dark);
    line-height: 1.2;
    letter-spacing: -.02em;
}

/* 우측 텍스트 영역 */
.director-v2-text h2 {
    margin: 12px 0 28px;
    font-size: clamp(28px, 3.5vw, 40px);
    line-height: 1.2;
}

/* 인용 박스 */
.director-quote {
    position: relative;
    background: #fff;
    border: 1px solid rgba(212,160,23,0.2);
    border-left: 4px solid var(--c-gold);
    border-radius: 14px;
    padding: 24px 28px 24px 32px;
    margin-bottom: 24px;
    box-shadow: 0 4px 12px rgba(15,23,42,.04);
}
.quote-mark {
    position: absolute;
    top: -8px;
    left: 18px;
    font-family: "Playfair Display", Georgia, serif;
    font-size: 64px;
    line-height: 1;
    color: var(--c-gold);
    margin: 0;
    text-shadow: 0 4px 12px rgba(212,160,23,0.25);
}
.quote-body {
    margin: 0 !important;
    font-size: 17px !important;
    line-height: 1.7 !important;
    color: var(--c-text);
    font-weight: 500;
}
.quote-body strong {
    color: var(--c-navy);
    background: linear-gradient(180deg, transparent 60%, rgba(212,160,23,0.22) 60%);
    padding: 0 2px;
}

/* 미니카드 3개 */
.director-cards {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin-bottom: 28px;
}
.director-mini-card {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    background: rgba(255,255,255,0.7);
    border: 1px solid var(--c-line);
    border-radius: 12px;
    padding: 16px 18px;
    transition: all 0.3s;
}
.director-mini-card:hover {
    background: #fff;
    border-color: var(--c-gold);
    transform: translateX(4px);
    box-shadow: 0 6px 16px rgba(15,23,42,.06);
}
.director-mini-card.highlight {
    background: linear-gradient(135deg, var(--c-navy-dark), var(--c-navy));
    border: none;
    color: #fff;
}
.director-mini-card.highlight p { color: rgba(255,255,255,0.92) !important; }
.director-mini-card.highlight strong {
    color: #fbbf24;
    background: linear-gradient(180deg, transparent 60%, rgba(212,160,23,0.3) 60%);
    padding: 0 3px;
}
.dmc-icon {
    flex-shrink: 0;
    width: 40px; height: 40px;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(212,160,23,0.15), rgba(251,191,36,0.2));
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
    border: 1px solid rgba(212,160,23,0.25);
}
.director-mini-card.highlight .dmc-icon {
    background: linear-gradient(135deg, rgba(251,191,36,0.25), rgba(212,160,23,0.4));
    border-color: rgba(251,191,36,0.4);
}
.director-mini-card p {
    margin: 0 !important;
    font-size: 16px !important;
    line-height: 1.6 !important;
    color: var(--c-text-soft);
    font-weight: 500;
}
.director-mini-card strong { color: var(--c-navy-dark); }

.director-cta {
    margin-top: 4px !important;
}

/* 모바일 */
@media (max-width: 1024px) {
    .director-v2-grid { grid-template-columns: 1fr; gap: 40px; }
    .director-badge { padding: 10px 14px; }
}
@media (max-width: 640px) {
    .badge-tl { left: 8px; top: 8px; }
    .badge-tr { right: 8px; top: 8px; }
    .badge-bl { left: 8px; bottom: 8px; }
    .badge-icon { font-size: 22px; }
    .badge-text { font-size: 16px; }
    .director-quote { padding: 22px 22px 22px 24px; }
    .quote-mark { font-size: 48px; left: 14px; }
    .quote-body { font-size: 16px !important; }
    .director-mini-card { padding: 14px; gap: 12px; }
    .dmc-icon { width: 36px; height: 36px; font-size: 18px; }
    .director-mini-card p { font-size: 16px !important; }
}

/* === 수업 5단계 v2 배경 이미지 fix === */
.section-flow-v2 {
    background-size: cover !important;
    background-position: center center !important;
    background-attachment: fixed !important;  /* 패럴렉스 효과 */
    background-repeat: no-repeat !important;
}
@media (max-width: 1024px) {
    /* 모바일은 fixed 잘 안되니 scroll */
    .section-flow-v2 { background-attachment: scroll !important; }
}

/* === 원장 소개 v2 배경 엷은 그레이 (위·아래 섹션과 구분) === */
.section-director-v2 {
    background: linear-gradient(180deg, #f1f5f9 0%, #e2e8f0 50%, #f1f5f9 100%) !important;
    position: relative;
}
.section-director-v2::before {
    background: radial-gradient(circle, rgba(212,160,23,0.06) 0%, transparent 70%) !important;
}
.section-director-v2::after {
    content: '' !important;
    position: absolute !important;
    width: 100% !important;
    height: 100% !important;
    top: 0 !important; left: 0 !important;
    background: radial-gradient(circle at 80% 20%, rgba(30,58,138,0.04), transparent 50%) !important;
    pointer-events: none !important;
    z-index: 0 !important;
}
.section-director-v2 > .container {
    position: relative;
    z-index: 1;
}

/* 인용/미니카드 배경 — 그레이 배경 위에서도 잘 보이도록 살짝 강화 */
.director-quote {
    background: #ffffff !important;
    box-shadow: 0 10px 25px rgba(15,23,42,.06) !important;
}
.director-mini-card {
    background: rgba(255,255,255,0.85) !important;
}
.director-mini-card:hover {
    background: #ffffff !important;
}

/* === 원장 섹션 폰트 17px 통일 (기준치) === */
.director-quote .quote-body {
    font-size: 17px !important;
    line-height: 1.75 !important;
}
.director-mini-card p {
    font-size: 17px !important;
    line-height: 1.65 !important;
}
.director-mini-card.highlight p {
    font-size: 17px !important;
    color: rgba(255,255,255,0.95) !important;
}
/* highlight 카드의 strong은 핵심 메시지라 골드 강조 유지 */
.director-mini-card.highlight strong {
    font-weight: 800;
}

/* 모바일에서도 16px 이상 유지 */
@media (max-width: 640px) {
    .director-quote .quote-body { font-size: 16px !important; }
    .director-mini-card p { font-size: 16px !important; }
}

/* === 원장 인용 박스 20px (사용자 요청) === */
.director-quote .quote-body {
    font-size: 20px !important;
    line-height: 1.65 !important;
    font-weight: 500 !important;
}
@media (max-width: 768px) {
    .director-quote .quote-body {
        font-size: 17px !important;
        line-height: 1.6 !important;
    }
}

/* === Highlight 카드 v2 — 강력한 임팩트 + 명확한 가독성 === */
.director-mini-card.highlight {
    display: block !important;
    background: linear-gradient(135deg, #0a1530 0%, #1e3a8a 60%, #172554 100%) !important;
    border: 2px solid rgba(251,191,36,0.45) !important;
    border-radius: 18px !important;
    padding: 28px 32px !important;
    position: relative;
    overflow: hidden;
    box-shadow: 0 20px 45px rgba(15,23,42,0.25), 0 0 0 1px rgba(251,191,36,0.1) inset !important;
    margin-top: 8px;
    color: #fff !important;
    transition: all 0.4s cubic-bezier(.2,.8,.2,1);
}
.director-mini-card.highlight::before {
    content: '' !important;
    position: absolute !important;
    width: 260px; height: 260px;
    background: radial-gradient(circle, rgba(251,191,36,0.35) 0%, transparent 70%) !important;
    top: -100px; right: -100px;
    border-radius: 50%;
    pointer-events: none;
    transition: transform 0.5s;
    z-index: 0;
}
.director-mini-card.highlight:hover {
    transform: translateY(-4px);
    box-shadow: 0 30px 60px rgba(15,23,42,0.35), 0 0 0 1px rgba(251,191,36,0.2) inset !important;
    border-color: rgba(251,191,36,0.7) !important;
}
.director-mini-card.highlight:hover::before {
    transform: scale(1.3);
}
/* highlight 카드 내부 dmc-icon 숨김 (새 디자인은 필요 없음) */
.director-mini-card.highlight .dmc-icon { display: none !important; }

/* 모든 자식 z-index 1 */
.director-mini-card.highlight > * {
    position: relative;
    z-index: 1;
}

/* 라벨 (별 + 텍스트) */
.hl-badge {
    display: inline-block;
    background: linear-gradient(135deg, rgba(251,191,36,0.2), rgba(212,160,23,0.3));
    color: #fbbf24;
    padding: 7px 16px;
    border-radius: 50px;
    font-size: 16px;
    font-weight: 800;
    letter-spacing: 0.05em;
    border: 1px solid rgba(251,191,36,0.5);
    margin-bottom: 16px;
    box-shadow: 0 4px 12px rgba(251,191,36,0.2);
}

/* 리드 (작은 흰 문장) */
.hl-lead {
    font-size: 16px !important;
    color: rgba(255,255,255,0.8) !important;
    margin: 0 0 10px !important;
    line-height: 1.5 !important;
    font-weight: 500 !important;
}

/* 메인 (큰 골드 강조) */
.hl-main {
    font-size: 24px !important;
    font-weight: 800 !important;
    color: #fbbf24 !important;
    line-height: 1.3 !important;
    margin: 0 0 14px !important;
    letter-spacing: -.02em;
    text-shadow: 0 2px 8px rgba(212,160,23,0.25);
}

/* 푸터 (이탤릭) */
.hl-footer {
    font-size: 16px !important;
    color: rgba(255,255,255,0.75) !important;
    font-style: italic;
    margin: 0 !important;
    padding-top: 12px;
    border-top: 1px solid rgba(255,255,255,0.1);
    line-height: 1.5 !important;
}

/* 모바일 */
@media (max-width: 640px) {
    .director-mini-card.highlight { padding: 24px 22px !important; }
    .hl-badge { font-size: 16px; padding: 6px 12px; }
    .hl-lead { font-size: 16px !important; }
    .hl-main { font-size: 20px !important; }
    .hl-footer { font-size: 16px !important; }
}

/* === 원장 소개 v3 — 상단 헤드(가운데) + 4.5:5.5 그리드 === */
.director-head-center {
    text-align: center;
    margin-bottom: 48px;
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}
.director-head-center .eyebrow {
    display: inline-block;
    margin-bottom: 14px;
}
.director-headline {
    font-size: clamp(28px, 4.2vw, 44px) !important;
    font-weight: 800 !important;
    color: var(--c-navy-dark) !important;
    line-height: 1.2 !important;
    letter-spacing: -.025em !important;
    margin: 0 0 28px !important;
}

.director-philosophy {
    background: linear-gradient(135deg, rgba(212,160,23,0.06) 0%, rgba(30,58,138,0.04) 100%);
    border-left: 4px solid var(--c-gold);
    border-radius: 12px;
    padding: 22px 28px;
    margin: 0 auto;
    max-width: 800px;
    text-align: left;
}
.philo-main {
    font-size: 18px !important;
    line-height: 1.6 !important;
    color: var(--c-navy-dark) !important;
    margin: 0 0 8px !important;
    font-weight: 600 !important;
}
.philo-main em {
    font-style: normal;
    font-weight: 800;
    background: linear-gradient(120deg, var(--c-gold) 0%, #fbbf24 100%);
    -webkit-background-clip: text;
    background-clip: text;
    color: transparent;
    font-size: 22px;
    letter-spacing: -.01em;
}
.philo-sub {
    font-size: 16px !important;
    color: var(--c-text-soft) !important;
    margin: 0 !important;
    font-style: italic;
    line-height: 1.55 !important;
}

/* 4.5 : 5.5 그리드 */
.director-content-grid {
    display: grid;
    grid-template-columns: 4.5fr 5.5fr;
    gap: 50px;
    align-items: center;
    position: relative;
    z-index: 1;
}

/* 우측 텍스트 헤딩 마진 조정 (위 헤드와 중복 X) */
.director-content-grid .director-v2-text h2,
.director-content-grid .director-v2-text .eyebrow {
    display: none !important;
}

/* 모바일 */
@media (max-width: 1024px) {
    .director-content-grid { grid-template-columns: 1fr; gap: 40px; }
    .director-head-center { margin-bottom: 32px; }
}
@media (max-width: 640px) {
    .director-philosophy { padding: 18px 20px; }
    .philo-main { font-size: 16px !important; }
    .philo-main em { font-size: 19px; }
    .philo-sub { font-size: 16px !important; }
}

/* === 원장 그리드 4.5:5.5 강제 (사용자 모니터에서 1열 떨어지는 것 방지) === */
.director-content-grid {
    display: grid !important;
    grid-template-columns: 4.5fr 5.5fr !important;
    gap: 40px !important;
    align-items: center;
}
.director-content-grid .director-v2-photo {
    grid-column: 1;
}
.director-content-grid .director-v2-text {
    grid-column: 2;
    display: block !important;
}

/* 우측 텍스트의 헤딩/eyebrow 숨김 (상단 head 와 중복 회피) */
.director-content-grid .director-v2-text > h2,
.director-content-grid .director-v2-text > .eyebrow {
    display: none !important;
}

/* 작은 노트북 (1024-1280) 에서도 2열 유지하되 비율 살짝 조정 */
@media (max-width: 1280px) and (min-width: 769px) {
    .director-content-grid {
        grid-template-columns: 4fr 6fr !important;
        gap: 30px !important;
    }
}

/* 768px 이하만 1열 (모바일·작은 태블릿) */
@media (max-width: 768px) {
    .director-content-grid {
        grid-template-columns: 1fr !important;
        gap: 32px !important;
    }
}

/* 사진 자체도 max-width 보장 */
.director-v2-photo,
.director-v2-photo-wrap {
    max-width: 100%;
}

/* === 지도 빠른 링크 (카카오·네이버·길찾기) === */
.map-quick-links {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    flex-wrap: wrap;
}
.map-link {
    flex: 1 1 auto;
    min-width: 140px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid var(--c-line);
    border-radius: 10px;
    color: var(--c-text);
    font-size: 16px;
    font-weight: 600;
    text-decoration: none;
    transition: all 0.2s;
}
.map-link:hover {
    background: var(--c-bg-soft);
    border-color: var(--c-gold);
    color: var(--c-navy);
    transform: translateY(-2px);
    box-shadow: 0 6px 14px rgba(15,23,42,0.08);
    text-decoration: none;
}
.map-link.kakao:hover { border-color: #FEE500; background: #FFFBEA; }
.map-link.naver:hover { border-color: #03C75A; background: #E6F9EE; }
.map-link.gmap:hover  { border-color: #4285F4; background: #E8F0FE; }
.map-link-icon { font-size: 18px; }