@charset "UTF-8";

/* 초기화 */
root,
[data-bs-theme="light"] {
  --bs-body-color: #111;
  --bs-body-font-family: "Pretendard Variable", -apple-system,
    BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI",
    "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", "Apple Color Emoji",
    "Segoe UI Emoji", "Segoe UI Symbol", sans-serif;
  --bs-body-font-size: 0.95rem;
  --bs-link-color: var(--bs-body-color);
  --bs-link-color-rgb: var(--bs-body-color-rgb);
  --na-bar-color: rgba(125, 125, 125, 0.5);
  --na-bar-sm-color: rgba(125, 125, 125, 0.25);
  --na-nav-bg: #fff;
  --na-sub-bg: #fff;
  --na-sub-link-color: #000;
  --na-sub-hover-color: #000;
  --na-sub-hover-bg: #f5f5f5;
  --na-sub-active-color: var(--bs-primary);
  --na-sub-active-bg: #f5f5f5;
  --na-title-color: var(--bs-body-color);
  --na-title-bg: var(--bs-tertiary-bg);
  --na-footer-bg: var(--bs-tertiary-bg);
  --na-menu-border-radius: 0.5rem;
  --na-primary-hover: #0a58ca;
  --na-line-color: var(--bs-dark);
  --na-font-size: var(--bs-body-font-size);
  --na-sm-font-size: 0.875rem;
  --na-lg-font-size: 1.25rem;
}

[data-bs-theme="dark"] {
  --bs-link-color: var(--bs-body-color);
  --bs-link-color-rgb: var(--bs-body-color-rgb);
  --na-bar-color: rgba(125, 125, 125, 0.5);
  --na-bar-sm-color: rgba(125, 125, 125, 0.25);
  --na-nav-bg: #111;
  --na-sub-bg: #333;
  --na-sub-link-color: #fff;
  --na-sub-hover-color: #fff;
  --na-sub-hover-bg: #222;
  --na-sub-active-color: #fff;
  --na-sub-active-bg: #111;
  --na-title-color: var(--bs-body-color);
  --na-title-bg: var(--bs-tertiary-bg);
  --na-footer-bg: var(--bs-tertiary-bg);
  --na-line-color: var(--bs-border-color);
}

/* 박스(box) 스타일 */
body.is-boxed {
  --bs-border-radius: 0;
  --bs-border-radius-sm: 0;
  --bs-border-radius-lg: 0;
  --bs-border-radius-xl: 0;
  --bs-border-radius-xxl: 0;
  --na-menu-border-radius: 0;
}

body.is-boxed .btn {
  --bs-btn-border-radius: 0;
}

body.is-boxed .form-check-input[type="checkbox"],
body.is-boxed div:where(.swal2-container) div:where(.swal2-popup),
body.is-boxed
  div:where(.swal2-container)
  button:where(.swal2-styled).swal2-cancel,
body.is-boxed
  div:where(.swal2-container)
  button:where(.swal2-styled).swal2-confirm {
  border-radius: 0 !important;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm {
  background-color: var(--bs-primary) !important;
}

/* 기본 공통 */
a {
  text-decoration: none !important;
}

a:hover {
  color: var(--bs-primary);
  text-decoration: none !important;
}

[data-bs-theme="dark"] .logo {
  filter: invert(100%) hue-rotate(180deg) brightness(120%) contrast(72.5%);
  -webkit-filter: invert(100%) hue-rotate(180deg) brightness(120%)
    contrast(72.5%);
  -moz-filter: invert(100%) hue-rotate(180deg) brightness(120%) contrast(72.5%);
  transition: 0.2s ease-out;
}

.line-top {
  border-top: calc(var(--bs-border-width) * 2) solid var(--na-line-color) !important;
}

.line-bottom {
  border-bottom: calc(var(--bs-border-width) * 2) solid var(--na-line-color) !important;
}

.bar {
  display: inline;
  position: relative;
  margin: 0 10px;
}

.bar:after {
  content: "";
  display: block;
  width: 1px;
  height: 14px;
  position: absolute;
  right: 1px;
  top: 50%;
  margin-top: -7px;
  background: var(--na-bar-color);
}

.bar-sm {
  display: inline;
  position: relative;
  margin: 0 8px;
}

.bar-sm:after {
  content: "";
  display: block;
  width: 1px;
  height: 12px;
  position: absolute;
  right: 1px;
  top: 50%;
  margin-top: -6px;
  background: var(--na-bar-sm-color);
}

/* 상단 진행바 */
#page-progress {
  position: fixed;
  z-index: 1040;
  top: 0;
  left: 0;
  height: 4px;
  background: var(--bs-primary);
  width: 0%;
}

