/* BEARING SHOP — 시네마틱 홈 (home.html 전용)
 * 한 화면 = 한 페이지 스냅 스크롤. HERO(메인배너) / 기획전(서브배너) /
 * PRODUCT RANGE(상품) / CLOSING(브랜드+푸터). 데이터는 BEARSYS /api/public/*.
 * 클린 에디토리얼 — 큰 이미지가 주연. 모노톤 페이퍼/잉크 유지.
 * main.css 의 토큰(--font-serif, --ease-out, --dur-*) 위에서 동작. */

/* ============================ 디스플레이 헬퍼 ============================ */
.serif        { font-family: var(--font-serif); font-weight: 300; letter-spacing: -0.01em; }
.serif--italic{ font-style: italic; font-feature-settings: "ss01","kern"; }
.font--serif        { font-family: var(--font-serif); font-style: normal; font-weight: 400; letter-spacing: -0.01em; }
.font--serif-italic { font-family: var(--font-serif); font-style: italic;  font-weight: 400; letter-spacing: -0.01em; }
.font--sans         { font-family: var(--font-sans);  font-style: normal; font-weight: 400; letter-spacing: -0.05em; }
.font--sans-bold    { font-family: var(--font-sans);  font-style: normal; font-weight: 800; letter-spacing: -0.02em; }
.font--mono         { font-family: var(--font-mono);  font-weight: 500; letter-spacing: 0.02em; text-transform: uppercase; }
.size--h1 { font-size: clamp(40px, 6vw,   88px); line-height: 1.02; }
.size--h2 { font-size: clamp(32px, 4.6vw, 64px); line-height: 1.06; }
.size--h3 { font-size: clamp(24px, 3.2vw, 44px); line-height: 1.12; }
.size--h4 { font-size: clamp(19px, 2.2vw, 28px); line-height: 1.20; }

/* ============================ 페이지 스냅 시스템 ============================ */
/* body 자체는 스크롤 잠금 — .pages 가 유일한 스크롤 영역. */
body.home--snap { margin: 0; height: 100vh; height: 100svh; overflow: hidden; }

.home--snap .pages {
  height: 100vh; height: 100svh;
  overflow-y: scroll; overflow-x: hidden;
  scroll-snap-type: y mandatory;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;   /* iOS 관성 보존 */
  scrollbar-width: none;
}
.home--snap .pages::-webkit-scrollbar { display: none; }

.home--snap .page {
  position: relative;
  height: 100vh; height: 100svh;
  width: 100%;
  scroll-snap-align: start;
  scroll-snap-stop: always;            /* 한 제스처에 한 페이지 */
  overflow: hidden;
}

/* 페이지별 배경 — HERO 만 어둡고(잉크), 나머지는 페이퍼. */
.page--hero    { background: var(--ink);   color: var(--paper); }
.page--groups  { background: var(--paper); }
.page--range   { background: var(--paper); }
.page--closing { background: var(--paper); color: var(--ink); }

/* 우하단 페이지 메타 라벨 (01 / 04 · OPENING) */
.page__meta {
  position: absolute;
  right: clamp(20px, 3vw, 40px);
  bottom: clamp(20px, 3vw, 40px);
  z-index: 5;
  display: flex; flex-direction: column; align-items: flex-end; gap: 4px;
  color: var(--ink);
  pointer-events: none;
}
.page--hero .page__meta { color: var(--paper); text-shadow: 0 1px 2px rgba(0,0,0,0.28); }
/* 섹션2(기획전) = 어두운 컬렉션 이미지가 풀블리드로 깔리므로 인디케이터를 흰색으로
   (그룹 라벨/eyebrow 가 이미 흰색이라 톤 일관성 유지). */
.page--groups .page__meta { color: var(--paper); text-shadow: 0 1px 2px rgba(0,0,0,0.32); }
.page--groups .page__metaLabel { opacity: 0.82; }
.page__metaNum   { font: 700 11px/1 var(--font-mono); letter-spacing: 0.22em; }
.page__metaLabel { font: 400 10px/1 var(--font-mono); letter-spacing: 0.18em; opacity: 0.72; }

