/* ============================================================
   Roots 신발장교체 — style.css  (GJL-style redesign)
   Primary: #8DB8A4 | Accent: #3D6B5C | BG: #fff
   Font: Pretendard | Radius: 0
   ============================================================ */

/* ── 1. 디자인 토큰 ──────────────────────────────────────── */
:root {
  --clr-primary:    #8DB8A4;
  --clr-primary-d:  #6E9E8C;
  --clr-primary-l:  #AACFBF;
  --clr-accent:     #3D6B5C;
  --clr-accent-d:   #2D5244;
  --clr-bg:         #ffffff;
  --clr-bg-soft:    #F0F7F4;
  --clr-text:       #1E3028;
  --clr-text-m:     #5A7A6E;
  --clr-border:     #C4DAD2;
  --clr-white:      #ffffff;
  --clr-success:    #2e7d32;
  --clr-error:      #c62828;

  --font:      'Pretendard', -apple-system, BlinkMacSystemFont, 'Noto Sans KR', sans-serif;
  --radius:    0px;
  --max-w:     1100px;
  --header-h:  64px;
  --ease:      cubic-bezier(0.16, 1, 0.3, 1);
  --tr:        .2s ease;
}

/* ── 2. 리셋 ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; overflow-x: hidden; }
body {
  font-family: var(--font);
  font-size: 1rem;
  line-height: 1.75;
  color: var(--clr-text);
  background: var(--clr-bg);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body.menu-open { overflow: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
p, li { word-break: keep-all; overflow-wrap: break-word; }
h1,h2,h3,h4,h5,h6 { font-family: var(--font); line-height: 1.3; color: var(--clr-text); word-break: keep-all; overflow-wrap: break-word; }
.svc-card-title, .gallery-title, .gallery-cat, .why-title,
.gnb-link, .mobile-link, .detail-badge, .detail-page-title,
.faq-question, .trust-label, .trust-suffix, .section-label,
.feat-title, .symp-title, .method-name, .proc-text,
.nseo-title, .cta-trust-item { word-break: keep-all; overflow-wrap: break-word; }
button { cursor: pointer; background: none; border: none; font: inherit; }

/* ── 3. 스크롤 진행바 ────────────────────────────────────── */
#scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 3px;
  background: var(--clr-accent);
  z-index: 9999;
  width: 0;
  transition: width .1s linear;
}

/* ── 4. 컨테이너 ─────────────────────────────────────────── */
.container {
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: 1.5rem;
}
.container-sm { max-width: 760px; }

/* ── 5. 헤더 ─────────────────────────────────────────────── */
.site-header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--clr-primary);
  height: var(--header-h);
  box-shadow: 0 2px 16px rgba(0,0,0,.25);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-h);
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: 1.5rem;
  gap: 1rem;
}
.logo {
  display: flex;
  flex-direction: column;
  gap: .1rem;
  text-decoration: none;
  line-height: 1;
}
.logo-name {
  font-family: var(--font);
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: -.01em;
  color: var(--clr-accent);
}
.logo-sub {
  font-size: .6rem;
  font-weight: 600;
  letter-spacing: .08em;
  color: rgba(30,48,40,.55);
}
.gnb-list {
  display: flex;
  align-items: center;
  gap: 4px;
}
.gnb-link {
  padding: 8px 16px;
  font-size: .88rem;
  font-weight: 600;
  color: rgba(30,48,40,.8);
  transition: color var(--tr);
}
.gnb-link:hover { color: var(--clr-accent); }
.gnb-cta {
  background: var(--clr-accent);
  color: var(--clr-white) !important;
  font-weight: 700;
  padding: 9px 20px;
}
.gnb-cta:hover { background: var(--clr-accent-d); }

/* 햄버거 */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  width: 28px;
  padding: 4px;
}
.hamburger span {
  display: block;
  height: 2px;
  background: var(--clr-accent);
  border-radius: 0;
  transition: transform .3s, opacity .3s;
}
.hamburger.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity: 0; }
.hamburger.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* 모바일 메뉴 */
.mobile-menu {
  display: none;
  position: fixed;
  top: var(--header-h);
  left: 0;
  width: 100%;
  background: var(--clr-accent);
  z-index: 199;
  transform: translateY(-8px);
  opacity: 0;
  pointer-events: none;
  transition: transform .3s var(--ease), opacity .3s;
}
.mobile-menu.open { transform: translateY(0); opacity: 1; pointer-events: auto; }
.mobile-menu-list { padding: 8px 0; }
.mobile-link {
  display: block;
  padding: 14px 24px;
  font-size: 1rem;
  font-weight: 600;
  color: rgba(255,255,255,.8);
  border-bottom: 1px solid rgba(255,255,255,.08);
  transition: color var(--tr);
}
.mobile-link:hover { color: var(--clr-white); }
.mobile-cta {
  color: var(--clr-accent) !important;
}
.mobile-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.5);
  z-index: 198;
  opacity: 0;
  transition: opacity .3s;
}
.mobile-overlay.show { opacity: 1; }

/* ── 6. 버튼 ─────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 2rem;
  background: var(--clr-accent);
  color: var(--clr-white);
  font-weight: 700;
  font-size: 1rem;
  border: 2px solid var(--clr-accent);
  border-radius: var(--radius);
  transition: background var(--tr), border-color var(--tr);
  min-height: 48px;
  white-space: nowrap;
}
.btn-primary:hover { background: var(--clr-accent-d); border-color: var(--clr-accent-d); }
.btn-primary.btn-lg { padding: 1rem 2.5rem; font-size: 1.05rem; min-height: 54px; }

.btn-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 2rem;
  background: transparent;
  color: var(--clr-white);
  font-weight: 700;
  font-size: 1rem;
  border: 2px solid rgba(255,255,255,.5);
  border-radius: var(--radius);
  transition: background var(--tr), border-color var(--tr);
  min-height: 48px;
}
.btn-secondary:hover { background: rgba(255,255,255,.12); border-color: var(--clr-white); }

.btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 2rem;
  background: transparent;
  color: var(--clr-accent);
  font-weight: 700;
  font-size: .95rem;
  border: 2px solid var(--clr-accent);
  border-radius: var(--radius);
  transition: background var(--tr), color var(--tr);
  min-height: 48px;
}
.btn-outline:hover { background: var(--clr-accent); color: var(--clr-white); }

.btn-white {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .75rem 2rem;
  background: var(--clr-white);
  color: var(--clr-accent);
  font-weight: 800;
  font-size: 1rem;
  border: 2px solid var(--clr-white);
  border-radius: var(--radius);
  min-height: 48px;
  transition: background var(--tr), color var(--tr);
}
.btn-white:hover { background: rgba(255,255,255,.9); color: var(--clr-accent-d); }

/* ── 7. 히어로 ───────────────────────────────────────────── */
.hero {
  position: relative;
  min-height: 100svh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--clr-accent);
}
.hero-slider {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1s ease;
}
.hero-slide.active { opacity: 1; }
.hero-slide img { width: 100%; height: 100%; object-fit: cover; }
.hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(135deg, rgba(61,107,92,.94) 0%, rgba(61,107,92,.80) 40%, rgba(61,107,92,.55) 70%, rgba(61,107,92,.35) 100%),
    radial-gradient(ellipse 60% 80% at 80% 50%, rgba(224,123,42,.12) 0%, transparent 65%);
}
.hero-content {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: 1.5rem;
  padding-top: 6rem;
  padding-bottom: 6rem;
}
.hero-eyebrow {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  margin-bottom: 1rem;
}
.hero-title {
  font-size: clamp(2.6rem, 6vw, 4.5rem);
  font-weight: 900;
  color: var(--clr-white);
  line-height: 1.1;
  margin-bottom: .75rem;
}
.hero-sub {
  font-size: 1rem;
  font-weight: 600;
  color: rgba(255,255,255,.55);
  margin-bottom: 1rem;
  letter-spacing: .03em;
}
.hero-desc {
  font-size: 1rem;
  color: rgba(255,255,255,.82);
  line-height: 1.85;
  margin-bottom: 2rem;
  max-width: 480px;
}
.hero-cta-group {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 2.5rem;
}
.hero-note {
  font-size: .76rem;
  color: rgba(255,255,255,.58);
  line-height: 1.6;
}

