@charset "utf-8";

.hc-title--sm {
    font-size: 2.2rem;
}

.hc-btn-outline--light {
    border-color: rgba(255, 255, 255, 0.45);
    color: #fff;
    background: transparent;
}

.hc-btn-outline--light:hover,
.hc-btn-outline--light:focus {
    color: #111111;
    background: #fff;
    text-decoration: none;
}

.hc-chip--light {
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    border: 1px solid rgba(255, 255, 255, 0.14);
}

.hc-chip--light:hover,
.hc-chip--light:focus {
    color: #fff;
    background: rgba(255, 255, 255, 0.2);
    text-decoration: none;
}

.hc-shop-page {
    background:
        radial-gradient(circle at top left, rgba(138, 153, 122, 0.18), transparent 34%),
        linear-gradient(180deg, #f7f3ea 0%, #f3eee3 100%);
    padding-top: 0; /* 헤더 바로 아래 배너 붙이기 */
}

.hc-shop-page a:hover {
    text-decoration: none;
}

.hc-shop-page,
.hc-shop-page h1,
.hc-shop-page h2,
.hc-shop-page h3,
.hc-shop-page h4,
.hc-shop-page p,
.hc-shop-page span,
.hc-shop-page a,
.hc-shop-page button,
.hc-shop-page th,
.hc-shop-page td,
.hc-shop-page label,
.hc-shop-page li {
    word-break: keep-all;
}

.hc-shop-page img,
.hc-shop-page input,
.hc-shop-page select,
.hc-shop-page textarea,
.hc-shop-page button {
    max-width: 100%;
}

.hc-shop-hero {
    position: relative;
    overflow: hidden;
    padding: 36px 0 28px; /* 상단 여백 축소 — 헤더에 바로 붙음 */
    background: linear-gradient(180deg, #edf4e8 0%, #f5efe4 100%);
    border-bottom: 1px solid rgba(0,0,0, 0.08);
}

.hc-shop-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(255, 255, 255, 0.54) 100%),
        radial-gradient(circle at top right, rgba(100,100,100, 0.18), transparent 34%);
}

.hc-shop-hero__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    opacity: 0.42;
    filter: saturate(0.92) brightness(1.18);
    transform: scale(1.02);
}

.hc-shop-hero .container {
    z-index: 2;
}

.hc-shop-hero__actions {
    display: flex;
    gap: 12px;
    justify-content: flex-start;
    flex-wrap: wrap;
}

.hc-shop-hero__actions .hc-btn-primary,
.hc-shop-hero__actions .hc-btn-outline,
.hc-shop-hero__chips .hc-chip {
    white-space: nowrap;
}

.hc-shop-hero .text-white {
    color: #183021 !important;
}

.hc-shop-hero .text-white-50,
.hc-shop-hero .hc-subtitle {
    color: #555555 !important;
}

.hc-shop-hero .hc-btn-outline--light {
    color: #111111;
    border-color: rgba(0,0,0, 0.18);
    background: rgba(255, 255, 255, 0.72);
}

.hc-shop-hero .hc-btn-outline--light:hover,
.hc-shop-hero .hc-btn-outline--light:focus {
    color: #111111;
    background: #fff;
}

.hc-shop-hero .hc-chip--light {
    background: rgba(255, 255, 255, 0.82);
    color: #111111;
    border-color: rgba(0,0,0, 0.12);
}

.hc-shop-hero .hc-chip--light:hover,
.hc-shop-hero .hc-chip--light:focus {
    color: #111111;
    background: #fff;
}

.hc-shop-hero__chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 24px;
}

.hc-shop-shell {
    padding: 26px 0 72px;
}

.hc-shop-overview {
    display: flex;
    gap: 28px;
    justify-content: space-between;
    align-items: stretch;
    max-width: 1180px;
    margin: 0 auto 32px;
    padding: 34px 36px;
    position: relative;
    z-index: 2;
}

.hc-shop-overview__copy {
    flex: 1 1 56%;
    min-width: 0;
}

.hc-shop-overview__title {
    margin: 8px 0 10px;
    font-size: 1.85rem;
    color: #183021;
}

.hc-shop-overview__tools {
    flex: 1 1 44%;
    display: flex;
    flex-direction: column;
    gap: 16px;
    min-width: 0;
}

.hc-shop-overview__copy .hc-text {
    overflow-wrap: anywhere;
}

.hc-shop-search {
    display: flex;
    align-items: center;
    gap: 0;
    border: 1px solid rgba(0,0,0, 0.12);
    border-radius: 999px;
    overflow: hidden;
    background: #f9f7f1;
}

.hc-shop-search input {
    flex: 1 1 auto;
    height: 52px;
    border: 0;
    background: transparent;
    padding: 0 18px;
    color: #183021;
}

.hc-shop-search input:focus {
    outline: none;
}

.hc-shop-search button {
    height: 52px;
    border: 0;
    background: #111111;
    color: #fff;
    padding: 0 20px;
    font-weight: 700;
}

.hc-shop-overview__links {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.hc-shop-overview__links .hc-btn-primary,
.hc-shop-overview__links .hc-btn-outline {
    white-space: nowrap;
}

.hc-shop-wrapper {
    width: auto;
    min-width: 0;
    margin: 0 auto;
    background: transparent;
}

.hc-shop-panel {
    width: auto;
    min-width: 0;
    max-width: 1180px;
    margin: 0 auto;
    background: #fff;
    border-radius: 30px;
    box-shadow: 0 30px 80px rgba(42, 57, 33, 0.08);
    padding: 38px 36px 44px;
}

.hc-shop-content {
    width: 100%;
    float: none;
    margin: 0 auto;
    clear: both;
}

.hc-shop-content.is_index {
    width: 100%;
}

.hc-shop-home-intro,
.hc-shop-category-grid,
.hc-shop-feature-strip {
    max-width: 1080px;
    margin: 0 auto 38px;
}

.hc-shop-closing {
    max-width: 1080px;
    margin: 0 auto 0;
}

/* ── CTA 클로징 박스 ── */
.hc-cta-box {
    position: relative;
    overflow: hidden;
    border-radius: 32px;
    background: linear-gradient(135deg, #0d0d0d 0%, #222222 50%, #111111 100%);
    box-shadow: 0 32px 80px rgba(24, 48, 33, 0.28);
}

.hc-cta-box__glow {
    position: absolute;
    inset: 0;
    pointer-events: none;
    background:
        radial-gradient(ellipse at 10% 20%, rgba(100,100,100, 0.22) 0%, transparent 50%),
        radial-gradient(ellipse at 90% 80%, rgba(100,100,100, 0.14) 0%, transparent 45%);
}

.hc-cta-box__inner {
    position: relative;
    z-index: 1;
    padding: 72px 48px 64px;
}

.hc-cta-box__label {
    display: inline-block;
    margin-bottom: 20px;
    padding: 6px 18px;
    border-radius: 999px;
    background: rgba(100,100,100, 0.18);
    border: 1px solid rgba(100,100,100, 0.35);
    color: #777777;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.24em;
    text-transform: uppercase;
}

.hc-cta-box__title {
    margin: 0 0 20px;
    font-size: 2.4rem;
    font-weight: 800;
    letter-spacing: -0.02em;
    line-height: 1.25;
    color: #fff;
}

.hc-cta-box__desc {
    margin: 0 auto;
    max-width: 520px;
    font-size: 1rem;
    line-height: 1.85;
    color: rgba(255, 255, 255, 0.68);
    word-break: keep-all;
}

.hc-cta-box__divider {
    width: 56px;
    height: 2px;
    background: linear-gradient(90deg, #777777, rgba(100,100,100, 0.2));
    margin: 28px auto;
}

.hc-cta-box__actions {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 32px;
}

.hc-cta-box__btn-primary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 34px;
    border-radius: 999px;
    background: #777777;
    color: #0d0d0d;
    font-size: 14px;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-decoration: none;
    transition: all 0.22s ease;
    white-space: nowrap;
}

.hc-cta-box__btn-primary:hover,
.hc-cta-box__btn-primary:focus {
    background: #d4b06a;
    color: #0d0d0d;
    text-decoration: none;
    transform: translateY(-2px);
    box-shadow: 0 10px 28px rgba(100,100,100, 0.38);
}

.hc-cta-box__btn-outline {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 34px;
    border-radius: 999px;
    border: 1.5px solid rgba(255, 255, 255, 0.35);
    background: rgba(255, 255, 255, 0.07);
    color: rgba(255, 255, 255, 0.88);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-decoration: none;
    transition: all 0.22s ease;
    white-space: nowrap;
}

.hc-cta-box__btn-outline:hover,
.hc-cta-box__btn-outline:focus {
    background: rgba(255, 255, 255, 0.14);
    border-color: rgba(255, 255, 255, 0.6);
    color: #fff;
    text-decoration: none;
}

.hc-cta-box__chips {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    flex-wrap: wrap;
}

.hc-cta-box__chips span {
    display: inline-block;
    padding: 7px 16px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.07);
    border: 1px solid rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.62);
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
}

@media (max-width: 767px) {
    .hc-cta-box__inner {
        padding: 52px 28px 48px;
    }
    .hc-cta-box__title {
        font-size: 1.85rem;
    }
    .hc-cta-box__actions {
        flex-direction: column;
        align-items: stretch;
    }
    .hc-cta-box__btn-primary,
    .hc-cta-box__btn-outline {
        width: 100%;
        justify-content: center;
    }
}

.hc-shop-home-intro__meta {
    border-radius: 24px;
    background: #f7f4ec;
    padding: 22px;
    height: 100%;
}

.hc-shop-home-intro .hc-surface {
    padding: 34px 36px;
}

.hc-shop-home-intro .row,
.hc-shop-category-grid .row,
.hc-shop-feature-strip .row,
.hc-shop-closing .row {
    justify-content: center;
}

.hc-shop-home-intro .hc-text {
    overflow-wrap: anywhere;
}

.hc-shop-category-card {
    height: 100%;
    overflow: hidden;
    background: #f9f6ef;
    border-radius: 24px;
    box-shadow: 0 18px 38px rgba(36, 53, 35, 0.06);
}

.hc-shop-category-card__image {
    display: block !important;
    width: 100% !important;
    height: 240px !important;
    overflow: hidden !important;
    flex-shrink: 0 !important;
}

.hc-shop-category-card__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.35s ease;
}

.hc-shop-category-card:hover .hc-shop-category-card__image img {
    transform: scale(1.05);
}

.hc-shop-category-card__body {
    padding: 20px 20px 22px;
}

.hc-shop-category-card__body h3 {
    margin: 8px 0 10px;
    font-size: 1.3rem;
    color: #183021;
}

.hc-shop-category-card__body p {
    margin: 0;
    line-height: 1.7;
    color: #5f675f;
    overflow-wrap: break-word;
}

.hc-shop-category-card__actions {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.hc-shop-category-card__actions a {
    color: #111111;
    font-weight: 700;
}

.hc-shop-feature-strip__card {
    display: flex;
    flex-direction: column;
    gap: 10px;
    height: 100%;
    padding: 22px;
    border-radius: 24px;
    background: linear-gradient(145deg, #111 0%, #333 100%);
    color: #fff;
    box-shadow: 0 22px 42px rgba(24, 48, 33, 0.15);
}

.hc-shop-feature-strip__card strong {
    font-size: 1.15rem;
    line-height: 1.45;
    white-space: normal;
}

.hc-shop-feature-strip__card span:last-child {
    color: rgba(255, 255, 255, 0.72);
    line-height: 1.65;
}

.hc-shop-section {
    max-width: 1080px;
    margin: 44px auto 0;
}

.hc-shop-section__heading {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 12px;
    max-width: 760px;
    margin: 0 auto 26px;
    text-align: center;
}

.hc-shop-section__heading .hc-title {
    margin: 0;
}

.hc-shop-section__heading .hc-text {
    max-width: 680px;
}

.hc-shop-section__products {
    justify-content: center;
}

.hc-shop-product-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    border-radius: 26px;
    background: #fbf9f4;
    border: 1px solid rgba(0,0,0, 0.08);
    box-shadow: 0 18px 40px rgba(36, 53, 35, 0.08);
}

.hc-shop-product-card__image {
    display: block !important;
    width: 100% !important;
    height: 240px !important;
    overflow: hidden !important;
    background: #eff3ea;
    flex-shrink: 0 !important;
}

.hc-shop-product-card__image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 0.35s ease;
}

.hc-shop-product-card:hover .hc-shop-product-card__image img {
    transform: scale(1.05);
}

.hc-shop-product-card__body {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    padding: 22px 22px 24px;
}

.hc-shop-product-card__meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}

