/* 메인 스타일: 섹션별 레이아웃과 색상 설정 */
/* 구글 폰트에서 Nanum Gothic을 불러와 전체 폰트로 사용합니다. */
@import url("https://fonts.googleapis.com/css2?family=Nanum+Gothic:wght@400;700&display=swap");
:root {
  --max-width: 1280px;
  /* 메인 톤에 맞는 컬러 시스템을 정의합니다. */
  --brand-blue: #1a1a1a;
  --brand-accent: #1a1a1a;
  --text-dark: #1a1a1a;
  --text-light: rgba(26, 26, 26, 0.6);
  --bg-light: #f7f7f5;
  --bg-dark: #1a1a1a;
  --border-light: #dedbd4;
  --wood-accent: #b08a63;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  /* 기본 폰트를 Nanum Gothic으로 설정해 통일감을 줍니다. */
  font-family: "Nanum Gothic", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text-dark);
  /* 메인 화면 전체 톤을 부드럽게 보이도록 연한 배경을 적용합니다. */
  background: var(--bg-light);
  line-height: 1.6;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

a {
  color: inherit;
}

/* 공통 컨테이너 */
.container {
  max-width: var(--max-width);
  margin: 0 auto;
  /* 메인 화면 여백을 넉넉히 둬 미니멀하게 보이도록 합니다. */
  padding: 0 28px;
}

/* 히어로 섹션 */
.hero {
  position: relative;
  color: #ffffff;
  /* 히어로 섹션은 상하 여백과 최소 높이를 넓혀 신뢰감을 줍니다. */
  padding: 115px 0 140px;
  min-height: 78vh;
  overflow: hidden;
}

/* 히어로 슬라이더 */
.hero-slider {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.hero-slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.8s ease-in-out;
}

.hero-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-slide::after {
  content: "";
  position: absolute;
  inset: 0;
  /* 좌측에서 우측으로 흐려지는 프리미엄 톤 오버레이로 가독성을 확보합니다. */
  background: linear-gradient(
    90deg,
    rgba(18, 18, 16, 0.78) 0%,
    rgba(18, 18, 16, 0.5) 42%,
    rgba(18, 18, 16, 0.2) 100%
  );
}

.hero-slide.is-active {
  opacity: 1;
}

/* 히어로 컨텐츠는 슬라이더 위에 표시 */
.hero .container {
  position: relative;
  z-index: 1;
  /* 텍스트가 좌측에 안정적으로 정렬되도록 설정합니다. */
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  min-height: 56vh;
}

.hero-content {
  /* 히어로 문구가 너무 넓게 퍼지지 않도록 최대 폭을 제한합니다. */
  width: min(720px, 100%);
}

/* 히어로 문구 등장 애니메이션: 처음 로드 시 부드럽게 나타나도록 설정합니다. */
.hero-content--reveal .hero-reveal-title,
.hero-content--reveal .hero-reveal-body {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.8s ease, transform 0.8s ease;
}

/* 타이틀이 먼저 등장하고, 설명/리스트는 함께 이어서 등장하도록 지연을 둡니다. */
.hero-content--reveal .hero-reveal-title {
  transition-delay: 0.1s;
}

.hero-content--reveal .hero-reveal-body {
  transition-delay: 0.45s;
}

/* 스크립트가 클래스를 붙이면 실제로 보이도록 처리합니다. */
.hero-content--reveal.is-visible .hero-reveal-title,
.hero-content--reveal.is-visible .hero-reveal-body {
  opacity: 1;
  transform: translateY(0);
}

/* 슬라이더 이전/다음 버튼 */
.hero-control {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  border: none;
  background: rgba(15, 23, 42, 0.6);
  color: #ffffff;
  font-size: 28px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 2;
}

.hero-control.prev {
  left: 20px;
}

.hero-control.next {
  right: 20px;
}

.hero-control:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

