/* ===== AURÉ — 프리미엄 웰니스 쇼핑몰 디자인시스템 ===== */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.css');
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&display=swap');

:root{
  --ink:#17191e; --ink2:#494c54; --muted:#8c8f98; --faint:#b6b9c0;
  --line:#e8e8ec; --line2:#f0efed;
  --bg:#ffffff; --soft:#f6f5f2; --soft2:#efede8;
  --accent:#e0392b; --accent-deep:#bd2a1e; --accent-soft:#fbeceb;
  --gold:#a98b52;
  --maxw:1480px; --gut:clamp(20px,5vw,72px);
  --r:4px; --r-lg:10px;
  --sh:0 2px 18px rgba(20,22,28,.06); --sh-lg:0 18px 50px rgba(20,22,28,.12);
  --serif:'Cormorant Garamond',serif;
  --t:.45s cubic-bezier(.22,.61,.36,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Pretendard',sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;
  -webkit-font-smoothing:antialiased;letter-spacing:-.2px;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button{font-family:inherit;cursor:pointer;border:none;background:none}
ul{list-style:none}
.wrap{width:90%;max-width:var(--maxw);margin:0 auto}
section{position:relative}

/* tit */
.eyebrow{font-family:var(--serif);font-size:clamp(15px,1.4vw,19px);letter-spacing:1.5px;
  color:var(--accent);font-style:italic;font-weight:500;display:inline-block;margin-bottom:14px}
h1,h2,h3{letter-spacing:-.8px;line-height:1.2;font-weight:700}
.sec-head{text-align:center;margin-bottom:clamp(34px,4vw,58px)}
.sec-head h2{font-size:clamp(26px,3.4vw,42px)}
.sec-head p{color:var(--ink2);margin-top:14px;font-size:clamp(14px,1.1vw,16px)}

/* btn */
.btn{display:inline-flex;align-items:center;gap:9px;padding:15px 32px;font-size:14.5px;font-weight:600;
  border-radius:var(--r);transition:var(--t);letter-spacing:-.3px;white-space:nowrap}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000;transform:translateY(-2px);box-shadow:var(--sh-lg)}
.btn-red{background:var(--accent);color:#fff}
.btn-red:hover{background:var(--accent-deep);transform:translateY(-2px)}
.btn-line{border:1px solid var(--ink);color:var(--ink)}
.btn-line:hover{background:var(--ink);color:#fff}
.btn-ghost{border:1px solid var(--line);color:var(--ink2)}
.btn-ghost:hover{border-color:var(--ink);color:var(--ink)}
.btn .ar{transition:transform .35s}
.btn:hover .ar{transform:translateX(4px)}

/* ============ HEADER ============ */
.topbar{background:var(--ink);color:#cfd0d4;font-size:12.5px}
.topbar .wrap{display:flex;justify-content:flex-end;align-items:center;gap:22px;height:38px}
.topbar a{color:#cfd0d4;transition:color .25s}
.topbar a:hover{color:#fff}
.topbar .sep{width:1px;height:11px;background:#3a3c43}

header.site{position:sticky;top:0;z-index:200;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line);transition:var(--t)}
.hbar{display:flex;align-items:center;justify-content:space-between;height:78px}
.logo{font-family:var(--serif);font-size:30px;font-weight:600;letter-spacing:2px;color:var(--ink)}
.logo b{color:var(--accent);font-weight:600}
.gnb{display:flex;gap:6px}
.gnb>li>a{display:block;padding:0 20px;height:78px;line-height:78px;font-size:15.5px;font-weight:600;
  position:relative;color:var(--ink)}
.gnb>li>a::after{content:'';position:absolute;left:20px;right:20px;bottom:24px;height:2px;background:var(--accent);
  transform:scaleX(0);transition:transform .3s;transform-origin:left}
.gnb>li:hover>a::after{transform:scaleX(1)}
.gnb>li{position:relative}
.drop{position:absolute;top:78px;left:50%;transform:translateX(-50%) translateY(10px);background:#fff;
  min-width:200px;border:1px solid var(--line);box-shadow:var(--sh-lg);padding:12px 0;border-radius:var(--r-lg);
  opacity:0;visibility:hidden;transition:var(--t)}
.gnb>li:hover .drop{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.drop a{display:block;padding:10px 24px;font-size:14px;color:var(--ink2);transition:.2s}
.drop a:hover{background:var(--soft);color:var(--accent);padding-left:30px}
.hicons{display:flex;align-items:center;gap:18px}
.hicons a{position:relative;color:var(--ink);display:flex}
.hicons svg{width:21px;height:21px}
.cart-count{position:absolute;top:-7px;right:-9px;background:var(--accent);color:#fff;font-size:10.5px;
  font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.ham{display:none;flex-direction:column;gap:5px;padding:8px}
.ham span{width:24px;height:2px;background:var(--ink);transition:.3s}

/* mobile drawer */
.mdrawer{position:fixed;inset:0;z-index:300;visibility:hidden;opacity:0;transition:.35s}
.mdrawer.open{visibility:visible;opacity:1}
.mdrawer .ov{position:absolute;inset:0;background:rgba(0,0,0,.45)}
.mdrawer .panel{position:absolute;top:0;right:0;width:min(82vw,360px);height:100%;background:#fff;
  transform:translateX(100%);transition:.4s;padding:26px;overflow-y:auto}
.mdrawer.open .panel{transform:none}
.mdrawer .mhead{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.mdrawer nav a{display:block;padding:15px 4px;font-size:17px;font-weight:600;border-bottom:1px solid var(--line2)}
.mdrawer nav a.sub{font-size:14px;font-weight:500;color:var(--ink2);padding-left:18px}

/* ============ HERO ============ */
.hero{position:relative;height:clamp(540px,82vh,860px);overflow:hidden;background:#000}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1.1s ease;z-index:1}
.hero .slide.on{opacity:1;z-index:2}
.hero .slide img{width:100%;height:100%;object-fit:cover;transform:scale(1.0)}
.hero .slide.on img{animation:kenburns 7s ease-out both}
@keyframes kenburns{from{transform:scale(1.0)}to{transform:scale(1.1)}}
.hero .slide::after{content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,0,0,.55) 0%,rgba(0,0,0,.22) 45%,rgba(0,0,0,0) 75%)}
.hero-txt{position:absolute;z-index:5;top:50%;transform:translateY(-50%);left:0;width:100%}
.hero-txt .wrap{color:#fff}
.hero-txt .et{font-family:var(--serif);font-style:italic;font-size:clamp(18px,2vw,26px);letter-spacing:1px;
  color:#fff;opacity:.9;margin-bottom:16px;display:block}
.hero-txt h2{font-size:clamp(34px,5.4vw,72px);line-height:1.12;font-weight:700;letter-spacing:-1.5px;
  text-shadow:0 2px 30px rgba(0,0,0,.3)}
.hero-txt p{font-size:clamp(15px,1.4vw,19px);margin-top:20px;max-width:440px;color:#eee;line-height:1.6}
.hero-txt .btns{margin-top:34px;display:flex;gap:12px;flex-wrap:wrap}
.hero-txt .btn-red:hover{transform:translateY(-2px)}
.hero-txt .btn-line{border-color:#fff;color:#fff}
.hero-txt .btn-line:hover{background:#fff;color:var(--ink)}
/* promo card */
.promo{position:absolute;z-index:6;left:var(--gut);bottom:50px;background:#fff;border-radius:var(--r-lg);
  padding:22px 24px;width:300px;box-shadow:var(--sh-lg)}
.promo .tag{display:inline-block;background:var(--accent-soft);color:var(--accent);font-size:11.5px;font-weight:700;
  padding:5px 11px;border-radius:20px;margin-bottom:12px}
.promo h4{font-size:19px;letter-spacing:-.6px;margin-bottom:6px}
.promo h4 b{color:var(--accent)}
.promo .d{font-size:12.5px;color:var(--muted)}
.promo a{margin-top:14px;display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--ink)}
/* hero controls */
.hero-dots{position:absolute;z-index:7;right:var(--gut);bottom:54px;display:flex;gap:10px}
.hero-dots button{width:34px;height:3px;background:rgba(255,255,255,.4);transition:.3s}
.hero-dots button.on{background:#fff;width:50px}
.hero-prog{position:absolute;z-index:7;left:0;bottom:0;height:3px;background:var(--accent);width:0}

/* quick thumbs strip */
.qstrip{border-bottom:1px solid var(--line);background:#fff}
.qstrip ul{display:flex;justify-content:center;gap:clamp(20px,4vw,64px);padding:22px 0;flex-wrap:wrap}
.qstrip a{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--ink2);font-size:13.5px;
  font-weight:600;transition:.25s}
.qstrip a:hover{color:var(--accent)}
.qstrip .ic{width:54px;height:54px;border-radius:50%;background:var(--soft);display:flex;align-items:center;
  justify-content:center;transition:.3s}
.qstrip a:hover .ic{background:var(--accent-soft);transform:translateY(-4px)}
.qstrip svg{width:26px;height:26px}

/* ============ COLLECTION ============ */
.pad{padding:clamp(64px,8vw,118px) 0}
.pad-sm{padding:clamp(46px,5vw,76px) 0}
.collection .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.colcard{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/3.6;display:block}
.colcard img{width:100%;height:100%;object-fit:cover;transition:transform .8s}
.colcard:hover img{transform:scale(1.06)}
.colcard::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.62))}
.colcard .c{position:absolute;z-index:2;left:0;bottom:0;padding:30px;color:#fff}
.colcard .n{font-family:var(--serif);font-style:italic;font-size:16px;opacity:.85;margin-bottom:6px}
.colcard h3{font-size:25px;letter-spacing:-.5px}
.colcard .more{margin-top:14px;font-size:13px;font-weight:600;display:inline-flex;gap:7px;align-items:center;
  opacity:0;transform:translateY(8px);transition:.35s}
.colcard:hover .more{opacity:1;transform:none}

/* ============ PRODUCT CARDS ============ */
.ptabs{display:flex;justify-content:center;gap:8px;margin-bottom:38px;flex-wrap:wrap}
.ptabs button{padding:9px 22px;border-radius:30px;font-size:14px;font-weight:600;color:var(--ink2);
  border:1px solid var(--line);transition:.25s}
.ptabs button.on,.ptabs button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.pgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:26px 22px}
.pcard{position:relative;display:block}
.pcard .thumb{position:relative;border-radius:var(--r-lg);overflow:hidden;background:var(--soft);aspect-ratio:1/1;margin-bottom:16px}
.pcard .thumb img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.pcard:hover .thumb img{transform:scale(1.05)}
.pcard .badges{position:absolute;top:12px;left:12px;z-index:2;display:flex;flex-direction:column;gap:6px}
.pcard .bdg{font-size:11px;font-weight:700;padding:4px 9px;border-radius:3px;background:var(--ink);color:#fff}
.pcard .bdg.red{background:var(--accent)}
.pcard .bdg.gold{background:var(--gold)}
.pcard .wish{position:absolute;top:11px;right:11px;z-index:2;width:36px;height:36px;border-radius:50%;
  background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;transition:.25s}
.pcard .wish svg{width:18px;height:18px;stroke:var(--ink2);fill:none;stroke-width:1.7;transition:.25s}
.pcard .wish:hover{background:#fff}
.pcard .wish.on svg{fill:var(--accent);stroke:var(--accent)}
.pcard .cat{font-size:12px;color:var(--muted);margin-bottom:5px;font-weight:500}
.pcard .nm{font-size:16px;font-weight:600;letter-spacing:-.4px;line-height:1.4;margin-bottom:9px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pcard:hover .nm{color:var(--accent)}
.pcard .price{display:flex;align-items:baseline;gap:8px}
.pcard .now{font-size:18px;font-weight:700}
.pcard .was{font-size:13px;color:var(--faint);text-decoration:line-through}
.pcard .off{font-size:13px;font-weight:700;color:var(--accent)}
.pcard .sub{font-size:12.5px;color:var(--ink2);margin-top:5px}
.pcard .sub b{color:var(--accent)}
.pcard .stars{margin-top:8px;font-size:12px;color:var(--muted)}
.pcard .stars i{color:#f5a623;font-style:normal}

/* subscription banner */
.subbar{background:var(--ink);color:#fff;border-radius:var(--r-lg);overflow:hidden;
  display:grid;grid-template-columns:1.2fr 1fr;align-items:center}
.subbar .t{padding:clamp(40px,5vw,68px)}
.subbar .eyebrow{color:#ff7a6e}
.subbar h2{font-size:clamp(26px,3vw,40px);line-height:1.25}
.subbar p{color:#c9cace;margin:18px 0 28px;max-width:420px}
.subbar .img{height:100%;min-height:300px}
.subbar .img img{width:100%;height:100%;object-fit:cover}
.subbar .feats{display:flex;gap:30px;margin-bottom:30px;flex-wrap:wrap}
.subbar .feats .v{font-family:var(--serif);font-size:34px;color:#ff8478;line-height:1}
.subbar .feats .k{font-size:13px;color:#aeb0b5;margin-top:6px}

/* ============ EVENT ============ */
.evgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.evcard{display:block;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);transition:.35s;background:#fff}
.evcard:hover{box-shadow:var(--sh-lg);transform:translateY(-5px)}
.evcard .im{aspect-ratio:3/2;overflow:hidden}
.evcard .im img{width:100%;height:100%;object-fit:cover;transition:.7s}
.evcard:hover .im img{transform:scale(1.06)}
.evcard .b{padding:24px}
.evcard .pd{font-size:12px;color:var(--accent);font-weight:700;letter-spacing:.5px;margin-bottom:9px}
.evcard h3{font-size:19px;letter-spacing:-.5px;margin-bottom:8px}
.evcard p{font-size:14px;color:var(--ink2);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

/* ============ BRAND BAND ============ */
.brand{position:relative;color:#fff;overflow:hidden}
.brand .bg{position:absolute;inset:0}
.brand .bg img{width:100%;height:100%;object-fit:cover}
.brand .bg::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,rgba(15,16,20,.82),rgba(15,16,20,.35))}
.brand .wrap{position:relative;z-index:2;padding:clamp(80px,11vw,150px) 0}
.brand .eyebrow{color:#ff8478}
.brand h2{font-size:clamp(28px,3.8vw,50px);line-height:1.28;max-width:660px}
.brand p{color:#d6d7da;margin:22px 0 0;max-width:520px;font-size:16px}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.stats .s .v{font-family:var(--serif);font-size:clamp(40px,5vw,64px);font-weight:600;color:var(--ink);line-height:1}
.stats .s .v b{color:var(--accent);font-weight:600}
.stats .s .k{font-size:14px;color:var(--ink2);margin-top:10px}

/* ============ CTA band ============ */
.cta{background:var(--soft);text-align:center}
.cta h2{font-size:clamp(26px,3.4vw,44px);line-height:1.25}
.cta .eyebrow{margin-bottom:10px}
.cta p{color:var(--ink2);margin:16px auto 30px;max-width:480px}
.cta .btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============ FOOTER ============ */
footer.site{background:#121317;color:#9b9da4;font-size:13.5px;padding:64px 0 40px}
.fgrid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:40px;padding-bottom:46px;border-bottom:1px solid #26282e}
.fbrand .logo{color:#fff;margin-bottom:16px}
.fbrand p{max-width:280px;line-height:1.7}
.fbrand .sns{display:flex;gap:12px;margin-top:20px}
.fbrand .sns a{width:38px;height:38px;border:1px solid #2e3036;border-radius:50%;display:flex;
  align-items:center;justify-content:center;transition:.25s}
.fbrand .sns a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.fbrand .sns svg{width:17px;height:17px}
.fcol h5{color:#fff;font-size:14.5px;margin-bottom:18px;letter-spacing:-.3px}
.fcol a{display:block;padding:6px 0;transition:.2s}
.fcol a:hover{color:#fff;padding-left:4px}
.fcs{display:flex;align-items:center;gap:10px;margin:8px 0 4px}
.fcs .num{font-family:var(--serif);font-size:30px;color:#fff;font-weight:600}
.fbot{padding-top:26px;font-size:12.5px;line-height:1.9;color:#71747b}
.fbot .pay{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.fbot .pay span{padding:4px 10px;border:1px solid #2e3036;border-radius:4px;font-size:11px}

/* float buttons */
.floats{position:fixed;right:22px;bottom:26px;z-index:150;display:flex;flex-direction:column;gap:10px}
.floats a,.floats button{width:52px;height:52px;border-radius:50%;background:#fff;box-shadow:var(--sh-lg);
  display:flex;align-items:center;justify-content:center;color:var(--ink);transition:.25s;font-size:12px;font-weight:700}
.floats .kakao{background:#FEE500}
.floats a:hover,.floats button:hover{transform:translateY(-3px)}
.floats svg{width:24px;height:24px}
#totop{opacity:0;visibility:hidden;transition:.3s}
#totop.on{opacity:1;visibility:visible}

/* ============ reveal anims ============ */
.rv{opacity:0;transform:translateY(34px);transition:.9s cubic-bezier(.2,.7,.3,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}.rv.d4{transition-delay:.32s}

/* ============ MARQUEE (benefits) ============ */
.marquee{background:var(--ink);color:#fff;overflow:hidden}
.marquee .track{display:flex;width:max-content;animation:scroll 30s linear infinite}
.marquee:hover .track{animation-play-state:paused}
.marquee .track .it{display:inline-flex;align-items:center;gap:13px;padding:17px 38px;font-size:14px;font-weight:600;letter-spacing:.2px;white-space:nowrap}
.marquee .track .it::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--accent)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* product thumb premium refine */
.pcard .thumb{background:linear-gradient(160deg,#f7f6f3,#efece6)}
.pcard .thumb::after{content:'';position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.03);border-radius:var(--r-lg);z-index:1;pointer-events:none}
.colcard,.evcard .im,.pd-gal .main{will-change:transform}

/* hero refine */
.hero-txt h2{font-size:clamp(36px,5.6vw,78px)}
.hero-txt .et{position:relative;padding-left:46px}
.hero-txt .et::before{content:'';position:absolute;left:0;top:50%;width:34px;height:1px;background:rgba(255,255,255,.7)}

/* section heading refine */
.sec-head h2{letter-spacing:-1px}
.eyebrow{position:relative}

/* ============ PAGE: subhero ============ */
.subhero{position:relative;height:340px;display:flex;align-items:center;color:#fff;overflow:hidden;background:#222}
.subhero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.subhero::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.6))}
.subhero .wrap{position:relative;z-index:2}
.subhero .et{font-family:var(--serif);font-style:italic;font-size:20px;opacity:.9}
.subhero h1{font-size:clamp(30px,4vw,52px);margin-top:8px}
.crumb{font-size:13px;color:var(--ink2);padding:18px 0;border-bottom:1px solid var(--line)}
.crumb a:hover{color:var(--accent)}
.crumb span{color:var(--faint);margin:0 8px}

/* ============ PAGE: shop ============ */
.shop-lay{display:grid;grid-template-columns:240px 1fr;gap:46px;align-items:start}
.filter h4{font-size:15px;margin-bottom:14px;padding-bottom:12px;border-bottom:2px solid var(--ink)}
.filter .grp{margin-bottom:30px}
.filter label{display:flex;align-items:center;gap:9px;padding:7px 0;font-size:14px;color:var(--ink2);cursor:pointer;transition:.2s}
.filter label:hover{color:var(--accent)}
.filter input{accent-color:var(--accent);width:16px;height:16px}
.filter label .c{margin-left:auto;font-size:12px;color:var(--faint)}
.shop-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}
.shop-top .cnt{font-size:14px;color:var(--ink2)}
.shop-top .cnt b{color:var(--ink)}
.shop-top select{padding:9px 14px;border:1px solid var(--line);border-radius:var(--r);font-size:14px;color:var(--ink);font-family:inherit}
.shop-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 22px}
.pager{display:flex;justify-content:center;gap:8px;margin-top:56px}
.pager a{width:42px;height:42px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line);
  border-radius:var(--r);font-size:14px;transition:.2s}
.pager a:hover,.pager a.on{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============ PAGE: product detail ============ */
.pd-lay{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.pd-gal .main{border-radius:var(--r-lg);overflow:hidden;background:var(--soft);aspect-ratio:1/1;margin-bottom:14px}
.pd-gal .main img{width:100%;height:100%;object-fit:cover}
.pd-gal .thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.pd-gal .thumbs button{border-radius:var(--r);overflow:hidden;aspect-ratio:1/1;border:2px solid transparent;background:var(--soft)}
.pd-gal .thumbs button.on{border-color:var(--ink)}
.pd-gal .thumbs img{width:100%;height:100%;object-fit:cover}
.pd-info .cat{color:var(--accent);font-weight:700;font-size:13px;margin-bottom:10px}
.pd-info h1{font-size:clamp(24px,2.6vw,34px);letter-spacing:-.8px}
.pd-info .rate{display:flex;align-items:center;gap:10px;margin:14px 0 22px;font-size:13.5px;color:var(--ink2)}
.pd-info .rate i{color:#f5a623;font-style:normal}
.pd-price{padding:22px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pd-price .was{color:var(--faint);text-decoration:line-through;font-size:16px}
.pd-price .row{display:flex;align-items:baseline;gap:12px;margin-top:6px}
.pd-price .off{font-size:24px;font-weight:700;color:var(--accent)}
.pd-price .now{font-size:32px;font-weight:700}
.pd-price .sub{margin-top:14px;background:var(--accent-soft);color:var(--accent-deep);padding:12px 16px;
  border-radius:var(--r);font-size:14px;font-weight:600}
.pd-opt{margin:24px 0}
.pd-opt .lab{font-size:14px;font-weight:600;margin-bottom:10px}
.pd-opt .opts{display:flex;gap:9px;flex-wrap:wrap}
.pd-opt .opts button{padding:11px 18px;border:1px solid var(--line);border-radius:var(--r);font-size:14px;transition:.2s}
.pd-opt .opts button.on{border-color:var(--ink);background:var(--ink);color:#fff}
.qty{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:var(--r)}
.qty button{width:42px;height:46px;font-size:18px;color:var(--ink2)}
.qty input{width:50px;height:46px;text-align:center;border:none;border-left:1px solid var(--line);border-right:1px solid var(--line);font-size:15px;font-family:inherit}
.pd-total{display:flex;justify-content:space-between;align-items:center;padding:20px 0;margin-top:8px;border-top:1px solid var(--line)}
.pd-total .l{font-size:15px;color:var(--ink2)}
.pd-total .v{font-size:28px;font-weight:700}
.pd-total .v small{font-size:15px;font-weight:500}
.pd-acts{display:flex;gap:10px}
.pd-acts .btn{flex:1;justify-content:center;padding:18px}
.pd-acts .wishbig{flex:0 0 56px;border:1px solid var(--line);border-radius:var(--r);display:flex;align-items:center;justify-content:center}
.pd-acts .wishbig svg{width:22px;stroke:var(--ink2);fill:none;stroke-width:1.7}
.pd-acts .wishbig.on svg{fill:var(--accent);stroke:var(--accent)}
.pd-trust{display:flex;gap:24px;margin-top:24px;padding-top:24px;border-top:1px solid var(--line);flex-wrap:wrap}
.pd-trust .it{display:flex;gap:10px;align-items:center;font-size:13px;color:var(--ink2)}
.pd-trust svg{width:22px;color:var(--accent)}
/* tabs */
.pd-tabs{margin-top:80px}
.pd-tabnav{display:flex;border-bottom:1px solid var(--line);gap:0}
.pd-tabnav button{padding:18px 34px;font-size:16px;font-weight:600;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:.2s}
.pd-tabnav button.on{color:var(--ink);border-color:var(--ink)}
.pd-panel{display:none;padding:48px 0}
.pd-panel.on{display:block}
.pd-panel img{border-radius:var(--r-lg);margin:0 auto 22px}
.pd-panel h3{font-size:24px;margin:34px 0 14px}
.pd-panel p{color:var(--ink2);max-width:760px;margin:0 auto 16px;text-align:center}
.specs{max-width:680px;margin:0 auto;border-top:2px solid var(--ink)}
.specs .r{display:flex;border-bottom:1px solid var(--line)}
.specs .k{width:180px;background:var(--soft);padding:15px 20px;font-weight:600;font-size:14px}
.specs .v{padding:15px 20px;font-size:14px;color:var(--ink2)}
/* reviews */
.rev{max-width:780px;margin:0 auto}
.rev .it{padding:24px 0;border-bottom:1px solid var(--line)}
.rev .top{display:flex;justify-content:space-between;margin-bottom:8px}
.rev .nm{font-weight:600;font-size:14px}
.rev .st{color:#f5a623;font-size:13px}
.rev .dt{font-size:12px;color:var(--faint)}
.rev p{font-size:14.5px;color:var(--ink2)}

/* ============ PAGE: cart ============ */
.cart-lay{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.cart-list{border-top:2px solid var(--ink)}
.cart-row{display:grid;grid-template-columns:90px 1fr auto auto auto;gap:18px;align-items:center;
  padding:22px 0;border-bottom:1px solid var(--line)}
.cart-row .im{width:90px;height:90px;border-radius:var(--r);overflow:hidden;background:var(--soft)}
.cart-row .im img{width:100%;height:100%;object-fit:cover}
.cart-row .nm{font-weight:600;font-size:15px;letter-spacing:-.4px}
.cart-row .op{font-size:13px;color:var(--muted);margin-top:5px}
.cart-row .pr{font-weight:700;font-size:16px;white-space:nowrap}
.cart-row .rm{color:var(--faint);font-size:13px;transition:.2s}
.cart-row .rm:hover{color:var(--accent)}
.cart-empty{text-align:center;padding:90px 0;color:var(--muted)}
.cart-empty svg{width:64px;color:var(--faint);margin:0 auto 20px}
.summary{background:var(--soft);border-radius:var(--r-lg);padding:28px;position:sticky;top:100px}
.summary h3{font-size:18px;margin-bottom:20px}
.summary .r{display:flex;justify-content:space-between;padding:9px 0;font-size:14px;color:var(--ink2)}
.summary .tot{border-top:1px solid var(--line);margin-top:12px;padding-top:18px;font-size:16px;color:var(--ink);font-weight:600}
.summary .tot b{font-size:24px;color:var(--accent)}
.summary .btn{width:100%;justify-content:center;margin-top:20px;padding:17px}

/* ============ PAGE: store ============ */
.store-lay{display:grid;grid-template-columns:380px 1fr;gap:30px;align-items:start}
.store-list{max-height:620px;overflow-y:auto;padding-right:6px}
.store-it{padding:20px;border:1px solid var(--line);border-radius:var(--r-lg);margin-bottom:12px;transition:.2s;cursor:pointer}
.store-it:hover,.store-it.on{border-color:var(--ink);box-shadow:var(--sh)}
.store-it .rg{font-size:11.5px;font-weight:700;color:var(--accent);margin-bottom:6px}
.store-it h4{font-size:16px;margin-bottom:7px}
.store-it .ad{font-size:13px;color:var(--ink2);line-height:1.5}
.store-it .tel{font-size:13px;color:var(--ink);font-weight:600;margin-top:8px}
.store-map{border-radius:var(--r-lg);overflow:hidden;height:620px;position:relative;background:var(--soft2)}
.store-map img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3)}
.store-map .pin{position:absolute;top:48%;left:52%;transform:translate(-50%,-100%);color:var(--accent);
  font-size:40px;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3))}
.region-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:20px}
.region-tabs button{padding:8px 18px;border:1px solid var(--line);border-radius:30px;font-size:13.5px;
  font-weight:600;color:var(--ink2);transition:.2s}
.region-tabs button.on,.region-tabs button:hover{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ============ PAGE: support / form ============ */
.faq-it{border-bottom:1px solid var(--line)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:22px 4px;cursor:pointer;font-size:16px;font-weight:600;gap:16px}
.faq-q .qm{color:var(--accent);font-family:var(--serif);font-size:22px;font-weight:600;flex:0 0 24px}
.faq-q .ic{flex:0 0 auto;transition:.3s;color:var(--muted);font-size:22px}
.faq-it.open .faq-q .ic{transform:rotate(45deg);color:var(--accent)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.faq-a div{padding:0 4px 24px 38px;color:var(--ink2);font-size:14.5px;line-height:1.75}
.form-card{background:var(--soft);border-radius:var(--r-lg);padding:clamp(28px,4vw,52px)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field{display:flex;flex-direction:column;gap:8px}
.field.full{grid-column:1/-1}
.field label{font-size:13.5px;font-weight:600}
.field label .req{color:var(--accent)}
.field input,.field select,.field textarea{padding:14px 16px;border:1px solid var(--line);border-radius:var(--r);
  font-size:14.5px;font-family:inherit;background:#fff;transition:.2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--ink)}
.field textarea{resize:vertical;min-height:130px}
.agree{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--ink2);margin-top:6px}
.agree input{width:17px;height:17px;accent-color:var(--accent);margin-top:2px}
.form-msg{margin-top:14px;padding:14px;border-radius:var(--r);font-size:14px;display:none}
.form-msg.ok{display:block;background:#e8f6ec;color:#1d7a3a}
.form-msg.err{display:block;background:var(--accent-soft);color:var(--accent-deep)}

/* info cols on support */
.sup-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sup-card{border:1px solid var(--line);border-radius:var(--r-lg);padding:30px;text-align:center;transition:.3s}
.sup-card:hover{box-shadow:var(--sh-lg);transform:translateY(-4px);border-color:transparent}
.sup-card .ic{width:60px;height:60px;border-radius:50%;background:var(--accent-soft);display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.sup-card .ic svg{width:28px;color:var(--accent)}
.sup-card h4{font-size:18px;margin-bottom:8px}
.sup-card p{font-size:13.5px;color:var(--ink2)}
.sup-card .big{font-family:var(--serif);font-size:26px;color:var(--ink);font-weight:600;margin-top:10px}

/* ============ RESPONSIVE ============ */
@media(max-width:1100px){
  .pgrid{grid-template-columns:repeat(3,1fr)}
  .fgrid{grid-template-columns:1fr 1fr;gap:34px}
  .shop-lay{grid-template-columns:1fr}
  .filter{display:none}
}
@media(max-width:980px){
  .gnb,.topbar{display:none}
  .ham{display:flex}
  .hbar{height:64px}
  .collection .grid{grid-template-columns:1fr 1fr}
  .subbar{grid-template-columns:1fr}
  .subbar .img{min-height:220px;order:-1}
  .pd-lay{grid-template-columns:1fr;gap:34px}
  .cart-lay{grid-template-columns:1fr}
  .store-lay{grid-template-columns:1fr}
  .store-map{height:340px}
  .stats{grid-template-columns:1fr 1fr;gap:34px 20px}
}
@media(max-width:680px){
  .pgrid,.shop-grid,.evgrid,.collection .grid,.sup-cards{grid-template-columns:1fr 1fr;gap:18px}
  .form-grid{grid-template-columns:1fr}
  .promo{display:none}
  .hero{height:78vh}
  .hero-txt p{max-width:none}
  .cart-row{grid-template-columns:70px 1fr;gap:12px}
  .cart-row .pr,.cart-row .qty,.cart-row .rm{grid-column:2}
  .fgrid{grid-template-columns:1fr}
  .pd-tabnav button{padding:14px 18px;font-size:14px}
}
@media(max-width:440px){
  .pgrid,.shop-grid,.evgrid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
}