.hc-shop-product-card__category {
    display: inline-flex;
    align-items: center;
    padding: 7px 12px;
    border-radius: 999px;
    background: rgba(0,0,0, 0.08);
    color: #111111;
    font-size: 0.78rem;
    font-weight: 700;
}

.hc-shop-product-card__body h3 {
    margin: 0 0 12px;
    font-size: 1.28rem;
    line-height: 1.45;
}

.hc-shop-product-card__body h3 a {
    color: #183021;
}

.hc-shop-product-card__body p {
    margin: 0;
    color: #5f675f;
    line-height: 1.75;
    flex: 1 1 auto;
    overflow-wrap: anywhere;
}

.hc-shop-product-card__footer {
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(0,0,0, 0.08);
}

.hc-shop-product-card__price {
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.hc-shop-product-card__price span {
    color: #9a8c7a;
    font-size: 0.92rem;
    text-decoration: line-through;
}

.hc-shop-product-card__price strong {
    color: #183021;
    font-size: 1.3rem;
    line-height: 1.2;
}

.hc-shop-product-card__actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 16px;
}

.hc-shop-product-card__ghost {
    display: inline-flex;
    align-items: center;
    color: #111111;
    font-weight: 700;
    padding: 0;
}

.hc-shop-page .sct_wrap {
    margin: 0;
}

.hc-shop-page .sct_10 {
    margin: 0;
}

.hc-shop-page .lists-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-left: -14px;
    margin-right: -14px;
}

.hc-shop-page .lists-row .col-row-5 {
    width: 33.333333%;
}

.hc-shop-page .lists-row .col-row-4 {
    width: 33.333333%;
}

.hc-shop-page .lists-row .col-row-3 {
    width: 33.333333%;
}

.hc-shop-page .sct_10 .sct_li {
    float: none;
    padding-left: 14px;
    padding-right: 14px;
    margin-bottom: 34px;
}

.hc-shop-page .sct_10 .row-clear {
    clear: none !important;
}

.hc-shop-page .sct_10 .sct_img {
    background: #f0f0f0 !important;
    border-radius: 26px;
    overflow: hidden !important;
    height: 0 !important;
    padding-bottom: 56.25% !important;
    position: relative !important;
    display: block;
}

.hc-shop-page .sct_10 .sct_img a {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
}

.hc-shop-page .sct_10 .sct_img img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block;
}

/* 장바구니 버튼 — .sct_img를 기준으로 정확히 맞춤 */
.hc-shop-page .sct_10 .sct_btn.list-10-btn {
    position: static !important;
}

.hc-shop-page .sct_10 .sct_cart {
    background: rgba(0, 0, 0, 0.82) !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: auto !important;
    text-align: center;
    padding: 14px 0;
    font-size: 0.95rem;
    letter-spacing: 0.04em;
    border-radius: 0 0 26px 26px;
}

.hc-shop-page .sct_10 .sct_ct_wrap {
    padding: 16px 4px 0;
}

.hc-shop-card__eyebrow {
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #8e9d83;
    margin-bottom: 8px;
}

.hc-shop-page .sct_10 .sct_txt {
    border-bottom: 0;
    margin: 0 0 10px;
    padding-bottom: 0;
    font-size: 1.14rem;
    font-weight: 700;
    line-height: 1.45;
    white-space: normal;
}

.hc-shop-page .sct_10 .sct_txt a {
    color: #183021;
}

.hc-shop-page .sct_10 .sct_basic {
    color: #5f675f;
    line-height: 1.7;
    min-height: 3.4em;
    margin-bottom: 14px;
    overflow-wrap: break-word;
}

.hc-shop-page .sct_10 .sct_cost {
    color: #111111;
    font-size: 1.28rem;
    margin: 0;
}

.hc-shop-page .sct_10 .sct_dict {
    margin-top: 4px;
    color: #9a8c7a;
}

.hc-shop-page .sct_10 .sct_op_btn {
    bottom: 4px;
}

.hc-shop-page .sct_10 .sct_op_btn > button {
    color: #5c635d;
}

.hc-shop-card__link {
    display: inline-flex;
    align-items: center;
    margin-top: 14px;
    color: #111111;
    font-weight: 700;
}

.hc-shop-page #sit_ov_from,
.hc-shop-page #sod_bsk,
.hc-shop-page #sod_ws,
.hc-shop-page #sod_fin,
.hc-shop-page #sod_frm,
.hc-shop-page #sod_lst,
.hc-shop-page #sod_v,
.hc-shop-page #sod_mem,
.hc-shop-page #sod_pay,
.hc-shop-page #sod_addr,
.hc-shop-page #sod_ov,
.hc-shop-page #sct {
    width: auto;
}

.hc-shop-page #sit_ov_wrap {
    display: grid;
    grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
    gap: 34px;
    align-items: stretch; /* 이미지·정보 박스 높이 동일하게 */
}

/* 이미지 박스 — 높이를 우측 정보 박스와 맞춤 */
.hc-shop-page #sit_pvi {
    display: flex;
    flex-direction: column;
    min-height: 0;
}
.hc-shop-page #sit_pvi_big {
    flex: 1 1 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 0;
}
.hc-shop-page #sit_pvi_big img {
    width: 100%;
    max-width: 100%;
    height: auto;
    max-height: 540px;
    object-fit: contain;
    display: block;
}

/* 우측 정보 박스 float 제거 → grid 항목으로만 동작 */
.hc-shop-page #sit_pvi,
.hc-shop-page #sit_ov {
    float: none !important;
    width: auto !important;
    min-width: 0;
}

.hc-shop-page .tbl_head01,
.hc-shop-page .tbl_frm01,
.hc-shop-page .tbl_wrap,
.hc-shop-page #sod_bsk,
.hc-shop-page #sod_ws,
.hc-shop-page #sod_frm,
.hc-shop-page #sod_fin,
.hc-shop-page #sod_mem,
.hc-shop-page #sod_addr,
.hc-shop-page #sod_pay,
.hc-shop-page #sod_lst,
.hc-shop-page #sod_v,
.hc-shop-page #sit_info,
.hc-shop-page #sit_buy {
    overflow-x: auto;
}

.hc-shop-page #sit_pvi_big,
.hc-shop-page #sit_ov,
.hc-shop-page #sit_info,
.hc-shop-page #sit_buy,
.hc-shop-page .tbl_head01,
.hc-shop-page .tbl_frm01,
.hc-shop-page .tbl_wrap,
.hc-shop-page .local_ov01,
.hc-shop-page .local_desc01,
.hc-shop-page .sod_list,
.hc-shop-page .sod_left,
.hc-shop-page .sod_right,
.hc-shop-page .coupon_list {
    background: #fbf9f4;
    border: 1px solid rgba(0,0,0, 0.08);
    border-radius: 24px;
}

.hc-shop-page #sit_pvi_big {
    padding: 18px;
}

.hc-shop-page #sit_pvi_big img {
    border-radius: 18px;
}

.hc-shop-page #sit_ov {
    padding: 26px 26px 30px;
}

.hc-shop-item__eyebrow {
    margin: 0 0 10px;
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: #8e9d83;
}

.hc-shop-item__category {
    margin: 14px 0 0;
}

.hc-shop-item__category a {
    color: #111111;
    font-weight: 700;
}

.hc-shop-page #sit_title {
    color: #183021;
    font-size: 2rem;
    line-height: 1.35;
}

.hc-shop-page #sit_desc {
    color: #5f675f;
    line-height: 1.8;
}

.hc-shop-page .sit_info,
.hc-shop-page .sit_option,
.hc-shop-page #sit_sel_option {
    background: #fff;
    border-radius: 18px;
    padding: 18px;
}

.hc-shop-page .sit_ov_tbl th,
.hc-shop-page .sit_ov_tbl td,
.hc-shop-page .tbl_head01 th,
.hc-shop-page .tbl_head01 td,
.hc-shop-page .tbl_frm01 th,
.hc-shop-page .tbl_frm01 td {
    border-color: rgba(0,0,0, 0.08);
}

.hc-shop-page .tab_tit {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 18px;
}

.hc-shop-page .tab_tit li {
    margin: 0;
}

.hc-shop-page .tab_tit li button {
    border-radius: 999px;
    border: 1px solid rgba(0,0,0, 0.12);
    padding: 12px 18px;
    background: #f7f4ec;
    color: #111111;
    white-space: nowrap;
    font-size: 0.92rem;
}

.hc-shop-page .tab_tit li button.selected {
    background: #111111;
    color: #fff;
}

.hc-shop-page .tab_con > li {
    background: #fff;
    border-radius: 18px;
    padding: 22px;
    border: 1px solid rgba(0,0,0, 0.08);
}

.hc-shop-page .sum_section,
.hc-shop-page .sod_right {
    padding: 22px;
}

.hc-shop-page .btn_submit,
.hc-shop-page .btn01,
.hc-shop-page .btn02,
.hc-shop-page .btn_b01,
.hc-shop-page .btn_b02,
.hc-shop-page .btn_frmline,
.hc-shop-page .sit_btn_cart,
.hc-shop-page .sit_btn_buy {
    border-radius: 999px;
    border: 0;
    padding: 14px 22px;
    font-weight: 700;
    white-space: nowrap;
}

.hc-shop-page .btn_submit,
.hc-shop-page .sit_btn_buy {
    background: #111111;
    color: #fff;
}

.hc-shop-page .btn01,
.hc-shop-page .btn_b01,
.hc-shop-page .sit_btn_cart,
.hc-shop-page .btn02,
.hc-shop-page .btn_b02 {
    background: #e8ede5;
    color: #111111;
}

.hc-shop-page #wrapper_title,
.hc-shop-page #text_size {
    display: none;
}

@media (max-width: 1199px) {
    .hc-shop-page .lists-row .col-row-5,
    .hc-shop-page .lists-row .col-row-4,
    .hc-shop-page .lists-row .col-row-3 {
        width: 33.333333%;
    }
}

@media (max-width: 991px) {
    .hc-title--sm {
        font-size: 1.85rem;
    }

    .hc-shop-page {
        padding-top: 0; /* 헤더에 바로 붙이기 */
    }

    .hc-shop-overview {
        flex-direction: column;
        align-items: start;
        padding: 28px 24px;
    }

    .hc-shop-panel {
        padding: 24px 20px 30px;
        border-radius: 24px;
    }

    .hc-shop-page #sit_ov_wrap {
        grid-template-columns: 1fr;
    }

    .hc-shop-page .lists-row .col-row-5,
    .hc-shop-page .lists-row .col-row-4,
    .hc-shop-page .lists-row .col-row-3 {
        width: 50%;
    }

    .hc-shop-home-intro .hc-surface {
        padding: 28px 24px;
    }

    .hc-shop-product-card__body {
        padding: 20px;
    }
}

@media (max-width: 575px) {
    .hc-shop-page {
        padding-top: 0;
    }

    .hc-shop-hero {
        padding: 24px 0 18px;
    }

    .hc-shop-overview {
        margin-bottom: 22px;
        padding: 22px 18px;
    }

    .hc-shop-page .lists-row {
        margin-left: -8px;
        margin-right: -8px;
    }

    .hc-shop-page .sct_10 .sct_li {
        padding-left: 8px;
        padding-right: 8px;
    }

    .hc-shop-home-intro .hc-surface {
        padding: 22px 18px;
    }

    .hc-shop-section__heading {
        margin-bottom: 22px;
    }

    .hc-shop-product-card__body {
        padding: 18px 18px 20px;
    }

    .hc-shop-page .lists-row .col-row-5,
    .hc-shop-page .lists-row .col-row-4,
    .hc-shop-page .lists-row .col-row-3,
    .hc-shop-page .lists-row .col-row-2 {
        width: 100%;
    }

    .hc-shop-search,
    .hc-shop-overview__links,
    .hc-shop-hero__actions {
        width: 100%;
    }

    .hc-shop-search {
        flex-wrap: wrap;
        border-radius: 22px;
    }

    .hc-shop-search input,
    .hc-shop-search button {
        width: 100%;
    }

    .hc-shop-page .tab_tit li {
        width: 100%;
    }

    .hc-shop-page .tab_tit li button {
        width: 100%;
    }
}

/* ── default_shop.css 사이드바 레이아웃 재정의 (hwangchil 테마는 사이드바 없음) ── */

/* #wrapper min-width 1200px 제거 → 반응형 */
.hc-shop-page #wrapper,
.hc-shop-page #hd,
.hc-shop-page #ft {
    min-width: 0 !important;
    width: 100% !important;
}

/* #container width:1200px 제거 → 반응형 */
.hc-shop-page #container {
    width: auto !important;
    max-width: none !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    position: static !important;
}

