/* Color Variables */
:root {
    --navy-dark: #1d2843;
    --navy-text: #242524;
    --cream-bg: #f3f5f6;
    --cream-light: #f9f4ec;
    --gray-light: #a3a3a3;
    --gray-border: #d7d1c9;
    --gray-dark: #444444;
    --yellow-badge: #f0b429;
    --old-price: #A3A3A3;
    --header-height: 70px;
}

/* Typography */
body {
    font-family: 'SVN Avenir Next', sans-serif;
    color: var(--navy-text);
    line-height: 1.6;
    padding-top: var(--header-height);
}

.toast-wrap-global {
    top: var(--header-height);
}

.line-height-base {
    line-height: 1.6 !important;
}

.pagination-custom .page-link {
    border-top: none;
    border-left: none;
    border-right: none;
    background: transparent;
    color: var(--gray-border);
    font-size: 16px;
    font-weight: 400;
}

.pagination-custom .page-item.active .page-link {
    color: var(--navy-text);
    font-weight: 500;
    border-bottom: 2px solid var(--navy-text);
    border-radius: 0;
}

.pagination-custom .page-arrow {
    color: var(--navy-text);
    border: none;
}

.pagination .page-link:focus,
.pagination .page-link:focus-visible {
    box-shadow: none;
    outline: none;
}

.navy-text {
    color: var(--navy-text) !important;
}

.product-item-filter {
    border-color: var(--gray-border) !important;
}

.top-banner-img {
    object-fit: cover;
}

.top-banner-container {
    height: calc(100vh - var(--header-height));
}

.customer-logo-list {
    overflow-x: scroll;
}

.top-banner-indicators .active {
    width: 115px;
    height: 10px;
    background-color: #ffffff !important;
    border-radius: 15px;
    opacity: 1;
}

.about-us-box-indicators .active {
    width: 60px;
    height: 6px;
    background-color: #000000 !important;
    border-radius: 11px;
    opacity: 1;
}

.about-us-box-indicators button:not(.active) {
    width: 6px;
    height: 6px;
    background-color: var(--gray-border) !important;
    border-radius: 50%;
    opacity: 1;
}

.top-banner-indicators button:not(.active) {
    width: 10px;
    height: 10px;
    background-color: #ffffff !important;
    border-radius: 50%;
    opacity: 1;
}

.heading-xl {
    font-size: 40px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--navy-dark);
    text-transform: uppercase;
}

.heading-lg {
    font-size: 36px;
    font-weight: 700;
    color: var(--navy-dark);
}

.heading-md {
    font-size: 24px;
    font-weight: 600;
    text-transform: uppercase;
    color: var(--navy-dark);
}

.heading-sm {
    font-size: 20px;
    font-weight: 600;
    color: var(--navy-dark);
}

.body-text {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--navy-text);
}

.body-text-sm {
    font-size: 14px;
    font-weight: 400;
    line-height: 1.5;
}

.nav-text {
    font-size: 14px;
    font-weight: 400;
    text-transform: uppercase;
    color: var(--navy-text) !important;
    text-align: center;
    transition: all 0.2s ease;
}

.nav-text:hover,
.nav-text-hover-measure {
    font-weight: 700;
}

.nav-text-bold {
    font-size: 14px;
    font-weight: 700 !important;
    text-transform: uppercase;
    color: var(--navy-text) !important;
    text-align: center;
}

.top-product-price-has-discount {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 2.5em;
}

.product-category-price {
    justify-content: center;
}

.top-product-price-text-wrap {
    min-height: 2.5em;
}

.old-price {
    text-decoration: line-through;
    color: var(--old-price);
    font-size: 16px;
    font-weight: 400;
}

.new-price,
.top-product-price-text,
.discount-name,
.price-text {
    font-weight: 600;
    font-size: 16px;
    color: var(--navy-text);
}

.discount-description {
    font-weight: 400;
    font-size: 14px;
    color: var(--navy-text);
}

.discount-count-down-date-time {
    font-weight: 600;
    font-size: 20px;
    color: var(--navy-text);
}

.discount-count-down-text {
    font-weight: 500;
    font-size: 10px;
    color: var(--navy-text);
}

.discount-count-down-colon {
    font-weight: 600;
    font-size: 14px;
    color: var(--navy-text);
}

.product-detail-product-name {
    font-weight: 600;
    font-size: 24px;
    color: var(--navy-text);
}

.discount-event {
    background-color: #ffedcf !important;
}

