/* ============================================================
   Roots 세면대대리석 — Magenta Ink Design System
   Colors: #1A1A2E (dark) / #FAFAFA (bg) / #D63384 (accent)
============================================================ */

/* ============================================================
   0. 디자인 토큰 (CSS Custom Properties)
============================================================ */
:root {
  /* Primary palette — 파스텔 세이지 그린 (청결·신뢰·자연) */
  --dp-primary:      #D63384;
  --dp-primary-2:    #82b296;
  --dp-primary-3:    #1A1A2E;

  /* Accent palette — 웜 허니/카라멜 (따뜻한 포인트) */
  --dp-accent:       #D63384;
  --dp-accent-soft:  #d9bf90;
  --dp-accent-pale:  #f5eedc;

  /* Background — 세이지·크림 계열로 통일 */
  --dp-bg:           #ffffff;
  --dp-bg-soft:      #f4f0f8;   /* 연한 세이지 민트 */
  --dp-bg-warm:      #fdfaf3;   /* 따뜻한 크림 아이보리 */

  /* Border */
  --dp-border:       #d4e4da;
  --dp-border-soft:  rgba(110,158,130,0.08);

  /* Text */
  --dp-text:         #1e2a24;
  --dp-text-sub:     #3a5244;
  --dp-text-muted:   #6e8a78;

  /* Typography */
  --dp-font-body:    "Pretendard Variable", "Pretendard", -apple-system, BlinkMacSystemFont, sans-serif;
  --dp-font-caps:    "Pretendard Variable", "Pretendard", sans-serif;

  /* Type scale */
  --dp-fs-display: clamp(2.5rem, 7vw, 5.5rem);
  --dp-fs-h1:      clamp(2rem,   4.5vw, 3.2rem);
  --dp-fs-h2:      clamp(1.75rem, 4vw, 2.8rem);
  --dp-fs-h3:      clamp(1.1rem, 2vw, 1.4rem);
  --dp-fs-lede:    clamp(0.95rem, 1.5vw, 1.1rem);

  /* Layout */
  --dp-max-w:      1300px;
  --dp-max-w-text: 800px;
  --dp-gutter:     clamp(20px, 4vw, 30px);
  --dp-sec-pad:    clamp(80px, 12vw, 140px);

  /* Misc */
  --dp-radius:     2px;
  --dp-shadow-sm:  0 2px 8px rgba(110,158,130,.06);
  --dp-shadow-md:  0 8px 28px rgba(123,111,168,.10);
  --dp-shadow-lg:  0 30px 60px rgba(71,61,107,0.12);
  --dp-ease:       cubic-bezier(.22, 1, .36, 1);
  --dp-trans:      0.3s;

  /* 하위호환 alias — geo/aeo 페이지 인라인 스타일용 */
  --color-primary:   var(--dp-text);
  --color-text-mute: var(--dp-text-muted);
}

/* ─── 스크롤 progress bar ─── */
#scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  width: 0%;
  background: var(--dp-accent);
  z-index: 9999;
  transition: width 0.1s linear;
  pointer-events: none;
}

/* Ken Burns — 이미지 컨테이너 overflow 처리 */
.fp-case__img { overflow: hidden; }
.fp-core-section__img-wrap { overflow: hidden; }

/* ============================================================
   1. 리셋 & 베이스
============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}

body {
  font-family: var(--dp-font-body);
  color: var(--dp-text);
  background: var(--dp-bg);
  line-height: 1.8;
  font-weight: 300;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  word-break: keep-all;
  overflow-wrap: break-word;
}

img, video, svg {
  display: block;
  max-width: 100%;
  height: auto;
  image-rendering: -webkit-optimize-contrast;
}

a {
  color: inherit;
  text-decoration: none;
  transition: color var(--dp-trans) var(--dp-ease);
}

ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font-family: inherit; }

/* ============================================================
   2. 레이아웃 유틸리티
============================================================ */
.page-container {
  max-width: var(--dp-max-w);
  margin: 0 auto;
  padding: 0 var(--dp-gutter);
}

/* Legacy dp-container alias */
.dp-container {
  width: 100%;
  max-width: var(--dp-max-w);
  margin-inline: auto;
  padding-inline: var(--dp-gutter);
}

/* 섹션 교차 배경 */
.dp-section         { padding-block: var(--dp-sec-pad); }
.dp-section--soft   { background: var(--dp-bg-soft); }
.dp-section--warm   { background: var(--dp-bg-warm); }
.dp-section--dark   { background: var(--dp-primary-3); color: #fff; }
.dp-section--tight  { padding-block: calc(var(--dp-sec-pad) * 0.5); }

/* ============================================================
   3. 공통 유틸리티 클래스 (레퍼런스 패턴)
============================================================ */

/* Eyebrow / label-caps */
.label-caps,
.dp-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--dp-accent);
  display: inline-block;
}

/* Serif italic accent */
.serif-italic {
  font-family: 'Georgia', 'Times New Roman', serif;
  font-style: italic;
  color: var(--dp-accent);
}

/* Fade-in-up reveal — JS가 로드되어야 숨겨짐 (no-js 환경 보호) */
.js-ready .fade-in-up,
.js-ready .dp-reveal {
  opacity: 0;
  transform: translateY(20px);
}
.fade-in-up, .dp-reveal {
  transition: opacity 0.75s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.75s cubic-bezier(0.16, 1, 0.3, 1);
}
.fade-in-up.is-visible,
.dp-reveal.is-visible {
  opacity: 1 !important;
  transform: translateY(0) !important;
}
@media (prefers-reduced-motion: reduce) {
  .fade-in-up, .dp-reveal { opacity: 1 !important; transform: none !important; transition: none; }
}

/* ============================================================
   4. 헤더 — fixed, backdrop-blur, 흰 배경 (레퍼런스 패턴)
============================================================ */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(0,0,0,0.04);
  transition: box-shadow 0.3s ease;
}

.site-header.scrolled {
  box-shadow: 0 1px 30px rgba(0,0,0,0.08);
}

.header-inner {
  max-width: var(--dp-max-w);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--dp-gutter);
  height: 76px;
}

/* Logo */
.header-logo {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: var(--dp-text);
  gap: 0;
}

.logo-brand {
  font-size: 19px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--dp-primary);
}

.logo-divider {
  display: inline-block;
  width: 1px;
  height: 14px;
  background: #ccc;
  margin: 0 8px;
  flex-shrink: 0;
}

.logo-sub {
  font-size: 11px;
  font-weight: 400;
  color: var(--dp-text-muted);
  letter-spacing: 0.02em;
}

/* Desktop nav */
.header-nav {
  display: flex;
  align-items: center;
  gap: 36px;
}

.header-nav a {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #aaa;
  text-decoration: none;
  transition: color 0.3s;
}

.header-nav a:hover { color: var(--dp-primary); }

/* 서비스 드롭다운 */
.header-nav__drop {
  position: relative;
}
.header-nav__drop > a {
  cursor: default;
}
.header-nav__drop-menu {
  display: none;
  position: absolute;
  top: calc(100% + 14px);
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  border: 1px solid var(--dp-border);
  border-radius: 4px;
  box-shadow: var(--dp-shadow-md);
  min-width: 180px;
  padding: 8px 0;
  z-index: 200;
}
.header-nav__drop:hover .header-nav__drop-menu,
.header-nav__drop:focus-within .header-nav__drop-menu {
  display: block;
}
.header-nav__drop-menu a {
  display: block;
  padding: 9px 18px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--dp-text-sub);
  text-decoration: none;
  transition: background 0.2s, color 0.2s;
  white-space: nowrap;
}
.header-nav__drop-menu a:hover {
  background: var(--dp-bg-soft);
  color: var(--dp-primary);
}

/* Header CTA button */
.header-cta {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dp-text);
  text-decoration: none;
  border-bottom: 1px solid var(--dp-text);
  padding-bottom: 2px;
  transition: all 0.3s;
}

.header-cta:hover {
  color: var(--dp-accent);
  border-color: var(--dp-accent);
}

/* Mobile hamburger */
.mobile-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  flex-direction: column;
  gap: 5px;
}

.mobile-toggle span {
  display: block;
  width: 20px;
  height: 1.5px;
  background: var(--dp-text);
  transition: all 0.3s;
}

.mobile-toggle.active span:nth-child(1) { transform: rotate(45deg) translate(4px,4px); }
.mobile-toggle.active span:nth-child(2) { opacity: 0; }
.mobile-toggle.active span:nth-child(3) { transform: rotate(-45deg) translate(4px,-4px); }

/* Mobile menu drawer */
.mobile-menu {
  display: none;
  position: fixed;
  top: 76px;
  left: 0;
  right: 0;
  background: rgba(255,255,255,0.98);
  backdrop-filter: blur(16px);
  padding: 24px var(--dp-gutter);
  flex-direction: column;
  gap: 4px;
  border-bottom: 1px solid rgba(0,0,0,0.04);
  z-index: 999;
}

.mobile-menu:not([hidden]) { display: flex; }

.mobile-menu a {
  display: block;
  padding: 14px 0;
  font-size: 13px;
  font-weight: 500;
  color: var(--dp-text);
  text-decoration: none;
  border-bottom: 1px solid rgba(0,0,0,0.04);
}

.mobile-menu .mobile-cta {
  margin-top: 12px;
  text-align: center;
  background: var(--dp-primary);
  color: #fff;
  border-radius: 0;
  padding: 16px;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  border: none;
}

/* Body offset for fixed header */
body { padding-top: 76px; }

/* ============================================================
   5. Hero Header Section (대형 editorial 타이포)
============================================================ */
.fp-hero-head {
  padding: clamp(48px, 8vw, 80px) 0 0;
  background: var(--dp-bg);
}

.fp-hero-head__inner {
  max-width: 820px;
}

.fp-hero-head__title {
  font-size: var(--dp-fs-display);
  font-weight: 200;
  letter-spacing: -0.05em;
  line-height: 1.05;
  margin-bottom: 0;
  color: var(--dp-text);
}

.fp-hero-head__em {
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  line-height: 1.1;
  margin-top: 4px;
  display: block;
}

.fp-hero-head__meta {
  display: flex;
  align-items: flex-end;
  gap: 40px;
  margin-top: clamp(28px, 5vw, 48px);
}

.fp-hero-head__sub {
  font-size: 15px;
  font-weight: 300;
  color: var(--dp-text-muted);
  max-width: 340px;
  line-height: 1.8;
}

.fp-hero-head .label-caps {
  margin-bottom: 20px;
  display: block;
}

/* ============================================================
   Hero entrance animations
============================================================ */
@keyframes heroLabelSlide {
  from { opacity: 0; transform: translateX(-22px); }
  to   { opacity: 1; transform: translateX(0); }
}
@keyframes heroW1Up {
  from { opacity: 0; transform: translateY(55px) skewX(-4deg); }
  to   { opacity: 1; transform: translateY(0)    skewX(0deg); }
}
@keyframes heroW2Up {
  from { opacity: 0; transform: translateY(55px) skewX(4deg); }
  to   { opacity: 1; transform: translateY(0)    skewX(0deg); }
}
@keyframes heroEmBlur {
  from { opacity: 0; transform: translateY(18px); filter: blur(8px); }
  to   { opacity: 1; transform: translateY(0);    filter: blur(0); }
}
@keyframes heroSubFade {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

.fp-hero-head .label-caps {
  animation: heroLabelSlide 0.5s cubic-bezier(0.22, 1, 0.36, 1) 0.05s both;
}
.fp-hero-head__title {
  overflow: hidden;
}
.fp-hero-head__title .title-w1 {
  display: inline-block;
  animation: heroW1Up 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.18s both;
}
.fp-hero-head__title .title-w2 {
  display: inline-block;
  font-style: normal;
  color: var(--dp-accent);
  animation: heroW2Up 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.30s both;
}
.fp-hero-head__title .title-w3 {
  display: inline-block;
  animation: heroW1Up 0.75s cubic-bezier(0.22, 1, 0.36, 1) 0.42s both;
}
.fp-hero-head__em {
  animation: heroEmBlur 0.7s cubic-bezier(0.22, 1, 0.36, 1) 0.62s both;
}
.fp-hero-head__sub {
  animation: heroSubFade 0.6s ease 0.92s both;
}

/* ============================================================
   6. Before & After Case 섹션
============================================================ */
.fp-case {
  padding: clamp(48px, 8vw, 80px) 0;
  background: var(--dp-bg);
}

.fp-case--sand {
  background: var(--dp-bg-soft);
}

.fp-case__label {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}

.fp-case__divider {
  display: inline-block;
  width: 40px;
  height: 1px;
  background: #ddd;
}

.fp-case__tag {
  font-size: 14px;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.fp-case__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-lg);
}

.fp-case__img {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
}

.fp-case__img img,
.fp-case__img .img-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* Before image — desaturated */
.fp-case__grid .fp-case__img:first-child img {
  filter: saturate(0.25);
}

.fp-case__badge {
  position: absolute;
  padding: 6px 14px;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: #fff;
}

.fp-case__badge--before {
  bottom: 16px;
  left: 16px;
  background: rgba(0,0,0,0.45);
  backdrop-filter: blur(8px);
}

.fp-case__badge--after {
  bottom: 16px;
  right: 16px;
  background: var(--dp-accent);
}

.fp-case__desc {
  margin-top: 32px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 40px;
  align-items: start;
}

.fp-case__desc--reverse {
  grid-template-columns: 2fr 1fr;
}

.fp-case__desc-title {
  font-size: clamp(22px, 3vw, 30px);
  font-weight: 200;
  letter-spacing: -0.03em;
  line-height: 1.3;
  color: var(--dp-text);
}

.fp-case__desc-body {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 2;
  font-weight: 300;
}

/* ============================================================
   7. Core Solutions — Dark Section (레퍼런스 #service)
============================================================ */
.fp-core-section {
  padding: var(--dp-sec-pad) 0;
  background: var(--dp-primary-3);
  color: #fff;
}

.fp-core-section__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
}

.fp-core-section__title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 200;
  letter-spacing: -0.03em;
  line-height: 1.25;
  margin-bottom: 48px;
  color: #fff;
}

.fp-principles {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

/* 스태거 등장: 각 원칙 따로따로 */
.js-ready .fp-principle {
  opacity: 0;
  transform: translateX(-24px);
  transition: opacity 0.5s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.fp-principles.is-visible .fp-principle:nth-child(1) { opacity: 1; transform: translateX(0); transition-delay: 0.05s; }
.fp-principles.is-visible .fp-principle:nth-child(2) { opacity: 1; transform: translateX(0); transition-delay: 0.22s; }
.fp-principles.is-visible .fp-principle:nth-child(3) { opacity: 1; transform: translateX(0); transition-delay: 0.39s; }
@media (prefers-reduced-motion: reduce) {
  .js-ready .fp-principle { opacity: 1 !important; transform: none !important; }
}

.fp-principle {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}

.fp-principle__num {
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: 22px;
  color: var(--dp-accent);
  opacity: 0.45;
  flex-shrink: 0;
  margin-top: 2px;
}

.fp-principle__title {
  font-size: 17px;
  font-weight: 700;
  margin-bottom: 6px;
  letter-spacing: -0.02em;
  color: #fff;
}

.fp-principle__desc {
  font-size: 14px;
  color: rgba(255,255,255,0.5);
  line-height: 1.8;
  font-weight: 300;
}

.fp-core-section__media {
  position: relative;
}

.fp-core-section__img-wrap {
  aspect-ratio: 4/5;
  overflow: hidden;
}

.fp-core-section__img-wrap img,
.fp-core-section__img-wrap .img-placeholder {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.72;
}

.fp-core-section__badge-card {
  position: absolute;
  bottom: -20px;
  left: -20px;
  background: var(--dp-accent);
  padding: 28px 32px;
  display: none;
}

.fp-core-section__badge-en {
  color: #fff;
  font-size: 22px;
  font-weight: 200;
  line-height: 1;
  font-family: 'Georgia', serif;
  font-style: italic;
}

.fp-core-section__badge-sub {
  color: #fff;
  opacity: 0.7;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  margin-top: 8px;
}

/* ============================================================
   8. Trust / Stats (레퍼런스 #trust)
============================================================ */
.fp-trust {
  padding: var(--dp-sec-pad) 0;
  background: var(--dp-bg);
}

.fp-trust__head {
  text-align: center;
  margin-bottom: 56px;
}

.fp-trust__title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
}

.fp-trust__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: #eee;
  margin-bottom: 64px;
}

.fp-trust__stat {
  background: var(--dp-bg);
  padding: 40px 20px;
  text-align: center;
}

.fp-trust__hl {
  display: block;
  font-size: clamp(28px, 4vw, 38px);
  font-weight: 200;
  color: var(--dp-primary);
  letter-spacing: -0.03em;
  margin-bottom: 6px;
  line-height: 1;
}