/* 핵심: .is_index margin-left:285px 제거 (사이드바용 오프셋) */
.hc-shop-page #container .is_index,
.hc-shop-page #container .shop-content {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    float: none !important;
    padding: 0 !important;
    position: static !important;
}

/* 상품 목록(sct) float 제거 */
.hc-shop-page #sct,
.hc-shop-page .sct_wrap,
.hc-shop-page .sct_10 {
    width: 100% !important;
    float: none !important;
    margin: 0 !important;
}

/* 카테고리 목록 float 제거 */
.hc-shop-page #cate_list,
.hc-shop-page #side,
.hc-shop-page #side_item {
    display: none !important;
}

/* hc-shop-panel 내부 정렬 보정 */
.hc-shop-panel > .hc-shop-content,
.hc-shop-panel > #wrapper,
.hc-shop-panel #container {
    display: block;
    width: 100%;
}

/* ══════════════════════════════════════════════
   마이페이지 레이아웃 재정의
   (default_shop.css의 고정 픽셀 float 레이아웃 → 반응형 flex)
══════════════════════════════════════════════ */

/* 전체 래퍼 */
.hc-shop-page #smb_my {
    display: flex;
    flex-wrap: wrap;
    gap: 24px;
    margin: 0 auto;
    max-width: 1080px;
    padding: 0;
}
.hc-shop-page #smb_my::after { display: none; }

/* 왼쪽 회원정보 카드 */
.hc-shop-page #smb_my_ov {
    float: none;
    width: 260px;
    flex-shrink: 0;
    border-radius: 16px;
    border: 1px solid rgba(35,65,46,0.10);
    background: #fff;
    box-shadow: 0 4px 16px rgba(35,65,46,0.07);
    overflow: hidden;
    margin: 0;
    align-self: flex-start;
}
.hc-shop-page #smb_my_ov h2 {
    position: static;
    font-size: 0.7rem !important;
    line-height: 1 !important;
    overflow: visible;
    padding: 14px 18px 0;
    color: #a09688;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 700;
}
.hc-shop-page #smb_my_ov .smb_me {
    padding: 14px 18px 16px;
    font-size: 0.95rem;
    text-align: center;
    border-bottom: 1px solid #f0ebe2;
    background: #faf8f4;
}
.hc-shop-page #smb_my_ov .smb_me img { width: 40px; }
.hc-shop-page #smb_my_ov .smb_me .my_ov_name {
    font-size: 1rem;
    margin-bottom: 8px;
    line-height: 1.4;
}
.hc-shop-page #smb_my_ov .smb_me a {
    font-size: 0.78rem;
    padding: 3px 8px;
    height: auto;
    line-height: 1.6;
}

/* 포인트/쿠폰/쪽지/스크랩 목록 */
.hc-shop-page #smb_private { padding: 6px 0; }
.hc-shop-page #smb_private li a {
    font-size: 0.88rem;
    padding: 8px 16px 8px 20px;
}
.hc-shop-page #smb_private a strong { font-size: 0.85rem; }

/* 내정보 */
.hc-shop-page #smb_my_ov h3 {
    font-size: 0.7rem;
    padding: 12px 18px 0;
    color: #a09688;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 700;
    margin: 0;
}
.hc-shop-page #smb_my_ov .op_area {
    padding: 8px 18px 12px;
    font-size: 0.82rem;
    line-height: 1.7;
    color: #635e58;
}
.hc-shop-page #smb_my_ov .op_area dt {
    float: left;
    clear: left;
    width: 72px;
    color: #a09688;
    font-weight: 600;
}
.hc-shop-page #smb_my_ov .op_area dd {
    margin-left: 76px;
    word-break: break-all;
}
.hc-shop-page #smb_my_ov a.withdrawal {
    display: block;
    text-align: center;
    font-size: 0.75rem;
    color: #c5bdb4;
    padding: 10px;
    border-top: 1px solid #f0ebe2;
}
.hc-shop-page #smb_my_ov a.withdrawal:hover { color: #e05050; }

/* 오른쪽 리스트 영역 */
.hc-shop-page #smb_my_list {
    float: none;
    flex: 1;
    min-width: 0;
    width: auto;
}

/* 주문내역 섹션 */
.hc-shop-page #smb_my_od { margin: 0 0 28px; }
.hc-shop-page #smb_my_od h2 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--hc-forest);
    margin: 0 0 12px;
    padding-bottom: 8px;
    border-bottom: 2px solid rgba(35,65,46,0.12);
}
/* 주문내역 테이블 헤더 — 50% 축소 */
.hc-shop-page #smb_my_od .tbl_head03 thead th {
    font-size: 0.6em;
    padding: 10px 0;
    letter-spacing: 0;
}

/* 주문내역 행 */
.hc-shop-page .smb_my_od { border-radius: 12px; overflow: hidden; }
.hc-shop-page .smb_my_od li { padding: 12px 14px; font-size: 0.88rem; }
.hc-shop-page .smb_my_od .smb_my_od_li1 { width: 110px; }
.hc-shop-page .smb_my_od .smb_my_od_li2 { width: 70%; }
.hc-shop-page .smb_my_od .smb_my_od_li3 { width: 70px; }
.hc-shop-page .smb_my_od .ord_num,
.hc-shop-page .smb_my_od .ord_name { font-size: 0.95rem; }
.hc-shop-page .smb_my_od .cost { font-size: 0.9rem; }

/* 위시리스트 섹션 */
.hc-shop-page #smb_my_wish { margin-bottom: 0; }
.hc-shop-page #smb_my_wish h2 {
    font-size: 1rem;
    font-weight: 700;
    color: var(--hc-forest);
    padding: 0 0 8px;
    border-bottom: 2px solid rgba(35,65,46,0.12);
}
.hc-shop-page #smb_my_wish li { padding: 10px 12px; font-size: 0.88rem; }
.hc-shop-page #smb_my_wish .smb_my_tit { font-size: 0.9rem; }
.hc-shop-page #smb_my_wish .smb_my_price { font-size: 0.92rem; margin-bottom: 18px; }
.hc-shop-page #smb_my_wish .smb_my_date { font-size: 0.82rem; }
.hc-shop-page #smb_my_wish li .wish_del { font-size: 1.1rem; top: 36px; }

/* 더보기 버튼 */
.hc-shop-page .smb_my_more { position: static; text-align: right; margin: 6px 0 0; }
.hc-shop-page .smb_my_more a {
    display: inline-block;
    font-size: 0.82rem;
    color: var(--hc-forest);
    background: none;
    padding: 0;
    height: auto;
    border-bottom: 1px solid rgba(35,65,46,0.3);
}

/* 장바구니/주문 버튼 */
.hc-shop-page #smb_ws_act {
    text-align: center;
    margin: 16px 0 20px;
    display: flex;
    gap: 8px;
    justify-content: center;
}
.hc-shop-page #smb_ws_act button {
    padding: 8px 22px;
    border-radius: 999px;
    font-size: 0.88rem;
    font-weight: 700;
    border: none;
    cursor: pointer;
    transition: all 0.18s;
}
.hc-shop-page #smb_ws_act .btn01 {
    background: var(--hc-forest);
    color: #fff;
}
.hc-shop-page #smb_ws_act .btn01:hover { background: #333333; }
.hc-shop-page #smb_ws_act .btn02 {
    background: var(--hc-gold);
    color: #fff;
}
.hc-shop-page #smb_ws_act .btn02:hover { background: #b38e48; }

/* ══════════════════════════════════
   B&W 통일 오버라이드 — 베이지·웜 컬러 제거
   ══════════════════════════════════ */