.site-wrap {
  min-height: 100vh;
  background: var(--na-footer-bg);
}

/* 사이트 최대 너비 */
.container {
  max-width: 1200px !important;
}

#main-wrap .sticky-top {
  z-index: 10 !important;
}

.py-6 {
  padding-top: 4rem !important;
  padding-bottom: 4rem !important;
}

/* 페이지 타이틀 */
.page-title {
  position: relative;
  letter-spacing: -1px;
  color: var(--na-title-color);
  background: var(--na-title-bg);
}

@media (max-width: 575.98px) {
  .page-title {
    margin-top: -1.5rem;
  }
}

.page-title .breadcrumb {
  --bs-breadcrumb-font-size: 0.89rem;
}

/***********************************/
/* PC & Sticky Navbar Style          */
/***********************************/
.site-navbar {
  transition: all 0.3s;
  background: var(--na-nav-bg);
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075) !important;
}

/* 번역기 상태일 때 */
.translated-ltr .site-navbar {
  top: 40px;
}

.translated-ltr .offcanvas-header {
  margin-top: 40px;
}

/* 메뉴 navbar */
.site-nav {
  position: relative;
}

.site-nav .active {
  color: var(--bs-primary);
  display: inline-block;
}

.site-nav .small {
  position: relative;
  top: -2px;
}

.site-nav a {
  text-decoration: none !important;
  display: inline-block;
}

.site-nav > ul > li {
  display: inline-block;
}

/* 메뉴 navbar Height */
.site-navbar .site-icon,
.site-nav > ul > li > a {
  padding: 1.25rem 1rem;
  display: inline-block;
  text-decoration: none !important;
}

.header-copy,
.site-navbar .site-icon {
  padding: 1.25rem 0;
}

.site-nav > ul > li > a:hover {
  color: var(--bs-primary);
}

.site-nav .has-sub {
  position: relative;
}

.site-nav .has-sub > a {
  position: relative;
  padding-right: 20px;
}

.site-nav .has-sub > a:before {
  position: absolute;
  content: "\f107";
  font-size: 14px;
  top: 50%;
  right: 5px;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-family: "FontAwesome";
}

.site-nav .has-sub .dropdown {
  visibility: hidden;
  opacity: 0;
  top: 100%;
  position: absolute;
  text-align: left;
  padding: 0px 0;
  margin-top: 20px;
  margin-left: 0px;
  -webkit-transition: 0.2s 0s;
  -o-transition: 0.2s 0s;
  transition: 0.2s 0s;
}

.site-nav .has-sub .dropdown.arrow-top {
  position: absolute;
}

.site-nav .has-sub .dropdown.arrow-top:before {
  bottom: 100%;
  left: 20%;
  border: solid transparent;
  content: " ";
  height: 0;
  width: 0;
  position: absolute;
  pointer-events: none;
}

.site-nav .has-sub .dropdown.arrow-top:before {
  border-width: 10px;
  margin-left: -10px;
}

.site-nav .has-sub .dropdown a {
  text-transform: none;
  letter-spacing: normal;
  -webkit-transition: 0s all;
  -o-transition: 0s all;
  transition: 0s all;
}

.site-nav .has-sub .dropdown > li {
  list-style: none;
  padding: 0;
  margin: 0;
  min-width: 180px;
}

.site-nav .has-sub .dropdown > li > a {
  padding: 8px 20px;
  display: block;
}

.site-nav .has-sub .dropdown > li.has-sub > a:before {
  content: "\f105";
  right: 20px;
}

.site-nav .has-sub .dropdown > li.has-sub > .dropdown,
.site-nav .has-sub .dropdown > li.has-sub > ul {
  left: 100%;
  top: -2px;
}

