/* 스크롤 내러티브 — BUSINESS(bn) + BRAND(br) */
.bn-wrap {
  background: var(--dark);
}
/* JS 높이 설정 전·실패 시에도 스크롤 구간 확보 (tn-wrap과 동일 패턴) */
.page-narrative-test .bn-wrap {
  min-height: calc(6 * 120vh);
}
@media (max-width: 768px) {
  .page-narrative-test .bn-wrap {
    min-height: calc(7 * 120vh);
  }
}
.bn-sticky {
  background: var(--dark);
}
.bn-phase {
  padding: 0 80px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 60px;
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
}
.bn-left {
  position: relative;
  z-index: 2;
}
.bn-right {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  height: 60vh;
}
.bn-visual {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* 사업 슬라이드 배경: 전체 화면(여백·효과 없음) */
.bn-phase--brokerage,
.bn-phase--shopping-mall,
.bn-phase--startup-platform,
.bn-phase--outsourcing,
.bn-phase--partnership {
  isolation: isolate;
}
/* 운영 브랜드 — BUSINESS 6번째 스크롤 단계(서비스 제휴 다음) */
.bn-phase--brands {
  display: block !important;
  grid-template-columns: unset !important;
  gap: 0 !important;
  padding: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  align-items: stretch !important;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.page-narrative-test .bn-wrap .sn-section-lbl--br {
  display: none;
}
.page-narrative-test .bn-sticky:has(.bn-phase--brands.on) .sn-section-lbl--bn,
.page-narrative-test .bn-sticky:has(.bn-phase--brand-mo.on) .sn-section-lbl--bn {
  display: none;
}
.page-narrative-test .bn-sticky:has(.bn-phase--brands.on) .sn-section-lbl--br,
.page-narrative-test .bn-sticky:has(.bn-phase--brand-mo.on) .sn-section-lbl--br {
  display: flex;
}
.page-narrative-test .bn-phase--brands .br-trio__head {
  display: none;
}
.page-narrative-test .bn-phase--brands {
  display: flex !important;
  flex-direction: column;
  height: 100%;
  min-height: 100%;
}
.page-narrative-test .bn-phase--brands .br-trio {
  width: 100%;
  flex: 1 1 auto;
  height: 100%;
  min-height: 100%;
  max-height: none;
}
.page-narrative-test .bn-phase--brands .br-trio__shell {
  flex: 1 1 auto;
  min-height: 0;
  padding-bottom: 0;
}
.page-narrative-test .bn-phase--brands .br-trio__grid {
  flex: 1 1 0;
  min-height: 0;
  align-self: stretch;
}
.page-narrative-test .bn-phase--brands .br-trio__duo {
  flex: 0 0 clamp(80px, 11.5vh, 112px);
  display: flex;
  flex-direction: row;
  align-items: stretch;
  width: 100%;
  min-height: 0;
  padding: clamp(10px, 1.4vh, 16px) clamp(20px, 2.4vw, 36px);
  box-sizing: border-box;
  border-top: 1px solid rgba(13, 18, 40, 0.08);
  background: #fff;
}
.page-narrative-test .br-trio__duo-cell {
  position: relative;
  flex: 1 1 0;
  display: flex;
  align-items: center;
  min-width: 0;
  padding: clamp(12px, 1.6vh, 18px) clamp(20px, 2.4vw, 32px);
  box-sizing: border-box;
  overflow: hidden;
  isolation: isolate;
  background: #fff;
}
.page-narrative-test .br-trio__duo-cell--delivery {
  flex: 8 1 0;
}
.page-narrative-test .br-trio__duo-cell--startup {
  flex: 2 1 0;
  border-left: 1px solid rgba(13, 18, 40, 0.08);
}
.page-narrative-test .br-trio__duo-cell::before,
.page-narrative-test .br-trio__duo-cell::after {
  display: none;
}
.page-narrative-test .br-trio__duo-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: clamp(16px, 2.2vw, 32px);
  flex-wrap: wrap;
  padding: clamp(2px, 0.5vh, 6px) 0;
  box-sizing: border-box;
}
.page-narrative-test .br-trio__duo-label {
  margin: 0;
  flex: 0 0 auto;
  white-space: nowrap;
  font-size: clamp(11px, 1vw, 12px);
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(13, 18, 40, 0.45);
  line-height: 1.3;
}
.page-narrative-test .br-trio__duo-logos {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  flex: 1 1 auto;
  min-width: 0;
  gap: clamp(10px, 1.4vh, 16px) clamp(12px, 2vw, 24px);
  margin: 0;
  padding: 0;
  list-style: none;
}
.page-narrative-test .br-trio__duo-logos a {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: clamp(34px, 4.8vh, 48px);
  opacity: 0.9;
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.page-narrative-test .br-trio__duo-logos a:hover {
  opacity: 1;
  transform: translateY(-1px);
}
.page-narrative-test .br-trio__duo-logos img {
  display: block;
  max-height: 100%;
  max-width: min(144px, 22vw);
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
}
.page-narrative-test .br-trio__duo-logo {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex: 1 1 auto;
  min-width: 0;
  height: clamp(30px, 4.2vh, 42px);
  opacity: 0.9;
  transition: opacity 0.25s ease, transform 0.25s ease;
}
.page-narrative-test .br-trio__duo-logo:hover {
  opacity: 1;
  transform: translateY(-1px);
}
.page-narrative-test .br-trio__duo-logo img {
  display: block;
  max-height: 100%;
  max-width: min(200px, 36vw);
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
}
.page-narrative-test .bn-phase--brands .br-trio__grid > * {
  align-items: stretch;
  padding-top: clamp(16px, 2.2vh, 24px);
  padding-right: clamp(16px, 1.6vw, 24px);
  padding-left: clamp(24px, 3vw, 40px);
  padding-bottom: clamp(32px, 4vh, 48px);
}
.page-narrative-test .bn-phase--brands .br-trio__grid .br-trio__inner {
  min-height: 100%;
  justify-content: flex-end;
  padding-left: clamp(4px, 0.5vw, 8px);
  padding-bottom: clamp(6px, 0.9vh, 12px);
  box-sizing: border-box;
}
/* OUR BRANDS — 바깥·하단(duo)만 흰색 / 상단 3브랜드 카드는 파란 그라데이션 유지 */
.page-narrative-test .bn-sticky:has(.bn-phase--brands.on) {
  background: #fff;
}
.page-narrative-test .bn-phase--brands {
  background: #fff;
}
.page-narrative-test .bn-phase--brands .br-trio {
  background: #fff;
}
.page-narrative-test .bn-phase--brands .br-trio__grid > * {
  background: transparent;
}
.page-narrative-test .bn-phase--brands .br-trio__grid > *::after {
  display: block;
}
.bn-phase--brokerage .bn-phase-bg,
.bn-phase--shopping-mall .bn-phase-bg,
.bn-phase--startup-platform .bn-phase-bg,
.bn-phase--outsourcing .bn-phase-bg,
.bn-phase--partnership .bn-phase-bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  max-width: none;
  margin-left: -50vw;
  z-index: 0;
  pointer-events: none;
}
.bn-phase--brokerage .bn-phase-bg__inner,
.bn-phase--shopping-mall .bn-phase-bg__inner,
.bn-phase--startup-platform .bn-phase-bg__inner,
.bn-phase--outsourcing .bn-phase-bg__inner,
.bn-phase--partnership .bn-phase-bg__inner {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background-repeat: no-repeat;
  image-rendering: auto;
}
.bn-phase--brokerage .bn-phase-bg__inner,
.bn-phase--shopping-mall .bn-phase-bg__inner,
.bn-phase--startup-platform .bn-phase-bg__inner,
.bn-phase--outsourcing .bn-phase-bg__inner,
.bn-phase--partnership .bn-phase-bg__inner {
  background-size: cover;
}
.bn-phase-bg__inner--brokerage {
  background-image: url("../images/home-brokerage-greenhouse-2560-v2.webp");
  background-position: center center;
}
.bn-phase-bg__inner--shopping {
  background-image: url("../images/home-shopping-mall-2560.webp");
  background-position: 72% center;
}
.bn-phase-bg__inner--startup {
  background-image: url("../images/home-startup-platform.webp");
  background-position: 88% center;
}
.bn-phase-bg__inner--outsourcing {
  background-image: url("../images/home-outsourcing-2560.webp");
  background-position: 58% center;
}
.bn-phase-bg__inner--partnership {
  background-image: url("../images/home-partnership-2560.webp");
  background-position: center center;
}
/* 배경 슬라이드: transform 대신 opacity만 — 확대 시 이미지 거칠어짐 방지 */
.page-narrative-test .bn-wrap .bn-phase--brokerage,
.page-narrative-test .bn-wrap .bn-phase--shopping-mall,
.page-narrative-test .bn-wrap .bn-phase--startup-platform,
.page-narrative-test .bn-wrap .bn-phase--outsourcing,
.page-narrative-test .bn-wrap .bn-phase--partnership {
  transition: opacity 0.36s cubic-bezier(0.22, 1, 0.36, 1);
}
.page-narrative-test .bn-wrap .bn-phase--brokerage:not(.on),
.page-narrative-test .bn-wrap .bn-phase--shopping-mall:not(.on),
.page-narrative-test .bn-wrap .bn-phase--startup-platform:not(.on),
.page-narrative-test .bn-wrap .bn-phase--outsourcing:not(.on),
.page-narrative-test .bn-wrap .bn-phase--partnership:not(.on),
.page-narrative-test .bn-wrap .bn-phase--brokerage.out,
.page-narrative-test .bn-wrap .bn-phase--shopping-mall.out,
.page-narrative-test .bn-wrap .bn-phase--startup-platform.out,
.page-narrative-test .bn-wrap .bn-phase--outsourcing.out,
.page-narrative-test .bn-wrap .bn-phase--partnership.out {
  transform: none;
}
.page-narrative-test .bn-wrap .bn-phase--brokerage.on,
.page-narrative-test .bn-wrap .bn-phase--shopping-mall.on,
.page-narrative-test .bn-wrap .bn-phase--startup-platform.on,
.page-narrative-test .bn-wrap .bn-phase--outsourcing.on,
.page-narrative-test .bn-wrap .bn-phase--partnership.on {
  transform: none;
}
.bn-phase--brokerage .bn-phase-bg__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(2, 8, 22, 0.88) 0%,
    rgba(2, 12, 30, 0.68) 36%,
    rgba(2, 12, 30, 0.22) 62%,
    rgba(2, 12, 30, 0.38) 100%
  );
}
.bn-phase--shopping-mall .bn-phase-bg__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(8, 18, 38, 0.9) 0%,
    rgba(8, 18, 38, 0.72) 34%,
    rgba(8, 18, 38, 0.28) 58%,
    rgba(8, 18, 38, 0.12) 100%
  );
}
.bn-phase--startup-platform .bn-phase-bg__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(8, 18, 38, 0.88) 0%,
    rgba(8, 18, 38, 0.62) 38%,
    rgba(8, 18, 38, 0.18) 62%,
    rgba(255, 255, 255, 0.08) 100%
  );
}
.bn-phase--outsourcing .bn-phase-bg__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(6, 14, 32, 0.9) 0%,
    rgba(6, 14, 32, 0.7) 38%,
    rgba(6, 14, 32, 0.25) 62%,
    rgba(6, 14, 32, 0.1) 100%
  );
}
.bn-phase--partnership .bn-phase-bg__scrim {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    90deg,
    rgba(4, 10, 26, 0.9) 0%,
    rgba(4, 12, 30, 0.72) 36%,
    rgba(4, 12, 30, 0.28) 58%,
    rgba(4, 12, 30, 0.12) 100%
  );
}
.bn-phase--brokerage .bn-left,
.bn-phase--brokerage .bn-right,
.bn-phase--shopping-mall .bn-left,
.bn-phase--shopping-mall .bn-right,
.bn-phase--startup-platform .bn-left,
.bn-phase--startup-platform .bn-right,
.bn-phase--outsourcing .bn-left,
.bn-phase--outsourcing .bn-right,
.bn-phase--partnership .bn-left,
.bn-phase--partnership .bn-right {
  position: relative;
  z-index: 2;
}
.bn-phase--shopping-mall .bn-shopping-logos {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 18px;
  width: min(100%, 400px);
}
.bn-phase--shopping-mall .bn-shopping-logos li {
  display: flex;
  justify-content: center;
}
.bn-phase--shopping-mall .bn-shopping-logos li:first-child {
  grid-column: 1 / -1;
}
.bn-phase--shopping-mall .bn-shopping-logos a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 64px;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition:
    background 0.25s ease,
    border-color 0.25s ease,
    transform 0.25s ease;
}
.bn-phase--shopping-mall .bn-shopping-logos a:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(255, 255, 255, 0.22);
  transform: translateY(-2px);
}
.bn-phase--shopping-mall .bn-shopping-logos a:focus-visible {
  outline: 2px solid rgba(33, 129, 255, 0.85);
  outline-offset: 2px;
}
.bn-phase--shopping-mall .bn-shopping-logos img {
  max-width: 100%;
  width: auto;
  height: auto;
  max-height: 40px;
  object-fit: contain;
}
.bn-phase--shopping-mall .bn-shopping-logos li:first-child img {
  max-height: 48px;
}
.bn-vis-num {
  font-size: clamp(160px, 18vw, 280px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: -12px;
  color: transparent;
  -webkit-text-stroke: 1px rgba(0, 128, 255, 0.18);
  user-select: none;
  pointer-events: none;
  animation: narrVisFloat 8s ease-in-out infinite;
}
@keyframes narrVisFloat {
  0%,
  100% {
    transform: translateY(0) scale(1);
  }
  50% {
    transform: translateY(-16px) scale(1.02);
  }
}
.bn-vis-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  animation: narrOrbFloat 10s ease-in-out infinite;
}
@keyframes narrOrbFloat {
  0%,
  100% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(20px, -20px);
  }
}
.bn-num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.25);
  margin-bottom: 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.bn-num::before {
  content: "";
  width: 20px;
  height: 1px;
  background: rgba(255, 255, 255, 0.2);
}
.bn-badge {
  display: inline-flex;
  align-items: center;
  font-size: 9.5px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 4px;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.bn-badge.b2b {
  background: rgba(0, 128, 255, 0.12);
  color: #7ab8ff;
  border: 1px solid rgba(0, 128, 255, 0.28);
}
.bn-badge.b2c {
  background: rgba(0, 255, 180, 0.07);
  color: #5fffce;
  border: 1px solid rgba(0, 255, 180, 0.18);
}
.bn-title {
  font-size: clamp(28px, 3.2vw, 52px);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -1.5px;
  margin-bottom: 24px;
  word-break: keep-all;
}
.bn-title--brand {
  margin: 0 0 24px;
  padding: 0;
  line-height: 0;
  letter-spacing: 0;
}
/* OUR BRANDS: 동일 가로·세로 슬롯 안에 object-fit → 전국플라워센터·꽃파는총각 가로 시각 정렬 */
.br-wrap .bn-title.bn-title--brand {
  box-sizing: border-box;
  width: min(100%, 360px);
  height: clamp(42px, 6.8vw, 80px);
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.br-wrap .bn-title.bn-title--brand .bn-title__logo {
  display: block;
  margin: 0;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
}
.br-wrap .bn-title.bn-title--brand.bn-title--brand-flachain {
  width: 100%;
  max-width: 80%;
  height: clamp(52px, 9.2vw, 100px);
}
.bn-desc {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.4);
  line-height: 1.85;
  margin-bottom: 40px;
  max-width: 440px;
  word-break: keep-all;
}
.bn-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 30px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.55);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.3px;
  border-radius: 7px;
  transition: all 0.3s;
  backdrop-filter: blur(4px);
}
.bn-link:hover {
  border-color: var(--blue);
  color: #fff;
  background: rgba(0, 128, 255, 0.1);
  gap: 14px;
}