.btn-gift {
    background-color: #fdb004;
}

.btn-gift:hover,
.btn-gift:focus {
    background-color: #fdb004;
}

.radio-black .form-check-input[type="radio"] {
    background-color: #fff;
    border-color: var(--navy-text);
}

.radio-black .form-check-input[type="radio"]:checked {
    background-color: #fff;
    border-color: var(--navy-text);
    background-image: radial-gradient(circle, var(--navy-text) 50%, transparent 36%);
}

.radio-black .form-check-input[type="radio"]:focus {
    box-shadow: none;
    border-color: var(--navy-text);
}

.ship-info-note {
    font-weight: 400 !important;
    font-size: 16px !important;
    color: #be2f31 !important;
    font-style: italic;
}

.skin-issue {
    font-size: 20px;
    font-weight: 300;
    color: #000000;
}

.skin-issue:hover {
    font-weight: 600;
}

.fs-40-fw-700 {
    font-size: 40px !important;
    font-weight: 700 !important;
    color: var(--navy-dark);
}

.fs-20-fw-300 {
    font-size: 20px !important;
    font-weight: 300 !important;
}

.fs-20-fw-500 {
    font-size: 20px !important;
    font-weight: 500 !important;
}

.about-us-box-text {
    font-size: 20px !important;
    font-weight: 500 !important;
}

.fs-10-fw-600 {
    font-weight: 600 !important;
    font-size: 10px !important;
    color: var(--navy-text) !important;
}

.fs-24-fw-400 {
    font-size: 24px !important;
    font-weight: 400 !important;
}

.fs-20-fw-600 {
    font-weight: 600 !important;
    font-size: 20px !important;
    color: var(--navy-text) !important;
}

.fs-20-fw-400 {
    font-weight: 400 !important;
    font-size: 20px !important;
    color: var(--navy-text) !important;
}

.fs-24-fw-600 {
    font-weight: 600 !important;
    font-size: 24px !important;
    color: var(--navy-text) !important;
}

.fs-16-fw-400 {
    font-weight: 400 !important;
    font-size: 16px !important;
    color: var(--navy-text) !important;
}

.fs-16-fw-600 {
    font-weight: 600 !important;
    font-size: 16px !important;
    color: var(--navy-text) !important;
}

.fs-16-fw-500 {
    font-weight: 500 !important;
    font-size: 16px !important;
    color: var(--navy-text) !important;
}

.fs-16-fw-300 {
    font-weight: 300 !important;
    font-size: 16px !important;
    color: var(--navy-text) !important;
}

.fs-16 {
    font-size: 16px !important;
}

.fs-24-fw-500 {
    font-weight: 500 !important;
    font-size: 24px !important;
    color: var(--navy-text) !important;
}

.product-detail-preview p,
#product-detail-info p,
.static-page-content p {
    margin-top: unset !important;
    margin-bottom: unset !important;
}

.required-field.has-error,
.ts-wrapper.has-error {
    border-color: #D84315;
}

.accordion-product-filter .disabled,
.btn-save-voucher.disabled {
    pointer-events: none;
}

.product-left-filter {
    font-weight: 400 !important;
    font-size: 16px !important;
    color: var(--navy-text) !important;
}

.product-left-filter .product-filter-item.active {
    font-weight: 600 !important;
}

.fs-14-fw-400 {
    font-weight: 400 !important;
    font-size: 14px !important;
    color: var(--navy-text) !important;
}

.fs-14-fw-600 {
    font-weight: 600 !important;
    font-size: 14px !important;
    color: var(--navy-text) !important;
}

.product-filter-top {
    font-weight: 400 !important;
    font-size: 14px !important;
    color: var(--navy-text) !important;
}

.fs-48-fw-700 {
    font-weight: 700 !important;
    font-size: 48px !important;
    color: var(--navy-dark) !important;
}

.fs-40-fw-600 {
    font-weight: 600 !important;
    font-size: 40px !important;
    color: var(--navy-dark) !important;
}

.fs-32-fw-600 {
    font-weight: 600 !important;
    font-size: 32px !important;
    color: var(--navy-dark) !important;
}

.text-fff {
    color: #ffffff !important;
}

.text-000 {
    color: #000000 !important;
}

.text-666 {
    color: #666666 !important;
}

.popup-campaign-modal.fade .modal-dialog {
    transform: scale(0.8) translateY(-30px);
    opacity: 0;
    transition: all 0.5s ease;
}