.site-nav .has-sub:hover,
.site-nav .has-sub:focus,
.site-nav .has-sub:active {
  cursor: pointer;
}

.site-nav .has-sub:hover > .dropdown,
.site-nav .has-sub:focus > .dropdown,
.site-nav .has-sub:active > .dropdown {
  -webkit-transition-delay: 0s;
  -o-transition-delay: 0s;
  transition-delay: 0s;
  margin-top: 0px;
  visibility: visible;
  opacity: 1;
}

.site-nav .has-sub .dropdown {
  border-top: 2px solid var(--bs-primary);
  -webkit-box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 10px -2px rgba(0, 0, 0, 0.1);
  background: var(--na-sub-bg);
}

.site-nav .has-sub .dropdown.arrow-top:before {
  border-color: rgba(136, 183, 213, 0);
  border-bottom-color: #fff;
}

.site-nav .has-sub .dropdown a {
  color: var(--na-sub-link-color);
}

.site-nav .has-sub .dropdown > li > a:hover {
  background: var(--na-sub-hover-bg);
  color: var(--na-sub-hover-color);
}

.site-nav .has-sub .dropdown .active {
  background: var(--na-sub-active-bg) !important;
  /* color: var(--na-sub-active-color) !important; */
  color: #ff4837 !important;
}

.site-nav .has-sub:hover > a,
.site-nav .has-sub:focus > a,
.site-nav .has-sub:active > a {
  color: var(--bs-primary);
}

/*******************************************************/
/* Menu Offcanvas Style : Mobile & Sidebar Full Menu   */
/*******************************************************/
.na-menu .dropdown-header {
  text-transform: uppercase;
  letter-spacing: 0.03125rem;
  font-size: 0.65625rem;
  font-weight: 600;
  padding: 0.5rem 0.85rem;
}

.na-menu .dropdown-toggle::after {
  display: inline-block;
  width: 1rem;
  background-image: url("data:image/svg+xml,%3csvg width='24' height='24' viewBox='0 0 24 24' fill='%23677788' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.72,15.78a.75.75,0,0,1-.53.22h-.38a.77.77,0,0,1-.53-.22L6.15,10.64a.5.5,0,0,1,0-.71l.71-.71a.49.49,0,0,1,.7,0L12,13.67l4.44-4.45a.5.5,0,0,1,.71,0l.7.71a.5.5,0,0,1,0,.71Z'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right center;
  background-size: 1rem 1rem;
  content: "";
  border-top: 0 solid;
  transition: 0.3s;
}

.na-menu .dropdown-toggle:not(.dropdown-toggle-empty)::after {
  padding-left: 1rem;
  margin-left: auto;
}

.na-menu .nav-item > .nav-link[aria-expanded="true"]::after,
.na-menu .show > .nav-link.dropdown-toggle::after {
  -webkit-transform: rotate(-180deg);
  transform: rotate(-180deg);
}

.na-menu .nav-link .small {
  margin-left: 0.25rem;
}

.na-menu .nav-link-title .small {
  margin-left: 0.1rem;
  position: relative;
  top: -2px;
}

.na-menu .nav-icon {
  opacity: 0.7;
  -ms-flex: 0 0 1.9375rem;
  flex: 0 0 1.9375rem;
}

.na-menu .nav-pills {
  --bs-nav-pills-border-radius: var(--na-menu-border-radius);
  --bs-nav-pills-link-active-color: var(--bs-body-color);
  --bs-nav-pills-link-active-bg: rgba(189, 197, 209, 0.2);
}

.na-menu .nav-pills .nav-link {
  color: var(--bs-body-color);
  background: 0 0;
  border: 0;
  border-radius: var(--bs-nav-pills-border-radius);
}

.na-menu .nav-pills .nav-link:disabled {
  color: var(--bs-nav-link-disabled-color);
  background-color: transparent;
  border-color: transparent;
}

.na-menu .nav-pills .nav-link.active {
  color: var(--bs-nav-pills-link-active-color) !important;
  background-color: var(--bs-nav-pills-link-active-bg) !important;
}

.na-menu .nav-fill .nav-item,
.na-menu .nav-fill > .nav-link {
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  text-align: center;
}

.na-menu .nav-fill .nav-item .nav-link,
.na-menu .nav-vertical.nav-pills {
  width: 100%;
}

.na-menu .nav-vertical {
  -ms-flex-direction: column;
  flex-direction: column;
}

.na-menu .nav-vertical.nav .nav-item:not(:last-child) {
  margin-right: 0;
}

.na-menu .nav-vertical.nav .nav-link {
  display: -ms-flexbox;
  display: flex;
  white-space: nowrap;
}

.na-menu .nav-vertical.nav-pills .nav-item {
  margin: 0;
}

.na-menu .nav-vertical.nav-pills .nav-link {
  padding: 0.25rem 0.875rem !important;
  margin-bottom: 0.25rem;
}

.na-menu .nav-vertical.nav-pills .nav-item .nav-link:hover,
.na-menu .nav-vertical.nav-pills .nav-item .nav-link[aria-expanded]:hover,
.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="false"],
.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="true"],
.na-menu .nav-vertical.nav-pills .nav-item.show .nav-link[aria-expanded]:hover,
.na-menu
  .nav-vertical.nav-pills
  .nav-collapse
  .nav-item.show
  .nav-link[aria-expanded]:hover {
  color: var(--bs-body-color);
}