.hc-shop-page {
    background: #fff !important;
}
.hc-shop-hero {
    background: linear-gradient(180deg, #f5f5f5 0%, #ffffff 100%) !important;
}
.hc-shop-search { background: #f5f5f5 !important; }
.hc-shop-home-intro__meta { background: #f5f5f5 !important; }
.hc-shop-category-card { background: #f5f5f5 !important; box-shadow: 0 4px 16px rgba(0,0,0,.08) !important; }
.hc-shop-product-card { background: #fff !important; box-shadow: 0 4px 16px rgba(0,0,0,.08) !important; }
.hc-shop-product-card__image,
.hc-shop-page .sct_10 .sct_img { background: #f0f0f0 !important; }
/* 글자색 — 다크그린 → 블랙 */
.hc-shop-category-card__body h3,
.hc-shop-product-card__body h3 a,
.hc-shop-page .sct_10 .sct_txt a,
.hc-shop-overview__title,
.hc-shop-search input { color: #111 !important; }
/* 서브 텍스트 — 숲색 → 중간 회색 */
.hc-shop-category-card__body p,
.hc-shop-product-card__body p,
.hc-shop-page .sct_10 .sct_basic,
.hc-shop-card__eyebrow { color: #555 !important; }
/* 가격 */
.hc-shop-product-card__price strong,
.hc-shop-page .sct_10 .sct_cost { color: #111 !important; }
.hc-shop-product-card__price span,
.hc-shop-page .sct_10 .sct_dict { color: #999 !important; }
/* 히어로 텍스트 */
.hc-shop-hero .text-white,
.hc-shop-hero .text-white-50,
.hc-shop-hero .hc-subtitle { color: #222 !important; }
.hc-shop-hero .hc-btn-outline--light { color: #111 !important; border-color: rgba(0,0,0,.2) !important; background: rgba(255,255,255,.8) !important; }

/* 반응형 */
@media (max-width: 767.98px) {
    .hc-shop-page #smb_my { flex-direction: column; }
    .hc-shop-page #smb_my_ov { width: 100%; }
    .hc-shop-page .smb_my_od .smb_my_od_li2 { width: 55%; }
}

/* ══════════════════════════════════════════════════════
   모바일 쇼핑몰 최적화 — purevirgin 헤더 사용 시
   (mobile/shop/shop.head.php 교체 후 적용)
   ══════════════════════════════════════════════════════ */
@media (max-width: 768px) {

    /* ① 구(舊) 모바일 기본 헤더·푸터 완전 숨김 */
    #hd, #hd_sch, #hd_wr, .menu,
    #ft, #device_change,
    #container_title            { display: none !important; }

    /* ② body 여백 — purevirgin 헤더(56px) 기준 */
    body                        { padding-top: 56px !important; font-size: 14px; }

    /* ③ 컨테이너 패딩 제거 (shop wrapper 가 담당) */
    #container                  { padding: 0 !important; background: #fff; }

    /* ④ 쇼핑몰 히어로 배너 — 헤더에 바로 붙이기 */
    .hc-shop-page               { padding-top: 0 !important; }
    .hc-shop-hero               { padding: 20px 16px 16px !important; }
    .hc-shop-hero .hc-title     { font-size: 1.3rem !important; margin: 4px 0 6px !important; }
    .hc-shop-hero .hc-subtitle  { font-size: 0.82rem !important; }
    .hc-shop-hero__chips        { gap: 6px !important; margin-top: 12px !important; }
    .hc-chip                    { padding: 5px 12px !important; font-size: 12px !important; }

    /* ⑤ 오버뷰(검색+링크) 패널 */
    .hc-shop-shell              { padding: 10px 0 40px !important; }
    .hc-shop-overview           { flex-direction: column !important; padding: 14px 14px !important;
                                  margin-bottom: 12px !important; border-radius: 12px !important; }
    .hc-shop-overview__title    { font-size: 1.1rem !important; margin: 4px 0 6px !important; }
    .hc-shop-search             { height: 44px !important; }
    .hc-shop-search input       { height: 44px !important; font-size: 14px !important; }
    .hc-shop-search button      { height: 44px !important; padding: 0 14px !important; font-size: 13px !important; }
    .hc-shop-overview__links    { gap: 8px !important; }
    .hc-btn-primary, .hc-btn-outline { padding: 8px 14px !important; font-size: 13px !important; }

    /* ⑥ 상품 패널(박스) */
    .hc-shop-panel              { border-radius: 10px !important; padding: 12px 8px 20px !important;
                                  box-shadow: 0 4px 16px rgba(0,0,0,.06) !important; margin: 0 8px !important; }

    /* ⑦ 상품 목록 2열 그리드 — 이미지 정형화 */
    .hc-shop-page .lists-row,
    .sct_wrap .lists-row        { display: flex !important; flex-wrap: wrap !important;
                                  margin-left: -5px !important; margin-right: -5px !important; }
    .hc-shop-page .lists-row .col-row-5,
    .hc-shop-page .lists-row .col-row-4,
    .hc-shop-page .lists-row .col-row-3 { width: 50% !important; }
    .hc-shop-page .sct_10 .sct_li { padding-left: 5px !important; padding-right: 5px !important;
                                     margin-bottom: 16px !important; }

    /* ⑧ 썸네일 이미지 — 정사각형 고정 */
    .hc-shop-page .sct_10 .sct_img { border-radius: 10px !important; aspect-ratio: 16/9 !important; }

    /* ⑨ 상품 텍스트 */
    .hc-shop-page .sct_10 .sct_txt     { font-size: 13px !important; line-height: 1.4 !important;
                                         white-space: normal !important; -webkit-line-clamp: 2;
                                         display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; }
    .hc-shop-page .sct_10 .sct_basic   { display: none !important; } /* 설명 숨김 → 공간 확보 */
    .hc-shop-page .sct_10 .sct_cost    { font-size: 14px !important; font-weight: 700 !important; }
    .hc-shop-page .sct_10 .sct_ct_wrap { padding: 8px 2px 0 !important; }
    .hc-shop-page .sct_10 .sct_cart    { font-size: 12px !important; padding: 10px 0 !important; }

    /* ⑩ 카테고리 탭(sanchor) */
    .sanchor li                 { width: 33.333% !important; font-size: 12px !important; }
    .sanchor a                  { padding: 8px 4px !important; }

    /* ⑪ 상품 상세 페이지 — 모바일 최적화 */
    /* 이미지+정보 박스: 1열 세로 쌓기 */
    .hc-shop-page #sit_ov_wrap,
    #sit_ov_wrap                { grid-template-columns: 1fr !important;
                                  align-items: start !important; gap: 16px !important; }

    /* 이미지 박스 — 빈 공간 없이 꽉 채우기 */
    .hc-shop-page #sit_pvi_big  { max-height: none !important; padding: 12px !important; }
    .hc-shop-page #sit_pvi_big img,
    #sit_pvi_big img            { width: 100% !important; max-width: 100% !important;
                                  height: auto !important; max-height: 100vw !important;
                                  object-fit: contain !important; }

    /* 우측 정보 박스 모바일 */
    .hc-shop-page #sit_ov,
    #sit_ov                     { float: none !important; width: auto !important;
                                  padding: 18px !important; min-height: 0 !important; }

    /* 상품명·가격 */
    .hc-shop-page #sit_title,
    #sit_title                  { font-size: 1.3rem !important; }
    .sit_price, .it_name        { font-size: 1.1rem !important; }
    #sit_opt                    { padding: 12px !important; }
    #sit_act                    { padding: 12px !important; }
    #btn_sit_sms, #btn_sit_wish { padding: 8px 12px !important; font-size: 12px !important; }
    #btn_sit_order              { height: 48px !important; font-size: 15px !important; }
    #sit_img_wrap               { margin-bottom: 16px !important; }
    #sit_top                    { padding: 0 !important; }
    #sit_inf                    { padding: 0 12px !important; }

    /* ⑫ 마이페이지 */
    .hc-shop-page #smb_my       { flex-direction: column !important; }
    .hc-shop-page #smb_my_ov    { width: 100% !important; }

    /* ⑬ 카테고리 소개 배너 불필요 섹션 숨김 */
    .hc-shop-overview__copy .hc-eyebrow,
    .hc-shop-overview__copy .hc-text { display: none !important; }
    .hc-shop-overview__copy .hc-shop-overview__title { margin-top: 0 !important; }

    /* ⑭ 모바일 상품 상세: 하단 고정 버튼으로 인한 여백 보정 */
    #sit                        { padding-bottom: 80px !important; }

    /* ⑮ 모바일 상품 슬라이드 이미지 넘침 방지 */
    #sit_pvi                    { overflow: hidden !important; }
    #sit_pvi img,
    #sit_pvi li img             { max-width: 100% !important; height: auto !important; }
    #sit_pvi ul                 { padding: 0 !important; margin: 0 !important; }

    /* ⑯ PC 상품 상세 상품이미지 모바일에서 넘침 방지 */
    #sit_ov_from                { overflow: hidden !important; padding: 0 !important; }
    #sit_ov_wrap                { width: 100% !important; padding: 12px !important;
                                  grid-template-columns: 1fr !important; gap: 12px !important; }
    .hc-shop-page #sit_pvi_big img,
    #sit_pvi_big img            { width: 100% !important; max-width: 100% !important;
                                  height: auto !important; }
    #sit_pvi_thumb              { display: flex !important; flex-wrap: wrap !important; gap: 6px !important; }
    #sit_pvi_thumb li           { margin: 0 !important; }
    #sit_pvi_thumb img          { width: 56px !important; height: 56px !important; object-fit: cover; }
}

/* ══════════════════════════════════════════════════════════════
   상품 상세 페이지 레이아웃 완전 재정의
   — 관련상품 박스 삭제 + 우측 사이드바 삭제 + 전체 반응형 정비
   ══════════════════════════════════════════════════════════════ */

/* ① 관련상품 박스 완전 숨김 */
.hc-shop-page #sit_rel,
#sit_rel                        { display: none !important; }

/* ② 우측 사이드바(#sit_buy) 숨김 — 옵션+장바구니 패널 */
.hc-shop-page #sit_buy,
#sit_buy                        { display: none !important; }

/* ③ #sit_info 전체 폭 사용 + min-height 제거 */
.hc-shop-page #sit_info,
#sit_info {
    display: block !important;
    width: 100% !important;
    min-height: 0 !important;
    border: none !important;
    border-radius: 18px;
    overflow: hidden;
}

/* ④ #sit_tab 전체 폭 */
.hc-shop-page #sit_tab,
#sit_tab                        { width: 100% !important; display: block !important; }

/* ⑤ #sit_ov_wrap — PC 2열 그리드, 완전히 반응형 */
.hc-shop-page #sit_ov_wrap {
    width: 100% !important;
    max-width: 100% !important;
    padding: 24px !important;
}

/* ⑥ 상품 이미지 컨테이너 — 넘침 방지 */
.hc-shop-page #sit_pvi_big img  { width: 100% !important; max-width: 100% !important; height: auto !important; }
.hc-shop-page #sit_pvi          { max-width: 100% !important; overflow: hidden; }

/* ⑦ 상품 정보 박스 — min-height 제거 (빈 공간 방지) */
.hc-shop-page #sit_ov           { min-height: 0 !important; height: auto !important; }

/* ⑧ 탭 컨텐츠 내부 — 이미지/테이블 넘침 방지 */
.hc-shop-page #sit_tab .tab_con img,
.hc-shop-page #sit_inf img,
.hc-shop-page #sit_use img,
.hc-shop-page #sit_qa  img      { max-width: 100% !important; height: auto !important; }
.hc-shop-page #sit_tab table    { width: 100% !important; word-break: break-all; }
.hc-shop-page #sit_tab td,
.hc-shop-page #sit_tab th       { word-break: break-word; overflow-wrap: anywhere; }

/* ⑨ 쇼핑몰 전역 — 컨테이너 넘침 방지 */
.hc-shop-page *                 { max-width: 100%; box-sizing: border-box; }
.hc-shop-page img               { max-width: 100% !important; height: auto !important; }
.hc-shop-page input,
.hc-shop-page select,
.hc-shop-page textarea          { max-width: 100%; box-sizing: border-box; }

/* ⑩ 제품 목록 페이지 — 박스 넘침 방지 */
.hc-shop-page .sct_li           { overflow: hidden; }
.hc-shop-page .sct_txt          { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.hc-shop-page .sct_10 .sct_li   { min-width: 0; }

/* ⑪ 히어로 오버뷰 패널 — 넘침 방지 */
.hc-shop-overview               { overflow: hidden; }
.hc-shop-overview__tools        { min-width: 0; overflow: hidden; }
.hc-shop-search input           { min-width: 0; }

/* ⑫ 주문/결제 폼 내부 테이블 넘침 방지 */
.hc-shop-page .tbl_head01,
.hc-shop-page .tbl_frm01        { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.hc-shop-page .tbl_head01 table,
.hc-shop-page .tbl_frm01 table  { min-width: 0; width: 100% !important; }
.hc-shop-page .tbl_head01 td,
.hc-shop-page .tbl_frm01 td,
.hc-shop-page .tbl_head01 th,
.hc-shop-page .tbl_frm01 th     { word-break: break-word; }

/* ⑬ 사이드 카테고리 목록 + 오늘 본 상품 완전 숨김 */
.hc-shop-page #side,
.hc-shop-page #side_item,
.hc-shop-page #cate_list,
.hc-shop-page .boxtodayview,
.hc-shop-page #sit_today_view   { display: none !important; }

/* ⑭ 반응형 브레이크포인트 — 상세 페이지 */
@media (max-width: 1199px) {
    .hc-shop-page #sit_ov_wrap  { padding: 18px !important; }
}
@media (max-width: 991px) {
    .hc-shop-page #sit_ov_wrap  { grid-template-columns: 1fr !important; padding: 14px !important; }
    .hc-shop-page #sit_ov       { padding: 18px !important; }
}
@media (max-width: 575px) {
    .hc-shop-page #sit_ov_wrap  { padding: 8px !important; gap: 8px !important; }
    .hc-shop-page #sit_ov       { padding: 14px !important; }
    .hc-shop-page #sit_pvi_big  { padding: 8px !important; }
    .hc-shop-page .tab_tit      { flex-wrap: wrap !important; }
    .hc-shop-page .tab_tit li button { padding: 8px 10px !important; font-size: 12px !important; }
}

/* ══════════════════════════════════════════════════════════════
   쇼핑몰 전체 레이아웃 크기 최적화
   — 히어로 축소 · 오버뷰 컴팩트 · 전역 사이즈 적정화
   ══════════════════════════════════════════════════════════════ */

/* ────────────────────────────────────────────
   A. 히어로 배너 — 서브 배너 이미지 표시
──────────────────────────────────────────── */
.hc-shop-hero {
    padding: 56px 0 42px !important;
    border-bottom: 1px solid rgba(0,0,0,0.08) !important;
}
.hc-shop-hero__bg { opacity: 0.35 !important; }   /* 배경이미지 복구 */
/* ::after 오버레이는 그대로 유지 */

.hc-shop-hero .hc-title {
    font-size: 1.25rem !important;
    font-weight: 700 !important;
    margin: 2px 0 4px !important;
    color: #111 !important;
}
.hc-shop-hero .hc-eyebrow   { font-size: 11px !important; margin-bottom: 2px !important; }
.hc-shop-hero .hc-subtitle  { display: none !important; }  /* 부제목 숨김 */

.hc-shop-hero__chips {
    margin-top: 8px !important;
    gap: 6px !important;
}
.hc-shop-hero__chips .hc-chip {
    padding: 4px 12px !important;
    font-size: 12px !important;
    border-radius: 999px !important;
    background: #efefef !important;
    color: #333 !important;
    border: 1px solid #ddd !important;
}
.hc-shop-hero__chips .hc-chip:hover { background: #111 !important; color: #fff !important; }

/* ────────────────────────────────────────────
   B. 오버뷰 패널 — 컴팩트 툴바 (1줄)
──────────────────────────────────────────── */
.hc-shop-shell { padding: 14px 0 48px !important; }

.hc-shop-overview {
    flex-direction: row !important;
    align-items: center !important;
    padding: 12px 20px !important;
    margin-bottom: 16px !important;
    gap: 16px !important;
    border-radius: 12px !important;
    background: #fafafa !important;
    border: 1px solid #ebebeb !important;
    box-shadow: none !important;
}

/* 왼쪽 제목 영역 — 최소화 */
.hc-shop-overview__copy {
    flex: 0 0 auto !important;
    min-width: 0 !important;
}
.hc-shop-overview__copy .hc-eyebrow,
.hc-shop-overview__copy .hc-text { display: none !important; }

.hc-shop-overview__title {
    font-size: 1rem !important;
    font-weight: 700 !important;
    margin: 0 !important;
    white-space: nowrap !important;
    color: #111 !important;
}

/* 오른쪽 검색 + 링크 영역 */
.hc-shop-overview__tools {
    flex: 1 !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 10px !important;
}

.hc-shop-search {
    flex: 1 !important;
    height: 40px !important;
    background: #fff !important;
}
.hc-shop-search input  { height: 40px !important; font-size: 13px !important; }
.hc-shop-search button { height: 40px !important; padding: 0 16px !important; font-size: 13px !important; }

.hc-shop-overview__links {
    flex-shrink: 0 !important;
    gap: 8px !important;
}
.hc-shop-overview__links .hc-btn-primary,
.hc-shop-overview__links .hc-btn-outline {
    padding: 8px 14px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
}

/* ────────────────────────────────────────────
   C. 상품 패널 — 여백 최적화 + 폭 축소
──────────────────────────────────────────── */
.hc-shop-panel {
    padding: 24px 24px 32px !important;
    border-radius: 16px !important;
    max-width: 960px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
/* 오버뷰 패널도 동일 폭으로 */
.hc-shop-overview { max-width: 960px !important; }

/* ────────────────────────────────────────────
   D. 제품 목록 그리드 — 적정 밀도
──────────────────────────────────────────── */
.hc-shop-page .sct_10 .sct_li   { margin-bottom: 24px !important; }
.hc-shop-page .sct_10 .sct_txt  { font-size: 0.95rem !important; }
.hc-shop-page .sct_10 .sct_cost { font-size: 1.05rem !important; }

/* ────────────────────────────────────────────
   E. 상품 상세 — 적정 여백 + PC 크기 제한
──────────────────────────────────────────── */
.hc-shop-page #sit_ov_wrap  {
    padding: 18px !important;
    gap: 24px !important;
    max-width: 860px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.hc-shop-page #sit_pvi_big  { padding: 12px !important; }
.hc-shop-page #sit_pvi_big img { max-height: 460px !important; }
.hc-shop-page #sit_ov       { padding: 20px !important; }
.hc-shop-page #sit_title    { font-size: 1.45rem !important; }

/* ────────────────────────────────────────────
   F. 푸터 로고 — 항상 28px 고정
   (.hc-shop-page img 규칙이 height:auto로 덮어쓰는 버그 수정)
──────────────────────────────────────────── */
.hc-footer__brand-logo {
    height: 28px !important;
    max-height: 28px !important;
    width: auto !important;
    max-width: none !important;    /* shop-page * max-width:100% 예외 */
}

/* ────────────────────────────────────────────
   G. 반응형 — 오버뷰 패널 모바일
──────────────────────────────────────────── */
@media (max-width: 991px) {
    .hc-shop-overview {
        flex-direction: column !important;
        align-items: stretch !important;
        padding: 12px 14px !important;
    }
    .hc-shop-overview__tools { flex-direction: column !important; }
    .hc-shop-overview__links { width: 100% !important; }
    .hc-shop-overview__links .hc-btn-primary,
    .hc-shop-overview__links .hc-btn-outline { flex: 1 !important; text-align: center !important; }
    .hc-shop-panel { padding: 16px 14px 24px !important; }
}
@media (max-width: 575px) {
    .hc-shop-hero { padding: 12px 0 10px !important; }
    .hc-shop-hero .hc-title { font-size: 1.05rem !important; }
    .hc-shop-shell { padding: 10px 0 32px !important; }
    .hc-shop-overview { padding: 10px 12px !important; margin-bottom: 10px !important; }
    .hc-shop-overview__title { font-size: 0.9rem !important; }
    .hc-shop-panel { padding: 10px 8px 20px !important; border-radius: 10px !important; }
}

/* ══════════════════════════════════════════════════════════════
   상품 상세 — 쿠팡 스타일 레이아웃
   :has(.is_item) 으로 상세 페이지만 별도 적용
   ══════════════════════════════════════════════════════════════ */

/* ─ 패널 카드 해제 — 상세 페이지는 넓은 흰 배경 ─ */
.hc-shop-panel:has(.is_item) {
    max-width: 1100px !important;
    background: transparent !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    padding: 32px 0 64px !important;
}

/* ─ 2열 그리드 — 이미지 55% : 정보 45% ─ */
.hc-shop-panel:has(.is_item) #sit_ov_wrap {
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1.2fr) minmax(340px, 460px) !important;
    gap: 40px !important;
    align-items: start !important;   /* 각 컬럼 상단 정렬 */
    background: transparent !important;
    border: none !important;
    border-radius: 0 !important;
}

/* ─ 메인 이미지 — 정사각형 흰 카드 ─ */
.hc-shop-panel:has(.is_item) #sit_pvi_big {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    padding: 24px !important;
    aspect-ratio: 16 / 9;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
}
.hc-shop-panel:has(.is_item) #sit_pvi_big img {
    max-height: none !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    border-radius: 6px !important;
    object-fit: contain !important;
}

/* ─ 썸네일 스트립 ─ */
.hc-shop-panel:has(.is_item) #sit_pvi_thumb {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 12px !important;
    list-style: none !important;
    padding: 0 !important;
}
.hc-shop-panel:has(.is_item) #sit_pvi_thumb li { margin: 0 !important; }
.hc-shop-panel:has(.is_item) #sit_pvi_thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border: none !important;
    border-radius: 0 !important;
    display: block !important;
    max-width: none !important;
}
/* 선택/호버 표시는 버튼(.spv-thumb-btn)이 담당 — img에는 border 없음 */

/* ─ 정보 박스 — 흰 카드 ─ */
.hc-shop-panel:has(.is_item) #sit_ov {
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    padding: 28px 28px 32px !important;
    min-height: 0 !important;
    height: auto !important;
    position: sticky;
    top: 80px;        /* 헤더 높이만큼 띄워 스티키 스크롤 */
}

/* ─ 상품 제목 ─ */
.hc-shop-panel:has(.is_item) #sit_title {
    font-size: 1.4rem !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
    color: #111 !important;
    letter-spacing: -0.02em !important;
    margin-bottom: 14px !important;
    white-space: normal !important;
    max-width: none !important;
}

/* ─ 가격 테이블 ─ */
.hc-shop-panel:has(.is_item) .sit_ov_tbl {
    width: 100% !important;
    border-collapse: collapse !important;
    font-size: 0.92rem !important;
}
.hc-shop-panel:has(.is_item) .sit_ov_tbl th {
    color: #888 !important;
    font-weight: 500 !important;
    padding: 7px 0 !important;
    text-align: left !important;
    width: 80px !important;
    vertical-align: top !important;
}
.hc-shop-panel:has(.is_item) .sit_ov_tbl td {
    color: #222 !important;
    padding: 7px 0 !important;
    vertical-align: top !important;
}
.hc-shop-panel:has(.is_item) .tr_price td strong {
    font-size: 1.5rem !important;
    font-weight: 800 !important;
    color: #e22 !important;
    letter-spacing: -0.03em !important;
}

/* ─ 탭 정보 섹션 — 전체 폭 흰 카드 ─ */
.hc-shop-panel:has(.is_item) #sit_info {
    margin-top: 28px !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    padding: 0 !important;
    overflow: hidden !important;
    width: 100% !important;
    display: block !important;
}
.hc-shop-panel:has(.is_item) #sit_tab {
    width: 100% !important;
    display: block !important;
    padding: 0 !important;
}