.hero h1 {
  /* 타이틀 크기와 굵기를 키워 신뢰감을 강조합니다. */
  font-size: clamp(25px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: -0.6px;
  margin-bottom: 16px;
  line-height: 1.35;
}

.hero p {
  color: rgba(255, 255, 255, 0.88);
  max-width: 640px;
  font-size: 15px;
  margin-bottom: 24px;
}

/* 신뢰감을 주는 핵심 문구 리스트 */
.hero-trust {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 12px;
  max-width: 680px;
  font-size: 18px;
  color: rgba(255, 255, 255, 0.88);
}

/* 리스트 앞에 심플한 포인트를 넣어 가독성을 높입니다. */
.hero-trust li {
  position: relative;
  padding-left: 20px;
}

.hero-trust li::before {
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  color: var(--wood-accent);
}

.btn {
  /* 버튼도 살짝 넓고 둥글게 만들어 안정적인 느낌을 줍니다. */
  padding: 14px 24px;
  border-radius: 999px;
  text-decoration: none;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease, color 0.2s ease;
}

.btn.primary {
  /* 주요 CTA는 브랜드 블루로 눈에 띄게 처리합니다. */
  background: var(--text-dark);
  color: #ffffff;
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.12);
}

.btn.secondary {
  /* 보조 CTA는 아웃라인으로 정리해 우선순위를 구분합니다. */
  background: transparent;
  color: var(--text-dark);
  border: 1px solid var(--text-dark);
}

.btn:hover {
  /* 버튼 hover는 과하게 튀지 않도록 살짝 들어올립니다. */
  transform: translateY(-2px);
}

.btn:focus-visible {
  /* 키보드 접근성을 위한 포커스 링을 제공합니다. */
  outline: 2px solid var(--text-dark);
  outline-offset: 3px;
}

/* CTA 버튼 아이콘은 이모지 대신 심플한 벡터 형태로 통일합니다. */
.btn--phone::before,
.btn--kakao::before {
  content: "";
  width: 18px;
  height: 18px;
  display: inline-block;
  background-color: currentColor;
  mask-repeat: no-repeat;
  mask-position: center;
  mask-size: contain;
}

.btn--phone::before {
  /* 전화 아이콘 */
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M6.6 2.5a1.5 1.5 0 0 1 2.2 0l2.4 2.4a1.5 1.5 0 0 1 .3 1.7l-1.1 2.2a13.2 13.2 0 0 0 5.3 5.3l2.2-1.1a1.5 1.5 0 0 1 1.7.3l2.4 2.4a1.5 1.5 0 0 1 0 2.2l-1.4 1.4c-1.2 1.2-3 1.6-4.6 1-5.6-2.1-9.9-6.4-12-12-.6-1.6-.2-3.4 1-4.6l1.4-1.4z'/%3E%3C/svg%3E");
}

.btn--kakao::before {
  /* 말풍선 아이콘 */
  mask-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 3c-4.97 0-9 3.14-9 7 0 2.36 1.52 4.45 3.86 5.7l-.77 2.82a.6.6 0 0 0 .88.67l3.2-1.75c.59.08 1.2.13 1.83.13 4.97 0 9-3.14 9-7s-4.03-7-9-7z'/%3E%3C/svg%3E");
}

.section {
  /* 섹션 간 간격을 넓혀 공간감을 확보합니다. */
  padding: 96px 0;
  background: transparent;
}

.section-title {
  /* 제목은 시각적 계층을 명확히 하기 위해 크게 설정합니다. */
  font-size: clamp(28px, 3vw, 40px);
  margin-bottom: 16px;
  letter-spacing: -0.4px;
}

.section-title::after {
  /* 섹션 타이틀 아래에 얇은 우드 포인트 라인을 추가합니다. */
  content: "";
  display: block;
  width: 36px;
  height: 2px;
  background: var(--wood-accent);
  margin-top: 10px;
}

.section-description {
  color: var(--text-light);
  max-width: 760px;
  margin-bottom: 32px;
  font-size: 17px;
}

/* CTA 버튼 그룹: 히어로/하단 영역에서 동일한 간격을 유지합니다. */
.hero-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 16px;
}

