
/* ───────────────────────────────────────────────
   styles.css L316-453 — site-header / brand / division-switcher (tooltip)
   ─────────────────────────────────────────────── */

/* ==== Top Nav ==== */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  height: var(--header-height);
  display: flex;
  align-items: center;
  background: var(--paper);
  border-bottom: 1px solid transparent;
  transition: background var(--dur-base) var(--ease-out-soft),
              border-color var(--dur-base) var(--ease-out-soft);
}
.site-header.is-scrolled {
  background: var(--paper-92);
  -webkit-backdrop-filter: saturate(140%) blur(16px);
  backdrop-filter: saturate(140%) blur(16px);
  border-bottom-color: var(--ink-200);
}
.site-header__inner {
  width: 100%;
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--container-pad);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--space-lg);
}

.brand {
  display: flex;
  align-items: center;
  gap: var(--space-md);
}
.brand__logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: -0.018em;
  color: var(--ink-900);
}
.brand__mark {
  width: 28px; height: 28px;
  border-radius: var(--r-sm);
  background: var(--ink-900);
  color: var(--paper);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  position: relative;
  overflow: hidden;
}
.brand__mark::before {
  content: "";
  position: absolute;
  inset: -10% -50% auto auto;
  width: 70%; height: 200%;
  background: var(--orange-500);
  transform: rotate(28deg);
}
.brand__mark span { position: relative; z-index: 1; color: var(--ink-900); }

.division-switcher {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 4px;
  border-radius: var(--r-pill);
  background: var(--ink-100);
  font-size: 13px;
  font-weight: 500;
}
.division-switcher a {
  padding: 6px 14px;
  border-radius: var(--r-pill);
  color: var(--ink-500);
  transition: background var(--dur-fast) var(--ease-out-soft), color var(--dur-fast) var(--ease-out-soft);
}
.division-switcher a[aria-current="page"] {
  background: var(--ink-900);
  color: var(--paper);
}
.division-switcher a:not([aria-current="page"]):hover { color: var(--ink-900); }

