/* =====================================================================
   밸롭 리뉴얼 — 메인 페이지 전용
   섹션 순서: 히어로 → 카테고리 바로가기 → BEST(탭) → 신상 → 카테고리 쇼케이스
              → 기획전 배너 → 룩북/인플루언서 → 리뷰 스트립
   ===================================================================== */

/* ---------- HERO ---------- */
.hero{position:relative;}
/* 히어로 이미지를 21:9(배너 비율)로 제작 → 컨테이너도 21:9 → 크롭 0, 전신(얼굴+신발) 항상 노출.
   초광폭에서만 max-height(px)로 약간 조정. */
.hero-slide{position:relative;width:100%;aspect-ratio:21/9;overflow:hidden;display:none;}
.hero-slide.active{display:block;}
.hero-slide img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;}
/* 실제 ballop 배너 적용 시: 자체 카피/그라데이션 숨김(배너에 카피 포함) */
.hero.real .hero-copy{display:none;}
.hero.real .hero-slide::after{background:linear-gradient(0deg,rgba(0,0,0,.18),transparent 40%);}
.hero-slide::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.42),rgba(0,0,0,.05) 55%);}
.hero-copy{position:absolute;z-index:2;left:0;right:0;bottom:clamp(54px,9vw,120px);}
.hero-copy .inner{color:#fff;}
.hero-copy .eyebrow{font-size:14px;font-weight:700;letter-spacing:0.04em;opacity:.92;margin-bottom:14px;}
.hero-copy .tt{font-size:clamp(34px,5.4vw,68px);font-weight:900;line-height:1.08;letter-spacing:-0.05em;}
.hero-copy .st{margin-top:16px;font-size:clamp(15px,1.6vw,19px);font-weight:400;opacity:.92;letter-spacing:-0.02em;}
.hero-copy .btn{margin-top:28px;}
/* 모바일: 21:9 그대로면 너무 납작(390px폭≈167px) → 3:2로 키우고
   세 히어로 모두 피사체가 우측이므로 우측 치우친 크롭 */
@media(max-width:640px){
  .hero-slide{aspect-ratio:3/2;}
  .hero-slide img{object-position:68% center;}
  .hero-copy{bottom:34px;}
  .hero-copy .tt{font-size:27px;}
  .hero-ctrl{bottom:34px;}
}

.hero-ctrl{position:absolute;z-index:3;bottom:clamp(54px,9vw,120px);right:var(--pad);display:flex;align-items:center;gap:14px;color:#fff;}
.hero-dots{display:flex;gap:8px;}
.hero-dots button{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,.45);transition:all .2s var(--ease);}
.hero-dots button.on{width:26px;border-radius:5px;background:#fff;}
.hero-count{font-size:13px;font-weight:600;letter-spacing:0.04em;font-variant-numeric:tabular-nums;}

/* ---------- 브랜드 피처 밴드 (왜 밸롭?) — 컬러 강조로 리듬 부여 ---------- */
.feature-band{background:linear-gradient(120deg,#1a55e5,#1240bb);color:#fff;position:relative;overflow:hidden;}
.feature-band::before{content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;border-radius:50%;
  background:rgba(255,255,255,.07);}
.feature-band::after{content:"";position:absolute;left:-90px;bottom:-140px;width:320px;height:320px;border-radius:50%;
  background:rgba(255,255,255,.06);}
.feature-band .inner{position:relative;z-index:1;padding-block:clamp(44px,6vw,72px);}
.feature-band .fb-head{text-align:center;margin-bottom:clamp(30px,4vw,48px);}
.feature-band .fb-head .k{font-size:12.5px;font-weight:800;letter-spacing:0.1em;opacity:.8;}
.feature-band .fb-head .t{font-size:clamp(24px,3vw,38px);font-weight:900;letter-spacing:-0.04em;margin-top:10px;}
.feature-band .fb-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.feature-band .ft{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--radius-lg);
  padding:30px 24px;text-align:center;backdrop-filter:blur(2px);transition:transform .25s var(--ease),background .25s var(--ease);}
.feature-band .ft:hover{transform:translateY(-5px);background:rgba(255,255,255,.13);}
.feature-band .ft .ic{margin-bottom:16px;display:flex;justify-content:center;}
.feature-band .ft .ic svg{width:40px;height:40px;color:#fff;}
.feature-band .ft .ti{font-size:18px;font-weight:800;letter-spacing:-0.03em;margin-bottom:9px;}
.feature-band .ft .de{font-size:13px;line-height:1.6;color:rgba(255,255,255,.78);}
@media(max-width:880px){.feature-band .fb-grid{grid-template-columns:1fr 1fr;}}

/* 섹션 배경 리듬용 */
.bg-soft{background:var(--soft-2);}

/* 블로그/매거진 배너 (홈 콘텐츠 섹션) */
.blog-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.blog-card{display:block;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line);background:#fff;
  transition:box-shadow .25s var(--ease),transform .25s var(--ease);}
.blog-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px);}
.blog-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;}
.blog-card .bc{padding:22px 24px 26px;}
.blog-card .bc .k{display:block;font-size:12px;font-weight:800;color:var(--accent);letter-spacing:.04em;margin-bottom:10px;}
.blog-card .bc .t{display:block;font-size:clamp(18px,2vw,22px);font-weight:800;letter-spacing:-0.04em;color:var(--ink);line-height:1.3;}
.blog-card .bc .d{display:block;margin-top:10px;font-size:14px;color:var(--muted);}
@media(max-width:760px){.blog-grid{grid-template-columns:1fr;}}

