/* 메인 비주얼 */

.main-visual .main-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(12, 13, 13, 0.9);
}

.main-title-line {
  margin: 0;
  padding: 0;
}

.mobile-br {
  display: none;
}

/* 도메인 컨테이너 (소프트웨어 테스트 페이지) */
.domain-section-container {
  margin-top: 160px;
}

.domain-content-wrapper {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 80px;
  width: 100%;
}

.domain-text-wrapper {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 0px;

  flex: none;
  order: 0;
  flex-grow: 0;

  opacity: 0;
  transform: translateY(40px);
  transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

.domain-section-container.is-revealed .domain-text-wrapper {
  opacity: 1;
  transform: translateY(0);
}

.domain-description {
  font-family: "Pretendard", sans-serif;
  font-style: normal;
  font-weight: 400;
  font-size: 18px;
  line-height: 140%;
  margin-top: 2rem;
  color: #ffffff;
  word-break: keep-all;
  flex: none;
  order: 1;
  flex-grow: 0;
}

.domain-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: flex-end;
  padding: 0px;
  gap: 40px 20px;

  margin: 0 auto;

  flex: none;
  order: 1;
  flex-grow: 0;
}

.domain-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  will-change: opacity, transform;
}

.domain-icon,
.domain-label {
  opacity: 0;
  transform: translateY(20px);
  transition: all 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.domain-section-container.is-revealed .domain-item .domain-icon,
.domain-section-container.is-revealed .domain-item .domain-label {
  opacity: 1;
  transform: translateY(0);
}

.domain-icon {
  width: 60px;
  height: 60px;
  object-fit: contain;
}

.domain-label {
  font-family: inherit;
  font-size: 1rem;
  font-weight: 400;
  color: #ffffff;
  text-align: center;
  word-break: keep-all;
}

/* 태블릿 및 모바일 반응형 */

/* 공통 섹션 스타일 */

.section-container {
  position: relative;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  height: 100%;
  padding: 0 var(--grid-margin);
}

.section-title {
  font-size: 1.111rem;
  font-weight: 600;
  letter-spacing: 0px;
  color: #0073e6; /* 메인컬러 */
  margin-bottom: 16px;
}

.section-subtitle {
  font-size: 2rem;
  font-weight: 700;
  line-height: 2.444rem;
  letter-spacing: 0px;

  color: #111111; /* 진한 텍스트 */
}

.solutions-title-line {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

/* 섹션별 배경 스타일 */
.solution-section {
  background-image: url("../img/solutions-section-bg.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.features-section {
  background-color: #ffffff;
}

.advantages-section {
  position: relative;
  width: 100%;
  padding: 160px 0;
  display: flex;
  flex-direction: column;
  gap: 160px;
  z-index: 2;
}

.advantages-section .main-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  object-fit: cover;
}

.advantages-section .main-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  z-index: 1;
}

.cta-section {
  position: relative;
  width: 100%;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 2;
  height: 280px;
}

.cta-section .cta-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
.cta-section .main-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    to right,
    rgba(0, 115, 230, 0.85),
    rgba(204, 245, 75, 0.85)
  );
  z-index: 0;
}

.cta-buttons {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
}

/* 콘텐츠 영역 */
.solution {
  overflow: hidden;
  position: relative;
}

.solution-wrap {
  position: relative;
}

/* 탭영역 (2단 컨설팅 탭) */
.consulting-tabs-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  position: relative;
  background-color: #f7f9fa;
  z-index: 100;
  transition:
    transform 0.3s ease,
    top 0.3s ease;
}

.consulting-tabs-container.fixed {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 990; /* 헤더(1000)보다 아래, 다른 콘텐츠보단 위로 */
}

/* Fixed state padding */
body.consulting-tabs-offset .consulting-wrap {
  padding-top: 60px; /* 1단 탭 기본값 */
}

body.consulting-tabs-offset:has(.has-sub-tabs) .consulting-wrap {
  padding-top: 120px; /* 2단 탭 */
}

@media (max-width: 767px) {
  body.consulting-tabs-offset .consulting-wrap {
    padding-top: 48px; /* 모바일 1단 */
  }

  body.consulting-tabs-offset:has(.has-sub-tabs) .consulting-wrap {
    padding-top: 96px; /* 모바일 2단 */
  }
}

.consulting-tabs {
  display: flex;
  width: 100%;
  height: 60px;
  align-items: flex-end;
  justify-content: center;
  gap: 80px;
  position: relative;
  background-color: #ffffff;
  border-bottom: 1px solid #e0e0e0;
}

.tab-active,
.tab-item {
  display: flex;
  width: auto;
  min-width: 140px;
  height: 50px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  text-decoration: none;
  transition: color 0.3s ease;
}

.tab-active {
  /* No default border */
}

.tab-item {
  /* No default border */
}

.tab-text {
  position: relative;
  width: fit-content;
  font-family: "Pretendard";
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0;
  line-height: 24px;
  white-space: nowrap;
  transition: all 0.3s ease;
}

.tab-active .tab-text {
  color: #111111;
}

.tab-item .tab-text {
  color: #999999;
}

/* 하단 바 애니메이션을 위한 인디케이터 */
.tab-indicator {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  background-color: #0073e6;
  transition: all 0.4s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
  z-index: 10;
}

/* 호버 효과 */
.tab-item:hover .tab-text {
  color: #0073e6;
}

/* 클릭 효과 */
.tab-item:active .tab-text {
  color: #111111;
}

/* 하단 서브 탭 */
.consulting-tabs-container:not(.has-sub-tabs) .consulting-sub-tabs {
  display: none !important;
}