/* Division-switcher — dark popover tooltip on hover (Film/School) */
.division-switcher a.has-tip { position: relative; }
.division-switcher .div-tip {
  position: absolute;
  top: calc(100% + 8px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  white-space: nowrap;
  font-family: var(--font-body);
  font-size: 12.5px;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: var(--white);
  background: var(--ink-900);
  padding: 8px 14px;
  border-radius: 8px;
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 100;
  text-transform: none;
}
.division-switcher .div-tip strong { font-weight: 700; }
.division-switcher a.has-tip::before {
  content: "";
  position: absolute;
  top: calc(100% + 2px);
  left: 50%;
  transform: translateX(-50%) translateY(-4px);
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-bottom: 6px solid var(--ink-900);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.18s ease, transform 0.18s ease;
  z-index: 100;
}
.division-switcher a.has-tip:hover .div-tip,
.division-switcher a.has-tip:focus-visible .div-tip,
.division-switcher a.has-tip:hover::before,
.division-switcher a.has-tip:focus-visible::before {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}



/* ───────────────────────────────────────────────
   styles.css L454-551 — site-nav / header-cta / menu-trigger / mobile-menu
   ─────────────────────────────────────────────── */
/* Nav */
.site-nav {
  display: flex;
  justify-content: center;
  gap: clamp(16px, 1.6vw, 28px);
}
.site-nav a {
  font-size: var(--fs-nav);
  font-weight: 500;
  color: var(--ink-800);
  padding: 8px 4px;
  letter-spacing: -0.005em;
  transition: color var(--dur-fast) var(--ease-out-soft);
}
.site-nav a:hover { color: var(--ink-900); }

.header-cta { display: flex; align-items: center; gap: var(--space-sm); }
.header-cta--studio { grid-column: 3; justify-self: end; }
.header-cta--studio .btn { padding-inline: 18px; }
.header-cta .btn--ghost {
  background: var(--paper) !important;
  color: var(--ink-900) !important;
  border: 1px solid var(--ink-200) !important;
}
.header-cta .signin {
  font-size: var(--fs-nav);
  font-weight: 500;
  color: var(--ink-800);
  padding: 8px 4px;
}
.header-cta .signin:hover { color: var(--ink-900); }

/* Mobile menu trigger */
.menu-trigger {
  display: none;
  width: 40px; height: 40px;
  align-items: center; justify-content: center;
  border: 1px solid var(--ink-300);
  border-radius: var(--r-md);
  background: var(--paper);
}
.menu-trigger span,
.menu-trigger span::before,
.menu-trigger span::after {
  display: block;
  width: 18px; height: 1.6px;
  background: var(--ink-900);
  border-radius: 2px;
}
.menu-trigger span { position: relative; }
.menu-trigger span::before, .menu-trigger span::after {
  content: ""; position: absolute; left: 0;
  transition: transform var(--dur-base) var(--ease-out-soft), top var(--dur-base) var(--ease-out-soft), bottom var(--dur-base) var(--ease-out-soft);
}
.menu-trigger span::before { top: -6px; }
.menu-trigger span::after { bottom: -6px; }
body.menu-open .menu-trigger span { background: transparent; }
body.menu-open .menu-trigger span::before { top: 0; transform: rotate(45deg); }
body.menu-open .menu-trigger span::after { bottom: 0; transform: rotate(-45deg); }

/* Mobile overlay */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 99;
  background: var(--paper);
  padding: calc(var(--header-height) + var(--space-lg)) var(--container-pad) var(--space-2xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  transform: translateY(-100%);
  transition: transform var(--dur-slow) var(--ease-out-soft);
  overflow-y: auto;
}
body.menu-open .mobile-menu { transform: translateY(0); }
.mobile-menu .division-switcher { align-self: flex-start; }
.mobile-menu nav {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.mobile-menu nav a {
  font-size: 28px;
  font-weight: 600;
  letter-spacing: -0.025em;
  color: var(--ink-900);
  padding: 12px 0;
  border-bottom: 1px solid var(--ink-100);
}
.mobile-menu .mobile-foot {
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
  color: var(--ink-500);
  font-size: var(--fs-body-sm);
}


/* ───────────────────────────────────────────────
   styles.css L552-644 — site-footer v1 (grid/sns/bar/mountain)
   ─────────────────────────────────────────────── */
/* ==== Footer (cream — never dark) ==== */
.site-footer {
  background: var(--ink-50);
  color: var(--ink-700);
  position: relative;
  padding-block: 80px 0;
  margin-top: var(--space-section);
}
.site-footer__grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.4fr;
  gap: var(--space-2xl);
  padding-bottom: var(--space-2xl);
}
.site-footer__brand .brand__logo { font-size: 18px; }
.site-footer__slogan {
  margin-top: var(--space-md);
  font-size: 22px;
  line-height: 1.25;
  font-weight: 500;
  letter-spacing: -0.022em;
  color: var(--ink-900);
  max-width: 22ch;
}
.site-footer__col h4 {
  font-size: var(--fs-caption-up);
  font-weight: 600;
  letter-spacing: var(--tracking-up);
  text-transform: uppercase;
  color: var(--ink-500);
  margin-bottom: var(--space-md);
}
.site-footer__links {
  display: flex; flex-direction: column; gap: 10px;
}
.site-footer__links a {
  font-size: var(--fs-body-sm);
  color: var(--ink-800);
}
.site-footer__links a:hover { color: var(--ink-900); border-bottom: 1px solid currentColor; padding-bottom: 1px; }

.site-footer__info p {
  font-size: var(--fs-body-sm);
  color: var(--ink-700);
  line-height: var(--lh-loose);
}
.site-footer__info strong { color: var(--ink-900); font-weight: 600; }

.site-footer__sns {
  display: flex; gap: 8px;
  margin-top: var(--space-md);
  flex-wrap: wrap;
}
.site-footer__sns a {
  width: 36px; height: 36px;
  border-radius: var(--r-md);
  background: var(--paper);
  border: 1px solid var(--ink-300);
  display: inline-flex;
  align-items: center; justify-content: center;
  color: var(--ink-900);
  transition: background var(--dur-fast) var(--ease-out-soft);
}
.site-footer__sns a:hover { background: var(--ink-100); }
.site-footer__sns svg { width: 16px; height: 16px; }

.site-footer__bar {
  padding: var(--space-lg) 0;
  border-top: 1px solid var(--ink-300);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-sm);
  font-size: var(--fs-caption);
  color: var(--ink-500);
}
.site-footer__sign {
  font-weight: 500;
  color: var(--ink-900);
  letter-spacing: -0.015em;
}

/* Footer mountain horizon (Clay signature) */
.site-footer__mountain {
  position: relative;
  height: 90px;
  margin-top: var(--space-xl);
  margin-inline: calc(var(--container-pad) * -1);
  overflow: hidden;
}
.site-footer__mountain svg { display: block; width: 100%; height: 100%; }


