@charset "utf-8";

/* ================================
   Miracle Shop Layout
   file: /theme/miracleeat/css/shop-layout.css
================================ */

:root{
    --me-beige:#e8ddcf;
    --me-beige-soft:#f3ede3;
    --me-green:#29443a;
    --me-green-dark:#1f342d;
    --me-white:#f8f5ef;
    --me-text:#2f2a26;
    --me-text-sub:#6a625a;
    --me-line:#d8cab8;
    --me-shadow:0 12px 30px rgba(41,68,58,.08);
    --me-shadow-soft:0 8px 24px rgba(41,68,58,.04);
    --me-radius:20px;
    --me-container:1280px;
}

/* ================================
   Base
================================ */
#me-shop-wrap,
#me-shop-wrap *{
    box-sizing:border-box;
}

#me-shop-wrap{
    min-height:100vh;
    background:var(--me-white);
    color:var(--me-text);
    line-height:1.7;
    letter-spacing:-0.02em;
    word-break:keep-all;
}

#me-shop-wrap a{
    color:inherit;
    text-decoration:none;
}

#me-shop-wrap img{
    max-width:100%;
    display:block;
}

.me-shop-container{
    width:100%;
    max-width:calc(var(--me-container) + 40px);
    margin:0 auto;
    padding:0 20px;
}

/* 접근성 */
#me-shop-wrap a:focus,
#me-shop-wrap button:focus,
#me-shop-wrap input:focus,
#me-shop-wrap select:focus,
#me-shop-wrap textarea:focus{
    outline:2px solid rgba(41,68,58,.25);
    outline-offset:2px;
}

/* ================================
   Header
================================ */
#me-shop-header{
    position:sticky;
    top:0;
    z-index:999;
    background:rgba(248,245,239,.95);
    backdrop-filter:blur(10px);
    border-bottom:1px solid rgba(216,202,184,.8);
}

#me-shop-header .me-shop-header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding: 16px 0;
    min-height: 88px;
}

.me-shop-logo{
    flex:0 0 auto;
    margin:0;
    font-size:0;
    line-height:1;
}

.me-shop-logo a{
    display:inline-block;
    font-size:28px;
    font-weight:700;
    color:var(--me-green);
    letter-spacing:-0.05em;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

/* 브랜드 영역 */
.me-brand {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 2px; /* 기존 4px → 줄임 */
    min-width: 260px;
}

.me-brand a {
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    gap:0;
}

.me-brand-eyebrow {
    font-size: 11px;
    letter-spacing: .18em;
    color: var(--me-text-sub);
    text-transform: uppercase;
    line-height: 1.1; /* ↓ 줄임 */
}

.me-brand-title {
    font-size: 24px;
    font-weight: 800;
    letter-spacing: -0.04em;
    line-height: 1.15; /* 핵심 ↓ */
    color: var(--me-green);
    margin: 2px 0; /* 위아래 여백 최소화 */
}

.me-brand-desc {
    font-size: 12px;
    line-height: 1.3; /* 기존 1.45 → 타이트하게 */
    color: var(--me-text-sub);
}

.me-shop-nav{
    display:flex;
    align-items:center;
    gap:30px;
    flex:1 1 auto;
    justify-content:center;
}

.me-shop-nav a{
    position:relative;
    display:inline-block;
    padding:4px 0;
    font-size:15px;
    color:var(--me-text);
    transition:color .2s ease;
}

.me-shop-nav a:after{
    content:"";
    position:absolute;
    left:0;
    bottom:0;
    width:0;
    height:1px;
    background:var(--me-green);
    transition:width .25s ease;
}

.me-shop-nav a:hover{
    color:var(--me-green);
}

.me-shop-nav a:hover:after{
    width:100%;
}

.me-shop-util{
    display:flex;
    align-items:center;
    gap:12px;
    flex:0 0 auto;
}

/* util 버튼 공통 */
.me-shop-util a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:110px;
    height:48px;
    padding:0 22px;
    border-radius:999px;
    font-size:15px;
    font-weight:700;
    letter-spacing:-0.02em;
    text-decoration:none;
    transition:all .25s ease;
}

/* 기본 버튼 */
.me-shop-util .outline{
    border:1px solid rgba(41,68,58,.20);
    background:#fcfbf8;
    color:var(--me-text);
}

.me-shop-util .outline:hover{
    border-color:var(--me-green);
    background:#ffffff;
    color:var(--me-green);
    transform:translateY(-1px);
}

