@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Noto+Sans+JP:wght@400;500;700&family=Noto+Sans+SC:wght@400;500;700&family=Inter:wght@400;500;600;700&display=swap');

:root {
  --gold: #C9A84C;
  --gold-light: #E8C97A;
  --gold-dark: #9A7A32;
  --beige: #F5F0E8;
  --beige-dark: #E8DFD0;
  --cream: #FAF7F2;
  --black: #1A1A1A;
  --dark: #2C2C2C;
  --dark2: #3D3D3D;
  --gray: #888888;
  --white: #FFFFFF;
  --border: rgba(201,168,76,0.3);
  --border-light: rgba(201,168,76,0.15);
  --font-en: 'Cormorant Garamond', serif;
  --font-sans: 'Inter', 'Pretendard', sans-serif;
  --font-ko: 'Pretendard', 'Pretendard Variable', -apple-system, BlinkMacSystemFont, sans-serif;
  --font-ja: 'Noto Sans JP', sans-serif;
  --font-zh: 'Noto Sans SC', sans-serif;
  --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { background:var(--cream); color:var(--black); font-family:var(--font-ko); line-height:1.7; overflow-x:hidden; }
body.lang-en { font-family:var(--font-sans); }
body.lang-ja { font-family:var(--font-ja); }
body.lang-zh { font-family:var(--font-zh); }

[data-lang] { display:none; }
[data-lang].active { display:block; }
[data-lang-inline] { display:none; }
[data-lang-inline].active { display:inline; }

/* NAV */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(250,247,242,0.96);
  backdrop-filter:blur(20px);
  border-bottom:1px solid var(--border-light);
  transition:var(--transition);
}
.nav-inner {
  max-width:1400px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 40px; height:76px;
}
.nav-logo { text-decoration:none; display:flex; flex-direction:column; gap:2px; }
.nav-logo-en { font-family:var(--font-en); font-size:26px; font-weight:600; letter-spacing:0.1em; color:var(--black); line-height:1; }
.nav-logo-sub { font-family:var(--font-sans); font-size:10px; font-weight:600; letter-spacing:0.22em; color:var(--gold); text-transform:uppercase; }
.nav-menu { display:flex; align-items:center; gap:36px; list-style:none; }
.nav-menu a {
  font-family:var(--font-ko); font-size:14px; font-weight:600; letter-spacing:0.005em;
  text-decoration:none; color:var(--dark2);
  transition:var(--transition); position:relative;
}
.nav-menu a::after { content:''; position:absolute; bottom:-4px; left:0; width:0; height:1px; background:var(--gold); transition:width 0.3s; }
.nav-menu a:hover { color:var(--gold); }
.nav-menu a:hover::after, .nav-menu a.active-link::after { width:100%; }
.nav-menu a.active-link { color:var(--gold); }
.nav-right { display:flex; align-items:center; gap:16px; }
.lang-switcher { display:flex; align-items:center; gap:3px; background:var(--beige); border:1px solid var(--border); border-radius:40px; padding:4px 6px; }
.lang-btn { font-family:var(--font-sans); font-size:12px; font-weight:600; letter-spacing:0.02em; padding:6px 12px; border-radius:30px; border:none; background:transparent; color:var(--gray); cursor:pointer; transition:var(--transition); }
.lang-btn.active { background:var(--black); color:var(--white); }
.lang-btn:hover:not(.active) { background:var(--beige-dark); color:var(--dark); }
.nav-cta { font-family:var(--font-ko); font-size:13.5px; font-weight:700; letter-spacing:0.01em; text-decoration:none; padding:11px 26px; background:var(--gold); color:var(--white); border-radius:3px; transition:var(--transition); }
.nav-cta:hover { background:var(--gold-dark); transform:translateY(-1px); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; }
.hamburger span { width:24px; height:1.5px; background:var(--black); transition:var(--transition); }