.br-wrap {
  background: var(--darker);
}
.br-sticky {
  background: var(--darker);
}
.br-phase {
  padding: 0 80px;
  width: 100%;
  max-width: 1920px;
  margin: 0 auto;
  flex-direction: column;
  justify-content: center;
}
.br-phase.flip {
  align-items: flex-end;
}
.br-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  transition: opacity 0.4s cubic-bezier(0.22, 1, 0.36, 1);
  z-index: 0;
}
.br-bg.on {
  opacity: 1;
}
.br-ov {
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(105deg, rgba(6, 15, 40, 0.97) 0%, rgba(6, 15, 40, 0.85) 35%, rgba(6, 15, 40, 0.5) 60%, rgba(6, 15, 40, 0.15) 100%);
}
.br-ov.r {
  background: linear-gradient(255deg, rgba(6, 15, 40, 0.97) 0%, rgba(6, 15, 40, 0.85) 35%, rgba(6, 15, 40, 0.5) 60%, rgba(6, 15, 40, 0.15) 100%);
}
.br-content {
  position: relative;
  z-index: 2;
  max-width: 600px;
}
.br-phase.flip .br-content {
  text-align: right;
}
.br-for {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 3px;
  color: var(--blue);
  text-transform: uppercase;
  margin-bottom: 24px;
  padding: 6px 14px;
  background: rgba(0, 128, 255, 0.1);
  border: 1px solid rgba(0, 128, 255, 0.22);
  border-radius: 4px;
}
.br-for::before {
  content: "";
  width: 6px;
  height: 6px;
  background: var(--blue);
  border-radius: 50%;
  box-shadow: 0 0 8px var(--blue);
  animation: narrDot 2s ease-in-out infinite;
}
@keyframes narrDot {
  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }
  50% {
    opacity: 0.4;
    transform: scale(0.85);
  }
}
.br-name {
  font-size: clamp(44px, 6vw, 96px);
  font-weight: 900;
  color: #fff;
  line-height: 1;
  letter-spacing: -3px;
  margin-bottom: 20px;
  word-break: keep-all;
}
.br-slogan {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.42);
  line-height: 1.8;
  margin-bottom: 36px;
  word-break: keep-all;
}
.br-stats {
  display: flex;
  gap: 44px;
  margin-bottom: 44px;
}
.br-phase.flip .br-stats {
  justify-content: flex-end;
}
.br-sv {
  font-size: clamp(22px, 2vw, 30px);
  font-weight: 900;
  color: #fff;
  line-height: 1;
  margin-bottom: 5px;
  letter-spacing: -0.5px;
}
.br-sv em {
  font-style: normal;
  color: var(--blue);
}
.br-sk {
  font-size: 10.5px;
  color: rgba(255, 255, 255, 0.28);
  letter-spacing: 1.5px;
  text-transform: uppercase;
}
.br-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 15px 32px;
  border: 1px solid rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.6);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.3px;
  border-radius: 7px;
  transition: all 0.3s;
}
.br-btn:hover {
  border-color: var(--blue);
  color: #fff;
  background: rgba(0, 128, 255, 0.12);
  gap: 14px;
}
/* 테스트: 첫 텍스트 내러티브(오프닝) 타이포·임팩트 */
@keyframes tnOpenHeroIn {
  from {
    opacity: 0;
    transform: translateY(22px) scale(0.96);
    filter: blur(8px);
  }
  to {
    opacity: 1;
    transform: none;
    filter: none;
  }
}
.page-narrative-test .tn-phase--open .tn-eyebrow {
  margin-bottom: clamp(32px, 4.5vw, 52px);
  color: rgba(255, 255, 255, 0.45);
}
.page-narrative-test .sn-phase.tn-phase--open.on .tn-eyebrow {
  animation: tnOpenHeroIn 0.52s cubic-bezier(0.22, 1, 0.36, 1) both;
}
.page-narrative-test .tn-big--open-hero {
  font-size: clamp(40px, 6.5vw, 102px);
  line-height: 1.16;
  letter-spacing: clamp(-2px, -0.06em, -5px);
  text-shadow: 0 6px 40px rgba(0, 0, 0, 0.55), 0 0 120px rgba(0, 128, 255, 0.16), 0 0 1px rgba(255, 255, 255, 0.12);
}
.page-narrative-test .sn-phase.tn-phase--open.on .tn-big--open-hero {
  animation: tnOpenHeroIn 0.62s cubic-bezier(0.22, 1, 0.36, 1) 0.04s both;
}
.page-narrative-test .tn-big .tn-word-fill {
  --flower-fill: 0;
  position: relative;
  display: inline-block;
  font-style: normal;
  vertical-align: baseline;
}
.page-narrative-test .tn-big--open-hero em.flower-scroll-em.tn-word-fill {
  margin-top: 0.06em;
  font-size: 1.08em;
}
.page-narrative-test .tn-big .tn-word-fill__muted {
  font-style: normal;
  color: rgba(255, 255, 255, 0.28);
}
.page-narrative-test .tn-big--open-hero .tn-word-fill__muted {
  color: rgba(255, 255, 255, 0.26);
  text-shadow: none;
}
.page-narrative-test .tn-big .tn-word-fill__grad {
  position: absolute;
  left: 0;
  top: 0;
  font-style: normal;
  font-weight: inherit;
  white-space: nowrap;
  background: linear-gradient(90deg, var(--blue) 0%, var(--cyan) 55%, #7ae8ff 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  pointer-events: none;
  text-shadow: none;
  clip-path: inset(0 calc((1 - var(--flower-fill)) * (100% + 2px)) 0 0);
  transition: clip-path 0.08s linear;
  will-change: clip-path;
}
.page-narrative-test .tn-big--open-hero .tn-word-fill__grad {
  text-shadow: none;
}

/* 테스트 메인(index-test-scroll-1): 브랜드 구간을 사업영역(bn)과 동일 그리드·타이포 */
.page-narrative-test .br-wrap,
.page-narrative-test .br-sticky {
  background: var(--dark);
}
.page-narrative-test .br-phase.bn-phase {
  flex-direction: unset;
  justify-content: unset;
}
.page-narrative-test .br-stats--bn {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 36px;
  margin-bottom: 40px;
  max-width: 440px;
}
.page-narrative-test .br-stats--bn .br-sv {
  font-size: clamp(18px, 2vw, 26px);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  margin-bottom: 6px;
  letter-spacing: -0.5px;
}
.page-narrative-test .br-stats--bn .br-sv em {
  font-style: normal;
  color: var(--blue);
}
/* 꽃파는총각 — 실적: 1(파랑) + 위(흰) / 오픈마켓 5년 연속 회색 */
.page-narrative-test .br-openmarket-rank {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: clamp(6px, 1vw, 10px);
}
.page-narrative-test .br-openmarket-rank__line {
  line-height: 1.12;
  word-break: keep-all;
}
.page-narrative-test .br-openmarket-rank__line--rank {
  display: inline-flex;
  flex-direction: row;
  align-items: baseline;
  font-size: clamp(34px, 3.8vw, 52px);
  font-weight: 900;
  letter-spacing: -0.04em;
}
.page-narrative-test .br-openmarket-rank__digit {
  font-style: normal;
  color: var(--blue);
  text-shadow: 0 0 28px rgba(0, 128, 255, 0.35);
}
.page-narrative-test .br-openmarket-rank__suffix {
  font-style: normal;
  color: #fff;
  text-shadow: 0 2px 24px rgba(0, 0, 0, 0.35);
}
.page-narrative-test .br-openmarket-rank__line--gray {
  font-size: clamp(13px, 1.25vw, 15px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.36);
  letter-spacing: -0.01em;
  margin-top: 2px;
}
.page-narrative-test .br-stats--bn .br-sk {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  color: rgba(255, 255, 255, 0.25);
  text-transform: none;
}

@media (max-width: 1024px) {
  .page-narrative-test .br-phase.bn-phase {
    padding: 0 40px;
  }
}
@media (max-width: 768px) {
  .page-narrative-test .br-phase.bn-phase {
    padding: 0 24px;
  }
}
@media (max-width: 480px) {
  .page-narrative-test .br-stats--bn {
    flex-direction: column;
    gap: 16px;
  }
  .page-narrative-test .tn-big--open-hero {
    font-size: clamp(30px, 9vw, 44px);
    letter-spacing: -0.04em;
  }
}

@media (max-width: 1280px) {
  .bn-phase:not(.bn-phase--brands),
  .br-phase {
    padding: 0 40px;
  }
}
@media (max-width: 1024px) {
  .bn-phase:not(.bn-phase--brands) {
    grid-template-columns: 1fr;
  }
  .bn-right {
    display: none;
  }
  .br-phase {
    padding: 80px 40px 60px;
  }
}
@media (max-width: 768px) {
  .bn-phase:not(.bn-phase--brands),
  .br-phase {
    padding: 0 24px;
  }
  .br-stats {
    gap: 24px;
  }
}
@media (max-width: 480px) {
  .bn-title {
    font-size: clamp(26px, 7vw, 38px);
  }
  .bn-badge {
    font-size: 11px;
    padding: 5px 11px;
  }
  .bn-num {
    font-size: 12px;
  }
  .bn-desc {
    font-size: 15px;
  }
  .bn-link {
    font-size: 15px;
    padding: 14px 22px;
  }
  .br-name {
    letter-spacing: -1.5px;
  }
  .br-stats {
    flex-direction: column;
    gap: 16px;
  }
  .br-btn {
    width: 100%;
    justify-content: center;
  }
}

/* 메인 사업영역(#bn)·브랜드(#brn): GNB .gnb-inner과 동일한 max-width·좌우 패딩으로 로고 기준선 정렬 */
.page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
.page-narrative-test .br-wrap .br-phase,
.page-narrative-test .bn-phase--brands .br-trio__shell,
.page-narrative-test .bn-phase--brands-v3 .v3-shell,
.page-narrative-test .bn-phase--brands-mobile .v3-shell,
.page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
  box-sizing: border-box;
  max-width: 1920px;
  margin-left: auto;
  margin-right: auto;
  padding-left: 80px;
  padding-right: 80px;
}
.page-narrative-test .bn-wrap .sn-header,
.page-narrative-test .br-wrap .sn-header {
  padding: 32px 80px 0;
}
@media (min-width: 1101px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    max-width: 1400px;
    padding-left: 56px;
    padding-right: 56px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 32px 56px 0;
  }
}
@media (max-width: 1440px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    max-width: 1280px;
    padding-left: 48px;
    padding-right: 48px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 32px 48px 0;
  }
}
@media (max-width: 1280px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    max-width: 1140px;
    padding-left: 40px;
    padding-right: 40px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 32px 40px 0;
  }
}
@media (max-width: 860px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    padding-left: 24px;
    padding-right: 24px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 28px 24px 0;
  }
}
@media (max-width: 480px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    padding-left: 18px;
    padding-right: 18px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 24px 18px 0;
  }
}
@media (max-width: 360px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    padding-left: 14px;
    padding-right: 14px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 20px 14px 0;
  }
}
@media (max-width: 320px) {
  .page-narrative-test .bn-wrap .bn-phase:not(.bn-phase--brands),
  .page-narrative-test .br-wrap .br-phase,
  .page-narrative-test .bn-phase--brands .br-trio__shell,
  .page-narrative-test .bn-phase--brands-v3 .v3-shell,
  .page-narrative-test .bn-phase--brands-mobile .v3-shell,
  .page-narrative-test .bn-phase--brands-family .v3-shell--family-only {
    padding-left: 12px;
    padding-right: 12px;
  }
  .page-narrative-test .bn-wrap .sn-header,
  .page-narrative-test .br-wrap .sn-header {
    padding: 18px 12px 0;
  }
}
@media (max-width: 1024px) {
  .page-narrative-test .br-wrap .br-phase {
    padding-top: 80px;
    padding-bottom: 60px;
  }
}