/* 장바구니 버튼 */
.me-shop-util .solid{
    border:1px solid #29443a;
    background:linear-gradient(135deg, #35584b 0%, #29443a 52%, #213730 100%);
    color:#ffffff !important;
    box-shadow:0 10px 20px rgba(41,68,58,.18);
}

.me-shop-util .solid:hover{
    transform:translateY(-2px);
    background:linear-gradient(135deg, #365a4d 0%, #2e4c41 50%, #223932 100%);
    color:#ffffff;
    box-shadow:0 14px 26px rgba(41,68,58,.24);
}

.me-shop-util .solid:active{
    transform:translateY(0);
    box-shadow:0 6px 12px rgba(41,68,58,.18);
}

.me-shop-menu-btn{
    display:none;
    width:44px;
    height:44px;
    padding:0;
    border:0;
    background:none;
    cursor:pointer;
    border-radius:10px;
    position:relative;
}

.me-shop-menu-btn span{
    position:absolute;
    left:10px;
    width:24px;
    height:2px;
    background:var(--me-green);
    transition:all .25s ease;
}

.me-shop-menu-btn span:nth-child(1){ top:14px; }
.me-shop-menu-btn span:nth-child(2){ top:21px; }
.me-shop-menu-btn span:nth-child(3){ top:28px; }

.me-shop-menu-btn.is-open span:nth-child(1){
    transform:rotate(45deg);
    top:21px;
}

.me-shop-menu-btn.is-open span:nth-child(2){
    opacity:0;
}

.me-shop-menu-btn.is-open span:nth-child(3){
    transform:rotate(-45deg);
    top:21px;
}

#me-shop-mobile{
    display:none;
    border-top:1px solid rgba(216,202,184,.7);
    background:#fbf8f2;
}

#me-shop-mobile .inner{
    padding:14px 20px 20px;
}

#me-shop-mobile nav,
#me-shop-mobile .util{
    display:flex;
    flex-direction:column;
    gap:8px;
}

#me-shop-mobile nav{
    padding-bottom:14px;
    margin-bottom:14px;
    border-bottom:1px solid rgba(216,202,184,.8);
}

#me-shop-mobile a{
    display:block;
    padding:10px 4px;
    font-size:15px;
    color:var(--me-text);
}

#me-shop-mobile .util a{
    border:1px solid rgba(41,68,58,.12);
    border-radius:12px;
    background:#fff;
    padding:12px 14px;
}

/* ================================
   Page Visual
================================ */
#me-shop-visual{
    background:linear-gradient(180deg, #f6f1e8 0%, #f8f5ef 100%);
    border-bottom:1px solid rgba(216,202,184,.45);
}

#me-shop-visual .inner{
    padding:42px 0 38px;
}

#me-shop-visual .eyebrow{
    display:inline-block;
    margin-bottom:10px;
    font-size:12px;
    font-weight:700;
    letter-spacing:.14em;
    color:var(--me-green);
    text-transform:uppercase;
}

#me-shop-visual h2{
    margin:0;
    font-size:38px;
    line-height:1.25;
    font-weight:700;
    letter-spacing:-0.04em;
    color:var(--me-text);
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

#me-shop-visual p{
    margin:12px 0 0;
    font-size:16px;
    color:var(--me-text-sub);
}

/* ================================
   Content Area
================================ */
#me-shop-main{
    min-height:500px;
    padding:42px 0 70px;
}

/* 기본 라운드 */
#me-shop-main .local_ov,
#me-shop-main .local_desc,
#me-shop-main .btn_confirm,
#me-shop-main .tbl_head01,
#me-shop-main .tbl_frm01,
#me-shop-main .sct_wrap,
#me-shop-main .sct,
#me-shop-main .sit,
#me-shop-main .cart_list,
#me-shop-main .od_prd_list,
#me-shop-main .wishlist,
#me-shop-main .shop-list-item,
#me-shop-main .shop-box{
    border-radius:16px;
}

/* ================================
   Footer
================================ */
#me-shop-footer{
    background:var(--me-beige-soft);
    border-top:1px solid rgba(216,202,184,.75);
}

#me-shop-footer .me-shop-footer-inner{
    padding:56px 0;
}

#me-shop-footer .top{
    display:flex;
    align-items:flex-start;
    justify-content:space-between;
    gap:30px;
    margin-bottom:22px;
}

#me-shop-footer .logo{
    font-size:24px;
    line-height:1.2;
    font-weight:700;
    color:var(--me-green);
    letter-spacing:-0.04em;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

#me-shop-footer .links{
    display:flex;
    flex-wrap:wrap;
    gap:18px;
}

#me-shop-footer .links a{
    font-size:14px;
    color:var(--me-text-sub);
}

#me-shop-footer .links a:hover{
    color:var(--me-green);
}

#me-shop-footer .info{
    font-size:14px;
    color:var(--me-text-sub);
}

#me-shop-footer .info p{
    margin:0 0 6px;
}

#me-shop-footer .info p:last-child{
    margin-bottom:0;
}

/* ==================================================
   YoungCart Extended Style
================================================== */

/* 공통 박스 / 제목 */
#me-shop-main .pg_wrap,
#me-shop-main .sct_wrap,
#me-shop-main .sit_wrap,
#me-shop-main .cart_wrap,
#me-shop-main .order_wrap,
#me-shop-main .od_inq_wrap,
#me-shop-main .wishlist_wrap,
#me-shop-main .personalpay_wrap{
    margin-bottom:28px;
}