/* 트러스트 배지 */
.trust-badges {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  margin-top: 2rem;
}
.trust-badge {
  display: flex;
  align-items: flex-start;
  gap: .75rem;
  color: var(--clr-white);
}
.trust-badge-icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border: 1.5px solid rgba(255,255,255,.35);
  display: flex;
  align-items: center;
  justify-content: center;
}
.trust-badge-icon svg { width: 18px; height: 18px; stroke: rgba(255,255,255,.8); fill: none; }
.trust-badge-hl { font-size: 1rem; font-weight: 800; color: var(--clr-white); }
.trust-badge-cap { font-size: .73rem; color: rgba(255,255,255,.55); line-height: 1.4; }

/* 히어로 슬라이드 도트 */
.hero-dots {
  position: absolute;
  bottom: 28px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  display: flex;
  gap: 8px;
}
.hero-dot {
  width: 8px;
  height: 8px;
  padding: 6px;
  box-sizing: content-box;
  background: rgba(255,255,255,.4);
  border: none;
  cursor: pointer;
  transition: background .3s, transform .3s;
  border-radius: 0;
}
.hero-dot.active { background: rgba(255,255,255,.95); transform: scale(1.3); }

/* ── 8. 섹션 기본 ────────────────────────────────────────── */
.section { padding: 5rem 0; }
.section--dark { background: var(--clr-accent); }
.section--dark .section-label,
.section--dark .section-title,
.section--dark .kicker,
.section--dark p { color: var(--clr-white); }
.services-section .kicker,
.symp-section .kicker,
.trust-section .kicker { color: var(--clr-primary); }
.section--soft {
  background: var(--clr-bg-soft);
  border-top: 1px solid var(--clr-border);
  border-bottom: 1px solid var(--clr-border);
}
.section-label {
  display: inline-block;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .2em;
  color: var(--clr-accent);
  margin-bottom: .5rem;
}
.section-title {
  font-size: clamp(1.7rem, 3.5vw, 2.4rem);
  font-weight: 800;
  color: var(--clr-accent);
  margin-bottom: .75rem;
}
.section-desc {
  font-size: 1rem;
  color: var(--clr-text-m);
  max-width: 580px;
  line-height: 1.7;
}
.section-header { margin-bottom: 3rem; }
.section-cta-row { text-align: center; margin-top: 2.5rem; }

/* ── 9. 마퀴 갤러리 ──────────────────────────────────────── */
.marquee-wrap {
  position: relative;
  overflow: hidden;
  margin-top: 2.5rem;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
  mask-image: linear-gradient(to right, transparent 0%, #000 8%, #000 92%, transparent 100%);
}
.marquee-track {
  display: flex;
  gap: 1rem;
  width: max-content;
  animation: marquee-scroll 30s linear infinite;
  will-change: transform;
}
.marquee-wrap:hover .marquee-track { animation-play-state: paused; }
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee-item {
  flex: 0 0 auto;
  width: 280px;
  position: relative;
  overflow: hidden;
}
.marquee-item img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  display: block;
  transition: transform .4s var(--ease);
}
.marquee-item:hover img { transform: scale(1.05); }
.marquee-cap {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: .5rem .75rem;
  font-size: .75rem;
  font-weight: 600;
  color: var(--clr-white);
  background: linear-gradient(transparent, rgba(61,107,92,.82));
  line-height: 1.3;
}

/* ── 10. 서비스 카드 (풀이미지) ──────────────────────────── */
.services-section { background: var(--clr-accent); }
.service-cards {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
}
.svc-card {
  position: relative;
  height: 340px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  text-decoration: none;
  border-top: 3px solid transparent;
  transition: border-top-color .3s;
}
.svc-card:hover { border-top-color: var(--clr-accent); }
.svc-card-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}
.svc-card-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .65s var(--ease);
}
.svc-card:hover .svc-card-bg img { transform: scale(1.07); }
.svc-card::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(to top, rgba(61,107,92,.9) 0%, rgba(61,107,92,.45) 45%, rgba(61,107,92,.08) 100%);
  transition: background .35s;
}
.svc-card:hover::after {
  background: linear-gradient(to top, rgba(61,107,92,.95) 0%, rgba(61,107,92,.6) 50%, rgba(61,107,92,.18) 100%);
}
.svc-card-content {
  position: relative;
  z-index: 2;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: flex-end;
}
.svc-card-num {
  font-size: 2rem;
  font-weight: 900;
  color: var(--clr-primary);
  opacity: .9;
  line-height: 1;
  margin-bottom: .3rem;
  letter-spacing: -.02em;
}
.svc-card-title {
  font-size: 1rem;
  font-weight: 800;
  color: var(--clr-white);
  margin-bottom: .4rem;
  line-height: 1.25;
}
.svc-card-arrow {
  font-size: .82rem;
  color: rgba(255,255,255,.55);
  font-weight: 600;
}
.svc-card + .svc-card { border-left: 1px solid rgba(255,255,255,.08); }

/* ── 11. Why / 특징 ─────────────────────────────────────── */
.why-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
  margin-top: 2.5rem;
}
.why-item {
  display: flex;
  gap: 1.25rem;
  align-items: flex-start;
}
.why-item > * { min-width: 0; }
.why-num {
  font-size: 2.5rem;
  font-weight: 900;
  color: var(--clr-primary);
  opacity: .85;
  line-height: 1;
  flex-shrink: 0;
}
.why-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clr-white);
  margin-bottom: .35rem;
}
.why-desc { font-size: .9rem; color: rgba(255,255,255,.72); line-height: 1.65; }

/* ── 12. 신뢰 수치 (다크 섹션) ───────────────────────────── */
.trust-section { background: var(--clr-accent-d); }
.trust-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,.08);
}
.trust-item {
  background: var(--clr-accent-d);
  padding: 2.5rem 1.5rem;
  text-align: center;
}
.trust-num {
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 900;
  color: var(--clr-primary);
  line-height: 1;
  display: block;
  margin-bottom: .2rem;
}
.trust-suffix {
  font-size: .88rem;
  font-weight: 700;
  color: rgba(255,255,255,.6);
  display: block;
  margin-bottom: .5rem;
}
.trust-label { font-size: .82rem; color: rgba(255,255,255,.45); }

