@charset "UTF-8";

/* 초기화 */
:root,
[data-bs-theme="light"] {
    --bs-primary: #e30413;
    --na-primary-hover: #e30413;
    --bs-link-color: #e30413;
    --bs-link-hover-color: #e30413;
    --consultation-btn-bg: #e30413;
    --consultation-btn-hover: #c00310;
    --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-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-primary: #e30413;
    --na-primary-hover: #e30413;
    --bs-link-color: #e30413;
    --bs-link-hover-color: #e30413;
    --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;
}

/* 모바일 세로 모드에서 가로 스크롤바 숨김 */
@media (max-width: 575.98px) {
    #main-wrap {
        overflow-x: hidden !important;
    }
}

/* 페이지 타이틀 */
.page-title {
    position: relative;
    padding-left: 0;
    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 .125rem .25rem rgba(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;
    font-size: 16px !important;
}

.site-nav>ul>li {
    display: inline-block;
}

/* 메뉴 navbar Height */
.site-navbar .site-icon,
.site-nav>ul>li>a {
    display: inline-block;
    padding: 1.3rem 1rem;
    font-size: 18px;
    text-decoration: none !important;
}

.header-copy,
.site-navbar .site-icon {
    padding: 1.25rem 0;
}

@media (max-width: 575.98px) {

    .header-copy,
    .site-navbar .site-icon {
        padding: 0.75rem 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;
    width: 100%;
    text-align: left;
    padding: 0px 0;
    margin-top: 10px;
    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; */
    text-align: center;
}

.site-nav .has-sub .dropdown>li>a {
    display: inline-block;
    padding: 8px 10px;
    text-align: center;
}

.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(--bs-primary);
	color: #fff; 
	border-radius: 999px; */
}

.site-nav .has-sub .dropdown .active {
    background: var(--na-sub-active-bg) !important;
    color: var(--na-sub-active-color) !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.5rem;
}

.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-check-input {
    --bs-form-check-bg: var(--bs-body-bg);
    flex-shrink: 0;
    width: 1.5em;
    height: 1.5em;
    margin-right: 0.5em;
    vertical-align: middle;
}

.form-check {
    display: flex;
    align-items: center;
}

.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);
}

/* 상담신청 버튼 스타일 */
.btn-consultation {
    background: linear-gradient(135deg, #e30413 0%, #c00310 100%);
    border: none;
    color: white;
    font-weight: 600;
    transition: all 0.3s ease;
    box-shadow: 0 4px 15px rgba(227, 4, 19, 0.3);
}

.btn-consultation:hover {
    background: linear-gradient(135deg, #c00310 0%, #a0020d 100%);
    color: white;
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(227, 4, 19, 0.4);
}

.btn-consultation:active {
    transform: translateY(0);
    box-shadow: 0 2px 10px rgba(227, 4, 19, 0.3);
}

/* 플로팅 버튼 펄스 애니메이션 */
@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(227, 4, 19, 0.7);
    }

    70% {
        box-shadow: 0 0 0 10px rgba(227, 4, 19, 0);
    }

    100% {
        box-shadow: 0 0 0 0 rgba(227, 4, 19, 0);
    }
}

/* 오프캔버스 배경 투명도 조정 */
.offcanvas {
    background-color: rgba(255, 255, 255, 0.85) !important;
    /* 투명도 조정 가능 */
    backdrop-filter: blur(10px);
    /* 블러 효과 추가 */
    --bs-offcanvas-border-color: transparent;
}

/* 다크모드에서의 오프캔버스 배경 */
[data-bs-theme="dark"] .offcanvas {
    background-color: rgba(33, 37, 41, 0.85) !important;
}

/* 오프캔버스 백드롭(뒤 배경) 투명도 */
.offcanvas-backdrop {
    background-color: rgba(0, 0, 0, 0.4) !important;
    /* 백드롭 투명도 조정 */
}

/* 오프캔버스 메뉴 폰트 사이즈 조정 */
.offcanvas .nav-link {
    font-size: 1.3rem !important;
    /* 폰트 사이즈 더 증가 */
    font-weight: 500;
    /* 폰트 굵기 조정 */
    padding: 1rem 1.25rem;
    /* 패딩 더 증가 */
    line-height: 1.4;
    /* 줄 간격 조정 */
}

/* 오프캔버스 메뉴 전체 위치 조정 */
.offcanvas .na-menu {
    padding: 8rem 2rem 8rem;
    /* 현재 적용된 값 */
}

.offcanvas .nav-link-title {
    font-size: 1.3rem !important;
}

.offcanvas .dropdown-header {
    font-size: 1.1rem !important;
    font-weight: 600;
    margin-bottom: 0.75rem;
    padding: 0.5rem 1.25rem;
}

/* 모바일 플로팅 버튼 추가 스타일 */
@media (max-width: 991.98px) {
    .position-fixed .btn-consultation {
        font-size: 0.9rem;
    }

    .position-fixed .btn-consultation:hover {
        transform: scale(1.05);
    }

    .position-fixed .btn-consultation:active {
        transform: scale(0.95);
    }
}

@media (max-width: 767px) {
    .offcanvas.offcanvas-end {
        width: 70%;
    }
}

/* 모바일용 포트폴리오 텍스트 */
.portfolio-mobile-text {
    padding: 1rem 0;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5rem;
}

.apartment-name-mobile {
    font-weight: 600;
    font-size: 1.1rem;
    color: #333;
    display: inline-block;
}

.area-size-mobile {
    font-size: 0.9rem;
    color: #666;
    display: inline-block;
}

/* 모바일에서 한 줄로 표시 */
@media (max-width: 767px) {
    .portfolio-mobile-text {
        flex-direction: row;
        justify-content: center;
        gap: 0rem;
    }
}