/* MOBILE NAV */
.mobile-nav { position:fixed; inset:0; z-index:2000; background:var(--black); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:6px; transform:translateX(100%); transition:transform 0.4s cubic-bezier(0.4,0,0.2,1); }
.mobile-nav.open { transform:translateX(0); }
.mobile-nav-close { position:absolute; top:24px; right:24px; width:44px; height:44px; border:1px solid rgba(255,255,255,0.2); background:transparent; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; }
.mobile-nav-close svg { width:20px; height:20px; stroke:white; fill:none; stroke-width:1.5; }
.mobile-nav a { font-family:var(--font-en); font-size:28px; font-weight:400; color:rgba(255,255,255,0.7); text-decoration:none; letter-spacing:0.05em; transition:var(--transition); }
.mobile-nav a:hover { color:var(--gold); }
.mobile-nav-lang { display:flex; gap:8px; margin-top:24px; }
.mobile-nav-lang .lang-btn { border:1px solid rgba(255,255,255,0.2); color:rgba(255,255,255,0.5); }
.mobile-nav-lang .lang-btn.active { background:var(--gold); border-color:var(--gold); color:white; }

/* PAGE HERO */
.page-hero {
  background:var(--black); padding:140px 40px 80px;
  position:relative; overflow:hidden;
}
.page-hero-pattern { position:absolute; inset:0; opacity:0.04; background-image:repeating-linear-gradient(45deg,var(--gold) 0px,var(--gold) 1px,transparent 1px,transparent 40px); }
.page-hero-inner { max-width:1400px; margin:0 auto; position:relative; z-index:2; }
.page-hero-tag { display:inline-flex; align-items:center; gap:12px; font-family:var(--font-sans); font-size:10px; font-weight:500; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:20px; }
.page-hero-tag::before { content:''; width:32px; height:1px; background:var(--gold); }
.page-hero h1 { font-family:var(--font-en); font-size:clamp(40px,6vw,72px); font-weight:300; color:var(--white); line-height:1; letter-spacing:-0.01em; }
.page-hero h1 em { color:var(--gold); font-style:italic; }

/* SECTION */
section { scroll-margin-top:76px; }
.section-inner { max-width:1400px; margin:0 auto; padding:0 40px; }
.section-header { text-align:center; margin-bottom:60px; }
.section-tag { display:inline-flex; align-items:center; gap:16px; font-family:var(--font-sans); font-size:10px; font-weight:500; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.section-tag::before, .section-tag::after { content:''; height:1px; background:var(--border); width:36px; }
.section-title { font-family:var(--font-en); font-size:clamp(28px,4vw,48px); font-weight:400; color:var(--black); line-height:1.1; }
.section-title em { color:var(--gold); font-style:italic; }
.section-desc { font-size:14.5px; color:var(--gray); max-width:540px; margin:16px auto 0; line-height:1.9; }

/* BUTTONS */
.btn-primary { font-family:var(--font-sans); font-size:11px; font-weight:600; letter-spacing:0.15em; text-transform:uppercase; text-decoration:none; padding:15px 34px; background:var(--gold); color:var(--white); border:none; cursor:pointer; border-radius:2px; transition:var(--transition); display:inline-block; }
.btn-primary:hover { background:var(--gold-dark); transform:translateY(-2px); box-shadow:0 8px 30px rgba(201,168,76,0.3); }
.btn-outline { font-family:var(--font-sans); font-size:11px; font-weight:500; letter-spacing:0.15em; text-transform:uppercase; text-decoration:none; padding:14px 33px; background:transparent; color:var(--black); border:1px solid var(--border); border-radius:2px; transition:var(--transition); display:inline-block; cursor:pointer; }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }

