@charset "utf-8";

@font-face {
    font-family: 'Freesentation-4Regular';
    src: url('../fonts/Freesentation-4Regular.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Freesentation-5Medium';
    src: url('../fonts/Freesentation-5Medium.woff2') format('woff2');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Freesentation-6SemiBold';
    src: url('../fonts/Freesentation-6SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'Noto Sans KR';
    src: url('../fonts/noto-sans-kr-v36-korean_latin-regular.woff2') format('woff2');
    font-weight: 100 400;
    font-style: normal;
}

@font-face {
    font-family: 'Noto Sans KR';
    src: url('../fonts/noto-sans-kr-v36-korean_latin-600.woff2') format('woff2');
    font-weight: 500 900;
    font-style: normal;
}

body {
    font-family: 'Noto Sans KR' !important;
}

p {
    margin-bottom: 0px !important;
}

.ft-noto {
    font-family: 'Noto Sans KR' !important;
}

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

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

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

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

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

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

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

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

.warning-sentence {
    font-size: 25px;
}

@media (min-width: 440px) {
    .warning-sentence {
        font-size: 28px;
    }
}

.content-center {
    align-content: center;
}

.self-center {
    align-self: center;
}

.active-top-menu {
    font-weight: 700 !important;
    color: white !important;
}

.active-top-menu::after {
    content: "";
    display: block;
    border-bottom: 3px solid #ffffff;
    margin-top: 6px;
    margin-left: 5px;
    margin-right: 5px;
}

.bg-theme {
    --tw-bg-opacity: 1;
    background-color: #ff6400;
}

.bg-theme-light {
    background-color: #fbecf4;
}

.bg-sub-theme {
    background: #F5F5F5;
}

.bg-theme-gray {
    background: #F5F5F5;
}

.bg-white {
    background: #FFFFFF;
}

.bg-theme-divider {
    background: rgb(241, 241, 241);
    height: 1px;
}

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

.color-theme {
    color: #ff6400;
}

.color-red {
    color: red;
}

.sub-color-theme {
    color: #3a8afd;
}

.color-gray {
    color: gray;
}

.ft-base {
    font-size: 1rem;
    line-height: 1.5rem;
}

.ft-sm {
    font-size: .875rem;
    line-height: 1.25rem;
}

.ft-xs {
    font-size: .75rem;
    line-height: 1rem;
}

.fw-500 {
    font-weight: 500;
}

.fw-700 {
    font-weight: 700;
}

#bg-main {
    max-width: 550px;
    margin-right: auto !important;
    margin-left: auto !important;
    --tw-bg-opacity: 1;
    background-color: rgb(247 247 247);
}

/* PC화면에서는 550px로 넓히기 */
@media (min-width: 992px) {
    #bg-main {
        max-width: 550px;
        border-left: 1px solid #e5e5e5;
        border-right: 1px solid #e5e5e5;
    }
}

@media (min-width: 992px) {
    .slogan-logo {
        display: block;
    }
}

.shop-simple-header {
    position: sticky;
    top: 0px;
    width: 100%;
    height: 55px;
    z-index: 1000;
    transform: translateZ(0);
    will-change: transform;
}

#main-container {
    background-color: white;
}

.container-inner-no-mx {
    margin-left: calc(var(--bs-gutter-x)* -.5);
    margin-right: calc(var(--bs-gutter-x)* -.5);
}

.badge-position {
    right: -18px;
    top: 20%;
}

.main_brand_title {
    font-size: .7rem;
    text-align: center;
    padding-top: 7px;
    padding-bottom: 7px;
}

.item_price_001 {
    font-size: .75rem;
    font-weight: 600;
    color: black;
    line-height: 1rem;
}

.dc_price_percent_001 {
    font-size: .75rem;
    font-weight: 600;
    color: red;
}

.bg-footer {
    background: #F9F9F9;
    color: rgb(145, 145, 145);
}

.footer_main_text {
    font-weight: 700;
    color: black;
    font-size: .85rem;
}

.footer_text {
    font-size: .77rem;
    line-height: 1.2rem;
}

.bottom_menu {
    position: sticky;
    bottom: -1px !important;
    height: 60px;
    align-content: center;
    background-color: #fff;
}

.bottom-menu-my-icon {
    font-size: 1.4rem;
    line-height: 1.8rem;
}

.menu_item {
    font-size: 1.1rem
}

.menu_desc {
    font-size: .65rem;
    font-weight: 700;
    text-align: center;
    font-family: 'notosanskr', 'Apple SD Gothic Neo';
}

.gotop-detail {
    right: .6rem;
    bottom: 4.2rem;
    opacity: 0.4;
    z-index: 1200;
}

.mypage-row {
    display: flex;
    justify-content: space-between !important;
    padding-top: .73rem;
    padding-bottom: .73rem;
}

.mypage-row-text {
    font-weight: 600;
    font-size: .875rem;
    line-height: 1.25rem;
}

