/*
Theme Name:  HotClipFolio
Theme URI:   https://hotclipfolio.com
Author:      hotclipfolio
Description: 해외 여행 뷰티·영양제 쇼핑 가이드. 돈키호테 × 쿠팡 가격비교 특화. 완전 반응형.
Version:     3.0.0
License:     GNU General Public License v2
Text Domain: hotclipfolio
Tags:        travel, beauty, supplement, responsive, editorial
*/

/* ============================================================
   TOKENS
   ============================================================ */
:root {
  --cream:       #faf6f1;
  --cream-d:     #f2ebe0;
  --parchment:   #e8ddd0;
  --white:       #ffffff;
  --ink:         #1c1a18;
  --ink-s:       #3d3830;
  --muted:       #8a8278;
  --line:        #ddd3c5;
  --coral:       #d95f3b;
  --coral-p:     #fce9e1;
  --navy:        #1d3557;
  --sage:        #5a7a62;
  --sage-l:      #e6efe8;
  --gold:        #c8973a;
  --gold-l:      #f7edda;
  --coup:        #c8001a;
  --r:           10px;
  --r-s:         6px;
  --sh:          0 2px 16px rgba(28,26,24,.08);
  --sh-lg:       0 8px 36px rgba(28,26,24,.13);
  --t:           .22s ease;
  --max:         1240px;
}

/* ============================================================
   RESET
   ============================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Noto Sans KR',sans-serif;background:var(--cream);color:var(--ink);line-height:1.7;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button{cursor:pointer;border:none;background:none;font-family:inherit}

/* ============================================================
   LAYOUT HELPERS
   ============================================================ */
.wrap{max-width:var(--max);margin:0 auto;padding:0 clamp(16px,4vw,40px)}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}

/* ============================================================
   MASTHEAD
   ============================================================ */
.masthead{
  background:var(--navy);
  padding:6px clamp(16px,4vw,40px);
  display:flex;align-items:center;justify-content:space-between;
}
.masthead-brand{
  font-family:'Playfair Display',serif;
  font-size:10px;letter-spacing:3px;text-transform:uppercase;
  color:rgba(255,255,255,.5);
}
.masthead-date{font-size:10px;color:rgba(255,255,255,.35);letter-spacing:1px}
@media(max-width:480px){.masthead-date{display:none}}

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  background:var(--white);
  border-bottom:2px solid var(--navy);
  position:sticky;top:0;z-index:200;
  box-shadow:0 2px 12px rgba(28,26,24,.06);
  transition:box-shadow var(--t);
}
.site-header.scrolled{box-shadow:0 4px 20px rgba(28,26,24,.12)}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  height:64px;
  max-width:var(--max);margin:0 auto;
  padding:0 clamp(16px,4vw,40px);
  gap:16px;
}

/* Logo */
.logo a{display:flex;flex-direction:column;gap:1px}
.logo-main{
  font-family:'Playfair Display',serif;
  font-size:clamp(18px,2.5vw,22px);font-weight:700;
  color:var(--navy);letter-spacing:-.4px;
  line-height:1.1;
}
.logo-main span{color:var(--coral)}
.logo-sub{font-size:9px;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted);line-height:1}
@media(max-width:380px){.logo-sub{display:none}}

/* Desktop nav */
.site-nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}
.site-nav a{
  padding:6px 11px;font-size:13px;font-weight:500;
  color:var(--ink-s);border-radius:var(--r-s);
  transition:all var(--t);white-space:nowrap;
}
.site-nav a:hover{color:var(--coral);background:var(--coral-p)}
.site-nav .cta a{
  background:var(--coral);color:white;
  padding:7px 14px;border-radius:20px;
}
.site-nav .cta a:hover{background:var(--navy)}