/* ===== 매거진 아티클 (에디토리얼) ===== */
.mag-hero{position:relative;height:clamp(420px,60vh,620px);overflow:hidden;display:flex;align-items:flex-end;}
.mag-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.mag-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.74),rgba(0,0,0,.08) 62%);}
.mag-hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(34px,6vw,72px);color:#fff;}
.mag-hero .mag-cat{font-size:13px;font-weight:800;letter-spacing:.08em;opacity:.92;}
.mag-hero h1{font-size:clamp(30px,5vw,60px);font-weight:900;letter-spacing:-0.045em;line-height:1.12;margin-top:14px;max-width:18ch;}
.mag-hero .mag-sub{margin-top:14px;font-size:clamp(15px,1.8vw,19px);opacity:.92;letter-spacing:-0.02em;}
.mag-meta{margin-top:18px;display:flex;align-items:center;gap:10px;font-size:13px;opacity:.85;}
.mag-meta .dot{opacity:.6;}

.mag-body{max-width:740px;margin:0 auto;padding:clamp(36px,6vw,64px) var(--pad) 24px;}
.mag-lead{font-size:clamp(18px,2.2vw,23px);font-weight:600;line-height:1.65;letter-spacing:-0.03em;color:var(--ink);
  padding-bottom:32px;border-bottom:1px solid var(--line);}
.mb-h{font-size:clamp(21px,2.6vw,28px);font-weight:800;letter-spacing:-0.04em;margin:44px 0 14px;}
.mb-p{font-size:16.5px;line-height:1.95;color:var(--ink);letter-spacing:-0.01em;margin-bottom:8px;}
.mb-img{margin:44px -70px;}
.mb-img img{width:100%;border-radius:var(--radius-lg);display:block;}
.mb-img figcaption{margin-top:13px;font-size:13px;color:var(--sub);text-align:center;}
.mb-quote{margin:48px 0;padding-left:26px;border-left:3px solid var(--accent);}
.mb-quote p{font-size:clamp(20px,2.7vw,29px);font-weight:800;letter-spacing:-0.04em;line-height:1.4;color:var(--ink);}
.mb-quote cite{display:block;margin-top:14px;font-size:13px;font-weight:700;color:var(--accent);font-style:normal;letter-spacing:.02em;}
.mb-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:48px -70px;padding:34px clamp(20px,4vw,50px);
  background:var(--soft);border-radius:var(--radius-lg);text-align:center;}
.mb-stats .ms b{display:block;font-size:clamp(26px,3.6vw,42px);font-weight:900;letter-spacing:-0.04em;color:var(--accent);line-height:1;}
.mb-stats .ms span{display:block;margin-top:9px;font-size:13px;color:var(--muted);}
.mb-split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,38px);align-items:center;margin:48px -70px;}
.mb-split .ms-img img{width:100%;border-radius:var(--radius-lg);display:block;}
.mb-split .ms-txt h3{font-size:clamp(19px,2.2vw,25px);font-weight:800;letter-spacing:-0.04em;margin-bottom:12px;}
.mb-split .ms-txt p{font-size:15.5px;line-height:1.85;color:var(--muted);}
.mag-share{margin-top:50px;padding-top:32px;border-top:1px solid var(--line);text-align:center;}
.mag-share span{display:block;margin-bottom:16px;font-size:15px;color:var(--muted);}
@media(max-width:900px){
  .mb-img,.mb-stats,.mb-split{margin-left:0;margin-right:0;}
  .mb-split{grid-template-columns:1fr;}
}