.fp-trust__cap {
  display: block;
  font-size: 11px;
  color: var(--dp-text-muted);
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.fp-trust__reviews {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.fp-trust__review {
  border-top: 1px solid #eee;
  padding-top: 24px;
}

.fp-trust__review-text {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.9;
  font-weight: 300;
  margin-bottom: 20px;
}

.fp-trust__reviewer {
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.05em;
  color: var(--dp-text-sub);
}

/* ============================================================
   9. Process (레퍼런스 #process 스타일)
============================================================ */
.fp-process {
  padding: var(--dp-sec-pad) 0;
  background: var(--dp-bg-soft);
}

.fp-process__container {
  max-width: 900px;
}

.fp-process__head {
  text-align: center;
  margin-bottom: 56px;
}

.fp-process__title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
}

.fp-step {
  display: flex;
  gap: 24px;
  align-items: flex-start;
  padding: 28px 0;
  border-bottom: 1px solid var(--dp-border-soft);
}

.fp-step:last-child {
  border-bottom: none;
}

.fp-step__num {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  background: var(--dp-primary-3);
  color: var(--dp-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: 15px;
  font-weight: 400;
}

.fp-step__title {
  font-size: 16px;
  font-weight: 700;
  margin-bottom: 4px;
  letter-spacing: -0.02em;
  color: var(--dp-text);
}

.fp-step__desc {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.8;
  font-weight: 300;
}

/* ============================================================
   10. FAQ (레퍼런스 스타일 accordion)
============================================================ */
.fp-faq {
  padding: var(--dp-sec-pad) 0;
  background: var(--dp-bg);
}

.fp-faq__container {
  max-width: 800px;
}

.fp-faq__head {
  text-align: center;
  margin-bottom: 56px;
}

.fp-faq__title {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
}

.fp-faq__list {
  display: flex;
  flex-direction: column;
}

.fp-faq__item {
  border-bottom: 1px solid var(--dp-border-soft);
}

.fp-faq__toggle {
  width: 100%;
  padding: 24px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  gap: 16px;
}

.fp-faq__q-text {
  font-size: 15px;
  font-weight: 500;
  color: var(--dp-text);
  letter-spacing: -0.02em;
  line-height: 1.4;
}

.fp-faq__icon {
  font-size: 18px;
  color: #ccc;
  transition: transform 0.3s, color 0.3s;
  flex-shrink: 0;
  margin-left: 16px;
  font-weight: 200;
  line-height: 1;
}

.fp-faq__toggle[aria-expanded="true"] .fp-faq__icon {
  color: var(--dp-accent);
}

.fp-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease;
}

.fp-faq__answer-inner {
  padding: 0 0 24px;
}

.fp-faq__answer-inner p {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.9;
  font-weight: 300;
}

/* Legacy dp-faq support */
.dp-faq__list { max-width: 760px; margin-inline: auto; }
.dp-faq__item { border-top: 1px solid var(--dp-border-soft); }
.dp-faq__item:last-child { border-bottom: 1px solid var(--dp-border-soft); }
.dp-faq__q { display: block; }
.dp-faq__toggle {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 20px 0; font-size: 0.98rem; font-weight: 600;
  color: var(--dp-text); text-align: left; gap: 16px; cursor: pointer;
}
.dp-faq__toggle:hover { color: var(--dp-primary); }
.dp-faq__toggle[aria-expanded="true"] { color: var(--dp-primary); }
.dp-faq__icon {
  font-size: 1.2rem; font-weight: 400; color: var(--dp-accent);
  flex-shrink: 0; line-height: 1; transition: transform var(--dp-trans) var(--dp-ease);
}
.dp-faq__toggle[aria-expanded="true"] .dp-faq__icon { transform: rotate(45deg); }
.dp-faq__a { padding-bottom: 20px; }
.dp-faq__a p { font-size: 0.92rem; color: var(--dp-text-muted); line-height: 1.75; }

/* ============================================================
   11. 관련 서비스 내부 링크
============================================================ */
.fp-services-nav {
  padding: clamp(48px, 8vw, 72px) 0;
  background: var(--dp-bg-soft);
}

.fp-services-nav__container {
  max-width: 900px;
}

.fp-services-nav__head {
  text-align: center;
  margin-bottom: 32px;
}

.fp-services-nav__title {
  font-size: clamp(22px, 3vw, 28px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
}

.fp-services-nav__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.fp-services-nav__item {
  display: block;
  padding: 20px;
  background: var(--dp-bg);
  text-align: center;
  text-decoration: none;
  color: var(--dp-text);
  font-size: 14px;
  font-weight: 500;
  border: 1px solid transparent;
  transition: all 0.3s;
}

.fp-services-nav__item:hover {
  border-color: var(--dp-primary);
  color: var(--dp-primary);
}

/* ============================================================
   12. 시공사례 마퀴 (갤러리 스크롤 스트립)
============================================================ */
.fp-marquee-section {
  padding: clamp(56px, 8vw, 80px) 0;
  overflow: hidden;
  background: var(--dp-bg-warm);
}

.fp-marquee-head {
  text-align: center;
  margin-bottom: 32px;
  padding: 0 var(--dp-gutter);
}

.fp-marquee-title {
  font-size: clamp(24px, 3vw, 32px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
}

.fp-marquee-container {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.fp-marquee-track {
  display: flex;
  gap: 8px;
  animation: marquee-scroll 70s linear infinite;
  width: max-content;
}

.fp-marquee-track:hover { animation-play-state: paused; }

@keyframes marquee-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.fp-marquee-item {
  flex-shrink: 0;
  width: 280px;
  position: relative;
  overflow: hidden;
  border-radius: var(--dp-radius);
}

.fp-marquee-item img,
.fp-marquee-item .img-placeholder {
  width: 280px;
  height: 210px;
  object-fit: cover;
  display: block;
  filter: grayscale(20%);
  transition: filter 0.4s;
}

.fp-marquee-item:hover img { filter: grayscale(0); }

.fp-marquee-item__label {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 10px 14px;
  background: linear-gradient(transparent, rgba(0,0,0,0.5));
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
}

/* ─── 리뷰 마퀴 ─── */
.fp-review-marquee {
  padding-block: clamp(56px, 8vw, 88px);
  background: var(--dp-primary-3);
  overflow: hidden;
}
.fp-review-marquee__head {
  text-align: center;
  margin-bottom: 40px;
  padding-inline: var(--dp-gutter);
}
.fp-review-marquee__label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.3em;
  text-transform: uppercase; color: var(--dp-accent);
  display: block; margin-bottom: 10px;
}
.fp-review-marquee__title {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 200; color: #fff; line-height: 1.3;
}
.fp-review-track-wrap { overflow: hidden; }
.fp-review-track {
  display: flex;
  gap: 20px;
  width: max-content;
  animation: review-scroll 85s linear infinite;
}
.fp-review-track:hover { animation-play-state: paused; }
@keyframes review-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.fp-review-card {
  flex-shrink: 0;
  width: 320px;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 8px;
  padding: 28px 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.fp-review-card__stars {
  color: var(--dp-accent);
  font-size: 14px;
  letter-spacing: 2px;
}
.fp-review-card__body {
  font-size: 0.9rem;
  color: rgba(255,255,255,.82);
  line-height: 1.75;
  flex: 1;
}
.fp-review-card__author {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,.4);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

/* ============================================================
   13. 지역 서비스
============================================================ */
.fp-area {
  padding: var(--dp-sec-pad) 0;
  background: var(--dp-primary-3);
  color: #fff;
}

.fp-area__head {
  text-align: center;
  margin-bottom: 52px;
}

.fp-area__title {
  font-size: clamp(26px, 4vw, 40px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: #fff;
}

.fp-area__lead {
  margin-top: 14px;
  font-size: 14px;
  color: rgba(255,255,255,.45);
  line-height: 1.8;
}

/* 2컬럼 그리드 */
.fp-area__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  margin-bottom: 48px;
}

.fp-area__col-hd {
  display: flex;
  align-items: baseline;
  gap: 10px;
  padding-bottom: 14px;
  margin-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,.1);
}

.fp-area__col-name {
  font-size: 17px;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.02em;
}

.fp-area__col-sub {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  letter-spacing: 0.03em;
}

/* 태그 목록 */
.fp-area__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  list-style: none;
  padding: 0;
  margin: 0;
}

.fp-area__tag {
  font-size: 12px;
  color: rgba(255,255,255,.45);
  padding: 5px 11px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 3px;
  line-height: 1;
}

/* 전용 페이지 있는 지역 — 골드 강조 */
.fp-area__tag--page {
  border-color: rgba(200,169,110,.45);
  background: rgba(200,169,110,.07);
}

.fp-area__tag--page a {
  color: var(--dp-accent-soft);
  font-weight: 600;
  transition: color var(--dp-trans);
}

.fp-area__tag--page a:hover {
  color: #fff;
}

.fp-area__extra {
  margin-top: 16px;
  font-size: 12px;
  color: rgba(255,255,255,.28);
  line-height: 1.8;
}

.fp-area__cta { text-align: center; }

@media (max-width: 600px) {
  .fp-area__grid { grid-template-columns: 1fr; }
}

/* ── 지역 섹션 입장 애니메이션 ── */

/* 컬럼: 좌→오른쪽, 우→왼쪽 슬라이드인 */
.js-ready .fp-area__col {
  opacity: 0;
  transition: opacity 0.55s cubic-bezier(0.22, 1, 0.36, 1),
              transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}
.js-ready .fp-area__col:nth-child(1) {
  transform: translateX(-30px);
  --col-delay: 0.08s;
  transition-delay: 0.08s;
}
.js-ready .fp-area__col:nth-child(2) {
  transform: translateX(30px);
  --col-delay: 0.24s;
  transition-delay: 0.24s;
}
.fp-area__grid.is-visible .fp-area__col {
  opacity: 1;
  transform: translateX(0);
}

/* 태그: 팝 캐스케이드 (컬럼별 독립 스태거) */
.js-ready .fp-area__tag {
  opacity: 0;
  transform: scale(0.75);
  transition: opacity 0.22s ease,
              transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1);
  transition-delay: calc(var(--col-delay, 0.08s) + var(--i, 0) * 18ms);
}
.fp-area__grid.is-visible .fp-area__tag {
  opacity: 1;
  transform: scale(1);
}

/* 헤더 구분선 골드 드로우 */
.fp-area__col-hd {
  position: relative;
}
.fp-area__col-hd::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  height: 1px;
  background: var(--dp-accent);
  width: 0;
  transition: width 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.fp-area__grid.is-visible .fp-area__col:nth-child(1) .fp-area__col-hd::after {
  width: 35%;
  transition-delay: 0.35s;
}
.fp-area__grid.is-visible .fp-area__col:nth-child(2) .fp-area__col-hd::after {
  width: 35%;
  transition-delay: 0.5s;
}

@media (prefers-reduced-motion: reduce) {
  .js-ready .fp-area__col,
  .js-ready .fp-area__tag { opacity: 1 !important; transform: none !important; }
  .fp-area__col-hd::after { display: none; }
}

/* ============================================================
   14. CTA 버튼
============================================================ */
.dp-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 52px;
  padding: 16px 32px;
  font-family: var(--dp-font-caps);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  border-radius: var(--dp-radius);
  border: 2px solid transparent;
  cursor: pointer;
  transition: all var(--dp-trans) var(--dp-ease);
  white-space: nowrap;
  text-decoration: none;
}

.dp-cta--primary {
  background: var(--dp-accent);
  color: #fff;
  border-color: var(--dp-accent);
}

.dp-cta--primary:hover {
  background: var(--dp-accent-soft);
  border-color: var(--dp-accent-soft);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(232,146,122,0.30);
}

.dp-cta--outline {
  background: transparent;
  color: var(--dp-primary);
  border-color: var(--dp-primary);
}

.dp-cta--outline:hover {
  background: var(--dp-primary);
  color: #fff;
}

.dp-cta--outline-light {
  background: transparent;
  color: rgba(255,255,255,0.9);
  border-color: rgba(255,255,255,0.4);
}

.dp-cta--outline-light:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.8);
  color: #fff;
}

.dp-cta--ghost {
  background: transparent;
  color: var(--dp-accent);
  border-color: var(--dp-accent);
}

.dp-cta--ghost:hover {
  background: var(--dp-accent);
  color: #fff;
}

/* ============================================================
   15. 섹션 헤드 (legacy dp-section-head)
============================================================ */
.dp-section-head {
  text-align: center;
  margin-bottom: clamp(40px, 6vw, 64px);
}

.dp-section-head--left { text-align: left; }

.dp-section-head__title {
  font-size: var(--dp-fs-h2);
  font-weight: 200;
  color: var(--dp-text);
  line-height: 1.25;
  letter-spacing: -0.03em;
  margin-bottom: 16px;
}

.dp-section-head--light .dp-section-head__title { color: #fff; }
.dp-section-head--light .dp-eyebrow { opacity: .85; }
.dp-section-head--light p { color: rgba(255,255,255,.7); }

.dp-section-head__sub {
  font-size: 14px;
  color: var(--dp-text-muted);
  max-width: var(--dp-max-w-text);
  margin-inline: auto;
  line-height: 1.7;
  font-weight: 300;
}

/* ============================================================
   16. Trust Badge (legacy dp-trust)
============================================================ */
.dp-trust__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0;
  border: 1px solid var(--dp-border-soft);
  border-radius: var(--dp-radius);
  overflow: hidden;
  background: var(--dp-bg);
  box-shadow: var(--dp-shadow-sm);
}

.dp-trust__item {
  flex: 1 1 220px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 32px 24px;
  border-right: 1px solid var(--dp-border-soft);
  text-align: center;
  transition: background var(--dp-trans);
}

.dp-trust__item:last-child { border-right: none; }
.dp-trust__item:hover { background: var(--dp-bg-soft); }

.dp-trust__hl {
  display: block;
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 200;
  color: var(--dp-primary);
  letter-spacing: -0.03em;
  line-height: 1;
}

.dp-trust__cap {
  font-size: 0.78rem;
  color: var(--dp-text-muted);
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

/* ============================================================
   17. Service Cards (legacy dp-service-card)
============================================================ */
.dp-service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px;
}

.dp-service-card {
  border-radius: var(--dp-radius);
  overflow: hidden;
  background: var(--dp-bg);
  box-shadow: var(--dp-shadow-sm);
  border: 1px solid var(--dp-border-soft);
  transition: transform var(--dp-trans) var(--dp-ease), box-shadow var(--dp-trans);
}

.dp-service-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--dp-shadow-md);
}

.dp-service-card__link { display: block; height: 100%; }

.dp-service-card__fig {
  aspect-ratio: 16/11;
  overflow: hidden;
  position: relative;
  background: var(--dp-bg-soft);
}

.dp-service-card__fig img,
.dp-service-card__fig .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.45s var(--dp-ease);
}

.dp-service-card:hover .dp-service-card__fig img { transform: scale(1.05); }

.dp-service-card__body { padding: 20px 20px 24px; }

.dp-service-card__title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--dp-text);
  margin-bottom: 8px;
  letter-spacing: -0.01em;
}

.dp-service-card__desc {
  font-size: 0.88rem;
  color: var(--dp-text-muted);
  line-height: 1.6;
  margin-bottom: 16px;
}

.dp-more {
  display: inline-block;
  font-size: 0.8rem;
  font-weight: 700;
  color: var(--dp-accent);
  letter-spacing: 0.03em;
  position: relative;
}

.dp-more::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 0;
  height: 1px;
  background: var(--dp-accent);
  transition: width var(--dp-trans) var(--dp-ease);
}

.dp-service-card:hover .dp-more::after { width: 100%; }

/* ============================================================
   18. CTA 배너 (split layout — legacy dp-cta-banner)
============================================================ */
.dp-cta-banner__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-lg);
}

.dp-cta-banner__media {
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--dp-bg-soft);
}

.dp-cta-banner__media img,
.dp-cta-banner__media .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
}

.dp-cta-banner__body {
  background: var(--dp-primary-3);
  padding: clamp(36px, 5vw, 64px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 16px;
}

.dp-cta-banner__title {
  font-size: clamp(1.5rem, 2.8vw, 2.1rem);
  font-weight: 200;
  color: #fff;
  line-height: 1.25;
  letter-spacing: -0.03em;
}

.dp-cta-banner__sub {
  font-size: 0.9rem;
  color: rgba(255,255,255,.65);
  line-height: 1.6;
  font-weight: 300;
}

.dp-micro-copy {
  font-size: 0.78rem;
  color: rgba(255,255,255,.45);
  margin-top: 4px;
  letter-spacing: 0.01em;
}

.dp-final-cta .dp-container {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}

/* ============================================================
   19. Gallery / Portfolio (legacy)
============================================================ */
.dp-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-bottom: 40px;
}

.dp-gallery-item__fig {
  position: relative;
  overflow: hidden;
  border-radius: var(--dp-radius);
  aspect-ratio: 3/4;
  background: var(--dp-bg-soft);
}

.dp-gallery-item__fig img,
.dp-gallery-item__fig .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s var(--dp-ease);
}

.dp-gallery-item:hover .dp-gallery-item__fig img { transform: scale(1.04); }

.dp-gallery-item__caption {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 16px 14px 14px;
  background: linear-gradient(0deg, rgba(71,61,107,.72) 0%, transparent 100%);
  color: #fff;
  font-size: 0.8rem;
  font-weight: 600;
}

.dp-gallery-cta { text-align: center; }

/* 포트폴리오 — 에디토리얼 1컬럼 리스트 */
.dp-portfolio-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  list-style: none;
  padding: 0;
  margin: 40px 0 0;
}

.dp-portfolio-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--dp-border);
  transition: background 0.3s;
}
.dp-portfolio-item:last-child { border-bottom: 1px solid var(--dp-border); }
.dp-portfolio-item:nth-child(even) { background: var(--dp-bg-soft); }

/* 전후 페어 */
.dp-portfolio-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  overflow: hidden;
}
.dp-portfolio-pair__fig {
  position: relative;
  overflow: hidden;
  aspect-ratio: 3/2;
  margin: 0;
}
.dp-portfolio-pair__fig img,
.dp-portfolio-pair__fig .img-placeholder {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.25, 1, 0.5, 1);
}
.dp-portfolio-item:hover .dp-portfolio-pair__fig img { transform: scale(1.04); }

.dp-portfolio-pair__badge {
  position: absolute;
  bottom: 12px; left: 12px;
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  padding: 4px 10px;
  color: #fff;
  background: rgba(0,0,0,.5);
  backdrop-filter: blur(4px);
}
.dp-portfolio-pair__badge--after { background: var(--dp-primary); }

/* 캡션 */
.dp-portfolio-item__caption {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(28px, 4vw, 56px) clamp(24px, 3.5vw, 48px);
  background: transparent;
}
.dp-portfolio-item__region {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 14px;
}
.dp-portfolio-item__title {
  font-size: clamp(17px, 2.2vw, 24px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dp-text);
  line-height: 1.35;
  margin-bottom: 14px;
}
.dp-portfolio-item__content {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.8;
}

/* 반응형 */
@media (max-width: 760px) {
  .dp-portfolio-item { grid-template-columns: 1fr; }
  .dp-portfolio-pair { aspect-ratio: unset; }
  .dp-portfolio-pair__fig { aspect-ratio: 4/3; }
}

/* ============================================================
   19-B. 라이트박스
============================================================ */
.dp-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(0,0,0,.88);
  align-items: center;
  justify-content: center;
  padding: 20px;
  cursor: zoom-out;
}
.dp-lightbox.is-open { display: flex; }

.dp-lightbox__img {
  max-width: 92vw;
  max-height: 88vh;
  object-fit: contain;
  border-radius: 4px;
  box-shadow: 0 8px 48px rgba(0,0,0,.6);
  cursor: default;
  pointer-events: none;
}

.dp-lightbox__close {
  position: absolute;
  top: 20px; right: 24px;
  font-size: 2rem;
  color: rgba(255,255,255,.8);
  background: none;
  border: none;
  cursor: pointer;
  line-height: 1;
  padding: 4px 8px;
}

.dp-portfolio-pair__fig {
  cursor: zoom-in;
}

/* ============================================================
   20. 서비스 상세 (2컬럼 — legacy)
============================================================ */
.dp-service-detail__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}

.dp-check-list { margin-top: 20px; display: flex; flex-direction: column; gap: 12px; }
.dp-check-list li {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 0.92rem; color: var(--dp-text-sub); line-height: 1.5;
}
.dp-check-list li::before {
  content: '';
  display: block; width: 18px; height: 18px; border-radius: 50%;
  background: var(--dp-accent); flex-shrink: 0; margin-top: 1px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%236e9e82'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41z'/%3E%3C/svg%3E");
  background-size: 12px; background-repeat: no-repeat; background-position: center;
}
.dp-service-detail__media {
  border-radius: var(--dp-radius); overflow: hidden; box-shadow: var(--dp-shadow-md); aspect-ratio: 4/3;
}
.dp-service-detail__media img,
.dp-service-detail__media .img-placeholder { width: 100%; height: 100%; object-fit: cover; }

/* ============================================================
   21. Steps (legacy dp-steps — for sub-pages)
============================================================ */
.dp-steps {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 32px;
}

.dp-step {
  display: flex;
  flex-direction: column;
  gap: 16px;
  position: relative;
}

.dp-step__num {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--dp-accent);
  letter-spacing: -0.04em;
  line-height: 1;
}

.dp-step__title { font-size: 1.1rem; font-weight: 700; color: var(--dp-text); margin-bottom: 8px; }
.dp-step__desc { font-size: 0.9rem; color: var(--dp-text-muted); line-height: 1.65; }

.dp-step::after {
  content: '';
  position: absolute;
  top: 20px; right: -16px;
  width: 32px; height: 1px;
  background: var(--dp-accent-soft);
  opacity: 0.4;
}
.dp-step:last-child::after { display: none; }