/* ── 13. CTA 배너 ────────────────────────────────────────── */
.cta-section {
  position: relative;
  overflow: hidden;
  padding: 6rem 0;
}
.cta-bg-img {
  position: absolute;
  inset: 0;
}
.cta-bg-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
  filter: brightness(.45) saturate(.7);
}
.cta-bg-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg,
    rgba(30,48,40,.88) 0%,
    rgba(61,107,92,.72) 100%);
}
.cta-inner {
  position: relative; z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0;
}

/* 프로세스 스트립 */
.cta-steps {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 2.5rem;
  flex-wrap: wrap;
  justify-content: center;
}
.cta-step {
  display: flex;
  align-items: center;
  gap: .55rem;
  padding: .45rem 1rem;
  background: rgba(255,255,255,.1);
  border: 1px solid rgba(255,255,255,.18);
}
.cta-step-num {
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--clr-primary);
  font-size: .65rem; font-weight: 700;
  color: var(--clr-accent);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.cta-step-text {
  font-size: .78rem; font-weight: 600;
  color: rgba(255,255,255,.85);
  white-space: nowrap;
}
.cta-step-arrow {
  width: 20px;
  text-align: center;
  color: rgba(255,255,255,.35);
  font-size: .8rem;
  flex-shrink: 0;
}

/* 헤드라인 */
.cta-title {
  font-size: clamp(2rem, 4.5vw, 3.2rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.15;
  letter-spacing: -.03em;
  margin-bottom: 1rem;
  text-shadow: 0 2px 20px rgba(0,0,0,.35);
}
.cta-title em {
  font-style: normal;
  color: var(--clr-primary);
}
.cta-desc {
  font-size: 1.05rem;
  color: rgba(255,255,255,.78);
  line-height: 1.75;
  margin-bottom: 2.5rem;
  max-width: 480px;
}

/* 버튼 */
.cta-btn-wrap {
  margin-bottom: 2.5rem;
}
.btn-cta-main {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  background: var(--clr-primary);
  color: var(--clr-accent);
  font-size: 1.08rem;
  font-weight: 800;
  padding: 1.1rem 2.5rem;
  letter-spacing: -.01em;
  text-decoration: none;
  transition: background var(--tr), transform var(--tr), box-shadow var(--tr);
  box-shadow: 0 8px 32px rgba(141,184,164,.35);
}
.btn-cta-main:hover {
  background: #a8cfc0;
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(141,184,164,.45);
}
.btn-cta-main svg {
  width: 18px; height: 18px;
  stroke: var(--clr-accent);
  fill: none;
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

/* 신뢰 배지 */
.cta-trust {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
  justify-content: center;
}
.cta-trust-item {
  display: flex;
  align-items: center;
  gap: .45rem;
  font-size: .8rem;
  color: rgba(255,255,255,.6);
  font-weight: 500;
}
.cta-trust-item svg {
  width: 14px; height: 14px;
  stroke: var(--clr-primary);
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex-shrink: 0;
}

/* 서비스·지역 페이지 심플 CTA (컨테이너 좁음) */
.cta-inner.cta-simple {
  gap: 1rem;
}
.cta-inner.cta-simple .cta-title { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.cta-inner.cta-simple .cta-desc  { margin-bottom: 1.75rem; }

@media (max-width: 640px) {
  .cta-section { padding: 4.5rem 0; }
  .cta-steps { gap: 0; }
  .cta-step { padding: .4rem .75rem; }
  .cta-step-arrow { width: 14px; font-size: .7rem; }
  .btn-cta-main { font-size: 1rem; padding: 1rem 2rem; }
}

/* ── 14. FAQ ─────────────────────────────────────────────── */
.faq-section { background: var(--clr-bg-soft); }
.faq-list { margin-top: 2rem; }
.faq-item { border-bottom: 1px solid var(--clr-border); }
.faq-question {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0;
  font-weight: 600;
  color: var(--clr-accent);
  gap: 1rem;
  background: none;
  border: none;
  width: 100%;
  text-align: left;
  cursor: pointer;
}
.faq-q { /* alias */ }
.faq-icon {
  flex-shrink: 0;
  color: var(--clr-accent);
  transition: transform var(--tr);
  font-size: 1.3rem;
  font-weight: 300;
  line-height: 1;
}
.faq-item.open .faq-icon { transform: rotate(45deg); }
.faq-answer, .faq-a {
  overflow: hidden;
  max-height: 0;
  transition: max-height .35s ease;
  font-size: .92rem;
  color: var(--clr-text-m);
  line-height: 1.75;
}
.faq-item.open .faq-answer,
.faq-item.open .faq-a {
  max-height: 400px;
  padding-bottom: 1.25rem;
}

/* ── 15. 지역 ────────────────────────────────────────────── */
.regions-section { background: var(--clr-bg-soft); }
.regions-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
  margin-top: 2rem;
}
.region-card {
  background: var(--clr-bg);
  padding: 1rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
  font-size: .88rem;
  font-weight: 600;
  color: var(--clr-accent);
  transition: background var(--tr), color var(--tr);
}
.region-card:hover { background: var(--clr-accent); color: var(--clr-white); }
.region-arrow { color: var(--clr-accent); font-weight: 700; }

/* ── 16. 갤러리 페이지 ───────────────────────────────────── */
.gallery-section { background: var(--clr-bg); }
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
}
.gallery-card {
  background: var(--clr-bg);
  overflow: hidden;
  transition: background var(--tr);
}
.gallery-card-link { display: block; }
.gallery-thumb { aspect-ratio: 4/3; overflow: hidden; }
.gallery-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .5s var(--ease);
}
.gallery-card:hover .gallery-thumb img { transform: scale(1.05); }
.gallery-info { padding: 1.25rem; border-top: 1px solid var(--clr-border); }
.gallery-cat {
  display: inline-block;
  font-size: .7rem;
  font-weight: 700;
  color: var(--clr-accent);
  letter-spacing: .05em;
  margin-bottom: .4rem;
}
.gallery-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--clr-accent);
  margin-bottom: .4rem;
}
.gallery-meta {
  display: flex;
  gap: 1rem;
  font-size: .78rem;
  color: var(--clr-text-m);
  margin-bottom: .6rem;
}
.gallery-more { font-size: .82rem; font-weight: 700; color: var(--clr-accent); }
.empty-msg { text-align: center; color: var(--clr-text-m); padding: 3rem; }