/* ============================ PAGE 1 — HERO 슬라이드쇼 ============================ */
.hero__slides { position: absolute; inset: 0; }
.hero__slide {
  position: absolute; inset: 0;
  opacity: 0; pointer-events: none;
  transition: opacity 0.8s var(--ease-out);
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  padding: clamp(84px, 11vh, 150px) clamp(28px, 5vw, 80px) clamp(56px, 8vh, 100px);
}
.hero__slide.is-on { opacity: 1; pointer-events: auto; }

.hero__slideBg   { position: absolute; inset: 0; margin: 0; z-index: 0; overflow: hidden; }
.hero__slideMedia{ width: 100%; height: 100%; object-fit: cover; object-position: 50% 50%; display: block; }
.hero__slideScrim{
  position: absolute; inset: 0; pointer-events: none;
  background: linear-gradient(180deg,
    rgba(10,10,10,0.28) 0%, rgba(10,10,10,0.06) 32%,
    rgba(10,10,10,0.16) 64%, rgba(10,10,10,0.56) 100%);
}
.hero__slide[data-tone="dark"] .hero__slideScrim {
  background: linear-gradient(180deg,
    rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.02) 40%, rgba(255,255,255,0.18) 100%);
}

/* 슬라이드 컨텐츠 — 3×3 그리드 셀에 배치 (data-pos) */
.hero__slideContent {
  position: relative; z-index: 1;
  display: flex; flex-direction: column;
  gap: clamp(8px, 1vw, 14px);
  max-width: min(900px, 92%);
}
.hero__eyebrow { letter-spacing: 0.18em; }
.hero__title {
  margin: 0; max-width: 20ch;
  /* 글씨체·크기는 슬라이드의 font-- / size-- 클래스가 결정 (어드민 상세 설정 반영) */
}
.hero__sub { margin: 0; font: 400 14px/1.55 var(--font-sans); opacity: 0.82; max-width: 38ch; }
.hero__cta {
  display: inline-flex; align-items: center; gap: 12px; width: max-content;
  margin-top: clamp(0px, 0.4vw, 4px);
  font: 700 11px/1 var(--font-sans); letter-spacing: 0.22em; text-transform: uppercase;
  text-decoration: none; cursor: pointer;
  transition: gap var(--dur-fast) var(--ease-out);
}
.hero__cta:hover { gap: 20px; }
.hero__ctaArrow { font-family: var(--font-mono); }

/* tone — light: 페이퍼 텍스트(어두운 사진 위) / dark: 잉크 텍스트(밝은 사진 위) */
.hero__slide[data-tone="light"] .hero__title,
.hero__slide[data-tone="light"] .hero__sub,
.hero__slide[data-tone="light"] .hero__eyebrow,
.hero__slide[data-tone="light"] .hero__cta { color: var(--paper); }
.hero__slide[data-tone="dark"] .hero__title,
.hero__slide[data-tone="dark"] .hero__sub,
.hero__slide[data-tone="dark"] .hero__eyebrow,
.hero__slide[data-tone="dark"] .hero__cta { color: var(--ink); }

/* CTA 스타일 */
.hero__slide[data-cta="underline"] .hero__cta { padding: 13px 0 11px; border: 0; border-bottom: 1px solid currentColor; }
.hero__slide[data-cta="outline"]   .hero__cta { padding: 13px 22px; border: 1px solid currentColor; }
.hero__slide[data-cta="solid"]     .hero__cta { padding: 13px 22px; border: 1px solid currentColor; background: currentColor; }
.hero__slide[data-cta="solid"][data-tone="light"] .hero__cta > * { color: var(--ink); }
.hero__slide[data-cta="solid"][data-tone="dark"]  .hero__cta > * { color: var(--paper); }
.hero__slide[data-cta="none"]      .hero__cta { display: none; }