/* ============================================================
   22. 푸터
============================================================ */
.site-footer {
  background: var(--dp-primary-3);
  color: rgba(255,255,255,.75);
  padding-block: clamp(48px, 7vw, 72px);
  font-size: 0.85rem;
  border-top: 4px solid var(--dp-accent);
}

.site-footer__inner {
  max-width: var(--dp-max-w);
  margin-inline: auto;
  padding-inline: var(--dp-gutter);
  display: grid;
  grid-template-columns: 2fr 1.5fr 1fr;
  gap: 40px;
}

.footer-logo {
  font-size: 1.2rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: 8px;
  letter-spacing: 0.04em;
}

.footer-logo span { color: var(--dp-accent); }
.footer-desc { color: rgba(255,255,255,.55); margin-bottom: 12px; line-height: 1.6; }
.footer-contact { color: rgba(255,255,255,.65); }
.footer-consult-link { color: var(--dp-accent); font-weight: 600; }

.footer-nav ul { display: flex; flex-direction: column; gap: 8px; }
.footer-nav a { color: rgba(255,255,255,.6); transition: color var(--dp-trans); line-height: 1.5; }
.footer-nav a:hover { color: #fff; }

.footer-social { display: flex; flex-direction: column; gap: 8px; }
.footer-social-link { color: rgba(255,255,255,.6); transition: color var(--dp-trans); }
.footer-social-link:hover { color: var(--dp-accent); }

.footer-legal {
  grid-column: 1 / -1;
  border-top: 1px solid rgba(255,255,255,.08);
  padding-top: 20px;
  color: rgba(255,255,255,.35);
  font-size: 0.78rem;
  line-height: 1.8;
}

.footer-copyright { margin-top: 4px; }

/* ============================================================
   23. CRO 컴포넌트
============================================================ */
.dp-urgency {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1100;
  background: var(--dp-primary-3);
  color: rgba(255,255,255,0.92);
  padding: 10px var(--dp-gutter);
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.85rem;
  font-weight: 600;
  box-shadow: 0 2px 8px rgba(0,0,0,.15);
}

.dp-urgency__dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--dp-accent);
  animation: pulse 1.5s ease-in-out infinite;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

.dp-urgency__text { flex: 1; }
.dp-urgency__cta {
  padding: 4px 14px;
  background: var(--dp-accent);
  color: #fff;
  border-radius: var(--dp-radius);
  font-size: 0.8rem;
  font-weight: 700;
  white-space: nowrap;
}
.dp-urgency__close { color: rgba(255,255,255,0.7); font-size: 1rem; opacity: .7; padding: 4px; }

.dp-mobile-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  z-index: 110;
  display: flex;
  box-shadow: 0 -2px 12px rgba(0,0,0,.12);
}

.dp-mobile-bar__btn {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 12px;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.dp-mobile-bar__btn--call {
  background: var(--dp-primary);
  color: #fff;
  border-right: 1px solid rgba(255,255,255,.15);
}

.dp-mobile-bar__btn--consult {
  background: var(--dp-accent);
  color: #fff;
}

.dp-floating {
  position: fixed;
  bottom: 32px; right: 32px;
  z-index: 110;
}

.dp-floating__btn {
  display: flex;
  align-items: center;
  padding: 14px 24px;
  background: var(--dp-accent);
  color: #fff;
  border-radius: 100px;
  font-size: 0.88rem;
  font-weight: 700;
  box-shadow: 0 4px 20px rgba(232,146,122,.35);
  transition: transform var(--dp-trans), box-shadow var(--dp-trans);
  white-space: nowrap;
}

.dp-floating__btn:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 28px rgba(232,146,122,.45);
}

/* ============================================================
   24. Breadcrumb / Page Hero
============================================================ */
.dp-breadcrumb {
  background: var(--dp-bg-soft);
  border-bottom: 1px solid var(--dp-border-soft);
  padding: 12px var(--dp-gutter);
}

.dp-breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 8px;
  max-width: var(--dp-max-w);
  margin-inline: auto;
  font-size: 0.8rem;
  color: var(--dp-text-muted);
}

.dp-breadcrumb ol li + li::before { content: '›'; margin-right: 8px; }
.dp-breadcrumb a { color: var(--dp-text-muted); }
.dp-breadcrumb a:hover { color: var(--dp-primary); }

.dp-page-hero {
  background: linear-gradient(140deg, var(--dp-primary-3) 0%, var(--dp-primary) 100%);
  padding: 0;
  min-height: clamp(360px, 50vh, 560px);
  display: flex;
  align-items: center;
}

.dp-page-hero__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: center;
  padding-block: clamp(48px, 8vw, 84px);
}

.dp-page-hero__copy { color: #fff; }

.dp-page-hero__title {
  font-size: var(--dp-fs-h1);
  font-weight: 200;
  color: #fff;
  line-height: 1.2;
  letter-spacing: -0.03em;
  margin-bottom: 20px;
}

.dp-page-hero__sub {
  font-size: var(--dp-fs-lede);
  color: rgba(255,255,255,.76);
  line-height: 1.7;
  margin-bottom: 28px;
  max-width: 440px;
  font-weight: 300;
}
.dp-portfolio-hero .dp-page-hero__sub,
.dp-consult-hero .dp-page-hero__sub {
  margin-inline: auto;
}

.dp-page-hero__media {
  border-radius: var(--dp-radius);
  overflow: hidden;
  aspect-ratio: 3/2;
  box-shadow: var(--dp-shadow-lg);
}

.dp-page-hero__media img,
.dp-page-hero__media .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
}

.dp-portfolio-hero,
.dp-consult-hero {
  min-height: clamp(240px, 35vh, 380px);
  display: flex;
  align-items: center;
}

.dp-consult-hero__title {
  font-size: var(--dp-fs-h1);
  font-weight: 200;
  color: #fff;
  margin-bottom: 16px;
  letter-spacing: -0.03em;
}

.dp-consult-hero__sub {
  font-size: var(--dp-fs-lede);
  color: rgba(255,255,255,.76);
  font-weight: 300;
}

/* ============================================================
   25. 상담·운영 정보
============================================================ */
.dp-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 28px;
  max-width: 840px;
  margin-inline: auto;
}

.dp-contact-card {
  background: var(--dp-bg);
  border-radius: var(--dp-radius);
  border: 1px solid var(--dp-border-soft);
  padding: 40px 32px;
  text-align: center;
  box-shadow: var(--dp-shadow-md);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  transition: transform var(--dp-trans);
}

.dp-contact-card:hover { transform: translateY(-4px); }
.dp-contact-card__icon { color: var(--dp-accent); }
.dp-contact-card__title { font-size: 1.25rem; font-weight: 700; color: var(--dp-text); }
.dp-contact-card__desc { font-size: 0.9rem; color: var(--dp-text-muted); line-height: 1.65; }
.dp-contact-card__phone { font-size: 1.4rem; font-weight: 800; color: var(--dp-primary); letter-spacing: -0.01em; }

.dp-operation__list { max-width: 640px; margin-inline: auto; display: flex; flex-direction: column; gap: 0; }
.dp-operation__item {
  display: grid; grid-template-columns: 120px 1fr;
  gap: 12px; padding: 16px 0;
  border-bottom: 1px solid var(--dp-border-soft);
  font-size: 0.92rem;
}
.dp-operation__item dt { font-weight: 700; color: var(--dp-text-sub); }
.dp-operation__item dd { color: var(--dp-text-muted); line-height: 1.6; }
.dp-operation__item dd a { color: var(--dp-primary); text-decoration: underline; }

/* 가이드 카드 — 연락카드와 너비 통일 */
.dp-guide-card {
  max-width: 840px;
  margin-inline: auto;
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  border-radius: var(--dp-radius);
  box-shadow: var(--dp-shadow-md);
  padding: 40px 40px 36px;
}
.dp-guide-card__title {
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--dp-text-sub);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--dp-border);
}
.dp-guide-list { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.dp-guide-list li { display: flex; align-items: flex-start; gap: 12px; font-size: 0.92rem; color: var(--dp-text-sub); line-height: 1.6; }
.dp-guide-list li::before { content: '✓'; color: var(--dp-primary); font-weight: 700; font-size: 0.9em; flex-shrink: 0; margin-top: 2px; }
.dp-guide-note {
  font-size: 0.85rem; color: var(--dp-text-muted);
  background: var(--dp-bg-soft); padding: 12px 16px;
  border-left: 3px solid var(--dp-accent);
  border-radius: 0 var(--dp-radius) var(--dp-radius) 0;
}

/* 미니멀 운영정보 */
.dp-operation-minimal {
  padding-block: 28px;
  border-top: 1px solid var(--dp-border);
}
.dp-operation-minimal__text {
  font-size: 0.82rem;
  color: var(--dp-text-muted);
  text-align: center;
  line-height: 2;
}
.dp-operation-minimal__text strong { color: var(--dp-text-sub); font-weight: 600; }

/* ============================================================
   26. 관련 서비스 (legacy dp-related)
============================================================ */
.dp-related__title { font-size: 1.15rem; font-weight: 700; color: var(--dp-text); margin-bottom: 16px; }
.dp-related__list { display: flex; flex-wrap: wrap; gap: 10px; }
.dp-related__list a {
  display: inline-block; padding: 9px 20px;
  border: 1px solid var(--dp-border); border-radius: 100px;
  font-size: 0.85rem; font-weight: 600; color: var(--dp-text-sub);
  transition: all var(--dp-trans);
}
.dp-related__list a:hover { background: var(--dp-primary); color: #fff; border-color: var(--dp-primary); }

/* ============================================================
   27. img-placeholder
============================================================ */
.img-placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--dp-bg-soft);
  width: 100%;
  height: 100%;
}

/* ============================================================
   28. 반응형
============================================================ */
@media (min-width: 1024px) {
  .fp-core-section__badge-card { display: block; }
}

/* PC: 모바일 바 완전 차단, floating만 표시 */
@media (min-width: 769px) {
  .dp-mobile-bar { display: none !important; }
  .dp-floating { display: block; }
}

@media (max-width: 1024px) {
  .site-footer__inner { grid-template-columns: 1fr 1fr; }
  .footer-legal { grid-column: 1 / -1; }
}

@media (max-width: 768px) {
  /* Header */
  .header-nav, .header-cta { display: none; }
  .mobile-toggle { display: flex; }
  .header-inner { padding: 0 20px; }

  /* Hero head */
  .fp-hero-head { padding: clamp(32px, 6vw, 56px) 0 0; }

  /* Case grids */
  .fp-case__grid { grid-template-columns: 1fr; }
  .fp-case__desc { grid-template-columns: 1fr; }
  .fp-case__desc--reverse { grid-template-columns: 1fr; }
  .fp-case__desc--reverse h2 { text-align: left; order: -1; }

  /* Core section */
  .fp-core-section__grid { grid-template-columns: 1fr; }
  .fp-core-section__media { display: none; }

  /* Trust */
  .fp-trust__stats { grid-template-columns: repeat(2, 1fr); }
  .fp-trust__reviews { grid-template-columns: 1fr; }

  /* Process */
  .fp-process__container { max-width: 100%; }

  /* Services nav */
  .fp-services-nav__grid { grid-template-columns: repeat(2, 1fr); }

  /* Gallery */
  .dp-gallery-grid { grid-template-columns: 1fr 1fr; }

  /* CTA Banner */
  .dp-cta-banner__grid { grid-template-columns: 1fr; }
  .dp-cta-banner__media { aspect-ratio: 16/9; }

  /* Service cards */
  .dp-service-grid { grid-template-columns: 1fr 1fr; }

  /* Service detail */
  .dp-service-detail__grid { grid-template-columns: 1fr; }
  .dp-service-detail__media { order: -1; }

  /* Contact */
  .dp-contact-grid { grid-template-columns: 1fr; }

  /* Footer */
  .site-footer__inner { grid-template-columns: 1fr; gap: 24px; }

  /* Page hero */
  .dp-page-hero__grid { grid-template-columns: 1fr; }
  .dp-page-hero__media { display: none; }

  /* CRO: 모바일에서 floating 완전 차단 */
  .dp-floating { display: none !important; }

  /* Op table */
  .dp-operation__item { grid-template-columns: 100px 1fr; }

  /* Steps */
  .dp-steps { grid-template-columns: 1fr; }
  .dp-step::after { display: none; }
}

@media (max-width: 480px) {
  .fp-services-nav__grid { grid-template-columns: 1fr; }
  .dp-service-grid { grid-template-columns: 1fr; }
  .dp-gallery-grid { grid-template-columns: 1fr; }
  .dp-portfolio-list { grid-template-columns: 1fr; }
  .dp-cta { width: 100%; justify-content: center; }
  .dp-hero__actions { flex-direction: column; }
}

/* ─── 사이트맵 ─── */
/* ── 사이트맵 (레거시 호환) ── */
.dp-sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 48px 40px;
  padding-block: clamp(40px, 6vw, 72px);
}
.dp-sitemap-group__title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dp-primary);
  margin-bottom: 16px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--dp-border);
}
.dp-sitemap-list { display: flex; flex-direction: column; gap: 10px; }
.dp-sitemap-list a {
  font-size: 0.9rem;
  color: var(--dp-text-sub);
  text-decoration: none;
  transition: color 0.25s, padding-left 0.25s;
  display: block;
}
.dp-sitemap-list a:hover {
  color: var(--dp-primary);
  padding-left: 6px;
}

/* ============================================================
   사이트맵 재설계 (sm-*)
============================================================ */
.sm-hero {
  padding: clamp(48px, 8vw, 80px) 0 clamp(32px, 5vw, 56px);
  background: var(--dp-bg);
}
.sm-hero__title {
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  line-height: 1.1;
  margin: 0 0 16px;
  color: var(--dp-text);
}
.sm-hero__sub {
  font-size: 13px;
  color: var(--dp-text-muted);
  letter-spacing: 0.06em;
}

.sm-body { padding-top: 0; }

/* 4-블록 그리드 */
.sm-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2px;
  background: var(--dp-border);
  border: 1px solid var(--dp-border);
}

/* 카테고리 블록 */
.sm-cat {
  background: var(--dp-bg);
  padding: clamp(28px, 4vw, 48px) clamp(24px, 3vw, 40px);
}

/* 카테고리 헤더 */
.sm-cat__hd {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 28px;
  padding-bottom: 20px;
  border-bottom: 2px solid currentColor;
}
.sm-cat--service  .sm-cat__hd { border-color: var(--dp-text); }
.sm-cat--area     .sm-cat__hd { border-color: var(--dp-accent); }
.sm-cat--portfolio .sm-cat__hd { border-color: var(--dp-text-sub); }
.sm-cat--links    .sm-cat__hd { border-color: var(--dp-text-muted); }

.sm-cat__num {
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: clamp(28px, 3.5vw, 40px);
  line-height: 1;
  font-weight: 400;
  flex-shrink: 0;
}
.sm-cat--service  .sm-cat__num { color: var(--dp-text); opacity: .2; }
.sm-cat--area     .sm-cat__num { color: var(--dp-accent); opacity: .5; }
.sm-cat--portfolio .sm-cat__num { color: var(--dp-text-sub); opacity: .25; }
.sm-cat--links    .sm-cat__num { color: var(--dp-text-muted); opacity: .4; }

.sm-cat__title {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dp-text);
  margin-bottom: 4px;
}
.sm-cat__desc {
  font-size: 12px;
  color: var(--dp-text-muted);
  line-height: 1.5;
}

/* 아이템 리스트 */
.sm-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0;
}
.sm-list__item {
  padding: 11px 0;
  border-bottom: 1px solid var(--dp-border);
}
.sm-list__item:last-child { border-bottom: none; }

.sm-list__item a {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 600;
  color: var(--dp-text);
  text-decoration: none;
  transition: color 0.2s;
}
.sm-list__item a:hover { color: var(--dp-accent); }
.sm-list__item a:hover .sm-list__arrow { transform: translateX(3px); }

.sm-list__arrow {
  font-size: 12px;
  color: var(--dp-text-muted);
  transition: transform 0.2s;
  flex-shrink: 0;
}
.sm-cat--area .sm-list__item a:hover { color: var(--dp-accent); }

.sm-list__kw {
  display: block;
  font-size: 11px;
  color: var(--dp-text-muted);
  margin-top: 3px;
  padding-left: 18px;
  line-height: 1.5;
}
.sm-list__region {
  color: var(--dp-accent);
  font-weight: 500;
}

/* 시공사례 전체보기 버튼 */
.sm-list__item--more {
  padding-top: 14px;
  border-bottom: none;
}
.sm-list__item--more a {
  font-size: 13px;
  font-weight: 700;
  color: var(--dp-text-muted);
  letter-spacing: 0.02em;
}
.sm-list__item--more a:hover { color: var(--dp-text); }

/* 기타 */
.sm-note {
  margin-top: 16px;
  font-size: 11px;
  color: var(--dp-text-muted);
  padding: 8px 12px;
  background: var(--dp-bg-soft);
  border-radius: 4px;
}
.sm-cat__cta {
  margin-top: 24px;
}

@media (max-width: 640px) {
  .sm-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   지역 페이지 (al-*) — area local template
============================================================ */

/* ── Hero ── */
.al-hero {
  padding: clamp(48px, 8vw, 88px) 0 clamp(32px, 5vw, 64px);
  background: var(--dp-bg);
  overflow: hidden;
}
.al-hero__inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.al-hero__eyebrow {
  display: block;
  margin-bottom: 16px;
}
.al-hero__title {
  font-size: var(--dp-fs-display);
  font-weight: 200;
  letter-spacing: -0.05em;
  line-height: 1.05;
  margin-bottom: 20px;
}
.al-hero__t1 {
  display: block;
  animation: heroW1Up 0.75s cubic-bezier(0.22,1,0.36,1) 0.15s both;
}
.al-hero__t2 {
  display: block;
  color: var(--dp-accent);
  font-style: normal;
  animation: heroW2Up 0.75s cubic-bezier(0.22,1,0.36,1) 0.28s both;
}
.al-hero__sub {
  font-size: 15px;
  color: var(--dp-text-muted);
  line-height: 1.8;
  max-width: 420px;
  margin-bottom: 28px;
  animation: heroSubFade 0.6s ease 0.55s both;
}
.al-hero__actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 12px;
  animation: heroSubFade 0.6s ease 0.65s both;
}
.al-hero__media {
  border-radius: 2px;
  overflow: hidden;
  aspect-ratio: 4/3;
  animation: heroSubFade 0.8s ease 0.2s both;
}
.al-hero__media img,
.al-hero__media .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
}