/* 서비스 카드 */
.service-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 40px;
}

.card {
  /* 카드 스타일은 미니멀하게 정리합니다. */
  background: #ffffff;
  border: 1px solid var(--border-light);
  border-radius: 18px;
  padding: 24px;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
  transition: transform 0.2s ease;
}

.card h3 {
  margin-top: 12px;
}

.card:hover {
  /* 카드 hover는 살짝 떠오르는 정도로만 처리합니다. */
  transform: translateY(-2px);
}

/* 서비스 섹션 카드: 이미지/텍스트를 항상 한 줄(가로)로 유지하기 위해 flex로 정렬합니다. */
#services .service-grid .card {
  /* 카드 안에서 이미지와 텍스트를 가로로 나란히 배치합니다. */
  display: flex;
  /* 줄바꿈이 발생하지 않도록 고정하여 텍스트가 아래로 떨어지는 문제를 방지합니다. */
  flex-wrap: nowrap;
  /* 이미지와 텍스트 사이 간격을 일정하게 둡니다. */
  gap: 32px;
  /* 이미지와 텍스트의 시작선을 맞춰 정렬합니다. */
  align-items: flex-start;
  /* 기존 카드의 여백/배경은 서비스 섹션용 디자인에 맞춰 제거합니다. */
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}

/* 서비스 카드 이미지 크기 설정: 여기 값을 바꾸면 모든 카드 이미지 크기가 함께 변경됩니다. */
#services .service-grid {
  /* 이미지 너비를 조절하고 싶다면 이 값을 수정하세요. */
  --service-card-image-width: 520px;
  /* 이미지 높이를 조절하고 싶다면 이 값을 수정하세요. */
  --service-card-image-height: 360px;
}

/* 서비스 섹션 카드 이미지: 고정 크기 + 크롭 방식으로 통일합니다. */
#services .service-grid .card .card-image {
  /* 이미지가 항상 동일한 크기로 보이도록 고정합니다. */
  width: var(--service-card-image-width);
  height: var(--service-card-image-height);
  /* 비율이 다른 이미지도 영역을 꽉 채우도록 처리합니다. */
  object-fit: cover;
  /* 둥근 모서리는 카드 톤에 맞춰 유지합니다. */
  border-radius: 18px;
  /* flex 행 배치에서 불필요한 하단 여백을 제거합니다. */
  margin-bottom: 0;
  /* 이미지가 텍스트와 같은 줄에 고정되도록 block으로 유지합니다. */
  display: block;
}

/* 서비스 카드 텍스트 묶음을 이미지 옆에 배치합니다. */
#services .service-grid .card .service-text {
  /* 텍스트 영역이 남은 공간을 채워 같은 줄을 유지합니다. */
  flex: 1;
  /* 텍스트가 이미지와 동일한 시작선에서 정렬되도록 설정합니다. */
  align-self: flex-start;
  /* 제목과 설명 사이 간격을 일정하게 유지합니다. */
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.service-grid .card .service-text h3 {
  margin: 0 0 12px;
}

.service-grid .card .service-text p {
  margin: 0;
  color: var(--text-light);
}

/* 짝수 카드만 이미지 위치를 오른쪽으로 바꿉니다. */
#services .service-grid .card:nth-child(even) {
  /* 순서만 바꿔 이미지가 오른쪽, 텍스트가 왼쪽으로 배치됩니다. */
  flex-direction: row-reverse;
}

/* 서비스 섹션: 860px 이하에서는 카드 내용을 세로로 쌓습니다. */
@media (max-width: 860px) {
  #services .service-grid .card {
    /* 모바일에서는 이미지와 텍스트를 위아래로 배치합니다. */
    flex-direction: column;
    align-items: flex-start;
  }

  #services .service-grid .card:nth-child(even) {
    /* 짝수 카드도 동일하게 세로 정렬로 통일합니다. */
    flex-direction: column;
  }
}