/* ───────────────────────────────────────────────
   styles.css L1562-1566 — .brand__logo SVG (헤더/푸터 로고)
   ─────────────────────────────────────────────── */
/* New SVG logo (replaces .brand__mark + text) */
.brand__logo { gap: 0; color: var(--ink-900); }
.brand__logo-img { height: 22px; width: auto; display: block; }
.site-footer__brand .brand__logo-img { height: 24px; }


/* ───────────────────────────────────────────────
   styles.css L1567-1666 — 전역 타이포 통합 override — head에서 layout 뒤(.brand__logo/.site-nav a 등 layout 정의를 이김) + body의 block CSS 앞(.fossa-en 등 block 비-!important에 짐)에 위치해야 함 → layout이 정확한 슬롯
   ─────────────────────────────────────────────── */
/* ============================================================
   Global typography unification — overrides everything above
   - 한글: Pretendard Variable
   - 영문: Montserrat
   - italic 절대 금지 — 강조는 굵기로만
   ============================================================ */
:root {
  --font-kr:  "Pretendard Variable", Pretendard, system-ui, -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", sans-serif;
  --font-en:  "Montserrat", "Pretendard Variable", system-ui, sans-serif;
  --font-display: var(--font-en);
  --font-body:    var(--font-kr);
  --font-mono:    var(--font-en);
  --font-serif:   var(--font-kr);  /* serif alias killed */
}

html, body { font-family: var(--font-body); font-style: normal; }

/* italic 전면 차단 (인라인 스타일 포함) */
em, i, cite, var, address, dfn, .serif-it,
em *, i *, cite *, .serif-it *,
[style*="italic"] {
  font-style: normal !important;
}

/* serif 류 인라인 → Pretendard 강제 */
.serif-it,
[style*="font-serif"], [style*="var(--font-serif)"],
[style*="Instrument Serif"], [style*="Fraunces"] {
  font-family: var(--font-kr) !important;
}

/* em 류 강조 — italic 대신 굵기 */
em, i, cite, .serif-it { font-weight: 700; font-family: var(--font-kr) !important; }

/* hero kinetic / display headings — 영문 Montserrat 통일 */
.hero-line, .hero-line *,
.h-display, .h-display.kr,
.ftr-mega, .ftr-mega *,
.hdr-main-en, .stat__num, .num,
.fossa-letter, .fw-name, .tl-year,
.fast-cell h3, .eco-side h3 {
  font-family: var(--font-en) !important;
  font-style: normal !important;
}

/* 한글 본문 헤딩 — Pretendard, weight 강조 */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3,
.sect-head__title, .page-hero__title, .page-hero h1,
.cta-band__title, .cta-band__title em,
.testi-quote, .voice p, .quote {
  font-family: var(--font-kr) !important;
  font-style: normal !important;
}

/* tiny / mono / eyebrow — 영문 라벨이라 Montserrat */
.tiny, .eyebrow, .caption-up, .hdr-main-link,
.svc-en, .svc-tag, .fossa-en, .fw-tag, .lbl,
.hdr-switch-link .en, .hero-stat .lbl,
.testi-meta, .port-client, .course-meta,
.product-frag__title, .product-frag__row, .product-frag__meta,
.work-tile .meta, .work-tile .client, .feature-card .label, .feature-card .price-tag,
.benefit .ico, .ftr h4, .ftr-bottom, .layered__list .tiny,
.shell-bar__tagline, .site-switch__btn,
.hdr-logo, .brand__logo,
.hero-eyebrow-row .tiny, .strip-statement .meta,
.b2b__partners .label, .b2b__partners li small,
.course-card .format span, .course-card .badge, .course-card .price-row .was,
.framework-card .badge, .framework-card .fw-tag {
  font-family: var(--font-en);
  font-style: normal !important;
  letter-spacing: 0.04em;
}

/* 본문 단락 / 리스트 — Pretendard */
p, li, td, th, dd, dt, label, input, textarea, select, button {
  font-family: var(--font-kr);
  font-style: normal !important;
}

/* 영문 디스플레이 안의 한글 토큰은 Pretendard 로 다시 */
.hero-line:lang(ko), .h-display:lang(ko) {
  font-family: var(--font-kr) !important;
}
/* Division switcher (Film / School) — uppercase */
.division-switcher a { text-transform: uppercase; letter-spacing: 0.04em; font-weight: 700; }