/* data-pos — 9 앵커 */
.hero__slide[data-pos="tl"] .hero__slideContent { grid-row:1; grid-column:1 / span 2; justify-self:start;  align-self:start;  text-align:left;   align-items:flex-start; }
.hero__slide[data-pos="tc"] .hero__slideContent { grid-row:1; grid-column:1 / span 3; justify-self:center; align-self:start;  text-align:center; align-items:center; }
.hero__slide[data-pos="tr"] .hero__slideContent { grid-row:1; grid-column:2 / span 2; justify-self:end;    align-self:start;  text-align:right;  align-items:flex-end; }
.hero__slide[data-pos="ml"] .hero__slideContent { grid-row:2; grid-column:1 / span 2; justify-self:start;  align-self:center; text-align:left;   align-items:flex-start; }
.hero__slide[data-pos="mc"] .hero__slideContent { grid-row:2; grid-column:1 / span 3; justify-self:center; align-self:center; text-align:center; align-items:center; }
.hero__slide[data-pos="mr"] .hero__slideContent { grid-row:2; grid-column:2 / span 2; justify-self:end;    align-self:center; text-align:right;  align-items:flex-end; }
.hero__slide[data-pos="bl"] .hero__slideContent { grid-row:3; grid-column:1 / span 2; justify-self:start;  align-self:end;    text-align:left;   align-items:flex-start; }
.hero__slide[data-pos="bc"] .hero__slideContent { grid-row:3; grid-column:1 / span 3; justify-self:center; align-self:end;    text-align:center; align-items:center; }
.hero__slide[data-pos="br"] .hero__slideContent { grid-row:3; grid-column:2 / span 2; justify-self:end;    align-self:end;    text-align:right;  align-items:flex-end; }

/* 화살표 + 도트 */
.hero__nav {
  position: absolute; top: 50%; transform: translateY(-50%); z-index: 6;
  appearance: none; width: 48px; height: 48px;
  display: flex; align-items: center; justify-content: center;
  background: rgba(10,10,10,0.30); color: var(--paper);
  border: 0; border-radius: 50%; cursor: pointer;
  font: 400 26px/1 var(--font-sans);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  transition: background-color var(--dur-fast) var(--ease-out);
}
.hero__nav:hover { background: rgba(10,10,10,0.56); }
.hero__nav--prev { left: clamp(16px, 2vw, 28px); }
/* 우측 화살표는 우측 세로 페이지 도트(.pageDots)와 겹치지 않도록 안쪽으로. */
.hero__nav--next { right: clamp(54px, 5vw, 76px); }
.hero__nav.is-hidden { display: none; }
.hero__dots {
  position: absolute; left: 50%; bottom: clamp(18px, 3vh, 32px);
  transform: translateX(-50%); z-index: 6; display: flex; gap: 10px;
}
.hero__dots.is-hidden { display: none; }
.hero__dot {
  appearance: none; width: 28px; height: 2px; padding: 0; border: 0;
  background: rgba(255,255,255,0.55); cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out);
}
.hero__dot:hover { background: rgba(255,255,255,0.85); }
.hero__dot.is-on { background: var(--paper); }

/* ============================ PAGE 2 — 기획전 (서브배너 대형 블록) ============================ */
.groups {
  display: grid;
  grid-auto-flow: column; grid-auto-columns: 1fr;
  height: 100%;
}
.group {
  position: relative; display: block; overflow: hidden;
  color: var(--paper); text-decoration: none;
  border-left: 1px solid rgba(255,255,255,0.08);
}
.group:first-child { border-left: 0; }
.group__media { position: absolute; inset: 0; margin: 0; }
.group__media img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; object-position: 50% 50%; display: block;
  transition: transform 0.8s var(--ease-out);
}
.group:hover .group__media img { transform: scale(1.04); }
.group__media .ph { position: absolute; inset: 0; }
.group::after {
  content: ""; position: absolute; inset: auto 0 0 0; height: 58%;
  background: linear-gradient(180deg, transparent 0%, rgba(10,10,10,0.52) 100%);
  pointer-events: none;
}
.group__overlay {
  position: absolute; z-index: 2;
  left: clamp(24px, 3vw, 56px); right: clamp(24px, 3vw, 56px);
  bottom: clamp(36px, 5vw, 72px);
  display: flex; flex-direction: column; gap: clamp(8px, 1vw, 16px);
}
.group__eyebrow { color: var(--paper); opacity: 0.85; letter-spacing: 0.22em; }
.group__label   { margin: 0; font-size: clamp(20px, 2.8vw, 40px); line-height: 1.1; letter-spacing: -0.05em; color: var(--paper); font-style: normal; }
.group__cta {
  display: inline-flex; align-items: center; gap: 10px; width: max-content;
  margin-top: clamp(2px, 0.6vw, 8px);
  font: 700 11px/1 var(--font-sans); letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--paper);
  transition: gap var(--dur-fast) var(--ease-out);
}
.group:hover .group__cta { gap: 18px; }
/* dark tone (밝은 사진 위 잉크 텍스트) */
.group[data-tone="dark"] { color: var(--ink); }
.group[data-tone="dark"]::after { background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,0.42) 100%); }
.group[data-tone="dark"] .group__eyebrow,
.group[data-tone="dark"] .group__label,
.group[data-tone="dark"] .group__cta { color: var(--ink); }

