/* ============================================
   COCOLABEL - Main Stylesheet
   ============================================ */

/* === RESET === */
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Noto Sans KR',sans-serif;color:#333;background:#fff;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%;height:auto;display:block}

/* ============================================
   HEADER
   ============================================ */
header{position:fixed;top:0;left:0;right:0;z-index:1000;padding:0 30px;display:flex;align-items:center;justify-content:space-between;height:46px;transition:background .3s,box-shadow .3s}
header.on-hero{background:rgba(0,0,0,.5)}
header.scrolled{background:#fff;box-shadow:0 1px 4px rgba(0,0,0,.08)}
header.scrolled .logo,
header.scrolled .gnb-lv0,
header.scrolled .hi-ico svg{color:#000;stroke:#000}
.logo{font-size:17px;font-weight:700;letter-spacing:3px;color:#fff;white-space:nowrap}

/* --- GNB 3-depth cascading dropdown --- */
.gnb{display:flex;gap:0;position:relative}
.gnb-item{position:relative}
.gnb-lv0{color:#fff;font-size:11.5px;font-weight:500;padding:14px 7px;display:block;white-space:nowrap;transition:color .2s}
.gnb-item:hover .gnb-lv0{opacity:.8}

/* 2뎁스: 메가 드롭다운 (멀티컬럼 그리드) */
.gnb-mega{position:absolute;top:100%;left:50%;transform:translateX(-50%);background:#fff;box-shadow:0 8px 30px rgba(0,0,0,.12);display:none;z-index:100;padding:16px 18px;border-top:2px solid #000;
  display:none;width:max-content;max-width:80vw;max-height:75vh;overflow-y:auto;
  column-count:3;column-gap:6px}
.gnb-item:hover .gnb-mega{display:block}
/* 컬럼 수 조정: 하위 개수에 따라 자동 배분 */
.gnb-col{break-inside:avoid;padding:0 0 12px 0;position:relative}
.gnb-lv1{font-size:11px;font-weight:600;color:#111;display:block;padding:5px 10px;white-space:nowrap;transition:background .15s;letter-spacing:-.02em;border-bottom:1px solid #eee;margin-bottom:2px}
.gnb-lv1:hover{background:#f5f5f5}
/* 화살표 제거 (펼쳐진 상태이므로) */
.gnb-col.has-sub .gnb-lv1::after{display:none}

/* 3뎁스: 브랜드 아래 바로 노출 (항상 보임) */
.gnb-col ul{list-style:none;position:static;background:none;box-shadow:none;min-width:auto;padding:0;display:block;border-left:none}
.gnb-col:hover>ul{display:block}
.gnb-col ul li a{font-size:10.5px;color:#888;display:block;padding:3px 10px;transition:color .15s;white-space:nowrap;line-height:1.5}
.gnb-col ul li a:hover{color:#000;background:#f8f8f8}

/* --- Header Icons --- */
.hi{display:flex;align-items:center;gap:10px;flex-shrink:0}
.hi-ico{display:flex;align-items:center}
.hi-ico svg{width:18px;height:18px;stroke:#fff;stroke-width:1.8;fill:none;transition:stroke .3s}
.point-badge{background:#ffe812;color:#000;font-size:10px;padding:3px 10px;border-radius:12px;font-weight:700;white-space:nowrap}
.hamburger{display:none;background:none;border:none;cursor:pointer;padding:4px}
.hamburger svg{width:24px;height:24px;stroke:#fff;stroke-width:2;fill:none}
header.scrolled .hamburger svg{stroke:#000}

/* ============================================
   MOBILE MENU
   ============================================ */
.mobile-menu{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.96);z-index:2000;display:none;flex-direction:column;padding:60px 24px 30px;overflow-y:auto}
.mobile-menu.open{display:flex}
.mm-close{position:absolute;top:14px;right:18px;background:none;border:none;cursor:pointer}
.mm-group{border-bottom:1px solid rgba(255,255,255,.08)}
.mm-lv0{color:#fff;font-size:16px;font-weight:600;padding:14px 0;display:block}
.mm-sub{padding:0 0 12px 16px}
.mm-sub a{color:rgba(255,255,255,.6);font-size:14px;padding:6px 0;display:block}
.mm-sub a:hover{color:#fff}
.mm-lv2{padding-left:12px!important;font-size:13px!important;color:rgba(255,255,255,.4)!important}

/* ============================================
   HERO
   ============================================ */
.hero{height:100vh;background-size:cover;background-position:center;background-attachment:fixed;position:relative}
.hero::after{content:'';position:absolute;inset:0;background:rgba(0,0,0,.35)}
.hero-ct{position:absolute;bottom:80px;left:0;right:0;text-align:center;z-index:1}
.hero-ct h1{color:#fff;font-size:26px;letter-spacing:6px;font-weight:400}
.hero-ct a{color:#fff;font-size:13px;letter-spacing:3px;display:inline-block;margin-top:14px;border-bottom:1px solid rgba(255,255,255,.6);padding-bottom:4px}

/* ============================================
   SECTION COMMON
   ============================================ */
.section-wrap{max-width:1600px;margin:0 auto;padding:0 40px}
.sh{text-align:center;padding:50px 0 28px}
.sh span{font-size:12px;color:#aaa;letter-spacing:2px;display:block;margin-bottom:4px}
.sh h2{font-size:20px;font-weight:700}
.sf{text-align:center;padding:28px 0 50px}

/* ============================================
   BRAND GRID
   ============================================ */
.brand-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.bi{text-align:center}
.bi img{width:100%;aspect-ratio:4/3;object-fit:contain;background:#f5f5f5;border-radius:4px}
.bi p{margin-top:8px;font-size:12px;color:#777}

/* ============================================
   PRODUCT GRID
   ============================================ */
.pg{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.pc{cursor:pointer}
.pi{position:relative;aspect-ratio:1;overflow:hidden;background:#f3f4f6;border-radius:4px}
.pi img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.pc:hover .pi img{transform:scale(1.05)}
.pf{padding:10px 2px 0}
.pf .brand-name{font-size:11px;color:#999;margin-bottom:2px}
.pf h3{font-size:13px;font-weight:400;line-height:1.4;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pf b{font-size:14px;font-weight:700}
.pf s{font-size:11px;color:#aaa;margin-left:4px}
.badge{position:absolute;bottom:8px;left:8px;background:#ff3040;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:2px}
.badge-sold{background:#666}
.va{display:inline-block;padding:10px 32px;border:1px solid #333;color:#333;font-size:12px;letter-spacing:2px;transition:.3s;margin-top:18px}
.va:hover{background:#333;color:#fff}

/* ============================================
   CATEGORY BANNER (parallax)
   ============================================ */
.cb{width:100%;height:50vh;background-size:cover;background-position:center;background-attachment:fixed;position:relative;margin:40px 0}
.bo{position:absolute;inset:0;background:rgba(0,0,0,.3);display:flex;flex-direction:column;align-items:center;justify-content:center}
.bo h2{color:#fff;font-size:26px;letter-spacing:5px;font-weight:400}
.bo .va{border-color:#fff;color:#fff}
.bo .va:hover{background:#fff;color:#333}

/* ============================================
   REVIEW
   ============================================ */
.review-slider{margin:0 -8px}
.rc{padding:0 8px}
.rp{width:100%;aspect-ratio:1;background-size:cover;background-position:center;border-radius:4px}
.rd{font-size:12px;color:#555;line-height:1.5;margin-top:10px;height:36px;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.ri{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:8px;border-top:1px solid #eee}
.rt{width:36px;height:36px;border-radius:4px;object-fit:cover;flex-shrink:0}
.rn{font-size:11px;color:#333;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.rs{font-size:12px;color:#ffd700;display:block;margin-top:2px}

/* ============================================
   QUALITY CHECK
   ============================================ */
.quality-slider{margin:0 -8px}
.qc{padding:0 8px}
.qp{width:100%;aspect-ratio:1;background-size:cover;background-position:center;border-radius:4px;position:relative;display:flex;align-items:flex-start;justify-content:flex-end;padding:10px}
.qb{background:rgba(0,0,0,.75);color:#fff;font-size:10px;padding:5px 12px;border-radius:20px}
.qc h4{font-size:12px;font-weight:500;margin-top:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qc .qd{font-size:11px;color:#999;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* ============================================
   SERVICE ICONS
   ============================================ */
.svc{display:grid;grid-template-columns:repeat(4,1fr);max-width:1600px;margin:0 auto;padding:50px 40px;border-top:1px solid #eee}
.si{text-align:center}
.si .ico{font-size:28px;margin-bottom:8px}
.si h4{font-size:14px;font-weight:600;margin-bottom:4px}
.si p{font-size:12px;color:#999}

/* ============================================
   FOOTER
   ============================================ */
footer{background:#fafafa;padding:40px 40px 30px;border-top:1px solid #eee}
.ft-inner{max-width:1600px;margin:0 auto;display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px}
.ft-left h4,.ft-right h4{font-size:14px;font-weight:700;margin-bottom:12px}
.ft-left .tm{font-size:20px;font-weight:700;margin-bottom:5px}
.ft-left .nt{font-size:12px;color:#999}
.ft-right{text-align:right}
.bk{display:inline-block;padding:8px 20px;background:#000;color:#fff;border-radius:9999px;font-size:12px;margin:3px}
.bn{display:inline-block;padding:8px 20px;border:1px solid #333;border-radius:9999px;font-size:12px;margin:3px}
.ft-btm{text-align:center;margin-top:30px;padding-top:20px;border-top:1px solid #e5e5e5}
.ft-btm img{width:120px;margin:0 auto 8px}
.ft-btm p{font-size:12px;color:#666}

/* ============================================
   FLOATING BAR
   ============================================ */
.fb{position:fixed;bottom:24px;right:24px;display:flex;gap:10px;z-index:999}
.fl{width:62px;height:62px;background:#fff;border-radius:50%;box-shadow:0 2px 12px rgba(0,0,0,.12);display:flex;flex-direction:column;align-items:center;justify-content:center;font-size:9px;color:#555;cursor:pointer;transition:transform .2s}
.fl:hover{transform:translateY(-3px)}
.fl.kk{background:#ffe812;color:#333}
.fl i{font-size:18px;margin-bottom:3px}

/* ============================================
   SLICK OVERRIDES
   ============================================ */
.slick-prev,.slick-next{width:40px;height:40px;z-index:10}
.slick-prev{left:0}.slick-next{right:0}
.slick-prev:before,.slick-next:before{font-size:28px;opacity:.6}
.slick-dots{bottom:-30px}
.slick-dots li button:before{font-size:10px}

/* ============================================
   RESPONSIVE - TABLET (≤1024)
   ============================================ */
@media(max-width:1024px){
  header{padding:0 16px}
  .gnb{gap:4px}.gnb-lv0{font-size:10.5px;padding:14px 5px}
  .gnb-mega{column-count:2;max-width:90vw;padding:14px 14px}
  .brand-grid{grid-template-columns:repeat(3,1fr)}
  .pg{grid-template-columns:repeat(3,1fr)}
  .section-wrap{padding-left:20px;padding-right:20px}
  .svc{grid-template-columns:repeat(2,1fr);padding-left:20px;padding-right:20px}
}

/* ============================================
   RESPONSIVE - MOBILE (≤768)
   ============================================ */
@media(max-width:768px){
  header{padding:0 16px;height:48px}
  .logo{font-size:16px;letter-spacing:3px}
  .gnb{display:none}
  .hamburger{display:block}
  .hi-pc{display:none!important}
  .point-badge{font-size:9px;padding:2px 7px}

  .hero{height:65vh;background-attachment:scroll}
  .hero-ct{bottom:50px}.hero-ct h1{font-size:18px;letter-spacing:3px}

  .section-wrap{padding:0 16px}
  .brand-grid{grid-template-columns:repeat(3,1fr);gap:10px}
  .bi p{font-size:10px}

  .pg{grid-template-columns:repeat(2,1fr);gap:10px}
  .sh{padding:30px 0 16px}.sh span{font-size:10px}.sh h2{font-size:16px}
  .pf h3{font-size:11px}.pf b{font-size:12px}.pf s{font-size:10px}

  .cb{height:35vh;margin:20px 0;background-attachment:scroll}
  .bo h2{font-size:18px;letter-spacing:3px}
  .va{padding:8px 20px;font-size:11px}
  .sf{padding:16px 0 30px}

  .svc{grid-template-columns:repeat(2,1fr);padding:30px 16px;gap:16px}
  .si .ico{font-size:22px}.si h4{font-size:12px}.si p{font-size:10px}

  footer{padding:30px 16px 20px}
  .ft-inner{flex-direction:column;gap:20px}.ft-right{text-align:left}
  .ft-left .tm{font-size:16px}

  .fb{bottom:0;left:0;right:0;background:#fff;border-top:1px solid #eee;border-radius:0;padding:8px 0;justify-content:center;gap:0;box-shadow:0 -2px 10px rgba(0,0,0,.08)}
  .fl{width:auto;height:auto;border-radius:0;box-shadow:none;padding:6px 16px;background:transparent;font-size:10px}
  .fl.kk{background:transparent}
  .fl i{font-size:16px}
  body{padding-bottom:60px}
}

/* ============================================
   RESPONSIVE - SMALL (≤400)
   ============================================ */
@media(max-width:400px){
  .brand-grid{grid-template-columns:repeat(2,1fr)}
  .hero{height:55vh}
  .logo{font-size:14px}
  .fl{padding:6px 10px;font-size:9px}
}

/* ============================================
   PRODUCT DETAIL PAGE
   ============================================ */
.pd-wrap{padding-top:20px}
.pd-top{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:16px}

/* Gallery */
.pd-main-img{width:100%;aspect-ratio:1;overflow:hidden;background:#f3f4f6;border-radius:6px}
.pd-main-img img{width:100%;height:100%;object-fit:cover}
.pd-thumbs{display:flex;gap:8px;margin-top:10px;overflow-x:auto}
.pd-thumb{width:64px;height:64px;object-fit:cover;border:2px solid transparent;border-radius:4px;cursor:pointer;flex-shrink:0;transition:.2s}
.pd-thumb.active,.pd-thumb:hover{border-color:#000}

/* Info */
.pd-name{font-size:20px;font-weight:700;line-height:1.4;margin-bottom:12px}
.pd-price-row{margin-bottom:16px;display:flex;align-items:baseline;gap:8px}
.pd-sale{font-size:24px;font-weight:700}
.pd-orig{font-size:14px;color:#aaa;text-decoration:line-through}

/* Membership table */
.pd-membership{border:1px solid #ddd;margin-bottom:20px}
.pd-mb-head{background:#333;color:#fff;padding:16px;text-align:center}
.pd-mb-head strong{font-size:14px;letter-spacing:2px}
.pd-mb-head p{font-size:13px;margin-top:4px;font-weight:400}
.pd-mb-table{width:100%;border-collapse:collapse;font-size:12px}
.pd-mb-table thead{background:#555;color:#fff}
.pd-mb-table th{padding:8px;font-weight:500}
.pd-mb-table td{padding:8px;text-align:center;border-bottom:1px solid #eee}
.pd-mb-table tbody tr:hover{background:#f9f9f9}

/* Spec */
.pd-spec{margin:20px 0;font-size:13px}
.pd-spec dt{float:left;width:80px;font-weight:700;clear:left;padding:6px 0}
.pd-spec dd{margin-left:90px;padding:6px 0;color:#555;border-bottom:1px solid #f0f0f0}

/* Options */
.pd-option-group{margin-bottom:12px}
.pd-option-group label{font-size:13px;font-weight:600;display:block;margin-bottom:6px}
.pd-option-select{width:100%;padding:12px;border:1px solid #ddd;font-size:13px;background:#fff;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%23999'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.pd-sel-opt{display:inline-flex;align-items:center;gap:8px;background:#f5f5f5;border:1px solid #eee;padding:6px 12px;border-radius:4px;font-size:12px;margin:4px 4px 4px 0}
.pd-sel-opt button{background:none;border:none;cursor:pointer;font-size:14px;color:#999}

/* Actions */
.pd-actions{display:flex;gap:8px;margin:16px 0}
.pd-btn-buy,.pd-btn-cart,.pd-btn-wish,.pd-btn-sold{padding:14px;font-size:14px;font-weight:600;border-radius:0;border:none;cursor:pointer;transition:.2s}
.pd-btn-buy{flex:2;background:#000;color:#fff}.pd-btn-buy:hover{background:#222}
.pd-btn-cart{flex:2;background:#fff;color:#000;border:1px solid #000}.pd-btn-cart:hover{background:#f5f5f5}
.pd-btn-wish{flex:0 0 52px;background:#fff;border:1px solid #ddd;font-size:18px}
.pd-btn-sold{flex:1;background:#999;color:#fff;cursor:not-allowed}

/* CTA buttons */
.pd-cta{display:block;text-align:center;padding:14px;border-radius:999px;font-size:13px;font-weight:600;margin-top:8px}
.pd-cta-kakao{background:#ffe812;color:#000}
.pd-cta-signup{background:#000;color:#fff}

/* ============================================
   TABS (구매평 / 상세정보 / Q&A)
   ============================================ */
.pd-tabs{display:flex;border-bottom:2px solid #eee;margin-top:50px;position:sticky;top:46px;background:#fff;z-index:10}
.pd-tab{flex:1;padding:14px;text-align:center;font-size:14px;font-weight:500;background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:.2s;color:#999}
.pd-tab.active{border-bottom-color:#000;color:#000;font-weight:700;background:#000;color:#fff}

/* Reviews */
.pd-rev-head{padding:24px 0;border-bottom:1px solid #eee}
.pd-rev-head h3{font-size:16px;font-weight:700;margin-bottom:4px}
.pd-rev-head p{font-size:13px;color:#999;margin-bottom:12px}
.pd-btn-write{display:inline-block;padding:8px 20px;background:#000;color:#fff;font-size:12px;border-radius:4px}
.pd-photo-filter{display:flex;align-items:center;gap:6px;font-size:13px;padding:12px 0;color:#555;cursor:pointer}
.pd-photo-filter input{margin:0}

.pd-rev-item{padding:20px 0;border-bottom:1px solid #f0f0f0}
.pd-rev-stars{color:#ffd700;font-size:14px;margin-bottom:8px}
.pd-rev-photo{width:140px;height:140px;object-fit:cover;border-radius:6px;margin-bottom:10px}
.pd-rev-text{font-size:13px;line-height:1.7;color:#444}
.pd-rev-meta{margin-top:8px;font-size:11px;color:#bbb;display:flex;gap:12px}

/* Q&A */
.pd-qna-item{border-bottom:1px solid #f0f0f0}
.pd-qna-q,.pd-qna-a{display:flex;gap:12px;padding:16px 0}
.pd-qna-badge{width:28px;height:28px;border-radius:50%;background:#000;color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}
.pd-qna-badge-a{background:#00b894}
.pd-qna-q p,.pd-qna-a p{font-size:13px;line-height:1.6}
.pd-qna-q small,.pd-qna-a small{font-size:11px;color:#bbb;display:block;margin-top:4px}
.pd-qna-a{background:#f9f9f9;margin-left:40px;border-radius:6px;padding:12px 16px}

/* Detail images */
.pd-detail-html{padding:30px 0;font-size:14px;line-height:1.8}
.pd-detail-html img{max-width:100%;margin:10px auto;display:block}
.pd-detail-imgs{padding:20px 0;text-align:center}
.pd-detail-imgs img{max-width:100%;margin-bottom:10px}

.pd-empty{text-align:center;padding:40px;color:#bbb;font-size:14px}

/* ============================================
   PRODUCT DETAIL - MOBILE
   ============================================ */
@media(max-width:768px){
  .pd-top{grid-template-columns:1fr;gap:20px}
  .pd-name{font-size:16px}
  .pd-sale{font-size:20px}
  .pd-thumbs{gap:6px}.pd-thumb{width:52px;height:52px}
  .pd-mb-table{font-size:11px}.pd-mb-table th,.pd-mb-table td{padding:6px 4px}
  .pd-spec dt{width:70px;font-size:12px}.pd-spec dd{margin-left:78px;font-size:12px}
  .pd-actions{flex-wrap:wrap}.pd-btn-buy,.pd-btn-cart{flex:1 1 calc(50% - 4px)}.pd-btn-wish{flex:0 0 48px}
  .pd-tabs{top:48px}.pd-tab{font-size:12px;padding:12px 8px}
  .pd-rev-photo{width:100px;height:100px}
  .pd-qna-a{margin-left:20px}
  .pd-cta{font-size:12px;padding:12px}
}

/* ============================================
   CATEGORY PAGE LAYOUT
   ============================================ */
.cat-layout{display:flex;gap:30px;padding-top:20px;min-height:60vh}

/* Sidebar */
.cat-sidebar{width:180px;flex-shrink:0;padding:10px 0;border-right:1px solid #eee}
.cs-lv1{display:block;padding:10px 0;font-size:14px;color:#555;transition:color .2s;border-left:3px solid transparent;padding-left:12px}
.cs-lv1:hover{color:#000}
.cs-lv1.active{color:#000;font-weight:700;border-left-color:#000}
.cs-lv2{display:block;padding:6px 0 6px 28px;font-size:13px;color:#999;transition:color .2s}
.cs-lv2:hover{color:#000}
.cs-lv2.active{color:#000;font-weight:600}

/* Brand filter in sidebar */
.cs-group{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid #eee}
.cs-brand{display:block;padding:6px 12px;font-size:13px;color:#666;transition:.2s}
.cs-brand:hover{color:#000}
.cs-brand.active{color:#000;font-weight:700}
.cs-reset{color:#999;font-size:12px;margin-top:8px}

/* Main area */
.cat-main{flex:1;min-width:0}
.cat-topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #eee}
.cat-title{font-size:16px;font-weight:700;display:flex;align-items:baseline;gap:8px}
.cat-count{font-size:14px;font-weight:400;color:#999}
.cat-sort{padding:8px 12px;border:1px solid #ddd;font-size:12px;background:#fff;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 10 10'%3E%3Cpath d='M5 7L1 3h8z' fill='%23999'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}
.cat-grid{grid-template-columns:repeat(4,1fr)}
.cat-empty{text-align:center;padding:80px 0;color:#bbb;font-size:14px}

/* RESPONSIVE */
@media(max-width:1024px){
  .cat-grid{grid-template-columns:repeat(3,1fr)}
  .cat-sidebar{width:150px}
}
@media(max-width:768px){
  .cat-layout{flex-direction:column;gap:0}
  .cat-sidebar{width:100%;border-right:none;border-bottom:1px solid #eee;padding:10px 0;display:flex;flex-wrap:wrap;gap:0;overflow-x:auto}
  .cs-group{display:flex;flex-wrap:wrap;gap:4px;width:100%;border-bottom:1px solid #eee;padding-bottom:10px;margin-bottom:10px}
  .cs-brand{padding:6px 14px;border:1px solid #eee;border-radius:999px;font-size:11px;white-space:nowrap}
  .cs-brand.active{background:#000;color:#fff;border-color:#000}
  .cs-lv1{border-left:none;padding:8px 14px;white-space:nowrap;font-size:13px;border:1px solid #eee;border-radius:999px;margin:2px}
  .cs-lv1.active{background:#000;color:#fff;border-color:#000}
  .cs-lv2{padding:6px 12px;font-size:12px;border:1px solid #f0f0f0;border-radius:999px;margin:2px;white-space:nowrap}
  .cs-lv2.active{background:#333;color:#fff;border-color:#333}
  .cat-grid{grid-template-columns:repeat(2,1fr)}
  .cat-topbar{flex-direction:column;align-items:flex-start;gap:8px}
}

/* ============================================
   BREADCRUMB
   ============================================ */
.breadcrumb{padding:12px 0;font-size:12px;color:#aaa}
.breadcrumb a{color:#aaa;transition:color .2s}
.breadcrumb a:hover{color:#000}
.breadcrumb span{margin:0 4px}

/* ============================================
   SUB CATEGORY TABS
   ============================================ */
.sub-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-bottom:30px}
.sub-tab{padding:8px 20px;border:1px solid #ddd;border-radius:999px;font-size:12px;color:#777;transition:.2s}
.sub-tab:hover,.sub-tab.active{background:#000;color:#fff;border-color:#000}

/* ============================================
   PAGINATION
   ============================================ */
.pagination{display:flex;justify-content:center;gap:6px;margin-top:30px;padding-bottom:40px}
.pagination a{padding:8px 14px;border:1px solid #ddd;color:#777;font-size:13px;border-radius:4px;transition:.2s}
.pagination a:hover,.pagination a.active{background:#000;color:#fff;border-color:#000}

/* ============================================
   PRODUCT DETAIL
   ============================================ */
.prod-detail{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:20px}
.prod-main-img img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;background:#f3f4f6}
.prod-thumbs{display:flex;gap:8px;margin-top:10px}
.pt-item{width:64px;height:64px;object-fit:cover;border:2px solid transparent;border-radius:4px;cursor:pointer;transition:.2s}
.pt-item.active,.pt-item:hover{border-color:#000}
.prod-brand{font-size:13px;color:#999;margin-bottom:4px}
.prod-name{font-size:20px;font-weight:700;line-height:1.4;margin-bottom:16px}
.prod-price{margin-bottom:20px}
.prod-sale{font-size:24px;font-weight:700}
.prod-orig{font-size:14px;color:#aaa;text-decoration:line-through;margin-left:8px}
.prod-disc{font-size:14px;color:#ff3040;font-weight:700;margin-left:6px}
.prod-actions{display:flex;gap:10px;margin-bottom:24px}
.btn-cart,.btn-buy{flex:1;text-align:center;padding:14px;font-size:14px;font-weight:600;border-radius:4px;transition:.2s}
.btn-cart{border:1px solid #000;color:#000;background:#fff}.btn-cart:hover{background:#f5f5f5}
.btn-buy{background:#000;color:#fff;border:1px solid #000}.btn-buy:hover{background:#222}
.prod-desc{margin-top:20px;padding-top:20px;border-top:1px solid #eee;font-size:14px;line-height:1.8;color:#555}

/* Product Reviews */
.prod-reviews{margin-top:50px;border-top:1px solid #eee;padding-top:30px}
.prod-reviews h3{font-size:16px;font-weight:700;margin-bottom:20px}
.pr-item{border-bottom:1px solid #f0f0f0;padding:16px 0}
.pr-stars{color:#ffd700;margin-bottom:8px}
.pr-photo{width:120px;height:120px;object-fit:cover;border-radius:6px;margin-bottom:8px}
.pr-item p{font-size:13px;line-height:1.6;color:#555}
.pr-item small{font-size:11px;color:#bbb;margin-top:6px;display:block}

/* ============================================
   MOBILE - category/product detail
   ============================================ */
@media(max-width:768px){
  .prod-detail{grid-template-columns:1fr;gap:20px}
  .prod-name{font-size:16px}
  .prod-sale{font-size:20px}
  .sub-tabs{gap:6px}.sub-tab{padding:6px 14px;font-size:11px}
  .breadcrumb{font-size:11px}
}

.no-img{width:100%;height:100%;background:#f0f0f0}

/* 위시리스트 활성 상태 */
.pd-btn-wish.wished{color:#e74c3c;border-color:#e74c3c;background:#fff5f5}
.pd-btn-wish:hover{border-color:#e74c3c;color:#e74c3c}

/* 토스트 메시지 */
.pd-toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);background:#333;color:#fff;padding:12px 28px;border-radius:24px;font-size:14px;z-index:10000;opacity:0;transition:all .3s;pointer-events:none}
.pd-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── 리뷰 개선 ── */
.pd-rev-top{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.pd-rev-name{font-size:12px;color:#999}
.pd-rev-item{padding:20px 0;border-bottom:1px solid #f0f0f0;transition:background .15s}
.pd-rev-item:hover{background:#fafafa}
.pd-rev-photo-thumb{width:80px;height:80px;object-fit:cover;border-radius:6px;margin-top:8px}

/* 리뷰 모달 */
.rv-modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:9999;align-items:center;justify-content:center}
.rv-modal-overlay.open{display:flex}
.rv-modal{background:#fff;border-radius:12px;width:760px;max-width:94vw;max-height:90vh;overflow:hidden;position:relative}
.rv-modal-close{position:absolute;top:14px;right:16px;background:none;border:none;font-size:22px;cursor:pointer;color:#999;z-index:2}
.rv-modal-close:hover{color:#333}
.rv-modal-body{display:flex;min-height:400px}
.rv-modal-img{flex:0 0 50%;background:#f5f5f5;display:flex;align-items:center;justify-content:center}
.rv-modal-img[style*="display: none"] + .rv-modal-info{flex:1;max-width:100%}
.rv-modal-img img{width:100%;height:100%;object-fit:cover}
.rv-modal-info{flex:1;padding:32px 28px;display:flex;flex-direction:column}
.rv-modal-stars{color:#ffb800;font-size:20px;margin-bottom:4px}
.rv-modal-author{font-size:13px;color:#999;margin-bottom:16px}
.rv-modal-content{font-size:14px;line-height:1.8;flex:1;overflow-y:auto;margin-bottom:20px}
.rv-modal-product{display:flex;align-items:center;gap:10px;padding:12px;background:#f8f8f8;border-radius:8px;margin-bottom:12px}
.rv-modal-pthumb{width:44px;height:44px;object-fit:cover;border-radius:4px;border:1px solid #eee}
.rv-modal-product span{font-size:13px;font-weight:500}
.rv-modal-date{font-size:12px;color:#bbb}

@media(max-width:640px){
    .rv-modal-body{flex-direction:column}
    .rv-modal-img{flex:none;height:280px}
    .rv-modal-info{padding:20px}
}

/* ── 실시간 검수 ── */
.qc-item{padding:30px 0;border-bottom:1px solid #f0f0f0}
.qc-title{font-size:16px;font-weight:700;margin-bottom:4px}
.qc-sub{font-size:13px;color:#999;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #eee}
.qc-desc{font-size:14px;color:#555;line-height:1.7;margin-bottom:16px}
.qc-photo{max-width:540px;width:100%;border-radius:4px}
.qc-date{font-size:12px;color:#bbb;margin-top:10px}