/* 스크롤 등장 애니메이션: 이미지가 자연스럽게 올라오며 나타나도록 처리합니다. */
.scroll-reveal-image {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.8s ease, transform 0.8s ease;
  will-change: opacity, transform;
}

.scroll-reveal-image.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* 스크롤 등장 애니메이션: 텍스트도 이미지와 동일하게 부드럽게 나타나도록 처리합니다. */
.scroll-reveal-text {
  /* 처음에는 살짝 아래에 두고 투명하게 시작합니다. */
  opacity: 0;
  transform: translateY(16px);
  /* 텍스트는 조금 더 빠르게 등장하도록 시간을 조정합니다. */
  transition: opacity 0.6s ease, transform 0.6s ease;
  will-change: opacity, transform;
}

.scroll-reveal-text.is-visible {
  /* 화면에 보이면 제자리로 올라오며 나타납니다. */
  opacity: 1;
  transform: translateY(0);
}

/* 이미지 플레이스홀더 */
.image-placeholder {
  background: linear-gradient(135deg, var(--border-light), var(--bg-light));
  border-radius: 14px;
  width: 100%;
  height: 180px;
}

/* 서비스 카드 실제 이미지 스타일 */
.card-image {
  /* 이미지를 카드 폭에 맞춰 꽉 채웁니다. */
  width: 100%;
  /* 카드 간 높이 균일성을 위해 4:3 비율을 유지합니다. */
  aspect-ratio: 4 / 3;
  /* 이미지 비율이 달라도 영역을 자연스럽게 채우도록 설정합니다. */
  object-fit: cover;
  /* 플레이스홀더와 동일한 둥근 모서리를 적용해 디자인 일관성을 유지합니다. */
  border-radius: 14px;
  /* 이미지 하단 여백을 살짝 줘 텍스트와 붙어 보이지 않게 합니다. */
  margin-bottom: 4px;
  display: block;
}

/* 갤러리 카드 */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 28px;
}

/* 우측 하단 플로팅 버튼: 상담/블로그 바로가기 */
.floating-buttons {
  position: absolute;
  top: 0;
  right: 20px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 40;
  /* 스크롤 시 transform으로 부드럽게 이동할 예정이므로 성능 힌트 */
  will-change: transform;
}

.floating-button {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--text-dark);
  color: #ffffff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  border: 1px solid rgba(26, 26, 26, 0.2);
  box-shadow: 0 6px 12px rgba(0, 0, 0, 0.12);
  transition: transform 0.2s ease, filter 0.2s ease, background 0.2s ease;
}

.floating-button svg {
  width: 20px;
  height: 20px;
}

.floating-button--kakao {
  /* 카카오 버튼도 동일한 톤으로 통일합니다. */
  background: var(--text-dark);
  color: #ffffff;
}

.floating-button--blog {
  /* 블로그 버튼은 다크 톤으로 대비를 줍니다. */
  background: #1a1a1a;
  color: #ffffff;
}

.floating-button--instagram {
  /* 인스타그램 버튼도 동일한 단색 톤으로 정리합니다. */
  background: var(--text-dark);
  color: #ffffff;
}

.floating-text {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3px;
}

.floating-button:hover,
.floating-button:focus-visible {
  transform: translateY(-2px) scale(1.04);
  filter: brightness(1.05);
}

.floating-button:focus-visible {
  outline: 2px solid #ffffff;
  outline-offset: 2px;
}

/* 고객 후기: 가로 한 줄 무한 슬라이드 구성 */
.testimonial-section {
  /* 슬라이드가 섹션 밖으로 나가면 잘리도록 설정합니다. */
  overflow: hidden;
  /* 후기 영역만 살짝 구분되도록 밝은 배경색을 사용합니다. */
  background: var(--bg-light);
}

.testimonial-container {
  /* 컨테이너 내부에서만 여백을 조금 더 확보합니다. */
  padding-top: 0;
}

.testimonial-wrapper {
  /* 트랙이 움직일 때 양 끝이 잘리도록 래퍼에도 overflow를 적용합니다. */
  overflow: hidden;
  position: relative;
  /* 하단 굵은 라인이나 배경이 있다면 제거해 자연스럽게 보이게 합니다. */
  border: none;
  background: transparent;
}