/* ── 서비스 베리에이션 카드 ── */
.al-var-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 20px;
  margin-top: 40px;
}
.al-var-card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  border-top: 3px solid var(--dp-text);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-top-color 0.25s, box-shadow 0.25s, transform 0.25s;

  /* 초기 상태: 숨김 */
  opacity: 0;
  transform: translateY(32px);
}
.al-var-grid.is-visible .al-var-card {
  animation: varCardIn 0.55s cubic-bezier(0.22,1,0.36,1) calc(0.05s + var(--vi,0) * 0.1s) forwards;
}
@keyframes varCardIn {
  from { opacity: 0; transform: translateY(32px); }
  to   { opacity: 1; transform: translateY(0); }
}
.al-var-card:hover {
  border-top-color: var(--dp-accent);
  box-shadow: 0 8px 32px rgba(0,0,0,.08);
  transform: translateY(-3px);
}
.al-var-card__num {
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: 28px;
  color: var(--dp-text);
  opacity: .15;
  line-height: 1;
}
.al-var-card__title {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dp-text);
  line-height: 1.35;
}
.al-var-card__desc {
  font-size: 13px;
  color: var(--dp-text-muted);
  line-height: 1.7;
  flex: 1;
}
.al-var-card__cta {
  font-size: 12px;
  font-weight: 700;
  color: var(--dp-accent);
  letter-spacing: 0.03em;
  margin-top: 6px;
  transition: letter-spacing 0.2s;
}
.al-var-card:hover .al-var-card__cta { letter-spacing: 0.08em; }

/* ── 지역 특화 ── */
.al-local__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: center;
}
.al-local__title {
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 200;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin: 12px 0 16px;
}
.al-local__desc {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.9;
  margin-bottom: 20px;
}
.al-local__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.al-local__tag {
  font-size: 12px;
  padding: 4px 12px;
  border: 1px solid var(--dp-border);
  border-radius: 3px;
  color: var(--dp-text-sub);
}
.al-local__tag--more {
  border-color: var(--dp-accent);
  color: var(--dp-accent);
  font-weight: 600;
}
.al-local__media {
  overflow: hidden;
  border-radius: 2px;
  aspect-ratio: 4/3;
}
.al-local__media img,
.al-local__media .img-placeholder { width:100%; height:100%; object-fit:cover; }

/* ── 시공 과정 ── */
.al-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  background: var(--dp-border);
  margin-top: 40px;
}
.al-step {
  background: var(--dp-bg);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  transition: background 0.25s;
}
.al-step:hover { background: var(--dp-bg-warm); }
.al-step__num {
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: 32px;
  color: var(--dp-accent);
  opacity: .5;
  line-height: 1;
}
.al-step__title {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dp-text);
}
.al-step__desc {
  font-size: 13px;
  color: var(--dp-text-muted);
  line-height: 1.75;
}

/* ── FAQ ── */
.al-faq__inner {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}
.al-faq__head { position: sticky; top: 80px; }
.al-faq__title {
  font-size: clamp(22px, 3vw, 32px);
  font-weight: 200;
  letter-spacing: -0.03em;
  line-height: 1.3;
  margin-top: 12px;
}
.al-faq__list { display: flex; flex-direction: column; }
.al-faq__item {
  border-bottom: 1px solid var(--dp-border);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.4s ease calc(0.05s + var(--fi,0) * 0.06s),
              transform 0.4s ease calc(0.05s + var(--fi,0) * 0.06s);
}
.al-faq__item.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.al-faq__toggle {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 0;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
}
.al-faq__q {
  font-size: 15px;
  font-weight: 600;
  color: var(--dp-text);
  letter-spacing: -0.01em;
  line-height: 1.4;
}
.al-faq__icon {
  font-size: 20px;
  color: var(--dp-text-muted);
  flex-shrink: 0;
  transition: transform 0.3s, color 0.2s;
  font-family: Georgia, serif;
}
.al-faq__toggle[aria-expanded="true"] .al-faq__icon {
  transform: rotate(45deg);
  color: var(--dp-accent);
}
.al-faq__answer {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.38s cubic-bezier(0.22,1,0.36,1);
}
.al-faq__a {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.85;
  padding-bottom: 20px;
}

/* ── CTA ── */
.al-cta { background: var(--dp-primary-3); }
.al-cta__inner {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 40px;
  align-items: center;
}
.al-cta__title {
  font-size: clamp(24px, 3.5vw, 38px);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: #fff;
  line-height: 1.25;
}
.al-cta__sub {
  font-size: 14px;
  color: rgba(255,255,255,.45);
  margin-top: 8px;
}
.al-cta__actions {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-end;
}

/* ── 반응형 ── */
@media (max-width: 900px) {
  .al-hero__inner,
  .al-local__grid { grid-template-columns: 1fr; }
  .al-hero__media { display: none; }
  .al-steps { grid-template-columns: 1fr 1fr; }
  .al-faq__inner { grid-template-columns: 1fr; }
  .al-faq__head { position: static; }
  .al-cta__inner { grid-template-columns: 1fr; }
  .al-cta__actions { align-items: flex-start; }
}
@media (max-width: 600px) {
  .al-steps { grid-template-columns: 1fr; }
  .al-var-grid { grid-template-columns: 1fr; }
}

/* ── FAQ 스크롤 IntersectionObserver용 ── */
.al-faq__item.is-visible { opacity: 1; transform: translateY(0); }

/* ── 사이트맵 서비스지역 베리에이션 ── */
.sm-area-group {
  padding: 12px 0;
  border-bottom: 1px solid var(--dp-border);
}
.sm-area-group:last-of-type { border-bottom: none; }
.sm-area-group__hd {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 700;
  color: var(--dp-text);
  text-decoration: none;
  margin-bottom: 6px;
  transition: color 0.2s;
}
.sm-area-group__hd:hover { color: var(--dp-accent); }
.sm-var-list {
  list-style: none;
  padding: 0 0 0 18px;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.sm-var-list__item {
  font-size: 12px;
  color: var(--dp-text-muted);
  display: flex;
  gap: 6px;
}
.sm-var-list__dot { color: var(--dp-accent); opacity: .6; }

/* ============================================================
   35. 서비스 상세 페이지 공통 — sv-* 컴포넌트
============================================================ */

/* Pain Points ("이런 분이라면") */
.sv-pain {
  background: var(--dp-bg-soft);
}
.sv-pain__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
  margin-top: 36px;
}
.sv-pain__card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  border-left: 3px solid var(--dp-accent);
  padding: 18px 20px;
  display: flex;
  align-items: flex-start;
  gap: 12px;
  border-radius: 2px;
}
.sv-pain__mark {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--dp-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 2px;
}
.sv-pain__mark::after {
  content: '';
  display: block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #fff;
}
.sv-pain__text {
  font-size: 14px;
  color: var(--dp-text);
  line-height: 1.65;
}

/* 차별화 스펙 수치 */
.sv-specs__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--dp-border);
  border: 1px solid var(--dp-border);
  margin-top: 40px;
  border-radius: var(--dp-radius);
  overflow: hidden;
}
.sv-specs__item {
  background: var(--dp-bg);
  padding: clamp(24px, 3.5vw, 40px) clamp(16px, 2.5vw, 28px);
  text-align: center;
}
.sv-specs__num {
  font-size: clamp(32px, 4.5vw, 52px);
  font-weight: 200;
  color: var(--dp-primary);
  line-height: 1;
  letter-spacing: -0.04em;
  margin-bottom: 6px;
}
.sv-specs__label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--dp-text-muted);
  text-transform: uppercase;
}
.sv-specs__sub {
  font-size: 11px;
  color: var(--dp-text-muted);
  margin-top: 4px;
  opacity: .7;
}

/* 서비스 본문 풍부 콘텐츠 */
.sv-body {
  background: var(--dp-bg);
}
.sv-body__grid {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}
.sv-body__content p {
  font-size: 15px;
  color: var(--dp-text-muted);
  line-height: 1.85;
  margin-bottom: 20px;
}
.sv-body__content p:last-of-type { margin-bottom: 0; }
.sv-body__media {
  border-radius: var(--dp-radius);
  overflow: hidden;
  aspect-ratio: 3/4;
  position: sticky;
  top: 100px;
}
.sv-body__media img,
.sv-body__media .img-placeholder {
  width: 100%; height: 100%; object-fit: cover;
}

/* 프로세스 (sv 버전) */
.sv-process {
  background: var(--dp-bg-soft);
}
.sv-steps {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 0;
  margin-top: 40px;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  overflow: hidden;
}
.sv-step {
  padding: 28px 24px;
  border-right: 1px solid var(--dp-border);
  background: var(--dp-bg);
  position: relative;
}
.sv-step:last-child { border-right: none; }
.sv-step__num {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  color: var(--dp-accent);
  margin-bottom: 10px;
}
.sv-step__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--dp-text);
  margin-bottom: 8px;
  line-height: 1.3;
}
.sv-step__desc {
  font-size: 13px;
  color: var(--dp-text-muted);
  line-height: 1.7;
}

/* 반응형 */
@media (max-width: 900px) {
  .sv-specs__grid { grid-template-columns: repeat(3, 1fr); }
  .sv-body__grid { grid-template-columns: 1fr; }
  .sv-body__media { aspect-ratio: 4/3; position: static; }
}
@media (max-width: 640px) {
  .sv-specs__grid { grid-template-columns: 1fr; }
  .sv-steps { grid-template-columns: 1fr; }
  .sv-step { border-right: none; border-bottom: 1px solid var(--dp-border); }
  .sv-step:last-child { border-bottom: none; }
}

/* ============================================================
   36. 서비스 페이지 고도화 — sv2-* 비주얼 컴포넌트
============================================================ */

/* ── 강조 콜아웃 박스 ── */
.sv2-callout {
  background: var(--dp-primary-3);
  color: #fff;
  border-radius: var(--dp-radius);
  padding: clamp(32px, 5vw, 56px) clamp(24px, 4vw, 48px);
  position: relative;
  overflow: hidden;
}
.sv2-callout::before {
  content: '';
  position: absolute;
  top: -40px; right: -40px;
  width: 180px; height: 180px;
  border-radius: 50%;
  background: rgba(255,255,255,.05);
}
.sv2-callout__eyebrow {
  display: inline-block;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 14px;
}
.sv2-callout__title {
  font-size: clamp(20px, 3vw, 30px);
  font-weight: 700;
  line-height: 1.35;
  margin-bottom: 20px;
  letter-spacing: -0.02em;
}
.sv2-callout__body {
  font-size: 15px;
  line-height: 1.85;
  color: rgba(255,255,255,.82);
  max-width: 640px;
}
.sv2-callout__body strong {
  color: var(--dp-accent);
  font-weight: 700;
}

/* ── 아이콘 카드 그리드 ── */
.sv2-icon-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
  margin-top: 36px;
}
.sv2-icon-card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  transition: border-color .2s, box-shadow .2s;
}
.sv2-icon-card * {
  text-align: center !important;
}
.sv2-icon-card:hover {
  border-color: var(--dp-primary);
  box-shadow: 0 4px 20px rgba(110,158,130,.12);
}
.sv2-icon-card__icon {
  width: 48px; height: 48px;
  border-radius: 12px;
  background: var(--dp-bg-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
  margin: 0 auto;
}
.sv2-icon-card__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--dp-text);
  line-height: 1.3;
  width: 100%;
  text-align: center;
}
.sv2-icon-card__desc {
  font-size: 13px;
  color: var(--dp-text-muted);
  line-height: 1.7;
  width: 100%;
  text-align: center;
}

/* ── 비교 테이블 ── */
.sv2-compare {
  margin-top: 40px;
  border-radius: var(--dp-radius);
  overflow: hidden;
  border: 1px solid var(--dp-border);
}
.sv2-compare__head {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}
.sv2-compare__head-cell {
  padding: 14px 20px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-align: center;
}
.sv2-compare__head-cell:first-child {
  background: var(--dp-bg-soft);
  color: var(--dp-text-muted);
}
.sv2-compare__head-cell:nth-child(2) {
  background: var(--dp-primary-3);
  color: #fff;
}
.sv2-compare__head-cell:nth-child(3) {
  background: #f0f0f0;
  color: #888;
}
.sv2-compare__row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  border-top: 1px solid var(--dp-border);
}
.sv2-compare__row:nth-child(even) { background: var(--dp-bg-soft); }
.sv2-compare__cell {
  padding: 14px 20px;
  font-size: 13px;
  color: var(--dp-text-muted);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}
.sv2-compare__cell:first-child {
  font-weight: 600;
  color: var(--dp-text);
  text-align: left;
  justify-content: flex-start;
}
.sv2-compare__cell--yes {
  color: var(--dp-primary);
  font-weight: 700;
}
.sv2-compare__cell--no {
  color: #bbb;
}
.sv2-compare__badge-yes::before { content: '✓ '; }
.sv2-compare__badge-no::before  { content: '✗ '; }

/* ── 숫자 강조 인라인 스탯 ── */
.sv2-stats-row {
  display: flex;
  gap: 0;
  margin-top: 40px;
  border: 1px solid var(--dp-border);
  border-radius: var(--dp-radius);
  overflow: hidden;
}
.sv2-stat {
  flex: 1;
  padding: clamp(20px, 3vw, 36px) 20px;
  text-align: center;
  border-right: 1px solid var(--dp-border);
  background: var(--dp-bg);
}
.sv2-stat:last-child { border-right: none; }
.sv2-stat__num {
  font-size: clamp(28px, 4vw, 48px);
  font-weight: 200;
  color: var(--dp-primary);
  letter-spacing: -0.04em;
  line-height: 1;
  display: block;
  margin-bottom: 4px;
}
.sv2-stat__label {
  font-size: 12px;
  font-weight: 700;
  color: var(--dp-text-muted);
  letter-spacing: 0.06em;
  display: block;
}
.sv2-stat__sub {
  font-size: 11px;
  color: var(--dp-text-muted);
  opacity: .7;
  margin-top: 4px;
  display: block;
}

/* ── 시각적 체크리스트 ── */
.sv2-checklist {
  list-style: none;
  padding: 0;
  margin: 24px 0 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sv2-checklist li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
  color: var(--dp-text);
  line-height: 1.6;
}
.sv2-checklist li::before {
  content: '';
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--dp-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 10'%3E%3Cpath d='M1 5l3.5 3.5L11 1' stroke='%23fff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px;
  margin-top: 1px;
}

/* ── 페인포인트 번호 카드 ── */
.sv2-pain-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
  margin-top: 32px;
}
.sv2-pain-card {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 20px;
  background: var(--dp-bg);
  border-radius: var(--dp-radius);
  border: 1px solid var(--dp-border);
}
.sv2-pain-card__num {
  flex-shrink: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: var(--dp-accent-pale);
  color: var(--dp-accent);
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}
.sv2-pain-card__text {
  font-size: 14px;
  color: var(--dp-text);
  line-height: 1.65;
}

/* ── 프로세스 타임라인 ── */
.sv2-process-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin-top: 40px;
  counter-reset: sv2step;
}
.sv2-process-item {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 0 24px;
  position: relative;
}
.sv2-process-item:not(:last-child) .sv2-process-item__line {
  position: absolute;
  left: 27px; top: 52px;
  width: 2px;
  bottom: 0;
  background: var(--dp-border);
}
.sv2-process-item__num {
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--dp-primary-3);
  color: #fff;
  font-size: 18px;
  font-weight: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  letter-spacing: -0.02em;
  position: relative;
  z-index: 1;
}
.sv2-process-item__body {
  padding: 12px 0 36px;
}
.sv2-process-item:last-child .sv2-process-item__body { padding-bottom: 0; }
.sv2-process-item__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--dp-text);
  margin-bottom: 6px;
  line-height: 1.3;
}
.sv2-process-item__desc {
  font-size: 14px;
  color: var(--dp-text-muted);
  line-height: 1.75;
}

/* ── 반응형 ── */
@media (max-width: 640px) {
  .sv2-icon-grid { grid-template-columns: 1fr 1fr; }
  .sv2-stats-row { flex-direction: column; }
  .sv2-stat { border-right: none; border-bottom: 1px solid var(--dp-border); }
  .sv2-stat:last-child { border-bottom: none; }
  .sv2-compare__head,
  .sv2-compare__row { grid-template-columns: 1fr 1fr 1fr; }
}

/* ============================================================
   37. sv3 — 아이콘 카드 재설계 (좌정렬 기반)
============================================================ */
.sv3-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 40px;
}
.sv3-card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  border-top: 4px solid var(--dp-primary);
  border-radius: 0 0 var(--dp-radius) var(--dp-radius);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.sv3-card__emoji {
  font-size: 32px;
  line-height: 1;
}
.sv3-card__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--dp-text);
  line-height: 1.35;
}
.sv3-card__desc {
  font-size: 15px;
  color: #3d5045;
  line-height: 1.85;
}
@media (max-width: 720px) {
  .sv3-cards { grid-template-columns: 1fr; }
}

/* ============================================================
   케이스 세부 페이지
============================================================ */
.dp-case-detail-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-lg);
}
.dp-case-detail-pair__fig {
  position: relative;
  aspect-ratio: 4/3;
  margin: 0;
  overflow: hidden;
}
.dp-case-detail-pair__fig img,
.dp-case-detail-pair__fig .img-placeholder {
  width: 100%; height: 100%;
  object-fit: cover;
}
.dp-case-detail-pair__cap {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 12px 16px;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: #fff;
}
.dp-case-detail-pair__cap--before { background: rgba(0,0,0,.5); }
.dp-case-detail-pair__cap--after  { background: var(--dp-primary); }

.dp-case-detail-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 72px);
  align-items: start;
}
.dp-case-detail-info__title {
  font-size: clamp(20px, 2.5vw, 28px);
  font-weight: 700;
  margin-bottom: 16px;
  letter-spacing: -0.02em;
}
.dp-case-detail-info__content {
  font-size: 15px;
  line-height: 1.8;
  color: var(--dp-text-muted);
}
.dp-case-detail-cta {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  border-radius: var(--dp-radius);
  padding: clamp(28px, 4vw, 48px);
  text-align: center;
}
@media (max-width: 760px) {
  .dp-case-detail-pair { grid-template-columns: 1fr; }
  .dp-case-detail-body  { grid-template-columns: 1fr; }
}

/* 포트폴리오 목록 → 세부 링크 표시 */
.dp-portfolio-item--linked {
  cursor: pointer;
  text-decoration: none;
  color: inherit;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-top: 1px solid var(--dp-border);
  transition: background 0.3s;
}
.dp-portfolio-item--linked:hover { background: var(--dp-bg-soft); }
.dp-portfolio-item--linked:last-child { border-bottom: 1px solid var(--dp-border); }
.dp-portfolio-item--linked:hover .dp-portfolio-pair__fig img { transform: scale(1.04); }
.dp-portfolio-item__arrow {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-top: 16px;
  font-size: 13px;
  font-weight: 700;
  color: var(--dp-accent);
  letter-spacing: 0.02em;
}


/* ============================================================
   포트폴리오 케이스 세부 페이지 (pc-*)
============================================================ */

/* ── 히어로: 그라디언트 배경, 이미지 없음 ── */
.pc-hero {
  background: linear-gradient(135deg, var(--dp-primary) 0%, var(--dp-primary-2, #1e3a6e) 100%);
  padding: clamp(56px, 9vw, 100px) 0 clamp(48px, 7vw, 80px);
}
.pc-hero__inner { max-width: 720px; }
.pc-hero__tag {
  display: inline-block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--dp-accent);
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.2);
  padding: 5px 14px;
  border-radius: 100px;
  margin-bottom: 20px;
}
.pc-hero__title {
  font-size: clamp(26px, 4vw, 44px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin-bottom: 18px;
}
.pc-hero__lead {
  font-size: clamp(15px, 1.8vw, 18px);
  color: rgba(255,255,255,.8);
  line-height: 1.7;
  max-width: 600px;
  margin-bottom: 32px;
}
.pc-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 28px;
  font-size: 13px;
  color: rgba(255,255,255,.65);
}
.pc-hero__meta strong {
  display: block;
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 2px;
}