.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="false"]:hover,
.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="true"]:hover,
.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="false"],
.na-menu .nav-vertical.nav-pills .nav-link.active[aria-expanded="true"],
.na-menu .nav-vertical.nav-pills .nav-link {
  background-color: transparent;
}

.na-menu .nav-vertical.nav-pills .nav-link.active,
.na-menu .nav-vertical.nav-pills .nav-item .nav-collapse.show .nav-link.active,
.na-menu
  .nav-vertical.nav-pills
  .nav-collapse
  .nav-item
  .nav-link[aria-expanded]:hover,
.na-menu .nav-vertical.nav-pills .nav-collapse .nav-link:hover,
.na-menu .nav-pills .nav-link:hover,
.na-menu .nav-pills .nav-link.active:hover {
  color: var(--bs-body-color);
  background-color: rgba(189, 197, 209, 0.2);
}

.na-menu .nav-vertical.nav-pills .nav-collapse {
  position: relative;
  padding-left: 1.9375rem;
}

.na-menu .nav-vertical.nav-pills .nav-collapse::before {
  position: absolute;
  top: 0;
  left: 1.3125rem;
  width: 0.125rem;
  height: calc(100% - 0.25rem);
  content: "";
  background-color: rgba(231, 234, 243, 0.7);
}

.na-menu .nav-vertical.nav-pills .nav-link.dropdown-toggle {
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

.na-menu .nav-pills .nav-item {
  margin: 0.25rem 0.25rem;
}

.na-menu .nav-pills .nav-link {
  padding: 1rem 1rem;
}

.na-menu .nav-pills .nav-link.active:hover,
.na-menu .nav-pills .show > .nav-link:hover {
  border-color: transparent;
}

/* 컬러 적용 */
.btn-primary {
  --bs-btn-bg: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--na-primary-hover);
  --bs-btn-hover-border-color: var(--na-primary-hover);
  --bs-btn-active-bg: var(--na-primary-hover);
  --bs-btn-active-border-color: var(--na-primary-hover);
  --bs-btn-disabled-bg: var(--bs-primary);
  --bs-btn-disabled-border-color: var(--bs-primary);
}

.btn-outline-primary {
  --bs-btn-color: var(--bs-primary);
  --bs-btn-border-color: var(--bs-primary);
  --bs-btn-hover-bg: var(--bs-primary);
  --bs-btn-hover-border-color: var(--bs-primary);
  --bs-btn-active-bg: var(--bs-primary);
  --bs-btn-active-border-color: var(--bs-primary);
  --bs-btn-disabled-color: var(--bs-primary);
  --bs-btn-disabled-border-color: var(--bs-primary);
}

.dropdown-menu,
.dropdown-menu-dark {
  --bs-dropdown-link-active-bg: var(--bs-primary);
}

.progress,
.progress-stacked {
  --bs-progress-bar-bg: var(--bs-primary);
}

.pagination {
  --bs-pagination-active-bg: var(--bs-primary);
  --bs-pagination-active-border-color: var(--bs-primary);
  --bs-pagination-hover-color: var(--bs-primary);
}

