/*
Theme Name: Leon Cellar
Theme URI: https://leoncellar.com
Description: leoncellar.com 전용 차일드 테마. 부모 = Astra. 시안(랜딩·아카이브·리뷰)을 1:1로 구현한다.
Author: Leon
Template: astra
Version: 0.9.26
Text Domain: leoncellar
*/

/* ===================================================================
   디자인 시스템 토큰 (시안 공용)
   =================================================================== */
:root{
  --serif:'Cormorant Garamond','Noto Serif KR',Georgia,serif;
  --serif-ko:'Noto Serif KR',Georgia,serif;
  --sans:'Noto Sans KR',-apple-system,'Helvetica Neue',sans-serif;
  --maxw:1180px;
  --edge:max(24px, calc(50vw - 566px));
  --bg:#faf7f2;--surface:#fff;--surface2:#f3eee6;--text:#211c18;--muted:#6f655a;--line:#e7e0d4;
  --wine:#7b1e2b;--wine-soft:#9d4452;--gold:#9c7b45;
  --d-bg:#190b10;--d-surface:#251218;--d-text:#f1e7e9;--d-muted:#b29aa1;--d-line:#3c2530;--d-wine:#c66576;--d-gold:#cba96c;
  --shadow:0 10px 34px rgba(40,20,15,.12);
}

/* ===================================================================
   리셋 · 베이스
   =================================================================== */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--sans);font-weight:300;line-height:1.6;-webkit-font-smoothing:antialiased}