.testimonial-wrapper::before,
.testimonial-wrapper::after {
  /* 트랙 양 끝을 부드럽게 페이드 처리해 자연스러운 흐름을 만듭니다. */
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 48px;
  pointer-events: none;
  z-index: 1;
}

.testimonial-wrapper::before {
  /* 왼쪽 페이드: 섹션 배경색과 자연스럽게 연결됩니다. */
  left: 0;
  background: linear-gradient(to right, var(--bg-light) 0%, rgba(247, 247, 245, 0) 100%);
}

.testimonial-wrapper::after {
  /* 오른쪽 페이드: 트랙이 끝에서 끊겨 보이지 않게 합니다. */
  right: 0;
  background: linear-gradient(to left, var(--bg-light) 0%, rgba(247, 247, 245, 0) 100%);
}

.testimonial-track {
  /* 후기 아이템을 가로로 한 줄 배치합니다. */
  display: flex;
  /* 카드 사이 간격을 넉넉하게 둬 읽기 편하게 만듭니다. */
  gap: 24px;
  /* 한 줄이 유지되도록 줄바꿈을 방지합니다. */
  width: max-content;
  /* 일정 속도로 오른쪽에서 왼쪽으로 계속 흐르게 합니다. */
  animation: testimonial-scroll 110s linear infinite;
  /* 애니메이션 성능 힌트를 브라우저에 제공합니다. */
  will-change: transform;
  /* 기본 리스트 스타일(점)을 제거합니다. */
  list-style: none;
  /* ul 기본 여백을 제거해 의도한 레이아웃을 유지합니다. */
  margin: 0;
  padding: 8px 0;
}

.testimonial-item {
  /* 강조선을 배치하기 위해 상대 위치를 지정합니다. */
  position: relative;
  /* 카드 내부를 세로로 나눠 텍스트와 작성자 라인을 배치합니다. */
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
  /* 카드가 줄어들지 않고 내용 길이만큼 유지되게 합니다. */
  flex: 0 0 auto;
  /* 너무 길게 늘어지는 것을 막기 위해 최대 너비를 제한합니다. */
  max-width: min(360px, 80vw);
  /* 카드 스타일을 적용합니다. */
  background: #f7f7f5;
  border: 1px solid var(--border-light);
  border-radius: 20px;
  padding: 26px 30px;
  color: var(--text-dark);
  font-size: 18px;
  line-height: 1.7;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.03);
  /* 마우스 올림 효과는 과하지 않게 그림자만 살짝 조정합니다. */
  transition: box-shadow 0.2s ease;
}

.testimonial-item:hover {
  /* 카드가 튀지 않도록 그림자만 살짝 강화합니다. */
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.06);
}

.testimonial-item--accent::before {
  /* 파란 강조선을 카드 외곽처럼 보이게 추가합니다. */
  content: none;
}

.testimonial-text {
  /* 후기 내용은 큰 따옴표가 포함된 상단 텍스트입니다. */
  margin: 0;
  font-weight: 500;
}

.testimonial-user {
  /* 작성자 라인은 굵게 강조합니다. */
  font-size: 20px;
  font-weight: 800;
  color: var(--text-dark);
}

.testimonial-item strong {
  /* 강조 텍스트가 들어올 가능성을 대비해 색상을 맞춰둡니다. */
  color: var(--text-dark);
}

@keyframes testimonial-scroll {
  from {
    /* 시작 지점: 첫 번째 묶음이 화면에 보이는 상태입니다. */
    transform: translateX(0);
  }
  to {
    /* 끝 지점: 전체 트랙의 절반(=첫 번째 묶음 길이)만큼 이동합니다. */
    transform: translateX(-50%);
  }
}