/* Site nav — bold + tracking (EN uppercase) */
.site-nav a { font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; }
body.film .site-nav a { font-weight: 700; letter-spacing: 0.12em; }
/* school nav is Korean — drop EN-tracking + uppercase, use natural Pretendard */
body.school .site-nav a,
body.school .header-cta .signin,
body.school .site-footer__nav a {
  font-family: var(--font-body);
  letter-spacing: -0.012em;
  text-transform: none;
  font-weight: 650;
}


/* ───────────────────────────────────────────────
   styles.css L2565-2672 — footer v2 slim + school-banner
   ─────────────────────────────────────────────── */
/* ============================================================
   Footer — slim 2-area top + sadari school banner + minimal bar
   ============================================================ */
.site-footer__top {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 48px;
  align-items: start;
  padding-bottom: 36px;
  border-bottom: 1px solid var(--ink-300);
}
@media (max-width: 800px) {
  .site-footer__top { grid-template-columns: 1fr; }
}
.site-footer__brand .site-footer__slogan {
  margin-top: 20px;
  font-size: 22px;
  font-weight: 600;
  line-height: 1.5;
  letter-spacing: -0.022em;
  color: var(--ink-900);
  max-width: none;
}

.site-footer__nav {
  display: flex; flex-wrap: wrap;
  gap: 8px 28px;
  align-self: center;
  padding-top: 8px;
}
.site-footer__nav a {
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-900);
  border-bottom: 1.5px solid transparent;
  padding-bottom: 2px;
  transition: border-color 0.15s;
}
.site-footer__nav a:hover { border-bottom-color: var(--ink-900); }

/* 사다리스쿨 banner */
.school-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin: 28px 0 8px;
  padding: 24px 32px;
  background: var(--ink-900);
  color: var(--paper);
  border-radius: 14px;
  text-decoration: none;
  transition: background 0.2s, transform 0.2s;
}
.school-banner:hover {
  background: var(--cta-blue, var(--accent-blue));
  transform: translateY(-1px);
}
.school-banner__eyebrow {
  display: block;
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--paper-55);
  margin-bottom: 6px;
}
.school-banner h3 {
  font-family: var(--font-kr);
  font-weight: 700;
  font-size: 19px;
  line-height: 1.45;
  color: var(--paper);
  margin: 0;
}
.school-banner__cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-kr);
  font-size: 14px;
  font-weight: 600;
  color: var(--paper);
  white-space: nowrap;
}
@media (max-width: 600px) {
  .school-banner { flex-direction: column; align-items: flex-start; padding: 20px 22px; }
  .school-banner h3 { font-size: 17px; }
}

/* Slim bar */
.site-footer__bar {
  border-top: 0;
  padding: 16px 0;
  font-family: var(--font-en);
  font-size: 12px;
  letter-spacing: 0.04em;
  color: var(--ink-500);
  display: block;
}

/* Hide legacy bits if they ever come back */
.site-footer__sign,
.site-footer__grid,
.site-footer__col { display: none; }


/* ───────────────────────────────────────────────
   styles.css L2673-2887 — footer v3 3-col (brand/nav/family-card)
   ─────────────────────────────────────────────── */
/* ============================================================
   Footer v3 — 3-col layout (brand / nav+© / family card)
   ============================================================ */
.site-footer { background: var(--ink-50); padding: 56px 0 40px; margin-top: var(--space-section); }
.site-footer__top {
  display: grid;
  grid-template-columns: minmax(240px, 1.4fr) minmax(0, 1.8fr) minmax(280px, 320px);
  gap: 56px;
  align-items: start;
  padding-bottom: 0;
  border-bottom: 0;
}
@media (max-width: 1000px) {
  .site-footer__top { grid-template-columns: 1fr; gap: 36px; }
}

/* Brand area */
.site-footer__brand .brand__logo-img { height: 24px; }
.site-footer__brand .site-footer__slogan {
  margin-top: 18px;
  font-size: 15px;
  line-height: 1.65;
  font-weight: 400;
  letter-spacing: 0;
  color: var(--ink-700);
  max-width: none;
}
.site-footer__sns {
  display: flex; gap: 8px;
  margin-top: 22px;
  flex-wrap: wrap;
}
.site-footer__sns a {
  width: 40px; height: 40px;
  background: var(--ink-100);
  border: 0;
  border-radius: 10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-900);
  transition: background 0.15s, color 0.15s;
}
.site-footer__sns a:hover { background: var(--ink-900); color: var(--paper); }