/* ── Before/After ── */
.pc-pair-section { padding-top: 0; margin-top: -1px; }
.pc-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-lg);
}
.pc-pair__fig {
  position: relative;
  aspect-ratio: 4/3;
  margin: 0;
  overflow: hidden;
}
.pc-pair__fig img,
.pc-pair__fig .img-placeholder {
  width: 100%; height: 100%;
  object-fit: cover;
}
.pc-pair__cap {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 12px 16px;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: #fff;
}
.pc-pair__cap--before { background: rgba(0,0,0,.55); }
.pc-pair__cap--after  { background: var(--dp-primary); }
@media (max-width: 580px) {
  .pc-pair { grid-template-columns: 1fr; }
}

/* ── 본문 + 사이드바 ── */
.pc-body-grid {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: clamp(32px, 5vw, 64px);
  align-items: start;
}
.pc-body__block {
  margin-bottom: 48px;
}
.pc-body__block:last-child { margin-bottom: 0; }
.pc-body__heading {
  font-size: clamp(17px, 2vw, 22px);
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--dp-text);
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid var(--dp-border-soft);
}
.pc-body__text {
  font-size: 15px;
  line-height: 1.95;
  color: var(--dp-text-muted);
}
.pc-point {
  background: rgba(var(--dp-accent-rgb, 232,146,122), 0.06);
  border-left: 4px solid var(--dp-accent);
  padding: 24px 28px;
  border-radius: 0 var(--dp-radius) var(--dp-radius) 0;
}
.pc-point .pc-body__heading {
  border-bottom-color: rgba(var(--dp-accent-rgb, 232,146,122), 0.25);
}

/* 시공 과정 번호 리스트 */
.pc-process-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.pc-process-step {
  display: flex;
  gap: 20px;
  align-items: flex-start;
}
.pc-process-step__num {
  flex-shrink: 0;
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--dp-primary);
  color: #fff;
  font-size: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  letter-spacing: 0;
  margin-top: 2px;
}
.pc-process-step__title {
  font-size: 15px;
  font-weight: 700;
  color: var(--dp-text);
  margin-bottom: 7px;
  letter-spacing: -0.01em;
}
.pc-process-step__desc {
  font-size: 14px;
  line-height: 1.85;
  color: var(--dp-text-muted);
}

/* ── 사이드바 ── */
.pc-aside {
  position: sticky;
  top: 100px;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.pc-spec-box {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  border-radius: var(--dp-radius);
  padding: 28px 24px;
}
.pc-spec-box__title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-bottom: 18px;
  padding-bottom: 14px;
  border-bottom: 2px solid var(--dp-primary);
  color: var(--dp-text);
}
.pc-spec-table {
  width: 100%;
  border-collapse: collapse;
}
.pc-spec-table th,
.pc-spec-table td {
  padding: 10px 0;
  font-size: 13px;
  border-bottom: 1px solid var(--dp-border-soft);
  text-align: left;
  vertical-align: top;
}
.pc-spec-table th {
  color: var(--dp-text-muted);
  font-weight: 600;
  width: 38%;
  padding-right: 8px;
}
.pc-spec-table td { color: var(--dp-text); font-weight: 500; }
.pc-spec-table tr:last-child th,
.pc-spec-table tr:last-child td { border-bottom: none; }
.pc-warranty-mini {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.pc-warranty-mini li {
  font-size: 13px;
  color: var(--dp-text-muted);
  display: flex;
  gap: 8px;
  line-height: 1.5;
}
.pc-warranty-mini li::before {
  content: '✓';
  color: var(--dp-accent);
  font-weight: 800;
  flex-shrink: 0;
}
@media (max-width: 900px) {
  .pc-body-grid { grid-template-columns: 1fr; }
  .pc-aside { position: static; }
}

/* ── 관련 시공사례 ── */
.pc-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 40px;
}
.pc-related-card {
  display: block;
  text-decoration: none;
  border-radius: var(--dp-radius);
  overflow: hidden;
  border: 1px solid var(--dp-border-soft);
  transition: box-shadow 0.3s, transform 0.3s;
  color: inherit;
}
.pc-related-card:hover {
  box-shadow: var(--dp-shadow-lg);
  transform: translateY(-4px);
}
.pc-related-card__img {
  aspect-ratio: 4/3;
  overflow: hidden;
}
.pc-related-card__img img,
.pc-related-card__img .img-placeholder {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.pc-related-card:hover .pc-related-card__img img { transform: scale(1.05); }
.pc-related-card__body {
  padding: 18px 20px 20px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.pc-related-card__region {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dp-accent);
}
.pc-related-card__title {
  font-size: 14px;
  font-weight: 700;
  color: var(--dp-text);
  line-height: 1.4;
}
.pc-related-card__more {
  font-size: 12px;
  color: var(--dp-text-muted);
  margin-top: 6px;
}
@media (max-width: 760px) {
  .pc-related-grid { grid-template-columns: 1fr; }
}

/* ── 최종 CTA ── */
.pc-final-cta { padding: clamp(56px, 8vw, 96px) 0; }
.pc-final-cta__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  flex-wrap: wrap;
}
.pc-final-cta__title {
  font-size: clamp(22px, 3vw, 34px);
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1.3;
  margin-bottom: 10px;
}
.pc-final-cta__sub {
  font-size: 14px;
  color: rgba(255,255,255,.65);
  line-height: 1.6;
}
.pc-final-cta__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  flex-shrink: 0;
}
@media (max-width: 700px) {
  .pc-final-cta__inner { flex-direction: column; align-items: flex-start; }
}

/* ── 지역 맞춤 서비스 (service_variations) ── */
.al-svlist { background: var(--dp-bg-alt, #f8f7f4); }
.al-svlist__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
  margin-top: 40px;
  list-style: none;
  padding: 0;
}
.al-svlist__item {
  background: #fff;
  border: 1px solid var(--dp-border, #e8e4e0);
  border-radius: 8px;
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.al-svlist__icon { font-size: 28px; line-height: 1; }
.al-svlist__title {
  font-size: clamp(15px, 1.6vw, 17px);
  font-weight: 700;
  color: var(--dp-primary, #1a2b4a);
  letter-spacing: -0.02em;
  margin: 0;
}
.al-svlist__desc {
  font-size: 14px;
  color: var(--dp-text-muted, #666);
  line-height: 1.65;
  margin: 0;
}

/* ── 지역 간 내부 링크 ── */
.dp-related__areas { margin-top: 28px; padding-top: 20px; border-top: 1px solid var(--dp-border, #e8e4e0); }
.dp-related__areas-label {
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--dp-text-muted, #888);
  margin-bottom: 10px;
}
.dp-related__areas-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.dp-related__areas-list a {
  display: inline-block;
  padding: 5px 14px;
  border: 1px solid var(--dp-border, #e8e4e0);
  border-radius: 100px;
  font-size: 13px;
  color: var(--dp-primary, #1a2b4a);
  text-decoration: none;
  transition: background .2s, border-color .2s;
}
.dp-related__areas-list a:hover { background: var(--dp-primary, #1a2b4a); color: #fff; border-color: var(--dp-primary, #1a2b4a); }

/* ── 마이크로데이터 숨김 헬퍼 ── */
.dp-hidden { display: none !important; }

/* ════════════════════════════════════════════════════════
   정보성 포스트 본문 (single.php) — .roots-prose
════════════════════════════════════════════════════════ */
.roots-prose {
  font-size: var(--dp-fs-body);
  line-height: 1.85;
  color: var(--dp-text);
}
.roots-prose h2 {
  font-size: clamp(1.15rem, 2.2vw, 1.4rem);
  font-weight: 700;
  color: var(--dp-primary);
  margin: 2.4em 0 .6em;
  letter-spacing: -.02em;
  padding-bottom: .4em;
  border-bottom: 2px solid var(--dp-primary-light, #e6eaf2);
  line-height: 1.35;
}
.roots-prose h2:first-child { margin-top: 0; }
.roots-prose h3 {
  font-size: clamp(1rem, 1.8vw, 1.15rem);
  font-weight: 600;
  color: var(--dp-text);
  margin: 1.8em 0 .5em;
  line-height: 1.45;
}
.roots-prose p {
  margin-bottom: 1.3em;
  color: var(--dp-text-soft);
}
.roots-prose p:last-child { margin-bottom: 0; }
.roots-prose a {
  color: var(--dp-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 500;
  transition: opacity .15s;
}
.roots-prose a:hover { opacity: .72; }
.roots-prose strong { color: var(--dp-text); font-weight: 600; }
.roots-prose ul,
.roots-prose ol {
  padding-left: 1.4em;
  margin-bottom: 1.3em;
  color: var(--dp-text-soft);
}
.roots-prose li { margin-bottom: .45em; line-height: 1.75; }
/* Gutenberg block paragraph overrides — 기본 블록 클래스 리셋 */
.roots-prose .wp-block-paragraph,
.roots-prose .wp-block-heading {
  all: revert;
  font-family: inherit;
  color: inherit;
}
.roots-prose .wp-block-heading { font-size: inherit; font-weight: inherit; }

@media (max-width: 767px) {
  .roots-prose h2 { font-size: 1.1rem; margin-top: 1.8em; }
}

/* ============================================================
   공통 유틸리티 — gallery · consultation 페이지
============================================================ */
.container {
  width: 100%;
  max-width: var(--dp-max-w);
  margin-inline: auto;
  padding-inline: var(--dp-gutter);
}
.container-narrow {
  width: 100%;
  max-width: 860px;
  margin-inline: auto;
  padding-inline: var(--dp-gutter);
}

.section-pad { padding-block: clamp(72px, 10vw, 120px); }
.section-dark { background: var(--dp-primary-3); color: #fff; }

.accent { color: var(--dp-accent); }

/* ── content-article: geo/aeo 라이트 배경 아티클 레이아웃 ── */
.content-article {
  max-width: 820px;
  margin-inline: auto;
}
.content-article .breadcrumb ol {
  color: var(--dp-text-muted);
}
.content-article .breadcrumb a {
  color: var(--dp-text-muted);
}
.content-article .breadcrumb a:hover {
  color: var(--dp-primary);
}
.content-article .page-title {
  color: var(--dp-text);
}
.content-article h2 {
  font-size: clamp(1.3rem, 2.5vw, 1.7rem);
  font-weight: 600;
  color: var(--dp-text);
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  letter-spacing: -0.02em;
}
.content-article h3 {
  font-size: clamp(1rem, 1.8vw, 1.2rem);
  font-weight: 600;
  color: var(--dp-text-sub);
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}
.content-article p,
.content-article li {
  font-size: 1rem;
  line-height: 1.85;
  color: var(--dp-text-sub);
}
.content-article ul,
.content-article ol {
  padding-left: 1.4rem;
}
.content-article li + li { margin-top: 0.4rem; }
.content-article table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
  margin-block: 1.5rem;
}
.content-article th {
  background: var(--dp-bg-soft);
  color: var(--dp-text);
  font-weight: 600;
  padding: 10px 14px;
  text-align: left;
  border: 1px solid var(--dp-border);
}
.content-article td {
  padding: 9px 14px;
  border: 1px solid var(--dp-border);
  color: var(--dp-text-sub);
}
.content-article tr:nth-child(even) td {
  background: var(--dp-bg-soft);
}

/* Breadcrumb */
.breadcrumb ol {
  display: flex;
  align-items: center;
  gap: 6px;
  list-style: none;
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  color: rgba(255,255,255,.55);
  margin-bottom: 28px;
}
.breadcrumb ol li + li::before { content: '›'; margin-right: 6px; }
.breadcrumb a { color: rgba(255,255,255,.55); transition: color var(--dp-trans); }
.breadcrumb a:hover { color: #fff; }

/* Page hero — 다크 그라디언트 */
.page-hero {
  background: linear-gradient(140deg, var(--dp-primary-3) 0%, #2a1a3e 100%);
  padding: clamp(80px, 12vw, 130px) 0 clamp(56px, 8vw, 96px);
}
.page-title {
  font-size: var(--dp-fs-h1);
  font-weight: 200;
  color: #fff;
  letter-spacing: -0.04em;
  line-height: 1.15;
  margin-bottom: 16px;
}
.page-desc {
  font-size: var(--dp-fs-lede);
  color: rgba(255,255,255,.65);
  font-weight: 300;
  line-height: 1.7;
}

/* 버튼 */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 14px 32px;
  background: var(--dp-accent);
  color: #fff;
  font-weight: 700;
  font-size: 0.9rem;
  letter-spacing: 0.02em;
  border-radius: var(--dp-radius);
  transition: transform var(--dp-trans), box-shadow var(--dp-trans), background var(--dp-trans);
  box-shadow: 0 4px 20px rgba(214,51,132,.28);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(214,51,132,.38);
  background: #b8296e;
}
.btn-primary.btn-xl {
  padding: 18px 48px;
  font-size: 1rem;
  letter-spacing: 0.04em;
}

/* ============================================================
   갤러리 페이지
============================================================ */

/* 필터 바 */
.filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 48px;
}
.filter-btn {
  padding: 8px 22px;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--dp-text-muted);
  border: 1px solid var(--dp-border);
  border-radius: 100px;
  background: var(--dp-bg);
  transition: all var(--dp-trans);
  cursor: pointer;
}
.filter-btn:hover {
  border-color: var(--dp-accent);
  color: var(--dp-accent);
}
.filter-btn.active {
  background: var(--dp-primary-3);
  border-color: var(--dp-primary-3);
  color: #fff;
}

/* 빈 상태 */
.gallery-empty {
  text-align: center;
  padding: clamp(64px, 10vw, 120px) 0;
  color: var(--dp-text-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.gallery-empty p { font-size: 1rem; line-height: 1.7; }

/* 갤러리 그리드 */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* 갤러리 카드 */
.gallery-item {
  display: flex;
  flex-direction: column;
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-sm);
  transition: box-shadow var(--dp-trans), transform var(--dp-trans);
}
.gallery-item:hover {
  box-shadow: var(--dp-shadow-md);
  transform: translateY(-4px);
}
.gallery-item-link {
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}

/* 이미지 래퍼 — Before/After 오버레이 */
.gallery-img-wrap {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--dp-bg-soft);
}
.gallery-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s var(--dp-ease), opacity 0.4s;
}
.img-before {
  z-index: 1;
  opacity: 1;
}
.img-after {
  z-index: 2;
  opacity: 0;
}
.gallery-item:hover .img-before { transform: scale(1.04); opacity: 0; }
.gallery-item:hover .img-after  { opacity: 1; transform: scale(1.04); }

/* Before → After 오버레이 라벨 */
.gallery-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  display: flex;
  align-items: flex-end;
  pointer-events: none;
}
.gallery-ba-label {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fff;
  background: linear-gradient(0deg, rgba(26,26,46,.72) 0%, transparent 100%);
  width: 100%;
}
.ba-before { opacity: .7; }
.ba-arrow   { color: var(--dp-accent); font-size: 12px; }
.ba-after   { color: var(--dp-accent); }

/* 카드 정보 */
.gallery-info {
  padding: 20px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  flex: 1;
}
.gallery-cat {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dp-accent);
}
.gallery-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--dp-text);
  letter-spacing: -0.01em;
  line-height: 1.4;
}
.gallery-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px 16px;
  margin-top: 4px;
}
.gallery-meta span {
  font-size: 0.8rem;
  color: var(--dp-text-muted);
  line-height: 1.5;
}
.gallery-meta strong {
  font-weight: 600;
  color: var(--dp-text-sub);
  margin-right: 4px;
}

/* CTA 섹션 */
.cta-section .cta-box {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.cta-title {
  font-size: var(--dp-fs-h2);
  font-weight: 200;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1.3;
}
.cta-title .accent { color: var(--dp-accent); }
.cta-desc {
  font-size: var(--dp-fs-lede);
  color: rgba(255,255,255,.6);
  font-weight: 300;
}

/* ============================================================
   상담 문의 페이지
============================================================ */
.consultation-section {
  background: var(--dp-bg-warm);
}
.consultation-section .breadcrumb ol { color: var(--dp-text-muted); }
.consultation-section .breadcrumb a { color: var(--dp-text-muted); }
.consultation-section .breadcrumb a:hover { color: var(--dp-primary); }
.consultation-section .page-title { color: var(--dp-text); }
.consultation-section .page-title .accent { color: var(--dp-accent); }
.consultation-section .page-desc { color: var(--dp-text-muted); }

/* 상담 카드 래퍼 */
.consult-card-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 48px;
  margin-bottom: 48px;
}

/* 상담 카드 */
.consult-card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-md);
  padding: 44px 36px 40px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
  transition: transform var(--dp-trans), box-shadow var(--dp-trans);
}
.consult-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--dp-shadow-lg);
}

.consult-icon {
  color: var(--dp-accent);
  margin-bottom: 4px;
}
.consult-card-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--dp-text);
  letter-spacing: -0.01em;
}
.consult-card-desc {
  font-size: 0.88rem;
  color: var(--dp-text-muted);
  line-height: 1.6;
}

/* 액션 버튼 — 전화 / 문자 */
.consult-action-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  width: 100%;
  padding: 18px 20px;
  margin-top: 8px;
  border-radius: var(--dp-radius);
  font-weight: 700;
  transition: transform var(--dp-trans), box-shadow var(--dp-trans);
  text-decoration: none;
}
.consult-action-btn:hover { transform: translateY(-2px); }

.consult-tel {
  background: var(--dp-primary-3);
  color: #fff;
  box-shadow: 0 4px 16px rgba(26,26,46,.20);
}
.consult-tel:hover { box-shadow: 0 8px 24px rgba(26,26,46,.28); }

.consult-sms {
  background: var(--dp-accent);
  color: #fff;
  box-shadow: 0 4px 16px rgba(214,51,132,.22);
}
.consult-sms:hover { box-shadow: 0 8px 24px rgba(214,51,132,.32); }

.consult-phone-num {
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.consult-btn-label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  opacity: .8;
}

.consult-hours {
  font-size: 0.8rem;
  color: var(--dp-text-muted);
  line-height: 1.6;
  margin-top: 4px;
}
.consult-card-note {
  font-size: 0.82rem;
  color: var(--dp-text-muted);
  line-height: 1.65;
  margin-top: 4px;
  padding: 10px 14px;
  background: var(--dp-bg-soft);
  border-left: 2px solid var(--dp-accent);
}

/* 상담 안내 */
.consult-guide {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-sm);
  padding: 40px 40px 36px;
  margin-bottom: 32px;
}
.consult-guide-title {
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--dp-text-sub);
  margin-bottom: 24px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--dp-border);
}
.consult-guide-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  list-style: none;
}
.consult-guide-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 0.92rem;
  color: var(--dp-text-sub);
  line-height: 1.65;
}
.consult-guide-list li::before {
  content: '✓';
  color: var(--dp-accent);
  font-weight: 700;
  font-size: 0.85em;
  flex-shrink: 0;
  margin-top: 3px;
}