#me-shop-main .pg_tit,
#me-shop-main .sct_ct h2,
#me-shop-main .sit_ovr h2,
#me-shop-main .cart_title,
#me-shop-main .od_tit,
#me-shop-main .wishlist_title{
    color:var(--me-text);
    letter-spacing:-0.03em;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

/* ================================
   상품 목록
================================ */
#me-shop-main .sct_wrap{
    margin-top:10px;
}

#me-shop-main .sct_wrap ul,
#me-shop-main .sct ul,
#me-shop-main ul.sct{
    list-style:none;
    margin:0;
    padding:0;
}

#me-shop-main .sct_li,
#me-shop-main .sct > li,
#me-shop-main .sct_li_wr{
    border:1px solid rgba(216,202,184,.78);
    border-radius:24px;
    background:#fff;
    overflow:hidden;
    box-shadow:0 8px 24px rgba(41,68,58,.05);
    transition:transform .25s ease, box-shadow .25s ease;
}

#me-shop-main .sct_li:hover,
#me-shop-main .sct > li:hover,
#me-shop-main .sct_li_wr:hover{
    transform:translateY(-4px);
    box-shadow:0 14px 34px rgba(41,68,58,.09);
}

#me-shop-main .sct_img,
#me-shop-main .sct_img a{
    display:block;
    position:relative;
    overflow:hidden;
    background:#efe5d8;
    aspect-ratio:1 / 1;
}

#me-shop-main .sct_img img,
#me-shop-main .sct_img a img{
    width:100%;
    height:100%;
    object-fit:cover;
    transition:transform .35s ease;
}

#me-shop-main .sct_li:hover .sct_img img,
#me-shop-main .sct_li:hover .sct_img a img,
#me-shop-main .sct > li:hover .sct_img img{
    transform:scale(1.04);
}

#me-shop-main .sct_txt,
#me-shop-main .sct_basic,
#me-shop-main .sct_info{
    color:var(--me-text-sub);
}

#me-shop-main .sct_it_name,
#me-shop-main .sct_it_name a,
#me-shop-main .sct_txt a{
    color:var(--me-text);
    font-size:20px;
    line-height:1.4;
    font-weight:700;
    letter-spacing:-0.03em;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

#me-shop-main .sct_it_name a:hover,
#me-shop-main .sct_txt a:hover{
    color:var(--me-green);
}

#me-shop-main .sct_cost,
#me-shop-main .sct_price,
#me-shop-main .sct_a{
    color:var(--me-green);
    font-weight:800;
}

#me-shop-main .sct_cost strike,
#me-shop-main .sct_icon,
#me-shop-main .sct_discount{
    color:var(--me-text-sub);
}

#me-shop-main .sct_icon img,
#me-shop-main .item_icon img{
    display:inline-block;
    width:auto;
    max-height:22px;
    vertical-align:middle;
}

/* 목록 카드 내부 여백 보강 */
#me-shop-main .sct_li .sct_txt,
#me-shop-main .sct_li .sct_basic,
#me-shop-main .sct_li .sct_info,
#me-shop-main .sct_li .sct_cost,
#me-shop-main .sct_li .sct_icon,
#me-shop-main .sct > li .sct_txt,
#me-shop-main .sct > li .sct_basic,
#me-shop-main .sct > li .sct_info,
#me-shop-main .sct > li .sct_cost,
#me-shop-main .sct > li .sct_icon{
    padding-left:20px;
    padding-right:20px;
}

#me-shop-main .sct_li .sct_txt,
#me-shop-main .sct > li .sct_txt{
    padding-top:18px;
}

#me-shop-main .sct_li .sct_cost,
#me-shop-main .sct_li .sct_icon,
#me-shop-main .sct > li .sct_cost,
#me-shop-main .sct > li .sct_icon{
    padding-bottom:18px;
}

/* 목록 정렬 / 카테고리 */
#me-shop-main #sct_sort{
    margin-bottom:0px;
}
#me-shop-main .sct_sort,
#me-shop-main #sct_sortlst{
    margin-bottom:24px;
}

#me-shop-main #sct_sort ul,
#me-shop-main .sct_sort ul,
#me-shop-main #sct_sortlst ul{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-wrap:wrap;
    gap:8px;
}

#me-shop-main #sct_sort li,
#me-shop-main .sct_sort li,
#me-shop-main #sct_sortlst li{
    margin:0;
    padding:0;
}

#me-shop-main #sct_sort a,
#me-shop-main .sct_sort a,
#me-shop-main #sct_sortlst a{
    display:inline-flex;
    align-items:center;
    min-height:38px;
    padding:0 14px;
    border-radius:999px;
    border:1px solid rgba(41,68,58,.14);
    background:#fff;
    color:var(--me-text-sub);
    font-size:14px;
    transition:all .2s ease;
}