.consulting-sub-tabs {
  display: flex;
  width: 100%;
  height: 60px;
  align-items: center;
  justify-content: center;
  gap: 40px;
  background-color: #f5f7fa;
  border-bottom: 1px solid #e5e8ee;
}

.sub-tab-item {
  font-family: "Pretendard";
  font-weight: 500;
  font-size: 15px;
  color: #666666;
  text-decoration: none;
  padding: 8px 20px;
  border-radius: 9999px; /* 알약 형태 둥근 테두리 */
  transition: all 0.2s ease;
}

.sub-tab-item:hover {
  color: #333333;
}

.sub-tab-item.active {
  background-color: #0073e6;
  color: #ffffff;
  font-weight: 600;
}

/* 솔루션 요약 영역 */
.summary-section {
  width: 100%;
  position: relative;
  overflow: hidden;
  scroll-margin-top: 60px; /* 1단 탭 기본값 */
}

.consulting-tabs-container.has-sub-tabs + .consulting-wrap .summary-section {
  scroll-margin-top: 120px; /* 2단 탭 */
}

.consulting-summary-section {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
  isolation: isolate;
  min-height: 629px;
}

.consulting-summary-section::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.consulting-summary-section::after {
  content: "";
  position: absolute;
  width: 680.45px;
  height: 680.45px;
  left: -399.23px;
  top: 75.71px;
  background: linear-gradient(112.06deg, #0073e6 40.9%, #ccf54b 64.42%);
  opacity: 0.13;
  filter: blur(181.45px);
  transform: rotate(60deg);
  z-index: 1;
  pointer-events: none;
}

.consulting-summary-section .header-bg-wrap {
  z-index: 0;
}

.consulting-summary-section .header-bg {
  width: 100%;
  height: 648px;
  object-fit: cover;
}

.consulting-summary-section .section-container {
  position: relative;
  z-index: 2;
}

.consulting-summary-section .consulting-header {
  position: relative;
  width: 100%;
  height: 100%;
  /* max-width: 1280px; 를 제거하고 부모 container를 쓰거나 height 유지 */
  min-height: 629px;
  margin: 0 auto !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.consulting-summary-section .consulting-info {
  width: 65% !important;
  height: 100%;
  display: flex;
  flex-direction: column;
  gap: 28px !important;
  color: #fff;
  padding-right: 90px;
}

.consulting-summary-section .header-title {
  margin: 0;
  gap: 10px !important;
}

.consulting-summary-section .summary-subtitle,
.consulting-summary-section .summary-title {
  margin: 0;
}

.consulting-summary-section .summary-subtitle {
  font-family: "Pretendard", sans-serif;
  font-size: 20px;
  font-weight: 600;
  white-space: nowrap;
}

.consulting-summary-section .summary-title {
  font-family: "Pretendard", sans-serif;
  font-size: 40px;
  font-weight: 800;
}

.consulting-summary-section .summary-title-blue {
  color: #0073e6;
}

.consulting-summary-section .summary-title-gradient {
  background: linear-gradient(to right, #0073e6, #ccf54b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.consulting-summary-section .consulting-description {
  display: flex;
  flex-direction: column;
  gap: 12px !important;
}

.consulting-summary-section .product-description {
  width: 100%;
  margin: 0;
  font-family: "Pretendard", sans-serif;
  line-height: 140%;
}

.consulting-summary-section .product-description-lead {
  font-size: 32px;
  font-weight: 700;
  color: #e5e5e5;
}

.consulting-summary-section .product-description-light {
  font-weight: 400;
}

.consulting-summary-section .product-description-body {
  font-size: 18px;
  font-weight: 400;
  color: #b0b0b0;
}

.consulting-summary-section .desc-nowrap {
  white-space: nowrap;
}

.consulting-summary-section .cta-buttons {
  margin-top: 4px;
}

.consulting-summary-section .header-product {
  width: 35% !important;
  max-height: 420px !important;
  object-fit: cover;
  border-radius: 16px;
}

.header-bg-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  overflow: hidden;
}

.header-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.solution-header {
  position: relative;
  width: 100%;
  height: 100%;
  margin: 160px auto;
  display: flex;
  align-items: center;
  z-index: 2;
}

.solution-header-inner {
  position: relative;
  max-width: 1280px;
  height: 100%;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
}

.solution-info {
  position: relative;
  width: 50%;
  height: 100%;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 40px;
  color: #fff;
}

.header-product {
  position: absolute;
  width: 45%;
  height: auto;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  /* object-fit: contain; */
  z-index: 2;
}

.header-product-logo {
  position: relative;
  width: 64px;
  height: auto;
  z-index: 1;
}

.header-icons {
  position: absolute;
  display: flex;
  flex-direction: column;
  width: 96px;
  gap: 8px;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  z-index: 4;
  height: 420px;
}

.header-title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  width: 100%;
}

.summary-title {
  font-family: "Pretendard";
  font-size: 1.5rem;
  font-weight: 600;
  line-height: normal;
  letter-spacing: -0.01em;
}

.summary-title-wrapper {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 16px;
}

.summary-subtitle {
  font-family: "Pretendard";
  font-size: 3.111rem;
  font-weight: 800;
  line-height: 100%;
  letter-spacing: -0.01em;
}

.header-gradient-text {
  font-family: "Pretendard";
  font-size: 3.111rem;
  font-weight: 800;
  background: linear-gradient(to right, #0073e6, #ccf54b);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline;
}

.product-description {
  font-family: "Pretendard";
  font-weight: 400;
  color: #b0b0b0;
  font-size: 1.111rem;
  line-height: 130%;
  width: 48%;
}

.inquiry-buttons {
  display: inline-flex;
  align-items: flex-start;
  gap: 16px;
}

.general-inquiry-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 40px;
  position: relative;
  border-radius: 40px;
  border: 2px solid;
  border-color: #ffffff;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  overflow: hidden;
}

.quote-inquiry-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 10px 40px;
  position: relative;
  background-color: #111111;
  border-radius: 40px;
  border: 2px solid;
  border-color: #111111;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  overflow: hidden;
}

