/* 제니스허브 건강 매거진 — Heritage Editorial
   (pension-nextjs 디자인 언어 참고: Pretendard + Cormorant Garamond, 테라코타, 웜 페이퍼, 그레인, ledger 룰)
   폰트 self-host (CDN 미사용) */

@font-face{
  font-family:'Pretendard';font-weight:100 900;font-style:normal;font-display:swap;
  src:url('../vendor/fonts/PretendardVariable.woff2') format('woff2-variations');
}
@font-face{font-family:'Cormorant Garamond';font-weight:300;font-style:italic;font-display:swap;src:url('../vendor/fonts/cormorant-300-italic.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-weight:500;font-style:italic;font-display:swap;src:url('../vendor/fonts/cormorant-500-italic.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-weight:500;font-style:normal;font-display:swap;src:url('../vendor/fonts/cormorant-500-normal.woff2') format('woff2')}
@font-face{font-family:'Cormorant Garamond';font-weight:600;font-style:normal;font-display:swap;src:url('../vendor/fonts/cormorant-600-normal.woff2') format('woff2')}

:root{
  --maxw:1200px;--gap:30px;
  --paper:#faf8f5; --ink:#1a1612; --soot:#2a2520;
  --accent:#c8472e; --accent-d:#a13a25; --gold:#b08948;
  --cream:#f4ede0; --muted:#6e655d; --faint:#a2988f;
  --edge:#1f1a14;      /* 진한 헤어라인(카드·룰) */
  --hair:#ddd5c8;      /* 연한 헤어라인 */
  --line:var(--hair);  /* 관리자 인라인 호환 */
  --serif:'Cormorant Garamond',serif;
  --sans:'Pretendard',-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
  margin:0;font-family:var(--sans);color:var(--ink);
  background-color:var(--paper);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.1 0 0 0 0 0.08 0 0 0 0 0.06 0 0 0 0.045 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  font-size:16px;line-height:1.72;letter-spacing:-.005em;word-break:keep-all;
  font-feature-settings:"ss01","tnum","lnum";
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}

/* ---------- header ---------- */
.site-header{background:rgba(250,248,245,.92);backdrop-filter:saturate(160%) blur(6px);
  border-bottom:1px solid var(--edge);position:sticky;top:0;z-index:30}
.header-inner{display:flex;align-items:center;gap:26px;padding:15px 24px;flex-wrap:wrap}
.brand{display:inline-flex;align-items:center;flex-shrink:0}
.brand img{height:30px;width:auto;display:block}
.main-nav{display:flex;gap:22px;flex:1;flex-wrap:wrap}
.main-nav a{color:var(--ink);font-weight:600;font-size:14.5px;letter-spacing:-.01em;position:relative;padding:3px 0}
.main-nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:1.5px;background:var(--accent);transition:right .25s ease}
.main-nav a:hover{color:var(--accent)}
.main-nav a:hover::after{right:0}
.search-box{display:flex;border:1px solid var(--edge);background:transparent;overflow:hidden}
.search-box input{padding:7px 12px;border:0;background:transparent;font:inherit;font-size:13.5px;min-width:0;width:132px}
.search-box input:focus{outline:none}
.search-box button{padding:7px 14px;border:0;background:transparent;border-left:1px solid var(--edge);color:var(--ink);cursor:pointer;font-family:var(--sans);font-weight:600;font-size:13px}
.search-box button:hover{background:var(--ink);color:var(--paper)}
.nav-toggle{display:none;background:0;border:0;font-size:22px;cursor:pointer;color:var(--ink)}

/* 쇼핑몰 버튼 — 항상 눈에 띄게 */
.shop-btn{
  flex-shrink:0;display:inline-flex;align-items:center;gap:0;
  background:var(--accent);color:#fff;font-weight:700;font-size:14px;letter-spacing:.01em;
  padding:10px 18px;border:1px solid var(--accent);transition:.18s;white-space:nowrap;
}
.shop-btn:hover{background:var(--accent-d);border-color:var(--accent-d)}