#me-shop-main #sct_sort a:hover,
#me-shop-main .sct_sort a:hover,
#me-shop-main #sct_sortlst a:hover{
    border-color:var(--me-green);
    color:var(--me-green);
    background:rgba(41,68,58,.04);
}

#me-shop-main #sct_ct_1,
#me-shop-main #sct_ct_2,
#me-shop-main .sct_ct{
    margin-bottom:26px;
}

#me-shop-main #sct_ct ul,
#me-shop-main .sct_ct ul{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

#me-shop-main #sct_ct li,
#me-shop-main .sct_ct li{
    margin:0;
}

#me-shop-main #sct_ct a,
#me-shop-main .sct_ct a{
    display:inline-flex;
    align-items:center;
    min-height:40px;
    padding:0 16px;
    border-radius:999px;
    border:1px solid rgba(216,202,184,.9);
    background:#fff;
    color:var(--me-text);
    font-size:14px;
    transition:all .2s ease;
}

#me-shop-main #sct_ct a:hover,
#me-shop-main .sct_ct a:hover,
#me-shop-main #sct_ct .ct_on a,
#me-shop-main .sct_ct .ct_on a{
    border-color:var(--me-green);
    background:var(--me-green);
    color:var(--me-white);
}

/* ================================
   상품 상세
================================ */
#me-shop-main .sit{
    background:transparent;
}

#me-shop-main .sit_ov_wrap,
#me-shop-main .sit_info_wrap,
#me-shop-main .sit_desc,
#me-shop-main .sit_qa,
#me-shop-main .sit_use,
#me-shop-main .sit_rel{
    background:#fff;
    border:1px solid rgba(216,202,184,.75);
    border-radius:24px;
    box-shadow:var(--me-shadow-soft);
}

#me-shop-main .sit_ov_wrap,
#me-shop-main .sit_info_wrap{
    padding:28px;
}

#me-shop-main .sit_ov_img,
#me-shop-main .sit_pvi,
#me-shop-main .sit_pvi_big{
    overflow:hidden;
    border-radius:22px;
    background:#efe5d8;
}

#me-shop-main .sit_ov_img img,
#me-shop-main .sit_pvi img,
#me-shop-main .sit_pvi_big img{
    width:100%;
    height:auto;
    display:block;
}

#me-shop-main .sit_pvi_thumb,
#me-shop-main .sit_pvi ul{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

#me-shop-main .sit_pvi li{
    overflow:hidden;
    border-radius:12px;
    border:1px solid rgba(216,202,184,.75);
    background:#fff;
}

#me-shop-main .sit_ovr h2,
#me-shop-main .sit_title{
    margin:0 0 16px;
    color:var(--me-text);
    font-size:34px;
    line-height:1.3;
    font-weight:700;
    letter-spacing:-0.04em;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

#me-shop-main .sit_ovr p,
#me-shop-main .sit_basic,
#me-shop-main .sit_info,
#me-shop-main .sit_desc{
    color:var(--me-text-sub);
}

#me-shop-main .sit_ov_tbl,
#me-shop-main .sit_option,
#me-shop-main .sit_sel_option{
    color:var(--me-text);
}

#me-shop-main .sit_ov_tbl table,
#me-shop-main .sit_ov_tbl th,
#me-shop-main .sit_ov_tbl td{
    border-color:rgba(216,202,184,.7);
}

#me-shop-main .sit_price,
#me-shop-main .sit_tot_price,
#me-shop-main .sit_ov_tbl .price,
#me-shop-main .sit_ov_tbl .cost{
    color:var(--me-green);
    font-weight:800;
}

#me-shop-main .sit_ov_btn,
#me-shop-main .sit_order_btn,
#me-shop-main .sit_btn{
    display:flex;
    flex-wrap:wrap;
    gap:10px;
    margin-top:20px;
}

#me-shop-main .sit_ov_btn a,
#me-shop-main .sit_ov_btn button,
#me-shop-main .sit_order_btn a,
#me-shop-main .sit_order_btn button,
#me-shop-main .sit_btn a,
#me-shop-main .sit_btn button,
#me-shop-main .btn_buy,
#me-shop-main .btn_submit,
#me-shop-main .btn_cart,
#me-shop-main .btn_wish{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:150px;
    height:52px;
    padding:0 22px;
    border-radius:999px;
    border:1px solid var(--me-green);
    background:var(--me-green);
    color:var(--me-white);
    font-size:15px;
    font-weight:700;
    transition:all .2s ease;
}

#me-shop-main .sit_ov_btn a:hover,
#me-shop-main .sit_ov_btn button:hover,
#me-shop-main .sit_order_btn a:hover,
#me-shop-main .sit_order_btn button:hover,
#me-shop-main .sit_btn a:hover,
#me-shop-main .sit_btn button:hover,
#me-shop-main .btn_buy:hover,
#me-shop-main .btn_submit:hover,
#me-shop-main .btn_cart:hover,
#me-shop-main .btn_wish:hover{
    background:var(--me-green-dark);
    border-color:var(--me-green-dark);
}