.general-inquiry-wrapper:hover,
.quote-inquiry-wrapper:hover {
  transform: translateY(-3px);
  box-shadow: 0 5px 15px rgba(0, 0, 0, 0.2);
}

.general-inquiry-wrapper::before,
.quote-inquiry-wrapper::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(
    120deg,
    transparent,
    rgba(255, 255, 255, 0.2),
    transparent
  );
  transition: 0.5s;
}

.general-inquiry-wrapper:hover::before,
.quote-inquiry-wrapper:hover::before {
  left: 100%;
}

/* CTA 섹션 버튼 스타일 오버라이드 */
.cta-section .general-inquiry-wrapper {
  border-color: #ffffff;
  background-color: transparent;
}

.cta-section .quote-inquiry-wrapper {
  background-color: #111111;
  border-color: #111111;
}

.quote-inquiry-wrapper.quote-outline-blue {
  background-color: #0073e6;
  border-color: #0073e6;
}

.inquiry-text {
  font-family: "Pretendard";
  font-weight: 600;
  color: #ffffff;
  font-size: 1rem;
  letter-spacing: 0;
  line-height: 24px;
  white-space: nowrap;
  text-align: center;
}

/* 스탯 섹션 */
.stats-section {
  background-color: #f0f6fb;
  padding: 60px 0;
}

.solution-stats {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0px 200px;
  position: relative;
  align-self: stretch;
  width: 100%;
}

.stat-item {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  position: relative;
}

.stat-label {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "Pretendard";
  font-weight: 600;
  color: #0073e6;
  font-size: 20px;
  letter-spacing: 0;
  line-height: 30px;
  white-space: nowrap;
}

.stat-value {
  position: relative;
  width: fit-content;
  font-family: "Pretendard";
  font-weight: 700;
  color: #111111;
  font-size: 48px;
  letter-spacing: 0;
  line-height: 48px;
  white-space: nowrap;
}

.stat-divider {
  position: relative;
  align-self: stretch;
  width: 1px;
}

/* GS 사전 컨설팅이란? 영역 */
.features-section.definition-section {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 160px 0;
}

.features-section.definition-section .section-container {
  position: relative;
  z-index: 1;
}

.definition-title-wrapper {
  text-align: center;
  margin-bottom: 80px;
  position: relative;
}

.definition-title-wrapper::before {
  content: "";
  position: absolute;
  width: 243px;
  height: 243px;
  left: 30%;
  top: 20%;
  transform: translate(-50%, -50%);
  background: linear-gradient(112.06deg, #0073e6 40.9%, #ccf54b 64.42%);
  opacity: 0.3;
  filter: blur(100px);
  pointer-events: none;
  z-index: 0;
}

.definition-label {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 600;
  font-size: 1.25rem;
  line-height: 30px;
  /* 내부 오토레이아웃 */
  flex: none;
  order: 0;
  flex-grow: 0;
  color: #0073e6;
  margin-bottom: 16px;
  display: inline-block;
}

.definition-title {
  font-family: "Pretendard";
  font-size: 2rem;
  font-weight: 700;
  margin-bottom: 32px;
  letter-spacing: -0.04em;
  color: #111111;
  position: relative;
  z-index: 1;
}

.definition-description {
  font-family: "Pretendard";
  font-size: 1.125rem;
  font-weight: 400;
  line-height: 1.4;
  color: #4d4d4d;
  width: 100%;
  max-width: 1280px;
  text-align: center;
  margin: 0 auto;
}

.definition-description p {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
  color: inherit;
  margin: 0 0 24px 0;
  word-break: keep-all;
}

@media screen and (max-width: 767px) {
  .definition-description {
    font-size: 1rem;
    padding: 0 16px;
  }
}

.definition-description p:last-child {
  margin-bottom: 0;
}

.features-section.definition-section.definition-anim-ready
  .definition-description
  p {
  opacity: 0;
  transform: translateY(72px);
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.features-section.definition-section.definition-step-text
  .definition-description
  p {
  opacity: 1;
  transform: translateY(0);
}

.features-section.definition-section.definition-anim-ready
  .definition-card
  .card-icon-wrapper,
.features-section.definition-section.definition-anim-ready
  .definition-card
  .card-title,
.features-section.definition-section.definition-anim-ready
  .definition-card
  .card-description {
  opacity: 0;
  transform: translateY(56px);
  transition:
    transform 0.5s cubic-bezier(0.16, 1, 0.3, 1),
    opacity 0.5s cubic-bezier(0.16, 1, 0.3, 1);
}

.features-section.definition-section.definition-step-card-content
  .definition-card
  .card-icon-wrapper,
.features-section.definition-section.definition-step-card-content
  .definition-card
  .card-title,
.features-section.definition-section.definition-step-card-content
  .definition-card
  .card-description {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .features-section.definition-section.definition-anim-ready
    .definition-description
    p,
  .features-section.definition-section.definition-anim-ready
    .definition-card
    .card-icon-wrapper,
  .features-section.definition-section.definition-anim-ready
    .definition-card
    .card-title,
  .features-section.definition-section.definition-anim-ready
    .definition-card
    .card-description {
    transition: none;
    opacity: 1;
    transform: none;
  }
}

.effects-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  width: 100%;
  margin-top: 60px;
  justify-items: center;
}

.definition-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 40px;
  width: 100%;
  margin-top: 80px;
}