/* 검색 아이콘(모바일) + dimm 오버레이 */
.search-toggle{display:none;background:0;border:0;cursor:pointer;color:var(--ink);padding:4px;line-height:0}
.search-overlay{
  position:fixed;inset:0;z-index:80;background:rgba(26,22,18,.5);
  -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);
  display:flex;align-items:flex-start;justify-content:center;padding:74px 16px 0;
  opacity:0;visibility:hidden;transition:opacity .28s ease,visibility .28s;
}
body.search-open .search-overlay{opacity:1;visibility:visible}
.search-overlay-form{
  width:100%;max-width:560px;background:var(--paper);border:1px solid var(--edge);
  display:flex;align-items:center;gap:10px;padding:12px 14px;
  transform:translateY(-16px);opacity:.5;transition:transform .3s cubic-bezier(.2,.7,.2,1),opacity .3s;
}
body.search-open .search-overlay-form{transform:translateY(0);opacity:1}
.search-overlay-ico{color:var(--muted);flex-shrink:0}
.search-overlay-form input{flex:1;min-width:0;border:0;background:transparent;font:inherit;font-size:16px;padding:8px 2px;outline:none;color:var(--ink)}
.search-overlay-form button[type=submit]{flex-shrink:0;background:var(--accent);color:#fff;border:0;padding:10px 16px;font-family:var(--sans);font-weight:700;font-size:14px;cursor:pointer}
.search-overlay-close{flex-shrink:0;background:0;border:0;font-size:17px;color:var(--muted);cursor:pointer;padding:6px}

/* 모바일 전역 쇼핑몰 FAB (흰 아이콘 + 시그니처색) */
.shop-fab{display:none}
@media(max-width:600px){
  .shop-fab{
    display:flex;align-items:center;justify-content:center;
    position:fixed;right:16px;bottom:16px;z-index:70;
    width:56px;height:56px;border-radius:50%;background:var(--accent);
    box-shadow:0 8px 22px rgba(200,71,46,.42);transition:transform .15s;
  }
  .shop-fab:active{transform:scale(.94)}
}

/* ---------- eyebrow / kicker ---------- */
.card-cat{
  font-size:10.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  color:var(--accent);display:inline-flex;align-items:center;gap:8px;
}

/* ---------- section title ---------- */
.section-title{
  font-family:var(--sans);font-weight:600;font-size:clamp(22px,2.6vw,30px);
  letter-spacing:-.03em;color:var(--ink);
  margin:56px 0 26px;padding-top:20px;border-top:1.5px solid var(--edge);
  display:flex;align-items:baseline;gap:14px;
}
.section-title::before{
  content:"§";font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:.8em;color:var(--accent);
}

/* ---------- grid + cards (Cormorant 이탤릭 인덱스 넘버 = 시그니처) ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:44px 30px;counter-reset:card}
.card{counter-increment:card;display:flex;flex-direction:column}
.card-thumb{display:block;overflow:hidden;border:1px solid var(--edge);background:var(--cream)}
.card-thumb img{aspect-ratio:16/10;object-fit:cover;width:100%;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.card:hover .card-thumb img{transform:scale(1.04)}
.card-body{padding:16px 2px 0;position:relative}
.card-body::before{
  content:counter(card,decimal-leading-zero);
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:30px;line-height:.8;
  color:var(--accent);display:block;margin-bottom:10px;
}
.card-title{
  font-family:var(--sans);font-weight:600;font-size:18px;line-height:1.44;
  letter-spacing:-.025em;margin:9px 0 8px;
}
.card-title a{background-image:linear-gradient(var(--ink),var(--ink));background-size:0 1px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .3s}
.card:hover .card-title a{background-size:100% 1px}
.card-summary{
  font-size:13.5px;color:var(--muted);margin:0;line-height:1.66;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}

/* ---------- featured hero ---------- */
.featured{margin:36px 0 10px}
.featured-link{
  display:grid;grid-template-columns:1.3fr 1fr;gap:0;
  border:1px solid var(--edge);background:var(--cream);min-height:360px;
}
.featured img{width:100%;height:100%;object-fit:cover;min-height:250px;border-right:1px solid var(--edge)}
.featured-text{padding:42px 44px;display:flex;flex-direction:column;justify-content:center;gap:16px}
.badge{
  align-self:flex-start;font-family:var(--serif);font-style:italic;font-weight:500;
  font-size:19px;color:var(--accent);letter-spacing:0;
}
.featured-text h2{
  font-family:var(--sans);font-weight:700;font-size:clamp(24px,3vw,34px);
  line-height:1.28;margin:0;letter-spacing:-.035em;color:var(--ink);
}
.featured-text p{margin:0;color:var(--muted);font-size:14.5px;line-height:1.7;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* ---------- tag cloud ---------- */
.tagcloud{margin-top:12px}
.tag{
  display:inline-block;margin:6px 8px 0 0;padding:6px 14px;
  border:1px solid var(--hair);font-size:13px;color:var(--muted);font-weight:500;transition:.18s;
}
.tag:hover{border-color:var(--ink);color:var(--ink)}

/* ---------- pagination ---------- */
.pagination{display:flex;gap:4px;justify-content:center;flex-wrap:wrap;margin:50px 0}
.pagination a{
  min-width:42px;text-align:center;padding:9px 13px;border:1px solid var(--hair);
  font-family:var(--serif);font-size:18px;font-weight:500;color:var(--muted);transition:.15s;
}
.pagination a:hover{border-color:var(--ink);color:var(--ink)}
.pagination a.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

.empty{color:var(--muted);padding:64px 0;text-align:center;font-size:15px}

/* ---------- article ---------- */
.article{max-width:720px;margin:16px auto 0}
.article .card-cat{margin-bottom:18px}
.article h1{
  font-family:var(--sans);font-weight:700;font-size:clamp(28px,4.2vw,42px);
  line-height:1.26;margin:8px 0 16px;letter-spacing:-.04em;
}
.article .meta{
  color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  margin-bottom:32px;padding-bottom:22px;border-bottom:1.5px solid var(--edge);
}
.article .content{font-size:17px;line-height:1.9;color:var(--soot)}
.article .content p img,.article .content img{border:1px solid var(--edge);margin:26px auto}
.article .content h2{
  font-family:var(--sans);font-weight:700;font-size:23px;letter-spacing:-.03em;
  margin:46px 0 16px;padding-top:20px;border-top:1px solid var(--hair);color:var(--ink);
}
.article .content h3{font-weight:700;font-size:18px;margin:30px 0 10px;color:var(--accent);letter-spacing:-.01em}
.article .content p{margin:0 0 20px}
.article .content strong{font-weight:700;color:var(--ink)}
.article .content blockquote{
  margin:30px 0;padding:24px 28px;background:var(--cream);border:1px solid var(--edge);
  font-family:var(--serif);font-style:italic;font-weight:500;font-size:21px;line-height:1.6;color:var(--soot);
}
.article .content ul,.article .content ol{margin:0 0 20px;padding-left:22px}
.article .content li{margin-bottom:8px}
.article .content li::marker{color:var(--accent)}
.article .tags{margin-top:42px;border-top:1px solid var(--hair);padding-top:24px}

/* ---------- 기사 하단 쇼핑몰 CTA (멋진 블록) ---------- */
.shop-cta{max-width:720px;margin:54px auto 0}
.shop-cta-inner{
  background:var(--ink);color:var(--paper);padding:38px 40px;position:relative;overflow:hidden;
  border:1px solid var(--ink);
}
.shop-cta-inner::after{
  content:"℞";position:absolute;right:22px;bottom:-22px;font-family:var(--serif);
  font-size:158px;line-height:1;color:rgba(200,71,46,.18);pointer-events:none;
}
.shop-cta-eyebrow{font-size:11px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--accent);margin:0 0 14px;position:relative;z-index:1}
.shop-cta-title{font-family:var(--sans);font-weight:700;font-size:clamp(20px,2.5vw,26px);line-height:1.36;letter-spacing:-.03em;margin:0 0 10px;position:relative;z-index:1}
.shop-cta-desc{margin:0 0 22px;color:rgba(250,248,245,.66);font-size:14px;position:relative;z-index:1}
.shop-cta-btn{
  display:inline-flex;align-items:center;gap:10px;background:var(--accent);color:#fff;
  font-weight:700;font-size:15px;padding:13px 26px;position:relative;z-index:1;transition:.18s;
}
.shop-cta-btn span{transition:transform .2s}
.shop-cta-btn:hover{background:var(--accent-d)}
.shop-cta-btn:hover span{transform:translateX(4px)}

/* ---------- PC 본문: 우측에 따라다니는 멋진 카드 ---------- */
.shop-follow{display:none}
@media(min-width:1200px){
  .shop-follow{
    /* 본문(720px, 중앙정렬) 오른쪽 가장자리에서 24px 간격 두고 따라옴 */
    display:block;position:fixed;top:50%;left:calc(50% + 384px);right:auto;transform:translateY(-50%);z-index:60;
    width:200px;background:var(--ink);color:var(--paper);padding:24px 22px;overflow:hidden;
    box-shadow:0 16px 44px rgba(26,22,18,.3);
  }
  .shop-follow::after{content:"℞";position:absolute;right:10px;bottom:-24px;font-family:var(--serif);font-size:96px;line-height:1;color:rgba(200,71,46,.16);pointer-events:none}
  .shop-follow-eyebrow{display:block;font-size:10px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:11px;position:relative;z-index:1}
  .shop-follow-title{margin:0 0 16px;font-weight:700;font-size:16px;line-height:1.45;letter-spacing:-.02em;position:relative;z-index:1}
  .shop-follow-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;width:100%;background:var(--accent);color:#fff;font-weight:700;font-size:13.5px;padding:12px 14px;position:relative;z-index:1;transition:.18s}
  .shop-follow-btn span{transition:transform .2s}
  .shop-follow-btn:hover{background:var(--accent-d)}.shop-follow-btn:hover span{transform:translateX(3px)}
  .shop-cta{display:none}          /* PC는 팔로우 카드가 대체 */
}

/* ---------- footer ---------- */
.site-footer{border-top:1.5px solid var(--edge);margin-top:72px;padding:34px 0;color:var(--muted);font-size:13px;letter-spacing:.02em}

/* ---------- responsive ---------- */
@media(max-width:900px){
  .grid{grid-template-columns:repeat(2,1fr);gap:40px 26px}
  .featured-link{grid-template-columns:1fr}
  .featured img{max-height:270px;border-right:0;border-bottom:1px solid var(--edge)}
  .featured-text{padding:32px 28px}
}

/* ── 모바일: PC 값 그대로 쓰지 않고 글씨·패딩·간격 축소 ── */
@media(max-width:600px){
  body{font-size:15px}
  .wrap{padding:0 15px}
  /* 헤더: 검색은 아이콘+오버레이로 */
  .header-inner{padding:12px 15px;gap:12px}
  .brand{order:1}.brand img{height:26px}
  .search-toggle{display:inline-block;order:2;margin-left:auto}
  .nav-toggle{display:block;order:3}
  .shop-btn{display:none}    /* 모바일은 우하단 FAB로 대체 */
  .search-box{display:none}
  .main-nav{display:none;order:5;flex-basis:100%;flex-direction:column;gap:12px;padding-top:6px}
  body.nav-open .main-nav{display:flex}
  /* 그리드·카드 */
  .grid{grid-template-columns:1fr;gap:34px}
  .section-title{font-size:19px;margin:40px 0 20px;padding-top:16px;gap:10px}
  .card-body{padding-top:13px}
  .card-body::before{font-size:24px;margin-bottom:7px}
  .card-title{font-size:16.5px}
  .card-summary{font-size:13px}
  /* featured */
  .featured-text{padding:24px 18px;gap:12px}
  .featured-text h2{font-size:21px}
  .featured-text p{font-size:13.5px}
  .badge{font-size:16px}
  /* 본문 */
  .article{margin-top:4px}
  .article .card-cat{margin-bottom:14px}
  .article h1{font-size:25px;line-height:1.3;margin:6px 0 12px}
  .article .meta{font-size:11px;margin-bottom:24px;padding-bottom:18px}
  .article .content{font-size:15.5px;line-height:1.8}
  .article .content h2{font-size:20px;margin:34px 0 12px;padding-top:16px}
  .article .content h3{font-size:16.5px;margin:24px 0 9px}
  .article .content p{margin:0 0 16px}
  .article .content img{margin:18px auto}
  .article .content blockquote{padding:18px 20px;font-size:17px;margin:24px 0}
  .article .content ul,.article .content ol{padding-left:20px}
  .article .tags{margin-top:32px;padding-top:20px}
  /* CTA·기타 */
  .shop-cta{margin-top:40px}
  .shop-cta-inner{padding:28px 22px}
  .shop-cta-title{font-size:20px}
  .shop-cta-desc{font-size:13px;margin-bottom:18px}
  .shop-cta-btn{padding:12px 22px;font-size:14px}
  .shop-cta-inner::after{font-size:120px;right:14px;bottom:-16px}
  .tag{font-size:12.5px;padding:5px 12px}
  .pagination{margin:38px 0}
  .pagination a{min-width:38px;padding:8px 11px;font-size:16px}
  .site-footer{margin-top:52px;padding:26px 0;font-size:12px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