/* Hamburger */
.ham{
  display:none;flex-direction:column;gap:5px;
  padding:6px;border-radius:var(--r-s);
  transition:background var(--t);
  flex-shrink:0;
}
.ham:hover{background:var(--cream-d)}
.ham span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all var(--t)}
.ham.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.ham.active span:nth-child(2){opacity:0;transform:translateX(-4px)}
.ham.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav drawer */
.mobile-nav{
  display:none;position:fixed;
  top:0;right:-100%;bottom:0;
  width:min(300px,80vw);
  background:var(--white);
  box-shadow:-8px 0 32px rgba(0,0,0,.15);
  z-index:300;
  transition:right .3s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;
  padding-top:72px;
}
.mobile-nav.open{right:0}
.mobile-nav ul{padding:16px}
.mobile-nav li{border-bottom:1px solid var(--line)}
.mobile-nav li:last-child{border:none}
.mobile-nav a{
  display:block;padding:14px 12px;
  font-size:14px;font-weight:500;color:var(--ink-s);
  transition:color var(--t);
}
.mobile-nav a:hover{color:var(--coral)}
.mobile-nav-close{
  position:absolute;top:16px;right:16px;
  width:36px;height:36px;border-radius:50%;
  background:var(--cream-d);color:var(--ink-s);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;cursor:pointer;
  transition:background var(--t);
}
.mobile-nav-close:hover{background:var(--coral-p);color:var(--coral)}
.overlay{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.4);z-index:250;
  opacity:0;transition:opacity .3s;
}
.overlay.visible{opacity:1}

@media(max-width:860px){
  .site-nav{display:none}
  .ham{display:flex}
  .mobile-nav{display:block}
}

/* ============================================================
   COUNTRY STRIP
   ============================================================ */
.country-strip{
  background:var(--cream-d);
  border-bottom:1px solid var(--line);
  overflow-x:auto;scrollbar-width:none;
}
.country-strip::-webkit-scrollbar{display:none}
.country-list{
  display:flex;align-items:stretch;
  max-width:var(--max);margin:0 auto;
  padding:0 clamp(16px,4vw,40px);
  gap:0;
}
.country-item{
  display:flex;align-items:center;gap:5px;
  padding:9px 12px;font-size:12px;font-weight:500;
  color:var(--ink-s);white-space:nowrap;
  border-bottom:2px solid transparent;
  transition:all var(--t);
}
.country-item:hover,.country-item.active{color:var(--coral);border-bottom-color:var(--coral)}
.country-flag{font-size:15px;line-height:1}
@media(max-width:640px){.country-item{padding:8px 10px;font-size:11px}}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  background:var(--cream-d);
  border-bottom:1px solid var(--line);
  padding:clamp(40px,7vw,80px) clamp(16px,4vw,40px) clamp(36px,6vw,64px);
  text-align:center;
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(ellipse 65% 50% at 10% 90%,rgba(217,95,59,.07) 0%,transparent 60%),
    radial-gradient(ellipse 55% 35% at 90% 10%,rgba(29,53,87,.06) 0%,transparent 55%);
  pointer-events:none;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:clamp(14px,2vw,20px);
  position:relative;
}
.ey-line{width:clamp(24px,4vw,40px);height:1px;background:var(--coral)}
.ey-text{
  font-size:10px;font-weight:600;letter-spacing:3px;
  text-transform:uppercase;color:var(--coral);
}
.hero h1{
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,5.5vw,58px);
  font-weight:400;line-height:1.12;
  color:var(--ink);margin-bottom:clamp(12px,2vw,18px);
  position:relative;
}
.hero h1 em{font-style:italic;color:var(--coral)}
.hero-lead{
  font-family:'Noto Serif KR',serif;
  font-size:clamp(13px,1.8vw,16px);font-weight:300;
  color:var(--muted);max-width:520px;
  margin:0 auto clamp(20px,3vw,32px);line-height:1.8;
  position:relative;
}
.hero-chips{
  display:flex;flex-wrap:wrap;gap:8px;justify-content:center;
  position:relative;
}
.chip{
  font-size:12px;padding:5px 14px;
  border:1px solid var(--line);border-radius:20px;
  color:var(--muted);background:var(--white);
}
.chip strong{color:var(--ink-s)}

/* ============================================================
   RATE BAR
   ============================================================ */
.rate-bar{
  background:var(--gold-l);
  border-bottom:1px solid rgba(200,151,58,.2);
  padding:9px clamp(16px,4vw,40px);
  display:flex;align-items:center;
  gap:clamp(12px,3vw,28px);flex-wrap:wrap;
  font-size:12px;
}
.rate-item{display:flex;align-items:center;gap:5px}
.rate-lbl{color:var(--muted)}
.rate-val{font-weight:700;color:var(--gold)}

/* ============================================================
   SECTION HEADER
   ============================================================ */
.sec-head{
  display:flex;align-items:center;gap:14px;
  padding:clamp(24px,4vw,40px) 0 clamp(14px,2vw,20px);
}
.sec-icon{font-size:18px;line-height:1}
.sec-label{
  font-family:'Playfair Display',serif;
  font-size:clamp(16px,2.5vw,20px);font-weight:400;
  color:var(--ink);white-space:nowrap;
}
.sec-line{flex:1;height:1px;background:var(--line)}
.sec-sub{font-size:11px;color:var(--muted);letter-spacing:1px;white-space:nowrap}