.cloud-definition-grid {
  display: flex !important;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px;
}

.cloud-definition-grid .definition-card {
  width: calc(33.333% - 27px); /* gap(40px) 고려하여 3개씩 배치 */
  flex: 0 0 auto;
}

@media screen and (max-width: 767px) {
  .definition-grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 40px;
  }
  .cloud-definition-grid {
    flex-direction: column;
    gap: 20px;
  }
  .cloud-definition-grid .definition-card {
    width: 100%;
  }
}

.definition-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding: 24px;
  background-color: #ffffff;
  border-radius: 12px;
  box-shadow: 0px 0px 3px rgba(0, 0, 0, 0.2);
  gap: 16px;
}

.card-icon-wrapper {
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.card-icon {
  width: 100%;
  height: 100%;
}

.card-title {
  font-family: "Pretendard";
  font-size: 1.375rem; /* 22px */
  font-weight: 600;
  color: #111111;
  line-height: 1.4;
}

.card-description {
  font-family: "Pretendard";
  font-size: 1rem; /* 16px */
  font-weight: 400;
  line-height: 1.4;
  color: #4d4d4d;
}

@media screen and (max-width: 767px) {
  .card-title {
    font-size: 1.25rem; /* 20px */
  }
  .card-description {
    font-size: 0.9375rem; /* 15px */
  }
  .definition-card {
    padding: 20px;
    gap: 12px;
  }
  .card-icon-wrapper {
    width: 60px;
    height: 60px;
  }
}

/* 기존 features 관련 CSS (다른 페이지에서 사용) */
.features-section {
  width: 100%;
  position: relative;
  overflow: hidden;
  padding: 160px 0;
}

.features-list {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.feature-item-left {
  display: flex;
  align-items: center;
  align-self: stretch;
  width: 100%;
  height: 360px;
  padding: 32px 40px;
  background-color: #ffffff;
  border-radius: 24px;
  box-shadow:
    0px 0px 35.9px rgba(32, 34, 41, 0.1),
    0px 0px 4px rgba(32, 34, 41, 0.04);
}

.feature-content-left {
  display: flex;
  flex-direction: column;
  gap: 24px;
  width: 100%;
  padding-right: 48px;
}

.feature-title {
  font-family: "Pretendard";
  font-size: 1.111rem;
  font-weight: 500;
  color: #b0b0b0;
  margin-bottom: 8px;
}

.feature-subtitle {
  font-family: "Pretendard";
  font-size: 2rem;
  font-weight: 700;
  color: #111111;
  margin-bottom: 24px;
}

.feature-description {
  font-family: "Pretendard";
  font-size: 1.111rem;
  font-weight: 400;
  line-height: 140%;
  color: #4d4d4d;
}

.feature-image {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  /* border : 1px solid rgb(255, 255, 255); */
  /* box-shadow: inset 0 0 0 2px #fff;  */
  outline: 2px solid rgb(255, 255, 255);
  outline-offset: -2px;
}

.feature-item-right {
  display: flex;
  align-items: center;
  align-self: stretch;
  width: 100%;
  height: 360px;
  padding: 32px 40px;
  background-color: #ffffff;
  border-radius: 24px;
  box-shadow:
    0px 0px 35.9px rgba(32, 34, 41, 0.1),
    0px 0px 4px rgba(32, 34, 41, 0.04);
  overflow: hidden;
}

/* ensure stacking so image is above text (text won't cover image) */
.feature-item-left,
.feature-item-right {
  position: relative;
}

.feature-content-left,
.feature-content-right {
  z-index: 1;
  position: relative;
}

.feature-image {
  z-index: 3;
  position: relative;
}

.feature-content-left::before,
.feature-content-right::before,
.feature-image::before {
  content: "";
  position: absolute;
  inset: 0;
  background: #ffffff;
  transform: translateX(0);
  transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1);
  pointer-events: none;
  will-change: transform;
}

/* lower z-index for content mask so it doesn't overlap image area */
.feature-content-left::before,
.feature-content-right::before {
  z-index: 2;
}

/* image mask sits above image so reveal covers image correctly */
.feature-image::before {
  z-index: 4;
}

/* image mask delayed */
.feature-item-left.is-revealed .feature-image::before,
.feature-item-right.is-revealed .feature-image::before {
  transform: translateX(100%);
  transition-delay: 0.3s;
}

/* 이미지 자체도 텍스트 뒤에 이어서 페이드+슬라이드로 등장 */
.feature-item-left.is-revealed .feature-image,
.feature-item-right.is-revealed .feature-image {
  opacity: 1;
  transform: translateY(0) scale(1);
  transition-delay: 0.3s;
}

/* text mask: reveal immediately when class applied */
.feature-item-left.is-revealed .feature-content-left::before,
.feature-item-right.is-revealed .feature-content-right::before {
  transform: translateX(100%);
}

/* Directional slide-in: 초기 상태와 방향별 노출 동작 지정 */
.feature-item-left,
.feature-item-right {
  opacity: 1;
  transform: none;
  transition: none;
  will-change: auto;
}

/* Text content: initial offset */
.feature-item-left.from-left .feature-content-left,
.feature-item-right.from-left .feature-content-right {
  opacity: 0;
  transform: translateX(-48px);
  transition:
    opacity 0.45s ease,
    transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

.feature-item-left.from-right .feature-content-left,
.feature-item-right.from-right .feature-content-right {
  opacity: 0;
  transform: translateX(48px);
  transition:
    opacity 0.45s ease,
    transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

/* Reveal text content */
.feature-item-left.is-revealed .feature-content-left,
.feature-item-right.is-revealed .feature-content-right {
  opacity: 1;
  transform: translateX(0);
}

/* Image: initial offset */
.feature-item-left.from-left .feature-image,
.feature-item-right.from-left .feature-image {
  opacity: 0;
  transform: translateX(-24px) translateY(12px) scale(0.99);
  transition:
    opacity 0.45s ease,
    transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.feature-item-left.from-right .feature-image,
.feature-item-right.from-right .feature-image {
  opacity: 0;
  transform: translateX(24px) translateY(12px) scale(0.99);
  transition:
    opacity 0.9s ease,
    transform 1s cubic-bezier(0.16, 1, 0.3, 1);
}

/* Reveal image */
.feature-item-left.is-revealed .feature-image,
.feature-item-right.is-revealed .feature-image {
  opacity: 1;
  transform: translateX(0) translateY(0) scale(1);
  transition-delay: 0.15s;
}

/* from-right 인 경우 마스크가 왼쪽으로 빠져나가도록 반대 방향으로 처리 */
.feature-item-left.from-right.is-revealed .feature-content-left::before,
.feature-item-right.from-right.is-revealed .feature-content-right::before,
.feature-item-left.from-right.is-revealed .feature-image::before,
.feature-item-right.from-right.is-revealed .feature-image::before {
  transform: translateX(-100%);
}

/* Fast animation override */
.fast-animation .feature-content-left::before,
.fast-animation .feature-content-right::before,
.fast-animation .feature-image::before {
  transition-duration: 0.6s !important;
}

.fast-animation.from-left .feature-content-left,
.fast-animation.from-left .feature-content-right,
.fast-animation.from-right .feature-content-left,
.fast-animation.from-right .feature-content-right {
  transition-duration: 0.4s !important;
}

.fast-animation .feature-image {
  transition-duration: 0.6s !important;
}

.fast-animation.is-revealed .feature-image {
  transition-delay: 0.1s !important;
}

.fast-animation.is-revealed .feature-image::before {
  transition-delay: 0.15s !important;
}

.feature-content-right {
  display: flex;
  align-items: flex-end;
  flex-direction: column;
  gap: 24px;
  padding-left: 48px;
  width: 100%;
}

.feature-content-right .feature-description {
  text-align: right;
}

.feature-content-right .feature-header {
  align-items: flex-end;
}

.feature-content-right .feature-title,
.feature-content-right .feature-subtitle {
  text-align: right;
}

.feature-header {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.feature-content-left .feature-header {
  align-items: flex-start;
}

.feature-content-left .feature-title,
.feature-content-left .feature-subtitle {
  text-align: left;
}

/* 특장점 섹션 */
.advantages-section .section-title {
  color: #63b1ff;
}

.advantages-section .section-subtitle {
  color: #ffffff;
}

.advantages-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px;
  margin-top: 60px;
  width: 100%;
}

.advantages-grid.cloud-advantages-grid {
  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  gap: 16px !important;
  width: 100%;
  max-width: 1280px;
  margin: 60px auto 0;
}

@media screen and (max-width: 767px) {
  .advantages-grid.cloud-advantages-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    margin: 40px auto 0;
  }
}

.cloud-advantages-grid .advantage-item {
  min-width: 0;
  width: 100%;
  margin: 0;
  gap: 6px;
}

@media screen and (max-width: 767px) {
  .cloud-advantages-grid .advantage-item {
    min-width: 100%;
  }
}

.cloud-advantages-grid .advantage-header {
  height: 44px;
  background: linear-gradient(292.91deg, #ccf54b -15.27%, #0073e6 61.78%);
  border-radius: 40px;
  padding: 10px 8px;
}

.cloud-advantages-grid .advantage-title {
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
}

.cloud-advantages-grid .advantage-content {
  min-height: 170px;
  padding: 18px 10px;
  background: transparent;
  border: 1px solid #777777;
  box-shadow:
    inset 0px -0.2px 8.4px rgba(139, 199, 243, 0.1),
    inset 0px 0.5px 4.3px rgba(255, 255, 255, 0.15);
  filter: drop-shadow(0px 0px 3px rgba(17, 17, 20, 0.4));
  border-radius: 16px;
  justify-content: center;
}

.cloud-advantages-grid .advantage-description {
  font-size: 1rem;
  line-height: 1.28;
  letter-spacing: 0;
}

.advantage-item {
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
}

.advantage-header {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  padding: 12px 12px;
  background: linear-gradient(140deg, #0073e6 25%, #ccf54b 110%);
  border-radius: 9999px;
}

.advantage-title {
  font-family: "Pretendard";
  font-size: 1.111rem;
  font-weight: 700;
  line-height: 1.333rem;
  letter-spacing: 0;
  color: #ffffff;
  word-break: keep-all;
  text-align: center;
  opacity: 0;
  transform: translate3d(0, 28px, 0);
  transition:
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.advantage-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 40px 24px;
  gap: 8px;
  position: relative;
  width: 100%;
  background: rgba(107, 107, 108, 0.1);
  border-radius: 16px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  backdrop-filter: blur(13.25px);
  -webkit-backdrop-filter: blur(13.25px);
  height: 100%;
}

.advantage-description {
  font-family: "Pretendard";
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.444rem;
  letter-spacing: 0;
  color: #ffffff;
  word-break: keep-all;
  text-align: center;
  opacity: 0;
  transform: translate3d(0, 28px, 0);
  transition:
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.advantages-section.advantages-step-title .advantage-title {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

.advantages-section.advantages-step-description .advantage-description {
  opacity: 1;
  transform: translate3d(0, 0, 0);
}

/* 도입효과 섹션 */
.effects-section {
  padding: 160px 0;
}

.effects-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 40px;
  margin-top: 60px;
  width: 100%;
  justify-content: center;
  justify-items: center;
}

.cloud-effects-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 40px 140px;
  max-width: 1180px;
  margin: 60px auto 0;
}

@media screen and (max-width: 767px) {
  .cloud-effects-grid {
    gap: 40px;
    margin: 40px auto 0;
    flex-direction: column;
    align-items: center;
  }
}

.cloud-effects-grid .effect-item {
  flex: 0 0 300px;
  width: 300px;
  height: 300px;
  margin: 0;
  padding: 0;
  gap: 17px;
}

@media screen and (max-width: 767px) {
  .cloud-effects-grid .effect-item {
    width: 250px;
    height: 250px;
    flex: 0 0 250px;
    padding: 20px;
  }
}

.cloud-effects-grid .effect-description {
  font-size: 1.25rem; /* 20px */
  font-weight: 400;
  line-height: 1.2;
}

@media screen and (max-width: 767px) {
  .cloud-effects-grid .effect-description {
    font-size: 1rem;
  }
}

.effect-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 300px;
  height: 300px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.1);
  backdrop-filter: blur(13.25px);
  -webkit-backdrop-filter: blur(13.25px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  padding: 40px 20px;
  gap: 26px;
}

.effect-description {
  color: rgba(255, 255, 255);
  font-family: "Pretendard";
  font-size: 1.111rem;
  font-weight: 400;
  line-height: 1.333rem;
  word-break: keep-all;
}

.effects-section .effect-item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 40px;
  background: rgba(255, 255, 255, 0.1);
  border-radius: 50%;
}

.effect-icon {
  width: 100px;
  height: 100px;
  object-fit: contain;
}

.effects-grid .effect-icon,
.effects-grid .effect-description {
  transition:
    transform 0.8s cubic-bezier(0.16, 1, 0.3, 1),
    opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: transform, opacity;
  opacity: 0;
  transform: translateY(30px);
}

/* 개별 아이템 단위로 표시 제어 */
.effects-grid .effect-item.is-visible .effect-icon,
.effects-grid .effect-item.is-visible .effect-description {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .effects-grid .effect-icon,
  .effects-grid .effect-description {
    transition: none;
    opacity: 1;
    transform: none;
  }
}

/* CTA 섹션 */

.cta-wrapper {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 40px;
  height: 100%;
}

.cta-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  position: relative;
  opacity: 0;
  transform: translateY(30px);
  filter: blur(5px);
  transition: all 1s cubic-bezier(0.16, 1, 0.3, 1);
}

.cta-section.is-revealed .cta-content {
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}

.cta-section .cta-buttons {
  opacity: 0;
  transform: translateY(30px);
  transition: all 0.8s cubic-bezier(0.34, 1.56, 0.64, 1);
}

.cta-section.is-revealed .cta-buttons {
  opacity: 1;
  transform: translateY(0);
}

.cta-section.is-revealed .cta-buttons .general-inquiry-wrapper,
.cta-section.is-revealed .cta-buttons .quote-inquiry-wrapper {
  opacity: 1 !important;
  transform: scale(1) translateY(0) !important;
}

.cta-section .cta-buttons .general-inquiry-wrapper,
.cta-section .cta-buttons .quote-inquiry-wrapper {
  opacity: 0;
  transform: scale(0.9) translateY(20px);
}

.cta-section.is-revealed .cta-buttons .general-inquiry-wrapper {
  transition-delay: 0.4s;
}

.cta-section.is-revealed .cta-buttons .quote-inquiry-wrapper {
  transition-delay: 0.55s;
}

.cta-text {
  position: relative;
  text-shadow: 0px 1px 4px #00000040;
  font-family: "Pretendard";
  font-weight: 700;
  color: #ffffff;
  font-size: 2rem;
  text-align: center;
  letter-spacing: -0.5px;
  line-height: 100%;
}

/* Solutions page styles */

/* Use standardized container */
.solutions-container {
  width: var(--container-width-desktop);
  max-width: 100%;
  margin: 0 auto;
  padding: 0 var(--grid-margin);
}

.solutions-grid {
  display: grid;
  gap: var(--grid-gutter);
  grid-template-columns: repeat(var(--grid-columns), 1fr);
}

/* Convert specific grids to use standard grid system */
.features-grid {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  gap: var(--grid-gutter);
}

.advantages-grid {
  display: grid;
  grid-template-columns: repeat(var(--grid-columns), 1fr);
  gap: var(--grid-gutter);
}

@import url("https://cdnjs.cloudflare.com/ajax/libs/meyer-reset/2.0/reset.min.css");
* {
  -webkit-font-smoothing: antialiased;
  box-sizing: border-box;
}
html,
body {
  margin: 0px;
  height: 100%;
  scroll-behavior: smooth;
}
/* a blue color as a generic focus style */
button:focus-visible {
  outline: 2px solid #4a90e2 !important;
  outline: -webkit-focus-ring-color auto 5px !important;
}
a {
  text-decoration: none;
}

:root {
  --bwfff: rgba(255, 255, 255, 1);
}

/* 문의 팝업 스타일 */
.inquiry-popup {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.7);
  z-index: 1000;
  justify-content: center;
  align-items: center;
}

.inquiry-popup.active {
  display: flex;
}

.popup-content {
  background: #f0f6fb;
  padding: 40px;
  border-radius: 20px;
  width: 90%;
  max-width: 500px;
  position: relative;
  animation: popupFadeIn 0.3s ease-out;
  max-height: 85vh;
  overflow-y: auto;
}

@media (max-width: 767px) {
  .popup-content {
    padding: 24px 20px;
  }
}

.popup-content h2 {
  font-size: 24px;
  font-weight: 700;
  color: #111;
  margin-bottom: 30px;
}

@keyframes popupFadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.close-popup {
  position: absolute;
  top: 20px;
  right: 20px;
  font-size: 24px;
  background: none;
  border: none;
  cursor: pointer;
  color: #666;
}

.inquiry-form {
  margin-top: 20px;
}

.form-group {
  margin-bottom: 15px;
}

.form-group input,
.form-group select,
.form-group textarea {
  width: 100%;
  /* padding: 12px; */
  border: 1px solid #ddd;
  border-radius: 8px;
  font-size: 14px;
  background: #fff;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border: 2px solid #0073e6 !important;
  padding: 9px 19px;
}

.form-group textarea {
  height: 120px;
  resize: vertical;
}

.form-select {
  position: relative;
}

.form-select::after {
  content: "⌵";
  display: block;
  font-size: 20px;
  font-weight: bold;
  position: absolute;
  top: 55%;
  right: 10px;
  width: 20px;
  height: 15px;
  text-align: center;
  color: #666;
}

.form-select select {
  -webkit-appearance: none; /* Safari, Chrome */
  -moz-appearance: none; /* Firefox */
  appearance: none; /* 표준 */
  position: relative;
  padding: 12px 20px;
  font-size: 16px;
  color: #777;
  background: #fff;
}

.submit-btn {
  width: 100%;
  padding: 15px;
  background: #007bff;
  color: white;
  border: none;
  border-radius: 8px;
  font-size: 16px;
  font-weight: bold;
  cursor: pointer;
  transition: background 0.3s;
}

.submit-btn:hover {
  background: #0056b3;
}

@media (max-width: 767px) {
  .section-container,
  .features-section,
  .effects-section,
  .cta-section,
  .definition-title-wrapper {
    margin-bottom: 0 !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    gap: 0 !important;
  }

  .definition-title-wrapper::before {
    display: none !important;
  }
  /* 기존 폰트/스페이싱/레이아웃 스타일은 그대로 유지 */

  .solution-header,
  .effects-grid {
    gap: 0.5rem !important;
    margin: 80px auto !important;
    padding: 0 16px !important;
  }

  .domain-section-container {
    margin-top: 80px !important;
    margin-bottom: 120px !important; /* CTA 섹션과의 간격 확보 */
  }

  .domain-content-wrapper {
    flex-direction: column !important;
    gap: 40px !important;
    align-items: center !important;
    text-align: center !important;
  }

  .domain-text-wrapper {
    align-items: center !important;
    width: 100% !important;
  }

  .domain-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 30px 10px !important;
    width: 100% !important;
    margin-top: 20px !important;
  }

  .domain-item {
    gap: 8px !important;
  }

  .domain-icon {
    width: 48px !important;
    height: 48px !important;
  }

  .domain-label {
    font-size: 0.85rem !important;
  }

  .consulting-summary-section {
    min-height: auto;
  }

  .consulting-summary-section .consulting-header {
    min-height: auto;
    margin: 80px auto !important;
    padding: 0 16px !important;
  }

  .consulting-summary-section .consulting-info {
    width: 100% !important;
    gap: 16px !important;
    padding-right: 0;
  }

  .consulting-summary-section .consulting-description {
    gap: 10px !important;
  }

  .consulting-summary-section .desc-nowrap {
    white-space: normal;
  }
  .section-title {
    font-family: "Pretendard" !important;
    font-size: 0.95rem !important;
    margin-bottom: 8px !important;
  }

  .subtitle {
    font-family: "Pretendard" !important;
    font-size: 0.95rem !important;
    line-height: 1.4 !important;
    margin-bottom: 0.5rem !important;
    width: 100% !important;
    text-align: left !important;
  }

  .section-subtitle,
  .summary-subtitle,
  .business-title,
  .cta-text {
    font-family: "Pretendard" !important;
    font-size: 1.5rem !important;
    line-height: 1.3 !important; /* 조금 더 여유롭게 */
    margin-bottom: 32px !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
  }

  .consulting-summary-section .summary-title {
    font-size: 1.8rem !important; /* 40px -> 1.8rem (약 28px) 로 축소 */
    line-height: 1.3 !important;
    word-break: keep-all !important;
  }

  .product-description,
  .feature-description,
  .advantage-description,
  .effect-description,
  .stat-label {
    font-family: "Pretendard" !important;
    font-size: 0.944rem !important; /* 0.889 -> 0.944 (약 17px) 로 살짝 키움 */
    line-height: 1.5 !important; /* 가독성을 위해 줄간격 확보 */
    width: 100% !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
  }

  .solution-description + .cta-buttons {
    margin-top: 1rem;
  }

  .consulting-tabs {
    height: 48px !important;
    gap: 16px !important;
    margin-bottom: 0 !important;
  }
  .consulting-sub-tabs {
    height: 48px !important;
    gap: 8px !important;
  }
  .sub-tab-item {
    font-size: 13px !important;
    padding: 6px 12px !important;
  }
  .tab-active,
  .tab-item {
    font-family: "Pretendard" !important;
    width: auto !important;
    font-size: 0.95rem !important;
    padding: 0 12px !important;
  }

  .tab-text {
    font-family: "Pretendard" !important;
    font-size: 0.95rem !important;
  }

  .features-section,
  .effects-section {
    padding: 80px 16px !important;
  }

  .definition-title-wrapper {
    margin-bottom: 40px !important;
  }

  .definition-label {
    font-size: 1rem !important;
    margin-bottom: 12px !important;
  }

  .definition-title {
    font-size: 1.5rem !important;
    margin-bottom: 24px !important;
  }

  .definition-description {
    font-size: 0.889rem !important;
    line-height: 1.4 !important;
  }

  .advantages-section {
    padding: 80px 16px 0px 16px !important;
    gap: 0px !important;
  }

  .cta-section {
    margin-bottom: 0 !important;
    padding: 0 16px !important;
  }

  .features-list,
  .definition-grid,
  .advantages-grid,
  .effects-grid {
    margin-top: 40px !important;
    flex-direction: column !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .feature-item-left,
  .feature-item-right,
  .definition-card {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    justify-content: flex-start !important;
    width: 100% !important;
    height: auto !important;
    padding: 24px 16px !important;
    border-radius: 12px !important;
    box-sizing: border-box !important;
    background: #fff !important;
    gap: 12px !important;
    /* box-shadow: 0px 0px 20px rgba(32, 34, 41, 0.07),
      0px 0px 2px rgba(32, 34, 41, 0.03) !important; */
  }
  .feature-content-left,
  .feature-content-right {
    order: 1 !important;
    padding: 0 !important;
    gap: 12px !important;
    width: 100% !important;
    margin-bottom: 0 !important;
    align-items: flex-start !important;
    text-align: left !important;
  }
  .feature-header {
    align-items: flex-start !important;
  }
  .feature-content-left *,
  .feature-content-right * {
    text-align: left !important;
  }
  .feature-image {
    order: 2 !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    margin-bottom: 0 !important;
    margin-top: 12px !important;
    border-radius: 12px !important;
    outline: none !important;
  }

  .header-icons.small {
    position: static !important;
    display: flex !important;
    flex-direction: row !important;
    width: auto !important;
    height: auto !important;
    gap: 6px !important;
    margin-bottom: 16px !important;
    justify-content: flex-start !important;
    align-items: center !important;
    right: auto !important;
    top: auto !important;
    transform: none !important;
    z-index: auto !important;
  }
  .inquiry-text {
    font-size: 0.944rem !important;
  }
  .header-icons.small .certifi-img {
    width: 64px;
    height: 64px;
    max-width: 64px;
    max-height: 64px;
  }
  .header-product {
    display: none !important;
  }
  .solution-info {
    gap: 0px;
  }

  .inquiry-buttons {
    margin-top: 40px;
  }

  .solution-stats {
    padding: 0 0 !important;
    gap: 0 !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
  }
  .stat-item {
    min-width: 0 !important;
    flex: 1 1 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    gap: 2px !important;
  }
  .stat-label {
    font-family: "Pretendard" !important;
    font-size: 0.85rem !important;
    margin: 0 0 2px 0 !important;
    line-height: 1.1 !important;
    text-align: center !important;
  }
  .stat-value {
    font-family: "Pretendard" !important;
    font-size: 1.5rem !important;
    line-height: 1.1 !important;
    margin: 0 !important;
    text-align: center !important;
  }
  .stat-divider {
    height: 32px !important;
    width: 1px !important;
    margin: 0 4px !important;
    display: inline-block !important;
    vertical-align: middle !important;
  }
  .stats-section {
    padding: 24px 0 !important;
    margin: 0 !important;
    background: #f0f6fb !important;
  }
  .summary-section {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    scroll-margin-top: 48px; /* 모바일 1단 */
  }

  .consulting-tabs-container.has-sub-tabs + .consulting-wrap .summary-section {
    scroll-margin-top: 96px; /* 모바일 2단 */
  }
  .feature-title {
    font-family: "Pretendard" !important;
    font-size: 0.95rem !important;
    margin-bottom: 2px !important;
  }
  .feature-subtitle {
    font-family: "Pretendard" !important;
    font-size: 1.25rem !important;
    margin-bottom: 8px !important;
    line-height: 1.3 !important;
    word-break: keep-all !important;
  }
  .feature-description br {
    display: none !important;
  }
  .advantages-grid,
  .effects-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
  }

  .advantages-grid {
    margin-top: 0 !important;
    margin-bottom: 80px !important;
  }

  .effect-item {
    width: 100% !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    border-radius: 12px !important;
    background: rgba(255, 255, 255, 0.1) !important;
    padding: 1rem !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: flex-start !important;
    text-align: center !important;
    box-shadow: 0px 0px 12px rgba(32, 34, 41, 0.06) !important;
  }

  .effect-icon {
    width: 64px !important;
    height: 64px !important;
    max-width: 64px !important;
    max-height: 64px !important;
    margin-bottom: 8px !important;
  }

  @media (max-width: 767px) {
    .effect-description br {
      display: none !important;
    }
  }

  .summary-subtitle,
  .header-gradient-text {
    display: block !important;
    white-space: pre-line !important;
    word-break: keep-all !important;
  }

  .cta-section {
    height: auto !important;
    padding: 80px 0 !important;
  }

  .cta-text {
    display: block !important;
    white-space: pre-line !important;
    word-break: keep-all !important;
    text-align: center !important;
    line-height: 1.4 !important;
  }

  .cta-wrapper {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 32px !important;
    height: 100%;
    position: relative;
    z-index: 1;
  }
}
@media (max-width: 360px) {
  .advantages-grid,
  .effects-grid {
    grid-template-columns: 1fr !important;
  }
}
@media (max-width: 430px) {
  .advantages-grid,
  .effects-grid {
    grid-template-columns: 1fr !important;
  }
  .form-select::after {
    content: "⌵";
    display: block;
    font-size: 15px;
    font-weight: bold;
    position: absolute;
    top: 55%;
    right: 10px;
    width: 15px;
    height: 15px;
  }
}

/* 375px 이하에서만 .mobile-br 줄바꿈 */
@media (max-width: 375px) {
  .mobile-br {
    display: inline;
  }
  .mobile-br br {
    display: block;
  }
}
@media (min-width: 376px) {
  .mobile-br {
    display: none !important;
  }
}