.form-check-input:checked,
.form-check-input[type="checkbox"]:indeterminate {
  background-color: var(--bs-primary);
  border-color: var(--bs-primary);
}

.form-range::-webkit-slider-thumb,
.form-range::-moz-range-thumb {
  background-color: var(--bs-primary);
}

.nav-pills {
  --bs-nav-pills-link-active-bg: var(--bs-primary);
}

.list-group {
  --bs-list-group-active-bg: var(--bs-primary);
  --bs-list-group-active-border-color: var(--bs-primary);
}

/* Font Size */
.btn {
  --bs-btn-font-size: var(--na-font-size);
}

.btn-lg,
.btn-group-lg > .btn {
  --bs-btn-font-size: var(--na-lg-font-size);
}

.btn-sm,
.btn-group-sm > .btn {
  --bs-btn-font-size: var(--na-sm-font-size);
}

.dropdown-menu {
  --bs-dropdown-font-size: var(--na-font-size);
}

.pagination {
  --bs-pagination-font-size: var(--na-font-size);
}

.pagination-lg {
  --bs-pagination-font-size: var(--na-lg-font-size);
}

.pagination-sm {
  --bs-pagination-font-size: var(--na-sm-font-size);
}

.form-control,
.form-select,
.input-group-text {
  font-size: var(--na-font-size);
}

.form-control-lg,
.form-select-lg,
.input-group-lg > .form-control,
.input-group-lg > .form-select,
.input-group-lg > .input-group-text,
.input-group-lg > .btn {
  font-size: var(--na-lg-font-size);
}

.form-control-sm,
.form-select-sm,
.input-group-sm > .form-control,
.input-group-sm > .form-select,
.input-group-sm > .input-group-text,
.input-group-sm > .btn {
  font-size: var(--na-sm-font-size);
}

#offcanvas-site-menu .collapse {
  visibility: visible !important;
}

/* ==========================
   공통 레이아웃 및 폰트
   ========================== */
html,
body {
  max-width: 100vw;
  overflow-x: hidden;
  font-family: "Pretendard", "Roboto", "Inter", sans-serif;
}

section {
  /* width: 100vw;
  min-width: 100vw;
  max-width: 100vw; */
}

.container {
  max-width: 1280px;
  padding-left: 80px;
  padding-right: 80px;
}

@media (max-width: 1400px) {
  .container {
    max-width: 100vw;
    padding-left: 40px;
    padding-right: 40px;
  }
}

.display-3,
.display-5,
.fs-1,
.fs-4,
.fs-5 {
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 800;
}

.bg-primary {
  background-color: #ff4837 !important;
}
.text-primary {
  color: #ff4837 !important;
}
.bg-secondary {
  background-color: #2b2b2b !important;
}
.text-secondary {
  color: #4b5563 !important;
}
.bg-light {
  background-color: #f9fafb !important;
}

.rounded-3 {
  border-radius: 16px !important;
}
.rounded-4 {
  border-radius: 24px !important;
}

.shadow-sm {
  box-shadow: 0px 10px 15px -3px rgba(0, 0, 0, 0.1);
}

.object-fit-cover {
  object-fit: cover !important;
}

/* 버튼 스타일 */
.btn-primary {
  background-color: #ff4837;
  border: none;
}
.btn-primary:hover {
  background-color: #e13d2b;
}

/* 기타 커스텀 스타일 */
.z-1 {
  z-index: 1;
}

/* 네비게이션, 푸터 등 추가 스타일 필요시 여기에 작성 */

/* ==========================
   Hero Section (Figma → Bootstrap)
   ========================== */
.hero-bg {
  max-width: 100vw;
  min-width: 100vw;
  max-height: 100vh;
  min-height: 100vh;
  object-fit: cover;
  z-index: 1;
}
.hero-gradient {
  width: 100vw;
  height: 100vh;
  position: absolute;
  left: 0;
  top: 0;
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.2) 0%,
    rgba(0, 0, 0, 0.6) 100%
  );
  z-index: 2;
}
#hero .container {
  max-width: 1280px;
  padding-left: 80px;
  padding-right: 80px;
}
@media (max-width: 1400px) {
  #hero .container {
    max-width: 100vw;
    padding-left: 40px;
    padding-right: 40px;
  }
}
@media (max-width: 991.98px) {
  #hero .container {
    padding-left: 16px;
    padding-right: 16px;
  }
  #hero .d-flex.flex-lg-row {
    flex-direction: column !important;
    gap: 0 !important;
  }
  #hero .d-flex.flex-column.justify-content-center {
    font-size: 36px !important;
    line-height: 40px !important;
  }
}