/* OUR BRANDS — #bn 스티키 영역 높이에 맞춤(100vh 고정 시 하단 여백 생김) */
.page-narrative-test .br-trio {
  min-height: 100%;
  height: 100%;
  max-height: none;
  background: #fff;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  box-sizing: border-box;
}
/* 모바일 브랜드 패널 — .br-trio 래퍼는 타이포 상속만 (레이아웃은 패널이 담당) */
.page-narrative-test .br-trio.br-trio--pass-through {
  display: contents;
  min-height: 0;
  height: auto;
  max-height: none;
  background: transparent;
  overflow: visible;
  position: static;
}
.page-narrative-test .bn-phase--brands .br-trio {
  min-height: 100%;
  height: 100%;
}
.page-narrative-test .br-trio__shell {
  flex: 1;
  display: flex;
  flex-direction: column;
  width: 100%;
  min-height: 0;
  padding-bottom: clamp(28px, 4vh, 48px);
}
.page-narrative-test .br-trio__head {
  position: relative;
  flex-shrink: 0;
  padding: 32px 0 12px;
  z-index: 30;
  pointer-events: none;
}
.page-narrative-test .br-trio__grid {
  flex: 1;
  display: flex;
  flex-direction: row;
  align-items: stretch;
  min-height: 0;
  width: 100%;
}
/* 호버 열 가로 2배 — flex-grow 전환이 fr 그리드보다 줄어들 때 자연스러움 */
.page-narrative-test .br-trio__grid > * {
  position: relative !important;
  inset: auto !important;
  flex: 1 1 0;
  opacity: 1 !important;
  pointer-events: auto !important;
  display: flex !important;
  align-items: flex-end;
  min-height: 0;
  min-width: 0;
  margin: 0;
  padding: clamp(12px, 2vh, 20px) clamp(12px, 1.2vw, 20px) clamp(24px, 3.5vh, 40px);
  box-sizing: border-box;
  border-left: 1px solid rgba(255, 255, 255, 0.07);
  overflow: hidden;
  isolation: isolate;
  width: auto;
  max-width: none;
  z-index: 1;
  transition:
    flex-grow 0.72s cubic-bezier(0.33, 1, 0.68, 1),
    flex-shrink 0.72s cubic-bezier(0.33, 1, 0.68, 1),
    flex-basis 0.72s cubic-bezier(0.33, 1, 0.68, 1),
    opacity 0.58s cubic-bezier(0.33, 1, 0.68, 1),
    box-shadow 0.58s cubic-bezier(0.33, 1, 0.68, 1);
  will-change: flex-grow;
}
.page-narrative-test .br-trio__grid:has(> .br-trio__row:hover) > *:not(:hover):not(:focus-within),
.page-narrative-test .br-trio__grid:has(> .br-trio__row:focus-within) > *:not(:hover):not(:focus-within) {
  opacity: 0.82 !important;
}
.page-narrative-test .br-trio__grid > *:hover,
.page-narrative-test .br-trio__grid > *:focus-within {
  flex: 2 1 0;
  z-index: 5;
  opacity: 1 !important;
  box-shadow:
    0 20px 56px rgba(0, 0, 0, 0.45),
    0 0 0 1px rgba(0, 128, 255, 0.2);
}
.page-narrative-test .br-trio__grid > [data-i="0"]:first-child,
.page-narrative-test .br-trio__grid > *:first-child {
  border-left: none;
}
.page-narrative-test .br-trio__grid .bn-right {
  display: none !important;
}
.page-narrative-test .br-trio__grid .bn-left,
.page-narrative-test .br-trio__grid .br-trio__inner {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  min-height: 100%;
}
/* 실적·자세히 보기 — 호버 시 펼침; 접힐 때는 내용 먼저, 너비는 뒤이어 줄어듦 */
.page-narrative-test .br-trio__reveal {
  width: 100%;
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.58s cubic-bezier(0.33, 1, 0.68, 1) 0.1s;
}
.page-narrative-test .br-trio__reveal-in {
  overflow: hidden;
  min-height: 0;
  opacity: 0;
  transform: translateY(10px);
  transition:
    opacity 0.22s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.page-narrative-test .br-trio__row:hover .br-trio__reveal,
.page-narrative-test .br-trio__row:focus-within .br-trio__reveal {
  grid-template-rows: 1fr;
  transition: grid-template-rows 0.42s cubic-bezier(0.22, 1, 0.36, 1) 0s;
}
.page-narrative-test .br-trio__row:hover .br-trio__reveal-in,
.page-narrative-test .br-trio__row:focus-within .br-trio__reveal-in {
  opacity: 1;
  transform: translateY(0);
  transition:
    opacity 0.36s cubic-bezier(0.22, 1, 0.36, 1) 0.1s,
    transform 0.42s cubic-bezier(0.22, 1, 0.36, 1) 0.08s;
}
.page-narrative-test .br-trio__row:hover .br-trio__reveal-in,
.page-narrative-test .br-trio__row:focus-within .br-trio__reveal-in {
  padding-top: clamp(12px, 1.8vh, 18px);
}
.page-narrative-test .br-trio .bn-desc {
  margin-bottom: 0;
}
.page-narrative-test .br-trio__reveal .br-stats--bn {
  margin-bottom: 10px;
}
.page-narrative-test .br-trio__grid > a.br-trio__row {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}
.page-narrative-test .br-trio__grid > a.br-trio__row:focus-visible {
  outline: 2px solid rgba(0, 128, 255, 0.65);
  outline-offset: -2px;
}
.page-narrative-test .br-trio__grid .br-trio__inner,
.page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio__inner {
  position: relative;
  z-index: 2;
}
.page-narrative-test .br-trio__more {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  pointer-events: none;
  font-size: clamp(9px, 0.88vw, 11px);
  font-weight: 500;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.68);
  line-height: 1;
  transform: translateY(8px);
  transition: color 0.25s ease;
}
.page-narrative-test .br-trio__more-arrow {
  flex-shrink: 0;
  opacity: 0.9;
}
.page-narrative-test .br-trio__row:hover .br-trio__more,
.page-narrative-test .br-trio__row:focus-within .br-trio__more {
  color: rgba(255, 255, 255, 0.9);
}
.page-narrative-test .br-trio__grid > [data-i="0"]::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(135deg, #020b1e 0%, #001d45 35%, #003d80 65%, #005fb8 100%);
}
.page-narrative-test .br-trio__grid > [data-i="1"]::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(225deg, #020b1e 0%, #00204a 30%, #004db0 60%, #0075e0 100%);
}
.page-narrative-test .br-trio__grid > [data-i="2"]::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: linear-gradient(135deg, #010810 0%, #001535 35%, #002c68 65%, #0052a8 100%);
}
.page-narrative-test .br-trio__grid > *::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: linear-gradient(
    0deg,
    rgba(6, 15, 40, 0.94) 0%,
    rgba(6, 15, 40, 0.5) 38%,
    rgba(6, 15, 40, 0.1) 72%,
    rgba(6, 15, 40, 0.02) 100%
  );
}
.page-narrative-test .br-trio__row .br-trio__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
  pointer-events: none;
}
.page-narrative-test .br-trio__row .br-trio__bg img {
  display: block;
  width: 100%;
  height: 100%;
  min-width: 100%;
  min-height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1);
  transition: transform 0.72s cubic-bezier(0.33, 1, 0.68, 1);
  will-change: transform;
}
@media (hover: hover) {
  .page-narrative-test .br-trio__grid > .br-trio__row:hover .br-trio__bg img,
  .page-narrative-test .br-trio__grid > .br-trio__row:focus-within .br-trio__bg img {
    transform: scale(1.06);
  }
}
@media (prefers-reduced-motion: reduce) {
  .page-narrative-test .br-trio__row .br-trio__bg img {
    transition: none;
  }
  .page-narrative-test .br-trio__row:hover .br-trio__bg img,
  .page-narrative-test .br-trio__row:focus-within .br-trio__bg img {
    transform: none;
  }
}
.page-narrative-test .br-trio__row--flowercenter .br-trio__bg img {
  object-position: 58% 42%;
}
.page-narrative-test .br-trio__row--flowerman .br-trio__bg img {
  object-position: center center;
}
.page-narrative-test .br-trio__row--flachain .br-trio__bg img {
  object-position: 62% center;
}
.page-narrative-test .br-trio__grid > [data-i="0"]::before,
.page-narrative-test .br-trio__grid > [data-i="1"]::before,
.page-narrative-test .br-trio__grid > [data-i="2"]::before {
  display: none;
}
.page-narrative-test .br-trio .bn-title {
  margin-bottom: 8px;
  font-size: clamp(18px, 2vw, 26px);
}
/* 가로 3칸: 고정 슬롯 + object-fit으로 로고 비율 유지 (br-wrap과 동일 원칙) */
.page-narrative-test .br-trio .bn-title.bn-title--brand {
  box-sizing: border-box;
  width: min(100%, 260px);
  height: clamp(36px, 5.2vw, 56px);
  margin: 0 0 10px;
  padding: 0;
  line-height: 0;
  letter-spacing: 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.page-narrative-test .br-trio .bn-title.bn-title--brand .bn-title__logo {
  display: block;
  margin: 0;
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  object-position: left center;
}
.page-narrative-test .br-trio__row--flowerman .bn-title.bn-title--brand {
  width: min(100%, 200px);
  height: clamp(28px, 3.8vw, 42px);
}
.page-narrative-test .br-trio__row--flowerman .bn-title__logo--flowerman {
  max-width: 200px;
  max-height: 42px;
  width: auto;
  height: auto;
}
.page-narrative-test .br-trio .bn-title.bn-title--brand.bn-title--brand-flachain {
  width: 100%;
  max-width: min(100%, 240px);
  height: clamp(42px, 6.5vw, 68px);
}
.page-narrative-test .br-trio .bn-desc {
  font-size: clamp(12px, 1.1vw, 14px);
  line-height: 1.5;
  max-width: 100%;
}
.page-narrative-test .br-trio .br-stats--bn {
  flex-direction: row;
  flex-wrap: wrap;
  align-items: flex-start;
  margin-bottom: 10px;
  gap: clamp(6px, 1vh, 12px) clamp(10px, 1.6vw, 22px);
  max-width: 100%;
}
.page-narrative-test .br-trio .br-stats--bn > div {
  flex: 0 1 auto;
  min-width: 0;
  white-space: nowrap;
}
.page-narrative-test .br-trio .br-stats--bn .br-sv {
  font-size: clamp(18px, 1.9vw, 26px);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -0.5px;
  margin-bottom: 5px;
}
.page-narrative-test .br-trio .br-stats--bn .br-sv em {
  font-style: normal;
  color: var(--blue);
}
.page-narrative-test .br-trio .br-stats--bn .br-sk {
  font-size: clamp(13px, 1.25vw, 15px);
  font-weight: 600;
  letter-spacing: -0.01em;
  color: rgba(255, 255, 255, 0.36);
  text-transform: none;
}
/* 꽃파는총각 1위 — 전국플라워 실적(.br-sv)과 동일 타이포 */
.page-narrative-test .br-trio .br-openmarket-rank {
  gap: 4px;
}
.page-narrative-test .br-trio .br-openmarket-rank__line--rank {
  font-size: clamp(18px, 1.9vw, 26px);
  font-weight: 900;
  letter-spacing: -0.5px;
  line-height: 1.15;
}
.page-narrative-test .br-trio .br-openmarket-rank__digit {
  color: var(--blue);
  text-shadow: none;
}
.page-narrative-test .br-trio .br-openmarket-rank__suffix {
  color: #fff;
  text-shadow: none;
}
/* 오픈마켓 5년 연속 — 가맹 화원사·누적 창업자 등 라벨(.br-sk)과 동일 타이포 */
.page-narrative-test .br-trio .br-openmarket-rank__line--gray {
  font-size: clamp(13px, 1.25vw, 15px);
  font-weight: 600;
  color: rgba(255, 255, 255, 0.36);
  letter-spacing: -0.01em;
  margin-top: 0;
}
.page-narrative-test .br-trio .bn-badge {
  position: absolute;
  top: clamp(12px, 2vh, 20px);
  right: clamp(12px, 1.2vw, 20px);
  z-index: 3;
  margin: 0;
  width: auto;
  max-width: calc(100% - 24px);
}
@media (min-width: 769px) {
  .bn-phase--brand-mo {
    display: none !important;
  }
}
@media (max-width: 768px) {
  .page-narrative-test .br-trio__reveal {
    grid-template-rows: 1fr;
  }
  .page-narrative-test .br-trio__reveal-in {
    opacity: 1;
    transform: none;
    padding-top: clamp(12px, 1.8vh, 18px);
  }
  /* 모바일: OUR BRANDS — BUSINESS AREAS와 동일 스티키 스크롤 4단 */
  .bn-phase--brands-desktop {
    display: none !important;
  }
  .page-narrative-test .bn-phase--brand-mo {
    display: flex !important;
    align-items: flex-end;
    justify-content: stretch;
    padding: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    grid-template-columns: unset !important;
    gap: 0 !important;
    width: 100%;
  }
  /* 비활성 슬라이드 클릭 차단 — visibility:hidden은 배경 레이아웃·cover 계산을 깨뜨릴 수 있음 */
  .page-narrative-test .bn-phase--brand-mo:not(.on) {
    pointer-events: none !important;
    z-index: 1;
  }
  .page-narrative-test .bn-phase--brand-mo.on {
    pointer-events: auto;
    z-index: 12;
  }
  .page-narrative-test .bn-sticky:has(.bn-phase--brand-mo.on) {
    background: var(--dark);
  }
  .page-narrative-test .bn-sticky:has(.bn-phase--brand-mo-duo.on) {
    background: #fff;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel {
    position: absolute;
    inset: 0;
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: none;
    box-sizing: border-box;
    opacity: 1 !important;
    pointer-events: auto;
    flex: none;
    overflow: hidden;
    isolation: isolate;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel::after {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    display: block;
    background: linear-gradient(
      0deg,
      rgba(6, 15, 40, 0.94) 0%,
      rgba(6, 15, 40, 0.5) 38%,
      rgba(6, 15, 40, 0.1) 72%,
      rgba(6, 15, 40, 0.02) 100%
    );
  }
  /* pass-through: 전면 배경 + 패널 패딩은 여기서 (콘텐츠·자세히 보기 정렬 기준) */
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio.br-trio--pass-through {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: stretch;
    width: 100%;
    height: 100%;
    min-height: 0;
    margin: 0;
    padding: clamp(72px, 12vh, 96px) 20px clamp(20px, 3.5vh, 32px);
    box-sizing: border-box;
    pointer-events: none;
    z-index: 2;
    background: transparent;
    overflow: visible;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio__bg {
    position: absolute;
    inset: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    overflow: hidden;
    pointer-events: none;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio__bg img {
    display: block;
    width: 100%;
    height: 100%;
    min-width: 100%;
    min-height: 100%;
    object-fit: cover;
    object-position: center;
    transform: none;
    transition: none;
  }
  .page-narrative-test .bn-phase--brand-mo-fc .br-brand-mo__panel .br-trio__bg img {
    object-position: 58% 42%;
  }
  .page-narrative-test .bn-phase--brand-mo-fm .br-brand-mo__panel .br-trio__bg img {
    object-position: center center;
  }
  .page-narrative-test .bn-phase--brand-mo-fl .br-brand-mo__panel .br-trio__bg img {
    object-position: 62% center;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__hit {
    position: absolute;
    inset: 0;
    z-index: 4;
    display: block;
    text-indent: -9999px;
    overflow: hidden;
    background: transparent;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio__more {
    position: absolute;
    right: 0;
    bottom: 0;
    z-index: 3;
    transform: none;
    margin: 0;
    font-size: 11px;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__panel .br-trio__inner {
    position: relative;
    z-index: 2;
    flex: 0 1 auto;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: flex-start;
    width: 100%;
    max-width: 420px;
    min-height: auto;
    margin: 0;
    padding: 0 0 clamp(28px, 4.5vh, 36px);
    box-sizing: border-box;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo {
    position: absolute;
    inset: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: clamp(68px, 11vh, 92px) 20px clamp(24px, 5vh, 40px);
    box-sizing: border-box;
    background: linear-gradient(180deg, #f4f8ff 0%, #fff 42%, #fff 100%);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo-head {
    width: 100%;
    max-width: 420px;
    margin: 0 0 clamp(20px, 3vh, 28px);
    text-align: left;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo-eyebrow {
    margin: 0 0 10px;
    display: flex;
    align-items: center;
    gap: 10px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 3px;
    text-transform: uppercase;
    color: var(--blue);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo-eyebrow::before {
    content: "";
    width: 14px;
    height: 1px;
    background: var(--blue);
    flex-shrink: 0;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo-title {
    margin: 0;
    font-size: clamp(22px, 5.5vw, 28px);
    font-weight: 900;
    letter-spacing: -0.03em;
    line-height: 1.2;
    color: var(--dark);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo--mo {
    flex-direction: column;
    width: 100%;
    max-width: 420px;
    min-height: 0;
    padding: 0;
    gap: 14px;
    box-sizing: border-box;
    border-top: none;
    background: transparent;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-cell {
    flex: none;
    width: 100%;
    padding: 0;
    background: transparent;
    border: none;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-cell--delivery,
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-cell--startup {
    border: none;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-inner {
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: clamp(18px, 2.8vh, 24px) clamp(16px, 4vw, 20px);
    box-sizing: border-box;
    background: #fff;
    border: 1px solid rgba(0, 128, 255, 0.1);
    border-radius: 16px;
    box-shadow:
      0 4px 24px rgba(12, 40, 90, 0.06),
      0 0 0 1px rgba(255, 255, 255, 0.8) inset;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-cell--startup .br-trio__duo-inner {
    background: linear-gradient(145deg, #f8fbff 0%, #fff 55%);
    border-color: rgba(0, 128, 255, 0.14);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-label {
    display: flex;
    align-items: center;
    gap: 8px;
    margin: 0 0 6px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--blue);
    white-space: normal;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-label::before {
    content: "";
    width: 3px;
    height: 12px;
    border-radius: 2px;
    background: var(--blue);
    flex-shrink: 0;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-desc {
    margin: 0 0 clamp(14px, 2vh, 18px);
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: -0.02em;
    color: rgba(13, 18, 40, 0.52);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    width: 100%;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos li {
    margin: 0;
    min-width: 0;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: auto;
    min-height: 52px;
    padding: 10px 12px;
    box-sizing: border-box;
    background: #f7faff;
    border: 1px solid rgba(0, 128, 255, 0.08);
    border-radius: 12px;
    opacity: 1;
    transition:
      background 0.2s ease,
      border-color 0.2s ease,
      transform 0.2s ease;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos a:active {
    transform: scale(0.98);
    background: #eef5ff;
    border-color: rgba(0, 128, 255, 0.2);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos img {
    max-width: min(108px, 38vw);
    max-height: 32px;
    width: auto;
    height: auto;
    object-position: center;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logo {
    position: relative;
    z-index: 6;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 56px;
    height: auto;
    padding: 14px 16px;
    box-sizing: border-box;
    background: #fff;
    border: 1px solid rgba(0, 128, 255, 0.1);
    border-radius: 12px;
    opacity: 1;
    transition:
      background 0.2s ease,
      border-color 0.2s ease,
      transform 0.2s ease;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logos a {
    position: relative;
    z-index: 6;
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logo:active {
    transform: scale(0.98);
    background: #f7faff;
    border-color: rgba(0, 128, 255, 0.22);
  }
  .page-narrative-test .bn-phase--brand-mo .br-brand-mo__duo .br-trio__duo-logo img {
    max-width: min(180px, 72vw);
    max-height: 40px;
    object-position: center;
    opacity: 1;
    filter: none;
  }
}

@media (prefers-reduced-motion: reduce) {
  .page-narrative-test .br-trio__grid > * {
    transition: none;
    will-change: auto;
  }
  .page-narrative-test .br-trio__grid > *:hover,
  .page-narrative-test .br-trio__grid > *:focus-within {
    box-shadow: none;
  }
  .page-narrative-test .br-trio__reveal {
    grid-template-rows: 1fr;
  }
  .page-narrative-test .br-trio__reveal-in {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .bn-vis-num,
  .bn-vis-orb {
    animation: none !important;
  }
  .bn-vis-orb {
    filter: none !important;
  }
  .bn-link {
    backdrop-filter: none !important;
  }
  .page-narrative-test .sn-phase.tn-phase--open.on .tn-eyebrow,
  .page-narrative-test .sn-phase.tn-phase--open.on .tn-big--open-hero {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}