/* 사업자 정보 */
.consult-biz-info {
  border-top: 1px solid var(--dp-border);
  padding-top: 28px;
}
.biz-dl {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.biz-dl > div {
  display: grid;
  grid-template-columns: 72px 1fr;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid var(--dp-border-soft);
  font-size: 0.85rem;
}
.biz-dl > div:last-child { border-bottom: none; }
.biz-dl dt {
  font-weight: 700;
  color: var(--dp-text-sub);
}
.biz-dl dd { color: var(--dp-text-muted); line-height: 1.6; }

/* ============================================================
   갤러리·상담 — 반응형
============================================================ */
@media (max-width: 1024px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 768px) {
  .gallery-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .consult-card-wrap { grid-template-columns: 1fr; }
  .consult-guide { padding: 28px 24px; }
}

@media (max-width: 480px) {
  .gallery-grid { grid-template-columns: 1fr; }
  .page-hero { padding: clamp(72px, 14vw, 100px) 0 clamp(40px, 8vw, 64px); }
  .btn-primary.btn-xl { padding: 16px 32px; }
}

/* ============================================================
   시공사례 상세 — cd-* (portfolio-detail.php)
============================================================ */

/* ── 스크롤 reveal 애니메이션 ── */
.cd-reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.72s cubic-bezier(0.16, 1, 0.3, 1),
              transform 0.72s cubic-bezier(0.16, 1, 0.3, 1);
}
.cd-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.cd-reveal--delay-1 { transition-delay: 0.12s; }
.cd-reveal--delay-2 { transition-delay: 0.24s; }
.cd-reveal--stagger { transition-delay: calc(var(--stagger, 0) * 0.1s); }
@media (prefers-reduced-motion: reduce) {
  .cd-reveal { opacity: 1 !important; transform: none !important; transition: none !important; }
}

/* ── btn-outline / btn-lg ── */
.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 13px 28px;
  border: 1.5px solid var(--dp-border);
  color: var(--dp-text-sub);
  font-weight: 600;
  font-size: 0.88rem;
  letter-spacing: 0.02em;
  border-radius: var(--dp-radius);
  transition: border-color var(--dp-trans), color var(--dp-trans), background var(--dp-trans);
}
.btn-outline:hover {
  border-color: var(--dp-primary-3);
  color: var(--dp-primary-3);
}
.btn-lg { padding: 15px 36px; font-size: 0.95rem; }

/* ── cd-section 공통 ── */
.cd-section-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 12px;
}
.cd-section-title {
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  color: var(--dp-text);
  line-height: 1.2;
  margin-bottom: clamp(36px, 5vw, 60px);
}

/* ══════════════════════════════════════════════════
   cd-section 공통
══════════════════════════════════════════════════ */
.cd-section-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 12px;
}
.cd-section-title {
  font-size: clamp(1.6rem, 3.2vw, 2.4rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  color: var(--dp-text);
  line-height: 1.2;
  margin-bottom: 12px;
}
.cd-section-sub {
  font-size: 0.9rem;
  color: var(--dp-text-muted);
  font-weight: 300;
  margin-bottom: clamp(36px, 5vw, 56px);
  line-height: 1.6;
}
.cd-section-title + .cd-section-sub { margin-top: 0; }
.cd-section-title:not(+ .cd-section-sub) { margin-bottom: clamp(36px, 5vw, 56px); }

/* ══════════════════════════════════════════════════
   1. 히어로
══════════════════════════════════════════════════ */
.cd-hero {
  position: relative;
  min-height: clamp(520px, 70vh, 860px);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  background: var(--dp-primary-3);
}
.cd-hero-img-wrap {
  position: absolute;
  inset: 0;
}
.cd-hero-img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  transform: scale(1.04);
  transition: transform 8s ease-out;
}
.cd-hero.is-loaded .cd-hero-img { transform: scale(1); }
.cd-hero-scrim {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to top,
    rgba(10,10,22,0.92) 0%,
    rgba(10,10,22,0.62) 40%,
    rgba(10,10,22,0.08) 100%
  );
}
.cd-hero-body {
  position: relative;
  z-index: 2;
  width: 100%;
  padding-top: 100px;
  padding-bottom: clamp(52px, 8vw, 88px);
}

/* 긴박감 바 */
.cd-hero-urgency {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.78rem;
  font-weight: 600;
  color: rgba(255,255,255,.7);
  letter-spacing: 0.04em;
  margin-bottom: 20px;
  padding: 6px 14px;
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 100px;
  backdrop-filter: blur(6px);
}
.cd-urgency-dot {
  display: inline-block;
  width: 7px; height: 7px;
  background: #4ade80;
  border-radius: 50%;
  flex-shrink: 0;
  box-shadow: 0 0 0 0 rgba(74,222,128,.5);
  animation: cd-pulse 2s ease-in-out infinite;
}
@keyframes cd-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(74,222,128,.5); }
  70%  { box-shadow: 0 0 0 7px rgba(74,222,128,0);  }
  100% { box-shadow: 0 0 0 0   rgba(74,222,128,0);  }
}

.cd-category {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 14px;
}
.cd-title {
  font-size: clamp(2rem, 5.5vw, 4rem);
  font-weight: 200;
  color: #fff;
  letter-spacing: -0.04em;
  line-height: 1.12;
  margin-bottom: 16px;
  max-width: 820px;
}
.cd-hero-sub {
  font-size: 0.88rem;
  color: rgba(255,255,255,.5);
  font-weight: 300;
  letter-spacing: 0.04em;
  margin-bottom: 36px;
}
.cd-hero-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
}
.cd-hero-tel {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: rgba(255,255,255,.72);
  font-size: 0.9rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  padding: 14px 0;
  transition: color var(--dp-trans);
}
.cd-hero-tel:hover { color: #fff; }

/* ══════════════════════════════════════════════════
   2. 트러스트 바
══════════════════════════════════════════════════ */
.cd-trust-bar {
  background: var(--dp-primary-3);
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 0;
}
.cd-trust-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  list-style: none;
  divide-x: 1px;
}
.cd-trust-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 24px 20px;
  border-right: 1px solid rgba(255,255,255,.06);
  text-align: center;
}
.cd-trust-item:last-child { border-right: none; }
.cd-trust-num {
  font-size: clamp(1.5rem, 3vw, 2rem);
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.03em;
  line-height: 1;
}
.cd-trust-num span { font-size: .65em; color: var(--dp-accent); }
.cd-trust-label {
  font-size: 0.72rem;
  font-weight: 500;
  color: rgba(255,255,255,.45);
  letter-spacing: 0.04em;
}

/* ══════════════════════════════════════════════════
   3. Before & After 나란히
══════════════════════════════════════════════════ */
.cd-ba-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg);
}
.cd-ba-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.cd-ba-figure { margin: 0; }
.cd-ba-img-wrap {
  overflow: hidden;
  aspect-ratio: 4/3;
  background: var(--dp-bg-soft);
}
.cd-ba-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s var(--dp-ease);
}
.cd-ba-figure:hover .cd-ba-img-wrap img { transform: scale(1.04); }
.cd-ba-caption {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 20px;
  background: var(--dp-bg-soft);
}
.cd-ba-figure:first-child .cd-ba-caption { border-top: 2px solid var(--dp-border); }
.cd-ba-figure:last-child  .cd-ba-caption { border-top: 2px solid var(--dp-accent); }
.cd-ba-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 100px;
}
.cd-ba-badge--before { background: var(--dp-primary-3); color: rgba(255,255,255,.8); }
.cd-ba-badge--after  { background: var(--dp-accent);    color: #fff; }
.cd-ba-caption-text {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--dp-text-sub);
}

/* ══════════════════════════════════════════════════
   4. 고객 공감 + 시공 개요
══════════════════════════════════════════════════ */
.cd-empathy-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg-warm);
}
.cd-empathy-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3px;
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-md);
}
.cd-empathy-pain,
.cd-empathy-solution {
  padding: clamp(32px, 5vw, 56px) clamp(28px, 4vw, 48px);
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: var(--dp-bg);
}
.cd-empathy-pain { border-right: 3px solid var(--dp-border); }
.cd-empathy-solution { border-left: 3px solid var(--dp-accent); }
.cd-empathy-icon { color: var(--dp-text-muted); }
.cd-empathy-icon--accent { color: var(--dp-accent); }
.cd-empathy-head {
  font-size: 1rem;
  font-weight: 700;
  color: var(--dp-text);
  letter-spacing: -0.01em;
}
.cd-empathy-text {
  font-size: 0.92rem;
  color: var(--dp-text-sub);
  line-height: 1.85;
  font-weight: 300;
}

/* ══════════════════════════════════════════════════
   5. 시공 프로세스
══════════════════════════════════════════════════ */
.cd-process-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg);
}
.cd-process-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  list-style: none;
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-sm);
}
.cd-process-step {
  display: grid;
  grid-template-columns: 68px 1fr;
  border-right: 1px solid var(--dp-border-soft);
  border-bottom: 1px solid var(--dp-border-soft);
  transition: background var(--dp-trans);
  background: var(--dp-bg);
}
.cd-process-step:hover { background: var(--dp-bg-soft); }
.cd-step-num {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 28px 0;
  font-family: 'Georgia', serif;
  font-style: italic;
  font-size: clamp(1.8rem, 3vw, 2.2rem);
  font-weight: 400;
  color: var(--dp-accent);
  opacity: .4;
  line-height: 1;
  border-right: 1px solid var(--dp-border-soft);
  background: var(--dp-bg-soft);
  transition: opacity var(--dp-trans);
}
.cd-process-step:hover .cd-step-num { opacity: .7; }
.cd-step-body { padding: 28px 24px; }
.cd-step-text {
  font-size: 0.88rem;
  color: var(--dp-text-sub);
  line-height: 1.75;
}

/* ══════════════════════════════════════════════════
   6. 고객 후기
══════════════════════════════════════════════════ */
.cd-review-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg-soft);
}
.cd-review-card {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-md);
  padding: clamp(36px, 5vw, 60px) clamp(32px, 5vw, 56px);
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin: 0;
  position: relative;
}
.cd-review-card::before {
  content: '\201C';
  position: absolute;
  top: -24px; left: clamp(32px, 5vw, 56px);
  font-family: 'Georgia', serif;
  font-size: 120px;
  line-height: 1;
  color: var(--dp-accent);
  opacity: .12;
}
.cd-review-stars {
  display: flex;
  align-items: center;
  gap: 3px;
}
.cd-review-score {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--dp-accent);
  margin-left: 8px;
}
.cd-review-quote p {
  font-size: clamp(1rem, 2vw, 1.25rem);
  font-weight: 300;
  color: var(--dp-text);
  line-height: 1.85;
  letter-spacing: -0.01em;
}
.cd-review-author {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--dp-text-muted);
  padding-top: 16px;
  border-top: 1px solid var(--dp-border-soft);
}
.cd-review-name {
  font-weight: 700;
  color: var(--dp-text-sub);
}

/* ══════════════════════════════════════════════════
   7. 루츠를 선택하는 이유
══════════════════════════════════════════════════ */
.cd-why-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-primary-3);
}
.cd-why-section .cd-section-eyebrow { color: var(--dp-accent); }
.cd-why-section .cd-section-title { color: #fff; }
.cd-why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 3px;
}
.cd-why-card {
  padding: clamp(36px, 5vw, 56px) clamp(28px, 4vw, 44px);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.07);
  display: flex;
  flex-direction: column;
  gap: 18px;
  transition: background var(--dp-trans);
}
.cd-why-card:hover { background: rgba(255,255,255,.07); }
.cd-why-icon {
  color: var(--dp-accent);
  opacity: .8;
}
.cd-why-title {
  font-size: 1.1rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: -0.01em;
}
.cd-why-desc {
  font-size: 0.88rem;
  color: rgba(255,255,255,.5);
  line-height: 1.8;
  font-weight: 300;
}

/* ══════════════════════════════════════════════════
   8. 시공 정보 카드
══════════════════════════════════════════════════ */
.cd-specs-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg-warm);
}
.cd-specs-card {
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-md);
  overflow: hidden;
  background: var(--dp-bg);
}
.cd-specs-dl { display: flex; flex-direction: column; }
.cd-spec-row {
  display: grid;
  grid-template-columns: 120px 1fr;
  border-bottom: 1px solid var(--dp-border-soft);
}
.cd-spec-row:last-child { border-bottom: none; }
.cd-spec-row dt {
  padding: 18px 24px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--dp-text-sub);
  background: var(--dp-bg-soft);
  border-right: 1px solid var(--dp-border-soft);
  display: flex;
  align-items: center;
}
.cd-spec-row dd {
  padding: 18px 28px;
  font-size: 0.92rem;
  color: var(--dp-text);
  line-height: 1.6;
  display: flex;
  align-items: center;
}

/* ══════════════════════════════════════════════════
   9. 관련 사례
══════════════════════════════════════════════════ */
.cd-related-section {
  padding-block: clamp(72px, 10vw, 120px);
  background: var(--dp-bg-soft);
}
.cd-related-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-bottom: 44px;
}
.cd-related-card {
  display: flex;
  flex-direction: column;
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-sm);
  text-decoration: none;
  color: inherit;
  transition: transform var(--dp-trans), box-shadow var(--dp-trans);
}
.cd-related-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--dp-shadow-md);
}
.cd-related-img-wrap {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--dp-bg-soft);
}
.cd-related-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.7s var(--dp-ease);
  display: block;
}
.cd-related-card:hover .cd-related-img-wrap img { transform: scale(1.06); }
.cd-related-overlay {
  position: absolute;
  inset: 0;
  background: rgba(26,26,46,.0);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background var(--dp-trans);
}
.cd-related-overlay span {
  font-size: 0.82rem;
  font-weight: 700;
  color: #fff;
  letter-spacing: 0.06em;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity var(--dp-trans), transform var(--dp-trans);
}
.cd-related-card:hover .cd-related-overlay { background: rgba(26,26,46,.42); }
.cd-related-card:hover .cd-related-overlay span { opacity: 1; transform: translateY(0); }
.cd-related-placeholder {
  width: 100%; height: 100%;
  background: var(--dp-bg-soft);
}
.cd-related-info {
  padding: 20px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.cd-related-cat {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--dp-accent);
}
.cd-related-title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--dp-text);
  letter-spacing: -0.01em;
  line-height: 1.4;
}
.cd-related-meta { font-size: 0.8rem; color: var(--dp-text-muted); }
.cd-related-footer { text-align: center; }

/* ══════════════════════════════════════════════════
   10. 하단 CTA
══════════════════════════════════════════════════ */
.cd-cta-section {
  padding-block: clamp(88px, 13vw, 150px);
  background: var(--dp-bg);
  position: relative;
  overflow: hidden;
}
.cd-cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 80% 60% at 50% 50%, rgba(214,51,132,.06) 0%, transparent 70%);
  pointer-events: none;
}
.cd-cta-inner {
  position: relative;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}
.cd-cta-eyebrow {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--dp-accent);
}
.cd-cta-title {
  font-size: clamp(1.8rem, 3.8vw, 3rem);
  font-weight: 200;
  color: var(--dp-text);
  letter-spacing: -0.04em;
  line-height: 1.3;
}
.cd-cta-title .accent { color: var(--dp-accent); }
.cd-cta-desc {
  font-size: var(--dp-fs-lede);
  color: var(--dp-text-muted);
  font-weight: 300;
}
.cd-cta-urgency-bar {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--dp-text-muted);
  padding: 8px 18px;
  border: 1px solid var(--dp-border);
  border-radius: 100px;
}
.cd-cta-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  justify-content: center;
  margin-top: 8px;
}

/* ══════════════════════════════════════════════════
   cd-* 반응형
══════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .cd-related-grid { grid-template-columns: repeat(2, 1fr); }
  .cd-process-list { grid-template-columns: repeat(2, 1fr); }
  .cd-why-grid { grid-template-columns: 1fr; gap: 2px; }
}
@media (max-width: 768px) {
  .cd-hero { min-height: clamp(380px, 60vh, 560px); }
  .cd-trust-list { grid-template-columns: repeat(2, 1fr); }
  .cd-trust-item { border-bottom: 1px solid rgba(255,255,255,.06); }
  .cd-empathy-grid { grid-template-columns: 1fr; }
  .cd-empathy-pain { border-right: none; border-bottom: 3px solid var(--dp-border); }
  .cd-empathy-solution { border-left: none; border-top: none; }
  .cd-related-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .cd-process-list { grid-template-columns: 1fr; }
  .cd-spec-row { grid-template-columns: 96px 1fr; }
  .cd-cta-actions { flex-direction: column; align-items: stretch; }
  .cd-cta-actions .btn-primary,
  .cd-cta-actions .btn-outline { justify-content: center; }
}
@media (max-width: 480px) {
  .cd-related-grid { grid-template-columns: 1fr; }
  .cd-title { font-size: clamp(1.8rem, 7.5vw, 2.5rem); }
  .cd-hero-actions { flex-direction: column; align-items: flex-start; }
  .cd-trust-list { grid-template-columns: repeat(2, 1fr); }
}


/* ============================================================
   서비스 페이지 v2 — svc-* (Premium Redesign)
   레퍼런스: ns.standardhaengjipsa.com/service/service-ceiling/
   Brand: #1A1A2E (dark) · #D63384 (magenta accent)
============================================================ */

@keyframes svc-zoom {
  from { transform: scale(1.06); }
  to   { transform: scale(1.14) translate(2%, 1%); }
}

/* ── Hero ── */
.svc-hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(480px, 72vh, 780px);
  display: flex;
  align-items: center;
  color: #fff;
  isolation: isolate;
}
.svc-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  background: #1A1A2E;
}
.svc-hero__bg img {
  width: 100%; height: 100%; object-fit: cover;
  transform: scale(1.06);
  animation: svc-zoom 14s cubic-bezier(.22,.61,.36,1) infinite alternate;
  will-change: transform;
}
.svc-hero__overlay {
  position: absolute; inset: 0; z-index: -1;
  background:
    linear-gradient(135deg, rgba(26,26,46,.93) 0%, rgba(26,26,46,.68) 55%, rgba(26,26,46,.32) 100%),
    linear-gradient(0deg, rgba(0,0,0,.45), transparent 60%);
}
.svc-hero__inner {
  width: 100%;
  padding: clamp(80px, 12vw, 120px) 0 clamp(64px, 10vw, 100px);
}
.svc-hero__eyebrow {
  display: inline-block;
  font-size: .75rem; font-weight: 700; letter-spacing: .22em; text-transform: uppercase;
  color: rgba(255,255,255,.9);
  padding: 7px 16px; border-radius: 999px;
  background: rgba(255,255,255,.1); border: 1px solid rgba(255,255,255,.22);
  backdrop-filter: blur(8px);
  margin-bottom: 24px;
}
.svc-hero__title {
  color: #fff;
  font-size: clamp(2.6rem, 6vw, 4.8rem);
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: -0.04em;
  margin: 0 0 20px;
}
.svc-hero__sub {
  font-size: clamp(1rem, 1.5vw, 1.15rem);
  color: rgba(255,255,255,.8);
  line-height: 1.75;
  max-width: 620px;
  margin: 0 0 36px;
  font-weight: 400;
}
.svc-hero__actions {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

/* ── Buttons (svc-btn) ── */
.svc-btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 15px 28px; border-radius: 999px;
  font-weight: 700; font-size: 1rem; letter-spacing: -.01em;
  transition: transform .25s cubic-bezier(.22,.61,.36,1),
              box-shadow .25s, background .25s, color .25s;
  will-change: transform;
  border: 1.5px solid transparent;
  text-decoration: none; cursor: pointer;
}
.svc-btn--primary {
  background: #D63384; color: #fff;
  box-shadow: 0 6px 20px rgba(214,51,132,.32);
}
.svc-btn--primary:hover {
  background: #b01e6a; color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(214,51,132,.48);
}
.svc-btn--ghost-light {
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.35);
  color: #fff; backdrop-filter: blur(6px);
}
.svc-btn--ghost-light:hover {
  background: rgba(255,255,255,.2); color: #fff;
  transform: translateY(-2px);
}
.svc-btn--outline {
  background: transparent; color: #1A1A2E;
  border-color: #c4c9d4;
}
.svc-btn--outline:hover {
  background: #1A1A2E; color: #fff;
  border-color: #1A1A2E; transform: translateY(-2px);
}
.svc-btn--accent {
  background: #f59e0b; color: #1A1A2E;
  box-shadow: 0 6px 18px rgba(245,158,11,.32);
}
.svc-btn--accent:hover {
  background: #fff; transform: translateY(-2px);
  box-shadow: 0 12px 28px rgba(245,158,11,.44);
}