/* ============================================================
   PRODUCT GRID
   ============================================================ */
.prod-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:clamp(14px,2vw,22px);
}
@media(max-width:640px){
  .prod-grid{grid-template-columns:repeat(2,1fr);gap:12px}
}
@media(max-width:340px){
  .prod-grid{grid-template-columns:1fr}
}

/* ============================================================
   PRODUCT CARD
   ============================================================ */
.pcard{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:var(--r);overflow:hidden;
  display:flex;flex-direction:column;
  position:relative;
  transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.pcard:hover{
  transform:translateY(-5px);
  box-shadow:var(--sh-lg);
  border-color:var(--parchment);
}

/* rank */
.pcard-rank{
  position:absolute;top:10px;left:10px;z-index:10;
  width:26px;height:26px;border-radius:50%;
  background:var(--navy);color:white;
  font-size:11px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 2px 8px rgba(0,0,0,.22);
}
.pcard-rank.hot{background:var(--coral)}

/* image */
.pcard-img{
  height:clamp(150px,22vw,200px);
  background:var(--cream);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;border-bottom:1px solid var(--line);
  position:relative;
}
.pcard-img img{
  max-height:88%;max-width:85%;
  object-fit:contain;
  transition:transform .35s;
}
.pcard:hover .pcard-img img{transform:scale(1.06)}

/* placeholder */
.pcard-ph{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  color:var(--parchment);
}
.pcard-ph svg{width:40px;height:40px}
.pcard-ph span{font-size:10px;color:var(--muted);text-align:center;line-height:1.4}

/* category tag */
.cat-tag{
  position:absolute;bottom:9px;right:9px;
  font-size:9px;font-weight:700;letter-spacing:.4px;
  padding:3px 8px;border-radius:4px;color:white;
  text-transform:uppercase;
}
.t-sun  {background:#2e6b9e}
.t-skin {background:#7b4f9e}
.t-hair {background:#2e7d5e}
.t-supp {background:#c87020}
.t-mask {background:#c83050}

/* body */
.pcard-body{padding:clamp(10px,2vw,14px);flex:1;display:flex;flex-direction:column;gap:9px}
.pcard-name{
  font-family:'Noto Serif KR',serif;
  font-size:clamp(12px,1.5vw,14px);font-weight:600;
  color:var(--ink);line-height:1.45;
}
.pcard-jp{font-size:10px;color:var(--muted);font-weight:300;margin-top:2px;line-height:1.4}

/* price table */
.ptable{
  background:var(--cream);
  border:1px solid var(--parchment);
  border-radius:var(--r-s);overflow:hidden;
  font-size:clamp(11px,1.3vw,12px);
}
.ptrow{
  display:flex;justify-content:space-between;align-items:center;
  padding:6px 10px;border-bottom:1px solid var(--parchment);
}
.ptrow:last-child{border-bottom:none}
.ptrow.save{background:var(--sage-l)}
.pt-lbl{color:var(--muted);display:flex;align-items:center;gap:4px}
.pt-val{font-weight:700}
.v-jpy{color:var(--coral)}
.v-krw{color:var(--ink-s);font-size:10px}
.v-coup{color:var(--coup)}
.v-save{color:var(--sage);font-size:10px}

/* badge */
.coup-badge{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10px;font-weight:600;
  padding:3px 8px;border-radius:4px;
  align-self:flex-start;
}
.b-ok    {background:var(--sage-l);color:var(--sage)}
.b-sim   {background:var(--gold-l);color:var(--gold)}
.b-src   {background:var(--cream-d);color:var(--muted)}

/* links */
.pcard-links{display:flex;flex-direction:column;gap:5px;padding:0 clamp(10px,2vw,14px) clamp(10px,2vw,12px)}
.pbtn{
  display:flex;align-items:center;
  padding:clamp(7px,1vw,9px) 11px;
  border-radius:var(--r-s);
  font-size:clamp(11px,1.3vw,12px);font-weight:600;
  gap:5px;transition:opacity var(--t),box-shadow var(--t);
}
.pbtn:hover{opacity:.87;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.btn-donki{background:var(--navy);color:white}
.btn-coup {background:var(--coup);color:white}
.btn-sim  {background:var(--gold);color:white}
.pbtn-ico{font-size:12px}
.pbtn-lbl{flex:1}
.pbtn-arr{opacity:.6;font-size:10px}

/* note */
.pcard-note{
  font-size:10px;color:var(--muted);
  padding:7px clamp(10px,2vw,14px) 10px;
  border-top:1px solid var(--line);
  line-height:1.6;background:var(--cream);
}

/* ============================================================
   FADE-IN ANIMATION
   ============================================================ */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(18px)}
  to  {opacity:1;transform:translateY(0)}
}
.pcard{animation:fadeUp .45s ease both}
.pcard:nth-child(1) {animation-delay:.04s}
.pcard:nth-child(2) {animation-delay:.08s}
.pcard:nth-child(3) {animation-delay:.12s}
.pcard:nth-child(4) {animation-delay:.16s}
.pcard:nth-child(5) {animation-delay:.20s}
.pcard:nth-child(6) {animation-delay:.24s}
.pcard:nth-child(7) {animation-delay:.28s}
.pcard:nth-child(8) {animation-delay:.32s}
.pcard:nth-child(9) {animation-delay:.36s}
.pcard:nth-child(10){animation-delay:.40s}
.pcard:nth-child(11){animation-delay:.44s}
.pcard:nth-child(12){animation-delay:.48s}
.pcard:nth-child(13){animation-delay:.52s}
.pcard:nth-child(14){animation-delay:.56s}
.pcard:nth-child(15){animation-delay:.60s}

/* ============================================================
   LEGEND BAR
   ============================================================ */
.legend{
  background:var(--white);
  border-bottom:1px solid var(--line);
  padding:10px clamp(16px,4vw,40px);
  display:flex;align-items:center;gap:20px;flex-wrap:wrap;
  font-size:11px;color:var(--ink-s);
}
.legend-title{color:var(--muted);font-weight:500;letter-spacing:.4px}
.ldot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:4px;vertical-align:middle}
.ldot-ok  {background:var(--sage)}
.ldot-sim {background:var(--gold)}
.ldot-src {background:var(--line);border:1px solid var(--muted)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--navy);margin-top:clamp(40px,6vw,64px)}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr;
  gap:clamp(24px,4vw,48px);
  padding:clamp(32px,5vw,52px) clamp(16px,4vw,40px) clamp(28px,4vw,44px);
  max-width:var(--max);margin:0 auto;
}
@media(max-width:720px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr;gap:24px}}

.foot-logo{
  font-family:'Playfair Display',serif;
  font-size:20px;color:white;margin-bottom:10px;
}
.foot-logo span{color:#f0a882}
.foot-desc{font-size:13px;color:rgba(255,255,255,.55);line-height:1.7;margin-bottom:14px}
.foot-social{display:flex;gap:8px}
.foot-social a{
  width:30px;height:30px;border-radius:50%;
  background:rgba(255,255,255,.1);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;transition:background var(--t);
}
.foot-social a:hover{background:var(--coral)}
.foot-col h4{
  font-family:'Playfair Display',serif;
  font-size:13px;font-weight:700;color:white;
  margin-bottom:12px;letter-spacing:.4px;
}
.foot-links{display:flex;flex-direction:column;gap:8px}
.foot-links a{font-size:12px;color:rgba(255,255,255,.48);transition:color var(--t)}
.foot-links a:hover{color:#f0a882}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);
  padding:14px clamp(16px,4vw,40px);
  text-align:center;font-size:11px;color:rgba(255,255,255,.28);
  line-height:1.8;
}
.footer-bottom a{color:rgba(255,255,255,.4)}

/* ============================================================
   SCROLL TO TOP
   ============================================================ */
.scroll-top{
  position:fixed;bottom:24px;right:24px;
  width:42px;height:42px;border-radius:50%;
  background:var(--navy);color:white;
  font-size:16px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:var(--sh-lg);
  opacity:0;pointer-events:none;
  transition:opacity var(--t),transform var(--t);
  z-index:100;cursor:pointer;border:none;
}
.scroll-top.visible{opacity:1;pointer-events:auto}
.scroll-top:hover{background:var(--coral);transform:translateY(-2px)}
@media(max-width:480px){.scroll-top{bottom:16px;right:16px;width:36px;height:36px;font-size:14px}}

/* ============================================================
   MOBILE BOTTOM SAFE AREA
   ============================================================ */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  body{padding-bottom:env(safe-area-inset-bottom)}
}