/* ── 17. 포트폴리오 상세 ──────────────────────────────────── */
.detail-hero {
  position: relative;
  min-height: 480px;
  overflow: hidden;
}
.detail-hero-img-wrap { position: absolute; inset: 0; }
.detail-hero-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.detail-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(61,107,92,.3) 0%, rgba(61,107,92,.82) 100%);
  display: flex;
  align-items: flex-end;
  padding-bottom: 3rem;
  padding-top: calc(var(--header-h) + 1.5rem);
}
.breadcrumb {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: .8rem;
  color: rgba(255,255,255,.6);
  margin-bottom: .75rem;
}
.breadcrumb a { color: rgba(255,255,255,.6); transition: color var(--tr); }
.breadcrumb a:hover { color: var(--clr-white); }
.detail-badge {
  display: inline-block;
  padding: 3px 10px;
  background: var(--clr-accent);
  color: var(--clr-white);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .04em;
  margin-bottom: .75rem;
}
.detail-hero-title {
  font-size: clamp(1.6rem, 4vw, 2.5rem);
  font-weight: 900;
  color: var(--clr-white);
}
.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; background: var(--clr-border); }
.compare-fig { background: var(--clr-bg); }
.compare-img-wrap { aspect-ratio: 4/3; overflow: hidden; }
.compare-img-wrap img { width: 100%; height: 100%; object-fit: cover; }
.compare-label {
  display: inline-block;
  margin: .75rem .75rem;
  padding: 4px 12px;
  font-size: .78rem;
  font-weight: 700;
}
.compare-label-before { background: var(--clr-bg-soft); color: var(--clr-text-m); }
.compare-label-after { background: var(--clr-accent); color: var(--clr-white); }
.summary-cards {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
  margin-bottom: 2.5rem;
}
.summary-card {
  background: var(--clr-bg);
  padding: 1.5rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: .4rem;
}
.summary-label { font-size: .75rem; color: var(--clr-text-m); }
.summary-value { font-weight: 700; color: var(--clr-accent); font-size: .95rem; }
.detail-area-section { background: var(--clr-bg-soft); }
.detail-area-text { font-size: 1.08rem; color: var(--clr-text); line-height: 2; max-width: 640px; margin-top: 1rem; }
.detail-scope-title { font-weight: 700; color: var(--clr-accent); margin-bottom: .4rem; }
.detail-scope-text { font-size: .95rem; color: var(--clr-text-m); }
.detail-summary-text { font-size: .95rem; color: var(--clr-text); line-height: 1.85; margin-top: 1rem; }
.detail-process-section { background: var(--clr-bg-soft); }
.detail-proc-list { display: flex; flex-direction: column; gap: 1px; background: var(--clr-border); border: 1px solid var(--clr-border); }
.detail-proc-item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  background: var(--clr-bg);
  padding: 1.25rem 1.5rem;
}
.detail-proc-item > * { min-width: 0; }
.proc-num {
  width: 32px; height: 32px;
  flex-shrink: 0;
  background: var(--clr-accent);
  color: var(--clr-white);
  font-weight: 700;
  font-size: .82rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 0;
}
.proc-text { font-size: .92rem; color: var(--clr-text); line-height: 1.7; padding-top: .3rem; }
.detail-nav-section { background: var(--clr-bg-soft); padding: 3rem 0; }
.detail-pagination {
  display: flex;
  align-items: stretch;
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
}
.detail-page-link {
  flex: 1;
  padding: 1.25rem 1.5rem;
  background: var(--clr-bg);
  display: flex;
  flex-direction: column;
  gap: .3rem;
  transition: background var(--tr);
}
.detail-page-link:hover { background: var(--clr-bg-soft); }
.detail-page-list {
  flex: 0 0 auto;
  align-items: center;
  justify-content: center;
  background: var(--clr-accent);
  color: var(--clr-white);
  font-weight: 700;
  font-size: .88rem;
  padding: 1.25rem 1.75rem;
}
.detail-page-list:hover { background: var(--clr-primary-l); }
.detail-page-dir { font-size: .72rem; color: var(--clr-text-m); }
.detail-page-title { font-weight: 600; color: var(--clr-accent); font-size: .88rem; }
.detail-page-link-disabled { background: var(--clr-bg-soft) !important; pointer-events: none; }

/* ── 18. 상담 페이지 ──────────────────────────────────────── */
.consult-section { background: var(--clr-bg); padding: 5rem 0; }
.consult-page-hero { padding-top: 5rem; padding-bottom: 4rem; }
.consult-cta-wrap {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
  margin-bottom: 3rem;
}
.btn-consult {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: 2.5rem 2rem;
  font-weight: 700;
  text-align: center;
  background: var(--clr-bg);
  transition: background var(--tr);
  border: none;
  cursor: pointer;
}
.btn-consult:hover { background: var(--clr-bg-soft); }
.btn-sms { border-top: 3px solid var(--clr-accent); }
.btn-tel { border-top: 3px solid var(--clr-accent); }
.btn-consult svg { width: 28px; height: 28px; stroke: var(--clr-accent); fill: none; }
.btn-consult span { font-size: 1rem; font-weight: 800; color: var(--clr-accent); }
.btn-consult small { font-size: .85rem; color: var(--clr-text-m); }
.consult-guide-title { font-weight: 800; font-size: 1.1rem; color: var(--clr-accent); margin-bottom: 1rem; }
.consult-guide-list { display: flex; flex-direction: column; gap: 1px; background: var(--clr-border); border: 1px solid var(--clr-border); margin-bottom: 2rem; }
.consult-guide-list li {
  display: flex;
  gap: 1rem;
  background: var(--clr-bg);
  padding: 1.25rem 1.5rem;
  align-items: flex-start;
}
.guide-num {
  width: 28px; height: 28px;
  background: var(--clr-accent);
  color: var(--clr-white);
  border-radius: 0;
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: .8rem;
  flex-shrink: 0;
}
.consult-guide-list strong { display: block; font-weight: 700; color: var(--clr-accent); margin-bottom: .25rem; }
.consult-guide-list p { font-size: .88rem; color: var(--clr-text-m); line-height: 1.65; }
.consult-info-box { background: var(--clr-accent); padding: 2rem; }
.consult-info-dl { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 2rem; }
.consult-info-dl dt { font-size: .78rem; font-weight: 700; color: rgba(255,255,255,.45); margin-bottom: .2rem; }
.consult-info-dl dd { font-size: .95rem; color: var(--clr-white); font-weight: 600; }

/* ── 19. 서비스 상세 페이지 ───────────────────────────────── */
.svc-hero {
  position: relative;
  min-height: 580px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.svc-hero-img { position: absolute; inset: 0; z-index: 0; }
.svc-hero-img img { width:100%;height:100%;object-fit:cover; }
.svc-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(61,107,92,.12) 0%, rgba(61,107,92,.88) 55%, rgba(61,107,92,.98) 100%);
  z-index: 1;
}
.svc-hero-content {
  position: relative; z-index: 2;
  width: 100%; max-width: var(--max-w);
  margin-inline: auto;
  padding: 5rem 1.5rem 5rem;
}
.svc-hero-kicker { font-size: .85rem; letter-spacing: .16em; text-transform: uppercase; color: rgba(255,255,255,.68); font-weight: 700; display: block; margin-bottom: 1.25rem; }
.svc-hero-title {
  font-size: clamp(2.8rem, 7vw, 5.5rem);
  font-weight: 900;
  color: var(--clr-white);
  margin-bottom: 0;
  line-height: 1.05;
  letter-spacing: -.03em;
  text-shadow: 0 4px 32px rgba(0,0,0,.45);
}
.svc-hero-rule { width: 56px; height: 4px; background: rgba(255,255,255,.5); margin: 1.5rem 0 2rem; }
.svc-hero-sub { color: rgba(255,255,255,.88); font-size: 1.1rem; margin-bottom: 2.25rem; line-height: 1.75; }