#me-shop-main .btn_cart,
#me-shop-main .btn_wish,
#me-shop-main .sit_ov_btn .btn01,
#me-shop-main .sit_ov_btn .btn02{
    background:#fff;
    color:var(--me-green);
}

#me-shop-main .btn_cart:hover,
#me-shop-main .btn_wish:hover,
#me-shop-main .sit_ov_btn .btn01:hover,
#me-shop-main .sit_ov_btn .btn02:hover{
    background:rgba(41,68,58,.05);
    color:var(--me-green);
}

#me-shop-main .sit_info_wrap{
    margin-top:26px;
}

#me-shop-main .sit_tab{
    margin-bottom:22px;
}

#me-shop-main .sit_tab ul{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-wrap:wrap;
    gap:10px;
}

#me-shop-main .sit_tab li{
    margin:0;
}

#me-shop-main .sit_tab a{
    display:inline-flex;
    align-items:center;
    min-height:42px;
    padding:0 18px;
    border-radius:999px;
    border:1px solid rgba(41,68,58,.14);
    background:#fff;
    color:var(--me-text-sub);
    font-size:14px;
    font-weight:600;
    transition:all .2s ease;
}

#me-shop-main .sit_tab a:hover,
#me-shop-main .sit_tab .tab_selected a,
#me-shop-main .sit_tab .active a{
    background:var(--me-green);
    border-color:var(--me-green);
    color:var(--me-white);
}

#me-shop-main .sit_desc,
#me-shop-main .sit_use,
#me-shop-main .sit_qa,
#me-shop-main .sit_rel{
    padding:28px;
    margin-top:22px;
}

#me-shop-main .sit_rel ul{
    list-style:none;
    margin:0;
    padding:0;
}

#me-shop-main .sit_rel li{
    border-radius:20px;
}

/* 옵션 선택 */
#me-shop-main select,
#me-shop-main input[type="text"],
#me-shop-main input[type="number"],
#me-shop-main input[type="password"],
#me-shop-main textarea{
    border:1px solid rgba(216,202,184,.95);
    background:#fff;
    color:var(--me-text);
    border-radius:14px;
    transition:border-color .2s ease, box-shadow .2s ease;
}

#me-shop-main select:focus,
#me-shop-main input[type="text"]:focus,
#me-shop-main input[type="number"]:focus,
#me-shop-main input[type="password"]:focus,
#me-shop-main textarea:focus{
    border-color:rgba(41,68,58,.5);
    box-shadow:0 0 0 4px rgba(41,68,58,.06);
    outline:none;
}

/* ================================
   장바구니 / 주문서 / 주문조회
================================ */
#me-shop-main .cart_list,
#me-shop-main .od_prd_list,
#me-shop-main .tbl_head01,
#me-shop-main .tbl_frm01{
    overflow:hidden;
    background:#fff;
    border:1px solid rgba(216,202,184,.75);
    box-shadow:var(--me-shadow-soft);
}

#me-shop-main .tbl_head01 table,
#me-shop-main .tbl_frm01 table,
#me-shop-main .cart_list table,
#me-shop-main .od_prd_list table{
    width:100%;
    border-collapse:collapse;
}

#me-shop-main .tbl_head01 th,
#me-shop-main .tbl_head01 td,
#me-shop-main .tbl_frm01 th,
#me-shop-main .tbl_frm01 td,
#me-shop-main .cart_list th,
#me-shop-main .cart_list td,
#me-shop-main .od_prd_list th,
#me-shop-main .od_prd_list td{
    padding:14px 16px;
}

#me-shop-main .tbl_head01 th,
#me-shop-main .tbl_frm01 th,
#me-shop-main .cart_list th,
#me-shop-main .od_prd_list th{
    background:#f7f2ea;
    color:var(--me-text);
    border-bottom:1px solid rgba(216,202,184,.85);
    font-weight:700;
}

#me-shop-main .tbl_head01 td,
#me-shop-main .tbl_frm01 td,
#me-shop-main .cart_list td,
#me-shop-main .od_prd_list td{
    color:var(--me-text-sub);
    border-top:1px solid rgba(216,202,184,.5);
    background:#fff;
}

#me-shop-main .tbl_head01 a,
#me-shop-main .tbl_frm01 a,
#me-shop-main .cart_list a,
#me-shop-main .od_prd_list a{
    color:var(--me-text);
}

#me-shop-main .tbl_head01 a:hover,
#me-shop-main .tbl_frm01 a:hover,
#me-shop-main .cart_list a:hover,
#me-shop-main .od_prd_list a:hover{
    color:var(--me-green);
}

#me-shop-main .ct_total,
#me-shop-main .od_total,
#me-shop-main .order_total_price,
#me-shop-main .cart_total_price,
#me-shop-main .od_prd_price{
    color:var(--me-green);
    font-weight:800;
}