body.lc{background:var(--bg)} /* Astra .ast-separate-container(#F0F5FA) 덮기 — 클래스 specificity 확보 */
body.error404{background:var(--d-bg)} /* 404는 전체 다크(헤더·푸터 색과 통일) */
body.error404 .page-body p{color:var(--d-text)}
body.error404 .arch-hero h1{font-size:16px;letter-spacing:.1em;font-weight:600}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.btn{display:inline-block;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:#fff;background:var(--wine);padding:13px 26px;border-radius:999px;transition:.25s;border:1px solid transparent}
.btn:hover{background:var(--wine-soft);transform:translateY(-2px)}

/* ===================================================================
   헤더 (고정 · 다크 히어로 위 오버레이 → 스크롤 시 라이트)
   =================================================================== */
header{position:fixed;top:0;left:0;right:0;z-index:60;transition:background .35s,box-shadow .35s,border-color .35s;border-bottom:1px solid transparent}
.nav{display:flex;align-items:center;justify-content:space-between;height:70px;max-width:var(--maxw);margin:0 auto;padding:0 24px}
.logo{font-family:var(--serif);font-weight:600;font-size:23px;letter-spacing:.18em;color:#f1e7e9;transition:color .35s}
.logo b{color:var(--d-gold);font-weight:600;transition:color .35s}
.rightnav{display:flex;align-items:center;gap:28px}
nav.links{display:flex;gap:28px;align-items:center}
.navitem{position:relative}
.navitem>a,.navitem>span{font-size:13px;letter-spacing:.1em;text-transform:uppercase;color:rgba(241,231,233,.88);cursor:pointer;display:inline-flex;align-items:center;gap:5px;transition:color .25s}
.navitem>span i{font-style:normal;font-size:9px;opacity:.7}
.navitem:hover>a,.navitem:hover>span{color:#fff}
.dd{position:absolute;top:calc(100% + 12px);right:0;background:var(--surface);border:1px solid var(--line);border-radius:11px;padding:7px 0;min-width:150px;opacity:0;visibility:hidden;transform:translateY(6px);transition:.22s;box-shadow:var(--shadow)}
.navitem:hover .dd{opacity:1;visibility:visible;transform:translateY(0)}
.dd a{display:block;padding:10px 20px;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text)}
.dd a:hover{color:var(--wine);background:var(--surface2)}
.util{display:flex;align-items:center;gap:14px}
.util .ic{font-size:12px;letter-spacing:.06em;color:rgba(241,231,233,.65);cursor:pointer;transition:color .25s}
.ham{display:none;background:none;border:none;color:#f1e7e9;font-size:23px;cursor:pointer}
.leftnav{display:flex;align-items:center;gap:20px;flex:1 1 auto;max-width:560px;min-width:0}
.nav .search{display:flex;align-items:center;gap:8px;border:1px solid rgba(241,231,233,.14);border-radius:13px;padding:4px 22px;background:rgba(255,255,255,.03);transition:border-color .25s,background .35s;flex:1 1 auto;min-width:0}
.nav .search:focus-within{border-color:var(--d-gold)}
.nav .search svg{width:15px;height:15px;color:rgba(241,231,233,.7);flex:0 0 auto}
.nav .search input{background:none;border:0;outline:0;color:#f1e7e9;font-size:13px;flex:1 1 auto;min-width:0;font-family:var(--sans);font-weight:300}
.nav .search input::placeholder{color:rgba(241,231,233,.5)}
header.scrolled .search{border-color:var(--line);background:var(--surface2)}
header.scrolled .search svg{color:var(--muted)}
header.scrolled .search input{color:var(--text)}
header.scrolled .search input::placeholder{color:var(--muted)}
.msearch{display:none;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;border:1px solid rgba(241,231,233,.3);background:rgba(255,255,255,.06);color:#f1e7e9;cursor:pointer}
.msearch svg{width:17px;height:17px;flex:0 0 auto}
header.scrolled .msearch{border-color:var(--line);background:var(--surface2);color:var(--text)}

/* 헤더 검색 — 아일랜드 모프(돋보기 탭 → 검은 헤더가 아래로 한 줄 확장 + 본문 딤) */
.msearch .i-close{display:none}
#hd.search-open{background:#000}
#hd.search-open .msearch .i-mag{display:none}
#hd.search-open .msearch .i-close{display:block;font-size:24px;line-height:1;color:#f1e7e9}
.hsearch{overflow:hidden;height:0;background:#000;transition:height .42s cubic-bezier(.22,1,.36,1)}
#hd.search-open .hsearch{height:64px;border-radius:0 0 22px 22px;box-shadow:0 14px 26px rgba(0,0,0,.28)}
.hsearch-form{max-width:var(--maxw);margin:0 auto;height:64px;display:flex;align-items:center;padding:0 16px}
.hsearch-pill{flex:1;display:flex;align-items:center;gap:9px;height:42px;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.05);border-radius:999px;padding:0 16px;opacity:0;transform:translateY(-6px);transition:opacity .3s .12s,transform .34s .12s cubic-bezier(.22,1,.36,1),border-color .25s}
#hd.search-open .hsearch-pill{opacity:1;transform:none}
.hsearch-pill:focus-within{border-color:var(--d-gold)}
.hsearch-pill svg{width:16px;height:16px;color:rgba(241,231,233,.55);flex:0 0 auto}
.hsearch-pill input{flex:1;min-width:0;border:0;outline:none;color:#f1e7e9;font-family:var(--sans);font-weight:300;font-size:15px;-webkit-appearance:none!important;appearance:none!important;background:transparent!important;box-shadow:none!important}
.hsearch-pill input::-webkit-search-decoration,.hsearch-pill input::-webkit-search-cancel-button{-webkit-appearance:none}
.hsearch-pill input::placeholder{color:rgba(241,231,233,.45)}
.hsearch-dim{position:fixed;inset:0;background:rgba(0,0,0,.42);opacity:0;visibility:hidden;transition:opacity .35s,visibility .35s;z-index:55}
body.search-dim .hsearch-dim{opacity:1;visibility:visible}
header.scrolled{background:rgba(250,247,242,.9);backdrop-filter:blur(12px);border-bottom-color:var(--line);box-shadow:0 2px 20px rgba(40,20,15,.05)}
header.scrolled .logo{color:var(--text)} header.scrolled .logo b{color:var(--wine)}
header.scrolled .navitem>a,header.scrolled .navitem>span{color:var(--text)} header.scrolled .navitem:hover>a,header.scrolled .navitem:hover>span{color:var(--wine)}
header.scrolled .util .ic{color:var(--muted)} header.scrolled .ham{color:var(--text)}

/* 라이트 본문(히어로 없는 페이지)에서는 헤더를 처음부터 라이트 상태로 */
body.lc-light-header header{background:rgba(250,247,242,.9);backdrop-filter:blur(12px);border-bottom-color:var(--line);box-shadow:0 2px 20px rgba(40,20,15,.05)}
body.lc-light-header header .logo{color:var(--text)} body.lc-light-header header .logo b{color:var(--wine)}
body.lc-light-header header .navitem>a,body.lc-light-header header .navitem>span{color:var(--text)}
body.lc-light-header header .util .ic{color:var(--muted)} body.lc-light-header header .ham{color:var(--text)}
body.lc-light-header header .search{border-color:var(--line);background:var(--surface2)}
body.lc-light-header header .search svg,body.lc-light-header header .search input{color:var(--text)}

/* 워드프레스 관리자 바와 고정 헤더 겹침 방지 */
.admin-bar header{top:32px}

/* ===================================================================
   다크 클로징 밴드 + 푸터 (시안 공용)
   =================================================================== */
.band-dark{background:var(--d-bg)}
.closing{padding:70px 0 0;margin-top:54px}
.about-inner{padding-bottom:56px;border-bottom:1px solid var(--d-line);text-align:center}
.about-inner .quote{font-family:var(--serif-ko);font-size:23px;font-weight:500;line-height:1.55;max-width:none;color:#fff}
.about-inner .quote .w{color:var(--d-wine)}
footer.wrap{padding:14px 24px 40px;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px;color:var(--d-muted);font-size:12px;letter-spacing:.06em}
footer .flog{font-family:var(--serif);font-size:20px;color:var(--d-text);letter-spacing:.16em;justify-self:start;cursor:pointer}
footer .fcopy{justify-self:center;letter-spacing:.08em}
footer .fright{display:flex;gap:28px;text-transform:uppercase;justify-self:end}
footer a:hover{color:var(--d-wine)}

/* ===================================================================
   스크롤 등장
   =================================================================== */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ===================================================================
   셸 미리보기 데모 (임시 — front-page.php 완성 시 제거)
   =================================================================== */
.shell-hero{min-height:62vh;display:flex;align-items:center;padding:150px 0 90px}
.shell-hero .eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--d-gold);font-weight:500;margin-bottom:16px}
.shell-hero h1{font-family:var(--serif);font-weight:600;font-size:54px;line-height:1.08;letter-spacing:.04em;color:#fff;margin-bottom:16px}
.shell-hero p{color:var(--d-muted);font-size:15px;max-width:42em;line-height:1.7}
.shell-body .block{padding:58px 0}
.shell-body h2{font-family:var(--serif);font-weight:600;font-size:30px;margin-bottom:16px}
.shell-body p{color:var(--muted);max-width:46em}

/* ===================================================================
   반응형 (헤더 · 푸터)
   =================================================================== */
@media(max-width:860px){
  nav.links{display:none}.ham{display:block}.rightnav{gap:14px}.nav .search{display:none}.util .ic{display:none}.util{gap:8px}
  .msearch,
  header.scrolled .msearch,
  body.lc-light-header header .msearch{display:flex;width:34px;height:34px;align-items:center;justify-content:center;border:0;background:none;border-radius:0;color:#f1e7e9}
  .nav{padding:0 16px}
  .logo{font-size:16px;letter-spacing:.06em}
  nav.links.open{display:flex;position:absolute;top:70px;left:0;right:0;flex-direction:column;gap:0;background:var(--surface);border-bottom:1px solid var(--line);padding:8px 0}
  nav.links.open .navitem>a,nav.links.open .navitem>span{padding:14px 24px;border-top:1px solid var(--line);color:var(--text);display:flex}
  nav.links.open .dd{position:static;opacity:1;visibility:visible;transform:none;border:none;box-shadow:none;padding:0;background:transparent;min-width:0}
  nav.links.open .dd a{padding:12px 40px;color:var(--muted);border-top:1px solid var(--line)}
  footer.wrap{grid-template-columns:1fr auto;justify-items:stretch;align-items:center;text-align:left;row-gap:14px;column-gap:14px;padding:18px 24px 38px}
  footer .flog{grid-column:1;grid-row:1;justify-self:start;font-size:17px}
  footer .fright{grid-column:2;grid-row:1;justify-self:end;gap:16px}
  footer .fcopy{grid-column:1/-1;grid-row:2;justify-self:center;text-align:center}
  .shell-hero h1{font-size:38px}
}
@media(max-width:782px){.admin-bar header{top:46px}}

/* 모바일 다크 헤더 — 라이트 상태(스크롤·내부페이지) 헤더를 순검정으로 = 다이내믹 아일랜드 위장. */
@media(max-width:520px){
  header.scrolled,
  body.lc-light-header header{background:#000;border-bottom-color:transparent;box-shadow:0 2px 18px rgba(0,0,0,.22);backdrop-filter:none}
  header.scrolled .logo,
  body.lc-light-header header .logo{color:#f1e7e9}
  header.scrolled .logo b,
  body.lc-light-header header .logo b{color:var(--d-gold)}
  header.scrolled .ham,
  body.lc-light-header header .ham{color:#f1e7e9}
}
/* ===================================================================
   랜딩(front-page) — 히어로 슬라이더
   =================================================================== */
.hero{position:relative;overflow:hidden;background:var(--d-bg)}
.track{display:flex;transition:transform .7s cubic-bezier(.4,0,.2,1);touch-action:pan-y}
.slide{flex:0 0 100%;min-width:100%}
.slide-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr .82fr;min-height:clamp(560px,76vh,840px)}
.htext{display:flex;flex-direction:column;justify-content:center;padding:120px 40px 80px 24px}
.eyebrow{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--d-gold);font-weight:500;margin-bottom:18px}
.slide h1{font-family:var(--serif);font-weight:600;font-size:46px;line-height:1.08;letter-spacing:.005em;margin-bottom:8px;color:#fff;max-width:13em}
.slide .ko{font-family:var(--serif-ko);font-size:18px;font-weight:500;color:var(--d-gold);margin-bottom:22px}
.winecard{margin-bottom:22px;padding:20px 22px;border:1px solid var(--d-line);border-radius:13px;background:rgba(255,255,255,.025);max-width:560px}
.wc-meta{display:grid;grid-template-columns:1fr 1fr;gap:13px 26px;margin-bottom:18px}
.wc-meta .l{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--d-gold);display:block;margin-bottom:3px}
.wc-meta .v{font-size:13.5px;color:#f1e7e9}
.gauges{display:grid;grid-template-columns:1fr 1fr;gap:12px 26px}
.g{display:flex;align-items:center;gap:11px}
.g .gl{font-size:11px;letter-spacing:.05em;color:var(--d-muted);width:66px;flex:0 0 auto}
.g .bar{flex:1;height:4px;border-radius:3px;background:rgba(255,255,255,.13);overflow:hidden}
.g .bar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--d-gold),var(--d-wine));width:0}
.slide .btn{display:none}/* Read the Review 버튼 제거 — 이미지 클릭으로 진입 */
.himg{position:relative;overflow:hidden}
.himg .pic{position:absolute;inset:0;background-size:cover;background-position:center 28%;transform:scale(1.02);transition:transform 1s cubic-bezier(.2,.7,.2,1);will-change:transform}
.himg:hover .pic{transform:scale(1.11)}/* 랩탑: 사진에 마우스 올리면 살짝 확대 */
.himg-go{display:flex;position:absolute;inset:0;z-index:6;align-items:center;justify-content:center;color:#fff;cursor:pointer}
.himg-go svg{display:none;width:80px;height:80px;opacity:.5;filter:drop-shadow(0 2px 12px rgba(0,0,0,.55));transition:opacity .2s,transform .2s}/* 랩탑: 화살표 없음(사진 클릭 진입) — 모바일에서만 표시 */
.himg-go:active svg{opacity:.78;transform:scale(.94)}
@keyframes ken{0%{transform:scale(1.04)}100%{transform:scale(1.13)}}
.slide .anim{opacity:0;transform:translateY(26px)}
.slide.active .anim{animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.slide.active .anim.d1{animation-delay:.12s}.slide.active .anim.d2{animation-delay:.24s}.slide.active .anim.d3{animation-delay:.36s}.slide.active .anim.d4{animation-delay:.48s}
.slide.active .g .bar i{animation:fill 1.2s cubic-bezier(.2,.8,.2,1) both}
.slide.active .gauges .g:nth-child(1) .bar i{animation-delay:.55s}
.slide.active .gauges .g:nth-child(2) .bar i{animation-delay:.69s}
.slide.active .gauges .g:nth-child(3) .bar i{animation-delay:.83s}
.slide.active .gauges .g:nth-child(4) .bar i{animation-delay:.97s}
@keyframes rise{to{opacity:1;transform:none}}
@keyframes fill{from{width:0}to{width:var(--v)}}
/* 랩탑: 좌우 화살표를 좌측 하단 점(dots) 바로 오른쪽에 작은 투명 버튼으로 */
.arrows{position:absolute;bottom:37px;left:calc(var(--edge) + 110px);right:auto;display:flex;gap:7px;z-index:20}
.arrows button{width:27px;height:27px;border-radius:50%;border:1px solid rgba(241,231,233,.22);background:rgba(255,255,255,.04);color:#f1e7e9;cursor:pointer;transition:.25s;display:flex;align-items:center;justify-content:center;padding:0}
.arrows button:hover{background:rgba(255,255,255,.12);border-color:rgba(241,231,233,.5);color:#fff}
.arrows button svg{width:15px;height:15px;flex:0 0 auto}
.dots{position:absolute;bottom:46px;left:var(--edge);display:flex;gap:9px;z-index:20}
.dot{width:8px;height:8px;border-radius:50%;border:0;background:rgba(241,231,233,.28);cursor:pointer;transition:.3s;padding:0}
.dot.on{width:26px;border-radius:5px;background:var(--d-gold)}

/* 섹션 헤더 */
section.block{padding:58px 0;border-top:1px solid var(--line)}
section.block:first-of-type{border-top:none}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:30px}
.sec-head h2{font-family:var(--serif);font-weight:600;font-size:30px;letter-spacing:.01em;position:relative;display:inline-block}
.sec-head h2::after{content:"";position:absolute;left:0;bottom:-11px;width:0;height:2px;background:var(--wine);transition:width .85s .15s cubic-bezier(.2,.8,.2,1)}
.sec-head.reveal.in h2::after{width:44px}
.sec-head .note{font-size:12px;color:var(--muted);font-weight:300;letter-spacing:0;text-transform:none}
.sec-head a{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);transition:color .25s}
.sec-head a:hover{color:var(--wine)}

/* Browse 칩 */
.browse{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-size:13px;color:var(--text);background:var(--surface2);border:1px solid var(--line);padding:9px 17px;border-radius:999px;cursor:pointer;transition:.22s;white-space:nowrap}
.chip:hover{background:var(--wine);color:#fff;border-color:var(--wine);transform:translateY(-2px)}
.chip .k{color:var(--muted);font-size:10px;letter-spacing:.06em;text-transform:uppercase;margin-right:7px}

/* 카드 그리드 */
.grid{display:grid;gap:26px}
.grid.reviews{grid-template-columns:repeat(4,1fr)}
.grid.reads{grid-template-columns:repeat(3,1fr)}
.card{background:var(--surface);border:1px solid var(--line);border-radius:13px;overflow:hidden;cursor:pointer;transition:transform .3s,box-shadow .3s,border-color .3s;display:flex;flex-direction:column}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#dccfbb}
.card .thumb{height:260px;overflow:hidden;background:#ece4d6}
.grid.reviews .card .thumb{height:auto;aspect-ratio:3/4}
.card .thumb img{height:100%;width:100%;object-fit:cover;object-position:center;transition:transform .6s ease}
.card:hover .thumb img{transform:scale(1.06)}
.card .body{padding:18px 18px 20px}
.tag{display:inline-block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.card h3{font-family:var(--serif);font-weight:600;font-size:21px;line-height:1.18;margin-bottom:3px;transition:color .25s}
.card:hover h3{color:var(--wine)}
.card .ko{font-size:12.5px;color:var(--muted);margin-bottom:10px}
.snip{font-size:13px;color:#5a5048;line-height:1.6;margin-bottom:13px;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.meta{font-size:11px;letter-spacing:.04em;color:var(--muted)}
.lmeta{display:none}/* 모바일 목록형 행에서만 노출(지역·생산자·품종·별점) */
/* 카드 메타(랜딩식: 별점·생산자·지역품종) — 아카이브 카드 + 관련 캐러셀 카드 공용 */
.cardmeta{display:flex;flex-direction:column;gap:4px;margin-top:3px}
.cardmeta .cstars{font-size:12px;letter-spacing:1.5px;line-height:1;color:var(--gold)}
.cardmeta .cstars .e{color:var(--line)}
.cardmeta .cprod{font-size:12.5px;color:#5a5048;line-height:1.45}
.cardmeta .cinfo{font-size:12px;color:var(--muted);line-height:1.45}
.relcard .cardmeta .cstars{color:var(--d-gold)}
.relcard .cardmeta .cstars .e{color:var(--d-line)}
.relcard .cardmeta .cprod{color:var(--d-text)}
.relcard .cardmeta .cinfo{color:var(--d-muted)}
.thumb.ph-e{background:linear-gradient(150deg,#2a2420,#4a3f36)}
.thumb.ph-i{background:linear-gradient(150deg,#1f2a30,#3a5560)}
.more{text-align:center;margin-top:36px}
.more button{font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:none;border:1px solid var(--line);color:var(--text);padding:13px 34px;border-radius:999px;cursor:pointer;transition:.22s}
.more button:hover{border-color:var(--wine);color:var(--wine)}

/* reveal 지연(그리드) */
.grid.reads .card.reveal:nth-child(2){transition-delay:.09s}.grid.reads .card.reveal:nth-child(3){transition-delay:.18s}
.grid.reviews .card.reveal:nth-child(2){transition-delay:.07s}.grid.reviews .card.reveal:nth-child(3){transition-delay:.14s}.grid.reviews .card.reveal:nth-child(4){transition-delay:.21s}.grid.reviews .card.reveal:nth-child(6){transition-delay:.07s}.grid.reviews .card.reveal:nth-child(7){transition-delay:.14s}.grid.reviews .card.reveal:nth-child(8){transition-delay:.21s}

/* 랜딩 반응형 */
@media(max-width:860px){
  .slide-inner{grid-template-columns:1fr;min-height:0}
  .htext{padding:18px 24px 44px;order:2}.slide h1{font-size:34px}
  .himg{height:430px;order:1}
  .dots{left:24px;bottom:auto;top:392px}
  .arrows{left:auto;right:18px;bottom:auto;top:378px}
  .arrows button{width:42px;height:42px;border-color:rgba(241,231,233,.32);background:rgba(20,9,12,.32);backdrop-filter:blur(5px)}
  .arrows button svg{width:20px;height:20px}
  .grid.reviews{grid-template-columns:repeat(2,1fr)}.grid.reads{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:520px){
  .grid.reviews,.grid.reads{grid-template-columns:1fr}
  .slide h1{font-size:29px}.sec-head h2{font-size:24px}
  .wc-meta,.gauges{grid-template-columns:1fr}
  /* 히어로 카드: 게이지 아래 안쪽 여백 + 카드 아래 다크 히어로 여백 축소 */
  .winecard{padding-bottom:14px;margin-bottom:8px}
  .htext{padding-bottom:24px}
  /* 히어로 좌우 화살표: 화면 스크롤을 따라오게 고정 + 좌우 분리(히어로 보일 때만) */
  .arrows{display:contents}
  #prev,#next{position:fixed;top:50%;transform:translateY(-50%);z-index:40;width:60px;height:60px;background:none;border:0;backdrop-filter:none;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
  #prev svg,#next svg{width:52px;height:52px;opacity:.55}
  #prev{left:8px;right:auto}
  #next{right:8px;left:auto}
  body.hero-inview #prev,body.hero-inview #next{opacity:1;visibility:visible}
  /* 히어로: 모바일은 사진 가운데 화살표 표시 + 앰비언트 줌(ken) 유지(hover 없음) */
  .himg-go svg{display:block;width:80px;height:80px;opacity:.5}
  .himg .pic{animation:ken 26s ease-in-out infinite alternate;transition:none}
  /* 스펙 카드 아래 첫 구분선 간격 = 카드 좌우 여백(24px)과 동일 */
  article .specbox + .divider{margin-top:24px}
  /* Latest Reviews: 첫 글=큰 카드(작성자·날짜 유지), 2번째부터=가로 목록 행 */
  .grid.reviews{gap:0}
  .grid.reviews .card:first-child{margin-bottom:22px}
  .grid.reviews .card:first-child .meta{display:none}
  .grid.reviews .card:nth-child(n+2){flex-direction:row;align-items:stretch;gap:14px;background:none;border:0;border-top:1px solid var(--line);border-radius:0;overflow:visible;padding:17px 0}
  .grid.reviews .card:nth-child(n+2):hover{transform:none;box-shadow:none;border-color:var(--line)}
  .grid.reviews .card:nth-child(n+2) .thumb{order:2;flex:0 0 86px;width:86px;height:auto;align-self:stretch;min-height:86px;aspect-ratio:auto;border-radius:9px}
  .grid.reviews .card:nth-child(n+2) .body{order:1;flex:1;min-width:0;padding:1px 0 0;display:flex;flex-direction:column}
  /* 목록 행: 발췌·작성자·날짜·태그 숨기고 별점·생산자·지역·품종 노출 */
  .grid.reviews .card:nth-child(n+2) .tag,
  .grid.reviews .card:nth-child(n+2) .snip,
  .grid.reviews .card:nth-child(n+2) .meta{display:none}
  .grid.reviews .card:nth-child(n+2) h3{font-size:16.5px;line-height:1.25;margin-bottom:2px}
  .grid.reviews .card:nth-child(n+2) .ko{font-size:11.5px;margin-bottom:7px}
  .grid.reviews .card:nth-child(n+2) .lmeta{display:flex;flex-direction:column;gap:3px}
  .grid.reviews .card:nth-child(n+2) .lstars{color:var(--gold);font-size:12px;letter-spacing:1.5px;line-height:1}
  .grid.reviews .card:nth-child(n+2) .lstars .e{color:var(--line)}
  .grid.reviews .card:nth-child(n+2) .lprod{font-size:11.5px;color:#5a5048;line-height:1.45}
  .grid.reviews .card:nth-child(n+2) .linfo{font-size:11.5px;color:var(--muted);line-height:1.45}
}

@media(prefers-reduced-motion:reduce){.reveal,.slide .anim{transition:none!important;animation:none!important;opacity:1!important;transform:none!important}.himg .pic{animation:none}.slide.active .g .bar i,.slide .g .bar i{animation:none!important;width:var(--v)!important}.track{transition:none}}

/* ===================================================================
   아카이브(카테고리 목록)
   =================================================================== */
.arch-hero{background:var(--d-bg);color:var(--d-text);position:relative;overflow:hidden}
.arch-hero::after{content:"";position:absolute;right:-120px;top:-80px;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(198,101,118,.16),transparent 68%);pointer-events:none}
.arch-hero-inner{max-width:var(--maxw);margin:0 auto;padding:126px 24px 54px;position:relative;z-index:1}
.crumb{font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--d-muted);margin-bottom:22px;display:flex;gap:9px;flex-wrap:wrap;align-items:center}
.crumb a{color:var(--d-muted);transition:color .25s}
.crumb a:hover{color:var(--d-gold)}
.crumb .sep{opacity:.5}
.crumb .cur{color:var(--d-gold)}
.kicker{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--d-gold);font-weight:500;margin-bottom:16px}
.arch-hero h1{font-family:var(--serif);font-weight:600;font-size:clamp(40px,5.4vw,60px);line-height:1.02;letter-spacing:.05em;color:#fff;margin-bottom:24px}
.arch-stat{display:flex;gap:26px;flex-wrap:wrap;font-size:12.5px;letter-spacing:.04em;color:var(--d-text)}
.arch-stat .st{display:flex;align-items:baseline;gap:7px}
.arch-stat .st b{font-family:var(--serif);font-size:21px;font-weight:600;color:var(--d-gold)}
.arch-stat .st span{color:var(--d-muted);text-transform:uppercase;letter-spacing:.08em;font-size:11px}

.filterbar{position:sticky;top:70px;z-index:40;background:rgba(250,247,242,.93);backdrop-filter:blur(11px);border-bottom:1px solid var(--line)}
.admin-bar .filterbar{top:102px}
.filterbar-inner{max-width:var(--maxw);margin:0 auto;padding:15px 24px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.filters{display:flex;gap:9px;flex-wrap:wrap;align-items:center;min-width:0}
.filters .chip{font-size:13px;color:var(--text);background:var(--surface2);border:1px solid var(--line);padding:9px 16px;border-radius:999px;cursor:pointer;transition:.2s;white-space:nowrap;font-weight:300}
.filters .chip:hover{border-color:#cdbfa8;transform:translateY(-1px)}
.filters .chip.on{background:var(--wine);color:#fff;border-color:var(--wine)}
.filters .chip.on .k{color:rgba(255,255,255,.7)}
.filters .chip .k{color:var(--muted);font-size:10px;letter-spacing:.06em;text-transform:uppercase;margin-right:7px}
.fsep{width:1px;height:20px;background:var(--line);margin:0 4px;flex:0 0 auto}
.controls{display:flex;align-items:center;gap:16px;flex:0 0 auto}
.rescount{font-size:12.5px;color:var(--muted);letter-spacing:.02em;white-space:nowrap}
.rescount b{color:var(--text);font-weight:500}
.sortwrap{position:relative;display:flex;align-items:center;gap:7px;margin:0}
.sortwrap label{font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.sortwrap select{appearance:none;-webkit-appearance:none;font-family:var(--sans);font-weight:300;font-size:13px;color:var(--text);background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:9px 34px 9px 16px;cursor:pointer;transition:.2s}
.sortwrap select:hover{border-color:#cdbfa8}
.sortwrap::after{content:"▾";position:absolute;right:14px;font-size:10px;color:var(--muted);pointer-events:none}

.listing{padding:46px 0 20px}
.listing .grid{grid-template-columns:repeat(4,1fr);gap:24px}
.listing .card .thumb{height:auto;aspect-ratio:3/4}
.listing .card .body{display:flex;flex-direction:column;flex:1;padding:16px 16px 18px}
.listing .card h3{font-size:19px}
.listing .card .ko{font-size:12px}
.listing .snip{-webkit-line-clamp:2;font-size:12.5px}
.listing .card .meta{margin-top:auto;display:flex;align-items:center;gap:8px}
.listing .card .meta .vint{color:var(--text)}
.listing .card .meta .d{opacity:.55}
.listing .grid .card.reveal:nth-child(4n+2){transition-delay:.06s}
.listing .grid .card.reveal:nth-child(4n+3){transition-delay:.12s}
.listing .grid .card.reveal:nth-child(4n){transition-delay:.18s}
.empty{text-align:center;padding:70px 0;color:var(--muted);font-size:14px}

.pager{display:flex;justify-content:center;align-items:center;gap:7px;flex-wrap:wrap;margin:42px 0 8px}
.pager .page-numbers{min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border-radius:11px;border:1px solid var(--line);background:var(--surface);color:var(--text);font-size:13.5px;letter-spacing:.02em;transition:.2s;padding:0 8px}
.pager a.page-numbers:hover{border-color:var(--wine);color:var(--wine)}
.pager .page-numbers.current{background:var(--wine);color:#fff;border-color:var(--wine)}
.pager .page-numbers.dots{border:none;background:none;min-width:auto}

@media(max-width:980px){.listing .grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:860px){
  .filterbar-inner{flex-direction:column;align-items:stretch;gap:13px}
  .filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:4px;-webkit-overflow-scrolling:touch}
  .controls{justify-content:space-between}
  .admin-bar .filterbar{top:116px}
}
@media(max-width:680px){.listing .grid{grid-template-columns:repeat(2,1fr)}.arch-hero h1{font-size:36px}.arch-stat{gap:18px}}

/* ===================================================================
   단일 리뷰
   =================================================================== */
.rhero{position:relative;overflow:hidden;background:var(--d-bg)}
.rhero::before{content:"";position:absolute;inset:0;background:radial-gradient(130% 90% at 50% -12%, rgba(198,101,118,.13), transparent 56%);pointer-events:none}
.rhero-inner{position:relative;max-width:800px;margin:0 auto;padding:138px 24px 76px;text-align:center}
.admin-bar .rhero-inner{padding-top:170px}
.rhero .crumb{justify-content:center}
.rhero h1{font-family:var(--serif);font-weight:600;font-size:clamp(36px,4.6vw,54px);line-height:1.06;letter-spacing:.005em;color:#fff;margin:0 auto 12px;max-width:15em}
.rhero .ko{font-family:var(--serif-ko);font-size:19px;font-weight:500;color:var(--d-gold);margin-bottom:20px}
.stars{display:flex;align-items:center;gap:10px;justify-content:center}
.stars .s{color:var(--d-gold);font-size:18px;letter-spacing:2px}
.stars .s .e{color:rgba(203,169,108,.32)}
.stars .num{font-size:13px;color:var(--d-text);letter-spacing:.04em}
.stars .num b{color:#fff;font-weight:500}
.rhero .anim{opacity:0;transform:translateY(24px);animation:rise .9s cubic-bezier(.2,.7,.2,1) forwards}
.rhero .d1{animation-delay:.1s}.rhero .d2{animation-delay:.22s}.rhero .d3{animation-delay:.34s}

.article-wrap{max-width:1180px;margin:0 auto;padding:64px 24px 20px;display:grid;grid-template-columns:minmax(0,1fr) 300px;gap:64px;align-items:start}
article{min-width:0}
.byline{display:flex;align-items:center;gap:14px;padding-bottom:24px;margin-bottom:30px;border-bottom:1px solid var(--line);font-size:12.5px;color:var(--muted);letter-spacing:.02em}
.byline .av{width:34px;height:34px;border-radius:50%;background:linear-gradient(150deg,var(--wine),var(--gold));flex:0 0 auto;display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--serif);font-size:15px;font-weight:600}
.byline b{color:var(--text);font-weight:500}
.byline .dot{opacity:.5;margin:0 2px}
.specbox{margin:0 0 22px;padding:22px 26px;border:1px solid var(--line);border-radius:14px;background:var(--surface);box-shadow:var(--shadow)}
.specbox .wc-meta{display:grid;grid-template-columns:1fr 1fr;gap:15px 30px;margin-bottom:18px}
.specbox .wc-meta .l{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);display:block;margin-bottom:4px}
.specbox .wc-meta .v{font-size:13.5px;color:var(--text);line-height:1.4}
.specbox .gauges{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px}
.specbox .g{display:flex;align-items:center;gap:11px}
.specbox .g .gl{font-size:11px;letter-spacing:.04em;color:var(--muted);width:58px;flex:0 0 auto}
.specbox .g .bar{flex:1;height:5px;border-radius:3px;background:#e7e0d4;overflow:hidden}
.specbox .g .bar i{display:block;height:100%;border-radius:3px;background:linear-gradient(90deg,var(--gold),var(--wine));width:var(--v)}
.specbox .g .gv{font-size:11px;color:var(--muted);width:30px;flex:0 0 auto;text-align:right}
.summary{margin:0 0 18px;padding:22px 26px;background:var(--surface2);border:1px solid var(--line);border-radius:12px}
.summary .sl{font-size:11px;letter-spacing:.14em;color:var(--gold);margin-bottom:11px;font-weight:500}
.summary p{font-size:16px;line-height:1.9;color:#3a332d;margin:0}
.summary .wine-summary{margin:0!important;background:none!important;border:0!important;border-radius:0!important;padding:0!important;box-shadow:none!important}/* 외부 전역 .wine-summary 박스 무력화(이중 박스 방지) */
/* 본문에 콘텐츠로 박힌 카드 = 테마가 직접 그리는 스펙 카드(.specbox)·관련 캐러셀과 중복 → 숨김 */
article .lc-wine-card{display:none}
.summary .wine-summary p{font-size:16px;line-height:1.9;color:#3a332d;margin:0}
.summary .wine-summary p + p{margin-top:12px}
@media(max-width:520px){.summary{padding:18px 18px}.summary .wine-summary p{font-size:14.5px;line-height:1.82}}
.divider{display:flex;align-items:center;justify-content:center;gap:13px;margin:50px 0}
.divider span{width:5px;height:5px;border-radius:50%;background:var(--wine);opacity:.4}
article h2{font-family:var(--serif);font-weight:600;font-size:26px;line-height:1.22;letter-spacing:.01em;margin:30px 0 20px;scroll-margin-top:92px}
article p{font-size:16px;line-height:1.92;color:#3a332d;margin-bottom:18px}
article p strong{font-weight:500;color:var(--text)}
article figure{margin:45px 0 12px}
article figure img{width:100%;border-radius:13px;display:block;background:#ece4d6;height:auto}
article figure.wp-block-image{margin-top:45px;margin-bottom:45px}/* 캡션 아래 여백을 이미지 위 여백과 대칭으로 */
article figcaption{font-size:12px;color:var(--muted);margin-top:10px;letter-spacing:.01em;text-align:center;white-space:nowrap;overflow:hidden}
article figcaption a{color:var(--gold);text-decoration:underline;text-underline-offset:2px;transition:color .2s}
article figcaption a:hover{color:var(--wine)}
article .wp-block-separator{border:0;border-top:1px solid var(--line);max-width:120px;margin:46px auto;opacity:.7}
.tagrow{display:flex;align-items:flex-start;gap:14px;margin:46px 0 44px;padding-top:18px;border-top:1px solid var(--line)}
.tagrow .tags{flex:1 1 auto;display:flex;flex-wrap:wrap;gap:6px 12px;min-width:0}
.tagrow .pubdate{flex:0 0 auto;font-size:12px;color:var(--muted);letter-spacing:.04em;white-space:nowrap}
.tagrow .tg{font-size:12.5px;color:var(--muted);transition:color .2s}
.tagrow .tg:hover{color:var(--wine)}
.tagrow .tg .h{color:inherit;margin-right:1px}

aside{position:sticky;top:92px}
.admin-bar aside{top:124px}
.side-card{border:1px solid var(--line);border-radius:14px;background:var(--surface);padding:20px 20px;margin-bottom:20px}
.side-h{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.toc a{display:block;font-size:13px;color:var(--muted);padding:8px 0 8px 13px;border-left:2px solid var(--line);transition:.2s;line-height:1.4}
.toc a:hover{color:var(--text)}
.toc a.on{color:var(--wine);border-left-color:var(--wine);font-weight:500}
.ag-name{padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line)}
.ag-name .ag-en{font-family:var(--serif);font-weight:600;font-size:17px;line-height:1.2;color:var(--text);margin-bottom:5px}
.ag-name .ag-ko{font-size:12px;color:var(--muted);line-height:1.45}
.facts{display:flex;flex-direction:column;gap:12px}
.facts .f{display:flex;justify-content:space-between;align-items:flex-start;font-size:13px;gap:14px}
.facts .f .fl{color:var(--muted);letter-spacing:.02em;flex:0 0 auto}
.facts .f .fv{color:var(--text);text-align:right;line-height:1.45}
.facts .f .fv .star{color:var(--gold);letter-spacing:1px}
.facts .f .fv .star .e{color:#d8ccb8}
.side-pair{display:flex;flex-wrap:wrap;gap:7px}
.side-pair .sp{font-size:12px;color:var(--text);background:var(--surface2);border:1px solid var(--line);padding:6px 11px;border-radius:999px}
.side-ad{border:1px dashed var(--line);border-radius:12px;background:repeating-linear-gradient(45deg,#f7f2ea,#f7f2ea 11px,#f3eee6 11px,#f3eee6 22px);min-height:240px;display:flex;align-items:center;justify-content:center;color:#b6a892;font-size:10px;letter-spacing:.16em;text-transform:uppercase;text-align:center;margin-bottom:20px}
.share{display:flex;gap:9px}
.share button{flex:1;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);background:var(--surface2);border:1px solid var(--line);border-radius:9px;padding:10px 0;cursor:pointer;transition:.2s;font-family:var(--sans)}
.share button:hover{color:var(--wine);border-color:#dccfbb}

.related{background:var(--d-bg);border-top:1px solid var(--d-line)}
.related-inner{max-width:var(--maxw);margin:0 auto;padding:60px 24px 40px}
.related .sec-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:30px;gap:18px}
.related .sec-head h2{font-family:var(--serif);font-weight:600;font-size:28px;letter-spacing:.01em;color:#fff;display:block}
.related .sec-head h2::after{display:none}
.related .seclink{display:flex;align-items:center;gap:18px}
.related .seclink a{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--d-muted);transition:color .25s;white-space:nowrap}
.related .seclink a:hover{color:var(--d-gold)}
.relcar{position:relative;overflow:hidden}
/* 관련 캐러셀 화살표 = 히어로 좌우 화살표와 동일(원 없는 흐린 셰브론) */
.relarrow{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:40px;height:40px;border:0;background:none;color:#f1e7e9;cursor:pointer;transition:opacity .25s,color .22s;display:flex;align-items:center;justify-content:center;opacity:.55;padding:0}
.relarrow:hover{opacity:1;color:#fff}
.relarrow.prev{left:4px}
.relarrow.next{right:4px}
.relarrow:disabled{opacity:0;pointer-events:none}
.relarrow svg{width:30px;height:30px;flex:0 0 auto}
.reltrack{display:flex;gap:22px;transition:transform .55s cubic-bezier(.4,0,.2,1);touch-action:pan-y}
.relcard{flex:0 0 calc((100% - 66px)/4);background:var(--d-surface);border:1px solid var(--d-line);border-radius:13px;overflow:hidden;cursor:pointer;transition:transform .3s,border-color .3s}
.relcard:hover{transform:translateY(-6px);border-color:var(--d-wine)}
.relcard .thumb{aspect-ratio:3/4;overflow:hidden;background:#241016;height:auto}
.relcard .thumb img{height:100%;width:100%;object-fit:cover;object-position:center;transition:transform .6s ease}
.relcard:hover .thumb img{transform:scale(1.05)}
.relcard .cbody{padding:16px 16px 18px}
.relcard .tag{display:inline-block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--d-gold);margin-bottom:9px}
.relcard h3{font-family:var(--serif);font-weight:600;font-size:19px;line-height:1.18;margin-bottom:3px;color:#fff;transition:color .25s}
.relcard:hover h3{color:var(--d-wine)}
.relcard .cko{font-size:12px;color:var(--d-muted);margin-bottom:9px}
.relcard .snip{font-size:12.5px;color:var(--d-muted);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}

.closing-review{padding:18px 0 0;margin-top:0}
footer.wrap.footer-review{border-top:1px solid var(--d-line);padding:30px 24px 40px}

@media(max-width:1079px){.relcard{flex:0 0 calc((100% - 44px)/3)}}
@media(max-width:900px){
  .article-wrap{grid-template-columns:1fr;gap:0}
  aside{display:none}
  .rhero-inner{padding:104px 22px 56px}
}
@media(max-width:780px){.relcard{flex:0 0 calc((100% - 22px)/2)}}
@media(max-width:540px){
  .specbox .wc-meta,.specbox .gauges{grid-template-columns:1fr}
  .relcard{flex:0 0 80%}
  article h2{font-size:23px}
}
@media(prefers-reduced-motion:reduce){.rhero .anim{animation:none!important;opacity:1!important;transform:none!important}}

/* ===================================================================
   일반 페이지(About·Contact·Privacy)
   =================================================================== */
.page-wrap{padding:56px 24px 64px}
.page-body{max-width:800px;margin:0 auto}
.page-body > :first-child{margin-top:0}
article ul,article ol{margin:0 0 18px 1.25em;font-size:16px;line-height:1.9;color:#3a332d}
article li{margin-bottom:7px}
article a{color:var(--wine);text-decoration:underline;text-underline-offset:2px;transition:color .2s}
article a:hover{color:var(--wine-soft)}