.feat-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; background: var(--clr-border); border: 1px solid var(--clr-border); margin-top: 3rem; }
.feat-card { background: var(--clr-bg); padding: 2.5rem 2rem; border-top: 4px solid transparent; transition: border-top-color var(--tr), background var(--tr); }
.feat-card:hover { border-top-color: var(--clr-accent); background: var(--clr-bg-soft); }
.feat-card-title { font-weight: 800; color: var(--clr-accent); margin-bottom: .75rem; font-size: 1.15rem; }
.feat-card-desc { font-size: 1rem; color: var(--clr-text-m); line-height: 1.9; }
/* ── Intro block ─────────────────────────────────────────── */
.intro-block {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
  margin-bottom: 3.5rem;
}
.intro-statement {
  position: relative;
}
.intro-accent-bar {
  width: 48px;
  height: 5px;
  background: var(--clr-accent);
  border-radius: 3px;
  margin-bottom: 2rem;
}
.intro-statement-text {
  font-size: clamp(1.55rem, 2.8vw, 2.15rem);
  font-weight: 800;
  color: var(--clr-text);
  line-height: 1.55;
  letter-spacing: -.025em;
}
.intro-body-group {
  display: flex;
  flex-direction: column;
  gap: 1.75rem;
  padding-top: .25rem;
}
.intro-body-para {
  font-size: 1.08rem;
  color: var(--clr-text-m);
  line-height: 2;
  padding-left: 1.25rem;
  border-left: 3px solid var(--clr-primary);
}
@media (max-width: 760px) {
  .intro-block { grid-template-columns: 1fr; gap: 2.25rem; margin-bottom: 2.5rem; }
  .intro-statement-text { font-size: clamp(1.35rem, 5vw, 1.7rem); }
}

.symp-section { background: var(--clr-accent); }
.symp-kicker { color: var(--clr-primary); font-size: .82rem; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; margin-bottom: .75rem; display: block; }
.symp-title { font-size: clamp(1.6rem,3.5vw,2.3rem); font-weight: 800; color: var(--clr-white); margin-bottom: 2.5rem; line-height: 1.25; }
.symp-list { display: grid; grid-template-columns: repeat(2,1fr); gap: 1px; background: rgba(255,255,255,.08); }
.symp-item { background: var(--clr-accent); padding: 2.25rem; display: flex; gap: 1.5rem; transition: background var(--tr); }
.symp-item:hover { background: rgba(255,255,255,.03); }
.symp-icon {
  width: 52px; height: 52px;
  border: 2px solid rgba(255,255,255,.6);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: var(--clr-white);
  font-weight: 800; font-size: 1.05rem;
}
.symp-head { font-weight: 700; color: var(--clr-white); margin-bottom: .55rem; font-size: 1.1rem; line-height: 1.4; }
.symp-body { font-size: .98rem; color: rgba(255,255,255,.72); line-height: 1.85; }

.proc-steps { max-width: 700px; margin: 0 auto; display: flex; flex-direction: column; gap: 0; position: relative; }
.proc-steps::before { content:''; position:absolute; left:25px; top:0;bottom:0; width:2px; background:var(--clr-border); z-index:0; }
.proc-step { display:flex; gap:1.75rem; align-items:flex-start; position:relative;z-index:1; padding-bottom:2.5rem; }
.proc-step:last-child { padding-bottom:0; }
.proc-step .proc-num { width:52px;height:52px;background:var(--clr-accent);color:var(--clr-white);font-weight:800;font-size:1.05rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;border-radius:0; }
.proc-name { font-weight:800;color:var(--clr-accent);margin-bottom:.5rem;font-size:1.2rem; }
.proc-desc { font-size:.98rem;color:var(--clr-text-m);line-height:1.9; }

.methods-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.method-card { background:var(--clr-bg-soft); padding:2.25rem; border-top:4px solid var(--clr-border); }
.method-card:first-child { border-top-color:var(--clr-accent); background:#fff9f5; }
.method-name { font-weight:800;color:var(--clr-accent);font-size:1.15rem;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--clr-border); }
.method-pros li,.method-cons li { padding:6px 0;font-size:.97rem;color:var(--clr-text-m);padding-left:20px;position:relative;line-height:1.6; }
.method-pros li::before { content:'O';position:absolute;left:0;color:var(--clr-success);font-weight:800; }
.method-cons li::before { content:'X';position:absolute;left:0;color:var(--clr-error);font-weight:800; }

.svc-gallery-grid { display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--clr-border);border:1px solid var(--clr-border); }
.svc-gallery-img { aspect-ratio:4/3;overflow:hidden; }
.svc-gallery-img img { width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease); }
.svc-gallery-item:hover .svc-gallery-img img { transform:scale(1.05); }
.svc-gallery-caption { padding:.9rem 1.1rem;font-size:.9rem;font-weight:600;color:var(--clr-text-m);border-top:1px solid var(--clr-border); }

.related-links { display:flex;gap:8px;flex-wrap:wrap;margin-top:2rem; }
.related-link { padding:10px 22px;border:2px solid var(--clr-border);font-size:.9rem;font-weight:600;color:var(--clr-accent);border-radius:0;transition:border-color var(--tr),background var(--tr); }
.related-link:hover { border-color:var(--clr-accent);background:var(--clr-accent);color:var(--clr-white); }

/* ── 20. 사이트맵 ────────────────────────────────────────── */
.sitemap-section { background: var(--clr-bg); }
.sitemap-group { margin-bottom: 2.5rem; }
.sitemap-group-title { font-weight:800;color:var(--clr-accent);border-left:3px solid var(--clr-accent);padding-left:.75rem;margin-bottom:1rem;font-size:.95rem; }
.sitemap-list { display:flex;flex-wrap:wrap;gap:6px; }
.sitemap-item a { display:inline-block;padding:6px 14px;background:var(--clr-bg-soft);border:1px solid var(--clr-border);font-size:.85rem;color:var(--clr-text);transition:background var(--tr),color var(--tr);border-radius:0; }
.sitemap-item a:hover { background:var(--clr-accent);border-color:var(--clr-accent);color:var(--clr-white); }

/* ── 21. 지역 페이지 ──────────────────────────────────────── */
.page-hero { padding-top: 5rem; padding-bottom: 3rem; background: var(--clr-accent); text-align: center; }
.page-hero-sm { padding-top: 4.5rem; padding-bottom: 2.5rem; }
.page-hero-inner { max-width: 700px; margin-inline: auto; padding-inline: 1.5rem; }
.kicker { display:inline-block;font-size:.72rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--clr-accent);margin-bottom:.75rem; }
.page-title { font-size:clamp(1.6rem,4vw,2.5rem);font-weight:900;color:var(--clr-white); }
.region-intro { font-size:.98rem;color:var(--clr-text);line-height:1.9;margin-bottom:2rem; }
.region-dongs { display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.5rem; }
.region-dong-tag { padding:5px 12px;background:var(--clr-bg-soft);border:1px solid var(--clr-border);font-size:.8rem;color:var(--clr-text-m);font-weight:500; }
.region-apts-title { font-weight:700;color:var(--clr-accent);margin-bottom:.6rem;font-size:.9rem; }