/* 버튼 적용 범위 정리 */
#me-shop-main .btn_confirm .btn_submit,
#me-shop-main .btn_confirm .btn01,
#me-shop-main .btn_confirm .btn02,
#me-shop-main .btn_confirm .btn03,
#me-shop-main .btn_b01,
#me-shop-main .btn_b02,
#me-shop-main .cart_list .btn01,
#me-shop-main .cart_list .btn02,
#me-shop-main .cart_list .btn03,
#me-shop-main .od_prd_list .btn01,
#me-shop-main .od_prd_list .btn02,
#me-shop-main .od_prd_list .btn03,
#me-shop-main .btn_cancel{
    border-radius:999px;
}

#me-shop-main .btn_submit,
#me-shop-main .btn_confirm .btn_submit,
#me-shop-main .btn_b02,
#me-shop-main .btn02{
    background:var(--me-green);
    border-color:var(--me-green);
    color:var(--me-white);
}

#me-shop-main .btn_submit:hover,
#me-shop-main .btn_confirm .btn_submit:hover,
#me-shop-main .btn_b02:hover,
#me-shop-main .btn02:hover{
    background:var(--me-green-dark);
    border-color:var(--me-green-dark);
}

#me-shop-main .btn01,
#me-shop-main .btn03,
#me-shop-main .btn_b01,
#me-shop-main .btn_cancel{
    background:#fff;
    color:var(--me-green);
    border:1px solid var(--me-green);
}

#me-shop-main .btn01:hover,
#me-shop-main .btn03:hover,
#me-shop-main .btn_b01:hover,
#me-shop-main .btn_cancel:hover{
    background:rgba(41,68,58,.05);
}

/* 주문서 입력폼 */
#me-shop-main .tbl_frm01 th{
    color:var(--me-text);
}

#me-shop-main .tbl_frm01 td{
    color:var(--me-text-sub);
}

#me-shop-main .tbl_frm01 label{
    color:var(--me-text);
    font-weight:600;
}

#me-shop-main .od_pay_area,
#me-shop-main .od_cart_list,
#me-shop-main .od_info,
#me-shop-main .od_recvr_info,
#me-shop-main .order_info,
#me-shop-main .cart_info{
    background:#fff;
    border:1px solid rgba(216,202,184,.78);
    border-radius:24px;
    box-shadow:var(--me-shadow-soft);
    padding:24px;
    margin-bottom:24px;
}

/* 장바구니 상품 이미지 */
#me-shop-main .cart_list .prd_img,
#me-shop-main .od_prd_list .prd_img,
#me-shop-main .cart_list .sod_img,
#me-shop-main .od_prd_list .sod_img{
    overflow:hidden;
    border-radius:14px;
    background:#efe5d8;
}

#me-shop-main .cart_list .prd_img img,
#me-shop-main .od_prd_list .prd_img img,
#me-shop-main .cart_list .sod_img img,
#me-shop-main .od_prd_list .sod_img img{
    display:block;
}

/* ================================
   위시리스트 / 개인결제
================================ */
#me-shop-main .wishlist,
#me-shop-main .personalpay{
    background:#fff;
    border:1px solid rgba(216,202,184,.75);
    border-radius:24px;
    box-shadow:var(--me-shadow-soft);
    overflow:hidden;
}

#me-shop-main .wishlist ul,
#me-shop-main .personalpay ul{
    list-style:none;
    margin:0;
    padding:0;
}

#me-shop-main .wishlist li,
#me-shop-main .personalpay li{
    border-top:1px solid rgba(216,202,184,.5);
}

#me-shop-main .wishlist li:first-child,
#me-shop-main .personalpay li:first-child{
    border-top:0;
}

/* ================================
   페이징
================================ */
#me-shop-main .pg,
#me-shop-main .pagination{
    margin-top:28px;
    text-align:center;
}

#me-shop-main .pg_page,
#me-shop-main .pg_current,
#me-shop-main .pagination a,
#me-shop-main .pagination strong{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    min-width:40px;
    height:40px;
    margin:0 3px;
    padding:0 10px;
    border-radius:999px;
    border:1px solid rgba(216,202,184,.9);
    background:#fff;
    color:var(--me-text-sub);
    font-size:14px;
    transition:all .2s ease;
}

#me-shop-main .pg_page:hover,
#me-shop-main .pagination a:hover{
    border-color:var(--me-green);
    color:var(--me-green);
    background:rgba(41,68,58,.04);
}

#me-shop-main .pg_current,
#me-shop-main .pagination strong{
    border-color:var(--me-green);
    background:var(--me-green);
    color:var(--me-white);
    font-weight:700;
}

/* ================================
   리뷰 / Q&A
================================ */
#me-shop-main .sit_use,
#me-shop-main .sit_qa{
    color:var(--me-text-sub);
}