/* ─ 반응형 — 태블릿 이하 1열로 ─ */
@media (max-width: 1024px) {
    .hc-shop-panel:has(.is_item) {
        padding: 20px 0 40px !important;
    }
    .hc-shop-panel:has(.is_item) #sit_ov_wrap {
        grid-template-columns: 1fr !important;
        gap: 20px !important;
    }
    .hc-shop-panel:has(.is_item) #sit_pvi_big {
        aspect-ratio: auto !important;
        max-height: 480px !important;
    }
    .hc-shop-panel:has(.is_item) #sit_ov {
        position: static !important;
    }
}
@media (max-width: 575px) {
    .hc-shop-panel:has(.is_item) #sit_ov {
        padding: 18px 16px 22px !important;
    }
    .hc-shop-panel:has(.is_item) #sit_title {
        font-size: 1.15rem !important;
    }
    .hc-shop-panel:has(.is_item) .tr_price td strong {
        font-size: 1.25rem !important;
    }
    .hc-shop-panel:has(.is_item) #sit_pvi_thumb img {
        width: 56px !important; height: 56px !important;
    }
}

/* ══════════════════════════════════════════════════════════════
   헤더 내폭(1400px) 기준 쇼핑몰 통일 레이아웃
   header-inner { width:1400px } 과 동일한 폭 사용
   ══════════════════════════════════════════════════════════════ */

/* ① Bootstrap .container → 헤더 내폭 1400px 와 동일하게 */
.hc-shop-hero .container,
.hc-shop-shell .container {
    max-width: 1400px !important;
    width: 100% !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
}

/* ② 오버뷰 바 — 960px 제한 해제, 컨테이너 꽉 채우기 */
.hc-shop-overview {
    max-width: 100% !important;
    width: 100% !important;
}

/* ③ 상품 패널(목록/주문 등) — 컨테이너 꽉 채우기 */
.hc-shop-panel {
    max-width: 100% !important;
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* ④ 상품 상세 패널 — 1400px 안에서 1100px 중앙 정렬 유지
   (.hc-shop-panel:has(.is_item) 규칙이 더 높은 우선순위로 계속 적용됨) */

/* ⑤ 상품 상세 그리드 — 이미지 자동 확장, 정보 고정 420px
   이미지 컬럼이 남은 공간을 모두 채움 → 크게 표시 */
.hc-shop-panel:has(.is_item) #sit_ov_wrap {
    grid-template-columns: 1fr minmax(320px, 420px) !important;
}
/* 이미지 박스 패딩 최소화 — 이미지가 꽉 차게 */
.hc-shop-panel:has(.is_item) #sit_pvi_big {
    padding: 6px !important;
}
.hc-shop-panel:has(.is_item) #sit_pvi_big img {
    border-radius: 8px !important;
}

/* ⑥ 반응형 */
@media (max-width: 1280px) {
    .hc-shop-hero .container,
    .hc-shop-shell .container { max-width: 100% !important; }
}
@media (max-width: 1024px) {
    .hc-shop-panel:has(.is_item) #sit_ov_wrap {
        grid-template-columns: 1fr !important;
    }
    .hc-shop-panel:has(.is_item) #sit_pvi_big {
        padding: 8px !important;
    }
}

/* ══════════════════════════════════════════════════════════════
   ⑳ 이미지 슬라이더 + 스펙 박스 + 가격 박스 스타일
   spv-*          : 상품 이미지 슬라이더
   sit_price_box  : 우측 컬럼 가격/배송 표시
   sit_item_spec  : 2열 그리드 아래 상품 정보 박스
   ══════════════════════════════════════════════════════════════ */

/* ── sit_pvi_big 리셋 (슬라이더로 교체) ── */
.hc-shop-panel:has(.is_item) #sit_pvi_big {
    position: relative !important;
    padding: 0 !important;
    aspect-ratio: auto !important;
    display: block !important;
    background: #fff !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 12px !important;
    overflow: hidden !important;
}
.hc-shop-panel:has(.is_item) #sit_pvi {
    position: relative !important;
}

/* ── 슬라이더 메인 트랙 ── */
.spv-main {
    position: relative;
    width: 100%;
    overflow: hidden;
}
.spv-slide {
    display: none;
    width: 100%;
}
.spv-slide.active {
    display: block;
}
.spv-slide .spv-img-link {
    display: block !important;
    width: 100% !important;
    line-height: 0;
}
.spv-slide .spv-img-link img {
    display: block !important;
    width: 100% !important;
    height: auto !important;
    max-width: 100% !important;
    max-height: none !important;
    object-fit: cover !important;
    border-radius: 0 !important;
    transition: transform 0.25s ease;
}
.spv-slide .spv-img-link:hover img {
    transform: scale(1.015);
}

/* ── 이전 / 다음 화살표 버튼 ── */
.spv-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    background: rgba(255,255,255,0.88);
    border: 1px solid rgba(0,0,0,0.10);
    border-radius: 50%;
    cursor: pointer;
    color: #333;
    padding: 0;
    transition: background 0.15s, box-shadow 0.15s;
    box-shadow: 0 2px 8px rgba(0,0,0,0.10);
}
.spv-btn:hover {
    background: #fff;
    box-shadow: 0 3px 12px rgba(0,0,0,0.18);
}
.spv-prev { left: 10px; }
.spv-next { right: 10px; }

/* ── 슬라이드 카운터 (우하단) ── */
.spv-counter {
    position: absolute;
    bottom: 12px;
    left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,0.45);
    color: #fff;
    font-size: 12px;
    font-weight: 500;
    padding: 3px 10px;
    border-radius: 20px;
    pointer-events: none;
    letter-spacing: 0.03em;
    z-index: 10;
}