.mypage-row-light-text {
    font-weight: 400;
    font-size: .875rem;
    line-height: 1.25rem;
    font-family: 'notosanskr', 'Apple SD Gothic Neo';
}

.detail-buy-btn {
    color: white;
    background-color: #ff6400;
    display: grid;
    text-align: center;
    align-content: center !important;
    vertical-align: middle;
    width: 100%;
    height: 100% !important;
    border-radius: .5rem;
    margin-left: .125rem;
    font-family: 'Freesentation-6SemiBold';
    font-size: .95rem;
}

.detail-basket-btn {
    color: #ff6400;
    background-color: #fff;
    display: grid;
    text-align: center;
    align-content: center !important;
    vertical-align: middle;
    width: 100%;
    height: 100% !important;
    border-radius: .5rem;
    border: 1px #ff6400 solid;
    margin-right: .125rem;
    font-family: 'Freesentation-6SemiBold';
    font-size: .95rem;
}

.btn-height {
    height: 43px;
}

.btn-theme-strong {
    background: #ff6400 !important;
    color: white !important;
    border-radius: 10px !important;
    font-size: .85rem !important;
    font-family: 'Freesentation-4Regular' !important;
}

.btn-theme-normal {
    background: #fff !important;
    color: #ff6400 !important;
    border-radius: 10px !important;
    font-size: .85rem !important;
    font-family: 'Freesentation-4Regular' !important;
    border: 1px solid #ff6400 !important;
}

.btn-theme-light {
    background: #fff !important;
    color: #555555 !important;
    border-radius: 10px !important;
    font-size: .85rem !important;
    font-family: 'Freesentation-4Regular' !important;
    border: 1px solid #555555 !important;
}

#sct_sortlst {
    position: sticky;
    top: 54px;
    z-index: 500;
    background: #ebebeb;
    padding: 0px;
    padding-bottom: 7px;
    padding-top: 7px;
    transform: translateZ(0);
    will-change: transform;
}

.sort-wrap {
    overflow-x: auto;
    white-space: nowrap;
}

.sort-wrap::-webkit-scrollbar {
    display: none;
}

.list-group-item.active {
    background-color: #ffffff !important;
    border-color: #000000 !important;
}

.item-sort-wrap .active a {
    color: #000000 !important;
}

.theme-min-height {
    min-height: calc(100vh - 115px);
}

.theme-min-height-footer {
    min-height: calc(100vh - 115px - 214px);
}

.theme-min-height-list-sort {
    min-height: calc(100vh - 115px - 54px);
}

.theme-min-height-title {
    min-height: calc(100vh - 55px);
}

.btn-gotop {
    background: white !important;
    border-radius: 50%;
    border: 1px solid #d6d6d6 !important;
    right: 20px;
    bottom: -50px;
    z-index: 1000000;
}

.divider {
    border-bottom: 1px solid #f5f5f5;
    margin-bottom: 23px;
    margin-top: 23px;
}

.divider-grey {
    border-bottom: 1px solid #e9e9e9;
}

.main-review-wrap {
    padding-right: calc(var(--bs-gutter-x) * .5);
    padding-left: calc(var(--bs-gutter-x) * .5);
}

.cancle-item-wrap {
    margin-left: calc(var(--bs-gutter-x) * -.5);
    margin-right: calc(var(--bs-gutter-x) * -.5);
}

.divider-m {
    border-bottom: 5px solid #f5f5f5;
    margin-bottom: 23px;
    margin-top: 23px;
}

.divider-s {
    border-bottom: 4px solid #f5f5f5;
}

.divider-l {
    border-bottom: 15px solid #f5f5f5;
}

.review-item-img-wrapper {
    background: #f5f5f5;
    border-radius: 10px;
    margin-bottom: 25px;
}

.review-item-desc {
    margin-left: 10px;
    font-size: 13px;
}

.review-item-title {
    font-size: 13px;
    font-weight: 600;
}

.review-profile {
    width: 40px !important;
    height: 40px !important;
}

.orderform-title {
    font-family: 'Freesentation-6SemiBold';
    font-size: 20px;
}

.order-item-img {
    width: 90px !important;
    flex-shrink: 0;
}

.order-item-desc {
    flex-grow: 1;
}

.order-item-desc div {
    padding-top: 1px;
}

.order-benefit {
    color: #245eff;
}

#od_temp_point {
    font-size: 13px;
    border: 1px solid #e3e3e3;
    border-radius: 7px;
    width: 100%;
    padding: .25rem .7rem;
    height: 35px;
}

.video-container {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%;
    /* 16:9 비율 */
    height: 0;
    overflow: hidden;
}

.video-container iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.h-full {
    height: 100%;
}

.search-btn {
    position: absolute !important;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    border: none !important;
    background: none;
    cursor: pointer !important;
}