/* FLOATING CHANNELS */
#channels-float { position:fixed; right:16px; bottom:80px; z-index:900; display:flex; flex-direction:column; gap:6px; align-items:flex-end; }
.ch-main-btn { width:52px; height:52px; border-radius:50%; background:var(--gold); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:0 4px 20px rgba(201,168,76,0.4); transition:var(--transition); }
.ch-main-btn:hover { transform:scale(1.08); background:var(--gold-dark); }
.ch-main-btn svg { width:22px; height:22px; stroke:white; fill:none; stroke-width:2; }
.ch-group { display:flex; flex-direction:column; gap:6px; align-items:flex-end; overflow:hidden; max-height:0; transition:max-height 0.4s cubic-bezier(0.4,0,0.2,1); }
.ch-group.open { max-height:600px; }
.ch-icon { display:flex; align-items:center; gap:8px; cursor:pointer; text-decoration:none; font-family:var(--font-sans); font-size:11px; font-weight:600; letter-spacing:0.03em; box-shadow:0 2px 12px rgba(0,0,0,0.15); transition:var(--transition); border:none; border-radius:24px; padding:0 14px 0 6px; height:40px; white-space:nowrap; }
.ch-icon:hover { transform:translateX(-4px); box-shadow:0 4px 20px rgba(0,0,0,0.2); }
.ch-icon-dot { width:28px; height:28px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:800; }
.ch-kakao { background:#FEE500; color:#3C1E1E; } .ch-kakao .ch-icon-dot { background:rgba(0,0,0,0.1); }
.ch-naver { background:#03C75A; color:white; } .ch-naver .ch-icon-dot { background:rgba(0,0,0,0.15); }
.ch-insta { background:#E1306C; color:white; } .ch-insta .ch-icon-dot { background:rgba(0,0,0,0.15); }
.ch-line { background:#00B900; color:white; } .ch-line .ch-icon-dot { background:rgba(0,0,0,0.15); }
.ch-wechat { background:#07C160; color:white; } .ch-wechat .ch-icon-dot { background:rgba(0,0,0,0.15); }
.ch-phone { background:#2C2C2C; color:white; } .ch-phone .ch-icon-dot { background:rgba(255,255,255,0.1); }
.ch-consult { background:var(--gold); color:white; } .ch-consult .ch-icon-dot { background:rgba(0,0,0,0.15); }

/* FOOTER */
footer { background:var(--black); padding:72px 0 36px; border-top:1px solid rgba(201,168,76,0.2); }
.footer-inner { max-width:1400px; margin:0 auto; padding:0 40px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px; margin-bottom:52px; padding-bottom:52px; border-bottom:1px solid rgba(255,255,255,0.08); }
.footer-logo { font-family:var(--font-en); font-size:26px; font-weight:600; letter-spacing:0.1em; color:var(--white); margin-bottom:6px; }
.footer-logo-sub { font-family:var(--font-sans); font-size:8px; letter-spacing:0.3em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-desc { font-size:13px; color:rgba(255,255,255,0.4); line-height:1.9; max-width:260px; }
.footer-col h4 { font-family:var(--font-sans); font-size:10px; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a { font-size:13px; color:rgba(255,255,255,0.5); text-decoration:none; transition:var(--transition); }
.footer-col a:hover { color:var(--gold); }
.footer-bottom { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px; }
.footer-copy { font-size:12px; color:rgba(255,255,255,0.3); }
.footer-legal { display:flex; gap:20px; }
.footer-legal a { font-family:var(--font-sans); font-size:10px; letter-spacing:0.1em; color:rgba(255,255,255,0.3); text-decoration:none; }
.footer-legal a:hover { color:var(--gold); }

/* RESPONSIVE */
@media(max-width:900px) {
  .nav-menu, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .nav-inner { padding:0 20px; }
  .page-hero { padding:120px 20px 60px; }
  .section-inner { padding:0 20px; }
  .footer-top { grid-template-columns:1fr 1fr; gap:28px; }
}
@media(max-width:600px) {
  .footer-top { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; align-items:flex-start; }
  #channels-float { right:10px; bottom:60px; }
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* PROFESSIONAL TYPOGRAPHY ENHANCEMENT (2026-05-07) */
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
body {
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  letter-spacing: -0.005em;
}

body.lang-ko {
  font-feature-settings: "ss10";  /* Pretendard 한글 최적화 */
}

/* 한글 본문 가독성 강화 */
body.lang-ko p,
body.lang-ko li,
body.lang-ko span,
body.lang-ko div { font-weight: 400; }

body.lang-ko h1, body.lang-ko h2, body.lang-ko h3,
body.lang-ko h4, body.lang-ko h5 { font-weight: 600; letter-spacing: -0.02em; }

/* 영문은 Inter (전문성) */
body.lang-en p, body.lang-en li, body.lang-en span, body.lang-en div { font-weight: 400; }
body.lang-en h1, body.lang-en h2, body.lang-en h3, body.lang-en h4 { font-weight: 600; letter-spacing: -0.015em; }

/* 일본어/중국어 가독성 */
body.lang-ja, body.lang-zh { font-weight: 400; }
body.lang-ja h1, body.lang-ja h2, body.lang-ja h3,
body.lang-zh h1, body.lang-zh h2, body.lang-zh h3 { font-weight: 600; }

/* 폰트 굵기 일괄 강화 */
.footer-desc,
.contact-text p,
.contact-text a,
.form-input,
.form-select,
.form-textarea { font-weight: 400; }

/* 본문 색상 강화 (가독성) */
body.lang-ko { color: #141414; }

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* NEW FLOATING CHANNEL BUTTON (직관적 채팅 아이콘) */
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.ch-main-btn {
  position: relative;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-dark) 100%);
  box-shadow: 0 6px 24px rgba(201,168,76,0.45), 0 2px 8px rgba(0,0,0,0.1);
  width: 60px;
  height: 60px;
}
.ch-main-btn:hover { transform: scale(1.08) translateY(-2px); }
.ch-main-btn svg { width: 26px; height: 26px; transition: transform 0.3s ease; }
.ch-main-btn.open svg { transform: rotate(90deg); }

/* "1:1 상담" 라벨 (Pulse 효과) */
.ch-main-btn::before {
  content: '';
  position: absolute;
  top: -2px; left: -2px; right: -2px; bottom: -2px;
  border-radius: 50%;
  border: 2px solid var(--gold);
  opacity: 0;
  animation: pulseRing 2.5s ease-out infinite;
  pointer-events: none;
}
@keyframes pulseRing {
  0% { transform: scale(0.95); opacity: 0.7; }
  80%, 100% { transform: scale(1.4); opacity: 0; }
}

/* 라벨 툴팁 */
.ch-tooltip {
  position: absolute;
  right: 70px;
  top: 50%;
  transform: translateY(-50%);
  background: var(--black);
  color: white;
  font-size: 12px;
  font-weight: 600;
  padding: 8px 14px;
  border-radius: 6px;
  white-space: nowrap;
  box-shadow: 0 4px 16px rgba(0,0,0,0.2);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s ease;
  font-family: var(--font-ko);
}
.ch-tooltip::after {
  content: '';
  position: absolute;
  right: -5px;
  top: 50%;
  transform: translateY(-50%);
  border: 5px solid transparent;
  border-left-color: var(--black);
}
.ch-main-btn:hover ~ .ch-tooltip,
.ch-main-wrap:hover .ch-tooltip { opacity: 1; }

/* WhatsApp 추가 색상 */
.ch-whatsapp { background: #25D366; color: white; }
.ch-whatsapp .ch-icon-dot { background: rgba(0,0,0,0.15); }

/* 채널 아이콘 글자 굵기 강화 */
.ch-icon { font-weight: 700; font-family: var(--font-ko); }

/* 모바일 반응형 */
@media (max-width: 768px) {
  .ch-main-btn { width: 56px; height: 56px; }
  .ch-tooltip { display: none; }
}