.popup-campaign-modal.fade.show .modal-dialog {
    transform: scale(1) translateY(0);
    opacity: 1;
}

.contact-box {
    height: 250px;
}

.toast-custom {
    z-index: 1;
}

#plusToast {
    position: absolute;
    top: 100%;      /* ngay dưới nút + */
    left: 50%;
    transform: translateX(-50%);
    z-index: 1055;
  }

.retinol-question-name {
    font-size: 32px;
    font-weight: 600;
    color: var(--navy-dark);
}

.section-step-input-phone .phone {
    width: 60%;
    margin: 0 auto;
}

.btn-apply-voucher {
    padding: 14px 24px;
}

#product-detail-info .accordion-button::after {
    display: none !important;
}

#product-detail-info .accordion-button:not(.collapsed) {
    font-weight: 600 !important;
}

.btn-product-detail-sku.active,
.btn-product-detail-sku-cart.active {
    background-color: var(--navy-text) !important;
    color: #ffffff !important;
}

.related-products-text {
    font-size: 32px;
    font-weight: 700;
    color: var(--navy-text);
}

.top-product-body-text-wrap,
.blog-title-wrap-top {
    min-height: 1.5em;
}

.blog-title-wrap-list {
    min-height: 3.2em;
}

.blog-description-wrap-top,
.blog-title-wrap {
    min-height: 3em;
}