/* About Section Box Border Custom */
.about-section-box {
  border-width: 1.5px !important;
  border-color: #c5c8ce !important;
}

/* ==========================
   Services Section (Figma → Bootstrap)
   ========================== */
.services-bg {
  max-width: 100vw;
  min-width: 100vw;
  max-height: 100vh;
  min-height: 100vh;
  object-fit: cover;
  z-index: 1;
}
#services .container {
  max-width: 1280px;
  padding-left: 80px;
  padding-right: 80px;
}
.services-title {
  font-size: 2.25rem;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 700;
  line-height: 40px;
}
.services-desc {
  font-size: 1.125rem;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 400;
  line-height: 28px;
}
.services-card-row {
  gap: 32px !important;
}
.services-card {
  background: rgba(255, 255, 255, 0.7) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(2px);
  min-height: 244px;
  min-width: 256px;
  max-width: 256px;
  padding: 32px !important;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  box-shadow: 0px 10px 15px -3px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.services-card:hover {
  box-shadow: 0px 18px 32px -4px rgba(0, 0, 0, 0.22);
  transform: translateY(-12px);
}
.services-icon {
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  font-size: 2.5rem;
  color: #ff4837;
}
.services-card-title {
  font-size: 1.25rem;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 700;
  line-height: 28px;
  margin-bottom: 16px;
  width: 100%;
  text-align: center;
}
.services-card-desc {
  font-size: 1rem;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 400;
  line-height: 24px;
  width: 100%;
  text-align: center;
}

/* 1200px 이상 */
@media (min-width: 1200px) {
  #services .container {
    max-width: 1280px !important;
    padding-left: 80px !important;
    padding-right: 80px !important;
  }
  #services .services-card {
    width: 256px !important;
    min-width: 256px !important;
    max-width: 256px !important;
    padding: 32px !important;
  }
}

/* 991.98px 이하 */
@media (max-width: 991.98px) {
  #services .container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  #services .services-card {
    width: 180px !important;
    min-width: 140px !important;
    max-width: 200px !important;
    padding: 16px !important;
  }
  #services .gap-4 {
    gap: 16px !important;
  }
}

.fp-watermark {
  display: none !important;
}