#me-shop-main .sit_use h3,
#me-shop-main .sit_qa h3,
#me-shop-main .sit_rel h3,
#me-shop-main .sit_desc h3{
    margin:0 0 18px;
    color:var(--me-text);
    font-size:24px;
    line-height:1.35;
    font-family:'Nanum Myeongjo','Noto Serif KR','Apple SD Gothic Neo',serif;
}

#me-shop-main .sit_use_list,
#me-shop-main .sit_qa_list{
    border-top:1px solid rgba(216,202,184,.7);
}

#me-shop-main .sit_use_list li,
#me-shop-main .sit_qa_list li{
    border-bottom:1px solid rgba(216,202,184,.5);
    padding:18px 0;
}

/* ================================
   Responsive
================================ */

@media (max-width:1024px){
    .me-shop-nav{
        gap:20px;
    }

    .me-shop-util a{
        min-width:96px;
        height:44px;
        padding:0 18px;
        font-size:14px;
    }

    #me-shop-visual h2{
        font-size:34px;
    }

    #me-shop-main .sit_ovr h2,
    #me-shop-main .sit_title{
        font-size:30px;
    }

    #me-shop-main .sct_it_name,
    #me-shop-main .sct_it_name a,
    #me-shop-main .sct_txt a{
        font-size:18px;
    }
}

@media (max-width:820px){
    .me-shop-nav,
    .me-shop-util{
        display:none;
    }

    .me-shop-menu-btn{
        display:block;
    }

    #me-shop-mobile.is-open{
        display:block;
    }

    #me-shop-header .me-shop-header-inner{
        height:74px;
    }

    .me-shop-logo a{
        font-size:24px;
    }

    #me-shop-visual .inner{
        padding:30px 0 28px;
    }

    #me-shop-visual h2{
        font-size:30px;
    }

    #me-shop-main{
        padding:30px 0 60px;
    }

    #me-shop-footer .top{
        flex-direction:column;
        gap:16px;
        margin-bottom:18px;
    }

    #me-shop-footer .logo{
        font-size:22px;
    }

    #me-shop-main .sit_ov_wrap,
    #me-shop-main .sit_info_wrap,
    #me-shop-main .sit_desc,
    #me-shop-main .sit_qa,
    #me-shop-main .sit_use,
    #me-shop-main .sit_rel,
    #me-shop-main .od_pay_area,
    #me-shop-main .od_cart_list,
    #me-shop-main .od_info,
    #me-shop-main .od_recvr_info,
    #me-shop-main .order_info,
    #me-shop-main .cart_info{
        padding:20px;
        border-radius:20px;
    }

    #me-shop-main .sit_ovr h2,
    #me-shop-main .sit_title{
        font-size:26px;
    }

    #me-shop-main .sit_ov_btn a,
    #me-shop-main .sit_ov_btn button,
    #me-shop-main .sit_order_btn a,
    #me-shop-main .sit_order_btn button,
    #me-shop-main .sit_btn a,
    #me-shop-main .sit_btn button,
    #me-shop-main .btn_buy,
    #me-shop-main .btn_submit,
    #me-shop-main .btn_cart,
    #me-shop-main .btn_wish{
        min-width:130px;
        height:48px;
        padding:0 18px;
        font-size:14px;
    }

    #me-shop-main .sit_tab ul{
        gap:8px;
    }

    #me-shop-main .sit_tab a{
        min-height:38px;
        padding:0 14px;
        font-size:13px;
    }
}

@media (max-width:640px){
    #me-shop-main .sit_ovr h2,
    #me-shop-main .sit_title{
        font-size:22px;
        line-height:1.35;
    }

    #me-shop-main .sct_it_name,
    #me-shop-main .sct_it_name a,
    #me-shop-main .sct_txt a{
        font-size:17px;
    }

    #me-shop-main .sit_desc,
    #me-shop-main .sit_use,
    #me-shop-main .sit_qa,
    #me-shop-main .sit_rel{
        padding:18px;
    }

    #me-shop-main .od_pay_area,
    #me-shop-main .od_cart_list,
    #me-shop-main .od_info,
    #me-shop-main .od_recvr_info,
    #me-shop-main .order_info,
    #me-shop-main .cart_info{
        padding:18px;
    }

    #me-shop-main .sit_ov_btn,
    #me-shop-main .sit_order_btn,
    #me-shop-main .sit_btn{
        flex-direction:column;
    }

    #me-shop-main .sit_ov_btn a,
    #me-shop-main .sit_ov_btn button,
    #me-shop-main .sit_order_btn a,
    #me-shop-main .sit_order_btn button,
    #me-shop-main .sit_btn a,
    #me-shop-main .sit_btn button,
    #me-shop-main .btn_buy,
    #me-shop-main .btn_submit,
    #me-shop-main .btn_cart,
    #me-shop-main .btn_wish{
        width:100%;
        min-width:auto;
    }

    #me-shop-main #sct_sort ul,
    #me-shop-main .sct_sort ul,
    #me-shop-main #sct_sortlst ul,
    #me-shop-main #sct_ct ul,
    #me-shop-main .sct_ct ul,
    #me-shop-main .sit_tab ul{
        gap:6px;
    }

    #me-shop-main .tbl_head01 th,
    #me-shop-main .tbl_head01 td,
    #me-shop-main .tbl_frm01 th,
    #me-shop-main .tbl_frm01 td,
    #me-shop-main .cart_list th,
    #me-shop-main .cart_list td,
    #me-shop-main .od_prd_list th,
    #me-shop-main .od_prd_list td{
        padding:12px 10px;
    }

    #me-shop-main .pg_page,
    #me-shop-main .pg_current,
    #me-shop-main .pagination a,
    #me-shop-main .pagination strong{
        min-width:36px;
        height:36px;
        font-size:13px;
    }
}