/* 화면이 좁아지면 간격과 속도를 조금 조정해 모바일 가독성을 높입니다. */
@media (max-width: 768px) {
  .container {
    /* 모바일에서는 좌우 여백을 살짝 줄여 공간을 확보합니다. */
    padding: 0 20px;
  }

  .hero {
    /* 모바일에서 히어로 높이가 과도하지 않도록 조정합니다. */
    padding: 110px 0 96px;
    min-height: 60vh;
  }

  .hero h1 {
    /* 모바일에서 타이틀이 답답하지 않도록 크기를 조정합니다. */
    font-size: clamp(30px, 7vw, 40px);
  }

  .section {
    /* 모바일 섹션 간격은 조금 줄여서 스크롤 부담을 낮춥니다. */
    padding: 72px 0;
  }

  .hero-actions {
    /* 버튼 간격을 줄여 작은 화면에서도 보기 좋게 합니다. */
    gap: 12px;
  }

  .service-grid,
  .gallery-grid {
    /* 카드 간격을 모바일에 맞게 줄입니다. */
    gap: 20px;
  }

  #services .service-grid .card {
    /* 모바일에서는 서비스 카드가 위아래로 쌓이도록 변경합니다. */
    flex-direction: column;
    /* 세로로 쌓여도 간격이 유지되도록 설정합니다. */
    align-items: flex-start;
  }

  #services .service-grid .card:nth-child(even) {
    /* 모바일에서는 순서 뒤집기를 해제해도 무방하지만, 동일하게 세로 정렬합니다. */
    flex-direction: column;
  }

  .testimonial-track {
    /* 모바일에서는 카드 간격을 줄여 더 많은 후기가 지나가도록 합니다. */
    gap: 16px;
    /* 화면이 작아 카드가 많이 차지하므로 속도를 약간 빠르게 조정합니다. */
    animation-duration: 90s;
  }

  .testimonial-item {
    /* 모바일에서 카드가 너무 넓지 않도록 제한을 더 강하게 줍니다. */
    max-width: 82vw;
    font-size: 16px;
    padding: 22px 24px;
    gap: 14px;
  }

  .testimonial-user {
    /* 모바일에서는 작성자 라인을 살짝 줄여 균형을 맞춥니다. */
    font-size: 18px;
  }
}

/* 사용자의 접근성 설정(모션 줄이기)을 존중해 애니메이션을 끕니다. */
@media (prefers-reduced-motion: reduce) {
  .testimonial-track {
    animation: none;
    transform: translateX(0);
  }
}

/* FAQ - details/summary 사용 */
.faq-list details {
  border: 1px solid var(--border-light);
  border-radius: 12px;
  padding: 16px 18px;
  margin-bottom: 12px;
  background: #ffffff;
}

.faq-list summary {
  cursor: pointer;
  font-weight: 600;
  position: relative;
  padding-right: 28px;
}

.faq-list summary::after {
  /* 아코디언 우측에 + 표시를 넣어 초보자도 쉽게 인지하게 합니다. */
  content: "+";
  position: absolute;
  right: 6px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 18px;
  color: var(--text-light);
}

.faq-list details[open] summary::after {
  /* 열려 있을 때는 - 표시로 변경합니다. */
  content: "−";
}

.faq-list summary:focus-visible {
  /* FAQ에도 포커스 스타일을 적용해 접근성을 높입니다. */
  outline: 2px solid var(--text-dark);
  outline-offset: 3px;
}

/* 문의 CTA */
.cta {
  /* 하단 CTA는 프리미엄 톤으로 강조합니다. */
  background: var(--bg-light);
  color: var(--text-dark);
  text-align: center;
  padding: 60px 0;
}

.cta .btn.secondary {
  /* CTA 영역에서 보조 버튼이 잘 보이도록 색상을 보정합니다. */
  background: transparent;
  color: var(--text-dark);
  border-color: var(--text-dark);
}

/* 푸터 */
.site-footer {
  background: var(--bg-dark);
  color: rgba(255, 255, 255, 0.85);
  padding: 40px 0 20px;
}

.footer-inner {
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 0 20px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 24px;
}

.footer-copy {
  text-align: center;
  margin-top: 24px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 13px;
}