/* Center: nav + copy */
.site-footer__center {
  padding-top: 6px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.site-footer__nav {
  display: flex; flex-wrap: wrap;
  gap: 8px 24px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--ink-300);
}
.site-footer__nav a {
  font-family: var(--font-en);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-800);
  padding-bottom: 1px;
  border-bottom: 1.5px solid transparent;
  transition: border-color 0.15s, color 0.15s;
}
.site-footer__nav a:hover { color: var(--ink-900); border-bottom-color: var(--ink-900); }
.site-footer__copy {
  font-family: var(--font-en);
  font-size: 12.5px;
  font-weight: 500;
  color: var(--ink-500);
  margin: 0;
  letter-spacing: 0.02em;
}

/* Right: family card */
.family-card {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px 24px;
  background: var(--paper);
  border: 1px solid var(--ink-300);
  border-radius: 16px;
  text-decoration: none;
  transition: border-color 0.15s, transform 0.15s;
}
.family-card:hover { border-color: var(--ink-900); transform: translateY(-2px); }
.family-card__eyebrow {
  font-family: var(--font-en);
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-500);
}
.family-card__title {
  font-family: var(--font-kr);
  font-weight: 600;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--ink-900);
  margin: 0;
  letter-spacing: -0.005em;
}
.family-card__brand {
  display: flex; align-items: center; gap: 10px;
  margin-top: 4px;
}
.family-card__brand-mark {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--cta-blue, var(--accent-blue));
  flex-shrink: 0;
}
.family-card__brand-name {
  font-family: var(--font-en);
  font-weight: 800;
  font-size: 13px;
  letter-spacing: 0.02em;
  color: var(--ink-900);
  line-height: 1.1;
}
.family-card__arrow {
  margin-left: auto;
  font-family: var(--font-kr);
  font-size: 13px;
  font-weight: 500;
  color: var(--ink-500);
  transition: color 0.15s;
}
.family-card:hover .family-card__arrow { color: var(--ink-900); }

/* Hide legacy/decorative elements */
.site-footer__mountain { display: none !important; }
.site-footer__bar { display: none !important; }
.site-footer__sign { display: none !important; }

/* Footer contact list (메뉴 아래) */
.site-footer__contact {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 4px;
  font-family: var(--font-kr);
  font-size: 13px;
  line-height: 1.7;
  color: var(--ink-700);
}
.site-footer__contact a { color: inherit; }
.site-footer__contact a:hover { color: var(--ink-900); border-bottom: 1px solid currentColor; padding-bottom: 1px; }

/* Footer slogan — bigger, bolder */
.site-footer__brand .site-footer__slogan {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.018em;
  color: var(--ink-900);
}

/* Footer center — children must align to identical left edge */
.site-footer__center > * { padding-inline: 0 !important; margin-inline: 0 !important; }
.site-footer__nav { padding-bottom: 18px; border-bottom: 1px solid var(--ink-300); }
.site-footer__nav a { padding: 0 0 1px; border-bottom: 1.5px solid transparent; }
.site-footer__contact li { padding: 0; margin: 0; }

/* Footer SNS — solid filled icons (icon IS the badge) */
.site-footer__sns { gap: 8px !important; }
.site-footer__sns a {
  width: 40px !important;
  height: 40px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
  color: var(--ink-400) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: color 0.15s !important;
}
.site-footer__sns a:hover {
  background: transparent !important;
  color: var(--ink-900) !important;
  transform: none !important;
}
.site-footer__sns svg { width: 100% !important; height: 100% !important; display: block !important; }

/* Family-card brand mark — SVG dot-arc (override earlier blue dot) */
.family-card__brand-mark {
  width: 28px !important;
  height: 26px !important;
  background: transparent !important;
  border-radius: 0 !important;
  flex-shrink: 0;
  display: block;
}

/* Footer SNS — final compact size + consistent 4-icon set */
.site-footer__sns { gap: 6px !important; }
.site-footer__sns a {
  width: 32px !important;
  height: 32px !important;
}

/* Family-card brand mark — slightly smaller */
.family-card__brand-mark { width: 22px !important; height: 20px !important; }

/* Footer SNS — smaller, tighter spacing */
.site-footer__sns { gap: 5px !important; }
.site-footer__sns a {
  width: 28px !important;
  height: 28px !important;
}