.blog-description-list {
    font-size: 16px;
    font-weight: 400;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-description-top {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-description-wrap {
    min-height: 4.5em;
}

.blog-description {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-title-list {
    font-size: 24px;
    font-weight: 600;
    margin-bottom: unset !important;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-title-top {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: unset !important;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.blog-title {
    font-size: 24px;
    font-weight: 600;
    margin-bottom: unset !important;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.top-product-body-text {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.product-box-body-text-wrap {
    min-height: 3em;
}

.product-box-body-text {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5;
    color: var(--navy-text);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.top-product-title-wrap,
.product-categy-title-wrap,
.product-box-title-wrap,
.skin-quiz-product-note-wrap {
    min-height: 2.6em; /* nếu line-height 1.3 và 2 dòng */
}

.product-category-title {
    font-size: 16px;
    font-weight: 600;
    color: var(--navy-text);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.top-product-title,
.product-box-title {
    font-size: 20px;
    font-weight: 600;
    color: var(--navy-text);
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.product-box-title {
    height: calc(1.3em * 2);
}

.skin-quiz-product-note {
    line-height: 1.3;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.season-product-title {
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.season-product-body-text {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.season-price {
    min-height: unset !important;
}

.product-box-price-wrap {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    min-height: 3.2em !important;
}

.product-box-title a {
    color: var(--navy-text);
}

.btn-text {
    font-size: 16px;
    font-weight: 500;
}

/* Background Colors */
.bg-cream {
    background-color: var(--cream-bg);
}

.bg-cream-light {
    background-color: var(--cream-light);
}

.bg-cfccc3 {
    background-color: #cfccc3;
}

.bg-f1eee9 {
    background-color: #f1eee9;
}

.bg-f8f4f1 {
    background-color: #f8f4f1;
}

.bg-f4f0ed {
    background-color: #f4f0ed;
}

.bg-f7f2ef {
    background-color: #f7f2ef;
}

.text-navy {
    color: var(--navy-dark);
}

/* Header */
.header-main {
    height: var(--header-height);
    z-index: 1021;
}

.navbar-nav .nav-link {
    padding: 0.5rem 0;
    transition: opacity 0.3s;
}

.navbar-nav .nav-link:hover {
    opacity: 0.7;
}

.dropdown-toggle::after {
    border: none;
    content: '\F282';
    font-family: 'bootstrap-icons';
    font-size: 12px;
    vertical-align: middle;
    margin-left: 4px;
}

/* Product Card */
.top-product-card,
.product-category-card {
    background-color: #ffffff;
    padding: 10px;
    border-radius: 20px;
}

.product-box {
    background-color: #ffffff;
    padding: 20px;
    border-radius: 20px;
}

.product-category-card-mobile {
    outline: 1px solid var(--navy-dark);
    width: 195px;
    min-width: 195px;
    max-width: 195px;
}

.top-product-card:hover,
.product-category-card-desktop:hover,
.product-box:hover {
    outline: 1px solid var(--navy-dark);
}

.top-product-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.top-product-card .img-hover,
.sub-category-banner img,
.product-box .img-hover,
.section-mobile-product .img-hover {
    display: none;
}

.top-product-card:hover .img-hover,
.sub-category-banner:hover img,
.product-box:hover .img-hover,
.section-mobile-product:hover .img-hover {
    display: block;
}

.top-product-card:hover .img-default,
.sub-category-banner:hover .sub-cat-name,
.product-box:hover .img-default,
.section-mobile-product:hover .img-default {
    display: none;
}

.section-mobile-product {
    margin-top: -60px;
}

.top-product-card:hover .btn-add-to-card {
    background-color: var(--gray-border) !important;
    color: var(--navy-text) !important;
    border: none;
}

.top-product-img-wrap {
    width: 100%;
    height: 240px;
    min-height: 240px;
    max-height: 240px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-detail-content img {
    max-width: 100% !important;
    height: auto !important;
}

.blog-detail-img-wrap {
    width: 100%;
    height: 500px;
    min-height: 500px;
    max-height: 500px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-detail-dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background-color: #666666;
}

.blog-detail-wrap {
    margin-top: -50px;
}

.blog-detail-content {
    overflow-x: hidden;
    font-size: 18px !important;
}

.blog-detail-content table {
    border-collapse: separate !important;
    /* display: block;
    max-width: 100%;
    overflow-x: auto;
    white-space: nowrap; */
}

.blog-detail-content table,
.blog-detail-content th,
.blog-detail-content td {
    border-width: 1px;
}

.product-box-img-wrap {
    width: 100%;
    height: 267px;
    min-height: 267px;
    max-height: 267px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.product-category-img-wrap {
    width: 100%;
    height: 174px;
    min-height: 174px;
    max-height: 174px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.normal-blog-item-img-wrap {
    width: 100%;
    height: 250px;
    min-height: 250px;
    max-height: 250px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pin-blog-item-img-wrap {
    width: 100%;
    height: 387px;
    min-height: 387px;
    max-height: 387px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-item-img-wrap-top {
    width: 100%;
    height: 368px;
    min-height: 368px;
    max-height: 368px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.blog-item-img-wrap-top-normal {
    width: 100%;
    height: 308px;
    min-height: 308px;
    max-height: 308px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.season-mobile-image-wrap {
    width: 100%;
    height: 195px;
    min-height: 195px;
    max-height: 195px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.featured-img-wrap {
    width: 100%;
    height: 273px;
    min-height: 273px;
    max-height: 273px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* Carousel Controls */
.carousel-control-prev,
.carousel-control-next {
    width: auto;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    width: 50px;
    height: 50px;
}

/* Tabs */
.nav-tabs .nav-link {
    border: none;
    border-bottom: 2px solid transparent;
    color: var(--navy-text);
    opacity: 0.6;
    padding: 0.5rem 1.5rem;
}

.nav-tabs .nav-link:hover {
    opacity: 1;
    border-color: transparent;
}

.nav-tabs .nav-link.active {
    background: transparent;
    border-bottom: 2px solid var(--navy-dark);
    opacity: 1;
    font-weight: 700;
}

/* Forms */
.form-control,
.form-select {
    border: 1px solid var(--gray-border);
    padding: 14px 24px;
}

.form-control:focus,
.form-select:focus {
    border-color: var(--gray-border);
    box-shadow: none;
}

.form-control::placeholder {
    color: var(--gray-light);
}

/* Buttons */
.btn-dark {
    background-color: var(--navy-text) !important;
    border-color: var(--navy-text) !important;
}

/* .btn-dark:hover {
    background-color: var(--navy-text);
    border-color: var(--navy-text);
    opacity: 0.9;
} */

/* Footer */
footer a:hover {
    opacity: 0.7;
}

/* Utilities */

.shadow-lg {
    box-shadow: 0 0 16px rgba(0, 0, 0, 0.1) !important;
}

.slider-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 20;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: none;
    background: white;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

.slider-btn-prev {
    left: -20px;
}

.slider-btn-next {
    right: -20px;
}

.slider-btn i {
    color: var(--navy-text) !important;
}

.product-detail-price {
    font-size: 20px !important;
}

.product-detail-discount-badge {
    top: 0;
    right: 0;
    transform: translate(100%, -50%);
    white-space: nowrap;
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 10px;
    font-weight: 600;
}

.product-detail-voucher-bg {
    background-image: url(/public/images/voucher_bg_1.png);
    background-repeat: no-repeat;
    background-size: contain;
}

.ticket-voucher {
    background: #A10419;
    clip-path: url(#ticket-scallop);
    border-radius: 12px;
    box-sizing: border-box;
    position: relative;
}

/* .ticket-voucher::after {
    content: "";
    position: absolute;
    top: 20px;
    bottom: 20px;
    left: 50%;
    border-left: 2px dashed rgba(0,0,0,.25);
    transform: translateX(-50%);
} */

.btn-save-voucher {
    font-size: 10px;
    font-weight: 600;
    border-radius: 20px;
    width: 100%;
    background-color: #ffffff;
    border: none;
    padding: 3px;
    color: var(--navy-text) !important;
}

.product-detail-voucher-name {
    font-size: 14px;
    font-weight: 600;
    color: #ffffff;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.product-detail-voucher-desciption {
    font-size: 12px;
    font-weight: 400;
    color: #ffffff;
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.quantity-wrap {
    font-size: 20px;
    font-weight: 400;
}

.bg-gray-border {
    background-color: var(--gray-border) !important;
}

.sign-up-newsletter:hover,
.sign-up-newsletter:focus {
    background-color: var(--gray-border) !important;
}

.featured-banner,
.featured-card {
    height: 525px;
    max-height: 525px;
}

.mb--30 {
    margin-bottom: -30px;
}

.featured-banner img,
.sub-category-banner img,
.collection-box-img-wrap img,
.product-category-card img,
.blog-item-img-wrap-top img,
.blog-item-img-wrap-top-normal img,
.object-fit-cover-position-center {
    object-fit: cover;
    object-position: center;
}

.object-fit-contain-position-center {
    object-fit: contain;
    object-position: center;
}

.product-thumbnail-item {
    height: 83px;
    min-height: 83px;
    max-height: 83px;
    width: 83px;
    min-width: 83px;
}

.product-detail-gallery-img-wrap {
    height: 532px;
    min-height: 532px;
    max-height: 532px;
    width: 100%;
}

.cart-info-img-wrap {
    height: 112px;
    min-height: 112px;
    max-height: 112px;
    width: 100%;
}

.cart-gift-info-img-wrap {
    height: 80px;
    min-height: 80px;
    max-height: 80px;
    width: 100%;
}

.search-result-img-wrap {
    height: 64px;
    min-height: 64px;
    max-height: 64px;
    width: 100%;
}

.sub-category-banner {
    height: 150px;
    min-height: 150px;
    max-height: 150px;
    border-radius: 16px;
    width: 100%;
}

.collection-box-img-wrap {
    height: 307px;
    min-height: 307px;
    max-height: 307px;
}

.heading-md-sub-category-banner {
    font-weight: 500;
}

.heading-md-collection-box {
    font-weight: 400;
}

.col-collection-box:hover .heading-md-collection-box {
    font-weight: 700;
}

.skincare-by-experts-section-determine-skin-type {
    margin-top: 150px;
}

.skincare-by-experts-section-determine-skin-type h2 {
    font-weight: 600 !important;
}

.col-collection-box:hover .skin-issue {
    font-weight: 600;
}

.determine-skin-type-wrap {
    height: 516px;
    position: relative;
    overflow: visible;
}

.determine-skin-type-wrap::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 700px;
    background-image: url(/public/images/determine_skin_type.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 35% auto;
    z-index: 1;
    pointer-events: none;
}

.create-skincare-rotine-section {
    position: relative;
}

.create-skincare-rotine-section::before {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 340px;
    background-image: url(/public/images/create_skincare_rotine_section_1.png);
    background-repeat: no-repeat;
    background-position: bottom left;
    background-size: 15% auto;
    z-index: 1;
    pointer-events: none;
}

.create-skincare-rotine-section::after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 501px;
    background-image: url(/public/images/create_skincare_rotine_section_2.png);
    background-repeat: no-repeat;
    background-position: bottom right;
    background-size: 25% auto;
    z-index: 1;
    pointer-events: none;
}


.determine-skin-type-image {
    position: absolute;
    right: 0;
    top: -102px;
    object-fit: cover;
}

.determine-skin-type-text-normal {
    font-size: 24px;
    font-weight: 400;
}

.determine-skin-type-text-normal span {
    font-style: italic;
    font-weight: 700;
}

.determine-skin-type-filter {
    width: 20%;
    justify-content: center;
}

.determine-skin-type-filter-wrap select {
    font-size: 20px;
    font-weight: 600;
    background-color: var(--cream-bg);
}

.determine-skin-type-filter-wrap select option {
    font-size: 16px !important;
    font-weight: 400 !important;
}

.determine-skin-type-filter-wrap span {
    font-size: 20px;
    font-weight: 400;
    background-color: #ffffff;
}

.nav-tabs-product-category .nav-link {
    border-bottom: unset !important;
    font-size: 20px !important;
    font-weight: 400 !important;
    color: var(--navy-text) !important;
    opacity: unset !important;
}

.nav-tabs-product-category-mobile {
    border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
    margin-left: 10px;
}

.nav-tabs-product-category-mobile .nav-item {
    padding-left: 10px;
}

.nav-tabs-product-category-mobile .nav-link {
    border-bottom: unset !important;
    font-size: 16px !important;
    font-weight: 400 !important;
    color: var(--navy-text) !important;
    opacity: unset !important;
    padding-left: unset !important;
    padding-right: unset !important;
    text-align: left;
}

.nav-tabs-product-category .nav-link.active,
.nav-tabs-product-category-mobile .nav-link.active {
    font-weight: 700 !important;
}

.nav-tabs-product-category-mobile .dot {
    margin-left: -14px;
}

.nav-tabs-product-category .dot span {
    width: 8px;
    height: 8px;
    background: #000;
    border-radius: 50%;
    position: absolute;
}

.nav-tabs-product-category-mobile .dot span {
    width: 8px;
    height: 8px;
    background: #000;
    border-radius: 50%;
}

.nav-tabs-product-category-mobile .dot {
    opacity: 0;
}

.nav-tabs-product-category-mobile .nav-item:has(.nav-link.active) .dot {
    opacity: 1;
}

.nav-tabs-product-category .dot {
    display: none;
}

.nav-tabs-product-category .nav-link.active + .dot {
    display: block;
}

.search-form {
    position: absolute;
    top: 90px;
    visibility: hidden;
    opacity: 0;
    left: 50%;
    transform: translateX(-50%);
    z-index: 9999;
    width: 40%;
}

.search-form.active {
    visibility: visible;
    opacity: 1;
}

.search-box {
    background-color: #ffffff;
    color: var(--navy-text);
}

.search-result-container {
    background-color: #ffffff;
    max-height: 420px;
    overflow-y: scroll;
    overflow-x: hidden;
}

.search-box .search-input {
    font-size: 20px;
    font-weight: 500;
}

.offcanvas-card {
    width: 50% !important;
}

.card-total-info {
    display: none;
    position: fixed;
    right: 0;
    bottom: 0;
    width: 50% !important;
}

.cart-not-empty {
    display: none;
}

.card-container {
    overflow-y: scroll;
}

.accordion-cart,
.accordion-product-filter {
    --bs-accordion-border-width: 0;
}

.bg-f7f7f7 {
    background-color: #f7f7f7 !important;
}

.bg-d7d1c9 {
    background-color: var(--gray-border) !important;
}

.color-d7d1c9 {
    color: var(--gray-border) !important;
}

.category-top-banner,
.skincare-101,
.contact-us-top-banner,
.skincare-by-experts-top-banner,
.contact-us-banner,
.sub-category-top-banner,
.skincare-with-retinol {
    height: 400px;
    background-repeat: no-repeat;
    background-size: cover;
}

.start-retinol-with-image-skincare {
    height: 565px;
    background-repeat: no-repeat;
    background-size: cover;
}

.create-skincare-rotine-last-bg {
    height: 524px;
    background-repeat: no-repeat;
    background-size: cover;
}

.bg-no-repeat-size-cover-position-center {
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.step-line {
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--navy-text);
    transform: translateY(-50%);
    z-index: 1;
}

.step {
    width: 27px;
    height: 27px;
    background: #fff;
    border: 2px solid var(--navy-text);
    border-radius: 50%;
    z-index: 2;
}

.step.active {
    background: var(--navy-text);
}

.skin-quiz-question-answer {
    font-size: 20px;
    font-weight: 400;
    width: 45%;
}

.skin-quiz-question-answer:hover,
.skin-quiz-question-answer.selected {
    font-weight: 600;
    background-color: var(--cream-light) !important;
    outline: 1px solid var(--navy-dark);
}

.section-step {
    min-height: calc(100vh - var(--header-height));
}

.therapy-wrap {
    background-image: url(/public/images/bg_skin_care_skin_peel.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.fw-600 {
    font-weight: 600 !important;
}

.therapy-body,
.blog-description-wrap-list {
    min-height: 4.8em;
}

.about-us-section-1 {
    background-image: url(/public/images/about_us_bg_1_1.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: 25% auto;
}

.about-us-section-2 {
    background-image: url(/public/images/about_us_bg_2.png);
    background-repeat: no-repeat;
    /* background-position: right bottom; */
    background-size: cover;
}

.section-order-success {
    min-height: calc(100vh - var(--header-height));
    background-image: url(/public/images/order_success_bg.png);
    background-repeat: no-repeat;
    background-size: cover;
}

.section-step-4 {
    background-image: url(/public/images/retinol_step_1.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: 30% auto;
}

.section-step-input-phone {
    background-image: url(/public/images/skin_quiz_final_bg.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

.section-step-1 {
    background-image: url(/public/images/skin_quiz_step_1.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
}

/* .section-step-2 {
    background-image: url(/public/images/retinol_step_2.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 25% auto;
} */

.section-step-5 {
    background-image: url(/public/images/retinol_step_3.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: 40% auto;
}

/* .section-step-4 {
    background-image: url(/public/images/retinol_step_4.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 30% auto;
} */

/* .section-step-5 {
    background-image: url(/public/images/retinol_step_5.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: 30% auto;
} */

.section-step-6 {
    background-image: url(/public/images/retinol_step_6.png);
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 30% auto;
}

.skincare-with-retinol-bg-bottom {
    background-image: url("/public/images/skin_care_with_retinol_2.png"), url("/public/images/skin_care_with_retinol_3.png");
    background-repeat: no-repeat, no-repeat;
    background-position: left bottom, right bottom;
    background-size: 20% auto, 20% auto;
}

.what-is-retinol {
    margin-top: 100px;
}

.skin-care-with-retinol-bg {
    height: 110px;
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center
}

.base-routine-rotinol-wrap {
    width: 80%;
    margin: 0 auto;
}

.base-routine-rotinol-text {
    font-size: 24px;
    font-weight: 400;
}

/* background-image: url("/public/images/retinol_step_7_1.png"), url("/public/images/retinol_step_7_2.png");
    background-repeat: no-repeat, no-repeat;
    background-position: left bottom, right bottom;
    background-size: 20% auto, 20% auto; */
.section-step-2 {
    background-image: url("/public/images/skin_quiz_step_2_bg.png");
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: cover;
}

.section-step-3 {
    background-image: url("/public/images/skin_quiz_step_3_bg.png");
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: cover;
}

.section-step-8 {
    background-image: url(/public/images/retinol_step_8.png);
    background-repeat: no-repeat;
    background-position: right bottom;
    background-size: 12% auto;
}

.section-step {
    display: none;
}

.section-step.active {
    display: block;
}

.line-height-1-5 {
    line-height: 1.5 !important;
}

.section-season-mobile {
    height: 493px;
    min-height: 493px;
    max-height: 493px;
    background-repeat: no-repeat;
    background-size: cover;
}

.fs-14 {
    font-size: 14px !important;
}

.sticky-top-custom {
    top: calc(var(--header-height) + 10px);
}

/* html, body {
    max-width: 100%;
    overflow-x: hidden;
}

/* Responsive */
@media (max-width: 767.98px) {
    .heading-xl {
        font-size: 28px;
    }
    
    .heading-lg {
        font-size: 24px;
    }
    
    .heading-md {
        font-size: 20px;
    }
    
    /* .container-fluid {
        padding-left: 20px !important;
        padding-right: 20px !important;
    } */

    .top-banner-container{
        height: auto;
    }

    .slider-btn-prev {
        left: -15px;
    }

    .slider-btn-next {
        right: -15px;
    }

    .featured-card {
        height: 428px;
        max-height: 428px;
    }

    .featured-banner {
        height: 716px;
        max-height: 716px;
    }

    .featured-img-wrap {
        height: 174px;
        min-height: 174px;
        max-height: 174px;
    }

    .product-overlay {
        position: absolute;
        bottom: 20px;
        left: 10%;
        transform: translateX(-10%);
        width: 70%;
        z-index: 10;
    }

    .heading-md-sub-category-banner {
        font-size: 20px;
    }

    .heading-md-sub-category-banner:hover {
        font-weight: 700;
    }

    .collection-box-img-wrap {
        height: 242px;
        min-height: 242px;
        max-height: 242px;
    }

    .heading-md-collection-box {
        font-size: 16px;
    }

    .determine-skin-type-text-normal {
        font-size: 14px;
    }

    .determine-skin-type-wrap {
        height: 460px;
    }

    .determine-skin-type-wrap::after {
        background-size: 50% auto;
    }

    .determine-skin-type-image {
        max-width: 50%;
        top: 55%;
    }

    .heading-blog-top {
        font-size: 24px;
    }

    .blog-title {
        font-size: 20px;
    }

    .blog-title-top {
        font-size: 20px !important;
    }

    .pin-blog-item-img-wrap {
        height: 247px;
        min-height: 247px;
        max-height: 247px;
    }

    .blog-item-img-wrap-top {
        height: 228px;
        min-height: 228px;
        max-height: 228px;
    }

    .blog-item-img-wrap-top-normal,
    .normal-blog-item-img-wrap {
        height: 195px;
        min-height: 195px;
        max-height: 195px;
    }

    .product-detail-gallery-img-wrap {
        height: 399px;
        min-height: 399px;
        max-height: 399px;
    }

    .related-products-text {
        font-size: 28px;
    }

    .search-form {
        width: 90%;
    }

    .offcanvas-card {
        width: 100% !important;
    }

    .card-total-info {
        width: 100% !important;
    }

    .category-top-banner {
        height: 200px;
    }

    .skincare-101 {
        background-position: center center;
    }

    .product-filter-top {
        font-size: 20px !important;
    }

    .product-left-filter {
        font-size: 24px !important;
    }

    .product-box {
        padding: 10px;
    }

    .product-box-img-wrap {
        height: 174px;
        min-height: 174px;
        max-height: 174px;
    }

    .product-box-title-wrap,
    .skin-quiz-product-note {
        min-height: 3.9em;
    }

    .skin-quiz-product-note {
        font-size: 12px !important;
        -webkit-line-clamp: 3;
    }

    .product-box-title {
        font-size: 16px;
        -webkit-line-clamp: 3;
        height: calc(1.3em * 3);
    }

    .product-box-body-text,
    .product-box-price {
        font-size: 14px;
    }

    .btn-product-box-add-to-cart {
        font-size: 13px;
    }

    .retinol-question-name {
        font-size: 28px;
        font-weight: 700;
    }

    .skin-quiz-question-answer {
        width: 100%;
    }

    .section-step-4 {
        background-position: center bottom;
        background-size: 45% auto;
    }

    /* .section-step-2 {
        background-size: 45% auto;
    } */

    .section-step-5 {
        background-position: center bottom;
        background-size: 100% auto;
    }

    /* .section-step-4 {
        background-size: 100% auto;
    } */

    /* .section-step-5 {
        background-position: center bottom;
        background-size: 90% auto;
    } */

    .section-step-6 {
        background-size: 100% auto;
    }

    /* .section-step-2 {
        background-size: 65% auto, 40% auto;
    } */

    .section-step-8 {
        background-position: center bottom;
        background-size: 30% auto;
    }

    .skincare-by-experts-section-determine-skin-type {
        margin-top: 40px;
    }

    .contact-box {
        height: 200px;
    }

    .contact-us-banner {
        height: auto;
    }

    .about-us-section-1 {
        background-size: 100% auto;
    }

    .about-us-box-text {
        font-size: 16px !important;
    }

    .fs-24 {
        font-size: 24px !important;
    }

    .top-product-mobile-wrap {
        overflow-x: auto;
    }

    .top-product-mobile {
        width: 260px;
        min-width: 260px;
        max-width: 260px;
    }

    .category-demand-mobile {
        width: 308px;
        min-width: 308px;
        max-width: 308px;
    }

    .category-collection-mobile {
        width: 243px;
        min-width: 243px;
        max-width: 243px;
    }

    .section-step-input-phone .phone {
        width: 100%;
    }

    .skin-quiz-product-box {
        outline: 1px solid var(--navy-dark);
    }

    .blog-detail-img-wrap {
        height: 200px;
        min-height: 200px;
        max-height: 200px;
    }

    .blog-detail-title {
        font-size: 28px !important;
    }

    .blog-detail-nav {
        font-size: 14px !important;
    }

    .blog-list-nav {
        font-size: 12px !important;
    }

    .what-is-retinol {
        margin-top: unset !important;
    }

    .base-routine-rotinol-wrap {
        width: 100%;
    }

    .base-routine-rotinol-text {
        font-size: 13px;
    }

    .base-routine-rotinol-wrap img {
        width: 35px;
    }

    .blog-detail-content table {
        display: block;
        max-width: 100%;
        overflow-x: auto;
        /* white-space: nowrap; */
    }
}