/* ── 크게보기 (돋보기) 버튼 ── */
.spv-zoom {
    position: absolute !important;
    bottom: 12px !important;
    right: 12px !important;
    z-index: 11 !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background: rgba(255,255,255,0.80);
    border-radius: 6px;
    color: #444;
    transition: background 0.15s;
}
.spv-zoom:hover { background: #fff; }

/* ── 썸네일 스트립 ── */
.spv-thumbs {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    padding: 8px 2px 2px !important;
    margin: 0 !important;
    list-style: none !important;
    overflow-x: auto !important;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: #ccc transparent;
}
.spv-thumbs::-webkit-scrollbar { height: 4px; }
.spv-thumbs::-webkit-scrollbar-thumb { background: #ccc; border-radius: 2px; }

.spv-thumb-item {
    flex: 0 0 auto !important;
    margin: 0 !important;
}
.spv-thumb-btn {
    display: block;
    width: 68px;
    height: 68px;
    padding: 0;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    cursor: pointer;
    background: #fff;
    transition: border-color 0.15s;
}
.spv-thumb-btn img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    max-width: none !important;
    border-radius: 0 !important;
}
.spv-thumb-item.selected .spv-thumb-btn,
.spv-thumb-item:hover .spv-thumb-btn {
    border-color: #2a6040;
}

/* ── 이미지 없음 ── */
.spv-no-img img {
    display: block;
    width: 100%;
    height: auto;
}

/* ── 가격 박스 (우측 컬럼) ── */
.sit_price_box {
    background: #f9f7f4;
    border: 1px solid #e8e5e0;
    border-radius: 10px;
    padding: 18px 20px 16px;
    margin: 14px 0 18px;
}
.sit_price_state {
    font-size: 1rem;
    color: #888;
    margin: 0;
}
.sit_cust_price {
    font-size: 0.85rem;
    color: #aaa;
    margin: 0 0 2px;
}
.sit_cust_price s {
    text-decoration: line-through;
}
.sit_price_label {
    font-size: 0.8rem;
    color: #999;
    margin: 0 0 2px;
    font-weight: 500;
}
.sit_price_val {
    margin: 0 0 10px;
    line-height: 1.1;
}
.sit_price_val strong {
    font-size: 1.9rem !important;
    font-weight: 800 !important;
    color: #d62e2e !important;
    letter-spacing: -0.04em !important;
}
.sit_shipping_note {
    font-size: 0.82rem;
    color: #888;
    margin: 0;
    border-top: 1px solid #e8e5e0;
    padding-top: 10px;
}
.sit_shipping_note select {
    font-size: 0.82rem;
    padding: 2px 6px;
    border: 1px solid #d0cdc8;
    border-radius: 4px;
    background: #fff;
    color: #555;
}

/* ── 상품 정보 스펙 박스 ── */
#sit_item_spec {
    background: #fff;
    border: 1px solid #e8e8e8;
    border-radius: 12px;
    padding: 24px 28px 20px;
    margin-top: 24px;
    width: 100%;
    box-sizing: border-box;
}
.sit_spec_title {
    font-size: 0.95rem;
    font-weight: 700;
    color: #333;
    margin: 0 0 14px;
    padding-bottom: 10px;
    border-bottom: 1px solid #ebebeb;
}
.sit_spec_tbl {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.88rem;
}
.sit_spec_tbl tr + tr th,
.sit_spec_tbl tr + tr td {
    border-top: 1px solid #f2f2f2;
}
.sit_spec_tbl th {
    color: #888;
    font-weight: 500;
    padding: 8px 0;
    text-align: left;
    width: 110px;
    vertical-align: top;
    white-space: nowrap;
}
.sit_spec_tbl td {
    color: #333;
    padding: 8px 8px 8px 0;
    vertical-align: top;
    word-break: break-word;
}

/* ── 반응형 ── */
@media (max-width: 768px) {
    #sit_item_spec { padding: 18px 16px 14px; }
    .sit_price_val strong { font-size: 1.5rem !important; }
    .sit_spec_tbl th { width: 90px; }
}

/* ══════════════════════════════════════════════════════════════
   ㉒ 모바일 메인 — 히어로 배너 + 배너슬라이더 + 상품그리드 쿠팡 최적화
   ══════════════════════════════════════════════════════════════ */

/* ─── 메인 히어로 배너 (PC·모바일 공통 기초) ─── */
#main_bn {
    position: relative !important;
    overflow: hidden;
    line-height: 0;
    background: #111;
}
.main_banner_owl { width: 100%; }
.main_banner_owl .item { width: 100%; line-height: 0; }
.main_banner_owl .item img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    display: block;
    object-fit: cover;
}

/* 슬라이드 카운터 — 쿠팡 스타일 우하단 필 */
.btn_wr {
    position: absolute;
    bottom: 12px; right: 14px;
    z-index: 20;
    display: flex;
    align-items: center;
    gap: 4px;
    pointer-events: none;
}
.btn_wr .pager-prev,
.btn_wr .pager-next { display: none; }
#slide-counter {
    background: rgba(0,0,0,.48);
    color: #fff;
    font-size: 12px; font-weight: 600;
    padding: 3px 10px;
    border-radius: 20px;
    line-height: 1.5;
    letter-spacing: .5px;
}

/* 상품 타입 섹션 제목 */
.sct_wrap h2 {
    font-size: 18px; font-weight: 700; color: #111;
    padding: 20px 16px 12px;
    display: flex; align-items: center; gap: 10px;
    margin: 0;
}
.sct_wrap h2 a { color: inherit; text-decoration: none; }
.sct_wrap h2::before,
.sct_wrap h2::after {
    content: ''; flex: 1; height: 1px; background: #e5e5e5;
}

/* ─── 모바일 전용 ─── */
@media (max-width: 768px) {

    /* 히어로 배너 — 전체 폭, 인라인 min-height 무효화 */
    #main_bn {
        min-height: 0 !important;
        width: 100% !important;
    }
    .owl_pager { display: none; } /* 도트 페이저 숨김 (카운터로 대체) */

    /* 히어로 배너 이미지 — 세로로 길게 portrait (모바일) */
    .main_banner_owl .item {
        overflow: hidden !important;
    }
    .main_banner_owl .item img {
        width: 100vw !important;
        height: 150vw !important;      /* portrait: 세로 길게 */
        object-fit: cover !important;
        object-position: center top !important;
    }

    /* ── 배너 슬라이더 (#sbn_side) — 쿠팡 가로 스크롤 카드 ── */
    #sbn_side {
        background: #fff;
        padding: 0 0 20px;
        overflow: hidden;
    }
    #sbn_side h2 {
        font-size: 16px !important;
        padding: 16px 14px 10px !important;
    }
    .sb_bn {
        display: flex !important;
        flex-direction: row !important;
        overflow-x: auto !important;
        overflow-y: hidden !important;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        gap: 10px !important;
        padding: 4px 14px 8px !important;
        margin: 0 !important;
        list-style: none !important;
        scrollbar-width: none;
    }
    .sb_bn::-webkit-scrollbar { display: none; }
    .sb_bn li {
        flex-shrink: 0 !important;
        width: 72vw !important; /* 1.4개 살짝 보임 */
        scroll-snap-align: start;
        border-radius: 12px;
        overflow: hidden;
        box-shadow: 0 2px 10px rgba(0,0,0,.10);
        line-height: 0;
    }
    .sb_bn li img {
        width: 100% !important; height: auto !important;
        display: block !important;
        object-fit: cover !important;
    }

    /* ── 상품 그리드 — 2열 강제 적용 ── */
    .sct.sct_10.lists-row,
    .sct_wrap .sct.sct_10 {
        display: flex !important;
        flex-wrap: wrap !important;
        padding: 0 8px !important;
        margin: 0 !important;
        list-style: none !important;
    }
    .sct_li.col-row-5,
    .sct_li.col-row-4,
    .sct_li.col-row-3,
    .sct_li.col-row-2,
    .sct_li.col-row-1 {
        width: 50% !important;
        box-sizing: border-box !important;
        padding: 4px !important;
        float: none !important;
    }

    /* 상품 이미지 정사각형 — padding-top 100% 기법 (cross-browser) */
    .sct_10 .sct_img {
        position: relative !important;
        width: 100% !important;
        padding-top: 100% !important; /* 1:1 비율 확보 */
        overflow: hidden !important;
        border-radius: 10px !important;
        background: #f5f5f5 !important;
        display: block !important;
        height: 0 !important; /* padding-top으로 높이 제어 */
    }
    .sct_10 .sct_img > a,
    .sct_10 .sct_img > div {
        position: absolute !important;
        top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
        display: block !important;
    }
    .sct_10 .sct_img img {
        position: absolute !important;
        top: 0 !important; left: 0 !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
    }

    /* 장바구니 버튼 — 이미지 우하단 아이콘 */
    .sct_10 .sct_btn.list-10-btn {
        position: absolute !important;
        bottom: 8px; right: 8px;
        z-index: 5;
    }
    .sct_10 .list-10-btn .btn_cart {
        background: rgba(255,255,255,.92) !important;
        border: none !important;
        border-radius: 50% !important;
        width: 32px !important; height: 32px !important;
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        padding: 0 !important;
        font-size: 0 !important; /* 텍스트 숨김 */
        box-shadow: 0 1px 4px rgba(0,0,0,.18) !important;
        cursor: pointer !important;
    }
    .sct_10 .list-10-btn .btn_cart .fa {
        font-size: 14px !important;
        color: #333 !important;
    }

    /* 상품명 + 가격 */
    .sct_10 .sct_ct_wrap { padding: 8px 2px 4px !important; }
    .sct_10 .sct_txt {
        font-size: 13px !important; font-weight: 500 !important;
        color: #111 !important; line-height: 1.4 !important;
        margin: 0 0 4px !important;
        display: -webkit-box;
        -webkit-line-clamp: 2;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .sct_10 .sct_txt a { color: inherit !important; text-decoration: none !important; }
    .sct_10 .sct_cost {
        font-size: 15px !important; font-weight: 700 !important;
        color: #d62e2e !important;
    }
    .sct_10 .sct_basic { display: none !important; } /* 간단설명 숨김 */
    .sct_10 .sct_op_btn { display: none !important; } /* 위시·공유 버튼 숨김 */

    /* ── 상품 상세 — 설명 이미지 전체 폭 + 가운데 ── */
    #sit_inf_explan { padding: 0 !important; }
    #sit_inf_explan > div {
        max-width: 100% !important;
        padding: 0 !important;
        margin: 0 !important;
    }
    #sit_inf_explan img,
    #sit_inf img {
        max-width: 100% !important;
        width: 100% !important;
        height: auto !important;
        display: block !important;
        margin: 0 auto !important;
    }

    /* sct_wrap 간격 */
    .sct_wrap { margin-bottom: 20px; }
    .sct_wrap h2 { font-size: 15px !important; padding: 14px 12px 8px !important; }
}

/* ══════════════════════════════════════════════════════════════
   ㉑ 모바일 상품 상세 — 슬라이더 정사각형 + 쿠팡 스타일 최적화
   ══════════════════════════════════════════════════════════════ */