.main-card-caption {
  height: 100% !important;
  display: flex;
  align-items: flex-end;
  transition: height 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.position-relative.overflow-hidden.rounded-1:hover .main-card-caption {
  height: unset !important;
  min-height: unset;
  max-height: unset;
}
.main-card-caption-text {
  width: 100%;
}

.news-card {
  transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card:hover {
  box-shadow: 0px 18px 32px -4px rgba(0, 0, 0, 0.18);
  transform: translateY(-12px);
}
.news-card img {
  transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
.news-card:hover img {
  transform: scale(1.08);
}

/* 풀페이지 배경 */

#fullpage .section:nth-child(2),
#fullpage .section:nth-child(5) {
  background-color: #f8f9fa;
}

/* 주요업무(채용) 섹션 스타일 */
.main-task-section {
  background: #f9fafb;
  width: 100vw;
  max-width: 100vw;
}
.main-task-title {
  color: #4b5563;
  font-size: 24px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 36px;
  text-align: center;
}
.main-task-card {
  width: 536px;
  height: 632px;
  border-radius: 24px;
  box-shadow: 0px 10px 15px -3px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  background: #fff;
  display: flex;
  flex-direction: column;
}
.main-task-card-img-wrap {
  width: 536px;
  height: 256px;
  position: relative;
  overflow: hidden;
}
.main-task-card-img {
  width: 536px;
  height: 256px;
  object-fit: cover;
  max-width: 536px;
}
.main-task-card-gradient {
  background: linear-gradient(
    0deg,
    rgba(0, 0, 0, 0.6) 0%,
    rgba(0, 0, 0, 0) 100%
  );
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  z-index: 1;
}
.main-task-card-img-title {
  color: #fff;
  font-size: 24px;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 32px;
  z-index: 2;
  width: auto;
  height: 32px;
  display: flex;
  align-items: center;
}
.main-task-card-body {
  width: 536px;
  height: 376px;
  padding: 32px;
  display: flex;
  flex-direction: column;
}
.main-task-desc-box {
  width: 472px;
  height: 88px;
  padding: 16px;
  border-radius: 16px;
  background: #fff;
  gap: 16px;
  display: flex;
  align-items: flex-start;
  margin-bottom: 0.75rem;
}
.main-task-desc-icon {
  width: 48px;
  height: 48px;
  background: rgba(255, 72, 55, 0.1);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.main-task-desc-title {
  color: #111;
  font-size: 16px;
  font-family: "Roboto", sans-serif;
  font-weight: 500;
  line-height: 24px;
  margin-bottom: 8px;
}
.main-task-desc-text {
  color: #4b5563;
  font-size: 16px;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  line-height: 24px;
}

@media (max-width: 1200px) {
  .main-task-inner,
  .main-task-title-box,
  .main-task-card,
  .main-task-card-img-wrap,
  .main-task-card-body {
    width: 100% !important;
    max-width: 100% !important;
  }
  .main-task-desc-box {
    width: 100% !important;
  }
  .performance-inner {
    max-width: 100% !important;
    padding-left: 16px;
    padding-right: 16px;
  }

  #services
    .d-flex.flex-wrap.justify-content-center.align-items-start.gap-4.mx-auto {
    max-width: 960px !important;
    gap: 16px !important;
  }
  #services .services-card {
    width: 220px !important;
    min-width: 160px !important;
    max-width: 240px !important;
    padding: 16px !important;
  }

  .main-card-caption {
    height: unset !important;
    min-height: unset;
    max-height: unset;
  }
}

@media (max-width: 991.98px) {
  #services .w-100 {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
  #services .mx-auto {
    max-width: 100vw !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  #services .services-card {
    width: 180px !important;
    min-width: 140px !important;
    max-width: 200px !important;
    padding: 16px !important;
  }
  #services .gap-4 {
    gap: 16px !important;
  }
}

@media (min-width: 768px) and (max-width: 991.98px) {
  .services-card {
    min-width: 180px !important;
    max-width: 200px !important;
    padding: 16px !important;
  }
}

/* Services Section Figma 스타일 우선 적용 */
#services .w-100 {
  max-width: 100vw;
}
#services .mx-auto {
  max-width: 1280px;
}
#services .services-card {
  width: 256px !important;
  height: 244px !important;
  padding: 32px !important;
  background: rgba(255, 255, 255, 0.7) !important;
  border-radius: 16px !important;
  backdrop-filter: blur(2px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  margin: 0;
  transition: box-shadow 0.3s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
#services .services-card:hover {
  box-shadow: 0px 18px 32px -4px rgba(0, 0, 0, 0.18);
  transform: translateY(-8px);
}
#services .services-icon {
  width: 64px !important;
  height: 64px !important;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  color: #ff4837;
  margin: 0 auto 24px auto !important;
}
#services .services-card-title {
  font-size: 20px !important;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 700;
  line-height: 28px !important;
  margin-bottom: 16px !important;
  width: 192px !important;
  text-align: center;
}
#services .services-card-desc {
  font-size: 16px !important;
  font-family: "Roboto", "Pretendard", sans-serif;
  font-weight: 400;
  line-height: 24px !important;
  width: 192px !important;
  text-align: center;
}
#services .gap-4 {
  gap: 32px !important;
}