/* ── 지역 페이지 리디자인 ─────────────────────────────────── */
/* 1. 풀 히어로 */
.rg-hero {
  position: relative;
  min-height: 520px;
  display: flex;
  align-items: flex-end;
  overflow: hidden;
}
.rg-hero-img {
  position: absolute;
  inset: 0;
}
.rg-hero-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center;
}
.rg-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg,
    rgba(30,48,40,.25) 0%,
    rgba(30,48,40,.75) 55%,
    rgba(30,48,40,.97) 100%);
}
.rg-hero-content {
  position: relative; z-index: 2;
  width: 100%; max-width: var(--max-w);
  margin-inline: auto;
  padding: 3rem 1.5rem 3.5rem;
}
.rg-hero-kicker {
  display: inline-block;
  font-size: .78rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: rgba(255,255,255,.65);
  margin-bottom: 1rem;
}
.rg-hero-title {
  font-size: clamp(2.4rem, 6vw, 4.5rem);
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
  letter-spacing: -.03em;
  text-shadow: 0 3px 24px rgba(0,0,0,.4);
  margin-bottom: .75rem;
}
.rg-hero-sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,.8);
  margin-bottom: 2rem;
  line-height: 1.6;
}
.rg-hero-stats {
  display: flex;
  gap: 2rem;
  flex-wrap: wrap;
  margin-bottom: 2.25rem;
}
.rg-stat {
  display: flex;
  flex-direction: column;
  gap: .15rem;
}
.rg-stat-value {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--clr-primary);
  line-height: 1;
}
.rg-stat-label {
  font-size: .72rem;
  color: rgba(255,255,255,.55);
  letter-spacing: .06em;
}

/* 2. Why 섹션 */
.rg-why-section { background: var(--clr-bg); }
.rg-why-inner {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: 3.5rem;
  align-items: start;
}
.rg-why-label {
  font-size: .72rem; font-weight: 700;
  letter-spacing: .18em; text-transform: uppercase;
  color: var(--clr-accent);
  display: block;
  margin-bottom: 1rem;
}
.rg-why-title {
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 800;
  line-height: 1.4;
  color: var(--clr-text);
  letter-spacing: -.02em;
}
.rg-why-body {
  font-size: 1.05rem;
  line-height: 2;
  color: var(--clr-text-m);
  border-left: 4px solid var(--clr-primary);
  padding-left: 1.5rem;
}

/* 3. 지역별 카드 */
.rg-area-section { background: var(--clr-bg-soft); }
.rg-district-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
  margin-top: 2.5rem;
}
.rg-district-card {
  background: var(--clr-bg);
  border: 1px solid var(--clr-border);
  border-top: 4px solid var(--clr-accent);
  padding: 1.75rem 1.5rem;
  transition: box-shadow var(--tr);
}
.rg-district-card:hover { box-shadow: 0 6px 24px rgba(61,107,92,.12); }
.rg-district-name {
  font-size: 1rem; font-weight: 800;
  color: var(--clr-accent);
  margin-bottom: .65rem;
}
.rg-district-desc {
  font-size: .88rem;
  color: var(--clr-text-m);
  line-height: 1.75;
}
.rg-apt-group { margin-top: 2.5rem; }
.rg-apt-label {
  font-size: .8rem; font-weight: 700;
  color: var(--clr-accent);
  letter-spacing: .08em;
  margin-bottom: .75rem;
  display: block;
}
.rg-dong-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.rg-dong-tag {
  padding: 5px 14px;
  background: #fff;
  border: 1px solid var(--clr-border);
  font-size: .8rem;
  color: var(--clr-text-m);
  font-weight: 500;
}

/* 4. 체크리스트 */
.rg-checklist-section { background: var(--clr-accent); }
.rg-checklist-inner { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; align-items: center; }
.rg-checklist-title {
  font-size: clamp(1.35rem, 2.5vw, 1.9rem);
  font-weight: 800;
  color: #fff;
  line-height: 1.35;
  margin-bottom: 1rem;
}
.rg-checklist-lead { font-size: .95rem; color: rgba(255,255,255,.72); line-height: 1.7; }
.rg-checklist-list { display: flex; flex-direction: column; gap: .85rem; }
.rg-checklist-item {
  display: flex;
  align-items: flex-start;
  gap: .9rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.15);
  padding: 1rem 1.25rem;
  font-size: .9rem;
  color: rgba(255,255,255,.9);
  line-height: 1.55;
}
.rg-check-num {
  flex-shrink: 0;
  width: 22px; height: 22px;
  background: rgba(255,255,255,.18);
  border-radius: 50%;
  font-size: .68rem; font-weight: 700;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
}