/* BALLOP IS NOW — 랜딩 인트로 밴드 */
.now-hero{background:linear-gradient(120deg,#1a55e5,#1240bb);color:#fff;text-align:center;position:relative;overflow:hidden;}
.now-hero::before{content:"";position:absolute;right:-120px;top:-120px;width:380px;height:380px;border-radius:50%;background:rgba(255,255,255,.07);}
.now-hero .inner{position:relative;z-index:1;padding-block:clamp(56px,9vw,110px);}
.now-hero .k{font-size:13px;font-weight:800;letter-spacing:0.1em;opacity:.85;}
.now-hero h1{font-size:clamp(36px,7vw,84px);font-weight:900;letter-spacing:-0.05em;line-height:1;margin-top:14px;}
.now-hero p{margin-top:18px;font-size:clamp(15px,1.8vw,19px);opacity:.92;letter-spacing:-0.02em;}

/* BALLOP IS NOW (브랜드 콘텐츠) */
.now-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.now-card{display:block;}
.now-card .now-img{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:4/5;background:var(--soft);}
.now-card .now-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.now-card:hover .now-img img{transform:scale(1.04);}
.now-card .now-cat{position:absolute;top:14px;left:14px;z-index:2;font-size:11px;font-weight:800;letter-spacing:.06em;
  color:#fff;background:rgba(21,23,26,.55);backdrop-filter:blur(4px);padding:6px 11px;border-radius:999px;}
.now-card .now-info{padding:16px 4px 0;}
.now-card .now-info .nt{display:block;font-size:17px;font-weight:800;letter-spacing:-0.03em;color:var(--ink);line-height:1.3;}
.now-card .now-info .nd{display:block;margin-top:7px;font-size:13.5px;color:var(--muted);line-height:1.5;}
.now-card:hover .now-info .nt{color:var(--accent);}
@media(max-width:880px){.now-grid{grid-template-columns:1fr;}}

/* 브랜드 영상 (유튜브 16:9 반응형) */
.video-wrap{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius-lg);overflow:hidden;background:#000;box-shadow:var(--shadow-lg);}
.video-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* ---------- 카테고리 바로가기 (아이콘 칩) ---------- */
.cat-quick{border-bottom:1px solid var(--line);}
.cat-quick .inner{display:flex;justify-content:center;gap:clamp(18px,3vw,44px);padding-block:22px;overflow-x:auto;scrollbar-width:none;}
.cat-quick .inner::-webkit-scrollbar{display:none;}
.cat-quick a{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:7px;min-width:56px;padding:4px;}
.cat-quick .ic{width:45px;height:45px;border-radius:50%;background:var(--soft);display:flex;align-items:center;justify-content:center;
  transition:all .2s var(--ease);}
.cat-quick .ic svg{width:20px;height:20px;color:var(--ink);transition:color .2s var(--ease);}
.cat-quick a:hover .ic{background:var(--accent-soft);transform:translateY(-3px);}
.cat-quick a:hover .ic svg{color:var(--accent);}
.cat-quick .lb{font-size:13px;font-weight:600;color:var(--ink);}

/* ---------- BEST 탭 ---------- */
.tabs{display:flex;gap:8px;justify-content:center;margin-bottom:34px;flex-wrap:wrap;}
.tabs button{height:42px;padding:0 22px;border-radius:999px;font-size:14.5px;font-weight:700;color:var(--muted);
  border:1.5px solid var(--line);background:#fff;transition:all .2s var(--ease);}
.tabs button:hover{border-color:var(--ink);color:var(--ink);}
.tabs button.on{background:var(--ink);border-color:var(--ink);color:#fff;}

/* ---------- 카테고리 쇼케이스 (대형 이미지 카드) ---------- */
.show-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;}
.show-card{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:16/10;display:block;}
.show-card:first-child{grid-row:span 2;aspect-ratio:auto;}
.show-card img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease);}
.show-card:hover img{transform:scale(1.05);}
.show-card::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.5),transparent 55%);}
.show-card .cap{position:absolute;z-index:2;left:28px;bottom:26px;color:#fff;}
.show-card .cap .k{font-size:13px;font-weight:700;opacity:.9;letter-spacing:0.04em;margin-bottom:8px;}
.show-card .cap .t{font-size:clamp(22px,2.4vw,30px);font-weight:800;letter-spacing:-0.04em;}
.show-card .cap .go{display:inline-flex;align-items:center;gap:6px;margin-top:12px;font-size:13px;font-weight:600;
  opacity:.92;}
@media(max-width:880px){
  .show-grid{grid-template-columns:1fr;}
  .show-card:first-child{grid-row:auto;aspect-ratio:16/10;}
}

/* ---------- 기획전 와이드 배너 ---------- */
.promo{position:relative;border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:24/7;display:flex;align-items:center;}
.promo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.promo::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(0,0,0,.45),transparent 60%);}
.promo .pc{position:relative;z-index:2;color:#fff;padding-inline:clamp(28px,5vw,72px);}
.promo .pc .k{font-size:13px;font-weight:700;opacity:.9;margin-bottom:10px;letter-spacing:0.04em;}
.promo .pc .t{font-size:clamp(24px,3.2vw,44px);font-weight:900;line-height:1.1;letter-spacing:-0.04em;}
.promo .pc .btn{margin-top:22px;}
@media(max-width:680px){.promo{aspect-ratio:4/3;}}

/* ---------- 룩북 / 인플루언서 스타일컷 ---------- */
.look-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px 16px;}
.look-card{display:block;}
.look-card .look-img{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;}
.look-card .look-img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.look-card:hover .look-img img{transform:scale(1.05);}
.look-card .tag{position:absolute;left:12px;bottom:12px;z-index:2;display:flex;align-items:center;gap:7px;
  color:#fff;font-size:13px;font-weight:600;text-shadow:0 1px 6px rgba(0,0,0,.4);}
.look-card .tag::before{content:"";width:24px;height:24px;border-radius:50%;background:rgba(255,255,255,.35);flex-shrink:0;}
/* 착샷 아래 제품 정보 (대표 썸네일 + 이름/가격, 클릭 시 해당 상품 상세로) */
.look-card .look-info{padding:11px 2px 0;display:flex;align-items:center;gap:10px;}
.look-card .look-info .lthumb{width:46px;height:46px;flex-shrink:0;border-radius:8px;object-fit:cover;
  background:var(--soft);border:1px solid var(--line);}
.look-card .look-info .ltxt{min-width:0;}
.look-card .look-info .ln{display:block;font-size:13px;font-weight:600;color:var(--ink);line-height:1.3;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.look-card .look-info .lp{display:block;font-size:13.5px;font-weight:800;color:var(--ink);margin-top:3px;}
.look-card:hover .look-info .ln{color:var(--accent);}
@media(max-width:880px){.look-grid{grid-template-columns:repeat(2,1fr);}}

/* ---------- 리뷰 스트립 ---------- */
.review-strip{background:var(--soft);overflow:hidden;}
/* 무한 마퀴 (왼쪽으로 천천히 이동, 호버 시 일시정지) */
.review-marquee{overflow:hidden;margin-top:8px;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.rv-track{display:flex;gap:16px;width:max-content;animation:rvscroll 60s linear infinite;}
.rv-track:hover{animation-play-state:paused;}
@keyframes rvscroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.rv-track{animation:none;}}
.rv-card{flex:0 0 auto;width:330px;background:#fff;border-radius:var(--radius);padding:22px;border:1px solid var(--line);}
.rv-card .stars{color:#ffb300;font-size:14px;letter-spacing:2px;}
.rv-card .txt{margin-top:12px;font-size:14px;color:var(--ink);line-height:1.6;min-height:66px;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;}
/* 상품 썸네일(원형) + 제품명 */
.rv-card .rv-prod{margin-top:16px;padding-top:15px;border-top:1px solid var(--line);display:flex;align-items:center;gap:11px;}
.rv-card .rv-prod img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--line);background:var(--soft);flex-shrink:0;}
.rv-card .rv-prod .rp-info{display:flex;flex-direction:column;min-width:0;}
.rv-card .rv-prod .rp-info b{font-size:13px;font-weight:700;color:var(--ink);}
.rv-card .rv-prod .rp-info em{font-size:12.5px;color:var(--muted);font-style:normal;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rv-card:hover .rv-prod .rp-info em{color:var(--accent);}

/* ---------- 최저가보장: 멤버십 8% 가격 구조 ---------- */
.gp-calc{display:flex;align-items:stretch;justify-content:center;gap:14px;flex-wrap:wrap;}
.gp-calc .gc-step{flex:1;min-width:180px;max-width:280px;background:#fff;border:1.5px solid var(--line);border-radius:var(--radius-lg);
  padding:26px 22px;text-align:center;display:flex;flex-direction:column;gap:9px;justify-content:center;}
.gp-calc .gc-step .gc-lb{font-size:13px;font-weight:600;color:var(--muted);}
.gp-calc .gc-step .gc-v{font-size:clamp(22px,2.6vw,30px);font-weight:900;letter-spacing:-0.04em;color:var(--ink);}
.gp-calc .gc-step.accent{border-color:var(--accent);}
.gp-calc .gc-step.accent .gc-v{color:var(--accent);}
.gp-calc .gc-step.final{background:var(--accent);border-color:var(--accent);}
.gp-calc .gc-step.final .gc-lb{color:rgba(255,255,255,.85);}
.gp-calc .gc-step.final .gc-v{color:#fff;}
.gp-calc .gc-arrow{align-self:center;font-size:22px;color:var(--sub);font-weight:700;}
.gc-note{margin-top:18px;text-align:center;font-size:13.5px;color:var(--muted);}
.gc-note b{color:var(--accent);}
@media(max-width:760px){.gp-calc{flex-direction:column;align-items:stretch;}.gp-calc .gc-step{max-width:none;}.gp-calc .gc-arrow{transform:rotate(90deg);}}