@media (max-width: 767.98px) {
  #services .w-100 {
    padding-left: 0px !important;
    padding-right: 0px !important;
  }
  #services .container {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }
  #services .services-card {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 12px !important;
  }
  #services .services-card-title,
  #services .services-card-desc {
    width: auto !important;
    max-width: 100% !important;
  }

  .container {
    padding-left: 24px;
    padding-right: 24px;
  }

  .main-task-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .main-task-card {
    width: 100% !important;
    height: auto !important;
    min-width: 0 !important;
    min-height: 0 !important;
  }
  .main-task-card-img-wrap,
  .main-task-card-img {
    width: 100% !important;
    height: 180px !important;
    max-width: 100% !important;
  }
  .main-task-card-body {
    width: 100% !important;
    height: auto !important;
    padding: 16px !important;
  }
  .main-task-desc-box {
    width: 100% !important;
    height: auto !important;
    padding: 12px !important;
  }

  /* 검색광고 성과(Performance) 섹션 스타일 */
  .performance-section {
    background: #f9fafb;
    width: 100vw;
    max-width: 100vw;
    border-bottom: 1px #f3f4f6 solid;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    overflow: hidden;
  }
  .performance-inner {
    max-width: 1280px;
    width: 100%;
    margin: 0 auto;
  }
  .performance-label {
    color: #ff4837;
    font-size: 16px;
    font-family: "Roboto", sans-serif;
    font-weight: 600;
    line-height: 24px;
    letter-spacing: 0.02em;
  }
  .performance-title {
    color: #111;
    font-size: 36px;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    line-height: 40px;
    margin-bottom: 8px;
  }
  .performance-desc {
    color: #4b5563;
    font-size: 18px;
    font-family: "Roboto", sans-serif;
    font-weight: 400;
    line-height: 28px;
    margin-bottom: 24px;
  }
  .performance-card {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0px 1px 2px rgba(0, 0, 0, 0.05);
    min-height: 212px;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    transition: box-shadow 0.2s;
  }
  .performance-card:hover {
    box-shadow: 0px 8px 24px rgba(0, 0, 0, 0.1);
  }
  .performance-icon {
    width: 64px;
    height: 64px;
    background: rgba(255, 72, 55, 0.1);
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 2rem;
    color: #ff4837;
  }
  .performance-value {
    color: #ff4837;
    font-size: 36px;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    line-height: 40px;
  }
  .performance-card-title {
    color: #111;
    font-size: 20px;
    font-family: "Roboto", sans-serif;
    font-weight: 700;
    line-height: 28px;
  }
  .performance-card-desc {
    color: #4b5563;
    font-size: 16px;
    font-family: "Roboto", sans-serif;
    font-weight: 400;
    line-height: 24px;
  }
  .performance-section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  .performance-title {
    font-size: 28px;
    line-height: 32px;
  }
  .performance-desc {
    font-size: 15px;
    line-height: 22px;
    max-width: 100%;
  }
  .performance-card {
    min-height: 160px;
    padding: 16px !important;
  }
  .performance-icon {
    width: 48px;
    height: 48px;
    font-size: 1.5rem;
  }
  .performance-value {
    font-size: 28px;
    line-height: 32px;
  }
  .performance-card-title {
    font-size: 16px;
    line-height: 22px;
  }
  .performance-card-desc {
    font-size: 14px;
    line-height: 20px;
  }
  .services-bg {
    max-height: inherit;
    min-height: inherit;
  }
  .col-12-width {
    padding: 0 24px;
  }
}

/* 575.98px 이하 */
@media (max-width: 575.98px) {
  .header-copy,
  .site-navbar .site-icon {
    padding: 0.75rem 0;
  }
  #main-wrap {
    overflow-x: hidden !important;
  }
  #services .container {
    padding-left: 0 !important;
    padding-right: 0 !important;
    max-width: 100vw !important;
  }
  #services .services-card {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 8px !important;
  }
  #services .services-card-title,
  #services .services-card-desc {
    width: auto !important;
    max-width: 100% !important;
  }
}

.site-footer-wrap {
  background: #1b1f27 !important;
  color: rgba(255, 255, 255, 0.6) !important;
}

.business-media-section {
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  background: #f9fafb;
  border-bottom: 1px solid #f3f4f6;
  position: relative;
  overflow-x: hidden;
  padding-top: 3rem;
  padding-bottom: 3rem;
}
@media (min-width: 768px) {
  .business-media-section {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
}
@media (min-width: 992px) {
  .business-media-section {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}
.business-media-bg {
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 100%;
  height: 100%;
  z-index: 0;
  background: url("../business/business3.jpg") center center / cover no-repeat;
  opacity: 0.3;
}