/* ── Breadcrumb ── */
.svc-breadcrumb { margin-bottom: 24px; }
.svc-breadcrumb ol {
  list-style: none; display: flex; flex-wrap: wrap;
  gap: 6px; font-size: .84rem; color: rgba(255,255,255,.65);
}
.svc-breadcrumb li::after { content: '/'; margin-left: 6px; color: rgba(255,255,255,.35); }
.svc-breadcrumb li:last-child::after { display: none; }
.svc-breadcrumb a { color: rgba(255,255,255,.65); }
.svc-breadcrumb a:hover { color: #fff; }
.svc-breadcrumb [aria-current="page"] { color: #fff; font-weight: 600; }

/* ── Section base ── */
.svc-section { padding: clamp(64px, 10vw, 120px) 0; }
.svc-section--white { background: #fff; }
.svc-section--soft  { background: #f4f0f8; }
.svc-section--dark  { background: #1A1A2E; color: #fff; }

.svc-container--narrow { max-width: 880px; margin-inline: auto; }

/* ── Eyebrow ── */
.svc-eyebrow {
  display: inline-block;
  font-size: .72rem; font-weight: 700;
  letter-spacing: .22em; text-transform: uppercase;
  color: #D63384;
  padding: 6px 14px; border-radius: 999px;
  background: rgba(214,51,132,.08);
  margin-bottom: 14px;
}
.svc-section--dark .svc-eyebrow { color: rgba(255,255,255,.75); background: rgba(255,255,255,.1); }

/* ── Section head ── */
.svc-section__head {
  text-align: center;
  max-width: 680px;
  margin: 0 auto clamp(40px, 6vw, 64px);
}
.svc-section__head--left { text-align: left; margin-left: 0; }
.svc-section__head h2 {
  font-size: clamp(1.8rem, 3.5vw, 2.6rem);
  font-weight: 900; letter-spacing: -.03em; line-height: 1.2;
  margin: 0 0 14px; color: #1A1A2E;
}
.svc-section--dark .svc-section__head h2 { color: #fff; }
.svc-section__sub {
  color: #6e8a78; font-size: 1.05rem; margin: 0;
}

/* ── Intro ── */
.svc-intro__body {
  font-size: 1.05rem; line-height: 1.95; color: #6e8a78;
  max-width: 740px;
}
.svc-intro__body br { margin-bottom: .8em; }

/* ── Material/feature cards (light bg) ── */
.svc-cards { display: grid; gap: 20px; }
.svc-cards--3 { grid-template-columns: repeat(3, 1fr); }
.svc-cards--4 { grid-template-columns: repeat(4, 1fr); }

.svc-card {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 18px;
  padding: 36px 28px;
  transition: transform .32s cubic-bezier(.22,.61,.36,1),
              box-shadow .32s, border-color .25s;
}
.svc-section--soft .svc-card { background: #fff; }
.svc-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 44px rgba(26,26,46,.1);
  border-color: #D63384;
}
.svc-card__num {
  display: block; font-size: 2.2rem; font-weight: 800;
  color: #D63384; letter-spacing: -.04em; line-height: 1; margin-bottom: 16px;
}
.svc-card__title {
  font-size: 1.1rem; font-weight: 700; color: #1A1A2E; margin: 0 0 10px;
}
.svc-card__desc { font-size: .9rem; color: #6e8a78; line-height: 1.75; margin: 0; }

/* ── Process steps ── */
.svc-process {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 18px;
}
.svc-process__step {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 30px 24px;
  transition: transform .32s cubic-bezier(.22,.61,.36,1), box-shadow .32s;
}
.svc-process__step:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 32px rgba(26,26,46,.1);
}
.svc-process__num {
  display: block; font-size: 2rem; font-weight: 800;
  color: #D63384; letter-spacing: -.04em; line-height: 1; margin-bottom: 16px;
}
.svc-process__step h3 {
  font-size: 1rem; font-weight: 700; color: #1A1A2E; margin: 0 0 8px;
}
.svc-process__step p {
  font-size: .85rem; color: #6e8a78; line-height: 1.65; margin: 0;
}

/* ── Feature cards (dark bg) ── */
.svc-feat-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.svc-feat-card {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 16px; padding: 32px 24px;
  transition: transform .3s, background .25s, border-color .25s;
}
.svc-feat-card:hover {
  transform: translateY(-4px);
  background: rgba(255,255,255,.1);
  border-color: rgba(214,51,132,.55);
}
.svc-feat-card__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px;
  background: rgba(214,51,132,.15);
  border: 1px solid rgba(214,51,132,.3);
  border-radius: 12px; margin-bottom: 18px; color: #D63384;
}
.svc-feat-card h3 {
  font-size: 1.05rem; font-weight: 700; color: #fff; margin: 0 0 8px;
}
.svc-feat-card p {
  font-size: .85rem; color: rgba(255,255,255,.62); line-height: 1.75; margin: 0;
}

/* ── FAQ (details/summary) ── */
.svc-faq { display: flex; flex-direction: column; gap: 12px; }
.svc-faq__item {
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 14px;
  transition: border-color .25s, box-shadow .25s;
}
.svc-faq__item[open] {
  border-color: #D63384;
  box-shadow: 0 4px 18px rgba(214,51,132,.12);
  background: #fff;
}
.svc-faq__item summary {
  cursor: pointer;
  padding: 22px 60px 22px 26px;
  font-weight: 600; color: #1A1A2E;
  position: relative; list-style: none;
  font-size: 1.02rem; line-height: 1.5;
  user-select: none;
}
.svc-faq__item summary::-webkit-details-marker { display: none; }
.svc-faq__item summary::after {
  content: '+';
  position: absolute; right: 22px; top: 50%; transform: translateY(-50%);
  width: 30px; height: 30px; border-radius: 50%;
  background: #D63384; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; line-height: 1;
  transition: transform .3s cubic-bezier(.22,.61,.36,1), background .25s;
}
.svc-faq__item[open] summary::after {
  transform: translateY(-50%) rotate(45deg);
  background: #1A1A2E;
}
.svc-faq__answer {
  padding: 0 26px 24px;
  color: #6e8a78; line-height: 1.85; font-size: .95rem;
}

/* ── CTA banner ── */
.svc-cta {
  background: linear-gradient(135deg, #1A1A2E 0%, #2c1a52 100%);
  color: #fff; text-align: center;
  padding: clamp(72px, 12vw, 120px) 0;
  position: relative; overflow: hidden;
}
.svc-cta::before {
  content: ''; position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(circle at 18% 80%, rgba(214,51,132,.28), transparent 50%),
    radial-gradient(circle at 82% 20%, rgba(95,188,230,.14), transparent 50%);
}
.svc-cta > .page-container { position: relative; }
.svc-cta__title { color: #fff; margin: 14px 0 16px; font-size: clamp(1.8rem, 3.5vw, 2.6rem); font-weight: 900; }
.svc-cta__sub { color: rgba(255,255,255,.78); margin: 0 0 36px; font-size: 1.05rem; }

/* ── Related services (inside CTA) ── */
.svc-related {
  margin-top: 48px; padding-top: 32px;
  border-top: 1px solid rgba(255,255,255,.12);
}
.svc-related__label {
  font-size: .72rem; color: rgba(255,255,255,.45);
  margin-bottom: 14px; text-transform: uppercase; letter-spacing: .18em;
}
.svc-related__links { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.svc-related__links a {
  display: inline-block; padding: 8px 18px;
  border: 1px solid rgba(255,255,255,.2); border-radius: 999px;
  font-size: .85rem; font-weight: 600; color: rgba(255,255,255,.75);
  transition: background .22s, border-color .22s, color .22s;
}
.svc-related__links a:hover {
  background: rgba(255,255,255,.15); border-color: rgba(255,255,255,.4); color: #fff;
}

/* ── Services nav ── */
.svc-nav-section { padding: clamp(40px, 7vw, 72px) 0; background: #f4f0f8; }
.svc-nav-section .svc-eyebrow { display: block; text-align: center; margin-bottom: 20px; }
.svc-nav-pills {
  display: flex; flex-wrap: wrap; gap: 10px; justify-content: center;
}
.svc-nav-pill {
  display: inline-block; padding: 11px 22px;
  border: 1.5px solid #d4c8e4; border-radius: 999px;
  font-size: .9rem; font-weight: 600; color: #3a2860; background: #fff;
  transition: background .22s, color .22s, border-color .22s, transform .22s;
}
.svc-nav-pill:hover {
  background: #D63384; color: #fff; border-color: #D63384; transform: translateY(-1px);
}
.svc-nav-pill--active {
  background: #1A1A2E; color: #fff; border-color: #1A1A2E;
}

/* ── Before/After cases ── */
.svc-cases { display: flex; flex-direction: column; gap: 60px; }
.svc-case__cat {
  display: inline-block; font-size: .72rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase;
  color: #D63384; margin-bottom: 16px;
}
.svc-case__grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
}
.svc-case__img-wrap {
  position: relative; overflow: hidden; border-radius: 14px;
  aspect-ratio: 4/3; background: #e8e4f0;
  box-shadow: 0 4px 14px rgba(26,26,46,.08);
}
.svc-case__img-wrap img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .8s cubic-bezier(.22,.61,.36,1);
}
.svc-case__img-wrap:hover img { transform: scale(1.04); }
.svc-case__badge {
  position: absolute; bottom: 12px; left: 12px;
  background: rgba(0,0,0,.55); color: #fff;
  font-size: .7rem; font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 5px;
}
.svc-case__badge--after { background: #D63384; }
.svc-case__desc {
  margin-top: 14px; font-size: .9rem; color: #6e8a78; line-height: 1.7;
}

/* ── Responsive ── */
@media (max-width: 1024px) {
  .svc-cards--4, .svc-feat-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .svc-cards--3, .svc-cards--4, .svc-feat-cards { grid-template-columns: 1fr; }
  .svc-case__grid { grid-template-columns: 1fr; }
  .svc-hero__title { letter-spacing: -.03em; }
}
@media (max-width: 480px) {
  .svc-hero__actions { flex-direction: column; }
  .svc-btn { width: 100%; justify-content: center; }
}


/* ============================================================
   서비스 페이지 A안 — sv-* (에디토리얼 화이트, 메인 톤 통일)
   메인과 동일: weight 200 / radius 2px / label-caps / serif-italic
============================================================ */

/* ── 히어로 ── */
.sv-hero {
  background: var(--dp-bg);
  padding: clamp(48px, 8vw, 80px) 0 0;
}
.sv-hero__inner { max-width: 860px; }
.sv-hero__title {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  font-weight: 200;
  letter-spacing: -0.05em;
  line-height: 1.05;
  margin-bottom: 0;
  color: var(--dp-text);
}
.sv-hero__title em {
  font-style: normal;
  color: var(--dp-accent);
}
.sv-hero__em {
  font-size: clamp(1.5rem, 3.5vw, 2.8rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  line-height: 1.15;
  margin-top: 6px;
  display: block;
  color: var(--dp-text);
}
.sv-hero__meta {
  display: flex;
  align-items: flex-end;
  gap: 40px;
  margin-top: clamp(24px, 4vw, 40px);
  flex-wrap: wrap;
}
.sv-hero__sub {
  font-size: 14px;
  font-weight: 300;
  color: var(--dp-text-muted);
  max-width: 360px;
  line-height: 1.85;
}

/* ── 통계 배지 ── */
.sv-stats {
  display: flex;
  gap: clamp(20px, 4vw, 40px);
  flex-wrap: wrap;
  margin-top: clamp(28px, 4vw, 44px);
  padding-top: clamp(24px, 3vw, 36px);
  border-top: 1px solid var(--dp-border);
}
.sv-stat { display: flex; flex-direction: column; gap: 4px; }
.sv-stat__num {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  color: var(--dp-text);
  line-height: 1;
}
.sv-stat__num em {
  font-style: italic;
  font-family: 'Georgia', serif;
  color: var(--dp-accent);
}
.sv-stat__label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--dp-text-muted);
}

/* ── 히어로 이미지 스트립 ── */
.sv-hero__strip {
  margin-top: clamp(36px, 6vw, 60px);
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  gap: 4px;
  overflow: hidden;
  border-radius: 2px;
  box-shadow: var(--dp-shadow-lg);
  max-height: 420px;
}
.sv-hero__strip-img {
  position: relative;
  overflow: hidden;
  background: var(--dp-bg-soft);
}
.sv-hero__strip-img img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  transition: transform 0.8s var(--dp-ease);
}
.sv-hero__strip-img:hover img { transform: scale(1.04); }
.sv-hero__strip-img:nth-child(2) img,
.sv-hero__strip-img:nth-child(3) img { filter: saturate(0.35); }

/* ── 섹션 공통 ── */
.sv-section { padding: clamp(56px, 9vw, 110px) 0; background: var(--dp-bg); }
.sv-section--soft { background: var(--dp-bg-soft); }
.sv-section--dark { background: var(--dp-primary-3); color: #fff; }

/* ── 섹션 헤드 ── */
.sv-section-head { margin-bottom: clamp(32px, 5vw, 52px); }
.sv-section-head h2 {
  font-size: clamp(1.8rem, 4vw, 2.8rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  line-height: 1.2;
  color: var(--dp-text);
  margin-top: 10px;
  margin-bottom: 0;
}
.sv-section--dark .sv-section-head h2 { color: #fff; }
.sv-section-head .label-caps { color: var(--dp-accent); }
.sv-section--dark .sv-section-head .label-caps { color: rgba(255,255,255,.45); }

/* ── 인트로 텍스트 ── */
.sv-intro-body {
  font-size: 15px;
  font-weight: 300;
  color: var(--dp-text-muted);
  line-height: 2;
  max-width: 680px;
}

/* ── Before/After 케이스 (fp-case 동일 스타일) ── */
.sv-case { padding: clamp(48px, 8vw, 80px) 0; background: var(--dp-bg); }
.sv-case + .sv-case { padding-top: 0; }
.sv-case--soft { background: var(--dp-bg-soft); }
.sv-case__label {
  display: flex; align-items: center; gap: 12px; margin-bottom: 20px;
}
.sv-case__divider { display: inline-block; width: 40px; height: 1px; background: #ddd; }
.sv-case__tag { font-size: 14px; font-weight: 600; letter-spacing: -0.02em; color: var(--dp-text); }
.sv-case__grid {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 4px; border-radius: 2px; overflow: hidden; box-shadow: var(--dp-shadow-lg);
}
.sv-case__grid--reverse { direction: rtl; }
.sv-case__grid--reverse > * { direction: ltr; }
.sv-case__img {
  position: relative; aspect-ratio: 4/3; overflow: hidden;
  background: var(--dp-bg-soft);
}
.sv-case__img img { width: 100%; height: 100%; object-fit: cover; }
.sv-case__grid .sv-case__img:first-child img { filter: saturate(0.25); }
.sv-case__img-badge {
  position: absolute; padding: 6px 14px;
  font-size: 9px; font-weight: 700; letter-spacing: 0.2em; text-transform: uppercase; color: #fff;
}
.sv-case__img-badge--before { bottom: 16px; left: 16px; background: rgba(0,0,0,.45); backdrop-filter: blur(8px); }
.sv-case__img-badge--after  { bottom: 16px; right: 16px; background: var(--dp-accent); }
.sv-case__desc {
  margin-top: 28px; display: grid; grid-template-columns: 1fr 2fr; gap: 40px; align-items: start;
}
.sv-case__desc--reverse { grid-template-columns: 2fr 1fr; }
.sv-case__desc-title {
  font-size: clamp(20px, 3vw, 28px); font-weight: 200; letter-spacing: -0.03em;
  line-height: 1.35; color: var(--dp-text); margin: 0;
}
.sv-case__desc-body {
  font-size: 14px; color: var(--dp-text-muted); line-height: 2; font-weight: 300; margin: 0;
}

/* ── 소재 카드 ── */
.sv-materials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2px; }
.sv-material {
  padding: 36px 28px; background: #fff;
  border: 1px solid var(--dp-border-soft);
  transition: box-shadow 0.3s var(--dp-ease);
}
.sv-section--soft .sv-material { background: var(--dp-bg); }
.sv-material:hover { box-shadow: var(--dp-shadow-md); }
.sv-material__num {
  font-family: 'Georgia', serif; font-style: italic;
  font-size: 20px; color: var(--dp-accent); opacity: 0.5;
  margin-bottom: 14px; display: block;
}
.sv-material__name { font-size: 1.05rem; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 10px; color: var(--dp-text); }
.sv-material__desc { font-size: 13px; color: var(--dp-text-muted); line-height: 1.85; font-weight: 300; margin: 0; }

/* ── 프로세스 스텝 ── */
.sv-steps { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 2px; }
.sv-step {
  padding: 32px 24px; background: #fff; border: 1px solid var(--dp-border-soft);
  transition: box-shadow 0.3s var(--dp-ease);
}
.sv-section--soft .sv-step { background: var(--dp-bg); }
.sv-step:hover { box-shadow: var(--dp-shadow-sm); }
.sv-step__num {
  font-family: 'Georgia', serif; font-style: italic;
  font-size: 28px; color: var(--dp-accent); opacity: 0.4;
  display: block; line-height: 1; margin-bottom: 16px;
}
.sv-step h3 { font-size: 1rem; font-weight: 700; color: var(--dp-text); margin: 0 0 8px; }
.sv-step p { font-size: 13px; color: var(--dp-text-muted); line-height: 1.8; font-weight: 300; margin: 0; }

/* ── 강점 (dark, fp-principles 동일 스타일) ── */
.sv-strengths-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 6vw, 80px); align-items: start;
}
.sv-strengths-title {
  font-size: clamp(26px, 4vw, 38px); font-weight: 200;
  letter-spacing: -0.03em; line-height: 1.25; margin-bottom: 44px; color: #fff;
}
.sv-principles { display: flex; flex-direction: column; gap: 36px; }
.js-ready .sv-principle {
  opacity: 0; transform: translateX(-24px);
  transition: opacity 0.5s cubic-bezier(.22,1,.36,1), transform 0.5s cubic-bezier(.22,1,.36,1);
}
.sv-principles.is-visible .sv-principle:nth-child(1) { opacity: 1; transform: none; transition-delay: .05s; }
.sv-principles.is-visible .sv-principle:nth-child(2) { opacity: 1; transform: none; transition-delay: .2s; }
.sv-principles.is-visible .sv-principle:nth-child(3) { opacity: 1; transform: none; transition-delay: .35s; }
.sv-principles.is-visible .sv-principle:nth-child(4) { opacity: 1; transform: none; transition-delay: .5s; }
@media (prefers-reduced-motion: reduce) {
  .js-ready .sv-principle { opacity: 1 !important; transform: none !important; }
}
.sv-principle { display: flex; gap: 20px; align-items: flex-start; }
.sv-principle__num {
  font-family: 'Georgia', serif; font-style: italic;
  font-size: 22px; color: var(--dp-accent); opacity: 0.45; flex-shrink: 0; margin-top: 2px;
}
.sv-principle__title { font-size: 17px; font-weight: 700; margin-bottom: 6px; letter-spacing: -0.02em; color: #fff; }
.sv-principle__desc { font-size: 14px; color: rgba(255,255,255,.5); line-height: 1.85; font-weight: 300; }
.sv-strengths-media { position: relative; }
.sv-strengths-img {
  aspect-ratio: 4/5; overflow: hidden; border-radius: 2px;
  background: rgba(255,255,255,.06);
}
.sv-strengths-img img { width: 100%; height: 100%; object-fit: cover; opacity: 0.72; }

/* ── 고객 후기 ── */
.sv-reviews { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.sv-review {
  background: var(--dp-bg); padding: 32px 26px;
  border: 1px solid var(--dp-border-soft);
  border-radius: 2px; display: flex; flex-direction: column; gap: 16px;
}
.sv-review__stars { color: var(--dp-accent); font-size: 14px; letter-spacing: 2px; }
.sv-review__text {
  font-size: 14px; color: var(--dp-text-muted); line-height: 1.9; font-weight: 300;
  flex: 1; font-style: italic; position: relative; padding-left: 18px;
}
.sv-review__text::before {
  content: '"'; position: absolute; left: 0; top: -2px;
  font-size: 2rem; color: var(--dp-accent); opacity: 0.35; line-height: 1;
  font-family: 'Georgia', serif;
}
.sv-review__author { display: flex; flex-direction: column; gap: 2px; }
.sv-review__name { font-size: 13px; font-weight: 700; color: var(--dp-text); }
.sv-review__loc  { font-size: 11px; color: var(--dp-text-muted); letter-spacing: 0.05em; }

/* ── FAQ ── */
.sv-faq { display: flex; flex-direction: column; gap: 0; max-width: 760px; }
.sv-faq__item {
  border-bottom: 1px solid var(--dp-border);
  transition: background 0.2s;
}
.sv-faq__item[open] { background: var(--dp-bg-soft); }
.sv-faq__item summary {
  cursor: pointer; padding: 22px 48px 22px 0;
  font-weight: 600; font-size: 1rem; color: var(--dp-text);
  list-style: none; position: relative; line-height: 1.5; user-select: none;
}
.sv-faq__item summary::-webkit-details-marker { display: none; }
.sv-faq__item summary::after {
  content: '+'; position: absolute; right: 0; top: 50%; transform: translateY(-50%);
  font-size: 1.4rem; color: var(--dp-accent); line-height: 1;
  transition: transform 0.3s var(--dp-ease);
}
.sv-faq__item[open] summary::after { transform: translateY(-50%) rotate(45deg); }
.sv-faq__answer { padding: 0 0 22px; font-size: 14px; color: var(--dp-text-muted); line-height: 1.9; font-weight: 300; }

/* ── 견적 안내 ── */
.sv-quote-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(32px, 5vw, 60px); align-items: start; }
.sv-quote-title { font-size: clamp(1.6rem, 3.5vw, 2.4rem); font-weight: 200; letter-spacing: -0.04em; line-height: 1.25; color: var(--dp-text); margin: 10px 0 24px; }
.sv-quote-body { font-size: 14px; font-weight: 300; color: var(--dp-text-muted); line-height: 2; margin-bottom: 28px; }
.sv-quote-checks { display: flex; flex-direction: column; gap: 12px; margin-bottom: 32px; }
.sv-quote-check {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 14px; color: var(--dp-text-sub); font-weight: 400; line-height: 1.6;
}
.sv-quote-check::before {
  content: '✓'; color: var(--dp-accent); font-weight: 700; flex-shrink: 0; margin-top: 1px;
}
.sv-quote-box {
  background: var(--dp-primary-3); color: #fff; padding: 36px 32px; border-radius: 2px;
}
.sv-quote-box__label {
  font-size: 10px; font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase;
  color: rgba(255,255,255,.45); margin-bottom: 16px; display: block;
}
.sv-quote-box__price {
  font-size: clamp(1.8rem, 4vw, 2.6rem); font-weight: 200; letter-spacing: -0.04em;
  color: #fff; margin-bottom: 6px;
}
.sv-quote-box__price em { font-style: italic; font-family: 'Georgia', serif; color: var(--dp-accent); }
.sv-quote-box__note { font-size: 13px; color: rgba(255,255,255,.5); font-weight: 300; line-height: 1.7; margin-bottom: 24px; }
.sv-quote-box__cta {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 26px; background: var(--dp-accent); color: #fff;
  font-weight: 700; font-size: 0.9rem; letter-spacing: 0.02em; border-radius: 2px;
  transition: transform 0.25s var(--dp-ease), box-shadow 0.25s var(--dp-ease), background 0.25s;
  box-shadow: 0 4px 20px rgba(214,51,132,.28);
}
.sv-quote-box__cta:hover {
  background: #b8296e; transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(214,51,132,.38); color: #fff;
}

/* ── 하단 CTA 배너 ── */
.sv-cta-banner {
  background: var(--dp-primary-3); color: #fff;
  padding: clamp(60px, 10vw, 100px) 0;
  text-align: center;
}
.sv-cta-banner__eyebrow { display: block; margin-bottom: 16px; }
.sv-cta-banner__title {
  font-size: clamp(1.8rem, 4vw, 3rem); font-weight: 200; letter-spacing: -0.04em;
  color: #fff; margin: 0 0 12px; line-height: 1.2;
}
.sv-cta-banner__title em { font-style: italic; font-family: 'Georgia', serif; color: var(--dp-accent); }
.sv-cta-banner__sub { font-size: 14px; font-weight: 300; color: rgba(255,255,255,.55); margin: 0 0 36px; }
.sv-cta-banner__actions { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }
.sv-cta-banner__related { margin-top: 44px; padding-top: 28px; border-top: 1px solid rgba(255,255,255,.1); }
.sv-cta-banner__related-label { font-size: 10px; font-weight: 700; letter-spacing: 0.25em; text-transform: uppercase; color: rgba(255,255,255,.35); margin-bottom: 12px; display: block; }
.sv-cta-banner__related-links { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; }
.sv-cta-banner__related-links a {
  display: inline-block; padding: 7px 18px;
  border: 1px solid rgba(255,255,255,.18); border-radius: 100px;
  font-size: 0.82rem; font-weight: 500; color: rgba(255,255,255,.65);
  transition: all 0.22s var(--dp-ease);
}
.sv-cta-banner__related-links a:hover { background: rgba(255,255,255,.12); color: #fff; border-color: rgba(255,255,255,.35); }

/* ── 서비스 네비 ── */
.sv-service-nav { background: var(--dp-bg); padding: clamp(36px, 6vw, 60px) 0; border-top: 1px solid var(--dp-border); }
.sv-service-nav__head { display: flex; align-items: center; gap: 16px; margin-bottom: 20px; }
.sv-service-nav__pills { display: flex; flex-wrap: wrap; gap: 8px; }
.sv-service-nav__pill {
  display: inline-block; padding: 10px 20px;
  border: 1px solid var(--dp-border); border-radius: 100px;
  font-size: 0.85rem; font-weight: 600; color: var(--dp-text-muted);
  background: var(--dp-bg); transition: all 0.22s var(--dp-ease);
}
.sv-service-nav__pill:hover { background: var(--dp-accent); color: #fff; border-color: var(--dp-accent); }
.sv-service-nav__pill--active { background: var(--dp-primary-3); color: #fff; border-color: var(--dp-primary-3); }

/* ── 반응형 ── */
@media (max-width: 900px) {
  .sv-strengths-grid { grid-template-columns: 1fr; }
  .sv-strengths-media { display: none; }
  .sv-quote-grid { grid-template-columns: 1fr; }
  .sv-reviews { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 768px) {
  .sv-hero__strip { grid-template-columns: 1fr 1fr; }
  .sv-hero__strip-img:last-child { display: none; }
  .sv-materials, .sv-case__grid { grid-template-columns: 1fr; }
  .sv-case__grid--reverse { direction: ltr; }
  .sv-case__desc, .sv-case__desc--reverse { grid-template-columns: 1fr; gap: 20px; }
  .sv-reviews { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .sv-hero__strip { display: none; }
  .sv-stats { gap: 20px; }
}

/* ── Back to top ── */
#back-to-top {
  position: fixed;
  bottom: 28px;
  right: 28px;
  width: 44px;
  height: 44px;
  background: var(--dp-primary-3);
  color: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 2px;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s, transform .3s, background .2s;
  z-index: 500;
}
#back-to-top.visible {
  opacity: 1;
  pointer-events: auto;
}
#back-to-top:hover {
  background: var(--dp-accent);
  color: #fff;
  transform: translateY(-3px);
}
@media (max-width: 768px) {
  #back-to-top { bottom: 80px; right: 16px; }
}

/* ── 서비스 카드 그리드 (sv-svc-cards) ── */
.sv-svc-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2px;
  margin-top: clamp(32px, 5vw, 48px);
}
.sv-svc-card {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  background: var(--dp-bg);
  border: 1px solid var(--dp-border);
  overflow: hidden;
  transition: transform .3s var(--dp-ease), box-shadow .3s var(--dp-ease), border-color .3s;
}
.sv-svc-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--dp-shadow-md);
  border-color: var(--dp-accent);
  z-index: 1;
}
.sv-svc-card__body {
  padding: 24px 22px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.sv-svc-card__kw {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  color: var(--dp-text-muted);
  text-transform: uppercase;
}
.sv-svc-card__title {
  font-size: 1rem;
  font-weight: 600;
  color: var(--dp-text);
  letter-spacing: -0.02em;
}
.sv-svc-card__arrow {
  margin-top: auto;
  padding-top: 12px;
  font-size: 14px;
  color: var(--dp-accent);
  font-weight: 700;
  display: block;
}
@media (max-width: 768px) {
  .sv-svc-cards { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .sv-svc-cards { grid-template-columns: 1fr 1fr; gap: 1px; }
  .sv-svc-card__body { padding: 12px 14px 14px; }
}

/* ============================================================
   지역 페이지 공통 (region-page / _region_render.php)
============================================================ */

/* CTA 섹션 배경 — 미정의로 글자 안보이던 문제 수정 */
.cta-section { background: var(--dp-primary-3); }

/* ── 히어로 ── */
.rg-hero {
  position: relative;
  background: var(--dp-primary-3);
  overflow: hidden;
  padding-block: clamp(80px, 12vw, 140px);
}
.rg-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.rg-hero__bg img {
  width: 100%; height: 100%;
  object-fit: cover;
  opacity: .18;
  filter: saturate(.4);
}
.rg-hero__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg, rgba(26,26,46,.85) 55%, rgba(26,26,46,.4) 100%);
}
.rg-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 720px;
}
.rg-hero__label {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--dp-accent);
  margin-bottom: 20px;
}
.rg-hero__title {
  font-size: clamp(2rem, 5.5vw, 3.6rem);
  font-weight: 200;
  letter-spacing: -.04em;
  line-height: 1.15;
  color: #fff;
  margin: 0 0 20px;
}
.rg-hero__title .accent { color: var(--dp-accent); font-weight: 400; }
.rg-hero__desc {
  font-size: clamp(.95rem, 1.8vw, 1.1rem);
  color: rgba(255,255,255,.7);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 36px;
}
.rg-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 56px; }
.rg-stats {
  display: flex;
  gap: 0;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 28px;
  flex-wrap: wrap;
}
.rg-stat {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-right: 32px;
  margin-right: 32px;
  border-right: 1px solid rgba(255,255,255,.12);
}
.rg-stat:last-child { border-right: none; margin-right: 0; }
.rg-stat__num {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 200;
  color: #fff;
  letter-spacing: -.04em;
  line-height: 1;
}
.rg-stat__num em { font-style: italic; font-family: Georgia, serif; color: var(--dp-accent); }
.rg-stat__label {
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .06em;
  color: rgba(255,255,255,.5);
  text-transform: uppercase;
}
.rg-hero .breadcrumb ol { color: rgba(255,255,255,.45); }
.rg-hero .breadcrumb a  { color: rgba(255,255,255,.6); }
.rg-hero .breadcrumb li[aria-current] { color: rgba(255,255,255,.85); }

/* ── 오버뷰 (텍스트 + Before/After) ── */
.rg-overview {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 6vw, 80px);
  align-items: center;
}
.rg-overview__lead {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 200;
  letter-spacing: -.03em;
  line-height: 1.3;
  color: var(--dp-text);
  margin-bottom: 20px;
}
.rg-overview__body {
  font-size: .95rem;
  color: var(--dp-text-muted);
  font-weight: 300;
  line-height: 1.85;
  margin-bottom: 28px;
}
.rg-ba {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.rg-ba__item {
  position: relative;
  border-radius: 2px;
  overflow: hidden;
  aspect-ratio: 4/5;
}
.rg-ba__item img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s var(--dp-ease);
}
.rg-ba__item:hover img { transform: scale(1.04); }
.rg-ba__badge {
  position: absolute;
  bottom: 10px; left: 10px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #fff;
  background: rgba(0,0,0,.55);
  padding: 4px 10px;
  border-radius: 2px;
  backdrop-filter: blur(4px);
}

/* ── 서비스 카드 (이미지 포함) ── */
.rg-svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 20px;
}
.rg-svc-card {
  border-radius: var(--dp-radius);
  overflow: hidden;
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  box-shadow: var(--dp-shadow-sm);
  transition: transform .3s var(--dp-ease), box-shadow .3s;
  display: flex;
  flex-direction: column;
}
.rg-svc-card:hover { transform: translateY(-5px); box-shadow: var(--dp-shadow-md); }
.rg-svc-card__fig {
  aspect-ratio: 3/2;
  overflow: hidden;
}
.rg-svc-card__fig img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(.7);
  transition: filter .4s, transform .45s var(--dp-ease);
}
.rg-svc-card:hover .rg-svc-card__fig img { filter: saturate(1); transform: scale(1.06); }
.rg-svc-card__body { padding: 18px 20px 22px; flex: 1; display: flex; flex-direction: column; }
.rg-svc-card__title { font-size: 1rem; font-weight: 700; color: var(--dp-text); margin-bottom: 8px; letter-spacing: -.01em; }
.rg-svc-card__desc { font-size: .85rem; color: var(--dp-text-muted); line-height: 1.6; flex: 1; margin-bottom: 14px; }
.rg-svc-card__more { font-size: .8rem; font-weight: 700; color: var(--dp-accent); letter-spacing: .02em; }

/* ── 시공 과정 (아이콘 강조) ── */
.rg-steps { display: grid; grid-template-columns: repeat(4,1fr); gap: 2px; }
.rg-step {
  background: var(--dp-bg);
  border: 1px solid var(--dp-border-soft);
  padding: 32px 24px 28px;
  display: flex; flex-direction: column; gap: 12px;
  position: relative;
}
.rg-step__num {
  font-size: 2.4rem;
  font-weight: 900;
  color: var(--dp-accent);
  letter-spacing: -.04em;
  line-height: 1;
  opacity: .35;
}
.rg-step__title { font-size: 1rem; font-weight: 700; color: var(--dp-text); }
.rg-step__desc { font-size: .85rem; color: var(--dp-text-muted); line-height: 1.7; }

/* ── 다른 지역 (발행 필터됨) ── */
.rg-regions { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 16px; }
.rg-regions a {
  display: inline-block;
  padding: 8px 20px;
  border: 1px solid var(--dp-border);
  border-radius: 100px;
  font-size: .85rem;
  color: var(--dp-text-sub);
  background: var(--dp-bg);
  font-weight: 500;
  transition: all .22s var(--dp-ease);
}
.rg-regions a:hover { background: var(--dp-primary-3); color: #fff; border-color: var(--dp-primary-3); }

/* ── CTA (지역) ── */
.rg-cta {
  background: var(--dp-primary-3);
  text-align: center;
  padding-block: clamp(64px, 10vw, 100px);
}
.rg-cta__title {
  font-size: clamp(1.8rem, 4vw, 3rem);
  font-weight: 200;
  letter-spacing: -.04em;
  color: #fff;
  margin-bottom: 12px;
  line-height: 1.2;
}
.rg-cta__title .accent { color: var(--dp-accent); font-weight: 400; font-style: italic; font-family: Georgia, serif; }
.rg-cta__sub { font-size: .95rem; color: rgba(255,255,255,.55); font-weight: 300; margin-bottom: 36px; }

/* ── 반응형 ── */
@media (max-width: 900px) {
  .rg-overview { grid-template-columns: 1fr; }
  .rg-steps { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .rg-svc-grid { grid-template-columns: 1fr 1fr; }
  .rg-steps { grid-template-columns: 1fr 1fr; }
  .rg-stats { gap: 20px; }
  .rg-stat { padding-right: 20px; margin-right: 20px; }
  .svc-hero-cta { flex-direction: column; }
  .dp-steps { grid-template-columns: 1fr 1fr; }
}

/* ── region-page 레거시 (구형 호환) ── */
.region-page-hero {
  background: var(--dp-primary-3);
  color: #fff;
}
.region-page-hero .breadcrumb ol { color: rgba(255,255,255,.5); }
.region-page-hero .breadcrumb a  { color: rgba(255,255,255,.65); }
.region-page-hero .breadcrumb li[aria-current] { color: rgba(255,255,255,.9); }
.region-content { max-width: 680px; }
.svc-hero-title {
  font-size: clamp(2rem, 5vw, 3.2rem);
  font-weight: 200;
  letter-spacing: -0.04em;
  line-height: 1.2;
  color: #fff;
  margin: 20px 0 16px;
}
.svc-hero-title .accent { color: var(--dp-accent); font-weight: 400; }
.svc-hero-desc {
  font-size: clamp(0.95rem, 2vw, 1.1rem);
  color: rgba(255,255,255,.7);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 32px;
}
.svc-hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }
.bg-soft { background: var(--dp-bg-soft); }
.section-title {
  font-size: clamp(1.5rem, 3.5vw, 2.2rem);
  font-weight: 200;
  letter-spacing: -0.03em;
  color: var(--dp-text);
  margin-bottom: 12px;
}
.section-desc {
  font-size: 0.95rem;
  color: var(--dp-text-muted);
  font-weight: 300;
  line-height: 1.7;
  margin-bottom: 40px;
}
.region-dong-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.region-dong-list li {
  padding: 8px 18px;
  border: 1px solid var(--dp-border);
  border-radius: 100px;
  font-size: 0.88rem;
  color: var(--dp-text-sub);
  background: var(--dp-bg);
}
@media (max-width: 600px) {
  .svc-hero-cta { flex-direction: column; }
  .dp-steps { grid-template-columns: 1fr 1fr; }
}