/* ─── 슬라이더 공통 (모바일·데스크톱 공통 기초) ─── */
#sit_pvi_big {
    position: relative;
    display: block;
    overflow: hidden;
    padding: 0 !important;
    border-radius: 0;
    background: #f8f8f8;
}
.spv-main {
    width: 100%;
    overflow: hidden;
}
.spv-slide { display: none; }
.spv-slide.active { display: block; }
.spv-slide .spv-img-link {
    display: block !important;
    width: 100% !important;
    line-height: 0;
}
.spv-slide .spv-img-link img {
    display: block;
    width: 100% !important;
    height: 100%;
    object-fit: cover !important;
}
/* 화살표 버튼 */
.spv-btn {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 36px; height: 36px;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.88);
    border: none; border-radius: 50%;
    box-shadow: 0 2px 8px rgba(0,0,0,.18);
    cursor: pointer; padding: 0;
}
.spv-prev { left: 10px; }
.spv-next { right: 10px; }
.spv-btn svg { width: 16px; height: 16px; }
/* 카운터 */
.spv-counter {
    position: absolute;
    bottom: 10px; left: 50%;
    transform: translateX(-50%);
    background: rgba(0,0,0,.45);
    color: #fff;
    font-size: 12px; line-height: 1;
    padding: 4px 10px;
    border-radius: 20px;
    white-space: nowrap;
    z-index: 10;
}
/* 줌 버튼 */
.spv-zoom {
    position: absolute;
    bottom: 10px; right: 10px;
    width: 34px; height: 34px;
    background: rgba(255,255,255,.88);
    border: none; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; z-index: 10;
    box-shadow: 0 2px 6px rgba(0,0,0,.15);
    text-decoration: none;
}
.spv-zoom svg { width: 18px; height: 18px; }
/* 썸네일 스트립 */
.spv-thumbs {
    display: flex;
    overflow-x: auto;
    gap: 6px;
    padding: 8px 4px;
    list-style: none;
    margin: 0;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.spv-thumbs::-webkit-scrollbar { display: none; }
.spv-thumb-btn {
    display: block;
    width: 60px; height: 60px;
    border: 2px solid #e0e0e0;
    border-radius: 8px;
    overflow: hidden;
    padding: 0; background: #fff;
    cursor: pointer; flex-shrink: 0;
}
.spv-thumb-btn.active { border-color: #2a6040; }
.spv-thumb-btn img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ─── 모바일 전용: 이미지 정사각형 고정 ─── */
@media (max-width: 768px) {

    /* 슬라이드 이미지를 1:1 정사각형으로 */
    #sit_pvi_big {
        aspect-ratio: 1 / 1 !important;
        width: 100% !important;
        border-radius: 0 !important;
    }
    .spv-main {
        height: 100% !important;
    }
    .spv-slide {
        height: 100% !important;
    }
    .spv-slide .spv-img-link {
        height: 100% !important;
    }
    .spv-slide .spv-img-link img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }

    /* 기존 it_img 방식 이미지도 정사각형 */
    #sit_pvi_big > a > img,
    #sit_pvi_big img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
    }

    /* 썸네일 버튼 모바일에서 약간 작게 */
    .spv-thumb-btn { width: 52px; height: 52px; }

    /* ── 쿠팡 스타일 모바일 쇼핑몰 전체 최적화 ── */

    /* 전체 기본 폰트 크기 */
    body { font-size: 15px !important; }

    /* 상품 목록 카드 — 텍스트 크게 */
    .sct_10 .sct_txt,
    .hc-shop-page .sct_txt {
        font-size: 14px !important;
        font-weight: 600 !important;
        line-height: 1.45 !important;
        color: #111 !important;
    }
    .sct_10 .sct_cost,
    .hc-shop-page .sct_cost {
        font-size: 16px !important;
        font-weight: 800 !important;
        color: #d62e2e !important;
    }
    .sct_10 .sct_cart,
    .hc-shop-page .sct_cart {
        font-size: 14px !important;
        padding: 12px 0 !important;
        font-weight: 700 !important;
        border-radius: 8px !important;
        margin-top: 6px !important;
    }
    /* 상품 이미지 */
    .sct_10 .sct_img,
    .hc-shop-page .sct_img {
        border-radius: 10px !important;
        height: 0 !important;
        padding-bottom: 56.25% !important;
        overflow: hidden !important;
        position: relative !important;
    }
    .sct_10 .sct_img img,
    .hc-shop-page .sct_img img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
    }

    /* 상품 목록 그리드 2열 확실히 */
    .sct_wrap .sct_ul,
    .hc-shop-page .sct_ul {
        display: flex !important;
        flex-wrap: wrap !important;
        gap: 10px 8px !important;
        padding: 4px 8px !important;
    }
    .sct_wrap .sct_ul .sct_li,
    .hc-shop-page .sct_ul .sct_li {
        width: calc(50% - 4px) !important;
        box-sizing: border-box !important;
    }

    /* 상품 상세 페이지 제목·가격 크게 */
    #sit_title,
    .hc-shop-page #sit_title {
        font-size: 1.25rem !important;
        font-weight: 700 !important;
        line-height: 1.4 !important;
    }
    .sit_price_val strong {
        font-size: 1.8rem !important;
        font-weight: 800 !important;
        color: #d62e2e !important;
    }

    /* 구매 버튼 크게 */
    #btn_sit_order,
    .sit_order_btn,
    input[type=button].btn_order,
    .hc-shop-page .btn_order {
        height: 54px !important;
        font-size: 17px !important;
        font-weight: 700 !important;
        border-radius: 10px !important;
        letter-spacing: -0.3px !important;
    }
    /* 장바구니 버튼 */
    #btn_sit_cart,
    .sit_cart_btn,
    input[type=button].btn_cart {
        height: 54px !important;
        font-size: 16px !important;
        font-weight: 600 !important;
        border-radius: 10px !important;
    }

    /* 옵션 드롭다운 터치 친화적 */
    #sit_opt select,
    #sit_opt .sod_select {
        height: 48px !important;
        font-size: 15px !important;
        border-radius: 8px !important;
        padding: 0 14px !important;
    }

    /* 탭 메뉴 (상세설명 / 리뷰 등) */
    #sit_tab_menu li a,
    #sit_tab_menu li span {
        font-size: 14px !important;
        padding: 14px 10px !important;
        font-weight: 600 !important;
    }

    /* 카테고리 탭 */
    .sanchor li {
        font-size: 13px !important;
    }
    .sanchor a {
        padding: 10px 4px !important;
        font-weight: 600 !important;
    }

    /* 상품 상세 정보 영역 */
    #sit_inf {
        font-size: 15px !important;
        line-height: 1.7 !important;
    }
    #sit_inf img {
        max-width: 100% !important;
        height: auto !important;
    }

    /* 수량 선택 버튼 크게 */
    .qty_wrap,
    #sit_qty {
        height: 44px !important;
    }
    .qty_wrap input,
    #sit_qty input {
        font-size: 16px !important;
        height: 44px !important;
        min-width: 44px !important;
    }
    .qty_wrap button,
    #sit_qty button,
    .qty_wrap .btn_qty {
        width: 44px !important;
        height: 44px !important;
        font-size: 20px !important;
    }

    /* 스펙 박스 */
    #sit_item_spec {
        padding: 16px 14px 12px !important;
        border-radius: 10px !important;
    }
    .sit_spec_tbl th,
    .sit_spec_tbl td {
        font-size: 13px !important;
        padding: 9px 4px !important;
    }

    /* 가격 박스 */
    .sit_price_box {
        padding: 16px !important;
        border-radius: 12px !important;
    }

    /* 배송 안내 */
    .sit_shipping_note {
        font-size: 13px !important;
        padding: 12px 14px !important;
        border-radius: 8px !important;
    }
}

/* ══════════════════════════════════════════════════════════════
   ㉓ 모바일 헤더 강제 적용 — 햄버거 확실히 표시
   (viewport 메타 없이도 동작하도록 !important 강화)
   ══════════════════════════════════════════════════════════════ */

/* 모바일 헤더 #mhd (mobile/shop/shop.head.php) */
#mhd {
    display: flex !important;
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important;
    z-index: 9000 !important;
    height: 56px !important;
    background: #fff !important;
    border-bottom: 1px solid #eee !important;
    align-items: center !important;
    padding: 0 12px !important;
    gap: 8px !important;
}
#mhd_hamburger {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    flex-shrink: 0 !important;
    background: none !important;
    border: none !important;
    padding: 6px !important;
    cursor: pointer !important;
    font-size: 22px !important;
    color: #333 !important;
    line-height: 1 !important;
    align-items: center !important;
    justify-content: center !important;
}
#mhd_logo {
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 7px !important;
    text-decoration: none !important;
}
#mhd_logo img { height: 32px !important; width: auto !important; }
#mhd_search_form {
    flex: 1 !important;
    min-width: 0 !important;
    display: flex !important;
    align-items: center !important;
    border: 1px solid #ddd !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    background: #f7f7f7 !important;
    height: 36px !important;
}
#mhd_cart {
    flex-shrink: 0 !important;
    display: flex !important;
    font-size: 22px !important;
    text-decoration: none !important;
    color: #333 !important;
    padding: 4px !important;
}

/* 모바일 body 여백 (모바일 테마: 56px 헤더) */
@media (max-width: 768px) {
    /* #mhd 가 있을 때만 body padding 조정 (모바일 테마) */
    body:has(#mhd) { padding-top: 56px !important; }
}

/* ── 배너 슬라이더 점 인디케이터 ── */
.sbn-dots {
    display: flex;
    justify-content: center;
    gap: 6px;
    margin-top: 10px;
    padding: 2px 14px 8px;
}
.sbn-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: #ccc;
    transition: background .3s, width .3s;
    cursor: pointer;
    border: none;
    padding: 0;
    flex-shrink: 0;
}
.sbn-dot.active {
    background: #1a3a2a !important;
    width: 20px !important;
    border-radius: 4px !important;
}

/* ── 모바일: 제품 카테고리 칩 배너 링크 숨김 ── */
@media (max-width: 768px) {
    .hc-shop-hero__chips { display: none !important; }
}

/* ══════════════════════════════════════════════════════
   [수정] 1. 검색/스토어홈 박스 제거 후 wrapper 상단 여백
   ══════════════════════════════════════════════════════ */
.hc-shop-wrapper {
    margin-top: 20px !important;
}

/* ══════════════════════════════════════════════════════
   [수정] 2. 정렬 버튼(판매많은순/낮은가격순 등) 작게
   ══════════════════════════════════════════════════════ */
#sct_sort h2 { position: absolute; font-size: 0; overflow: hidden; }
#sct_sortlst { border: 1px solid #e8e8e8; border-radius: 8px; padding: 8px 12px; background: #fafafa; }
#ssch_sort { display: flex !important; flex-wrap: wrap !important; gap: 4px !important; padding: 0 !important; margin: 0 !important; list-style: none !important; }
#ssch_sort li { float: none !important; height: auto !important; padding: 0 !important; margin: 0 !important; }
#ssch_sort li a {
    display: inline-block !important;
    border: 1px solid #ddd !important;
    border-left: 1px solid #ddd !important;
    border-radius: 4px !important;
    padding: 4px 8px !important;
    font-size: 11px !important;
    line-height: 1.4 !important;
    color: #555 !important;
    text-decoration: none !important;
    background: #fff !important;
    white-space: nowrap !important;
}
#ssch_sort li a:hover { background: #1a3a2a !important; color: #fff !important; border-color: #1a3a2a !important; }
@media (max-width: 768px) {
    #ssch_sort { gap: 3px !important; }
    #ssch_sort li a { font-size: 10px !important; padding: 3px 6px !important; }
}

/* ══════════════════════════════════════════════════════
   [수정] 3. 썸네일 이중 표시 수정 (flex-wrap 충돌 해결)
   ══════════════════════════════════════════════════════ */
#sit_pvi_thumb,
.spv-thumbs {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    overflow-x: auto !important;
    padding: 8px 2px 4px !important;
    margin: 0 !important;
    list-style: none !important;
    scrollbar-width: none !important;
}
#sit_pvi_thumb::-webkit-scrollbar,
.spv-thumbs::-webkit-scrollbar { display: none !important; }
/* 하위 호환: 이전 .hc-shop-panel:has 규칙 무력화 */
.hc-shop-panel:has(.is_item) #sit_pvi_thumb {
    flex-wrap: nowrap !important;
    margin-top: 8px !important;
}

/* ══════════════════════════════════════════════════════
   [수정] 4. 사용후기/상품문의/배송교환 탭 한 줄
   ══════════════════════════════════════════════════════ */
.hc-shop-page .tab_tit,
#sit_tab .tab_tit {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
    -webkit-overflow-scrolling: touch !important;
}
.hc-shop-page .tab_tit::-webkit-scrollbar { display: none !important; }
.hc-shop-page .tab_tit li { width: auto !important; flex-shrink: 0 !important; }
.hc-shop-page .tab_tit li button {
    padding: 9px 12px !important;
    font-size: 0.82rem !important;
    white-space: nowrap !important;
    width: auto !important;
}
@media (max-width: 575px) {
    .hc-shop-page .tab_tit { flex-wrap: nowrap !important; gap: 4px !important; }
    .hc-shop-page .tab_tit li button { padding: 7px 9px !important; font-size: 0.75rem !important; }
}

/* ═══════════════════════════════════════════════════════════════
   [수정] 1. 모바일 카테고리 위치(sct_location) + 설명 텍스트 겹침 해결
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 768px) {
    #sct_location {
        position: relative !important;
        top: 0 !important;
        right: 0 !important;
        float: none !important;
        display: block !important;
        width: 100% !important;
        padding: 8px 4px !important;
        font-size: 12px !important;
    }
    #sct_hhtml {
        clear: both !important;
        padding: 4px 4px 6px !important;
        font-size: 12px !important;
    }
    #sct_hhtml p { margin: 0 0 2px !important; }
    #sct_sortlst {
        position: relative !important;
        clear: both !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   [수정] 2. 정렬박스 한 줄 컴팩트 (텍스트+아이콘 같은 줄)
   ═══════════════════════════════════════════════════════════════ */