/* 5. 지역 인근 링크 */
.rg-related-section { background: var(--clr-bg-soft); padding: 3rem 0; }
.rg-related-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 1rem; }
.rg-related-link {
  padding: 8px 18px;
  border: 1.5px solid var(--clr-accent);
  color: var(--clr-accent);
  font-size: .85rem; font-weight: 600;
  text-decoration: none;
  transition: background var(--tr), color var(--tr);
}
.rg-related-link:hover { background: var(--clr-accent); color: #fff; }

/* 반응형 */
@media (max-width: 900px) {
  .rg-why-inner { grid-template-columns: 1fr; gap: 2rem; }
  .rg-district-grid { grid-template-columns: repeat(2, 1fr); }
  .rg-checklist-inner { grid-template-columns: 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
  .rg-hero { min-height: 420px; }
  .rg-hero-stats { gap: 1.25rem; }
  .rg-district-grid { grid-template-columns: 1fr; }
}

/* ── 22. 404 ─────────────────────────────────────────────── */
.not-found-section { padding:8rem 0 6rem;background:var(--clr-bg); }
.not-found-inner { text-align:center; }
.not-found-code { font-size:clamp(5rem,15vw,9rem);font-weight:900;color:var(--clr-border);line-height:1;margin-bottom:1rem; }
.not-found-title { font-size:clamp(1.3rem,3vw,2rem);font-weight:800;color:var(--clr-accent);margin-bottom:.75rem; }
.not-found-desc { color:var(--clr-text-m);margin-bottom:2.5rem;line-height:1.8; }
.not-found-nav { display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap; }

/* ── 23. 관리자 ──────────────────────────────────────────── */
.admin-body { background:#0f1520;min-height:100vh; }
.admin-wrap { max-width:960px;margin:0 auto;padding:2rem 1.5rem; }
.admin-header { background:var(--clr-accent);color:var(--clr-white);padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem; }
.admin-title { font-weight:800;font-size:1rem; }
.admin-logout { font-size:.82rem;color:rgba(255,255,255,.65);transition:color var(--tr); }
.admin-logout:hover { color:var(--clr-white); }
.admin-card { background:var(--clr-white);padding:2rem;margin-bottom:1.25rem;border-top:3px solid var(--clr-accent); }
.admin-card-title { font-weight:800;color:var(--clr-accent);font-size:.92rem;margin-bottom:1rem;border-bottom:1px solid var(--clr-border);padding-bottom:.75rem; }
.admin-stat-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--clr-border); }
.admin-stat { background:var(--clr-bg-soft);padding:1.25rem;text-align:center; }
.admin-stat-num { font-weight:900;font-size:1.6rem;color:var(--clr-accent); }
.admin-stat-label { font-size:.75rem;color:var(--clr-text-m);margin-top:.2rem; }
.admin-action-btn { display:inline-flex;align-items:center;gap:.5rem;padding:8px 18px;background:var(--clr-accent);color:var(--clr-white);font-size:.85rem;font-weight:600;border:none;cursor:pointer;transition:background var(--tr); }
.admin-action-btn:hover { background:var(--clr-accent); }
.admin-action-btn.danger { background:#c62828; }
.admin-action-btn.accent { background:var(--clr-accent); }
.admin-table { width:100%;border-collapse:collapse;font-size:.85rem; }
.admin-table th { text-align:left;padding:8px 12px;background:var(--clr-bg-soft);color:var(--clr-text-m);font-weight:700;border-bottom:1px solid var(--clr-border); }
.admin-table td { padding:8px 12px;border-bottom:1px solid var(--clr-border);color:var(--clr-text); }
.admin-badge { display:inline-block;padding:2px 8px;font-size:.72rem;font-weight:700;border-radius:0; }
.admin-badge.pub { background:#e8f5e9;color:#2e7d32; }
.admin-badge.queue { background:#fff3e0;color:#e65100; }
.admin-msg { padding:10px 14px;margin-bottom:1rem;font-size:.85rem;font-weight:600; }
.admin-msg.ok { background:#e8f5e9;color:#2e7d32; }
.admin-msg.err { background:#ffebee;color:#c62828; }
.admin-login { min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f1520; }
.admin-login-box { background:var(--clr-white);padding:3rem 2.5rem;width:100%;max-width:380px; }
.admin-login-title { font-weight:900;font-size:1.3rem;color:var(--clr-accent);text-align:center;margin-bottom:2rem; }
.admin-form-group { margin-bottom:1rem; }
.admin-form-group label { display:block;font-size:.82rem;font-weight:700;color:var(--clr-text-m);margin-bottom:.4rem; }
.admin-form-group input { width:100%;padding:10px 12px;border:1.5px solid var(--clr-border);font-size:.95rem;transition:border-color var(--tr);border-radius:0; }
.admin-form-group input:focus { outline:none;border-color:var(--clr-accent); }
.admin-submit { width:100%;padding:12px;background:var(--clr-accent);color:var(--clr-white);border:none;font-size:.95rem;font-weight:700;cursor:pointer;transition:background var(--tr);margin-top:.5rem;border-radius:0; }
.admin-submit:hover { background:var(--clr-primary-l); }

/* ── 24. 푸터 ────────────────────────────────────────────── */
.site-footer {
  background: var(--clr-accent);
  color: var(--clr-white);
  padding: 4rem 0 0;
}
.footer-inner {
  max-width: var(--max-w);
  margin-inline: auto;
  padding-inline: 1.5rem;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 3rem;
}
.footer-logo-text { font-weight:900;font-size:1.2rem;color:var(--clr-white);margin-bottom:.2rem; }
.footer-sub { font-size:.6rem;color:rgba(255,255,255,.35);letter-spacing:.08em;margin-bottom:.85rem; }
.footer-tagline { font-size:.88rem;color:rgba(255,255,255,.55);line-height:1.7; }
.footer-address { font-style:normal;font-size:.82rem;color:rgba(255,255,255,.45);line-height:1.85;margin-top:.75rem; }
.footer-nav-title { font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:rgba(255,255,255,.35);margin-bottom:.85rem; }
.footer-nav ul { display:flex;flex-direction:column;gap:.5rem; }
.footer-nav a { font-size:.88rem;color:rgba(255,255,255,.6);transition:color var(--tr); }
.footer-nav a:hover { color:var(--clr-accent); }
.footer-bottom {
  border-top:1px solid rgba(255,255,255,.1);
  text-align:center;
  padding:1.5rem 1.5rem;
  font-size:.78rem;
  color:rgba(255,255,255,.3);
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:.5rem;
  max-width:var(--max-w);
  margin-inline:auto;
}
.footer-hours { font-size:.78rem;color:rgba(255,255,255,.3); }

/* ── 25. Floating CTA ────────────────────────────────────── */
.floating-cta {
  position: fixed;
  bottom: 2rem; right: 1.5rem;
  z-index: 500;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: var(--clr-accent);
  color: var(--clr-white);
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 20px rgba(224,123,42,.45);
  text-decoration: none;
  transition: transform var(--tr), box-shadow var(--tr);
}
.floating-cta:hover { transform: scale(1.08); box-shadow: 0 6px 28px rgba(224,123,42,.6); }
.floating-cta svg { width:24px;height:24px;stroke:var(--clr-white);fill:none; }
.floating-cta::before {
  content:'';
  position:absolute;inset:0;
  border-radius:50%;
  background:var(--clr-accent);
  animation:pulse-ring 2.4s ease-out infinite;
}
@keyframes pulse-ring {
  0%   { transform:scale(1);opacity:.6; }
  50%  { transform:scale(1.2);opacity:.2; }
  100% { transform:scale(1.4);opacity:0; }
}
.back-to-top {
  position:fixed;
  bottom:5rem; right:1.5rem;
  z-index:300;
  width:44px;height:44px;
  border-radius:50%;
  background:var(--clr-accent);
  color:var(--clr-white);
  border:2px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;
  opacity:0;pointer-events:none;
  transform:translateY(12px);
  transition:opacity .3s,transform .3s;
  box-shadow:0 4px 16px rgba(61,107,92,.35);
}
.back-to-top.visible { opacity:1;pointer-events:auto;transform:translateY(0); }
.back-to-top:hover { background:var(--clr-accent); }

/* ── 26. 애니메이션 ──────────────────────────────────────── */
/* 스크롤 카드 reveal */
.rv {
  opacity:0;
  transform:translateY(20px);
  transition:opacity .65s var(--ease), transform .65s var(--ease);
}
.rv.in { opacity:1;transform:translateY(0); }

/* 텍스트/섹션 fade-in-up (reference pattern) */
.fade-in-up {
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s var(--ease), transform .7s var(--ease);
}
.fade-in-up.is-visible { opacity:1; transform:none; }

/* 순차 지연 */
.fade-in-up[data-delay="1"] { transition-delay:.08s; }
.fade-in-up[data-delay="2"] { transition-delay:.18s; }
.fade-in-up[data-delay="3"] { transition-delay:.28s; }
.fade-in-up[data-delay="4"] { transition-delay:.38s; }
.fade-in-up[data-delay="5"] { transition-delay:.48s; }

/* 히어로 슬라이드 진행 바 */
.hero-progress {
  position:absolute;
  bottom:0; left:0;
  height:2px;
  background:rgba(255,255,255,.6);
  z-index:3;
  width:0;
  transition:none;
}


/* 동작 줄이기 설정 */
@media (prefers-reduced-motion: reduce) {
  .fade-in-up,
  .rv { transition:none; opacity:1; transform:none; }
  .marquee-track { animation:none; flex-wrap:wrap; width:100%; }
  .floating-cta::before { animation:none; }
}

/* ── 27. NSEO 내부링크 카드 그리드 ──────────────────────── */
.nseo-section { background: var(--clr-bg-soft); border-top: 1px solid var(--clr-border); border-bottom: 1px solid var(--clr-border); }
.nseo-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: var(--clr-border);
  border: 1px solid var(--clr-border);
  margin-top: 2rem;
  overflow: hidden;
}
.nseo-card {
  background: var(--clr-bg);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  position: relative;
  transition: transform .3s var(--ease), box-shadow .3s var(--ease);
}
a.nseo-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 16px 40px rgba(61,107,92,.14);
  z-index: 2;
}
.nseo-card.is-main { border-top: 3px solid var(--clr-accent); }
.nseo-card.is-current { opacity: .55; cursor: default; }
.nseo-card-img { overflow: hidden; aspect-ratio: 16/9; }
.nseo-card-img img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
a.nseo-card:hover .nseo-card-img img { transform: scale(1.05); }
.nseo-card-body { padding: 1rem 1.25rem; flex: 1; }
.nseo-card-title { font-size: .95rem; font-weight: 800; color: var(--clr-accent); margin-bottom: .25rem; }
.nseo-card-label { font-size: .78rem; color: var(--clr-text-m); line-height: 1.45; }
.nseo-badge {
  display: inline-block;
  font-size: .65rem; font-weight: 700; letter-spacing: .06em;
  padding: 2px 7px;
  margin-bottom: .4rem;
  border-radius: 0;
}
.nseo-badge--main { background: var(--clr-accent); color: #fff; }
.nseo-badge--cur  { background: var(--clr-accent); color: #fff; }


/* ── 29. Breadcrumb ─────────────────────────────────────── */
.breadcrumb-bar {
  background: var(--clr-accent);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.breadcrumb-list {
  display: flex; align-items: center; gap: .4rem;
  list-style: none;
  font-size: .75rem;
  color: rgba(255,255,255,.45);
  padding: .55rem 0;
}
.breadcrumb-list a { color: rgba(255,255,255,.45); text-decoration: none; transition: color var(--tr); }
.breadcrumb-list a:hover { color: var(--clr-accent); }
.breadcrumb-list li + li::before { content: '/'; margin-right: .4rem; }
.breadcrumb-list li:last-child { color: rgba(255,255,255,.75); }
.svc-hero-breadcrumb { display: none; }

/* ── 30. CTA 신뢰배지 ───────────────────────────────────── */
.cta-trust {
  display: flex; gap: 2rem; flex-wrap: wrap;
  margin-top: 1.75rem;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,.2);
}
.cta-trust-item {
  display: flex; align-items: center; gap: .5rem;
  font-size: .82rem; font-weight: 600;
  color: rgba(255,255,255,.85);
}
.cta-trust-item svg { width: 16px; height: 16px; stroke: rgba(255,255,255,.7); fill: none; flex-shrink: 0; }

/* ── 31. 반응형 ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .service-cards { grid-template-columns: repeat(3,1fr); }
  .svc-card { height:300px; }
  .svc-card + .svc-card { border-left:none;border-top:1px solid rgba(255,255,255,.08); }
  .trust-grid { grid-template-columns: repeat(2,1fr); }
  .gallery-grid { grid-template-columns: repeat(2,1fr); }
  .feat-cards { grid-template-columns: 1fr 1fr; }
  .symp-list { grid-template-columns: 1fr; }
  .methods-grid { grid-template-columns: 1fr 1fr; }
  .summary-cards { grid-template-columns: repeat(2,1fr); }
  .footer-inner { grid-template-columns: 1fr 1fr; }
  .cta-inner { flex-direction: column; gap: 2rem; }
  .nseo-grid { grid-template-columns: repeat(3, 1fr) !important; }
  .admin-stat-grid { grid-template-columns: repeat(2,1fr); }
  .consult-info-dl { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .gnb { display:none; }
  .hamburger { display:flex; }
  .mobile-menu { display:block; }
  .mobile-overlay { display:block; }

  .section { padding:3.5rem 0; }
  .service-cards { grid-template-columns: repeat(2,1fr); }
  .svc-card { height:260px; }
  .gallery-grid { grid-template-columns: 1fr; }
  .svc-gallery-grid { grid-template-columns: 1fr 1fr; }
  .footer-inner { grid-template-columns: 1fr;gap:2rem; }
  .footer-bottom { flex-direction:column;text-align:center; }
  .compare-grid { grid-template-columns: 1fr; }
  .regions-grid { grid-template-columns: repeat(3,1fr); }
  .consult-cta-wrap { grid-template-columns: 1fr; }
  .detail-pagination { flex-direction:column; }
  .hero-cta-group { flex-direction:column; }
  .hero-cta-group .btn-primary,
  .hero-cta-group .btn-secondary { width:100%;justify-content:center; }
  .trust-badges { gap:1.25rem; }
  .why-grid { grid-template-columns: 1fr; }
  .nseo-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .cta-trust { gap:1.25rem; }
}

@media (max-width: 560px) {
  .feat-cards { grid-template-columns: 1fr; }
  .methods-grid { grid-template-columns: repeat(2,1fr); }
  .nseo-grid { grid-template-columns: 1fr !important; }
  .trust-grid { grid-template-columns: repeat(2,1fr); }
  .summary-cards { grid-template-columns: 1fr; }
  .svc-gallery-grid { grid-template-columns: 1fr; }
  .consult-cta-wrap { grid-template-columns: 1fr; }
  .regions-grid { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 480px) {
  .service-cards { grid-template-columns: repeat(2,1fr); }
  .svc-card { height:200px; }
  .svc-gallery-grid { grid-template-columns: 1fr; }
  .trust-grid { grid-template-columns: 1fr 1fr; }
  .regions-grid { grid-template-columns: repeat(2,1fr); }
  .summary-cards { grid-template-columns: repeat(2,1fr); }
  .floating-cta { bottom:1.5rem;right:1rem; }
  .back-to-top { bottom:4.5rem;right:1rem; }
  .cta-inner { text-align:center; }
  h1,h2,h3,h4,h5,h6 { line-height: 1.4; }
  body { line-height: 1.8; }
}

@media (hover: none) {
  .svc-card:hover { border-top-color: transparent; }
  .svc-card:active { border-top-color: var(--clr-accent); }
  .gallery-card:hover .gallery-thumb img { transform: none; }
  .gallery-card:active .gallery-thumb img { transform: scale(1.03); }
  .marquee-wrap:hover .marquee-track { animation-play-state: running; }
}