/* 홈 빅이미지 placeholder — 어두운 시네마틱 빈 슬롯 (사진 입수 전, 텍스트 가독) */
.page--hero .hero__slideMedia.ph,
.group__media .ph {
  background: linear-gradient(135deg, #242424 0%, #0e0e0e 100%);
  color: rgba(255,255,255,0.4);
}
.page--hero .hero__slideMedia.ph::before,
.group__media .ph::before {
  background: radial-gradient(circle at 50% 42%, transparent 58%, rgba(0,0,0,0.35) 100%);
}
.page--hero .hero__slideMedia.ph::after,
.group__media .ph::after {
  color: rgba(255,255,255,0.5);
  border-color: rgba(255,255,255,0.22);
  background: transparent;
}

/* ============================ PAGE 3 — PRODUCT RANGE (가로 스트립) ============================ */
.page--range .page__inner {
  height: 100%;
  display: flex; flex-direction: column; justify-content: center;
  gap: clamp(20px, 3.5vh, 40px);
  padding: clamp(96px, 12vh, 140px) 0 clamp(56px, 8vh, 100px);
}
.range__head {
  display: flex; align-items: flex-end; justify-content: space-between; gap: 16px;
  padding: 0 var(--gutter); max-width: var(--grid-max); margin: 0 auto; width: 100%;
}
.range__title { margin: 0; font-family: var(--font-serif); font-weight: 400; font-size: clamp(28px, 3.8vw, 52px); line-height: 1.05; letter-spacing: -0.01em; }
.range__more { font: 700 11px/1 var(--font-sans); letter-spacing: 0.2em; text-transform: uppercase; color: var(--gray-600); border-bottom: 1px solid transparent; transition: border-color var(--dur-fast) var(--ease-out); }
.range__more:hover { border-bottom-color: var(--ink); }
.range__rail {
  /* 첫 카드 좌측을 그리드폭(--grid-max)으로 가운데 정렬된 .range__head 제목과
     맞춘다. 우측은 gutter 까지 흘려보내 스크롤 블리드 유지.
     scroll-padding-left 를 같이 줘야 scroll-snap 이 첫 카드를 컨테이너 끝까지
     끌어당겨 좌측 패딩을 무시하는 현상을 막는다. */
  --rail-inset: max(var(--gutter), calc((100vw - var(--grid-max)) / 2 + var(--gutter)));
  display: flex; gap: clamp(14px, 1.8vw, 28px);
  overflow-x: auto; overflow-y: hidden;
  scroll-snap-type: x proximity;
  padding: 4px var(--gutter);
  padding-left: var(--rail-inset);
  scroll-padding-left: var(--rail-inset);
  scrollbar-width: none;
}
.range__rail::-webkit-scrollbar { display: none; }
.range__card { flex: 0 0 auto; width: clamp(210px, 24vw, 300px); scroll-snap-align: start; text-decoration: none; color: inherit; }
.range__media { position: relative; aspect-ratio: 4 / 5; background: var(--gray-50); overflow: hidden; }
.range__media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.6s var(--ease-out); }
.range__card:hover .range__media img { transform: scale(1.04); }
.range__media--empty { display: flex; align-items: center; justify-content: center; color: var(--gray-300); font-size: 28px; }
.range__flag { position: absolute; top: 10px; left: 10px; font: 700 9.5px/1 var(--font-mono); letter-spacing: 0.16em; text-transform: uppercase; padding: 5px 8px; background: var(--ink); color: var(--paper); }
.range__flag--sale { background: #A83131; }
.range__info { padding-top: 12px; display: flex; flex-direction: column; gap: 4px; }
.range__cat   { font: 400 10px/1 var(--font-mono); letter-spacing: 0.1em; text-transform: uppercase; color: var(--gray-500); }
.range__name  { font: 500 14px/1.35 var(--font-sans); color: var(--ink); }
.range__price { font: 500 13px/1 var(--font-sans); color: var(--ink); margin-top: 2px; }
.range__price--orig { color: var(--gray-400); text-decoration: line-through; margin-right: 6px; }
.range__price--now  { color: #A83131; }

/* ============================ PAGE 4 — CLOSING (푸터) ============================ */
.page__inner--closing {
  height: 100%;
  display: flex; flex-direction: column; justify-content: center;
  gap: clamp(24px, 4vh, 44px);
  padding: clamp(88px, 11vh, 132px) var(--gutter) clamp(40px, 6vh, 72px);
  max-width: var(--grid-max); margin: 0 auto;
}

/* 상단 밴드 — 팔로우(소셜) + 지역/언어 */
.closing__connect {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: clamp(20px, 4vw, 56px); flex-wrap: wrap;
}
.closing__follow { display: flex; flex-direction: column; gap: clamp(12px, 1.6vh, 18px); }
.closing__follow .meta-label { color: var(--gray-500); letter-spacing: 0.22em; }
.closing__social { display: flex; flex-wrap: wrap; gap: clamp(16px, 2vw, 28px); }
.closing__social-link {
  display: inline-flex; align-items: center; gap: 9px;
  color: var(--ink); text-decoration: none;
  font: 500 14px/1 var(--font-sans); letter-spacing: -0.01em;
  border-bottom: 1px solid transparent; padding-bottom: 2px;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.closing__social-link svg { flex: none; }
.closing__social-link:hover { border-bottom-color: var(--ink); }

.closing__region { display: flex; align-items: center; gap: 9px; font: 400 12px/1 var(--font-sans); color: var(--gray-600); }
.closing__region-globe { display: inline-flex; opacity: 0.7; }
.closing__region-current { color: var(--ink); font-weight: 600; letter-spacing: 0.02em; }
.closing__region-sep { color: var(--gray-300); }
.closing__region-link {
  color: var(--gray-500); text-decoration: none;
  border-bottom: 1px solid transparent; padding-bottom: 1px;
  transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out);
}
.closing__region-link:hover { color: var(--ink); border-bottom-color: var(--ink); }

.closing__grid {
  display: grid; grid-template-columns: 1fr 1fr 1fr 1.4fr;
  gap: clamp(24px, 3vw, 56px);
  border-top: var(--rule); padding-top: clamp(28px, 4vw, 48px);
}
.closing__col h4 { margin: 0 0 12px; color: var(--gray-500); letter-spacing: 0.22em; }
.closing__links { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.closing__links a {
  color: var(--ink); text-decoration: none; font: 400 13px/1.4 var(--font-sans);
  border-bottom: 1px solid transparent; padding-bottom: 1px; width: max-content;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.closing__links a:hover { border-bottom-color: var(--ink); }
.closing__legal { margin: 0; display: grid; grid-template-columns: max-content 1fr; column-gap: 14px; row-gap: 6px; font: 400 12px/1.5 var(--font-sans); color: var(--gray-700); }
.closing__legal dt { color: var(--gray-500); font-weight: 600; white-space: nowrap; }
.closing__legal dd { margin: 0; color: var(--ink); }
.closing__base { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-top: clamp(16px, 2vw, 24px); border-top: var(--rule-soft); flex-wrap: wrap; }
.closing__mark { height: 22px; width: auto; }
.closing__copy { font: 700 10px/1 var(--font-mono); letter-spacing: 0.18em; color: var(--gray-500); }
.closing__policy { display: flex; flex-wrap: wrap; gap: 4px 16px; }
.closing__policy a { color: var(--gray-600); font: 500 11px/1.5 var(--font-sans); letter-spacing: 0.02em; border-bottom: 1px solid transparent; }
.closing__policy a:hover { color: var(--ink); border-bottom-color: var(--ink); }

/* ============================ 페이지 도트 인디케이터 ============================ */
.pageDots {
  position: fixed; right: clamp(16px, 2vw, 24px); top: 50%; transform: translateY(-50%);
  z-index: 60; display: flex; flex-direction: column; gap: 14px; background: transparent; border: 0;
}
.pageDots__dot {
  appearance: none; width: 8px; height: 8px; padding: 0; border: 0; border-radius: 50%;
  background: var(--paper); opacity: 0.5; cursor: pointer;
  transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out);
  text-indent: -9999px; overflow: hidden;
  box-shadow: 0 0 0 1px rgba(10,10,10,0.18);
}
.pageDots__dot:hover { opacity: 0.85; }
.pageDots__dot.is-on { opacity: 1; transform: scale(1.35); }
/* 페이지 2+ (밝은 배경) → 잉크 도트 */
body.home--snap.is-solid .pageDots__dot { background: var(--ink); box-shadow: 0 0 0 1px rgba(255,255,255,0.6); }

/* ============================ NAV 투명 → 솔리드 (홈 전용) ============================ */
body.home--snap .nav {
  position: fixed; top: 0; left: 0; right: 0;
  background: transparent; backdrop-filter: none; -webkit-backdrop-filter: none;
  border-bottom: 0; color: var(--paper);
  transition: background-color 0.3s var(--ease-out), color 0.3s var(--ease-out), border-color 0.3s var(--ease-out);
}
body.home--snap .nav .nav__meta    { color: rgba(255,255,255,0.72); }
body.home--snap .nav .nav__links a  { color: var(--paper); }
body.home--snap .nav .nav__links a::after { background: var(--paper); }
body.home--snap .nav .nav__icon     { color: var(--paper); }
body.home--snap .nav .nav__toggle   { color: var(--paper); }
body.home--snap .nav .logo--nav     { filter: invert(1) brightness(1.5); transition: filter 0.3s var(--ease-out); }

body.home--snap .nav.nav--solid {
  background: rgba(243,243,243,0.92);
  backdrop-filter: saturate(140%) blur(10px); -webkit-backdrop-filter: saturate(140%) blur(10px);
  border-bottom: var(--rule); color: var(--ink);
}
body.home--snap .nav.nav--solid .nav__meta   { color: var(--gray-500); }
body.home--snap .nav.nav--solid .nav__links a { color: var(--ink); }
body.home--snap .nav.nav--solid .nav__icon    { color: var(--ink); }
body.home--snap .nav.nav--solid .nav__toggle  { color: var(--ink); }
body.home--snap .nav.nav--solid .logo--nav    { filter: none; }

/* ============================ 반응형 ============================ */
@media (max-width: 860px) {
  .groups { grid-auto-flow: row; grid-auto-columns: auto; grid-auto-rows: 1fr; }
  .group { border-left: 0; border-top: 1px solid rgba(255,255,255,0.08); }
  .group:first-child { border-top: 0; }
  .closing__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 720px) {
  .pageDots { display: none; }
  .hero__nav { width: 36px; height: 36px; font-size: 20px; }
  /* 도트가 숨겨지므로 우측 화살표를 좌우 대칭 위치로 복귀 */
  .hero__nav--next { right: clamp(16px, 2vw, 28px); }

  /* 모바일도 페이지별 스냅 유지(mandatory·100vh 는 기본값). 푸터(closing)는
     컴팩트하게 배치해 한 화면(100vh) 안에 전부 들어가게 한다 —
     링크 3열 + 법적정보 전체폭, 상단패딩·간격·폰트 축소. */
  .page__inner--closing {
    padding: clamp(60px, 8.5vh, 80px) var(--gutter) clamp(16px, 3vh, 28px);
    gap: clamp(12px, 2vh, 18px);
  }
  .closing__connect { gap: 10px 24px; }
  .closing__grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 12px 14px; padding-top: clamp(12px, 2vh, 20px);
  }
  .closing__col--legal { grid-column: 1 / -1; }
  .closing__col h4 { margin: 0 0 8px; }
  .closing__links { gap: 6px; }
  .closing__links a { font-size: 12px; }
  .closing__legal { column-gap: 10px; row-gap: 4px; font-size: 11px; }
  .closing__base { padding-top: 12px; }
  .page--closing .page__meta { display: none; }
}
@media (max-width: 560px) {
  .closing__base { flex-direction: column; align-items: flex-start; gap: 10px; }
}

/* ============================ 접근성 — 모션 최소화 ============================ */
@media (prefers-reduced-motion: reduce) {
  .home--snap .pages { scroll-behavior: auto; }
  .hero__slide { transition: none; }
  .group__media img, .range__media img { transition: none; }
}