#sct_sortlst {
    display: flex !important;
    align-items: center !important;
    flex-wrap: wrap !important;
    gap: 0 !important;
    padding: 6px 10px !important;
    min-height: 0 !important;
    border: 1px solid #e8e8e8 !important;
    border-radius: 6px !important;
    background: #fafafa !important;
}
#sct_sort {
    float: none !important;
    flex: 1 1 auto !important;
    width: auto !important;
    display: flex !important;
    align-items: center !important;
}
#sct_sort ul,
#ssch_sort {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 3px !important;
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
    align-items: center !important;
}
#sct_sort li,
#ssch_sort li {
    float: none !important;
    height: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
}
#sct_sort li a,
#ssch_sort li a {
    display: inline-block !important;
    padding: 4px 8px !important;
    font-size: 11px !important;
    line-height: 1.3 !important;
    border: 1px solid #ddd !important;
    border-radius: 4px !important;
    background: #fff !important;
    color: #555 !important;
    white-space: nowrap !important;
    text-decoration: none !important;
}
#sct_sort li a:hover,
#ssch_sort li a:hover { background: #1a3a2a !important; color: #fff !important; border-color: #1a3a2a !important; }
#sct_lst {
    float: none !important;
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
}
#sct_lst li { float: none !important; }
#sct_lst button { width: 32px !important; height: 32px !important; }

/* ═══════════════════════════════════════════════════════════════
   [수정] 3. 썸네일 스트립 겹침 완전 해결 (float 제거 + nowrap 강제)
   ═══════════════════════════════════════════════════════════════ */
/* 기본 float 제거 */
#sit_pvi_big { float: none !important; }
#sit_pvi_thumb { float: none !important; }

/* 썸네일 flex nowrap 최고 우선순위 */
.hc-shop-panel:has(.is_item) #sit_pvi_thumb,
.hc-shop-panel:has(.is_item) #sit_pvi_thumb.spv-thumbs,
#sit_pvi_thumb,
#sit_pvi_thumb.spv-thumbs {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    gap: 6px !important;
    padding: 8px 0 4px !important;
    margin: 0 !important;
    list-style: none !important;
    scrollbar-width: none !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
#sit_pvi_thumb::-webkit-scrollbar,
#sit_pvi_thumb.spv-thumbs::-webkit-scrollbar { display: none !important; }

/* 기존 .spv-thumbs 규칙에서 wrap 방지 재선언 */
.spv-thumbs {
    flex-wrap: nowrap !important;
}

/* ═══════════════════════════════════════════════════════════════
   [수정] 4. 로그인 후 고정 헤더 공간 (body padding-top 복원용)
   ═══════════════════════════════════════════════════════════════ */
body.login-page { padding-top: 60px !important; }

/* ═══════════════════════════════════════════════════════════════
   정렬 박스 완전 숨김 (PC · 모바일 공통)
   ═══════════════════════════════════════════════════════════════ */
#sct_sortlst { display: none !important; }

/* ═══════════════════════════════════════════════════════════════
   썸네일 겹침 완전 수정
   — 원인: 기본 skin/shop/basic/style.css 의
           #sit_pvi {float:left} 가 덮어써지지 않아
           썸네일 컨테이너가 float 된 상태로 남아 겹침 발생
   ═══════════════════════════════════════════════════════════════ */

/* 1. #sit_pvi 컨테이너 float 완전 제거 */
#sit_pvi {
    float: none !important;
    width: 100% !important;
    display: block !important;
    overflow: visible !important;
}

/* 2. 썸네일 li 아이템 — position static 강제 (float 잔재 제거) */
#sit_pvi_thumb > li,
ul#sit_pvi_thumb > li {
    position: static !important;
    float: none !important;
    display: block !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    width: auto !important;
    height: auto !important;
}

/* 3. 썸네일 버튼 크기·overflow 통일 (중복 선언 최종 해결) */
#sit_pvi_thumb .spv-thumb-btn {
    width: 64px !important;
    height: 64px !important;
    overflow: hidden !important;
    display: block !important;
    padding: 0 !important;
    border: 2px solid #e0e0e0 !important;
    border-radius: 8px !important;
    background: none !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
    flex-shrink: 0 !important;
}
#sit_pvi_thumb .spv-thumb-item.selected .spv-thumb-btn,
#sit_pvi_thumb .spv-thumb-item:hover .spv-thumb-btn {
    border-color: #2a6040 !important;
}

/* 4. 썸네일 내부 이미지 버튼 크기에 맞춤 */
#sit_pvi_thumb li .spv-thumb-btn img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block !important;
    max-width: none !important;
    border: none !important;
    border-radius: 0 !important;
}

/* ====================================================
   상품 상세설명(it_explan) - HTMLPurifier 우회 스타일
   ==================================================== */
/* 상세 이미지 전체폭 */
.sit_explan img {
    width: 100% !important;
    display: block !important;
    max-width: 100% !important;
    height: auto !important;
}

/* YouTube 전체폭 16:9 래퍼 */
.hc-yt-wrap {
    position: relative !important;
    width: 100% !important;
    max-width: 860px !important;
    margin: 20px auto !important;
    padding-bottom: 56.25% !important;
    height: 0 !important;
    overflow: hidden !important;
    border-radius: 10px !important;
}
.hc-yt-wrap iframe {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    border: 0 !important;
}

/* ====================================================
   메인페이지 인기상품 썸네일 16:9 비율
   ==================================================== */
.main_list_style_1 .hc-prod-thumb-wrap {
    position: relative !important;
    width: 100% !important;
    padding-bottom: 56.25% !important;
    height: 0 !important;
    overflow: hidden !important;
    background: #f0ede8 !important;
    border-radius: 8px !important;
}
.main_list_style_1 .hc-prod-thumb-wrap a {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    display: block !important;
}
.main_list_style_1 .hc-prod-thumb-wrap img {
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}

/* ====================================================
   메인페이지 — 배너·제목·인기상품 공통 레이아웃
   ==================================================== */

/* 히어로 슬라이더 래퍼 */
.main_slide_img { width: 100%; overflow: hidden; }

/* 3열 배너 — 데스크탑 */
.main_banner_set {
    padding: 0 20px 24px;
    max-width: 1400px;
    margin: 0 auto;
}
.main_banner_set ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 16px;
}
.main_banner_set li {
    flex: 1;
    overflow: hidden;
    border-radius: 10px;
}
.main_banner_set a {
    display: block;
    overflow: hidden;
    position: relative;
    border-radius: 10px;
}
.main_banner_set a img {
    width: 100%;
    height: auto;
    object-fit: cover;
    display: block;
    border-radius: 10px;
    transition: transform 0.3s ease, opacity 0.3s ease;
}
.main_banner_set a:hover img {
    opacity: .88;
    transform: scale(1.03);
}
.main_banner_set .bn-caption {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 12px 14px;
    background: rgba(0, 0, 0, 0.42);
    color: #fff;
    border-radius: 0 0 10px 10px;
}
.main_banner_set .bn-caption strong {
    display: block;
    font-size: 1rem;
    font-weight: 700;
    color: #fff;
}
.main_banner_set .bn-caption span {
    display: block;
    font-size: 0.8rem;
    color: rgba(255, 255, 255, 0.82);
    margin-top: 2px;
}

/* 섹션 제목 */
.main_disp_title {
    text-align: center;
    padding: 40px 20px 24px;
    max-width: 1400px;
    margin: 0 auto;
}
.main_disp_title h2 {
    font-size: 1.6rem;
    font-weight: 800;
    color: #1a3a2a;
    margin: 0 0 8px;
}
.main_disp_title h2 span {
    display: inline-block;
    border-bottom: 3px solid #2a6040;
    padding-bottom: 4px;
}
.main_disp_title p {
    font-size: 0.95rem;
    color: #888;
    margin: 0;
}

/* 인기상품 그리드 — 데스크탑 4열 */
.main_disp {
    padding: 0 20px 40px;
    max-width: 1400px;
    margin: 0 auto;
}
.main_list_style_1.product_list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}
.main_list_style_1 .colm4 {
    flex: 0 0 calc(25% - 15px);
    width: calc(25% - 15px);
    min-width: 0;
}
.main_list_style_1 ul.description {
    list-style: none;
    padding: 8px 0 0;
    margin: 0;
}
.main_list_style_1 .description .name a {
    font-size: 0.9rem;
    color: #1a3a2a;
    text-decoration: none;
    font-weight: 600;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    line-height: 1.4;
}
.main_list_style_1 .description .price {
    margin-top: 4px;
}
.main_list_style_1 .description .price strong {
    font-size: 0.95rem;
    color: #2a6040;
    font-weight: 800;
}

/* ====================================================
   메인페이지 모바일 — 배너 3열 고정 레이아웃
   (sticky 해제 → 정상 스크롤, 고정 높이, 반응형 텍스트)
   ==================================================== */
@media (max-width: 768px) {
    /* 배너 컨테이너 — 문서 흐름 복귀, 컴팩트 패딩 */
    .main_banner_set {
        position: relative !important;
        top: auto !important;
        z-index: auto !important;
        background: #f5f2eb !important;
        padding: 8px 10px !important;
        margin: 0 !important;
        box-shadow: none !important;
    }
    /* 3열 가로 나열 */
    .main_banner_set ul {
        display: flex !important;
        flex-wrap: nowrap !important;
        gap: 4px !important;
        margin: 0 !important;
        padding: 0 !important;
    }
    .main_banner_set li {
        flex: 1 1 0 !important;
        min-width: 0 !important;
        border-radius: 6px !important;
        overflow: hidden !important;
    }
    /* 링크에 고정 높이 — 이미지 스트레칭 방지 */
    .main_banner_set a {
        display: block !important;
        position: relative !important;
        height: 88px !important;
        border-radius: 6px !important;
        overflow: hidden !important;
    }
    /* 이미지: 절대 배치로 박스를 꽉 채움 */
    .main_banner_set a img {
        position: absolute !important;
        inset: 0 !important;
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        aspect-ratio: unset !important;
        border-radius: 6px !important;
    }
    /* 캡션 오버레이 */
    .main_banner_set .bn-caption {
        position: absolute !important;
        bottom: 0 !important;
        left: 0 !important;
        right: 0 !important;
        padding: 4px 5px 5px !important;
        background: rgba(0, 0, 0, 0.50) !important;
        border-radius: 0 0 6px 6px !important;
    }
    /* 제목 — clamp() 로 화면 폭에 맞게 자동 축소 */
    .main_banner_set .bn-caption strong {
        display: block !important;
        font-size: clamp(8px, 2.6vw, 12px) !important;
        line-height: 1.3 !important;
        color: #fff !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
    }
    /* 부제목 */
    .main_banner_set .bn-caption span {
        display: block !important;
        font-size: clamp(7px, 2.0vw, 10px) !important;
        line-height: 1.2 !important;
        color: rgba(255, 255, 255, 0.88) !important;
        white-space: nowrap !important;
        overflow: hidden !important;
        text-overflow: ellipsis !important;
        margin-top: 1px !important;
    }

    /* 섹션 제목 모바일 */
    .main_disp_title {
        padding: 24px 16px 14px !important;
    }
    .main_disp_title h2 {
        font-size: 1.25rem !important;
    }

    /* 인기상품 그리드 모바일 — 2열 */
    .main_disp {
        padding: 0 12px 28px !important;
    }
    .main_list_style_1.product_list {
        gap: 12px !important;
    }
    .main_list_style_1 .colm4 {
        flex: 0 0 calc(50% - 6px) !important;
        width: calc(50% - 6px) !important;
    }
}


/* ═══════════════════════════════════════════════════════════════
   프리미엄 상세페이지 레이아웃 보호
   style.css #sit_inf_explan img{height:auto} 오버라이드 방지
   specificity: ID(100)+class(10) = 110 > ID(100)+element(1) = 101
   ═══════════════════════════════════════════════════════════════ */

/* 히어로 이미지 고정 높이 */
#sit_inf_explan .hi,
#sit_inf_explan .hi.hc-hero        { height: 300px !important; object-fit: cover !important; width: 100% !important; }

/* 스플릿 레이아웃 이미지 */
#sit_inf_explan .ig-split-img img  { height: 260px !important; object-fit: cover !important; }

/* 배너 이미지 */
#sit_inf_explan .ig-banner-img     { height: 200px !important; object-fit: cover !important; width: 100% !important; }

/* hcd 컨테이너 — 모바일에서 full-width, 데스크톱에서 max 600px */
#sit_inf_explan .hcd               { max-width: 600px; margin: 0 auto; }

/* 갤러리 그리드 이미지 — 비율 유지 */
#sit_inf_explan .gl-item img       { height: 160px !important; object-fit: cover !important; }

/* 효과 카드 내 아이콘 이미지 */
#sit_inf_explan .ec-icon           { height: auto !important; max-height: 48px !important; width: auto !important; }

@media (max-width: 768px) {
    /* 모바일: hcd 전폭 */
    #sit_inf_explan .hcd           { max-width: 100% !important; }
    /* 히어로 이미지 모바일 축소 */
    #sit_inf_explan .hi,
    #sit_inf_explan .hi.hc-hero    { height: 220px !important; }
    /* 스플릿 이미지 모바일 */
    #sit_inf_explan .ig-split-img img { height: 180px !important; }
}