.search-form-control {
    display: block;
    width: 100%;
    padding: 0.575rem .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 2;
    color: var(--bs-body-color);
    appearance: none;
    background-color: var(--bs-body-bg);
    background-clip: padding-box;
    border: var(--bs-border-width) solid var(--bs-border-color);
    border-radius: 0;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.as-h {
    margin-bottom: .5rem;
    line-height: 1.2;
}

.underline-yellow {
    background: linear-gradient(transparent 60%, yellow 40%);
}

.text-divider {
    display: flex;
    align-items: center;
    text-align: center;
    color: #cbc8c8;
    margin: 10px 0;
}

.text-divider::before,
.text-divider::after {
    content: "";
    flex: 1;
    border-bottom: 1px solid #cbc8c8;
    /* 회색 선 */
    margin: 0 10px;
}

/* 1:1 정사각형 썸네일 */
.review-image-container {
    position: relative;
    width: 100%;
    aspect-ratio: 1 / 1;
    /* 화면 너비에 따라 2칸/3칸일 때도 정사각 유지 */
    overflow: hidden;
    border-radius: 5px;
}

.review-image-container img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.review-thumb-descrption-wrapper {
    background: white;
    padding: 7px 10px 22px 10px;
    min-height: 75px;
    font-size: 13px;
    font-weight: 500;
}

.review-thumb-subject {
    font-weight: 700;
}

.reivew-thumb-description-teaser-wrapper {
    display: flex;
    margin-top: 2px;
    gap: 10px;
    font-weight: 400;
    font-size: 12px;
    color: #696969;
}

.reivew-thumb-description-reviewer-wrapper {
    display: flex;
    margin-top: 2px;
    /* gap: 10px; */
    font-size: 11px;
    color: #797979;
    /* font-weight: 800; */
}

.reivew-thumb-description-etc-wrapper {
    display: flex;
    margin-top: 2px;
    gap: 10px;
    font-size: 12px;
    color: black;
    font-weight: 500;
}

.sticky-bug-fix {
    transform: translateZ(0);
    will-change: transform;
}

.not-sure-adult {
    filter: blur(30px);
    transform: scale(0.5);
}

/* review-content 안에 있는 not-sure-adult만 별도 스타일 */
.review-content .not-sure-adult {
    filter: blur(5px);
    transform: scale(0.7);
}

@media screen and (min-width: 700px) {
    .honeyme-character {
        position: fixed;
        bottom: 140px;
        right: calc((100vw - 450px) / 2 - 220px);
        width: 150px;
        z-index: 9999;
    }
}

@media screen and (max-width: 699px) {
    .honeyme-character {
        display: none;
    }
}

.items-wrap-brand-page {
    padding-top: 10px;
    padding-bottom: 20px;
    color: #000;
}

.wrapper-basic {
    padding-left: 15px;
    padding-right: 15px;
}

/* 팝업 컨테이너 전체 화면 덮기 */
#hd_pop {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: 99998;
}

/* 배경 어둡게 하는 레이어 (팝업보다 아래) */
#hd_pop .popup_overlay {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.6);
    z-index: 99998;
}

/* 팝업은 오버레이보다 위 */
#hd_pop .hd_pops {
    position: fixed;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
    max-width: 80%;
    background: #000;
    border: 1px solid #000;
    /* 기존 border: 1px black; 오타 수준이라 수정 */
    box-shadow: 0 5px 20px rgba(0, 0, 0, 0.3);
    z-index: 99999;
}

.review-award-badge {
    display: inline-block;
    margin-left: 4px;
    color: #ff6400;
}

/* 기본 숨김 */
.hm-side-banners {
    display: none;
}

/* PC에서만 노출 */
@media (min-width:1024px) {

    .hm-side-banners {
        display: block;
    }

    .hm-side-banner {
        position: fixed;
        top: 160px;
        right: calc(50% + 300px);
        width: 220px;
    }

    /* 전체 박스 */
    .side-popular-posts {
        background: #fff;
        border: 1px solid #ececec;
        border-radius: 12px;
        padding: 18px;
        box-shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
    }

    /* 제목 */
    .side-popular-title {
        font-size: 14px;
        font-weight: 800;
        margin-bottom: 7px;
        color: #111;
    }

    /* 게시글 */
    .side-post {
        display: block;
        text-decoration: none;
        padding: 8px 0;
        border-bottom: 1px solid #f3f3f3;
        transition: all .2s ease;
        line-height: 1.2;
    }

    .side-post:last-child {
        border-bottom: none;
    }

    /* hover */
    .side-post:hover .post-title {
        color: #ff6400;
    }

    /* 뱃지 */
    .post-badge {
        display: inline-block;
        font-size: 11px;
        font-weight: 700;
        margin-right: 2px;
    }

    /* 허니톡 */
    .post-badge {
        color: #111;
    }

    /* 리뷰 */
    .post-badge.review {
        color: #111;
    }

    /* 제목 */
    .post-title {
        font-size: 12px;
        color: #333;
        line-height: 1.2;
    }

    .post-comment {
        font-weight: 400;
        font-size: 11px;
        margin-left: 0px;
        color: #ff6400;
    }
}