/* ───────────────────────────────────────────────
   styles.css L2888-2993 — footer v4 flexbox + hover 비활성 + 메뉴 정렬
   ─────────────────────────────────────────────── */
/* ============================================================
   Footer v4 — flexbox layout (3 areas), no menu hover/padding
   ============================================================ */
.site-footer__top {
  display: flex !important;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 48px;
}
.site-footer__brand { flex: 0 1 260px; }
.site-footer__center { flex: 1 1 380px; min-width: 0; }
.family-card { flex: 0 1 300px; align-self: stretch; }

/* Menu items: pulled to span full center width, no hover, no padding */
.site-footer__nav {
  display: flex !important;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between !important;
  align-items: center;
  gap: 8px 16px;
  padding: 0 0 18px !important;
  margin: 0 !important;
  border-bottom: 1px solid var(--ink-300);
}
.site-footer__nav a {
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  border-bottom: 0 !important;
  transition: none !important;
}
.site-footer__nav a:hover {
  color: var(--ink-800) !important;
  border: 0 !important;
  border-bottom: 0 !important;
  background: transparent !important;
}

/* Footer menu — left-aligned (not space-between) */
.site-footer__nav { justify-content: flex-start !important; gap: 8px 32px !important; }

/* Family-card — disable hover */
.family-card { transition: none !important; }
.family-card:hover {
  border-color: var(--ink-300) !important;
  transform: none !important;
  background: var(--paper) !important;
}
.family-card:hover .family-card__arrow { color: var(--ink-500) !important; }

/* Footer center — column with all children stretched & left-aligned */
.site-footer__center {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  text-align: left !important;
}
.site-footer__center > * { align-self: stretch !important; }
.site-footer__nav {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  justify-content: flex-start !important;
  align-items: center !important;
  gap: 8px 32px !important;
  text-align: left !important;
  width: 100% !important;
}

/* Footer center — pull menu up to baseline with left logo */
.site-footer__center { padding-top: 0 !important; }
.site-footer__nav { margin-top: -4px !important; }

/* Footer menu — slight nudge down */
.site-footer__nav { margin-top: 2px !important; }

/* Footer text links — disable hover (no underline, no color shift) */
.site-footer a:hover,
.site-footer__contact a:hover {
  color: inherit !important;
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
  text-decoration: none !important;
}

/* Family card — stretch to siblings' height + extra bottom padding */
.family-card {
  align-self: stretch !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 22px 24px 32px !important;
}

/* Family card — natural own height + own padding (override blanket footer-a hover) */
.site-footer .family-card,
.site-footer .family-card:hover {
  align-self: flex-start !important;
  height: auto !important;
  min-height: 0 !important;
  padding: 22px 24px !important;
  padding-bottom: 22px !important;
}


/* ───────────────────────────────────────────────
   styles.css L4058-4059 — .site-footer margin-top:0 override — footer 패밀리와 co-locate(layout), 모든 페이지 적용돼야 함
   ─────────────────────────────────────────────── */
.section.section--tight#contact + .site-footer,
.site-footer { margin-top: 0 !important; }

/* ───────────────────────────────────────────────
   styles.css L4231-4234 — .site-footer border-top:1px override — footer 패밀리와 co-locate(layout)
   ─────────────────────────────────────────────── */

/* Footer — subtle top border */
.site-footer { border-top: 1px solid var(--ink-200) !important; }


/* ───────────────────────────────────────────────
   styles.css L7668-7725 — page-dots studio side dot 네비
   ─────────────────────────────────────────────── */
/* ============================================================
   Studio side dot indicator
   ============================================================ */
.page-dots {
  position: fixed;
  right: 28px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 16px;
  z-index: 50;
  pointer-events: auto;
}
.page-dot {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 8px 6px 8px 28px;
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.page-dot__mark {
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--ink-200);
  transition: background 0.25s var(--ease-out-soft, ease),
              transform 0.25s var(--ease-out-soft, ease);
}
.page-dot.is-active .page-dot__mark {
  background: var(--orange-700);
  transform: scale(1.2);
}
.page-dot__label {
  position: absolute;
  right: 30px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--font-body);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
  color: var(--ink-200);
  white-space: nowrap;
  pointer-events: none;
  transition: color 0.25s var(--ease-out-soft, ease);
}
.page-dot.is-active .page-dot__label {
  color: var(--ink-900);
}
@media (max-width: 900px) {
  .page-dots { display: none; }
}