@media (max-width:480px){
    .me-shop-container{
        padding:0 16px;
    }

    .me-shop-logo a{
        font-size:22px;
    }

    #me-shop-visual h2{
        font-size:26px;
        line-height:1.3;
    }

    #me-shop-visual p{
        font-size:15px;
    }

    #me-shop-footer .me-shop-footer-inner{
        padding:44px 0;
    }

    #me-shop-footer .links{
        gap:12px 16px;
    }

    #me-shop-footer .info{
        font-size:13px;
    }
}

.hero {
    display:flex;
    align-items:center;
    min-height:520px;
    background:#f8f5ef;
}

.hero-img {
    flex:1;
    background:url('/img/v1/hero.jpg') center/cover no-repeat;
    filter:brightness(0.85);
}

.hero-text {
    flex:1;
    padding:60px;
}

.hero-text h1 {
    font-size:42px;
    font-family:'Nanum Myeongjo';
    color:#29443a;
}

.hero-text p {
    margin-top:20px;
    color:#6a625a;
}

.hero-btn {
    margin-top:30px;
    display:inline-block;
    padding:14px 28px;
    border-radius:999px;
    background:#29443a;
    color:#fff;
}

/* =========================================
   Product Banner Upgrade
========================================= */
.me-products-banner .me-products-head {
    margin-bottom: 34px;
}

.me-product-banner-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
}

.me-product-banner-card {
    position: relative;
    min-height: 560px;
    overflow: hidden;
    border-radius: 30px;
    background: #ddd3c5;
    box-shadow: 0 12px 32px rgba(41, 68, 58, 0.10);
    transition: transform .25s ease, box-shadow .25s ease;
}

.me-product-banner-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 18px 40px rgba(41, 68, 58, 0.15);
}

.me-product-banner-thumb {
    position: absolute;
    inset: 0;
    display: block;
}

.me-product-banner-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .45s ease;
}

.me-product-banner-card:hover .me-product-banner-thumb img {
    transform: scale(1.04);
}

.me-product-banner-overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(
            180deg,
            rgba(24, 24, 24, 0.08) 0%,
            rgba(24, 24, 24, 0.20) 38%,
            rgba(24, 24, 24, 0.72) 100%
        );
    z-index: 1;
}

.me-product-banner-body {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    padding: 30px 26px 28px;
    color: #fff;
}

.me-product-banner-badge {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(248, 245, 239, 0.16);
    border: 1px solid rgba(255,255,255,0.22);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .04em;
    margin-bottom: 14px;
}

.me-product-banner-title {
    margin: 0 0 12px;
    font-size: 32px;
    line-height: 1.25;
    font-weight: 700;
    letter-spacing: -0.04em;
    font-family: 'Nanum Myeongjo', 'Noto Serif KR', 'Apple SD Gothic Neo', serif;
}

.me-product-banner-title a {
    color: #fff;
}

.me-product-banner-desc {
    margin: 0 0 18px;
    font-size: 16px;
    line-height: 1.7;
    color: rgba(255,255,255,0.88);
}

.me-product-banner-meta {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
}

.me-product-banner-price {
    display: inline-block;
    font-size: 22px;
    line-height: 1.2;
    font-weight: 800;
    color: #fff;
}

.me-product-banner-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 116px;
    height: 42px;
    padding: 0 16px;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    border: 1px solid rgba(255,255,255,0.24);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    backdrop-filter: blur(3px);
    transition: all .2s ease;
}

.me-product-banner-link:hover {
    background: rgba(255,255,255,0.22);
}

@media (max-width: 1180px) {
    .me-product-banner-grid {
        grid-template-columns: 1fr;
    }

    .me-product-banner-card {
        min-height: 520px;
    }
}

@media (max-width: 767px) {
    .me-product-banner-card {
        min-height: 440px;
        border-radius: 22px;
    }

    .me-product-banner-body {
        padding: 22px 18px 20px;
    }

    .me-product-banner-title {
        font-size: 24px;
    }

    .me-product-banner-desc {
        font-size: 15px;
        line-height: 1.65;
    }

    .me-product-banner-meta {
        flex-direction: column;
        align-items: flex-start;
    }

    .me-product-banner-price {
        font-size: 20px;
    }
}

